/* DMS_fnc_selectMission Influenced by WAI Created by eraser1 Selects/Spawns missions. Takes no arguments, returns nothing. */ private "_time"; _time = diag_tickTime; if (DMS_RunningBMissionCount >= DMS_MaxBanditMissions) then { DMS_BMissionLastStart = _time; }; if ((count DMS_RunningStaticMissions) >= DMS_MaxStaticMissions) then { DMS_StaticMissionLastStart = _time; }; if (diag_fps >= DMS_MinServerFPS && {(count allPlayers) >= DMS_MinPlayerCount}) then { if (DMS_DynamicMission && {_time - DMS_BMissionLastStart > DMS_BMissionDelay}) then { private "_mission"; _mission = DMS_BanditMissionTypesArray call BIS_fnc_selectRandom; if (DMS_DEBUG) then { (format ["SelectMission :: Selected bandit mission: %1",_mission]) call DMS_fnc_DebugLog; }; [_mission] call DMS_fnc_SpawnBanditMission; if (DMS_DEBUG) then { (format ["SelectMission :: Spawning of bandit mission ""%1"" complete!",_mission]) call DMS_fnc_DebugLog; }; }; if (DMS_StaticMission && {_time - DMS_StaticMissionLastStart > DMS_StaticMissionDelay}) then { private ["_mission", "_availableMissions"]; _availableMissions = (DMS_StaticMissionTypesArray - DMS_RunningStaticMissions); if (_availableMissions isEqualTo []) exitWith { DMS_StaticMissionLastStart = _time; if (DMS_DEBUG) then { (format ["SelectMission :: No available missions! Running missions: %1", DMS_RunningStaticMissions]) call DMS_fnc_DebugLog; }; }; _mission = _availableMissions call BIS_fnc_selectRandom; if (DMS_DEBUG) then { (format ["SelectMission :: Selected static mission: %1", _mission]) call DMS_fnc_DebugLog; }; [_mission] call DMS_fnc_SpawnStaticMission; if (DMS_DEBUG) then { (format ["SelectMission :: Spawning of static mission ""%1"" complete!", _mission]) call DMS_fnc_DebugLog; }; }; };