From 5b9682275e384635a1fd9f7320cf4d9a604a43b4 Mon Sep 17 00:00:00 2001 From: ChrisTX Date: Fri, 12 Oct 2012 22:31:38 +0200 Subject: Windows: In-depth cleanup (see details) -Fix x64 builds for Windows. Now all configurations compile. -Remove the non-working rebase stuff. -Remove the Windows fork hack and instead use FreeConsole() to emulate the behavior. This directly allows us to compile with ASLR, which is turned on now. -Remove the old IPC mechanism for the removed GUI. This is not needed anymore as the GUI wasn't ever supported on anything newer than 1.2 -Remove the WIN32/WINDOWS macros. _WIN32 is supported on all x86-based VC++ targets, so that's what we need. -Enable optimizations for release builds. -De-duplicate printf_c(), it was previously copy-pasted into colors.h for configure -Add the VC++ specific bad files in .gitignore -Disable PID writing on Windows. This is only making sense for *nix builds. -Replace the CPU usage retrieval with an algorithm analogous to the *nix behavior. Also supports separated now/total values. (Tested with a dummy busy loop - seems working) -Removed certain unused functions and variables -Remove stdint defines from the windows wrapper -Remove CRT debug alloc. This is a bad idea as it would define a macro to replace free which breaks builds. -Re-evaluated the warnings list, commented it. -Moved inspircd_config/_version to include/ to match *nix -Removed the creation of inspircd_se_config, as it isn't used at all. -Made non-git builds show as "r0" instead of "r" (thanks to @SaberUK for pointing this out) -Fixed up m_spanningtree's project paths. Now all configurations (debug/release x86/x64) have been tested and build properly. -Moved FindDNS out of the wrapper and matched its log behavior with *nix. (It's pointless having it in the wrapper after the recent slimming down) -Replaced random/srandom wrappers with a mechanism that tries to use Windows' Random API first is no SSL module is loaded. -Removed more old junk from support for compilers older than VC++ 2010 (we don't have project files for these, so compiling them would be hard anyways) -Removed the unused ClearConsole() -Removed unused includes from the wrapper. Also, do not include psapi.h here if we don't link psapi.lib. This should be done where appropriate. -Made inet_aton an inline function for increased performance -C4800, performance warning about bool forcing, resolved at all occurrences. -C4701, uninitialized variable 'cached', resolved at all occurrences. -dlerror() was migrated out of the wrapper for more thread safety (no global buffer being shared) and increased performance. -Removed the wrong CRT debug flags. This drains a lot of performance. -Removed the clock_gettime/gettimeofday wrappers -Replaced all TCHAR/ANSI mix-ups of functions with the correct respective function. -Added a block of C4355 for < VS2012 -Update project files for c870714 --- win/inspircd.vcxproj | 94 ++++++++++++++++++++++++++-------------------------- 1 file changed, 47 insertions(+), 47 deletions(-) (limited to 'win/inspircd.vcxproj') diff --git a/win/inspircd.vcxproj b/win/inspircd.vcxproj index d6da89562..c4901cdf1 100644 --- a/win/inspircd.vcxproj +++ b/win/inspircd.vcxproj @@ -88,13 +88,13 @@ inspircd .exe false - ..\bin\debug_x64\bin\ - x64DebugVc80\ + ..\bin\debug_x64\ + x64Debug\ inspircd .exe false - ..\bin\release_x64\bin\ - x64ReleaseVc80\ + ..\bin\release_x64\ + x64Release\ inspircd .exe false @@ -106,8 +106,8 @@ Disabled - .;../include;../../include;../include/modes;../include/commands;../../include/modes;../../include/commands;../win;%(AdditionalIncludeDirectories) - WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) + ../include;../../include;../include/modes;../include/commands;../../include/modes;../../include/commands;../win;%(AdditionalIncludeDirectories) + _DEBUG;_CONSOLE;%(PreprocessorDefinitions) false EnableFastChecks MultiThreadedDebugDLL @@ -115,17 +115,17 @@ Level4 ProgramDatabase - 4100; 4512; 4127;%(DisableSpecificWarnings) + %(DisableSpecificWarnings) true - psapi.lib;ws2_32.lib;mswsock.lib;kernel32.lib;user32.lib;%(AdditionalDependencies) + %(AdditionalDependencies) LinkVerbose %(IgnoreSpecificDefaultLibraries) true $(OutDir)inspircd.pdb Console - false + true false @@ -149,10 +149,10 @@ nmake -f modules.mak /MP %(AdditionalOptions) - MinSpace + MaxSpeed true - .;../include;../../include;../include/modes;../include/commands;../../include/modes;../../include/commands;../win;%(AdditionalIncludeDirectories) - WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + ../include;../../include;../include/modes;../include/commands;../../include/modes;../../include/commands;../win;%(AdditionalIncludeDirectories) + NDEBUG;_CONSOLE;%(PreprocessorDefinitions) false MultiThreadedDLL @@ -160,16 +160,17 @@ nmake -f modules.mak Level3 + true - psapi.lib;ws2_32.lib;mswsock.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;%(AdditionalDependencies) + %(AdditionalDependencies) inspircd.ico;%(EmbedManagedResourceFile) true Console true true UseLinkTimeCodeGeneration - false + true MachineX86 @@ -187,69 +188,79 @@ nmake -f modules.mak - - + running configure... + "$(ProjectDir)\configure.exe" X64 Disabled - .;../include;../../include;../include/modes;../include/commands;../../include/modes;../../include/commands;../win;%(AdditionalIncludeDirectories) - WIN32;_DEBUG;_CONSOLE;WIN64;%(PreprocessorDefinitions) - true + ../include;../../include;../include/modes;../include/commands;../../include/modes;../../include/commands;../win;%(AdditionalIncludeDirectories) + _DEBUG;_CONSOLE;%(PreprocessorDefinitions) + false EnableFastChecks MultiThreadedDebug - Level3 + Level4 ProgramDatabase + true - ws2_32.lib;mswsock.lib;%(AdditionalDependencies) + %(AdditionalDependencies) NotSet %(IgnoreSpecificDefaultLibraries) true $(OutDir)inspircd.pdb Console - false + true false MachineX64 - - + @echo off +echo Compiling Command Modules... +cd ..\src\commands +nmake -f commands.mak +echo Compiling Modules... +cd ..\modules +nmake -f modules.mak + running configure... $(ProjectDir)\configure.exe - + X64 - Disabled - .;../include;../../include;../include/modes;../include/commands;../../include/modes;../../include/commands;../win;%(AdditionalIncludeDirectories) - WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) - true + MaxSpeed + ../include;../../include;../include/modes;../include/commands;../../include/modes;../../include/commands;../win;%(AdditionalIncludeDirectories) + NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + false MultiThreaded - Level3 + Level2 ProgramDatabase + true + true - ws2_32.lib;mswsock.lib;%(AdditionalDependencies) + %(AdditionalDependencies) true + inspircd.ico;%(EmbedManagedResourceFile) Console true true - false + true MachineX64 @@ -257,10 +268,10 @@ nmake -f modules.mak @echo off echo Compiling Command Modules... -cd ..\src +cd ..\src\commands nmake -f commands.mak echo Compiling Modules... -cd modules +cd ..\modules nmake -f modules.mak @@ -287,20 +298,12 @@ nmake -f modules.mak - - - - - - - - @@ -320,7 +323,6 @@ nmake -f modules.mak - @@ -368,9 +370,7 @@ nmake -f modules.mak - - - + @@ -389,4 +389,4 @@ nmake -f modules.mak - + \ No newline at end of file -- cgit v1.2.3