static compilation wiith musl and nix for linux systems
This commit is contained in:
parent
f7c1408cef
commit
efd5df958e
1
.gitignore
vendored
1
.gitignore
vendored
@ -4,3 +4,4 @@
|
|||||||
node_modules
|
node_modules
|
||||||
/target
|
/target
|
||||||
nzz/
|
nzz/
|
||||||
|
result
|
||||||
|
34
flake.lock
34
flake.lock
@ -37,6 +37,25 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"naersk": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs": "nixpkgs_2"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1718727675,
|
||||||
|
"narHash": "sha256-uFsCwWYI2pUpt0awahSBorDUrUfBhaAiyz+BPTS2MHk=",
|
||||||
|
"owner": "nix-community",
|
||||||
|
"repo": "naersk",
|
||||||
|
"rev": "941ce6dc38762a7cfb90b5add223d584feed299b",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "nix-community",
|
||||||
|
"ref": "master",
|
||||||
|
"repo": "naersk",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1719690277,
|
"lastModified": 1719690277,
|
||||||
@ -54,6 +73,18 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nixpkgs_2": {
|
"nixpkgs_2": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 0,
|
||||||
|
"narHash": "sha256-H3+EC5cYuq+gQW8y0lSrrDZfH71LB4DAf+TDFyvwCNA=",
|
||||||
|
"path": "/nix/store/j4jzjbr302cw5bl0n3pch5j9bh5qwmaj-source",
|
||||||
|
"type": "path"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"id": "nixpkgs",
|
||||||
|
"type": "indirect"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"nixpkgs_3": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1719075281,
|
"lastModified": 1719075281,
|
||||||
"narHash": "sha256-CyyxvOwFf12I91PBWz43iGT1kjsf5oi6ax7CrvaMyAo=",
|
"narHash": "sha256-CyyxvOwFf12I91PBWz43iGT1kjsf5oi6ax7CrvaMyAo=",
|
||||||
@ -73,7 +104,8 @@
|
|||||||
"inputs": {
|
"inputs": {
|
||||||
"fenix": "fenix",
|
"fenix": "fenix",
|
||||||
"flake-utils": "flake-utils",
|
"flake-utils": "flake-utils",
|
||||||
"nixpkgs": "nixpkgs_2"
|
"naersk": "naersk",
|
||||||
|
"nixpkgs": "nixpkgs_3"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"rust-analyzer-src": {
|
"rust-analyzer-src": {
|
||||||
|
114
flake.nix
114
flake.nix
@ -1,8 +1,10 @@
|
|||||||
|
# thanks to https://code.betamike.com/micropelago/domani for the flake, I still do not completely understand it :)
|
||||||
{
|
{
|
||||||
description = "little-hesinde project";
|
description = "little-hesinde project";
|
||||||
inputs = {
|
inputs = {
|
||||||
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
||||||
flake-utils.url = "github:numtide/flake-utils";
|
flake-utils.url = "github:numtide/flake-utils";
|
||||||
|
naersk.url = "github:nix-community/naersk/master";
|
||||||
fenix.url = "github:nix-community/fenix";
|
fenix.url = "github:nix-community/fenix";
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -10,14 +12,69 @@
|
|||||||
{
|
{
|
||||||
nixpkgs,
|
nixpkgs,
|
||||||
flake-utils,
|
flake-utils,
|
||||||
|
naersk,
|
||||||
fenix,
|
fenix,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
|
let
|
||||||
|
mkToolchain =
|
||||||
|
fenixPkgs:
|
||||||
|
fenixPkgs.fromToolchainFile {
|
||||||
|
file = ./rust-toolchain.toml;
|
||||||
|
sha256 = "sha256-Ngiz76YP4HTY75GGdH2P+APE/DEIx2R/Dn+BwwOyzZU=";
|
||||||
|
};
|
||||||
|
|
||||||
|
buildTargets = {
|
||||||
|
"x86_64-linux" = {
|
||||||
|
crossSystemConfig = "x86_64-unknown-linux-musl";
|
||||||
|
rustTarget = "x86_64-unknown-linux-musl";
|
||||||
|
};
|
||||||
|
|
||||||
|
"i686-linux" = {
|
||||||
|
crossSystemConfig = "i686-unknown-linux-musl";
|
||||||
|
rustTarget = "i686-unknown-linux-musl";
|
||||||
|
};
|
||||||
|
|
||||||
|
"aarch64-linux" = {
|
||||||
|
crossSystemConfig = "aarch64-unknown-linux-musl";
|
||||||
|
rustTarget = "aarch64-unknown-linux-musl";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
eachSystem =
|
||||||
|
supportedSystems: callback:
|
||||||
|
builtins.foldl' (overall: system: overall // { ${system} = callback system; }) { } supportedSystems;
|
||||||
|
|
||||||
|
eachCrossSystem =
|
||||||
|
supportedSystems: callback:
|
||||||
|
eachSystem supportedSystems (
|
||||||
|
buildSystem:
|
||||||
|
builtins.foldl' (
|
||||||
|
inner: targetSystem: inner // { "cross-${targetSystem}" = callback buildSystem targetSystem; }
|
||||||
|
) { default = callback buildSystem buildSystem; } supportedSystems
|
||||||
|
);
|
||||||
|
|
||||||
|
mkPkgs =
|
||||||
|
buildSystem: targetSystem:
|
||||||
|
import nixpkgs (
|
||||||
|
{
|
||||||
|
system = buildSystem;
|
||||||
|
}
|
||||||
|
// (
|
||||||
|
if targetSystem == null then
|
||||||
|
{ }
|
||||||
|
else
|
||||||
|
{ crossSystem.config = buildTargets.${targetSystem}.crossSystemConfig; }
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
in
|
||||||
flake-utils.lib.eachDefaultSystem (
|
flake-utils.lib.eachDefaultSystem (
|
||||||
system:
|
system:
|
||||||
let
|
let
|
||||||
pkgs = import nixpkgs { inherit system; };
|
pkgs = import nixpkgs { inherit system; };
|
||||||
rust = fenix.packages.${system}.stable;
|
toolchain = mkToolchain fenix.packages.${system};
|
||||||
|
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
devShells.default =
|
devShells.default =
|
||||||
@ -25,11 +82,62 @@
|
|||||||
mkShell {
|
mkShell {
|
||||||
buildInputs = [
|
buildInputs = [
|
||||||
geckodriver
|
geckodriver
|
||||||
rust.toolchain
|
toolchain
|
||||||
cargo-deny
|
cargo-deny
|
||||||
rust-analyzer
|
rust-analyzer
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
);
|
)
|
||||||
|
// {
|
||||||
|
packages = eachCrossSystem (builtins.attrNames buildTargets) (
|
||||||
|
buildSystem: targetSystem:
|
||||||
|
let
|
||||||
|
pkgs = mkPkgs buildSystem null;
|
||||||
|
pkgsCross = mkPkgs buildSystem targetSystem;
|
||||||
|
rustTarget = buildTargets.${targetSystem}.rustTarget;
|
||||||
|
|
||||||
|
fenixPkgs = fenix.packages.${buildSystem};
|
||||||
|
toolchain = mkToolchain fenixPkgs;
|
||||||
|
|
||||||
|
buildPackageAttrs =
|
||||||
|
if builtins.hasAttr "makeBuildPackageAttrs" buildTargets.${targetSystem} then
|
||||||
|
buildTargets.${targetSystem}.makeBuildPackageAttrs pkgsCross
|
||||||
|
else
|
||||||
|
{ };
|
||||||
|
|
||||||
|
naersk-lib = pkgs.callPackage naersk {
|
||||||
|
cargo = toolchain;
|
||||||
|
rustc = toolchain;
|
||||||
|
};
|
||||||
|
|
||||||
|
in
|
||||||
|
naersk-lib.buildPackage (
|
||||||
|
buildPackageAttrs
|
||||||
|
// rec {
|
||||||
|
src = ./.;
|
||||||
|
strictDeps = true;
|
||||||
|
doCheck = false;
|
||||||
|
|
||||||
|
OPENSSL_STATIC = "1";
|
||||||
|
OPENSSL_LIB_DIR = "${pkgsCross.pkgsStatic.openssl.out}/lib";
|
||||||
|
OPENSSL_INCLUDE_DIR = "${pkgsCross.pkgsStatic.openssl.dev}/include";
|
||||||
|
|
||||||
|
# Required because ring crate is special. This also seems to have
|
||||||
|
# fixed some issues with the x86_64-windows cross-compile :shrug:
|
||||||
|
TARGET_CC = "${pkgsCross.stdenv.cc}/bin/${pkgsCross.stdenv.cc.targetPrefix}cc";
|
||||||
|
|
||||||
|
CARGO_BUILD_TARGET = rustTarget;
|
||||||
|
CARGO_BUILD_RUSTFLAGS = [
|
||||||
|
"-C"
|
||||||
|
"target-feature=+crt-static"
|
||||||
|
|
||||||
|
# https://github.com/rust-lang/cargo/issues/4133
|
||||||
|
"-C"
|
||||||
|
"linker=${TARGET_CC}"
|
||||||
|
];
|
||||||
|
}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
4
rust-toolchain.toml
Normal file
4
rust-toolchain.toml
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
[toolchain]
|
||||||
|
channel = "stable"
|
||||||
|
targets = [ "i686-unknown-linux-musl", "aarch64-unknown-linux-musl", "x86_64-unknown-linux-musl" ]
|
||||||
|
profile = "minimal"
|
Loading…
Reference in New Issue
Block a user