A3XAI-Final/A3XAI/scripts/A3XAI_buildFoodList.sqf
Snark Industries c4a7084754 A3XAI Final Release (April 17, 2016 version)
Releasing previously unreleased version. Completely unsupported with no guarantee of functionality. Use at own risk.
2017-07-19 21:20:00 -04:00

41 lines
1.5 KiB
Plaintext

#include "\A3XAI\globaldefines.hpp"
private ["_food", "_drink", "_startTime", "_foodList", "_items", "_itemClassInfo", "_itemClassBias", "_itemClassType", "_itemList", "_itemInfo", "_itemBias", "_itemType", "_item","_itemClass"];
_startTime = diag_tickTime;
_loot0 = [missionConfigFile >> "CfgTraderCategories" >> "Food","items",[]] call BIS_fnc_returnConfigEntry;
_loot1 = [missionConfigFile >> "CfgTraderCategories" >> "Drinks","items",[]] call BIS_fnc_returnConfigEntry;
_items = [];
{
_items append _x;
} forEach [_loot0,_loot1];
if !(A3XAI_dynamicFoodBlacklist isEqualTo []) then {
_items = _items - A3XAI_dynamicFoodBlacklist;
};
{
_itemPrice = getNumber(missionConfigFile >> "CfgExileArsenal" >> _x >> "price");
if (_itemPrice > A3XAI_itemPriceLimit) then {
_items deleteAt _forEachIndex;
if (A3XAI_debugLevel > 0) then {diag_log format ["A3XAI Debug: Item %1 exceeds price limit of %2.",_x,A3XAI_itemPriceLimit];};
};
} forEach _items;
if !(_items isEqualTo []) then {
A3XAI_foodLoot = _items;
if (A3XAI_debugLevel > 0) then {
diag_log format ["A3XAI Debug: Generated %1 food classnames in %2 seconds.",(count _items),diag_tickTime - _startTime];
if (A3XAI_debugLevel > 1) then {
diag_log format ["A3XAI Debug: Contents of A3XAI_foodLoot: %1",A3XAI_foodLoot];
};
};
} else {
diag_log "A3XAI Error: Could not dynamically generate food classname list. Classnames from A3XAI_config.sqf used instead.";
};
//Cleanup global vars
A3XAI_dynamicFoodBlacklist = nil;