From c778d1258a3d778d0a6227b632ba5091a0eb25a0 Mon Sep 17 00:00:00 2001 From: w00t Date: Sat, 19 May 2007 16:01:06 +0000 Subject: Helps if I add the w32 specific code, too. :p git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@7044 e03df62e-2008-0410-955e-edbf42e46eb7 --- win/inspircd_win32wrapper.h | 162 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 162 insertions(+) create mode 100644 win/inspircd_win32wrapper.h (limited to 'win/inspircd_win32wrapper.h') diff --git a/win/inspircd_win32wrapper.h b/win/inspircd_win32wrapper.h new file mode 100644 index 000000000..a876b86ba --- /dev/null +++ b/win/inspircd_win32wrapper.h @@ -0,0 +1,162 @@ +/* +------------------------------------+ + * | Inspire Internet Relay Chat Daemon | + * +------------------------------------+ + * + * InspIRCd: (C) 2002-2007 InspIRCd Development Team + * See: http://www.inspircd.org/wiki/index.php/Credits + * + * This program is free but copyrighted software; see + * the file COPYING for details. + * + * --------------------------------------------------- + */ + +/* Windows Port + Wrapper Functions/Definitions + By Burlex */ + +#ifndef INSPIRCD_WIN32WRAPPER_H +#define INSPIRCD_WIN32WRAPPER_H + +/* 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 + +/* 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 + +/* 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 +#include +#include +#include +#include +#include +#include +#include +#include + +/* 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); } + +/* Convert formatted (xxx.xxx.xxx.xxx) string to in_addr struct */ +CoreExport int 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); + +/* 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); + +/* Unix-style sleep (argument is in seconds) */ +__inline void sleep(int seconds) { Sleep(seconds * 1000); } + +/* IPV4 only convert string to address struct */ +CoreExport int inet_aton(const char *, struct in_addr *); + +/* Unix-style get running user id */ +CoreExport int geteuid(); + +/* Handles colors in printf */ +CoreExport int printf_c(const char * format, ...); + +/* getopt() wrapper */ +# define no_argument 0 +# define required_argument 1 +# define optional_argument 2 +struct option +{ + char *name; + int has_arg; + int *flag; + int val; +}; +extern char optarg[514]; +int getopt_long_only (int ___argc, char *const *___argv, const char *__shortopts, const struct option *__longopts, int *__longind); + +/* Accept Handlers */ +int CoreExport __accept_socket(SOCKET s, sockaddr * addr, int * addrlen, void * acceptevent); +int CoreExport __getsockname(SOCKET s, sockaddr * name, int * namelen, void * acceptevent); + +/* Module Loading */ +#define dlopen(path, state) (void*)LoadLibrary(path) +#define dlsym(handle, export) (void*)GetProcAddress((HMODULE)handle, export) +#define dlclose(handle) FreeLibrary((HMODULE)handle) +const char * dlerror(); + +/* Unix-style directory searching functions */ +#define chmod(filename, mode) +struct dirent +{ + char d_name[MAX_PATH]; +}; + +struct DIR +{ + dirent dirent_pointer; + HANDLE find_handle; + WIN32_FIND_DATA find_data; + bool first; +}; + +CoreExport DIR * opendir(const char * path); +CoreExport dirent * readdir(DIR * handle); +CoreExport void closedir(DIR * handle); + +/* Disable these stupid warnings.. */ +#pragma warning(disable:4800) +#pragma warning(disable:4251) +#pragma warning(disable:4275) +#pragma warning(disable:4996) +#pragma warning(disable:4244) // warning C4244: '=' : conversion from 'long' to 'short', possible loss of data +#pragma warning(disable:4267) // warning C4267: 'argument' : conversion from 'size_t' to 'int', possible loss of data +#pragma warning(disable:4805) // warning C4805: '!=' : unsafe mix of type 'char' and type 'bool' in operation +#pragma warning(disable:4311) // warning C4311: 'type cast' : pointer truncation from 'accept_overlap *' to 'int' +#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 + +/* Mehhhh... typedefs. */ + +typedef unsigned char uint8_t; +typedef unsigned long long uint64_t; +typedef signed char int8_t; +typedef signed long int32_t; +typedef signed long long int64_t; + +void * ::operator new(size_t iSize); +void ::operator delete(void * ptr); + +/* IPC Handlers */ +class InspIRCd; + +void InitIPC(); +void CheckIPC(InspIRCd * Instance); +void CloseIPC(); + +#endif + -- cgit v1.2.3