JAR Manifests

JAR Manifests are plaintext files in the tree that are used to package chrome files into .jar files and create Chrome Registration manifests. JAR Manifests are commonly named jar.mn. They are declared in moz.build files using the JAR_MANIFESTS variable, which makes up a collection of jar.mn files. All files declared in JAR Manifests are processed and installed into omni.ja files in browser/ and toolkit/ when building Firefox.

jar.mn files are automatically processed by the build system when building a source directory that contains one. The jar.mn is run through the Text Preprocessor before being passed to the manifest processor. In order to have @variables@ expanded (such as @AB_CD@) throughout the file, add the line #filter substitution at the top of your jar.mn file.

The format of a jar.mn is fairly simple; it consists of a heading specifying which JAR file is being packaged, followed by indented lines listing files and chrome registration instructions.

For a simple jar.mn file, see toolkit/profile/jar.mn. For a much more complex jar.mn file, see toolkit/locales/jar.mn. More examples with specific formats and uses are available below.

Shipping Chrome Files

General Format

To ship chrome files in a JAR, an indented line indicates a file to be packaged:

<jarfile>.jar:
  path/in/jar/file_name.xul     (source/tree/location/file_name.xul)

Note that file path mappings are listed by destination (left) followed by source (right).

Same Directory Omission

If the JAR manifest and packaged files live in the same directory, the source path and parentheses can be omitted. A sample of a jar.mn file with omitted source paths and parentheses is this revision of browser/components/colorways/jar.mn:

browser.jar:
  content/browser/colorwaycloset.html
  content/browser/colorwaycloset.css
  content/browser/colorwaycloset.js

Writing the following is equivalent, given that the aforementioned files exist in the same directory as the jar.mn. Notice the .jar file is named browser.jar:

browser.jar:
  content/browser/colorwaycloset.html (colorwaycloset.html)
  content/browser/colorwaycloset.css  (colorwaycloset.css)
  content/browser/colorwaycloset.js   (colorwaycloset.js)

This manifest is responsible for packaging files needed by Colorway Closet, including JS scripts, localization files, images (ex. PNGs, AVIFs), and CSS styling. Look at browser/components/colorways/colorwaycloset.html to see how a file may be referenced using its chrome URL.

Absolute Paths

The source tree location may also be an absolute path (taken from the top of the source tree). One such example can be found in toolkit/components/pictureinpicture/jar.mn:

toolkit.jar:
  * content/global/pictureinpicture/player.xhtml   (content/player.xhtml)
  content/global/pictureinpicture/player.js      (content/player.js)

Asterisk Marker (Preprocessing)

An asterisk marker (*) at the beginning of the line indicates that the file should be processed by the Text Preprocessor before being packaged. The file toolkit/profile/jar.mn indicates that the file toolkit/profile/content/profileDowngrade.xhtml should be run through the preprocessor, since it contains #ifdef and #endif statements that need to be interpreted:

* content/mozapps/profile/profileDowngrade.xhtml  (content/profileDowngrade.xhtml)

Base Path, Variables, Wildcards and Localized Files

The .jar file location may be preceded with a base path between square brackets. The file toolkit/locales/jar.mn uses a base path so that the .jar file is under a localization directory, which is a special directory parsed by mozbuild.

It is also named according to the value passed by the variable @AB_CD@, normally a locale. Note the use of the preprocessor directive #filter substitution at the top of the file for replacing the variable with the value:

#filter substitution

...

[localization] @AB_CD@.jar:
  crashreporter                                    (%crashreporter/**/*.ftl)
  toolkit                                          (%toolkit/**/*.ftl)

The percentage sign in front of the source paths designates the locale to target as a source. By default, this is en-US. With this specific example, /toolkit/locales/en-US would be targeted. Otherwise, the file from an alternate localization source tree /l10n/<locale>/toolkit/ is read if building a localized version. The wildcards in **/*.ftl tell the processor to install all Fluent files within the crashreporter and toolkit directories, as well as their subdirectories.

Registering Chrome

Chrome Registration instructions are marked with a percent sign (%) at the beginning of the line, and must be part of the definition of a JAR file. Any additional percents signs are replaced with an appropriate relative URL of the JAR file being packaged.

There are two possible locations for a manifest file. If the chrome is being built into a standalone application, the jar.mn processor creates a <jarfilename>.manifest next to the JAR file itself. This is the default behavior.

If the moz.build specifies USE_EXTENSION_MANIFEST = 1, the jar.mn processor creates a single chrome.manifest file suitable for registering chrome as an extension.

Example

The file browser/themes/addons/jar.mn registers a resource chrome package under the name builtin-themes. Its source files are in %content/builtin-themes/:

browser.jar:
  %  resource builtin-themes %content/builtin-themes/

  content/builtin-themes/alpenglow                 (alpenglow/*.svg)
  content/builtin-themes/alpenglow/manifest.json   (alpenglow/manifest.json)

Notice how other files declare an installation destination using the builtin-themes resource that is defined. As such, a SVG file preview.svg for a theme Alpenglow may be loaded using the resource URL resource://builtin-themes/alpenglow/preview.svg so that a preview of the theme is available on about:addons. See Chrome Registration for more details on resource and other manifest instructions.