diff options
author | Christopher Faylor <me@cgf.cx> | 2001-04-11 19:09:53 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2001-04-11 19:09:53 +0000 |
commit | fc672fb26c42cc18eb0729236b221943d7bf25b3 (patch) | |
tree | bbce71fde4c40232124894c953cf25ff4b05a7f3 | |
parent | dd9752e88e985b1ec7ec4a2cb4f3b276f5d35abb (diff) | |
download | newlib-fc672fb26c42cc18eb0729236b221943d7bf25b3.zip newlib-fc672fb26c42cc18eb0729236b221943d7bf25b3.tar.gz newlib-fc672fb26c42cc18eb0729236b221943d7bf25b3.tar.bz2 |
* path.cc (struct symlink_info): Add extn and ext_tacked_on fields.
(path_conv::check): Only tack on extension if a known one didn't already exist.
(suffix_scan::has): Return pointer to known extension.
(symlink_info::check): Record location of extension, if any.
-rw-r--r-- | winsup/cygwin/ChangeLog | 8 | ||||
-rw-r--r-- | winsup/cygwin/path.cc | 24 |
2 files changed, 25 insertions, 7 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 6bed3b0..a68c2e7 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,11 @@ +Tue Apr 10 22:02:53 2001 Christopher Faylor <cgf@cygnus.com> + + * path.cc (struct symlink_info): Add extn and ext_tacked_on fields. + (path_conv::check): Only tack on extension if a known one didn't + already exist. + (suffix_scan::has): Return pointer to known extension. + (symlink_info::check): Record location of extension, if any. + 2001-04-09 Egor Duda <deo@logos-m.ru> * fhandler.h (class fhandler_socket): Add members and methods to diff --git a/winsup/cygwin/path.cc b/winsup/cygwin/path.cc index ec14ea8..9d2f63d 100644 --- a/winsup/cygwin/path.cc +++ b/winsup/cygwin/path.cc @@ -94,10 +94,12 @@ struct symlink_info { char buf[3 + MAX_PATH * 3]; char *ext_here; + int extn; char *contents; unsigned pflags; DWORD fileattr; int is_symlink; + bool ext_tacked_on; int error; symlink_info (): contents (buf + MAX_PATH + 1) {} int check (const char *path, const suffix_info *suffixes); @@ -377,10 +379,11 @@ path_conv::check (const char *src, unsigned opt, } fillin: - if (sym.ext_here && !(opt & PC_SYM_CONTENTS)) + if (sym.ext_here && *sym.ext_here && !(opt & PC_SYM_CONTENTS)) { - known_suffix = strchr (this->path, '\0'); - strcpy (known_suffix, sym.ext_here); + known_suffix = this->path + sym.extn; + if (sym.ext_tacked_on) + strcpy (known_suffix, sym.ext_here); } out: @@ -2467,8 +2470,11 @@ suffix_scan::has (const char *in_path, const suffix_info *in_suffixes) suffixes = suffixes_start = in_suffixes; char *ext_here = strrchr (in_path, '.'); + path = in_path; + eopath = strchr (path, '\0'); + if (!ext_here) - goto done; + goto noext; if (suffixes) { @@ -2489,10 +2495,11 @@ suffix_scan::has (const char *in_path, const suffix_info *in_suffixes) suffixes = NULL; } + noext: + ext_here = eopath; + done: - path = in_path; - eopath = strchr (path, '\0'); - return eopath; + return ext_here; } int @@ -2574,6 +2581,9 @@ symlink_info::check (const char *path, const suffix_info *suffixes) is_symlink = TRUE; ext_here = suffix.has (path, suffixes); + extn = ext_here - path; + + ext_tacked_on = !*ext_here; while (suffix.next ()) { |