Difference between revisions of "Tables"

From FreeSpace Wiki
Jump to: navigation, search
(.tbm files)
 
(60 intermediate revisions by 19 users not shown)
Line 1: Line 1:
'''Tables''' are the major data files in [[Portal:Freespace 1|FreeSpace]] and [[Portal:Freespace 2|FreeSpace 2]]. Compared with many other games, they are highly intuitive and easy to edit, requiring no special tools other than notepad. For more detail on specific tables, see the links below.
+
{{Tables}}
<br><br>
+
'''Tables''' are the major data files in [[Portal:FreeSpace 1|FreeSpace]] and [[Portal:FreeSpace 2|FreeSpace 2]]. Compared with many other games, they are highly intuitive and easy to edit, requiring no special tools other than Notepad. For more detail on specific tables, see the links below.
'''''Full list of tables can be found from [[:Category:Tables]] page'''''
+
 
<br><br>
+
'''''Full list of active tables can be found below. <br>In-depth modular tables info can be found in [[Modular Tables]] page.
 +
 
 +
Information on how FreeSpace uses tables can be found on the [[FreeSpace 2 directory structure|FreeSpace 2 directory structure]] page.'''''
 +
 
 +
Tables can use [[Version-specific commenting]].
 +
 
 +
==Accessing table files==
 +
Volition used a special kind of packaging method called .vp (Volition Pack) for the FreeSpace games. Table files are stored in Root_fs2.vp. To open and extract files from a VP, you must use a VP editing program such as [[VPView32]]. For more details about VP files and how to work with them, consult [[*.VP|this article]].
 +
 
 +
For some further information about where to put modified files, consult [[FreeSpace 2 directory structure]].
  
 
==Table files==
 
==Table files==
 +
Table files are customarily edited using Notepad, but any text editor that can save in a pure text format will do.
  
In general tables files are simple unformatted text files
 
 
 
===.tbl files===
 
===.tbl files===
  
Line 13: Line 21:
  
 
===.tbm files===
 
===.tbm files===
 +
These files are modular table files. They can be used for adding content to the 'base' tables or to modify the data from those files. For usage info and important notes, see [[Modular Tables]].
  
These files are modular table files. They can be used for adding content to the 'base' tables or to modify the data from those files.
+
==Notes of certain table files==
 
 
For deeper info see [[Modular Tables]].
 
 
 
===Notes of certain table files===
 
  
====Hardcoded table files====
+
===Hardcoded table files===
  
 
Some of the table files are not actually required as the basic version has been written directly to the code. However these can be overridden by table files present in game directories.
 
Some of the table files are not actually required as the basic version has been written directly to the code. However these can be overridden by table files present in game directories.
Line 26: Line 31:
 
'''These files are not present in standard FreeSpace 2 .vp files'''
 
'''These files are not present in standard FreeSpace 2 .vp files'''
  
[[Species_defs.tbl]]<br>
+
*[[Ai_profiles.tbl]]
[[Objecttypes.tbl]]<br>
+
*[[Autopilot.tbl]]
[[iff_defs.tbl]]
+
*[[Colors.tbl]]
 +
*[[Iff_defs.tbl]]
 +
*[[Objecttypes.tbl]]
 +
*[[Species_defs.tbl]]
  
====Optional table files====
+
===Optional table files===
  
 
Certain tables are not found from the code nor do they belong to the basic table set. These tables are parsed if game detects them
 
Certain tables are not found from the code nor do they belong to the basic table set. These tables are parsed if game detects them
Line 36: Line 44:
 
'''These files are not present in standard FreeSpace 2 .vp files'''
 
'''These files are not present in standard FreeSpace 2 .vp files'''
  
[[Armor.tbl]]
+
*[[Armor.tbl]]
[[Scripting.tbl]]
+
*[[Controlconfigdefaults.tbl]]
 +
*[[Scripting.tbl]]
 +
 
 +
===Obsolete table files===
 +
 
 +
Some table files have since been 'retired' and they are no longer needed with FreeSpace Open
 +
 
 +
*[[Hud.tbl]]
 +
*[[Launchhelp.tbl]]
 +
*[[Menu.tbl]]
 +
*[[Pixels.tbl]]
 +
*[[Tooltips.tbl]]
 +
 
 +
===Theoretical table files===
 +
 
 +
These tables are documentations of possible future tables for use with FreeSpace Open
 +
 
 +
*[[Interface.tbl]]
  
 
==Important notes==
 
==Important notes==
Line 43: Line 68:
 
===Table entries must be ordered===
 
===Table entries must be ordered===
  
*As a general rule, all '''''Table entries must be ordered'''''.
+
*As a general rule, '''''all the table entries must be ordered'''''.
 
*Keep the order shown in the following help sections for each table in both normal tables (tbl files) and [[Modular Tables]] (tbm files). If you don't do it, you can get parser errors on FS2 or FRED2 loading when they are reading them.
 
*Keep the order shown in the following help sections for each table in both normal tables (tbl files) and [[Modular Tables]] (tbm files). If you don't do it, you can get parser errors on FS2 or FRED2 loading when they are reading them.
 +
** In other words, you don't have to have all of these details/attributes for a given weapon/ship/etc (or a modification of a weapon/etc)--few, if any, have them all, and many have a mere fraction of these--but the ones you do have must be kept in the same relative order. If, for example, your weapon doesn't have/need any of the 30-or-so attributes between 'Lifetime' and 'ImpactSnd', you can probably leave them out altogether, but be sure to place your entry for 'ImpactSnd' after your entry for 'Lifetime' on the weapon in question.
  
  
 
==Brief descriptions of table files==
 
==Brief descriptions of table files==
*Asterisks (*) denote a table added for Freespace 2. These are not required by FS1.
+
 
*Plus signs (<sup>+</sup>) denote a table added by the [[FSSCP_Introduction|Source Code Project]]. These are not required by retail FS2
+
*In all the table help pages, SCP added entries are usually marked with infoboxes that mark the branch there the particular feature has added to.
*For full list and links see [[:Category:Tables]]
+
:*'''<nowiki>{{Table3610| text}}</nowiki>''' gives 3.6.10 box
<br>[[ai.tbl]] - Defines a small subset of the AI behavior.
+
{{Table3610| text}}
<br>[[ai_profiles.tbl]]<sup>+</sup> - Defines extended options for AI behavior. AI profiles can be specified on a per-mission basis.
+
:*'''<nowiki>{{Table3612| text}}</nowiki>''' gives 3.6.12 box
<br>[[armor.tbl]]<sup>+</sup> - Defines the behaviour of ship armor.
+
{{Table3612| text}}
<br>[[iff_defs.tbl]]<sup>+</sup> - Defines IFF. New IFFs can be specified, with different behaviors for each.
+
:*'''<nowiki>{{Table3614| text}}</nowiki>''' gives 3.6.14 box
<br>[[ships.tbl]] - Defines the statistics of ships in-game.
+
{{Table3614| text}}
<br>[[species_defs.tbl]]<sup>+</sup> - Defines characteristics of ships belonging to each species.
+
:*'''<nowiki>{{Table3616| text}}</nowiki>''' gives 3.6.16 box
<br>[[weapons.tbl]] - Defines the statistics of weapons in-game.
+
{{Table3616| text}}
 +
:*'''<nowiki>{{Table37| text}}</nowiki>''' gives 3.7.0 box
 +
{{Table37| text}}
 +
:*'''<nowiki>{{Table372| text}}</nowiki>''' gives 3.7.2 box
 +
{{Table372| text}}
 +
:*'''<nowiki>{{Table3610| text}}</nowiki>''' gives 3.7.4 box
 +
{{Table374| text}}
 +
:*'''<nowiki>{{Table3612| text}}</nowiki>''' gives 3.8.0 box
 +
{{Table38| text}}
 +
:*'''<nowiki>{{Table3614| text}}</nowiki>''' gives 3.8.2 box
 +
{{Table382| text}}
 +
*For full list of table related pages and links see [[:Category:Tables]]
 +
 
  
 
[[Category:Tables|*]]
 
[[Category:Tables|*]]
  
 
[[Category:Modding]]
 
[[Category:Modding]]
 +
 +
[[Category:File Types]]

Latest revision as of 02:06, 15 December 2022

List of Tables and related code files
* Notes Modular Tables
** Notes tables which only use modular tables
Ai.tbl* /ai/aicode.cpp
Ai_profiles.tbl* /ai/ai_profiles.cpp
Animation.tbl** /model/modelanimation.cpp
Armor.tbl* /ship/ship.cpp
Asteroid.tbl* /asteroid/asteroid.cpp
Autopilot.tbl* /autopilot/autopilot.cpp
Cheats.tbl* /cheats_table/cheats_table.cpp
Colors.tbl* /globalincs/alphacolors.cpp
Curves.tbl* /math/curves.cpp
Controlconfigdefaults.tbl /controlconfig/controlsconfigcommon.cpp
Credits.tbl* /menuui/credits.cpp
Cutscenes.tbl* /cutscene/cutscenes.cpp
Decals.tbl** /decals/decals.cpp
Fireball.tbl* /fireball/fireballs.cpp
Fonts.tbl* /graphics/font.cpp
Game_settings.tbl* /mod_table/mod_table.cpp
Glowpoints.tbl* /model/modelread.cpp
Help.tbl* /gamehelp/contexthelp.cpp
Hud_gauges.tbl* /hud/hudparse.cpp
Icons.tbl* /mission/missionbriefcommon.cpp
Iff_defs.tbl* /iff_defs/iff_defs.cpp
Keywords.tbl* Not In Codebase
Lighting_Profiles.tbl* /lighting/lighting_profiles.cpp
Lightning.tbl* /nebula/neblightning.cpp
Mainhall.tbl* /menuui/mainhallmenu.cpp
Medals.tbl* /stats/medals.cpp
Messages.tbl* /mission/missionmessage.cpp
Mflash.tbl* /weapon/muzzleflash.cpp
Music.tbl* /gamesnd/eventmusic.cpp
Nebula.tbl* /nebula/neb.cpp
Objecttypes.tbl* /ship/ship.cpp
Options.tbl* Not In Codebase
Particle effects(-part.tbm)** /particle/effects...
Post_processing.tbl /graphics/gropenglpostprocessing.cpp
Rank.tbl* /stats/scoring.cpp
Scpui.tbl* Not In Codebase
Scripting.tbl* /parse/scripting.cpp
Ships.tbl* /ship/ship.cpp
Sexps.tbl** /parse/sexp/sexp_lookup.cpp
Sounds.tbl* /gamesnd/gamesnd.cpp
Species_defs.tbl* /species_defs/species_defs.cpp
Species.tbl* /menuui/techmenu.cpp
Ssm.tbl* /hud/hudartillery.cpp
Stars.tbl* /starfield/starfield.cpp
Strings.tbl* /localization/localize.cpp
Tips.tbl* /menuui/playermenu.cpp
Traitor.tbl* /stats/scoring.cpp
Tstrings.tbl* /localization/localize.cpp
Virtual_pofs.tbl* /model/modelreplace.cpp
Weapon_expl.tbl* /weapon/weapons.cpp
Weapons.tbl* /weapon/weapons.cpp

Tables are the major data files in FreeSpace and FreeSpace 2. Compared with many other games, they are highly intuitive and easy to edit, requiring no special tools other than Notepad. For more detail on specific tables, see the links below.

Full list of active tables can be found below.
In-depth modular tables info can be found in Modular Tables page.

Information on how FreeSpace uses tables can be found on the FreeSpace 2 directory structure page.

Tables can use Version-specific commenting.

Accessing table files

Volition used a special kind of packaging method called .vp (Volition Pack) for the FreeSpace games. Table files are stored in Root_fs2.vp. To open and extract files from a VP, you must use a VP editing program such as VPView32. For more details about VP files and how to work with them, consult this article.

For some further information about where to put modified files, consult FreeSpace 2 directory structure.

Table files

Table files are customarily edited using Notepad, but any text editor that can save in a pure text format will do.

.tbl files

These files are the basic FreeSpace table used for defining various aspects of the game. Game reads only single .tbl choosing the one it encounters first while parsing the game directories.

.tbm files

These files are modular table files. They can be used for adding content to the 'base' tables or to modify the data from those files. For usage info and important notes, see Modular Tables.

Notes of certain table files

Hardcoded table files

Some of the table files are not actually required as the basic version has been written directly to the code. However these can be overridden by table files present in game directories.

These files are not present in standard FreeSpace 2 .vp files

Optional table files

Certain tables are not found from the code nor do they belong to the basic table set. These tables are parsed if game detects them

These files are not present in standard FreeSpace 2 .vp files

Obsolete table files

Some table files have since been 'retired' and they are no longer needed with FreeSpace Open

Theoretical table files

These tables are documentations of possible future tables for use with FreeSpace Open

Important notes

Table entries must be ordered

  • As a general rule, all the table entries must be ordered.
  • Keep the order shown in the following help sections for each table in both normal tables (tbl files) and Modular Tables (tbm files). If you don't do it, you can get parser errors on FS2 or FRED2 loading when they are reading them.
    • In other words, you don't have to have all of these details/attributes for a given weapon/ship/etc (or a modification of a weapon/etc)--few, if any, have them all, and many have a mere fraction of these--but the ones you do have must be kept in the same relative order. If, for example, your weapon doesn't have/need any of the 30-or-so attributes between 'Lifetime' and 'ImpactSnd', you can probably leave them out altogether, but be sure to place your entry for 'ImpactSnd' after your entry for 'Lifetime' on the weapon in question.


Brief descriptions of table files

  • In all the table help pages, SCP added entries are usually marked with infoboxes that mark the branch there the particular feature has added to.
  • {{Table3610| text}} gives 3.6.10 box
FS2 Open 3.6.10: text
  • {{Table3612| text}} gives 3.6.12 box
FS2 Open, 3.6.12: text
  • {{Table3614| text}} gives 3.6.14 box
FS2 Open, 3.6.14: text
  • {{Table3616| text}} gives 3.6.16 box
FS2 Open, 3.6.16: text
  • {{Table37| text}} gives 3.7.0 box
FS2 Open, 3.7: text
  • {{Table372| text}} gives 3.7.2 box
FS2 Open, 3.7.2: text
  • {{Table3610| text}} gives 3.7.4 box
FS2 Open, 3.7.4: text
  • {{Table3612| text}} gives 3.8.0 box
FS2 Open, 3.8: text
  • {{Table3614| text}} gives 3.8.2 box
FS2 Open, 19.0: text