diff --git a/cScripts/Loadouts/CfgLoadouts_Alpha_Rotary.hpp b/cScripts/Loadouts/CfgLoadouts_Alpha_Rotary.hpp index 1f1f0334a..beab135cd 100644 --- a/cScripts/Loadouts/CfgLoadouts_Alpha_Rotary.hpp +++ b/cScripts/Loadouts/CfgLoadouts_Alpha_Rotary.hpp @@ -26,6 +26,7 @@ class Cav_B_A_Helicopter_Tra_DoorGunner_F: Cav_B_A_Helicopter_Tra_CrewChief_F { displayName = "$STR_Cav_Alpha_Characters_A_Helicopter_Tra_DoorGunner"; scope = 2; abilityMedic = 1; + role = "rotarycls"; loadout = [["rhs_weap_m4a1_blockII_grip_bk","ACE_muzzle_mzls_L","acc_pointer_IR","rhsusf_acc_ACOG_RMR",["ACE_30Rnd_556x45_Stanag_M995_AP_mag",30],[],"rhsusf_acc_rvg_blk"],[],["rhsusf_weap_glock17g4","","acc_flashlight_pistol","",["rhsusf_mag_17Rnd_9x19_JHP",17],[],""],["USP_G3C_RS2_MC",[["ACE_Banana",1],["ACE_EarPlugs",1],["ACE_MapTools",1],["ACE_microDAGR",1],["ACE_tourniquet",4],["ACE_splint",4],["ACE_packingBandage",20],["kat_Painkiller",2,10]]],["UK3CB_V_Pilot_Vest",[["ACE_IR_Strobe_Item",2],["kat_chestSeal",2],["kat_guedel",1],["kat_ncdKit",1],["kat_Pulseoximeter",1],["ACE_elasticBandage",20],["ACE_quikclot",20],["ACE_splint",2],["ACE_tourniquet",2],["SmokeShellRed",2,1],["SmokeShell",4,1],["ACE_30Rnd_556x45_Stanag_M995_AP_mag",6,30],["rhsusf_mag_17Rnd_9x19_JHP",1,17],["SmokeShellPurple",2,1],["ACE_HandFlare_Green",2,1],["SmokeShellBlue",2,1],[["hgun_Pistol_Signal_F","","","",[],[],""],1]]],["USP_TACTICAL_PACK_CCT2",[["H_Cap_tan",1],["ACE_CableTie",2],["ACE_EntrenchingTool",1],["ToolKit",1],["rhsusf_m112_mag",1,1]]],"rhsusf_hgu56p_visor_mask","",["ACE_Vector","","","",[],[],""],["ItemMap","ItemcTab","","ItemCompass","ACE_Altimeter","NVGogglesB_blk_F"]]; }; diff --git a/cScripts/Loadouts/CfgLoadouts_Bravo_Atlas.hpp b/cScripts/Loadouts/CfgLoadouts_Bravo_Atlas.hpp index 999c659fe..0edc54d44 100644 --- a/cScripts/Loadouts/CfgLoadouts_Bravo_Atlas.hpp +++ b/cScripts/Loadouts/CfgLoadouts_Bravo_Atlas.hpp @@ -4,7 +4,7 @@ class Cav_B_Bravo_Atlas_base_F: Cav_B_Bravo_base_F { insignia = "cav_insignia_Specialized_Medic0"; abilityMedic = 2; - role = "medic"; + role = "doctor"; icon = "iconManMedic"; }; diff --git a/cScripts/Loadouts/CfgLoadouts_Bravo_Viking.hpp b/cScripts/Loadouts/CfgLoadouts_Bravo_Viking.hpp index e8becc6f4..4c58b6a41 100644 --- a/cScripts/Loadouts/CfgLoadouts_Bravo_Viking.hpp +++ b/cScripts/Loadouts/CfgLoadouts_Bravo_Viking.hpp @@ -110,6 +110,7 @@ class Cav_B_B_Scout_CombatLifeSaver_F: Cav_B_B_Scout_Base_F { loadout = [["rhs_weap_m4a1_blockII_KAC","rhsusf_acc_SF3P556","rhsusf_acc_anpeq15","rhsusf_acc_ACOG_RMR",["rhs_mag_30Rnd_556x45_M855A1_PMAG",30],[],"rhsusf_acc_grip2"],[],[],["USP_G3C_RS_KP_OR_MC",[["ACE_packingBandage",10],["ACE_quikclot",10],["ACE_tourniquet",4],["ACE_microDAGR",1],["ACE_Flashlight_XL50",1],["ACE_MapTools",1],["ACE_splint",4]]],["USP_CRYE_JPC_ASLTB",[["kat_CarbonateItem",1],["ACE_epinephrine",3],["kat_phenylephrineAuto",3],["HandGrenade",4,1],["SmokeShell",4,1],["ACE_Chemlight_IR",2,1],["rhs_mag_mk3a2",4,1],["rhs_mag_30Rnd_556x45_M855A1_PMAG",8,30]]],["USP_DELTA_BAG_MC",[["ACE_EntrenchingTool",1],["ACE_packingBandage",40],["ACE_quikclot",40],["ACE_tourniquet",12],["ACE_splint",8],["ACE_EarPlugs",2],["kat_chestSeal",10],["kat_guedel",10],["kat_ncdKit",5],["kat_pocketBVM",1],["kat_accuvac",1],["kat_Painkiller",3,10]]],"USP_OPS_FASTXP_TAN_MC_03","USP_MFRAME_BLK2",["ACE_Vector","","","",[],[],""],["ItemMap","ItemAndroid","","ItemCompass","ItemWatch","USP_PVS15"]]; insignia = "cav_insignia_specialized_cls"; abilityMedic = 1; + role = "medic"; icon = "iconManMedic"; }; diff --git a/cScripts/Loadouts/CfgLoadouts_Charlie_Squad.hpp b/cScripts/Loadouts/CfgLoadouts_Charlie_Squad.hpp index 6c2acc94a..80856cf6e 100644 --- a/cScripts/Loadouts/CfgLoadouts_Charlie_Squad.hpp +++ b/cScripts/Loadouts/CfgLoadouts_Charlie_Squad.hpp @@ -77,6 +77,7 @@ class Cav_B_C_CombatLifeSaver_F: Cav_B_Charlie_base_F { category[] += {"cScripts_Loadout_Cat_Charlie_Squad"}; loadout = [["rhs_weap_m4a1_blockII_KAC","rhsusf_acc_SF3P556","rhsusf_acc_anpeq15","rhsusf_acc_ACOG_RMR",["rhs_mag_30Rnd_556x45_M855A1_PMAG_Tan",30],[],""],[],[],["USP_G3C_CU_KP_OR_MC",[["ACE_tourniquet",4],["ACE_Flashlight_XL50",1],["ACE_MapTools",1],["ACE_microDAGR",1],["ACE_packingBandage",14],["ACE_splint",2],["ACE_EarPlugs",1],["ACE_Chemlight_IR",2,1]]],["USP_CRYE_JPC_DMB",[["SmokeShell",4,1],["rhs_mag_30Rnd_556x45_M855A1_PMAG_Tan",9,30],["HandGrenade",2,1],["SmokeShellBlue",1,1],["SmokeShellPurple",1,1]]],["USP_DELTA_BAG_MC",[["USP_PVS15",1],["ACE_packingBandage",40],["ACE_quikclot",40],["ACE_EntrenchingTool",1],["ACE_splint",8],["ACE_tourniquet",12],["kat_chestSeal",10],["ACE_epinephrine",3],["kat_guedel",10],["kat_ncdKit",5],["kat_pocketBVM",1],["kat_accuvac",1],["kat_phenylephrineAuto",3],["kat_CarbonateItem",1],["kat_Painkiller",7,10]]],"USP_OPSCORE_FASTMTC_GSW","USP_MFRAME_TAN",[],["ItemMap","","","ItemCompass","ACE_Altimeter",""]]; insignia = "cav_insignia_specialized_cls"; abilityMedic = 1; + role = "cls"; icon = "iconManMedic"; }; class Cav_B_C_Marksman_F_Local: Cav_B_Charlie_base_F { diff --git a/cScripts/functions/init/fn_init_logistics.sqf b/cScripts/functions/init/fn_init_logistics.sqf index ba27209f7..bcef51f3a 100644 --- a/cScripts/functions/init/fn_init_logistics.sqf +++ b/cScripts/functions/init/fn_init_logistics.sqf @@ -318,7 +318,7 @@ private _dataArray = [ ["ACE_Chemlight_HiBlue",0], ["ACE_Chemlight_HiRed",0], - // Medical + // Medical ["ACE_EarPlugs",10], ["kat_chestSeal",0], ["ACE_quikclot",0], @@ -421,6 +421,7 @@ private _dataArray = [ // Cardiac resuscitation ["kat_amiodarone",0], + ["kat_atropine",0], // Hemorrhage control ["kat_EACA",0], @@ -625,12 +626,27 @@ private _dataArray = [ ["kat_AED",1], ["kat_X_AED",1], + // Airway Management and Respiration + ["kat_aatKit",10], + ["kat_accuvac",2], + ["kat_BVM",4], + ["kat_chestSeal",20], + ["kat_larynx",10], + + // Autoinjectors + ["ACE_morphine",20], + ["ACE_epinephrine",40], + ["kat_phenylephrineAuto",40], + // Bandages ["ACE_elasticBandage",150], ["ACE_packingBandage",90], ["ACE_quikclot",150], - ["kat_chestSeal",20], - ["kat_guedel",10], + + // Diagnostic Tools + ["kat_Pulseoximeter",12], + ["kat_ultrasound",2], + ["kat_stethoscope",4], // Tourniquets ["ACE_tourniquet",20], @@ -644,6 +660,15 @@ private _dataArray = [ ["kat_IO_FAST",20], ["kat_IV_16",40], + // Analgesic Medication + ["kat_fentanyl",10], + ["kat_ketamine",10], + ["kat_nalbuphine",40], + + // Cardiac resuscitation + ["kat_amiodarone",10], + ["kat_atropine",10], + // Blood Pressure Medication ["kat_nitroglycerin",40], ["kat_phenylephrine",40], @@ -653,15 +678,11 @@ private _dataArray = [ ["kat_EACA",40], ["kat_TXA",40], - // Oral Medication + // Oral Medication & + ["kat_naloxone",20], ["kat_carbonate",20], ["kat_Painkiller",40], - - // Autoinjector & Nasal Spray Medication - ["kat_naloxone",20], - ["ACE_morphine",20], - ["ACE_epinephrine",40], - ["kat_phenylephrine_inject",40], + ["kat_PenthroxItem",10], // Splints ["ACE_splint",40], @@ -672,6 +693,7 @@ private _dataArray = [ ["kat_clamp",4], ["kat_retractor",4], ["kat_vacuum",1], + ["kat_reboa",12], // Surgical Medication ["kat_lidocaine",20], @@ -680,7 +702,7 @@ private _dataArray = [ ["kat_flumazenil",10], // Surgical Kits - ["ACE_surgicalKit",8], + ["ACE_surgicalKit",4], // Body Bags ["ACE_bodyBag",10], @@ -746,8 +768,7 @@ private _dataArray = [ ["crate_strykerDragoon_82mm",[ ["ACE_1Rnd_82mm_Mo_HE", 24], ["ACE_1Rnd_82mm_Mo_Illum", 8], - ["ACE_1Rnd_82mm_Mo_Smoke", 8], - ["ACE_1Rnd_82mm_Mo_HE_LaserGuided",8] + ["ACE_1Rnd_82mm_Mo_Smoke", 8] ]], ["crate_stinger",[ ["rhs_weap_fim92", 1], @@ -756,15 +777,16 @@ private _dataArray = [ ["crate_resupply_general", [ // Rifle Ammo ["rhs_mag_30Rnd_556x45_M855A1_PMAG_Tracer_Red",70], + ["rhsusf_20Rnd_762x51_SR25_m118_special_Mag",7], // MG Ammo - ["rhsusf_200rnd_556x45_mixed_soft_pouch",15], - ["rhsusf_100Rnd_762x51_m62_tracer",15], + ["rhsusf_200rnd_556x45_mixed_soft_pouch",16], + ["rhsusf_100Rnd_762x51_m62_tracer",19], // AT ["rhs_fgm148_magazine_AT",3], - ["MRAWS_HEAT_F",4], - ["MRAWS_HE_F",4], + ["MRAWS_HEAT_F",6], + ["MRAWS_HE_F",3], ["rhs_weap_M136_hedp",8], // AA @@ -778,10 +800,9 @@ private _dataArray = [ ["ACE_40mm_Flare_IR",10], // Mortar Ammo - ["NDS_M_6Rnd_60mm_HE_0",5], - ["NDS_M_6Rnd_60mm_HE",5], + ["NDS_M_6Rnd_60mm_HE_0",3], + ["NDS_M_6Rnd_60mm_HE",7], ["NDS_M_6Rnd_60mm_SMOKE",2], - ["NDS_M_6Rnd_60mm_ILLUM",2], // Offensive/Defensive Hand Grenades ["HandGrenade",20], @@ -981,8 +1002,8 @@ private _dataArray = [ ["ACE_wirecutter", 1], // 82mm Mortars + ["ace_compat_rhs_usf3_m252_carry", 2], ["ace_csw_carryMortarBaseplate", 2], - ["ace_csw_staticMortarCarry", 2], // Medical ["kat_AED",1], @@ -1459,14 +1480,25 @@ private _dataArray = [ ["USP_PACK_HYDRATION", 0], // Medical - ["ACE_EarPlugs",10], + ["ACE_EarPlugs",0], + + // Airway Management and Respiration ["kat_chestSeal",0], - ["ACE_quikclot",0], - ["ACE_tourniquet",0], + + // Bandages and Stitching + ["ACE_packingBandage",0], + + //Pills and Inhalants ["kat_Painkiller",0], ["kat_PainkillerItem",0], - // Common Gear + // Massive Hemorrhage Control + ["ACE_tourniquet",0], + + // Splints + ["ACE_splint",0], + + // Night Gear ["ACE_IR_Strobe_Item",0] ]], @@ -1511,6 +1543,7 @@ private _dataArray = [ ["ACE_HuntIR_monitor", 0], ["ItemAndroid", 0], ["rhsusf_weap_glock17g4", 0], + ["rhsusf_mag_17Rnd_9x19_FMJ",0], ["USP_VEST_STRANDHOGG2_MC", 0], ["USP_VEST_STRANDHOGG2_CBR", 0], ["ACE_Vector", 0], @@ -1531,6 +1564,7 @@ private _dataArray = [ ["ACE_microDAGR", 0], ["ACE_MX2A", 0], ["rhsusf_weap_glock17g4", 0], + ["rhsusf_mag_17Rnd_9x19_FMJ",0], ["USP_VEST_STRANDHOGG2_MC", 0], ["USP_VEST_STRANDHOGG2_CBR", 0], ["ACE_HuntIR_monitor", 0], @@ -1547,15 +1581,6 @@ private _dataArray = [ ["UK3CB_US_B_B_RIF_OCP_Radio", 0] ]], ["arsenal_role_weapons", [ - // Launchers - ["rhs_weap_maaws", 0], - ["launch_MRAWS_green_F", 0], - ["launch_MRAWS_sand_F", 0], - ["launch_MRAWS_olive_F", 0], - ["rhs_weap_fgm148",0], - ["rhs_weap_fim92",0], - - // MAAWS ammo ["MRAWS_HEAT_F", 0], ["MRAWS_HE_F", 0], @@ -1665,6 +1690,218 @@ private _dataArray = [ ["USP_TACTICAL_PACK_MCB_CCT8", 0], ["UK3CB_US_B_B_RIF_OCP_Radio", 0] ]], + ["arsenal_role_doctor",[ + // AEDs + ["kat_AED",0], + ["kat_X_AED",0], + + // Airway Management and Respiration + ["kat_aatKit",0], + ["kat_accuvac",0], + ["kat_BVM",0], + ["kat_chestSeal",0], + ["kat_guedel",0], + ["kat_larynx",0], + ["kat_ncdKit",0], + ["kat_pocketBVM",0], + + // Autoinjectors + ["ACE_adenosine",0], + ["ACE_epinephrine",0], + ["ACE_morphine",0], + ["kat_phenylephrineAuto",0], + + // Bandages and Stitching + ["ACE_elasticBandage",0], + ["ACE_packingBandage",0], + ["ACE_quikclot",0], + ["ACE_surgicalKit",0], + + // Diagnostic Tools + ["kat_Pulseoximeter",0], + ["kat_ultrasound",0], + ["kat_stethoscope",0], + + // Fluids + ["ACE_bloodIV",0], + ["ACE_bloodIV_250",0], + ["ACE_bloodIV_500",0], + ["ACE_plasmaIV",0], + ["ACE_plasmaIV_250",0], + ["ACE_plasmaIV_500",0], + ["ACE_salineIV",0], + ["ACE_salineIV_250",0], + ["ACE_salineIV_500",0], + + //Pills and Inhalants + ["kat_Carbonate",0], + ["kat_CarbonateItem",0], + ["kat_naloxone",0], + ["kat_Painkiller",0], + ["kat_PainkillerItem",0], + ["kat_PenthroxItem",0], + + // Massive Hemorrhage Control + ["kat_reboa",0], + ["ACE_tourniquet",0], + + //-------------------------- + // Catheters and Medication + //-------------------------- + + // Catheters + ["kat_IV_16",0], + ["kat_IO_FAST",0], + + // Analgesic Medication + ["kat_fentanyl",0], + ["kat_ketamine",0], + ["kat_nalbuphine",0], + + // BP Medication + ["kat_nitroglycerin",0], + ["kat_norepinephrine",0], + ["kat_phenylephrine",0], + ["kat_atropine",0], + + // Cardiac resuscitation + ["kat_amiodarone",0], + + // Hemorrhage control + ["kat_EACA",0], + ["kat_TXA",0], + + // Surgical Medication + ["kat_etomidate",0], + ["kat_flumazenil",0], + ["kat_lidocaine",0], + ["kat_lorazepam",0], + //-------------------------- + + //-------------------------- + // Surgery and Fractures + //-------------------------- + + // Debridement + ["kat_vacuum",0], + + // Splints + ["ACE_splint",0], + + // Surgical Equipment + ["kat_clamp",0], + ["kat_plate",0], + ["kat_retractor",0], + ["kat_scalpel",0] + //-------------------------- + ]], + ["arsenal_role_medic",[ + // Airway Management and Respiration + ["kat_accuvac",0], + ["kat_chestSeal",0], + ["kat_guedel",0], + ["kat_ncdKit",0], + ["kat_pocketBVM",0], + + // Autoinjectors + ["ACE_adenosine",0], + ["ACE_epinephrine",0], + ["ACE_morphine",0], + ["kat_phenylephrineAuto",0], + + // Bandages and Stitching + ["ACE_elasticBandage",0], + ["ACE_packingBandage",0], + ["ACE_quikclot",0], + ["ACE_surgicalKit",0], + + // Diagnostic Tools + ["kat_Pulseoximeter",0], + ["kat_stethoscope",0], + + // Fluids + ["ACE_bloodIV",0], + ["ACE_bloodIV_250",0], + ["ACE_bloodIV_500",0], + ["ACE_plasmaIV",0], + ["ACE_plasmaIV_250",0], + ["ACE_plasmaIV_500",0], + ["ACE_salineIV",0], + ["ACE_salineIV_250",0], + ["ACE_salineIV_500",0], + + //Pills and Inhalants + ["kat_Carbonate",0], + ["kat_CarbonateItem",0], + ["kat_naloxone",0], + ["kat_Painkiller",0], + ["kat_PainkillerItem",0], + ["kat_PenthroxItem",0], + + // Massive Hemorrhage Control + ["ACE_tourniquet",0], + + //-------------------------- + // Catheters and Medication + //-------------------------- + + // Catheters + ["kat_IV_16",0], + ["kat_IO_FAST",0], + + // Analgesic Medication + ["kat_fentanyl",0], + ["kat_ketamine",0], + ["kat_nalbuphine",0], + + // BP Medication + ["kat_nitroglycerin",0], + ["kat_norepinephrine",0], + ["kat_phenylephrine",0], + ["kat_atropine",0], + + // Cardiac resuscitation + ["kat_amiodarone",0], + + // Hemorrhage control + ["kat_EACA",0], + ["kat_TXA",0], + + // Splints + ["ACE_splint",0] + //-------------------------- + ]], + ["arsenal_role_cls",[ + // Airway Management and Respiration + ["kat_accuvac",0], + ["kat_chestSeal",0], + ["kat_guedel",0], + ["kat_ncdKit",0], + ["kat_pocketBVM",0], + + // Autoinjectors + ["ACE_epinephrine",0], + ["kat_phenylephrineAuto",0], + + // Bandages and Stitching + ["ACE_packingBandage",0], + ["ACE_quikclot",0], + + //Pills and Inhalants + ["kat_Carbonate",0], + ["kat_CarbonateItem",0], + ["kat_Painkiller",0], + ["kat_PainkillerItem",0], + ["kat_PenthroxItem",0], + + // Massive Hemorrhage Control + ["ACE_tourniquet",0], + + // Splints + ["ACE_splint",0] + //-------------------------- + ]], + // Weapons ["arsenal_weap_ugl", [ ["rhs_weap_m4a1_m320", 0], @@ -1900,8 +2137,31 @@ private _dataArray = [ ["rhsusf_acc_wmx", 0], ["rhsusf_acc_wmx_bk", 0], ["acc_flashlight", 0] - ]] + ]], + ["arsenal_weap_launchers", [ + // Launchers + ["launch_MRAWS_green_F", 0], + ["launch_MRAWS_sand_F", 0], + ["launch_MRAWS_olive_F", 0], + ["rhs_weap_fgm148",0], + ["rhs_weap_fim92",0], + // Launcher ammo + ["MRAWS_HEAT_F", 0], + ["MRAWS_HE_F", 0], + ["MAA_MAAWS_ASM509", 0], + ["MAA_MAAWS_HEDP502", 0], + ["MAA_MAAWS_GMM_MT", 0], + ["MAA_MAAWS_MT756", 0], + ["rhs_fgm148_magazine_AT",0], + ["rhs_fim92_mag",0] + ]], + ["arsenal_weap_sidearm",[ + ["rhsusf_weap_glock17g4",0], + ["rhsusf_weap_m1911a1",0], + ["rhsusf_mag_7x45acp_MHP",0], + ["rhsusf_mag_17Rnd_9x19_FMJ",0] + ]] ]; private _return = createHashMapFromArray _dataArray; diff --git a/cScripts/functions/systems/fn_getArsenalWhitelist.sqf b/cScripts/functions/systems/fn_getArsenalWhitelist.sqf index db61fc5dc..469da7945 100644 --- a/cScripts/functions/systems/fn_getArsenalWhitelist.sqf +++ b/cScripts/functions/systems/fn_getArsenalWhitelist.sqf @@ -37,10 +37,6 @@ private _companyItems = switch (_company) do { }; -private _medicRole = getNumber (missionConfigFile >> "CfgLoadouts" >> _classname >> "abilityMedic"); -private _medicGear = if (_medicRole >= 1) then {GET_CONTAINER_KEYS("bravo_company_atlas");} else {[]}; - - private _roleSpecific = switch ([player] call EFUNC(gear,getLoadoutRole)) do { case "officer": {GET_CONTAINER_KEYS("arsenal_role_officer");}; case "squadleader": {GET_CONTAINER_KEYS("arsenal_role_squadleader");}; @@ -49,31 +45,58 @@ private _roleSpecific = switch ([player] call EFUNC(gear,getLoadoutRole)) do { case "pilot"; case "rotarypilot": {GET_CONTAINER_KEYS("arsenal_role_rotarypilot");}; case "rotarycrew": {GET_CONTAINER_KEYS("arsenal_role_pilotcrew");}; + case "rotarycls": { + private _rotaryRole = GET_CONTAINER_KEYS("arsenal_role_pilotcrew"); + private _clsRole = GET_CONTAINER_KEYS("arsenal_role_cls"); + _rotaryRole + _clsRole; + }; case "pilotfighter": {GET_CONTAINER_KEYS("arsenal_role_pilotfighter");}; case "pilottransport": {GET_CONTAINER_KEYS("arsenal_role_pilottransport");}; + case "cls": {GET_CONTAINER_KEYS("arsenal_role_cls");}; + case "medic": {GET_CONTAINER_KEYS("arsenal_role_medic");}; + case "doctor": {GET_CONTAINER_KEYS("arsenal_role_doctor");}; default {[]}; }; private _primaryWeapon = if (!isNil{_loadout#0#0}) then {_loadout#0#0} else {""}; -private _weaponSystemSpecific = switch (true) do { +private _primarySpecific = switch (true) do { case (_primaryWeapon isKindof ['rhs_weap_mk18_m320', configFile >> 'CfgWeapons'] - || _primaryWeapon isKindof ['rhs_weap_m16a4_carryhandle_M203', configFile >> 'CfgWeapons']): {GET_CONTAINER_KEYS("arsenal_weap_ugl");}; + || _primaryWeapon isKindof ['rhs_weap_m16a4_carryhandle_M203', configFile >> 'CfgWeapons'] + || _primaryWeapon isKindof ['rhs_weap_m4a1_m320', configFile >> 'CfgWeapons']): {GET_CONTAINER_KEYS("arsenal_weap_ugl");}; case (_primaryWeapon isKindof ['rhs_weap_m4a1', configFile >> 'CfgWeapons'] || _primaryWeapon isKindof ['rhs_weap_m16a4', configFile >> 'CfgWeapons']): {GET_CONTAINER_KEYS("arsenal_weap_m4");}; case (_primaryWeapon isKindof ['rhs_weap_sr25_ec', configFile >> 'CfgWeapons']): {GET_CONTAINER_KEYS("arsenal_weap_sr25");}; - case (primaryWeapon player isKindof ['rhs_weap_m240_base', configFile >> 'CfgWeapons']): {GET_CONTAINER_KEYS("arsenal_weap_m240");}; + case (_primaryWeapon isKindof ['rhs_weap_m240_base', configFile >> 'CfgWeapons']): {GET_CONTAINER_KEYS("arsenal_weap_m240");}; - case (primaryWeapon player isKindof ['rhs_weap_m249_pip', configFile >> 'CfgWeapons'] + case (_primaryWeapon isKindof ['rhs_weap_m249_pip', configFile >> 'CfgWeapons'] || _primaryWeapon isKindof ['rhs_weap_m249_pip_L', configFile >> 'CfgWeapons'] || _primaryWeapon isKindof ['rhs_weap_m249_pip_S', configFile >> 'CfgWeapons']): {GET_CONTAINER_KEYS("arsenal_weap_m249");}; + default {[]}; +}; + +private _handgunWeapon = if (!isNil{_loadout#2#0}) then {_loadout#2#0} else {""}; +private _handgunSpecific = switch (true) do { + case (_handgunWeapon isKindOf ['rhs_weap_M320', configFile >> 'CfgWeapons']): {GET_CONTAINER_KEYS("arsenal_weap_ugl");}; + case (_handgunWeapon isKindOf ['rhsusf_weap_glock17g4', configFile >> 'CfgWeapons'] + || _handgunWeapon isKindOf ['rhsusf_weap_m1911a1', configFile >> 'CfgWeapons']): {GET_CONTAINER_KEYS("arsenal_weap_sidearm");}; + default {[]}; +}; +private _launcherWeapon = if (!isNil{_loadout#1#0}) then {_loadout#1#0} else {""}; +private _launcherSpecific = switch (true) do { + case (_launcherWeapon isKindOf ['rhs_weap_fgm148', configFile >> 'CfgWeapons'] + || _launcherWeapon isKindof ['rhs_weap_fim92', configFile >> 'CfgWeapons'] + || _launcherWeapon isKindof ['rhs_weap_maaws', configFile >> 'CfgWeapons'] + || _launcherWeapon isKindof ['launch_MRAWS_green_F', configFile >> 'CfgWeapons'] + || _launcherWeapon isKindof ['launch_MRAWS_sand_F', configFile >> 'CfgWeapons'] + || _launcherWeapon isKindof ['launch_MRAWS_olive_F', configFile >> 'CfgWeapons']): {GET_CONTAINER_KEYS("arsenal_weap_launchers");}; default {[]}; }; -private _whitelist = _commonGear + _unitItems + _companyItems + _roleSpecific + _medicGear + _weaponSystemSpecific; +private _whitelist = _commonGear + _unitItems + _companyItems + _roleSpecific + _medicGear + _primarySpecific + _handgunSpecific + _launcherSpecific; _whitelist