OSDN Git Service

Simplify code used in is_absolute_path() macro; also add comment about
authorBruce Momjian <bruce@momjian.us>
Thu, 3 Feb 2011 15:46:31 +0000 (10:46 -0500)
committerBruce Momjian <bruce@momjian.us>
Thu, 3 Feb 2011 15:47:06 +0000 (10:47 -0500)
'E:abc' Win32 path handling.

src/include/port.h
src/port/path.c

index 4f0c0c1..2020a26 100644 (file)
@@ -68,17 +68,27 @@ extern void pgfnames_cleanup(char **filenames);
  *     By making this a macro we avoid needing to include path.c in libpq.
  */
 #ifndef WIN32
+#define IS_DIR_SEP(ch) ((ch) == '/')
+
 #define is_absolute_path(filename) \
 ( \
-       ((filename)[0] == '/') \
+       IS_DIR_SEP((filename)[0]) \
 )
 #else
+#define IS_DIR_SEP(ch) ((ch) == '/' || (ch) == '\\')
+
+/*
+ * On Win32, a drive letter _not_ followed by a slash, e.g. 'E:abc', is
+ * relative to the cwd on that drive, or the drive's root directory
+ * if that drive has no cwd.  Because the path itself cannot tell us
+ * which is the case, we have to assume the worst, i.e. that it is not
+ * absolute;  this check is done by IS_DIR_SEP(filename[2]).
+ */
 #define is_absolute_path(filename) \
 ( \
-       ((filename)[0] == '/') || \
-       (filename)[0] == '\\' || \
+       IS_DIR_SEP((filename)[0]) || \
        (isalpha((unsigned char) ((filename)[0])) && (filename)[1] == ':' && \
-       ((filename)[2] == '\\' || (filename)[2] == '/')) \
+        IS_DIR_SEP((filename)[2])) \
 )
 #endif
 
index ccf801e..5b0056d 100644 (file)
 
 
 #ifndef WIN32
-#define IS_DIR_SEP(ch) ((ch) == '/')
-#else
-#define IS_DIR_SEP(ch) ((ch) == '/' || (ch) == '\\')
-#endif
-
-#ifndef WIN32
 #define IS_PATH_VAR_SEP(ch) ((ch) == ':')
 #else
 #define IS_PATH_VAR_SEP(ch) ((ch) == ';')