mirror of
https://github.com/EpochModTeam/Epoch.git
synced 2024-08-30 18:22:13 +00:00
5db8af19f8
debug
295 lines
11 KiB
Plaintext
295 lines
11 KiB
Plaintext
// make sure we wait for Display #46
|
|
// waitUntil {!(isNull (findDisplay 46))};
|
|
waitUntil {!isNull (findDisplay 46) && (!isNil "EPOCH_loadingScreenDone")};
|
|
|
|
// load favBar
|
|
'load' spawn epoch_favBar_draw;
|
|
|
|
// set player rating
|
|
player addRating -2000;
|
|
|
|
// force update within 15 seconds
|
|
EPOCH_forceUpdate = false;
|
|
_forceUpdate = false;
|
|
// force update within 1 second
|
|
EPOCH_forceUpdateNow = false;
|
|
|
|
// start alive timer
|
|
_clientAliveTimer = diag_tickTime;
|
|
|
|
if (isNil "_playerEnergyKey") then {
|
|
diag_log "DEBUG: _playerEnergyKey not set"
|
|
};
|
|
|
|
// init player stat vars
|
|
_customVarsInit = ["CfgEpochClient", "customVarsDefaults", EPOCH_customVarsDefaults] call EPOCH_fnc_returnConfigEntryV2;
|
|
_customVarNames = _customVarsInit apply {_x param [0,""]};
|
|
_defaultVarValues = _customVarsInit apply {_x param [1,0]};
|
|
_customVarLimits = _customVarsInit apply {_x param [2,[]]};
|
|
|
|
// init limits and keys
|
|
{
|
|
_varLimits = _customVarLimits select _forEachIndex;
|
|
_varDefault = _defaultVarValues select _foreachindex;
|
|
_varName = format["EPOCH_player%1",_x];
|
|
_varNameTmp = call compile format["_player%1Key",_x];
|
|
if !(isNil "_varNameTmp") then {_varName = _varNameTmp};
|
|
_varLimits params [[format["_player%1MaxRaw",_x],100],[format["_player%1MinRaw",_x],0]];
|
|
missionNamespace setVariable [_varName, missionNamespace getVariable [format["EPOCH_player%1",_x], _varDefault]];
|
|
call compile format['_player%1 = missionNamespace getVariable [_varName, _varDefault]; _player%1Max = _player%1MaxRaw; _player%1Min = _player%1MinRaw',_x];
|
|
} forEach _customVarNames;
|
|
|
|
EPOCH_playerEnergyMax = _playerEnergyMax;
|
|
|
|
// inline function to sync player stats to server
|
|
_fnc_forceUpdate = {
|
|
private _customVars = [];
|
|
{
|
|
private _varName = format["EPOCH_player%1",_x];
|
|
private _varNameTmp = call compile format["_player%1Key",_x];
|
|
if !(isNil "_varNameTmp") then {_varName = _varNameTmp};
|
|
_customVars pushBack (missionNamespace getVariable [_varName,_defaultVarValues select _foreachindex]);
|
|
} forEach _customVarNames;
|
|
[player,_customVars,Epoch_personalToken] remoteExec ["EPOCH_fnc_savePlayer",2];
|
|
};
|
|
|
|
// disable fuel sources client side.
|
|
{_x setFuelCargo 0;} foreach (missionNamespace getVariable ["EPOCH_staticFuelSources", []]);
|
|
|
|
// setup display EH's
|
|
if (isNil "EPOCH_display_setup_complete") then {
|
|
EPOCH_display_setup_complete = true;
|
|
{
|
|
(findDisplay 46) displayAddEventHandler [_x,(["CfgEpochClient", _x, ""] call EPOCH_fnc_returnConfigEntryV2)];
|
|
} forEach (["CfgEpochClient", "displayAddEventHandler", []] call EPOCH_fnc_returnConfigEntryV2);
|
|
// reset anim state
|
|
player switchMove "";
|
|
// setup Epoch Hud
|
|
call epoch_dynamicHUD_start;
|
|
};
|
|
|
|
|
|
|
|
// Background radiation
|
|
_outOfBoundsRadiation = ["CfgEpochClient", "outOfBoundsRadiation", 10] call EPOCH_fnc_returnConfigEntryV2;
|
|
_radsLevel = 0;
|
|
|
|
_prevEquippedItem = [];
|
|
_damagePlayer = damage player;
|
|
_isOnFoot = isNull objectParent player;
|
|
_panic = false;
|
|
_prevEnergy = _playerEnergy;
|
|
|
|
|
|
// init config data
|
|
_antagonistRndChance = ["CfgEpochClient", "antagonistRngChance", 100] call EPOCH_fnc_returnConfigEntryV2;
|
|
|
|
_baseHungerLoss = ["CfgEpochClient", "baseHungerLoss", 2] call EPOCH_fnc_returnConfigEntryV2;
|
|
_baseThirstLoss = ["CfgEpochClient", "baseThirstLoss", 2] call EPOCH_fnc_returnConfigEntryV2;
|
|
_energyCostNV = ["CfgEpochClient", "energyCostNV", 3] call EPOCH_fnc_returnConfigEntryV2;
|
|
_energyRegenMax = ["CfgEpochClient", "energyRegenMax", 5] call EPOCH_fnc_returnConfigEntryV2;
|
|
_energyRange = ["CfgEpochClient", "energyRange", 75] call EPOCH_fnc_returnConfigEntryV2;
|
|
_hudConfigs = ["CfgEpochClient", "hudConfigs", []] call EPOCH_fnc_returnConfigEntryV2;
|
|
|
|
_chargeRate = 0;
|
|
EPOCH_playerIsSwimming = false;
|
|
|
|
_antagonistChanceDefaults = [
|
|
"Epoch_Cloak_F",0.07,
|
|
"Epoch_Sapper_F",0.25,
|
|
"Epoch_SapperG_F",0.12,
|
|
"Epoch_SapperB_F",0.06,
|
|
"I_UAV_01_F",0.2,
|
|
"PHANTOM",0.01,
|
|
"EPOCH_RyanZombie_1",0.25
|
|
];
|
|
_antagonistChances = ["CfgEpochClient", "antagonistChances", _antagonistChanceDefaults] call EPOCH_fnc_returnConfigEntryV2;
|
|
|
|
|
|
// Init antagonist spawn limits
|
|
_spawnIndex = [];
|
|
_spawnLimits = [];
|
|
_antagonistSpawnDefaults = [
|
|
["Epoch_Cloak_F", 1],
|
|
["GreatWhite_F", 2],
|
|
["Epoch_Sapper_F",2],
|
|
["Epoch_SapperG_F",1],
|
|
["Epoch_SapperB_F",1],
|
|
["I_UAV_01_F",2],
|
|
["PHANTOM",1],
|
|
["B_Heli_Transport_01_F",1],
|
|
["EPOCH_RyanZombie_1",12]
|
|
];
|
|
_antagonistSpawnLimits = ["CfgEpochClient", "antagonistSpawnIndex", _antagonistSpawnDefaults] call EPOCH_fnc_returnConfigEntryV2;
|
|
|
|
{
|
|
_x params ["_spawnName","_spawnLimit"];
|
|
if (_spawnName isEqualTo "EPOCH_RyanZombie_1") then {
|
|
if (EPOCH_mod_Ryanzombies_Enabled) then {
|
|
_spawnIndex pushBack _spawnName;
|
|
_spawnLimits pushBack _spawnLimit;
|
|
};
|
|
} else {
|
|
_spawnIndex pushBack _spawnName;
|
|
_spawnLimits pushBack _spawnLimit;
|
|
};
|
|
} forEach _antagonistSpawnLimits;
|
|
|
|
EPOCH_spawnIndex = _spawnIndex;
|
|
EPOCH_spawnLimits = _spawnLimits;
|
|
|
|
// default data if mismatch
|
|
if !(_playerSpawnArray isEqualTypeParams _spawnIndex) then{
|
|
_playerSpawnArray = [];
|
|
{ _playerSpawnArray pushBack 0 } forEach _spawnIndex;
|
|
};
|
|
|
|
// find radio
|
|
{
|
|
if (configName(inheritsFrom(configFile >> "CfgWeapons" >> _x)) == "ItemRadio") exitWith{
|
|
EPOCH_equippedItem_PVS = [_x, true, player];
|
|
};
|
|
} forEach assignedItems player;
|
|
|
|
// lootBubble Init
|
|
_buildingJammerRange = ["CfgEpochClient", "buildingJammerRange", 75] call EPOCH_fnc_returnConfigEntryV2;
|
|
_masterConfig = 'CfgBuildingLootPos' call EPOCH_returnConfig;
|
|
|
|
_lootClasses = [];
|
|
_lootClassesIgnore = ['Default'];
|
|
'_cN = configName _x;if !(_cN in _lootClassesIgnore)then{_lootClasses pushBackUnique _cN}; true' configClasses _masterConfig;
|
|
|
|
|
|
|
|
_lastPlayerPos = getPosATL player;
|
|
_lootBubble = {
|
|
private["_jammer", "_others", "_objects", "_nearObjects", "_building", "_lootDist", "_lootLoc", "_playerPos", "_distanceTraveled"];
|
|
_playerPos = getPosATL vehicle player;
|
|
_distanceTraveled = _lastPlayerPos distance _playerPos;
|
|
if (_distanceTraveled > 10 && _distanceTraveled < 200) then {
|
|
_lootDist = 30 + _distanceTraveled;
|
|
_lootLoc = player getRelPos [_lootDist, (random [-180,0,180])];
|
|
_objects = nearestObjects[_lootLoc, _lootClasses, 30];
|
|
_jammer = nearestObjects [_lootLoc, ["PlotPole_EPOCH","ProtectionZone_Invisible_F"], _buildingJammerRange];
|
|
if (!(_objects isEqualTo[]) && (_jammer isEqualTo[])) then {
|
|
_building = selectRandom _objects;
|
|
if !(_building in EPOCH_LootedBlds) then {
|
|
_others = _building nearEntities[["Epoch_Male_F", "Epoch_Female_F"], 15];
|
|
if (_others isEqualTo[]) then {
|
|
_nearObjects = nearestObjects[_building, ["WH_Loot", "Animated_Loot"], sizeOf (typeOf _building)];
|
|
//diag_log format["DEBUG: sizeof %1 %2",sizeOf (typeOf _building), typeOf _building];
|
|
if (_nearObjects isEqualTo[]) then {
|
|
[_building] call EPOCH_spawnLoot;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
_lastPlayerPos = _playerPos;
|
|
};
|
|
|
|
// init weather temperature var if not already set
|
|
if (isNil "EPOCH_CURRENT_WEATHER") then {
|
|
EPOCH_CURRENT_WEATHER = 75;
|
|
};
|
|
|
|
_cursorTarget = objNull;
|
|
|
|
// init cfgBaseBuilding config var
|
|
_cfgBaseBuilding = 'CfgBaseBuilding' call EPOCH_returnConfig;
|
|
_cfgObjectInteractions = 'CfgObjectInteractions' call EPOCH_returnConfig;
|
|
|
|
|
|
_EPOCH_BuildTraderMisson = {
|
|
params ['_inGameTasksconfig','_taskName',['_unit',objnull],['_taskItem',objnull]];
|
|
_taskTitle = getText ( _inGameTasksconfig >> _taskName >> "title");
|
|
_taskSQF = getText ( _inGameTasksconfig >> _taskName >> "initsqf");
|
|
if !(_taskSQF isequalto '') then {
|
|
call compile format ["[_taskName,player,_unit,_taskItem] execVM ""%1""",_taskSQF];
|
|
};
|
|
_taskCall = getText ( _inGameTasksconfig >> _taskName >> "initcall");
|
|
if !(_taskCall isequalto '') then {
|
|
call compile _taskCall;
|
|
};
|
|
|
|
_taskDelay = diag_ticktime + (getNumber ( _inGameTasksconfig >> _taskName >> "triggerDelay"));
|
|
_triggerintervall = getNumber ( _inGameTasksconfig >> _taskName >> "triggerintervall");
|
|
_taskItems = getArray ( _inGameTasksconfig >> _taskName >> "items");
|
|
if !(_taskItems isequalto []) then {
|
|
[player,Epoch_personalToken,_taskItems,[],objNull,false] remoteExec ["EPOCH_Server_createObject",2];
|
|
};
|
|
|
|
_taskMarkerType = getnumber (_inGameTasksconfig >> _taskName >> 'markerType');
|
|
if (_taskMarkerType > 0) then {
|
|
_taskMarkerVis = getNumber ( _inGameTasksconfig >> _taskName >> "markerVisible");
|
|
_markerPos = [0,0,0];
|
|
if (isNil "EPOCH_taskMarkerPos") then {
|
|
if !(isNull _trgt) then {
|
|
_markerPos = getPos _trgt;
|
|
};
|
|
if !(isNull _unit) then{
|
|
_markerPos = getPos _unit;
|
|
};
|
|
if !(isNull _taskItem) then {
|
|
_markerPos = getPos _taskItem;
|
|
};
|
|
}
|
|
else {
|
|
_markerPos = EPOCH_taskMarkerPos;
|
|
};
|
|
_mkrName = format ["EPOCHTaskMark%1%2",_taskName,diag_tickTime];
|
|
EPOCH_taskMarker = [_mkrName,_taskMarkerVis];
|
|
_taskMarkerText = getText ( _inGameTasksconfig >> _taskName >> "markerText");
|
|
_taskMarkerRad = getNumber ( _inGameTasksconfig >> _taskName >> "markerRadius");
|
|
if(_taskMarkerType == 2)then{
|
|
_markerPos set [0, (_markerPos select 0) + (floor (random _taskMarkerRad) - (_taskMarkerRad / 2))];
|
|
_markerPos set [1, (_markerPos select 1) + (floor (random _taskMarkerRad) - (_taskMarkerRad / 2))];
|
|
};
|
|
[[_taskMarkerVis,player],_markerPos,"ELLIPSE","mil_dot",_taskMarkerText,"ColorYellow",[_taskMarkerRad,_taskMarkerRad], "SolidBorder", 42, 0.6,_mkrName] remoteExec ["EPOCH_server_makeMarker",2];
|
|
};
|
|
_taskDialogues = [];
|
|
{
|
|
_x params [["_condition",""],["_dialogue",""]];
|
|
if !(_condition isequalto "" || _dialogue isequalto "") then {
|
|
_taskDialogues pushback [compile _condition,_dialogue];
|
|
};
|
|
} foreach (getarray (_inGameTasksconfig >> _taskName >> 'dialogues'));
|
|
_taskEvents = [];
|
|
{
|
|
_x params [["_condition",""],["_taskEventCALL",""],["_taskEventTasks",[]]];
|
|
if !(_condition isequalto "") then {
|
|
_taskEvents pushback [compile _condition,compile _taskEventCALL,_taskEventTasks];
|
|
};
|
|
} foreach (getarray (_inGameTasksconfig >> _taskName >> 'callevents'));
|
|
_taskFailedCond = compile getText ( _inGameTasksconfig >> _taskName >> "failedCondition");
|
|
_taskFailTime = (getNumber ( _inGameTasksconfig >> _taskName >> "abandonTime"));
|
|
if (_taskFailTime < 1) then {_taskFailTime=999999} else {_taskFailTime = _taskFailTime + diag_ticktime};
|
|
_taskFailedDiags = getArray ( _inGameTasksconfig >> _taskName >> "faileddialogues");
|
|
_taskFailedSQF = getText ( _inGameTasksconfig >> _taskName >> "failedSQF");
|
|
_taskFailedCall = compile getText ( _inGameTasksconfig >> _taskName >> "failedCall");
|
|
_nextTask = getArray ( _inGameTasksconfig >> _taskName >> "failedTask");
|
|
|
|
_taskCompleteCond = compile getText ( _inGameTasksconfig >> _taskName >> "completeCondition");
|
|
_taskReward = getArray ( _inGameTasksconfig >> _taskName >> "reward");
|
|
_taskCompleteDiags = getArray ( _inGameTasksconfig >> _taskName >> "completedialogues");
|
|
_taskCompleteCall = compile getText ( _inGameTasksconfig >> _taskName >> "completedCALL");
|
|
_taskNextTrigger = getArray ( _inGameTasksconfig >> _taskName >> "nextTask");
|
|
|
|
_missionCleanUpCall = compile getText ( _inGameTasksconfig >> _taskName >> "cleanUpCall");
|
|
_taskCleanup = getNumber ( _inGameTasksconfig >> _taskName >> "cleanUp");
|
|
_return = [
|
|
[_inGameTasksconfig,_taskName,_unit,_taskItem,_taskTitle,_missionCleanUpCall,_taskCleanup],
|
|
_taskDelay,
|
|
_triggerintervall,
|
|
_taskDialogues,
|
|
_taskEvents,
|
|
[_taskFailedCond,_taskFailTime,_taskFailedDiags,_taskFailedSQF,_taskFailedCall,_nextTask],
|
|
[_taskCompleteCond,_taskReward,_taskCompleteDiags,_taskCompleteCall,_taskNextTrigger]
|
|
];
|
|
EPOCH_task_startTime = diag_ticktime;
|
|
_return
|
|
};
|
|
_epoch_tradermissionarray = [];
|
|
EPOCH_ActiveTraderMission = [];
|
|
_LastMissionTrigger = 0;
|