# HG changeset patch # User Adam Kaminski # Date 1608524623 18000 # Sun Dec 20 23:23:43 2020 -0500 # Node ID a9da0c5f89906f3851c03db8b73a43deb9af45b7 # Parent 043cc8c7ec642dd2a40a9b37c6aecac2fc2caedb Fixed the StopSound ACS function not working in online games. diff -r 043cc8c7ec64 -r a9da0c5f8990 docs/zandronum-history.txt --- a/docs/zandronum-history.txt Fri Dec 18 21:15:16 2020 -0500 +++ b/docs/zandronum-history.txt Sun Dec 20 23:23:43 2020 -0500 @@ -49,6 +49,7 @@ - - Fixed missiles with the STEPMISSILE flag disappearing in online games. [Kaminsky] - - Fixed faulty armor behaviour that occurred when the player's inventory was cleared. [Kaminsky] - - Fixed sound channels containing looped sounds not being synced with newly connected clients. [Kaminsky] +- - Fixed the StopSound ACS function not working in online games. [Kaminsky] ! - sv_forcegldefaults renamed to sv_forcevideodefaults. The old name still exists for compatibility. [Dusk] ! - r_3dfloors is now forced to be true when sv_forcevideodefaults is true. [Dusk] ! - When the wad authentication fails for a connecting client, the client only reports the missing and incompatible PWADS instead of all of them. [Pol Marcet] diff -r 043cc8c7ec64 -r a9da0c5f8990 protocolspec/spec.sounds.txt --- a/protocolspec/spec.sounds.txt Fri Dec 18 21:15:16 2020 -0500 +++ b/protocolspec/spec.sounds.txt Sun Dec 20 23:23:43 2020 -0500 @@ -38,3 +38,9 @@ Command AnnouncerSound String sound EndCommand + +Command StopSound + ExtendedCommand + Actor actor + Short channel +EndCommand diff -r 043cc8c7ec64 -r a9da0c5f8990 src/cl_main.cpp --- a/src/cl_main.cpp Fri Dec 18 21:15:16 2020 -0500 +++ b/src/cl_main.cpp Sun Dec 20 23:23:43 2020 -0500 @@ -6770,6 +6770,13 @@ //***************************************************************************** // +void ServerCommands::StopSound::Execute() +{ + S_StopSound( actor, channel ); +} + +//***************************************************************************** +// void ServerCommands::StartSectorSequence::Execute() { SN_StartSequence( sector, channel, sequence.GetChars(), modeNum ); diff -r 043cc8c7ec64 -r a9da0c5f8990 src/network_enums.h --- a/src/network_enums.h Fri Dec 18 21:15:16 2020 -0500 +++ b/src/network_enums.h Sun Dec 20 23:23:43 2020 -0500 @@ -371,6 +371,7 @@ ENUM_ELEMENT ( SVC2_SETMAPSKYSCROLLSPEED ), ENUM_ELEMENT ( SVC2_SETLOCALPLAYERJUMPTICS ), ENUM_ELEMENT ( SVC2_SETPLAYERDEATHS ), + ENUM_ELEMENT ( SVC2_STOPSOUND ), // [BB] Commands necessary for the account system. ENUM_ELEMENT ( SVC2_SRP_USER_START_AUTHENTICATION ), ENUM_ELEMENT ( SVC2_SRP_USER_PROCESS_CHALLENGE ), diff -r 043cc8c7ec64 -r a9da0c5f8990 src/p_acs.cpp --- a/src/p_acs.cpp Fri Dec 18 21:15:16 2020 -0500 +++ b/src/p_acs.cpp Sun Dec 20 23:23:43 2020 -0500 @@ -6206,8 +6206,12 @@ S_StopSound(activator, chan); // [AK] If we're the server, remove this channel from the list of looping channels. + // Also tell the clients to stop playing the sound in this channel. if ( NETWORK_GetState() == NETSTATE_SERVER ) + { + SERVERCOMMANDS_StopSound( activator, chan ); SERVER_UpdateLoopingChannels( activator, chan, 0, 0, 0, true ); + } } else { @@ -6219,8 +6223,12 @@ S_StopSound(spot, chan); // [AK] If we're the server, remove this channel from the list of looping channels. + // Also tell the clients to stop playing the sound in this channel. if ( NETWORK_GetState() == NETSTATE_SERVER ) + { + SERVERCOMMANDS_StopSound( spot, chan ); SERVER_UpdateLoopingChannels( spot, chan, 0, 0, 0, true ); + } } } } diff -r 043cc8c7ec64 -r a9da0c5f8990 src/sv_commands.cpp --- a/src/sv_commands.cpp Fri Dec 18 21:15:16 2020 -0500 +++ b/src/sv_commands.cpp Sun Dec 20 23:23:43 2020 -0500 @@ -3212,6 +3212,20 @@ } //***************************************************************************** +// +void SERVERCOMMANDS_StopSound( AActor *pActor, LONG lChannel, ULONG ulPlayerExtra, ServerCommandFlags flags ) +{ + // [AK] The actor must have a NetID so we can tell clients to stop the sound on their channel. + if ( EnsureActorHasNetID( pActor ) == false ) + return; + + ServerCommands::StopSound command; + command.SetActor( pActor ); + command.SetChannel( lChannel ); + command.sendCommandToClients( ulPlayerExtra, flags ); +} + +//***************************************************************************** //***************************************************************************** // void SERVERCOMMANDS_StartSectorSequence( sector_t *pSector, const int Channel, const char *pszSequence, const int Modenum, ULONG ulPlayerExtra, ServerCommandFlags flags ) diff -r 043cc8c7ec64 -r a9da0c5f8990 src/sv_commands.h --- a/src/sv_commands.h Fri Dec 18 21:15:16 2020 -0500 +++ b/src/sv_commands.h Sun Dec 20 23:23:43 2020 -0500 @@ -313,6 +313,7 @@ void SERVERCOMMANDS_SoundSector( sector_t *sector, int channel, const char *sound, float volume, float attenuation, ULONG ulPlayerExtra = MAXPLAYERS, ServerCommandFlags flags = 0 ); void SERVERCOMMANDS_SoundPoint( LONG lX, LONG lY, LONG lZ, LONG lChannel, const char *pszSound, float fVolume, float fAttenuation, ULONG ulPlayerExtra = MAXPLAYERS, ServerCommandFlags flags = 0 ); void SERVERCOMMANDS_AnnouncerSound( const char *pszSound, ULONG ulPlayerExtra = MAXPLAYERS, ServerCommandFlags flags = 0 ); +void SERVERCOMMANDS_StopSound( AActor *pActor, LONG lChannel, ULONG ulPlayerExtra = MAXPLAYERS, ServerCommandFlags flags = 0 ); // Sector sequence commands. These handle sector sound sequences. void SERVERCOMMANDS_StartSectorSequence( sector_t *pSector, const int Channel, const char *pszSequence, const int Modenum, ULONG ulPlayerExtra = MAXPLAYERS, ServerCommandFlags flags = 0 );