Difference between revisions of "Content Management"

From Ultronomicon
Jump to navigation Jump to search
(More history, top-level goals)
 
(30 intermediate revisions by 4 users not shown)
Line 1: Line 1:
 +
{{safe}}
 +
 
==Introduction==
 
==Introduction==
The game still uses a virtual file system as before, see [[Content Management]] for information on this.  However, starting in 0.6.4, the "layering" effect of the directory system is no longer used to index files.
+
The game still uses a virtual file system as before: see [[Content Management]] for information on this.  However, starting in 0.6.4, the "layering" effect of the directory system is no longer used to index files for the purposes of regular addons. The concept of addon shadow packages was introduced in 0.6.6 as a stop-gap since the resource system is not yet finished.
  
 
==Hey, my remixes don't work!==
 
==Hey, my remixes don't work!==
Line 15: Line 17:
  
 
==A typical layout==
 
==A typical layout==
 +
 +
===On Windows===
 +
A typical The Ur-Quan Masters installation on Windows looks like this:
 +
<code>
 +
C:\Program Files\The Ur-Quan Masters\uqm.exe
 +
C:\Program Files\The Ur-Quan Masters\content\packages\uqm-0.7.0-content.uqm
 +
C:\Program Files\The Ur-Quan Masters\content\addons\uqm-0.7.0-3domusic.uqm
 +
C:\Program Files\The Ur-Quan Masters\content\addons\uqm-0.7.0-voice.uqm
 +
C:\Program Files\The Ur-Quan Masters\content\addons\uqm-remix-disc1.uqm
 +
C:\Program Files\The Ur-Quan Masters\content\addons\uqm-remix-disc2.uqm
 +
C:\Program Files\The Ur-Quan Masters\content\addons\uqm-remix-disc3.uqm
 +
C:\Program Files\The Ur-Quan Masters\content\version
 +
</code>
 +
 +
===On Mac OS X===
 +
A typical The Ur-Quan Masters installation on Mac OS X looks like this:
 +
<code>
 +
/Applications/The Ur-Quan Masters/Contents/PkgInfo
 +
/Applications/The Ur-Quan Masters/Contents/Info.plist
 +
/Applications/The Ur-Quan Masters/Contents/Frameworks/Ogg.framework
 +
/Applications/The Ur-Quan Masters/Contents/Frameworks/SDL_image.framework
 +
/Applications/The Ur-Quan Masters/Contents/Frameworks/SDL.framework
 +
/Applications/The Ur-Quan Masters/Contents/Frameworks/Vorbis.framework
 +
/Applications/The Ur-Quan Masters/Contents/MacOS/The Ur-Quan Masters
 +
/Applications/The Ur-Quan Masters/Contents/Resources/The Ur-Quan Masters.icns
 +
/Applications/The Ur-Quan Masters/Contents/Resources/content/version
 +
/Applications/The Ur-Quan Masters/Contents/Resources/content/packages/uqm-0.7.0-content.uqm
 +
/Applications/The Ur-Quan Masters/Contents/Resources/content/addons/uqm-0.7.0-voice.uqm
 +
/Applications/The Ur-Quan Masters/Contents/Resources/content/addons/uqm-remix-disc1.uqm
 +
/Applications/The Ur-Quan Masters/Contents/Resources/content/addons/uqm-remix-disc2.uqm
 +
/Applications/The Ur-Quan Masters/Contents/Resources/content/addons/uqm-remix-disc3.uqm
 +
</code>
  
 
===On Linux===
 
===On Linux===
Line 21: Line 55:
 
  /usr/local/bin/uqm        (wrapper script)
 
  /usr/local/bin/uqm        (wrapper script)
 
  /usr/local/lib/uqm/uqm    (the actual executable)
 
  /usr/local/lib/uqm/uqm    (the actual executable)
  /usr/local/share/uqm/content/packages/uqm-0.6.0-content.uqm
+
  /usr/local/share/uqm/content/packages/uqm-0.7.0-content.uqm
  /usr/local/share/uqm/content/packages/uqm-0.6.0-3domusic.uqm
+
  /usr/local/share/uqm/content/addons/uqm-0.7.0-3domusic.uqm
  /usr/local/share/uqm/content/packages/uqm-0.6.0-voice.uqm
+
  /usr/local/share/uqm/content/addons/uqm-0.7.0-voice.uqm
  /usr/local/share/uqm/content/addons/remix/uqm-remix-pack1.zip
+
  /usr/local/share/uqm/content/addons/uqm-remix-disc1.uqm
  /usr/local/share/uqm/content/addons/remix/uqm-remix-pack2.zip
+
  /usr/local/share/uqm/content/addons/uqm-remix-disc2.uqm
  /usr/local/share/uqm/content/addons/remix/uqm-remix-pack3.zip
+
  /usr/local/share/uqm/content/addons/uqm-remix-disc3.uqm
/usr/local/share/uqm/content/addons/remix/remix1.rmp
 
/usr/local/share/uqm/content/addons/remix/remix2.rmp
 
/usr/local/share/uqm/content/addons/remix/remix3.rmp
 
 
  /usr/local/share/uqm/content/version
 
  /usr/local/share/uqm/content/version
 
</code>
 
</code>
  
Other OS layouts should be similarTODO: Expand.
+
==Content directories==
 +
The following list shows which directories are mounted in the game in 0.7. The later mentioned ones are mounted on top of the earlier mentioned ones.
 +
{|border=1
 +
!Directory!!Mounted on!!flags
 +
|-
 +
|[[#Default packages|default packages]], in alphabetic order||/  ||read-only
 +
|-
 +
|[[#Add-on packages|add-on packages]], in alphabetic order  ||/addons/[name]  ||read-only
 +
|-
 +
|[[#Content base directory|content base directory]]        ||/  ||read-only
 +
|-
 +
|[[#Add-on shadow packages|add-on shadow packages]], in specified order  ||/  ||read-only
 +
|-
 +
|[[#User data directory|user data directory]]              ||/  ||read-write
 +
|-
 +
|[[#Temporary directory|temporary directory]]              ||/tmp||read-write
 +
|}
 +
Note that addon packages are now mounted in their own tree branches, with one exception. The only way to override (or ''shadow'') the content is with an add-on shadow package. This is necessary in cases like extending fonts or supplying different menu keys because the resource system is not yet finished.
 +
 
 +
==Add-on layout==
 +
This is better illustrated with an example:
 +
<code>
 +
addons/russian-trans-2.0.zip
 +
</code>
 +
Where ''russian-trans-2.0.zip'' contains:
 +
<code>
 +
lang-russian/russian.rmp
 +
lang-russian/uqmpack.nfo
 +
lang-russian/shadow-content/russian-shadow.zip (see notes below)
 +
lang-russian/comm/commander.txt
 +
lang-russian/comm/arilou.txt
 +
[etc., files with layout of author's choosing, all under lang-russian/ ]
 +
</code>
 +
and is mounted like so:
 +
<code>
 +
/addons/lang-russian/russian.rmp
 +
/addons/lang-russian/uqmpack.nfo
 +
/addons/lang-russian/comm/commander.txt
 +
/addons/lang-russian/comm/arilou.txt
 +
[etc.]
 +
</code>
 +
 
 +
And ''russian-shadow.zip'' contains:
 +
<code>
 +
base/fonts/micro.fon/
 +
base/fonts/player.fon/
 +
[etc.]
 +
</code>
 +
and is mounted like so:
 +
<code>
 +
/base/fonts/micro.fon/
 +
/base/fonts/player.fon/
 +
[etc.]
 +
</code>
 +
A shadow content zip works like the add-ons worked in the prior versions: the file structure must match the default content layout, and the files in the zip will ''shadow'' (or override) the default content.
 +
 
 +
''russian.rmp'' contains:
 +
<code>
 +
comm.arilou.dialogue = CONVERSATION:addons/lang-russian/comm/arilou.txt:addons/3dovoice/arilou/:addons/3dovoice/arilou/arilou.ts
 +
comm.commander.dialogue = CONVERSATION:addons/lang-russian/comm/commander.txt:addons/3dovoice/commander/:addons/3dovoice/commander/commander.ts
 +
[etc., resource identifiers of author's choosing; see content/uqm.rmp for resource strings]
 +
</code>
 +
An add-on must contain at least one .rmp file or it will not be loaded.
 +
Note that CONVERSATION resource type has three parts: the subtitles file, the voice ogg directory, and the timestamps file. If the last two are omitted, the voices will not play when this add-on is loaded. See the ''3domusic'' and ''3dovoice'' standard add-on for more examples. You may add completely new resource identifiers if you plan to add brand new content in your mod.
 +
 
 +
''uqmpack.nfo'' contains:
 +
<code>
 +
name=Russian Pack
 +
author=John Doe
 +
version=2
 +
description=Russian translation of the game.
 +
year=2011
 +
  min_uqm_version=0.7
 +
</code>
 +
While ''uqmpack.nfo'' file is not currently required in the add-on, we ask that you add one for the future online add-on management. This will make your add-on more user-friendly.
 +
 
 +
====Shadow content====
 +
Shadow content works like the add-ons worked in the prior versions: the file structure must match the default content layout, and the files will ''shadow'' (or override) the default content.
 +
 
 +
Currently, add-on ''shadow-content'' directory '''must''' contain .zip (or .uqm) files. Only zipped files will be mounted under the root directory. This means that in order to create a single zipped add-on file with shadow content, you have to put a zip inside a zip. In that case, it may be a good idea to zip the shadow content with method ''store'' (no compression) in order to improve the in-game performance. Please note that we intend to remove this limitation in v0.7.1. We hope to release the 0.7.1 with bugfixes as quickly as we possible, so modders may want to wait for it.
  
 
==Current Development Status==
 
==Current Development Status==
  
The resource system (and thus the content directory) are in flux as the development team works on implemented a new resource system.  This should remove a lot of the more brittle components from the legacy system and make addons easier to add, and mods to the source easier to make work.  Detailed goals, milestones, and comments are in this section.
+
The resource system (and thus the content directory) are in flux as the development team works on implementing a new resource system.  This should remove a lot of the more brittle components from the legacy system and make addons easier to add, and mods to the source easier to make work.  Detailed goals, milestones, and comments are in this section.
  
 
===Top-Level Roadmap===
 
===Top-Level Roadmap===
Line 43: Line 153:
 
This actually may migrate over time as we see what works and what doesn't, but it will at least mark where we've been and where we think we're going.
 
This actually may migrate over time as we see what works and what doesn't, but it will at least mark where we've been and where we think we're going.
  
# Implement a generic string-based key-to-value system for doing resource lookups.  ''Completed in revision 1916.''
+
# Implement a generic string-based key-to-value system for doing resource lookups.  ''Completed in Revision 1916.''
# Keep user settings in the resource-map system. ''Completed in revision 1916.''
 
 
# Drop requirement on binary resource indices by translating them to text. ''Completed in Revision 2003.''
 
# Drop requirement on binary resource indices by translating them to text. ''Completed in Revision 2003.''
# Unify key configuration into the resource-map. ''Completed in revision 2705.''
+
# Replace the integer-based resource system with string-based key mappings that are easier to extend. ''Completed in Revision 2963.''
# Unify Melee configuration into the resource-map.
+
# Rework resource types to allow for a wider range of resources. Migrate all 3DO content into standalone addon packs. ''Completed in Revision 3104.''
# Unify file-loading with the resource-map system. ''In progress.''
+
# Uniform API for all uses of the resource-map system, merging about six redundant subsystems into one. ''In progress.''
# Uniform API for all uses of the resource-map system, merging about six redundant subsystems into one. ''Previous steps require partial progress, but not currently an explicit target.''
 
  
 
===Current goals===
 
===Current goals===
  
The immediate goal is to shift away from .lst files (themselves text translations of the old binary .ndx files) to a string-based key-mapping system.
+
It's now feasible to start moving hardcoded data like the starship constants and the starmap itself into .rmp files.  It's not clear how much of this is wise for 0.7.0 itself, but we should probably do at least a ''little'' to gather interest.
  
*Instead of pointing from resource numbers to files, point them to string IDs that the resource map will forward to files. ''Completed in Revision 2868.''
+
* Keep user settings in a resource-map. ''Completed in Revision 1916.''
*Have addon packs modify the resource map, not the underlying file system. ''Completed in Revision 2871.''
+
* Keep key configuration in a resource-map. ''Completed in Revision 2705.''
*Self-contained addon packs that own their own directory names. ''Completed in Revision 2871.''
+
* Allow loads of resource files to be placed into isolated submaps to keep values separated. ''Completed in Revision 3105.''
*Remixes selectable from the Setup Menu, even if general Resource Management UIs don't work. ''Completed in Revision 2873.''
+
* Allow saves to strip some or all of the common prefix to save only the "submap" component. ''Completed in Revision 3105.''
*Efficiency concerns indicate resmap.c should be using hashtables, not an association list. ''Completed in Revision 2875.''
+
* Merge user settings and key configuration into the main resource map, eliminating the now-redundant mapres.c routines. ''Completed in Revision 3108.''
*Types of resources should be functions of the resource, not the name. SvdB suggests making the values be something like STRING:starcon.txt. This is probably the Right Thing, but it's not what the integer-based ID system does. This could make life interesting. ''Completed in Revision 2909, with both systems currently active in parallel for cross-checking.''
+
* Turn melee data (teams, current situation) into resource maps like the other two.
*Resource names need to be modified so that resources in the same package have identical prefixes. ''Abandoned: Replaced with...''
 
*Resource names for constructed resources -- primarily planet graphics, life forms, and the initial selection of starships -- need to be reorganized so that the resource strings are easy to construct.
 
*Switch from 32-bit integers indexed via .ls2 files into direct indices into the .rmp files. A lot of things have to change all at once to do this:
 
**RESOURCE changes from DWORD to const char *.
 
**Calls to MAKE_RESOURCE need to be modified to work with string resources.
 
*It really looks like the RES_INDEX type can actually be safely retired -- there is exactly one point in the entire codebase where the same resource number is intended for use in multiple indices, and it's part of the blank CODE resource.
 
*We lack types/handlers for presentations, voice clips, and timestamps. This should change. The easiest way to handle voice clips and timestamps is to have multiple values for the comm resource; something like CONVERSATION:comm/arilou/arilou.txt:addons/voice/arilou:addons/voice/arilou/arilou.ts.
 
* Uniform APIs require uniform reference.  This is actually part of a different step, but part of it turned out to be necessary for sensibly dropping the indices.
 
** Uniform reference to file-type resources. ''Completed in Revision 2903.'' This also let us actually start using malloc and free for our memory management directly.
 
** Uniform reference between file-type and value-type resources.
 
  
 
===Other work===
 
===Other work===
Line 77: Line 175:
  
 
*Massive, cathartic violence against the content directory structure, ending in convenient subprojects. ''Incomplete, but started in revision 2870.''
 
*Massive, cathartic violence against the content directory structure, ending in convenient subprojects. ''Incomplete, but started in revision 2870.''
**Note that an SVN update following an SVN move will redownload all content, so we should be very sure about where we're moving the voice packs before actually performing the move.
 
**Doing this right really requires at least resource support for voice clips and timestamps. Rehardcoding voice data locations might work as a stopgap.
 
**We will require a new option (and new automatic defaults) for automatically detecting the content directory and mounting the addons directory from a separate location (So that one could individually SVN-checkout just source, just source+base content, or everything.)
 
 
*Let .rmp files include other ones to make uqm.rmp less monolithic.  This could also be used to automatically include addon packs (such as, say, a Cyrillic Font Pack) if necessary.
 
*Let .rmp files include other ones to make uqm.rmp less monolithic.  This could also be used to automatically include addon packs (such as, say, a Cyrillic Font Pack) if necessary.
 +
**At the moment we just load all .rmp files in any given directory. This may be good enough.
 
*The hack to make the remix packs work is kind of ugly. A more permanent fix would allow special variable expansion to map to wherever uio elected to put it, giving each extension its own space for files. Best of all would be a magic variable for "The home of the extension named X." Implementing this would give us full namespaces and namespace imports.
 
*The hack to make the remix packs work is kind of ugly. A more permanent fix would allow special variable expansion to map to wherever uio elected to put it, giving each extension its own space for files. Best of all would be a magic variable for "The home of the extension named X." Implementing this would give us full namespaces and namespace imports.
 
** It's only ugly under the surface, though, and will only affect mod writers, and that rather minimally.  The users just shove packages blindly into content/addons.
 
** It's only ugly under the surface, though, and will only affect mod writers, and that rather minimally.  The users just shove packages blindly into content/addons.
*RES_INDEX resources are basically redundant in the new system, but there's no reason they couldn't become const char *s as well. These would go to a new SetResourcePrefix command that replaces SetResourceIndex. Then each ship can load large.graphics on its own, and can also load ship-specific resources like zapsat.large. Resource saving actually already works like this (you provide a prefix that specifies the root of the key-tree to save); we should extend loading to do the same.
+
*Online configuration of which extensions to use.
*online configuration of which extensions to use.
 
 
*It would be nice to have an offline application for building extensions.
 
*It would be nice to have an offline application for building extensions.
 
*A more "self-aware" resource system should give us a much better handle on the remaining resource-related bugs.
 
*A more "self-aware" resource system should give us a much better handle on the remaining resource-related bugs.
 
*Can we leverage this for improving save game formats?
 
*Can we leverage this for improving save game formats?
 +
*Planet data is aliased in #defines and structure initializers when it should probably be in the resource map.
 +
*Ship data is *not* aliased, requiring a bunch of structure initializers that probably (though less probably than in the planet data case) should be name normalized.
  
 
[[Category:About the Star Control series]]
 
[[Category:About the Star Control series]]

Latest revision as of 19:35, 18 July 2011

This page is guaranteed to be spoiler free. It is safe for you to read this page even if you have not completed playing The Ur-Quan Masters. Links you follow from this page do not share this guarantee unless they also include this text.


Introduction[edit]

The game still uses a virtual file system as before: see Content Management for information on this. However, starting in 0.6.4, the "layering" effect of the directory system is no longer used to index files for the purposes of regular addons. The concept of addon shadow packages was introduced in 0.6.6 as a stop-gap since the resource system is not yet finished.

Hey, my remixes don't work![edit]

UQM 0.6.4 (SVN revision 2869) changed addon pack mechanics incompatibly. Your remix zips are still OK, but you will need to perform these steps:

  • Move the addons directory from content/packages to content/
  • Download the appropriate .rmp files from http://sc2.sourceforge.net/remix-rmp/ and put them in the same directory as the remix zips.
  • Ensure that the remix directory is, in fact, addons/remix.

Detailed description[edit]

Still needs to be done.

A typical layout[edit]

On Windows[edit]

A typical The Ur-Quan Masters installation on Windows looks like this:

C:\Program Files\The Ur-Quan Masters\uqm.exe
C:\Program Files\The Ur-Quan Masters\content\packages\uqm-0.7.0-content.uqm
C:\Program Files\The Ur-Quan Masters\content\addons\uqm-0.7.0-3domusic.uqm
C:\Program Files\The Ur-Quan Masters\content\addons\uqm-0.7.0-voice.uqm
C:\Program Files\The Ur-Quan Masters\content\addons\uqm-remix-disc1.uqm
C:\Program Files\The Ur-Quan Masters\content\addons\uqm-remix-disc2.uqm
C:\Program Files\The Ur-Quan Masters\content\addons\uqm-remix-disc3.uqm
C:\Program Files\The Ur-Quan Masters\content\version

On Mac OS X[edit]

A typical The Ur-Quan Masters installation on Mac OS X looks like this:

/Applications/The Ur-Quan Masters/Contents/PkgInfo
/Applications/The Ur-Quan Masters/Contents/Info.plist
/Applications/The Ur-Quan Masters/Contents/Frameworks/Ogg.framework
/Applications/The Ur-Quan Masters/Contents/Frameworks/SDL_image.framework
/Applications/The Ur-Quan Masters/Contents/Frameworks/SDL.framework
/Applications/The Ur-Quan Masters/Contents/Frameworks/Vorbis.framework
/Applications/The Ur-Quan Masters/Contents/MacOS/The Ur-Quan Masters
/Applications/The Ur-Quan Masters/Contents/Resources/The Ur-Quan Masters.icns
/Applications/The Ur-Quan Masters/Contents/Resources/content/version
/Applications/The Ur-Quan Masters/Contents/Resources/content/packages/uqm-0.7.0-content.uqm
/Applications/The Ur-Quan Masters/Contents/Resources/content/addons/uqm-0.7.0-voice.uqm
/Applications/The Ur-Quan Masters/Contents/Resources/content/addons/uqm-remix-disc1.uqm
/Applications/The Ur-Quan Masters/Contents/Resources/content/addons/uqm-remix-disc2.uqm
/Applications/The Ur-Quan Masters/Contents/Resources/content/addons/uqm-remix-disc3.uqm

On Linux[edit]

A typical The Ur-Quan Masters installation on Linux looks like this:

/usr/local/bin/uqm        (wrapper script)
/usr/local/lib/uqm/uqm    (the actual executable)
/usr/local/share/uqm/content/packages/uqm-0.7.0-content.uqm
/usr/local/share/uqm/content/addons/uqm-0.7.0-3domusic.uqm
/usr/local/share/uqm/content/addons/uqm-0.7.0-voice.uqm
/usr/local/share/uqm/content/addons/uqm-remix-disc1.uqm
/usr/local/share/uqm/content/addons/uqm-remix-disc2.uqm
/usr/local/share/uqm/content/addons/uqm-remix-disc3.uqm
/usr/local/share/uqm/content/version

Content directories[edit]

The following list shows which directories are mounted in the game in 0.7. The later mentioned ones are mounted on top of the earlier mentioned ones.

Directory Mounted on flags
default packages, in alphabetic order / read-only
add-on packages, in alphabetic order /addons/[name] read-only
content base directory / read-only
add-on shadow packages, in specified order / read-only
user data directory / read-write
temporary directory /tmp read-write

Note that addon packages are now mounted in their own tree branches, with one exception. The only way to override (or shadow) the content is with an add-on shadow package. This is necessary in cases like extending fonts or supplying different menu keys because the resource system is not yet finished.

Add-on layout[edit]

This is better illustrated with an example:

addons/russian-trans-2.0.zip

Where russian-trans-2.0.zip contains:

lang-russian/russian.rmp
lang-russian/uqmpack.nfo
lang-russian/shadow-content/russian-shadow.zip (see notes below)
lang-russian/comm/commander.txt
lang-russian/comm/arilou.txt
[etc., files with layout of author's choosing, all under lang-russian/ ]

and is mounted like so:

/addons/lang-russian/russian.rmp
/addons/lang-russian/uqmpack.nfo
/addons/lang-russian/comm/commander.txt
/addons/lang-russian/comm/arilou.txt
[etc.]

And russian-shadow.zip contains:

base/fonts/micro.fon/
base/fonts/player.fon/
[etc.]

and is mounted like so:

/base/fonts/micro.fon/
/base/fonts/player.fon/
[etc.]

A shadow content zip works like the add-ons worked in the prior versions: the file structure must match the default content layout, and the files in the zip will shadow (or override) the default content.

russian.rmp contains:

comm.arilou.dialogue = CONVERSATION:addons/lang-russian/comm/arilou.txt:addons/3dovoice/arilou/:addons/3dovoice/arilou/arilou.ts 
comm.commander.dialogue = CONVERSATION:addons/lang-russian/comm/commander.txt:addons/3dovoice/commander/:addons/3dovoice/commander/commander.ts 
[etc., resource identifiers of author's choosing; see content/uqm.rmp for resource strings]

An add-on must contain at least one .rmp file or it will not be loaded. Note that CONVERSATION resource type has three parts: the subtitles file, the voice ogg directory, and the timestamps file. If the last two are omitted, the voices will not play when this add-on is loaded. See the 3domusic and 3dovoice standard add-on for more examples. You may add completely new resource identifiers if you plan to add brand new content in your mod.

uqmpack.nfo contains:

name=Russian Pack
author=John Doe
version=2
description=Russian translation of the game.
year=2011
min_uqm_version=0.7

While uqmpack.nfo file is not currently required in the add-on, we ask that you add one for the future online add-on management. This will make your add-on more user-friendly.

Shadow content[edit]

Shadow content works like the add-ons worked in the prior versions: the file structure must match the default content layout, and the files will shadow (or override) the default content.

Currently, add-on shadow-content directory must contain .zip (or .uqm) files. Only zipped files will be mounted under the root directory. This means that in order to create a single zipped add-on file with shadow content, you have to put a zip inside a zip. In that case, it may be a good idea to zip the shadow content with method store (no compression) in order to improve the in-game performance. Please note that we intend to remove this limitation in v0.7.1. We hope to release the 0.7.1 with bugfixes as quickly as we possible, so modders may want to wait for it.

Current Development Status[edit]

The resource system (and thus the content directory) are in flux as the development team works on implementing a new resource system. This should remove a lot of the more brittle components from the legacy system and make addons easier to add, and mods to the source easier to make work. Detailed goals, milestones, and comments are in this section.

Top-Level Roadmap[edit]

This actually may migrate over time as we see what works and what doesn't, but it will at least mark where we've been and where we think we're going.

  1. Implement a generic string-based key-to-value system for doing resource lookups. Completed in Revision 1916.
  2. Drop requirement on binary resource indices by translating them to text. Completed in Revision 2003.
  3. Replace the integer-based resource system with string-based key mappings that are easier to extend. Completed in Revision 2963.
  4. Rework resource types to allow for a wider range of resources. Migrate all 3DO content into standalone addon packs. Completed in Revision 3104.
  5. Uniform API for all uses of the resource-map system, merging about six redundant subsystems into one. In progress.

Current goals[edit]

It's now feasible to start moving hardcoded data like the starship constants and the starmap itself into .rmp files. It's not clear how much of this is wise for 0.7.0 itself, but we should probably do at least a little to gather interest.

  • Keep user settings in a resource-map. Completed in Revision 1916.
  • Keep key configuration in a resource-map. Completed in Revision 2705.
  • Allow loads of resource files to be placed into isolated submaps to keep values separated. Completed in Revision 3105.
  • Allow saves to strip some or all of the common prefix to save only the "submap" component. Completed in Revision 3105.
  • Merge user settings and key configuration into the main resource map, eliminating the now-redundant mapres.c routines. Completed in Revision 3108.
  • Turn melee data (teams, current situation) into resource maps like the other two.

Other work[edit]

This is a bit more nebulous since we haven't advanced far enough to see what's a good idea and what isn't.

  • Massive, cathartic violence against the content directory structure, ending in convenient subprojects. Incomplete, but started in revision 2870.
  • Let .rmp files include other ones to make uqm.rmp less monolithic. This could also be used to automatically include addon packs (such as, say, a Cyrillic Font Pack) if necessary.
    • At the moment we just load all .rmp files in any given directory. This may be good enough.
  • The hack to make the remix packs work is kind of ugly. A more permanent fix would allow special variable expansion to map to wherever uio elected to put it, giving each extension its own space for files. Best of all would be a magic variable for "The home of the extension named X." Implementing this would give us full namespaces and namespace imports.
    • It's only ugly under the surface, though, and will only affect mod writers, and that rather minimally. The users just shove packages blindly into content/addons.
  • Online configuration of which extensions to use.
  • It would be nice to have an offline application for building extensions.
  • A more "self-aware" resource system should give us a much better handle on the remaining resource-related bugs.
  • Can we leverage this for improving save game formats?
  • Planet data is aliased in #defines and structure initializers when it should probably be in the resource map.
  • Ship data is *not* aliased, requiring a bunch of structure initializers that probably (though less probably than in the planet data case) should be name normalized.