- * ---------------------------------------------------
- */\r
-\r
-/* Windows Port\r
- Wrapper Functions/Definitions\r
- By Burlex */\r
-\r
-#ifndef INSPIRCD_WIN32WRAPPER_H\r
-#define INSPIRCD_WIN32WRAPPER_H\r
-\r
-/* Define the WINDOWS macro. This means we're building on windows to the rest of the server.\r
- I think this is more reasonable than using WIN32, especially if we're gonna be doing 64-bit compiles */\r
-#define WINDOWS 1\r
-\r
-/* Macros for exporting symbols - dependant on what is being compiled */\r
-\r
-#ifdef DLL_BUILD\r
-#define CoreExport __declspec(dllimport)\r
-#define DllExport __declspec(dllexport)\r
-#else\r
-#define CoreExport __declspec(dllexport)\r
-#define DllExport __declspec(dllimport)\r
-#endif\r
-\r
-/* Say we're building on windows 2000. Anyone running something older than this\r
- * reeeeeeeally needs to upgrade! */\r
-\r
-#define _WIN32_WINNT 0x500\r
-\r
-/* Normal windows (platform-specific) includes */\r
-#include <winsock2.h>\r
-#include <windows.h>\r
-#include <ws2tcpip.h>\r
-#include <sys/types.h>\r
-#include <sys/stat.h>\r
-#include <direct.h>\r
-#include <process.h>\r
-#include <stdio.h>\r
-#include <algorithm>\r
-\r
-/* strcasecmp is not defined on windows by default */\r
-#define strcasecmp stricmp\r
-\r
-/* Error macros need to be redirected to winsock error codes */\r
-#define ETIMEDOUT WSAETIMEDOUT
-#define ECONNREFUSED WSAECONNREFUSED
-#define EADDRINUSE WSAEADDRINUSE
-#define EINPROGRESS WSAEWOULDBLOCK\r
-\r
-/* Remember file descriptors are treated differently on windows ;) */\r
-__inline int close(int socket) { return closesocket(socket); }\r
-\r
-/* Convert formatted (xxx.xxx.xxx.xxx) string to in_addr struct */\r
-CoreExport int inet_pton(int af, const char * src, void * dst);\r
-\r
-/* Convert struct to formatted (xxx.xxx.xxx.xxx) string */\r
-CoreExport const char * inet_ntop(int af, const void * src, char * dst, socklen_t cnt);\r
-\r
-/* Safe printf functions aren't defined in VC2003 */\r
-#define snprintf _snprintf\r
-#define vsnprintf _vsnprintf\r
-\r
-/* Recursive token function doesn't exist in VC++ */\r
-CoreExport char * strtok_r(char *_String, const char *_Control, char **_Context);\r
-\r
-/* Unix-style sleep (argument is in seconds) */\r
-__inline void sleep(int seconds) { Sleep(seconds * 1000); }\r
-\r
-/* IPV4 only convert string to address struct */\r
-CoreExport int inet_aton(const char *, struct in_addr *);\r
-\r
-/* Unix-style get running user id */\r
-CoreExport int geteuid();\r
-\r
-/* Handles colors in printf */\r
-CoreExport int printf_c(const char * format, ...);\r
-\r
-/* getopt() wrapper */\r
-# define no_argument 0
-# define required_argument 1
-# define optional_argument 2\r
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
+ * details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+
+/* Windows Port
+ Wrapper Functions/Definitions
+ By Burlex */
+
+#ifndef INSPIRCD_WIN32WRAPPER_H
+#define INSPIRCD_WIN32WRAPPER_H
+
+/*
+ * Starting with PSAPI version 2 for Windows 7 and Windows Server 2008 R2, this function is defined as K32GetProcessMemoryInfo in Psapi.h and exported
+ * in Kernel32.lib and Kernel32.dll. However, you should always call this function as GetProcessMemoryInfo. To ensure correct resolution of symbols
+ * for programs that will run on earlier versions of Windows, add Psapi.lib to the TARGETLIBS macro and compile the program with PSAPI_VERSION=1.
+ *
+ * We do this before anything to make sure it's done.
+ */
+#define PSAPI_VERSION 1
+
+#include "win32service.h"
+
+/* This defaults to 64, way too small for an ircd! */
+
+#define FD_SETSIZE 24000
+
+/* Make builds smaller, leaner and faster */
+#define VC_EXTRALEAN
+#define WIN32_LEAN_AND_MEAN
+
+/* They just have to be *different*, don't they. */
+#define PATH_MAX MAX_PATH
+
+/* Macros for exporting symbols - dependant on what is being compiled */
+
+#ifdef DLL_BUILD
+#define CoreExport __declspec(dllimport)
+#define DllExport __declspec(dllexport)
+#else
+#define CoreExport __declspec(dllexport)
+#define DllExport __declspec(dllimport)
+#endif
+
+/* Redirect main() through a different method in win32service.cpp, to intercept service startup */
+#define ENTRYPOINT CoreExport int smain(int argc, char** argv)
+
+/* Disable the deprecation warnings.. it spams :P */
+#define _CRT_SECURE_NO_DEPRECATE
+#define _WINSOCK_DEPRECATED_NO_WARNINGS
+
+/* Normal windows (platform-specific) includes */
+#include <winsock2.h>
+#pragma comment(lib, "Ws2_32.lib")
+#include <windows.h>
+#include <ws2tcpip.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <direct.h>
+#include <process.h>
+
+/* strcasecmp is not defined on windows by default */
+#define strcasecmp _stricmp
+#define strncasecmp _strnicmp
+
+typedef int ssize_t;
+
+/* Convert formatted (xxx.xxx.xxx.xxx) string to in_addr struct */
+CoreExport int insp_inet_pton(int af, const char * src, void * dst);
+
+/* Convert struct to formatted (xxx.xxx.xxx.xxx) string */
+CoreExport const char * insp_inet_ntop(int af, const void * src, char * dst, socklen_t cnt);
+
+/* inet_pton/ntop require at least NT 6.0 */
+#define inet_pton insp_inet_pton
+#define inet_ntop insp_inet_ntop
+
+/* Safe printf functions aren't defined in VC++ releases older than v14 */
+#if _MSC_VER <= 1800
+#define snprintf _snprintf
+#define vsnprintf _vsnprintf
+#endif
+
+/* Unix-style sleep (argument is in seconds) */
+__inline void sleep(int seconds) { Sleep(seconds * 1000); }
+
+/* _popen, _pclose */
+#define popen _popen
+#define pclose _pclose
+
+/* IPV4 only convert string to address struct */
+__inline int inet_aton(const char *cp, struct in_addr *addr)
+{
+ addr->s_addr = inet_addr(cp);
+ return (addr->s_addr == INADDR_NONE) ? 0 : 1;
+};
+
+/* getopt() wrapper */
+#define no_argument 0
+#define required_argument 1
+#define optional_argument 2