Module faction
Lua bindings to deal with factions.
Use like:
f = faction.get( "Empire" ) if f:playerStanding() < 0 then-- player is hostile to "Empire"
end
Functions
exists (name) | Gets a faction if it exists. |
get (name) | Gets the faction based on its name. |
getAll () | Gets all the factions. |
player () | Gets the player's faction. |
__eq (f, comp) | __eq (equality) metamethod for factions. |
name (f) | Gets the faction's translated short name. |
nameRaw (f) | Gets the faction's raw / "real" (untranslated, internal) name. |
longname (f) | Gets the faction's translated long name. |
areNeutral (f, n) | Checks to see if two factions are truly neutral with respect to each other. |
areEnemies (f, e[, sys]) | Checks to see if f is an enemy of e. |
areAllies (f, a[, sys]) | Checks to see if f is an ally of a. |
hit (f, mod, Whether[, reason="script"[, single=false]]) | Modifies the player's standing with the faction. |
hit (f, mod, Whether[, reason="script"]) | Simulates modifying the player's standing with a faction and computes how much would be changed. |
reputationGlobal (f) | Gets the player's global reputation with the faction. |
reputationText (f[, val=f:reputationGlobal()]) | Gets the human readable standing text correpsonding (translated). |
reputationDefault (f) | Gets the player's default reputation with the faction. |
setReputationGlobal (f, The) | Overrides the player's faction global standing with a faction. |
applyLocalThreshold (f, sys) | Enforces the local threshold of a faction starting at a particular system. |
modPlayer (f, mod[, reason="script"]) | Modifies the player's standing with the faction. |
modPlayerSingle (f, mod[, reason="script"]) | Modifies the player's standing with the faction. |
modPlayerRaw (f, mod) | Modifies the player's standing with the faction. |
setPlayerStanding (f, value) | Sets the player's standing with the faction. |
playerStanding (f, value) | Gets the player's standing with the faction. |
playerStandingDefault (f) | Gets the player's default standing with the faction. |
enemies (f) | Gets the enemies of the faction. |
allies (f) | Gets the allies of the faction. |
usesHiddenJumps (f) | Gets whether or not a faction uses hidden jumps. |
logo (f) | Gets the faction logo. |
colour (f) | Gets the faction colour. |
known (f) | Checks to see if a faction is known by the player. |
setKnown (f[, b=false]) | Sets a faction's known state. |
invisible (f) | Checks to see if a faction is invisible the player. |
static (f) | Checks to see if a faction has a static standing with the player. |
reputationOverride (f) | Gets the overriden reputation value of a faction. |
setReputationOverride (f, Sets) | Gets the overriden reputation value of a faction. |
tags ([tag=nil]) | Gets the tags a faction has. |
dynAdd (base, name[, display[, params]]) | Adds a faction dynamically. |
dynAlly (fac, ally[, remove=false]) | Adds or removes allies to a faction. |
dynEnemy (fac, enemy[, remove=false]) | Adds or removes enemies to a faction. |
Functions
- exists (name)
-
Gets a faction if it exists.
Parameters:
- name string Name of the faction to get if exists.
Returns:
-
Faction
The faction matching name or nil if not matched.
Usage:
f = faction.exists( "Empire" )
- get (name)
-
Gets the faction based on its name.
Parameters:
- name string Name of the faction to get.
Returns:
-
Faction
The faction matching name.
Usage:
f = faction.get( "Empire" )
- getAll ()
-
Gets all the factions.
Returns:
-
{Faction,...}
An ordered table containing all of the factions.
- player ()
-
Gets the player's faction.
Returns:
-
Faction The player's faction.
Usage:
pf = faction.player()
- __eq (f, comp)
-
__eq (equality) metamethod for factions.
You can use the '==' operator within Lua to compare factions with this.
Parameters:
- f Faction Faction comparing.
- comp Faction faction to compare against.
Returns:
-
boolean
true if both factions are the same.
Usage:
if f == faction.get( "Dvaered" ) then
- name (f)
-
Gets the faction's translated short name.
This translated name should be used for display purposes (e.g. messages) where the shorter version of the faction's display name should be used. It cannot be used as an identifier for the faction; for that, use faction.nameRaw() instead.
Parameters:
- f Faction The faction to get the name of.
Returns:
-
string
The name of the faction.
Usage:
shortname = f:name()
- nameRaw (f)
-
Gets the faction's raw / "real" (untranslated, internal) name.
This untranslated name should be used for identification purposes (e.g. can be passed to faction.get()). It should not be used for display purposes; for that, use faction.name() or faction.longname() instead.
Parameters:
- f Faction The faction to get the name of.
Returns:
-
string
The name of the faction.
Usage:
name = f:nameRaw()
- longname (f)
-
Gets the faction's translated long name.
This translated name should be used for display purposes (e.g. messages) where the longer version of the faction's display name should be used. It cannot be used as an identifier for the faction; for that, use faction.nameRaw() instead.
Parameters:
- f Faction Faction to get long name of.
Returns:
-
string
The long name of the faction (translated).
Usage:
longname = f:longname()
- areNeutral (f, n)
-
Checks to see if two factions are truly neutral with respect to each
other.
Parameters:
- f Faction Faction to check against.
- n Faction Faction to check if is true neutral.
Returns:
-
boolean
true if they are truely neutral, false if they aren't.
- areEnemies (f, e[, sys])
-
Checks to see if f is an enemy of e.
Parameters:
- f Faction Faction to check against.
- e Faction Faction to check if is an enemy.
- sys System System to check to see if they are enemies in. Mainly for when comparing to the player's faction. (optional)
Returns:
-
boolean
true if they are enemies, false if they aren't.
Usage:
if f:areEnemies( faction.get( "Dvaered" ) ) then
- areAllies (f, a[, sys])
-
Checks to see if f is an ally of a.
Parameters:
- f Faction Faction to check against.
- a faction Faction to check if is an enemy.
- sys System System to check to see if they are allies in. Mainly for when comparing to the player's faction. (optional)
Returns:
-
boolean
true if they are enemies, false if they aren't.
Usage:
if f:areAllies( faction.get( "Pirate" ) ) then
- hit (f, mod, Whether[, reason="script"[, single=false]])
-
Modifies the player's standing with the faction.
Also can modify the standing with allies and enemies of the faction.
Parameters:
- f Faction Faction to modify player's standing with.
- mod number Amount of reputation to change.
- Whether System or nil to make the faction hit local at a system, or global affecting all systems of the faction.
- reason string Reason behind it. This is passed as a string to the faction "hit" function. The engine can generate "kill" and "distress" sources. For missions the default is "script". (default "script")
- single boolean Whether or not the hit should affect allies/enemies of the faction getting a hit. (default false)
Returns:
-
How
much the reputation was actually changed after Lua script
was run.
Usage:
f:hit( -5, system.cur() ) -- Lowers faction by 5 at the current system
f:hit( 10 ) -- Globally increases faction by 10
f:hit( 10, nil, nil, true ) -- Globally increases faction by 10, but doesn't affect allies nor enemies of the faction.
- hit (f, mod, Whether[, reason="script"])
-
Simulates modifying the player's standing with a faction and computes
how much would be changed.
Parameters:
- f Faction Faction to simulate player's standing with.
- mod number Amount of reputation to simulate change.
- Whether System or nil to make the faction hit local at a system, or global.
- reason string Reason behind it. This is passed as a string to the faction "hit" function. The engine can generate "kill" and "distress" sources. For missions the default is "script". (default "script")
Returns:
-
How
much the reputation was actually changed after Lua script
was run.
- reputationGlobal (f)
-
Gets the player's global reputation with the faction.
Parameters:
- f Faction Faction to get player's standing with.
Returns:
-
number
The value of the standing.
Usage:
if f:reputationGlobal() >= 0 then -- Player is not hostile
- reputationText (f[, val=f:reputationGlobal()])
-
Gets the human readable standing text correpsonding (translated).
Parameters:
- f faction Faction to get standing text from.
- val number or nil Value to get the standing text of, or nil to use the global faction standing. (default f:reputationGlobal())
Returns:
-
string
Translated text corresponding to the faction value.
- reputationDefault (f)
-
Gets the player's default reputation with the faction.
Parameters:
- f Faction Faction to get player's default standing with.
Returns:
-
number
The value of the standing.
- setReputationGlobal (f, The)
-
Overrides the player's faction global standing with a faction. Use
sparingly as it overrites local standings at all systems.
Parameters:
- f Faction Faction to set the player's global reputation with.
- The number value of the reputation to set to.
- applyLocalThreshold (f, sys)
-
Enforces the local threshold of a faction starting at a particular
system. Meant to be used when computing faction hits from the faction
standing Lua scripts. Not meant for use elsewhere.
Parameters:
- f Faction Faction to apply local thresholding to.
- sys System System to compute the thresholding from. This will be the reference and will not have its value modified.
- modPlayer (f, mod[, reason="script"])
-
Modifies the player's standing with the faction.
Also modifies standing with allies and enemies of the faction.
Parameters:
- f Faction Faction to modify player's standing with.
- mod number The modifier to modify faction by.
- reason string Reason behind it. This is passed as a string to the faction "hit" function. The engine can generate "kill" and "distress" sources. For missions the default is "script". (default "script")
Usage:
f:modPlayer( -5 ) -- Lowers faction by 5
- modPlayerSingle (f, mod[, reason="script"])
-
Modifies the player's standing with the faction.
Does not affect other faction standings.
Parameters:
- f Faction Faction to modify player's standing with.
- mod number The modifier to modify faction by.
- reason string Reason behind it. This is passed as a string to the faction "hit" function. The engine can generate "kill" and "distress" sources. For missions the default is "script". (default "script")
Usage:
f:modPlayerSingle( 10 )
- modPlayerRaw (f, mod)
-
Modifies the player's standing with the faction.
Does not affect other faction standings and is not processed by the faction Lua script, so it indicates exactly the amount to be changed.
Parameters:
- f Faction Faction to modify player's standing with.
- mod number The modifier to modify faction by.
Usage:
f:modPlayerRaw( 10 )
- setPlayerStanding (f, value)
-
Sets the player's standing with the faction.
Parameters:
- f Faction Faction to set the player's standing for.
- value number Value to set the player's standing to (from -100 to 100).
Usage:
f:setPlayerStanding(70) -- Make player an ally
- playerStanding (f, value)
-
Gets the player's standing with the faction.
Parameters:
- f Faction Faction to get player's standing with.
- value number Faction standing value to get string of.
Returns:
- number The value of the standing and the human readable string.
- string The text corresponding to the standing (translated).
Usage:
if f:playerStanding() > 70 then -- Player is an ally
_v, str = f:playerStanding(50) -- Get the standing text for a value of 50
- playerStandingDefault (f)
-
Gets the player's default standing with the faction.
Parameters:
- f Faction Faction to get player's default standing with.
Returns:
-
number
The value of the standing.
- enemies (f)
-
Gets the enemies of the faction.
Parameters:
- f Faction Faction to get enemies of.
Returns:
-
{Faction,...}
A table containing the enemies of the faction.
Usage:
for k,v in pairs(f:enemies()) do -- Iterates over enemies
- allies (f)
-
Gets the allies of the faction.
Parameters:
- f Faction Faction to get allies of.
Returns:
-
{Faction,...}
A table containing the allies of the faction.
Usage:
for k,v in pairs(f:allies()) do -- Iterate over faction allies
- usesHiddenJumps (f)
-
Gets whether or not a faction uses hidden jumps.
Parameters:
- f Faction Faction to get whether or not they use hidden jumps.
Returns:
-
boolean
true if the faction uses hidden jumps, false
otherwise.
- logo (f)
-
Gets the faction logo.
Parameters:
- f Faction Faction to get logo from.
Returns:
-
Tex
The faction logo or nil if not applicable.
- colour (f)
-
Gets the faction colour.
Parameters:
- f Faction Faction to get colour from.
Returns:
-
Colour or nil
The faction colour or nil if not applicable.
- known (f)
-
Checks to see if a faction is known by the player.
Parameters:
- f Faction Faction to check if the player knows.
Returns:
-
boolean
true if the player knows the faction.
Usage:
b = f:known()
- setKnown (f[, b=false])
-
Sets a faction's known state.
Parameters:
- f Faction Faction to set known.
- b boolean Whether or not to set as known. (default false)
Usage:
f:setKnown( false ) -- Makes faction unknown.
- invisible (f)
-
Checks to see if a faction is invisible the player.
Parameters:
- f Faction Faction to check if is invisible to the player.
Returns:
-
boolean
true if the faction is invisible to the player.
Usage:
b = f:invisible()
- static (f)
-
Checks to see if a faction has a static standing with the player.
Parameters:
- f Faction Faction to check if has a static standing to the player.
Returns:
-
boolean
true if the faction is static to the player.
Usage:
b = f:static()
- reputationOverride (f)
-
Gets the overriden reputation value of a faction.
Parameters:
- f Faction Faction to get whether or not the reputation is overriden and the value.
Returns:
-
number or nil
The override reputation value or nil if not
overriden.
- setReputationOverride (f, Sets)
-
Gets the overriden reputation value of a faction.
Parameters:
- f Faction Faction to enable/disable reputation override of.
- Sets number or nil the faction reputation override to the value if a number, or disables it if nil.
- tags ([tag=nil])
-
Gets the tags a faction has.
Parameters:
- tag string Tag to check if exists. (default nil)
Returns:
-
table or boolean
Table of tags where the name is the key and true
is the value or a boolean value if a string is passed as the second parameter
indicating whether or not the specified tag exists.
Usage:
for k,v in ipairs(f:tags()) do ... end
if f:tags().likes_cheese then ... end
if f:tags("generic") then ... end
- dynAdd (base, name[, display[, params]])
-
Adds a faction dynamically. Note that if the faction already exists as
a dynamic faction, the existing one is returned.
Note Defaults to known.
Parameters:
- base Faction or nil Faction to base it off of or nil for new faction.
- name string Name to give the faction.
- display string Display name to give the faction. (optional)
- params table Table of parameters. Options include "ai" (string) to set the AI to use, "clearallies" (boolean) to clear all allies, "clearenemies" (boolean) to clear all enemies, "player" (number) to set the default player standing, "colour" (string|colour) which represents the factional colours. (optional)
- dynAlly (fac, ally[, remove=false])
-
Adds or removes allies to a faction. Only works with dynamic factions.
Parameters:
- fac Faction Faction to add ally to.
- ally Faction Faction to add as an ally.
- remove boolean Whether or not to remove the ally from the faction instead of adding it. (default false)
- dynEnemy (fac, enemy[, remove=false])
-
Adds or removes enemies to a faction. Only works with dynamic
factions.
Parameters:
- fac Faction Faction to add enemy to.
- enemy Faction Faction to add as an enemy.
- remove boolean Whether or not to remove the enemy from the faction instead of adding it. (default false)