X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=win%2Finspircd_win32wrapper.h;h=4bc364881dccb55386768e257e09186c17b44f18;hb=4354774fe57e579087f6ba121f5569a8cda52d09;hp=86382157e84be46d29fd401b12960ee85f3f73bb;hpb=1bdc61df779bbd74ca8641cde512dc0a1d8be4c0;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/win/inspircd_win32wrapper.h b/win/inspircd_win32wrapper.h index 86382157e..4bc364881 100644 --- a/win/inspircd_win32wrapper.h +++ b/win/inspircd_win32wrapper.h @@ -18,6 +18,10 @@ #ifndef INSPIRCD_WIN32WRAPPER_H #define INSPIRCD_WIN32WRAPPER_H +#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 @@ -55,6 +59,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 @@ -107,9 +114,6 @@ CoreExport const char * inet_ntop(int af, const void * src, char * dst, socklen_ /* Since when does the ISO C++ standard *remove* C functions?! */ #define mkdir(file,mode) _mkdir(file) -/* Recursive token function doesn't exist in VC++ */ -CoreExport char * strtok_r(char *_String, const char *_Control, char **_Context); - /* Unix-style sleep (argument is in seconds) */ __inline void sleep(int seconds) { Sleep(seconds * 1000); } @@ -196,22 +200,24 @@ class ValueItem; class ServerConfig; /* 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(InspIRCd* Instance); -DWORD WindowsForkStart(InspIRCd* Instance); +CoreExport void WindowsForkKillOwner(InspIRCd* Instance); -void WindowsForkKillOwner(InspIRCd* Instance); +CoreExport void ChangeWindowsSpecificPointers(InspIRCd* Instance); -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(); -bool initwmi(); -void donewmi(); -int getcpu(); +CoreExport void usleep(unsigned long usecs); #endif