2016-04-13 20:32:39 +00:00
|
|
|
/*
|
|
|
|
Author: IT07
|
|
|
|
|
|
|
|
Description:
|
|
|
|
Handles the start and timeout of missions
|
|
|
|
|
|
|
|
Params:
|
|
|
|
none
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
nothing
|
|
|
|
*/
|
|
|
|
|
2016-05-09 13:30:27 +00:00
|
|
|
scopeName "outer";
|
2016-04-13 20:32:39 +00:00
|
|
|
_maxGlobalMissions = "maxGlobalMissions" call VEMFr_fnc_getSetting;
|
2016-05-09 13:30:27 +00:00
|
|
|
_minNew = "minNew" call VEMFr_fnc_getSetting;
|
|
|
|
if (_minNew > -1) then
|
2016-05-06 11:09:26 +00:00
|
|
|
{
|
2016-05-09 13:30:27 +00:00
|
|
|
_maxNew = "maxNew" call VEMFr_fnc_getSetting;
|
|
|
|
if (_maxNew > 0) then
|
2016-05-06 11:09:26 +00:00
|
|
|
{
|
2016-05-09 13:30:27 +00:00
|
|
|
_missionList = "missionList" call VEMFr_fnc_getSetting;
|
|
|
|
if (count _missionList > 0) then
|
2016-04-13 20:32:39 +00:00
|
|
|
{
|
2016-05-09 13:30:27 +00:00
|
|
|
_minFps = "minServerFPS" call VEMFr_fnc_getSetting;
|
|
|
|
_minPlayers = "minPlayers" call VEMFr_fnc_getSetting;
|
2016-06-02 21:20:00 +00:00
|
|
|
if isNil "VEMFrForceStart" then { VEMFrForceStart = false };
|
2016-06-23 20:42:29 +00:00
|
|
|
waitUntil { if ((((count allPlayers) >= _minPlayers) AND (diag_fps > _minFps)) OR VEMFrForceStart) then { true } else { uiSleep 5; false } };
|
2016-05-09 13:30:27 +00:00
|
|
|
if VEMFrForceStart then
|
2016-05-06 11:09:26 +00:00
|
|
|
{
|
2016-05-10 12:18:49 +00:00
|
|
|
["missionTimer", 1, format["VEMFr has been forced to start. Server FPS: %1", diag_fps]] ExecVM "exile_vemf_reloaded\sqf\log.sqf";
|
2016-05-09 13:30:27 +00:00
|
|
|
} else
|
|
|
|
{
|
2016-05-10 12:18:49 +00:00
|
|
|
["missionTimer", 1, format["Enough players online (%1) and server FPS (%2) is above %3. Starting missionTimer...", count allPlayers, diag_fps, _minFps]] ExecVM "exile_vemf_reloaded\sqf\log.sqf";
|
2016-06-23 20:42:29 +00:00
|
|
|
["missionTimer", 1, format["Global mission limit is set at: %1", _maxGlobalMissions]] ExecVM "exile_vemf_reloaded\sqf\log.sqf";
|
2016-05-09 13:30:27 +00:00
|
|
|
};
|
|
|
|
VEMFrMissionCount = 0;
|
|
|
|
private ["_ignoreLimit"];
|
|
|
|
_ignoreLimit = false;
|
|
|
|
if (_maxGlobalMissions isEqualTo 0) then
|
|
|
|
{
|
|
|
|
_ignoreLimit = true;
|
|
|
|
};
|
|
|
|
_sleep =
|
|
|
|
{
|
|
|
|
// Wait random amount
|
|
|
|
uiSleep ((_minNew*60)+ floor random ((_maxNew*60)-(_minNew*60)));
|
|
|
|
};
|
|
|
|
call _sleep;
|
|
|
|
while {true} do
|
|
|
|
{
|
|
|
|
// Pick A Mission if enough players online
|
2016-06-23 20:42:29 +00:00
|
|
|
if ((count allPlayers) >= _minPlayers) then
|
2016-05-09 13:30:27 +00:00
|
|
|
{
|
|
|
|
scopeName "pick";
|
2016-06-23 20:42:29 +00:00
|
|
|
if ((VEMFrMissionCount < _maxGlobalMissions) AND (VEMFrMissionCount >= 0) OR _ignoreLimit) then
|
2016-05-06 11:09:26 +00:00
|
|
|
{
|
2016-05-09 13:30:27 +00:00
|
|
|
_missionName = selectRandom _missionList;
|
|
|
|
_mission = [_missionName] execVM format["exile_vemf_reloaded\missions\%1.sqf", _missionName];
|
|
|
|
uiSleep 5;
|
|
|
|
if (scriptDone _mission) then
|
2016-05-06 11:09:26 +00:00
|
|
|
{
|
2016-05-09 13:30:27 +00:00
|
|
|
// Mission sqf file finished executing within 5 seconds. Assume it did not meet requirements to spawn.
|
|
|
|
breakOut "pick"; // break the current scope and redo the loop (a.k.a. pick a new mission and launch it right away instead of the failed one)
|
2016-05-06 11:09:26 +00:00
|
|
|
} else
|
2016-05-09 13:30:27 +00:00
|
|
|
{
|
|
|
|
// Mission sqf file did not finish within 5 seconds. Assume it is running successfully.
|
|
|
|
call _sleep;
|
|
|
|
};
|
|
|
|
} else
|
|
|
|
{
|
|
|
|
if (VEMFrMissionCount < 0) then
|
|
|
|
{
|
2016-05-10 12:18:49 +00:00
|
|
|
["missionTimer", 0, format["VEMFrMissionCount (%1) is BELOW 0! Stopping missionTimer...", VEMFrMissionCount]] ExecVM "exile_vemf_reloaded\sqf\log.sqf";
|
2016-05-09 13:30:27 +00:00
|
|
|
breakOut "outer";
|
|
|
|
};
|
|
|
|
|
|
|
|
call _sleep;
|
2016-05-06 11:09:26 +00:00
|
|
|
};
|
2016-05-09 13:30:27 +00:00
|
|
|
} else
|
|
|
|
{
|
|
|
|
uiSleep 60; // If no players online, check again in 60 seconds
|
|
|
|
};
|
|
|
|
};
|
2016-04-13 20:32:39 +00:00
|
|
|
};
|
2016-05-06 11:09:26 +00:00
|
|
|
};
|
2016-05-09 13:30:27 +00:00
|
|
|
};
|