We have to define ws_statb64 before declaring routines that use it.
authorguy <guy@f5534014-38df-0310-8fa8-9805f1628bb7>
Sun, 10 Apr 2011 23:51:34 +0000 (23:51 +0000)
committerguy <guy@f5534014-38df-0310-8fa8-9805f1628bb7>
Sun, 10 Apr 2011 23:51:34 +0000 (23:51 +0000)
git-svn-id: http://anonsvn.wireshark.org/wireshark/trunk@36550 f5534014-38df-0310-8fa8-9805f1628bb7

wsutil/file_util.h

index d0cbf9ee11ad4ac83165d02a54bc833123516c16..29b9343a8ec1096b0afe34fc6fdc5da0523193e3 100644 (file)
@@ -41,11 +41,20 @@ extern "C" {
 #endif
 
 
+#ifdef _WIN32
+
+/*
+ * The structure to pass to ws_stat64() and ws_fstat64().
+ */
+#define ws_statb64     struct _stat64
+
 /*  Win32: Since GLib2.6, we use UTF8 throughout the code, so file functions
  *  must tweak a given filename from UTF8 to UTF16 as we use NT Unicode (Win9x
  *  - now unsupported - used locale based encoding here).
  */
-#if defined _WIN32 && GLIB_CHECK_VERSION(2,6,0)
+#if GLIB_CHECK_VERSION(2,6,0)
+
+/* Win32, GLib 2.6 or later */
 #include <stdio.h>
 
 extern int ws_stdio_open (const gchar *filename, int flags, int mode);
@@ -54,6 +63,7 @@ extern int ws_stdio_mkdir (const gchar *filename, int mode);
 extern int ws_stdio_stat64 (const gchar *filename, ws_statb64 *buf);
 extern int ws_stdio_unlink (const gchar *filename);
 extern int ws_stdio_remove (const gchar *filename);
+
 extern FILE * ws_stdio_fopen (const gchar *filename, const gchar *mode);
 extern FILE * ws_stdio_freopen (const gchar *filename, const gchar *mode, FILE *stream);
 
@@ -66,34 +76,24 @@ extern FILE * ws_stdio_freopen (const gchar *filename, const gchar *mode, FILE *
 #define ws_fopen       ws_stdio_fopen
 #define ws_freopen     ws_stdio_freopen
 
-#else  /* _WIN32 && GLIB_CHECK_VERSION */
+#else /* GLIB_CHECK_VERSION(2,6,0) */
 
-/* "Not Windows" or GLib < 2.6: use "old school" functions */
-#ifdef _WIN32
-/* Windows, but GLib < 2.6 */
+/* Win32, GLib prior to 2.6 */
 #define ws_open                        _open
+#define ws_rename              rename
+#define ws_mkdir(dir,mode)     _mkdir(dir)     /* _mkdir() doesn't have a permission bits argument */
 #define ws_stat64              _stati64        /* use _stati64 for 64-bit size support */
 #define ws_unlink              _unlink
-#define ws_mkdir(dir,mode)     _mkdir(dir)
-#else /* _WIN32 */
-/* "Not Windows" */
-#define ws_open                        open
-#define ws_stat64              stat
-#define ws_unlink              unlink
-#define ws_mkdir(dir,mode)     mkdir(dir,mode)
-#endif /* _WIN32 */
-
-#define ws_rename      rename
-#define ws_remove      remove
-#define ws_fopen       fopen
-#define ws_freopen     freopen
+#define ws_remove              remove
+#define ws_fopen               fopen
+#define ws_freopen             freopen
 
-#endif /* _WIN32 && GLIB_CHECK_VERSION */
+#endif /* GLIB_CHECK_VERSION(2,6,0) */
 
-
-/* some common file function differences between UNIX and WIN32 */
-#ifdef _WIN32
-/* the Win32 API prepends underscores for whatever reasons */
+/*
+ * These routines don't take pathnames, so they're the same regardless
+ * of what version of GLib we have.
+ */
 #define ws_read    _read
 #define ws_write   _write
 #define ws_close   _close
@@ -101,11 +101,6 @@ extern FILE * ws_stdio_freopen (const gchar *filename, const gchar *mode, FILE *
 #define ws_fstat64 _fstati64   /* use _fstati64 for 64-bit size support */
 #define ws_lseek64 _lseeki64   /* use _lseeki64 for 64-bit offset support */
 
-/*
- * The structure to pass to ws_fstat64().
- */
-#define ws_statb64     struct _stat64
-
 /* DLL loading */
 
 /** Try to remove the current directory from the DLL search path.
@@ -137,7 +132,23 @@ GModule *ws_module_open(gchar *module_name, GModuleFlags flags);
  */
 extern char *getenv_utf8(const char *varname);
 
-#else /* _WIN32 */
+#else  /* _WIN32 */
+
+/*
+ * The structure to pass to ws_fstat64().
+ */
+#define ws_statb64     struct stat
+
+/* Not Windows, presumed to be UN*X-compatible */
+#define ws_open                        open
+#define ws_rename              rename
+#define ws_mkdir(dir,mode)     mkdir(dir,mode)
+#define ws_stat64              stat
+#define ws_unlink              unlink
+#define ws_remove              remove
+#define ws_fopen               fopen
+#define ws_freopen             freopen
+
 #define ws_read    read
 #define ws_write   write
 #define ws_close   close
@@ -146,10 +157,6 @@ extern char *getenv_utf8(const char *varname);
 #define ws_lseek64 lseek       /* AC_SYS_LARGEFILE should make off_t 64-bit */
 #define O_BINARY   0           /* Win32 needs the O_BINARY flag for open() */
 
-/*
- * The structure to pass to ws_fstat64().
- */
-#define ws_statb64     struct stat
 #endif /* _WIN32 */
 
 /* directory handling */