ArmA 1.74 Exile 1.0.3 Exile Scavange 0.7 Build Status

General Information:

Please note that this is a project in its development stage and there might be some bugs. Feel free to give feedback and suggestions to this work.

Information:

Basicly this system will allow players to interact with terrain/map objects.
If the object has a entry in a scavenge class within the configurations the player can loot this object
and has a chance to get a item from that depending on the class.

So far the player can:

  • Scavenge through trash-bins/piles. (enabled by default)
  • Scavenge through wrecks. (enabled by default)
  • Scavenge through abandoned tents. (maybe only used in CHR, disabled by default)
  • Scavenge through furniture inside houses. (enabled by default)
  • Get water from different sources if player has empty bottle/container to fill. (enabled by default)
  • Get fuel from different sources if player has empty fuel canister to fill. (enabled by default)
  • Get log from stocks of wood (enabled by default)
  • Get leaves and sticks from bushes and lower height trees (still WIP, disabled by default)
  • Get cement from concrete slabs (disabled by default, use with care as game balance breaking if set incorrectly)
  • Get wood planks from wood plank objects (disabled by default, use with care as game balance breaking if set incorrectly)
  • Get Metal Poles from metal pole objects (disabled by default, use with care as game balance breaking if set incorrectly)
  • Get Cinderblocks from Cinder Block pack objects if sledgehammer equipped (disabled by default, Requires Exile Extended Items Mod).
  • Get pumpkins from pumpkin patch if shovel equiped (disabled by default, Requires Exile Extended Items Mod).
  • Pickup apples from apple trees (disabled by default, Requires LordRampantHumps Items Pack Mod).
  • Pickup fruit from various trees and bushes (disabled by default, Requires LordRampantHumps Items Pack Mod).

This framework is simply customizable and you can add new interaction classes easily just by adding the required information to the configfiles.

CfgExileHoldActions.cpp

This file contains the information for each holdaction icon. If you want to create your own icon you can add a new class to this file and add the required information to get your icon working with the scavange system. You can find more information and examples in the file.

CfgExileScavenge.cpp

This file contains the information for each scavange class. If you want to create your own interaction to terrain/map objects you can do that by adding a new class for your interaction and fill it with the required information. You can find more information and examples in the file.

CfgScavengeRecipes.cpp

This file comes in action if you create a crafting scavange class that will require a item/weapon/tool to get a item back from the source. Take a look at the Waters and Cinderblocks classes within CfgExileScavenge.cpp to get a example for creating such a class. In short words this file contains crafting recipes that will be used for crafting scavange classes. You can find more information and examples in the file.

Requirements:

Exile Mod 1.0.3: http://www.exilemod.com/downloads/ Base Exile Mod.

Optionals:

LordRampantHumps Items Pack : https://steamcommunity.com/sharedfiles/filedetails/?id=1082756693 New Exile cusumables.

Exile Extended Items: https://steamcommunity.com/sharedfiles/filedetails/?id=897168981 New Exile Items.

Uncomment the classes on the end of the CfgExileScavenge.cpp files to get some actions that use these mod items if you use these Mods!

Installation:

  1. Drop the bootstrap, core, holdactions, dialogs and Exile_Client_Overrides folders + the > CfgFunctions.cpp, CfgExileScavange.cpp, CfgScavengeRecipes.cpp, CfgExileHoldActions.cpp files into the root of your mission directory.
  2. Merge the content of the provided description.ext with your Exile missions description.ext.

So it looks like this for example:

// Add this on the end of your missions description.ext
#include "CfgFunctions.cpp"
#include "CfgRemoteExec.cpp"
#include "CfgScavengeRecipes.cpp"
#include "CfgExileScavenge.cpp"
#include "CfgExileHoldActions.cpp"

// Just add this if you dont have already a RscTitles class within your mission!
#include "CfgDialogs.cpp"

// If you dont have any ExileCustommCode entrys yet
#include "CfgExileCustomCode.cpp"
  1. Merge the content of the provided CfgDialogs.cpp with your missions RscTitles class.

So it looks like this for example:

class RscTitles
{
     class Default
     {
         idd = -1;
         fadein = 0;
         fadeout = 0;
         duration = 0;
     };
     // Scavenge system
     #include "dialogs\ExileScavengeUI.hpp"
 };

 If you dont have any RscTitles class within your mission then just include the provided CfgDialogs.cpp in your missions description.ext.
  1. Merge the content of the provided CfgRemoteExec.cpp with your missions CfgRemoteExec class. Normaly this class is inside your missions description.ext.

So it looks like this for example:

class CfgRemoteExec
{
  class Functions
  {
  	mode = 2;
  	jip = 0;
  	class fnc_AdminReq 												{ allowedTargets=2; };
  	class ExileServer_system_network_dispatchIncomingMessage 		{ allowedTargets=2; };
  	class ExileExpansionServer_system_scavenge_spawnLoot			{ allowedTargets=0; };
  };
  class Commands
  {
  	mode=0;
  	jip=0;
  };
};
  1. Open your mission config.cpp find the class CfgExileCustomCode and add this into the class:

So it looks like this for example:

////////////////////////////////////
//	Exile Client Overrides
///////////////////////////////////
// Custom player client init
ExileClient_object_player_initialize = "Exile_Client_Overrides\ExileClient_object_player_initialize.sqf";

If you dont have any CfgExileCustomCode entrys yet within your mission then you can also just include the provided CfgExileCustomCode.cpp in your missions description.ext.
Delete the CfgExileCustomCode class in the main exile confip.cpp if you do so then!
  1. Edit the CfgExileScavange.cpp to suit your server.
Enjoy :)

Thanks and Credits:

Thanks and Credits:
Credits to Larrow for the base script: https://forums.bistudio.com/forums/topic/184456-looting-trash-piles-bins/?do=findComment&comment=2942397
Credits to Kurewe for the first port and rewrite for the exile mod.
Credits to oldmatechoc for a base rewrite and port for the exile mod.
Credits to yukihito23 for plenty amount of help, expansions and additions of the system.
Credits to NiiRoZz for plenty amount of help, expansions, additions and optimizations of the system.
Credits to Salutesh for a complete rewrite and buildup of the framework and system.