// stdafx.h : include file for standard system include files, // or project specific include files that are used frequently, but // are changed infrequently // #pragma once #define WIN32_LEAN_AND_MEAN // Exclude rarely-used stuff from Windows headers #include #include #include #include #include #include #include #include #include "resource.h" #include "version.h" #include "get_time.h" #include "lan.h" #include "mlan.h" #define PROTONAME "EM_LAN_PROTO" struct CMPlugin : public PLUGIN { CMPlugin() : PLUGIN(PROTONAME) { RegisterProtocol(PROTOTYPE_PROTOCOL); SetUniqueId("Nick"); } }; //#define VERBOSE #ifdef VERBOSE #include extern std::fstream emlanLog; #define EMLOG(x) emlanLog << "[" << __FUNCTION__ << "] [" << __FILE__ << ":" << __LINE__ << "] " << x << std::endl #define EMLOGIF(x, y) if (y) EMLOG(x) inline const char* showErrName(int err) { const char* name = "unknown"; switch (err) { case 0: name = "NOERROR"; break; case WSANOTINITIALISED: name = "WSANOTINITIALIZED"; break; case WSAENETDOWN: name = "WSAENETDOWN"; break; case WSAEACCES: name = "WSAEACCES"; break; case WSAEFAULT: name = "WSAEFAULT"; break; case WSAENOTCONN: name = "WSAENOTCONN"; break; case WSAEINTR: name = "WSAEINTR"; break; case WSAEINPROGRESS: name = "WSAEINPROGRESS"; break; case WSAENETRESET: name = "WSAENETRESET"; break; case WSAENOTSOCK: name = "WSAENOTSOCK"; break; case WSAEOPNOTSUPP: name = "WSAEOPNOTSUPP"; break; case WSAESHUTDOWN: name = "WSAESHUTDOWN"; break; case WSAEWOULDBLOCK: name = "WSAEWOULDBLOCK"; break; case WSAEMSGSIZE: name = "WSAEMSGSIZE"; break; case WSAEINVAL: name = "WSAEINVAL"; break; case WSAECONNABORTED: name = "WSAECONNABORTED"; break; case WSAETIMEDOUT: name = "WSAETIMEDOUT"; break; case WSAECONNRESET: name = "WSAECONNRESET"; break; case WSAENOBUFS: name = "WSAENOBUFS"; break; case WSAEHOSTUNREACH: name = "WSAEHOSTUNREACH"; break; } return name; } #define EMLOGERR() { int err = WSAGetLastError(); const char* name = showErrName(err); EMLOG( "Error: " << err << '(' << name << ')' ); } #define EMLOGERRIF(y) if (y) EMLOGERR() #else #define EMLOG(x) #define EMLOGIF(x, y) #define EMLOGERR() #define EMLOGERRIF() #endif