2020-09-15 06:07:02 +08:00
# Manifest Mode
2021-03-12 08:37:49 +08:00
**The latest version of this documentation is available on [GitHub ](https://github.com/Microsoft/vcpkg/tree/master/docs/users/manifests.md ).**
vcpkg has two modes of consuming dependencies - classic mode and manifest mode.
2020-09-15 06:07:02 +08:00
2021-02-27 05:10:37 +08:00
In classic mode, vcpkg produces an "installed" tree, whose contents are changed by explicit calls to `vcpkg install` or
`vcpkg remove` . The installed tree is intended for consumption by any number of projects: for example, installing a
bunch of libraries and then using those libraries from Visual Studio, without additional configuration. Because the
installed tree is not associated with an individual project, it's similar to tools like `brew` or `apt` , except that the
installed tree is vcpkg-installation-local, rather than global to a system or user.
In manifest mode, an installed tree is associated with a particular project rather than the vcpkg installation. The set
of installed ports is controlled by editing the project's "manifest file", and the installed tree is placed in the
project directory or build directory. This mode acts more similarly to language package managers like Cargo, or npm. We
recommend using this manifest mode whenever possible, because it allows one to encode a project's dependencies
explicitly in a project file, rather than in the documentation, making your project much easier to consume.
2020-10-13 01:22:47 +08:00
Check out the [manifest cmake example ](../examples/manifest-mode-cmake.md ) for an example project using CMake and
manifest mode.
2020-09-15 06:07:02 +08:00
2021-02-27 05:10:37 +08:00
## Table of Contents
2021-02-25 05:55:16 +08:00
2021-02-27 05:10:37 +08:00
- [Simple Example Manifest ](#simple-example-manifest )
- [Manifest Syntax Reference ](#manifest-syntax-reference )
2022-05-28 00:34:11 +08:00
- [`"name"` ](#name )
- [Version Fields ](#version-fields )
- [`"description"` ](#description )
- [`"builtin-baseline"` ](#builtin-baseline )
- [`"dependencies"` ](#dependencies )
- [`"name"` ](#dependencies-name )
- [`"default-features"` ](#dependencies-default-features )
- [`"features"` ](#dependencies-features )
2022-09-24 03:30:43 +08:00
- [`"host"` ](#host )
2022-05-28 00:34:11 +08:00
- [`"platform"` ](#platform )
- [`"version>="` ](#version-gt )
- [`"overrides"` ](#overrides )
- [`"supports"` ](#supports )
- [`"features"` ](#features )
- [`"default-features"` ](#default-features )
2022-11-12 04:54:00 +08:00
- [`"vcpkg-configuration"` ](#vcpkg-configuration )
2021-02-27 05:10:37 +08:00
2021-02-10 06:03:41 +08:00
## Simple Example Manifest
```json
{
2022-12-13 06:38:01 +08:00
"$schema": "https://raw.githubusercontent.com/microsoft/vcpkg-tool/main/docs/vcpkg.schema.json",
2021-02-10 06:03:41 +08:00
"name": "my-application",
"version": "0.15.2",
"dependencies": [
"boost-system",
{
"name": "cpprestsdk",
"default-features": false
},
"libxml2",
"yajl"
]
}
```
2021-02-27 05:10:37 +08:00
## Manifest Syntax Reference
2020-09-15 06:07:02 +08:00
2020-10-13 01:22:47 +08:00
A manifest is a JSON-formatted file named `vcpkg.json` which lies at the root of your project.
2020-09-15 06:07:02 +08:00
It contains all the information a person needs to know to get dependencies for your project,
as well as all the metadata about your project that a person who depends on you might be interested in.
2020-10-13 01:22:47 +08:00
Manifests follow strict JSON: they can't contain C++-style comments (`//`) nor trailing commas. However
you can use field names that start with `$` to write your comments in any object that has a well-defined set of keys.
These comment fields are not allowed in any objects which permit user-defined keys (such as `"features"` ).
2020-09-15 06:07:02 +08:00
2022-12-13 06:38:01 +08:00
The latest JSON Schema is available at https://raw.githubusercontent.com/microsoft/vcpkg-tool/main/docs/vcpkg.schema.json. IDEs with JSON Schema support such as Visual Studio and Visual Studio Code can use this file to provide IntelliSense and syntax checking. For most IDEs, you should set `"$schema"` in your `vcpkg.json` to this URL (like the above example).
2022-09-24 03:30:43 +08:00
Each manifest contains a top level object with the following fields:
2020-09-15 06:07:02 +08:00
2022-05-28 00:34:11 +08:00
< a id = "name" > < / a >
2020-09-15 06:07:02 +08:00
### `"name"`
This is the name of your project! It must be formatted in a way that vcpkg understands - in other words,
it must be lowercase alphabetic characters, digits, and hyphens, and it must not start nor end with a hyphen.
For example, `Boost.Asio` might be given the name `boost-asio` .
2022-05-28 00:34:11 +08:00
### Version Fields
2020-09-15 06:07:02 +08:00
2022-01-07 07:55:41 +08:00
There are four version field options, depending on how the port orders its
releases.
* [`"version"` ](versioning.md#version ) - Generic, dot-separated numeric
sequence.
* [`"version-semver"` ](versioning.md#version-semver ) - [Semantic Version
2.0.0](https://semver.org/#semantic-versioning-specification-semver)
* [`"version-date"` ](versioning.md#version-date ) - Used for packages which do
not have numeric releases (for example, Live-at-HEAD). Matches `YYYY-MM-DD`
with optional trailing dot-separated numeric sequence.
* [`"version-string"` ](versioning.md#version-string ) - Used for packages that
don't have orderable versions. This should be rarely used, however all ports
created before the other version fields were introduced use this scheme.
Additionally, the optional `"port-version"` field is used to indicate revisions
to the port with the same upstream source version. For pure consumers, this
field should not be used.
See [versioning ](versioning.md#version-schemes ) for more details.
2021-01-16 04:35:48 +08:00
2022-05-28 00:34:11 +08:00
< a id = "description" > < / a >
2020-09-15 06:07:02 +08:00
### `"description"`
This is where you describe your project. Give it a good description to help in searching for it!
This can be a single string, or it can be an array of strings;
in the latter case, the first string is treated as a summary,
while the remaining strings are treated as the full description.
2022-05-28 00:34:11 +08:00
< a id = "builtin-baseline" > < / a >
2021-01-16 04:35:48 +08:00
### `"builtin-baseline"`
2022-01-07 07:55:41 +08:00
This field indicates the commit of vcpkg which provides global minimum version
2022-06-24 05:59:09 +08:00
information for your manifest.
2021-01-16 04:35:48 +08:00
2022-06-24 05:59:09 +08:00
It is required for top-level manifest files using versioning without a specified [`"default-registry"` ](registries.md#configuration-default-registry ). It has the same semantic as defining your default registry to be:
```json
{
"default-registry": {
"kind": "builtin",
"baseline": "< value > "
}
}
```
2021-01-16 04:35:48 +08:00
2022-06-24 05:59:09 +08:00
See [versioning ](versioning.md#baselines ) for more semantic details.
2021-01-16 04:35:48 +08:00
2022-05-28 00:34:11 +08:00
< a id = "dependencies" > < / a >
2020-09-15 06:07:02 +08:00
### `"dependencies"`
This field lists all the dependencies you'll need to build your library (as well as any your dependents might need,
if they were to use you). It's an array of strings and objects:
* A string dependency (e.g., `"dependencies": [ "zlib" ]` ) is the simplest way one can depend on a library;
it means you don't depend on a single version, and don't need to write down any more information.
* On the other hand, an object dependency (e.g., `"dependencies": [ { "name": "zlib" } ]` )
allows you to add that extra information.
2021-02-10 06:03:41 +08:00
#### Example:
```json
"dependencies": [
{
"name": "arrow",
"default-features": false,
"features": [ "json" ]
},
"boost-asio",
"openssl",
{
"name": "picosha2",
"platform": "!windows"
}
]
```
2020-09-15 06:07:02 +08:00
2022-05-28 00:34:11 +08:00
< a id = "dependencies-name" > < / a >
2021-02-10 06:03:41 +08:00
#### `"name"` Field
2020-09-15 06:07:02 +08:00
The name of the dependency. This follows the same restrictions as the [`"name"` ](#name ) property for a project.
2022-05-28 00:34:11 +08:00
< a id = "dependencies-default-features" > < / a >
< a id = "dependencies-features" > < / a >
2021-02-10 06:03:41 +08:00
#### `"features"` and `"default-features"` Fields
2020-09-15 06:07:02 +08:00
`"features"` is an array of feature names which tell you the set of features that the
dependencies need to have at a minimum,
while `"default-features"` is a boolean that tells vcpkg whether or not to
install the features the package author thinks should be "most common for most people to use".
For example, `ffmpeg` is a library which supports many, many audio and video codecs;
however, for your specific project, you may only need mp3 encoding.
Then, you might just ask for:
```json
{
"name": "ffmpeg",
"default-features": false,
"features": [ "mp3lame" ]
}
```
2022-09-24 03:30:43 +08:00
< a id = "host" > < / a >
#### `"host"` Field
A boolean indicating that the dependency must be built for the [host triplet ](host-dependencies.md ) instead of the current port's triplet. Defaults to `false` .
Any dependency that provides tools or scripts which should be "executed" during a build (such as buildsystems, code generators, or helpers) should be marked as `"host": true` . This enables correct cross-compilation in cases that the target is not executable -- such as when compiling for `arm64-android` .
See [Host Dependencies ](host-dependencies.md ) for more information.
2022-05-21 05:42:35 +08:00
< a id = "platform" > < / a >
2022-05-28 00:34:11 +08:00
2021-02-10 06:03:41 +08:00
#### `"platform"` Field
2020-09-15 06:07:02 +08:00
The `"platform"` field defines the platforms where the dependency should be installed - for example,
you might need to use sha256, and so you use platform primitives on Windows, but `picosha2` on non-Windows platforms.
```json
{
"name": "picosha2",
"platform": "!windows"
}
```
This is a string field which takes boolean expressions of the form `<identifier>` ,
`!expression` , `expression { & expression & expression...}` , and `expression { | expression | expression...}` ,
along with parentheses to denote precedence.
For example, a dependency that's only installed on the Windows OS, for the ARM64 architecture,
and on Linux on x64, would be written `(windows & arm64) | (linux & x64)` .
The common identifiers are:
- The operating system: `windows` , `uwp` , `linux` , `osx` (includes macOS), `android` , `emscripten`
- The architecture: `x86` , `x64` , `wasm32` , `arm64` , `arm` (includes both arm32 and arm64 due to backwards compatibility)
although one can define their own.
2022-05-28 00:34:11 +08:00
< a id = "version-gt" > < / a >
2021-02-10 06:03:41 +08:00
#### `"version>="` Field
2021-01-16 04:35:48 +08:00
A minimum version constraint on the dependency.
2022-01-07 07:55:41 +08:00
This field specifies the minimum version of the dependency, optionally using a
`#N` suffix to denote port-version if non-zero.
2021-01-16 04:35:48 +08:00
2021-05-04 00:43:34 +08:00
See also [versioning ](versioning.md#version-1 ) for more semantic details.
2021-01-16 04:35:48 +08:00
2022-05-28 00:34:11 +08:00
< a id = "overrides" > < / a >
2021-01-16 04:35:48 +08:00
### `"overrides"`
2022-01-07 07:55:41 +08:00
This field pins exact versions for individual dependencies.
2021-01-16 04:35:48 +08:00
2022-01-07 07:55:41 +08:00
`"overrides"` from transitive manifests (i.e. from dependencies) are ignored.
2021-01-16 04:35:48 +08:00
See also [versioning ](versioning.md#overrides ) for more semantic details.
#### Example:
```json
"overrides": [
{
"name": "arrow", "version": "1.2.3", "port-version": 7
}
]
```
2022-05-28 00:34:11 +08:00
< a id = "supports" > < / a >
2020-09-15 06:07:02 +08:00
### `"supports"`
If your project doesn't support common platforms, you can tell your users this with the `"supports"` field.
It uses the same platform expressions as [`"platform"` ](#platform ), from dependencies, as well as the
`"supports"` field of features.
For example, if your library doesn't support linux, you might write `{ "supports": "!linux" }` .
2022-05-28 00:34:11 +08:00
< a id = "default-features" > < / a >
< a id = "features" > < / a >
2020-09-15 06:07:02 +08:00
### `"features"` and `"default-features"`
The `"features"` field defines _your_ project's optional features, that others may either depend on or not.
It's an object, where the keys are the names of the features, and the values are objects describing the feature.
`"description"` is required,
and acts exactly like the [`"description"` ](#description ) field on the global package,
and `"dependencies"` are optional,
and again act exactly like the [`"dependencies"` ](#dependencies ) field on the global package.
There's also the `"supports"` field,
which again acts exactly like the [`"supports"` ](#supports ) field on the global package.
You also have control over which features are default, if a person doesn't ask for anything specific,
and that's the `"default-features"` field, which is an array of feature names.
#### Example:
2021-02-10 06:03:41 +08:00
```json
2020-09-15 06:07:02 +08:00
{
"name": "libdb",
2021-02-10 06:03:41 +08:00
"version": "1.0.0",
2020-09-15 06:07:02 +08:00
"description": [
"An example database library.",
2021-01-16 04:35:48 +08:00
"Optionally can build with CBOR, JSON, or CSV as backends."
2020-09-15 06:07:02 +08:00
],
2021-01-16 04:35:48 +08:00
"$default-features-explanation": "Users using this library transitively will get all backends automatically",
2020-09-15 06:07:02 +08:00
"default-features": [ "cbor", "csv", "json" ],
"features": {
"cbor": {
"description": "The CBOR backend",
"dependencies": [
{
"$explanation": [
2021-01-16 04:35:48 +08:00
"This is how you tell vcpkg that the cbor feature depends on the json feature of this package"
2020-09-15 06:07:02 +08:00
],
"name": "libdb",
"default-features": false,
"features": [ "json" ]
}
]
},
"csv": {
"description": "The CSV backend",
"dependencies": [
"fast-cpp-csv-parser"
]
},
"json": {
"description": "The JSON backend",
"dependencies": [
"jsoncons"
]
2021-02-10 06:03:41 +08:00
}
2020-09-15 06:07:02 +08:00
}
}
```
2022-11-12 04:54:00 +08:00
### `"vcpkg-configuration"`
Allows to embed vcpkg configuration properties inside the `vcpkg.json` file. Everything inside
the `vcpkg-configuration` property is treated as if it were defined in a `vcpkg-configuration.json` file.
See the [`vcpkg-configuration.json` documentation ](registries.md ) for details.
Having a `vcpkg-configuration` defined in `vcpkg.json` while also having a `vcpkg-configuration.json`
file is not allowed and will result in the vcpkg command terminating with an error message.
#### Example:
```json
"name": "test",
"version": "1.0.0",
"dependencies": [ "beison", "zlib" ],
"vcpkg-configuration": {
"registries": [
{
"kind": "git",
"baseline": "dacf4de488094a384ca2c202b923ccc097956e0c",
"repository": "https://github.com/northwindtraders/vcpkg-registry",
"packages": [ "beicode", "beison" ]
}
],
"overlay-ports": [ "./my-ports/fmt",
"./team-ports"
]
}
```