From cf41a11770d1e9e7c4752a42342d31f5d2667f78 Mon Sep 17 00:00:00 2001 From: Steel Titanium Date: Mon, 11 Sep 2017 16:36:30 -0400 Subject: [PATCH 01/27] Fix for window being offcenter --- src/sdl/i_video.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/sdl/i_video.c b/src/sdl/i_video.c index 9cebe4945..e8d1876d9 100644 --- a/src/sdl/i_video.c +++ b/src/sdl/i_video.c @@ -194,7 +194,7 @@ static void SDLSetMode(INT32 width, INT32 height, SDL_bool fullscreen) } // Reposition window only in windowed mode SDL_SetWindowSize(window, width, height); - SDL_SetWindowPosition(window, SDL_WINDOWPOS_CENTERED_DISPLAY(1), SDL_WINDOWPOS_CENTERED_DISPLAY(1)); + SDL_SetWindowPosition(window, SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED); } } else From 97445f941a25df089c7bdf7d1b645faaf46e1654 Mon Sep 17 00:00:00 2001 From: Steel Titanium Date: Sun, 29 Oct 2017 01:09:34 -0400 Subject: [PATCH 02/27] Add command to restart the audio system --- src/d_netcmd.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/src/d_netcmd.c b/src/d_netcmd.c index b5563f4e8..247829c8d 100644 --- a/src/d_netcmd.c +++ b/src/d_netcmd.c @@ -26,6 +26,7 @@ #include "p_local.h" #include "p_setup.h" #include "s_sound.h" +#include "i_sound.h" #include "m_misc.h" #include "am_map.h" #include "byteptr.h" @@ -128,6 +129,7 @@ static void Command_Playintro_f(void); static void Command_Displayplayer_f(void); static void Command_Tunes_f(void); +static void Command_RestartAudio_f(void); static void Command_ExitLevel_f(void); static void Command_Showmap_f(void); @@ -670,6 +672,7 @@ void D_RegisterClientCommands(void) COM_AddCommand("displayplayer", Command_Displayplayer_f); COM_AddCommand("tunes", Command_Tunes_f); + COM_AddCommand("restartaudio", Command_RestartAudio_f); CV_RegisterVar(&cv_resetmusic); // FIXME: not to be here.. but needs be done for config loading @@ -3909,6 +3912,20 @@ static void Command_Tunes_f(void) } } +static void Command_RestartAudio_f(void) +{ + I_ShutdownMusic(); + I_ShutdownSound(); + I_StartupSound(); + I_InitMusic(); + +// These must be called or everthing will be muted for the user until next volume change. + + I_SetSfxVolume(cv_soundvolume.value); + I_SetDigMusicVolume(cv_digmusicvolume.value); + I_SetMIDIMusicVolume(cv_midimusicvolume.value); +} + /** Quits a game and returns to the title screen. * */ From 67aba2648cbd4309bbaef80174a1e1e29e01003a Mon Sep 17 00:00:00 2001 From: Louis-Antoine Date: Wed, 25 Oct 2017 10:32:48 +0200 Subject: [PATCH 03/27] Fix download freezes (well, most of them) --- src/d_clisrv.c | 21 ++++++++++++--------- src/i_tcp.c | 3 +-- 2 files changed, 13 insertions(+), 11 deletions(-) diff --git a/src/d_clisrv.c b/src/d_clisrv.c index 312a308a1..374cb75f1 100644 --- a/src/d_clisrv.c +++ b/src/d_clisrv.c @@ -3120,16 +3120,19 @@ static boolean SV_AddWaitingPlayers(void) { newplayer = true; - // search for a free playernum - // we can't use playeringame since it is not updated here - for (; newplayernum < MAXPLAYERS; newplayernum++) - { - for (n = 0; n < MAXNETNODES; n++) - if (nodetoplayer[n] == newplayernum || nodetoplayer2[n] == newplayernum) + if (netgame) + newplayernum = node; // OMFG SAY WELCOME TO TEH NEW HACK FOR FIX FIL DOWNLOAD!!1! + else + // search for a free playernum + // we can't use playeringame since it is not updated here + for (; newplayernum < MAXPLAYERS; newplayernum++) + { + for (n = 0; n < MAXNETNODES; n++) + if (nodetoplayer[n] == newplayernum || nodetoplayer2[n] == newplayernum) + break; + if (n == MAXNETNODES) break; - if (n == MAXNETNODES) - break; - } + } // should never happen since we check the playernum // before accepting the join diff --git a/src/i_tcp.c b/src/i_tcp.c index c65a536a8..0063dedd7 100644 --- a/src/i_tcp.c +++ b/src/i_tcp.c @@ -498,8 +498,7 @@ static void cleanupnodes(void) // Why can't I start at zero? for (j = 1; j < MAXNETNODES; j++) - //if (!(nodeingame[j] || SV_SendingFile(j))) - if (!nodeingame[j]) + if (!(nodeingame[j] || SV_SendingFile(j))) nodeconnected[j] = false; } From 4f8b91c770d35f12e3aeef08910cac88586002af Mon Sep 17 00:00:00 2001 From: Steel Titanium Date: Tue, 7 Nov 2017 16:26:45 -0500 Subject: [PATCH 04/27] Attempt to restart music --- src/d_netcmd.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/d_netcmd.c b/src/d_netcmd.c index 247829c8d..501216b04 100644 --- a/src/d_netcmd.c +++ b/src/d_netcmd.c @@ -3914,16 +3914,21 @@ static void Command_Tunes_f(void) static void Command_RestartAudio_f(void) { + if (dedicated) // No point in doing anything game is a dedicated server. + return; + I_ShutdownMusic(); I_ShutdownSound(); I_StartupSound(); I_InitMusic(); -// These must be called or everthing will be muted for the user until next volume change. - +// These must be called or no sound and music untill manually set. + I_SetSfxVolume(cv_soundvolume.value); I_SetDigMusicVolume(cv_digmusicvolume.value); I_SetMIDIMusicVolume(cv_midimusicvolume.value); + if (Playing() && (!dedicated)) + P_RestoreMusic(displayplayer); } /** Quits a game and returns to the title screen. From c1405137ecf6464cb68eefd299955004e3147a86 Mon Sep 17 00:00:00 2001 From: Steel Titanium Date: Tue, 7 Nov 2017 23:48:03 -0500 Subject: [PATCH 05/27] Extra tab space to make the compiler happy --- src/d_netcmd.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/d_netcmd.c b/src/d_netcmd.c index 501216b04..67a680c31 100644 --- a/src/d_netcmd.c +++ b/src/d_netcmd.c @@ -3915,7 +3915,7 @@ static void Command_Tunes_f(void) static void Command_RestartAudio_f(void) { if (dedicated) // No point in doing anything game is a dedicated server. - return; + return; I_ShutdownMusic(); I_ShutdownSound(); @@ -3928,7 +3928,7 @@ static void Command_RestartAudio_f(void) I_SetDigMusicVolume(cv_digmusicvolume.value); I_SetMIDIMusicVolume(cv_midimusicvolume.value); if (Playing() && (!dedicated)) - P_RestoreMusic(displayplayer); + P_RestoreMusic(displayplayer); } /** Quits a game and returns to the title screen. From 7cb0138293d9d9822ea41626582a790443e294f1 Mon Sep 17 00:00:00 2001 From: Monster Iestyn Date: Wed, 8 Nov 2017 15:06:42 +0000 Subject: [PATCH 06/27] Change version number to 2.1.20 --- CMakeLists.txt | 2 +- appveyor.yml | 2 +- src/doomdef.h | 8 ++++---- src/sdl/macosx/Srb2mac.xcodeproj/project.pbxproj | 4 ++-- src/sdl12/macosx/Srb2mac.xcodeproj/project.pbxproj | 4 ++-- 5 files changed, 10 insertions(+), 10 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index f9364fdd2..eb91866f0 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,6 +1,6 @@ cmake_minimum_required(VERSION 3.0) project(SRB2 - VERSION 2.1.19 + VERSION 2.1.20 LANGUAGES C) if(${PROJECT_SOURCE_DIR} MATCHES ${PROJECT_BINARY_DIR}) diff --git a/appveyor.yml b/appveyor.yml index ae3f82f58..69913cfc8 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -1,4 +1,4 @@ -version: 2.1.19.{branch}-{build} +version: 2.1.20.{branch}-{build} os: MinGW environment: diff --git a/src/doomdef.h b/src/doomdef.h index 1eca59d52..7245061bf 100644 --- a/src/doomdef.h +++ b/src/doomdef.h @@ -150,9 +150,9 @@ extern FILE *logstream; // we use comprevision and compbranch instead. #else #define VERSION 201 // Game version -#define SUBVERSION 19 // more precise version number -#define VERSIONSTRING "v2.1.19" -#define VERSIONSTRINGW L"v2.1.19" +#define SUBVERSION 20 // more precise version number +#define VERSIONSTRING "v2.1.20" +#define VERSIONSTRINGW L"v2.1.20" // Hey! If you change this, add 1 to the MODVERSION below! // Otherwise we can't force updates! #endif @@ -214,7 +214,7 @@ extern FILE *logstream; // it's only for detection of the version the player is using so the MS can alert them of an update. // Only set it higher, not lower, obviously. // Note that we use this to help keep internal testing in check; this is why v2.1.0 is not version "1". -#define MODVERSION 24 +#define MODVERSION 25 // ========================================================================= diff --git a/src/sdl/macosx/Srb2mac.xcodeproj/project.pbxproj b/src/sdl/macosx/Srb2mac.xcodeproj/project.pbxproj index 68391f99c..eaac87deb 100644 --- a/src/sdl/macosx/Srb2mac.xcodeproj/project.pbxproj +++ b/src/sdl/macosx/Srb2mac.xcodeproj/project.pbxproj @@ -1214,7 +1214,7 @@ C01FCF4B08A954540054247B /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { - CURRENT_PROJECT_VERSION = 2.1.19; + CURRENT_PROJECT_VERSION = 2.1.20; GCC_PREPROCESSOR_DEFINITIONS = ( "$(inherited)", NORMALSRB2, @@ -1226,7 +1226,7 @@ C01FCF4C08A954540054247B /* Release */ = { isa = XCBuildConfiguration; buildSettings = { - CURRENT_PROJECT_VERSION = 2.1.19; + CURRENT_PROJECT_VERSION = 2.1.20; GCC_ENABLE_FIX_AND_CONTINUE = NO; GCC_GENERATE_DEBUGGING_SYMBOLS = NO; GCC_PREPROCESSOR_DEFINITIONS = ( diff --git a/src/sdl12/macosx/Srb2mac.xcodeproj/project.pbxproj b/src/sdl12/macosx/Srb2mac.xcodeproj/project.pbxproj index fada7849c..574161c68 100644 --- a/src/sdl12/macosx/Srb2mac.xcodeproj/project.pbxproj +++ b/src/sdl12/macosx/Srb2mac.xcodeproj/project.pbxproj @@ -1214,7 +1214,7 @@ C01FCF4B08A954540054247B /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { - CURRENT_PROJECT_VERSION = 2.1.19; + CURRENT_PROJECT_VERSION = 2.1.20; GCC_PREPROCESSOR_DEFINITIONS = ( "$(inherited)", NORMALSRB2, @@ -1226,7 +1226,7 @@ C01FCF4C08A954540054247B /* Release */ = { isa = XCBuildConfiguration; buildSettings = { - CURRENT_PROJECT_VERSION = 2.1.19; + CURRENT_PROJECT_VERSION = 2.1.20; GCC_ENABLE_FIX_AND_CONTINUE = NO; GCC_GENERATE_DEBUGGING_SYMBOLS = NO; GCC_PREPROCESSOR_DEFINITIONS = ( From 55c86f3e1558c6bf34de2de4a9b36cd9f9c12df4 Mon Sep 17 00:00:00 2001 From: Steel Titanium Date: Wed, 8 Nov 2017 14:48:05 -0500 Subject: [PATCH 07/27] Successful attempt at restarting the music --- src/d_netcmd.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/d_netcmd.c b/src/d_netcmd.c index 67a680c31..e433e3c53 100644 --- a/src/d_netcmd.c +++ b/src/d_netcmd.c @@ -3914,9 +3914,10 @@ static void Command_Tunes_f(void) static void Command_RestartAudio_f(void) { - if (dedicated) // No point in doing anything game is a dedicated server. + if (dedicated) { // No point in doing anything if game is a dedicated server. return; - +} + S_StopMusic(); I_ShutdownMusic(); I_ShutdownSound(); I_StartupSound(); @@ -3927,8 +3928,9 @@ static void Command_RestartAudio_f(void) I_SetSfxVolume(cv_soundvolume.value); I_SetDigMusicVolume(cv_digmusicvolume.value); I_SetMIDIMusicVolume(cv_midimusicvolume.value); - if (Playing() && (!dedicated)) - P_RestoreMusic(displayplayer); + if (Playing() && (!dedicated)) { // Gotta make sure the player is in a level + P_RestoreMusic(&players[displayplayer]); + } } /** Quits a game and returns to the title screen. From e61549d81fcef5fc26f7f45ef16a5253baedcdff Mon Sep 17 00:00:00 2001 From: Steel Titanium Date: Wed, 8 Nov 2017 14:50:27 -0500 Subject: [PATCH 08/27] Opps, forgot to change this. --- src/d_netcmd.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/d_netcmd.c b/src/d_netcmd.c index e433e3c53..041cb134b 100644 --- a/src/d_netcmd.c +++ b/src/d_netcmd.c @@ -3929,7 +3929,7 @@ static void Command_RestartAudio_f(void) I_SetDigMusicVolume(cv_digmusicvolume.value); I_SetMIDIMusicVolume(cv_midimusicvolume.value); if (Playing() && (!dedicated)) { // Gotta make sure the player is in a level - P_RestoreMusic(&players[displayplayer]); + P_RestoreMusic(&players[consoleplayer]); } } From 16b8265c6eb12baecc98aa3aa0619734cb411a82 Mon Sep 17 00:00:00 2001 From: Louis-Antoine Date: Tue, 12 Dec 2017 22:48:08 +0100 Subject: [PATCH 09/27] F stands for Fun. You want more Fun, don't you? --- src/d_clisrv.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/d_clisrv.c b/src/d_clisrv.c index 312a308a1..3d4a695fe 100644 --- a/src/d_clisrv.c +++ b/src/d_clisrv.c @@ -937,7 +937,7 @@ static void SV_RequireResynch(INT32 node) resynch_delay[node] = 10; // Delay before you can fail sync again resynch_score[node] += 200; // Add score for initial desynch - resynch_status[node] = 0xFF; // No players assumed synched + resynch_status[node] = 0xFFFFFFFF; // No players assumed synched resynch_inprogress[node] = true; // so we know to send a PT_RESYNCHEND after sync // Initial setup From 4e89c03b0f9ee10018731422f9d4665498dcb947 Mon Sep 17 00:00:00 2001 From: Louis-Antoine Date: Tue, 12 Dec 2017 23:08:18 +0100 Subject: [PATCH 10/27] =?UTF-8?q?Node=20and=20player=20isn't=20the=20same?= =?UTF-8?q?=20thing=20!#^&*%^:'\[[^!#^$4&@(=C3=A9@*(&$*@#=C3=A0$%@?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/d_clisrv.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/d_clisrv.c b/src/d_clisrv.c index 3d4a695fe..5cd95a6d6 100644 --- a/src/d_clisrv.c +++ b/src/d_clisrv.c @@ -109,7 +109,7 @@ static INT16 consistancy[BACKUPTICS]; static UINT32 resynch_score[MAXNETNODES]; // "score" for kicking -- if this gets too high then cfail kick static UINT16 resynch_delay[MAXNETNODES]; // delay time before the player can be considered to have desynched static UINT32 resynch_status[MAXNETNODES]; // 0 bit means synched for that player, 1 means possibly desynched -static UINT8 resynch_sent[MAXNETNODES][MAXNETNODES]; // what synch packets have we attempted to send to the player +static UINT8 resynch_sent[MAXNETNODES][MAXPLAYERS]; // what synch packets have we attempted to send to the player static UINT8 resynch_inprogress[MAXNETNODES]; static UINT8 resynch_local_inprogress = false; // WE are desynched and getting packets to fix it. static UINT8 player_joining = false; @@ -928,7 +928,7 @@ static void SV_InitResynchVars(INT32 node) resynch_score[node] = 0; // clean slate resynch_status[node] = 0x00; resynch_inprogress[node] = false; - memset(resynch_sent[node], 0, MAXNETNODES); + memset(resynch_sent[node], 0, MAXPLAYERS); } static void SV_RequireResynch(INT32 node) @@ -941,12 +941,12 @@ static void SV_RequireResynch(INT32 node) resynch_inprogress[node] = true; // so we know to send a PT_RESYNCHEND after sync // Initial setup - memset(resynch_sent[node], 0, MAXNETNODES); + memset(resynch_sent[node], 0, MAXPLAYERS); for (i = 0; i < MAXPLAYERS; ++i) { if (!playeringame[i]) // Player not in game so just drop it from required synch resynch_status[node] &= ~(1<>1)+1; } From ac3fef15eb954c1705360a7cfc25252ddcee58a3 Mon Sep 17 00:00:00 2001 From: Monster Iestyn Date: Wed, 13 Dec 2017 19:07:02 +0000 Subject: [PATCH 11/27] Rob is now in charge of Mod IDs, change MODID comment in doomdef.h to reflect this --- src/doomdef.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/doomdef.h b/src/doomdef.h index 7245061bf..7f641558f 100644 --- a/src/doomdef.h +++ b/src/doomdef.h @@ -205,7 +205,7 @@ extern FILE *logstream; // Will always resemble the versionstring, 205 = 2.0.5, 210 = 2.1, etc. #define CODEBASE 210 -// The Modification ID; must be obtained from Inuyasha ( http://mb.srb2.org/private.php?do=newpm&u=2604 ). +// The Modification ID; must be obtained from Rob ( https://mb.srb2.org/private.php?do=newpm&u=546 ). // DO NOT try to set this otherwise, or your modification will be unplayable through the Master Server. // "12" is the default mod ID for version 2.1 #define MODID 12 From 0b836a984147bf525fab5bdc4cd381673538f5b7 Mon Sep 17 00:00:00 2001 From: Louis-Antoine Date: Fri, 15 Dec 2017 16:31:27 +0100 Subject: [PATCH 12/27] Fix missing lua_pop in ArchiveExtVars --- src/lua_script.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/lua_script.c b/src/lua_script.c index acb306827..fa87f80dc 100644 --- a/src/lua_script.c +++ b/src/lua_script.c @@ -716,7 +716,10 @@ static void ArchiveExtVars(void *pointer, const char *ptype) lua_pop(gL, 1); if (i == 0 && !fastcmp(ptype,"player")) // skip anything that has an empty table and isn't a player. + { + lua_pop(gL, 1); return; + } if (fastcmp(ptype,"mobj")) // mobjs must write their mobjnum as a header WRITEUINT32(save_p, ((mobj_t *)pointer)->mobjnum); WRITEUINT16(save_p, i); From beb9b0f103f5df99d8688a72153a5c40c9ac9948 Mon Sep 17 00:00:00 2001 From: Louis-Antoine Date: Fri, 15 Dec 2017 22:02:34 +0100 Subject: [PATCH 13/27] Return for both players and mobjs if they've got an empty table, instead of just mobjs --- src/lua_script.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/lua_script.c b/src/lua_script.c index fa87f80dc..be6b20032 100644 --- a/src/lua_script.c +++ b/src/lua_script.c @@ -715,11 +715,15 @@ static void ArchiveExtVars(void *pointer, const char *ptype) for (i = 0; lua_next(gL, -2); i++) lua_pop(gL, 1); - if (i == 0 && !fastcmp(ptype,"player")) // skip anything that has an empty table and isn't a player. + // skip anything that has an empty table and isn't a player. + if (i == 0) { + if (fastcmp(ptype,"player")) // always include players even if they have no extra variables + WRITEUINT16(save_p, 0); lua_pop(gL, 1); return; } + if (fastcmp(ptype,"mobj")) // mobjs must write their mobjnum as a header WRITEUINT32(save_p, ((mobj_t *)pointer)->mobjnum); WRITEUINT16(save_p, i); From ec10367856ed53152c50c57aea05fb4e468daa60 Mon Sep 17 00:00:00 2001 From: Monster Iestyn Date: Sun, 17 Dec 2017 20:57:45 +0000 Subject: [PATCH 14/27] Bail out of P_RespawnSpecials if no mobjinfo entry has a doomednum that matches, and print a warning to the console. This prevents a mobj of NUMMOBJTYPES from being created and potentially crashing the game. Really, this happens only if you start messing with the mapthings of respawning items like rings/weapons/etc in the first place via Lua. --- src/p_mobj.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/p_mobj.c b/src/p_mobj.c index 7871d10cd..5f85474c6 100644 --- a/src/p_mobj.c +++ b/src/p_mobj.c @@ -8332,6 +8332,16 @@ void P_RespawnSpecials(void) if (mthing->type == mobjinfo[i].doomednum) break; + if (i == NUMMOBJTYPES) // prevent creation of objects with this type -- Monster Iestyn 17/12/17 + { + // 3D Mode start Thing is unlikely to be added to the que, + // so don't bother checking for that specific type + CONS_Alert(CONS_WARNING, M_GetText("P_RespawnSpecials: Unknown thing type %d attempted to respawn at (%d, %d)\n"), mthing->type, mthing->x, mthing->y); + // pull it from the que + iquetail = (iquetail+1)&(ITEMQUESIZE-1); + return; + } + //CTF rings should continue to respawn as normal rings outside of CTF. if (gametype != GT_CTF) { From c7cd64583dd1bc5327f690f93532c191d813871c Mon Sep 17 00:00:00 2001 From: Monster Iestyn Date: Sun, 17 Dec 2017 20:59:24 +0000 Subject: [PATCH 15/27] Added a bunch of I_Asserts to lua_hooklib.c relating to mobj types just in case --- src/lua_hooklib.c | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/src/lua_hooklib.c b/src/lua_hooklib.c index a24473bad..eadd01537 100644 --- a/src/lua_hooklib.c +++ b/src/lua_hooklib.c @@ -231,6 +231,8 @@ boolean LUAh_MobjHook(mobj_t *mo, enum hook which) if (!gL || !(hooksAvailable[which/8] & (1<<(which%8)))) return false; + I_Assert(mo->type < NUMMOBJTYPES); + lua_settop(gL, 0); // Look for all generic mobj hooks @@ -406,6 +408,8 @@ UINT8 LUAh_MobjCollideHook(mobj_t *thing1, mobj_t *thing2, enum hook which) if (!gL || !(hooksAvailable[which/8] & (1<<(which%8)))) return 0; + I_Assert(thing1->type < NUMMOBJTYPES); + lua_settop(gL, 0); // Look for all generic mobj collision hooks @@ -479,6 +483,8 @@ boolean LUAh_MobjThinker(mobj_t *mo) if (!gL || !(hooksAvailable[hook_MobjThinker/8] & (1<<(hook_MobjThinker%8)))) return false; + I_Assert(mo->type < NUMMOBJTYPES); + lua_settop(gL, 0); // Look for all generic mobj thinker hooks @@ -532,6 +538,8 @@ boolean LUAh_TouchSpecial(mobj_t *special, mobj_t *toucher) if (!gL || !(hooksAvailable[hook_TouchSpecial/8] & (1<<(hook_TouchSpecial%8)))) return 0; + I_Assert(special->type < NUMMOBJTYPES); + lua_settop(gL, 0); // Look for all generic touch special hooks @@ -595,6 +603,8 @@ UINT8 LUAh_ShouldDamage(mobj_t *target, mobj_t *inflictor, mobj_t *source, INT32 if (!gL || !(hooksAvailable[hook_ShouldDamage/8] & (1<<(hook_ShouldDamage%8)))) return 0; + I_Assert(target->type < NUMMOBJTYPES); + lua_settop(gL, 0); // Look for all generic should damage hooks @@ -676,6 +686,8 @@ boolean LUAh_MobjDamage(mobj_t *target, mobj_t *inflictor, mobj_t *source, INT32 if (!gL || !(hooksAvailable[hook_MobjDamage/8] & (1<<(hook_MobjDamage%8)))) return 0; + I_Assert(target->type < NUMMOBJTYPES); + lua_settop(gL, 0); // Look for all generic mobj damage hooks @@ -747,6 +759,8 @@ boolean LUAh_MobjDeath(mobj_t *target, mobj_t *inflictor, mobj_t *source) if (!gL || !(hooksAvailable[hook_MobjDeath/8] & (1<<(hook_MobjDeath%8)))) return 0; + I_Assert(target->type < NUMMOBJTYPES); + lua_settop(gL, 0); // Look for all generic mobj death hooks From c8e9e779e7c3bd4362e97a3f1cc98d7eedd2e923 Mon Sep 17 00:00:00 2001 From: Louis-Antoine Date: Mon, 18 Dec 2017 21:35:02 +0100 Subject: [PATCH 16/27] Add a short comment to explain the newplayernum hack --- src/d_clisrv.c | 51 +++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 50 insertions(+), 1 deletion(-) diff --git a/src/d_clisrv.c b/src/d_clisrv.c index 374cb75f1..88e8da2d6 100644 --- a/src/d_clisrv.c +++ b/src/d_clisrv.c @@ -3121,8 +3121,57 @@ static boolean SV_AddWaitingPlayers(void) newplayer = true; if (netgame) + // !!!!!!!!! EXTREMELY SUPER MEGA GIGA ULTRA ULTIMATELY TERRIBLY IMPORTANT !!!!!!!!! + // + // The line just after that comment is an awful, horrible, terrible, TERRIBLE hack. + // + // Basically, the fix I did in order to fix the download freezes happens + // to cause situations in which a player number does not match + // the node number associated to that player. + // That is totally normal, there is absolutely *nothing* wrong with that. + // Really. Player 7 being tied to node 29, for instance, is totally fine. + // + // HOWEVER. A few (broken) parts of the netcode do the TERRIBLE mistake + // of mixing up the concepts of node and player, resulting in + // incorrect handling of cases where a player is tied to a node that has + // a different number (which is a totally normal case, or at least should be). + // This incorrect handling can go as far as literally + // anyone from joining your server at all, forever. + // + // Given those two facts, there are two options available + // in order to let this download freeze fix be: + // 1) Fix the broken parts that assume a node is a player or similar bullshit. + // 2) Change the part this comment is located at, so that any player who joins + // is given the same number as their associated node. + // + // No need to say, 1) is by far the obvious best, whereas 2) is a terrible hack. + // Unfortunately, after trying 1), I most likely didn't manage to find all + // of those broken parts, and thus 2) has become the only safe option that remains. + // + // So I did this hack. + // + // If it isn't clear enough, in order to get rid of this ugly hack, + // you will have to fix all parts of the netcode that + // make a confusion between nodes and players. + // + // And if it STILL isn't clear enough, a node and a player + // is NOT the same thing. Never. NEVER. *NEVER*. + // + // And if someday you make the terrible mistake of + // daring to have the unforgivable idea to try thinking + // that a node might possibly be the same as a player, + // or that a player should have the same number as its node, + // be sure that I will somehow know about it and + // hunt you down tirelessly and make you regret it, + // even if you live on the other side of the world. + // + // TODO: vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv + // \todo >>>>>>>>>> Remove this horrible hack as soon as possible <<<<<<<<<< + // TODO: ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + // + // !!!!!!!!! EXTREMELY SUPER MEGA GIGA ULTRA ULTIMATELY TERRIBLY IMPORTANT !!!!!!!!! newplayernum = node; // OMFG SAY WELCOME TO TEH NEW HACK FOR FIX FIL DOWNLOAD!!1! - else + else // Don't use the hack if we don't have to // search for a free playernum // we can't use playeringame since it is not updated here for (; newplayernum < MAXPLAYERS; newplayernum++) From d576453b569855cc84ce5e5cdb5354e080ec01f2 Mon Sep 17 00:00:00 2001 From: Monster Iestyn Date: Mon, 18 Dec 2017 21:17:37 +0000 Subject: [PATCH 17/27] Command_Addfile: add "too many files" and already-loaded checks and respective error messages No more shall the server be kicked from their own servers for re-adding a wad by accident! --- src/d_netcmd.c | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/src/d_netcmd.c b/src/d_netcmd.c index 83bbc7aad..2ca48180d 100644 --- a/src/d_netcmd.c +++ b/src/d_netcmd.c @@ -3012,8 +3012,31 @@ static void Command_Addfile(void) if (*p == '\\' || *p == '/' || *p == ':') break; ++p; + // check total packet size and no of files currently loaded + { + size_t packetsize = 0; + serverinfo_pak *dummycheck = NULL; + + // Shut the compiler up. + (void)dummycheck; + + // See W_LoadWadFile in w_wad.c + for (i = 0; i < numwadfiles; i++) + packetsize += nameonlylength(wadfiles[i]->filename) + 22; + + packetsize += nameonlylength(fn) + 22; + + if ((numwadfiles >= MAX_WADFILES) + || (packetsize > sizeof(dummycheck->fileneeded))) + { + CONS_Alert(CONS_ERROR, M_GetText("Too many files loaded to add %s\n"), fn); + return; + } + } + WRITESTRINGN(buf_p,p,240); + // calculate and check md5 { UINT8 md5sum[16]; #ifdef NOMD5 @@ -3031,6 +3054,15 @@ static void Command_Addfile(void) } else // file not found return; + + for (i = 0; i < numwadfiles; i++) + { + if (!memcmp(wadfiles[i]->md5sum, md5sum, 16)) + { + CONS_Alert(CONS_ERROR, M_GetText("%s is already loaded\n"), fn); + return; + } + } #endif WRITEMEM(buf_p, md5sum, 16); } From a1620b709ef803984fac1fb11315f77e7a31d160 Mon Sep 17 00:00:00 2001 From: toasterbabe Date: Mon, 25 Sep 2017 20:35:04 +0100 Subject: [PATCH 18/27] Fix airbob sectors fucking up when below 0 z-height. --- src/p_spec.c | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/src/p_spec.c b/src/p_spec.c index 0418fcd85..c62c3b209 100644 --- a/src/p_spec.c +++ b/src/p_spec.c @@ -5216,13 +5216,11 @@ static void P_AddOldAirbob(sector_t *sec, line_t *sourceline, boolean noadjust) airbob->vars[2] = FRACUNIT; if (noadjust) - { airbob->vars[7] = airbob->sector->ceilingheight-16*FRACUNIT; - airbob->vars[6] = airbob->vars[7] - - (sec->ceilingheight - sec->floorheight); - } else airbob->vars[7] = airbob->sector->ceilingheight - P_AproxDistance(sourceline->dx, sourceline->dy); + airbob->vars[6] = airbob->vars[7] + - (sec->ceilingheight - sec->floorheight); airbob->vars[3] = airbob->vars[2]; From 97af30ae4be2690b07a654d35dd31702dc40bbac Mon Sep 17 00:00:00 2001 From: Alam Arias Date: Mon, 25 Dec 2017 00:41:05 -0500 Subject: [PATCH 19/27] SRB2: disable Smaller Type Check for MSVC --- SRB2_Debug.props | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/SRB2_Debug.props b/SRB2_Debug.props index 2c16f7cb6..8be11c58a 100644 --- a/SRB2_Debug.props +++ b/SRB2_Debug.props @@ -17,7 +17,7 @@ MultiThreadedDebugDLL true All - true + false EnableFastChecks From e2b604fdfd4bf92cf06837662d10c0cc2b485bc4 Mon Sep 17 00:00:00 2001 From: Alam Ed Arias Date: Tue, 26 Dec 2017 19:56:50 -0500 Subject: [PATCH 20/27] TCP: remove BADSOCKET --- src/i_tcp.c | 21 +++++++-------- src/mserv.c | 64 +++++++++++++++++++++----------------------- src/win32/win_main.c | 4 +-- src/win32/win_sys.c | 8 +++--- src/win32/win_vid.c | 1 + 5 files changed, 47 insertions(+), 51 deletions(-) diff --git a/src/i_tcp.c b/src/i_tcp.c index 3d55236ec..6488e9845 100644 --- a/src/i_tcp.c +++ b/src/i_tcp.c @@ -215,7 +215,6 @@ static UINT8 UPNP_support = TRUE; #if defined (USE_WINSOCK) && !defined (NONET) typedef SOCKET SOCKET_TYPE; -#define BADSOCKET INVALID_SOCKET #define ERRSOCKET (SOCKET_ERROR) #else #if (defined (__unix__) && !defined (MSDOS)) || defined (__APPLE__) || defined (__HAIKU__) || defined(_PS3) @@ -223,7 +222,6 @@ typedef int SOCKET_TYPE; #else typedef unsigned long SOCKET_TYPE; #endif -#define BADSOCKET (SOCKET_TYPE)(~0) #define ERRSOCKET (-1) #endif @@ -232,10 +230,10 @@ typedef int socklen_t; #endif #ifndef NONET -static SOCKET_TYPE mysockets[MAXNETNODES+1] = {BADSOCKET}; +static SOCKET_TYPE mysockets[MAXNETNODES+1] = {ERRSOCKET}; static size_t mysocketses = 0; static int myfamily[MAXNETNODES+1] = {0}; -static SOCKET_TYPE nodesocket[MAXNETNODES+1] = {BADSOCKET}; +static SOCKET_TYPE nodesocket[MAXNETNODES+1] = {ERRSOCKET}; static mysockaddr_t clientaddress[MAXNETNODES+1]; static mysockaddr_t broadcastaddress[MAXNETNODES+1]; static size_t broadcastaddresses = 0; @@ -647,7 +645,7 @@ static boolean FD_CPY(fd_set *src, fd_set *dst, SOCKET_TYPE *fd, size_t len) FD_ZERO(dst); for (i = 0; i < len;i++) { - if(fd[i] != BADSOCKET && fd[i] != (SOCKET_TYPE)ERRSOCKET && + if(fd[i] != (SOCKET_TYPE)ERRSOCKET && FD_ISSET(fd[i], src) && !FD_ISSET(fd[i], dst)) // no checking for dups { FD_SET(fd[i], dst); @@ -725,7 +723,7 @@ static void SOCK_Send(void) } return; } - else if (nodesocket[doomcom->remotenode] == BADSOCKET) + else if (nodesocket[doomcom->remotenode] == (SOCKET_TYPE)ERRSOCKET) { for (i = 0; i < mysocketses; i++) { @@ -777,7 +775,7 @@ static void SOCK_FreeNodenum(INT32 numnode) DEBFILE(va("Free node %d (%s)\n", numnode, SOCK_GetNodeAddress(numnode))); nodeconnected[numnode] = false; - nodesocket[numnode] = BADSOCKET; + nodesocket[numnode] = ERRSOCKET; // put invalid address memset(&clientaddress[numnode], 0, sizeof (clientaddress[numnode])); @@ -804,7 +802,7 @@ static SOCKET_TYPE UDP_Bind(int family, struct sockaddr *addr, socklen_t addrlen #endif mysockaddr_t straddr; - if (s == (SOCKET_TYPE)ERRSOCKET || s == BADSOCKET) + if (s == (SOCKET_TYPE)ERRSOCKET) return (SOCKET_TYPE)ERRSOCKET; #ifdef USE_WINSOCK { // Alam_GBC: disable the new UDP connection reset behavior for Win2k and up @@ -911,9 +909,9 @@ static boolean UDP_Socket(void) for (s = 0; s < mysocketses; s++) - mysockets[s] = BADSOCKET; + mysockets[s] = ERRSOCKET; for (s = 0; s < MAXNETNODES+1; s++) - nodesocket[s] = BADSOCKET; + nodesocket[s] = ERRSOCKET; FD_ZERO(&masterset); s = 0; @@ -1250,7 +1248,6 @@ static void SOCK_CloseSocket(void) for (i=0; i < MAXNETNODES+1; i++) { if (mysockets[i] != (SOCKET_TYPE)ERRSOCKET - && mysockets[i] != BADSOCKET && FD_ISSET(mysockets[i], &masterset)) { #if !defined (__DJGPP__) || defined (WATTCP) @@ -1258,7 +1255,7 @@ static void SOCK_CloseSocket(void) close(mysockets[i]); #endif } - mysockets[i] = BADSOCKET; + mysockets[i] = ERRSOCKET; } } #endif diff --git a/src/mserv.c b/src/mserv.c index 76fba835b..2bb2923d7 100644 --- a/src/mserv.c +++ b/src/mserv.c @@ -102,35 +102,35 @@ #define PACKET_SIZE 1024 -#define MS_NO_ERROR 0 -#define MS_SOCKET_ERROR -201 -#define MS_CONNECT_ERROR -203 -#define MS_WRITE_ERROR -210 -#define MS_READ_ERROR -211 -#define MS_CLOSE_ERROR -212 -#define MS_GETHOSTBYNAME_ERROR -220 -#define MS_GETHOSTNAME_ERROR -221 -#define MS_TIMEOUT_ERROR -231 +#define MS_NO_ERROR 0 +#define MS_SOCKET_ERROR -201 +#define MS_CONNECT_ERROR -203 +#define MS_WRITE_ERROR -210 +#define MS_READ_ERROR -211 +#define MS_CLOSE_ERROR -212 +#define MS_GETHOSTBYNAME_ERROR -220 +#define MS_GETHOSTNAME_ERROR -221 +#define MS_TIMEOUT_ERROR -231 // see master server code for the values -#define ADD_SERVER_MSG 101 -#define REMOVE_SERVER_MSG 103 -#define ADD_SERVERv2_MSG 104 -#define GET_SERVER_MSG 200 -#define GET_SHORT_SERVER_MSG 205 -#define ASK_SERVER_MSG 206 -#define ANSWER_ASK_SERVER_MSG 207 -#define ASK_SERVER_MSG 206 -#define ANSWER_ASK_SERVER_MSG 207 -#define GET_MOTD_MSG 208 -#define SEND_MOTD_MSG 209 -#define GET_ROOMS_MSG 210 -#define SEND_ROOMS_MSG 211 -#define GET_ROOMS_HOST_MSG 212 -#define GET_VERSION_MSG 213 -#define SEND_VERSION_MSG 214 -#define GET_BANNED_MSG 215 // Someone's been baaaaaad! -#define PING_SERVER_MSG 216 +#define ADD_SERVER_MSG 101 +#define REMOVE_SERVER_MSG 103 +#define ADD_SERVERv2_MSG 104 +#define GET_SERVER_MSG 200 +#define GET_SHORT_SERVER_MSG 205 +#define ASK_SERVER_MSG 206 +#define ANSWER_ASK_SERVER_MSG 207 +#define ASK_SERVER_MSG 206 +#define ANSWER_ASK_SERVER_MSG 207 +#define GET_MOTD_MSG 208 +#define SEND_MOTD_MSG 209 +#define GET_ROOMS_MSG 210 +#define SEND_ROOMS_MSG 211 +#define GET_ROOMS_HOST_MSG 212 +#define GET_VERSION_MSG 213 +#define SEND_VERSION_MSG 214 +#define GET_BANNED_MSG 215 // Someone's been baaaaaad! +#define PING_SERVER_MSG 216 #define HEADER_SIZE (sizeof (INT32)*4) @@ -217,7 +217,6 @@ UINT16 current_port = 0; #if (defined (_WIN32) || defined (_WIN32_WCE) || defined (_WIN32)) && !defined (NONET) typedef SOCKET SOCKET_TYPE; -#define BADSOCKET INVALID_SOCKET #define ERRSOCKET (SOCKET_ERROR) #else #if (defined (__unix__) && !defined (MSDOS)) || defined (__APPLE__) || defined (__HAIKU__) || defined (_PS3) @@ -225,7 +224,6 @@ typedef int SOCKET_TYPE; #else typedef unsigned long SOCKET_TYPE; #endif -#define BADSOCKET (SOCKET_TYPE)(~0) #define ERRSOCKET (-1) #endif @@ -234,7 +232,7 @@ typedef int socklen_t; #endif #ifndef NONET -static SOCKET_TYPE socket_fd = BADSOCKET; // WINSOCK socket +static SOCKET_TYPE socket_fd = ERRSOCKET; // WINSOCK socket static struct timeval select_timeout; static fd_set wset; static size_t recvfull(SOCKET_TYPE s, char *buf, size_t len, int flags); @@ -265,9 +263,9 @@ void AddMServCommands(void) static void CloseConnection(void) { #ifndef NONET - if (socket_fd != (SOCKET_TYPE)ERRSOCKET && socket_fd != BADSOCKET) + if (socket_fd != (SOCKET_TYPE)ERRSOCKET) close(socket_fd); - socket_fd = BADSOCKET; + socket_fd = ERRSOCKET; #endif } @@ -385,7 +383,7 @@ static INT32 MS_Connect(const char *ip_addr, const char *str_port, INT32 async) while (runp != NULL) { socket_fd = socket(runp->ai_family, runp->ai_socktype, runp->ai_protocol); - if (socket_fd != BADSOCKET && socket_fd != (SOCKET_TYPE)ERRSOCKET) + if (socket_fd != (SOCKET_TYPE)ERRSOCKET) { if (async) // do asynchronous connection { diff --git a/src/win32/win_main.c b/src/win32/win_main.c index 4ac05f94f..4bb3df868 100644 --- a/src/win32/win_main.c +++ b/src/win32/win_main.c @@ -244,7 +244,7 @@ static LRESULT CALLBACK MainWndproc(HWND hWnd, UINT message, WPARAM wParam, LPAR D_PostEvent(&ev); return TRUE; } - + break; case WM_XBUTTONDOWN: if (nodinput) { @@ -253,7 +253,7 @@ static LRESULT CALLBACK MainWndproc(HWND hWnd, UINT message, WPARAM wParam, LPAR D_PostEvent(&ev); return TRUE; } - + break; case WM_MOUSEWHEEL: //I_OutputMsg("MW_WHEEL dispatched.\n"); ev.type = ev_keydown; diff --git a/src/win32/win_sys.c b/src/win32/win_sys.c index 80b89a6e6..316da61d4 100644 --- a/src/win32/win_sys.c +++ b/src/win32/win_sys.c @@ -2581,7 +2581,7 @@ acquire: UINT64 newbuttons = joybuttons ^ lastjoybuttons; lastjoybuttons = joybuttons; - for (i = 0; i < JOYBUTTONS && i < JOYBUTTONS_MAX; i++, j <<= 1) + for (i = 0; i < JOYBUTTONS_MIN; i++, j <<= 1) { if (newbuttons & j) // button changed state? { @@ -2601,7 +2601,7 @@ acquire: UINT64 newhats = joyhats ^ lastjoyhats; lastjoyhats = joyhats; - for (i = 0; i < JOYHATS*4 && i < JOYHATS_MAX*4; i++, j <<= 1) + for (i = 0; i < JOYHATS_MIN*4; i++, j <<= 1) { if (newhats & j) // button changed state? { @@ -2825,7 +2825,7 @@ acquire: UINT64 newbuttons = joybuttons ^ lastjoy2buttons; lastjoy2buttons = joybuttons; - for (i = 0; i < JOYBUTTONS && i < JOYBUTTONS_MAX; i++, j <<= 1) + for (i = 0; i < JOYBUTTONS_MIN; i++, j <<= 1) { if (newbuttons & j) // button changed state? { @@ -2845,7 +2845,7 @@ acquire: UINT64 newhats = joyhats ^ lastjoy2hats; lastjoy2hats = joyhats; - for (i = 0; i < JOYHATS*4 && i < JOYHATS_MAX*4; i++, j <<= 1) + for (i = 0; i < JOYHATS_MIN*4; i++, j <<= 1) { if (newhats & j) // button changed state? { diff --git a/src/win32/win_vid.c b/src/win32/win_vid.c index 0960bb6dd..a9dd097b3 100644 --- a/src/win32/win_vid.c +++ b/src/win32/win_vid.c @@ -322,6 +322,7 @@ static inline boolean I_SkipFrame(void) case GS_LEVEL: if (!paused) return false; + /* FALLTHRU */ case GS_TIMEATTACK: #ifndef CLIENT_LOADINGSCREEN case GS_WAITINGPLAYERS: From a29203acd8059d2428c1a2c414815a66a1d48b37 Mon Sep 17 00:00:00 2001 From: Alam Ed Arias Date: Tue, 26 Dec 2017 20:24:08 -0500 Subject: [PATCH 21/27] Disable win_dbg --- src/sdl/i_main.c | 2 ++ src/win32/Makefile.cfg | 2 +- src/win32/win_main.c | 2 ++ 3 files changed, 5 insertions(+), 1 deletion(-) diff --git a/src/sdl/i_main.c b/src/sdl/i_main.c index f1cecad4d..65b7b5ffe 100644 --- a/src/sdl/i_main.c +++ b/src/sdl/i_main.c @@ -148,7 +148,9 @@ int main(int argc, char **argv) LoadLibraryA("exchndl.dll"); } } +#ifndef __MINGW32__ prevExceptionFilter = SetUnhandledExceptionFilter(RecordExceptionInfo); +#endif MakeCodeWritable(); #endif // startup SRB2 diff --git a/src/win32/Makefile.cfg b/src/win32/Makefile.cfg index 99b8bc9b2..3560af0c4 100644 --- a/src/win32/Makefile.cfg +++ b/src/win32/Makefile.cfg @@ -64,7 +64,7 @@ endif ifdef SDL i_system_o+=$(OBJDIR)/SRB2.res - i_main_o+=$(OBJDIR)/win_dbg.o + #i_main_o+=$(OBJDIR)/win_dbg.o ifndef NOHW OPTS+=-DUSE_WGL_SWAP endif diff --git a/src/win32/win_main.c b/src/win32/win_main.c index 4bb3df868..6c774f557 100644 --- a/src/win32/win_main.c +++ b/src/win32/win_main.c @@ -666,7 +666,9 @@ int WINAPI WinMain (HINSTANCE hInstance, #endif LoadLibraryA("exchndl.dll"); +#ifndef __MINGW32__ prevExceptionFilter = SetUnhandledExceptionFilter(RecordExceptionInfo); +#endif Result = HandledWinMain(hInstance); #ifdef BUGTRAP From f397b5fc3ff5395fc84c1aaa2fc2841d1092c131 Mon Sep 17 00:00:00 2001 From: Alam Ed Arias Date: Tue, 26 Dec 2017 20:42:37 -0500 Subject: [PATCH 22/27] Makefile: disable win_dbg for DirectDraw --- src/win32/Makefile.cfg | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/win32/Makefile.cfg b/src/win32/Makefile.cfg index 3560af0c4..749734a72 100644 --- a/src/win32/Makefile.cfg +++ b/src/win32/Makefile.cfg @@ -81,7 +81,8 @@ endif i_net_o=$(OBJDIR)/win_net.o i_system_o=$(OBJDIR)/win_sys.o $(OBJDIR)/SRB2.res i_sound_o=$(OBJDIR)/win_snd.o - i_main_o=$(OBJDIR)/win_dbg.o $(OBJDIR)/win_main.o + i_main_o=$(OBJDIR)/win_main.o + #i_main_o+=$(OBJDIR)/win_dbg.o OBJS=$(OBJDIR)/dx_error.o $(OBJDIR)/fabdxlib.o $(OBJDIR)/win_vid.o $(OBJDIR)/win_dll.o endif From 38561656233229536fb5bf8e5488191e470c495e Mon Sep 17 00:00:00 2001 From: Steel Titanium Date: Wed, 27 Dec 2017 13:18:20 -0500 Subject: [PATCH 23/27] Indentation cleanup --- src/d_netcmd.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/d_netcmd.c b/src/d_netcmd.c index 041cb134b..2abba77ac 100644 --- a/src/d_netcmd.c +++ b/src/d_netcmd.c @@ -3914,23 +3914,23 @@ static void Command_Tunes_f(void) static void Command_RestartAudio_f(void) { - if (dedicated) { // No point in doing anything if game is a dedicated server. + if (dedicated) // No point in doing anything if game is a dedicated server. return; -} + S_StopMusic(); I_ShutdownMusic(); I_ShutdownSound(); I_StartupSound(); I_InitMusic(); -// These must be called or no sound and music untill manually set. +// These must be called or no sound and music until manually set. I_SetSfxVolume(cv_soundvolume.value); I_SetDigMusicVolume(cv_digmusicvolume.value); I_SetMIDIMusicVolume(cv_midimusicvolume.value); - if (Playing() && (!dedicated)) { // Gotta make sure the player is in a level + if (Playing() && (!dedicated)) // Gotta make sure the player is in a level P_RestoreMusic(&players[consoleplayer]); - } + } /** Quits a game and returns to the title screen. From 875446295b6abdd60731bb46be546cab413513c2 Mon Sep 17 00:00:00 2001 From: Steel Titanium Date: Wed, 27 Dec 2017 16:36:57 -0500 Subject: [PATCH 24/27] Remove redundant !dedicated check --- src/d_netcmd.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/d_netcmd.c b/src/d_netcmd.c index 2abba77ac..43b933cfc 100644 --- a/src/d_netcmd.c +++ b/src/d_netcmd.c @@ -3928,7 +3928,7 @@ static void Command_RestartAudio_f(void) I_SetSfxVolume(cv_soundvolume.value); I_SetDigMusicVolume(cv_digmusicvolume.value); I_SetMIDIMusicVolume(cv_midimusicvolume.value); - if (Playing() && (!dedicated)) // Gotta make sure the player is in a level + if (Playing()) // Gotta make sure the player is in a level P_RestoreMusic(&players[consoleplayer]); } From f6479894333a0521a08e5e5c9f4930f05f0142b9 Mon Sep 17 00:00:00 2001 From: Alam Ed Arias Date: Wed, 27 Dec 2017 19:32:38 -0500 Subject: [PATCH 25/27] MSVC: set SubSystem on DLLs to Windows --- src/hardware/r_opengl/r_opengl-vc10.vcxproj | 4 ++++ src/hardware/s_openal/s_openal-vc10.vcxproj | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/src/hardware/r_opengl/r_opengl-vc10.vcxproj b/src/hardware/r_opengl/r_opengl-vc10.vcxproj index 43da2a3ee..f04ae320b 100644 --- a/src/hardware/r_opengl/r_opengl-vc10.vcxproj +++ b/src/hardware/r_opengl/r_opengl-vc10.vcxproj @@ -122,6 +122,7 @@ $(IntDir)r_opengl.lib MachineX86 + Windows true @@ -166,6 +167,7 @@ $(IntDir)r_opengl.lib MachineX64 + Windows true @@ -212,6 +214,7 @@ $(IntDir)r_opengl.lib MachineX86 + Windows true @@ -258,6 +261,7 @@ $(IntDir)r_opengl.lib MachineX64 + Windows true diff --git a/src/hardware/s_openal/s_openal-vc10.vcxproj b/src/hardware/s_openal/s_openal-vc10.vcxproj index 67d2d95ac..8b4f6cbbe 100644 --- a/src/hardware/s_openal/s_openal-vc10.vcxproj +++ b/src/hardware/s_openal/s_openal-vc10.vcxproj @@ -125,6 +125,7 @@ $(IntDir)s_openal.lib MachineX86 + Windows true @@ -170,6 +171,7 @@ $(IntDir)s_openal.lib MachineX64 + Windows true @@ -216,6 +218,7 @@ $(IntDir)s_openal.lib MachineX86 + Windows true @@ -262,6 +265,7 @@ $(IntDir)s_openal.lib MachineX64 + Windows true From 98d6619c36a250b85e97297811ce78e892fb8b98 Mon Sep 17 00:00:00 2001 From: Alam Ed Arias Date: Wed, 27 Dec 2017 19:32:59 -0500 Subject: [PATCH 26/27] GIT: ignore .vs folder --- .gitignore | 1 + 1 file changed, 1 insertion(+) diff --git a/.gitignore b/.gitignore index 7b2304ec0..922fac4aa 100644 --- a/.gitignore +++ b/.gitignore @@ -18,3 +18,4 @@ Win32_LIB_ASM_Release *.user *.db *.opendb +/.vs From 75abd428fc1b6524c540ae9392cc9b0d2086756f Mon Sep 17 00:00:00 2001 From: Alam Ed Arias Date: Tue, 2 Jan 2018 13:22:10 -0500 Subject: [PATCH 27/27] MSVC2015: fixup --- src/lua_hudlib.c | 2 +- src/lua_infolib.c | 6 +++--- src/m_menu.c | 5 ++++- src/sdl/Srb2SDL-vc10.vcxproj | 2 ++ src/sdl/Srb2SDL-vc10.vcxproj.filters | 6 ++++++ src/w_wad.c | 3 ++- src/win32/Srb2win-vc10.vcxproj | 2 ++ src/win32/Srb2win-vc10.vcxproj.filters | 6 ++++++ 8 files changed, 26 insertions(+), 6 deletions(-) diff --git a/src/lua_hudlib.c b/src/lua_hudlib.c index 68a69cd1d..7d0f535fb 100644 --- a/src/lua_hudlib.c +++ b/src/lua_hudlib.c @@ -407,7 +407,7 @@ static int libd_getSpritePatch(lua_State *L) static int libd_getSprite2Patch(lua_State *L) { INT32 i; // skin number - UINT32 j; // sprite2 prefix + INT32 j; // sprite2 prefix UINT32 frame = 0; // 'A' UINT8 angle = 0; spritedef_t *sprdef; diff --git a/src/lua_infolib.c b/src/lua_infolib.c index 8f2ce67cd..3f5bdc53b 100644 --- a/src/lua_infolib.c +++ b/src/lua_infolib.c @@ -102,7 +102,7 @@ static int lib_sprnamelen(lua_State *L) // push sprite name static int lib_getSpr2name(lua_State *L) { - UINT32 i; + INT32 i; lua_remove(L, 1); // don't care about spr2names[] dummy userdata. @@ -129,7 +129,7 @@ static int lib_getSpr2name(lua_State *L) static int lib_getSpr2default(lua_State *L) { - UINT32 i; + INT32 i; lua_remove(L, 1); // don't care about spr2defaults[] dummy userdata. @@ -154,7 +154,7 @@ static int lib_getSpr2default(lua_State *L) static int lib_setSpr2default(lua_State *L) { - UINT32 i; + INT32 i; UINT8 j = 0; lua_remove(L, 1); // don't care about spr2defaults[] dummy userdata. diff --git a/src/m_menu.c b/src/m_menu.c index dedbd86f0..44386b34a 100644 --- a/src/m_menu.c +++ b/src/m_menu.c @@ -4964,7 +4964,10 @@ static void M_DrawAddons(void) // hack - need to refresh at end of frame to handle addfile... if (refreshdirmenu & M_AddonsRefresh()) - return M_DrawMessageMenu(); + { + M_DrawMessageMenu(); + return; + } if (addonsresponselimit) addonsresponselimit--; diff --git a/src/sdl/Srb2SDL-vc10.vcxproj b/src/sdl/Srb2SDL-vc10.vcxproj index abf6d76d2..00ed0db39 100644 --- a/src/sdl/Srb2SDL-vc10.vcxproj +++ b/src/sdl/Srb2SDL-vc10.vcxproj @@ -141,6 +141,7 @@ + @@ -282,6 +283,7 @@ + diff --git a/src/sdl/Srb2SDL-vc10.vcxproj.filters b/src/sdl/Srb2SDL-vc10.vcxproj.filters index bdb029cf9..1d132faf0 100644 --- a/src/sdl/Srb2SDL-vc10.vcxproj.filters +++ b/src/sdl/Srb2SDL-vc10.vcxproj.filters @@ -444,6 +444,9 @@ SDLApp + + Hw_Hardware + @@ -879,6 +882,9 @@ SDLApp + + Hw_Hardware + diff --git a/src/w_wad.c b/src/w_wad.c index 75bf40983..f25711e4e 100644 --- a/src/w_wad.c +++ b/src/w_wad.c @@ -448,7 +448,7 @@ UINT16 W_InitFile(const char *filename) // We must look for the central directory through the file. (Thanks to JTE for this algorithm.) // All of the central directory entry headers have a signature of 0x50 0x4b 0x01 0x02. // The first entry found means the beginning of the central directory. - fseek(handle, -min(size, (22 + 65536)), SEEK_CUR); + fseek(handle, 0-min(size, (22 + 65536)), SEEK_CUR); s = endPat; while((c = fgetc(handle)) != EOF) { @@ -1198,6 +1198,7 @@ size_t W_ReadLumpHeaderPwad(UINT16 wad, UINT16 lump, void *dest, size_t size, si default: I_Error("wad %d, lump %d: unsupported compression type!", wad, lump); } + return 0; } size_t W_ReadLumpHeader(lumpnum_t lumpnum, void *dest, size_t size, size_t offset) diff --git a/src/win32/Srb2win-vc10.vcxproj b/src/win32/Srb2win-vc10.vcxproj index 95f9c85f9..ed6b46b8f 100644 --- a/src/win32/Srb2win-vc10.vcxproj +++ b/src/win32/Srb2win-vc10.vcxproj @@ -119,6 +119,7 @@ + @@ -276,6 +277,7 @@ + diff --git a/src/win32/Srb2win-vc10.vcxproj.filters b/src/win32/Srb2win-vc10.vcxproj.filters index cfd46f1f8..6319749a9 100644 --- a/src/win32/Srb2win-vc10.vcxproj.filters +++ b/src/win32/Srb2win-vc10.vcxproj.filters @@ -450,6 +450,9 @@ M_Misc + + Hw_Hardware + @@ -845,6 +848,9 @@ O_Other + + Hw_Hardware +