mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-16 12:49:56 +00:00
225 lines
9.7 KiB
ReStructuredText
225 lines
9.7 KiB
ReStructuredText
|
Files and Directories
|
|||
|
#####################
|
|||
|
|
|||
|
In this chapter of the manual we will cover the usage of files and directories
|
|||
|
by OpenMW CS. Files and directories are file system concepts of your operating
|
|||
|
system, so we will not be going into specifics about that, we will only focus
|
|||
|
on what is relevant to OpenMW CS.
|
|||
|
|
|||
|
|
|||
|
Basics
|
|||
|
******
|
|||
|
|
|||
|
|
|||
|
Directories
|
|||
|
===========
|
|||
|
|
|||
|
OpenMW and OpenMW CS us multiple directories on the file system. First of all
|
|||
|
there is a *user directory* that holds configuration files and a number of
|
|||
|
different sub-directories. The location of the user directory is hard-coded
|
|||
|
into the CS and depends on your operating system.
|
|||
|
|
|||
|
================ =========================================
|
|||
|
Operating System User Dircetory
|
|||
|
================ =========================================
|
|||
|
GNU/Linux ``<whatever>``
|
|||
|
OS X ``~/Library/Application Support/openmw/``
|
|||
|
Windows ``<whatever>``
|
|||
|
================ =========================================
|
|||
|
|
|||
|
In addition to to this single hard-coded directory both OpenMW and OpenMW CS
|
|||
|
need a place to seek for a actuals data files of the game: textures, 3D models,
|
|||
|
sounds and record files that store objects in game; dialogues an so one. These
|
|||
|
files are called *content files*. We support multiple such paths (we call them
|
|||
|
*data paths*) as specified in the configuration. Usually one data path points
|
|||
|
to the directory where the original Morrowind game is either installed or
|
|||
|
unpacked to. You are free to specify as many data paths as you would like,
|
|||
|
however, there is one special data path that, as described later, which is used
|
|||
|
to store newly created content files.
|
|||
|
|
|||
|
|
|||
|
Content files
|
|||
|
=============
|
|||
|
|
|||
|
The original Morrowind engine by Bethesda Softworks uses two types of content
|
|||
|
files: `esm` (master) and `esp` (plugin). The distinction between those two is
|
|||
|
not clear, and often confusing. One would expect the `esm` (master) file to be
|
|||
|
used to specify one master, which is then modified by the `esp` plugins. And
|
|||
|
indeed: this is the basic idea. However, the official expansions were also made
|
|||
|
as ESM files, even though they could essentially be described as really large
|
|||
|
plugins, and therefore would rather use `esp` files. There were technical
|
|||
|
reasons behind this decision – somewhat valid in the case of the original
|
|||
|
engine, but clearly it is better to create a system that can be used in a more
|
|||
|
sensible way. OpenMW achieves this with our own content file types.
|
|||
|
|
|||
|
We support both ESM and ESP files, but in order to make use of new features in
|
|||
|
OpenMW one should consider using new file types designed with our engine in
|
|||
|
mind: *game* files and *addon* files, collectively called *content files*.
|
|||
|
|
|||
|
|
|||
|
OpenMW content files
|
|||
|
--------------------
|
|||
|
|
|||
|
The concepts of *Game* and *Addon* files are somewhat similar to the old
|
|||
|
concept of *ESM* and *ESP*, but more strictly enforced. It is quite
|
|||
|
straight-formward: If you want to make new game using OpenMW as the engine (a
|
|||
|
so called *total conversion*) you should create a game file. If you want to
|
|||
|
create an addon for an existing game file create an addon file. Nothing else
|
|||
|
matters; the only distinction you should consider is if your project is about
|
|||
|
changing another game or creating a new one. Simple as that.
|
|||
|
|
|||
|
Another simple thing about content files are the extensions: we are using
|
|||
|
``.omwaddon`` for addon files and ``.omwgame`` for game files.
|
|||
|
|
|||
|
|
|||
|
Morrowind content files
|
|||
|
-----------------------
|
|||
|
|
|||
|
Using our content files is recommended for projects that are intended to used
|
|||
|
with the OpenMW engine. However, some players might wish to still use the
|
|||
|
original Morrowind engine. In addition thousands of *ESP*/*ESM* files were
|
|||
|
created since 2002, some of them with really outstanding content. Because of
|
|||
|
this OpenMW CS simply has no other choice but to support *ESP*/*ESM* files. If
|
|||
|
you decid to choose *ESP*/*ESM* file instead of using our own content file
|
|||
|
types you are most likely aimng at compatibility with the original engine. This
|
|||
|
subject is covered in it own chapter of this manual.
|
|||
|
|
|||
|
|
|||
|
.. TODO This paragraph sounds weird
|
|||
|
|
|||
|
The actual creation of new files is described in the next chapter. Here we are
|
|||
|
going to focus only on the details you need to know in order to create your
|
|||
|
first OpenMW CS file while fully understanding your needs. For now let’s jut
|
|||
|
remember that content files are created inside the user directory in the the
|
|||
|
``data`` subdirectory (that is the one special data directory mentioned
|
|||
|
earlier).
|
|||
|
|
|||
|
|
|||
|
Dependencies
|
|||
|
------------
|
|||
|
|
|||
|
Since an addon is supposed to change the game it follows that it also depends
|
|||
|
on the said game to work. We can conceptualise this with an examples: your
|
|||
|
modification is the changing prize of an iron sword, but what if there is no
|
|||
|
iron sword in game? That's right: we get nonsense. What you want to do is tie
|
|||
|
your addon to the files you are changing. Those can be either game files (for
|
|||
|
example when making an expansion island for a game) or other addon files
|
|||
|
(making a house on said island). Obviously It is a good idea to be dependent
|
|||
|
only on files that are really changed in your addon, but sadly there is no
|
|||
|
other way to achieve this than knowing what you want to do. Again, please
|
|||
|
remember that this section of the manual does not cover creating the content
|
|||
|
files – it is only a theoretical introduction to the subject. For now just keep
|
|||
|
in mind that dependencies exist, and is up to you to decide whether your
|
|||
|
content file should depend on other content files.
|
|||
|
|
|||
|
Game files are not intend to have any dependencies for a very simple reasons:
|
|||
|
the player is using only one game file (excluding original and the dirty
|
|||
|
ESP/ESM system) at a time and therefore no game file can depend on other game
|
|||
|
file, and since a game file makes the base for addon files it can not depend on
|
|||
|
addon files.
|
|||
|
|
|||
|
|
|||
|
Project files
|
|||
|
-------------
|
|||
|
|
|||
|
Project files act as containers for data not used by the OpenMW game engine
|
|||
|
itself, but still useful for OpenMW CS. The shining example of this data
|
|||
|
category are without doubt record filters (described in a later chapter of the
|
|||
|
manual). As a mod author you probably do not need or want to distribute project
|
|||
|
files at all, they are meant to be used only by you and your team.
|
|||
|
|
|||
|
.. TODO "you and your team": is that correct?
|
|||
|
|
|||
|
As you would imagine, project files make sense only in combination with actual
|
|||
|
content files. In fact, each time you start to work on new content file and a
|
|||
|
project file was not found, one will be created. The extensio of project files
|
|||
|
is ``.project``. The whole name of the project file is the whole name of the
|
|||
|
content file with appended extension. For instance a ``swords.omwaddon`` file
|
|||
|
is associated with a ``swords.omwaddon.project`` file.
|
|||
|
|
|||
|
Project files are stored inside the user directory, in the ``projects``
|
|||
|
subdirectory. This is the path location for both freshly created project files,
|
|||
|
and a place where OpenMW CS looks for already existing files.
|
|||
|
|
|||
|
|
|||
|
Resource files
|
|||
|
==============
|
|||
|
|
|||
|
.. TODO This paragraph sounds weird
|
|||
|
|
|||
|
Unless we are talking about a fully text based game, like Zork or Rogue, one
|
|||
|
would expect that a video game is using some media files: 3D models with
|
|||
|
textures, images acting as icons, sounds and anything else. Since content
|
|||
|
files, no matter whether they are *ESP*, *ESM* or new OpenMW file type, do not
|
|||
|
contain any of those, it is clear that they have to be delivered with a
|
|||
|
different file. It is also clear that this, let’s call it “resources file“,
|
|||
|
has to be supported by the engine. Without code handling those files it is
|
|||
|
nothing more than a mathematical abstraction – something, that lacks meaning
|
|||
|
for human beings. Therefore this section must cover ways to add resources
|
|||
|
files to your content file, and point out what is supported. We are going to do
|
|||
|
just that. Later, you will learn how to make use of those files in your
|
|||
|
content.
|
|||
|
|
|||
|
|
|||
|
Audio
|
|||
|
-----
|
|||
|
|
|||
|
OpenMW uses FFmpeg_ for audio playback, and so we support every audio type
|
|||
|
supported by that library. This makes a huge list. Below is only small portion
|
|||
|
of the supported file types.
|
|||
|
|
|||
|
mp3 (MPEG-1 Part 3 Layer 3)
|
|||
|
A popular audio file format and de facto standard for storing audio. Used by
|
|||
|
the Morrowind game.
|
|||
|
|
|||
|
ogg
|
|||
|
An open source, multimedia container file using a high quality Vorbis_ audio
|
|||
|
codec. Recommended.
|
|||
|
|
|||
|
|
|||
|
Video
|
|||
|
-----
|
|||
|
|
|||
|
Video As in the case of audio files, we are using FFmepg to decode video files.
|
|||
|
The list of supported files is long, we will cover only the most significant.
|
|||
|
|
|||
|
bik
|
|||
|
Videos used by the original Morrowind game.
|
|||
|
|
|||
|
mp4
|
|||
|
A multimedia container which use more advanced codecs (MPEG-4 Parts 2, 3 and
|
|||
|
10) with a better audio and video compression rate, but also requiring more
|
|||
|
CPU intensive decoding – this makes it probably less suited for storing
|
|||
|
sounds in computer games, but good for videos.
|
|||
|
|
|||
|
webm
|
|||
|
A new, shiny and open source video format with excellent compression. It
|
|||
|
needs quite a lot of processing power to be decoded, but since game logic is
|
|||
|
not running during cutscenes we can recommend it for use with OpenMW.
|
|||
|
|
|||
|
ogv
|
|||
|
Alternative, open source container using Theora_ codec for video and Vorbis for audio.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Textures and images
|
|||
|
-------------------
|
|||
|
|
|||
|
The original Morrowind game uses *DDS* and *TGA* files for all kinds of two
|
|||
|
dimensional images and textures alike. In addition, the engine supported *BMP*
|
|||
|
files for some reason (*BMP* is a terrible format for a video game). We also
|
|||
|
support an extended set of image files – including *JPEG* and *PNG*. *JPEG* and
|
|||
|
*PNG* files can be useful in some cases, for instance a *JPEG* file is a valid
|
|||
|
option for skybox texture and *PNG* can useful for masks. However, please keep
|
|||
|
in mind that *JPEG* images can grow to large sizes quickly and are not the best
|
|||
|
option with a DirectX rendering backend. You probably still want to use *DDS*
|
|||
|
files for textures.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
.. Hyperlink targets for the entire document
|
|||
|
|
|||
|
.. _FFmpeg: http://ffmpeg.org
|
|||
|
.. _Vorbis: http://www.vorbis.com
|
|||
|
.. _Theora: http://www.theora.org
|