mirror of
https://github.com/EpochModTeam/DayZ-Epoch.git
synced 2025-12-22 20:12:20 +03:00
+ Added variable pricing to traders. Stock under 5 will be sold at the buy price and over 50 will be bought at the sell price. + Fixed trades not forcing a gear save and added more forced gear saves. + Added test for time based UID for purchased vehicles. + Reduced humanity gained by using a blood bag to 100 down from 250. + Added 5 minute penalty knockout for combat loggers. + Added prevention to logging out in a trader city. fixes #171 + Changed cargo check to only show on alive vehicles. Fixes #176 + Potential fix for gunner on armored SUV. Fixes #172 + Fixes for refueling and repairing that was broken by 1.7.61 + Removed taming of dogs for now. fixes #162
97 lines
2.4 KiB
Plaintext
97 lines
2.4 KiB
Plaintext
private["_vehicle","_part","_hitpoint","_type","_selection","_array"];
|
|
|
|
disableSerialization;
|
|
|
|
_id = _this select 2;
|
|
_array = _this select 3;
|
|
_vehicle = _array select 0;
|
|
_part = _array select 1;
|
|
_hitpoint = _array select 2;
|
|
_type = typeOf _vehicle;
|
|
|
|
|
|
// if ((count (crew _vehicle)) > 0) exitWith {cutText ["You may not salvage while someone is in the vehicle", "PLAIN DOWN"]};
|
|
|
|
_isOK = false;
|
|
_brokenPart = false;
|
|
|
|
//
|
|
_hasToolbox = "ItemToolbox" in items player;
|
|
|
|
// moving this here because we need to know which part needed if we don't have it
|
|
_nameType = getText(configFile >> "cfgVehicles" >> _type >> "displayName");
|
|
_namePart = getText(configFile >> "cfgMagazines" >> _part >> "displayName");
|
|
|
|
{_vehicle removeAction _x} forEach s_player_repairActions;s_player_repairActions = [];
|
|
s_player_repair_crtl = 1;
|
|
|
|
if (_hasToolbox) then {
|
|
|
|
|
|
|
|
_damage = [_vehicle,_hitpoint] call object_getHit;
|
|
// _vehicle removeAction _id;
|
|
|
|
//dont allow removal of damaged parts
|
|
if (_damage < 1) then {
|
|
|
|
_findPercent = (1 - _damage) * 10;
|
|
if(ceil (random _findPercent) == 1) then {
|
|
_isOK = true;
|
|
_brokenPart = true;
|
|
} else {
|
|
_isOK = [player,_part] call BIS_fnc_invAdd;
|
|
_brokenPart = false;
|
|
|
|
|
|
call dayz_forceSave;
|
|
|
|
};
|
|
|
|
|
|
if (_isOK) then {
|
|
|
|
player playActionNow "Medic";
|
|
|
|
//break the part
|
|
_selection = getText(configFile >> "cfgVehicles" >> _type >> "HitPoints" >> _hitpoint >> "name");
|
|
|
|
//vehicle is owned by whoever is in it, so we have to have each client try and fix it
|
|
//["dayzSetFix",[_vehicle,_selection,1],_vehicle] call broadcastRpcCallIfLocal;
|
|
|
|
dayzSetFix = [_vehicle,_selection,1];
|
|
publicVariable "dayzSetFix";
|
|
if (local _vehicle) then {
|
|
dayzSetFix call object_setFixServer;
|
|
};
|
|
|
|
sleep 1;
|
|
|
|
[player,"repair",0,false] call dayz_zombieSpeak;
|
|
null = [player,50,true,(getPosATL player)] spawn player_alertZombies;
|
|
sleep 5;
|
|
_vehicle setvelocity [0,0,1];
|
|
|
|
if(_brokenPart) then {
|
|
//Failed!
|
|
cutText [format["You have destroyed %1 while attempting to remove from %2",_namePart,_nameType], "PLAIN DOWN"];
|
|
} else {
|
|
//Success!
|
|
cutText [format["You have successfully removed %1 from the %2",_namePart,_nameType], "PLAIN DOWN"];
|
|
};
|
|
|
|
|
|
} else {
|
|
cutText [localize "STR_DAYZ_CODE_2", "PLAIN DOWN"];
|
|
};
|
|
|
|
|
|
};
|
|
|
|
} else {
|
|
cutText [format["You need %1 to remove this part.",_namePart], "PLAIN DOWN"];
|
|
};
|
|
|
|
|
|
dayz_myCursorTarget = objNull;
|
|
s_player_repair_crtl = -1; |