Epoch/Sources/epoch_code/compile/building/EPOCH_isBuildAllowed.sqf

195 lines
7.4 KiB
Plaintext
Raw Normal View History

2015-12-07 16:24:52 +00:00
/*
Author: Aaron Clark - EpochMod.com
Contributors: Raimonds Virtoss
Description:
2015-12-15 18:46:09 +00:00
check if building is allowed
2015-12-07 16:24:52 +00:00
Licence:
Arma Public License Share Alike (APL-SA) - https://www.bistudio.com/community/licenses/arma-public-license-share-alike
Github:
2016-06-13 16:54:19 +00:00
https://github.com/EpochModTeam/Epoch/tree/release/Sources/epoch_code/compile/building/EPOCH_isBuildAllowed.sqf
2015-12-07 16:24:52 +00:00
Example:
_isAllowed = "" call EPOCH_isBuildAllowed;
_isAllowed = _objType call EPOCH_isBuildAllowed;
Parameter(s):
_this select 0: OBJECT - Base building object
Returns:
BOOL
*/
private ["_cfgBaseBuilding","_buildingJammerRange","_buildingCountLimit","_buildingAllowed","_nearestJammer","_ownedJammerExists","_objectCount","_limitNearby","_restricted","_range","_config","_staticClass","_objType","_simulClass","_bypassJammer","_jammer","_restrictedLocations","_myPosATL"];
Release 0.3.8 (#502) * first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
2016-04-08 20:21:46 +00:00
2015-09-14 20:55:36 +00:00
_buildingAllowed = true;
2015-12-07 16:24:52 +00:00
_ownedJammerExists = false;
2015-09-14 20:55:36 +00:00
_nearestJammer = objNull;
2016-04-10 16:16:27 +00:00
// reject building if in vehicle
2016-06-18 01:22:29 +00:00
if (vehicle player != player)exitWith{["Building Disallowed: Inside Vehicle", 5] call Epoch_message; false };
2016-04-10 16:16:27 +00:00
2015-09-14 20:55:36 +00:00
// defaults
_config = 'CfgEpochClient' call EPOCH_returnConfig;
_cfgBaseBuilding = 'CfgBaseBuilding' call EPOCH_returnConfig;
2015-09-14 20:55:36 +00:00
_buildingJammerRange = getNumber(_config >> "buildingJammerRange");
_buildingCountLimit = getNumber(_config >> "buildingCountLimit");
if (_buildingJammerRange == 0) then { _buildingJammerRange = 75; };
if (_buildingCountLimit == 0) then { _buildingCountLimit = 200; };
2016-07-07 23:48:34 +00:00
_buildingCountLeader = getNumber(_config >> "buildingCountLeader");
2016-07-07 23:54:50 +00:00
_buildingCountPerMember = getNumber(_config >> "buildingCountPerMember");
2016-07-07 23:48:34 +00:00
_storagecountLeader = getNumber(_config >> "storagecountLeader");
2016-07-07 23:54:50 +00:00
_storagecountPerMember = getNumber(_config >> "storagecountPerMember");
2016-07-07 23:48:34 +00:00
_minjammerdistance = getNumber(_config >> "minJammerDistance");
_maxbuildingheigh = getNumber(_config >> "maxBuildingHeigh");
_jammerpergroup = getNumber(_config >> "JammerPerGroup");
if (_buildingCountLeader == 0) then { _buildingCountLeader = _buildingCountLimit};
if (_storagecountLeader == 0) then { _storagecountLeader = 100};
if (_minjammerdistance == 0) then { _minjammerdistance = _buildingJammerRange*3};
if (_maxbuildingheigh == 0) then { _maxbuildingheigh = 100};
if (_jammerpergroup == 0) then { _jammerpergroup = 2};
2015-12-07 16:24:52 +00:00
// input
params ["_objType"];
_obj = objNull;
if (_objType isEqualType objNull) then {
_obj = _objType;
_objType = typeOf _objType;
};
2015-12-07 16:24:52 +00:00
_staticClass = getText(_cfgBaseBuilding >> _objType >> "staticClass");
_simulClass = getText(_cfgBaseBuilding >> _objType >> "simulClass");
_bypassJammer = getNumber(_cfgBaseBuilding >> _staticClass >> "bypassJammer");
2015-09-14 20:55:36 +00:00
// Jammer
2016-07-07 23:48:34 +00:00
_jammer = nearestObjects[player, ["PlotPole_EPOCH"], _minjammerdistance];
2015-09-14 20:55:36 +00:00
if !(_jammer isEqualTo []) then {
2015-12-07 16:24:52 +00:00
if (_objType in ["PlotPole_EPOCH", "PlotPole_SIM_EPOCH"]) then {
2015-09-14 20:55:36 +00:00
{
if (alive _x) exitWith{
_buildingAllowed = false;
2016-06-18 01:22:29 +00:00
["Building Disallowed: Existing Jammer Signal", 5] call Epoch_message;
2015-09-14 20:55:36 +00:00
};
} foreach _jammer;
} else {
2015-12-07 16:24:52 +00:00
2015-09-14 20:55:36 +00:00
{
if (alive _x && (_x distance player) <= _buildingJammerRange) exitWith{
_nearestJammer = _x;
};
} foreach _jammer;
if !(isNull _nearestJammer) then {
2016-07-07 23:48:34 +00:00
if ((getposatl player) select 2 < _maxbuildingheigh) then {
2015-09-14 20:55:36 +00:00
if ((_nearestJammer getVariable["BUILD_OWNER", "-1"]) in[getPlayerUID player, Epoch_my_GroupUID]) then {
_ownedJammerExists = true;
} else {
_buildingAllowed = false;
2016-06-18 01:22:29 +00:00
["Building Disallowed: Frequency Blocked", 5] call Epoch_message;
2015-09-14 20:55:36 +00:00
};
_objectCount = count nearestObjects[_nearestJammer, ["Constructions_static_F"], _buildingJammerRange];
2016-07-07 23:48:34 +00:00
2016-07-07 23:58:09 +00:00
_membercount = 0;
2016-07-07 23:48:34 +00:00
if (count Epoch_my_Group > 0) then {
2016-07-07 23:58:09 +00:00
_membercount = count (Epoch_my_Group select 3) + count (Epoch_my_Group select 4);
2016-07-07 23:48:34 +00:00
};
if (_objType in ["WorkBench_EPOCH","StorageShelf_EPOCH","Tipi_EPOCH","LockBox_EPOCH","Safe_EPOCH","StorageShelf_SIM_EPOCH","LockBox_SIM_EPOCH","Safe_SIM_EPOCH","Workbench_SIM_EPOCH","Tipi_SIM_EPOCH"]) then {
_buildingCountLimit = _storagecountLeader + _storagecountPerMember*_membercount;
_objectCount = count nearestObjects[_nearestJammer, ["Buildable_Storage","Constructions_lockedstatic_F"], _buildingJammerRange];
}
else {
_buildingCountLimit = _buildingCountLeader + _buildingCountPerMember*_membercount;
_objectCount = count nearestObjects[_nearestJammer, ["Constructions_static_F","Constructions_foundation_F"], _buildingJammerRange];
};
2015-09-14 20:55:36 +00:00
if (_objectCount >= _buildingCountLimit) then {
_buildingAllowed = false;
2016-07-07 23:48:34 +00:00
[format["Building Disallowed: Frequency Overloaded: Limit %1", _buildingCountLimit], 5] call Epoch_message;
2015-09-14 20:55:36 +00:00
};
2016-07-07 23:48:34 +00:00
}
else {
_buildingAllowed = false;
["Building Disallowed: Max building heigh reached", 5] call Epoch_message;
};
};
};
}
else {
if (_objType in ["PlotPole_EPOCH", "PlotPole_SIM_EPOCH"]) then {
_alljammer = allmissionobjects 'PlotPole_EPOCH';
_c = 0;
{
if ((_x getVariable["BUILD_OWNER", "-1"]) in[getPlayerUID player, Epoch_my_GroupUID]) then {
_c = _c+1;
};
} foreach _alljammer;
if (_c >= _jammerpergroup) then {
_buildingAllowed = false;
[format["Building Disallowed: Max %1 Jammer per Group!", _jammerpergroup], 5] call Epoch_message;
2015-09-14 20:55:36 +00:00
};
};
};
if !(_buildingAllowed)exitWith{ false };
// Max object
if (!_ownedJammerExists) then{
_limitNearby = getNumber(_cfgBaseBuilding >> _staticClass >> "limitNearby");
2015-09-14 20:55:36 +00:00
if (_limitNearby > 0) then{
// remove current target from objects
_objectCount = count (nearestObjects[player, [_staticClass, _simulClass], _buildingJammerRange] - [_obj]);
// TODO: not properly limiting simulated objects
if (_objectCount >= _limitNearby) then{
2015-09-14 20:55:36 +00:00
_buildingAllowed = false;
2016-06-18 01:22:29 +00:00
[format["Building Disallowed: Limit %1", _limitNearby], 5] call Epoch_message;
2015-09-14 20:55:36 +00:00
};
};
};
if !(_buildingAllowed)exitWith{ false };
// require jammer check if not found as owner of jammer
if (getNumber(_config >> "buildingRequireJammer") == 0 && _bypassJammer == 0) then{
2015-12-07 16:24:52 +00:00
if !(_objType in ["PlotPole_EPOCH", "PlotPole_SIM_EPOCH"]) then {
2015-09-14 20:55:36 +00:00
_buildingAllowed = _ownedJammerExists;
if !(_buildingAllowed) then {
2016-06-18 01:22:29 +00:00
["Building Disallowed: Frequency Jammer Needed", 5] call Epoch_message;
2015-09-14 20:55:36 +00:00
};
};
};
if !(_buildingAllowed)exitWith{ false };
if (getNumber(_config >> "buildingNearbyMilitary") == 0) then{
_range = getNumber(_config >> "buildingNearbyMilitaryRange");
if (_range > 0) then {
_restricted = nearestObjects [player, ["ProtectionZone_Invisible_F","Cargo_Tower_base_F","Cargo_HQ_base_F","Cargo_Patrol_base_F","Cargo_House_base_F"], 300];
} else {
_restricted = nearestObjects [player, ["Cargo_Tower_base_F","Cargo_HQ_base_F","Cargo_Patrol_base_F","Cargo_House_base_F"], _range];
_restricted append (nearestObjects [player, ["ProtectionZone_Invisible_F","Cargo_Tower_base_F","Cargo_HQ_base_F","Cargo_Patrol_base_F","Cargo_House_base_F"], 300]);
};
} else {
_restricted = nearestObjects [player, ["ProtectionZone_Invisible_F"], 300];
};
if !(_restricted isEqualTo []) then {
_buildingAllowed = false;
2016-07-07 23:48:34 +00:00
["Building Disallowed: Area Blocked", 5] call Epoch_message;
2015-09-14 20:55:36 +00:00
};
_restrictedLocations = nearestLocations [player, ["NameCityCapital"], 300];
if !(_restrictedLocations isEqualTo []) then {
_buildingAllowed = false;
2016-07-07 23:48:34 +00:00
["Building Disallowed: Area Blocked", 5] call Epoch_message;
2015-09-14 20:55:36 +00:00
};
_myPosATL = getPosATL player;
{
if ((_x select 0) distance _myPosATL < (_x select 1)) exitWith {
_buildingAllowed = false;
2016-07-07 23:48:34 +00:00
["Building Disallowed: Area Blocked", 5] call Epoch_message;
2015-09-14 20:55:36 +00:00
};
} forEach(getArray(_config >> worldname >> "blockedArea"));
2015-12-07 16:24:52 +00:00
_buildingAllowed