-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathflake.nix
75 lines (67 loc) · 3.22 KB
/
flake.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
{
description = "Discord Bot for all things Lunaro";
inputs = {
nixpkgs.url = "nixpkgs/nixpkgs-unstable";
utils.url = "github:numtide/flake-utils";
rust = {
url = "github:oxalica/rust-overlay";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = { self, nixpkgs, utils, rust }:
utils.lib.eachDefaultSystem (system:
let
pkgs = import nixpkgs {
inherit system;
overlays = [ (import rust) ];
};
ssl-toolchain = with pkgs; [ openssl.dev pkg-config ];
rust-toolchain = with pkgs;
[
(rust-bin.stable.latest.default.override {
extensions = [ "rust-src" ];
})
];
cargoToml = builtins.fromTOML (builtins.readFile ./Cargo.toml);
in with pkgs; {
packages.default = rustPlatform.buildRustPackage {
inherit (cargoToml.package) name version;
src = ./.;
cargoLock.lockFile = ./Cargo.lock;
# https://github.com/sfackler/rust-openssl/issues/1663#issuecomment-1541050597
nativeBuildInputs = lib.optionals stdenv.isLinux [ pkg-config ];
buildInputs = lib.optionals stdenv.isLinux [ openssl openssl.dev ];
OPENSSL_NO_VENDOR = 1;
};
devShells.default = mkShell {
name = "${cargoToml.package.name}-${cargoToml.package.version}";
buildInputs = rust-toolchain ++ ssl-toolchain
++ pkgs.lib.optionals pkgs.stdenv.isDarwin
[ pkgs.darwin.apple_sdk.frameworks.SystemConfiguration ];
shellHook = ''
echo
echo " .... ..=#%#."
echo " .+%@@@# -*@@@@@@:"
echo " :. =@@*@@@+.=++- .#@@=+@@@%."
echo " =%@@# :@@%:-@@@%@@#=. ... :#@@@:.#@@#."
echo " #@@@+ -@@. #@@@%- :=+#%@@@@@%- %@@@%+@@%-"
echo " :=. :. :@@@= :*@@@@%++++*%%* .@@@@@%=."
echo " :=*#%%**+--..-- :=***+=-:. =*- -*%@@@@@%*+=-. :=--"
echo "*%#****%@@@@@@@@=. +%@%*#%@@@@@@#**%# *@@@@@@%%%@@@@@@+."
echo " .-#@@@@@@@%+:. .:+%@@@@@@@*-. . .. :+%@@%."
echo " .@@@@@@@@@@%*=. .=#@@@@@@@%*=: .+@#."
echo " .. .-+%@@@@@@#*=:. .-@#+=*%@@@@@@%*=. -="
echo " .:=#@@@@@@@@@@#. :+%@@@@@@@#=:"
echo " .--+**=-. ..=*%@@@@@%*+-."
echo " :=*%@@@@@%*=-."
echo " .=*%@@@@@@%+:"
echo " .-+#@@@@@@%*=."
echo "The near Moon eclipses the far Sun. .=*%@@@@@@@%*#%*"
echo
echo "- $(rustc --version)"
echo "- $(cargo --version)"
echo
'';
};
});
}