Bug fixes for Killing Floor
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

93 lines
3.3 KiB

/**
* This feature fixes different instances of log spam by the killing floor
* with various warnings and errors. Some of them have actual underlying bugs
* that need to be fixed, but a lot seem to be just a byproduct of dead and
* abandoned features or simple negligence.
* Whatever the case, now that TWI will no longer make any new changes to
* the game a lot of them do not serve any purpose and simply pollute
* log files. We try to get rid of at least some of them.
* Since changes we make do not actually have gameplay effect and
* are more aimed at convenience of server owners, our philosophy with the
* changes will be to avoid solutions that are way too "hacky" and prefer some
* message spam getting through to the possibility of some unexpected gameplay
* effects as far as vanilla game is concerned.
* Copyright 2021 Anton Tarasenko
*------------------------------------------------------------------------------
* This file is part of Acedia.
*
* Acedia 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, version 3 of the License, or
* (at your option) any later version.
*
* Acedia 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.
*
* You should have received a copy of the GNU General Public License
* along with Acedia. If not, see <https://www.gnu.org/licenses/>.
*/
class FixLogSpam_Feature extends Feature;
// This is responsible for fixing log spam due to picking up dropped
// weapons without set `inventory` variable.
var private /*config*/ bool fixPickupSpam;
var private HelperPickup helperPickupSpam;
var private /*config*/ bool fixTraderSpam;
var private HelperTrader helperTraderSpam;
protected function OnEnabled()
{
if (fixPickupSpam) {
helperPickupSpam = HelperPickup(_.memory.Allocate(class'HelperPickup'));
}
if (fixTraderSpam) {
helperTraderSpam = HelperTrader(_.memory.Allocate(class'HelperTrader'));
}
}
protected function OnDisabled()
{
_.memory.Free(helperPickupSpam);
helperPickupSpam = none;
_.memory.Free(helperTraderSpam);
helperTraderSpam = none;
}
protected function SwapConfig(FeatureConfig config)
{
local FixLogSpam newConfig;
newConfig = FixLogSpam(config);
if (newConfig == none) {
return;
}
// Pickup spam
fixPickupSpam = newConfig.fixPickupSpam;
if (fixPickupSpam && helperPickupSpam == none) {
helperPickupSpam = HelperPickup(_.memory.Allocate(class'HelperPickup'));
}
if (!fixPickupSpam && helperPickupSpam != none)
{
_.memory.Free(helperPickupSpam);
helperPickupSpam = none;
}
// Trader fixTraderSpam
fixTraderSpam = newConfig.fixTraderSpam;
if (fixTraderSpam && helperTraderSpam == none) {
helperTraderSpam = HelperTrader(_.memory.Allocate(class'HelperPickup'));
}
if (!fixTraderSpam && helperTraderSpam != none)
{
_.memory.Free(helperTraderSpam);
helperTraderSpam = none;
}
}
defaultproperties
{
configClass = class'FixLogSpam'
fixPickupSpam = true
fixTraderSpam = true
}