X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=win%2Finspircd_win32wrapper.h;h=1694691e91071d8798216d5387bb51618dfa1c59;hb=1bf7ca389426e196697eba9a8b60277db03fbedb;hp=8b418928d28be458e1441502ba9920e41a0e1ca9;hpb=f2da7dd588adb52148f0cd4779cde29b372cdc2e;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/win/inspircd_win32wrapper.h b/win/inspircd_win32wrapper.h index 8b418928d..1694691e9 100644 --- a/win/inspircd_win32wrapper.h +++ b/win/inspircd_win32wrapper.h @@ -1,9 +1,17 @@ /* * InspIRCd -- Internet Relay Chat Daemon * - * Copyright (C) 2007 Dennis Friis - * Copyright (C) 2007 Craig Edwards - * Copyright (C) 2007 Robin Burchell + * Copyright (C) 2020 Matt Schatz + * Copyright (C) 2013-2015 Attila Molnar + * Copyright (C) 2013, 2015, 2018-2019, 2021 Sadie Powell + * Copyright (C) 2012-2013 ChrisTX + * Copyright (C) 2012 Robby + * Copyright (C) 2011, 2014, 2019 Adam + * Copyright (C) 2009 Uli Schlachter + * Copyright (C) 2007-2009 Robin Burchell + * Copyright (C) 2007-2008 Craig Edwards + * Copyright (C) 2007, 2009 Dennis Friis + * Copyright (C) 2007 burlex * * This file is part of InspIRCd. InspIRCd is free software: you can * redistribute it and/or modify it under the terms of the GNU General Public @@ -43,7 +51,7 @@ #define VC_EXTRALEAN #define WIN32_LEAN_AND_MEAN -/* Macros for exporting symbols - dependant on what is being compiled */ +/* Macros for exporting symbols - dependent on what is being compiled */ #ifdef DLL_BUILD #define CoreExport __declspec(dllimport) @@ -60,6 +68,9 @@ #define _CRT_SECURE_NO_DEPRECATE #define _WINSOCK_DEPRECATED_NO_WARNINGS +// Windows doesn't support getopt_long so we use ya_getopt instead. +#include "ya_getopt.h" + /* Normal windows (platform-specific) includes */ #include #pragma comment(lib, "Ws2_32.lib") @@ -85,43 +96,14 @@ #define strcasecmp _stricmp #define strncasecmp _strnicmp -typedef int ssize_t; +typedef SSIZE_T ssize_t; /* _popen, _pclose */ #define popen _popen #define pclose _pclose - -/* 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 int optind; -extern char optarg[514]; -int getopt_long(int ___argc, char *const *___argv, const char *__shortopts, const struct option *__longopts, int *__longind); - -struct dirent -{ - char d_name[MAX_PATH]; -}; - -struct DIR -{ - dirent dirent_pointer; - HANDLE find_handle; - WIN32_FIND_DATAA find_data; - bool first; -}; - -CoreExport DIR * opendir(const char * path); -CoreExport dirent * readdir(DIR * handle); -CoreExport void closedir(DIR * handle); +#define getpid _getpid +#define dup _dup +#define fdopen _fdopen // warning: 'identifier' : class 'type' needs to have dll-interface to be used by clients of class 'type2' // Normally, this is a huge problem, but due to our new/delete remap, we can ignore it. @@ -153,6 +135,9 @@ CoreExport void closedir(DIR * handle); // warning C4706: assignment within conditional expression #pragma warning(disable:4706) +// warning C4800: 'type' : forcing value to bool 'true' or 'false' (performance warning) +#pragma warning(disable:4800) + /* Shared memory allocation functions */ void * ::operator new(size_t iSize); void ::operator delete(void * ptr); @@ -198,3 +183,11 @@ inline ssize_t writev(int fd, const WindowsIOVec* iov, int count) return sent; return -1; } + +// This wrapper is just so we don't need to do #ifdef _WIN32 everywhere in the socket code. It is +// not actually used and does not need to be the same size as sockaddr_un on UNIX systems. +struct sockaddr_un +{ + ADDRESS_FAMILY sun_family; + char sun_path[6]; +};