Fix compile under MingW
authorkwolekr <mirrorisim@gmail.com>
Wed, 23 Jan 2013 07:21:26 +0000 (02:21 -0500)
committerkwolekr <mirrorisim@gmail.com>
Wed, 23 Jan 2013 21:28:15 +0000 (16:28 -0500)
src/porting.h
src/util/string.cpp
src/util/string.h

index 184e1ab54e1ab393f317ea48154e2611cc3f3a74..c8d19154c9c341fde8b708d4939e7c8e71f82233 100644 (file)
@@ -42,18 +42,26 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 #ifdef _WIN32
        #include <windows.h>
        
-       #define ALIGNOF(x) __alignof(x)
        #define sleep_ms(x) Sleep(x)
+#else
+       #include <unistd.h>
+       #include <stdint.h> //for uintptr_t
+       
+       #define sleep_ms(x) usleep(x*1000)
+#endif
+
+#ifdef _MSC_VER
+       #define ALIGNOF(x) __alignof(x)
        #define strtok_r(x, y, z) strtok_s(x, y, z)
        #define strtof(x, y) (float)strtod(x, y)
        #define strtoll(x, y, z) _strtoi64(x, y, z)
        #define strtoull(x, y, z) _strtoui64(x, y, z)
 #else
-       #include <unistd.h>
-       #include <stdint.h> //for uintptr_t
-       
        #define ALIGNOF(x) __alignof__(x)
-       #define sleep_ms(x) usleep(x*1000)
+#endif
+
+#ifdef __MINGW32__
+       #define strtok_r(x, y, z) mystrtok_r(x, y, z)
 #endif
 
 #define PADDING(x, y) ((ALIGNOF(y) - ((uintptr_t)(x) & (ALIGNOF(y) - 1))) & (ALIGNOF(y) - 1))
index 215ac299d13cab211219cda3bfc55c1b772a58ca..481e74dad98fd6dd43c74dd08bb2dc1e95a42499 100644 (file)
@@ -47,3 +47,33 @@ size_t curl_write_data(char *ptr, size_t size, size_t nmemb, void *userdata) {
     stream->write(ptr, count);
     return count;
 }
+
+char *mystrtok_r(char *s, const char *sep, char **lasts) {
+       char *t;
+       int delim_reached;
+
+       if (!s)
+               s = *lasts;
+
+       while (*s && strchr(sep, *s))
+               s++;
+
+       if (!*s)
+               return NULL;
+
+       delim_reached = 0;
+       t = s;
+       while (*t) {
+               if (strchr(sep, *t)) {
+                       *t = '\0';
+                       delim_reached = 1;
+               } else if (delim_reached) {
+                       *lasts = t;
+                       return s;
+               }
+               t++;
+       }
+       
+       *lasts = t;
+       return s;
+}
index 58274c6773cd7a3807c52c7df7674e29734a81fc..d081b365b42fd837846dedfaa84208c28d32a6a5 100644 (file)
@@ -283,6 +283,7 @@ inline std::string wrap_rows(const std::string &from, u32 rowlen)
 
 std::string translatePassword(std::string playername, std::wstring password);
 size_t curl_write_data(char *ptr, size_t size, size_t nmemb, void *userdata);
+char *mystrtok_r(char *s, const char *sep, char **lasts);
 
 #endif