2021-08-03 13:56:45 -07:00
# Selecting Library Features
2020-11-02 18:26:25 -07:00
2021-03-11 16:37:49 -08:00
**The latest version of this documentation is available on [GitHub ](https://github.com/Microsoft/vcpkg/tree/master/docs/users/selecting-library-features.md ).**
2020-11-02 18:26:25 -07:00
## Installing a library
2021-03-11 16:37:49 -08:00
We will look at [llvm ](https://llvm.org/ ) as an example. You could install it using:
2020-11-02 18:26:25 -07:00
```powershell
2021-03-11 16:37:49 -08:00
> vcpkg install llvm
2020-11-02 18:26:25 -07:00
```
2021-03-11 16:37:49 -08:00
or via a manifest with
```json
{
"dependencies": ["llvm"]
}
2020-11-02 18:26:25 -07:00
```
With llvm now installed, we can execute:
```powershell
2021-03-11 16:37:49 -08:00
> installed\x86-windows\bin\llc.exe --version
2020-11-02 18:26:25 -07:00
```
we see:
```powershell
Registered Targets:
x86 - 32-bit X86: Pentium-Pro and above
x86-64 - 64-bit X86: EM64T and AMD64
```
## Installing additional features
But [llvm supports many more targets ](https://llvm.org/docs/GettingStarted.html#local-llvm-configuration ), from ARM to SPARC to SystemZ.
However, clearly our current installation doesn't include ARM as a target;
thus, we need to learn how vcpkg allows us to install other LLVM targets.
The llvm port allows this via the "target-*" features.
If we do:
```powershell
2021-03-11 16:37:49 -08:00
> vcpkg search llvm
2020-11-02 18:26:25 -07:00
```
We can see:
```
llvm 10.0.0#6 The LLVM Compiler Infrastructure
llvm[clang] Build C Language Family Front-end.
llvm[clang-tools-extra] Build Clang tools.
...
llvm[target-all] Build with all backends.
llvm[target-amdgpu] Build with AMDGPU backend.
llvm[target-arm] Build with ARM backend.
...
```
We can install any of these targets by using the install-feature syntax:
```powershell
2021-03-11 16:37:49 -08:00
> vcpkg install llvm[target-arm] # Installs LLVM with the ARM target
```
```json
{
"dependencies": [{ "name": "llvm", "features": ["target-arm"] }]
}
2020-11-02 18:26:25 -07:00
```
2021-03-11 16:37:49 -08:00
## Opting out of default features
2020-11-02 18:26:25 -07:00
The llvm port includes a few default features that you as a user may not want: for example,
the `clang` feature is default, which means that `vcpkg install llvm` will also build and install clang.
If you are writing a compiler that uses LLVM as a backend,
you're likely not interested in installing clang as well,
and we can do that by disabling default features with the special `core` "feature":
```powershell
2021-03-11 16:37:49 -08:00
> vcpkg install llvm[core,target-arm] # removing the default-feature with "core" also removes all of the default targets you get
```
or in manifest files:
```json
{
"dependencies": [{
"name": "llvm",
"default-features": false,
"features": ["target-arm"]
}]
}
2020-11-02 18:26:25 -07:00
```
# Further reading
2021-04-28 22:52:32 +02:00
- The [Feature Packages ](../specifications/feature-packages.md ) specification was the initial design for features.