X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=win%2Finspircd_win32wrapper.h;h=6d03d05071502425358c85b64d5295577250eeee;hb=f94e4c9eeb00b19a5b8b0b6d90cd6395dda49952;hp=fb688237868dd94fc5352056a0d805afb355cc94;hpb=3abff3a37550cc1d88dd4d1fd7ed526e89309a53;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/win/inspircd_win32wrapper.h b/win/inspircd_win32wrapper.h index fb6882378..6d03d0507 100644 --- a/win/inspircd_win32wrapper.h +++ b/win/inspircd_win32wrapper.h @@ -24,6 +24,10 @@ /* Make builds smaller, leaner and faster */ #define VC_EXTRALEAN +#define WIN32_LEAN_AND_MEAN + +/* Not defined in windows */ +#define SIGHUP 1 /* They just have to be *different*, don't they. */ #define PATH_MAX MAX_PATH @@ -75,9 +79,6 @@ #define EADDRINUSE WSAEADDRINUSE #define EINPROGRESS WSAEWOULDBLOCK -/* Remember file descriptors are treated differently on windows ;) */ -__inline int close(int socket) { return closesocket(socket); } - /* Convert formatted (xxx.xxx.xxx.xxx) string to in_addr struct */ CoreExport int inet_pton(int af, const char * src, void * dst); @@ -117,12 +118,6 @@ struct option 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) @@ -148,6 +143,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) @@ -174,10 +171,19 @@ void ::operator delete(void * ptr); /* IPC Handlers */ class InspIRCd; +class ValueItem; +class ServerConfig; -void InitIPC(); -void CheckIPC(InspIRCd * Instance); -void CloseIPC(); +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(); @@ -185,5 +191,13 @@ std::string FindNameServerWin(); /* Clear a windows console */ void ClearConsole(); +DWORD WindowsForkStart(InspIRCd* Instance); + +void WindowsForkKillOwner(InspIRCd* Instance); + +void ChangeWindowsSpecificPointers(InspIRCd* Instance); + +bool ValidateWindowsDnsServer(ServerConfig* conf, const char* tag, const char* value, ValueItem &data); + #endif