2020-08-13 07:59:03 +00:00
# Installing Linux dependencies
This page lists the required dependencies to build a Bevy project on your Linux machine.
If you don't see your distro present in the list, feel free to add the instructions in this document.
## Ubuntu 20.04
2020-10-21 22:57:03 +00:00
2020-08-23 20:18:46 +00:00
```bash
2020-09-21 20:16:17 +00:00
sudo apt-get install pkg-config libx11-dev libasound2-dev libudev-dev
2020-08-23 20:18:46 +00:00
```
2021-02-22 04:50:05 +00:00
2021-02-04 03:15:25 +00:00
If you want to enable fast compiles
2021-02-22 04:50:05 +00:00
2020-12-15 07:10:58 +00:00
```bash
sudo apt-get install clang
```
2020-10-29 01:51:51 +00:00
### Windows Subsystem for Linux (WSL 2)
2021-02-22 04:50:05 +00:00
Graphics and audio need to be configured for them to work with WSL 2 backend.
Please see the ubuntu [WSL documentation ](https://wiki.ubuntu.com/WSL ) on how to set up graphics and audio.
2020-08-13 23:45:43 +00:00
2020-12-24 19:30:36 +00:00
## Fedora 33
2020-10-21 22:57:03 +00:00
2020-08-23 20:18:46 +00:00
```bash
2020-09-21 20:53:17 +00:00
sudo dnf install gcc-c++ libX11-devel alsa-lib-devel systemd-devel
2020-08-23 20:18:46 +00:00
```
## Arch / Manjaro
2020-10-21 22:57:03 +00:00
2020-08-23 20:18:46 +00:00
```bash
sudo pacman -S libx11 pkgconf alsa-lib
```
2020-08-25 23:50:44 +00:00
## Solus
2020-10-21 22:57:03 +00:00
2020-08-25 23:50:44 +00:00
```bash
sudo eopkg install pkg-config libx11-devel g++ alsa-lib-devel
```
2020-08-29 00:09:44 +00:00
2020-10-08 17:28:56 +00:00
## Void
2020-10-21 22:57:03 +00:00
2020-10-08 17:28:56 +00:00
```bash
sudo xbps-install -S pkgconf alsa-lib-devel libX11-devel eudev-libudev-devel
```
2020-08-29 00:09:44 +00:00
## NixOS
Add a `build.rs` file to your project with the following:
```rust
fn main() {
if cfg!(target_os = "linux") {
println!("cargo:rustc-link-lib=vulkan");
}
}
```
2021-02-04 03:15:25 +00:00
These packages provide the dependencies required to run a bevy project. They can be installed globally or via nix-shell.
2020-08-29 00:09:44 +00:00
`nix-shell -p pkgconfig x11 xorg.libXcursor xorg.libXrandr xorg.libXi vulkan-tools lutris vulkan-headers vulkan-loader vulkan-validation-layers alsaLib`
2020-09-14 21:34:43 +00:00
Alternatively, you can copy the following code block and create a file called `shell.nix` . You can now enter nix-shell just by running `nix-shell` .
```nix
# shell.nix
{ pkgs ? import < nixpkgs > { } }:
pkgs.mkShell {
buildInputs = [
pkgs.alsaLib
pkgs.lutris
pkgs.pkgconfig
pkgs.vulkan-headers
pkgs.vulkan-loader
pkgs.vulkan-tools
pkgs.vulkan-validation-layers
pkgs.x11
pkgs.xorg.libXcursor
pkgs.xorg.libXi
pkgs.xorg.libXrandr
];
}
```
2020-11-15 19:33:21 +00:00
At this point, projects should successfully compile but fail on execution. This is due to `glslang_validator` which, unfortunately, needs to have it's binary patched to link correctly. This is a known issue, and there are plans to remove this dependency.
2020-08-29 00:09:44 +00:00
1. `find target -type f -name glslang_validator` in order to find glslang_validator in `target/debug/build/bevy-glsl-to-spirv-<hash>/out/glslang_validator` . The directory containing glslang_validator will be referenced again, so save it for later: `export OUT_DIR="$(dirname $(find target -type f -name glslang_validator))"` .
2. Running `ldd $OUT_DIR/glslang_validator` may show `libstdc++.so.6` is not found. If all dependencies are found, then bevy should work. If not, install (globally or in nix-shell) any of the results found by `nix-locate -w libstdc++.so.6` . For example purposes, consider `nixos.gcc-unwrapped` . In theory, any of the ones in `find -L /nix/store -type f -name libstdc++.so.6` will work.
3. `patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" --set-rpath /nix/store/784rh7jrfhagbkydjfrv68h9x3g4gqmk-gcc-8.3.0-lib/lib $OUT_DIR/glslang_validator`
2020-11-15 19:33:21 +00:00
4. Bevy should now be working correctly!