# Building Resources
*Resource build process* refers to the process of packaging all game assets –
including models, textures, levels, and their associated settings and game logic
– into binary files. This approach helps reduce the number of files that need to
be downloaded, speeding up the download process while keeping the data volume
constant. It also protects our assets from being exploited by players for
unintended purposes.
The game itself does not interact directly with the raw assets like models,
textures, or level settings that we create. Instead, it only interacts with the
compiled binary files. When a level is loaded, the necessary packages are
fetched, decompressed, and the required information is extracted from them.
This article provides an overview of how to build assets, levels, and settings.
## Parameters in `.folder.blk` Affecting the Building Process
Resource build process is governed by the rules defined in `.folder.blk` files.
```{seealso}
For more information, see
[.folder.blk](../../assets/all-about-blk/folder_blk.md).
```
For example, the following block specifies compression parameters for `.tiff`
textures.
```text
virtual_res_blk{
find:t="^(.*)\.tiff$" // search for any .tiff files
className:t="tex" // assign the "texture" class
contents{ // processing details
convert:b=yes;fmt:t="DXT1|DXT5" // convert; use DXT1 or DXT5 format (if alpha is present)
mipFilter:t="filterKaiser";mipFilterAlpha:r=40;mipFilterStretch:r=2 // mipmap compression using
// the Kaiser filter (sharpens); with two parameters
addrU:t="wrap";addrV:t="wrap" // define texture tiling behavior, wrap = repeat for repeating textures.
hqMip:i=0;mqMip:i=1;lqMip:i=2 // define the displayed mip level based on graphics quality;
// hq (high quality) uses the original texture,
// mq uses mip level 1 (50% compression), lq uses mip level 2 (75% compression).
}
}
```
There are numerous such processing blocks. Below, we'll examine the key ones.
## Global Export Parameters
```text
export{
package:t="*" // Specify the package to which the asset will be built
// (a package is the highest level of asset grouping)
forcePackage:t="*" // Some packages might be automatically renamed by hardcoded logic.
// This parameter enforces a specific name. Use this if you want to
// ensure that certain assets are built into only one location.
ddsxTexPackPrefix:t="tanks/" // Specify the directory in the built resources where
// texture packs will be stored (a pack is the next level of grouping within a package).
// In this example, texture packs for tanks will be built
// into the "tanks" directory rather than the general directory.
ddsxTexPack:t="*name_src" // Specify the name of the texture pack. If "*name_src" is used,
// the name will be derived from the directory containing the textures.
gameResPack:t="aces.grp" // Specify the name of the resource pack. If "*name_src" is used,
// the name will be derived from the folder containing the textures.
splitNotSeparate:b=true // Indicate that textures should not be split between the base client and the full client.
// In the base client, textures are downscaled to 512px so players can download a smaller
// amount of data and start playing sooner. To maintain visual quality, some textures, like
// those for tanks or hangars, are not downscaled but kept at normal quality. This flag is
// set to true to prevent downscaling. The default is false, and it can be omitted.
}
```
These are just a few examples. Let's delve into the primary parameters.
## About Packs and Packages
The hierarchy of resources can be illustrated as follows:
In essence, a project can contain several packages, and each package can include
multiple packs.
### What Is a Package?
A *package* typically serves as a container for resources that we want to
distribute to or remove from the player's environment. For example, we might
bundle a specific location and its assets into a package for a particular event.
Players download it, enjoy the event for a week, and once the event concludes,
the package is removed from their resources.
Packages can also be used to release or sell add-ons. Instead of requiring
players to download 20 GB of resources upfront, they can start with a
minimal setup and quickly get into the game. Later, they can purchase additional
content and download the necessary data from the relevant package.
```{seealso}
For more information, see
[Packages](./packages.md).
```
### What Is a Pack?
A *pack* is a component of a package where the assets are actually built. The
logic for dividing assets into packs is straightforward:
- When a location is loaded, the minimum possible number of packs should be
fetched to optimize loading times.
- Each pack should ideally be between 10 MB to 100 MB (with
100 MB being the absolute maximum) to ensure efficient unpacking.
Generally, we group similar assets together; for example, all vehicle props
might go into a pack named `vehicles`. Defensive structures like pillboxes,
trenches, bunkers, and barricades might be grouped into a pack called
`fortifications`.
If a pack becomes too large, we break it down into smaller groups. For example,
vehicles could be further divided into packs such as `buses`, `trucks`, and
`cars`.
## Local Build
When you create a new asset, it needs to be tested locally in the game. The
local client, like the player's client, only understands built resources, so
they need to be built before testing.
There are three types of builds:
1. **Full Build**: builds all resources.
2. **Partial Pack Build**: builds the specific pack containing the resource you
need. This method is used when only a few assets have been modified – quick
and efficient.
3. **Partial Package Build**: builds an entire package (a set of packs).
Although this is a longer process, it can be more convenient in some cases,
such as in daNetGame-based games, where packaging the resources this way
might be preferable to building individual packs.
## Local Full daBuild
The daBuild is a program executed via the `dabuild.cmd` batch file.
```{important}
Running `dabuild.cmd` will build all resources – this process can take hours. If
you only need to build a single resource for quick testing, use
`dabuild_test.bat` instead.
```
### Building and Errors
In theory, all assets should be error-free. However, asset management initially
relied heavily on manual checks, leading to human error and allowing issues to
slip through. Over time, more automated checks were added to daBuild, which
means that older assets that previously built without problems might now trigger
errors. If an error occurs while building a pack, the build process for that
pack is halted, and subsequent assets are not built. Errors are only detected
during the build process, but they also interrupt it, making it time-consuming
to identify and fix issues across all assets within a pack.
To address this, the `-keep_building_after_error` flag was introduced. If the
previous build resulted in errors, you can add this flag at the end of the batch
file command to allow daBuild to continue building all resources while logging
the errors.
```{note}
The `-keep_building_after_error` flag should not be used to ignore errors. The
build process for specific assets will still be interrupted, but it will move on
to the next asset in the pack rather than stopping at the first error. Once
you've collected error data, fix the assets and run the build without this flag
to ensure that daBuild completes successfully without issues.
```
### Local Pack Build
```{important}
Building packs with daBuild will compile all packs matching a specified pattern.
For example, if you have a `vehicles` pack and a `vehicles_modern` pack,
building `vehicles` will compile both packs unless you specify the exact pack
extension (e.g., `vehicles.grp` to target only that pack).
Also, note that daBuild will build packs based on the package name. For example,
if you have several packs within the `main` package and you run a build using
the `main` pattern, it will build all packs within the `main` package. **This
builds all packs within the `main` package, not the `main` package itself.**
This happens because the final pack names always include the package name as a
prefix. For example, the `vehicles` pack in the `main` package will ultimately
be named `main_vehicles`.
```
To build a specific pack, open `dabuild_test.bat` in any text editor, and you
will see a line like this:
```text
..\..\tools\dagor3_cdk\bin64\dabuild-dev.exe -target:PC ..\application.blk -packs_re:usa_gm -Q
```
Replace `usa_gm` with the name of the pack you need to build. The pack is
determined by the nearest `.folder.blk` file to the asset, containing lines
like:
```text
export{
ddsxTexPack:t="gm_lvl_assets.dxp.bin"
gameResPack:t="gm_lvl_assets.grp"
}
```
The `gm_lvl_assets` is an example of the pack name into which the resources will
be built. It may vary – refer to your specific setup.
```{important}
Notice that there are two types of packs:
- `ddsxTexPack`: exports textures
- `gameResPack`: exports models
It's possible for textures to be exported to one pack and models to another.
For example:
```
export{
ddsxTexPack:t="gm_lvl_assets.dxp.bin"
gameResPack:t="locations.grp"
}
```
You need to build the packs corresponding to the resources you've modified. If
you've changed textures, build the texture pack. If you've changed models, build
the model pack. If both were changed, build both packs.
```
## Local Package Build
Unlike packs, packages are more comprehensive and refer to self-contained
volumes of resources that can be enabled or disabled with a "toggle".
For example, in War Thunder:
- `pkg_main` (or simply `*`): the default package where all assets are exported.
- `pkg_dev`: contains assets that should be built but not distributed to
players.
- `tomoe`: a package for modifying certain symbols in countries where their
original form is prohibited.
- Event packages are also occasionally used.
In daNetGame-based games, each location is its own package, which can be
distributed to players independently.
In a `.folder.blk` file, the package entry looks like this:
```text
export{
package:t="tomoe"
}
```
In War Thunder, local package builds are not common, as there are few packages,
and packs are usually built instead. However, in daNetGame-based games, this is
an extremely useful feature. There are two options for such builds.
### Option 1: Building a Specific Package
In the `daBuild` batch file, write:
```text
..\..\tools\dagor3_cdk\bin64\dabuild-dev.exe -target:PC ..\application.blk -package:package_name -Q
```
Replace `package_name` with the name of the package you need to build. This will
build the entire package with validation and checks.
```{note}
Package builds target specific packages, unlike packs, which work based on
patterns. This isn't usually an issue unless you're trying to build textures.
For example, `package_name` and `package_name_hq` (high-quality textures used
for close-up views) are different packages. Building the package with
`-package:package_name` will only compile standard textures, not high-quality
ones. This could result in your changes appearing in low-quality textures but
reverting when viewed up close, as the high-quality textures haven't been
updated.
To avoid this, you should either:
- sequentially build both packages using one batch file:
`-package:package_name -package:package_name_hq`
or
- create two separate batch files: one for the main resource package (non-HQ
textures) and another specifically for HQ textures.
```
### Option 2: Building a Specific Package and Its Dependencies
In daNetGame-based games, packages often have cross-references. When something
changes in a "common" package, you need to ensure that everything works
correctly in all other packages that reference it. Instead of doing a full build
(which is very time-consuming), you can build the "common" package along with
its dependent packages, which is much faster.
To do this, write the following in the `daBuild` batch file:
```text
..\..\tools\dagor3_cdk\bin64\dabuild-dev.exe -target:PC ..\application.blk -package_and_deps:package_name -Q
```
The `package_and_deps` refers to the package and its dependencies.
## Toggling Packages in settings.blk
Occasionally, you may need to enable or disable packages to test specific
scenarios (for example, disabling a package to verify that the game runs without
it). This is configured in the `settings.blk` file.
```{seealso}
For more information, see
[settings.blk](../../assets/all-about-blk/config_and_settings_blk).
```
For all projects, after modifying the package list, you must rebuild the
`.vromfs.bin` files.
In War Thunder, packages are enabled or disabled in the file located at
`//develop/gameBase/_pc/settings.blk`:
```text
addons{
folder:t = "content.hq/hq_tex"
folder:t = "content.hq/pkg_cockpits"
folder:t = "content/pkg_china"
folder:t = "content.hq/pkg_china_hq"
folder:t = "content/pkg_dev"
folder:t = "content.hq/pkg_dev_hq"
folder:t = "content/hc_pacific"
folder:t = "content/pkg_user"
folder:t = "content/pkg_local"
folder:t = "content/tomoe"
folder:t = "content.hq/tomoe_hq"
folder:t = "content.hq/uhq_vehicles"
folder:t = "content.hq/uhq_aircraft"
folder:t = "content.hq/uhq_environment"
}
addons_no_check{
folder:t = "content.hq/hq_tex"
folder:t = "content.hq/pkg_cockpits"
folder:t = "content/pkg_china"
folder:t = "content.hq/pkg_china_hq"
folder:t = "content/pkg_dev"
folder:t = "content.hq/pkg_dev_hq"
folder:t = "content/hc_pacific"
folder:t = "content/pkg_user"
folder:t = "content/pkg_local"
folder:t = "content/tomoe"
folder:t = "content.hq/tomoe_hq"
folder:t = "content.hq/uhq_vehicles"
folder:t = "content.hq/uhq_aircraft"
folder:t = "content.hq/uhq_environment"
}
```
To disable a package, simply comment out the relevant lines in both blocks and
rebuild `.vromfs.bin` files.
It's important to note that this file is responsible only for enabling or
disabling packages within the game; it does not handle the creation of packages.
The requirement for a package to be built by daBuild is defined in the
`application.blk` file within the `packages{}` block.
```{seealso}
For more information, see
[application.blk](../../assets/all-about-blk/application_blk.md).
```
## Local Build of a Specific Asset
The `daBuild` command with the `-build:[:]` parameter allows
you to build a single asset into the specified file. This command does not
update packages, meaning the updated asset will not be added to any package.
## Local Resource Build in Asset Viewer
Resources can also be built using the [Asset
Viewer](../asset-viewer/asset-viewer/asset_viewer.md), which often speeds up
the process since `daBuild` via batch files can sometimes lag unpredictably.
```{seealso}
For more information on how to build using Asset Viewer, see
[Asset Viewer: Building Assets](../asset-viewer/asset-viewer/asset_viewer.md#building-assets).
```
## Local Vromfs Build
*VROMFS* stands for "Virtual Read-Only Memory File System". Essentially,
[vromfs](vromfs.md) files are the "virtual configuration disk" for our game.
They contain all the game's operational settings that aren't hard-coded.
When creating assets, you need to build vromfs primarily when you're configuring
asset destruction or fine-tuning the behavior of in-game vehicles. In other
scenarios, vromfs building is typically unnecessary.
It's crucial to remember that, by default, vromfs are delivered over the network
at the start of each mission, allowing for different settings per mission. If
you want to test something locally, ensure that your `config.blk` file has the
following line in the `debug{}` block: `offlineBinaries:b=yes`. Alternatively,
you can use `disableNetwork:b=yes` if network features are irrelevant to you.
For added security, you might want to include both.
### Methods to Build Vromfs
1. **Using `create_vrsroms.bat`**
The `create_vrsroms.bat` file located in the
`//develop/gameBase` directory.
This method is useful because it immediately indicates if there's an issue
with the settings by throwing an error.
Additionally, it provides a local log (`log_vrom`) in the same directory,
which helps you identify and resolve any problems.
2. **Using `aces_dev.exe`**
Technically, this tool does not build vromfs. However, if you have
`vromfsPriority:b=no` set in the `debug{}` block of your `config.blk`, all
configuration files will be read directly from `develop/gameBase` instead of
from vromfs.
This approach offers several advantages: there's no need to wait for vromfs
building after each change, and errors are logged in a more readable format.
Additionally, this method allows you to add the powerful
`trackEnvChanges:b=yes` line to your `config.blk`, enabling you to tweak
settings directly in-game. Although this doesn't work for all settings, it's
particularly helpful for adjusting weather or visual elements, as you can see
the changes in real-time without restarting the client.
Choose the method based on your experience. The in-game approach might be less
convenient, but sometimes it's essential to ensure everything behaves exactly as
it would in production.
## Local Build of Resources and Vromfs in the Open daEditor and Client
You can build resources and [vromfs](vromfs.md) while the
[daEditor](../daeditor/daeditor/daeditor.md) is open (though resource building
might cause the [daEditor](../daeditor/daeditor/daeditor.md) to crash).
However, resources and vromfs cannot be built while the client is open.
If you find that resources aren't building after you've closed the client – or
they seem to build, but the changes aren't reflected in-game – open the Task
Manager and terminate any lingering `aces_dev.exe` processes.
## Local Level Export
If you're developing in-game vehicles that are loaded via missions, you can skip
this section.
However, if you're creating objects for maps, you'll need to place them on the
map and export the level to test them in-game. This process is done via the
[daEditor](../daeditor/daeditor/daeditor.md).
Level export is necessary when:
- You're working with prefabs. Prefabs are only included in the game during
level re-export.
- You've added a new asset that wasn't previously on the level or removed
something from the location.
- Something has changed in object generation, and their placement needs to be
updated.
If you're only modifying render instances or textures, there's no need to
re-export the level – doing so would just waste time.
Once you have placed all your objects, save the level and follow these steps:
1. Open the **Project** menu.
2. Select **Export to Game (PC format)** (if needed).
3. Click **OK** on all subsequent dialog boxes.
4. Save the level binary file.
5. After the level build is complete, launch the game and verify the objects.