]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - win/inspircd_win32wrapper.h
Remove InspIRCd* parameters and fields
[user/henk/code/inspircd.git] / win / inspircd_win32wrapper.h
index ffda9ff406061086ab352023ce7c598f8a6d5f43..a1eba11e9714b0cf2b5449f9a727199f8543eaef 100644 (file)
@@ -2,8 +2,8 @@
  *       | Inspire Internet Relay Chat Daemon |
  *       +------------------------------------+
  *
- *  InspIRCd: (C) 2002-2007 InspIRCd Development Team
- * See: http://www.inspircd.org/wiki/index.php/Credits
+ *  InspIRCd: (C) 2002-2009 InspIRCd Development Team
+ * See: http://wiki.inspircd.org/Credits
  *
  * This program is free but copyrighted software; see
  *            the file COPYING for details.
 #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 ofWindows, 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
+
+#ifndef CONFIGURE_BUILD
+#include "win32service.h"
+#endif
+
 /* Define the WINDOWS macro. This means we're building on windows to the rest of the server.
    I think this is more reasonable than using WIN32, especially if we're gonna be doing 64-bit compiles */
 #define WINDOWS 1
+#define ENABLE_CRASHDUMPS 0
+
+/* This defaults to 64, way too small for an ircd! */
+/* CRT memory debugging */
+#ifdef DEBUG
+#define _CRTDBG_MAP_ALLOC
+#include <stdlib.h>
+#include <crtdbg.h>
+#endif
+
+#define FD_SETSIZE 24000
+
+typedef unsigned __int16 uint16_t;
+typedef unsigned __int32 uint32_t;
 
 /* Make builds smaller, leaner and faster */
 #define VC_EXTRALEAN
@@ -29,6 +56,9 @@
 /* Not defined in windows */
 #define SIGHUP 1
 
+/* Not defined in windows, parameter to shutdown() */
+#define SHUT_WR 2
+
 /* They just have to be *different*, don't they. */
 #define PATH_MAX MAX_PATH
 
@@ -48,6 +78,9 @@
 #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 _SCL_SECURE_NO_DEPRECATE
@@ -57,8 +90,6 @@
 /* Say we're building on windows 2000. Anyone running something older than this
  * reeeeeeeally needs to upgrade! */
 
-#define _WIN32_WINNT 0x500
-
 /* Normal windows (platform-specific) includes */
 #include <winsock2.h>
 #include <windows.h>
 #include <stdio.h>
 #include <algorithm>
 
+#ifdef ENABLE_CRASHDUMPS
+#include <DbgHelp.h>
+#endif
+
 /* strcasecmp is not defined on windows by default */
 #define strcasecmp _stricmp
 
-/* Error macros need to be redirected to winsock error codes */
-#define ETIMEDOUT WSAETIMEDOUT
-#define ECONNREFUSED WSAECONNREFUSED
-#define EADDRINUSE WSAEADDRINUSE
-#define EINPROGRESS WSAEWOULDBLOCK
-
-/* Remember file descriptors are treated differently on windows ;) */
-__inline int close(int socket) { return closesocket(socket); }
+/* this standard function is nonstarard. go figure. */
+#define popen _popen
+#define pclose _pclose
+
+/* Error macros need to be redirected to winsock error codes, apart from on VS2010 *SIGH* */
+#if _MSC_VER < 1600
+       #define ETIMEDOUT WSAETIMEDOUT
+       #define ECONNREFUSED WSAECONNREFUSED
+       #define EADDRINUSE WSAEADDRINUSE
+       #define EINPROGRESS WSAEWOULDBLOCK
+       #define EADDRNOTAVAIL WSAEADDRNOTAVAIL
+#endif
 
 /* Convert formatted (xxx.xxx.xxx.xxx) string to in_addr struct */
-CoreExport int inet_pton(int af, const char * src, void * dst);
+CoreExport int insp_inet_pton(int af, const char * src, void * dst);
 
 /* Convert struct to formatted (xxx.xxx.xxx.xxx) string */
-CoreExport const char * inet_ntop(int af, const void * src, char * dst, socklen_t cnt);
+CoreExport const char * insp_inet_ntop(int af, const void * src, char * dst, socklen_t cnt);
+
+/* we don't want to use windows' broken inet_pton and ntop */
+#define inet_pton insp_inet_pton
+#define inet_ntop insp_inet_ntop
 
 /* Safe printf functions aren't defined in VC2003 */
 #define snprintf _snprintf
 #define vsnprintf _vsnprintf
 
-/* Recursive token function doesn't exist in VC++ */
-CoreExport char * strtok_r(char *_String, const char *_Control, char **_Context);
+/* Since when does the ISO C++ standard *remove* C functions?! */
+#define mkdir(file,mode) _mkdir(file)
 
 /* Unix-style sleep (argument is in seconds) */
 __inline void sleep(int seconds) { Sleep(seconds * 1000); }
@@ -118,15 +161,10 @@ struct option
        int *flag;
        int val;
 };
+extern int optind;
 extern char optarg[514];
 int getopt_long_only (int ___argc, char *const *___argv, const char *__shortopts, const struct option *__longopts, int *__longind);
 
-/* Accept Handlers */
-struct udp_overlap;
-CoreExport int __accept_socket(SOCKET s, sockaddr * addr, int * addrlen, void * acceptevent);
-CoreExport int __getsockname(SOCKET s, sockaddr * name, int * namelen, void * acceptevent);
-CoreExport int __recvfrom(SOCKET s, char * buf, int len, int flags, struct sockaddr * from, int * fromlen, udp_overlap * ov);
-
 /* Module Loading */
 #define dlopen(path, state) (void*)LoadLibrary(path)
 #define dlsym(handle, export) (void*)GetProcAddress((HMODULE)handle, export)
@@ -135,6 +173,7 @@ const char * dlerror();
 
 /* Unix-style directory searching functions */
 #define chmod(filename, mode)  
+
 struct dirent
 {
        char d_name[MAX_PATH];
@@ -152,6 +191,8 @@ CoreExport DIR * opendir(const char * path);
 CoreExport dirent * readdir(DIR * handle);
 CoreExport void closedir(DIR * handle);
 
+CoreExport int gettimeofday(struct timeval * tv, void * tz);
+
 /* Disable these stupid warnings.. */
 #pragma warning(disable:4800)
 #pragma warning(disable:4251)
@@ -163,6 +204,8 @@ CoreExport void closedir(DIR * handle);
 #pragma warning(disable:4312)          // warning C4312: 'type cast' : conversion from 'int' to 'HANDLE' of greater size
 #pragma warning(disable:4355)          // warning C4355: 'this' : used in base member initializer list
 #pragma warning(disable:4996)          // warning C4996: 'std::_Traits_helper::move_s' was declared deprecated
+#pragma warning(disable:4706)          // warning C4706: assignment within conditional expression
+#pragma warning(disable:4201)          // mmsystem.h generates this warning
 
 /* Mehhhh... typedefs. */
 
@@ -177,34 +220,26 @@ void * ::operator new(size_t iSize);
 void ::operator delete(void * ptr);
 
 /* IPC Handlers */
-class InspIRCd;
 class ValueItem;
 class ServerConfig;
 
-class IPC
-{
- private:
-       InspIRCd* Instance;
-       HANDLE hIPCPipe;
- public:
-       IPC(InspIRCd* Srv);
-       void Check();
-       ~IPC();
-};
-
 /* Look up the nameserver in use from the registry on windows */
-std::string FindNameServerWin();
+CoreExport std::string FindNameServerWin();
 
 /* Clear a windows console */
-void ClearConsole();
+CoreExport void ClearConsole();
+
+CoreExport DWORD WindowsForkStart();
 
-DWORD WindowsForkStart(InspIRCd* Instance);
+CoreExport void WindowsForkKillOwner();
 
-void WindowsForkKillOwner(InspIRCd* Instance);
+CoreExport void ChangeWindowsSpecificPointers();
 
-void ChangeWindowsSpecificPointers(InspIRCd* Instance);
+CoreExport bool ValidateWindowsDnsServer(ServerConfig* conf, const char* tag, const char* value, ValueItem &data);
 
-bool ValidateWindowsDnsServer(ServerConfig* conf, const char* tag, const char* value, ValueItem &data);
+CoreExport bool initwmi();
+CoreExport void donewmi();
+CoreExport int getcpu();
 
 #endif