diff --git a/src/win32/CMakeLists.txt b/src/win32/CMakeLists.txt
deleted file mode 100644
index 39b01588b28c622a65f40ea63f9b2e541df220ec..0000000000000000000000000000000000000000
--- a/src/win32/CMakeLists.txt
+++ /dev/null
@@ -1,18 +0,0 @@
-file(GLOB SRB2_WIN_SOURCES *.c *.h *.rc)
-
-if(${SRB2_CONFIG_HWRENDER})
-	set(SRB2_WIN_SOURCES ${SRB2_WIN_SOURCES} ${SRB2_HWRENDER_SOURCES} ${SRB2_HWRENDER_HEADERS})
-	set(SRB2_WIN_SOURCES ${SRB2_WIN_SOURCES} ${SRB2_R_OPENGL_SOURCES} ${SRB2_R_OPENGL_HEADERS})
-endif()
-
-add_executable(SRB2DD EXCLUDE_FROM_ALL WIN32
-	${SRB2_WIN_SOURCES}
-)
-
-target_compile_definitions(SRB2DD PRIVATE
-	-D_WINDOWS
-)
-
-set_target_properties(SRB2DD PROPERTIES OUTPUT_NAME ${SRB2_WIN_EXE_NAME})
-
-target_link_libraries(SRB2DD PRIVATE SRB2Core)
diff --git a/src/win32/Srb2win-vc10.vcxproj b/src/win32/Srb2win-vc10.vcxproj
deleted file mode 100644
index 3e8af3b0ed866b9039879abbc4b4e28b1d623ba4..0000000000000000000000000000000000000000
--- a/src/win32/Srb2win-vc10.vcxproj
+++ /dev/null
@@ -1,517 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project DefaultTargets="Build" ToolsVersion="14.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
-  <ItemGroup Label="ProjectConfigurations">
-    <ProjectConfiguration Include="Debug|ARM">
-      <Configuration>Debug</Configuration>
-      <Platform>ARM</Platform>
-    </ProjectConfiguration>
-    <ProjectConfiguration Include="Debug|ARM64">
-      <Configuration>Debug</Configuration>
-      <Platform>ARM64</Platform>
-    </ProjectConfiguration>
-    <ProjectConfiguration Include="Debug|Win32">
-      <Configuration>Debug</Configuration>
-      <Platform>Win32</Platform>
-    </ProjectConfiguration>
-    <ProjectConfiguration Include="Release|ARM">
-      <Configuration>Release</Configuration>
-      <Platform>ARM</Platform>
-    </ProjectConfiguration>
-    <ProjectConfiguration Include="Release|ARM64">
-      <Configuration>Release</Configuration>
-      <Platform>ARM64</Platform>
-    </ProjectConfiguration>
-    <ProjectConfiguration Include="Release|Win32">
-      <Configuration>Release</Configuration>
-      <Platform>Win32</Platform>
-    </ProjectConfiguration>
-    <ProjectConfiguration Include="Debug|x64">
-      <Configuration>Debug</Configuration>
-      <Platform>x64</Platform>
-    </ProjectConfiguration>
-    <ProjectConfiguration Include="Release|x64">
-      <Configuration>Release</Configuration>
-      <Platform>x64</Platform>
-    </ProjectConfiguration>
-  </ItemGroup>
-  <PropertyGroup Label="Globals">
-    <ProjectName>Srb2DD</ProjectName>
-    <ProjectGuid>{0F554F1D-ED49-4D65-A9A7-F63C57F277BE}</ProjectGuid>
-    <Keyword>Win32Proj</Keyword>
-    <RootNamespace>Srb2win</RootNamespace>
-    <WindowsTargetPlatformVersion>10.0.17763.0</WindowsTargetPlatformVersion>
-  </PropertyGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
-  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
-    <PlatformToolset>v140</PlatformToolset>
-    <UseDebugLibraries>true</UseDebugLibraries>
-  </PropertyGroup>
-  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM'" Label="Configuration">
-    <UseDebugLibraries>true</UseDebugLibraries>
-    <WindowsSDKDesktopARMSupport>true</WindowsSDKDesktopARMSupport>
-    <PlatformToolset>v141</PlatformToolset>
-  </PropertyGroup>
-  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
-    <PlatformToolset>v140</PlatformToolset>
-    <UseDebugLibraries>false</UseDebugLibraries>
-    <WholeProgramOptimization>true</WholeProgramOptimization>
-  </PropertyGroup>
-  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|ARM'" Label="Configuration">
-    <UseDebugLibraries>false</UseDebugLibraries>
-    <WholeProgramOptimization>true</WholeProgramOptimization>
-    <WindowsSDKDesktopARMSupport>true</WindowsSDKDesktopARMSupport>
-    <PlatformToolset>v141</PlatformToolset>
-  </PropertyGroup>
-  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration">
-    <PlatformToolset>v140</PlatformToolset>
-    <UseDebugLibraries>true</UseDebugLibraries>
-  </PropertyGroup>
-  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM64'" Label="Configuration">
-    <UseDebugLibraries>true</UseDebugLibraries>
-    <WindowsSDKDesktopARM64Support>true</WindowsSDKDesktopARM64Support>
-    <PlatformToolset>v141</PlatformToolset>
-  </PropertyGroup>
-  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
-    <PlatformToolset>v140</PlatformToolset>
-    <UseDebugLibraries>false</UseDebugLibraries>
-    <WholeProgramOptimization>true</WholeProgramOptimization>
-  </PropertyGroup>
-  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|ARM64'" Label="Configuration">
-    <UseDebugLibraries>false</UseDebugLibraries>
-    <WholeProgramOptimization>true</WholeProgramOptimization>
-    <WindowsSDKDesktopARM64Support>true</WindowsSDKDesktopARM64Support>
-    <PlatformToolset>v141</PlatformToolset>
-  </PropertyGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
-  <ImportGroup Label="ExtensionSettings">
-  </ImportGroup>
-  <ImportGroup Label="Shared">
-    <Import Project="..\..\SRB2_common.props" />
-    <Import Project="..\..\comptime.props" />
-    <Import Project="..\..\libs\FMOD.props" />
-    <Import Project="..\..\libs\zlib.props" />
-    <Import Project="..\..\libs\libpng.props" />
-    <Import Project="..\..\libs\libgme.props" />
-    <Import Project="SRB2Win.props" />
-  </ImportGroup>
-  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
-    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
-    <Import Project="..\..\SRB2_Debug.props" />
-  </ImportGroup>
-  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM'" Label="PropertySheets">
-    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
-    <Import Project="..\..\SRB2_Debug.props" />
-  </ImportGroup>
-  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
-    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
-    <Import Project="..\..\SRB2_Release.props" />
-  </ImportGroup>
-  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|ARM'" Label="PropertySheets">
-    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
-    <Import Project="..\..\SRB2_Release.props" />
-  </ImportGroup>
-  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
-    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
-    <Import Project="..\..\SRB2_Debug.props" />
-  </ImportGroup>
-  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM64'" Label="PropertySheets">
-    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
-    <Import Project="..\..\SRB2_Debug.props" />
-  </ImportGroup>
-  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
-    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
-    <Import Project="..\..\SRB2_Release.props" />
-  </ImportGroup>
-  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|ARM64'" Label="PropertySheets">
-    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
-    <Import Project="..\..\SRB2_Release.props" />
-  </ImportGroup>
-  <PropertyGroup Label="UserMacros" />
-  <PropertyGroup>
-    <_ProjectFileVersion>10.0.30319.1</_ProjectFileVersion>
-    <RunCodeAnalysis>false</RunCodeAnalysis>
-  </PropertyGroup>
-  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM64'">
-    <Link>
-      <RandomizedBaseAddress>true</RandomizedBaseAddress>
-      <AdditionalDependencies>gdi32.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-    <ClCompile>
-      <DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
-      <MinimalRebuild>false</MinimalRebuild>
-    </ClCompile>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|ARM64'">
-    <Link>
-      <RandomizedBaseAddress>true</RandomizedBaseAddress>
-      <AdditionalDependencies>gdi32.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM'">
-    <ClCompile>
-      <DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
-      <MinimalRebuild>false</MinimalRebuild>
-    </ClCompile>
-    <Link>
-      <AdditionalDependencies>gdi32.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|ARM'">
-    <Link>
-      <AdditionalDependencies>gdi32.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
-    <Link>
-      <AdditionalDependencies>gdi32.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
-    <Link>
-      <AdditionalDependencies>gdi32.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
-    <Link>
-      <AdditionalDependencies>gdi32.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
-    <Link>
-      <AdditionalDependencies>gdi32.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-  </ItemDefinitionGroup>
-  <ItemGroup>
-    <ClCompile Include="..\am_map.c" />
-    <ClCompile Include="..\apng.c" />
-    <ClCompile Include="..\blua\lapi.c" />
-    <ClCompile Include="..\blua\lauxlib.c" />
-    <ClCompile Include="..\blua\lbaselib.c" />
-    <ClCompile Include="..\blua\lcode.c" />
-    <ClCompile Include="..\blua\ldebug.c" />
-    <ClCompile Include="..\blua\ldo.c" />
-    <ClCompile Include="..\blua\ldump.c" />
-    <ClCompile Include="..\blua\lfunc.c" />
-    <ClCompile Include="..\blua\lgc.c" />
-    <ClCompile Include="..\blua\linit.c" />
-    <ClCompile Include="..\blua\llex.c" />
-    <ClCompile Include="..\blua\lmem.c" />
-    <ClCompile Include="..\blua\lobject.c" />
-    <ClCompile Include="..\blua\lopcodes.c" />
-    <ClCompile Include="..\blua\lparser.c" />
-    <ClCompile Include="..\blua\lstate.c" />
-    <ClCompile Include="..\blua\lstring.c" />
-    <ClCompile Include="..\blua\lstrlib.c" />
-    <ClCompile Include="..\blua\ltable.c" />
-    <ClCompile Include="..\blua\ltablib.c" />
-    <ClCompile Include="..\blua\ltm.c" />
-    <ClCompile Include="..\blua\lundump.c" />
-    <ClCompile Include="..\blua\lvm.c" />
-    <ClCompile Include="..\blua\lzio.c" />
-    <ClCompile Include="..\b_bot.c" />
-    <ClCompile Include="..\command.c" />
-    <ClCompile Include="..\comptime.c" />
-    <ClCompile Include="..\console.c" />
-    <ClCompile Include="..\dehacked.c" />
-    <ClCompile Include="..\d_clisrv.c" />
-    <ClCompile Include="..\d_main.c" />
-    <ClCompile Include="..\d_net.c" />
-    <ClCompile Include="..\d_netcmd.c" />
-    <ClCompile Include="..\d_netfil.c" />
-    <ClCompile Include="..\filesrch.c" />
-    <ClCompile Include="..\f_finale.c" />
-    <ClCompile Include="..\f_wipe.c" />
-    <ClCompile Include="..\g_game.c" />
-    <ClCompile Include="..\g_input.c" />
-    <ClCompile Include="..\hardware\hw3sound.c" />
-    <ClCompile Include="..\hardware\hw_bsp.c" />
-    <ClCompile Include="..\hardware\hw_cache.c" />
-    <ClCompile Include="..\hardware\hw_clip.c" />
-    <ClCompile Include="..\hardware\hw_draw.c" />
-    <ClCompile Include="..\hardware\hw_light.c" />
-    <ClCompile Include="..\hardware\hw_main.c" />
-    <ClCompile Include="..\hardware\hw_md2.c" />
-    <ClCompile Include="..\hardware\hw_md2load.c" />
-    <ClCompile Include="..\hardware\hw_md3load.c" />
-    <ClCompile Include="..\hardware\hw_model.c" />
-    <ClCompile Include="..\hardware\u_list.c" />
-    <ClCompile Include="..\hu_stuff.c" />
-    <ClCompile Include="..\info.c" />
-    <ClCompile Include="..\i_addrinfo.c">
-      <ExcludedFromBuild>true</ExcludedFromBuild>
-    </ClCompile>
-    <ClCompile Include="..\i_tcp.c" />
-    <ClCompile Include="..\lua_baselib.c" />
-    <ClCompile Include="..\lua_blockmaplib.c" />
-    <ClCompile Include="..\lua_consolelib.c" />
-    <ClCompile Include="..\lua_hooklib.c" />
-    <ClCompile Include="..\lua_hudlib.c" />
-    <ClCompile Include="..\lua_infolib.c" />
-    <ClCompile Include="..\lua_maplib.c" />
-    <ClCompile Include="..\lua_mathlib.c" />
-    <ClCompile Include="..\lua_mobjlib.c" />
-    <ClCompile Include="..\lua_playerlib.c" />
-    <ClCompile Include="..\lua_script.c" />
-    <ClCompile Include="..\lua_skinlib.c" />
-    <ClCompile Include="..\lua_thinkerlib.c" />
-    <ClCompile Include="..\lzf.c" />
-    <ClCompile Include="..\md5.c" />
-    <ClCompile Include="..\mserv.c" />
-    <ClCompile Include="..\m_aatree.c" />
-    <ClCompile Include="..\m_anigif.c" />
-    <ClCompile Include="..\m_argv.c" />
-    <ClCompile Include="..\m_bbox.c" />
-    <ClCompile Include="..\m_cheat.c" />
-    <ClCompile Include="..\m_cond.c" />
-    <ClCompile Include="..\m_fixed.c" />
-    <ClCompile Include="..\m_menu.c" />
-    <ClCompile Include="..\m_misc.c" />
-    <ClCompile Include="..\m_queue.c" />
-    <ClCompile Include="..\m_random.c" />
-    <ClCompile Include="..\p_ceilng.c" />
-    <ClCompile Include="..\p_enemy.c" />
-    <ClCompile Include="..\p_floor.c" />
-    <ClCompile Include="..\p_inter.c" />
-    <ClCompile Include="..\p_lights.c" />
-    <ClCompile Include="..\p_map.c" />
-    <ClCompile Include="..\p_maputl.c" />
-    <ClCompile Include="..\p_mobj.c" />
-    <ClCompile Include="..\p_polyobj.c" />
-    <ClCompile Include="..\p_saveg.c" />
-    <ClCompile Include="..\p_setup.c" />
-    <ClCompile Include="..\p_sight.c" />
-    <ClCompile Include="..\p_slopes.c" />
-    <ClCompile Include="..\p_spec.c" />
-    <ClCompile Include="..\p_telept.c" />
-    <ClCompile Include="..\p_tick.c" />
-    <ClCompile Include="..\p_user.c" />
-    <ClCompile Include="..\r_bsp.c" />
-    <ClCompile Include="..\r_data.c" />
-    <ClCompile Include="..\r_draw.c" />
-    <ClCompile Include="..\r_draw16.c">
-      <ExcludedFromBuild>true</ExcludedFromBuild>
-    </ClCompile>
-    <ClCompile Include="..\r_draw8.c">
-      <ExcludedFromBuild>true</ExcludedFromBuild>
-    </ClCompile>
-    <ClCompile Include="..\r_draw8_npo2.c">
-      <ExcludedFromBuild>true</ExcludedFromBuild>
-    </ClCompile>
-    <ClCompile Include="..\r_main.c" />
-    <ClCompile Include="..\r_patch.c" />
-    <ClCompile Include="..\r_patchrotation.c" />
-    <ClCompile Include="..\r_picformats.c" />
-    <ClCompile Include="..\r_plane.c" />
-    <ClCompile Include="..\r_portal.c" />
-    <ClCompile Include="..\r_segs.c" />
-    <ClCompile Include="..\r_sky.c" />
-    <ClCompile Include="..\r_splats.c" />
-    <ClCompile Include="..\r_textures.c" />
-    <ClCompile Include="..\r_things.c" />
-    <ClCompile Include="..\screen.c" />
-    <ClCompile Include="..\sounds.c" />
-    <ClCompile Include="..\string.c" />
-    <ClCompile Include="..\st_stuff.c" />
-    <ClCompile Include="..\s_sound.c" />
-    <ClCompile Include="..\tables.c" />
-    <ClCompile Include="..\t_facon.c">
-      <ExcludedFromBuild>true</ExcludedFromBuild>
-    </ClCompile>
-    <ClCompile Include="..\t_fsin.c">
-      <ExcludedFromBuild>true</ExcludedFromBuild>
-    </ClCompile>
-    <ClCompile Include="..\t_ftan.c">
-      <ExcludedFromBuild>true</ExcludedFromBuild>
-    </ClCompile>
-    <ClCompile Include="..\t_tan2a.c">
-      <ExcludedFromBuild>true</ExcludedFromBuild>
-    </ClCompile>
-    <ClCompile Include="..\v_video.c" />
-    <ClCompile Include="..\w_wad.c" />
-    <ClCompile Include="..\y_inter.c" />
-    <ClCompile Include="..\z_zone.c" />
-    <ClCompile Include="dx_error.c" />
-    <ClCompile Include="fabdxlib.c" />
-    <ClCompile Include="win_cd.c" />
-    <ClCompile Include="win_dbg.c" />
-    <ClCompile Include="win_dll.c" />
-    <ClCompile Include="win_main.c" />
-    <ClCompile Include="win_net.c" />
-    <ClCompile Include="win_snd.c" />
-    <ClCompile Include="win_sys.c" />
-    <ClCompile Include="win_vid.c" />
-  </ItemGroup>
-  <ItemGroup>
-    <ClInclude Include="..\am_map.h" />
-    <ClInclude Include="..\apng.h" />
-    <ClInclude Include="..\blua\lapi.h" />
-    <ClInclude Include="..\blua\lauxlib.h" />
-    <ClInclude Include="..\blua\lcode.h" />
-    <ClInclude Include="..\blua\ldebug.h" />
-    <ClInclude Include="..\blua\ldo.h" />
-    <ClInclude Include="..\blua\lfunc.h" />
-    <ClInclude Include="..\blua\lgc.h" />
-    <ClInclude Include="..\blua\llex.h" />
-    <ClInclude Include="..\blua\llimits.h" />
-    <ClInclude Include="..\blua\lmem.h" />
-    <ClInclude Include="..\blua\lobject.h" />
-    <ClInclude Include="..\blua\lopcodes.h" />
-    <ClInclude Include="..\blua\lparser.h" />
-    <ClInclude Include="..\blua\lstate.h" />
-    <ClInclude Include="..\blua\lstring.h" />
-    <ClInclude Include="..\blua\ltable.h" />
-    <ClInclude Include="..\blua\ltm.h" />
-    <ClInclude Include="..\blua\lua.h" />
-    <ClInclude Include="..\blua\luaconf.h" />
-    <ClInclude Include="..\blua\lualib.h" />
-    <ClInclude Include="..\blua\lundump.h" />
-    <ClInclude Include="..\blua\lvm.h" />
-    <ClInclude Include="..\blua\lzio.h" />
-    <ClInclude Include="..\byteptr.h" />
-    <ClInclude Include="..\b_bot.h" />
-    <ClInclude Include="..\command.h" />
-    <ClInclude Include="..\comptime.h" />
-    <ClInclude Include="..\console.h" />
-    <ClInclude Include="..\dehacked.h" />
-    <ClInclude Include="..\doomdata.h" />
-    <ClInclude Include="..\doomdef.h" />
-    <ClInclude Include="..\doomstat.h" />
-    <ClInclude Include="..\doomtype.h" />
-    <ClInclude Include="..\d_clisrv.h" />
-    <ClInclude Include="..\d_event.h" />
-    <ClInclude Include="..\d_main.h" />
-    <ClInclude Include="..\d_net.h" />
-    <ClInclude Include="..\d_netcmd.h" />
-    <ClInclude Include="..\d_netfil.h" />
-    <ClInclude Include="..\d_player.h" />
-    <ClInclude Include="..\d_think.h" />
-    <ClInclude Include="..\d_ticcmd.h" />
-    <ClInclude Include="..\endian.h" />
-    <ClInclude Include="..\fastcmp.h" />
-    <ClInclude Include="..\filesrch.h" />
-    <ClInclude Include="..\f_finale.h" />
-    <ClInclude Include="..\g_game.h" />
-    <ClInclude Include="..\g_input.h" />
-    <ClInclude Include="..\g_state.h" />
-    <ClInclude Include="..\hardware\hw3dsdrv.h" />
-    <ClInclude Include="..\hardware\hw3sound.h" />
-    <ClInclude Include="..\hardware\hws_data.h" />
-    <ClInclude Include="..\hardware\hw_clip.h" />
-    <ClInclude Include="..\hardware\hw_data.h" />
-    <ClInclude Include="..\hardware\hw_defs.h" />
-    <ClInclude Include="..\hardware\hw_dll.h" />
-    <ClInclude Include="..\hardware\hw_drv.h" />
-    <ClInclude Include="..\hardware\hw_glob.h" />
-    <ClInclude Include="..\hardware\hw_light.h" />
-    <ClInclude Include="..\hardware\hw_main.h" />
-    <ClInclude Include="..\hardware\hw_md2.h" />
-    <ClInclude Include="..\hardware\hw_md2load.h" />
-    <ClInclude Include="..\hardware\hw_md3load.h" />
-    <ClInclude Include="..\hardware\hw_model.h" />
-    <ClInclude Include="..\hardware\u_list.h" />
-    <ClInclude Include="..\hu_stuff.h" />
-    <ClInclude Include="..\info.h" />
-    <ClInclude Include="..\i_addrinfo.h" />
-    <ClInclude Include="..\i_joy.h" />
-    <ClInclude Include="..\i_net.h" />
-    <ClInclude Include="..\i_sound.h" />
-    <ClInclude Include="..\i_system.h" />
-    <ClInclude Include="..\i_tcp.h" />
-    <ClInclude Include="..\i_video.h" />
-    <ClInclude Include="..\keys.h" />
-    <ClInclude Include="..\lua_hook.h" />
-    <ClInclude Include="..\lua_hud.h" />
-    <ClInclude Include="..\lua_libs.h" />
-    <ClInclude Include="..\lua_script.h" />
-    <ClInclude Include="..\lzf.h" />
-    <ClInclude Include="..\md5.h" />
-    <ClInclude Include="..\mserv.h" />
-    <ClInclude Include="..\m_aatree.h" />
-    <ClInclude Include="..\m_anigif.h" />
-    <ClInclude Include="..\m_argv.h" />
-    <ClInclude Include="..\m_bbox.h" />
-    <ClInclude Include="..\m_cheat.h" />
-    <ClInclude Include="..\m_cond.h" />
-    <ClInclude Include="..\m_dllist.h" />
-    <ClInclude Include="..\m_fixed.h" />
-    <ClInclude Include="..\m_menu.h" />
-    <ClInclude Include="..\m_misc.h" />
-    <ClInclude Include="..\m_queue.h" />
-    <ClInclude Include="..\m_random.h" />
-    <ClInclude Include="..\m_swap.h" />
-    <ClInclude Include="..\p5prof.h" />
-    <ClInclude Include="..\p_local.h" />
-    <ClInclude Include="..\p_maputl.h" />
-    <ClInclude Include="..\p_mobj.h" />
-    <ClInclude Include="..\p_polyobj.h" />
-    <ClInclude Include="..\p_pspr.h" />
-    <ClInclude Include="..\p_saveg.h" />
-    <ClInclude Include="..\p_setup.h" />
-    <ClInclude Include="..\p_slopes.h" />
-    <ClInclude Include="..\p_spec.h" />
-    <ClInclude Include="..\p_tick.h" />
-    <ClInclude Include="..\r_bsp.h" />
-    <ClInclude Include="..\r_data.h" />
-    <ClInclude Include="..\r_defs.h" />
-    <ClInclude Include="..\r_draw.h" />
-    <ClInclude Include="..\r_local.h" />
-    <ClInclude Include="..\r_main.h" />
-    <ClInclude Include="..\r_patch.h" />
-    <ClInclude Include="..\r_patchrotation.h" />
-    <ClInclude Include="..\r_picformats.h" />
-    <ClInclude Include="..\r_plane.h" />
-    <ClInclude Include="..\r_portal.h" />
-    <ClInclude Include="..\r_segs.h" />
-    <ClInclude Include="..\r_sky.h" />
-    <ClInclude Include="..\r_splats.h" />
-    <ClInclude Include="..\r_state.h" />
-    <ClInclude Include="..\r_textures.h" />
-    <ClInclude Include="..\r_things.h" />
-    <ClInclude Include="..\screen.h" />
-    <ClInclude Include="..\sounds.h" />
-    <ClInclude Include="..\st_stuff.h" />
-    <ClInclude Include="..\s_sound.h" />
-    <ClInclude Include="..\tables.h" />
-    <ClInclude Include="..\v_video.h" />
-    <ClInclude Include="..\w_wad.h" />
-    <ClInclude Include="..\y_inter.h" />
-    <ClInclude Include="..\z_zone.h" />
-    <ClInclude Include="afxres.h" />
-    <ClInclude Include="dx_error.h" />
-    <ClInclude Include="fabdxlib.h" />
-    <ClInclude Include="resource.h" />
-    <ClInclude Include="win_dbg.h" />
-    <ClInclude Include="win_dll.h" />
-    <ClInclude Include="win_main.h" />
-  </ItemGroup>
-  <ItemGroup>
-    <Image Include="Srb2win.ico" />
-  </ItemGroup>
-  <ItemGroup>
-    <ResourceCompile Include="Srb2win.rc" />
-  </ItemGroup>
-  <ItemGroup>
-    <ProjectReference Include="..\..\libs\libpng-src\projects\visualc10\libpng.vcxproj">
-      <Project>{72b01aca-7a1a-4f7b-acef-2607299cf052}</Project>
-    </ProjectReference>
-    <ProjectReference Include="..\..\libs\zlib\projects\visualc10\zlib.vcxproj">
-      <Project>{73a5729c-7323-41d4-ab48-8a03c9f81603}</Project>
-    </ProjectReference>
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="..\asm_defs.inc" />
-    <None Include="..\config.h.in" />
-    <CustomBuild Include="..\tmap.nas">
-      <FileType>Document</FileType>
-    </CustomBuild>
-    <CustomBuild Include="..\tmap_mmx.nas">
-      <FileType>Document</FileType>
-    </CustomBuild>
-    <CustomBuild Include="..\tmap_vc.nas">
-      <FileType>Document</FileType>
-    </CustomBuild>
-  </ItemGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
-  <ImportGroup Label="ExtensionTargets">
-  </ImportGroup>
-</Project>
diff --git a/src/win32/Srb2win-vc10.vcxproj.filters b/src/win32/Srb2win-vc10.vcxproj.filters
deleted file mode 100644
index 7279368f1423f4a02e962395e8d4b451a30e44cd..0000000000000000000000000000000000000000
--- a/src/win32/Srb2win-vc10.vcxproj.filters
+++ /dev/null
@@ -1,943 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
-  <ItemGroup>
-    <Filter Include="BLUA">
-      <UniqueIdentifier>{20cba664-c3ef-48f1-85dd-42aafd5345cc}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="LUA">
-      <UniqueIdentifier>{d3817a65-82f5-4989-9217-e5a7f43380a0}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="B_Bots">
-      <UniqueIdentifier>{9c3ed4ae-dbed-4d00-a164-b8bb7fc1710c}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="Docs">
-      <UniqueIdentifier>{4b8a8fb6-7c84-48c2-85d1-0583e6b8cacd}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="W_Wad">
-      <UniqueIdentifier>{1907eee5-0ebf-4325-a2fa-793f089ed2e3}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="S_Sounds">
-      <UniqueIdentifier>{b9e78a3f-3e2b-4f89-9817-b77c7a26d2aa}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="R_Rend">
-      <UniqueIdentifier>{3f336df5-a1d7-4610-9728-4525e42c0abc}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="P_Play">
-      <UniqueIdentifier>{b5090aa0-6645-4091-aa1a-ffc3bf4dc422}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="M_Misc">
-      <UniqueIdentifier>{d59e82c9-68e5-44bf-827e-f7bb1676cd6c}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="I_Interface">
-      <UniqueIdentifier>{29e746a2-3d91-4b69-af6e-5e03895516b7}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="Hw_Hardware">
-      <UniqueIdentifier>{b295d364-61c3-4ebb-9b68-7d6c0bb891be}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="H_Hud">
-      <UniqueIdentifier>{ba258ec5-13d7-4083-98bd-c2ee58700b66}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="G_Game">
-      <UniqueIdentifier>{6163f1e5-da5d-4af2-b92c-753452f9e1d0}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="F_Frame">
-      <UniqueIdentifier>{077b0966-1151-4afa-a533-120a4c931322}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="D_Doom">
-      <UniqueIdentifier>{bded90bc-8019-42b1-ba19-32166743d3e3}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="A_Asm">
-      <UniqueIdentifier>{c0ddfdb5-7494-4cca-b2ad-cb048be9cbdf}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="Win32app">
-      <UniqueIdentifier>{d5157f99-43ef-49cc-ad76-658a1168fc0d}</UniqueIdentifier>
-    </Filter>
-    <Filter Include="O_Other">
-      <UniqueIdentifier>{2cedf139-53a1-40ea-b4de-19e9f4505a1f}</UniqueIdentifier>
-    </Filter>
-  </ItemGroup>
-  <ItemGroup>
-    <ClCompile Include="dx_error.c">
-      <Filter>Win32app</Filter>
-    </ClCompile>
-    <ClCompile Include="fabdxlib.c">
-      <Filter>Win32app</Filter>
-    </ClCompile>
-    <ClCompile Include="win_cd.c">
-      <Filter>Win32app</Filter>
-    </ClCompile>
-    <ClCompile Include="win_dbg.c">
-      <Filter>Win32app</Filter>
-    </ClCompile>
-    <ClCompile Include="win_dll.c">
-      <Filter>Win32app</Filter>
-    </ClCompile>
-    <ClCompile Include="win_main.c">
-      <Filter>Win32app</Filter>
-    </ClCompile>
-    <ClCompile Include="win_net.c">
-      <Filter>Win32app</Filter>
-    </ClCompile>
-    <ClCompile Include="win_snd.c">
-      <Filter>Win32app</Filter>
-    </ClCompile>
-    <ClCompile Include="win_sys.c">
-      <Filter>Win32app</Filter>
-    </ClCompile>
-    <ClCompile Include="win_vid.c">
-      <Filter>Win32app</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_bsp.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_cache.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_clip.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_draw.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_light.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_main.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_md2.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw3sound.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lapi.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lauxlib.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lbaselib.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lcode.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\ldebug.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\ldo.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\ldump.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lfunc.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lgc.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\linit.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\llex.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lmem.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lobject.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lopcodes.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lparser.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lstate.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lstring.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lstrlib.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\ltable.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\ltablib.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\ltm.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lundump.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lvm.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\blua\lzio.c">
-      <Filter>BLUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\d_clisrv.c">
-      <Filter>D_Doom</Filter>
-    </ClCompile>
-    <ClCompile Include="..\d_main.c">
-      <Filter>D_Doom</Filter>
-    </ClCompile>
-    <ClCompile Include="..\d_net.c">
-      <Filter>D_Doom</Filter>
-    </ClCompile>
-    <ClCompile Include="..\d_netcmd.c">
-      <Filter>D_Doom</Filter>
-    </ClCompile>
-    <ClCompile Include="..\d_netfil.c">
-      <Filter>D_Doom</Filter>
-    </ClCompile>
-    <ClCompile Include="..\dehacked.c">
-      <Filter>D_Doom</Filter>
-    </ClCompile>
-    <ClCompile Include="..\g_game.c">
-      <Filter>G_Game</Filter>
-    </ClCompile>
-    <ClCompile Include="..\g_input.c">
-      <Filter>G_Game</Filter>
-    </ClCompile>
-    <ClCompile Include="..\f_finale.c">
-      <Filter>F_Frame</Filter>
-    </ClCompile>
-    <ClCompile Include="..\f_wipe.c">
-      <Filter>F_Frame</Filter>
-    </ClCompile>
-    <ClCompile Include="..\i_addrinfo.c">
-      <Filter>I_Interface</Filter>
-    </ClCompile>
-    <ClCompile Include="..\i_tcp.c">
-      <Filter>I_Interface</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_thinkerlib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_baselib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_blockmaplib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_consolelib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_hooklib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_hudlib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_infolib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_maplib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_mathlib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_mobjlib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_playerlib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_script.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lua_skinlib.c">
-      <Filter>LUA</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_aatree.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_anigif.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_argv.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_bbox.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_cheat.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_cond.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_fixed.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_menu.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_misc.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_queue.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\m_random.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\md5.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\am_map.c">
-      <Filter>H_Hud</Filter>
-    </ClCompile>
-    <ClCompile Include="..\b_bot.c">
-      <Filter>B_Bots</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_ceilng.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_enemy.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_floor.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_inter.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_lights.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_map.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_maputl.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_mobj.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_polyobj.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_saveg.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_setup.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_sight.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_slopes.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_spec.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_telept.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_tick.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\p_user.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_bsp.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_data.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_draw.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_draw8.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_draw16.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_draw8_npo2.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_main.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_plane.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_segs.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_sky.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_splats.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_things.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\t_facon.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\t_fsin.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\t_ftan.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\t_tan2a.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\tables.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\sounds.c">
-      <Filter>S_Sounds</Filter>
-    </ClCompile>
-    <ClCompile Include="..\w_wad.c">
-      <Filter>W_Wad</Filter>
-    </ClCompile>
-    <ClCompile Include="..\lzf.c">
-      <Filter>W_Wad</Filter>
-    </ClCompile>
-    <ClCompile Include="..\s_sound.c">
-      <Filter>S_Sounds</Filter>
-    </ClCompile>
-    <ClCompile Include="..\comptime.c">
-      <Filter>O_Other</Filter>
-    </ClCompile>
-    <ClCompile Include="..\command.c">
-      <Filter>H_Hud</Filter>
-    </ClCompile>
-    <ClCompile Include="..\console.c">
-      <Filter>H_Hud</Filter>
-    </ClCompile>
-    <ClCompile Include="..\filesrch.c">
-      <Filter>I_Interface</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hu_stuff.c">
-      <Filter>H_Hud</Filter>
-    </ClCompile>
-    <ClCompile Include="..\info.c">
-      <Filter>P_Play</Filter>
-    </ClCompile>
-    <ClCompile Include="..\mserv.c">
-      <Filter>I_Interface</Filter>
-    </ClCompile>
-    <ClCompile Include="..\st_stuff.c">
-      <Filter>H_Hud</Filter>
-    </ClCompile>
-    <ClCompile Include="..\v_video.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\screen.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\y_inter.c">
-      <Filter>H_Hud</Filter>
-    </ClCompile>
-    <ClCompile Include="..\z_zone.c">
-      <Filter>D_Doom</Filter>
-    </ClCompile>
-    <ClCompile Include="..\string.c">
-      <Filter>M_Misc</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_md2load.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_md3load.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_model.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\u_list.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\hardware\hw_clip.c">
-      <Filter>Hw_Hardware</Filter>
-    </ClCompile>
-    <ClCompile Include="..\apng.c" />
-    <ClCompile Include="..\r_patch.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_patchrotation.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_picformats.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_textures.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-    <ClCompile Include="..\r_portal.c">
-      <Filter>R_Rend</Filter>
-    </ClCompile>
-  </ItemGroup>
-  <ItemGroup>
-    <ClInclude Include="afxres.h">
-      <Filter>Win32app</Filter>
-    </ClInclude>
-    <ClInclude Include="dx_error.h">
-      <Filter>Win32app</Filter>
-    </ClInclude>
-    <ClInclude Include="fabdxlib.h">
-      <Filter>Win32app</Filter>
-    </ClInclude>
-    <ClInclude Include="resource.h">
-      <Filter>Win32app</Filter>
-    </ClInclude>
-    <ClInclude Include="win_dbg.h">
-      <Filter>Win32app</Filter>
-    </ClInclude>
-    <ClInclude Include="win_dll.h">
-      <Filter>Win32app</Filter>
-    </ClInclude>
-    <ClInclude Include="win_main.h">
-      <Filter>Win32app</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_clip.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_data.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_defs.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_dll.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_drv.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_glob.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_light.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_main.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_md2.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_md2load.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_md3load.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_model.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw3dsdrv.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw3sound.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hws_data.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\u_list.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lapi.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lauxlib.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lcode.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\ldebug.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\ldo.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lfunc.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lgc.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\llex.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\llimits.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lmem.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lobject.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lopcodes.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lparser.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lstate.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lstring.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\ltable.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\ltm.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lua.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\luaconf.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lualib.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lundump.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lvm.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\blua\lzio.h">
-      <Filter>BLUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\d_clisrv.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\d_event.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\d_main.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\d_net.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\d_netcmd.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\d_netfil.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\d_player.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\d_think.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\d_ticcmd.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\dehacked.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\doomdata.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\doomdef.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\doomstat.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\doomtype.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\g_game.h">
-      <Filter>G_Game</Filter>
-    </ClInclude>
-    <ClInclude Include="..\g_input.h">
-      <Filter>G_Game</Filter>
-    </ClInclude>
-    <ClInclude Include="..\g_state.h">
-      <Filter>G_Game</Filter>
-    </ClInclude>
-    <ClInclude Include="..\f_finale.h">
-      <Filter>F_Frame</Filter>
-    </ClInclude>
-    <ClInclude Include="..\i_addrinfo.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\i_joy.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\i_net.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\i_sound.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\i_system.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\i_tcp.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\i_video.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\lua_hook.h">
-      <Filter>LUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\lua_hud.h">
-      <Filter>LUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\lua_libs.h">
-      <Filter>LUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\lua_script.h">
-      <Filter>LUA</Filter>
-    </ClInclude>
-    <ClInclude Include="..\md5.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_aatree.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_anigif.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_argv.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_bbox.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_cheat.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_cond.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_dllist.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_fixed.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_menu.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_misc.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_queue.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_random.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\m_swap.h">
-      <Filter>M_Misc</Filter>
-    </ClInclude>
-    <ClInclude Include="..\am_map.h">
-      <Filter>H_Hud</Filter>
-    </ClInclude>
-    <ClInclude Include="..\b_bot.h">
-      <Filter>B_Bots</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p_local.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p_maputl.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p_mobj.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p_polyobj.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p_pspr.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p_saveg.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p_setup.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p_slopes.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p_spec.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p_tick.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_bsp.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_data.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_defs.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_draw.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_local.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_main.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_plane.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_segs.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_sky.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_splats.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_state.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_things.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\tables.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\sounds.h">
-      <Filter>S_Sounds</Filter>
-    </ClInclude>
-    <ClInclude Include="..\w_wad.h">
-      <Filter>W_Wad</Filter>
-    </ClInclude>
-    <ClInclude Include="..\lzf.h">
-      <Filter>W_Wad</Filter>
-    </ClInclude>
-    <ClInclude Include="..\byteptr.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\s_sound.h">
-      <Filter>S_Sounds</Filter>
-    </ClInclude>
-    <ClInclude Include="..\comptime.h">
-      <Filter>O_Other</Filter>
-    </ClInclude>
-    <ClInclude Include="..\keys.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\command.h">
-      <Filter>H_Hud</Filter>
-    </ClInclude>
-    <ClInclude Include="..\console.h">
-      <Filter>H_Hud</Filter>
-    </ClInclude>
-    <ClInclude Include="..\endian.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\filesrch.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hu_stuff.h">
-      <Filter>H_Hud</Filter>
-    </ClInclude>
-    <ClInclude Include="..\info.h">
-      <Filter>P_Play</Filter>
-    </ClInclude>
-    <ClInclude Include="..\mserv.h">
-      <Filter>I_Interface</Filter>
-    </ClInclude>
-    <ClInclude Include="..\p5prof.h">
-      <Filter>A_Asm</Filter>
-    </ClInclude>
-    <ClInclude Include="..\st_stuff.h">
-      <Filter>H_Hud</Filter>
-    </ClInclude>
-    <ClInclude Include="..\v_video.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\screen.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\y_inter.h">
-      <Filter>H_Hud</Filter>
-    </ClInclude>
-    <ClInclude Include="..\z_zone.h">
-      <Filter>D_Doom</Filter>
-    </ClInclude>
-    <ClInclude Include="..\fastcmp.h">
-      <Filter>O_Other</Filter>
-    </ClInclude>
-    <ClInclude Include="..\hardware\hw_clip.h">
-      <Filter>Hw_Hardware</Filter>
-    </ClInclude>
-    <ClInclude Include="..\apng.h" />
-    <ClInclude Include="..\r_patch.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_patchrotation.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_picformats.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_textures.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-    <ClInclude Include="..\r_portal.h">
-      <Filter>R_Rend</Filter>
-    </ClInclude>
-  </ItemGroup>
-  <ItemGroup>
-    <Image Include="Srb2win.ico">
-      <Filter>Win32app</Filter>
-    </Image>
-  </ItemGroup>
-  <ItemGroup>
-    <ResourceCompile Include="Srb2win.rc">
-      <Filter>Win32app</Filter>
-    </ResourceCompile>
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="..\asm_defs.inc">
-      <Filter>A_Asm</Filter>
-    </None>
-    <None Include="..\config.h.in">
-      <Filter>O_Other</Filter>
-    </None>
-  </ItemGroup>
-  <ItemGroup>
-    <CustomBuild Include="..\tmap.nas">
-      <Filter>A_Asm</Filter>
-    </CustomBuild>
-    <CustomBuild Include="..\tmap_mmx.nas">
-      <Filter>A_Asm</Filter>
-    </CustomBuild>
-    <CustomBuild Include="..\tmap_vc.nas">
-      <Filter>A_Asm</Filter>
-    </CustomBuild>
-  </ItemGroup>
-</Project>
diff --git a/src/win32/Srb2win-vc9.vcproj b/src/win32/Srb2win-vc9.vcproj
deleted file mode 100644
index c1c6b5bc43e3e99139bef441da8bf3b3c48bdbb2..0000000000000000000000000000000000000000
--- a/src/win32/Srb2win-vc9.vcproj
+++ /dev/null
@@ -1,4914 +0,0 @@
-<?xml version="1.0" encoding="Windows-1252"?>
-<VisualStudioProject
-	ProjectType="Visual C++"
-	Version="9.00"
-	Name="Srb2win"
-	ProjectGUID="{0F554F1D-ED49-4D65-A9A7-F63C57F277BE}"
-	RootNamespace="Srb2win"
-	TargetFrameworkVersion="0"
-	>
-	<Platforms>
-		<Platform
-			Name="Win32"
-		/>
-		<Platform
-			Name="x64"
-		/>
-	</Platforms>
-	<ToolFiles>
-	</ToolFiles>
-	<Configurations>
-		<Configuration
-			Name="Debug|Win32"
-			OutputDirectory=".\..\..\bin\VC9\$(PlatformName)\$(ConfigurationName)"
-			IntermediateDirectory=".\..\..\objs\VC9\$(PlatformName)\$(ConfigurationName)"
-			ConfigurationType="1"
-			InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC60.vsprops"
-			UseOfMFC="0"
-			ATLMinimizesCRunTimeLibraryUsage="false"
-			>
-			<Tool
-				Name="VCPreBuildEventTool"
-				Description="Getting revision number from the SCM system"
-				CommandLine="&quot;$(ProjectDir)..\..\comptime.bat&quot; &quot;$(ProjectDir)..&quot;"
-			/>
-			<Tool
-				Name="VCCustomBuildTool"
-			/>
-			<Tool
-				Name="VCXMLDataGeneratorTool"
-			/>
-			<Tool
-				Name="VCWebServiceProxyGeneratorTool"
-			/>
-			<Tool
-				Name="VCMIDLTool"
-				PreprocessorDefinitions="_DEBUG"
-				MkTypLibCompatible="true"
-				SuppressStartupBanner="true"
-				TargetEnvironment="1"
-				TypeLibraryName=".\..\..\bin\VC9\$(Platform)\$(Configuration)\Srb2win.tlb"
-				HeaderFileName=""
-			/>
-			<Tool
-				Name="VCCLCompilerTool"
-				Optimization="0"
-				OmitFramePointers="false"
-				AdditionalIncludeDirectories="&quot;$(ProjectDir)..\..\libs\libpng-src&quot;;&quot;$(ProjectDir)..\..\libs\zlib&quot;"
-				PreprocessorDefinitions="_DEBUG;_WINDOWS;USEASM;HAVE_PNG;COMPVERSION;_CRT_SECURE_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE"
-				MinimalRebuild="true"
-				RuntimeLibrary="1"
-				EnableFunctionLevelLinking="true"
-				AssemblerOutput="2"
-				AssemblerListingLocation="$(IntDir)\"
-				ProgramDataBaseFileName="$(IntDir)\Srb2win.pdb"
-				BrowseInformation="1"
-				WarningLevel="4"
-				SuppressStartupBanner="true"
-				DebugInformationFormat="4"
-				CompileAs="1"
-			/>
-			<Tool
-				Name="VCManagedResourceCompilerTool"
-			/>
-			<Tool
-				Name="VCResourceCompilerTool"
-				PreprocessorDefinitions="_DEBUG"
-				Culture="1033"
-			/>
-			<Tool
-				Name="VCPreLinkEventTool"
-			/>
-			<Tool
-				Name="VCLinkerTool"
-				AdditionalDependencies="dxguid.lib winmm.lib ws2_32.lib dinput8.lib"
-				OutputFile="$(OutDir)\srb2win.exe"
-				LinkIncremental="2"
-				SuppressStartupBanner="true"
-				GenerateDebugInformation="true"
-				ProgramDatabaseFile="$(OutDir)\srb2win.pdb"
-				SubSystem="2"
-				RandomizedBaseAddress="1"
-				DataExecutionPrevention="0"
-				TargetMachine="1"
-			/>
-			<Tool
-				Name="VCALinkTool"
-			/>
-			<Tool
-				Name="VCManifestTool"
-			/>
-			<Tool
-				Name="VCXDCMakeTool"
-			/>
-			<Tool
-				Name="VCBscMakeTool"
-				SuppressStartupBanner="true"
-				OutputFile="$(OutDir)\Srb2win.bsc"
-			/>
-			<Tool
-				Name="VCFxCopTool"
-			/>
-			<Tool
-				Name="VCAppVerifierTool"
-			/>
-			<Tool
-				Name="VCPostBuildEventTool"
-			/>
-		</Configuration>
-		<Configuration
-			Name="Debug|x64"
-			OutputDirectory=".\..\..\bin\VC9\$(PlatformName)\$(ConfigurationName)"
-			IntermediateDirectory=".\..\..\objs\VC9\$(PlatformName)\$(ConfigurationName)"
-			ConfigurationType="1"
-			InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC60.vsprops"
-			UseOfMFC="0"
-			ATLMinimizesCRunTimeLibraryUsage="false"
-			>
-			<Tool
-				Name="VCPreBuildEventTool"
-				Description="Getting revision number from the SCM system"
-				CommandLine="&quot;$(ProjectDir)..\..\comptime.bat&quot; &quot;$(ProjectDir)..&quot;"
-			/>
-			<Tool
-				Name="VCCustomBuildTool"
-			/>
-			<Tool
-				Name="VCXMLDataGeneratorTool"
-			/>
-			<Tool
-				Name="VCWebServiceProxyGeneratorTool"
-			/>
-			<Tool
-				Name="VCMIDLTool"
-				PreprocessorDefinitions="_DEBUG"
-				MkTypLibCompatible="true"
-				SuppressStartupBanner="true"
-				TargetEnvironment="3"
-				TypeLibraryName=".\..\..\bin\VC9\$(Platform)\$(Configuration)\Srb2win.tlb"
-				HeaderFileName=""
-			/>
-			<Tool
-				Name="VCCLCompilerTool"
-				Optimization="0"
-				OmitFramePointers="false"
-				AdditionalIncludeDirectories="&quot;$(ProjectDir)..\..\libs\libpng-src&quot;;&quot;$(ProjectDir)..\..\libs\zlib&quot;"
-				PreprocessorDefinitions="_DEBUG;_WINDOWS;HAVE_PNG;COMPVERSION;_CRT_SECURE_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE"
-				MinimalRebuild="true"
-				BasicRuntimeChecks="3"
-				SmallerTypeCheck="true"
-				RuntimeLibrary="1"
-				EnableFunctionLevelLinking="true"
-				AssemblerOutput="2"
-				AssemblerListingLocation="$(IntDir)\"
-				ProgramDataBaseFileName="$(IntDir)\Srb2win.pdb"
-				BrowseInformation="1"
-				WarningLevel="4"
-				SuppressStartupBanner="true"
-				DebugInformationFormat="3"
-				CompileAs="1"
-			/>
-			<Tool
-				Name="VCManagedResourceCompilerTool"
-			/>
-			<Tool
-				Name="VCResourceCompilerTool"
-				PreprocessorDefinitions="_DEBUG"
-				Culture="1033"
-			/>
-			<Tool
-				Name="VCPreLinkEventTool"
-			/>
-			<Tool
-				Name="VCLinkerTool"
-				AdditionalDependencies="dxguid.lib winmm.lib ws2_32.lib dinput8.lib"
-				OutputFile="$(OutDir)\srb2win.exe"
-				LinkIncremental="2"
-				SuppressStartupBanner="true"
-				GenerateDebugInformation="true"
-				ProgramDatabaseFile="$(OutDir)\srb2win.pdb"
-				SubSystem="2"
-				RandomizedBaseAddress="1"
-				DataExecutionPrevention="0"
-				TargetMachine="17"
-			/>
-			<Tool
-				Name="VCALinkTool"
-			/>
-			<Tool
-				Name="VCManifestTool"
-			/>
-			<Tool
-				Name="VCXDCMakeTool"
-			/>
-			<Tool
-				Name="VCBscMakeTool"
-				SuppressStartupBanner="true"
-				OutputFile="$(OutDir)\Srb2win.bsc"
-			/>
-			<Tool
-				Name="VCFxCopTool"
-			/>
-			<Tool
-				Name="VCAppVerifierTool"
-			/>
-			<Tool
-				Name="VCPostBuildEventTool"
-			/>
-		</Configuration>
-		<Configuration
-			Name="Release|Win32"
-			OutputDirectory=".\..\..\bin\VC9\$(PlatformName)\$(ConfigurationName)"
-			IntermediateDirectory=".\..\..\objs\VC9\$(PlatformName)\$(ConfigurationName)"
-			ConfigurationType="1"
-			InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC60.vsprops"
-			UseOfMFC="0"
-			ATLMinimizesCRunTimeLibraryUsage="false"
-			>
-			<Tool
-				Name="VCPreBuildEventTool"
-				Description="Getting revision number from the SCM system"
-				CommandLine="&quot;$(ProjectDir)..\..\comptime.bat&quot; &quot;$(ProjectDir)..&quot;"
-			/>
-			<Tool
-				Name="VCCustomBuildTool"
-			/>
-			<Tool
-				Name="VCXMLDataGeneratorTool"
-			/>
-			<Tool
-				Name="VCWebServiceProxyGeneratorTool"
-			/>
-			<Tool
-				Name="VCMIDLTool"
-				PreprocessorDefinitions="NDEBUG"
-				SuppressStartupBanner="true"
-				TargetEnvironment="1"
-				TypeLibraryName=".\..\..\bin\VC9\$(Platform)\$(Configuration)\Srb2win.tlb"
-				HeaderFileName=""
-			/>
-			<Tool
-				Name="VCCLCompilerTool"
-				AdditionalOptions="/MP"
-				Optimization="4"
-				InlineFunctionExpansion="1"
-				EnableIntrinsicFunctions="true"
-				FavorSizeOrSpeed="1"
-				OmitFramePointers="true"
-				AdditionalIncludeDirectories="&quot;$(ProjectDir)..\..\libs\libpng-src&quot;;&quot;$(ProjectDir)..\..\libs\zlib&quot;"
-				PreprocessorDefinitions="NDEBUG;_WINDOWS;USEASM;HAVE_PNG;COMPVERSION;_CRT_SECURE_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE"
-				StringPooling="true"
-				RuntimeLibrary="0"
-				EnableFunctionLevelLinking="true"
-				AssemblerListingLocation="$(IntDir)\"
-				ProgramDataBaseFileName="$(IntDir)\Srb2win.pdb"
-				BrowseInformation="1"
-				WarningLevel="3"
-				SuppressStartupBanner="true"
-				DebugInformationFormat="3"
-				CompileAs="1"
-			/>
-			<Tool
-				Name="VCManagedResourceCompilerTool"
-			/>
-			<Tool
-				Name="VCResourceCompilerTool"
-				PreprocessorDefinitions="NDEBUG"
-				Culture="1033"
-			/>
-			<Tool
-				Name="VCPreLinkEventTool"
-			/>
-			<Tool
-				Name="VCLinkerTool"
-				AdditionalDependencies="dxguid.lib winmm.lib ws2_32.lib dinput8.lib"
-				OutputFile="$(OutDir)\srb2win.exe"
-				LinkIncremental="1"
-				SuppressStartupBanner="true"
-				GenerateDebugInformation="true"
-				ProgramDatabaseFile="$(OutDir)\srb2win.pdb"
-				SubSystem="2"
-				RandomizedBaseAddress="1"
-				DataExecutionPrevention="0"
-				TargetMachine="1"
-			/>
-			<Tool
-				Name="VCALinkTool"
-			/>
-			<Tool
-				Name="VCManifestTool"
-			/>
-			<Tool
-				Name="VCXDCMakeTool"
-			/>
-			<Tool
-				Name="VCBscMakeTool"
-				SuppressStartupBanner="true"
-				OutputFile="$(OutDir)\Srb2win.bsc"
-			/>
-			<Tool
-				Name="VCFxCopTool"
-			/>
-			<Tool
-				Name="VCAppVerifierTool"
-			/>
-			<Tool
-				Name="VCPostBuildEventTool"
-			/>
-		</Configuration>
-		<Configuration
-			Name="Release|x64"
-			OutputDirectory=".\..\..\bin\VC9\$(PlatformName)\$(ConfigurationName)"
-			IntermediateDirectory=".\..\..\objs\VC9\$(PlatformName)\$(ConfigurationName)"
-			ConfigurationType="1"
-			InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC60.vsprops"
-			UseOfMFC="0"
-			ATLMinimizesCRunTimeLibraryUsage="false"
-			>
-			<Tool
-				Name="VCPreBuildEventTool"
-				Description="Getting revision number from the SCM system"
-				CommandLine="&quot;$(ProjectDir)..\..\comptime.bat&quot; &quot;$(ProjectDir)..&quot;"
-			/>
-			<Tool
-				Name="VCCustomBuildTool"
-			/>
-			<Tool
-				Name="VCXMLDataGeneratorTool"
-			/>
-			<Tool
-				Name="VCWebServiceProxyGeneratorTool"
-			/>
-			<Tool
-				Name="VCMIDLTool"
-				PreprocessorDefinitions="NDEBUG"
-				SuppressStartupBanner="true"
-				TargetEnvironment="3"
-				TypeLibraryName=".\..\..\bin\VC9\$(Platform)\$(Configuration)\Srb2win.tlb"
-				HeaderFileName=""
-			/>
-			<Tool
-				Name="VCCLCompilerTool"
-				AdditionalOptions="/MP"
-				Optimization="4"
-				InlineFunctionExpansion="1"
-				EnableIntrinsicFunctions="true"
-				FavorSizeOrSpeed="1"
-				OmitFramePointers="true"
-				AdditionalIncludeDirectories="&quot;$(ProjectDir)..\..\libs\libpng-src&quot;;&quot;$(ProjectDir)..\..\libs\zlib&quot;"
-				PreprocessorDefinitions="NDEBUG;_WINDOWS;HAVE_PNG;COMPVERSION;_CRT_SECURE_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE"
-				StringPooling="true"
-				RuntimeLibrary="0"
-				EnableFunctionLevelLinking="true"
-				AssemblerListingLocation="$(IntDir)\"
-				ProgramDataBaseFileName="$(IntDir)\Srb2win.pdb"
-				BrowseInformation="1"
-				WarningLevel="3"
-				SuppressStartupBanner="true"
-				DebugInformationFormat="3"
-				CompileAs="1"
-			/>
-			<Tool
-				Name="VCManagedResourceCompilerTool"
-			/>
-			<Tool
-				Name="VCResourceCompilerTool"
-				PreprocessorDefinitions="NDEBUG"
-				Culture="1033"
-			/>
-			<Tool
-				Name="VCPreLinkEventTool"
-			/>
-			<Tool
-				Name="VCLinkerTool"
-				AdditionalDependencies="dxguid.lib winmm.lib ws2_32.lib dinput8.lib"
-				OutputFile="$(OutDir)\srb2win.exe"
-				LinkIncremental="1"
-				SuppressStartupBanner="true"
-				GenerateDebugInformation="true"
-				ProgramDatabaseFile="$(OutDir)\srb2win.pdb"
-				SubSystem="2"
-				RandomizedBaseAddress="1"
-				DataExecutionPrevention="0"
-				TargetMachine="17"
-			/>
-			<Tool
-				Name="VCALinkTool"
-			/>
-			<Tool
-				Name="VCManifestTool"
-			/>
-			<Tool
-				Name="VCXDCMakeTool"
-			/>
-			<Tool
-				Name="VCBscMakeTool"
-				SuppressStartupBanner="true"
-				OutputFile="$(OutDir)\Srb2win.bsc"
-			/>
-			<Tool
-				Name="VCFxCopTool"
-			/>
-			<Tool
-				Name="VCAppVerifierTool"
-			/>
-			<Tool
-				Name="VCPostBuildEventTool"
-			/>
-		</Configuration>
-	</Configurations>
-	<References>
-	</References>
-	<Files>
-		<Filter
-			Name="Win32app"
-			>
-			<File
-				RelativePath="afxres.h"
-				>
-			</File>
-			<File
-				RelativePath="dx_error.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="dx_error.h"
-				>
-			</File>
-			<File
-				RelativePath="fabdxlib.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="fabdxlib.h"
-				>
-			</File>
-			<File
-				RelativePath="..\filesrch.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\filesrch.h"
-				>
-			</File>
-			<File
-				RelativePath="mid2strm.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="mid2strm.h"
-				>
-			</File>
-			<File
-				RelativePath="midstuff.h"
-				>
-			</File>
-			<File
-				RelativePath="resource.h"
-				>
-			</File>
-			<File
-				RelativePath="Srb2win.rc"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCResourceCompilerTool"
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCResourceCompilerTool"
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCResourceCompilerTool"
-						PreprocessorDefinitions=""
-						AdditionalIncludeDirectories="win32"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCResourceCompilerTool"
-						PreprocessorDefinitions=""
-						AdditionalIncludeDirectories="win32"
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="win_cd.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="win_dbg.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="win_dbg.h"
-				>
-			</File>
-			<File
-				RelativePath="win_dll.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="win_dll.h"
-				>
-			</File>
-			<File
-				RelativePath="win_main.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="win_main.h"
-				>
-			</File>
-			<File
-				RelativePath="win_net.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="win_snd.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="win_sys.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="win_vid.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-		</Filter>
-		<Filter
-			Name="A_Asm"
-			>
-			<File
-				RelativePath="..\p5prof.h"
-				>
-			</File>
-			<File
-				RelativePath="..\tmap.nas"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\tmap_mmx.nas"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\tmap_vc.nas"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-						Description="Compiling $(InputName).nas with NASM..."
-						CommandLine="nasm -g -o $(IntDir)/$(InputName).obj -f win32 &quot;$(InputPath)&quot;&#x0D;&#x0A;"
-						Outputs="$(IntDir)/$(InputName).obj"
-					/>
-				</FileConfiguration>
-			</File>
-		</Filter>
-		<Filter
-			Name="D_Doom"
-			>
-			<File
-				RelativePath="..\comptime.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\d_clisrv.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\d_clisrv.h"
-				>
-			</File>
-			<File
-				RelativePath="..\d_event.h"
-				>
-			</File>
-			<File
-				RelativePath="..\d_main.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\d_main.h"
-				>
-			</File>
-			<File
-				RelativePath="..\d_net.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\d_net.h"
-				>
-			</File>
-			<File
-				RelativePath="..\d_netcmd.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\d_netcmd.h"
-				>
-			</File>
-			<File
-				RelativePath="..\d_netfil.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\d_netfil.h"
-				>
-			</File>
-			<File
-				RelativePath="..\d_player.h"
-				>
-			</File>
-			<File
-				RelativePath="..\d_think.h"
-				>
-			</File>
-			<File
-				RelativePath="..\d_ticcmd.h"
-				>
-			</File>
-			<File
-				RelativePath="..\dehacked.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\dehacked.h"
-				>
-			</File>
-			<File
-				RelativePath="..\doomdata.h"
-				>
-			</File>
-			<File
-				RelativePath="..\doomdef.h"
-				>
-			</File>
-			<File
-				RelativePath="..\doomstat.h"
-				>
-			</File>
-			<File
-				RelativePath="..\doomtype.h"
-				>
-			</File>
-			<File
-				RelativePath="..\z_zone.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\z_zone.h"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="F_Frame"
-			>
-			<File
-				RelativePath="..\f_finale.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\f_finale.h"
-				>
-			</File>
-			<File
-				RelativePath="..\f_wipe.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-		</Filter>
-		<Filter
-			Name="G_Game"
-			>
-			<File
-				RelativePath="..\g_game.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\g_game.h"
-				>
-			</File>
-			<File
-				RelativePath="..\g_input.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\g_input.h"
-				>
-			</File>
-			<File
-				RelativePath="..\g_state.h"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="H_Hud"
-			>
-			<File
-				RelativePath="..\am_map.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\am_map.h"
-				>
-			</File>
-			<File
-				RelativePath="..\command.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\command.h"
-				>
-			</File>
-			<File
-				RelativePath="..\console.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\console.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hu_stuff.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\hu_stuff.h"
-				>
-			</File>
-			<File
-				RelativePath="..\st_stuff.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\st_stuff.h"
-				>
-			</File>
-			<File
-				RelativePath="..\y_inter.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\y_inter.h"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="Hw_Hardware"
-			>
-			<File
-				RelativePath="..\hardware\hw3dsdrv.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hardware\hw3sound.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\hardware\hw3sound.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_bsp.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_cache.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_data.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_defs.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_dll.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_draw.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_drv.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_glob.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_light.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_light.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_main.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_main.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_md2.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\hardware\hw_md2.h"
-				>
-			</File>
-			<File
-				RelativePath="..\hardware\hws_data.h"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="I_Interface"
-			>
-			<File
-				RelativePath="..\byteptr.h"
-				>
-			</File>
-			<File
-				RelativePath="..\i_addrinfo.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\i_addrinfo.h"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCustomBuildTool"
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\i_joy.h"
-				>
-			</File>
-			<File
-				RelativePath="..\i_net.h"
-				>
-			</File>
-			<File
-				RelativePath="..\i_sound.h"
-				>
-			</File>
-			<File
-				RelativePath="..\i_system.h"
-				>
-			</File>
-			<File
-				RelativePath="..\i_tcp.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\i_tcp.h"
-				>
-			</File>
-			<File
-				RelativePath="..\i_video.h"
-				>
-			</File>
-			<File
-				RelativePath="..\keys.h"
-				>
-			</File>
-			<File
-				RelativePath="..\mserv.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\mserv.h"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="M_Misc"
-			>
-			<File
-				RelativePath="..\m_anigif.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\m_anigif.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_argv.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\m_argv.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_bbox.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\m_bbox.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_cheat.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\m_cheat.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_cond.c"
-				>
-			</File>
-			<File
-				RelativePath="..\m_cond.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_dllist.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_fixed.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\m_fixed.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_menu.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\m_menu.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_misc.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\m_misc.h"
-				>
-			</File>
-			<File
-				RelativePath="..\apng.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\apng.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_queue.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\m_queue.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_random.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\m_random.h"
-				>
-			</File>
-			<File
-				RelativePath="..\m_swap.h"
-				>
-			</File>
-			<File
-				RelativePath="..\string.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-		</Filter>
-		<Filter
-			Name="P_Play"
-			>
-			<File
-				RelativePath="..\info.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\info.h"
-				>
-			</File>
-			<File
-				RelativePath="..\p_ceilng.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_enemy.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_fab.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_floor.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_inter.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_lights.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_local.h"
-				>
-			</File>
-			<File
-				RelativePath="..\p_map.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_maputl.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_maputl.h"
-				>
-			</File>
-			<File
-				RelativePath="..\p_mobj.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_mobj.h"
-				>
-			</File>
-			<File
-				RelativePath="..\p_polyobj.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_polyobj.h"
-				>
-			</File>
-			<File
-				RelativePath="..\p_pspr.h"
-				>
-			</File>
-			<File
-				RelativePath="..\p_saveg.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_saveg.h"
-				>
-			</File>
-			<File
-				RelativePath="..\p_setup.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_setup.h"
-				>
-			</File>
-			<File
-				RelativePath="..\p_sight.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_spec.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_spec.h"
-				>
-			</File>
-			<File
-				RelativePath="..\p_telept.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_tick.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\p_tick.h"
-				>
-			</File>
-			<File
-				RelativePath="..\p_user.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\tables.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\tables.h"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="R_Rend"
-			>
-			<File
-				RelativePath="..\r_bsp.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_bsp.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_data.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_data.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_defs.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_draw.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_draw.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_draw16.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_draw8.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					ExcludedFromBuild="true"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_local.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_main.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_main.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_plane.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_plane.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_segs.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_segs.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_sky.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_sky.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_splats.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_splats.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_state.h"
-				>
-			</File>
-			<File
-				RelativePath="..\r_things.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\r_things.h"
-				>
-			</File>
-			<File
-				RelativePath="..\screen.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\screen.h"
-				>
-			</File>
-			<File
-				RelativePath="..\v_video.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\v_video.h"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="S_Sounds"
-			>
-			<File
-				RelativePath="..\s_sound.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\s_sound.h"
-				>
-			</File>
-			<File
-				RelativePath="..\sounds.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\sounds.h"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="W_Wad"
-			>
-			<File
-				RelativePath="..\lzf.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\lzf.h"
-				>
-			</File>
-			<File
-				RelativePath="..\md5.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\md5.h"
-				>
-			</File>
-			<File
-				RelativePath="..\w_wad.c"
-				>
-				<FileConfiguration
-					Name="Debug|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Debug|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|Win32"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-				<FileConfiguration
-					Name="Release|x64"
-					>
-					<Tool
-						Name="VCCLCompilerTool"
-						AdditionalIncludeDirectories=""
-						PreprocessorDefinitions=""
-					/>
-				</FileConfiguration>
-			</File>
-			<File
-				RelativePath="..\w_wad.h"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="Docs"
-			>
-			<File
-				RelativePath="..\..\doc\copying"
-				>
-			</File>
-			<File
-				RelativePath="..\..\doc\faq.txt"
-				>
-			</File>
-			<File
-				RelativePath="..\..\readme.txt"
-				>
-			</File>
-			<File
-				RelativePath="..\..\doc\source.txt"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="B_Bots"
-			>
-			<File
-				RelativePath="..\b_bot.c"
-				>
-			</File>
-			<File
-				RelativePath="..\b_bot.h"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="LUA"
-			>
-			<File
-				RelativePath="..\fastcmp.h"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_baselib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_consolelib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_hook.h"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_hooklib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_hud.h"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_hudlib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_infolib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_libs.h"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_maplib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_mathlib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_mobjlib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_playerlib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_script.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_script.h"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_skinlib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\lua_thinkerlib.c"
-				>
-			</File>
-		</Filter>
-		<Filter
-			Name="BLUA"
-			>
-			<File
-				RelativePath="..\blua\lapi.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lapi.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lauxlib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lauxlib.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lbaselib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lcode.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lcode.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\ldebug.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\ldebug.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\ldo.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\ldo.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\ldump.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lfunc.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lfunc.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lgc.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lgc.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\linit.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\llex.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\llex.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\llimits.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lmem.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lmem.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lobject.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lobject.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lopcodes.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lopcodes.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lparser.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lparser.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lstate.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lstate.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lstring.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lstring.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lstrlib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\ltable.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\ltable.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\ltablib.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\ltm.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\ltm.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lua.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\luaconf.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lualib.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lundump.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lundump.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lvm.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lvm.h"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lzio.c"
-				>
-			</File>
-			<File
-				RelativePath="..\blua\lzio.h"
-				>
-			</File>
-		</Filter>
-		<File
-			RelativePath="Srb2win.ico"
-			>
-		</File>
-	</Files>
-	<Globals>
-	</Globals>
-</VisualStudioProject>
diff --git a/src/win32/Srb2win.dsp b/src/win32/Srb2win.dsp
deleted file mode 100644
index 661f3eaf90bcb354898fd9a4a3b1252c4fee014e..0000000000000000000000000000000000000000
--- a/src/win32/Srb2win.dsp
+++ /dev/null
@@ -1,1008 +0,0 @@
-# Microsoft Developer Studio Project File - Name="Srb2win" - Package Owner=<4>
-# Microsoft Developer Studio Generated Build File, Format Version 6.00
-# ** DO NOT EDIT **
-
-# TARGTYPE "Win32 (x86) Application" 0x0101
-
-CFG=Srb2win - Win32 Debug
-!MESSAGE This is not a valid makefile. To build this project using NMAKE,
-!MESSAGE use the Export Makefile command and run
-!MESSAGE
-!MESSAGE NMAKE /f "Srb2win.mak".
-!MESSAGE
-!MESSAGE You can specify a configuration when running NMAKE
-!MESSAGE by defining the macro CFG on the command line. For example:
-!MESSAGE
-!MESSAGE NMAKE /f "Srb2win.mak" CFG="Srb2win - Win32 Debug"
-!MESSAGE
-!MESSAGE Possible choices for configuration are:
-!MESSAGE
-!MESSAGE "Srb2win - Win32 Release" (based on "Win32 (x86) Application")
-!MESSAGE "Srb2win - Win32 Debug" (based on "Win32 (x86) Application")
-!MESSAGE
-
-# Begin Project
-# PROP AllowPerConfigDependencies 0
-# PROP Scc_ProjName ""
-# PROP Scc_LocalPath ""
-CPP=cl.exe
-MTL=midl.exe
-RSC=rc.exe
-
-!IF  "$(CFG)" == "Srb2win - Win32 Release"
-
-# PROP BASE Use_MFC 0
-# PROP BASE Use_Debug_Libraries 0
-# PROP BASE Output_Dir "..\..\objs\Release"
-# PROP BASE Intermediate_Dir "..\..\objs\Release"
-# PROP BASE Target_Dir ""
-# PROP Use_MFC 0
-# PROP Use_Debug_Libraries 0
-# PROP Output_Dir "..\..\bin\VC\Release\Win32"
-# PROP Intermediate_Dir "..\..\objs\VC\Release\Win32"
-# PROP Ignore_Export_Lib 0
-# PROP Target_Dir ""
-# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /YX /FD /c
-# ADD CPP /nologo /G5 /W3 /GX /Zi /Ot /Og /Oi /Op /Oy /Ob1 /Gy /I "..\..\libs\libpng-src" /I "..\..\libs\zlib" /D "NDEBUG" /D "_WINDOWS" /D "USEASM" /D "HAVE_PNG" /FR /FD /GF /Gs /GF /c
-# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /o "NUL" /win32
-# ADD MTL /nologo /D "NDEBUG" /o "NUL" /win32
-# SUBTRACT MTL /mktyplib203
-# ADD BASE RSC /l 0x40c /d "NDEBUG"
-# ADD RSC /l 0x409 /d "NDEBUG"
-BSC32=bscmake.exe
-# ADD BASE BSC32 /nologo
-# ADD BSC32 /nologo /o"..\..\objs\Release\Srb2win.bsc"
-LINK32=link.exe
-# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:windows /machine:I386
-# ADD LINK32 dxguid.lib user32.lib gdi32.lib winmm.lib advapi32.lib ws2_32.lib dinput.lib /nologo /subsystem:windows /pdb:"C:\srb2demo2\srb2.pdb" /debug /machine:I386 /out:"C:\srb2demo2\srb2win.exe"
-# SUBTRACT LINK32 /profile /pdb:none /incremental:yes /nodefaultlib
-
-!ELSEIF  "$(CFG)" == "Srb2win - Win32 Debug"
-
-# PROP BASE Use_MFC 0
-# PROP BASE Use_Debug_Libraries 1
-# PROP BASE Output_Dir "..\..\objs\Debug"
-# PROP BASE Intermediate_Dir "..\..\objs\Debug"
-# PROP BASE Target_Dir ""
-# PROP Use_MFC 0
-# PROP Use_Debug_Libraries 1
-# PROP Output_Dir "..\..\bin\VC\Debug\Win32"
-# PROP Intermediate_Dir "..\..\objs\VC\Debug\Win32"
-# PROP Ignore_Export_Lib 0
-# PROP Target_Dir ""
-# ADD BASE CPP /nologo /W3 /Gm /GX /Zi /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /YX /FD /c
-# ADD CPP /nologo /G6 /W4 /Gm /GX /ZI /Od /Op /Oy /I "libs\libpng-src" /I "..\..\libs\libpng-src" /I "..\..\libs\zlib" /D "_DEBUG" /D "_WINDOWS" /D "USEASM" /D "HAVE_PNG" /FAcs /FR /FD /c
-# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /o "NUL" /win32
-# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /o "NUL" /win32
-# ADD BASE RSC /l 0x40c /d "_DEBUG"
-# ADD RSC /l 0x409 /d "_DEBUG"
-BSC32=bscmake.exe
-# ADD BASE BSC32 /nologo
-# ADD BSC32 /nologo
-LINK32=link.exe
-# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:windows /debug /machine:I386 /pdbtype:sept
-# ADD LINK32 dxguid.lib user32.lib gdi32.lib winmm.lib advapi32.lib ws2_32.lib dinput.lib /nologo /subsystem:windows /profile /debug /machine:I386 /out:"C:\srb2demo2\srb2debug.exe"
-# SUBTRACT LINK32 /nodefaultlib
-
-!ENDIF
-
-# Begin Target
-
-# Name "Srb2win - Win32 Release"
-# Name "Srb2win - Win32 Debug"
-# Begin Group "Win32app"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=.\afxres.h
-# End Source File
-# Begin Source File
-
-SOURCE=.\dx_error.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\dx_error.h
-# End Source File
-# Begin Source File
-
-SOURCE=.\fabdxlib.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\fabdxlib.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\filesrch.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\filesrch.h
-# End Source File
-# Begin Source File
-
-SOURCE=.\mid2strm.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\mid2strm.h
-# End Source File
-# Begin Source File
-
-SOURCE=.\midstuff.h
-# End Source File
-# Begin Source File
-
-SOURCE=.\resource.h
-# End Source File
-# Begin Source File
-
-SOURCE=.\Srb2win.rc
-
-!IF  "$(CFG)" == "Srb2win - Win32 Release"
-
-# ADD BASE RSC /l 0x40c /i "win32"
-# ADD RSC /l 0x409 /i "win32"
-
-!ELSEIF  "$(CFG)" == "Srb2win - Win32 Debug"
-
-!ENDIF
-
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_cd.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_dbg.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_dbg.h
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_dll.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_dll.h
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_main.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_main.h
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_net.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_snd.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_sys.c
-# End Source File
-# Begin Source File
-
-SOURCE=.\win_vid.c
-# End Source File
-# End Group
-# Begin Group "A_Asm"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\p5prof.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\tmap.nas
-
-!IF  "$(CFG)" == "Srb2win - Win32 Release"
-
-# PROP Ignore_Default_Tool 1
-# Begin Custom Build - Compiling $(InputName).nas with NASM...
-IntDir=.\..\..\objs\VC\Release\Win32
-InputPath=..\tmap.nas
-InputName=tmap
-
-"$(IntDir)/$(InputName).obj" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
-	nasm -g -o $(IntDir)/$(InputName).obj -f win32 $(InputPath)
-
-# End Custom Build
-
-!ELSEIF  "$(CFG)" == "Srb2win - Win32 Debug"
-
-# PROP Ignore_Default_Tool 1
-# Begin Custom Build - Compiling $(InputName).nas with NASM...
-IntDir=.\..\..\objs\VC\Debug\Win32
-InputPath=..\tmap.nas
-InputName=tmap
-
-"$(IntDir)/$(InputName).obj" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
-	nasm -g -o $(IntDir)/$(InputName).obj -f win32 $(InputPath)
-
-# End Custom Build
-
-!ENDIF
-
-# End Source File
-# Begin Source File
-
-SOURCE=..\tmap_mmx.nas
-
-!IF  "$(CFG)" == "Srb2win - Win32 Release"
-
-# PROP Ignore_Default_Tool 1
-# Begin Custom Build - Compiling $(InputName).nas with NASM...
-IntDir=.\..\..\objs\VC\Release\Win32
-InputPath=..\tmap_mmx.nas
-InputName=tmap_mmx
-
-"$(IntDir)/$(InputName).obj" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
-	nasm -g -o $(IntDir)/$(InputName).obj -f win32 $(InputPath)
-
-# End Custom Build
-
-!ELSEIF  "$(CFG)" == "Srb2win - Win32 Debug"
-
-# PROP Ignore_Default_Tool 1
-# Begin Custom Build - Compiling $(InputName).nas with NASM...
-IntDir=.\..\..\objs\VC\Debug\Win32
-InputPath=..\tmap_mmx.nas
-InputName=tmap_mmx
-
-"$(IntDir)/$(InputName).obj" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
-	nasm -g -o $(IntDir)/$(InputName).obj -f win32 $(InputPath)
-
-# End Custom Build
-
-!ENDIF
-
-# End Source File
-# Begin Source File
-
-SOURCE=..\tmap_vc.nas
-
-!IF  "$(CFG)" == "Srb2win - Win32 Release"
-
-# Begin Custom Build - Compiling $(InputName).nas with NASM...
-IntDir=.\..\..\objs\VC\Release\Win32
-InputPath=..\tmap_vc.nas
-InputName=tmap_vc
-
-"$(IntDir)/$(InputName).obj" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
-	nasm -g -o $(IntDir)/$(InputName).obj -f win32 $(InputPath)
-
-# End Custom Build
-
-!ELSEIF  "$(CFG)" == "Srb2win - Win32 Debug"
-
-# PROP Ignore_Default_Tool 1
-# Begin Custom Build - Compiling $(InputName).nas with NASM...
-IntDir=.\..\..\objs\VC\Debug\Win32
-InputPath=..\tmap_vc.nas
-InputName=tmap_vc
-
-"$(IntDir)/$(InputName).obj" : $(SOURCE) "$(INTDIR)" "$(OUTDIR)"
-	nasm -g -o $(IntDir)/$(InputName).obj -f win32 $(InputPath)
-
-# End Custom Build
-
-!ENDIF
-
-# End Source File
-# End Group
-# Begin Group "D_Doom"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\comptime.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_clisrv.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_clisrv.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_event.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_main.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_main.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_net.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_net.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_netcmd.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_netcmd.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_netfil.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_netfil.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_player.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_think.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\d_ticcmd.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\dehacked.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\dehacked.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\doomdata.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\doomdef.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\doomstat.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\doomtype.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\z_zone.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\z_zone.h
-# End Source File
-# End Group
-# Begin Group "F_Frame"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\f_finale.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\f_finale.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\f_wipe.c
-# End Source File
-# End Group
-# Begin Group "G_Game"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\g_game.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\g_game.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\g_input.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\g_input.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\g_state.h
-# End Source File
-# End Group
-# Begin Group "H_Hud"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\am_map.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\am_map.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\command.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\command.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\console.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\console.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hu_stuff.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\hu_stuff.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\st_stuff.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\st_stuff.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\y_inter.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\y_inter.h
-# End Source File
-# End Group
-# Begin Group "Hw_Hardware"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\hardware\hw3dsdrv.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw3sound.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw3sound.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_bsp.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_cache.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_data.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_defs.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_dll.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_draw.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_drv.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_glob.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_light.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_light.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_main.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_main.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_md2.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hw_md2.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\hardware\hws_data.h
-# End Source File
-# End Group
-# Begin Group "I_Interface"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\byteptr.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\i_joy.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\i_net.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\i_sound.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\i_system.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\i_tcp.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\i_tcp.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\i_video.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\keys.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\mserv.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\mserv.h
-# End Source File
-# End Group
-# Begin Group "M_Misc"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\m_argv.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_argv.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_bbox.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_bbox.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_cheat.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_cheat.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_dllist.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_fixed.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_fixed.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_menu.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_menu.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_misc.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_misc.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_queue.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_queue.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_random.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_random.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\m_swap.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\string.c
-# End Source File
-# End Group
-# Begin Group "P_Play"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\info.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\info.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_ceilng.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_enemy.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_fab.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_floor.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_inter.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_lights.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_local.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_map.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_maputl.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_maputl.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_mobj.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_mobj.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_polyobj.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_polyobj.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_pspr.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_saveg.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_saveg.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_setup.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_setup.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_sight.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_spec.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_spec.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_telept.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_tick.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_tick.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\p_user.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\tables.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\tables.h
-# End Source File
-# End Group
-# Begin Group "R_Rend"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\r_bsp.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_bsp.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_data.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_data.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_defs.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_draw.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_draw.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_draw16.c
-# PROP Exclude_From_Build 1
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_draw8.c
-# PROP Exclude_From_Build 1
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_local.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_main.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_main.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_plane.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_plane.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_segs.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_segs.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_sky.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_sky.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_splats.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_splats.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_state.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_things.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\r_things.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\screen.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\screen.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\v_video.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\v_video.h
-# End Source File
-# End Group
-# Begin Group "S_Sounds"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\s_sound.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\s_sound.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\sounds.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\sounds.h
-# End Source File
-# End Group
-# Begin Group "W_Wad"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\lzf.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\lzf.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\md5.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\md5.h
-# End Source File
-# Begin Source File
-
-SOURCE=..\w_wad.c
-# End Source File
-# Begin Source File
-
-SOURCE=..\w_wad.h
-# End Source File
-# End Group
-# Begin Group "Docs"
-
-# PROP Default_Filter ""
-# Begin Source File
-
-SOURCE=..\..\doc\copying
-# End Source File
-# Begin Source File
-
-SOURCE=..\..\doc\faq.txt
-# End Source File
-# Begin Source File
-
-SOURCE=..\..\readme.txt
-# End Source File
-# Begin Source File
-
-SOURCE=..\..\doc\source.txt
-# End Source File
-# End Group
-# Begin Source File
-
-SOURCE=.\Srb2win.ico
-# End Source File
-# End Target
-# End Project
diff --git a/src/win32/Srb2win.dsw b/src/win32/Srb2win.dsw
deleted file mode 100644
index f2099814216df91dbad38161845fe5112df61c27..0000000000000000000000000000000000000000
--- a/src/win32/Srb2win.dsw
+++ /dev/null
@@ -1,77 +0,0 @@
-Microsoft Developer Studio Workspace File, Format Version 6.00
-# WARNING: DO NOT EDIT OR DELETE THIS WORKSPACE FILE!
-
-###############################################################################
-
-Project: "Srb2win"=.\Srb2win.dsp - Package Owner=<4>
-
-Package=<5>
-{{{
-}}}
-
-Package=<4>
-{{{
-    Begin Project Dependency
-    Project_Dep_Name libpng
-    End Project Dependency
-    Begin Project Dependency
-    Project_Dep_Name zlib
-    End Project Dependency
-}}}
-
-###############################################################################
-
-Project: "libpng"="..\..\libs\libpng-src\projects\visualc6\libpng.dsp" - Package Owner=<4>
-
-Package=<5>
-{{{
-}}}
-
-Package=<4>
-{{{
-    Begin Project Dependency
-    Project_Dep_Name zlib
-    End Project Dependency
-}}}
-
-###############################################################################
-
-Project: "r_opengl"=..\hardware\r_opengl\r_opengl.dsp - Package Owner=<4>
-
-Package=<5>
-{{{
-}}}
-
-Package=<4>
-{{{
-    Begin Project Dependency
-    Project_Dep_Name Srb2win
-    End Project Dependency
-}}}
-
-###############################################################################
-
-Project: "zlib"=..\..\libs\zlib\projects\visualc6\zlib.dsp - Package Owner=<4>
-
-Package=<5>
-{{{
-}}}
-
-Package=<4>
-{{{
-}}}
-
-###############################################################################
-
-Global:
-
-Package=<5>
-{{{
-}}}
-
-Package=<3>
-{{{
-}}}
-
-###############################################################################
-
diff --git a/src/win32/Srb2win.props b/src/win32/Srb2win.props
deleted file mode 100644
index fa152f0c97aa6894c289eadb388cb7b33fb153d2..0000000000000000000000000000000000000000
--- a/src/win32/Srb2win.props
+++ /dev/null
@@ -1,19 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
-  <ImportGroup Label="PropertySheets" />
-  <PropertyGroup Label="UserMacros" />
-  <PropertyGroup />
-  <ItemDefinitionGroup>
-    <ClCompile>
-      <!-- x86/x64 defines: has specific libraries that ARM does not -->
-      <PreprocessorDefinitions Condition="'$(Platform)' == 'Win32' OR '$(Platform)' == 'x64'">HAVE_ZLIB;HAVE_LIBGME;_WINDOWS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-      <!-- ARM defines -->
-      <PreprocessorDefinitions Condition="'$(Platform)' != 'Win32' AND '$(Platform)' != 'x64'">_WINDOWS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-    </ClCompile>
-    <Link />
-    <Link>
-      <AdditionalDependencies>dxguid.lib;winmm.lib;dinput8.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-  </ItemDefinitionGroup>
-  <ItemGroup />
-</Project>
\ No newline at end of file
diff --git a/src/win32/dx_error.c b/src/win32/dx_error.c
deleted file mode 100644
index 8e14539a3d5154631c41acb294e071cf5188f1b9..0000000000000000000000000000000000000000
--- a/src/win32/dx_error.c
+++ /dev/null
@@ -1,276 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief DirectX error messages
-///	adapted from DirectX6 sample code
-
-#include <stdarg.h>
-
-//#define WIN32_LEAN_AND_MEAN
-#define RPC_NO_WINDOWS_H
-#include <windows.h>
-#define DIRECTSOUND_VERSION     0x0600       /* version 6.0 */
-#define DXVERSION_NTCOMPATIBLE  0x0300
-#ifdef _MSC_VER
-#pragma warning(disable :  4201)
-#endif
-#include <ddraw.h>
-#include <dsound.h>
-#include <mmsystem.h>
-
-#include "dx_error.h"
-
-// -----------------
-// DXErrorMessageBox
-// Displays a message box containing the given formatted string.
-// -----------------
-/*
-VOID DXErrorMessageBox (HRESULT error) LPSTR fmt, ...)
-{
-	char buff[256];
-	va_list args;
-
-	va_start(args, fmt);
-	wvsprintf(buff, fmt, args);
-	va_end(args);
-
-	lstrcat(buff, "\r\n");
-	MessageBoxA(NULL, buff, "DirectX Error:", MB_ICONEXCLAMATION + MB_OK);
-}*/
-
-
-// ---------------
-// DXErrorToString
-// Returns a pointer to a string describing the given DD, D3D or D3DRM error code.
-// ---------------
-LPCSTR DXErrorToString (HRESULT error)
-{
-	switch (error) {
-		case DD_OK:
-			/* Also includes D3D_OK and D3DRM_OK */
-			return "No error.";
-		case DDERR_ALREADYINITIALIZED:
-			return "This object is already initialized.";
-		case DDERR_BLTFASTCANTCLIP:
-			return "Return if a clipper object is attached to the source surface passed into a BltFast call.";
-		case DDERR_CANNOTATTACHSURFACE:
-			return "This surface can not be attached to the requested surface.";
-		case DDERR_CANNOTDETACHSURFACE:
-			return "This surface can not be detached from the requested surface.";
-		case DDERR_CANTCREATEDC:
-			return "Windows can not create any more DCs.";
-		case DDERR_CANTDUPLICATE:
-			return "Can't duplicate primary & 3D surfaces, or surfaces that are implicitly created.";
-		case DDERR_CLIPPERISUSINGHWND:
-			return "An attempt was made to set a cliplist for a clipper object that is already monitoring an hwnd.";
-		case DDERR_COLORKEYNOTSET:
-			return "No src color key specified for this operation.";
-		case DDERR_CURRENTLYNOTAVAIL:
-			return "Support is currently not available.";
-		case DDERR_DIRECTDRAWALREADYCREATED:
-			return "A DirectDraw object representing this driver has already been created for this process.";
-		case DDERR_EXCEPTION:
-			return "An exception was encountered while performing the requested operation.";
-		case DDERR_EXCLUSIVEMODEALREADYSET:
-			return "An attempt was made to set the cooperative level when it was already set to exclusive.";
-		case DDERR_GENERIC:
-			return "Generic failure.";
-		case DDERR_HEIGHTALIGN:
-			return "Height of rectangle provided is not a multiple of reqd alignment.";
-		case DDERR_HWNDALREADYSET:
-			return "The CooperativeLevel HWND has already been set. It can not be reset while the process has surfaces or palettes created.";
-		case DDERR_HWNDSUBCLASSED:
-			return "HWND used by DirectDraw CooperativeLevel has been subclassed, this prevents DirectDraw from restoring state.";
-		case DDERR_IMPLICITLYCREATED:
-			return "This surface can not be restored because it is an implicitly created surface.";
-		case DDERR_INCOMPATIBLEPRIMARY:
-			return "Unable to match primary surface creation request with existing primary surface.";
-		case DDERR_INVALIDCAPS:
-			return "One or more of the caps bits passed to the callback are incorrect.";
-		case DDERR_INVALIDCLIPLIST:
-			return "DirectDraw does not support the provided cliplist.";
-		case DDERR_INVALIDDIRECTDRAWGUID:
-			return "The GUID passed to DirectDrawCreate is not a valid DirectDraw driver identifier.";
-		case DDERR_INVALIDMODE:
-			return "DirectDraw does not support the requested mode.";
-		case DDERR_INVALIDOBJECT:
-			return "DirectDraw received a pointer that was an invalid DIRECTDRAW object.";
-		case DDERR_INVALIDPARAMS:
-			return "One or more of the parameters passed to the function are incorrect.";
-		case DDERR_INVALIDPIXELFORMAT:
-			return "The pixel format was invalid as specified.";
-		case DDERR_INVALIDPOSITION:
-			return "Returned when the position of the overlay on the destination is no longer legal for that destination.";
-		case DDERR_INVALIDRECT:
-			return "Rectangle provided was invalid.";
-		case DDERR_LOCKEDSURFACES:
-			return "Operation could not be carried out because one or more surfaces are locked.";
-		case DDERR_NO3D:
-			return "There is no 3D present.";
-		case DDERR_NOALPHAHW:
-			return "Operation could not be carried out because there is no alpha accleration hardware present or available.";
-		case DDERR_NOBLTHW:
-			return "No blitter hardware present.";
-		case DDERR_NOCLIPLIST:
-			return "No cliplist available.";
-		case DDERR_NOCLIPPERATTACHED:
-			return "No clipper object attached to surface object.";
-		case DDERR_NOCOLORCONVHW:
-			return "Operation could not be carried out because there is no color conversion hardware present or available.";
-		case DDERR_NOCOLORKEY:
-			return "Surface doesn't currently have a color key";
-		case DDERR_NOCOLORKEYHW:
-			return "Operation could not be carried out because there is no hardware support of the destination color key.";
-		case DDERR_NOCOOPERATIVELEVELSET:
-			return "Create function called without DirectDraw object method SetCooperativeLevel being called.";
-		case DDERR_NODC:
-			return "No DC was ever created for this surface.";
-		case DDERR_NODDROPSHW:
-			return "No DirectDraw ROP hardware.";
-		case DDERR_NODIRECTDRAWHW:
-			return "A hardware-only DirectDraw object creation was attempted but the driver did not support any hardware.";
-		case DDERR_NOEMULATION:
-			return "Software emulation not available.";
-		case DDERR_NOEXCLUSIVEMODE:
-			return "Operation requires the application to have exclusive mode but the application does not have exclusive mode.";
-		case DDERR_NOFLIPHW:
-			return "Flipping visible surfaces is not supported.";
-		case DDERR_NOGDI:
-			return "There is no GDI present.";
-		case DDERR_NOHWND:
-			return "Clipper notification requires an HWND or no HWND has previously been set as the CooperativeLevel HWND.";
-		case DDERR_NOMIRRORHW:
-			return "Operation could not be carried out because there is no hardware present or available.";
-		case DDERR_NOOVERLAYDEST:
-			return "Returned when GetOverlayPosition is called on an overlay that UpdateOverlay has never been called on to establish a destination.";
-		case DDERR_NOOVERLAYHW:
-			return "Operation could not be carried out because there is no overlay hardware present or available.";
-		case DDERR_NOPALETTEATTACHED:
-			return "No palette object attached to this surface.";
-		case DDERR_NOPALETTEHW:
-			return "No hardware support for 16 or 256 color palettes.";
-		case DDERR_NORASTEROPHW:
-			return "Operation could not be carried out because there is no appropriate raster op hardware present or available.";
-		case DDERR_NOROTATIONHW:
-			return "Operation could not be carried out because there is no rotation hardware present or available.";
-		case DDERR_NOSTRETCHHW:
-			return "Operation could not be carried out because there is no hardware support for stretching.";
-		case DDERR_NOT4BITCOLOR:
-			return "DirectDrawSurface is not in 4 bit color palette and the requested operation requires 4 bit color palette.";
-		case DDERR_NOT4BITCOLORINDEX:
-			return "DirectDrawSurface is not in 4 bit color index palette and the requested operation requires 4 bit color index palette.";
-		case DDERR_NOT8BITCOLOR:
-			return "DirectDrawSurface is not in 8 bit color mode and the requested operation requires 8 bit color.";
-		case DDERR_NOTAOVERLAYSURFACE:
-			return "Returned when an overlay member is called for a non-overlay surface.";
-		case DDERR_NOTEXTUREHW:
-			return "Operation could not be carried out because there is no texture mapping hardware present or available.";
-		case DDERR_NOTFLIPPABLE:
-			return "An attempt has been made to flip a surface that is not flippable.";
-		case DDERR_NOTFOUND:
-			return "Requested item was not found.";
-		case DDERR_NOTLOCKED:
-			return "Surface was not locked.  An attempt to unlock a surface that was not locked at all, or by this process, has been attempted.";
-		case DDERR_NOTPALETTIZED:
-			return "The surface being used is not a palette-based surface.";
-		case DDERR_NOVSYNCHW:
-			return "Operation could not be carried out because there is no hardware support for vertical blank synchronized operations.";
-		case DDERR_NOZBUFFERHW:
-			return "Operation could not be carried out because there is no hardware support for zbuffer blitting.";
-		case DDERR_NOZOVERLAYHW:
-			return "Overlay surfaces could not be z layered based on their BltOrder because the hardware does not support z layering of overlays.";
-		case DDERR_OUTOFCAPS:
-			return "The hardware needed for the requested operation has already been allocated.";
-		case DDERR_OUTOFMEMORY:
-			return "There is not enough memory to perform the operation.";
-		case DDERR_OUTOFVIDEOMEMORY:
-			return "DirectDraw does not have enough memory to perform the operation.";
-		case DDERR_OVERLAYCANTCLIP:
-			return "The hardware does not support clipped overlays.";
-		case DDERR_OVERLAYCOLORKEYONLYONEACTIVE:
-			return "Can only have ony color key active at one time for overlays.";
-		case DDERR_OVERLAYNOTVISIBLE:
-			return "Returned when GetOverlayPosition is called on a hidden overlay.";
-		case DDERR_PALETTEBUSY:
-			return "Access to this palette is being refused because the palette is already locked by another thread.";
-		case DDERR_PRIMARYSURFACEALREADYEXISTS:
-			return "This process already has created a primary surface.";
-		case DDERR_REGIONTOOSMALL:
-			return "Region passed to Clipper::GetClipList is too small.";
-		case DDERR_SURFACEALREADYATTACHED:
-			return "This surface is already attached to the surface it is being attached to.";
-		case DDERR_SURFACEALREADYDEPENDENT:
-			return "This surface is already a dependency of the surface it is being made a dependency of.";
-		case DDERR_SURFACEBUSY:
-			return "Access to this surface is being refused because the surface is already locked by another thread.";
-		case DDERR_SURFACEISOBSCURED:
-			return "Access to surface refused because the surface is obscured.";
-		case DDERR_SURFACELOST:
-			return "Access to this surface is being refused because the surface memory is gone. The DirectDrawSurface object representing this surface should have Restore called on it.";
-		case DDERR_SURFACENOTATTACHED:
-			return "The requested surface is not attached.";
-		case DDERR_TOOBIGHEIGHT:
-			return "Height requested by DirectDraw is too large.";
-		case DDERR_TOOBIGSIZE:
-			return "Size requested by DirectDraw is too large, but the individual height and width are OK.";
-		case DDERR_TOOBIGWIDTH:
-			return "Width requested by DirectDraw is too large.";
-		case DDERR_UNSUPPORTED:
-			return "Function call not supported.";
-		case DDERR_UNSUPPORTEDFORMAT:
-			return "FOURCC format requested is unsupported by DirectDraw.";
-		case DDERR_UNSUPPORTEDMASK:
-			return "Bitmask in the pixel format requested is unsupported by DirectDraw.";
-		case DDERR_VERTICALBLANKINPROGRESS:
-			return "Vertical blank is in progress.";
-		case DDERR_WASSTILLDRAWING:
-			return "Informs DirectDraw that the previous Blt which is transfering information to or from this Surface is incomplete.";
-		case DDERR_WRONGMODE:
-			return "This surface can not be restored because it was created in a different mode.";
-		case DDERR_XALIGN:
-			return "Rectangle provided was not horizontally aligned on required boundary.";
-
-		//
-		// DirectSound errors
-		//
-		case DSERR_ALLOCATED:
-			return "The request failed because resources, such as a priority level, were already in use by another caller.";
-		case DSERR_ALREADYINITIALIZED:
-			return "The object is already initialized.";
-		case DSERR_BADFORMAT:
-			return "The specified wave format is not supported.";
-		case DSERR_BUFFERLOST:
-			return "The buffer memory has been lost and must be restored.";
-		case DSERR_CONTROLUNAVAIL:
-			return "The control (volume, pan, and so forth) requested by the caller is not available.";
-		case DSERR_INVALIDCALL:
-			return "This function is not valid for the current state of this object.";
-		case DSERR_NOAGGREGATION:
-			return "The object does not support aggregation.";
-		case DSERR_NODRIVER:
-			return "No sound driver is available for use.";
-		case DSERR_NOINTERFACE:
-			return "The requested COM interface is not available.";
-		case DSERR_OTHERAPPHASPRIO:
-			return "Another application has a higher priority level, preventing this call from succeeding";
-		case DSERR_PRIOLEVELNEEDED:
-			return "The caller does not have the priority level required for the function to succeed.";
-		case DSERR_UNINITIALIZED:
-			return "The IDirectSound::Initialize method has not been called or has not been called successfully before other methods were called.";
-		default:
-			return "Unrecognized error value.";
-	}
-}
diff --git a/src/win32/dx_error.h b/src/win32/dx_error.h
deleted file mode 100644
index 3af4220de75470b05f16d43e6c2acd9f41b170e3..0000000000000000000000000000000000000000
--- a/src/win32/dx_error.h
+++ /dev/null
@@ -1,39 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief transform an unreadable DirectX error code
-///	into a meaningful error message.
-
-#ifndef __DX_ERROR_H__
-#define __DX_ERROR_H__
-
-//#define WIN32_LEAN_AND_MEAN
-#include <windows.h>
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-// Displays a message box containing the given formatted string.
-//VOID DXErrorMessageBox (LPSTR fmt, ...);
-
-// Returns a pointer to a string describing the given DD, D3D or D3DRM error code.
-LPCSTR DXErrorToString (HRESULT error);
-
-#ifdef __cplusplus
-};
-#endif
-#endif // __DX_ERROR_H__
diff --git a/src/win32/fabdxlib.c b/src/win32/fabdxlib.c
deleted file mode 100644
index 45ec5d0d321914916d8137204ac26e3a0377bba4..0000000000000000000000000000000000000000
--- a/src/win32/fabdxlib.c
+++ /dev/null
@@ -1,677 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief faB's DirectX library v1.0
-///	- converted to C for Doom Legacy
-
-#include "../doomdef.h"
-
-#ifdef _WINDOWS
-
-//#define WIN32_LEAN_AND_MEAN
-#define RPC_NO_WINDOWS_H
-#include <windows.h>
-#include <windowsx.h>
-#include "../i_system.h"
-#include "dx_error.h"
-
-#include "fabdxlib.h"
-
-#define NT4COMPAT   //always defined, always compatible
-
-
-// globals
-
-IDirectDraw2*              DDr2 = NULL;
-IDirectDrawSurface*        ScreenReal = NULL;    // DirectDraw primary surface
-IDirectDrawSurface*        ScreenVirtual = NULL; // DirectDraw back surface
-IDirectDrawPalette*        DDPalette = NULL;     // The primary surface palette
-static IDirectDrawClipper *windclip = NULL;      // clipper for windowed mode
-
-BOOL                       bAppFullScreen;       // true for fullscreen exclusive mode,
-
-int                        windowPosX = 0;       // current position in windowed mode
-int                        windowPosY = 0;
-
-int                        ScreenWidth;
-int                        ScreenHeight;
-BOOL                       ScreenLocked;         // Screen surface is being locked
-int                        ScreenPitch;          // offset from one line to the next
-LPBYTE                     ScreenPtr;            // memory of the surface
-
-
-//
-// CreateNewSurface
-//
-static inline IDirectDrawSurface* CreateNewSurface(int dwWidth,
-                                                   int dwHeight,
-                                                   int dwSurfaceCaps)
-{
-	DDSURFACEDESC       ddsd;
-	HRESULT             hr;
-	LPDIRECTDRAWSURFACE psurf;
-
-	ZeroMemory(&ddsd, sizeof (ddsd));
-	ddsd.dwSize = sizeof (ddsd);
-	ddsd.dwFlags = DDSD_CAPS | DDSD_HEIGHT |DDSD_WIDTH;
-
-	ddsd.ddsCaps.dwCaps = dwSurfaceCaps;
-
-	ddsd.dwHeight = dwHeight;
-	ddsd.dwWidth = dwWidth;
-
-	hr = IDirectDraw2_CreateSurface (DDr2, &ddsd, &psurf, NULL);
-
-	if (hr == DD_OK)
-	{
-		//DDCOLORKEY ddck;
-		IDirectDrawSurface_Restore(psurf);
-
-		//hr = IDirectDrawSurface_GetColorKey(DDCKEY_SRCBLT, &ddck);
-		//psurf->SetColorKey(DDCKEY_SRCBLT, &ddck);
-	}
-	else
-		psurf = NULL;
-
-	return psurf;
-}
-
-//
-// wow! from 320x200x8 up to 1600x1200x32 thanks Banshee! :)
-//
-static HRESULT WINAPI myEnumModesCallback (LPDDSURFACEDESC surf, LPVOID lpContext)
-{
-	APPENUMMODESCALLBACK pfnContext = lpContext;
-
-	if (pfnContext) pfnContext(surf->dwWidth,
-		surf->dwHeight,surf->ddpfPixelFormat.
-#ifdef DUMMYUNIONNAMEN
-		DUMMYUNIONNAMEN(1).
-#endif
-		dwRGBBitCount
-		);
-
-		/*I_OutputMsg("%dx%dx%d bpp %d refresh\n",
-		surf->dwWidth,
-		surf->dwHeight,
-		surf->ddpfPixelFormat.dwRGBBitCount,
-	surf->dwRefreshRate);*/
-
-	return  DDENUMRET_OK;
-}
-
-
-//
-// Application call here to enumerate display modes
-//
-BOOL EnumDirectDrawDisplayModes (APPENUMMODESCALLBACK appFunc)
-{
-	LPVOID lpappFunc = appFunc;
-
-	if (DDr2 == NULL)
-		return FALSE;
-
-	// enumerate display modes
-	// Carl: DirectX 3.x apparently does not support VGA modes. Who cares. :)
-	// faB: removed DDEDM_REFRESHRATES, detects too many modes, plus we don't care of refresh rate.
-	if (bDX0300)
-		IDirectDraw2_EnumDisplayModes (DDr2, 0 /*| DDEDM_REFRESHRATES*/,
-		                               NULL, lpappFunc, myEnumModesCallback);
-	else
-		IDirectDraw2_EnumDisplayModes (DDr2, DDEDM_STANDARDVGAMODES /*| DDEDM_REFRESHRATES*/,
-		                               NULL, lpappFunc, myEnumModesCallback);
-	return TRUE;
-}
-
-static HINSTANCE DDrawDLL = NULL;
-typedef HRESULT(WINAPI *DDCreate)(GUID FAR *lpGUID, LPDIRECTDRAW FAR *lplpDD, IUnknown FAR *pUnkOuter);
-static DDCreate pfnDirectDrawCreate = NULL;
-
-static inline BOOL LoadDirectDraw(VOID)
-{
-	// load ddraw.dll
-	DDrawDLL = LoadLibraryA("DDRAW.DLL");
-	if (DDrawDLL == NULL)
-		return false;
-	pfnDirectDrawCreate = (DDCreate)(LPVOID)GetProcAddress(DDrawDLL, "DirectDrawCreate");
-	if (pfnDirectDrawCreate == NULL)
-		return false;
-	return true;
-}
-
-static inline VOID UnLoadDirectDraw(VOID)
-{
-	if (!DDrawDLL)
-		return;
-	FreeLibrary(DDrawDLL);
-	pfnDirectDrawCreate = NULL;
-	DDrawDLL = NULL;
-}
-
-//
-// Create the DirectDraw object for later
-//
-BOOL CreateDirectDrawInstance (VOID)
-{
-	HRESULT hr;
-	IDirectDraw* DDr;
-	IDirectDraw** rp = &DDr;
-	IDirectDraw2** rp2 = &DDr2;
-	LPVOID *tp = (LPVOID *)rp2;
-
-	if (!LoadDirectDraw())
-		return FALSE;
-	//
-	// create an instance of DirectDraw object
-	//
-	if (FAILED(hr = pfnDirectDrawCreate(NULL, rp, NULL)))
-		I_Error("DirectDrawCreate FAILED: %s", DXErrorToString(hr));
-
-	// change interface to IDirectDraw2
-	if (FAILED(hr = IDirectDraw_QueryInterface(DDr, &IID_IDirectDraw2, tp)))
-		I_Error("Failed to query DirectDraw2 interface: %s", DXErrorToString(hr));
-
-	// release the interface we don't need
-	IDirectDraw_Release (DDr);
-	return TRUE;
-}
-
-
-//
-// - returns true if DirectDraw was initialized properly
-//
-int  InitDirectDrawe (HWND appWin, int width, int height, int bpp, int fullScr)
-{
-	DDSURFACEDESC ddsd; // DirectDraw surface description for allocating
-	DDSCAPS       ddscaps;
-	HRESULT       ddrval;
-
-	DWORD         dwStyle;
-	RECT          rect;
-
-	// enumerate directdraw devices
-	//if (FAILED(DirectDrawEnumerate (myEnumDDDevicesCallback, NULL)))
-	//      I_Error("Error with DirectDrawEnumerate");
-
-	if (!DDr2)
-		CreateDirectDrawInstance();
-
-	// remember what screen mode we are in
-	bAppFullScreen = fullScr;
-	ScreenHeight = height;
-	ScreenWidth = width;
-
-	if (bAppFullScreen)
-	{
-		// Change window attributes
-		dwStyle = WS_POPUP | WS_VISIBLE;
-		SetWindowLong (appWin, GWL_STYLE, dwStyle);
-		SetWindowPos(appWin, HWND_TOPMOST, 0, 0, 0, 0, SWP_NOACTIVATE |
-			SWP_NOMOVE | SWP_NOSIZE | SWP_NOZORDER);
-
-		// Get exclusive mode
-		ddrval = IDirectDraw2_SetCooperativeLevel(DDr2, appWin, DDSCL_EXCLUSIVE |
-		                                          DDSCL_FULLSCREEN |
-		                                          DDSCL_ALLOWREBOOT);
-		if (ddrval != DD_OK)
-			I_Error("SetCooperativeLevel FAILED: %s\n", DXErrorToString(ddrval));
-
-		// Switch from windows desktop to fullscreen
-
-#ifdef NT4COMPAT
-		ddrval = IDirectDraw2_SetDisplayMode(DDr2, width, height, bpp, 0, 0);
-#else
-		ddrval = IDirectDraw2_SetDisplayMode(DDr2, width, height, bpp, 0, DDSDM_STANDARDVGAMODE);
-#endif
-		if (ddrval != DD_OK)
-			I_Error("SetDisplayMode FAILED: %s\n", DXErrorToString(ddrval));
-
-		// This is not really needed, except in certain cases. One case
-		// is while using MFC. When the desktop is initally at 16bpp, a mode
-		// switch to 8bpp somehow causes the MFC window to not fully initialize
-		// and a CreateSurface will fail with DDERR_NOEXCLUSIVEMODE. This will
-		// ensure that the window is initialized properly after a mode switch.
-
-		ShowWindow(appWin, SW_SHOW);
-
-		// Create the primary surface with 1 back buffer. Always zero the
-		// DDSURFACEDESC structure and set the dwSize member!
-
-		ZeroMemory(&ddsd, sizeof (ddsd));
-		ddsd.dwSize = sizeof (ddsd);
-		ddsd.dwFlags = DDSD_CAPS | DDSD_BACKBUFFERCOUNT;
-		ddsd.ddsCaps.dwCaps = DDSCAPS_PRIMARYSURFACE | DDSCAPS_FLIP | DDSCAPS_COMPLEX;
-
-		// for fullscreen we use page flipping, for windowed mode, we blit the hidden surface to
-		// the visible surface, in both cases we have a visible (or 'real') surface, and a hidden
-		// (or 'virtual', or 'backbuffer') surface.
-		ddsd.dwBackBufferCount = 2;
-
-		ddrval = IDirectDraw2_CreateSurface(DDr2,&ddsd, &ScreenReal, NULL);
-		if (ddrval != DD_OK)
-			I_Error("CreateSurface Primary Screen FAILED");
-
-		// Get a pointer to the back buffer
-
-		ddscaps.dwCaps = DDSCAPS_BACKBUFFER;
-		ddrval = IDirectDrawSurface_GetAttachedSurface(ScreenReal,&ddscaps, &ScreenVirtual);
-		if (ddrval != DD_OK)
-			I_Error("GetAttachedSurface FAILED");
-	}
-	else
-	{
-		rect.top = 0;
-		rect.left = 0;
-		rect.bottom = height;
-		rect.right = width;
-
-		// Change window attributes
-
-		dwStyle = GetWindowStyle(appWin);
-		dwStyle &= ~WS_POPUP;
-		dwStyle |= WS_OVERLAPPED | WS_SYSMENU | WS_CAPTION;
-
-		SetWindowLong(appWin, GWL_STYLE, dwStyle);
-
-		// Resize the window so that the client area is the requested width/height
-
-		AdjustWindowRectEx(&rect, GetWindowStyle(appWin), GetMenu(appWin) != NULL,
-		                   GetWindowExStyle(appWin));
-
-		// Just in case the window was moved off the visible area of the
-		// screen.
-
-		SetWindowPos(appWin, NULL, 0, 0, rect.right-rect.left,
-		             rect.bottom-rect.top, SWP_NOMOVE | SWP_NOZORDER |
-		             SWP_NOACTIVATE);
-
-		SetWindowPos(appWin, HWND_NOTOPMOST, 0, 0, 0, 0,
-		             SWP_NOSIZE | SWP_NOMOVE | SWP_NOACTIVATE);
-
-		// Exclusive mode is normal since it's in windowed mode and needs
-		// to cooperate with GDI
-
-		ddrval = IDirectDraw2_SetCooperativeLevel(DDr2,appWin, DDSCL_NORMAL);
-		if (ddrval != DD_OK)
-			I_Error("SetCooperativeLevel FAILED");
-
-		// Always zero the DDSURFACEDESC structure and set the dwSize member!
-
-		ZeroMemory(&ddsd, sizeof (ddsd));
-		ddsd.dwSize = sizeof (ddsd);
-		ddsd.dwFlags = DDSD_CAPS;
-		ddsd.ddsCaps.dwCaps = DDSCAPS_PRIMARYSURFACE;
-
-		// Create the primary surface
-
-		ddrval = IDirectDraw2_CreateSurface(DDr2,&ddsd, &ScreenReal, NULL);
-		if (ddrval != DD_OK)
-			I_Error("CreateSurface Primary Screen FAILED");
-
-		// Create a back buffer for offscreen rendering, this will be used to
-		// blt to the primary
-
-		ScreenVirtual = CreateNewSurface(width, height, DDSCAPS_OFFSCREENPLAIN |
-		                                 DDSCAPS_SYSTEMMEMORY);
-		if (ScreenVirtual == NULL)
-			I_Error("CreateSurface Secondary Screen FAILED");
-
-		/// \todo get the desktop bit depth, and build a lookup table
-		/// for quick conversions of 8bit color indexes 0-255 to desktop colors
-		/// eg: 256 entries of equivalent of palette colors 0-255 in 15,16,24,32 bit format
-		/// when blit virtual to real, convert pixels through lookup table..
-
-		// Use a clipper object for clipping when in windowed mode
-		// (make sure our drawing doesn't affect other windows)
-
-		ddrval = IDirectDraw2_CreateClipper (DDr2, 0, &windclip, 0);
-		if (ddrval != DD_OK)
-			I_Error("CreateClipper FAILED");
-
-		// Associate the clipper with the window.
-		ddrval = IDirectDrawClipper_SetHWnd (windclip,0, appWin);
-		if (ddrval != DD_OK)
-			I_Error("Clipper -> SetHWnd  FAILED");
-
-		// Attach the clipper to the surface.
-		ddrval = IDirectDrawSurface_SetClipper (ScreenReal,windclip);
-		if (ddrval != DD_OK)
-			I_Error("PrimaryScreen -> SetClipperClipper  FAILED");
-	}
-
-	return TRUE;
-}
-
-
-//
-// Free all memory
-//
-VOID CloseDirectDraw (VOID)
-{
-	ReleaseChtuff();
-	if (DDr2)
-	{
-		IDirectDraw2_Release(DDr2);
-		DDr2 = NULL;
-	}
-	UnLoadDirectDraw();
-}
-
-
-//
-// Release DirectDraw stuff before display mode change
-//
-VOID ReleaseChtuff (VOID)
-{
-	if (!DDr2)
-		return;
-	if (windclip)
-	{
-		IDirectDrawClipper_Release(windclip);
-		windclip = NULL;
-	}
-	if (DDPalette)
-	{
-		IDirectDrawPalette_Release(DDPalette);
-		DDPalette = NULL;
-	}
-	// If the app is fullscreen, the back buffer is attached to the
-	// primary. Releasing the primary buffer will also release any
-	// attached buffers, so explicitly releasing the back buffer is not
-	// necessary.
-
-	if (!bAppFullScreen && ScreenVirtual)
-	{
-		IDirectDrawSurface_Release(ScreenVirtual);   // release hidden surface
-		ScreenVirtual = NULL;
-	}
-	if (ScreenReal)
-	{
-		IDirectDrawSurface_Release(ScreenReal);                      // and attached backbuffers for bAppFullScreen mode
-		ScreenReal = NULL;
-	}
-}
-
-
-//
-// Clear the surface to color
-//
-VOID ClearSurface(IDirectDrawSurface* surface, int color)
-{
-	DDBLTFX ddbltfx;
-
-	// Use the blter to do a color fill to clear the back buffer
-	ddbltfx.dwSize = sizeof (ddbltfx);
-	ddbltfx.
-#ifdef DUMMYUNIONNAMEN
-	 DUMMYUNIONNAMEN(5).
-#endif
-	 dwFillColor = color;
-	IDirectDrawSurface_Blt(surface,NULL, NULL, NULL, DDBLT_COLORFILL | DDBLT_WAIT, &ddbltfx);
-
-}
-
-//
-// Flip the real page with virtual page
-// - in bAppFullScreen mode, do page flipping
-// - in windowed mode, copy the hidden surface to the visible surface
-//
-// waitflip : if not 0, wait for page flip to end
-BOOL ScreenFlip(int waitflip)
-{
-	HRESULT hr;
-	RECT rect;
-
-	if (bAppFullScreen)
-	{
-		//hr = IDirectDrawSurface_GetFlipStatus (ScreenReal, DDGFS_);
-
-		// In full-screen exclusive mode, do a hardware flip.
-		hr = IDirectDrawSurface_Flip(ScreenReal, NULL, DDFLIP_WAIT | (waitflip ? 0 : DDFLIP_NOVSYNC));   //return immediately
-
-		// If the surface was lost, restore it.
-		if (hr == DDERR_SURFACELOST)
-		{
-			IDirectDrawSurface_Restore(ScreenReal);
-
-			// The restore worked, so try the flip again.
-			hr = IDirectDrawSurface_Flip(ScreenReal, 0, DDFLIP_WAIT | (waitflip ? 0 : DDFLIP_NOVSYNC));
-		}
-	}
-	else
-	{
-		rect.left = windowPosX;
-		rect.top = windowPosY;
-		rect.right = windowPosX + ScreenWidth - 1;
-		rect.bottom = windowPosY + ScreenHeight - 1;
-
-		// Copy the back buffer to front.
-		hr = IDirectDrawSurface_Blt(ScreenReal, &rect, ScreenVirtual, 0, DDBLT_WAIT, 0);
-
-		if (hr != DD_OK)
-		{
-			// If the surfaces were lost, restore them.
-			if (IDirectDrawSurface_IsLost(ScreenReal) == DDERR_SURFACELOST)
-				IDirectDrawSurface_Restore(ScreenReal);
-
-			if (IDirectDrawSurface_IsLost(ScreenVirtual) == DDERR_SURFACELOST)
-				IDirectDrawSurface_Restore(ScreenVirtual);
-
-			// Retry the copy.
-			hr = IDirectDrawSurface_Blt(ScreenReal,&rect, ScreenVirtual, 0, DDBLT_WAIT, 0);
-		}
-	}
-
-	if (hr != DD_OK)
-		I_Error("ScreenFlip() : couldn't Flip surfaces because %s", DXErrorToString(hr));
-
-	return FALSE;
-}
-
-//
-// Print a text to the surface
-//
-VOID TextPrint(int x, int y, LPCSTR message)
-{
-	HRESULT hr;
-	HDC hdc = NULL;
-
-	// Get the device context handle.
-	hr = IDirectDrawSurface_GetDC(ScreenVirtual,&hdc);
-	if (hr != DD_OK)
-		return;
-
-	// Write the message.
-	SetBkMode(hdc, TRANSPARENT);
-	SetTextColor(hdc, RGB(255, 255, 255));
-	TextOutA(hdc, x, y, message, (int)strlen(message));
-
-	// Release the device context.
-	hr = IDirectDrawSurface_ReleaseDC(ScreenVirtual,hdc);
-}
-
-//
-// Lock surface before multiple drawings by hand, for speed
-//
-boolean LockScreen(VOID)
-{
-	DDSURFACEDESC ddsd;
-	HRESULT ddrval;
-
-	ZeroMemory(&ddsd, sizeof (ddsd));
-	ddsd.dwSize = sizeof (ddsd);
-
-	// attempt to Lock the surface
-	ddrval = IDirectDrawSurface_Lock(ScreenVirtual, NULL, &ddsd, DDLOCK_WAIT, NULL);
-
-	// Always, always check for errors with DirectX!
-	// If the surface was lost, restore it.
-	if (ddrval == DDERR_SURFACELOST)
-	{
-		ddrval = IDirectDrawSurface_Restore(ScreenReal);
-
-		// now retry to get the lock
-		ddrval = IDirectDrawSurface_Lock(ScreenVirtual, NULL, &ddsd, DDLOCK_WAIT, NULL);
-	}
-
-	if (ddrval == DD_OK)
-	{
-		ScreenLocked = TRUE;
-		ScreenPtr    = (LPBYTE)ddsd.lpSurface;
-		ScreenPitch = ddsd.
-#ifdef DUMMYUNIONNAMEN
-		 DUMMYUNIONNAMEN(1).
-#endif
-		 lPitch;
-	}
-	else
-	{
-		ScreenLocked = FALSE;
-		ScreenPtr = NULL;
-		ScreenPitch = 0;
-		//I_Error("LockScreen() : couldn't restore the surface.");
-		return false;
-	}
-	return true;
-}
-
-//
-// Unlock surface
-//
-VOID UnlockScreen(VOID)
-{
-	if (DD_OK != IDirectDrawSurface_Unlock(ScreenVirtual,NULL))
-		I_Error("Couldn't UnLock the renderer!");
-
-	ScreenLocked = FALSE;
-	ScreenPtr    = NULL;
-	ScreenPitch = 0;
-}
-
-// Blit virtual screen to real screen
-//faB: note: testing 14/03/1999, see if it is faster than memcopy of virtual to
-/*
-static LPDIRECTDRAWSURFACE lpDDS = NULL;
-VOID BlitScreen(VOID)
-{
-	HRESULT hr;
-
-	if (!lpDDS)
-		I_Error("lpDDS NULL");
-
-	hr = IDirectDrawSurface_BltFast(ScreenVirtual,
-	                                    0, 0,    // Upper left xy of destination
-	                                    lpDDS, // Source surface
-	                                    NULL,        // Source rectangle = entire surface
-	                                    DDBLTFAST_WAIT | DDBLTFAST_NOCOLORKEY);
-	if (FAILED(hr))
-		I_Error("BltFast FAILED");
-}
-
-VOID MakeScreen(int width, int height, BYTE* lpSurface)
-{
-	HRESULT hr;
-	DDSURFACEDESC ddsd;
-
-	// Initialize the surface description.
-	ZeroMemory (&ddsd, sizeof ddsd);
-	ZeroMemory (&ddsd.ddpfPixelFormat, sizeof (DDPIXELFORMAT));
-	ddsd.dwSize = sizeof ddsd;
-	ddsd.dwFlags = DDSD_WIDTH | DDSD_HEIGHT | //DDSD_LPSURFACE |
-	               DDSD_PITCH | DDSD_PIXELFORMAT | DDSD_CAPS;
-	ddsd.dwWidth = width;
-	ddsd.dwHeight= height;
-	ddsd.lPitch  = width;
-	ddsd.lpSurface = lpSurface;
-	ddsd.ddsCaps.dwCaps = DDSCAPS_SYSTEMMEMORY | DDSCAPS_OFFSCREENPLAIN;
-
-	// Set up the pixel format for 8-bit
-	ddsd.ddpfPixelFormat.dwSize = sizeof (DDPIXELFORMAT);
-	ddsd.ddpfPixelFormat.dwFlags= DDPF_RGB | DDPF_PALETTEINDEXED8;
-	ddsd.ddpfPixelFormat.dwRGBBitCount = 8;
-
-	//
-	ddsd.ddpfPixelFormat.dwRGBBitCount = (DWORD)DEPTH*8;
-	ddsd.ddpfPixelFormat.dwRBitMask    = 0x00FF0000;
-	ddsd.ddpfPixelFormat.dwGBitMask    = 0x0000FF00;
-	ddsd.ddpfPixelFormat.dwBBitMask    = 0x000000FF;
-
-	// Create the surface
-	hr = IDirectDraw2_CreateSurface(DDr2, &ddsd, &lpDDS, NULL);
-	if (FAILED(hr))
-		I_Error("MakeScreen FAILED: %s",DDError(hr));
-	//ddsd.lpSurface = lpSurface;
-}
-*/
-
-//
-// Create a palette object
-//
-VOID CreateDDPalette (PALETTEENTRY* colorTable)
-{
-	HRESULT  ddrval;
-	ddrval = IDirectDraw2_CreatePalette(DDr2,DDPCAPS_8BIT|DDPCAPS_ALLOW256, colorTable, &DDPalette, NULL);
-	if (ddrval != DD_OK)
-		I_Error("couldn't CreatePalette");
-};
-
-
-//
-// Free the palette object
-//
-VOID DestroyDDPalette (VOID)
-{
-	if (DDPalette)
-	{
-		IDirectDrawPalette_Release(DDPalette);
-		DDPalette = NULL;
-	}
-}
-
-//
-// Set a a full palette of 256 PALETTEENTRY entries
-//
-VOID SetDDPalette(PALETTEENTRY* pal)
-{
-	// create palette first time
-	if (DDPalette == NULL)
-		CreateDDPalette(pal);
-	else
-		IDirectDrawPalette_SetEntries(DDPalette, 0, 0, 256, pal);
-	// setting the same palette to the same surface again does not increase
-	// the reference count
-	IDirectDrawSurface_SetPalette(ScreenReal, DDPalette);
-}
-
-//
-// Wait for vsync, gross
-//
-VOID WaitVbl(VOID)
-{
-	IDirectDraw2_WaitForVerticalBlank(DDr2, DDWAITVB_BLOCKBEGIN, NULL);
-}
-
-
-//
-// Restore the palette. Useful when we regain focus.
-//
-VOID RestoreDDPalette(VOID)
-{
-	if (DDPalette)
-		IDirectDrawSurface_SetPalette(ScreenReal, DDPalette);
-}
-#endif
diff --git a/src/win32/fabdxlib.h b/src/win32/fabdxlib.h
deleted file mode 100644
index 2836b795db0aae9356abd3154e673ac6d85aea46..0000000000000000000000000000000000000000
--- a/src/win32/fabdxlib.h
+++ /dev/null
@@ -1,82 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief faB's DirectX library v1.0
-
-#ifndef _H_FABDXLIB_
-#define _H_FABDXLIB_
-
-//#define WIN32_LEAN_AND_MEAN
-#define RPC_NO_WINDOWS_H
-#include <windows.h>
-#ifdef __MINGW32__
-//#define NONAMELESSUNION
-#endif
-#ifdef _MSC_VER
-#pragma warning(disable :  4201)
-#endif
-#include <ddraw.h>
-#if (defined (DIRECTDRAW_VERSION) && (DIRECTDRAW_VERSION >= 0x0700))
-#undef DUMMYUNIONNAMEN
-#endif
-// format of function in app called with width,height
-typedef BOOL (*APPENUMMODESCALLBACK)(int width, int height, int bpp);
-
-
-// globals
-extern IDirectDraw2*                            DDr2;
-extern IDirectDrawSurface*                      ScreenReal;
-extern IDirectDrawSurface*                      ScreenVirtual;
-extern IDirectDrawPalette*                      DDPalette;
-
-extern BOOL                                     bAppFullScreen;                             // main code might need this to know the current
-                                                                                           // fullscreen or windowed state
-
-extern int                                      windowPosX;                             // current position in windowed mode
-extern int                                      windowPosY;
-
-extern int                                      ScreenWidth;
-extern int                                      ScreenHeight;
-extern BOOL                                     ScreenLocked;                   // Screen surface is being locked
-extern int                                      ScreenPitch;                    // offset from one line to the next
-extern LPBYTE                                   ScreenPtr;                              // memory of the surface
-
-extern BOOL                                     bDX0300;
-
-BOOL    EnumDirectDrawDisplayModes (APPENUMMODESCALLBACK appFunc);
-BOOL    CreateDirectDrawInstance (VOID);
-
-int     InitDirectDrawe (HWND appWin, int width, int height, int bpp, int fullScr);
-VOID    CloseDirectDraw (VOID);
-
-VOID    ReleaseChtuff (VOID);
-
-VOID    ClearSurface (IDirectDrawSurface* surface, int color);
-BOOL    ScreenFlip (int wait);
-VOID    TextPrint (int x, int y, LPCSTR message);
-
-VOID    CreateDDPalette (PALETTEENTRY* colorTable);
-VOID    DestroyDDPalette (VOID);
-VOID    SetDDPalette (PALETTEENTRY* pal);
-VOID    RestoreDDPalette(VOID);
-
-VOID    WaitVbl (VOID);
-
-boolean LockScreen (VOID);
-VOID    UnlockScreen (VOID);
-
-
-#endif /* _H_FABDXLIB_ */
diff --git a/src/win32/win_cd.c b/src/win32/win_cd.c
deleted file mode 100644
index 324c2492848a4a78e9f1c22542cc6180533a59ab..0000000000000000000000000000000000000000
--- a/src/win32/win_cd.c
+++ /dev/null
@@ -1,539 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief cd music interface (uses MCI).
-
-#include "../doomdef.h"
-#include "../doomstat.h"
-#ifdef _WINDOWS
-#include "win_main.h"
-#include <mmsystem.h>
-
-#include "../command.h"
-#include "../doomtype.h"
-#include "../i_sound.h"
-#include "../i_system.h"
-
-#include "../s_sound.h"
-
-#define MAX_CD_TRACKS       255
-
-typedef struct {
-	BOOL    IsAudio;
-	DWORD   Start, End;
-	DWORD   Length;         // minutes
-} CDTrack;
-
-// -------
-// private
-// -------
-static  CDTrack          m_nTracks[MAX_CD_TRACKS];
-static  int              m_nTracksCount;             // up to MAX_CD_TRACKS
-static  MCI_STATUS_PARMS m_MCIStatus;
-static  MCI_OPEN_PARMS   m_MCIOpen;
-
-// ------
-// protos
-// ------
-static void Command_Cd_f (void);
-
-
-// -------------------
-// MCIErrorMessageBox
-// Retrieve error message corresponding to return value from
-//  mciSendCommand() or mciSenString()
-// -------------------
-static VOID MCIErrorMessageBox (MCIERROR iErrorCode)
-{
-	char szErrorText[128];
-	if (!mciGetErrorStringA (iErrorCode, szErrorText, sizeof (szErrorText)))
-		wsprintfA(szErrorText,"MCI CD Audio Unknown Error #%lu\n", iErrorCode);
-	I_OutputMsg("%s", szErrorText);
-	/*MessageBox (GetActiveWindow(), szTemp+1, "LEGACY",
-				MB_OK | MB_ICONSTOP);*/
-}
-
-
-// --------
-// CD_Reset
-// --------
-static VOID CD_Reset (VOID)
-{
-	// no win32 equivalent
-	//faB: for DOS, some odd drivers like to be reset sometimes.. useless in MCI I guess
-}
-
-
-// ----------------
-// CD_ReadTrackInfo
-// Read in number of tracks, and length of each track in minutes/seconds
-// returns true if error
-// ----------------
-static BOOL CD_ReadTrackInfo(VOID)
-{
-	UINT     nTrackLength;
-	INT      i;
-	MCIERROR iErr;
-
-	m_nTracksCount = 0;
-
-	m_MCIStatus.dwItem = MCI_STATUS_NUMBER_OF_TRACKS;
-	iErr = mciSendCommand(m_MCIOpen.wDeviceID, MCI_STATUS, MCI_STATUS_ITEM|MCI_WAIT, (DWORD_PTR)&m_MCIStatus);
-	if (iErr)
-	{
-		MCIErrorMessageBox (iErr);
-		return FALSE;
-	}
-	m_nTracksCount = (int)m_MCIStatus.dwReturn;
-	if (m_nTracksCount > MAX_CD_TRACKS)
-		m_nTracksCount = MAX_CD_TRACKS;
-
-	for (i = 0; i < m_nTracksCount; i++)
-	{
-		m_MCIStatus.dwTrack = (DWORD)(i+1);
-		m_MCIStatus.dwItem = MCI_STATUS_LENGTH;
-		iErr = mciSendCommand(m_MCIOpen.wDeviceID, MCI_STATUS, MCI_TRACK|MCI_STATUS_ITEM|MCI_WAIT, (DWORD_PTR)&m_MCIStatus);
-		if (iErr)
-		{
-			MCIErrorMessageBox (iErr);
-			return FALSE;
-		}
-		nTrackLength = (DWORD)(MCI_MSF_MINUTE(m_MCIStatus.dwReturn)*60 + MCI_MSF_SECOND(m_MCIStatus.dwReturn));
-		m_nTracks[i].Length = nTrackLength;
-
-		m_MCIStatus.dwItem = MCI_CDA_STATUS_TYPE_TRACK;
-		iErr = mciSendCommand(m_MCIOpen.wDeviceID, MCI_STATUS, MCI_TRACK|MCI_STATUS_ITEM|MCI_WAIT, (DWORD_PTR)&m_MCIStatus);
-		if (iErr)
-		{
-			MCIErrorMessageBox (iErr);
-			return FALSE;
-		}
-		m_nTracks[i].IsAudio = (m_MCIStatus.dwReturn == MCI_CDA_TRACK_AUDIO);
-	}
-
-	return TRUE;
-}
-
-
-// ------------
-// CD_TotalTime
-// returns total time for all audio tracks in seconds
-// ------------
-static UINT CD_TotalTime(VOID)
-{
-	UINT nTotalLength = 0;
-	INT nTrack;
-	for (nTrack = 0; nTrack < m_nTracksCount; nTrack++)
-	{
-		if (m_nTracks[nTrack].IsAudio)
-			nTotalLength += m_nTracks[nTrack].Length;
-	}
-	return nTotalLength;
-}
-
-
-//======================================================================
-//                   CD AUDIO MUSIC SUBSYSTEM
-//======================================================================
-
-UINT8  cdaudio_started = 0;   // for system startup/shutdown
-
-static BOOL cdPlaying = FALSE;
-static  INT cdPlayTrack;         // when cdPlaying is true
-static BOOL cdLooping = FALSE;
-static BYTE cdRemap[MAX_CD_TRACKS];
-static BOOL cdEnabled = TRUE;      // cd info available
-static BOOL cdValid;             // true when last cd audio info was ok
-static BOOL wasPlaying;
-//static INT     cdVolume = 0;          // current cd volume (0-31)
-
-// 0-31 like Music & Sfx, though CD hardware volume is 0-255.
-consvar_t cd_volume = CVAR_INIT ("cd_volume","18",CV_SAVE,soundvolume_cons_t, NULL);
-
-// allow Update for next/loop track
-// some crap cd drivers take up to
-// a second for a simple 'busy' check..
-// (on those Update can be disabled)
-consvar_t cdUpdate  = CVAR_INIT ("cd_update","1",CV_SAVE, NULL, NULL);
-
-#if (__GNUC__ > 6)
-#pragma GCC diagnostic push
-#pragma GCC diagnostic ignored "-Wformat-overflow"
-#endif
-// hour,minutes,seconds
-static LPSTR hms(UINT seconds)
-{
-	UINT hours, minutes;
-	static CHAR s[9];
-
-	minutes = seconds / 60;
-	seconds %= 60;
-	hours = minutes / 60;
-	minutes %= 60;
-	if (hours > 0)
-		sprintf (s, "%lu:%02lu:%02lu", (long unsigned int)hours, (long unsigned int)minutes, (long unsigned int)seconds);
-	else
-		sprintf (s, "%2lu:%02lu", (long unsigned int)minutes, (long unsigned int)seconds);
-	return s;
-}
-#if (__GNUC__ > 6)
-#pragma GCC diagnostic pop
-#endif
-
-static void Command_Cd_f(void)
-{
-	LPCSTR    s;
-	int       i,j;
-
-	if (!cdaudio_started)
-		return;
-
-	if (COM_Argc() < 2)
-	{
-		CONS_Printf (M_GetText(
-		"cd [on] [off] [remap] [reset] [select]\n"
-		"   [open] [info] [play <track>] [resume]\n"
-		"   [stop] [pause] [loop <track>]\n"));
-		return;
-	}
-
-	s = COM_Argv(1);
-
-	// activate cd music
-	if (!strncmp(s,"on",2))
-	{
-		cdEnabled = TRUE;
-		return;
-	}
-
-	// stop/deactivate cd music
-	if (!strncmp(s, "off", 3))
-	{
-		if (cdPlaying)
-			I_StopCD();
-		cdEnabled = FALSE;
-		return;
-	}
-
-	// remap tracks
-	if (!strncmp(s, "remap", 5))
-	{
-		i = (int)COM_Argc() - 2;
-		if (i <= 0)
-		{
-			CONS_Printf(M_GetText("CD tracks remapped in that order :\n"));
-			for (j = 1; j < MAX_CD_TRACKS; j++)
-				if (cdRemap[j] != j)
-					CONS_Printf(" %2d -> %2d\n", j, cdRemap[j]);
-			return;
-		}
-		for (j = 1; j <= i; j++)
-			cdRemap[j] = (UINT8)atoi(COM_Argv(j+1));
-		return;
-	}
-
-	// reset the CD driver, useful on some odd cd's
-	if (!strncmp(s,"reset",5))
-	{
-		cdEnabled = TRUE;
-		if (cdPlaying)
-			I_StopCD ();
-		for (i = 0; i < MAX_CD_TRACKS; i++)
-			cdRemap[i] = (UINT8)i;
-		CD_Reset();
-		cdValid = CD_ReadTrackInfo();
-		return;
-	}
-
-	// any other command is not allowed until we could retrieve cd information
-	if (!cdValid)
-	{
-		CONS_Printf(M_GetText("CD is not ready.\n"));
-		return;
-	}
-
-	/* faB: not with MCI, didn't find it, useless anyway
-	if (!strncmp(s,"open",4))
-	{
-		if (cdPlaying)
-			I_StopCD ();
-		bcd_open_door();
-		cdValid = FALSE;
-		return;
-	}*/
-
-	if (!strncmp(s,"info",4))
-	{
-		if (!CD_ReadTrackInfo())
-		{
-			cdValid = FALSE;
-			return;
-		}
-
-		cdValid = TRUE;
-
-		if (m_nTracksCount <= 0)
-			CONS_Printf(M_GetText("No audio tracks\n"));
-		else
-		{
-			// display list of tracks
-			// highlight current playing track
-			for (i = 0; i < m_nTracksCount; i++)
-			{
-				CONS_Printf("%s%2d. %s  %s\n",
-				            cdPlaying && (cdPlayTrack == i) ? "\x82 " : " ",
-				            i+1, m_nTracks[i].IsAudio ? M_GetText("audio") : M_GetText("data "),
-				            hms(m_nTracks[i].Length));
-			}
-			CONS_Printf(M_GetText("\x82Total time : %s\n"), hms(CD_TotalTime()));
-		}
-		if (cdPlaying)
-		{
-			CONS_Printf(M_GetText("Currently %s track %u\n"), cdLooping ? M_GetText("looping") : M_GetText("playing"), cdPlayTrack);
-		}
-		return;
-	}
-
-	if (!strncmp(s,"play",4))
-	{
-		I_PlayCD ((UINT8)atoi (COM_Argv (2)), false);
-		return;
-	}
-
-	if (!strncmp(s,"stop",4))
-	{
-		I_StopCD ();
-		return;
-	}
-
-	if (!strncmp(s,"loop",4))
-	{
-		I_PlayCD((UINT8)atoi (COM_Argv (2)), true);
-		return;
-	}
-
-	if (!strncmp(s,"resume",4))
-	{
-		I_ResumeCD ();
-		return;
-	}
-
-	CONS_Printf (M_GetText("Invalid CD command \"CD %s\"\n"), s);
-}
-
-
-// ------------
-// I_ShutdownCD
-// Shutdown CD Audio subsystem, release whatever was allocated
-// ------------
-void I_ShutdownCD(void)
-{
-	MCIERROR    iErr;
-
-	if (!cdaudio_started)
-		return;
-
-	CONS_Printf("I_ShutdownCD: ");
-
-	I_StopCD();
-
-	// closes MCI CD
-	iErr = mciSendCommand(m_MCIOpen.wDeviceID, MCI_CLOSE, 0, 0);
-	if (iErr)
-		MCIErrorMessageBox (iErr);
-}
-
-
-// --------
-// I_InitCD
-// Init CD Audio subsystem
-// --------
-void I_InitCD(void)
-{
-	MCI_SET_PARMS   mciSet;
-	MCIERROR    iErr;
-	int         i;
-
-	// We don't have an open device yet
-	m_MCIOpen.wDeviceID = 0;
-	m_nTracksCount = 0;
-
-	cdaudio_started = false;
-
-	m_MCIOpen.lpstrDeviceType = (LPCTSTR)MCI_DEVTYPE_CD_AUDIO;
-	iErr = mciSendCommand(0, MCI_OPEN, MCI_OPEN_TYPE|MCI_OPEN_TYPE_ID, (DWORD_PTR)&m_MCIOpen);
-	if (iErr)
-	{
-		MCIErrorMessageBox (iErr);
-		return;
-	}
-
-	// Set the time format to track/minute/second/frame (TMSF).
-	mciSet.dwTimeFormat = MCI_FORMAT_TMSF;
-	iErr = mciSendCommand(m_MCIOpen.wDeviceID, MCI_SET, MCI_SET_TIME_FORMAT, (DWORD_PTR)&mciSet);
-	if (iErr)
-	{
-		MCIErrorMessageBox (iErr);
-		mciSendCommand(m_MCIOpen.wDeviceID, MCI_CLOSE, 0, 0);
-		return;
-	}
-
-	I_AddExitFunc (I_ShutdownCD);
-	cdaudio_started = true;
-
-	CONS_Printf (M_GetText("CD audio Initialized\n"));
-
-	// last saved in config.cfg
-	i = cd_volume.value;
-	//I_SetVolumeCD (0);   // initialize to 0 for some odd cd drivers
-	I_SetVolumeCD (i);   // now set the last saved volume
-
-	for (i = 0; i < MAX_CD_TRACKS; i++)
-		cdRemap[i] = (UINT8)i;
-
-	if (!CD_ReadTrackInfo())
-	{
-		CONS_Printf(M_GetText("No CD in drive\n"));
-		cdEnabled = FALSE;
-		cdValid = FALSE;
-	}
-	else
-	{
-		cdEnabled = TRUE;
-		cdValid = TRUE;
-	}
-
-	COM_AddCommand ("cd", Command_Cd_f);
-}
-
-
-
-// loop/go to next track when track is finished (if cd_update var is true)
-// update the volume when it has changed (from console/menu)
-void I_UpdateCD(void)
-{
-	/// \todo check for cd change and restart music ?
-}
-
-
-//
-void I_PlayCD(UINT8 nTrack, UINT8 bLooping)
-{
-	MCI_PLAY_PARMS  mciPlay;
-	MCIERROR        iErr;
-
-	if (!cdaudio_started || !cdEnabled)
-		return;
-
-	//faB: try again if it didn't work (just free the user of typing 'cd reset' command)
-	if (!cdValid)
-		cdValid = CD_ReadTrackInfo();
-	if (!cdValid)
-		return;
-
-	// tracks start at 0 in the code..
-	nTrack--;
-	if (nTrack >= m_nTracksCount)
-		nTrack = (UINT8) (nTrack % m_nTracksCount);
-
-	nTrack = cdRemap[nTrack];
-
-	if (cdPlaying)
-	{
-		if (cdPlayTrack == nTrack)
-			return;
-		I_StopCD ();
-	}
-
-	cdPlayTrack = nTrack;
-
-	if (!m_nTracks[nTrack].IsAudio)
-	{
-		//I_OutputMsg("\x82""CD Play: not an audio track\n"); // Tails 03-25-2001
-		return;
-	}
-
-	cdLooping = bLooping;
-
-	//faB: stop MIDI music, MIDI music will restart if volume is upped later
-	cv_digmusicvolume.value = 0;
-	cv_midimusicvolume.value = 0;
-	I_StopSong();
-
-	//faB: I don't use the notify message, I'm trying to minimize the delay
-	mciPlay.dwCallback = (DWORD)((size_t)hWndMain);
-	mciPlay.dwFrom = MCI_MAKE_TMSF(nTrack+1, 0, 0, 0);
-	iErr = mciSendCommand(m_MCIOpen.wDeviceID, MCI_PLAY, MCI_FROM|MCI_NOTIFY, (DWORD_PTR)&mciPlay);
-	if (iErr)
-	{
-		MCIErrorMessageBox (iErr);
-		cdValid = FALSE;
-		cdPlaying = FALSE;
-		return;
-	}
-
-	cdPlaying = TRUE;
-}
-
-
-// pause cd music
-void I_StopCD(void)
-{
-	MCIERROR    iErr;
-
-	if (!cdaudio_started || !cdEnabled)
-		return;
-
-	iErr = mciSendCommand(m_MCIOpen.wDeviceID, MCI_PAUSE, MCI_WAIT, 0);
-	if (iErr)
-		MCIErrorMessageBox (iErr);
-	else
-	{
-		wasPlaying = cdPlaying;
-		cdPlaying = FALSE;
-	}
-}
-
-
-// continue after a pause
-void I_ResumeCD(void)
-{
-	MCIERROR    iErr;
-
-	if (!cdaudio_started || !cdEnabled)
-		return;
-
-	if (!cdValid)
-		return;
-
-	if (!wasPlaying)
-		return;
-
-	iErr = mciSendCommand(m_MCIOpen.wDeviceID, MCI_RESUME, MCI_WAIT, 0);
-	if (iErr)
-		MCIErrorMessageBox (iErr);
-	else
-		cdPlaying = TRUE;
-}
-
-
-// volume : logical cd audio volume 0-31 (hardware is 0-255)
-boolean I_SetVolumeCD (INT32 volume)
-{
-	UNREFERENCED_PARAMETER(volume);
-	return false;
-}
-#endif
diff --git a/src/win32/win_dll.c b/src/win32/win_dll.c
deleted file mode 100644
index 4743cec34b2e6af738caeec60d7c179e58ec14d1..0000000000000000000000000000000000000000
--- a/src/win32/win_dll.c
+++ /dev/null
@@ -1,238 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief load and initialise the 3D driver DLL
-
-#include "../doomdef.h"
-#ifdef HWRENDER
-#include "../hardware/hw_drv.h"        // get the standard 3D Driver DLL exports prototypes
-#endif
-
-#ifdef HW3SOUND
-#include "../hardware/hw3dsdrv.h"      // get the 3D sound driver DLL export prototypes
-#endif
-
-#ifdef _WINDOWS
-
-#include "win_dll.h"
-#include "win_main.h"       // I_ShowLastError()
-
-#if defined(HWRENDER) || defined(HW3SOUND)
-typedef struct loadfunc_s {
-	LPCSTR fnName;
-	LPVOID fnPointer;
-} loadfunc_t;
-
-// --------------------------------------------------------------------------
-// Load a DLL, returns the HMODULE handle or NULL
-// --------------------------------------------------------------------------
-static HMODULE LoadDLL (LPCSTR dllName, loadfunc_t *funcTable)
-{
-	LPVOID      funcPtr;
-	loadfunc_t *loadfunc;
-	HMODULE     hModule;
-
-	if ((hModule = LoadLibraryA(dllName)) != NULL)
-	{
-		// get function pointers for all functions we use
-		for (loadfunc = funcTable; loadfunc->fnName != NULL; loadfunc++)
-		{
-			funcPtr = GetProcAddress(hModule, loadfunc->fnName);
-			if (!funcPtr) {
-				I_ShowLastError(FALSE);
-				MessageBoxA(NULL, va("The '%s' haven't the good specification (function %s missing)\n\n"
-				           "You must use dll from the same zip of this exe\n", dllName, loadfunc->fnName),
-				           "Error", MB_OK|MB_ICONINFORMATION);
-				return FALSE;
-			}
-			// store function address
-			*((LPVOID*)loadfunc->fnPointer) = funcPtr;
-		}
-	}
-	else
-	{
-		I_ShowLastError(FALSE);
-		MessageBoxA(NULL, va("LoadLibrary() FAILED : couldn't load '%s'\r\n", dllName), "Warning", MB_OK|MB_ICONINFORMATION);
-	}
-
-	return hModule;
-}
-
-
-// --------------------------------------------------------------------------
-// Unload the DLL
-// --------------------------------------------------------------------------
-static VOID UnloadDLL (HMODULE* pModule)
-{
-	if (FreeLibrary(*pModule))
-		*pModule = NULL;
-	else
-		I_ShowLastError(TRUE);
-}
-#endif
-
-// ==========================================================================
-// STANDARD 3D DRIVER DLL FOR DOOM LEGACY
-// ==========================================================================
-
-// note : the 3D driver loading should be put somewhere else..
-
-#ifdef HWRENDER
-static HMODULE hwdModule = NULL;
-
-static loadfunc_t hwdFuncTable[] = {
-#ifdef _X86_
-	{"Init@4",              &hwdriver.pfnInit},
-	{"Shutdown@0",          &hwdriver.pfnShutdown},
-	{"GetModeList@8",       &hwdriver.pfnGetModeList},
-	{"SetPalette@4",        &hwdriver.pfnSetPalette},
-	{"FinishUpdate@4",      &hwdriver.pfnFinishUpdate},
-	{"Draw2DLine@12",       &hwdriver.pfnDraw2DLine},
-	{"DrawPolygon@16",      &hwdriver.pfnDrawPolygon},
-	{"RenderSkyDome@4",     &hwdriver.pfnRenderSkyDome},
-	{"SetBlend@4",          &hwdriver.pfnSetBlend},
-	{"ClearBuffer@12",      &hwdriver.pfnClearBuffer},
-	{"SetTexture@4",        &hwdriver.pfnSetTexture},
-	{"UpdateTexture@4",     &hwdriver.pfnUpdateTexture},
-	{"DeleteTexture@4",     &hwdriver.pfnDeleteTexture},
-	{"ReadRect@24",         &hwdriver.pfnReadRect},
-	{"GClipRect@20",        &hwdriver.pfnGClipRect},
-	{"ClearMipMapCache@0",  &hwdriver.pfnClearMipMapCache},
-	{"SetSpecialState@8",   &hwdriver.pfnSetSpecialState},
-	{"DrawModel@16",        &hwdriver.pfnDrawModel},
-	{"SetTransform@4",      &hwdriver.pfnSetTransform},
-	{"GetTextureUsed@0",    &hwdriver.pfnGetTextureUsed},
-	{"GetRenderVersion@0",  &hwdriver.pfnGetRenderVersion},
-#ifdef SHUFFLE
-	{"PostImgRedraw@4",     &hwdriver.pfnPostImgRedraw},
-#endif
-	{"FlushScreenTextures@0",&hwdriver.pfnFlushScreenTextures},
-	{"StartScreenWipe@0",   &hwdriver.pfnStartScreenWipe},
-	{"EndScreenWipe@0",     &hwdriver.pfnEndScreenWipe},
-	{"DoScreenWipe@0",      &hwdriver.pfnDoScreenWipe},
-	{"DrawIntermissionBG@0",&hwdriver.pfnDrawIntermissionBG},
-	{"MakeScreenTexture@0", &hwdriver.pfnMakeScreenTexture},
-	{"MakeScreenFinalTexture@0", &hwdriver.pfnMakeScreenFinalTexture},
-	{"DrawScreenFinalTexture@8", &hwdriver.pfnDrawScreenFinalTexture},
-#else
-	{"Init",                &hwdriver.pfnInit},
-	{"Shutdown",            &hwdriver.pfnShutdown},
-	{"GetModeList",         &hwdriver.pfnGetModeList},
-	{"SetPalette",          &hwdriver.pfnSetPalette},
-	{"FinishUpdate",        &hwdriver.pfnFinishUpdate},
-	{"Draw2DLine",          &hwdriver.pfnDraw2DLine},
-	{"DrawPolygon",         &hwdriver.pfnDrawPolygon},
-	{"RenderSkyDome",       &hwdriver.pfnRenderSkyDome},
-	{"SetBlend",            &hwdriver.pfnSetBlend},
-	{"ClearBuffer",         &hwdriver.pfnClearBuffer},
-	{"SetTexture",          &hwdriver.pfnSetTexture},
-	{"UpdateTexture",       &hwdriver.pfnUpdateTexture},
-	{"DeleteTexture",       &hwdriver.pfnDeleteTexture},
-	{"ReadRect",            &hwdriver.pfnReadRect},
-	{"GClipRect",           &hwdriver.pfnGClipRect},
-	{"ClearMipMapCache",    &hwdriver.pfnClearMipMapCache},
-	{"SetSpecialState",     &hwdriver.pfnSetSpecialState},
-	{"DrawModel",           &hwdriver.pfnDrawModel},
-	{"SetTransform",        &hwdriver.pfnSetTransform},
-	{"GetTextureUsed",      &hwdriver.pfnGetTextureUsed},
-	{"GetRenderVersion",    &hwdriver.pfnGetRenderVersion},
-#ifdef SHUFFLE
-	{"PostImgRedraw",       &hwdriver.pfnPostImgRedraw},
-#endif
-	{"FlushScreenTextures", &hwdriver.pfnFlushScreenTextures},
-	{"StartScreenWipe",     &hwdriver.pfnStartScreenWipe},
-	{"EndScreenWipe",       &hwdriver.pfnEndScreenWipe},
-	{"DoScreenWipe",        &hwdriver.pfnDoScreenWipe},
-	{"DrawIntermissionBG",  &hwdriver.pfnDrawIntermissionBG},
-	{"MakeScreenTexture",   &hwdriver.pfnMakeScreenTexture},
-	{"MakeScreenFinalTexture", &hwdriver.pfnMakeScreenFinalTexture},
-	{"DrawScreenFinalTexture", &hwdriver.pfnDrawScreenFinalTexture},
-#endif
-	{NULL,NULL}
-};
-
-BOOL Init3DDriver (LPCSTR dllName)
-{
-	hwdModule = LoadDLL(dllName, hwdFuncTable);
-	return (hwdModule != NULL);
-}
-
-VOID Shutdown3DDriver (VOID)
-{
-	UnloadDLL(&hwdModule);
-}
-#endif
-
-#ifdef HW3SOUND
-static HMODULE hwsModule = NULL;
-
-static loadfunc_t hwsFuncTable[] = {
-#ifdef _X86_
-	{"Startup@8",              &hw3ds_driver.pfnStartup},
-	{"Shutdown@0",             &hw3ds_driver.pfnShutdown},
-	{"AddSfx@4",               &hw3ds_driver.pfnAddSfx},
-	{"AddSource@8",            &hw3ds_driver.pfnAddSource},
-	{"StartSource@4",          &hw3ds_driver.pfnStartSource},
-	{"StopSource@4",           &hw3ds_driver.pfnStopSource},
-	{"GetHW3DSVersion@0",      &hw3ds_driver.pfnGetHW3DSVersion},
-	{"BeginFrameUpdate@0",     &hw3ds_driver.pfnBeginFrameUpdate},
-	{"EndFrameUpdate@0",       &hw3ds_driver.pfnEndFrameUpdate},
-	{"IsPlaying@4",            &hw3ds_driver.pfnIsPlaying},
-	{"UpdateListener@8",       &hw3ds_driver.pfnUpdateListener},
-	{"UpdateSourceParms@12",   &hw3ds_driver.pfnUpdateSourceParms},
-	{"SetCone@8",              &hw3ds_driver.pfnSetCone},
-	{"SetGlobalSfxVolume@4",   &hw3ds_driver.pfnSetGlobalSfxVolume},
-	{"Update3DSource@8",       &hw3ds_driver.pfnUpdate3DSource},
-	{"ReloadSource@8",         &hw3ds_driver.pfnReloadSource},
-	{"KillSource@4",           &hw3ds_driver.pfnKillSource},
-	{"KillSfx@4",              &hw3ds_driver.pfnKillSfx},
-	{"GetHW3DSTitle@8",        &hw3ds_driver.pfnGetHW3DSTitle},
-#else
-	{"Startup",                &hw3ds_driver.pfnStartup},
-	{"Shutdown",               &hw3ds_driver.pfnShutdown},
-	{"AddSfx",                 &hw3ds_driver.pfnAddSfx},
-	{"AddSource",              &hw3ds_driver.pfnAddSource},
-	{"StartSource",            &hw3ds_driver.pfnStartSource},
-	{"StopSource",             &hw3ds_driver.pfnStopSource},
-	{"GetHW3DSVersion",        &hw3ds_driver.pfnGetHW3DSVersion},
-	{"BeginFrameUpdate",       &hw3ds_driver.pfnBeginFrameUpdate},
-	{"EndFrameUpdate",         &hw3ds_driver.pfnEndFrameUpdate},
-	{"IsPlaying",              &hw3ds_driver.pfnIsPlaying},
-	{"UpdateListener",         &hw3ds_driver.pfnUpdateListener},
-	{"UpdateSourceParms",      &hw3ds_driver.pfnUpdateSourceParms},
-	{"SetCone",                &hw3ds_driver.pfnSetCone},
-	{"SetGlobalSfxVolume",     &hw3ds_driver.pfnSetGlobalSfxVolume},
-	{"Update3DSource",         &hw3ds_driver.pfnUpdate3DSource},
-	{"ReloadSource",           &hw3ds_driver.pfnReloadSource},
-	{"KillSource",             &hw3ds_driver.pfnKillSource},
-	{"KillSfx",                &hw3ds_driver.pfnKillSfx},
-	{"GetHW3DSTitle",          &hw3ds_driver.pfnGetHW3DSTitle},
-#endif
-	{NULL, NULL}
-};
-
-BOOL Init3DSDriver(LPCSTR dllName)
-{
-	hwsModule = LoadDLL(dllName, hwsFuncTable);
-	return (hwsModule != NULL);
-}
-
-VOID Shutdown3DSDriver (VOID)
-{
-	UnloadDLL(&hwsModule);
-}
-#endif
-#endif //_WINDOWS
diff --git a/src/win32/win_dll.h b/src/win32/win_dll.h
deleted file mode 100644
index b4b259587caacbf91dd97523c850bf7a96a1b57a..0000000000000000000000000000000000000000
--- a/src/win32/win_dll.h
+++ /dev/null
@@ -1,31 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief load/unload a DLL at run-time
-
-//#define WIN32_LEAN_AND_MEAN
-#define RPC_NO_WINDOWS_H
-#include <windows.h>
-
-#ifdef HWRENDER
-BOOL Init3DDriver (LPCSTR dllName);
-VOID Shutdown3DDriver (VOID);
-#endif
-
-#ifdef HW3SOUND
-BOOL Init3DSDriver(LPCSTR dllName);
-VOID Shutdown3DSDriver(VOID);
-#endif
diff --git a/src/win32/win_main.c b/src/win32/win_main.c
deleted file mode 100644
index a5ebf32113f2723dbb5786c0eda8ae79a710d61b..0000000000000000000000000000000000000000
--- a/src/win32/win_main.c
+++ /dev/null
@@ -1,674 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief Win32 WinMain Entry Point
-///
-///	Win32 Sonic Robo Blast 2
-///
-///	NOTE:
-///		To compile WINDOWS SRB2 version : define a '_WINDOWS' symbol.
-///		to do this go to Project/Settings/ menu, click C/C++ tab, in
-///		'Preprocessor definitions:' add '_WINDOWS'
-
-#include "../doomdef.h"
-#include <stdio.h>
-
-#ifdef _WINDOWS
-
-#include "../doomstat.h"  // netgame
-#include "resource.h"
-
-#include "../m_argv.h"
-#include "../d_main.h"
-#include "../i_system.h"
-
-#include "../keys.h"    //hack quick test
-
-#include "../console.h"
-
-#include "fabdxlib.h"
-#include "win_main.h"
-#include "win_dbg.h"
-#include "../s_sound.h" // pause sound with handling
-#include "../g_input.h" // KEY_MOUSEWHEELxxx
-#include "../screen.h" // for BASEVID*
-
-// MSWheel support for Win95/NT3.51
-#include <zmouse.h>
-
-#ifndef WM_XBUTTONDOWN
-#define WM_XBUTTONDOWN 523
-#endif
-#ifndef WM_XBUTTONUP
-#define WM_XBUTTONUP 524
-#endif
-#ifndef MK_XBUTTON1
-#define MK_XBUTTON1 32
-#endif
-#ifndef MK_XBUTTON2
-#define MK_XBUTTON2 64
-#endif
-
-typedef BOOL (WINAPI *p_IsDebuggerPresent)(VOID);
-
-HWND hWndMain = NULL;
-static HCURSOR windowCursor = NULL; // main window cursor
-
-static LPCSTR wClassName = "SRB2WC";
-
-INT appActive = false; // app window is active
-
-#ifdef LOGMESSAGES
-FILE *logstream;
-#endif
-
-BOOL nodinput = FALSE;
-
-static LRESULT CALLBACK MainWndproc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
-{
-	event_t ev; //Doom input event
-	int mouse_keys;
-
-	// judgecutor:
-	// Response MSH Mouse Wheel event
-
-	if (message == MSHWheelMessage)
-	{
-		message = WM_MOUSEWHEEL;
-		wParam <<= 16;
-	}
-
-	//I_OutputMsg("MainWndproc: %p,%i,%i,%i",hWnd, message, wParam, (UINT)lParam);
-
-	switch (message)
-	{
-		case WM_CREATE:
-			nodinput = M_CheckParm("-nodinput");
-			if (!nodinput && !LoadDirectInput())
-				nodinput = true;
-			break;
-
-		case WM_ACTIVATEAPP:           // Handle task switching
-			appActive = (int)wParam;
-
-			//coming back from alt-tab?  reset the palette.
-			if (appActive)
-				vid.recalc = true;
-
-			// pause music when alt-tab
-			if (appActive  && !paused)
-				S_ResumeAudio();
-			else if (!paused)
-				S_PauseAudio();
-			{
-				HANDLE ci = GetStdHandle(STD_INPUT_HANDLE);
-				DWORD mode;
-				if (ci != INVALID_HANDLE_VALUE && GetFileType(ci) == FILE_TYPE_CHAR && GetConsoleMode(ci, &mode))
-					appActive = true;
-			}
-			InvalidateRect (hWnd, NULL, TRUE);
-			break;
-
-		case WM_PAINT:
-			if (!appActive && !bAppFullScreen && !netgame)
-				// app becomes inactive (if windowed)
-			{
-				// Paint "Game Paused" in the middle of the screen
-				PAINTSTRUCT ps;
-				RECT        rect;
-				HDC hdc = BeginPaint (hWnd, &ps);
-				GetClientRect (hWnd, &rect);
-				DrawText (hdc, TEXT("Game Paused"), -1, &rect,
-					DT_SINGLELINE | DT_CENTER | DT_VCENTER);
-				EndPaint (hWnd, &ps);
-				return 0;
-			}
-
-			break;
-
-		case WM_QUERYNEWPALETTE:
-			RestoreDDPalette();
-			return TRUE;
-
-		case WM_PALETTECHANGED:
-			if((HWND)wParam != hWnd)
-				RestoreDDPalette();
-			break;
-
-		//case WM_RBUTTONDOWN:
-		//case WM_LBUTTONDOWN:
-
-		case WM_MOVE:
-			if (bAppFullScreen)
-			{
-				SetWindowPos(hWnd, NULL, 0, 0, 0, 0, SWP_NOZORDER | SWP_NOSIZE);
-				return 0;
-			}
-			else
-			{
-				windowPosX = (SHORT) LOWORD(lParam);    // horizontal position
-				windowPosY = (SHORT) HIWORD(lParam);    // vertical position
-				break;
-			}
-			break;
-
-			// This is where switching windowed/fullscreen is handled. DirectDraw
-			// objects must be destroyed, recreated, and artwork reloaded.
-
-		case WM_DISPLAYCHANGE:
-		case WM_SIZE:
-			break;
-
-		case WM_SETCURSOR:
-			if (bAppFullScreen)
-				SetCursor(NULL);
-			else
-				SetCursor(windowCursor);
-			return TRUE;
-
-		case WM_KEYUP:
-			ev.type = ev_keyup;
-			goto handleKeyDoom;
-			break;
-
-		case WM_KEYDOWN:
-			ev.type = ev_keydown;
-
-	handleKeyDoom:
-			ev.key = 0;
-			if (wParam == VK_PAUSE)
-			// intercept PAUSE key
-			{
-				ev.key = KEY_PAUSE;
-			}
-			else if (!keyboard_started)
-			// post some keys during the game startup
-			// (allow escaping from network synchronization, or pressing enter after
-			//  an error message in the console)
-			{
-				switch (wParam)
-				{
-					case VK_ESCAPE: ev.key = KEY_ESCAPE;  break;
-					case VK_RETURN: ev.key = KEY_ENTER;   break;
-					case VK_SHIFT:  ev.key = KEY_LSHIFT;  break;
-					default: ev.key = MapVirtualKey((DWORD)wParam,2); // convert in to char
-				}
-			}
-
-			if (ev.key)
-				D_PostEvent (&ev);
-
-			return 0;
-			break;
-
-		// judgecutor:
-		// Handle mouse events
-		case WM_LBUTTONDOWN:
-		case WM_LBUTTONUP:
-		case WM_RBUTTONDOWN:
-		case WM_RBUTTONUP:
-		case WM_MBUTTONDOWN:
-		case WM_MBUTTONUP:
-		case WM_MOUSEMOVE:
-			if (nodinput)
-			{
-				mouse_keys = 0;
-				if (wParam & MK_LBUTTON)
-					mouse_keys |= 1;
-				if (wParam & MK_RBUTTON)
-					mouse_keys |= 2;
-				if (wParam & MK_MBUTTON)
-					mouse_keys |= 4;
-				I_GetSysMouseEvents(mouse_keys);
-			}
-			break;
-
-		case WM_XBUTTONUP:
-			if (nodinput)
-			{
-				ev.type = ev_keyup;
-				ev.key = KEY_MOUSE1 + 3 + HIWORD(wParam);
-				D_PostEvent(&ev);
-				return TRUE;
-			}
-			break;
-		case WM_XBUTTONDOWN:
-			if (nodinput)
-			{
-				ev.type = ev_keydown;
-				ev.key = KEY_MOUSE1 + 3 + HIWORD(wParam);
-				D_PostEvent(&ev);
-				return TRUE;
-			}
-			break;
-		case WM_MOUSEWHEEL:
-			//I_OutputMsg("MW_WHEEL dispatched.\n");
-			ev.type = ev_keydown;
-			if ((INT16)HIWORD(wParam) > 0)
-				ev.key = KEY_MOUSEWHEELUP;
-			else
-				ev.key = KEY_MOUSEWHEELDOWN;
-			D_PostEvent(&ev);
-			break;
-
-		case WM_SETTEXT:
-			COM_BufAddText((LPCSTR)lParam);
-			return TRUE;
-			break;
-
-		case WM_CLOSE:
-			PostQuitMessage(0);         //to quit while in-game
-			ev.key = KEY_ESCAPE;      //to exit network synchronization
-			ev.type = ev_keydown;
-			D_PostEvent (&ev);
-			return 0;
-		case WM_DESTROY:
-			//faB: main app loop will exit the loop and proceed with I_Quit()
-			PostQuitMessage(0);
-			break;
-
-		case WM_SYSCOMMAND:
-			// Don't allow the keyboard to activate the menu.
-			if(wParam == SC_KEYMENU)
-				return 0;
-
-			break;
-
-		default:
-			break;
-	}
-
-	return DefWindowProc(hWnd, message, wParam, lParam);
-}
-
-static inline VOID OpenTextConsole(VOID)
-{
-	HANDLE ci, co;
-	BOOL console;
-
-#ifdef _DEBUG
-	console = M_CheckParm("-noconsole") == 0;
-#else
-	console = M_CheckParm("-console") != 0;
-#endif
-
-	dedicated = M_CheckParm("-dedicated") != 0;
-
-	if (M_CheckParm("-detachconsole"))
-	{
-		if (FreeConsole())
-		{
-			I_OutputMsg("Detatched console.\n");
-			console = TRUE; //lets get back a console
-		}
-		else
-		{
-			I_OutputMsg("No console to detatch.\n");
-			I_ShowLastError(FALSE);
-		}
-	}
-
-	if (dedicated || console)
-	{
-		if (AllocConsole()) //Let get the real console HANDLEs, because Mingw's Bash is bad!
-		{
-			SetConsoleTitleA("SRB2 Console");
-			CONS_Printf(M_GetText("Hello, it's me, SRB2's Console Window\n"));
-		}
-		else
-		{
-			I_OutputMsg("We have a console already.\n");
-			I_ShowLastError(FALSE);
-			return;
-		}
-	}
-	else
-		return;
-
-	ci = CreateFile(TEXT("CONIN$") ,               GENERIC_READ, FILE_SHARE_READ,  NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
-	if (ci != INVALID_HANDLE_VALUE)
-	{
-		HANDLE sih = GetStdHandle(STD_INPUT_HANDLE);
-		if (sih != ci)
-		{
-			I_OutputMsg("Old STD_INPUT_HANDLE: %p\nNew STD_INPUT_HANDLE: %p\n", sih, ci);
-			SetStdHandle(STD_INPUT_HANDLE,ci);
-		}
-		else
-			I_OutputMsg("STD_INPUT_HANDLE already set at %p\n", ci);
-
-		if (GetFileType(ci) == FILE_TYPE_CHAR)
-		{
-#if 0
-			const DWORD CM = ENABLE_LINE_INPUT|ENABLE_ECHO_INPUT|ENABLE_PROCESSED_INPUT; //default mode but no ENABLE_MOUSE_INPUT
-			if (SetConsoleMode(ci,CM))
-			{
-				I_OutputMsg("Disabled mouse input on the console\n");
-			}
-			else
-			{
-				I_OutputMsg("Could not disable mouse input on the console\n");
-				I_ShowLastError(FALSE);
-			}
-#endif
-		}
-		else
-			I_OutputMsg("Handle CONIN$ in not a Console HANDLE\n");
-	}
-	else
-	{
-		I_OutputMsg("Could not get a CONIN$ HANDLE\n");
-		I_ShowLastError(FALSE);
-	}
-
-	co = CreateFile(TEXT("CONOUT$"), GENERIC_WRITE|GENERIC_READ, FILE_SHARE_WRITE, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
-	if (co != INVALID_HANDLE_VALUE)
-	{
-		HANDLE soh = GetStdHandle(STD_OUTPUT_HANDLE);
-		HANDLE seh = GetStdHandle(STD_ERROR_HANDLE);
-		if (soh != co)
-		{
-			I_OutputMsg("Old STD_OUTPUT_HANDLE: %p\nNew STD_OUTPUT_HANDLE: %p\n", soh, co);
-			SetStdHandle(STD_OUTPUT_HANDLE,co);
-		}
-		else
-			I_OutputMsg("STD_OUTPUT_HANDLE already set at %p\n", co);
-		if (seh != co)
-		{
-			I_OutputMsg("Old STD_ERROR_HANDLE: %p\nNew STD_ERROR_HANDLE: %p\n", seh, co);
-			SetStdHandle(STD_ERROR_HANDLE,co);
-		}
-		else
-			I_OutputMsg("STD_ERROR_HANDLE already set at %p\n", co);
-	}
-	else
-		I_OutputMsg("Could not get a CONOUT$ HANDLE\n");
-}
-
-
-//
-// Do that Windows initialization stuff...
-//
-static HWND OpenMainWindow (HINSTANCE hInstance, LPSTR wTitle)
-{
-	const LONG	styles = WS_CAPTION|WS_POPUP|WS_SYSMENU, exstyles = 0;
-	HWND        hWnd;
-	WNDCLASSEXA wc;
-	RECT		bounds;
-
-	// Set up and register window class
-	ZeroMemory(&wc, sizeof(wc));
-	wc.cbSize        = sizeof(wc);
-	wc.style         = CS_HREDRAW | CS_VREDRAW /*| CS_DBLCLKS*/;
-	wc.lpfnWndProc   = MainWndproc;
-	wc.hInstance     = hInstance;
-	wc.hIcon         = LoadIcon(hInstance, MAKEINTRESOURCE(IDI_DLICON1));
-	windowCursor     = LoadCursor(NULL, IDC_WAIT); //LoadCursor(hInstance, MAKEINTRESOURCE(IDC_DLCURSOR1));
-	wc.hCursor       = windowCursor;
-	wc.hbrBackground = (HBRUSH)GetStockObject(BLACK_BRUSH);
-	wc.lpszClassName = wClassName;
-
-	if (!RegisterClassExA(&wc))
-	{
-		I_OutputMsg("Error doing RegisterClassExA\n");
-		I_ShowLastError(TRUE);
-		return INVALID_HANDLE_VALUE;
-	}
-
-	// Create a window
-	// CreateWindowEx - seems to create just the interior, not the borders
-
-	bounds.left = 0;
-	bounds.right = dedicated ? 0 : specialmodes[0].width;
-	bounds.top = 0;
-	bounds.bottom = dedicated ? 0 : specialmodes[0].height;
-
-	AdjustWindowRectEx(&bounds, styles, FALSE, exstyles);
-
-	hWnd = CreateWindowExA(
-	       exstyles,                                 //ExStyle
-	       wClassName,                        //Classname
-	       wTitle,                            //Windowname
-	       styles,    //dwStyle       //WS_VISIBLE|WS_POPUP for bAppFullScreen
-	       0,
-	       0,
-	       bounds.right - bounds.left,        //GetSystemMetrics(SM_CXSCREEN),
-	       bounds.bottom - bounds.top,        //GetSystemMetrics(SM_CYSCREEN),
-	       NULL,                              //hWnd Parent
-	       NULL,                              //hMenu Menu
-	       hInstance,
-	       NULL);
-
-	if (hWnd == INVALID_HANDLE_VALUE)
-	{
-		I_OutputMsg("Error doing CreateWindowExA\n");
-		I_ShowLastError(TRUE);
-	}
-
-	return hWnd;
-}
-
-
-static inline BOOL tlErrorMessage(const TCHAR *err)
-{
-	/* make the cursor visible */
-	SetCursor(LoadCursor(NULL, IDC_ARROW));
-
-	//
-	// warn user if there is one
-	//
-	printf("Error %s..\n", err);
-	fflush(stdout);
-
-	MessageBox(hWndMain, err, TEXT("ERROR"), MB_OK);
-	return FALSE;
-}
-
-
-// ------------------
-// Command line stuff
-// ------------------
-#define         MAXCMDLINEARGS          64
-static  char *  myWargv[MAXCMDLINEARGS+1];
-static  char    myCmdline[512];
-
-static VOID     GetArgcArgv (LPSTR cmdline)
-{
-	LPSTR   tokenstr;
-	size_t  i = 0, len;
-	char    cSep = ' ';
-	BOOL    bCvar = FALSE, prevCvar = FALSE;
-
-	// split arguments of command line into argv
-	strlcpy (myCmdline, cmdline, sizeof(myCmdline));      // in case window's cmdline is in protected memory..for strtok
-	len = strlen (myCmdline);
-
-	myargc = 0;
-	while (myargc < MAXCMDLINEARGS)
-	{
-		// get token
-		while (myCmdline[i] == cSep)
-			i++;
-		if (i >= len)
-			break;
-		tokenstr = myCmdline + i;
-		if (myCmdline[i] == '"')
-		{
-			cSep = '"';
-			i++;
-			if (!prevCvar)    //cvar leave the "" in
-				tokenstr++;
-		}
-		else
-			cSep = ' ';
-
-		//cvar
-		if (myCmdline[i] == '+' && cSep == ' ')   //a + begins a cvarname, but not after quotes
-			bCvar = TRUE;
-		else
-			bCvar = FALSE;
-
-		while (myCmdline[i] &&
-				myCmdline[i] != cSep)
-			i++;
-
-		if (myCmdline[i] == '"')
-		{
-			cSep = ' ';
-			if (prevCvar)
-				i++; // get ending " quote in arg
-		}
-
-		prevCvar = bCvar;
-
-		if (myCmdline + i > tokenstr)
-		{
-			myWargv[myargc++] = tokenstr;
-		}
-
-		if (!myCmdline[i] || i >= len)
-			break;
-
-		myCmdline[i++] = '\0';
-	}
-	myWargv[myargc] = NULL;
-
-	// m_argv.c uses myargv[], we used myWargv because we fill the arguments ourselves
-	// and myargv is just a pointer, so we set it to point myWargv
-	myargv = myWargv;
-}
-
-static inline VOID MakeCodeWritable(VOID)
-{
-#ifdef USEASM // Disable write-protection of code segment
-	DWORD OldRights;
-	const DWORD NewRights = PAGE_EXECUTE_READWRITE;
-	PBYTE pBaseOfImage = (PBYTE)GetModuleHandle(NULL);
-	PIMAGE_DOS_HEADER dosH =(PIMAGE_DOS_HEADER)pBaseOfImage;
-	PIMAGE_NT_HEADERS ntH = (PIMAGE_NT_HEADERS)(pBaseOfImage + dosH->e_lfanew);
-	PIMAGE_OPTIONAL_HEADER oH = (PIMAGE_OPTIONAL_HEADER)
-		((PBYTE)ntH + sizeof (IMAGE_NT_SIGNATURE) + sizeof (IMAGE_FILE_HEADER));
-	LPVOID pA = pBaseOfImage+oH->BaseOfCode;
-	SIZE_T pS = oH->SizeOfCode;
-#if 1 // try to find the text section
-	PIMAGE_SECTION_HEADER ntS = IMAGE_FIRST_SECTION (ntH);
-	WORD s;
-	for (s = 0; s < ntH->FileHeader.NumberOfSections; s++)
-	{
-		if (memcmp (ntS[s].Name, ".text\0\0", 8) == 0)
-		{
-			pA = pBaseOfImage+ntS[s].VirtualAddress;
-			pS = ntS[s].Misc.VirtualSize;
-			break;
-		}
-	}
-#endif
-
-	if (!VirtualProtect(pA,pS,NewRights,&OldRights))
-		I_Error("Could not make code writable\n");
-#endif
-}
-
-// -----------------------------------------------------------------------------
-// HandledWinMain : called by exception handler
-// -----------------------------------------------------------------------------
-static int WINAPI HandledWinMain(HINSTANCE hInstance)
-{
-	LPSTR          args;
-
-#ifdef LOGMESSAGES
-	// DEBUG!!! - set logstream to NULL to disable debug log
-	// Replace WIN32 filehandle with standard C calls, because WIN32 doesn't handle \n properly.
-	logstream = fopen(va("%s"PATHSEP"%s", srb2home, "log.txt"), "wt");
-#endif
-
-	// fill myargc,myargv for m_argv.c retrieval of cmdline arguments
-	args = GetCommandLineA();
-	CONS_Printf("Command line arguments: '%s'\n", args);
-	GetArgcArgv(args);
-	// Create a text console window
-	OpenTextConsole();
-
-#ifdef _DEBUG
-	{
-		int i;
-		CONS_Printf("Myargc: %d\n", myargc);
-		for (i = 0; i < myargc; i++)
-			CONS_Printf("myargv[%d] : '%s'\n", i, myargv[i]);
-	}
-#endif
-
-	// open a dummy window, both OpenGL and DirectX need one.
-	if ((hWndMain = OpenMainWindow(hInstance, va("SRB2 "VERSIONSTRING))) == INVALID_HANDLE_VALUE)
-	{
-		tlErrorMessage(TEXT("Couldn't open window"));
-		return FALSE;
-	}
-
-	// currently starts DirectInput
-	CONS_Printf("I_StartupSystem() ...\n");
-	I_StartupSystem();
-	MakeCodeWritable();
-
-	// startup SRB2
-	CONS_Printf("Setting up SRB2...\n");
-	D_SRB2Main();
-	CONS_Printf("Entering main game loop...\n");
-	// never return
-	D_SRB2Loop();
-
-	// back to Windoze
-	return 0;
-}
-
-// -----------------------------------------------------------------------------
-// Exception handler calls WinMain for catching exceptions
-// -----------------------------------------------------------------------------
-int WINAPI WinMain (HINSTANCE hInstance,
-                    HINSTANCE hPrevInstance,
-                    LPSTR     lpCmdLine,
-                    int       nCmdShow)
-{
-	int Result = -1;
-	UNREFERENCED_PARAMETER(hPrevInstance);
-	UNREFERENCED_PARAMETER(lpCmdLine);
-	UNREFERENCED_PARAMETER(nCmdShow);
-
-	{
-#if 0
-		p_IsDebuggerPresent pfnIsDebuggerPresent = (p_IsDebuggerPresent)GetProcAddress(GetModuleHandleA("kernel32.dll"),"IsDebuggerPresent");
-		if((!pfnIsDebuggerPresent || !pfnIsDebuggerPresent())
-#ifdef BUGTRAP
-			&& !InitBugTrap()
-#endif
-		)
-#endif
-		{
-			LoadLibraryA("exchndl.dll");
-		}
-	}
-#ifndef __MINGW32__
-	prevExceptionFilter = SetUnhandledExceptionFilter(RecordExceptionInfo);
-#endif
-	Result = HandledWinMain(hInstance);
-#ifdef BUGTRAP
-	// This is safe even if BT didn't start.
-	ShutdownBugTrap();
-#endif
-
-	return Result;
-}
-#endif //_WINDOWS
diff --git a/src/win32/win_main.h b/src/win32/win_main.h
deleted file mode 100644
index 326a813ddd07952d412765a2c9aa282b74cf0fc9..0000000000000000000000000000000000000000
--- a/src/win32/win_main.h
+++ /dev/null
@@ -1,45 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief Win32 Sharing
-
-//#define WIN32_LEAN_AND_MEAN
-#define RPC_NO_WINDOWS_H
-#include <windows.h>
-#include <stdio.h>
-
-extern HWND hWndMain;
-
-extern INT appActive;
-
-VOID I_GetSysMouseEvents(INT mouse_state);
-extern UINT MSHWheelMessage;
-
-extern BOOL nodinput;
-BOOL LoadDirectInput(VOID);
-
-//faB: midi channel Volume set is delayed by the MIDI stream callback thread, see win_snd.c
-#define WM_MSTREAM_UPDATEVOLUME (WM_USER + 101)
-
-// defined in win_sys.c
-VOID I_BeginProfile(VOID); //for timing code
-DWORD I_EndProfile(VOID);
-
-VOID I_ShowLastError(BOOL MB);
-VOID I_LoadingScreen (LPCSTR msg);
-
-VOID I_RestartSysMouse(VOID);
-VOID I_DoStartupMouse(VOID);
diff --git a/src/win32/win_net.c b/src/win32/win_net.c
deleted file mode 100644
index 62c081bbecd7d7b0f536d2d3fc7c10682df99e31..0000000000000000000000000000000000000000
--- a/src/win32/win_net.c
+++ /dev/null
@@ -1,42 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief Win32 network interface
-
-#include "../doomdef.h"
-#include "../m_argv.h"
-#include "../i_net.h"
-
-#ifdef _WINDOWS
-
-//
-// NETWORKING
-//
-
-//
-// I_InitNetwork
-//
-boolean I_InitNetwork(void)
-{
-	if (M_CheckParm ("-net"))
-	{
-		I_Error("The Win32 version of SRB2 doesn't work with external drivers like ipxsetup, sersetup, or doomatic\n"
-		        "Read the documentation about \"-server\" and \"-connect\" parameters or just use the launcher\n");
-	}
-
-	return false;
-}
-#endif
diff --git a/src/win32/win_snd.c b/src/win32/win_snd.c
deleted file mode 100644
index 13f766728fa295dc03c852c72978b62ccc531c22..0000000000000000000000000000000000000000
--- a/src/win32/win_snd.c
+++ /dev/null
@@ -1,959 +0,0 @@
-/// \file
-/// \brief FMOD Ex interface for sound
-#include "../doomdef.h"
-#include "../sounds.h"
-#include "../i_sound.h"
-#include "../s_sound.h"
-#include "../w_wad.h"
-#include "../z_zone.h"
-#include "../byteptr.h"
-
-#include <fmod.h> // FMOD Ex
-#define errcode _errcode
-#include <fmod_errors.h>
-#undef errcode
-
-#ifdef HAVE_LIBGME
-#include "gme/gme.h"
-#define GME_TREBLE 5.0
-#define GME_BASS 1.0
-
-#ifdef HAVE_ZLIB
-#ifndef _MSC_VER
-#ifndef _LARGEFILE64_SOURCE
-#define _LARGEFILE64_SOURCE
-#endif
-#endif
-
-#ifndef _LFS64_LARGEFILE
-#define _LFS64_LARGEFILE
-#endif
-
-#ifndef _FILE_OFFSET_BITS
-#define _FILE_OFFSET_BITS 0
-#endif
-
-#include "zlib.h"
-#endif // HAVE_ZLIB
-#endif // HAVE_LIBGME
-
-static FMOD_SYSTEM *fsys;
-static FMOD_SOUND *music_stream;
-static FMOD_CHANNEL *music_channel;
-
-static UINT8 music_volume, midi_volume, sfx_volume;
-static INT32 current_track;
-
-#ifdef HAVE_LIBGME
-static Music_Emu *gme;
-#endif
-
-//
-// SYSTEM
-//
-
-// spew console messages for general errors.
-static void FMR_Debug(FMOD_RESULT e, int line)
-{
-	if (e != FMOD_OK)
-		CONS_Alert(CONS_ERROR, "FMOD:%d - %s\n", line, FMOD_ErrorString(e));
-}
-#define FMR(x) FMR_Debug(x, __LINE__)
-
-// for operations on music_channel ONLY.
-// returns false if music was released.
-// (in other words, if !FMR_MUSIC(op) return immediately,
-// because music_stream and music_channel are no longer valid.)
-static boolean FMR_Music_Debug(FMOD_RESULT e, int line)
-{
-	switch(e)
-	{
-	case FMOD_ERR_INVALID_HANDLE: // non-looping song ended
-	case FMOD_ERR_CHANNEL_STOLEN: // song ended and then sfx was played
-		FMOD_Sound_Release(music_stream);
-		music_stream = NULL;
-		return false;
-	default:
-		FMR_Debug(e, line);
-		break;
-	}
-	return true;
-}
-#define FMR_MUSIC(x) FMR_Music_Debug(x, __LINE__)
-
-void I_StartupSound(void)
-{
-	I_Assert(!sound_started);
-	sound_started = true;
-
-	FMR(FMOD_System_Create(&fsys));
-	FMR(FMOD_System_SetDSPBufferSize(fsys, 44100 / 30, 2));
-	FMR(FMOD_System_Init(fsys, 64, FMOD_INIT_VOL0_BECOMES_VIRTUAL, NULL));
-	music_stream = NULL;
-#ifdef HAVE_LIBGME
-	gme = NULL;
-#endif
-	current_track = -1;
-}
-
-void I_ShutdownSound(void)
-{
-	I_Assert(sound_started);
-	sound_started = false;
-
-#ifdef HAVE_LIBGME
-	if (gme)
-		gme_delete(gme);
-#endif
-	FMR(FMOD_System_Release(fsys));
-}
-
-void I_UpdateSound(void)
-{
-	FMR(FMOD_System_Update(fsys));
-}
-
-#ifdef HAVE_LIBGME
-// Callback hook to read streaming GME data.
-static FMOD_RESULT F_CALLBACK GMEReadCallback(FMOD_SOUND *sound, void *data, unsigned int datalen)
-{
-	Music_Emu *emu;
-	void *emuvoid = NULL;
-	// get our emu
-	FMR(FMOD_Sound_GetUserData(sound, &emuvoid));
-	emu = emuvoid;
-	// no emu? no play.
-	if (!emu)
-		return FMOD_ERR_FILE_EOF;
-	if (gme_track_ended(emu))
-	{
-		// don't delete the primary music stream
-		if (emu == gme)
-			return FMOD_ERR_FILE_EOF;
-		// do delete sfx streams
-		FMR(FMOD_Sound_SetUserData(sound, NULL));
-		gme_delete(emu);
-		return FMOD_ERR_FILE_EOF;
-	}
-	// play beautiful musics theme of ancient land.
-	if (gme_play(emu, datalen/2, data))
-		return FMOD_ERR_FILE_BAD;
-	// O.K
-	return FMOD_OK;
-}
-#endif
-
-//
-// SFX
-//
-
-// convert doom format sound (signed 8bit)
-// to an fmod format sound (unsigned 8bit)
-// and return the FMOD_SOUND.
-static inline FMOD_SOUND *ds2fmod(char *stream)
-{
-	FMOD_SOUND *sound;
-	UINT16 ver;
-	UINT16 freq;
-	UINT32 samples;
-	FMOD_CREATESOUNDEXINFO fmt;
-	UINT32 i;
-	UINT8 *p;
-
-	// lump header
-	ver = READUINT16(stream); // sound version format?
-	if (ver != 3) // It should be 3 if it's a doomsound...
-		return NULL; // onos! it's not a doomsound!
-	freq = READUINT16(stream);
-	samples = READUINT32(stream);
-	//CONS_Printf("FMT: v%d f%d, s%d, b%d\n", ver, freq, samples, bps);
-
-	memset(&fmt, 0, sizeof(FMOD_CREATESOUNDEXINFO));
-	fmt.cbsize = sizeof(FMOD_CREATESOUNDEXINFO);
-
-	// convert to unsigned
-	fmt.format = FMOD_SOUND_FORMAT_PCM8; // 8bit
-	fmt.length = samples*1; // 1 bps
-	fmt.numchannels = 1; // mono
-	fmt.defaultfrequency = freq;
-
-	// Make a duplicate of the stream to change format.
-	p = Z_Malloc(fmt.length, PU_SOUND, NULL);
-	for (i = 0; i < fmt.length; i++)
-		p[i] = (UINT8)(stream[i]+0x80); // convert from signed to unsigned
-	stream = (char *)p;
-
-	// Create FMOD_SOUND.
-	FMR(FMOD_System_CreateSound(fsys, stream, FMOD_CREATESAMPLE|FMOD_OPENMEMORY|FMOD_OPENRAW|FMOD_SOFTWARE|FMOD_LOWMEM, &fmt, &sound));
-
-	Z_Free(stream); // FMOD made its own copy, so we don't need this anymore.
-	return sound;
-}
-
-void *I_GetSfx(sfxinfo_t *sfx)
-{
-	FMOD_SOUND *sound;
-	char *lump;
-	FMOD_CREATESOUNDEXINFO fmt;
-#ifdef HAVE_LIBGME
-	Music_Emu *emu;
-	gme_info_t *info;
-#endif
-
-	if (sfx->lumpnum == LUMPERROR)
-		sfx->lumpnum = S_GetSfxLumpNum(sfx);
-	sfx->length = W_LumpLength(sfx->lumpnum);
-
-	lump = W_CacheLumpNum(sfx->lumpnum, PU_SOUND);
-	sound = ds2fmod(lump);
-	if (sound)
-	{
-		Z_Free(lump);
-		return sound;
-	}
-
-	// It's not a doom sound.
-	// Try to read it as an FMOD sound?
-
-	memset(&fmt, 0, sizeof(FMOD_CREATESOUNDEXINFO));
-	fmt.cbsize = sizeof(FMOD_CREATESOUNDEXINFO);
-	fmt.length = sfx->length;
-
-#ifdef HAVE_LIBGME
-	// VGZ format
-	if ((UINT8)lump[0] == 0x1F
-		&& (UINT8)lump[1] == 0x8B)
-	{
-#ifdef HAVE_ZLIB
-		UINT8 *inflatedData;
-		size_t inflatedLen;
-		z_stream stream;
-		int zErr; // Somewhere to handle any error messages zlib tosses out
-
-		memset(&stream, 0x00, sizeof (z_stream)); // Init zlib stream
-		// Begin the inflation process
-		inflatedLen = *(UINT32 *)(lump + (sfx->length-4)); // Last 4 bytes are the decompressed size, typically
-		inflatedData = (UINT8 *)Z_Malloc(inflatedLen, PU_SOUND, NULL); // Make room for the decompressed data
-		stream.total_in = stream.avail_in = sfx->length;
-		stream.total_out = stream.avail_out = inflatedLen;
-		stream.next_in = (UINT8 *)lump;
-		stream.next_out = inflatedData;
-
-		zErr = inflateInit2(&stream, 32 + MAX_WBITS);
-		if (zErr == Z_OK) // We're good to go
-		{
-			zErr = inflate(&stream, Z_FINISH);
-			if (zErr == Z_STREAM_END) {
-				// Run GME on new data
-				if (!gme_open_data(inflatedData, inflatedLen, &emu, 44100))
-				{
-					Z_Free(inflatedData); // GME supposedly makes a copy for itself, so we don't need this lying around
-					Z_Free(lump); // We're done with the uninflated lump now, too.
-
-					gme_start_track(emu, 0);
-					gme_track_info(emu, &info, 0);
-
-					fmt.format = FMOD_SOUND_FORMAT_PCM16;
-					fmt.defaultfrequency = 44100;
-					fmt.numchannels = 2;
-					fmt.length = ((UINT32)info->play_length * 441 / 10) * 4;
-					fmt.decodebuffersize = (44100 * 2) / 35;
-					fmt.pcmreadcallback = GMEReadCallback;
-					fmt.userdata = emu;
-
-					FMR(FMOD_System_CreateSound(fsys, NULL, FMOD_CREATESAMPLE|FMOD_OPENUSER|FMOD_SOFTWARE|FMOD_LOWMEM, &fmt, &sound));
-					return sound;
-				}
-			}
-			else
-			{
-				const char *errorType;
-				switch (zErr)
-				{
-					case Z_ERRNO:
-						errorType = "Z_ERRNO"; break;
-					case Z_STREAM_ERROR:
-						errorType = "Z_STREAM_ERROR"; break;
-					case Z_DATA_ERROR:
-						errorType = "Z_DATA_ERROR"; break;
-					case Z_MEM_ERROR:
-						errorType = "Z_MEM_ERROR"; break;
-					case Z_BUF_ERROR:
-						errorType = "Z_BUF_ERROR"; break;
-					case Z_VERSION_ERROR:
-						errorType = "Z_VERSION_ERROR"; break;
-					default:
-						errorType = "unknown error";
-				}
-				CONS_Alert(CONS_ERROR,"Encountered %s when running inflate: %s\n", errorType, stream.msg);
-			}
-			(void)inflateEnd(&stream);
-		}
-		else // Hold up, zlib's got a problem
-		{
-			const char *errorType;
-			switch (zErr)
-			{
-				case Z_ERRNO:
-					errorType = "Z_ERRNO"; break;
-				case Z_STREAM_ERROR:
-					errorType = "Z_STREAM_ERROR"; break;
-				case Z_DATA_ERROR:
-					errorType = "Z_DATA_ERROR"; break;
-				case Z_MEM_ERROR:
-					errorType = "Z_MEM_ERROR"; break;
-				case Z_BUF_ERROR:
-					errorType = "Z_BUF_ERROR"; break;
-				case Z_VERSION_ERROR:
-					errorType = "Z_VERSION_ERROR"; break;
-				default:
-					errorType = "unknown error";
-			}
-			CONS_Alert(CONS_ERROR,"Encountered %s when running inflateInit: %s\n", errorType, stream.msg);
-		}
-		Z_Free(inflatedData); // GME didn't open jack, but don't let that stop us from freeing this up
-#else
-		//CONS_Alert(CONS_ERROR,"Cannot decompress VGZ; no zlib support\n");
-#endif
-	}
-	// Try to read it as a GME sound
-	else if (!gme_open_data(lump, sfx->length, &emu, 44100))
-	{
-		Z_Free(lump);
-
-		gme_start_track(emu, 0);
-		gme_track_info(emu, &info, 0);
-
-		fmt.format = FMOD_SOUND_FORMAT_PCM16;
-		fmt.defaultfrequency = 44100;
-		fmt.numchannels = 2;
-		fmt.length = ((UINT32)info->play_length * 441 / 10) * 4;
-		fmt.decodebuffersize = (44100 * 2) / 35;
-		fmt.pcmreadcallback = GMEReadCallback;
-		fmt.userdata = emu;
-
-		gme_free_info(info);
-
-		FMR(FMOD_System_CreateSound(fsys, NULL, FMOD_CREATESAMPLE|FMOD_OPENUSER|FMOD_SOFTWARE|FMOD_LOWMEM, &fmt, &sound));
-		return sound;
-	}
-#endif
-
-	// Ogg, Mod, Midi, etc.
-	FMR(FMOD_System_CreateSound(fsys, lump, FMOD_CREATESAMPLE|FMOD_OPENMEMORY|FMOD_SOFTWARE|FMOD_LOWMEM, &fmt, &sound));
-	Z_Free(lump); // We're done with the lump now, at least.
-	return sound;
-}
-
-void I_FreeSfx(sfxinfo_t *sfx)
-{
-	if (sfx->data)
-		FMOD_Sound_Release(sfx->data);
-	sfx->data = NULL;
-}
-
-INT32 I_StartSound(sfxenum_t id, UINT8 vol, UINT8 sep, UINT8 pitch, UINT8 priority, INT32 channel)
-{
-	FMOD_SOUND *sound;
-	FMOD_CHANNEL *chan;
-	INT32 i;
-	float frequency;
-	(void)channel;
-
-	sound = (FMOD_SOUND *)S_sfx[id].data;
-	I_Assert(sound != NULL);
-
-	FMR(FMOD_System_PlaySound(fsys, FMOD_CHANNEL_FREE, sound, true, &chan));
-
-	if (sep == 0)
-		sep = 1;
-
-	FMR(FMOD_Channel_SetVolume(chan, (vol / 255.0) * (sfx_volume / 31.0)));
-	FMR(FMOD_Channel_SetPan(chan, (sep - 128) / 127.0));
-
-	FMR(FMOD_Sound_GetDefaults(sound, &frequency, NULL, NULL, NULL));
-	FMR(FMOD_Channel_SetFrequency(chan, (pitch / 128.0) * frequency));
-
-	FMR(FMOD_Channel_SetPriority(chan, priority));
-	//UNREFERENCED_PARAMETER(priority);
-	//FMR(FMOD_Channel_SetPriority(chan, 1 + ((0xff-vol)>>1))); // automatic priority 1 - 128 based on volume (priority 0 is music)
-
-	FMR(FMOD_Channel_GetIndex(chan, &i));
-	FMR(FMOD_Channel_SetPaused(chan, false));
-	return i;
-}
-
-void I_StopSound(INT32 handle)
-{
-	FMOD_CHANNEL *chan;
-	FMR(FMOD_System_GetChannel(fsys, handle, &chan));
-	if (music_stream && chan == music_channel)
-		return;
-	FMR(FMOD_Channel_Stop(chan));
-}
-
-boolean I_SoundIsPlaying(INT32 handle)
-{
-	FMOD_CHANNEL *chan;
-	FMOD_BOOL playing;
-	FMOD_RESULT e;
-	FMR(FMOD_System_GetChannel(fsys, handle, &chan));
-	if (music_stream && chan == music_channel)
-		return false;
-	e = FMOD_Channel_IsPlaying(chan, &playing);
-	switch(e)
-	{
-	case FMOD_ERR_INVALID_HANDLE: // Sound effect finished.
-	case FMOD_ERR_CHANNEL_STOLEN: // Sound effect interrupted. -- technically impossible due to GetChannel by handle. :(
-		return false; // therefore, it's not playing anymore.
-	default:
-		FMR(e);
-		break;
-	}
-	return (boolean)playing;
-}
-
-// seems to never be called on an invalid channel (calls I_SoundIsPlaying first?)
-// so I'm not gonna worry about it.
-void I_UpdateSoundParams(INT32 handle, UINT8 vol, UINT8 sep, UINT8 pitch)
-{
-	FMOD_CHANNEL *chan;
-	FMOD_SOUND *sound;
-	float frequency;
-
-	FMR(FMOD_System_GetChannel(fsys, handle, &chan));
-	FMR(FMOD_Channel_SetVolume(chan, (vol / 255.0) * (sfx_volume / 31.0)));
-	FMR(FMOD_Channel_SetPan(chan, (sep - 128) / 127.0));
-
-	FMR(FMOD_Channel_GetCurrentSound(chan, &sound));
-	FMR(FMOD_Sound_GetDefaults(sound, &frequency, NULL, NULL, NULL));
-	FMR(FMOD_Channel_SetFrequency(chan, (pitch / 128.0) * frequency));
-
-	//FMR(FMOD_Channel_SetPriority(chan, 1 + ((0xff-vol)>>1))); // automatic priority 1 - 128 based on volume (priority 0 is music)
-}
-
-void I_SetSfxVolume(UINT8 volume)
-{
-	// volume is 0 to 31.
-	sfx_volume = volume;
-}
-
-/// ------------------------
-//  MUSIC SYSTEM
-/// ------------------------
-
-void I_InitMusic(void)
-{
-}
-
-void I_ShutdownMusic(void)
-{
-	I_StopSong();
-}
-
-/// ------------------------
-//  MUSIC PROPERTIES
-/// ------------------------
-
-musictype_t I_SongType(void)
-{
-	FMOD_SOUND_TYPE type;
-
-#ifdef HAVE_LIBGME
-	if (gme)
-		return MU_GME;
-#endif
-
-	if (!music_stream)
-		return MU_NONE;
-
-	if (FMOD_Sound_GetFormat(music_stream, &type, NULL, NULL, NULL) == FMOD_OK)
-	{
-		switch(type)
-		{
-			case FMOD_SOUND_TYPE_WAV:
-				return MU_WAV;
-			case FMOD_SOUND_TYPE_MOD:
-				return MU_MOD;
-			case FMOD_SOUND_TYPE_MIDI:
-				return MU_MID;
-			case FMOD_SOUND_TYPE_OGGVORBIS:
-				return MU_OGG;
-			case FMOD_SOUND_TYPE_MPEG:
-				return MU_MP3;
-			case FMOD_SOUND_TYPE_FLAC:
-				return MU_FLAC;
-			default:
-				return MU_NONE;
-		}
-	}
-	else
-		return MU_NONE;
-}
-
-boolean I_SongPlaying(void)
-{
-	return (music_stream != NULL);
-}
-
-boolean I_SongPaused(void)
-{
-	FMOD_BOOL fmpaused = false;
-	if (music_stream)
-		FMOD_Channel_GetPaused(music_channel, &fmpaused);
-	return (boolean)fmpaused;
-}
-
-/// ------------------------
-//  MUSIC EFFECTS
-/// ------------------------
-
-boolean I_SetSongSpeed(float speed)
-{
-	FMOD_RESULT e;
-	float frequency;
-	if (!music_stream)
-		return false;
-	if (speed > 250.0f)
-		speed = 250.0f; //limit speed up to 250x
-
-#ifdef HAVE_LIBGME
-	// Try to set GME speed
-	if (gme)
-	{
-		gme_set_tempo(gme, speed);
-		return true;
-	}
-#endif
-
-	// Try to set Mod/Midi speed
-	e = FMOD_Sound_SetMusicSpeed(music_stream, speed);
-
-	if (e == FMOD_ERR_FORMAT)
-	{
-		// Just change pitch instead for Ogg/etc.
-		FMR(FMOD_Sound_GetDefaults(music_stream, &frequency, NULL, NULL, NULL));
-		FMR_MUSIC(FMOD_Channel_SetFrequency(music_channel, speed*frequency));
-	}
-	else
-		FMR_MUSIC(e);
-
-	return true;
-}
-
-/// ------------------------
-//  MUSIC PLAYBACK
-/// ------------------------
-
-boolean I_LoadSong(char *data, size_t len)
-{
-	FMOD_CREATESOUNDEXINFO fmt;
-	FMOD_RESULT e;
-	FMOD_TAG tag;
-	unsigned int loopstart, loopend;
-
-	if (
-#ifdef HAVE_LIBGME
-		gme ||
-#endif
-		music_stream
-	)
-		I_UnloadSong();
-
-	memset(&fmt, 0, sizeof(FMOD_CREATESOUNDEXINFO));
-	fmt.cbsize = sizeof(FMOD_CREATESOUNDEXINFO);
-
-#ifdef HAVE_LIBGME
-	if ((UINT8)data[0] == 0x1F
-		&& (UINT8)data[1] == 0x8B)
-	{
-#ifdef HAVE_ZLIB
-		UINT8 *inflatedData;
-		size_t inflatedLen;
-		z_stream stream;
-		int zErr; // Somewhere to handle any error messages zlib tosses out
-
-		memset(&stream, 0x00, sizeof (z_stream)); // Init zlib stream
-		// Begin the inflation process
-		inflatedLen = *(UINT32 *)(data + (len-4)); // Last 4 bytes are the decompressed size, typically
-		inflatedData = (UINT8 *)Z_Calloc(inflatedLen, PU_MUSIC, NULL); // Make room for the decompressed data
-		stream.total_in = stream.avail_in = len;
-		stream.total_out = stream.avail_out = inflatedLen;
-		stream.next_in = (UINT8 *)data;
-		stream.next_out = inflatedData;
-
-		zErr = inflateInit2(&stream, 32 + MAX_WBITS);
-		if (zErr == Z_OK) // We're good to go
-		{
-			zErr = inflate(&stream, Z_FINISH);
-			if (zErr == Z_STREAM_END) {
-				// Run GME on new data
-				if (!gme_open_data(inflatedData, inflatedLen, &gme, 44100))
-				{
-					gme_equalizer_t gmeq = {GME_TREBLE, GME_BASS, 0,0,0,0,0,0,0,0};
-					Z_Free(inflatedData); // GME supposedly makes a copy for itself, so we don't need this lying around
-					Z_Free(data); // We don't need this, either.
-					gme_set_equalizer(gme,&gmeq);
-					fmt.format = FMOD_SOUND_FORMAT_PCM16;
-					fmt.defaultfrequency = 44100;
-					fmt.numchannels = 2;
-					fmt.length = -1;
-					fmt.decodebuffersize = (44100 * 2) / 35;
-					fmt.pcmreadcallback = GMEReadCallback;
-					fmt.userdata = gme;
-					FMR(FMOD_System_CreateStream(fsys, NULL, FMOD_OPENUSER, &fmt, &music_stream));
-					return true;
-				}
-			}
-			else
-			{
-				const char *errorType;
-				switch (zErr)
-				{
-					case Z_ERRNO:
-						errorType = "Z_ERRNO"; break;
-					case Z_STREAM_ERROR:
-						errorType = "Z_STREAM_ERROR"; break;
-					case Z_DATA_ERROR:
-						errorType = "Z_DATA_ERROR"; break;
-					case Z_MEM_ERROR:
-						errorType = "Z_MEM_ERROR"; break;
-					case Z_BUF_ERROR:
-						errorType = "Z_BUF_ERROR"; break;
-					case Z_VERSION_ERROR:
-						errorType = "Z_VERSION_ERROR"; break;
-					default:
-						errorType = "unknown error";
-				}
-				CONS_Alert(CONS_ERROR,"Encountered %s when running inflate: %s\n", errorType, stream.msg);
-			}
-			(void)inflateEnd(&stream);
-		}
-		else // Hold up, zlib's got a problem
-		{
-			const char *errorType;
-			switch (zErr)
-			{
-				case Z_ERRNO:
-					errorType = "Z_ERRNO"; break;
-				case Z_STREAM_ERROR:
-					errorType = "Z_STREAM_ERROR"; break;
-				case Z_DATA_ERROR:
-					errorType = "Z_DATA_ERROR"; break;
-				case Z_MEM_ERROR:
-					errorType = "Z_MEM_ERROR"; break;
-				case Z_BUF_ERROR:
-					errorType = "Z_BUF_ERROR"; break;
-				case Z_VERSION_ERROR:
-					errorType = "Z_VERSION_ERROR"; break;
-				default:
-					errorType = "unknown error";
-			}
-			CONS_Alert(CONS_ERROR,"Encountered %s when running inflateInit: %s\n", errorType, stream.msg);
-		}
-		Z_Free(inflatedData); // GME didn't open jack, but don't let that stop us from freeing this up
-#else
-		//CONS_Alert(CONS_ERROR,"Cannot decompress VGZ; no zlib support\n");
-#endif
-	}
-	else if (!gme_open_data(data, len, &gme, 44100))
-	{
-		gme_equalizer_t gmeq = {GME_TREBLE, GME_BASS, 0,0,0,0,0,0,0,0};
-		Z_Free(data); // We don't need this anymore.
-		gme_set_equalizer(gme,&gmeq);
-		fmt.format = FMOD_SOUND_FORMAT_PCM16;
-		fmt.defaultfrequency = 44100;
-		fmt.numchannels = 2;
-		fmt.length = -1;
-		fmt.decodebuffersize = (44100 * 2) / 35;
-		fmt.pcmreadcallback = GMEReadCallback;
-		fmt.userdata = gme;
-		FMR(FMOD_System_CreateStream(fsys, NULL, FMOD_OPENUSER, &fmt, &music_stream));
-		return true;
-	}
-#endif
-
-	fmt.length = len;
-
-	e = FMOD_System_CreateStream(fsys, data, FMOD_OPENMEMORY_POINT, &fmt, &music_stream);
-	if (e != FMOD_OK)
-	{
-		if (e == FMOD_ERR_FORMAT)
-			CONS_Alert(CONS_WARNING, "Failed to play music lump due to invalid format.\n");
-		else
-			FMR(e);
-		return false;
-	}
-
-	// Try to find a loop point in streaming music formats (ogg, mp3)
-
-	// A proper LOOPPOINT is its own tag, stupid.
-	e = FMOD_Sound_GetTag(music_stream, "LOOPPOINT", 0, &tag);
-	if (e != FMOD_ERR_TAGNOTFOUND)
-	{
-		FMR(e);
-		loopstart = atoi((char *)tag.data); // assumed to be a string data tag.
-		FMR(FMOD_Sound_GetLoopPoints(music_stream, NULL, FMOD_TIMEUNIT_PCM, &loopend, FMOD_TIMEUNIT_PCM));
-		if (loopstart > 0)
-			FMR(FMOD_Sound_SetLoopPoints(music_stream, loopstart, FMOD_TIMEUNIT_PCM, loopend, FMOD_TIMEUNIT_PCM));
-		return true;
-	}
-
-	// Use LOOPMS for time in miliseconds.
-	e = FMOD_Sound_GetTag(music_stream, "LOOPMS", 0, &tag);
-	if (e != FMOD_ERR_TAGNOTFOUND)
-	{
-		FMR(e);
-		loopstart = atoi((char *)tag.data); // assumed to be a string data tag.
-		FMR(FMOD_Sound_GetLoopPoints(music_stream, NULL, FMOD_TIMEUNIT_MS, &loopend, FMOD_TIMEUNIT_PCM));
-		if (loopstart > 0)
-			FMR(FMOD_Sound_SetLoopPoints(music_stream, loopstart, FMOD_TIMEUNIT_MS, loopend, FMOD_TIMEUNIT_PCM));
-		return true;
-	}
-
-	// Try to fetch it from the COMMENT tag, like A.J. Freda
-	e = FMOD_Sound_GetTag(music_stream, "COMMENT", 0, &tag);
-	if (e != FMOD_ERR_TAGNOTFOUND)
-	{
-		char *loopText;
-		// Handle any errors that arose, first
-		FMR(e);
-		// Figure out where the number starts
-		loopText = strstr((char *)tag.data,"LOOPPOINT=");
-		if (loopText != NULL)
-		{
-			// Skip the "LOOPPOINT=" part.
-			loopText += 10;
-			// Convert it to our looppoint
-			// FMOD seems to ensure the tag is properly NULL-terminated.
-			// atoi will stop when it reaches anything that's not a number.
-			loopstart = atoi(loopText);
-			// Now do the rest like above
-			FMR(FMOD_Sound_GetLoopPoints(music_stream, NULL, FMOD_TIMEUNIT_PCM, &loopend, FMOD_TIMEUNIT_PCM));
-			if (loopstart > 0)
-				FMR(FMOD_Sound_SetLoopPoints(music_stream, loopstart, FMOD_TIMEUNIT_PCM, loopend, FMOD_TIMEUNIT_PCM));
-		}
-		return true;
-	}
-
-	// No special loop point
-	return true;
-}
-
-void I_UnloadSong(void)
-{
-	I_StopSong();
-#ifdef HAVE_LIBGME
-	if (gme)
-	{
-		gme_delete(gme);
-		gme = NULL;
-	}
-#endif
-	if (music_stream)
-	{
-		FMR(FMOD_Sound_Release(music_stream));
-		music_stream = NULL;
-	}
-}
-
-boolean I_PlaySong(boolean looping)
-{
-#ifdef HAVE_LIBGME
-	if (gme)
-	{
-		gme_start_track(gme, 0);
-		current_track = 0;
-		FMR(FMOD_System_PlaySound(fsys, FMOD_CHANNEL_FREE, music_stream, false, &music_channel));
-		FMR(FMOD_Channel_SetVolume(music_channel, music_volume / 31.0));
-		FMR(FMOD_Channel_SetPriority(music_channel, 0));
-		return true;
-	}
-#endif
-
-	FMR(FMOD_Sound_SetMode(music_stream, (looping ? FMOD_LOOP_NORMAL : FMOD_LOOP_OFF)));
-	FMR(FMOD_System_PlaySound(fsys, FMOD_CHANNEL_FREE, music_stream, false, &music_channel));
-	if (I_SongType() != MU_MID)
-		FMR(FMOD_Channel_SetVolume(music_channel, midi_volume / 31.0));
-	else
-		FMR(FMOD_Channel_SetVolume(music_channel, music_volume / 31.0));
-	FMR(FMOD_Channel_SetPriority(music_channel, 0));
-	current_track = 0;
-
-	return true;
-}
-
-void I_StopSong(void)
-{
-	if (music_channel)
-		FMR_MUSIC(FMOD_Channel_Stop(music_channel));
-}
-
-void I_PauseSong(void)
-{
-	if (music_channel)
-		FMR_MUSIC(FMOD_Channel_SetPaused(music_channel, true));
-}
-
-void I_ResumeSong(void)
-{
-	if (music_channel)
-		FMR_MUSIC(FMOD_Channel_SetPaused(music_channel, false));
-}
-
-void I_SetMusicVolume(UINT8 volume)
-{
-	if (!music_channel)
-		return;
-
-	// volume is 0 to 31.
-	if (I_SongType() == MU_MID)
-		music_volume = 31; // windows bug hack
-	else
-		music_volume = volume;
-
-	FMR_MUSIC(FMOD_Channel_SetVolume(music_channel, music_volume / 31.0));
-}
-
-UINT32 I_GetSongLength(void)
-{
-	UINT32 length;
-	if (I_SongType() == MU_MID)
-		return 0;
-	FMR_MUSIC(FMOD_Sound_GetLength(music_stream, &length, FMOD_TIMEUNIT_MS));
-	return length;
-}
-
-boolean I_SetSongLoopPoint(UINT32 looppoint)
-{
-        (void)looppoint;
-        return false;
-}
-
-UINT32 I_GetSongLoopPoint(void)
-{
-	return 0;
-}
-
-boolean I_SetSongPosition(UINT32 position)
-{
-	FMOD_RESULT e;
-	if(I_SongType() == MU_MID)
-		// Dummy out; this works for some MIDI, but not others.
-		// SDL does not support this for any MIDI.
-		return false;
-
-	e = FMOD_Channel_SetPosition(music_channel, position, FMOD_TIMEUNIT_MS);
-	if (e == FMOD_OK)
-		return true;
-	else if (e == FMOD_ERR_UNSUPPORTED // Only music modules, numbnuts!
-			|| e == FMOD_ERR_INVALID_POSITION) // Out-of-bounds!
-		return false;
-	else // Congrats, you horribly broke it somehow
-	{
-		FMR_MUSIC(e);
-		return false;
-	}
-}
-
-UINT32 I_GetSongPosition(void)
-{
-	FMOD_RESULT e;
-	unsigned int fmposition = 0;
-	if(I_SongType() == MU_MID)
-		// Dummy out because unsupported, even though FMOD does this correctly.
-		return 0;
-	e = FMOD_Channel_GetPosition(music_channel, &fmposition, FMOD_TIMEUNIT_MS);
-	if (e == FMOD_OK)
-		return (UINT32)fmposition;
-	else
-		return 0;
-}
-
-boolean I_SetSongTrack(INT32 track)
-{
-	if (track != current_track) // If the track's already playing, then why bother?
-	{
-		FMOD_RESULT e;
-
-		#ifdef HAVE_LIBGME
-		// If the specified track is within the number of tracks playing, then change it
-		if (gme)
-		{
-			if (track >= 0
-				&& track < gme_track_count(gme))
-			{
-				gme_err_t gme_e = gme_start_track(gme,track);
-				if (gme_e == NULL)
-				{
-					current_track = track;
-					return true;
-				}
-				else
-					CONS_Alert(CONS_ERROR, "Encountered GME error: %s\n", gme_e);
-			}
-			return false;
-		}
-		#endif // HAVE_LIBGME
-
-		// Try to set it via FMOD
-		e = FMOD_Channel_SetPosition(music_channel, (UINT32)track, FMOD_TIMEUNIT_MODORDER);
-		if (e == FMOD_OK) // We good
-		{
-			current_track = track;
-			return true;
-		}
-		else if (e == FMOD_ERR_UNSUPPORTED // Only music modules, numbnuts!
-				|| e == FMOD_ERR_INVALID_POSITION) // Out-of-bounds!
-			return false;
-		else // Congrats, you horribly broke it somehow
-		{
-			FMR_MUSIC(e);
-			return false;
-		}
-	}
-	return false;
-}
-
-/// ------------------------
-/// MUSIC FADING
-/// ------------------------
-
-void I_SetInternalMusicVolume(UINT8 volume)
-{
-	(void)volume;
-}
-
-void I_StopFadingSong(void)
-{
-}
-
-boolean I_FadeSongFromVolume(UINT8 target_volume, UINT8 source_volume, UINT32 ms, void (*callback)(void))
-{
-	(void)target_volume;
-	(void)source_volume;
-	(void)ms;
-	(void)callback;
-	return false;
-}
-
-boolean I_FadeSong(UINT8 target_volume, UINT32 ms, void (*callback)(void))
-{
-	(void)target_volume;
-	(void)ms;
-	(void)callback;
-	return false;
-}
-
-boolean I_FadeOutStopSong(UINT32 ms)
-{
-	(void)ms;
-	return false;
-}
-
-boolean I_FadeInPlaySong(UINT32 ms, boolean looping)
-{
-        (void)ms;
-        (void)looping;
-        return false;
-}
diff --git a/src/win32/win_sys.c b/src/win32/win_sys.c
deleted file mode 100644
index ff443935fa7f5a925e3539508b2fe5ce18244e09..0000000000000000000000000000000000000000
--- a/src/win32/win_sys.c
+++ /dev/null
@@ -1,3707 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief win32 system i/o
-///
-///	Startup & Shutdown routines for music,sound,timer,keyboard,...
-///	Signal handler to trap errors and exit cleanly.
-
-#include "../doomdef.h"
-
-#ifdef _WINDOWS
-
-#include <stdlib.h>
-#include <signal.h>
-#include <stdio.h>
-#include <string.h>
-#include <fcntl.h>
-#include <io.h>
-#include <stdarg.h>
-#include <direct.h>
-
-#include <mmsystem.h>
-
-#include "../m_misc.h"
-#include "../i_video.h"
-#include "../i_sound.h"
-#include "../i_system.h"
-
-#include "../d_net.h"
-#include "../g_game.h"
-
-#include "../d_main.h"
-
-#include "../m_argv.h"
-
-#include "../w_wad.h"
-#include "../z_zone.h"
-#include "../g_input.h"
-
-#include "../keys.h"
-
-#include "../screen.h"
-
-#include "../m_menu.h"
-
-// Wheel support for Win95/WinNT3.51
-#include <zmouse.h>
-
-// Taken from Win98/NT4.0
-#ifndef SM_MOUSEWHEELPRESENT
-#define SM_MOUSEWHEELPRESENT 75
-#endif
-
-#ifndef MSH_MOUSEWHEEL
-#ifdef UNICODE
-#define MSH_MOUSEWHEEL L"MSWHEEL_ROLLMSG"
-#else
-#define MSH_MOUSEWHEEL "MSWHEEL_ROLLMSG"
-#endif
-#endif
-
-#include "win_main.h"
-#include "win_dbg.h"
-#include "../i_joy.h"
-
-#ifndef NOMUMBLE
-// Mumble context string
-#include "../d_clisrv.h"
-#include "../byteptr.h"
-#endif
-
-#define DIRECTINPUT_VERSION     0x0500
-// Force dinput.h to generate old DX3 headers.
-#define DXVERSION_NTCOMPATIBLE  0x0300
-#include <dinput.h>
-#ifndef IDirectInputEffect_Stop
-#define IDirectInputEffect_Stop(p) (p)->lpVtbl->Stop(p)
-#endif
-#ifndef IDirectInputEffect_SetParameters
-#define IDirectInputEffect_SetParameters(p,a,b)   (p)->lpVtbl->SetParameters(p,a,b)
-#endif
-#ifndef IDirectInputEffect_Release
-#define IDirectInputEffect_Release(p)            (p)->lpVtbl->Release(p)
-#endif
-
-#include "fabdxlib.h"
-
-/// \brief max number of joystick buttons
-#define JOYBUTTONS_MAX 32 // rgbButtons[32]
-/// \brief max number of joystick button events
-#define JOYBUTTONS_MIN min((JOYBUTTONS),(JOYBUTTONS_MAX))
-
-/// \brief max number of joysick axies
-#define JOYAXISSET_MAX 4 // (lX, lY), (lZ,lRx), (lRy, lRz), rglSlider[2] is very diff
-/// \brief max number ofjoystick axis events
-#define JOYAXISSET_MIN min((JOYAXISSET),(JOYAXISSET_MAX))
-
-/// \brief max number of joystick hats
-#define JOYHATS_MAX 4 // rgdwPOV[4];
-/// \brief max number of joystick hat events
-#define JOYHATS_MIN min((JOYHATS),(JOYHATS_MAX))
-
-/// \brief max number of mouse buttons
-#define MOUSEBUTTONS_MAX 8 // 8 bit of BYTE and DIMOFS_BUTTON7
-/// \brief max number of muse button events
-#define MOUSEBUTTONS_MIN min((MOUSEBUTTONS),(MOUSEBUTTONS_MAX))
-
-// ==================
-// DIRECT INPUT STUFF
-// ==================
-BOOL bDX0300; // if true, we created a DirectInput 0x0300 version
-static LPDIRECTINPUTA lpDI = NULL;
-static LPDIRECTINPUTDEVICEA lpDIK = NULL;   // Keyboard
-static LPDIRECTINPUTDEVICEA lpDIM = NULL;   // mice
-static LPDIRECTINPUTDEVICEA lpDIJ = NULL;   // joystick 1P
-static LPDIRECTINPUTEFFECT lpDIE[NumberofForces];   // joystick 1Es
-static LPDIRECTINPUTDEVICE2A lpDIJA = NULL; // joystick 1I
-static LPDIRECTINPUTDEVICEA lpDIJ2 = NULL;  // joystick 2P
-static LPDIRECTINPUTEFFECT lpDIE2[NumberofForces];  // joystick 1Es
-static LPDIRECTINPUTDEVICE2A lpDIJ2A = NULL;// joystick 2I
-
-// Do not execute cleanup code more than once. See Shutdown_xxx() routines.
-UINT8 graphics_started = 0;
-UINT8 keyboard_started = 0;
-UINT8 sound_started = 0;
-static boolean mouse_enabled = false;
-static boolean joystick_detected = false;
-static boolean joystick2_detected = false;
-
-static VOID I_ShutdownKeyboard(VOID);
-static VOID I_GetKeyboardEvents(VOID);
-static VOID I_ShutdownJoystick(VOID);
-static VOID I_ShutdownJoystick2(VOID);
-
-static boolean entering_con_command = false;
-
-//
-// Why would this be system specific?? hmmmm....
-//
-// it is for virtual reality system, next incoming feature :)
-static ticcmd_t emptycmd;
-ticcmd_t *I_BaseTiccmd(void)
-{
-	return &emptycmd;
-}
-
-static ticcmd_t emptycmd2;
-ticcmd_t *I_BaseTiccmd2(void)
-{
-	return &emptycmd2;
-}
-
-// Allocates the base zone memory,
-// this function returns a valid pointer and size,
-// else it should interrupt the program immediately.
-//
-// now checks if mem could be allocated, this is still
-// prehistoric... there's a lot to do here: memory locking, detection
-// of win95 etc...
-//
-
-// return free and total memory in the system
-UINT32 I_GetFreeMem(UINT32* total)
-{
-	MEMORYSTATUS info;
-
-	info.dwLength = sizeof (MEMORYSTATUS);
-	GlobalMemoryStatus(&info);
-	if (total)
-		*total = (UINT32)info.dwTotalPhys;
-	return (UINT32)info.dwAvailPhys;
-}
-
-// ---------
-// I_Profile
-// Two little functions to profile our code using the high resolution timer
-// ---------
-static LARGE_INTEGER ProfileCount;
-VOID I_BeginProfile(VOID)
-{
-	if (!QueryPerformanceCounter(&ProfileCount))
-		I_Error("I_BeginProfile failed"); // can't profile without the high res timer
-}
-
-// we're supposed to use this to measure very small amounts of time,
-// that's why we return a DWORD and not a 64bit value
-DWORD I_EndProfile(VOID)
-{
-	LARGE_INTEGER CurrTime;
-	DWORD ret;
-	if (!QueryPerformanceCounter (&CurrTime))
-		I_Error("I_EndProfile failed");
-	if (CurrTime.QuadPart - ProfileCount.QuadPart > (LONGLONG)0xFFFFFFFFUL)
-		I_Error("I_EndProfile overflow");
-	ret = (DWORD)(CurrTime.QuadPart - ProfileCount.QuadPart);
-	// we can call I_EndProfile() several time, I_BeginProfile() need be called just once
-	ProfileCount = CurrTime;
-
-	return ret;
-}
-
-// ---------
-// I_GetTime
-// Use the High Resolution Timer if available,
-// else use the multimedia timer which has 1 millisecond precision on Windowz 95,
-// but lower precision on Windows NT
-// ---------
-static long hacktics = 0; // used locally for keyboard repeat keys
-static DWORD starttickcount = 0; // hack for win2k time bug
-
-tic_t I_GetTime(void)
-{
-	tic_t newtics = 0;
-
-	if (!starttickcount) // high precision timer
-	{
-		LARGE_INTEGER currtime; // use only LowPart if high resolution counter is not available
-		static LARGE_INTEGER basetime = {{0, 0}};
-
-		// use this if High Resolution timer is found
-		static LARGE_INTEGER frequency;
-
-		if (!basetime.LowPart)
-		{
-			if (!QueryPerformanceFrequency(&frequency))
-				frequency.QuadPart = 0;
-			else
-				QueryPerformanceCounter(&basetime);
-		}
-
-		if (frequency.LowPart && QueryPerformanceCounter(&currtime))
-		{
-			newtics = (int)((currtime.QuadPart - basetime.QuadPart) * NEWTICRATE
-				/ frequency.QuadPart);
-		}
-		else
-		{
-			currtime.LowPart = timeGetTime();
-			if (!basetime.LowPart)
-				basetime.LowPart = currtime.LowPart;
-			newtics = ((currtime.LowPart - basetime.LowPart)/(1000/NEWTICRATE));
-		}
-	}
-	else
-		newtics = (GetTickCount() - starttickcount)/(1000/NEWTICRATE);
-
-	hacktics = newtics; // a local counter for keyboard repeat key
-	return newtics;
-}
-
-void I_Sleep(void)
-{
-	if (cv_sleep.value != -1)
-		Sleep(cv_sleep.value);
-}
-
-// should move to i_video
-void I_WaitVBL(INT32 count)
-{
-	UNREFERENCED_PARAMETER(count);
-}
-
-// this is probably to activate the 'loading' disc icon
-// it should set a flag, that I_FinishUpdate uses to know
-// whether it draws a small 'loading' disc icon on the screen or not
-//
-// also it should explicitly draw the disc because the screen is
-// possibly not refreshed while loading
-//
-void I_BeginRead(void) {}
-
-// see above, end the 'loading' disc icon, set the flag false
-//
-void I_EndRead(void) {}
-
-// ===========================================================================================
-//                                                                                      EVENTS
-// ===========================================================================================
-static BOOL I_ReadyConsole(HANDLE ci)
-{
-	DWORD gotinput;
-	if (ci == INVALID_HANDLE_VALUE) return FALSE;
-	if (WaitForSingleObject(ci,0) != WAIT_OBJECT_0) return FALSE;
-	if (GetFileType(ci) != FILE_TYPE_CHAR) return FALSE;
-	if (!GetConsoleMode(ci, &gotinput)) return FALSE;
-	return (GetNumberOfConsoleInputEvents(ci, &gotinput) && gotinput);
-}
-
-static inline VOID I_GetConsoleEvents(VOID)
-{
-	event_t ev = {0,0,0,0};
-	HANDLE ci = GetStdHandle(STD_INPUT_HANDLE);
-	HANDLE co = GetStdHandle(STD_OUTPUT_HANDLE);
-	CONSOLE_SCREEN_BUFFER_INFO CSBI;
-	INPUT_RECORD input;
-	DWORD t;
-
-	while (I_ReadyConsole(ci) && ReadConsoleInput(ci, &input, 1, &t) && t)
-	{
-		ZeroMemory(&ev, sizeof(ev));
-		switch (input.EventType)
-		{
-			case KEY_EVENT:
-				if (input.Event.KeyEvent.bKeyDown)
-				{
-					ev.type = ev_console;
-					entering_con_command = true;
-					switch (input.Event.KeyEvent.wVirtualKeyCode)
-					{
-						case VK_ESCAPE:
-						case VK_TAB:
-							ev.key = KEY_NULL;
-							break;
-						case VK_SHIFT:
-							ev.key = KEY_LSHIFT;
-							break;
-						case VK_RETURN:
-							entering_con_command = false;
-							/* FALLTHRU */
-						default:
-							ev.key = MapVirtualKey(input.Event.KeyEvent.wVirtualKeyCode,2); // convert in to char
-					}
-					if (co != INVALID_HANDLE_VALUE && GetFileType(co) == FILE_TYPE_CHAR && GetConsoleMode(co, &t))
-					{
-						if (ev.key && ev.key != KEY_LSHIFT && ev.key != KEY_RSHIFT)
-						{
-#ifdef UNICODE
-							WriteConsole(co, &input.Event.KeyEvent.uChar.UnicodeChar, 1, &t, NULL);
-#else
-							WriteConsole(co, &input.Event.KeyEvent.uChar.AsciiChar, 1, &t, NULL);
-#endif
-						}
-						if (input.Event.KeyEvent.wVirtualKeyCode == VK_BACK
-							&& GetConsoleScreenBufferInfo(co,&CSBI))
-						{
-							WriteConsoleOutputCharacterA(co, " ",1, CSBI.dwCursorPosition, &t);
-						}
-					}
-				}
-				else
-				{
-					ev.type = ev_keyup;
-					switch (input.Event.KeyEvent.wVirtualKeyCode)
-					{
-						case VK_SHIFT:
-							ev.key = KEY_LSHIFT;
-							break;
-						default:
-							break;
-					}
-				}
-				if (ev.key) D_PostEvent(&ev);
-				break;
-			case MOUSE_EVENT:
-			case WINDOW_BUFFER_SIZE_EVENT:
-			case MENU_EVENT:
-			case FOCUS_EVENT:
-				break;
-		}
-	}
-}
-
-// ----------
-// I_GetEvent
-// Post new events for all sorts of user-input
-// ----------
-void I_GetEvent(void)
-{
-	I_GetConsoleEvents();
-	I_GetKeyboardEvents();
-	I_GetMouseEvents();
-	I_GetJoystickEvents();
-	I_GetJoystick2Events();
-}
-
-// ----------
-// I_OsPolling
-// ----------
-void I_OsPolling(void)
-{
-	MSG msg;
-	HANDLE ci = GetStdHandle(STD_INPUT_HANDLE);
-
-	// we need to dispatch messages to the window
-	// so the window procedure can respond to messages and PostEvent() for keys
-	// during D_SRB2Main startup.
-	// this one replaces the main loop of windows since I_OsPolling is called in the main loop
-	do
-	{
-		while (PeekMessage(&msg, NULL, 0, 0, PM_NOREMOVE))
-		{
-			if (GetMessage(&msg, NULL, 0, 0))
-			{
-				TranslateMessage(&msg);
-				DispatchMessage(&msg);
-			}
-			else // winspec : this is quit message
-				I_Quit();
-		}
-		if (!appActive && !netgame && !I_ReadyConsole(ci))
-			WaitMessage();
-	} while (!appActive && !netgame && !I_ReadyConsole(ci));
-
-	// this is called by the network synchronization,
-	// check keys and allow escaping
-	I_GetEvent();
-
-	// reset "emulated keys"
-	gamekeydown[KEY_MOUSEWHEELUP] = 0;
-	gamekeydown[KEY_MOUSEWHEELDOWN] = 0;
-}
-
-// ===========================================================================================
-//                                                                              TIMER
-// ===========================================================================================
-
-static VOID I_ShutdownTimer(VOID)
-{
-	timeEndPeriod(1);
-}
-
-//
-// Installs the timer interrupt handler with timer speed as TICRATE.
-//
-#define TIMER_ID 1
-#define TIMER_RATE (1000/TICRATE)
-void I_StartupTimer(void)
-{
-	// for win2k time bug
-	if (M_CheckParm("-gettickcount"))
-	{
-		starttickcount = GetTickCount();
-		CONS_Printf("Using GetTickCount()\n");
-	}
-	timeBeginPeriod(1);
-	I_AddExitFunc(I_ShutdownTimer);
-}
-
-// ===========================================================================================
-//                                                                   EXIT CODE, ERROR HANDLING
-// ===========================================================================================
-
-static int errorcount = 0; // phuck recursive errors
-static int shutdowning = false;
-
-//
-// Used to trap various signals, to make sure things get shut down cleanly.
-//
-#ifdef NDEBUG
-static void signal_handler(int num)
-{
-	//static char msg[] = "oh no! back to reality!\r\n";
-	const char *sigmsg;
-	char sigdef[64];
-
-	D_QuitNetGame(); // Fix server freezes
-	CL_AbortDownloadResume();
-	I_ShutdownSystem();
-
-	switch (num)
-	{
-		case SIGINT:
-			sigmsg = "interrupt";
-			break;
-		case SIGILL:
-			sigmsg = "illegal instruction - invalid function image";
-			break;
-		case SIGFPE:
-			sigmsg = "floating point exception";
-			break;
-		case SIGSEGV:
-			sigmsg = "segment violation";
-			break;
-		case SIGTERM:
-			sigmsg = "software termination signal from kill";
-			break;
-		case SIGBREAK:
-			sigmsg = "Ctrl-Break sequence";
-			break;
-		case SIGABRT:
-			sigmsg = "abnormal termination triggered by abort call";
-			break;
-		default:
-			sprintf(sigdef, "signal number %d", num);
-			sigmsg = sigdef;
-	}
-
-#ifdef LOGMESSAGES
-	if (logstream)
-	{
-		I_OutputMsg("signal_handler() error: %s\r\n", sigmsg);
-		fclose(logstream);
-		logstream = NULL;
-	}
-#endif
-
-	MessageBoxA(hWndMain, va("signal_handler(): %s", sigmsg), "SRB2 error", MB_OK|MB_ICONERROR);
-
-	signal(num, SIG_DFL); // default signal action
-	raise(num);
-}
-#endif
-
-//
-// put an error message (with format) on stderr
-//
-void I_OutputMsg(const char *fmt, ...)
-{
-	HANDLE co = GetStdHandle(STD_OUTPUT_HANDLE);
-	DWORD bytesWritten;
-	va_list argptr;
-	char txt[8192];
-
-	va_start(argptr,fmt);
-	vsprintf(txt, fmt, argptr);
-	va_end(argptr);
-
-#ifdef _MSC_VER
-	OutputDebugStringA(txt);
-#endif
-
-#ifdef LOGMESSAGES
-	if (logstream)
-	{
-		fwrite(txt, strlen(txt), 1, logstream);
-		fflush(logstream);
-	}
-#endif
-
-	if (co == INVALID_HANDLE_VALUE)
-		return;
-
-	if (GetFileType(co) == FILE_TYPE_CHAR && GetConsoleMode(co, &bytesWritten))
-	{
-		static COORD coordNextWrite = {0,0};
-		LPVOID oldLines = NULL;
-		INT oldLength;
-		CONSOLE_SCREEN_BUFFER_INFO csbi;
-
-		// Save the lines that we're going to obliterate.
-		GetConsoleScreenBufferInfo(co, &csbi);
-		oldLength = csbi.dwSize.X * (csbi.dwCursorPosition.Y - coordNextWrite.Y) + csbi.dwCursorPosition.X - coordNextWrite.X;
-
-		if (oldLength > 0)
-		{
-			LPVOID blank = malloc(oldLength);
-			if (!blank) return;
-			memset(blank, ' ', oldLength); // Blank out.
-			oldLines = malloc(oldLength*sizeof(TCHAR));
-			if (!oldLines)
-			{
-				free(blank);
-				return;
-			}
-
-			ReadConsoleOutputCharacter(co, oldLines, oldLength, coordNextWrite, &bytesWritten);
-
-			// Move to where we what to print - which is where we would've been,
-			// had console input not been in the way,
-			SetConsoleCursorPosition(co, coordNextWrite);
-
-			WriteConsoleA(co, blank, oldLength, &bytesWritten, NULL);
-			free(blank);
-
-			// And back to where we want to print again.
-			SetConsoleCursorPosition(co, coordNextWrite);
-		}
-
-		// Actually write the string now!
-		WriteConsoleA(co, txt, (DWORD)strlen(txt), &bytesWritten, NULL);
-
-		// Next time, output where we left off.
-		GetConsoleScreenBufferInfo(co, &csbi);
-		coordNextWrite = csbi.dwCursorPosition;
-
-		// Restore what was overwritten.
-		if (oldLines && entering_con_command)
-			WriteConsole(co, oldLines, oldLength, &bytesWritten, NULL);
-		if (oldLines) free(oldLines);
-	}
-	else // Redirected to a file.
-		WriteFile(co, txt, (DWORD)strlen(txt), &bytesWritten, NULL);
-}
-
-// display error messy after shutdowngfx
-//
-void I_Error(const char *error, ...)
-{
-	va_list argptr;
-	char txt[8192];
-
-	// added 11-2-98 recursive error detecting
-	if (shutdowning)
-	{
-		errorcount++;
-		// try to shutdown each subsystem separately
-		if (errorcount == 5)
-			I_ShutdownGraphics();
-		if (errorcount == 6)
-			I_ShutdownSystem();
-		if (errorcount == 7)
-		{
-			M_SaveConfig(NULL);
-			G_SaveGameData();
-		}
-		if (errorcount > 20)
-		{
-			// Don't print garbage
-			va_start(argptr,error);
-			vsprintf(txt, error, argptr);
-			va_end(argptr);
-
-			OutputDebugStringA(txt);
-			MessageBoxA(hWndMain, txt, "SRB2 Recursive Error", MB_OK|MB_ICONERROR);
-			W_Shutdown();
-			exit(-1); // recursive errors detected
-		}
-	}
-	shutdowning = true;
-
-	// put message to stderr
-	va_start(argptr, error);
-	wvsprintfA(txt, error, argptr);
-	va_end(argptr);
-
-	CONS_Printf("I_Error(): %s\n", txt); //don't change from CONS_Printf.
-
-	// saving one time is enough!
-	if (!errorcount)
-	{
-		M_SaveConfig(NULL); // save game config, cvars..
-		G_SaveGameData();
-	}
-
-	// save demo, could be useful for debug
-	// NOTE: demos are normally not saved here.
-	if (demorecording)
-		G_CheckDemoStatus();
-	if (metalrecording)
-		G_StopMetalRecording(false);
-
-	D_QuitNetGame();
-	CL_AbortDownloadResume();
-	M_FreePlayerSetupColors();
-
-	// shutdown everything that was started
-	I_ShutdownSystem();
-
-#ifdef LOGMESSAGES
-	if (logstream)
-	{
-		fclose(logstream);
-		logstream = NULL;
-	}
-#endif
-
-	MessageBoxA(hWndMain, txt, "SRB2 Error", MB_OK|MB_ICONERROR);
-
-	W_Shutdown();
-	exit(-1);
-}
-
-static inline VOID ShowEndTxt(HANDLE co)
-{
-	int i;
-	UINT16 j, att = 0;
-	int nlflag = 1;
-	CONSOLE_SCREEN_BUFFER_INFO backupcon;
-	COORD resizewin = {80,-1};
-	DWORD bytesWritten;
-	CHAR let = 0;
-	UINT16 *ptext;
-	LPVOID data;
-	lumpnum_t endoomnum = W_GetNumForName("ENDOOM");
-	//HANDLE ci = GetStdHandle(STD_INPUT_HANDLE);
-
-	/* get the lump with the text */
-	data = ptext = W_CacheLumpNum(endoomnum, PU_CACHE);
-
-	backupcon.wAttributes = FOREGROUND_RED|FOREGROUND_GREEN|FOREGROUND_BLUE; // Just in case
-	GetConsoleScreenBufferInfo(co, &backupcon); //Store old state
-	resizewin.Y = backupcon.dwSize.Y;
-	if (backupcon.dwSize.X < resizewin.X)
-		SetConsoleScreenBufferSize(co, resizewin);
-
-	for (i = 1; i <= 80*25; i++) // print 80x25 text and deal with the attributes too
-	{
-		j = (UINT16)(*ptext >> 8); // attribute first
-		let = (char)(*ptext & 0xff); // text senond
-		if (j != att) // attribute changed?
-		{
-			att = j; // save current attribute
-			SetConsoleTextAttribute(co, j); //set fg and bg color for buffer
-		}
-
-		WriteConsoleA(co, &let, 1, &bytesWritten, NULL); // now the text
-
-		if (nlflag && !(i % 80) && backupcon.dwSize.X > resizewin.X) // do we need a nl?
-		{
-			att = backupcon.wAttributes;
-			SetConsoleTextAttribute(co, att); // all attributes off
-			WriteConsoleA(co, "\n", 1, &bytesWritten, NULL); // newline to console
-		}
-		ptext++;
-	}
-	SetConsoleTextAttribute(co, backupcon.wAttributes); // all attributes off
-	//if (nlflag)
-	//	WriteConsoleA(co, "\n", 1, &bytesWritten, NULL);
-
-	getchar(); //pause!
-
-	Z_Free(data);
-}
-
-
-//
-// I_Quit: shutdown everything cleanly, in reverse order of Startup.
-//
-void I_Quit(void)
-{
-	HANDLE co = GetStdHandle(STD_OUTPUT_HANDLE);
-	DWORD mode;
-	// when recording a demo, should exit using 'q',
-	// but sometimes we forget and use Alt+F4, so save here too.
-	if (demorecording)
-		G_CheckDemoStatus();
-	if (metalrecording)
-		G_StopMetalRecording(false);
-
-	M_SaveConfig(NULL); // save game config, cvars..
-#ifndef NONET
-	D_SaveBan(); // save the ban list
-#endif
-	G_SaveGameData();
-
-	// maybe it needs that the ticcount continues,
-	// or something else that will be finished by I_ShutdownSystem(),
-	// so do it before.
-	D_QuitNetGame();
-	CL_AbortDownloadResume();
-
-	M_FreePlayerSetupColors();
-
-	// shutdown everything that was started
-	I_ShutdownSystem();
-
-	if (shutdowning || errorcount)
-		I_Error("Error detected (%d)", errorcount);
-
-#ifdef LOGMESSAGES
-	if (logstream)
-	{
-		I_OutputMsg("I_Quit(): end of logstream.\n");
-		fclose(logstream);
-		logstream = NULL;
-	}
-#endif
-	if (!M_CheckParm("-noendtxt") && W_CheckNumForName("ENDOOM")!=LUMPERROR
-		&& co != INVALID_HANDLE_VALUE && GetFileType(co) == FILE_TYPE_CHAR
-		&& GetConsoleMode(co, &mode))
-	{
-		printf("\r");
-		ShowEndTxt(co);
-	}
-	fflush(stderr);
-	if (myargmalloc)
-		free(myargv); // Deallocate allocated memory
-	W_Shutdown();
-	exit(0);
-}
-
-// --------------------------------------------------------------------------
-// I_ShowLastError
-// Print a GetLastError() error message, and if MB is TRUE, also display it in a MessageBox
-// --------------------------------------------------------------------------
-VOID I_ShowLastError(BOOL MB)
-{
-	LPSTR lpMsgBuf = NULL;
-	const DWORD LE = GetLastError();
-
-	if (LE == 0xdeadbeef) return; // Not a real error
-
-	FormatMessageA(FORMAT_MESSAGE_ALLOCATE_BUFFER|FORMAT_MESSAGE_FROM_SYSTEM|FORMAT_MESSAGE_IGNORE_INSERTS,
-		NULL, LE, MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
-		(LPVOID)&lpMsgBuf, 0, NULL);
-
-	if (!lpMsgBuf)
-	{
-		I_OutputMsg("GetLastError: Unknown\n");
-		return;
-	}
-
-	// Display the string
-	if (MB && LE) MessageBoxA(NULL, lpMsgBuf, "GetLastError", MB_OK|MB_ICONINFORMATION);
-
-	// put it in text console and log if any
-	I_OutputMsg("GetLastError: %s", lpMsgBuf);
-
-	// Free the buffer.
-	LocalFree(lpMsgBuf);
-}
-
-// ===========================================================================================
-// CLEAN STARTUP & SHUTDOWN HANDLING, JUST CLOSE EVERYTHING YOU OPENED.
-// ===========================================================================================
-//
-//
-static quitfuncptr quit_funcs[MAX_QUIT_FUNCS] =
-{
-	NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
-	NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL
-};
-
-// Adds a function to the list that need to be called by I_SystemShutdown().
-//
-void I_AddExitFunc(void (*func)())
-{
-	int c;
-
-	for (c = 0; c < MAX_QUIT_FUNCS; c++)
-	{
-		if (!quit_funcs[c])
-		{
-			quit_funcs[c] = func;
-			break;
-		}
-	}
-}
-
-// Removes a function from the list that need to be called by I_SystemShutdown().
-//
-void I_RemoveExitFunc(void (*func)())
-{
-	int c;
-
-	for (c = 0; c < MAX_QUIT_FUNCS; c++)
-	{
-		if (quit_funcs[c] == func)
-		{
-			while (c < MAX_QUIT_FUNCS - 1)
-			{
-				quit_funcs[c] = quit_funcs[c+1];
-				c++;
-			}
-			quit_funcs[MAX_QUIT_FUNCS-1] = NULL;
-			break;
-		}
-	}
-}
-
-// ===========================================================================================
-// DIRECT INPUT HELPER CODE
-// ===========================================================================================
-
-// Create a DirectInputDevice interface,
-// create a DirectInputDevice2 interface if possible
-static VOID CreateDevice2A(LPDIRECTINPUTA di, REFGUID pguid, LPDIRECTINPUTDEVICEA* lpDEV,
-                          LPDIRECTINPUTDEVICE2A* lpDEV2)
-{
-	HRESULT hr, hr2;
-	LPDIRECTINPUTDEVICEA lpdid1;
-	LPDIRECTINPUTDEVICE2A lpdid2 = NULL;
-
-	hr = IDirectInput_CreateDevice(di, pguid, &lpdid1, NULL);
-
-	if (SUCCEEDED(hr))
-	{
-		// get Device2 but only if we are not in DirectInput version 3
-		if (!bDX0300 && lpDEV2)
-		{
-			LPDIRECTINPUTDEVICE2A *rp = &lpdid2;
-			LPVOID *tp  = (LPVOID *)rp;
-			hr2 = IDirectInputDevice_QueryInterface(lpdid1, &IID_IDirectInputDevice2, tp);
-			if (FAILED(hr2))
-			{
-				CONS_Alert(CONS_ERROR, M_GetText("Could not create IDirectInput device 2"));
-				lpdid2 = NULL;
-			}
-		}
-	}
-	else
-		I_Error("Could not create IDirectInput device");
-
-	*lpDEV = lpdid1;
-	if (lpDEV2) // only if we requested it
-		*lpDEV2 = lpdid2;
-}
-
-// ===========================================================================================
-//                                                                          DIRECT INPUT MOUSE
-// ===========================================================================================
-
-#define DI_MOUSE_BUFFERSIZE 16 // number of data elements in mouse buffer
-
-//
-// Initialise the mouse.
-//
-static void I_ShutdownMouse(VOID);
-
-void I_StartupMouse(VOID)
-{
-	// this gets called when cv_usemouse is initted
-	// for the win32 version, we want to startup the mouse later
-	if (menuactive)
-	{
-		if (cv_usemouse.value)
-			I_DoStartupMouse();
-		else
-			I_ShutdownMouse();
-	}
-}
-
-static HANDLE mouse2filehandle = INVALID_HANDLE_VALUE;
-
-static void I_ShutdownMouse2(VOID)
-{
-	if (mouse2filehandle != INVALID_HANDLE_VALUE)
-	{
-		event_t event;
-		UINT i;
-
-		SetCommMask(mouse2filehandle, 0);
-
-		EscapeCommFunction(mouse2filehandle, CLRDTR);
-		EscapeCommFunction(mouse2filehandle, CLRRTS);
-
-		PurgeComm(mouse2filehandle, PURGE_TXABORT|PURGE_RXABORT|PURGE_TXCLEAR|PURGE_RXCLEAR);
-
-		CloseHandle(mouse2filehandle);
-
-		// emulate the up of all mouse buttons
-		for (i = 0; i < MOUSEBUTTONS; i++)
-		{
-			event.type = ev_keyup;
-			event.key = KEY_2MOUSE1 + i;
-			D_PostEvent(&event);
-		}
-
-		mouse2filehandle = INVALID_HANDLE_VALUE;
-	}
-}
-
-#define MOUSECOMBUFFERSIZE 256
-static int handlermouse2x, handlermouse2y, handlermouse2buttons;
-
-static VOID I_PoolMouse2(VOID)
-{
-	BYTE buffer[MOUSECOMBUFFERSIZE];
-	COMSTAT ComStat;
-	DWORD dwErrorFlags, dwLength, i;
-	CHAR dx, dy;
-	static BYTE bytenum, combytes[4];
-
-	ClearCommError(mouse2filehandle, &dwErrorFlags, &ComStat);
-	dwLength = min(MOUSECOMBUFFERSIZE, ComStat.cbInQue);
-
-	if (dwLength > 0)
-	{
-		if (!ReadFile(mouse2filehandle, buffer, dwLength, &dwLength, NULL))
-		{
-			CONS_Alert(CONS_ERROR, M_GetText("Read Error on secondary mouse port\n"));
-			return;
-		}
-
-		// parse the mouse packets
-		for (i = 0; i < dwLength; i++)
-		{
-			if ((buffer[i] & 64) == 64)
-				bytenum = 0;
-
-			if (bytenum < 4)
-				combytes[bytenum] = buffer[i];
-			bytenum++;
-
-			if (bytenum == 1)
-			{
-				handlermouse2buttons &= ~3;
-				handlermouse2buttons |= ((combytes[0] & (32+16)) >>4);
-			}
-			else if (bytenum == 3)
-			{
-				dx = (CHAR)((combytes[0] &  3) << 6);
-				dy = (CHAR)((combytes[0] & 12) << 4);
-				dx = (CHAR)(dx + combytes[1]);
-				dy = (CHAR)(dy + combytes[2]);
-				handlermouse2x += dx;
-				handlermouse2y += dy;
-			}
-			else if (bytenum == 4) // fourth byte (logitech mouses)
-			{
-				if (buffer[i] & 32)
-					handlermouse2buttons |= 4;
-				else
-					handlermouse2buttons &= ~4;
-			}
-		}
-	}
-}
-
-// secondary mouse doesn't use DirectX, therefore forget all about grabbing, acquire, etc.
-void I_StartupMouse2(void)
-{
-	DCB dcb;
-
-	if (mouse2filehandle != INVALID_HANDLE_VALUE)
-		I_ShutdownMouse2();
-
-	if (!cv_usemouse2.value)
-		return;
-
-	if (mouse2filehandle != INVALID_HANDLE_VALUE)
-	{
-		// COM file handle
-		mouse2filehandle = CreateFileA(cv_mouse2port.string, GENERIC_READ|GENERIC_WRITE,
-		                               0, // exclusive access
-		                               NULL, // no security attrs
-		                               OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
-		if (mouse2filehandle == INVALID_HANDLE_VALUE)
-		{
-			int e = GetLastError();
-			if (e == 5)
-				CONS_Alert(CONS_ERROR, M_GetText("Error opening %s!\n"), cv_mouse2port.string);
-			else
-				CONS_Alert(CONS_ERROR, M_GetText("Can't open %s: error %d\n"), cv_mouse2port.string, e);
-			return;
-		}
-	}
-
-	// buffers
-	SetupComm(mouse2filehandle, MOUSECOMBUFFERSIZE, MOUSECOMBUFFERSIZE);
-
-	// purge buffers
-	PurgeComm(mouse2filehandle, PURGE_TXABORT|PURGE_RXABORT|PURGE_TXCLEAR|PURGE_RXCLEAR);
-
-	// setup port to 1200 7N1
-	dcb.DCBlength = sizeof (DCB);
-
-	GetCommState(mouse2filehandle, &dcb);
-
-	dcb.BaudRate = CBR_1200;
-	dcb.ByteSize = 7;
-	dcb.Parity = NOPARITY;
-	dcb.StopBits = ONESTOPBIT;
-
-	dcb.fDtrControl = DTR_CONTROL_ENABLE;
-	dcb.fRtsControl = RTS_CONTROL_ENABLE;
-
-	dcb.fBinary = dcb.fParity = TRUE;
-
-	SetCommState(mouse2filehandle, &dcb);
-
-	I_AddExitFunc(I_ShutdownMouse2);
-}
-
-#define MAX_MOUSE_BTNS 5
-static int center_x, center_y;
-static INT old_mparms[3], new_mparms[3] = {0, 0, 1};
-static BOOL restore_mouse = FALSE;
-static INT old_mouse_state = 0;
-UINT MSHWheelMessage = 0;
-
-static VOID I_DoStartupSysMouse(VOID)
-{
-	boolean valid;
-	RECT w_rect;
-
-	valid = SystemParametersInfo(SPI_GETMOUSE, 0, old_mparms, 0);
-	if (valid)
-	{
-		new_mparms[2] = old_mparms[2];
-		restore_mouse = SystemParametersInfo(SPI_SETMOUSE, 0, new_mparms, 0);
-	}
-
-	if (bAppFullScreen)
-	{
-		w_rect.top = 0;
-		w_rect.left = 0;
-	}
-	else
-	{
-		w_rect.top = windowPosY;
-		w_rect.left = windowPosX;
-	}
-
-	w_rect.bottom = w_rect.top + VIDHEIGHT;
-	w_rect.right = w_rect.left + VIDWIDTH;
-	center_x = w_rect.left + (VIDWIDTH >> 1);
-	center_y = w_rect.top + (VIDHEIGHT >> 1);
-	SetCursor(NULL);
-	SetCursorPos(center_x, center_y);
-	SetCapture(hWndMain);
-	ClipCursor(&w_rect);
-}
-
-static VOID I_ShutdownSysMouse(VOID)
-{
-	if (restore_mouse)
-		SystemParametersInfo(SPI_SETMOUSE, 0, old_mparms, 0);
-	ClipCursor(NULL);
-	ReleaseCapture();
-}
-
-VOID I_RestartSysMouse(VOID)
-{
-	if (nodinput)
-	{
-		I_ShutdownSysMouse();
-		I_DoStartupSysMouse();
-	}
-}
-
-VOID I_GetSysMouseEvents(INT mouse_state)
-{
-	UINT i;
-	event_t event;
-	int xmickeys = 0, ymickeys = 0;
-	POINT c_pos;
-
-	for (i = 0; i < MAX_MOUSE_BTNS; i++)
-	{
-		// check if button pressed
-		if ((mouse_state & (1 << i)) && !(old_mouse_state & (1 << i)))
-		{
-			event.type = ev_keydown;
-			event.key = KEY_MOUSE1 + i;
-			D_PostEvent(&event);
-		}
-		// check if button released
-		if (!(mouse_state & (1 << i)) && (old_mouse_state & (1 << i)))
-		{
-			event.type = ev_keyup;
-			event.key = KEY_MOUSE1 + i;
-			D_PostEvent(&event);
-		}
-	}
-	old_mouse_state = mouse_state;
-
-	// proceed mouse movements
-	GetCursorPos(&c_pos);
-	xmickeys = c_pos.x - center_x;
-	ymickeys = c_pos.y - center_y;
-
-	if (xmickeys || ymickeys)
-	{
-		event.type  = ev_mouse;
-		event.key = 0;
-		event.x = xmickeys;
-		event.y = -ymickeys;
-		D_PostEvent(&event);
-		SetCursorPos(center_x, center_y);
-	}
-}
-
-// This is called just before entering the main game loop,
-// when we are going fullscreen and the loading screen has finished.
-VOID I_DoStartupMouse(VOID)
-{
-	DIPROPDWORD dip;
-
-	// mouse detection may be skipped by setting usemouse false
-	if (!cv_usemouse.value || M_CheckParm("-nomouse"))
-	{
-		mouse_enabled = false;
-		return;
-	}
-
-	if (nodinput)
-	{
-		CONS_Printf(M_GetText("\tMouse will not use DirectInput.\n"));
-		// System mouse input will be initiated by VID_SetMode
-		I_AddExitFunc(I_ShutdownMouse);
-
-		MSHWheelMessage = RegisterWindowMessage(MSH_MOUSEWHEEL);
-	}
-	else if (!lpDIM) // acquire the mouse only once
-	{
-		CreateDevice2A(lpDI, &GUID_SysMouse, &lpDIM, NULL);
-
-		if (lpDIM)
-		{
-			if (FAILED(IDirectInputDevice_SetDataFormat(lpDIM, &c_dfDIMouse)))
-				I_Error("Couldn't set mouse data format");
-
-			// create buffer for buffered data
-			dip.diph.dwSize = sizeof (dip);
-			dip.diph.dwHeaderSize = sizeof (dip.diph);
-			dip.diph.dwObj = 0;
-			dip.diph.dwHow = DIPH_DEVICE;
-			dip.dwData = DI_MOUSE_BUFFERSIZE;
-			if (FAILED(IDirectInputDevice_SetProperty(lpDIM, DIPROP_BUFFERSIZE, &dip.diph)))
-				I_Error("Couldn't set mouse buffer size");
-
-			if (FAILED(IDirectInputDevice_SetCooperativeLevel(lpDIM, hWndMain,
-				DISCL_EXCLUSIVE|DISCL_FOREGROUND)))
-			{
-				I_Error("Couldn't set mouse coop level");
-			}
-			I_AddExitFunc(I_ShutdownMouse);
-		}
-		else
-			I_Error("Couldn't create mouse input");
-	}
-
-	// if re-enabled while running, just set mouse_enabled true again,
-	// do not acquire the mouse more than once
-	mouse_enabled = true;
-}
-
-//
-// Shutdown Mouse DirectInput device
-//
-static void I_ShutdownMouse(void)
-{
-	int i;
-	event_t event;
-
-	CONS_Printf("I_ShutdownMouse()\n");
-
-	if (lpDIM)
-	{
-		IDirectInputDevice_Unacquire(lpDIM);
-		IDirectInputDevice_Release(lpDIM);
-		lpDIM = NULL;
-	}
-
-	// emulate the up of all mouse buttons
-	for (i = 0; i < MOUSEBUTTONS; i++)
-	{
-		event.type = ev_keyup;
-		event.key = KEY_MOUSE1 + i;
-		D_PostEvent(&event);
-	}
-	if (nodinput)
-		I_ShutdownSysMouse();
-
-	mouse_enabled = false;
-}
-
-//
-// Get buffered data from the mouse
-//
-void I_GetMouseEvents(void)
-{
-	DIDEVICEOBJECTDATA rgdod[DI_MOUSE_BUFFERSIZE];
-	DWORD dwItems, d;
-	HRESULT hr;
-
-	event_t event;
-	int xmickeys, ymickeys;
-
-	if (mouse2filehandle != INVALID_HANDLE_VALUE)
-	{
-		//mouse movement
-		static UINT8 lastbuttons2 = 0;
-
-		I_PoolMouse2();
-		// post key event for buttons
-		if (handlermouse2buttons != lastbuttons2)
-		{
-			int i, j = 1, k;
-			k = handlermouse2buttons ^ lastbuttons2; // only changed bit to 1
-			lastbuttons2 = (UINT8)handlermouse2buttons;
-
-			for (i = 0; i < MOUSEBUTTONS; i++, j <<= 1)
-				if (k & j)
-				{
-					if (handlermouse2buttons & j)
-						event.type = ev_keydown;
-					else
-						event.type = ev_keyup;
-					event.key = KEY_2MOUSE1 + i;
-					D_PostEvent(&event);
-				}
-		}
-
-		if (handlermouse2x || handlermouse2y)
-		{
-			event.type = ev_mouse2;
-			event.key = 0;
-			event.x = handlermouse2x<<1;
-			event.y = -handlermouse2y<<1;
-			handlermouse2x = 0;
-			handlermouse2y = 0;
-
-			D_PostEvent(&event);
-		}
-	}
-
-	if (!mouse_enabled || nodinput)
-		return;
-
-getBufferedData:
-	dwItems = DI_MOUSE_BUFFERSIZE;
-	hr = IDirectInputDevice_GetDeviceData(lpDIM, sizeof (DIDEVICEOBJECTDATA), rgdod, &dwItems, 0);
-
-	// If data stream was interrupted, reacquire the device and try again.
-	if (hr == DIERR_INPUTLOST || hr == DIERR_NOTACQUIRED)
-	{
-		hr = IDirectInputDevice_Acquire(lpDIM);
-		if (SUCCEEDED(hr))
-			goto getBufferedData;
-	}
-
-	// We got buffered input, act on it
-	if (SUCCEEDED(hr))
-	{
-		xmickeys = ymickeys = 0;
-
-		// dwItems contains number of elements read (could be 0)
-		for (d = 0; d < dwItems; d++)
-		{
-			if (rgdod[d].dwOfs >= DIMOFS_BUTTON0 &&
-				rgdod[d].dwOfs <  DIMOFS_BUTTON0 + MOUSEBUTTONS)
-			{
-				if (rgdod[d].dwData & 0x80) // Button down
-					event.type = ev_keydown;
-				else
-					event.type = ev_keyup; // Button up
-
-				event.key = rgdod[d].dwOfs - DIMOFS_BUTTON0 + KEY_MOUSE1;
-				D_PostEvent(&event);
-			}
-			else if (rgdod[d].dwOfs == DIMOFS_X)
-				xmickeys += rgdod[d].dwData;
-			else if (rgdod[d].dwOfs == DIMOFS_Y)
-				ymickeys += rgdod[d].dwData;
-
-			else if (rgdod[d].dwOfs == DIMOFS_Z)
-			{
-				// z-axes the wheel
-				if ((int)rgdod[d].dwData > 0)
-					event.key = KEY_MOUSEWHEELUP;
-				else
-					event.key = KEY_MOUSEWHEELDOWN;
-				event.type = ev_keydown;
-				D_PostEvent(&event);
-			}
-
-		}
-
-		if (xmickeys || ymickeys)
-		{
-			event.type = ev_mouse;
-			event.key = 0;
-			event.x = xmickeys;
-			event.y = -ymickeys;
-			D_PostEvent(&event);
-		}
-	}
-}
-
-void I_UpdateMouseGrab(void) {}
-
-// ===========================================================================================
-//                                                                       DIRECT INPUT JOYSTICK
-// ===========================================================================================
-
-struct DIJoyInfo_s
-{
-	BYTE X,Y,Z,Rx,Ry,Rz,U,V;
-	LONG ForceAxises;
-};
-typedef struct DIJoyInfo_s DIJoyInfo_t;
-
-// private info
-	static BYTE iJoyNum;        // used by enumeration
-	static DIJoyInfo_t JoyInfo;
-	static BYTE iJoy2Num;
-	static DIJoyInfo_t JoyInfo2;
-
-//-----------------------------------------------------------------------------
-// Name: EnumAxesCallback()
-// Desc: Callback function for enumerating the axes on a joystick and counting
-//       each force feedback enabled axis
-//-----------------------------------------------------------------------------
-static BOOL CALLBACK EnumAxesCallback(const DIDEVICEOBJECTINSTANCEA* pdidoi,
-                                VOID* pContext)
-{
-	DWORD* pdwNumForceFeedbackAxis = (DWORD*) pContext;
-
-	if ((pdidoi->dwFlags & DIDOI_FFACTUATOR) != 0)
-		(*pdwNumForceFeedbackAxis)++;
-
-	return DIENUM_CONTINUE;
-}
-
-
-static HRESULT SetupForceTacile(LPDIRECTINPUTDEVICE2A DJI, LPDIRECTINPUTEFFECT *DJE, DWORD FFAXIS, FFType EffectType,REFGUID EffectGUID)
-{
-	HRESULT hr;
-	DIEFFECT eff;
-	DWORD rgdwAxes[2] = { DIJOFS_X, DIJOFS_Y };
-	LONG rglDirection[2] = { 0, 0 };
-	DICONSTANTFORCE cf = { 0 }; // LONG lMagnitude
-	DIRAMPFORCE rf = {0,0}; // LONG lStart, lEnd;
-	DIPERIODIC pf = {0,0,0,0};
-	ZeroMemory(&eff, sizeof (eff));
-	if (FFAXIS > 2)
-		FFAXIS = 2; //up to 2 FFAXIS
-	eff.dwSize                  = sizeof (DIEFFECT);
-	eff.dwFlags                 = DIEFF_CARTESIAN | DIEFF_OBJECTOFFSETS; // Cartesian and data format offsets
-	eff.dwDuration              = INFINITE;
-	eff.dwSamplePeriod          = 0;
-	eff.dwGain                  = DI_FFNOMINALMAX;
-	eff.dwTriggerButton         = DIEB_NOTRIGGER;
-	eff.dwTriggerRepeatInterval = 0;
-	eff.cAxes                   = FFAXIS;
-	eff.rgdwAxes                = rgdwAxes;
-	eff.rglDirection            = rglDirection;
-	eff.lpEnvelope              = NULL;
-	eff.lpvTypeSpecificParams   = NULL;
-	if (EffectType == ConstantForce)
-	{
-		eff.cbTypeSpecificParams    = sizeof (cf);
-		eff.lpvTypeSpecificParams   = &cf;
-	}
-	else if (EffectType == RampForce)
-	{
-		eff.cbTypeSpecificParams    = sizeof (rf);
-		eff.lpvTypeSpecificParams   = &rf;
-	}
-	else if (EffectType >= SquareForce && SawtoothDownForce >= EffectType)
-	{
-		eff.cbTypeSpecificParams    = sizeof (pf);
-		eff.lpvTypeSpecificParams   = &pf;
-	}
-
-	// Create the prepared effect
-	if (FAILED(hr = IDirectInputDevice2_CreateEffect(DJI, EffectGUID,
-	 &eff, DJE, NULL)))
-	{
-		return hr;
-	}
-
-	if (NULL == *DJE)
-		return E_FAIL;
-
-	return hr;
-}
-
-static BOOL CALLBACK DIEnumEffectsCallback1(LPCDIEFFECTINFOA pdei, LPVOID pvRef)
-{
-	LPDIRECTINPUTEFFECT *DJE = pvRef;
-	if (DIEFT_GETTYPE(pdei->dwEffType) == DIEFT_CONSTANTFORCE)
-	{
-		if (SUCCEEDED(SetupForceTacile(lpDIJA,DJE, JoyInfo.ForceAxises, ConstantForce, &pdei->guid)))
-			return DIENUM_STOP;
-	}
-	if (DIEFT_GETTYPE(pdei->dwEffType) == DIEFT_RAMPFORCE)
-	{
-		if (SUCCEEDED(SetupForceTacile(lpDIJA,DJE, JoyInfo.ForceAxises, RampForce, &pdei->guid)))
-			return DIENUM_STOP;
-	}
-	return DIENUM_CONTINUE;
-}
-
-static BOOL CALLBACK DIEnumEffectsCallback2(LPCDIEFFECTINFOA pdei, LPVOID pvRef)
-{
-	LPDIRECTINPUTEFFECT *DJE = pvRef;
-	if (DIEFT_GETTYPE(pdei->dwEffType) == DIEFT_CONSTANTFORCE)
-	{
-		if (SUCCEEDED(SetupForceTacile(lpDIJ2A,DJE, JoyInfo2.ForceAxises, ConstantForce, &pdei->guid)))
-			return DIENUM_STOP;
-	}
-	if (DIEFT_GETTYPE(pdei->dwEffType) == DIEFT_RAMPFORCE)
-	{
-		if (SUCCEEDED(SetupForceTacile(lpDIJ2A,DJE, JoyInfo2.ForceAxises, RampForce, &pdei->guid)))
-			return DIENUM_STOP;
-	}
-	return DIENUM_CONTINUE;
-}
-
-static REFGUID DIETable[] =
-{
-	&GUID_ConstantForce, //ConstantForce
-	&GUID_RampForce,     //RampForce
-	&GUID_Square,        //SquareForce
-	&GUID_Sine,          //SineForce
-	&GUID_Triangle,      //TriangleForce
-	&GUID_SawtoothUp,    //SawtoothUpForce
-	&GUID_SawtoothDown,  //SawtoothDownForce
-	(REFGUID)-1,         //NumberofForces
-};
-
-static HRESULT SetupAllForces(LPDIRECTINPUTDEVICE2A DJI, LPDIRECTINPUTEFFECT DJE[], DWORD FFAXIS)
-{
-	FFType ForceType = EvilForce;
-	if (DJI == lpDIJA)
-	{
-		IDirectInputDevice2_EnumEffects(DJI,DIEnumEffectsCallback1,&DJE[ConstantForce],DIEFT_CONSTANTFORCE);
-		IDirectInputDevice2_EnumEffects(DJI,DIEnumEffectsCallback1,&DJE[RampForce],DIEFT_RAMPFORCE);
-	}
-	else if (DJI == lpDIJA)
-	{
-		IDirectInputDevice2_EnumEffects(DJI,DIEnumEffectsCallback2,&DJE[ConstantForce],DIEFT_CONSTANTFORCE);
-		IDirectInputDevice2_EnumEffects(DJI,DIEnumEffectsCallback2,&DJE[RampForce],DIEFT_RAMPFORCE);
-	}
-	for (ForceType = SquareForce; ForceType >  NumberofForces && DIETable[ForceType] != (REFGUID)-1; ForceType++)
-		if (DIETable[ForceType])
-			SetupForceTacile(DJI,&DJE[ForceType], FFAXIS, ForceType, DIETable[ForceType]);
-	return S_OK;
-}
-
-static inline VOID LimitEffect(LPDIEFFECT eff, FFType EffectType)
-{
-	LPDICONSTANTFORCE pCF = eff->lpvTypeSpecificParams;
-	LPDIPERIODIC pDP= eff->lpvTypeSpecificParams;
-	if (eff->rglDirection)
-	{
-	}
-/*	if (eff->dwDuration != INFINITE && eff->dwDuration < 0)
-	{
-		eff->dwDuration = 0;
-	}*/
-	if (eff->dwGain != 0)
-	{
-		if (eff->dwGain > DI_FFNOMINALMAX)
-			eff->dwGain = DI_FFNOMINALMAX;
-		//else if (eff->dwGain < -DI_FFNOMINALMAX)
-		//	eff->dwGain = DI_FFNOMINALMAX;
-	}
-	if (EffectType == ConstantForce && pCF->lMagnitude)
-	{
-	}
-	else if (EffectType >= SquareForce && SawtoothDownForce >= EffectType && pDP)
-	{
-	}
-
-}
-
-static HRESULT SetForceTacile(LPDIRECTINPUTEFFECT SDIE, const JoyFF_t *FF,DWORD FFAXIS, FFType EffectType)
-{
-	DIEFFECT eff;
-	HRESULT hr;
-	LONG Magnitude;
-	LONG rglDirection[2] = { 0, 0 };
-	DICONSTANTFORCE cf = { 0 }; // LONG lMagnitude
-	DIRAMPFORCE rf = {0,0}; // LONG lStart, lEnd;
-	DIPERIODIC pf = {0,0,0,0};
-	if (!FF)
-		IDirectInputEffect_Stop(SDIE);
-	Magnitude = FF->Magnitude;
-	ZeroMemory(&eff, sizeof (eff));
-	eff.dwSize                  = sizeof (eff);
-	//DIEP_START
-	eff.dwFlags                 = DIEFF_CARTESIAN | DIEFF_OBJECTOFFSETS; // Cartesian and data format offsets
-	//DIEP_DURATION
-	eff.dwDuration              = FF->Duration;
-	//DIEP_GAIN
-	eff.dwGain                  = FF->Gain;
-	//DIEP_DIRECTION
-	eff.rglDirection            = rglDirection;
-	//DIEP_TYPESPECIFICPARAMS
-	if (FFAXIS > 1)
-	{
-		double dMagnitude;
-		dMagnitude                  = (double)Magnitude;
-		dMagnitude                  = hypot(dMagnitude, dMagnitude);
-		Magnitude                   = (DWORD)dMagnitude;
-		rglDirection[0]             = FF->ForceX;
-		rglDirection[1]             = FF->ForceY;
-	}
-	if (EffectType == ConstantForce)
-	{
-		cf.lMagnitude               = Magnitude;
-		eff.cbTypeSpecificParams    = sizeof (cf);
-		eff.lpvTypeSpecificParams   = &cf;
-	}
-	else if (EffectType == RampForce)
-	{
-		rf.lStart                   = FF->Start;
-		rf.lEnd                     = FF->End;
-		eff.cbTypeSpecificParams    = sizeof (rf);
-		eff.lpvTypeSpecificParams   = &rf;
-	}
-	else if (EffectType >= SquareForce && SawtoothDownForce >= EffectType)
-	{
-		pf.dwMagnitude              = Magnitude;
-		pf.lOffset                  = FF->Offset;
-		pf.dwPhase                  = FF->Phase;
-		pf.dwPeriod                 = FF->Period;
-		eff.cbTypeSpecificParams    = sizeof (pf);
-		eff.lpvTypeSpecificParams   = &pf;
-	}
-
-	LimitEffect(&eff, EffectType);
-
-	hr = IDirectInputEffect_SetParameters(SDIE, &eff,
-	 DIEP_START|DIEP_DURATION|DIEP_GAIN|DIEP_DIRECTION|DIEP_TYPESPECIFICPARAMS);
-	return hr;
-}
-
-void I_Tactile(FFType Type, const JoyFF_t *Effect)
-{
-	if (!lpDIJA) return;
-	if (FAILED(IDirectInputDevice2_Acquire(lpDIJA)))
-		return;
-	if (Type == EvilForce)
-		IDirectInputDevice2_SendForceFeedbackCommand(lpDIJA,DISFFC_STOPALL);
-	if (Type <= EvilForce || Type > NumberofForces || !lpDIE[Type])
-		return;
-	SetForceTacile(lpDIE[Type], Effect, JoyInfo.ForceAxises, Type);
-}
-
-void I_Tactile2(FFType Type, const JoyFF_t *Effect)
-{
-	if (!lpDIJ2A) return;
-	if (FAILED(IDirectInputDevice2_Acquire(lpDIJ2A)))
-		return;
-	if (Type == EvilForce)
-		IDirectInputDevice2_SendForceFeedbackCommand(lpDIJ2A,DISFFC_STOPALL);
-	if (Type <= EvilForce || Type > NumberofForces || !lpDIE2[Type])
-		return;
-	SetForceTacile(lpDIE2[Type],Effect, JoyInfo2.ForceAxises, Type);
-}
-
-// ------------------
-// SetDIDwordProperty (HELPER)
-// Set a DWORD property on a DirectInputDevice.
-// ------------------
-static HRESULT SetDIDwordProperty(LPDIRECTINPUTDEVICEA pdev,
-                                   REFGUID guidProperty,
-                                   DWORD dwObject,
-                                   DWORD dwHow,
-                                   DWORD dwValue)
-{
-	DIPROPDWORD dipdw;
-
-	dipdw.diph.dwSize       = sizeof (dipdw);
-	dipdw.diph.dwHeaderSize = sizeof (dipdw.diph);
-	dipdw.diph.dwObj        = dwObject;
-	dipdw.diph.dwHow        = dwHow;
-	dipdw.dwData            = dwValue;
-
-	return IDirectInputDevice_SetProperty(pdev, guidProperty, &dipdw.diph);
-}
-
-#define DIDEADZONE 0000 //2500
-
-// ---------------
-// DIEnumJoysticks
-// There is no such thing as a 'system' joystick, contrary to mouse,
-// we must enumerate and choose one joystick device to use
-// ---------------
-static BOOL CALLBACK DIEnumJoysticks (LPCDIDEVICEINSTANCEA lpddi,
-                                       LPVOID pvRef)   //cv_usejoystick
-{
-	LPDIRECTINPUTDEVICEA pdev;
-	DIPROPRANGE          diprg;
-	DIDEVCAPS            caps;
-	BOOL                 bUseThisOne = FALSE;
-
-	iJoyNum++;
-
-	//faB: if cv holds a string description of joystick, the value from atoi() is 0
-	//     else, the value was probably set by user at console to one of the previously
-	//     enumerated joysticks
-	if (((consvar_t *)pvRef)->value == iJoyNum || !strcmp(((consvar_t *)pvRef)->string, lpddi->tszProductName))
-		bUseThisOne = TRUE;
-
-	//I_OutputMsg(" cv joy is %s\n", ((consvar_t *)pvRef)->string);
-
-	// print out device name
-	CONS_Printf("%c%d: %s\n",
-	            (bUseThisOne) ? '\2' : ' ',   // show name in white if this is the one we will use
-	            iJoyNum,
-	            //(GET_DIDEVICE_SUBTYPE(lpddi->dwDevType) == DIDEVTYPEJOYSTICK_GAMEPAD) ? "Gamepad " : "Joystick",
-	            lpddi->tszProductName); //, lpddi->tszInstanceName);
-
-	// use specified joystick (cv_usejoystick.value in pvRef)
-	if (!bUseThisOne)
-		return DIENUM_CONTINUE;
-
-	((consvar_t *)pvRef)->value = iJoyNum;
-	if (IDirectInput_CreateDevice(lpDI, &lpddi->guidInstance,
-	                              &pdev, NULL) != DI_OK)
-	{
-		// if it failed, then we can't use this joystick for some
-		// bizarre reason.  (Maybe the user unplugged it while we
-		// were in the middle of enumerating it.)  So continue enumerating
-		I_OutputMsg("DIEnumJoysticks(): CreateDevice FAILED\n");
-		return DIENUM_CONTINUE;
-	}
-
-	// get the Device capabilities
-	//
-	caps.dwSize = sizeof (DIDEVCAPS_DX3);
-	if (FAILED(IDirectInputDevice_GetCapabilities (pdev, &caps)))
-	{
-		I_OutputMsg("DIEnumJoysticks(): GetCapabilities FAILED\n");
-		IDirectInputDevice_Release (pdev);
-		return DIENUM_CONTINUE;
-	}
-	if (!(caps.dwFlags & DIDC_ATTACHED))   // should be, since we enumerate only attached devices
-		return DIENUM_CONTINUE;
-
-	Joystick.bJoyNeedPoll = ((caps.dwFlags & DIDC_POLLEDDATAFORMAT) != 0);
-
-	if (caps.dwFlags & DIDC_FORCEFEEDBACK)
-		JoyInfo.ForceAxises = 0;
-	else
-		JoyInfo.ForceAxises = -1;
-
-	Joystick.bGamepadStyle = (GET_DIDEVICE_SUBTYPE(caps.dwDevType) == DIDEVTYPEJOYSTICK_GAMEPAD);
-	//I_OutputMsg("Gamepad: %d\n", Joystick.bGamepadStyle);
-
-
-	CONS_Printf(M_GetText("Capabilities: %lu axes, %lu buttons, %lu POVs, poll %u, Gamepad %d\n"), caps.dwAxes, caps.dwButtons, caps.dwPOVs, Joystick.bJoyNeedPoll, Joystick.bGamepadStyle);
-
-	// Set the data format to "simple joystick" - a predefined data format
-	//
-	// A data format specifies which controls on a device we
-	// are interested in, and how they should be reported.
-	//
-	// This tells DirectInput that we will be passing a
-	// DIJOYSTATE structure to IDirectInputDevice::GetDeviceState.
-	if (IDirectInputDevice_SetDataFormat (pdev, &c_dfDIJoystick) != DI_OK)
-	{
-		I_OutputMsg("DIEnumJoysticks(): SetDataFormat FAILED\n");
-		IDirectInputDevice_Release (pdev);
-		return DIENUM_CONTINUE;
-	}
-
-	// Set the cooperativity level to let DirectInput know how
-	// this device should interact with the system and with other
-	// DirectInput applications.
-	if (IDirectInputDevice_SetCooperativeLevel (pdev, hWndMain,
-	 DISCL_EXCLUSIVE | DISCL_FOREGROUND) != DI_OK)
-	{
-		I_OutputMsg("DIEnumJoysticks(): SetCooperativeLevel FAILED\n");
-		IDirectInputDevice_Release (pdev);
-		return DIENUM_CONTINUE;
-	}
-
-	// set the range of the joystick axis
-	diprg.diph.dwSize       = sizeof (DIPROPRANGE);
-	diprg.diph.dwHeaderSize = sizeof (DIPROPHEADER);
-	diprg.diph.dwHow        = DIPH_BYOFFSET;
-	diprg.lMin              = -JOYAXISRANGE;    // value for extreme left
-	diprg.lMax              = +JOYAXISRANGE;    // value for extreme right
-
-	diprg.diph.dwObj = DIJOFS_X;    // set the x-axis range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//goto SetPropFail;
-		JoyInfo.X = FALSE;
-	}
-	else JoyInfo.X = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_Y;    // set the y-axis range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-//SetPropFail:
-//		I_OutputMsg("DIEnumJoysticks(): SetProperty FAILED\n");
-//		IDirectInputDevice_Release (pdev);
-//		return DIENUM_CONTINUE;
-		JoyInfo.Y = FALSE;
-	}
-	else JoyInfo.Y = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_Z;    // set the z-axis range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_Z not found\n");
-		JoyInfo.Z = FALSE;
-	}
-	else JoyInfo.Z = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_RX;   // set the x-rudder range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_RX (x-rudder) not found\n");
-		JoyInfo.Rx = FALSE;
-	}
-	else JoyInfo.Rx = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_RY;   // set the y-rudder range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_RY (y-rudder) not found\n");
-		JoyInfo.Ry = FALSE;
-	}
-	else JoyInfo.Ry = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_RZ;   // set the z-rudder range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_RZ (z-rudder) not found\n");
-		JoyInfo.Rz = FALSE;
-	}
-	else JoyInfo.Rz = TRUE;
-	diprg.diph.dwObj = DIJOFS_SLIDER(0);   // set the x-misc range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_RZ (x-misc) not found\n");
-		JoyInfo.U = FALSE;
-	}
-	else JoyInfo.U = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_SLIDER(1);   // set the y-misc range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_RZ (y-misc) not found\n");
-		JoyInfo.V = FALSE;
-	}
-	else JoyInfo.V = TRUE;
-
-	// set X axis dead zone to 25% (to avoid accidental turning)
-	if (!Joystick.bGamepadStyle)
-	{
-		if (JoyInfo.X)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_X,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks(): couldn't SetProperty for X DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo.Y)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_Y,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks(): couldn't SetProperty for Y DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo.Z)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_Z,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks(): couldn't SetProperty for Z DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo.Rx)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_RX,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks(): couldn't SetProperty for RX DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo.Ry)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_RY,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks(): couldn't SetProperty for RY DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo.Rz)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_RZ,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks(): couldn't SetProperty for RZ DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo.U)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_SLIDER(0),
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks(): couldn't SetProperty for U DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo.V)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_SLIDER(1),
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks(): couldn't SetProperty for V DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-	}
-
-	// query for IDirectInputDevice2 - we need this to poll the joystick
-	if (bDX0300)
-	{
-		FFType i = EvilForce;
-		// we won't use the poll
-		lpDIJA = NULL;
-		for (i = 0; i > NumberofForces; i++)
-			lpDIE[i] = NULL;
-	}
-	else
-	{
-		LPDIRECTINPUTDEVICE2A *rp = &lpDIJA;
-		LPVOID *tp  = (LPVOID *)rp;
-		if (FAILED(IDirectInputDevice_QueryInterface(pdev, &IID_IDirectInputDevice2, tp)))
-		{
-			I_OutputMsg("DIEnumJoysticks(): QueryInterface FAILED\n");
-			IDirectInputDevice_Release (pdev);
-			return DIENUM_CONTINUE;
-		}
-
-		if (lpDIJA && JoyInfo.ForceAxises != -1)
-		{
-			// Since we will be playing force feedback effects, we should disable the
-			// auto-centering spring.
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_AUTOCENTER, 0, DIPH_DEVICE, FALSE)))
-			{
-				//NOP
-			}
-
-			// Enumerate and count the axes of the joystick
-			if (FAILED(IDirectInputDevice_EnumObjects(pdev, EnumAxesCallback,
-				(LPVOID)&JoyInfo.ForceAxises, DIDFT_AXIS)))
-			{
-				JoyInfo.ForceAxises = -1;
-			}
-			else
-			{
-				SetupAllForces(lpDIJA,lpDIE,JoyInfo.ForceAxises);
-			}
-		}
-	}
-
-	// we successfully created an IDirectInputDevice.  So stop looking
-	// for another one.
-	lpDIJ = pdev;
-	return DIENUM_STOP;
-}
-
-// --------------
-// I_InitJoystick
-// This is called everytime the 'use_joystick' variable changes
-// It is normally called at least once at startup when the config is loaded
-// --------------
-void I_InitJoystick(void)
-{
-	HRESULT hr;
-
-	// cleanup
-	I_ShutdownJoystick();
-
-	//joystick detection can be skipped by setting use_joystick to 0
-	if (!lpDI || M_CheckParm("-nojoy"))
-	{
-		CONS_Printf(M_GetText("Joystick disabled\n"));
-		return;
-	}
-	else
-		// don't do anything at the registration of the joystick cvar,
-		// until config is loaded
-		if (!strcmp(cv_usejoystick.string, "0"))
-			return;
-
-	// acquire the joystick only once
-	if (!lpDIJ)
-	{
-		joystick_detected = false;
-
-		CONS_Printf(M_GetText("Looking for joystick devices:\n"));
-		iJoyNum = 0;
-		hr = IDirectInput_EnumDevices(lpDI, DIDEVTYPE_JOYSTICK, DIEnumJoysticks,
-			(void *)&cv_usejoystick, // our user parameter is joystick number
-			DIEDFL_ATTACHEDONLY);
-		if (FAILED(hr))
-		{
-			CONS_Alert(CONS_WARNING, M_GetText("Joystick initialize failed.\n"));
-			cv_usejoystick.value = 0;
-			return;
-		}
-
-		if (!lpDIJ)
-		{
-			if (!iJoyNum)
-				CONS_Printf(M_GetText("none found\n"));
-			else
-			{
-				CONS_Printf(M_GetText("none used\n"));
-				if (cv_usejoystick.value > 0 && cv_usejoystick.value > iJoyNum)
-				{
-					CONS_Alert(CONS_WARNING, M_GetText("Set the use_joystick variable to one of the enumerated joystick numbers\n"));
-				}
-			}
-			cv_usejoystick.value = 0;
-			return;
-		}
-
-		I_AddExitFunc(I_ShutdownJoystick);
-
-		// set coop level
-		if (FAILED(IDirectInputDevice_SetCooperativeLevel(lpDIJ, hWndMain,
-		 DISCL_NONEXCLUSIVE|DISCL_FOREGROUND)))
-		{
-			I_Error("I_InitJoystick: SetCooperativeLevel FAILED");
-		}
-	}
-	else
-		CONS_Printf(M_GetText("Joystick already initialized\n"));
-
-	// we don't unacquire joystick, so let's just pretend we re-acquired it
-	joystick_detected = true;
-}
-//Joystick 2
-
-// ---------------
-// DIEnumJoysticks2
-// There is no such thing as a 'system' joystick, contrary to mouse,
-// we must enumerate and choose one joystick device to use
-// ---------------
-static BOOL CALLBACK DIEnumJoysticks2 (LPCDIDEVICEINSTANCEA lpddi,
-                                        LPVOID pvRef)   //cv_usejoystick
-{
-	LPDIRECTINPUTDEVICEA pdev;
-	DIPROPRANGE          diprg;
-	DIDEVCAPS            caps;
-	BOOL                 bUseThisOne = FALSE;
-
-	iJoy2Num++;
-
-	//faB: if cv holds a string description of joystick, the value from atoi() is 0
-	//     else, the value was probably set by user at console to one of the previsouly
-	//     enumerated joysticks
-	if (((consvar_t *)pvRef)->value == iJoy2Num || !strcmp(((consvar_t *)pvRef)->string, lpddi->tszProductName))
-		bUseThisOne = TRUE;
-
-	//I_OutputMsg(" cv joy2 is %s\n", ((consvar_t *)pvRef)->string);
-
-	// print out device name
-	CONS_Printf("%c%d: %s\n",
-	            (bUseThisOne) ? '\2' : ' ',   // show name in white if this is the one we will use
-	            iJoy2Num,
-	            //(GET_DIDEVICE_SUBTYPE(lpddi->dwDevType) == DIDEVTYPEJOYSTICK_GAMEPAD) ? "Gamepad " : "Joystick",
-	            lpddi->tszProductName); //, lpddi->tszInstanceName);
-
-	// use specified joystick (cv_usejoystick.value in pvRef)
-	if (!bUseThisOne)
-		return DIENUM_CONTINUE;
-
-	((consvar_t *)pvRef)->value = iJoy2Num;
-	if (IDirectInput_CreateDevice (lpDI, &lpddi->guidInstance,
-	                               &pdev, NULL) != DI_OK)
-	{
-		// if it failed, then we can't use this joystick for some
-		// bizarre reason.  (Maybe the user unplugged it while we
-		// were in the middle of enumerating it.)  So continue enumerating
-		I_OutputMsg("DIEnumJoysticks2(): CreateDevice FAILED\n");
-		return DIENUM_CONTINUE;
-	}
-
-
-	// get the Device capabilities
-	//
-	caps.dwSize = sizeof (DIDEVCAPS_DX3);
-	if (FAILED(IDirectInputDevice_GetCapabilities (pdev, &caps)))
-	{
-		I_OutputMsg("DIEnumJoysticks2(): GetCapabilities FAILED\n");
-		IDirectInputDevice_Release (pdev);
-		return DIENUM_CONTINUE;
-	}
-	if (!(caps.dwFlags & DIDC_ATTACHED))   // should be, since we enumerate only attached devices
-		return DIENUM_CONTINUE;
-
-	Joystick2.bJoyNeedPoll = ((caps.dwFlags & DIDC_POLLEDDATAFORMAT) != 0);
-
-	if (caps.dwFlags & DIDC_FORCEFEEDBACK)
-		JoyInfo2.ForceAxises = 0;
-	else
-		JoyInfo2.ForceAxises = -1;
-
-	Joystick2.bGamepadStyle = (GET_DIDEVICE_SUBTYPE(caps.dwDevType) == DIDEVTYPEJOYSTICK_GAMEPAD);
-	//I_OutputMsg("Gamepad: %d\n", Joystick2.bGamepadStyle);
-
-	CONS_Printf(M_GetText("Capabilities: %lu axes, %lu buttons, %lu POVs, poll %u, Gamepad %d\n"), caps.dwAxes, caps.dwButtons, caps.dwPOVs, Joystick2.bJoyNeedPoll, Joystick2.bGamepadStyle);
-
-	// Set the data format to "simple joystick" - a predefined data format
-	//
-	// A data format specifies which controls on a device we
-	// are interested in, and how they should be reported.
-	//
-	// This tells DirectInput that we will be passing a
-	// DIJOYSTATE structure to IDirectInputDevice::GetDeviceState.
-	if (IDirectInputDevice_SetDataFormat (pdev, &c_dfDIJoystick) != DI_OK)
-	{
-		I_OutputMsg("DIEnumJoysticks2(): SetDataFormat FAILED\n");
-		IDirectInputDevice_Release (pdev);
-		return DIENUM_CONTINUE;
-	}
-
-	// Set the cooperativity level to let DirectInput know how
-	// this device should interact with the system and with other
-	// DirectInput applications.
-	if (IDirectInputDevice_SetCooperativeLevel (pdev, hWndMain,
-	         DISCL_EXCLUSIVE | DISCL_FOREGROUND) != DI_OK)
-	{
-		I_OutputMsg("DIEnumJoysticks2(): SetCooperativeLevel FAILED\n");
-		IDirectInputDevice_Release (pdev);
-		return DIENUM_CONTINUE;
-	}
-
-	// set the range of the joystick axis
-	diprg.diph.dwSize       = sizeof (DIPROPRANGE);
-	diprg.diph.dwHeaderSize = sizeof (DIPROPHEADER);
-	diprg.diph.dwHow        = DIPH_BYOFFSET;
-	diprg.lMin              = -JOYAXISRANGE;    // value for extreme left
-	diprg.lMax              = +JOYAXISRANGE;    // value for extreme right
-
-	diprg.diph.dwObj = DIJOFS_X;    // set the x-axis range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//goto SetPropFail;
-		JoyInfo2.X = FALSE;
-	}
-	else JoyInfo2.X = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_Y;    // set the y-axis range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-//SetPropFail:
-//		I_OutputMsg("DIEnumJoysticks(): SetProperty FAILED\n");
-//		IDirectInputDevice_Release (pdev);
-//		return DIENUM_CONTINUE;
-		JoyInfo2.Y = FALSE;
-	}
-	else JoyInfo2.Y = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_Z;    // set the z-axis range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_Z not found\n");
-		JoyInfo2.Z = FALSE;
-	}
-	else JoyInfo2.Z = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_RX;   // set the x-rudder range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_RX (x-rudder) not found\n");
-		JoyInfo2.Rx = FALSE;
-	}
-	else JoyInfo2.Rx = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_RY;   // set the y-rudder range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_RY (y-rudder) not found\n");
-		JoyInfo2.Ry = FALSE;
-	}
-	else JoyInfo2.Ry = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_RZ;   // set the z-rudder range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_RZ (z-rudder) not found\n");
-		JoyInfo2.Rz = FALSE;
-	}
-	else JoyInfo2.Rz = TRUE;
-	diprg.diph.dwObj = DIJOFS_SLIDER(0);   // set the x-misc range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_RZ (x-misc) not found\n");
-		JoyInfo2.U = FALSE;
-	}
-	else JoyInfo2.U = TRUE;
-
-	diprg.diph.dwObj = DIJOFS_SLIDER(1);   // set the y-misc range
-	if (FAILED(IDirectInputDevice_SetProperty(pdev, DIPROP_RANGE, &diprg.diph)))
-	{
-		//I_OutputMsg("DIJOFS_RZ (y-misc) not found\n");
-		JoyInfo2.V = FALSE;
-	}
-	else JoyInfo2.V = TRUE;
-
-	// set X axis dead zone to 25% (to avoid accidental turning)
-	if (!Joystick2.bGamepadStyle)
-	{
-		if (JoyInfo2.X)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_X,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks2(): couldn't SetProperty for X DEAD ZONE");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo2.Y)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_Y,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks2(): couldn't SetProperty for Y DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo2.Z)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_Z,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks2(): couldn't SetProperty for Z DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo2.Rx)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_RX,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks2(): couldn't SetProperty for RX DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo2.Ry)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_RY,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks2(): couldn't SetProperty for RY DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo2.Rz)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_RZ,
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks2(): couldn't SetProperty for RZ DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo2.U)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_SLIDER(0),
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks2(): couldn't SetProperty for U DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-		if (JoyInfo2.V)
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_DEADZONE, DIJOFS_SLIDER(1),
-			                              DIPH_BYOFFSET, DIDEADZONE)))
-			{
-				I_OutputMsg("DIEnumJoysticks2(): couldn't SetProperty for V DEAD ZONE\n");
-				//IDirectInputDevice_Release (pdev);
-				//return DIENUM_CONTINUE;
-			}
-	}
-
-	// query for IDirectInputDevice2 - we need this to poll the joystick
-	if (bDX0300)
-	{
-		FFType i = EvilForce;
-		// we won't use the poll
-		lpDIJA = NULL;
-		for (i = 0; i > NumberofForces; i++)
-			lpDIE[i] = NULL;
-	}
-	else
-	{
-		LPDIRECTINPUTDEVICE2A *rp = &lpDIJ2A;
-		LPVOID *tp  = (LPVOID *)rp;
-		if (FAILED(IDirectInputDevice_QueryInterface(pdev, &IID_IDirectInputDevice2, tp)))
-		{
-			I_OutputMsg("DIEnumJoysticks2(): QueryInterface FAILED\n");
-			IDirectInputDevice_Release (pdev);
-			return DIENUM_CONTINUE;
-		}
-
-		if (lpDIJ2A && JoyInfo2.ForceAxises != -1)
-		{
-			// Since we will be playing force feedback effects, we should disable the
-			// auto-centering spring.
-			if (FAILED(SetDIDwordProperty(pdev, DIPROP_AUTOCENTER, 0, DIPH_DEVICE, FALSE)))
-			{
-				//NOP
-			}
-
-			// Enumerate and count the axes of the joystick
-			if (FAILED(IDirectInputDevice_EnumObjects(pdev, EnumAxesCallback,
-				(LPVOID)&JoyInfo2.ForceAxises, DIDFT_AXIS)))
-			{
-				JoyInfo2.ForceAxises = -1;
-			}
-			else
-			{
-				SetupAllForces(lpDIJ2A,lpDIE2,JoyInfo2.ForceAxises);
-			}
-		}
-	}
-
-	// we successfully created an IDirectInputDevice.  So stop looking
-	// for another one.
-	lpDIJ2 = pdev;
-	return DIENUM_STOP;
-}
-
-
-// --------------
-// I_InitJoystick2
-// This is called everytime the 'use_joystick2' variable changes
-// It is normally called at least once at startup when the config is loaded
-// --------------
-void I_InitJoystick2 (void)
-{
-	HRESULT hr;
-
-	// cleanup
-	I_ShutdownJoystick2 ();
-
-	joystick2_detected = false;
-
-	// joystick detection can be skipped by setting use_joystick to 0
-	if (!lpDI || M_CheckParm("-nojoy"))
-	{
-		CONS_Printf(M_GetText("Joystick2 disabled\n"));
-		return;
-	}
-	else
-		// don't do anything at the registration of the joystick cvar,
-		// until config is loaded
-		if (!strcmp(cv_usejoystick2.string, "0"))
-			return;
-
-	// acquire the joystick only once
-	if (!lpDIJ2)
-	{
-		joystick2_detected = false;
-
-		CONS_Printf(M_GetText("Looking for joystick devices:\n"));
-		iJoy2Num = 0;
-		hr = IDirectInput_EnumDevices(lpDI, DIDEVTYPE_JOYSTICK,
-		                              DIEnumJoysticks2,
-		                              (LPVOID)&cv_usejoystick2,    // our user parameter is joystick number
-		                              DIEDFL_ATTACHEDONLY);
-		if (FAILED(hr))
-		{
-			CONS_Alert(CONS_WARNING, M_GetText("Joystick initialize failed.\n"));
-			cv_usejoystick2.value = 0;
-			return;
-		}
-
-		if (!lpDIJ2)
-		{
-			if (iJoy2Num == 0)
-				CONS_Printf(M_GetText("none found\n"));
-			else
-			{
-				CONS_Printf(M_GetText("none used\n"));
-				if (cv_usejoystick2.value > 0 &&
-				    cv_usejoystick2.value > iJoy2Num)
-				{
-					CONS_Alert(CONS_WARNING, M_GetText("Set the use_joystick2 variable to one of the enumerated joysticks number\n"));
-				}
-			}
-			cv_usejoystick2.value = 0;
-			return;
-		}
-
-		I_AddExitFunc (I_ShutdownJoystick2);
-
-		// set coop level
-		if (FAILED(IDirectInputDevice_SetCooperativeLevel (lpDIJ2, hWndMain, DISCL_NONEXCLUSIVE | DISCL_FOREGROUND)))
-			I_Error("I_InitJoystick2: SetCooperativeLevel FAILED");
-
-		// later
-		//if (FAILED(IDirectInputDevice_Acquire (lpDIJ2)))
-		//    I_Error("Couldn't acquire Joystick2");
-
-		joystick2_detected = true;
-	}
-	else
-		CONS_Printf(M_GetText("Joystick already initialized\n"));
-
-	//faB: we don't unacquire joystick, so let's just pretend we re-acquired it
-	joystick2_detected = true;
-}
-
-/**	\brief Joystick 1 buttons states
-*/
-static UINT64 lastjoybuttons = 0;
-
-/**	\brief Joystick 1 hats state
-*/
-static UINT64 lastjoyhats = 0;
-
-static VOID I_ShutdownJoystick(VOID)
-{
-	int i;
-	event_t event;
-
-	lastjoybuttons = lastjoyhats = 0;
-
-	event.type = ev_keyup;
-
-	// emulate the up of all joystick buttons
-	for (i = 0;i < JOYBUTTONS;i++)
-	{
-		event.key = KEY_JOY1+i;
-		D_PostEvent(&event);
-	}
-
-	// emulate the up of all joystick hats
-	for (i = 0;i < JOYHATS*4;i++)
-	{
-		event.key = KEY_HAT1+i;
-		D_PostEvent(&event);
-	}
-
-	// reset joystick position
-	event.type = ev_joystick;
-	for (i = 0;i < JOYAXISSET; i++)
-	{
-		event.key = i;
-		D_PostEvent(&event);
-	}
-
-	if (joystick_detected)
-		CONS_Printf("I_ShutdownJoystick()\n");
-
-	for (i = 0; i > NumberofForces; i++)
-	{
-		if (lpDIE[i])
-		{
-			IDirectInputEffect_Release(lpDIE[i]);
-			lpDIE[i] = NULL;
-
-		}
-	}
-	if (lpDIJ)
-	{
-		IDirectInputDevice_Unacquire(lpDIJ);
-		IDirectInputDevice_Release(lpDIJ);
-		lpDIJ = NULL;
-	}
-	if (lpDIJA)
-	{
-		IDirectInputDevice2_Release(lpDIJA);
-		lpDIJA = NULL;
-	}
-	joystick_detected = false;
-}
-
-/**	\brief Joystick 2 buttons states
-*/
-static UINT64 lastjoy2buttons = 0;
-
-/**	\brief Joystick 2 hats state
-*/
-static UINT64 lastjoy2hats = 0;
-
-static VOID I_ShutdownJoystick2(VOID)
-{
-	int i;
-	event_t event;
-
-	lastjoy2buttons = lastjoy2hats = 0;
-
-	event.type = ev_keyup;
-
-	// emulate the up of all joystick buttons
-	for (i = 0;i < JOYBUTTONS;i++)
-	{
-		event.key = KEY_2JOY1+i;
-		D_PostEvent(&event);
-	}
-
-	// emulate the up of all joystick hats
-	for (i = 0;i < JOYHATS*4;i++)
-	{
-		event.key = KEY_2HAT1+i;
-		D_PostEvent(&event);
-	}
-
-	// reset joystick position
-	event.type = ev_joystick2;
-	for (i = 0;i < JOYAXISSET; i++)
-	{
-		event.key = i;
-		D_PostEvent(&event);
-	}
-
-	if (joystick2_detected)
-		CONS_Printf("I_ShutdownJoystick2()\n");
-
-	for (i = 0; i > NumberofForces; i++)
-	{
-		if (lpDIE2[i])
-		{
-			IDirectInputEffect_Release(lpDIE2[i]);
-			lpDIE2[i] = NULL;
-		}
-	}
-	if (lpDIJ2)
-	{
-		IDirectInputDevice_Unacquire(lpDIJ2);
-		IDirectInputDevice_Release(lpDIJ2);
-		lpDIJ2 = NULL;
-	}
-	if (lpDIJ2A)
-	{
-		IDirectInputDevice2_Release(lpDIJ2A);
-		lpDIJ2A = NULL;
-	}
-	joystick2_detected = false;
-}
-
-// -------------------
-// I_GetJoystickEvents
-// Get current joystick axis and button states
-// -------------------
-void I_GetJoystickEvents(void)
-{
-	HRESULT hr;
-	DIJOYSTATE js; // DirectInput joystick state
-	int i;
-	UINT64 joybuttons = 0;
-	UINT64 joyhats = 0;
-	event_t event;
-
-	if (!lpDIJ)
-		return;
-
-	// if input is lost then acquire and keep trying
-	for (;;)
-	{
-		// poll the joystick to read the current state
-		// if the device doesn't require polling, this function returns almost instantly
-		if (lpDIJA)
-		{
-			hr = IDirectInputDevice2_Poll(lpDIJA);
-			if (hr == DIERR_INPUTLOST || hr == DIERR_NOTACQUIRED)
-				goto acquire;
-			else if (FAILED(hr))
-			{
-				I_OutputMsg("I_GetJoystickEvents(): Poll FAILED\n");
-				return;
-			}
-		}
-
-		// get the input's device state, and put the state in dims
-		hr = IDirectInputDevice_GetDeviceState(lpDIJ, sizeof (DIJOYSTATE), &js);
-
-		if (hr == DIERR_INPUTLOST || hr == DIERR_NOTACQUIRED)
-		{
-			// DirectInput is telling us that the input stream has
-			// been interrupted.  We aren't tracking any state
-			// between polls, so we don't have any special reset
-			// that needs to be done.  We just re-acquire and
-			// try again.
-			goto acquire;
-		}
-		else if (FAILED(hr))
-		{
-			I_OutputMsg("I_GetJoystickEvents(): GetDeviceState FAILED\n");
-			return;
-		}
-
-		break;
-acquire:
-		if (FAILED(IDirectInputDevice_Acquire(lpDIJ)))
-			return;
-	}
-
-	// look for as many buttons as g_input code supports, we don't use the others
-	for (i = JOYBUTTONS_MIN - 1; i >= 0; i--)
-	{
-		joybuttons <<= 1;
-		if (js.rgbButtons[i])
-			joybuttons |= 1;
-	}
-
-	for (i = JOYHATS_MIN -1; i >=0; i--)
-	{
-		if (js.rgdwPOV[i] != 0xffff && js.rgdwPOV[i] != 0xffffffff)
-		{
-			if     (js.rgdwPOV[i] > 270 * DI_DEGREES || js.rgdwPOV[i] <  90 * DI_DEGREES)
-				joyhats |= (UINT64)1<<(0 + 4*(UINT64)i); // UP
-			else if (js.rgdwPOV[i] >  90 * DI_DEGREES && js.rgdwPOV[i] < 270 * DI_DEGREES)
-				joyhats |= (UINT64)1<<(1 + 4*(UINT64)i); // DOWN
-			if     (js.rgdwPOV[i] >   0 * DI_DEGREES && js.rgdwPOV[i] < 180 * DI_DEGREES)
-				joyhats |= (UINT64)1<<(3 + 4*(UINT64)i); // LEFT
-			else if (js.rgdwPOV[i] > 180 * DI_DEGREES && js.rgdwPOV[i] < 360 * DI_DEGREES)
-				joyhats |= (UINT64)1<<(2 + 4*(UINT64)i); // RIGHT
-		}
-	}
-
-	if (joybuttons != lastjoybuttons)
-	{
-		UINT64 j = 1; // keep only bits that changed since last time
-		UINT64 newbuttons = joybuttons ^ lastjoybuttons;
-		lastjoybuttons = joybuttons;
-
-		for (i = 0; i < JOYBUTTONS_MIN; i++, j <<= 1)
-		{
-			if (newbuttons & j) // button changed state?
-			{
-				if (joybuttons & j)
-					event.type = ev_keydown;
-				else
-					event.type = ev_keyup;
-				event.key = KEY_JOY1 + i;
-				D_PostEvent(&event);
-			}
-		}
-	}
-
-	if (joyhats != lastjoyhats)
-	{
-		UINT64 j = 1; // keep only bits that changed since last time
-		UINT64 newhats = joyhats ^ lastjoyhats;
-		lastjoyhats = joyhats;
-
-		for (i = 0; i < JOYHATS_MIN*4; i++, j <<= 1)
-		{
-			if (newhats & j) // button changed state?
-			{
-				if (joyhats & j)
-					event.type = ev_keydown;
-				else
-					event.type = ev_keyup;
-				event.key = KEY_HAT1 + i;
-				D_PostEvent(&event);
-			}
-		}
-
-	}
-
-	// send joystick axis positions
-	event.type = ev_joystick;
-	event.key = event.x = event.y = 0;
-
-	if (Joystick.bGamepadStyle)
-	{
-		// gamepad control type, on or off, live or die
-		if (JoyInfo.X)
-		{
-			if (js.lX < -(JOYAXISRANGE/2))
-				event.x = -1;
-			else if (js.lX > JOYAXISRANGE/2)
-				event.x = 1;
-		}
-		if (JoyInfo.Y)
-		{
-			if (js.lY < -(JOYAXISRANGE/2))
-				event.y = -1;
-			else if (js.lY > JOYAXISRANGE/2)
-				event.y = 1;
-		}
-	}
-	else
-	{
-		// analog control style, just send the raw data
-		if (JoyInfo.X)  event.x = js.lX; // x axis
-		if (JoyInfo.Y)  event.y = js.lY; // y axis
-	}
-
-	D_PostEvent(&event);
-#if JOYAXISSET > 1
-	event.key = 1;
-	event.x = event.y = 0;
-
-	if (Joystick.bGamepadStyle)
-	{
-		// gamepad control type, on or off, live or die
-		if (JoyInfo.Z)
-		{
-			if (js.lZ < -(JOYAXISRANGE/2))
-				event.x = -1;
-			else if (js.lZ > JOYAXISRANGE/2)
-				event.x = 1;
-		}
-		if (JoyInfo.Rx)
-		{
-			if (js.lRx < -(JOYAXISRANGE/2))
-				event.y = -1;
-			else if (js.lRx > JOYAXISRANGE/2)
-				event.y = 1;
-		}
-	}
-	else
-	{
-		// analog control style, just send the raw data
-		if (JoyInfo.Z)  event.x = js.lZ;  // z axis
-		if (JoyInfo.Rx) event.y = js.lRx; // rx axis
-	}
-
-	D_PostEvent(&event);
-#endif
-#if JOYAXISSET > 2
-	event.key = 2;
-	event.x = event.y = 0;
-
-	if (Joystick.bGamepadStyle)
-	{
-		// gamepad control type, on or off, live or die
-		if (JoyInfo.Rx)
-		{
-			if (js.lRy < -(JOYAXISRANGE/2))
-				event.x = -1;
-			else if (js.lRy > JOYAXISRANGE/2)
-				event.x = 1;
-		}
-		if (JoyInfo.Rz)
-		{
-			if (js.lRz < -(JOYAXISRANGE/2))
-				event.y = -1;
-			else if (js.lRz > JOYAXISRANGE/2)
-				event.y = 1;
-		}
-	}
-	else
-	{
-		// analog control style, just send the raw data
-		if (JoyInfo.Ry) event.x = js.lRy; // ry axis
-		if (JoyInfo.Rz) event.y = js.lRz; // rz axis
-	}
-
-	D_PostEvent(&event);
-#endif
-#if JOYAXISSET > 3
-	event.key = 3;
-	event.x = event.y = 0;
-	if (Joystick.bGamepadStyle)
-	{
-		// gamepad control type, on or off, live or die
-		if (JoyInfo.U)
-		{
-			if (js.rglSlider[0] < -(JOYAXISRANGE/2))
-				event.x = -1;
-			else if (js.rglSlider[0] > JOYAXISRANGE/2)
-				event.x = 1;
-		}
-		if (JoyInfo.V)
-		{
-			if (js.rglSlider[1] < -(JOYAXISRANGE/2))
-				event.y = -1;
-			else if (js.rglSlider[1] > JOYAXISRANGE/2)
-				event.y = 1;
-		}
-	}
-	else
-	{
-		// analog control style, just send the raw data
-		if (JoyInfo.U)  event.x = js.rglSlider[0]; // U axis
-		if (JoyInfo.V)  event.y = js.rglSlider[1]; // V axis
-	}
-	D_PostEvent(&event);
-#endif
-}
-
-// -------------------
-// I_GetJoystickEvents
-// Get current joystick axis and button states
-// -------------------
-void I_GetJoystick2Events(void)
-{
-	HRESULT hr;
-	DIJOYSTATE js; // DirectInput joystick state
-	int i;
-	UINT64 joybuttons = 0;
-	UINT64 joyhats = 0;
-	event_t event;
-
-	if (!lpDIJ2)
-		return;
-
-	// if input is lost then acquire and keep trying
-	for (;;)
-	{
-		// poll the joystick to read the current state
-		// if the device doesn't require polling, this function returns almost instantly
-		if (lpDIJ2A)
-		{
-			hr = IDirectInputDevice2_Poll(lpDIJ2A);
-			if (hr == DIERR_INPUTLOST || hr == DIERR_NOTACQUIRED)
-				goto acquire;
-			else if (FAILED(hr))
-			{
-				I_OutputMsg("I_GetJoystick2Events(): Poll FAILED\n");
-				return;
-			}
-		}
-
-		// get the input's device state, and put the state in dims
-		hr = IDirectInputDevice_GetDeviceState(lpDIJ2, sizeof (DIJOYSTATE), &js);
-
-		if (hr == DIERR_INPUTLOST || hr == DIERR_NOTACQUIRED)
-		{
-			// DirectInput is telling us that the input stream has
-			// been interrupted.  We aren't tracking any state
-			// between polls, so we don't have any special reset
-			// that needs to be done.  We just re-acquire and
-			// try again.
-			goto acquire;
-		}
-		else if (FAILED(hr))
-		{
-			I_OutputMsg("I_GetJoystickEvents2(): GetDeviceState FAILED\n");
-			return;
-		}
-
-		break;
-acquire:
-		if (FAILED(IDirectInputDevice_Acquire(lpDIJ2)))
-			return;
-	}
-
-	// look for as many buttons as g_input code supports, we don't use the others
-	for (i = JOYBUTTONS_MIN - 1; i >= 0; i--)
-	{
-		joybuttons <<= 1;
-		if (js.rgbButtons[i])
-			joybuttons |= 1;
-	}
-
-	for (i = JOYHATS_MIN -1; i >=0; i--)
-	{
-		if (js.rgdwPOV[i] != 0xffff && js.rgdwPOV[i] != 0xffffffff)
-		{
-			if     (js.rgdwPOV[i] > 270 * DI_DEGREES || js.rgdwPOV[i] <  90 * DI_DEGREES)
-				joyhats |= (UINT64)1<<(0 + 4*(UINT64)i); // UP
-			else if (js.rgdwPOV[i] >  90 * DI_DEGREES && js.rgdwPOV[i] < 270 * DI_DEGREES)
-				joyhats |= (UINT64)1<<(1 + 4*(UINT64)i); // DOWN
-			if     (js.rgdwPOV[i] >   0 * DI_DEGREES && js.rgdwPOV[i] < 180 * DI_DEGREES)
-				joyhats |= (UINT64)1<<(3 + 4*(UINT64)i); // LEFT
-			else if (js.rgdwPOV[i] > 180 * DI_DEGREES && js.rgdwPOV[i] < 360 * DI_DEGREES)
-				joyhats |= (UINT64)1<<(2 + 4*(UINT64)i); // RIGHT
-		}
-	}
-
-	if (joybuttons != lastjoy2buttons)
-	{
-		UINT64 j = 1; // keep only bits that changed since last time
-		UINT64 newbuttons = joybuttons ^ lastjoy2buttons;
-		lastjoy2buttons = joybuttons;
-
-		for (i = 0; i < JOYBUTTONS_MIN; i++, j <<= 1)
-		{
-			if (newbuttons & j) // button changed state?
-			{
-				if (joybuttons & j)
-					event.type = ev_keydown;
-				else
-					event.type = ev_keyup;
-				event.key = KEY_2JOY1 + i;
-				D_PostEvent(&event);
-			}
-		}
-	}
-
-	if (joyhats != lastjoy2hats)
-	{
-		UINT64 j = 1; // keep only bits that changed since last time
-		UINT64 newhats = joyhats ^ lastjoy2hats;
-		lastjoy2hats = joyhats;
-
-		for (i = 0; i < JOYHATS_MIN*4; i++, j <<= 1)
-		{
-			if (newhats & j) // button changed state?
-			{
-				if (joyhats & j)
-					event.type = ev_keydown;
-				else
-					event.type = ev_keyup;
-				event.key = KEY_2HAT1 + i;
-				D_PostEvent(&event);
-			}
-		}
-
-	}
-
-	// send joystick axis positions
-	event.type = ev_joystick2;
-	event.key = event.x = event.y = 0;
-
-	if (Joystick2.bGamepadStyle)
-	{
-		// gamepad control type, on or off, live or die
-		if (JoyInfo2.X)
-		{
-			if (js.lX < -(JOYAXISRANGE/2))
-				event.x = -1;
-			else if (js.lX > JOYAXISRANGE/2)
-				event.x = 1;
-		}
-		if (JoyInfo2.Y)
-		{
-			if (js.lY < -(JOYAXISRANGE/2))
-				event.y = -1;
-			else if (js.lY > JOYAXISRANGE/2)
-				event.y = 1;
-		}
-	}
-	else
-	{
-		// analog control style, just send the raw data
-		if (JoyInfo2.X)  event.x = js.lX; // x axis
-		if (JoyInfo2.Y)  event.y = js.lY; // y axis
-	}
-
-	D_PostEvent(&event);
-#if JOYAXISSET > 1
-	event.key = 1;
-	event.x = event.y = 0;
-
-	if (Joystick2.bGamepadStyle)
-	{
-		// gamepad control type, on or off, live or die
-		if (JoyInfo2.Z)
-		{
-			if (js.lZ < -(JOYAXISRANGE/2))
-				event.x = -1;
-			else if (js.lZ > JOYAXISRANGE/2)
-				event.x = 1;
-		}
-		if (JoyInfo2.Rx)
-		{
-			if (js.lRx < -(JOYAXISRANGE/2))
-				event.y = -1;
-			else if (js.lRx > JOYAXISRANGE/2)
-				event.y = 1;
-		}
-	}
-	else
-	{
-		// analog control style, just send the raw data
-		if (JoyInfo2.Z)  event.x = js.lZ;  // z axis
-		if (JoyInfo2.Rx) event.y = js.lRx; // rx axis
-	}
-
-	D_PostEvent(&event);
-#endif
-#if JOYAXISSET > 2
-	event.key = 2;
-	event.x = event.y = 0;
-
-	if (Joystick2.bGamepadStyle)
-	{
-		// gamepad control type, on or off, live or die
-		if (JoyInfo2.Rx)
-		{
-			if (js.lRy < -(JOYAXISRANGE/2))
-				event.x = -1;
-			else if (js.lRy > JOYAXISRANGE/2)
-				event.x = 1;
-		}
-		if (JoyInfo2.Rz)
-		{
-			if (js.lRz < -(JOYAXISRANGE/2))
-				event.y = -1;
-			else if (js.lRz > JOYAXISRANGE/2)
-				event.y = 1;
-		}
-	}
-	else
-	{
-		// analog control style, just send the raw data
-		if (JoyInfo2.Ry) event.x = js.lRy; // ry axis
-		if (JoyInfo2.Rz) event.y = js.lRz; // rz axis
-	}
-
-	D_PostEvent(&event);
-#endif
-#if JOYAXISSET > 3
-	event.key = 3;
-	event.x = event.y = 0;
-	if (Joystick2.bGamepadStyle)
-	{
-		// gamepad control type, on or off, live or die
-		if (JoyInfo2.U)
-		{
-			if (js.rglSlider[0] < -(JOYAXISRANGE/2))
-				event.x = -1;
-			else if (js.rglSlider[0] > JOYAXISRANGE/2)
-				event.x = 1;
-		}
-		if (JoyInfo2.V)
-		{
-			if (js.rglSlider[1] < -(JOYAXISRANGE/2))
-				event.y = -1;
-			else if (js.rglSlider[1] > JOYAXISRANGE/2)
-				event.y = 1;
-		}
-	}
-	else
-	{
-		// analog control style, just send the raw data
-		if (JoyInfo2.U)  event.x = js.rglSlider[0]; // U axis
-		if (JoyInfo2.V)  event.y = js.rglSlider[1]; // V axis
-	}
-	D_PostEvent(&event);
-#endif
-}
-
-static int numofjoy = 0;
-static char joyname[MAX_PATH];
-static int needjoy = -1;
-
-static BOOL CALLBACK DIEnumJoysticksCount (LPCDIDEVICEINSTANCEA lpddi,
-                                            LPVOID pvRef)   //joyname
-{
-	numofjoy++;
-	if (needjoy == numofjoy && pvRef && pvRef == (void *)joyname && lpddi
-		&& lpddi->tszProductName)
-	{
-		sprintf(joyname,"%s",lpddi->tszProductName);
-		return DIENUM_STOP;
-	}
-	//else I_OutputMsg("DIEnumJoysticksCount need help!\n");
-	return DIENUM_CONTINUE;
-}
-
-INT32 I_NumJoys(void)
-{
-	HRESULT hr;
-	needjoy = -1;
-	numofjoy = 0;
-	hr = IDirectInput_EnumDevices(lpDI, DIDEVTYPE_JOYSTICK,
-		DIEnumJoysticksCount, (LPVOID)&numofjoy, DIEDFL_ATTACHEDONLY);
-	if (FAILED(hr))
-	{
-		I_OutputMsg("\nI_NumJoys(): EnumDevices FAILED\n");
-	}
-	return numofjoy;
-
-}
-
-const char *I_GetJoyName(INT32 joyindex)
-{
-	HRESULT hr;
-	needjoy = joyindex;
-	numofjoy = 0;
-	ZeroMemory(joyname,sizeof (joyname));
-	hr = IDirectInput_EnumDevices(lpDI, DIDEVTYPE_JOYSTICK,
-		DIEnumJoysticksCount, (LPVOID)joyname, DIEDFL_ATTACHEDONLY);
-	if (FAILED(hr))
-	{
-		I_OutputMsg("\nI_GetJoyName(): EnumDevices FAILED\n");
-	}
-	if (joyname[0] == 0) return NULL;
-	return joyname;
-}
-
-#ifndef NOMUMBLE
-// Best Mumble positional audio settings:
-// Minimum distance 3.0 m
-// Bloom 175%
-// Maximum distance 80.0 m
-// Minimum volume 50%
-#define DEG2RAD (0.017453292519943295769236907684883l) // TAU/360 or PI/180
-#define MUMBLEUNIT (64.0f) // FRACUNITS in a Meter
-
-static struct {
-	UINT32 uiVersion;
-	DWORD uiTick;
-	float fAvatarPosition[3];
-	float fAvatarFront[3];
-	float fAvatarTop[3]; // defaults to Y-is-up (only used for leaning)
-	wchar_t name[256]; // game name
-	float fCameraPosition[3];
-	float fCameraFront[3];
-	float fCameraTop[3]; // defaults to Y-is-up (only used for leaning)
-	wchar_t identity[256]; // player id
-	UINT32 context_len;
-	unsigned char context[256]; // server/team
-	wchar_t description[2048]; // game description
-} *mumble = NULL;
-
-static inline void I_SetupMumble(void)
-{
-	HANDLE hMap = OpenFileMappingW(FILE_MAP_ALL_ACCESS, FALSE, L"MumbleLink");
-	if (!hMap)
-		return;
-
-	mumble = MapViewOfFile(hMap, FILE_MAP_ALL_ACCESS, 0, 0, sizeof(*mumble));
-	if (!mumble)
-		CloseHandle(hMap);
-}
-
-void I_UpdateMumble(const mobj_t *mobj, const listener_t listener)
-{
-	double angle;
-	fixed_t anglef;
-
-	if (!mumble)
-		return;
-
-	if(mumble->uiVersion != 2) {
-		wcsncpy(mumble->name, L"SRB2 "VERSIONSTRINGW, 256);
-		wcsncpy(mumble->description, L"Sonic Robo Blast 2 with integrated Mumble Link support.", 2048);
-		mumble->uiVersion = 2;
-	}
-	mumble->uiTick++;
-
-	if (!netgame || gamestate != GS_LEVEL) { // Zero out, but never delink.
-		mumble->fAvatarPosition[0] = mumble->fAvatarPosition[1] = mumble->fAvatarPosition[2] = 0.0f;
-		mumble->fAvatarFront[0] = 1.0f;
-		mumble->fAvatarFront[1] = mumble->fAvatarFront[2] = 0.0f;
-		mumble->fCameraPosition[0] = mumble->fCameraPosition[1] = mumble->fCameraPosition[2] = 0.0f;
-		mumble->fCameraFront[0] = 1.0f;
-		mumble->fCameraFront[1] = mumble->fCameraFront[2] = 0.0f;
-		return;
-	}
-
-	{
-		UINT8 *p = mumble->context;
-		WRITEMEM(p, server_context, 8);
-		WRITEINT16(p, gamemap);
-		mumble->context_len = p - mumble->context;
-	}
-
-	if (mobj) {
-		mumble->fAvatarPosition[0] = FIXED_TO_FLOAT(mobj->x) / MUMBLEUNIT;
-		mumble->fAvatarPosition[1] = FIXED_TO_FLOAT(mobj->z) / MUMBLEUNIT;
-		mumble->fAvatarPosition[2] = FIXED_TO_FLOAT(mobj->y) / MUMBLEUNIT;
-
-		anglef = AngleFixed(mobj->angle);
-		angle = FIXED_TO_FLOAT(anglef)*DEG2RAD;
-		mumble->fAvatarFront[0] = (float)cos(angle);
-		mumble->fAvatarFront[1] = 0.0f;
-		mumble->fAvatarFront[2] = (float)sin(angle);
-	} else {
-		mumble->fAvatarPosition[0] = mumble->fAvatarPosition[1] = mumble->fAvatarPosition[2] = 0.0f;
-		mumble->fAvatarFront[0] = 1.0f;
-		mumble->fAvatarFront[1] = mumble->fAvatarFront[2] = 0.0f;
-	}
-
-	mumble->fCameraPosition[0] = FIXED_TO_FLOAT(listener.x) / MUMBLEUNIT;
-	mumble->fCameraPosition[1] = FIXED_TO_FLOAT(listener.z) / MUMBLEUNIT;
-	mumble->fCameraPosition[2] = FIXED_TO_FLOAT(listener.y) / MUMBLEUNIT;
-
-	anglef = AngleFixed(listener.angle);
-	angle = FIXED_TO_FLOAT(anglef)*DEG2RAD;
-	mumble->fCameraFront[0] = (float)cos(angle);
-	mumble->fCameraFront[1] = 0.0f;
-	mumble->fCameraFront[2] = (float)sin(angle);
-}
-#endif
-
-// ===========================================================================================
-//                                                                       DIRECT INPUT KEYBOARD
-// ===========================================================================================
-
-static UINT8 ASCIINames[256] =
-{
-	//  0       1       2       3       4       5       6       7
-	//  8       9       A       B       C       D       E       F
-	0,      27,     '1',    '2',    '3',    '4',    '5',    '6',
-	'7',    '8',    '9',    '0', KEY_MINUS,KEY_EQUALS,KEY_BACKSPACE, KEY_TAB,
-	'q',    'w',    'e',    'r',    't',    'y',    'u',    'i',
-	'o',    'p',    '[',    ']',KEY_ENTER,KEY_LCTRL,'a',    's',
-	'd',    'f',    'g',    'h',    'j',    'k',    'l',    ';',
-	'\'',   '`', KEY_LSHIFT,'\\',   'z',    'x',    'c',    'v',
-	'b',    'n',    'm',    ',',    '.',    '/', KEY_RSHIFT,'*',
-	KEY_LALT,KEY_SPACE,KEY_CAPSLOCK,KEY_F1,KEY_F2,KEY_F3,KEY_F4,KEY_F5,
-	KEY_F6, KEY_F7, KEY_F8, KEY_F9, KEY_F10,KEY_NUMLOCK,KEY_SCROLLLOCK,KEY_KEYPAD7,
-	KEY_KEYPAD8,KEY_KEYPAD9,KEY_MINUSPAD,KEY_KEYPAD4,KEY_KEYPAD5,KEY_KEYPAD6,KEY_PLUSPAD,KEY_KEYPAD1,
-	KEY_KEYPAD2,KEY_KEYPAD3,KEY_KEYPAD0,KEY_KPADDEL,0,0,0,      KEY_F11,
-	KEY_F12,0,          0,      0,      0,      0,      0,      0,
-	0,          0,      0,      0,      0,      0,      0,      0,
-	0,          0,      0,      0,      0,      0,      0,      0,
-	0,          0,      0,      0,      0,      0,      0,      0,
-	0,          0,      0,      0,      0,      0,      0,      0,
-
-	//  0       1       2       3       4       5       6       7
-	//  8       9       A       B       C       D       E       F
-
-	0,          0,      0,      0,      0,      0,      0,      0, // 0x80
-	0,          0,      0,      0,      0,      0,      0,      0,
-	0,          0,      0,      0,      0,      0,      0,      0,
-	0,          0,      0,      0,  KEY_ENTER,KEY_RCTRL,0,      0,
-	0,          0,      0,      0,      0,      0,      0,      0, // 0xa0
-	0,          0,      0,      0,      0,      0,      0,      0,
-	0,          0,      0, KEY_KPADDEL, 0,KEY_KPADSLASH,0,      0,
-	KEY_RALT,   0,      0,      0,      0,      0,      0,      0,
-	0,          0,      0,      0,      0,      0,      0,  KEY_HOME, // 0xc0
-	KEY_UPARROW,KEY_PGUP,0,KEY_LEFTARROW,0,KEY_RIGHTARROW,0,KEY_END,
-	KEY_DOWNARROW,KEY_PGDN, KEY_INS,KEY_DEL,0,0,0,0,
-	0,          0,      0,KEY_LEFTWIN,KEY_RIGHTWIN,KEY_MENU, 0, 0,
-	0,          0,      0,      0,      0,      0,      0,      0, // 0xe0
-	0,          0,      0,      0,      0,      0,      0,      0,
-	0,          0,      0,      0,      0,      0,      0,      0,
-	0,          0,      0,      0,      0,      0,      0,      0
-};
-
-// Return a key that has been pushed, or 0 (replace getchar() at game startup)
-//
-INT32 I_GetKey(void)
-{
-	event_t *ev;
-
-	if (eventtail != eventhead)
-	{
-		ev = &events[eventtail];
-		eventtail = (eventtail+1) & (MAXEVENTS-1);
-		if (ev->type == ev_keydown || ev->type == ev_console)
-			return ev->key;
-		else
-			return 0;
-	}
-	return 0;
-}
-
-// -----------------
-// I_StartupKeyboard
-// Installs DirectInput keyboard
-// -----------------
-#define DI_KEYBOARD_BUFFERSIZE 32 // number of data elements in keyboard buffer
-
-static void I_StartupKeyboard(void)
-{
-	DIPROPDWORD dip;
-
-	if (dedicated || !lpDI)
-		return;
-
-	// make sure the app window has the focus or DirectInput acquire keyboard won't work
-	if (hWndMain)
-	{
-		SetFocus(hWndMain);
-		ShowWindow(hWndMain, SW_SHOW);
-		UpdateWindow(hWndMain);
-	}
-
-	// detect error
-	if (lpDIK)
-	{
-		I_OutputMsg("I_StartupKeyboard(): called twice\n");
-		return;
-	}
-
-	CreateDevice2A(lpDI, &GUID_SysKeyboard, &lpDIK, NULL);
-
-	if (lpDIK)
-	{
-		if (FAILED(IDirectInputDevice_SetDataFormat(lpDIK, &c_dfDIKeyboard)))
-			I_Error("Couldn't set keyboard data format");
-
-		// create buffer for buffered data
-		dip.diph.dwSize = sizeof (dip);
-		dip.diph.dwHeaderSize = sizeof (dip.diph);
-		dip.diph.dwObj = 0;
-		dip.diph.dwHow = DIPH_DEVICE;
-		dip.dwData = DI_KEYBOARD_BUFFERSIZE;
-		if (FAILED(IDirectInputDevice_SetProperty(lpDIK, DIPROP_BUFFERSIZE, &dip.diph)))
-			I_Error("Couldn't set keyboard buffer size");
-
-		if (FAILED(IDirectInputDevice_SetCooperativeLevel(lpDIK, hWndMain,
-			DISCL_NONEXCLUSIVE|DISCL_FOREGROUND)))
-		{
-			I_Error("Couldn't set keyboard coop level");
-		}
-	}
-	else
-		I_Error("Couldn't create keyboard input");
-
-	I_AddExitFunc(I_ShutdownKeyboard);
-	hacktics = 0; // see definition
-	keyboard_started = true;
-}
-
-// ------------------
-// I_ShutdownKeyboard
-// Release DirectInput keyboard.
-// ------------------
-static VOID I_ShutdownKeyboard(VOID)
-{
-	if (!keyboard_started)
-		return;
-
-	CONS_Printf("I_ShutdownKeyboard()\n");
-
-	if (lpDIK)
-	{
-		IDirectInputDevice_Unacquire(lpDIK);
-		IDirectInputDevice_Release(lpDIK);
-		lpDIK = NULL;
-	}
-
-	keyboard_started = false;
-}
-
-// -------------------
-// I_GetKeyboardEvents
-// Get buffered data from the keyboard
-// -------------------
-static VOID I_GetKeyboardEvents(VOID)
-{
-	static BOOL KeyboardLost = false;
-
-	// simply repeat the last pushed key every xx tics,
-	// make more user friendly input for Console and game Menus
-#define KEY_REPEAT_DELAY (NEWTICRATE/17) // TICRATE tics, repeat every 1/3 second
-	static LONG RepeatKeyTics = 0;
-	static int RepeatKeyCode = 0;
-
-	DIDEVICEOBJECTDATA rgdod[DI_KEYBOARD_BUFFERSIZE];
-	DWORD dwItems, d;
-	HRESULT hr;
-	int ch;
-
-	event_t event;
-	ZeroMemory(&event,sizeof (event));
-
-	if (!keyboard_started)
-		return;
-
-	if (!appActive && RepeatKeyCode) // Stop when lost focus
-	{
-		event.type = ev_keyup;
-		event.key = RepeatKeyCode;
-		D_PostEvent(&event);
-		RepeatKeyCode = 0;
-	}
-getBufferedData:
-	dwItems = DI_KEYBOARD_BUFFERSIZE;
-	hr = IDirectInputDevice_GetDeviceData(lpDIK, sizeof (DIDEVICEOBJECTDATA), rgdod, &dwItems, 0);
-
-	// If data stream was interrupted, reacquire the device and try again.
-	if (hr == DIERR_INPUTLOST || hr == DIERR_NOTACQUIRED)
-	{
-		// why it succeeds to acquire just after I don't understand.. so I set the flag BEFORE
-		KeyboardLost = true;
-
-		hr = IDirectInputDevice_Acquire(lpDIK);
-		if (SUCCEEDED(hr))
-			goto getBufferedData;
-		return;
-	}
-
-	// we lost data, get device actual state to recover lost information
-	if (hr == DI_BUFFEROVERFLOW)
-	{
-		/// \note either uncomment or delete block
-		//I_Error("DI buffer overflow (keyboard)");
-		//I_RecoverKeyboardState ();
-
-		//hr = IDirectInputDevice_GetDeviceState (lpDIM, sizeof (keys), &diMouseState);
-	}
-
-	// We got buffered input, act on it
-	if (SUCCEEDED(hr))
-	{
-		// if we previously lost keyboard data, recover its current state
-		if (KeyboardLost)
-		{
-			/// \bug hack simply clears the keys so we don't have the last pressed keys
-			/// still active.. to have to re-trigger it is not much trouble for the user.
-			ZeroMemory(gamekeydown, NUMKEYS);
-			KeyboardLost = false;
-		}
-
-		// dwItems contains number of elements read (could be 0)
-		for (d = 0; d < dwItems; d++)
-		{
-			// dwOfs member is DIK_* value
-			// dwData member 0x80 bit set press down, clear is release
-
-			if (rgdod[d].dwData & 0x80)
-				event.type = ev_keydown;
-			else
-				event.type = ev_keyup;
-
-			ch = rgdod[d].dwOfs & 0xFF;
-			if (ASCIINames[ch])
-				event.key = ASCIINames[ch];
-			else
-				event.key = 0x80;
-
-			D_PostEvent(&event);
-		}
-
-		// Key Repeat
-		if (dwItems)
-		{
-			// new key events, so stop repeating key
-			RepeatKeyCode = 0;
-			// delay is tripled for first repeating key
-			RepeatKeyTics = hacktics + (KEY_REPEAT_DELAY*3);
-			if (event.type == ev_keydown) // use the last event!
-				RepeatKeyCode = event.key;
-		}
-		else
-		{
-			// no new keys, repeat last pushed key after some time
-			if (RepeatKeyCode && hacktics - RepeatKeyTics > KEY_REPEAT_DELAY)
-			{
-				event.type = ev_keydown;
-				event.key = RepeatKeyCode;
-				D_PostEvent(&event);
-
-				RepeatKeyTics = hacktics;
-			}
-		}
-	}
-}
-
-static HINSTANCE DInputDLL = NULL;
-typedef HRESULT (WINAPI *DICreateA)(HINSTANCE hinst, DWORD dwVersion, LPDIRECTINPUTA *ppDI, LPUNKNOWN punkOuter);
-static DICreateA pfnDirectInputCreateA = NULL;
-
-BOOL LoadDirectInput(VOID)
-{
-	// load dinput.dll
-	DInputDLL = LoadLibraryA("DINPUT.DLL");
-	if (DInputDLL == NULL)
-		return false;
-	pfnDirectInputCreateA = (DICreateA)(LPVOID)GetProcAddress(DInputDLL, "DirectInputCreateA");
-	if (pfnDirectInputCreateA == NULL)
-		return false;
-	return true;
-}
-
-static inline VOID UnLoadDirectInput(VOID)
-{
-	if (!DInputDLL)
-		return;
-	FreeLibrary(DInputDLL);
-	pfnDirectInputCreateA = NULL;
-	DInputDLL = NULL;
-}
-
-
-//
-// Closes DirectInput
-//
-static VOID I_ShutdownDirectInput(VOID)
-{
-	if (lpDI)
-		IDirectInput_Release(lpDI);
-	lpDI = NULL;
-	UnLoadDirectInput();
-}
-
-// This stuff should get rid of the exception and page faults when
-// SRB2 bugs out with an error. Now it should exit cleanly.
-//
-INT32 I_StartupSystem(void)
-{
-	HRESULT hr;
-	HINSTANCE myInstance = GetModuleHandle(NULL);
-
-	// some 'more global than globals' things to initialize here ?
-	graphics_started = keyboard_started = sound_started = cdaudio_started = false;
-
-	I_StartupKeyboard();
-
-#ifdef NDEBUG
-
-#ifdef BUGTRAP
-	if(!IsBugTrapLoaded())
-	{
-#endif
-		signal(SIGABRT, signal_handler);
-		signal(SIGFPE, signal_handler);
-		signal(SIGILL, signal_handler);
-		signal(SIGSEGV, signal_handler);
-		signal(SIGTERM, signal_handler);
-		signal(SIGINT, signal_handler);
-#ifdef BUGTRAP
-	}
-#endif
-
-#endif
-
-#ifndef NOMUMBLE
-	I_SetupMumble();
-#endif
-
-	if (!pfnDirectInputCreateA)
-		return 1;
-	// create DirectInput - so that I_StartupKeyboard/Mouse can be called later on
-	// from D_SRB2Main just like DOS version
-	hr = pfnDirectInputCreateA(myInstance, DIRECTINPUT_VERSION, &lpDI, NULL);
-
-	if (SUCCEEDED(hr))
-		bDX0300 = FALSE;
-	else
-	{
-		// try opening DirectX3 interface for NT compatibility
-		hr = pfnDirectInputCreateA(myInstance, DXVERSION_NTCOMPATIBLE, &lpDI, NULL);
-
-		if (FAILED(hr))
-		{
-			const char *sErr;
-			switch (hr)
-			{
-				case DIERR_BETADIRECTINPUTVERSION:
-					sErr = "DIERR_BETADIRECTINPUTVERSION";
-					break;
-				case DIERR_INVALIDPARAM:
-					sErr = "DIERR_INVALIDPARAM";
-					break;
-				case DIERR_OLDDIRECTINPUTVERSION :
-					sErr = "DIERR_OLDDIRECTINPUTVERSION";
-					break;
-				case DIERR_OUTOFMEMORY:
-					sErr = "DIERR_OUTOFMEMORY";
-					break;
-				default:
-					sErr = "UNKNOWN";
-					break;
-			}
-			I_Error("Couldn't create DirectInput (reason: %s)", sErr);
-		}
-		else
-			CONS_Printf("\x82%s", M_GetText("Using DirectX3 interface\n"));
-
-		// only use DirectInput3 compatible structures and calls
-		bDX0300 = TRUE;
-	}
-	I_AddExitFunc(I_ShutdownDirectInput);
-	return 0;
-}
-
-// Closes down everything. This includes restoring the initial
-// palette and video mode, and removing whatever mouse, keyboard, and
-// timer routines have been installed.
-//
-/// \bug doesn't restore wave/midi device volume
-//
-// Shutdown user funcs are effectively called in reverse order.
-//
-void I_ShutdownSystem(void)
-{
-	int c;
-
-	for (c = MAX_QUIT_FUNCS - 1; c >= 0; c--)
-		if (quit_funcs[c])
-			(*quit_funcs[c])();
-}
-
-// my god how win32 suck
-typedef BOOL (WINAPI *p_GetDiskFreeSpaceExA)(LPCSTR, PULARGE_INTEGER, PULARGE_INTEGER, PULARGE_INTEGER);
-
-void I_GetDiskFreeSpace(INT64* freespace)
-{
-	static p_GetDiskFreeSpaceExA pfnGetDiskFreeSpaceEx = NULL;
-	static boolean testwin95 = false;
-	ULARGE_INTEGER usedbytes, lfreespace;
-
-	if (!testwin95)
-	{
-		pfnGetDiskFreeSpaceEx = (p_GetDiskFreeSpaceExA)(LPVOID)GetProcAddress(GetModuleHandleA("kernel32.dll"), "GetDiskFreeSpaceExA");
-		testwin95 = true;
-	}
-	if (pfnGetDiskFreeSpaceEx)
-	{
-		if (pfnGetDiskFreeSpaceEx(NULL, &lfreespace, &usedbytes, NULL))
-			*freespace = lfreespace.QuadPart;
-		else
-			*freespace = INT32_MAX;
-	}
-	else
-	{
-		DWORD SectorsPerCluster, BytesPerSector, NumberOfFreeClusters, TotalNumberOfClusters;
-		GetDiskFreeSpace(NULL, &SectorsPerCluster, &BytesPerSector,
-			&NumberOfFreeClusters, &TotalNumberOfClusters);
-		*freespace = BytesPerSector * SectorsPerCluster * NumberOfFreeClusters;
-	}
-}
-
-char *I_GetUserName(void)
-{
-	static char username[MAXPLAYERNAME+1];
-	char *p;
-	DWORD i = MAXPLAYERNAME;
-
-	if (!GetUserNameA(username, &i))
-	{
-		p = getenv("USER");
-		if (!p)
-		{
-			p = getenv("user");
-			if (!p)
-			{
-				p = getenv("USERNAME");
-				if (!p)
-				{
-					p = getenv("username");
-					if (!p)
-					{
-						return NULL;
-					}
-				}
-			}
-		}
-		strlcpy(username, p, sizeof (username));
-	}
-
-	if (!strlen(username))
-		return NULL;
-	return username;
-}
-
-INT32 I_mkdir(const char *dirname, INT32 unixright)
-{
-	UNREFERENCED_PARAMETER(unixright); /// \todo should implement ntright under nt...
-	return CreateDirectoryA(dirname, NULL);
-}
-
-char * I_GetEnv(const char *name)
-{
-	return getenv(name);
-}
-
-INT32 I_PutEnv(char *variable)
-{
-	return putenv(variable);
-}
-
-INT32 I_ClipboardCopy(const char *data, size_t size)
-{
-	(void)data;
-	(void)size;
-	return -1;
-}
-
-const char *I_ClipboardPaste(void)
-{
-	return NULL;
-}
-
-typedef BOOL (WINAPI *p_IsProcessorFeaturePresent) (DWORD);
-
-const CPUInfoFlags *I_CPUInfo(void)
-{
-	static CPUInfoFlags WIN_CPUInfo;
-	SYSTEM_INFO SI;
-	p_IsProcessorFeaturePresent pfnCPUID = (p_IsProcessorFeaturePresent)(LPVOID)GetProcAddress(GetModuleHandleA("kernel32.dll"), "IsProcessorFeaturePresent");
-
-	ZeroMemory(&WIN_CPUInfo,sizeof (WIN_CPUInfo));
-	if (pfnCPUID)
-	{
-		WIN_CPUInfo.FPPE       = pfnCPUID( 0); //PF_FLOATING_POINT_PRECISION_ERRATA
-		WIN_CPUInfo.FPE        = pfnCPUID( 1); //PF_FLOATING_POINT_EMULATED
-		WIN_CPUInfo.cmpxchg    = pfnCPUID( 2); //PF_COMPARE_EXCHANGE_DOUBLE
-		WIN_CPUInfo.MMX        = pfnCPUID( 3); //PF_MMX_INSTRUCTIONS_AVAILABLE
-		WIN_CPUInfo.PPCMM64    = pfnCPUID( 4); //PF_PPC_MOVEMEM_64BIT_OK
-		WIN_CPUInfo.ALPHAbyte  = pfnCPUID( 5); //PF_ALPHA_BYTE_INSTRUCTIONS
-		WIN_CPUInfo.SSE        = pfnCPUID( 6); //PF_XMMI_INSTRUCTIONS_AVAILABLE
-		WIN_CPUInfo.AMD3DNow   = pfnCPUID( 7); //PF_3DNOW_INSTRUCTIONS_AVAILABLE
-		WIN_CPUInfo.RDTSC      = pfnCPUID( 8); //PF_RDTSC_INSTRUCTION_AVAILABLE
-		WIN_CPUInfo.PAE        = pfnCPUID( 9); //PF_PAE_ENABLED
-		WIN_CPUInfo.SSE2       = pfnCPUID(10); //PF_XMMI64_INSTRUCTIONS_AVAILABLE
-		//WIN_CPUInfo.blank    = pfnCPUID(11); //PF_SSE_DAZ_MODE_AVAILABLE
-		WIN_CPUInfo.DEP        = pfnCPUID(12); //PF_NX_ENABLED
-		WIN_CPUInfo.SSE3       = pfnCPUID(13); //PF_SSE3_INSTRUCTIONS_AVAILABLE
-		WIN_CPUInfo.cmpxchg16b = pfnCPUID(14); //PF_COMPARE_EXCHANGE128
-		WIN_CPUInfo.cmp8xchg16 = pfnCPUID(15); //PF_COMPARE64_EXCHANGE128
-		WIN_CPUInfo.PFC        = pfnCPUID(16); //PF_CHANNELS_ENABLED
-	}
-	GetSystemInfo(&SI);
-	WIN_CPUInfo.CPUs = SI.dwNumberOfProcessors;
-	WIN_CPUInfo.IA64 = (SI.dwProcessorType == 2200); // PROCESSOR_INTEL_IA64
-	WIN_CPUInfo.AMD64 = (SI.dwProcessorType == 8664); // PROCESSOR_AMD_X8664
-	return &WIN_CPUInfo;
-}
-
-static void CPUAffinity_OnChange(void);
-static consvar_t cv_cpuaffinity = CVAR_INIT ("cpuaffinity", "-1", CV_CALL, NULL, CPUAffinity_OnChange);
-
-typedef HANDLE (WINAPI *p_GetCurrentProcess) (VOID);
-static p_GetCurrentProcess pfnGetCurrentProcess = NULL;
-typedef BOOL (WINAPI *p_GetProcessAffinityMask) (HANDLE, PDWORD_PTR, PDWORD_PTR);
-static p_GetProcessAffinityMask pfnGetProcessAffinityMask = NULL;
-typedef BOOL (WINAPI *p_SetProcessAffinityMask) (HANDLE, DWORD_PTR);
-static p_SetProcessAffinityMask pfnSetProcessAffinityMask = NULL;
-
-static inline VOID GetAffinityFuncs(VOID)
-{
-	HMODULE h = GetModuleHandleA("kernel32.dll");
-	pfnGetCurrentProcess = (p_GetCurrentProcess)(LPVOID)GetProcAddress(h, "GetCurrentProcess");
-	pfnGetProcessAffinityMask = (p_GetProcessAffinityMask)(LPVOID)GetProcAddress(h, "GetProcessAffinityMask");
-	pfnSetProcessAffinityMask = (p_SetProcessAffinityMask)(LPVOID)GetProcAddress(h, "SetProcessAffinityMask");
-}
-
-static void CPUAffinity_OnChange(void)
-{
-	DWORD_PTR dwProcMask, dwSysMask;
-	HANDLE selfpid;
-
-	if (!pfnGetCurrentProcess || !pfnGetProcessAffinityMask || !pfnSetProcessAffinityMask)
-		return;
-	else
-		selfpid = pfnGetCurrentProcess();
-
-	pfnGetProcessAffinityMask(selfpid, &dwProcMask, &dwSysMask);
-
-	/* If resulting mask is zero, don't change anything and fall back to
-	 * actual mask.
-	 */
-	if(dwSysMask & cv_cpuaffinity.value)
-	{
-		pfnSetProcessAffinityMask(selfpid, dwSysMask & cv_cpuaffinity.value);
-		CV_StealthSetValue(&cv_cpuaffinity, (int)(dwSysMask & cv_cpuaffinity.value));
-	}
-	else
-		CV_StealthSetValue(&cv_cpuaffinity, (int)dwProcMask);
-}
-
-void I_RegisterSysCommands(void)
-{
-	GetAffinityFuncs();
-	CV_RegisterVar(&cv_cpuaffinity);
-}
-#endif
diff --git a/src/win32/win_vid.c b/src/win32/win_vid.c
deleted file mode 100644
index 7a33e19311f876fe595b72f7552fcf55f0af23fd..0000000000000000000000000000000000000000
--- a/src/win32/win_vid.c
+++ /dev/null
@@ -1,1113 +0,0 @@
-// Emacs style mode select   -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright (C) 1998-2000 by DooM Legacy Team.
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-// GNU General Public License for more details.
-//-----------------------------------------------------------------------------
-/// \file
-/// \brief win32 video driver for Doom Legacy
-
-#include "../doomdef.h"
-
-#ifdef _WINDOWS
-
-#include <stdlib.h>
-#include <stdarg.h>
-
-#include "../d_clisrv.h"
-#include "../i_system.h"
-#include "../m_argv.h"
-#include "../v_video.h"
-#include "../st_stuff.h"
-#include "../i_video.h"
-#include "../z_zone.h"
-#include "fabdxlib.h"
-#include "../doomstat.h"
-#include "win_main.h"
-#include "../command.h"
-#include "../screen.h"
-
-#ifdef HWRENDER
-#include "win_dll.h" // loading the render DLL
-#include "../hardware/hw_drv.h" // calling driver init & shutdown
-#include "../hardware/hw_main.h" // calling HWR module init & shutdown
-#endif
-
-// -------
-// Globals
-// -------
-
-// this is the CURRENT rendermode!! very important: used by w_wad, and much other code
-rendermode_t rendermode = render_soft;
-rendermode_t chosenrendermode = render_none; // set by command line arguments
-static void OnTop_OnChange(void);
-// synchronize page flipping with screen refresh
-static CV_PossibleValue_t CV_NeverOnOff[] = {{-1, "Never"}, {0, "Off"}, {1, "On"}, {0, NULL}};
-consvar_t cv_vidwait = CVAR_INIT ("vid_wait", "On", CV_SAVE, CV_OnOff, OnTop_OnChange);
-static consvar_t cv_stretch = CVAR_INIT ("stretch", "On", CV_SAVE|CV_NOSHOWHELP, CV_OnOff, NULL);
-static consvar_t cv_ontop = CVAR_INIT ("ontop", "Never", 0, CV_NeverOnOff, NULL);
-
-boolean highcolor;
-
-static BOOL bDIBMode; // means we are using DIB instead of DirectDraw surfaces
-static LPBITMAPINFO bmiMain = NULL;
-static HDC hDCMain = NULL;
-
-// -----------------
-// Video modes stuff
-// -----------------
-
-#define MAX_EXTRA_MODES 36
-static vmode_t extra_modes[MAX_EXTRA_MODES] = {{NULL, NULL, 0, 0, 0, 0, 0, 0, NULL, NULL, 0}};
-static char names[MAX_EXTRA_MODES][10];
-
-static INT32 numvidmodes; // total number of DirectDraw display modes
-static vmode_t *pvidmodes; // start of videomodes list.
-static vmode_t *pcurrentmode; // the current active videomode.
-static BOOL bWinParm;
-static INT32 WINAPI VID_SetWindowedDisplayMode(viddef_t *lvid, vmode_t *currentmode);
-
-// this holds description of the startup video mode,
-// the resolution is 320x200, windowed on the desktop
-static char winmodenames[NUMSPECIALMODES][11] = {
- // W to make sure it's the windowed mode
-	"320x200W",
-	"640x400W",
-	"960x600W",
-	"1280x800W"
-};
-vmode_t specialmodes[NUMSPECIALMODES] =
-{
-	{
-		NULL,
-		winmodenames[0], // hehe
-		320, 200, //(200.0/320.0)*(320.0/240.0),
-		320, 1, // rowbytes, bytes per pixel
-		1, 2, // windowed (TRUE), numpages
-		NULL,
-		VID_SetWindowedDisplayMode, 0
-	},
-	{
-		NULL,
-		winmodenames[1], // haha
-		640, 400,
-		640, 1, // rowbytes, bytes per pixel
-		1, 2, // windowed (TRUE), numpages
-		NULL,
-		VID_SetWindowedDisplayMode, 0
-	},
-	{
-		NULL,
-		winmodenames[2], // hihi?
-		960, 600,
-		960, 1, // rowbytes, bytes per pixel
-		1, 2, // windowed (TRUE), numpages
-		NULL,
-		VID_SetWindowedDisplayMode, 0
-	},
-	{
-		NULL,
-		winmodenames[3], // hoho!
-		1280, 800,
-		1280, 1, // rowbytes, bytes per pixel
-		1, 2, // windowed (TRUE), numpages
-		NULL,
-		VID_SetWindowedDisplayMode, 0
-	}
-};
-
-// ------
-// Protos
-// ------
-static void VID_Command_NumModes_f(void);
-static void VID_Command_ModeInfo_f(void);
-static void VID_Command_ModeList_f(void);
-static void VID_Command_Mode_f(void);
-static INT32 WINAPI VID_SetDirectDrawMode(viddef_t *lvid, vmode_t *currentmode);
-static vmode_t *VID_GetModePtr(int modenum);
-static VOID VID_Init(VOID);
-static BOOL VID_FreeAndAllocVidbuffer(viddef_t *lvid);
-
-#if 0
-	// Disable Composition in Vista DWM (Desktop Window Manager) ----------------
-static HMODULE DMdll = NULL;
-typedef HRESULT (CALLBACK *P_DwmIsCompositionEnabled) (BOOL *pfEnabled);
-static P_DwmIsCompositionEnabled pfnDwmIsCompositionEnabled = NULL;
-typedef HRESULT (CALLBACK *P_DwmEnableComposition) (BOOL   fEnable);
-static P_DwmEnableComposition pfnDwmEnableComposition = NULL;
-static BOOL AeroWasEnabled = FALSE;
-
-static inline VOID UnloadDM(VOID)
-{
-	pfnDwmEnableComposition = NULL;
-	pfnDwmIsCompositionEnabled = NULL;
-	if (DMdll) FreeLibrary(DMdll);
-	DMdll = NULL;
-}
-
-static inline BOOL LoadDM(VOID)
-{
-	if (DMdll)
-		return TRUE;
-
-	DMdll = LoadLibraryA("dwmapi.dll");
-	if (DMdll)
-		I_OutputMsg("dmwapi.dll loaded, Vista's Desktop Window Manager API\n");
-	else
-		return FALSE;
-
-	pfnDwmIsCompositionEnabled = (P_DwmIsCompositionEnabled)GetProcAddress(DMdll, "DwmIsCompositionEnabled");
-	if (pfnDwmIsCompositionEnabled)
-		I_OutputMsg("Composition Aero API found, DwmIsCompositionEnabled\n");
-
-	pfnDwmEnableComposition = (P_DwmEnableComposition)GetProcAddress(DMdll, "DwmEnableComposition");
-	if (pfnDwmEnableComposition)
-		I_OutputMsg("Composition Aero API found, DwmEnableComposition\n");
-
-	return TRUE;
-}
-
-static inline VOID DisableAero(VOID)
-{
-	BOOL pfnDwmEnableCompositiond = FALSE;
-	AeroWasEnabled = FALSE;
-
-	if (!LoadDM())
-		return;
-
-	if (pfnDwmIsCompositionEnabled && SUCCEEDED(pfnDwmIsCompositionEnabled(&pfnDwmEnableCompositiond)))
-		I_OutputMsg("Got the result of DwmIsCompositionEnabled, %i\n", pfnDwmEnableCompositiond);
-	else
-		return;
-
-	if ((AeroWasEnabled = pfnDwmEnableCompositiond))
-		I_OutputMsg("Disable the Aero rendering\n");
-	else
-		return;
-
-	if (pfnDwmEnableComposition && SUCCEEDED(pfnDwmEnableComposition(FALSE)))
-		I_OutputMsg("Aero rendering disabled\n");
-	else
-		I_OutputMsg("We failed to disable the Aero rendering\n");
-}
-
-static inline VOID ResetAero(VOID)
-{
-	if (pfnDwmEnableComposition && AeroWasEnabled)
-	{
-		if (SUCCEEDED(pfnDwmEnableComposition(AeroWasEnabled)))
-			I_OutputMsg("Aero rendering setting restored\n");
-		else
-			I_OutputMsg("We failed to restore Aero rendering\n");
-	}
-	UnloadDM();
-}
-#endif
-
-// -----------------
-// I_StartupGraphics
-// Initialize video mode, setup dynamic screen size variables,
-// and allocate screens.
-// -----------------
-void I_StartupGraphics(void)
-{
-	if (graphics_started)
-		return;
-
-#ifdef HWRENDER
-	else if (M_CheckParm("-opengl"))
-		rendermode = render_opengl;
-	else
-#endif
-		rendermode = render_soft;
-
-	if (dedicated)
-		rendermode = render_none;
-	else
-		VID_Init();
-
-	// register exit code for graphics
-	I_AddExitFunc(I_ShutdownGraphics);
-	if (!dedicated) graphics_started = true;
-}
-
-void VID_StartupOpenGL(void){}
-
-// ------------------
-// I_ShutdownGraphics
-// Close the screen, restore previous video mode.
-// ------------------
-void I_ShutdownGraphics(void)
-{
-#ifdef HWRENDER
-	const rendermode_t oldrendermode = rendermode;
-#endif
-
-// This is BAD because it makes the I_Error box screw up!
-//	rendermode = render_none;
-
-	if (!graphics_started)
-		return;
-
-	CONS_Printf("I_ShutdownGraphics: ");
-
-	//FreeConsole();
-
-	//ResetAero();
-
-	// release windowed startup stuff
-	if (hDCMain)
-	{
-		ReleaseDC(hWndMain, hDCMain);
-		hDCMain = NULL;
-	}
-	if (bmiMain)
-	{
-		GlobalFree(bmiMain);
-		bmiMain = NULL;
-	}
-
-#ifdef HWRENDER
-	if (oldrendermode != render_soft)
-	{
-		HWR_Shutdown(); // free stuff from the hardware renderer
-		HWD.pfnShutdown(); // close 3d card display
-		Shutdown3DDriver(); // free the driver DLL
-	}
-#endif
-
-	// free the last video mode screen buffers
-	if (vid.buffer)
-	{
-		GlobalFree(vid.buffer);
-		vid.buffer = NULL;
-	}
-
-#ifdef HWRENDER
-	if (rendermode == render_soft)
-#endif
-		CloseDirectDraw();
-
-	graphics_started = false;
-}
-
-// --------------
-// I_UpdateNoBlit
-// --------------
-void I_UpdateNoBlit(void)
-{
-	// what is this?
-}
-
-// I_SkipFrame
-//
-// Returns true if it thinks we can afford to skip this frame
-// from PrBoom's src/SDL/i_video.c
-static inline boolean I_SkipFrame(void)
-{
-	static boolean skip = false;
-
-	if (render_soft != rendermode)
-		return false;
-
-	skip = !skip;
-	switch (gamestate)
-	{
-		case GS_LEVEL:
-			if (!paused)
-				return false;
-		//case GS_TIMEATTACK: -- sorry optimisation but now we have a cool level platter and that being laggardly looks terrible
-#ifndef NONET
-		/* FALLTHRU */
-		case GS_WAITINGPLAYERS:
-#endif
-			return skip; // Skip odd frames
-		default:
-			return false;
-	}
-}
-
-static void OnTop_OnChange(void)
-{
-	const UINT uFlags = SWP_NOACTIVATE|SWP_NOMOVE|SWP_NOSIZE|SWP_NOZORDER;
-	RECT bounds;
-	int x = 0, y = 0, w = 0, h = 0;
-
-	if (!hWndMain || bAppFullScreen || cv_ontop.value == -1)
-		return;
-
-	GetWindowRect(hWndMain, &bounds);
-	AdjustWindowRectEx(&bounds, GetWindowLong(hWndMain, GWL_STYLE), 0, 0);
-	w = bounds.right - (x = bounds.left); h = bounds.bottom - (y = bounds.top);
-
-	if (cv_ontop.value && !paused)
-		SetWindowPos(hWndMain, HWND_TOP      , x, y, w, h, uFlags);
-	else
-		SetWindowPos(hWndMain, HWND_NOTOPMOST, x, y, w, h, uFlags);
-}
-
-// --------------
-// I_FinishUpdate
-// --------------
-void I_FinishUpdate(void)
-{
-	if (rendermode == render_none)
-		return;
-
-	if (I_SkipFrame())
-		return;
-
-	if (marathonmode)
-		SCR_DisplayMarathonInfo();
-
-	// draw captions if enabled
-	if (cv_closedcaptioning.value)
-		SCR_ClosedCaptions();
-
-	// display a graph of ticrate
-	if (cv_ticrate.value)
-		SCR_DisplayTicRate();
-
-	if (cv_showping.value && netgame && consoleplayer != serverplayer)
-		SCR_DisplayLocalPing();
-
-	//
-	if (bDIBMode)
-	{
-		// paranoia
-		if (!hDCMain || !bmiMain || !vid.buffer)
-			return;
-		// main game loop, still in a window (-win parm)
-		SetDIBitsToDevice(hDCMain, 0, 0, vid.width, vid.height, 0, 0, 0, vid.height, vid.buffer, bmiMain,
-			DIB_RGB_COLORS);
-	}
-	else
-#ifdef HWRENDER
-	if (rendermode != render_soft)
-		HWD.pfnFinishUpdate(cv_vidwait.value);
-	else
-#endif
-	{
-		// DIRECT DRAW
-		// copy virtual screen to real screen
-		// can fail when not active (alt-tab)
-		if (LockScreen())
-		{
-			/// \todo use directX blit here!!? a blit might use hardware with access
-			/// to main memory on recent hardware, and software blit of directX may be
-			/// optimized for p2 or mmx??
-			if (ScreenHeight > vid.height)
-			{
-				UINT8 *ptr = (UINT8 *)ScreenPtr;
-				size_t half_excess = ScreenPitch*(ScreenHeight-vid.height)/2;
-				memset(ptr, 0x1F, half_excess);
-				ptr += half_excess;
-				VID_BlitLinearScreen(screens[0], ptr, vid.width*vid.bpp, vid.height,
-					vid.width*vid.bpp, ScreenPitch);
-				ptr += vid.height*ScreenPitch;
-				memset(ptr, 0x1F, half_excess);
-			}
-			else
-				VID_BlitLinearScreen(screens[0], (UINT8 *)ScreenPtr, vid.width*vid.bpp, vid.height,
-					vid.width*vid.bpp, ScreenPitch);
-
-			UnlockScreen();
-
-			// swap screens
-			ScreenFlip(cv_vidwait.value);
-		}
-	}
-}
-
-// ---------------
-// I_UpdateNoVsync
-// ---------------
-void I_UpdateNoVsync(void)
-{
-	int real_vidwait = cv_vidwait.value;
-	cv_vidwait.value = 0;
-	I_FinishUpdate();
-	cv_vidwait.value = real_vidwait;
-}
-
-//
-// This is meant to be called only by CONS_Printf() while game startup
-//
-void I_LoadingScreen(LPCSTR msg)
-{
-	RECT rect;
-
-	// paranoia
-	if (!hDCMain || !bmiMain || !vid.buffer)
-		return;
-
-	GetClientRect(vid.WndParent, &rect);
-
-	SetDIBitsToDevice(hDCMain, 0, 0, vid.width, vid.height, 0, 0, 0, vid.height, vid.buffer, bmiMain, DIB_RGB_COLORS);
-
-	if (msg)
-	{
-		if (rect.bottom - rect.top > 32)
-			rect.top = rect.bottom - 32; // put msg on bottom of window
-		SetBkMode(hDCMain, TRANSPARENT);
-		SetTextColor(hDCMain, RGB(0x00, 0x00, 0x00));
-		DrawTextA(hDCMain, msg, -1, &rect, DT_WORDBREAK|DT_CENTER);
-	}
-}
-
-// ------------
-// I_ReadScreen
-// ------------
-void I_ReadScreen(UINT8 *scr)
-{
-	// DEBUGGING
-	if (rendermode != render_soft)
-		I_Error("I_ReadScreen: called while in non-software mode");
-	VID_BlitLinearScreen(screens[0], scr, vid.width*vid.bpp, vid.height, vid.width*vid.bpp,
-		vid.rowbytes);
-}
-
-// ------------
-// I_SetPalette
-// ------------
-void I_SetPalette(RGBA_t *palette)
-{
-	int i;
-
-	if (bDIBMode)
-	{
-		// set palette in RGBQUAD format, NOT THE SAME ORDER as PALETTEENTRY, grmpf!
-		RGBQUAD *pColors;
-		pColors = (RGBQUAD *)((LPBYTE)bmiMain + bmiMain->bmiHeader.biSize);
-		ZeroMemory(pColors, sizeof (RGBQUAD)*256);
-		for (i = 0; i < 256; i++, pColors++, palette++)
-		{
-			pColors->rgbRed = palette->s.red;
-			pColors->rgbGreen = palette->s.green;
-			pColors->rgbBlue = palette->s.blue;
-		}
-	}
-	else
-#ifdef HWRENDER
-	if (rendermode == render_soft)
-#endif
-	{
-		PALETTEENTRY mainpal[256];
-
-		// this clears the 'flag' for each color in palette
-		ZeroMemory(mainpal, sizeof mainpal);
-
-		// set palette in PALETTEENTRY format
-		for (i = 0; i < 256; i++, palette++)
-		{
-			mainpal[i].peRed = palette->s.red;
-			mainpal[i].peGreen = palette->s.green;
-			mainpal[i].peBlue = palette->s.blue;
-		}
-		SetDDPalette(mainpal);         // set DirectDraw palette
-	}
-}
-
-//
-// return number of video modes in pvidmodes list
-// MODES ARE ZERO INDEXED. DO NOT USE (n > nummodes). USE >= INSTEAD.
-//
-INT32 VID_NumModes(void)
-{
-	return numvidmodes;
-}
-
-// return a video mode number from the dimensions
-// returns any available video mode if the mode was not found
-INT32 VID_GetModeForSize(INT32 w, INT32 h)
-{
-	vmode_t *pv = pvidmodes;
-	int modenum = 0;
-
-	// Fullscreen resolutions exist
-	if (numvidmodes > NUMSPECIALMODES)
-	{
-		// skip the special modes so that it finds only fullscreen modes
-		for (; pv && modenum < NUMSPECIALMODES; pv = pv->pnext, ++modenum);
-		for (; pv; pv = pv->pnext, ++modenum)
-			if (pv->width == (unsigned)w && pv->height == (unsigned)h)
-				return modenum;
-
-		// Try default video mode first
-		if (w != cv_scr_width.value || h != cv_scr_height.value)
-			return VID_GetModeForSize(cv_scr_width.value, cv_scr_height.value);
-
-		// didn't find, return first fullscreen mode
-		return NUMSPECIALMODES;
-	}
-
-	// rely only on special (windowed) modes
-	for (; pv && modenum < NUMSPECIALMODES; pv = pv->pnext, ++modenum)
-		if (pv->width == (unsigned)w && pv->height == (unsigned)h)
-			return modenum;
-
-	// Try default video mode first
-	if (w != cv_scr_width.value || h != cv_scr_height.value)
-		return VID_GetModeForSize(cv_scr_width.value, cv_scr_height.value);
-
-	// didn't find, return first windowed mode
-	return 0;
-}
-
-//
-// Enumerate DirectDraw modes available
-//
-static int nummodes = 0;
-static BOOL GetExtraModesCallback(int width, int height, int bpp)
-{
-#ifdef _DEBUG
-	CONS_Printf("mode %d x %d x %d bpp\n", width, height, bpp);
-#endif
-
-	// skip all unwanted modes
-	if (highcolor && bpp != 15)
-		goto skip;
-	if (!highcolor && bpp != 8)
-		goto skip;
-
-	if (bpp > 16 || width > MAXVIDWIDTH || height > MAXVIDHEIGHT)
-		goto skip;
-
-	// check if we have space for this mode
-	if (nummodes >= MAX_EXTRA_MODES)
-	{
-#ifdef _DEBUG
-		CONS_Printf("mode skipped (too many)\n");
-#endif
-		return FALSE;
-	}
-
-	// store mode info
-	extra_modes[nummodes].pnext = &extra_modes[nummodes+1];
-	memset(names[nummodes], 0, 10);
-	snprintf(names[nummodes], 9, "%dx%d", width, height);
-
-	extra_modes[nummodes].name = names[nummodes];
-	extra_modes[nummodes].width = width;
-	extra_modes[nummodes].height = height;
-
-	// exactly, the current FinishUdpate() gets the rowbytes itself after locking the video buffer
-	// so for now we put anything here
-	extra_modes[nummodes].rowbytes = width;
-	extra_modes[nummodes].windowed = false;
-	extra_modes[nummodes].misc = 0; // unused
-	extra_modes[nummodes].pextradata = NULL;
-	extra_modes[nummodes].setmode = VID_SetDirectDrawMode;
-
-	extra_modes[nummodes].numpages = 3; // triple-buffer (but this value is unused)
-
-	extra_modes[nummodes].bytesperpixel = (bpp+1)>>3;
-
-	nummodes++;
-skip:
-	return TRUE;
-}
-
-//
-// Collect info about DirectDraw display modes we use
-//
-static inline VOID VID_GetExtraModes(VOID)
-{
-	nummodes = 0;
-	EnumDirectDrawDisplayModes(GetExtraModesCallback);
-
-	// add the extra modes (not 320x200) at the start of the mode list (if there are any)
-	if (nummodes)
-	{
-		extra_modes[nummodes-1].pnext = NULL;
-		pvidmodes = &extra_modes[0];
-		numvidmodes += nummodes;
-	}
-}
-
-// ---------------
-// WindowMode_Init
-// Add windowed modes to the start of the list,
-// mode 0 is used for windowed console startup (works on all computers with no DirectX)
-// ---------------
-static VOID WindowMode_Init(VOID)
-{
-	int modenum;
-
-	for (modenum = 0; modenum < NUMSPECIALMODES - 1; modenum++)
-		specialmodes[modenum].pnext = &specialmodes[modenum + 1];
-	specialmodes[NUMSPECIALMODES-1].pnext = pvidmodes;
-
-	pvidmodes = specialmodes;
-	numvidmodes += NUMSPECIALMODES;
-}
-
-// *************************************************************************************
-// VID_Init
-// Initialize Video modes subsystem
-// *************************************************************************************
-static VOID VID_Init(VOID)
-{
-#ifdef _DEBUG
-	vmode_t *pv;
-	int iMode;
-#endif
-
-	// if '-win' is specified on the command line, do not add DirectDraw modes
-	bWinParm = M_CheckParm("-win");
-
-	COM_AddCommand("vid_nummodes", VID_Command_NumModes_f);
-	COM_AddCommand("vid_modeinfo", VID_Command_ModeInfo_f);
-	COM_AddCommand("vid_modelist", VID_Command_ModeList_f);
-	COM_AddCommand("vid_mode", VID_Command_Mode_f);
-
-	CV_RegisterVar(&cv_vidwait);
-	CV_RegisterVar(&cv_stretch);
-	CV_RegisterVar(&cv_ontop);
-
-	// setup the videmodes list,
-	// note that mode 0 must always be VGA mode 0x13
-	pvidmodes = pcurrentmode = NULL;
-	numvidmodes = 0;
-
-	//DisableAero();
-
-	// store the main window handle in viddef struct
-	SetWindowPos(hWndMain, HWND_NOTOPMOST, 0, 0, 0, 0, SWP_NOACTIVATE|SWP_NOSENDCHANGING|SWP_NOSIZE|SWP_NOMOVE);
-	vid.WndParent = hWndMain;
-	vid.buffer = NULL;
-
-	// we startup in windowed mode using DIB bitmap
-	// we will use DirectDraw when switching fullScreen and entering main game loop
-	bDIBMode = TRUE;
-	bAppFullScreen = FALSE;
-
-#ifdef HWRENDER
-	// initialize the appropriate display device
-	if (rendermode != render_soft)
-	{
-		const char *drvname = NULL;
-
-		switch (rendermode)
-		{
-			case render_opengl:
-				drvname = "r_opengl.dll";
-				break;
-			default:
-				I_Error("Unknown hardware render mode");
-		}
-
-		// load the DLL
-		if (drvname && Init3DDriver(drvname))
-		{
-			int hwdversion = HWD.pfnGetRenderVersion();
-			if (hwdversion != VERSION)
-				CONS_Alert(CONS_WARNING, M_GetText("This r_opengl version is not supported, use it at your own risk!\n"));
-
-			// perform initialisations
-			HWD.pfnInit(I_Error);
-			// get available display modes for the device
-			HWD.pfnGetModeList(&pvidmodes, &numvidmodes);
-		}
-		else
-		{
-			switch (rendermode)
-			{
-				case render_opengl:
-					I_Error("Error initializing OpenGL");
-				default:
-					break;
-			}
-			rendermode = render_soft;
-		}
-	}
-
-	if (rendermode == render_soft)
-#endif
-		if (!bWinParm)
-		{
-			if (!CreateDirectDrawInstance())
-				bWinParm = TRUE;
-			else // get available display modes for the device
-				VID_GetExtraModes();
-		}
-
-	// the game boots in 320x200 standard VGA, but
-	// we need a highcolor mode to run the game in highcolor
-	if (highcolor && !numvidmodes)
-		I_Error("Cannot run in highcolor - No 15bit highcolor DirectX video mode found.");
-
-	// add windowed mode at the start of the list, very important!
-	WindowMode_Init();
-
-	if (!numvidmodes)
-		I_Error("No display modes available.");
-
-#ifdef _DEBUG // DEBUG
-	for (iMode = 0, pv = pvidmodes; pv; pv = pv->pnext, iMode++)
-		I_OutputMsg("#%02d: %dx%dx%dbpp (desc: '%s')\n", iMode, pv->width, pv->height, pv->bytesperpixel, pv->name);
-#endif
-
-	// set the startup screen in a window
-	VID_SetMode(0);
-}
-
-// --------------------------
-// VID_SetWindowedDisplayMode
-// Display the startup 320x200 console screen into a window on the desktop,
-// switching to fullscreen display only when we will enter the main game loop.
-// - we can display error message boxes for startup errors
-// - we can set the last used resolution only once, when entering the main game loop
-// --------------------------
-static INT32 WINAPI VID_SetWindowedDisplayMode(viddef_t *lvid, vmode_t *currentmode)
-{
-	RECT bounds;
-	int x = 0, y = 0, w = 0, h = 0;
-
-	UNREFERENCED_PARAMETER(currentmode);
-
-	I_OutputMsg("VID_SetWindowedDisplayMode()\n");
-
-
-	lvid->u.numpages = 1; // not used
-	lvid->direct = NULL; // DOS remains
-	lvid->buffer = NULL;
-
-	// allocate screens
-	if (!VID_FreeAndAllocVidbuffer(lvid))
-		return -1;
-
-	// lvid->buffer should be NULL here!
-
-	bmiMain = GlobalAlloc(GPTR, sizeof (BITMAPINFO) + (sizeof (RGBQUAD)*256));
-	if (!bmiMain)
-		I_Error("VID_SWDM(): No mem");
-
-	// setup a BITMAPINFO to allow copying our video buffer to the desktop,
-	// with color conversion as needed
-	bmiMain->bmiHeader.biSize = sizeof (BITMAPINFOHEADER);
-	bmiMain->bmiHeader.biWidth = lvid->width;
-	bmiMain->bmiHeader.biHeight= -(lvid->height);
-	bmiMain->bmiHeader.biPlanes = 1;
-	bmiMain->bmiHeader.biBitCount = 8;
-	bmiMain->bmiHeader.biCompression = BI_RGB;
-
-	// center window on the desktop
-	bounds.left = 0;
-	bounds.right = lvid->width;
-	bounds.top = 0;
-	bounds.bottom = lvid->height;
-	AdjustWindowRectEx(&bounds, GetWindowLong(hWndMain, GWL_STYLE), FALSE, GetWindowLong(hWndMain, GWL_EXSTYLE));
-
-	w = bounds.right-bounds.left;
-	h = bounds.bottom-bounds.top;
-	x = (GetSystemMetrics(SM_CXSCREEN)-w)/2;
-	y = (GetSystemMetrics(SM_CYSCREEN)-h)/2;
-
-	if (devparm)
-		MoveWindow(hWndMain, x<<1, y<<1, w, h, TRUE);
-	else
-		MoveWindow(hWndMain, x, y, w, h, TRUE);
-
-	SetFocus(hWndMain);
-	ShowWindow(hWndMain, SW_SHOW);
-
-	hDCMain = GetDC(hWndMain);
-	if (!hDCMain)
-		I_Error("VID_SWDM(): GetDC FAILED");
-
-	return 1;
-}
-
-// ========================================================================
-// Returns a vmode_t from the video modes list, given a video mode number.
-// ========================================================================
-vmode_t *VID_GetModePtr(int modenum)
-{
-	vmode_t *pv;
-
-	pv = pvidmodes;
-	if (!pv)
-		I_Error("VID_error: No video mode found\n");
-
-	while (modenum--)
-	{
-		pv = pv->pnext;
-		if (!pv)
-			I_Error("VID_error: Mode not available\n");
-	}
-	return pv;
-}
-
-//
-// return the name of a video mode
-//
-const char *VID_GetModeName(INT32 modenum)
-{
-	return (VID_GetModePtr(modenum))->name;
-}
-
-// ========================================================================
-// Sets a video mode
-// ========================================================================
-INT32 VID_SetMode(INT32 modenum)
-{
-	int vstat;
-	vmode_t *pnewmode;
-
-	if (dedicated)
-		return 0;
-
-	I_OutputMsg("VID_SetMode(%d)\n", modenum);
-
-	// if mode 0 (windowed) we must not be fullscreen already,
-	// if other mode, check it is not mode 0 and existing
-	if (modenum >= numvidmodes)
-	{
-		if (!pcurrentmode)
-			modenum = 0; // revert to the default base vid mode
-		else
-			I_Error("Unknown video mode: %d\n", modenum);
-	}
-	else if (bAppFullScreen && modenum < NUMSPECIALMODES)
-		I_Error("Tried to switch from fullscreen back to windowed mode %d\n", modenum);
-
-	pnewmode = VID_GetModePtr(modenum);
-
-	// dont switch to the same display mode
-	if (pnewmode == pcurrentmode)
-		return 1;
-
-	// initialize the new mode
-	pcurrentmode = pnewmode;
-
-	// initialize vidbuffer size for setmode
-	vid.width = pcurrentmode->width;
-	vid.height = pcurrentmode->height;
-	vid.rowbytes = pcurrentmode->rowbytes;
-	vid.bpp = pcurrentmode->bytesperpixel;
-	if (modenum) // if not 320x200 windowed mode, it's actually a hack
-	{
-		if (rendermode == render_opengl)
-		{
-			// don't accept depth < 16 for OpenGL mode (too much ugly)
-			if (cv_scr_depth.value < 16)
-				CV_SetValue(&cv_scr_depth,  16);
-			vid.bpp = cv_scr_depth.value/8;
-			vid.u.windowed = (bWinParm || !cv_fullscreen.value);
-			pcurrentmode->bytesperpixel = vid.bpp;
-			pcurrentmode->windowed = vid.u.windowed;
-		}
-	}
-
-	vstat = (*pcurrentmode->setmode)(&vid, pcurrentmode);
-
-	if (vstat == -1)
-		I_Error("Not enough mem for VID_SetMode\n");
-	else if (vstat == -2)
-		I_Error("Couldn't set video mode because it failed the test\n");
-	else if (vstat == -3)
-		I_Error("Couldn't set video mode because it failed the change?\n");
-	else if (!vstat)
-		I_Error("Couldn't set video mode %d (%dx%d %d bits)\n", modenum, vid.width, vid.height, (vid.bpp*8));// hardware could not setup mode
-	else
-		CONS_Printf(M_GetText("Mode changed to %d (%s)\n"), modenum, pcurrentmode->name);
-
-	vid.modenum = modenum;
-
-	// tell game engine to recalc all tables and realloc buffers based on new values
-	vid.recalc = 1;
-
-	if (modenum < NUMSPECIALMODES)
-	{
-		// we are in startup windowed mode
-		bAppFullScreen = FALSE;
-		bDIBMode = TRUE;
-	}
-	else
-	{
-		// we switch to fullscreen
-		bAppFullScreen = TRUE;
-		bDIBMode = FALSE;
-#ifdef HWRENDER
-		if (rendermode != render_soft)
-		{
-			// purge all patch graphics stored in software format
-			//Z_FreeTags (PU_PURGELEVEL, PU_PURGELEVEL+100);
-			HWR_Startup();
-		}
-#endif
-	}
-
-	I_RestartSysMouse();
-	return 1;
-}
-
-boolean VID_CheckRenderer(void)
-{
-	return false;
-}
-
-void VID_CheckGLLoaded(rendermode_t oldrender)
-{
-	(void)oldrender;
-}
-
-// ========================================================================
-// Free the video buffer of the last video mode,
-// allocate a new buffer for the video mode to set.
-// ========================================================================
-static BOOL VID_FreeAndAllocVidbuffer(viddef_t *lvid)
-{
-	const DWORD vidbuffersize = (lvid->width * lvid->height * lvid->bpp * NUMSCREENS);
-
-	// free allocated buffer for previous video mode
-	if (lvid->buffer)
-		GlobalFree(lvid->buffer);
-
-	// allocate & clear the new screen buffer
-	lvid->buffer = GlobalAlloc(GPTR, vidbuffersize);
-	if (!lvid->buffer)
-		return FALSE;
-
-	ZeroMemory(lvid->buffer, vidbuffersize);
-	I_OutputMsg("VID_FreeAndAllocVidbuffer done, vidbuffersize: %x\n",(UINT32)vidbuffersize);
-
-	return TRUE;
-}
-
-// ========================================================================
-// Set video mode routine for DirectDraw display modes
-// Out: 1 ok,
-//              0 hardware could not set mode,
-//     -1 no mem
-// ========================================================================
-static INT32 WINAPI VID_SetDirectDrawMode(viddef_t *lvid, vmode_t *currentmode)
-{
-	UNREFERENCED_PARAMETER(currentmode);
-
-	I_OutputMsg("VID_SetDirectDrawMode...\n");
-
-
-	// DD modes do double-buffer page flipping, but the game engine doesn't need this..
-	lvid->u.numpages = 2;
-
-	// release ddraw surfaces etc..
-	ReleaseChtuff();
-
-	// clean up any old vid buffer lying around, alloc new if needed
-	if (!VID_FreeAndAllocVidbuffer(lvid))
-		return -1; // no mem
-
-	// should clear video mem here
-
-	// note use lvid->bpp instead of 8...will this be needed? will we support other than 256color
-	// in software ?
-	if (!InitDirectDrawe(hWndMain, lvid->width, lvid->height, 8, TRUE)) // TRUE currently always full screen
-		return 0;               // could not set mode
-
-	// this is NOT used with DirectDraw modes, game engine should never use this directly
-	// but rather render to memory bitmap buffer
-	lvid->direct = NULL;
-
-	if (!cv_stretch.value && fabsf((float)vid.width/vid.height - ((float)BASEVIDWIDTH/BASEVIDHEIGHT)) > 1.0E-36f)
-		vid.height = (int)(vid.width * ((float)BASEVIDHEIGHT/BASEVIDWIDTH));// Adjust the height to match
-
-	return 1;
-}
-
-// ========================================================================
-//                     VIDEO MODE CONSOLE COMMANDS
-// ========================================================================
-
-// vid_nummodes
-//
-static void VID_Command_NumModes_f(void)
-{
-	CONS_Printf(M_GetText("%d video mode(s) available(s)\n"), VID_NumModes());
-}
-
-// vid_modeinfo <modenum>
-//
-static void VID_Command_ModeInfo_f(void)
-{
-	vmode_t *pv;
-	int modenum;
-
-	if (COM_Argc() != 2)
-		modenum = vid.modenum; // describe the current mode
-	else
-		modenum = atoi(COM_Argv(1)); // the given mode number
-
-	if (modenum >= VID_NumModes()
-	 || (!bWinParm && modenum < NUMSPECIALMODES)) // don't accept the windowed modes
-	{
-		CONS_Printf(M_GetText("Video mode not present\n"));
-		return;
-	}
-
-	pv = VID_GetModePtr(modenum);
-
-	CONS_Printf("\x82" "%s\n", VID_GetModeName(modenum));
-	CONS_Printf(M_GetText("width: %d\nheight: %d\n"),
-		pv->width, pv->height);
-	if (rendermode == render_soft)
-		CONS_Printf(M_GetText("bytes per scanline: %d\nbytes per pixel: %d\nnumpages: %d\n"),
-			pv->rowbytes, pv->bytesperpixel, pv->numpages);
-}
-
-// vid_modelist
-//
-static void VID_Command_ModeList_f(void)
-{
-	int i, numodes;
-	const char *pinfo;
-	vmode_t *pv;
-
-	numodes = VID_NumModes();
-
-	// hide windowed modes unless using them
-	i = (!bWinParm) ? NUMSPECIALMODES : 0;
-
-	for (; i < numodes; i++)
-	{
-		pv = VID_GetModePtr(i);
-		pinfo = VID_GetModeName(i);
-
-		if (pv->bytesperpixel == 1)
-			CONS_Printf("%d: %s\n", i, pinfo);
-		else
-			CONS_Printf("%d: %s (hicolor)\n", i, pinfo);
-	}
-}
-
-// vid_mode <modenum>
-//
-static void VID_Command_Mode_f(void)
-{
-	int modenum;
-
-	if (COM_Argc() != 2)
-	{
-		CONS_Printf(M_GetText("vid_mode <modenum> : set video mode, current video mode %i\n"), vid.modenum);
-		return;
-	}
-
-	modenum = atoi(COM_Argv(1));
-
-	if (modenum >= VID_NumModes()
-	 || (!bWinParm && modenum < NUMSPECIALMODES)) // don't accept the windowed modes
-		CONS_Printf(M_GetText("Video mode not present\n"));
-	else
-		setmodeneeded = modenum + 1; // request vid mode change
-}
-#endif