RATDOG/_module/nss/69_module_load.nss
Jaysyn904 0f13e6c538 Initial module commit
Initial module commit.
2021-08-29 23:34:48 -04:00

225 lines
8.9 KiB
Plaintext

//::///////////////////////////////////////////////
//:: OnLoad Script
//:: 69_module_load
//:: (c) 2003 Bioware Corp.
//:://////////////////////////////////////////////
/*
Put into: OnModuleLoad Event
This example script demonstrates how to tweak the
behavior of several subsystems in your module.
For more information, please check x2_inc_switches
which holds definitions for several variables that
can be set on modules, creatures, doors or waypoints
to change the default behavior of Bioware scripts.
Warning:
Using some of these switches may change your games
balancing and may introduce bugs or instabilities. We
recommend that you only use these switches if you
know what you are doing. Consider these features
unsupported!
Please do NOT report any bugs you experience while
these switches have been changed from their default
positions.
Make sure you visit the forums at nwn.bioware.com
to find out more about these scripts.
*/
//:://////////////////////////////////////////////
//:: Created By: Georg Zoeller
//:: Created On: 2003-07-16
//:: Modified: 69MEH69
//:://////////////////////////////////////////////
#include "x2_inc_switches"
#include "x2_inc_restsys"
void main()
{
//Henchman Kit Definitions 69MEH69
//Sets Database Name for your Module
//Useful for transfering henchmen from module to module
//Insure that all the transfering modules use the same database
string sDB = "MBHKit";
SetLocalString(GetModule(), "X0_CAMPAIGN_DB", sDB);
//Sets testing mode
//Useful for debugging and/or viewing feedback
//Set TEST_MODE = 1 to initiate test mode
//Set TEST_MODE = 0 to disable test mode (Default)
int TEST_MODE = 0;
SetLocalInt(GetModule(), "TEST_MODE", TEST_MODE);
//PC death option:
//Set PC_BLEEDING = 1 to initiate PC bleeding (-10 HP) & Raise Dead/Resurrection by a healer henchman
//Set PC_BLEEDING = 0 to initiate default BIOWARE PC death
int PC_BLEEDING = 0;
SetLocalInt(GetModule(), "PC_BLEEDING", PC_BLEEDING);
//Henchman Death Option:
//Set HENCH_BLEED = 3 for henchman to respawn at PC master's location after 30.0 seconds
//Set HENCH_BLEED = 2 for henchman destruction, henchman will be destroyed upon death
//Set HENCH_BLEED = 1 for henchman bleeding
//Set HENCH_BLEED = 0 for respawn death, henchman will respawn
// to location defined in spawn script
int HENCH_BLEED = 0;
SetLocalInt(GetModule(), "HENCH_BLEED", HENCH_BLEED);
//Set HENCH_SALVATION = 1 to allow for the possibility of
//henchman recovering from wounds each round
//Set HENCH_SALVATION = 0 to allow only one check for the
//possibility of henchman recovering from wounds
//Only available if HENCH_BLEED = 1;
int HENCH_SALVATION = 0;
SetLocalInt(GetModule(), "HENCH_SALVATION", HENCH_SALVATION);
//Sets whether henchman will gain own XP or level up with PC
//Will initiate the 3rd edition DMG XP code
//Adjust the XP slider to 0 in Module Properties.
//0 = Levels up when PC levels up
//1 = Henchman gains own personal XP
int nHenchXP = 0;
SetLocalInt(GetModule(), "HENCHXP", nHenchXP);
//Sets whether henchman retain level or level down to level 1
//Will destroy NPC and create original level 1 version at original spawn location
//determined by waypoint with TAG: "WP_Home_'NPC TAG'"
//OR Henchman will be destroyed permanently
//The 69_hench_quit script will initiate on the following dialog node:
// "No, I work better alone."
//0 = Retains leveled up henchman
//1 = NPC is destroyed and level 1 version is created at waypoint
//2 = NPC is destroyed
int nHenchQuit = 0;
SetLocalInt(GetModule(), "HENCHQUIT", nHenchQuit);
//Sets whether henchmen will autolevel up at hire:
//0 = must level up henchman through dialog
//1 = henchman will automatically level up at hire
int nAutoLevelup = 1;
SetLocalInt(GetModule(), "nAutoLevelup", nAutoLevelup);
//Sets Leadership requirement upon module:
//0 = No Leadership, 1 = Yes Leadership
int nLeadership = 0;
SetLocalInt(GetModule(), "nLeadership", nLeadership);
if(nLeadership == 1)
{
SetMaxHenchmen(100); //Do Not Edit
}
//Sets Loyalty requirement upon module:
//0 = No Loyalty, 1 = Yes Loyalty
int nLoyalty = 0;
SetLocalInt(GetModule(), "nLoyalty", nLoyalty);
//Maximum Henchmen
//Sets the number of henchman a PC may have:
//(Leadership requirement must be set to 0)
//0,1,2...
int nNumHench = 3;
if(nLeadership == 0)
{
SetMaxHenchmen(nNumHench);
}
//End Henchman Kit Definitions 69MEH69
//Other Definitions
if (GetGameDifficulty() == GAME_DIFFICULTY_CORE_RULES || GetGameDifficulty() == GAME_DIFFICULTY_DIFFICULT)
{
// * Setting the switch below will enable a seperate Use Magic Device Skillcheck for
// * rogues when playing on Hardcore+ difficulty. This only applies to scrolls
SetModuleSwitch (MODULE_SWITCH_ENABLE_UMD_SCROLLS, TRUE);
// * Activating the switch below will make AOE spells hurt neutral NPCS by default
// SetModuleSwitch (MODULE_SWITCH_AOE_HURT_NEUTRAL_NPCS, TRUE);
}
// * AI: Activating the switch below will make the creaures using the WalkWaypoint function
// * able to walk across areas
// SetModuleSwitch (MODULE_SWITCH_ENABLE_CROSSAREA_WALKWAYPOINTS, TRUE);
// * Spells: Activating the switch below will make the Glyph of Warding spell behave differently:
// * The visual glyph will disappear after 6 seconds, making them impossible to spot
// SetModuleSwitch (MODULE_SWITCH_ENABLE_INVISIBLE_GLYPH_OF_WARDING, TRUE);
// * Craft Feats: Want 50 charges on a newly created wand? We found this unbalancing,
// * but since it is described this way in the book, here is the switch to get it back...
// SetModuleSwitch (MODULE_SWITCH_ENABLE_CRAFT_WAND_50_CHARGES, TRUE);
// * Craft Feats: Use this to disable Item Creation Feats if you do not want
// * them in your module
// SetModuleSwitch (MODULE_SWITCH_DISABLE_ITEM_CREATION_FEATS, TRUE);
// * Palemaster: Deathless master touch in PnP only affects creatures up to a certain size.
// * We do not support this check for balancing reasons, but you can still activate it...
// SetModuleSwitch (MODULE_SWITCH_SPELL_CORERULES_DMASTERTOUCH, TRUE);
// * Epic Spellcasting: Some Epic spells feed on the liveforce of the caster. However this
// * did not fit into NWNs spell system and was confusing, so we took it out...
// SetModuleSwitch (MODULE_SWITCH_EPIC_SPELLS_HURT_CASTER, TRUE);
// * Epic Spellcasting: Some Epic spells feed on the liveforce of the caster. However this
// * did not fit into NWNs spell system and was confusing, so we took it out...
// SetModuleSwitch (MODULE_SWITCH_RESTRICT_USE_POISON_TO_FEAT, TRUE);
// * Spellcasting: Some people don't like caster's abusing expertise to raise their AC
// * Uncommenting this line will drop expertise mode whenever a spell is cast by a player
// SetModuleSwitch (MODULE_VAR_AI_STOP_EXPERTISE_ABUSE, TRUE);
// * Item Event Scripts: The game's default event scripts allow routing of all item related events
// * into a single file, based on the tag of that item. If an item's tag is "test", it will fire a
// * script called "test" when an item based event (equip, unequip, acquire, unacquire, activate,...)
// * is triggered. Check "x2_it_example.nss" for an example.
// * This feature is disabled by default.
SetModuleSwitch (MODULE_SWITCH_ENABLE_TAGBASED_SCRIPTS, TRUE);
if (GetModuleSwitchValue (MODULE_SWITCH_ENABLE_TAGBASED_SCRIPTS) == TRUE)
{
// * If Tagbased scripts are enabled, and you are running a Local Vault Server
// * you should use the line below to add a layer of security to your server, preventing
// * people to execute script you don't want them to. If you use the feature below,
// * all called item scrips will be the prefix + the Tag of the item you want to execute, up to a
// * maximum of 16 chars, instead of the pure tag of the object.
// * i.e. without the line below a user activating an item with the tag "test",
// * will result in the execution of a script called "test". If you uncomment the line below
// * the script called will be "1_test.nss"
// SetUserDefinedItemEventPrefix("1_");
}
// * This initializes Bioware's wandering monster system as used in Hordes of the Underdark
// * You can deactivate it, making your module load faster if you do not use it.
// * If you want to use it, make sure you set "x2_mod_def_rest" as your module's OnRest Script
// SetModuleSwitch (MODULE_SWITCH_USE_XP2_RESTSYSTEM, TRUE);
if (GetModuleSwitchValue(MODULE_SWITCH_USE_XP2_RESTSYSTEM) == TRUE)
{
// * This allows you to specify a different 2da for the wandering monster system.
// SetWanderingMonster2DAFile("des_restsystem");
//* Do not change this line.
WMBuild2DACache();
}
}