mirror of
https://github.com/EpochModTeam/Epoch.git
synced 2024-08-30 18:22:13 +00:00
0.3.8.0465
Epoch PBO packer 1.0 add playerNuisance variable a few small optimizations
This commit is contained in:
parent
c363bad748
commit
6f169cff93
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.
@ -1,149 +1,123 @@
|
|||||||
/*
|
/*
|
||||||
Author: Aaron Clark - EpochMod.com
|
Author: Aaron Clark - EpochMod.com
|
||||||
|
|
||||||
Contributors:
|
Contributors:
|
||||||
|
|
||||||
Description:
|
Description:
|
||||||
Epoch Change wall state
|
Epoch Change wall state
|
||||||
|
|
||||||
Licence:
|
Licence:
|
||||||
Arma Public License Share Alike (APL-SA) - https://www.bistudio.com/community/licenses/arma-public-license-share-alike
|
Arma Public License Share Alike (APL-SA) - https://www.bistudio.com/community/licenses/arma-public-license-share-alike
|
||||||
|
|
||||||
Github:
|
Github:
|
||||||
https://github.com/EpochModTeam/Epoch/tree/master/Sources/epoch_code/compile/building/EPOCH_changeWallState.sqf
|
https://github.com/EpochModTeam/Epoch/tree/master/Sources/epoch_code/compile/building/EPOCH_changeWallState.sqf
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
[_this,"NWall",1] call EPOCH_changeWallState;
|
[_this,"NWall",1] call EPOCH_changeWallState;
|
||||||
|
|
||||||
Parameter(s):
|
Parameter(s):
|
||||||
_this select 0: OBJECT - Base building object
|
_this select 0: OBJECT - Base building object
|
||||||
_this select 1: STRING - Name of animation
|
_this select 1: STRING - Name of animation
|
||||||
_this select 1: SCALAR - state
|
_this select 1: SCALAR - state
|
||||||
0: true = add wall
|
0: true = add wall
|
||||||
1: false = remove wall
|
1: false = remove wall
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
NOTHING
|
NOTHING
|
||||||
*/
|
*/
|
||||||
private ["_recipeItem","_recipeQty","_hasRecipeItems","_msg","_recipeCount","_currentCount","_numRemoved","_items","_mags","_recipe","_craftItem","_craftQty","_config","_objClass"];
|
private["_recipeItem", "_recipeQty", "_hasRecipeItems", "_msg", "_recipeCount", "_currentCount", "_numRemoved", "_items", "_mags", "_recipe", "_craftItem", "_craftQty", "_config", "_objClass"];
|
||||||
params [
|
params[
|
||||||
["_object",objNull],
|
["_object", objNull],
|
||||||
["_anim",""],
|
["_anim", ""],
|
||||||
["_state",0]
|
["_state", 0]
|
||||||
];
|
];
|
||||||
|
if !(isNull _object) then{
|
||||||
if !(isNull _object) then {
|
_msg = "Missing Items";
|
||||||
|
// Get config
|
||||||
_msg = "Missing Items";
|
_config = 'CfgBaseBuilding' call EPOCH_returnConfig;
|
||||||
// Get config
|
// upgradeBuildingPart
|
||||||
_config = 'CfgBaseBuilding' call EPOCH_returnConfig;
|
_objClass = typeOf _object;
|
||||||
|
// Add part
|
||||||
// upgradeBuildingPart
|
if (_state == 1) then{
|
||||||
_objClass = typeOf _object;
|
_recipe = getArray(_config >> _objClass >> "upgradeBuildingPart");
|
||||||
|
_mags = magazines player;
|
||||||
// Add part
|
_recipeCount = 0;
|
||||||
if (_state == 1) then {
|
_numRemoved = 0;
|
||||||
_recipe = getArray(_config >> _objClass >> "upgradeBuildingPart");
|
_hasRecipeItems = true;
|
||||||
|
// Dry Run
|
||||||
_mags = magazines player;
|
{
|
||||||
|
_recipeItem = _x;
|
||||||
_recipeCount = 0;
|
_recipeQty = 1;
|
||||||
_numRemoved = 0;
|
if (_x isEqualType[]) then{
|
||||||
_hasRecipeItems = true;
|
_recipeItem = _x select 0;
|
||||||
|
_recipeQty = _x select 1;
|
||||||
// Dry Run
|
};
|
||||||
{
|
_recipeCount = _recipeCount + _recipeQty;
|
||||||
_recipeItem = _x;
|
_currentCount = { _x == _recipeItem } count _mags;
|
||||||
_recipeQty = 1;
|
if (_currentCount < _recipeQty) exitWith{
|
||||||
if (_x isEqualType []) then {
|
_hasRecipeItems = false;
|
||||||
_recipeItem = _x select 0;
|
_msg = format["Need %2 %1 Have %3", _recipeItem call EPOCH_itemDisplayName, _recipeCount, _currentCount];
|
||||||
_recipeQty = _x select 1;
|
};
|
||||||
};
|
}forEach _recipe;
|
||||||
_recipeCount = _recipeCount + _recipeQty;
|
// remove item
|
||||||
_currentCount = { _x == _recipeItem } count _mags;
|
if (_hasRecipeItems) then{
|
||||||
if (_currentCount < _recipeQty) exitWith {
|
{
|
||||||
_hasRecipeItems = false;
|
_recipeItem = _x;
|
||||||
_msg = format["Need %2 %1 Have %3", _recipeItem call EPOCH_itemDisplayName,_recipeCount ,_currentCount];
|
_recipeQty = 1;
|
||||||
};
|
if (_x isEqualType[]) then{
|
||||||
}forEach _recipe;
|
_recipeItem = _x select 0;
|
||||||
|
_recipeQty = _x select 1;
|
||||||
// remove item
|
};
|
||||||
if (_hasRecipeItems) then {
|
if ([_recipeItem, "CfgWeapons"] call EPOCH_fnc_isAny) then{
|
||||||
{
|
_items = items player;
|
||||||
_recipeItem = _x;
|
_currentCount = { _x == _recipeItem } count _items;
|
||||||
_recipeQty = 1;
|
if (_currentCount >= _recipeQty) then{
|
||||||
if (_x isEqualType []) then {
|
for "_i" from 1 to _recipeQty do {
|
||||||
_recipeItem = _x select 0;
|
if (_recipeItem in _items) then{
|
||||||
_recipeQty = _x select 1;
|
player removeItem _recipeItem;
|
||||||
};
|
_numRemoved = _numRemoved + 1;
|
||||||
if ([_recipeItem, "CfgWeapons"] call EPOCH_fnc_isAny) then {
|
};
|
||||||
_items = items player;
|
};
|
||||||
_currentCount = { _x == _recipeItem } count _items;
|
};
|
||||||
if (_currentCount >= _recipeQty) then {
|
} else {
|
||||||
for "_i" from 1 to _recipeQty do {
|
_mags = magazines player;
|
||||||
if (_recipeItem in _items) then {
|
_currentCount = { _x == _recipeItem } count _mags;
|
||||||
player removeItem _recipeItem;
|
if (_currentCount >= _recipeQty) then{
|
||||||
_numRemoved = _numRemoved + 1;
|
for "_i" from 1 to _recipeQty do {
|
||||||
};
|
if (_recipeItem in _mags) then{
|
||||||
};
|
player removeMagazine _recipeItem;
|
||||||
};
|
_numRemoved = _numRemoved + 1;
|
||||||
|
};
|
||||||
} else {
|
};
|
||||||
|
};
|
||||||
_mags = magazines player;
|
};
|
||||||
_currentCount = { _x == _recipeItem } count _mags;
|
}forEach _recipe;
|
||||||
if (_currentCount >= _recipeQty) then {
|
};
|
||||||
for "_i" from 1 to _recipeQty do {
|
if (_numRemoved == _recipeCount) then{
|
||||||
if (_recipeItem in _mags) then {
|
_object animate[_anim, _state, true];
|
||||||
player removeMagazine _recipeItem;
|
// push interacted object to queue to save later
|
||||||
_numRemoved = _numRemoved + 1;
|
EPOCH_arr_interactedObjs pushBackUnique _object;
|
||||||
};
|
[format["<t size='1.6' color='#99ffffff'>%1 part on %2</t>", "Added", _objClass call EPOCH_itemDisplayName], 5] call Epoch_dynamicText;
|
||||||
};
|
} else {
|
||||||
};
|
[format["<t size='1.6' color='#99ffffff'>%1</t>", _msg], 5] call Epoch_dynamicText;
|
||||||
};
|
};
|
||||||
|
} else {
|
||||||
}forEach _recipe;
|
// Remove part
|
||||||
};
|
_recipe = getArray(_config >> _objClass >> "removeBuildingPart");
|
||||||
|
_object animate[_anim, _state, true];
|
||||||
if (_numRemoved == _recipeCount) then {
|
// push interacted object to save queue to save later
|
||||||
_object animate [_anim, _state, true];
|
EPOCH_arr_interactedObjs pushBackUnique _object;
|
||||||
|
{
|
||||||
// push interacted object to queue to save later
|
_craftItem = _x;
|
||||||
EPOCH_arr_interactedObjs pushBackUnique _object;
|
_craftQty = 1;
|
||||||
|
if (_x isEqualType[]) then{
|
||||||
[format["<t size='1.6' color='#99ffffff'>%1 part on %2</t>","Added",_objClass call EPOCH_itemDisplayName],5] call Epoch_dynamicText;
|
_craftItem = _x select 0;
|
||||||
|
_craftQty = _x select 1;
|
||||||
[format["<t size='1.6' color='#99ffffff'>%1 part on %2</t>","Added",_objClass call EPOCH_itemDisplayName], 5] call Epoch_dynamicText;
|
};
|
||||||
|
for "_i" from 1 to _craftQty do {
|
||||||
} else {
|
_craftItem call EPOCH_fnc_addItemOverflow;
|
||||||
[format["<t size='1.6' color='#99ffffff'>%1</t>", _msg], 5] call Epoch_dynamicText;
|
};
|
||||||
};
|
}forEach _recipe;
|
||||||
|
[format["<t size='1.6' color='#99ffffff'>%1 part on %2</t>", "Removed", _objClass call EPOCH_itemDisplayName], 5] call Epoch_dynamicText;
|
||||||
|
};
|
||||||
|
|
||||||
} else {
|
|
||||||
|
|
||||||
// Remove part
|
|
||||||
_recipe = getArray(_config >> _objClass >> "removeBuildingPart");
|
|
||||||
|
|
||||||
_object animate [_anim, _state, true];
|
|
||||||
|
|
||||||
// push interacted object to save queue to save later
|
|
||||||
EPOCH_arr_interactedObjs pushBackUnique _object;
|
|
||||||
|
|
||||||
{
|
|
||||||
_craftItem = _x;
|
|
||||||
_craftQty = 1;
|
|
||||||
if (_x isEqualType []) then {
|
|
||||||
_craftItem = _x select 0;
|
|
||||||
_craftQty = _x select 1;
|
|
||||||
};
|
|
||||||
for "_i" from 1 to _craftQty do {
|
|
||||||
_craftItem call EPOCH_fnc_addItemOverflow;
|
|
||||||
};
|
|
||||||
}forEach _recipe;
|
|
||||||
|
|
||||||
[format["<t size='1.6' color='#99ffffff'>%1 part on %2</t>","Removed",_objClass call EPOCH_itemDisplayName], 5] call Epoch_dynamicText;
|
|
||||||
};
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -174,10 +174,7 @@ if (isText(_simulClassConfig)) then {
|
|||||||
} forEach _snapArrayPerp;
|
} forEach _snapArrayPerp;
|
||||||
};
|
};
|
||||||
if (_isSnap && _distance < 5) then {
|
if (_isSnap && _distance < 5) then {
|
||||||
_pos2 = _snapPosition;
|
_pos2 = AGLToASL _snapPosition;
|
||||||
if (!surfaceIsWater _pos2) then {
|
|
||||||
_pos2 = ATLtoASL _pos2;
|
|
||||||
};
|
|
||||||
_vel2 = (velocity _nearestObject);
|
_vel2 = (velocity _nearestObject);
|
||||||
_direction = getDir _nearestObject;
|
_direction = getDir _nearestObject;
|
||||||
if (_snapType == "perp") then {
|
if (_snapType == "perp") then {
|
||||||
|
@ -27,23 +27,21 @@
|
|||||||
Returns:
|
Returns:
|
||||||
NOTHING
|
NOTHING
|
||||||
*/
|
*/
|
||||||
private ["_heal","_highestDMG","_currentHIT","_currentDMG","_newDMG","_attachments","_cursorTarget","_repaired","_gesture","_droneChance"];
|
private ["_heal","_highestDMG","_currentHIT","_currentDMG","_newDMG","_attachments","_cursorTarget","_repaired","_gesture","_nuisanceLevel"];
|
||||||
params ["_unit","_weapon","_muzzle","_mode","_ammo","_magazine","_projectile"];
|
params ["_unit","_weapon","_muzzle","_mode","_ammo","_magazine","_projectile"];
|
||||||
|
EPOCH_lastFiredLocation = getPosATL player;
|
||||||
switch true do {
|
switch true do {
|
||||||
case (_ammo isKindOf "B_EnergyPack"): {
|
case (_ammo isKindOf "B_EnergyPack"): {
|
||||||
if (!isNull cursorTarget) then {
|
if (!isNull cursorTarget) then {
|
||||||
_cursorTarget = cursorTarget;
|
_cursorTarget = cursorTarget;
|
||||||
_repaired = false;
|
_repaired = false;
|
||||||
if ((player distance _cursorTarget) <= 6) then {
|
if ((player distance _cursorTarget) <= 6) then {
|
||||||
|
|
||||||
_attachments = handgunItems player;
|
_attachments = handgunItems player;
|
||||||
_heal = false;
|
_heal = false;
|
||||||
|
|
||||||
if (_cursorTarget isKindOf "Man") then {
|
if (_cursorTarget isKindOf "Man") then {
|
||||||
if ("Heal_EPOCH" in _attachments) then {
|
if ("Heal_EPOCH" in _attachments) then {
|
||||||
_heal = true;
|
_heal = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
if ("Defib_EPOCH" in _attachments) then {
|
if ("Defib_EPOCH" in _attachments) then {
|
||||||
if (!alive _cursorTarget) then {
|
if (!alive _cursorTarget) then {
|
||||||
[_cursorTarget,player,Epoch_personalToken] remoteExec ["EPOCH_server_revivePlayer",2];
|
[_cursorTarget,player,Epoch_personalToken] remoteExec ["EPOCH_server_revivePlayer",2];
|
||||||
@ -65,11 +63,8 @@ switch true do {
|
|||||||
_currentHIT = _forEachIndex;
|
_currentHIT = _forEachIndex;
|
||||||
};
|
};
|
||||||
}forEach((getAllHitPointsDamage _cursorTarget) param[2,[]]);
|
}forEach((getAllHitPointsDamage _cursorTarget) param[2,[]]);
|
||||||
|
|
||||||
if (_highestDMG > 0) then {
|
if (_highestDMG > 0) then {
|
||||||
|
|
||||||
_newDMG = ((_highestDMG - 0.5) max 0);
|
_newDMG = ((_highestDMG - 0.5) max 0);
|
||||||
|
|
||||||
if (local _cursorTarget) then {
|
if (local _cursorTarget) then {
|
||||||
[_cursorTarget,[_currentHIT,_newDMG]] call EPOCH_client_repairVehicle;
|
[_cursorTarget,[_currentHIT,_newDMG]] call EPOCH_client_repairVehicle;
|
||||||
} else {
|
} else {
|
||||||
@ -84,13 +79,11 @@ switch true do {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
case (_ammo isKindOf "B_Hatchet"): {
|
case (_ammo isKindOf "B_Hatchet"): {
|
||||||
_gesture = selectRandom ["GestureSwing0", "GestureSwing1", "GestureSwing2"];
|
_gesture = selectRandom ["GestureSwing0", "GestureSwing1", "GestureSwing2"];
|
||||||
player playActionNow _gesture;
|
player playActionNow _gesture;
|
||||||
call EPOCH_chopWood;
|
call EPOCH_chopWood;
|
||||||
};
|
};
|
||||||
|
|
||||||
case (_ammo isKindOf "B_Swing" || _ammo isKindOf "B_Stick") : {
|
case (_ammo isKindOf "B_Swing" || _ammo isKindOf "B_Stick") : {
|
||||||
player playActionNow "SledgeSwing";
|
player playActionNow "SledgeSwing";
|
||||||
call EPOCH_mineRocks;
|
call EPOCH_mineRocks;
|
||||||
@ -101,23 +94,26 @@ switch true do {
|
|||||||
call EPOCH_fish;
|
call EPOCH_fish;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
case (_ammo isKindOf "ChainSaw_Bullet"): {
|
case (_ammo isKindOf "ChainSaw_Bullet"): {
|
||||||
call EPOCH_chopWood;
|
call EPOCH_chopWood;
|
||||||
};
|
};
|
||||||
|
|
||||||
default {
|
default {
|
||||||
_droneChance = 2;
|
_ammoConfig = (configFile >> "CfgAmmo" >> _ammo);
|
||||||
if !(EPOCH_nearestLocations isEqualTo[]) then{
|
_nuisanceLevel = ceil(getNumber (_ammoConfig >> "audibleFire") * getNumber (_ammoConfig >> "caliber"));
|
||||||
_droneChance = _droneChance * 2;
|
// reduce when not in a city or town
|
||||||
|
if (EPOCH_nearestLocations isEqualTo[]) then{
|
||||||
|
_nuisanceLevel = _nuisanceLevel / 2;
|
||||||
};
|
};
|
||||||
// reduce chance to spawn by 50% if weapon has silencer
|
// reduce if using a silencer
|
||||||
if (((player weaponAccessories _muzzle) select 0) != "") then{
|
if (((player weaponAccessories _muzzle) select 0) != "") then{
|
||||||
_droneChance = _droneChance / 2;
|
_nuisanceLevel = _nuisanceLevel / 2;
|
||||||
};
|
};
|
||||||
// 2% chance (+ 4% chance if in city) to spawn drone if shot fired (1% - 2% Half if using silencer)
|
// force spawn increase once player has become a Nuisance
|
||||||
if (random EPOCH_droneRndChance < _droneChance) then{
|
if (EPOCH_playerNuisance >= 50 && {random EPOCH_droneRndChance < EPOCH_playerNuisance}) then{
|
||||||
"I_UAV_01_F" call EPOCH_unitSpawnIncrease;
|
(selectRandom ["I_UAV_01_F","Epoch_Sapper_F"]) call EPOCH_unitSpawnIncrease;
|
||||||
};
|
};
|
||||||
|
// Nuisance System 0.1
|
||||||
|
(EPOCH_customVarLimits select (EPOCH_customVars find "Nuisance")) params [["_playerLimitMax",100],["_playerLimitMin",0]];
|
||||||
|
EPOCH_playerNuisance = ((EPOCH_playerNuisance + _nuisanceLevel) min _playerLimitMax) max _playerLimitMin;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -20,7 +20,7 @@ if (damage player != _damagePlayer) then {
|
|||||||
_energyValue = EPOCH_chargeRate min _energyRegenMax;
|
_energyValue = EPOCH_chargeRate min _energyRegenMax;
|
||||||
_vehicle = vehicle player;
|
_vehicle = vehicle player;
|
||||||
if (_vehicle != player && isEngineOn _vehicle) then {
|
if (_vehicle != player && isEngineOn _vehicle) then {
|
||||||
_energyValue = _energyValue + 5;
|
_energyValue = _energyValue + 5;
|
||||||
};
|
};
|
||||||
|
|
||||||
if (currentVisionMode player == 1) then { //NV enabled
|
if (currentVisionMode player == 1) then { //NV enabled
|
||||||
@ -45,7 +45,6 @@ if !(EPOCH_playerEnergy isEqualTo _prevEnergy) then {
|
|||||||
_display3 = uiNamespace getVariable "EPOCH_EpochGameUI3";
|
_display3 = uiNamespace getVariable "EPOCH_EpochGameUI3";
|
||||||
_energyDiff = round(EPOCH_playerEnergy - _prevEnergy);
|
_energyDiff = round(EPOCH_playerEnergy - _prevEnergy);
|
||||||
_diffText = if (_energyDiff > 0) then {format["+%1",_energyDiff]} else {format["%1",_energyDiff]};
|
_diffText = if (_energyDiff > 0) then {format["+%1",_energyDiff]} else {format["%1",_energyDiff]};
|
||||||
// hint str [_energyValue,_prevEnergy,EPOCH_playerEnergy];
|
|
||||||
(_display3 displayCtrl 21210) ctrlSetText format["%1/%2 %3", round(EPOCH_playerEnergy), EPOCH_playerEnergyMax, _diffText];
|
(_display3 displayCtrl 21210) ctrlSetText format["%1/%2 %3", round(EPOCH_playerEnergy), EPOCH_playerEnergyMax, _diffText];
|
||||||
_prevEnergy = EPOCH_playerEnergy;
|
_prevEnergy = EPOCH_playerEnergy;
|
||||||
};
|
};
|
||||||
@ -67,7 +66,6 @@ if !(_attackers isEqualTo[]) then {
|
|||||||
(_attackers select 0) call EPOCH_client_bitePlayer;
|
(_attackers select 0) call EPOCH_client_bitePlayer;
|
||||||
_panic = true;
|
_panic = true;
|
||||||
} else {
|
} else {
|
||||||
// custom poision
|
|
||||||
_toxicObjs = player nearobjects["SmokeShellCustom", 6];
|
_toxicObjs = player nearobjects["SmokeShellCustom", 6];
|
||||||
if!(_toxicObjs IsEqualTo[]) then {
|
if!(_toxicObjs IsEqualTo[]) then {
|
||||||
(_toxicObjs select 0) call EPOCH_client_bitePlayer;
|
(_toxicObjs select 0) call EPOCH_client_bitePlayer;
|
||||||
@ -95,3 +93,7 @@ EPOCH_playerThirst = (EPOCH_playerThirst - _HTlossRate) max 0;
|
|||||||
call _lootBubble;
|
call _lootBubble;
|
||||||
|
|
||||||
EPOCH_playerStaminaMax = (100 * (round(EPOCH_playerAliveTime/360)/10)) min 2500;
|
EPOCH_playerStaminaMax = (100 * (round(EPOCH_playerAliveTime/360)/10)) min 2500;
|
||||||
|
|
||||||
|
// downtick Nuisance
|
||||||
|
(EPOCH_customVarLimits select (EPOCH_customVars find "Nuisance")) params [["_playerLimitMax",100],["_playerLimitMin",0]];
|
||||||
|
EPOCH_playerNuisance = ((EPOCH_playerNuisance - 1) min _playerLimitMax) max _playerLimitMin;
|
||||||
|
@ -1,11 +1,4 @@
|
|||||||
_nearByBobbersLocal = [];
|
_nearByBobbersLocal = (player nearEntities[["Bobber_EPOCH"], 12]) select {local _x};
|
||||||
_nearByBobbers = player nearEntities[["Bobber_EPOCH"], 12];
|
|
||||||
{
|
|
||||||
if (local _x) then {
|
|
||||||
_nearByBobbersLocal pushBack _x
|
|
||||||
}
|
|
||||||
} forEach _nearByBobbers;
|
|
||||||
|
|
||||||
if !(_nearByBobbersLocal isEqualTo []) then {
|
if !(_nearByBobbersLocal isEqualTo []) then {
|
||||||
if ((random 100) < 50) then {
|
if ((random 100) < 50) then {
|
||||||
_bobber = selectRandom _nearByBobbersLocal;
|
_bobber = selectRandom _nearByBobbersLocal;
|
||||||
|
@ -54,6 +54,7 @@ EPOCH_soundLevel = 1;
|
|||||||
EPOCH_arr_interactedObjs = [];
|
EPOCH_arr_interactedObjs = [];
|
||||||
EPOCH_buildOption = 0;
|
EPOCH_buildOption = 0;
|
||||||
EPOCH_nearestLocations = [];
|
EPOCH_nearestLocations = [];
|
||||||
|
EPOCH_lastFiredLocation = [];
|
||||||
|
|
||||||
["EPOCH_onEachFrame", "onEachFrame", EPOCH_onEachFrame] call BIS_fnc_addStackedEventHandler;
|
["EPOCH_onEachFrame", "onEachFrame", EPOCH_onEachFrame] call BIS_fnc_addStackedEventHandler;
|
||||||
|
|
||||||
|
@ -51,7 +51,8 @@ class CfgEpochClient
|
|||||||
{"SpawnArray",{},{}},
|
{"SpawnArray",{},{}},
|
||||||
{"Karma",0,{50000,-50000}},
|
{"Karma",0,{50000,-50000}},
|
||||||
{"Alcohol",0,{100,0}},
|
{"Alcohol",0,{100,0}},
|
||||||
{"Radiation",0,{100,0}}
|
{"Radiation",0,{100,0}},
|
||||||
|
{"Nuisance",0,{100,0}}
|
||||||
};
|
};
|
||||||
// controls max group limit and cost
|
// controls max group limit and cost
|
||||||
group_upgrade_lvl[] = {4,"100",6,"300",8,"500",10,"1000",12,"1500",13,"1750",14,"2000",15,"3000",16,"5000"};
|
group_upgrade_lvl[] = {4,"100",6,"300",8,"500",10,"1000",12,"1500",13,"1750",14,"2000",15,"3000",16,"5000"};
|
||||||
|
@ -1 +1 @@
|
|||||||
build=456;
|
build=465;
|
||||||
|
@ -1 +1 @@
|
|||||||
build=456;
|
build=465;
|
||||||
|
@ -54,6 +54,7 @@ if (isNil "_instanceID") exitWith{
|
|||||||
|
|
||||||
EPOCH_modCUPWeaponsEnabled = (getNumber (configFile >> "CfgPatches" >> "CUP_WheeledVehicles_Core" >> "requiredVersion") > 0);
|
EPOCH_modCUPWeaponsEnabled = (getNumber (configFile >> "CfgPatches" >> "CUP_WheeledVehicles_Core" >> "requiredVersion") > 0);
|
||||||
EPOCH_modCUPVehiclesEnabled = (getNumber (configFile >> "CfgPatches" >> "CUP_Weapons_WeaponsCore" >> "requiredVersion") > 0);
|
EPOCH_modCUPVehiclesEnabled = (getNumber (configFile >> "CfgPatches" >> "CUP_Weapons_WeaponsCore" >> "requiredVersion") > 0);
|
||||||
|
EPOCH_mod_Ryanzombies_Enabled = (parseNumber (getText (configFile >> "CfgPatches" >> "Ryanzombies" >> "version")) >= 4.2);
|
||||||
|
|
||||||
if (EPOCH_modCUPWeaponsEnabled) then {
|
if (EPOCH_modCUPWeaponsEnabled) then {
|
||||||
diag_log "Epoch: CUP Weapons detected";
|
diag_log "Epoch: CUP Weapons detected";
|
||||||
@ -61,6 +62,9 @@ if (EPOCH_modCUPWeaponsEnabled) then {
|
|||||||
if (EPOCH_modCUPVehiclesEnabled) then {
|
if (EPOCH_modCUPVehiclesEnabled) then {
|
||||||
diag_log "Epoch: CUP Vehicles detected";
|
diag_log "Epoch: CUP Vehicles detected";
|
||||||
};
|
};
|
||||||
|
if (EPOCH_mod_Ryanzombies_Enabled) then {
|
||||||
|
diag_log "Epoch: Ryanzombies detected";
|
||||||
|
};
|
||||||
|
|
||||||
diag_log "Epoch: Init Variables";
|
diag_log "Epoch: Init Variables";
|
||||||
call compile preprocessFileLineNumbers "\epoch_server\init\server_variables.sqf";
|
call compile preprocessFileLineNumbers "\epoch_server\init\server_variables.sqf";
|
||||||
|
@ -1 +1 @@
|
|||||||
build=456;
|
build=465;
|
||||||
|
@ -1 +1 @@
|
|||||||
build=456;
|
build=465;
|
||||||
|
BIN
Tools/PowerShell/PBO_packaging_tool_GUI.exe
Normal file
BIN
Tools/PowerShell/PBO_packaging_tool_GUI.exe
Normal file
Binary file not shown.
@ -5,18 +5,22 @@
|
|||||||
# <arguments />
|
# <arguments />
|
||||||
# <extractdir>%TEMP%</extractdir>
|
# <extractdir>%TEMP%</extractdir>
|
||||||
# <files />
|
# <files />
|
||||||
# <usedefaulticon>true</usedefaulticon>
|
# <usedefaulticon>false</usedefaulticon>
|
||||||
|
# <icon>F:\ARCHIVE\Downloads\logo_only_1024.ico</icon>
|
||||||
# <showinsystray>false</showinsystray>
|
# <showinsystray>false</showinsystray>
|
||||||
|
# <tooltip>Epoch Mod PBO Packer</tooltip>
|
||||||
# <altcreds>false</altcreds>
|
# <altcreds>false</altcreds>
|
||||||
# <efs>true</efs>
|
# <efs>true</efs>
|
||||||
# <ntfs>true</ntfs>
|
# <ntfs>true</ntfs>
|
||||||
# <local>false</local>
|
# <local>false</local>
|
||||||
# <abortonfail>true</abortonfail>
|
# <abortonfail>true</abortonfail>
|
||||||
# <product />
|
# <product>Epoch PBO Packing Tool</product>
|
||||||
|
# <internalname>Epoch PBO Packing Tool </internalname>
|
||||||
# <version>1.0.0.1</version>
|
# <version>1.0.0.1</version>
|
||||||
# <versionstring />
|
# <versionstring>1.0</versionstring>
|
||||||
# <comments />
|
# <description>Tool to aid in the packing of Epoch Mod source files</description>
|
||||||
# <company />
|
# <comments>By Raimonds Virtoss and Aaron Clark</comments>
|
||||||
|
# <company>EpochMod.com</company>
|
||||||
# <includeinterpreter>false</includeinterpreter>
|
# <includeinterpreter>false</includeinterpreter>
|
||||||
# <forcecomregistration>false</forcecomregistration>
|
# <forcecomregistration>false</forcecomregistration>
|
||||||
# <consolemode>false</consolemode>
|
# <consolemode>false</consolemode>
|
||||||
@ -65,7 +69,7 @@ $Label4.Anchor = ([System.Windows.Forms.AnchorStyles]([System.Windows.Forms.Anch
|
|||||||
$Label4.Location = New-Object System.Drawing.Point(12, 9)
|
$Label4.Location = New-Object System.Drawing.Point(12, 9)
|
||||||
$Label4.Size = New-Object System.Drawing.Size(808, 18)
|
$Label4.Size = New-Object System.Drawing.Size(808, 18)
|
||||||
$Label4.TabIndex = 1
|
$Label4.TabIndex = 1
|
||||||
$Label4.Text = "Why do farts smell? So deaf people can enjoy them too."
|
$Label4.Text = ""
|
||||||
$Label4.TextAlign = [System.Drawing.ContentAlignment]::MiddleCenter
|
$Label4.TextAlign = [System.Drawing.ContentAlignment]::MiddleCenter
|
||||||
$Label4.add_Click({Label4Click($Label4)})
|
$Label4.add_Click({Label4Click($Label4)})
|
||||||
#~~< TabControl1 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
#~~< TabControl1 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
@ -158,11 +162,25 @@ $TabPage2.Size = New-Object System.Drawing.Size(800, 503)
|
|||||||
$TabPage2.TabIndex = 1
|
$TabPage2.TabIndex = 1
|
||||||
$TabPage2.Text = "Settings"
|
$TabPage2.Text = "Settings"
|
||||||
$TabPage2.BackColor = [System.Drawing.SystemColors]::Control
|
$TabPage2.BackColor = [System.Drawing.SystemColors]::Control
|
||||||
|
#~~< Label19 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
$Label19 = New-Object System.Windows.Forms.Label
|
||||||
|
$Label19.Location = New-Object System.Drawing.Point(7, 372)
|
||||||
|
$Label19.Size = New-Object System.Drawing.Size(145, 14)
|
||||||
|
$Label19.TabIndex = 38
|
||||||
|
$Label19.Text = "BIPrivatekey Location:"
|
||||||
|
#~~< TextBox13 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
$TextBox13 = New-Object System.Windows.Forms.TextBox
|
||||||
|
$TextBox13.Location = New-Object System.Drawing.Point(139, 349)
|
||||||
|
$TextBox13.ReadOnly = $true
|
||||||
|
$TextBox13.Size = New-Object System.Drawing.Size(96, 20)
|
||||||
|
$TextBox13.TabIndex = 33
|
||||||
|
$TextBox13.Text = ""
|
||||||
|
$TextBox13.add_TextChanged({TextBox13TextChanged($TextBox13)})
|
||||||
#~~< Label18 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
#~~< Label18 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
$Label18 = New-Object System.Windows.Forms.Label
|
$Label18 = New-Object System.Windows.Forms.Label
|
||||||
$Label18.Font = New-Object System.Drawing.Font("Microsoft Sans Serif", 14.25, [System.Drawing.FontStyle]::Bold, [System.Drawing.GraphicsUnit]::Point, ([System.Byte](0)))
|
$Label18.Font = New-Object System.Drawing.Font("Stencil Std", 12.0, [System.Drawing.FontStyle]::Bold, [System.Drawing.GraphicsUnit]::Point, ([System.Byte](0)))
|
||||||
$Label18.Location = New-Object System.Drawing.Point(270, 225)
|
$Label18.Location = New-Object System.Drawing.Point(6, 223)
|
||||||
$Label18.Size = New-Object System.Drawing.Size(179, 29)
|
$Label18.Size = New-Object System.Drawing.Size(235, 29)
|
||||||
$Label18.TabIndex = 37
|
$Label18.TabIndex = 37
|
||||||
$Label18.Text = "Sign File Settings"
|
$Label18.Text = "Sign File Settings"
|
||||||
$Label18.add_Click({Label18Click($Label18)})
|
$Label18.add_Click({Label18Click($Label18)})
|
||||||
@ -171,8 +189,22 @@ $Label16 = New-Object System.Windows.Forms.Label
|
|||||||
$Label16.Location = New-Object System.Drawing.Point(6, 292)
|
$Label16.Location = New-Object System.Drawing.Point(6, 292)
|
||||||
$Label16.Size = New-Object System.Drawing.Size(643, 14)
|
$Label16.Size = New-Object System.Drawing.Size(643, 14)
|
||||||
$Label16.TabIndex = 34
|
$Label16.TabIndex = 34
|
||||||
$Label16.Text = "Path to Arma 3 Tools (DSSignFile) biprivatekey:"
|
$Label16.Text = "Path to Arma 3 Tools (DSCreateKey):"
|
||||||
$Label16.add_Click({Label16Click($Label16)})
|
$Label16.add_Click({Label16Click($Label16)})
|
||||||
|
#~~< Label15 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
$Label15 = New-Object System.Windows.Forms.Label
|
||||||
|
$Label15.Location = New-Object System.Drawing.Point(139, 332)
|
||||||
|
$Label15.Size = New-Object System.Drawing.Size(145, 14)
|
||||||
|
$Label15.TabIndex = 32
|
||||||
|
$Label15.Text = "Sign Version:"
|
||||||
|
$Label15.add_Click({Label15Click($Label15)})
|
||||||
|
#~~< Label13 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
$Label13 = New-Object System.Windows.Forms.Label
|
||||||
|
$Label13.Location = New-Object System.Drawing.Point(6, 386)
|
||||||
|
$Label13.Size = New-Object System.Drawing.Size(785, 15)
|
||||||
|
$Label13.TabIndex = 29
|
||||||
|
$Label13.Text = ""
|
||||||
|
$Label13.add_Click({Label13Click($Label13)})
|
||||||
#~~< Label17 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
#~~< Label17 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
$Label17 = New-Object System.Windows.Forms.Label
|
$Label17 = New-Object System.Windows.Forms.Label
|
||||||
$Label17.Location = New-Object System.Drawing.Point(6, 252)
|
$Label17.Location = New-Object System.Drawing.Point(6, 252)
|
||||||
@ -349,8 +381,12 @@ $TextBox1.Location = New-Object System.Drawing.Point(6, 21)
|
|||||||
$TextBox1.Size = New-Object System.Drawing.Size(726, 20)
|
$TextBox1.Size = New-Object System.Drawing.Size(726, 20)
|
||||||
$TextBox1.TabIndex = 0
|
$TextBox1.TabIndex = 0
|
||||||
$TextBox1.Text = ""
|
$TextBox1.Text = ""
|
||||||
|
$TabPage2.Controls.Add($Label19)
|
||||||
|
$TabPage2.Controls.Add($TextBox13)
|
||||||
$TabPage2.Controls.Add($Label18)
|
$TabPage2.Controls.Add($Label18)
|
||||||
$TabPage2.Controls.Add($Label16)
|
$TabPage2.Controls.Add($Label16)
|
||||||
|
$TabPage2.Controls.Add($Label15)
|
||||||
|
$TabPage2.Controls.Add($Label13)
|
||||||
$TabPage2.Controls.Add($Label17)
|
$TabPage2.Controls.Add($Label17)
|
||||||
$TabPage2.Controls.Add($Button17)
|
$TabPage2.Controls.Add($Button17)
|
||||||
$TabPage2.Controls.Add($Label14)
|
$TabPage2.Controls.Add($Label14)
|
||||||
@ -385,27 +421,6 @@ $TabPage3.Size = New-Object System.Drawing.Size(800, 503)
|
|||||||
$TabPage3.TabIndex = 2
|
$TabPage3.TabIndex = 2
|
||||||
$TabPage3.Text = "Developers"
|
$TabPage3.Text = "Developers"
|
||||||
$TabPage3.BackColor = [System.Drawing.SystemColors]::Control
|
$TabPage3.BackColor = [System.Drawing.SystemColors]::Control
|
||||||
#~~< TextBox13 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
$TextBox13 = New-Object System.Windows.Forms.TextBox
|
|
||||||
$TextBox13.Location = New-Object System.Drawing.Point(6, 133)
|
|
||||||
$TextBox13.Size = New-Object System.Drawing.Size(96, 20)
|
|
||||||
$TextBox13.TabIndex = 33
|
|
||||||
$TextBox13.Text = ""
|
|
||||||
$TextBox13.add_TextChanged({TextBox13TextChanged($TextBox13)})
|
|
||||||
#~~< Label15 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
$Label15 = New-Object System.Windows.Forms.Label
|
|
||||||
$Label15.Location = New-Object System.Drawing.Point(6, 115)
|
|
||||||
$Label15.Size = New-Object System.Drawing.Size(145, 14)
|
|
||||||
$Label15.TabIndex = 32
|
|
||||||
$Label15.Text = "Sign Version:"
|
|
||||||
$Label15.add_Click({Label15Click($Label15)})
|
|
||||||
#~~< Label13 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
$Label13 = New-Object System.Windows.Forms.Label
|
|
||||||
$Label13.Location = New-Object System.Drawing.Point(6, 397)
|
|
||||||
$Label13.Size = New-Object System.Drawing.Size(785, 15)
|
|
||||||
$Label13.TabIndex = 29
|
|
||||||
$Label13.Text = ""
|
|
||||||
$Label13.add_Click({Label13Click($Label13)})
|
|
||||||
#~~< Button15 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
#~~< Button15 >~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
$Button15 = New-Object System.Windows.Forms.Button
|
$Button15 = New-Object System.Windows.Forms.Button
|
||||||
$Button15.Location = New-Object System.Drawing.Point(6, 240)
|
$Button15.Location = New-Object System.Drawing.Point(6, 240)
|
||||||
@ -503,9 +518,6 @@ $Button4.Size = New-Object System.Drawing.Size(54, 21)
|
|||||||
$Button4.TabIndex = 13
|
$Button4.TabIndex = 13
|
||||||
$Button4.Text = "Browse"
|
$Button4.Text = "Browse"
|
||||||
$Button4.UseVisualStyleBackColor = $true
|
$Button4.UseVisualStyleBackColor = $true
|
||||||
$TabPage3.Controls.Add($TextBox13)
|
|
||||||
$TabPage3.Controls.Add($Label15)
|
|
||||||
$TabPage3.Controls.Add($Label13)
|
|
||||||
$TabPage3.Controls.Add($Button15)
|
$TabPage3.Controls.Add($Button15)
|
||||||
$TabPage3.Controls.Add($Button12)
|
$TabPage3.Controls.Add($Button12)
|
||||||
$TabPage3.Controls.Add($Label6)
|
$TabPage3.Controls.Add($Label6)
|
||||||
@ -564,6 +576,8 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
|
|
||||||
# Defines
|
# Defines
|
||||||
|
|
||||||
|
$Label4.Text = Get-Random -InputObject "Bug? That's not a bug, that's a feature.", "A bug in the code is worth two in the documentation."
|
||||||
|
|
||||||
$ListView1.CheckBoxes = $true
|
$ListView1.CheckBoxes = $true
|
||||||
$FolderBrowserDialog1.ShowNewFolderButton = $false
|
$FolderBrowserDialog1.ShowNewFolderButton = $false
|
||||||
$TextBox1.Text = "Arma 3 not found"
|
$TextBox1.Text = "Arma 3 not found"
|
||||||
@ -694,11 +708,34 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
$p6 = Join-Path $Textbox4.Text "\version.txt"
|
$p6 = Join-Path $Textbox4.Text "\version.txt"
|
||||||
$p7 = Join-Path $Textbox4.Text "\build.txt"
|
$p7 = Join-Path $Textbox4.Text "\build.txt"
|
||||||
$p8 = Join-Path $Textbox2.Text "\build.txt"
|
$p8 = Join-Path $Textbox2.Text "\build.txt"
|
||||||
$p9 = Join-Path $Textbox4.Text "\version_int.txt"
|
|
||||||
$Textbox6.Text = if (Test-Path $p6) { Get-Content $p6 } else { "Path not set" }
|
$Textbox6.Text = if (Test-Path $p6) { Get-Content $p6 } else { "Path not set" }
|
||||||
$Textbox7.Text = if (Test-Path $p7) { Get-Content $p7 } else { "Path not set" }
|
$Textbox7.Text = if (Test-Path $p7) { Get-Content $p7 } else { "Path not set" }
|
||||||
$Textbox8.Text = if (Test-Path $p8) { Get-Content $p8 } else { "Path not set" }
|
$Textbox8.Text = if (Test-Path $p8) { Get-Content $p8 } else { "Path not set" }
|
||||||
$Textbox13.Text = if (Test-Path $p9) { Get-Content $p9 } else { "Path not set" }
|
$Textbox13.Text = if (Test-Path $p6) { (Get-Content $p6) -replace '[.]','' } else { "" }
|
||||||
|
}
|
||||||
|
|
||||||
|
function fnc_updateBuildNumber($inpath, $outpath, $increment)
|
||||||
|
{
|
||||||
|
if ($Checkbox1.Checked)
|
||||||
|
{
|
||||||
|
$path = Join-Path $inpath "\build.txt"
|
||||||
|
if (Test-Path $path)
|
||||||
|
{
|
||||||
|
$in = Get-Content $path
|
||||||
|
|
||||||
|
$newBuild = [int]$in + $increment
|
||||||
|
$Out = @(
|
||||||
|
'build=' + [string]$newBuild + ';'
|
||||||
|
)
|
||||||
|
|
||||||
|
$Out | Out-File(Join-Path $outpath "\build.hpp") -Encoding "UTF8"
|
||||||
|
$newBuild | Out-File $path -Encoding "UTF8"
|
||||||
|
if ($increment -eq 1)
|
||||||
|
{
|
||||||
|
fnc_reloadVersions
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function fnc_updateVersions
|
function fnc_updateVersions
|
||||||
@ -706,7 +743,6 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
$p6 = Join-Path $Textbox4.Text "\version.txt"
|
$p6 = Join-Path $Textbox4.Text "\version.txt"
|
||||||
$p7 = Join-Path $Textbox4.Text "\build.txt"
|
$p7 = Join-Path $Textbox4.Text "\build.txt"
|
||||||
$p8 = Join-Path $Textbox2.Text "\build.txt"
|
$p8 = Join-Path $Textbox2.Text "\build.txt"
|
||||||
$p9 = Join-Path $Textbox4.Text "\version_int.txt"
|
|
||||||
|
|
||||||
if (($Textbox6.Text -ne "Path not set") -and (Test-Path $p6))
|
if (($Textbox6.Text -ne "Path not set") -and (Test-Path $p6))
|
||||||
{
|
{
|
||||||
@ -720,10 +756,6 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
{
|
{
|
||||||
$TextBox8.Text | Out-File $p8 -Encoding "UTF8"
|
$TextBox8.Text | Out-File $p8 -Encoding "UTF8"
|
||||||
}
|
}
|
||||||
if (($Textbox9.Text -ne "Path not set") -and (Test-Path $p9))
|
|
||||||
{
|
|
||||||
$TextBox9.Text | Out-File $p9 -Encoding "UTF8"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function fnc_getSetPath($switch)
|
function fnc_getSetPath($switch)
|
||||||
@ -842,10 +874,14 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
$TextBox7.Enabled = $cbstate
|
$TextBox7.Enabled = $cbstate
|
||||||
$TextBox8.Enabled = $cbstate
|
$TextBox8.Enabled = $cbstate
|
||||||
$TextBox13.Enabled = $cbstate
|
$TextBox13.Enabled = $cbstate
|
||||||
|
$TextBox11.Enabled = $cbstate
|
||||||
|
$TextBoxPboPrefix.Enabled = $cbstate
|
||||||
|
$TextBoxBISignPrefix.Enabled = $cbstate
|
||||||
|
|
||||||
$Button4.Enabled = $cbstate
|
$Button4.Enabled = $cbstate
|
||||||
$Button15.Enabled = $cbstate
|
$Button15.Enabled = $cbstate
|
||||||
$Button12.Enabled = $cbstate
|
$Button12.Enabled = $cbstate
|
||||||
|
$Button17.Enabled = $cbstate
|
||||||
|
|
||||||
$ComboBox1.Enabled = $cbstate
|
$ComboBox1.Enabled = $cbstate
|
||||||
|
|
||||||
@ -853,6 +889,21 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
fnc_populateListView
|
fnc_populateListView
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function fnc_outputmodcpp
|
||||||
|
{
|
||||||
|
$Output = Join-Path $TextBox1.Text $ComboBox1.SelectedItem
|
||||||
|
$Out = @(
|
||||||
|
'dir = "@Epoch";'
|
||||||
|
'name = "Epoch Mod ' + $Textbox6.Text + '";'
|
||||||
|
'actionName = "Website";'
|
||||||
|
'picture = "mod.paa";'
|
||||||
|
'action = "http://www.epochmod.com";'
|
||||||
|
'overview = "Open world survival mod set in the year 2035, Just two years after the mass extinction of billions of people. Those that remain are left with remnants of a once technological society. Try to survive, build, or explore your way through the harsh dynamic environment.";'
|
||||||
|
)
|
||||||
|
|
||||||
|
$Out | Out-File (Join-Path $Output "mod.cpp")
|
||||||
|
}
|
||||||
|
|
||||||
function fnc_settingsSave
|
function fnc_settingsSave
|
||||||
{
|
{
|
||||||
$Out = @(
|
$Out = @(
|
||||||
@ -903,13 +954,15 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
|
|
||||||
function fnc_CreatePBO
|
function fnc_CreatePBO
|
||||||
{
|
{
|
||||||
|
|
||||||
#
|
#
|
||||||
$signName = ($TextBox12.Text + $TextBox13.Text)
|
$signName = ($TextBoxBISignPrefix.Text + $TextBox13.Text)
|
||||||
$signFileName = ($signName + ".biprivatekey")
|
$signFileName = ($signName + ".biprivatekey")
|
||||||
$signfile = Join-Path $TextBox11.Text $signFileName
|
$signfile = Join-Path $TextBox11.Text $signFileName
|
||||||
|
|
||||||
# make privatekey if it does not exist
|
# make privatekey if it does not exist
|
||||||
if (!(Test-Path $signfile)) {
|
if (!(Test-Path $signfile))
|
||||||
|
{
|
||||||
$createKeyExecutable = Join-Path $TextBox11.Text "DSCreateKey.exe"
|
$createKeyExecutable = Join-Path $TextBox11.Text "DSCreateKey.exe"
|
||||||
$argz = @($signName)
|
$argz = @($signName)
|
||||||
Start-Process -FilePath $createKeyExecutable -WorkingDirectory $TextBox11.Text -ArgumentList $argz -WindowStyle Minimized -Wait
|
Start-Process -FilePath $createKeyExecutable -WorkingDirectory $TextBox11.Text -ArgumentList $argz -WindowStyle Minimized -Wait
|
||||||
@ -917,6 +970,13 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
$Label4.Refresh()
|
$Label4.Refresh()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fnc_outputmodcpp
|
||||||
|
# increase build numbers
|
||||||
|
|
||||||
|
$incrementClientBuild = 1
|
||||||
|
$incrementServerBuild = 1
|
||||||
|
|
||||||
|
|
||||||
$Bob = Join-Path $TextBox3.Text "\AddonBuilder.exe"
|
$Bob = Join-Path $TextBox3.Text "\AddonBuilder.exe"
|
||||||
$includes = "P:\includes.txt"
|
$includes = "P:\includes.txt"
|
||||||
if (!(Test-Path $includes)) { "*.xml;*.pac;*.paa;*.sqf;*.sqs;*.bikb;*.fsm;*.wss;*.ogg;*.wav;*.fxy;*.csv;*.html;*.lip;*.txt;*.wrp;*.bisurf;*.rvmat;*.sqm;*.ext;*.hpp" | Out-File $includes -Encoding "UTF8"}
|
if (!(Test-Path $includes)) { "*.xml;*.pac;*.paa;*.sqf;*.sqs;*.bikb;*.fsm;*.wss;*.ogg;*.wav;*.fxy;*.csv;*.html;*.lip;*.txt;*.wrp;*.bisurf;*.rvmat;*.sqm;*.ext;*.hpp" | Out-File $includes -Encoding "UTF8"}
|
||||||
@ -944,7 +1004,13 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
if (Test-Path $tmp) { Remove-Item -Path $tmp -Recurse }
|
if (Test-Path $tmp) { Remove-Item -Path $tmp -Recurse }
|
||||||
Copy-Item -Path $x.subitems[1].Text -Destination $tmp -Recurse
|
Copy-Item -Path $x.subitems[1].Text -Destination $tmp -Recurse
|
||||||
|
|
||||||
$argz = @($tmp, ( '"' + $Output + '"' ), "-packonly", "-clear", "-prefix=$name", "-project=$tmp", "-include=$includes")
|
fnc_updateBuildNumber $TextBox2.Text ($x.subitems[1].Text) $incrementServerBuild
|
||||||
|
$incrementServerBuild = 0
|
||||||
|
|
||||||
|
$argz = @($tmp, ( '"' + $Output + '"' ), "-packonly", "-clear", "-prefix=$name", "-project=P:\", "-include=$includes")
|
||||||
|
|
||||||
|
$Label4.Text = "Building Server PBO (" + $x.subitems[0].Text + ".pbo) ... Please wait"
|
||||||
|
$Label4.Refresh()
|
||||||
|
|
||||||
Start-Process -FilePath $Bob -ArgumentList $argz -WindowStyle Minimized -Wait
|
Start-Process -FilePath $Bob -ArgumentList $argz -WindowStyle Minimized -Wait
|
||||||
}
|
}
|
||||||
@ -953,6 +1019,9 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
$name = Join-Path $TextBoxPboPrefix.Text $name
|
$name = Join-Path $TextBoxPboPrefix.Text $name
|
||||||
$tmp = "P:\$name"
|
$tmp = "P:\$name"
|
||||||
|
|
||||||
|
fnc_updateBuildNumber $TextBox4.Text ($x.subitems[1].Text) $incrementClientBuild
|
||||||
|
$incrementClientBuild = 0
|
||||||
|
|
||||||
$Output = $TextBox1.Text + "\" + $ComboBox1.SelectedItem + "\Addons"
|
$Output = $TextBox1.Text + "\" + $ComboBox1.SelectedItem + "\Addons"
|
||||||
if (Test-Path $tmp) { Remove-Item -Path $tmp -Recurse }
|
if (Test-Path $tmp) { Remove-Item -Path $tmp -Recurse }
|
||||||
Copy-Item -Path $x.subitems[1].Text -Destination $tmp -Recurse
|
Copy-Item -Path $x.subitems[1].Text -Destination $tmp -Recurse
|
||||||
@ -960,8 +1029,10 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
$signFlag = ""
|
$signFlag = ""
|
||||||
if (Test-Path $signfile) { $signFlag = ('-sign="' + $signfile + '"') }
|
if (Test-Path $signfile) { $signFlag = ('-sign="' + $signfile + '"') }
|
||||||
|
|
||||||
|
$argz = @($tmp, ( '"' + $Output + '"' ), "-clear", "-prefix=$name", "-project=P:\", "-include=$includes", $signFlag)
|
||||||
|
|
||||||
$argz = @($tmp, ( '"' + $Output + '"' ), "-clear", "-prefix=$name", "-project=$tmp", "-include=$includes", $signFlag)
|
$Label4.Text = "Building Client PBO (" + $x.subitems[0].Text + ".pbo) ... Please wait"
|
||||||
|
$Label4.Refresh()
|
||||||
|
|
||||||
Start-Process -FilePath $Bob -ArgumentList $argz -WindowStyle Minimized -Wait
|
Start-Process -FilePath $Bob -ArgumentList $argz -WindowStyle Minimized -Wait
|
||||||
}
|
}
|
||||||
@ -970,6 +1041,9 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
$Output = $TextBox9.Text
|
$Output = $TextBox9.Text
|
||||||
$src = $TextBox2.Text + "\Sources\"
|
$src = $TextBox2.Text + "\Sources\"
|
||||||
|
|
||||||
|
fnc_updateBuildNumber $TextBox2.Text ($src + "epoch_config") $incrementServerBuild
|
||||||
|
$incrementServerBuild = 0
|
||||||
|
|
||||||
if (Test-Path $tmp) { Remove-Item -Path $tmp -Recurse }
|
if (Test-Path $tmp) { Remove-Item -Path $tmp -Recurse }
|
||||||
Copy-Item -Path $x.subitems[1].Text -Destination $tmp -Recurse
|
Copy-Item -Path $x.subitems[1].Text -Destination $tmp -Recurse
|
||||||
Copy-Item($src + "epoch_code") -Destination $tmp -Recurse
|
Copy-Item($src + "epoch_code") -Destination $tmp -Recurse
|
||||||
@ -978,6 +1052,9 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
|
|
||||||
$argz = @($tmp, ( '"' + $Output + '"' ), "-clear", "-prefix=\", "-project=P:\", "-include=$includes")
|
$argz = @($tmp, ( '"' + $Output + '"' ), "-clear", "-prefix=\", "-project=P:\", "-include=$includes")
|
||||||
|
|
||||||
|
$Label4.Text = "Building MPMission PBO (" + $x.subitems[0].Text + ".pbo) ... Please wait"
|
||||||
|
$Label4.Refresh()
|
||||||
|
|
||||||
Start-Process -FilePath $Bob -ArgumentList $argz -WindowStyle Minimized -Wait
|
Start-Process -FilePath $Bob -ArgumentList $argz -WindowStyle Minimized -Wait
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1041,12 +1118,20 @@ $Timer1 = New-Object System.Windows.Forms.Timer($components)
|
|||||||
fnc_reloadVersions
|
fnc_reloadVersions
|
||||||
|
|
||||||
|
|
||||||
$signName = ($TextBox12.Text + $TextBox13.Text)
|
$signName = ($TextBoxBISignPrefix.Text + $TextBox13.Text)
|
||||||
$signFileName = ($signName + ".biprivatekey")
|
$signFileName = ($signName + ".biprivatekey")
|
||||||
$signfile = Join-Path $TextBox11.Text $signFileName
|
$signfile = Join-Path $TextBox11.Text $signFileName
|
||||||
$signFlag = ""
|
$signFlag = ""
|
||||||
if (Test-Path $signfile) { $signFlag = "-sign= '$signfile'" }
|
if (Test-Path $signfile) {
|
||||||
$Label13.Text = $signFlag;
|
$Label13.Text = $signfile
|
||||||
|
$signFlag = ('-sign="' + $signfile + '"')
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$Label13.Text = "Path Not Found!"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
@ -1114,8 +1199,9 @@ Main # This call must remain below all other event functions
|
|||||||
#
|
#
|
||||||
# Script Information
|
# Script Information
|
||||||
#
|
#
|
||||||
# Title: Epoch PBO Packing Tool
|
# Title: Epoch PBO Packing Tool - EpochMod.com
|
||||||
# Author: Raimonds Virtoss - Raymix @ Epoch UI code
|
# Author: Raimonds Virtoss - Raymix @ Epoch UI code
|
||||||
|
# Contributors: Aaron Clark - [VB]AWOL
|
||||||
# Originally created: 4/24/2016 - 17:56:19
|
# Originally created: 4/24/2016 - 17:56:19
|
||||||
# Description: Form based (GUI) Tool to Pack or binarize Epoch PBOs. Scans your github repos and automatically creates a list of relevant folders for packaging
|
# Description: Form based (GUI) Tool to Pack or binarize Epoch PBOs. Scans your github repos and automatically creates a list of relevant folders for packaging
|
||||||
# Usage: .EXE file will be provided when script is done, for now simply right click it and run with powershell.
|
# Usage: .EXE file will be provided when script is done, for now simply right click it and run with powershell.
|
||||||
|
Loading…
Reference in New Issue
Block a user