Compare commits

..

2 Commits

2 changed files with 19 additions and 8 deletions

View File

@ -7,6 +7,11 @@
path = ./templates/rust/workspace;
description = "Cargo based rust project using a virtual workspace";
};
rust-lib = {
path = ./templates/rust/crate-lib;
description = "Cargo based rust library crate";
};
};
};
}

View File

@ -3,34 +3,40 @@
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
rust-overlay.url = "github:oxalica/rust-overlay";
rust-overlay = {
url = "github:oxalica/rust-overlay";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = { nixpkgs, rust-overlay, ... }:
let
system = "x86_64-linux";
overlays = [ (import rust-overlay) ];
pkgs = import nixpkgs {
inherit system;
overlays = [ (import rust-overlay) ];
inherit system overlays;
};
rustToolchain = pkgs.rust-bin.fromRustupToolchainFile ./rust-toolchain.toml;
rustNightlyToolchain = pkgs.rust-bin.selectLatestNightlyWith (toolchain: toolchain.minimal.override {
rust = pkgs.rust-bin;
rustToolchain = rust.fromRustupToolchainFile ./rust-toolchain.toml;
rustNightlyToolchain = rust.selectLatestNightlyWith (tc: tc.minimal.override {
extensions = [ "rustfmt" ];
targets = [ "x86_64-unknown-linux-gnu" ];
});
buildTools = with pkgs; [
buildTools = [
rustToolchain
rustNightlyToolchain
pkg-config
];
devShell = pkgs.mkShell {
name = "@project_name@";
buildInputs = buildTools;
packages = with pkgs; [
rust-analyzer
];
};
in {
devShells.${system}.default = devShell;