mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
nix: update README, remove nixGL selection from dev shell (which also removes envrc-nvidia), update envrc to be used by both flakes, tidy up some stuff
This commit is contained in:
parent
9f8ec7e010
commit
9e62a6c322
18
flake.lock
18
flake.lock
@ -32,23 +32,6 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nixGL": {
|
|
||||||
"flake": false,
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1604138361,
|
|
||||||
"narHash": "sha256-I9/myywtqh9xrxC94molYpwN4c92dw1jUmfS2+pHwws=",
|
|
||||||
"owner": "guibou",
|
|
||||||
"repo": "nixGL",
|
|
||||||
"rev": "7d6bc1b21316bab6cf4a6520c2639a11c25a220e",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "guibou",
|
|
||||||
"repo": "nixGL",
|
|
||||||
"rev": "7d6bc1b21316bab6cf4a6520c2639a11c25a220e",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1606744648,
|
"lastModified": 1606744648,
|
||||||
@ -85,7 +68,6 @@
|
|||||||
"inputs": {
|
"inputs": {
|
||||||
"crate2nix": "crate2nix",
|
"crate2nix": "crate2nix",
|
||||||
"flake-utils": "flake-utils",
|
"flake-utils": "flake-utils",
|
||||||
"nixGL": "nixGL",
|
|
||||||
"nixpkgs": "nixpkgs",
|
"nixpkgs": "nixpkgs",
|
||||||
"nixpkgsMoz": "nixpkgsMoz"
|
"nixpkgsMoz": "nixpkgsMoz"
|
||||||
}
|
}
|
||||||
|
@ -11,22 +11,15 @@
|
|||||||
url = "github:mozilla/nixpkgs-mozilla";
|
url = "github:mozilla/nixpkgs-mozilla";
|
||||||
flake = false;
|
flake = false;
|
||||||
};
|
};
|
||||||
nixGL = {
|
|
||||||
url = "github:guibou/nixGL?rev=7d6bc1b21316bab6cf4a6520c2639a11c25a220e";
|
|
||||||
flake = false;
|
|
||||||
};
|
|
||||||
nixpkgs.url = "github:NixOS/nixpkgs?rev=c00959877fb06b09468562518b408acda886c79e";
|
nixpkgs.url = "github:NixOS/nixpkgs?rev=c00959877fb06b09468562518b408acda886c79e";
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs = inputs: with inputs;
|
outputs = inputs: with inputs;
|
||||||
flake-utils.lib.eachSystem [ "x86_64-linux" ] (system:
|
flake-utils.lib.eachSystem [ "x86_64-linux" ] (system:
|
||||||
let
|
let
|
||||||
pkgs = inputs.nixpkgs.legacyPackages."${system}";
|
|
||||||
|
|
||||||
sources = {
|
sources = {
|
||||||
inherit
|
inherit
|
||||||
crate2nix
|
crate2nix
|
||||||
nixGL
|
|
||||||
nixpkgs
|
nixpkgs
|
||||||
nixpkgsMoz
|
nixpkgsMoz
|
||||||
;
|
;
|
||||||
|
@ -4141,62 +4141,6 @@ rec {
|
|||||||
};
|
};
|
||||||
resolvedDefaultFeatures = [ "default" "std" ];
|
resolvedDefaultFeatures = [ "default" "std" ];
|
||||||
};
|
};
|
||||||
"failure" = rec {
|
|
||||||
crateName = "failure";
|
|
||||||
version = "0.1.8";
|
|
||||||
edition = "2015";
|
|
||||||
sha256 = "11jg1wmbkijrs6bk9fqnbrm9zf0850whnqpgnxyswbn0dk8rnbnk";
|
|
||||||
authors = [
|
|
||||||
"Without Boats <boats@mozilla.com>"
|
|
||||||
];
|
|
||||||
dependencies = [
|
|
||||||
{
|
|
||||||
name = "backtrace";
|
|
||||||
packageId = "backtrace";
|
|
||||||
optional = true;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
name = "failure_derive";
|
|
||||||
packageId = "failure_derive";
|
|
||||||
optional = true;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
features = {
|
|
||||||
"default" = [ "std" "derive" ];
|
|
||||||
"derive" = [ "failure_derive" ];
|
|
||||||
"std" = [ "backtrace" ];
|
|
||||||
};
|
|
||||||
resolvedDefaultFeatures = [ "backtrace" "default" "derive" "failure_derive" "std" ];
|
|
||||||
};
|
|
||||||
"failure_derive" = rec {
|
|
||||||
crateName = "failure_derive";
|
|
||||||
version = "0.1.8";
|
|
||||||
edition = "2015";
|
|
||||||
sha256 = "1936adqqk080439kx2bjf1bds7h89sg6wcif4jw0syndcv3s6kda";
|
|
||||||
procMacro = true;
|
|
||||||
authors = [
|
|
||||||
"Without Boats <woboats@gmail.com>"
|
|
||||||
];
|
|
||||||
dependencies = [
|
|
||||||
{
|
|
||||||
name = "proc-macro2";
|
|
||||||
packageId = "proc-macro2 1.0.23";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
name = "quote";
|
|
||||||
packageId = "quote 1.0.7";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
name = "syn";
|
|
||||||
packageId = "syn 1.0.42";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
name = "synstructure";
|
|
||||||
packageId = "synstructure";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
features = { };
|
|
||||||
};
|
|
||||||
"fehler" = rec {
|
"fehler" = rec {
|
||||||
crateName = "fehler";
|
crateName = "fehler";
|
||||||
version = "1.0.0";
|
version = "1.0.0";
|
||||||
@ -12502,42 +12446,6 @@ rec {
|
|||||||
};
|
};
|
||||||
resolvedDefaultFeatures = [ "clone-impls" "default" "derive" "extra-traits" "fold" "full" "parsing" "printing" "proc-macro" "quote" "visit" "visit-mut" ];
|
resolvedDefaultFeatures = [ "clone-impls" "default" "derive" "extra-traits" "fold" "full" "parsing" "printing" "proc-macro" "quote" "visit" "visit-mut" ];
|
||||||
};
|
};
|
||||||
"synstructure" = rec {
|
|
||||||
crateName = "synstructure";
|
|
||||||
version = "0.12.4";
|
|
||||||
edition = "2018";
|
|
||||||
sha256 = "00c72ij813xsilssgya6m6f73d0s5zzsld1y26bvhk3kdzbg4d5q";
|
|
||||||
authors = [
|
|
||||||
"Nika Layzell <nika@thelayzells.com>"
|
|
||||||
];
|
|
||||||
dependencies = [
|
|
||||||
{
|
|
||||||
name = "proc-macro2";
|
|
||||||
packageId = "proc-macro2 1.0.23";
|
|
||||||
usesDefaultFeatures = false;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
name = "quote";
|
|
||||||
packageId = "quote 1.0.7";
|
|
||||||
usesDefaultFeatures = false;
|
|
||||||
}
|
|
||||||
{
|
|
||||||
name = "syn";
|
|
||||||
packageId = "syn 1.0.42";
|
|
||||||
usesDefaultFeatures = false;
|
|
||||||
features = [ "derive" "parsing" "printing" "clone-impls" "visit" "extra-traits" ];
|
|
||||||
}
|
|
||||||
{
|
|
||||||
name = "unicode-xid";
|
|
||||||
packageId = "unicode-xid 0.2.1";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
features = {
|
|
||||||
"default" = [ "proc-macro" ];
|
|
||||||
"proc-macro" = [ "proc-macro2/proc-macro" "syn/proc-macro" "quote/proc-macro" ];
|
|
||||||
};
|
|
||||||
resolvedDefaultFeatures = [ "default" "proc-macro" ];
|
|
||||||
};
|
|
||||||
"take_mut" = rec {
|
"take_mut" = rec {
|
||||||
crateName = "take_mut";
|
crateName = "take_mut";
|
||||||
version = "0.2.2";
|
version = "0.2.2";
|
||||||
@ -14907,10 +14815,6 @@ rec {
|
|||||||
name = "euc";
|
name = "euc";
|
||||||
packageId = "euc";
|
packageId = "euc";
|
||||||
}
|
}
|
||||||
{
|
|
||||||
name = "failure";
|
|
||||||
packageId = "failure";
|
|
||||||
}
|
|
||||||
{
|
{
|
||||||
name = "gfx";
|
name = "gfx";
|
||||||
packageId = "gfx";
|
packageId = "gfx";
|
||||||
|
164
nix/README.md
164
nix/README.md
@ -1,71 +1,52 @@
|
|||||||
## Important
|
## Read this first!
|
||||||
|
|
||||||
If you are going to call the derivations with a custom `nixpkgs` argument, make sure that the `nixpkgs` you pass is on at least the same commit or newer than it.
|
Since this repo uses a new Nix feature called "Flakes", it is recommended to enable it.
|
||||||
Unexpected errors may pop up if you use an older version. Same goes for the `sources` argument.
|
It massively improves the `nix` CLI UX, and adds many useful features.
|
||||||
|
We include instructions for Nix without flakes enabled, but using flakes is the recommended way.
|
||||||
|
|
||||||
### How to use
|
See the [NixOS wiki](https://nixos.wiki/wiki/Flakes) for information on how to enable and use flakes.
|
||||||
|
|
||||||
To enter the development shell (which includes all tools mentioned in this readme + tools you'll need to develop Veloren), run:
|
It is recommended to first setup the [Cachix](https://cachix.org) cache to save time with builds:
|
||||||
```shell
|
```shell
|
||||||
nix-shell nix/shell.nix
|
nix shell nixpkgs#cachix -c cachix use veloren-nix
|
||||||
```
|
# or if you don't have flakes:
|
||||||
It is recommended that you enter the dev shell before starting to build using `nix-build` or `nix-env` (anything which build stuff),
|
nix-shell -p cachix --run "cachix use veloren-nix"
|
||||||
since it will setup a Cachix cache for you. (you can configure this for your user's `nix.conf` by running `cachix use veloren-nix` once in the dev shell,
|
|
||||||
which will make the cache available when you run commands outside of the dev shell).
|
|
||||||
|
|
||||||
If you have [direnv](https://direnv.net) setup on your system, it is also recommended to copy the `envrc`
|
|
||||||
(or `envrc-nvidia`, if you have an Nvidia GPU) file to the root of the repository as `.envrc`:
|
|
||||||
```shell
|
|
||||||
cp nix/envrc .envrc
|
|
||||||
```
|
|
||||||
This will make your env have the dev env setup automatically.
|
|
||||||
|
|
||||||
To build and install Voxygen and the server CLI into user profile, run:
|
|
||||||
```shell
|
|
||||||
nix-env -f nix/default.nix -i
|
|
||||||
```
|
|
||||||
You can configure what to install by changing the `cratesToBuild` argument:
|
|
||||||
```shell
|
|
||||||
nix-env -f nix/default.nix --arg cratesToBuild '["veloren-voxygen"]'
|
|
||||||
```
|
|
||||||
For example, this will install Voxygen only.
|
|
||||||
|
|
||||||
You can configure the crates to be built with debug mode (not recommended, equals to `opt-level = 0`):
|
|
||||||
```shell
|
|
||||||
nix-env -f nix/default.nix --arg release false
|
|
||||||
```
|
```
|
||||||
|
|
||||||
If you aren't on NixOS, you can run `veloren-voxygen` using the provided `nixGLIntel` in the dev shell:
|
As this repository uses `git-lfs`, please make sure `git-lfs` is in your path.
|
||||||
|
If you have a locally cloned repo, you can make sure it is setup with:
|
||||||
```shell
|
```shell
|
||||||
nixGLIntel veloren-voxygen
|
git lfs install --local && git lfs fetch && git lfs checkout
|
||||||
```
|
```
|
||||||
If you have an Nvidia GPU, you can enter the dev shell like so:
|
This should be automatically done if you use the development shell.
|
||||||
```shell
|
|
||||||
nix-shell nix/shell.nix --arg nvidia true
|
|
||||||
```
|
|
||||||
And you'll be able to use `nixGLNvidia` and `nixGLNvidiaBumblebee`.
|
|
||||||
|
|
||||||
#### Using the flake
|
## Usage for players
|
||||||
|
|
||||||
Due to the nature of flakes' reliance on git and the way `git-lfs` is configured for this repo, you must already have `git-lfs` in your environment when running nix commands on a local checkout. Run this to enter a shell environment with `git-lfs` in your path:
|
### With flakes
|
||||||
```shell
|
|
||||||
nix shell nixpkgs#git-lfs
|
|
||||||
```
|
|
||||||
|
|
||||||
To enter a shell environment with the necessary tools:
|
If you just want to run the game without installing it, you can do so with:
|
||||||
```shell
|
|
||||||
nix develop
|
|
||||||
```
|
|
||||||
|
|
||||||
If you simply want to run the latest version without necessarily installing it, you can do so with
|
|
||||||
```shell
|
```shell
|
||||||
# Voxygen (the default):
|
# Voxygen (the default):
|
||||||
nix run gitlab:veloren/veloren
|
nix run gitlab:veloren/veloren
|
||||||
# Server CLI:
|
# Server CLI:
|
||||||
nix run gitlab:veloren/veloren#veloren-server-cli
|
nix run gitlab:veloren/veloren#veloren-server-cli
|
||||||
|
# or if you have a local repo
|
||||||
|
nix run .
|
||||||
|
nix run .#veloren-server-cli
|
||||||
```
|
```
|
||||||
|
|
||||||
To install (for example) the game client on your system, the configuration could look something like this:
|
To install the game into your user profile:
|
||||||
|
```shell
|
||||||
|
# Voxygen:
|
||||||
|
nix profile install gitlab:veloren/veloren
|
||||||
|
# Server CLI:
|
||||||
|
nix profile install giltab:veloren/veloren#veloren-server-cli
|
||||||
|
# or if you have a local repo:
|
||||||
|
nix profile install .
|
||||||
|
nix profile install .#veloren-server-cli
|
||||||
|
```
|
||||||
|
|
||||||
|
To install (for example) Voxygen on your system, the NixOS configuration (if you use a flake based setup) could look something like this:
|
||||||
```nix
|
```nix
|
||||||
{ description = "NixOS configuration with flakes";
|
{ description = "NixOS configuration with flakes";
|
||||||
|
|
||||||
@ -106,18 +87,64 @@ To install (for example) the game client on your system, the configuration could
|
|||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
### Managing Cargo.nix
|
### Without flakes
|
||||||
|
|
||||||
Enter the development shell.
|
You can do this to run the game without installing it (you will need a local clone of the repo though):
|
||||||
|
|
||||||
To update `Cargo.nix` (and `crate-hashes.json`) using latest `Cargo.lock`, run:
|
|
||||||
```shell
|
```shell
|
||||||
crate2nix generate -f ../Cargo.toml
|
# build the game
|
||||||
|
nix-build nix/default.nix
|
||||||
|
# run it
|
||||||
|
./result/bin/veloren-voxygen
|
||||||
|
# or for server cli
|
||||||
|
./result-2/bin/veloren-server-cli
|
||||||
```
|
```
|
||||||
|
|
||||||
### Managing dependencies
|
To install Voxygen and server CLI into user profile:
|
||||||
|
```shell
|
||||||
|
nix-env -f nix/default.nix -i
|
||||||
|
```
|
||||||
|
|
||||||
#### Nix with flakes enabled
|
### Notes for non-NixOS setups
|
||||||
|
|
||||||
|
You'll need to use [nixGL](https://github.com/guibou/nixGL) to be able to run the game (after installing it):
|
||||||
|
```shell
|
||||||
|
# For Intel and AMD:
|
||||||
|
nixGLIntel veloren-voxygen
|
||||||
|
# For Nvidia:
|
||||||
|
nixGLNvidia veloren-voxygen
|
||||||
|
```
|
||||||
|
|
||||||
|
## Usage for developers
|
||||||
|
|
||||||
|
The development shell automatically setups the Cachix cache for you, so it is recommended to be in the dev shell always.
|
||||||
|
If you have the Cachix cache setup in `~/.config/nix/nix.conf` (as described in the beginning of this document), then this isn't a necessity.
|
||||||
|
|
||||||
|
### With flakes
|
||||||
|
|
||||||
|
To enter a shell environment with the necessary tools:
|
||||||
|
```shell
|
||||||
|
nix develop
|
||||||
|
```
|
||||||
|
|
||||||
|
### Without flakes
|
||||||
|
|
||||||
|
To enter the development shell:
|
||||||
|
```shell
|
||||||
|
nix-shell nix/shell.nix
|
||||||
|
```
|
||||||
|
|
||||||
|
### Direnv
|
||||||
|
|
||||||
|
This only works if you have flakes. There is an issue with the git-lfs hook in `shellHook` erroring out with `use nix`, so you'll have to enable flakes if you want to use the `envrc` file included.
|
||||||
|
|
||||||
|
If you have [direnv](https://direnv.net) and [nix-direnv](https://github.com/nix-community/nix-direnv) on your system, you can copy the `envrc` file to the root of the repository as `.envrc`:
|
||||||
|
```shell
|
||||||
|
cp nix/envrc .envrc
|
||||||
|
```
|
||||||
|
|
||||||
|
## Managing dependencies
|
||||||
|
|
||||||
|
### With flakes
|
||||||
|
|
||||||
If a specific revision is specified in `flake.nix`, you will have to update that first, either by specifying a new desired revision or by removing it.
|
If a specific revision is specified in `flake.nix`, you will have to update that first, either by specifying a new desired revision or by removing it.
|
||||||
|
|
||||||
@ -129,19 +156,34 @@ nix flake update --update-input nixpkgs
|
|||||||
nix flake update --recreate-lock-file
|
nix flake update --recreate-lock-file
|
||||||
```
|
```
|
||||||
|
|
||||||
See the [NixOS wiki](https://nixos.wiki/wiki/Flakes) for more information on how to use flakes.
|
### Without flakes
|
||||||
|
|
||||||
#### Legacy nix
|
|
||||||
|
|
||||||
It is inadvised to update revisions without the use of `nix flake update` as it's both tedious and error-prone to attempt setting all fields to their correct values in both `flake.nix` and `flake.lock`, but if you need to do it for testing, `flake.lock` is where legacy nix commands get the input revisions from (through `flake-compat`), regardless of what is specified in `flake.nix` (see https://github.com/edolstra/flake-compat/issues/10).
|
It is inadvised to update revisions without the use of `nix flake update` as it's both tedious and error-prone to attempt setting all fields to their correct values in both `flake.nix` and `flake.lock`, but if you need to do it for testing, `flake.lock` is where legacy nix commands get the input revisions from (through `flake-compat`), regardless of what is specified in `flake.nix` (see https://github.com/edolstra/flake-compat/issues/10).
|
||||||
|
|
||||||
Modify the relevant `rev` field in `flake.lock` to what you need - you can use `nix-prefetch-git` to find an up-to-date revision. Leave the `narHash` entry as is and attempt a rebuild to find out what its value should be.
|
Modify the relevant `rev` field in `flake.lock` to what you need - you can use `nix-prefetch-git` to find an up-to-date revision. Leave the `narHash` entry as is and attempt a rebuild to find out what its value should be.
|
||||||
|
|
||||||
### Formatting
|
### Generating Cargo.nix
|
||||||
|
|
||||||
|
Enter the development shell.
|
||||||
|
|
||||||
|
To update `Cargo.nix` (and `crate-hashes.json`) using latest `Cargo.lock`, run:
|
||||||
|
```shell
|
||||||
|
crate2nix generate -f ../Cargo.toml
|
||||||
|
```
|
||||||
|
|
||||||
|
### Rust toolchain
|
||||||
|
|
||||||
|
If the `rust-toolchain` file is updated, you will need to update the `sha256` hash in the `nix/rustPkgs.nix` file.
|
||||||
|
|
||||||
|
Trying to build the derivation should give you the correct hash to put in.
|
||||||
|
|
||||||
|
## Formatting
|
||||||
|
|
||||||
Use [nixpkgs-fmt](https://github.com/nix-community/nixpkgs-fmt) to format files.
|
Use [nixpkgs-fmt](https://github.com/nix-community/nixpkgs-fmt) to format files.
|
||||||
|
|
||||||
To format every Nix file:
|
To format every Nix file:
|
||||||
```shell
|
```shell
|
||||||
nixpkgs-fmt flake.nix nix/*.nix
|
nixpkgs-fmt flake.nix nix/*.nix
|
||||||
|
# or
|
||||||
|
nixpkgs-fmt **/**.nix
|
||||||
```
|
```
|
||||||
|
@ -11,14 +11,13 @@ let
|
|||||||
(final: prev: {
|
(final: prev: {
|
||||||
rustc = rustChannel.rust;
|
rustc = rustChannel.rust;
|
||||||
crate2nix = prev.callPackage sources.crate2nix { pkgs = prev; };
|
crate2nix = prev.callPackage sources.crate2nix { pkgs = prev; };
|
||||||
nixGL = prev.callPackage sources.nixGL { pkgs = prev; };
|
|
||||||
})
|
})
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
in
|
in
|
||||||
with pkgs;
|
with pkgs;
|
||||||
let
|
{
|
||||||
|
inherit pkgs;
|
||||||
# deps that crates need (for compiling)
|
# deps that crates need (for compiling)
|
||||||
crateDeps =
|
crateDeps =
|
||||||
let
|
let
|
||||||
@ -30,19 +29,9 @@ let
|
|||||||
veloren-network = makeDeps [ openssl ] [ pkg-config ];
|
veloren-network = makeDeps [ openssl ] [ pkg-config ];
|
||||||
veloren-voxygen = makeDeps [ xorg.libxcb ] [ ];
|
veloren-voxygen = makeDeps [ xorg.libxcb ] [ ];
|
||||||
};
|
};
|
||||||
|
|
||||||
# deps that voxygen needs to function
|
# deps that voxygen needs to function
|
||||||
# FIXME: Wayland doesn't work (adding libxkbcommon, wayland and wayland-protocols results in a panic)
|
# FIXME: Wayland doesn't work (adding libxkbcommon, wayland and wayland-protocols results in a panic)
|
||||||
voxygenNeededLibs = (with xorg; [ libX11 libXcursor libXrandr libXi ])
|
voxygenNeededLibs = (with xorg; [ libX11 libXcursor libXrandr libXi ])
|
||||||
++ [ libGL ];
|
++ [ libGL ];
|
||||||
|
|
||||||
gitLfsCheckFile = ../assets/voxygen/background/bg_main.png;
|
gitLfsCheckFile = ../assets/voxygen/background/bg_main.png;
|
||||||
in
|
|
||||||
{
|
|
||||||
inherit
|
|
||||||
crateDeps
|
|
||||||
gitLfsCheckFile
|
|
||||||
pkgs
|
|
||||||
voxygenNeededLibs
|
|
||||||
;
|
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
{ nixpkgs, sources, system, nvidia ? false }:
|
{ nixpkgs, sources, system }:
|
||||||
with import ./common.nix
|
with import ./common.nix
|
||||||
{
|
{
|
||||||
inherit
|
inherit
|
||||||
@ -9,22 +9,13 @@ with import ./common.nix
|
|||||||
};
|
};
|
||||||
with pkgs;
|
with pkgs;
|
||||||
let
|
let
|
||||||
nixGLPackages = ((with nixGL; [ nixGLIntel ]) ++ (lib.optional nvidia
|
|
||||||
(with nixGL; [ nixGLNvidia nixGLNvidiaBumblebee ])));
|
|
||||||
|
|
||||||
getAllCratesDeps = name:
|
getAllCratesDeps = name:
|
||||||
(lib.concatLists
|
(lib.concatLists
|
||||||
(map (attrset: attrset."${name}") (lib.attrValues crateDeps)));
|
(map (attrset: attrset."${name}") (lib.attrValues crateDeps)));
|
||||||
|
|
||||||
bundleCrate = writeScriptBin "bundleCrate" ''
|
|
||||||
#!${stdenv.shell}
|
|
||||||
${nix-bundle}/bin/nix-bundle "(pkgs.callPackage ./nix/veloren.nix { cratesToBuild = [ \"$1\" ]; }).$1" /bin/$1
|
|
||||||
'';
|
|
||||||
in
|
in
|
||||||
mkShell {
|
mkShell {
|
||||||
name = "veloren-shell";
|
name = "veloren-shell";
|
||||||
nativeBuildInputs = [
|
nativeBuildInputs = [
|
||||||
bundleCrate
|
|
||||||
cachix
|
cachix
|
||||||
cargo
|
cargo
|
||||||
clippy
|
clippy
|
||||||
@ -34,7 +25,7 @@ mkShell {
|
|||||||
nixpkgs-fmt
|
nixpkgs-fmt
|
||||||
rustc
|
rustc
|
||||||
rustfmt
|
rustfmt
|
||||||
] ++ nixGLPackages ++ (getAllCratesDeps "nativeBuildInputs");
|
] ++ (getAllCratesDeps "nativeBuildInputs");
|
||||||
buildInputs = getAllCratesDeps "buildInputs";
|
buildInputs = getAllCratesDeps "buildInputs";
|
||||||
shellHook = ''
|
shellHook = ''
|
||||||
# Setup our cachix "substituter"
|
# Setup our cachix "substituter"
|
||||||
|
@ -5,4 +5,5 @@ watch_file nix/devShell.nix
|
|||||||
watch_file nix/rustPkgs.nix
|
watch_file nix/rustPkgs.nix
|
||||||
watch_file nix/shell.nix
|
watch_file nix/shell.nix
|
||||||
watch_file nix/utils.nix
|
watch_file nix/utils.nix
|
||||||
use nix nix/shell.nix
|
|
||||||
|
use flake
|
||||||
|
@ -1,8 +0,0 @@
|
|||||||
watch_file flake.lock
|
|
||||||
watch_file flake.nix
|
|
||||||
watch_file nix/common.nix
|
|
||||||
watch_file nix/devShell.nix
|
|
||||||
watch_file nix/rustPkgs.nix
|
|
||||||
watch_file nix/shell.nix
|
|
||||||
watch_file nix/utils.nix
|
|
||||||
use nix nix/shell.nix --arg nvidia true
|
|
@ -8,7 +8,6 @@ let
|
|||||||
rustToolchain = ../rust-toolchain;
|
rustToolchain = ../rust-toolchain;
|
||||||
sha256 = "sha256-kDtMqYvrTbahqYHYFQOWyvT0+F5o4UVcqkMZt0c43kc=";
|
sha256 = "sha256-kDtMqYvrTbahqYHYFQOWyvT0+F5o4UVcqkMZt0c43kc=";
|
||||||
};
|
};
|
||||||
|
|
||||||
in
|
in
|
||||||
channel // {
|
channel // {
|
||||||
rust = channel.rust.override { extensions = [ "rust-src" ]; };
|
rust = channel.rust.override { extensions = [ "rust-src" ]; };
|
||||||
|
Loading…
Reference in New Issue
Block a user