1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-24 21:26:40 +00:00
openmw/docs/source/reference/modding/paths.rst
2025-07-04 11:03:29 -07:00

468 lines
26 KiB
ReStructuredText
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

Paths
#####
Default paths
=============
The following describes the default locations for the various OpenMW file paths for different types of files on different operating systems.
To see how to customise this, look at `Custom configuration directories`_.
.. note::
Actual location depends on your computer's setup. Username, harddrive, and language may vary.
Configuration files and log files
---------------------------------
+--------------+-----------------------------------------------------------------------------------------------+
| OS | Location |
+==============+===============================================================================================+
| Linux | ``$XDG_CONFIG_HOME/openmw`` or ``$HOME/.config/openmw`` |
+--------------+-----------------------------------------------------------------------------------------------+
| Mac | ``$HOME/Library/Preferences/openmw`` |
+--------------+---------------+-------------------------------------------------------------------------------+
| Windows | File Explorer | ``Documents\My Games\OpenMW`` |
| | | |
| | PowerShell | ``Join-Path ([environment]::GetFolderPath("mydocuments")) "My Games\OpenMW"`` |
| | | |
| | Example | ``C:\Users\Username\Documents\My Games\OpenMW`` |
+--------------+---------------+-------------------------------------------------------------------------------+
Savegames
---------
+--------------+-----------------------------------------------------------------------------------------------------+
| OS | Location |
+==============+=====================================================================================================+
| Linux | ``$XDG_DATA_HOME/openmw/saves`` or ``$HOME/.local/share/openmw/saves`` |
+--------------+-----------------------------------------------------------------------------------------------------+
| Mac | ``$HOME/Library/Application\ Support/openmw/saves`` |
+--------------+---------------+-------------------------------------------------------------------------------------+
| Windows | File Explorer | ``Documents\My Games\OpenMW\saves`` |
| | | |
| | PowerShell | ``Join-Path ([environment]::GetFolderPath("mydocuments")) "My Games\OpenMW\saves"`` |
| | | |
| | Example | ``C:\Users\Username\Documents\My Games\OpenMW\saves`` |
+--------------+---------------+-------------------------------------------------------------------------------------+
Screenshots
-----------
+--------------+-----------------------------------------------------------------------------------------------------------+
| OS | Location |
+==============+===========================================================================================================+
| Linux | ``$XDG_DATA_HOME/openmw/screenshots`` or ``$HOME/.local/share/openmw/screenshots`` |
+--------------+-----------------------------------------------------------------------------------------------------------+
| Mac | ``$HOME/Library/Application\ Support/openmw/screenshots`` |
+--------------+---------------+-------------------------------------------------------------------------------------------+
| Windows | File Explorer | ``Documents\My Games\OpenMW\screenshots`` |
| | | |
| | PowerShell | ``Join-Path ([environment]::GetFolderPath("mydocuments")) "My Games\OpenMW\screenshots"`` |
| | | |
| | Example | ``C:\Users\Username\Documents\My Games\OpenMW\screenshots`` |
+--------------+---------------+-------------------------------------------------------------------------------------------+
Custom configuration directories
================================
OpenMW has a powerful system to control where configuration files and user data are stored.
This is useful for things like a `Portable install`_ or `Profiles`_\ , but can also be used if you just want your saved games to end up somewhere else.
The OpenMW engine has supported this since 0.48, but if you want to use OpenMW's launcher, that only works correctly from 0.49 onwards.
Concepts
--------
Configuration sources
^^^^^^^^^^^^^^^^^^^^^
Configuration for OpenMW is composed from several sources.
From lowest to highest priority, these are:
* The local or global ``openmw.cfg``.
* Any ``openmw.cfg`` files in any other directories specified with the ``config`` option.
* Options specified on the command line.
.. tip::
Any option that can be specified as ``option=value`` in ``openmw.cfg`` can also be specified as ``--option=value`` or ``--option value`` on the command line for the engine (but not other OpenMW tools).
The command line is always the highest-priority source, even if it specifies extra configuration directories with ``--config``.
This lets you quickly test with extra options even if you're not using your normal configuration directories.
If one ``openmw.cfg`` specifies multiple configuration directories, they're all higher-priority than the one that specified them, and lower priority than any they go on to specify themselves.
I.e. if ``dir1/openmw.cfg`` contains ``config=dir2`` then ``config=dir3``, and ``dir2/openmw.cfg`` contains ``config=dir4`` the priority order will be ``dir1``, ``dir2``, ``dir3``, ``dir4``.
This might be a surprise if you expect it to work like C's ``#include`` directive.
Most settings in ``openmw.cfg`` only allow a single value, so will take the one from the highest-priority config source that sets one.
Others take several values which are combined together into a list.
Values from low-priority sources are included earlier than ones from high-priority sources.
If you don't want this, and would prefer that only values from the current source (and ones of higher priority) are used, you can specify this for each option with the ``replace`` option.
E.g. passing ``--replace content --content Morrowind.esm`` on the command line will ignore any ``content=…`` lines in your ``openmw.cfg``\ (s) and run the game with only ``Morrowind.esm``.
Every configuration directory is allowed, but not required, to contain its own ``settings.cfg``.
Settings in ``settings.cfg`` only ever have one value, so it'll be taken from the highest priority ``settings.cfg`` that sets one.
Special ``openmw.cfg`` files
""""""""""""""""""""""""""""
A local ``openmw.cfg`` is one which is in the same directory as the OpenMW binary, e.g. ``openmw.exe`` on Windows.
It is always loaded if it exists.
A global ``openmw.cfg`` is one in a special system-specific location for system-wide application configuration, e.g. ``/etc/openmw`` on some Linux systems.
Not all systems have a directory like this a global ``openmw.cfg`` only makes sense if there's a single system-wide OpenMW installation, e.g. from the operating system's package manager.
It is only loaded if there's no local ``openmw.cfg``.
If there's no local or global ``openmw.cfg``, OpenMW won't launch.
The user ``openmw.cfg`` is the highest priority ``openmw.cfg`` file that's active.
This is the one that the launcher will edit, so it must be somewhere the user has write access.
It *can* be the local ``openmw.cfg``, e.g. in a `Portable install`_, but we strongly recommend against installing OpenMW to a system protected directory (e.g. ``/usr/bin`` on Unix, ``C:\Program Files`` on Windows) if you decide to do this.
We also strongly recommend against using a global ``openmw.cfg`` as the user ``openmw.cfg``.
``openmw.cfg`` syntax
^^^^^^^^^^^^^^^^^^^^^
An ``openmw.cfg`` file is a sequence of lines.
Each line is either blank, contains an option, or contains a comment.
Blank lines are ignored.
Lines where the first non-whitespace character is an octothorpe (``#``), also known as the hash symbol or pound sign, are comments.
The line is ignored no matter what else it contains.
You can use comments to make notes for yourself or temporarily make OpenMW ignore specific lines.
Be aware that the launcher can only make a best effort to preserve comments when you use it to edit your user ``openmw.cfg``.
It has no way of knowing if you've written a comment to describe the lines above it versus below it (if a comment even goes with a particular line), so it has to guess.
This can't change until computers are able to read minds.
Lines with options have an option name, then an equals sign (``=``), then an option value.
Option names and values have leading and trailing whitespace trimmed, but whitespace within an option value is preserved - it's only removed if it's at the ends.
This means that these are all equivalent:
.. code-block:: openmwcfg
data=some/dir
data=some/dir
data = some/dir
As mentioned above, some options allow more than one value, but some only allow one.
If only one is allowed, and you provide two in the same file, the later one is used.
Extra rules for paths
"""""""""""""""""""""
OpenMW accepts Unix-style paths (separated by forward slashes (``/``)) on Unix, and both Unix-style and Windows-style (separated by backward slashes (``\``)) on Windows, including mixed paths.
Backward slashes have no special meaning and are not an escape character, so paths can be copied and pasted straight from your file browser on any platform.
Paths can also use a quoted syntax.
This is mainly useful if you want to make an ``openmw.cfg`` file that also works with older versions, where quoting was mandatory.
It also lets you specify paths with whitespace at the beginning or end, which would otherwise be stripped.
To quote a path, put a double quote mark (``"``) at the beginning and end.
Everything after the closing quote mark will be ignored.
If a path has quote marks within it, they can be escaped by putting an ampersand (``&``) first, and ampersands can be escaped by putting another ampersand first.
E.g. ``data=a/path/with a " symbol & an ampersand`` can also be written as ``data="a/path/with a &" symbol && an ampersand"``.
If you don't need your configuration to work with older versions, then it's usually easier not to bother quoting paths.
Paths can be absolute, relative, or start with a token.
Absolute paths start with a slash (``/`` or ``\``), or, on Windows, a drive identifier (e.g. ``C:\``).
Relative paths are **relative to the** ``openmw.cfg`` **file they're in**, or the current working directory if they're passed via the command line.
Tokens are used to access platform-dependent paths where OpenMW can store specific kinds of data.
The available tokens are ``?local?``, ``?userconfig?``, ``?userdata?`` and ``?global?``.
Tokens are used in the `Default paths`_.
:``?local?``: The directory where the OpenMW binary is installed, except on MacOS, where it's the ``Resources`` directory inside the bundle.
:``?userconfig?``: Platform-dependent:
+--------------+-----------------------------------------------------------+
| OS | Location |
+==============+===========================================================+
| Linux | ``$XDG_CONFIG_HOME/openmw/`` or ``$HOME/.config/openmw/`` |
+--------------+-----------------------------------------------------------+
| Mac | ``$HOME/Library/Preferences/openmw/`` |
+--------------+-----------------------------------------------------------+
| Windows | ``Documents\My Games\OpenMW\`` |
+--------------+-----------------------------------------------------------+
:``?userdata?``: Platform-dependent:
+--------------+--------------------------------------------------------------+
| OS | Location |
+==============+==============================================================+
| Linux | ``$XDG_DATA_HOME/openmw/`` or ``$HOME/.local/share/openmw/`` |
+--------------+--------------------------------------------------------------+
| Mac | ``$HOME/Library/Application Support/openmw/`` |
+--------------+--------------------------------------------------------------+
| Windows | ``Documents\My Games\OpenMW\`` |
+--------------+--------------------------------------------------------------+
:``?global?``: Platform-dependent:
+--------------+-------------------------------------------------------------------+
| OS | Location |
+==============+===================================================================+
| Linux | Chosen by the downstream packager, typically ``/usr/share/games`` |
+--------------+-------------------------------------------------------------------+
| Mac | ``/Library/Application Support/`` |
+--------------+-------------------------------------------------------------------+
| Windows | Not applicable |
+--------------+-------------------------------------------------------------------+
Examples
--------
Portable install
^^^^^^^^^^^^^^^^
If you want to put OpenMW onto removable storage so you can play on multiple machines, or you want an entirely self-contained setup, you'll want to set up a portable install.
Single ``openmw.cfg`` file
""""""""""""""""""""""""""
Some users find it easiest if there's a single ``openmw.cfg`` file with all their configuration, even if it means it's mixed in with the engine's default configuration.
To set up this kind of install, first install a fresh copy of OpenMW to a directory where you have write access.
Navigate to the OpenMW installation directory, and open the ``openmw.cfg`` file it contains.
By default, this contains a warning at the top telling you that this is the local ``openmw.cfg`` and not to modify it.
However, for this kind of install, it's okay to do so, so you can remove this warning.
Change the start of the file from:
.. code-block:: openmwcfg
:caption: openmw.cfg
# This is the local openmw.cfg file. Do not modify!
# Modifications should be done on the user openmw.cfg file instead
# (see: https://openmw.readthedocs.io/en/master/reference/modding/paths.html)
data-local="?userdata?data"
user-data="?userdata?"
config="?userconfig?"
resources=./resources
data=./resources/vfs-mw
# lighting
fallback=LightAttenuation_UseConstant,0
fallback=LightAttenuation_ConstantValue,0.0
fallback=LightAttenuation_UseLinear,1
to:
.. code-block:: openmwcfg
:caption: openmw.cfg
data-local=userdata/data
user-data=userdata
resources=./resources
data=./resources/vfs-mw
# lighting
fallback=LightAttenuation_UseConstant,0
fallback=LightAttenuation_ConstantValue,0.0
fallback=LightAttenuation_UseLinear,1
You can now run OpenMW's launcher to do first-time setup.
This will import the basic data to play *Morrowind* into the ``openmw.cfg`` you just modified, and create a ``settings.cfg`` next to it.
You can make any further changes you want to these files, or make changes in the launcher, which will modify them for you.
You'll need to make sure that any ``data=…`` lines in your ``openmw.cfg`` use relative paths so that they're not dependent on the drive letter/mount point when moved to another computer.
If you add data directories via the launcher, you'll need to change them manually afterwards.
Separate user ``openmw.cfg`` file
"""""""""""""""""""""""""""""""""
For most users, this is the type of portable OpenMW install we would recommend as it's the most similar to a regular install.
You'll have a separate local ``openmw.cfg`` with the engine's basic configuration and a user ``openmw.cfg`` with your personal configuration.
To set up this kind of install, first install a fresh copy of OpenMW to a directory where you have write access.
Navigate to the OpenMW installation directory, and open the ``openmw.cfg`` file it contains.
By default, this contains a warning at the top telling you that this is the local ``openmw.cfg`` and not to modify it.
However, you'll need to make a small change to create this kind of install.
Change the start of the file from:
.. code-block:: openmwcfg
:caption: openmw.cfg
# This is the local openmw.cfg file. Do not modify!
# Modifications should be done on the user openmw.cfg file instead
# (see: https://openmw.readthedocs.io/en/master/reference/modding/paths.html)
data-local="?userdata?data"
user-data="?userdata?"
config="?userconfig?"
resources=./resources
data=./resources/vfs-mw
# lighting
fallback=LightAttenuation_UseConstant,0
fallback=LightAttenuation_ConstantValue,0.0
fallback=LightAttenuation_UseLinear,1
to:
.. code-block:: openmwcfg
:caption: openmw.cfg
# This is the local openmw.cfg file. Do not modify!
# Modifications should be done on the user openmw.cfg file instead
# (see: https://openmw.readthedocs.io/en/master/reference/modding/paths.html)
data-local="userdata/data"
user-data="userdata"
config="config"
resources=./resources
data=./resources/vfs-mw
# lighting
fallback=LightAttenuation_UseConstant,0
fallback=LightAttenuation_ConstantValue,0.0
fallback=LightAttenuation_UseLinear,1
You can now run OpenMW's launcher to do first-time setup.
This will import the basic data to play Morrowind into a new ``openmw.cfg`` in the ``config`` directory, and create a ``settings.cfg`` next to it.
You can make any further changes you want to these files, or make changes in the launcher, which will modify them for you.
You'll need to make sure that any ``data=…`` lines in your ``openmw.cfg`` use relative paths so that they're not dependent on the drive letter/mount point when moved to another computer.
Remember that paths are relative to the ``openmw.cfg`` file they're in, not the OpenMW installation root.
If you add data directories via the launcher, you'll need to change them manually afterwards.
Profiles
^^^^^^^^
OpenMW can potentially be used to play several different games, and you may want to try several different mod lists for each.
You can use the custom configuration directory system to create a profile for each different setup with its own configuration directory.
For the example, we'll create a subdirectory in the default configuration directory for each game, and then create a subdirectory in the relevant game's directory for each mod list.
From scratch
""""""""""""
Start by installing OpenMW in the usual way.
Don't bother with first-time setup (i.e. telling it the location of an existing *Morrowind* installation).
In the default configuration directory (see `Configuration files and log files`_), create a file called ``openmw.cfg`` containing just
.. code-block:: openmwcfg
:caption: openmw.cfg
# select the game profile
config=Morrowind
Now it's time to run the launcher to do first-time setup.
This will put the basic setup required to play *Morrowind* into a new ``Morrowind`` directory of the default configuration directory, e.g. ``Documents\My Games\OpenMW\Morrowind\openmw.cfg`` on Windows.
Next, come up with a name for the subprofile you'll create for your mod list.
If you're following a modding guide, they've probably already given it a name, e.g. *Total Overhaul*, so that's the example we'll use.
Add a line to the ``Morrowind/openmw.cfg`` with the profile name like this:
.. code-block:: openmwcfg
:caption: Morrowind/openmw.cfg
# select the mod list profile
config=Total Overhaul
Run the launcher again.
You'll now have three separate levels of ``openmw.cfg`` and ``settings.cfg``.
The ones in the base default configuration directory are used for all profiles, so they're best for machine-wide settings, like your monitor's resolution.
The ones in the ``Morrowind`` directory are used for all profiles for *Morrowind*, so they're best for game-specific settings, like the values imported from ``Morrowind.ini``.
The ones in the ``Morrowind/Total Overhaul`` directory are only used for the *Total Overhaul* profile, so you can set up that mod list and any settings it requires here, and they won't affect any other profiles you set up later.
Making changes within the launcher will affect these files and leave all the others alone.
If you want the *Total Overhaul* profile to keep its saved games etc. in a dedicated location instead of mixing them in with ones from another profile, you can add a ``user-data=…`` line to your ``Morrowind/Total Overhaul/openmw.cfg``, like this:
.. code-block:: openmwcfg
:caption: Morrowind/Total Overhaul/openmw.cfg
# put saved games in a saves directory next to this file
user-data=.
When you want to set up another game or mod list, you can set up a new one just like the first create another directory for it and change the ``config=…`` line in the ``openmw.cfg`` next to the directory to use that directory's name.
To switch back, just change the line back.
Migrating an existing setup
"""""""""""""""""""""""""""
Lots of people will have an existing OpenMW setup, and decide they want to try a new mod list or game.
That existing configuration can be moved out of the way and turned into a profile.
Start by creating a subdirectory in the default configuration directory (see `Configuration files and log files`_) to be the profile.
Give it a meaningful name so you know what it is this example will call it *Original*.
You'll now have an empty directory e.g. at ``Documents\My Games\OpenMW\Original`` on Windows.
Next, move all the files that were already in the default configuration directory to the profile directory you just made.
Afterwards, the default configuration directory should only contain the profile directory you made.
Create a new ``openmw.cfg`` file in the default configuration directory containing:
.. code-block:: openmwcfg
:caption: openmw.cfg
# select the profile
config=Original
In the ``openmw.cfg`` in the profile directory, add these lines:
.. code-block:: openmwcfg
:caption: openmw.cfg
data-local=data
user-data=.
Now, if you run OpenMW or any of its tools, they'll work just like before, even though you've moved the files.
You can now make other directories for other profiles as described in the `From scratch`_ example, and switch between them and your original setup by changing the ``config=…`` line.
Launcher scripts and shortcuts
""""""""""""""""""""""""""""""
Once profiles have been set up, it might be a hassle to switch between them by editing ``config=…`` lines in ``openmw.cfg`` files.
Passing arguments on the command line lets you avoid this.
.. note::
This feature only works with the OpenMW engine, not tools like the launcher.
The basic idea is that you need to pass ``--replace config`` to ignore the configuration directories that the engine would have loaded because they were specified in ``openmw.cfg`` files, and pass each one you want to use instead with ``--config <directory path here>``.
E.g. if you've got a profile called *Morrowind* in your default configuration directory, and it's got a *Total Overhaul* subprofile, you could load it by running:
.. code-block:: console
$ openmw --replace config --config ?userconfig?/Morrowind --config "?userconfig?/Morrowind/Total Overhaul"
You can put this command into a script or shortcut and use it to easily launch OpenMW with that profile.
The command exactly as it appears above will work in most common shells (e.g. Bash, Windows Command Prompt and PowerShell) if OpenMW is on the system path.
Otherwise, the path to OpenMW must be specified instead of just the ``openmw`` command.
On Windows, you can create a desktop shortcut to run this command with these steps:
* Navigate to the OpenMW install directory.
* Right-click ``openmw.exe`` and choose *Send to* > *Desktop (create shortcut)*.
* Navigate to the Desktop, or minimise all windows.
* Find the newly-created shortcut and give it a sensible name, e.g. *OpenMW - Total Overhaul*.
* Right-click the shortcut and choose *Properties*.
* In the *Shortcut* tab of the *Properties* pane, find the *Target* field.
* At the end of that field, add the arguments for the profile you want, e.g. ``--replace config --config ?userconfig?/Morrowind --config "?userconfig?/Morrowind/Total Overhaul"``.
* Press *Apply* or *OK* to save the changes, and test the shortcut by double-clicking it.
On most Linux distros, you can create a ``.desktop`` file like this:
.. code-block:: desktop
[Desktop Entry]
Type=Application
Name=OpenMW - Total Overhaul
GenericName=Role Playing Game
Comment=OpenMW with the Total Overhaul profile
Keywords=Morrowind;Reimplementation Mods;esm;bsa;
TryExec=openmw
Exec=openmw --replace config --config ?userconfig?/Morrowind --config "?userconfig?/Morrowind/Total Overhaul"
Icon=openmw
Categories=Game;RolePlaying;