mirror of
https://github.com/EpochModTeam/Epoch.git
synced 2024-08-30 18:22:13 +00:00
0.3.8.0439
[Fixed] BE kick since 1.58 hotfix. [Fixed] Attempt fix issues with temporary angle and rotation issues with base building. [Fixed] Check for base kit item is in players inventory before spawning ghost. [Fixed] Use object as input for remoteExec instead of owner. http://epochmod.com/forum/topic/41959-be-carefull-with-remoteexec-and-owner/
This commit is contained in:
parent
f453683d46
commit
dabb8ff068
@ -43,7 +43,7 @@
|
|||||||
[Info] Some AI Scripts Mods may not work with disableRemoteSensors enabled. You can disable with "disableRemoteSensors = false;" in CfgEpochClient.
|
[Info] Some AI Scripts Mods may not work with disableRemoteSensors enabled. You can disable with "disableRemoteSensors = false;" in CfgEpochClient.
|
||||||
[Info] Removed old .bikey and added new one for 0380.
|
[Info] Removed old .bikey and added new one for 0380.
|
||||||
|
|
||||||
Build: 438
|
Build: 439
|
||||||
[Added] FastNights Epoch Event. http://epochmod.com/forum/topic/41949-accelerated-time/?do=findComment&comment=275310
|
[Added] FastNights Epoch Event. http://epochmod.com/forum/topic/41949-accelerated-time/?do=findComment&comment=275310
|
||||||
[Added] Install batch for all CUP mods and CBA. https://github.com/EpochModTeam/Epoch/tree/master/Tools/Install
|
[Added] Install batch for all CUP mods and CBA. https://github.com/EpochModTeam/Epoch/tree/master/Tools/Install
|
||||||
[Changed] The function EPOCH_fnc_addItemOverflow now supports spawning items and weapons types given a count.
|
[Changed] The function EPOCH_fnc_addItemOverflow now supports spawning items and weapons types given a count.
|
||||||
@ -55,6 +55,10 @@ Build: 438
|
|||||||
[Changed] Increased range for vehicle interactions to fix issues with access to larger vehicles. Thanks to Grahame for the report: http://epochmod.com/forum/index.php?/topic/41894-cannot-unlock-large-vehicles/
|
[Changed] Increased range for vehicle interactions to fix issues with access to larger vehicles. Thanks to Grahame for the report: http://epochmod.com/forum/index.php?/topic/41894-cannot-unlock-large-vehicles/
|
||||||
[Changed] Preloading sapper by spawning one on the map at server start.
|
[Changed] Preloading sapper by spawning one on the map at server start.
|
||||||
[Changed] Change to github markdown for credits and license.
|
[Changed] Change to github markdown for credits and license.
|
||||||
|
[Fixed] BE kick since 1.58 hotfix.
|
||||||
|
[Fixed] Use object as input for remoteExec instead of owner. http://epochmod.com/forum/topic/41959-be-carefull-with-remoteexec-and-owner/
|
||||||
|
[Fixed] Attempt fix issues with temporary angle and rotation issues with base building.
|
||||||
|
[Fixed] Check for base kit item is in players inventory before spawning ghost.
|
||||||
[Fixed] Prevent empty group menu display. Thanks to He-Man! for the fix.
|
[Fixed] Prevent empty group menu display. Thanks to He-Man! for the fix.
|
||||||
[Fixed] Group system marked player as "Dead Player" if moderator status was change while player offline. Thanks to He-Man! for the fix.
|
[Fixed] Group system marked player as "Dead Player" if moderator status was change while player offline. Thanks to He-Man! for the fix.
|
||||||
[Fixed] Group system invite and kick from group options not working. Thanks to He-Man for the fixes: http://epochmod.com/forum/topic/41893-group-menu-broken-kick-invite-for-admin-not-possible/#comment-275429
|
[Fixed] Group system invite and kick from group options not working. Thanks to He-Man for the fixes: http://epochmod.com/forum/topic/41893-group-menu-broken-kick-invite-for-admin-not-possible/#comment-275429
|
||||||
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -117,9 +117,9 @@ switch _interactOption do {
|
|||||||
closeDialog 0;
|
closeDialog 0;
|
||||||
_buildingJammerRange = ["CfgEpochClient", "buildingJammerRange", 75] call EPOCH_fnc_returnConfigEntryV2;
|
_buildingJammerRange = ["CfgEpochClient", "buildingJammerRange", 75] call EPOCH_fnc_returnConfigEntryV2;
|
||||||
_buildingCountLimit = ["CfgEpochClient", "buildingCountLimit", 200] call EPOCH_fnc_returnConfigEntryV2;
|
_buildingCountLimit = ["CfgEpochClient", "buildingCountLimit", 200] call EPOCH_fnc_returnConfigEntryV2;
|
||||||
|
_partCheck = _item in (magazines player);
|
||||||
_buildClass = getText(configfile >> "CfgMagazines" >> _item >> "buildClass");
|
_buildClass = getText(configfile >> "CfgMagazines" >> _item >> "buildClass");
|
||||||
if (_buildClass != "") then {
|
if (_buildClass != "" && _partCheck) then {
|
||||||
_isStorage = getNumber(configfile >> "CfgMagazines" >> _item >> "isStorage");
|
_isStorage = getNumber(configfile >> "CfgMagazines" >> _item >> "isStorage");
|
||||||
|
|
||||||
_isOk = if (_isStorage == 1 || _buildClass isKindOf "Secure_Storage_Temp") then { EPOCH_StorageSlotsCount > 0 } else { EPOCH_BuildingSlotCount > 0 };
|
_isOk = if (_isStorage == 1 || _buildClass isKindOf "Secure_Storage_Temp") then { EPOCH_StorageSlotsCount > 0 } else { EPOCH_BuildingSlotCount > 0 };
|
||||||
|
@ -1 +1 @@
|
|||||||
build=438;
|
build=439;
|
||||||
|
@ -1 +1 @@
|
|||||||
build=438;
|
build=439;
|
||||||
|
@ -72,7 +72,7 @@ for "_i" from 0 to _this do {
|
|||||||
// remove old safes on && !(_class isKindOf 'Constructions_lockedstatic_F')
|
// remove old safes on && !(_class isKindOf 'Constructions_lockedstatic_F')
|
||||||
if (isClass (configFile >> "CfgVehicles" >> _class) && (_damage < 1) && !(_class isKindOf 'Constructions_lockedstatic_F')) then {
|
if (isClass (configFile >> "CfgVehicles" >> _class) && (_damage < 1) && !(_class isKindOf 'Constructions_lockedstatic_F')) then {
|
||||||
|
|
||||||
_baseObj = createVehicle [_class, _location, [], 0, "CAN_COLLIDE"];
|
_baseObj = createVehicle [_class, [0,0,0], [], 0, "CAN_COLLIDE"];
|
||||||
|
|
||||||
_baseObj setposATL _location;
|
_baseObj setposATL _location;
|
||||||
_baseObj setVectorDirAndUp _worldspace;
|
_baseObj setVectorDirAndUp _worldspace;
|
||||||
@ -81,7 +81,7 @@ for "_i" from 0 to _this do {
|
|||||||
_ammoClass = (configFile >> "CfgVehicles" >> _class >> "ammoClass");
|
_ammoClass = (configFile >> "CfgVehicles" >> _class >> "ammoClass");
|
||||||
if(isText _ammoClass) then {
|
if(isText _ammoClass) then {
|
||||||
_ammoClass = getText _ammoClass;
|
_ammoClass = getText _ammoClass;
|
||||||
_ammoObj = createVehicle [_ammoClass, _location, [], 0, "CAN_COLLIDE"];
|
_ammoObj = createVehicle [_ammoClass, [0,0,0], [], 0, "CAN_COLLIDE"];
|
||||||
_ammoObj setposATL _location;
|
_ammoObj setposATL _location;
|
||||||
_ammoObj setVectorDirAndUp _worldspace;
|
_ammoObj setVectorDirAndUp _worldspace;
|
||||||
_baseObj setVariable ["EPOCH_TRAP_OBJ",_ammoObj];
|
_baseObj setVariable ["EPOCH_TRAP_OBJ",_ammoObj];
|
||||||
|
@ -81,7 +81,7 @@ if (typeOf _object == "PlotPole_EPOCH") then {
|
|||||||
_playerCryptoLimit params ["_playerCryptoLimitMax","_playerCryptoLimitMin"];
|
_playerCryptoLimit params ["_playerCryptoLimitMax","_playerCryptoLimitMin"];
|
||||||
_current_crypto = ((_current_crypto - _counter) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
_current_crypto = ((_current_crypto - _counter) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
||||||
|
|
||||||
_current_crypto remoteExec ['EPOCH_effectCrypto',(owner _player)];
|
_current_crypto remoteExec ['EPOCH_effectCrypto',_player];
|
||||||
|
|
||||||
_vars set[_cIndex, _current_crypto];
|
_vars set[_cIndex, _current_crypto];
|
||||||
_player setVariable["VARS", _vars];
|
_player setVariable["VARS", _vars];
|
||||||
|
@ -41,7 +41,7 @@ if (_vehSlot != -1 || _storageSlot != "ABORT" || _isTemporary == 1) then{
|
|||||||
_gwh = _nearbyWH select 0;
|
_gwh = _nearbyWH select 0;
|
||||||
// _posWH = getPosATL _gwh;
|
// _posWH = getPosATL _gwh;
|
||||||
} else {
|
} else {
|
||||||
_gwh = createVehicle["groundWeaponHolder", _posWH, [], 0, "CAN_COLLIDE"];
|
_gwh = createVehicle["groundWeaponHolder", [0,0,0], [], 0, "CAN_COLLIDE"];
|
||||||
_gwh setPosATL _posWH;
|
_gwh setPosATL _posWH;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -41,8 +41,7 @@ if (isText _config) then {
|
|||||||
_vectorDirAndUp = [vectordir _vehicle, vectorup _vehicle];
|
_vectorDirAndUp = [vectordir _vehicle, vectorup _vehicle];
|
||||||
deleteVehicle _vehicle;
|
deleteVehicle _vehicle;
|
||||||
|
|
||||||
_storageObj = createVehicle[_staticClass, _vehiclePos, [], 0, "CAN_COLLIDE"];
|
_storageObj = createVehicle[_staticClass, [0,0,0], [], 0, "CAN_COLLIDE"];
|
||||||
|
|
||||||
_storageObj setposATL _vehiclePos;
|
_storageObj setposATL _vehiclePos;
|
||||||
_storageObj setVectorDirAndUp _vectorDirAndUp;
|
_storageObj setVectorDirAndUp _vectorDirAndUp;
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ _entities = allMissionObjects "Constructions_modular_F";
|
|||||||
if (_objSlot != -1) then {
|
if (_objSlot != -1) then {
|
||||||
_worldspace = [_currentPosition,(vectordir _x),(vectorup _x)];
|
_worldspace = [_currentPosition,(vectordir _x),(vectorup _x)];
|
||||||
deleteVehicle _x;
|
deleteVehicle _x;
|
||||||
_newObj = createVehicle [_class, (_worldspace select 0), [], 0, "CAN_COLLIDE"];
|
_newObj = createVehicle [_class, [0,0,0], [], 0, "CAN_COLLIDE"];
|
||||||
_newObj setVariable ["BUILD_SLOT",_objSlot,true];
|
_newObj setVariable ["BUILD_SLOT",_objSlot,true];
|
||||||
_newObj call EPOCH_server_buildingInit;
|
_newObj call EPOCH_server_buildingInit;
|
||||||
|
|
||||||
|
@ -36,7 +36,7 @@ if (_objSlot != -1) then {
|
|||||||
_worldspace = [getposATL _object,vectordir _object,vectorup _object];
|
_worldspace = [getposATL _object,vectordir _object,vectorup _object];
|
||||||
deleteVehicle _object;
|
deleteVehicle _object;
|
||||||
|
|
||||||
_newObj = createVehicle [_class, _worldspace select 0, [], 0, "CAN_COLLIDE"];
|
_newObj = createVehicle [_class, [0,0,0], [], 0, "CAN_COLLIDE"];
|
||||||
_newObj setVariable ["BUILD_SLOT",_objSlot,true];
|
_newObj setVariable ["BUILD_SLOT",_objSlot,true];
|
||||||
_newObj call EPOCH_server_buildingInit;
|
_newObj call EPOCH_server_buildingInit;
|
||||||
|
|
||||||
@ -53,7 +53,7 @@ if (_objSlot != -1) then {
|
|||||||
_ammoClass = (configFile >> "CfgVehicles" >> _class >> "ammoClass");
|
_ammoClass = (configFile >> "CfgVehicles" >> _class >> "ammoClass");
|
||||||
if (isText _ammoClass) then {
|
if (isText _ammoClass) then {
|
||||||
_ammoClass = getText _ammoClass;
|
_ammoClass = getText _ammoClass;
|
||||||
_ammoObj = createVehicle [_ammoClass, _worldspace select 0, [], 0, "CAN_COLLIDE"];
|
_ammoObj = createVehicle [_ammoClass, [0,0,0], [], 0, "CAN_COLLIDE"];
|
||||||
_ammoObj setposATL (_worldspace select 0);
|
_ammoObj setposATL (_worldspace select 0);
|
||||||
_ammoObj setVectorDirAndUp [(_worldspace select 1),(_worldspace select 2)];
|
_ammoObj setVectorDirAndUp [(_worldspace select 1),(_worldspace select 2)];
|
||||||
_newObj setVariable ["EPOCH_TRAP_OBJ",_ammoObj];
|
_newObj setVariable ["EPOCH_TRAP_OBJ",_ammoObj];
|
||||||
|
@ -55,7 +55,7 @@ if (_objSlot != -1) then {
|
|||||||
deleteVehicle _object;
|
deleteVehicle _object;
|
||||||
_class = _upgrade select 0;
|
_class = _upgrade select 0;
|
||||||
|
|
||||||
_newObj = createVehicle[_class, (_worldspace select 0), [], 0, "CAN_COLLIDE"];
|
_newObj = createVehicle[_class, [0,0,0], [], 0, "CAN_COLLIDE"];
|
||||||
_newObj setposATL(_worldspace select 0);
|
_newObj setposATL(_worldspace select 0);
|
||||||
_newObj setVectorDirAndUp[(_worldspace select 1), (_worldspace select 2)];
|
_newObj setVectorDirAndUp[(_worldspace select 1), (_worldspace select 2)];
|
||||||
};
|
};
|
||||||
|
@ -40,7 +40,7 @@ if ((_response select 0) == 1 && (_response select 1) isEqualType []) then {
|
|||||||
_playerCryptoLimit params ["_playerCryptoLimitMax","_playerCryptoLimitMin"];
|
_playerCryptoLimit params ["_playerCryptoLimitMax","_playerCryptoLimitMin"];
|
||||||
_current_crypto = ((_current_crypto - _upgradePrice) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
_current_crypto = ((_current_crypto - _upgradePrice) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
||||||
// send to player
|
// send to player
|
||||||
_current_crypto remoteExec ['EPOCH_effectCrypto',(owner _player)];
|
_current_crypto remoteExec ['EPOCH_effectCrypto',_player];
|
||||||
_vars set[_cIndex, _current_crypto];
|
_vars set[_cIndex, _current_crypto];
|
||||||
_player setVariable["VARS", _vars];
|
_player setVariable["VARS", _vars];
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@ if !(isNull _object) then {
|
|||||||
|
|
||||||
deleteVehicle _object;
|
deleteVehicle _object;
|
||||||
|
|
||||||
_item = createVehicle["groundWeaponHolder", _pos, [], 0.0, "CAN_COLLIDE"];
|
_item = createVehicle["groundWeaponHolder", [0,0,0], [], 0.0, "CAN_COLLIDE"];
|
||||||
_item setPosATL _pos;
|
_item setPosATL _pos;
|
||||||
|
|
||||||
_class = "SeaFood";
|
_class = "SeaFood";
|
||||||
|
@ -267,7 +267,7 @@ if (_slot != -1) then {
|
|||||||
_playerCryptoLimit params ["_playerCryptoLimitMax","_playerCryptoLimitMin"];
|
_playerCryptoLimit params ["_playerCryptoLimitMax","_playerCryptoLimitMin"];
|
||||||
_current_crypto = ((_current_cryptoRaw + _tradeTotal) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
_current_crypto = ((_current_cryptoRaw + _tradeTotal) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
||||||
// send to player
|
// send to player
|
||||||
_current_crypto remoteExec ['EPOCH_effectCrypto',(owner _player)];
|
_current_crypto remoteExec ['EPOCH_effectCrypto',_player];
|
||||||
_vars set[_cIndex, _current_crypto];
|
_vars set[_cIndex, _current_crypto];
|
||||||
_player setVariable["VARS", _vars];
|
_player setVariable["VARS", _vars];
|
||||||
};
|
};
|
||||||
|
@ -44,7 +44,7 @@ if ((_player1 getVariable["currentTradeKey", -1]) isEqualto (_player2 getVariabl
|
|||||||
|
|
||||||
_current_crypto1 = ((_current_crypto1 - _tradeCryptoOffer1) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
_current_crypto1 = ((_current_crypto1 - _tradeCryptoOffer1) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
||||||
// send to player
|
// send to player
|
||||||
_current_crypto1 remoteExec ['EPOCH_effectCrypto',(owner _player1)];
|
_current_crypto1 remoteExec ['EPOCH_effectCrypto',_player1];
|
||||||
_player1_vars set[_cIndex, _current_crypto1];
|
_player1_vars set[_cIndex, _current_crypto1];
|
||||||
_player1 setVariable["VARS", _player1_vars];
|
_player1 setVariable["VARS", _player1_vars];
|
||||||
};
|
};
|
||||||
@ -64,7 +64,7 @@ if ((_player1 getVariable["currentTradeKey", -1]) isEqualto (_player2 getVariabl
|
|||||||
|
|
||||||
_current_crypto1 = ((_current_crypto1 + _tradeCryptoOffer2) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
_current_crypto1 = ((_current_crypto1 + _tradeCryptoOffer2) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
||||||
// send to player
|
// send to player
|
||||||
_current_crypto1 remoteExec ['EPOCH_effectCrypto',(owner _player1)];
|
_current_crypto1 remoteExec ['EPOCH_effectCrypto',_player1];
|
||||||
_player1_vars set[_cIndex, _current_crypto1];
|
_player1_vars set[_cIndex, _current_crypto1];
|
||||||
_player1 setVariable["VARS", _player1_vars];
|
_player1 setVariable["VARS", _player1_vars];
|
||||||
};
|
};
|
||||||
|
@ -33,7 +33,7 @@ if (_getCrypto > 0) then {
|
|||||||
_playerCryptoLimit params ["_playerCryptoLimitMax","_playerCryptoLimitMin"];
|
_playerCryptoLimit params ["_playerCryptoLimitMax","_playerCryptoLimitMin"];
|
||||||
_current_crypto = ((_current_crypto + _getCrypto) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
_current_crypto = ((_current_crypto + _getCrypto) min _playerCryptoLimitMax) max _playerCryptoLimitMin;
|
||||||
// send to player
|
// send to player
|
||||||
_current_crypto remoteExec ['EPOCH_effectCrypto',(owner _player)];
|
_current_crypto remoteExec ['EPOCH_effectCrypto',_player];
|
||||||
_vars set[_cIndex, _current_crypto];
|
_vars set[_cIndex, _current_crypto];
|
||||||
_player setVariable["VARS", _vars];
|
_player setVariable["VARS", _vars];
|
||||||
};
|
};
|
||||||
|
@ -76,10 +76,10 @@ if (_logic) then {
|
|||||||
} else {
|
} else {
|
||||||
if (_value) then {
|
if (_value) then {
|
||||||
// send to player
|
// send to player
|
||||||
[_vehicle, true] remoteExec ['EPOCH_client_lockVehicle',(owner _vehicle)];
|
[_vehicle, true] remoteExec ['EPOCH_client_lockVehicle',_vehicle];
|
||||||
} else {
|
} else {
|
||||||
// send to player
|
// send to player
|
||||||
[_vehicle, false] remoteExec ['EPOCH_client_lockVehicle',(owner _vehicle)];
|
[_vehicle, false] remoteExec ['EPOCH_client_lockVehicle',_vehicle];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -23,7 +23,7 @@ if ((_value select 0) isEqualTo "ALL") then {
|
|||||||
if (local _vehicle) then {
|
if (local _vehicle) then {
|
||||||
_vehicle setHitIndex _value;
|
_vehicle setHitIndex _value;
|
||||||
} else {
|
} else {
|
||||||
[_vehicle, _value] remoteExec ['EPOCH_client_repairVehicle',(owner _vehicle)];
|
[_vehicle, _value] remoteExec ['EPOCH_client_repairVehicle',_vehicle];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
_vehicle call EPOCH_server_save_vehicle;
|
_vehicle call EPOCH_server_save_vehicle;
|
||||||
|
@ -1089,7 +1089,7 @@ call compile ("'"+_skn_doAdminRequest+"' addPublicVariableEventHandler {
|
|||||||
_cIndex = EPOCH_customVars find 'Crypto';
|
_cIndex = EPOCH_customVars find 'Crypto';
|
||||||
_vars = _player getVariable['VARS', call EPOCH_defaultVars_SEPXVar];
|
_vars = _player getVariable['VARS', call EPOCH_defaultVars_SEPXVar];
|
||||||
_current_crypto = (((_vars select _cIndex) + (_content select 1)) min "+str _skn_playerCryptoLimit+") max 0;
|
_current_crypto = (((_vars select _cIndex) + (_content select 1)) min "+str _skn_playerCryptoLimit+") max 0;
|
||||||
_current_crypto remoteExec ['EPOCH_effectCrypto',(owner _player)];
|
_current_crypto remoteExec ['EPOCH_effectCrypto',_player];
|
||||||
_vars set[_cIndex, _current_crypto];
|
_vars set[_cIndex, _current_crypto];
|
||||||
_player setVariable['VARS', _vars];
|
_player setVariable['VARS', _vars];
|
||||||
if (_player == _admin) then {
|
if (_player == _admin) then {
|
||||||
|
@ -1 +1 @@
|
|||||||
build=438;
|
build=439;
|
||||||
|
@ -17,7 +17,7 @@ if ((count _position) == 2) then{
|
|||||||
if ((random 1) > _chance) then {
|
if ((random 1) > _chance) then {
|
||||||
// send earthquake to each player in zone
|
// send earthquake to each player in zone
|
||||||
{
|
{
|
||||||
[_position] remoteExec ['EPOCH_client_earthQuake',(owner _x)];
|
[_position] remoteExec ['EPOCH_client_earthQuake',_x];
|
||||||
}forEach _playersNearEpicenter;
|
}forEach _playersNearEpicenter;
|
||||||
|
|
||||||
// todo configize
|
// todo configize
|
||||||
|
@ -1 +1 @@
|
|||||||
build=438;
|
build=439;
|
||||||
|
Loading…
Reference in New Issue
Block a user