From 037774f1a8e0f5265c23659173495986ae1be557 Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Tue, 12 Sep 2023 13:16:36 -0700 Subject: [PATCH 01/11] chore(nix): Reduce nix to building final rust & wasm packages --- flake.lock | 24 ---- flake.nix | 360 ++++++++++++++++------------------------------------- 2 files changed, 104 insertions(+), 280 deletions(-) diff --git a/flake.lock b/flake.lock index 659daec5d3a..465d56c0838 100644 --- a/flake.lock +++ b/flake.lock @@ -1,28 +1,5 @@ { "nodes": { - "barretenberg": { - "inputs": { - "flake-utils": [ - "flake-utils" - ], - "nixpkgs": [ - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1688820427, - "narHash": "sha256-w7yMeYp50KrlTn23TTKfYmLOQL4uIgw0wSX67v2tvvc=", - "owner": "AztecProtocol", - "repo": "barretenberg", - "rev": "fdd46f77531a6fcc9d9b24a698c56590d54d487e", - "type": "github" - }, - "original": { - "owner": "AztecProtocol", - "repo": "barretenberg", - "type": "github" - } - }, "crane": { "inputs": { "flake-compat": [ @@ -104,7 +81,6 @@ }, "root": { "inputs": { - "barretenberg": "barretenberg", "crane": "crane", "flake-compat": "flake-compat", "flake-utils": "flake-utils", diff --git a/flake.nix b/flake.nix index 94e9f233924..25928ba7614 100644 --- a/flake.nix +++ b/flake.nix @@ -36,31 +36,22 @@ rust-overlay.follows = "rust-overlay"; }; }; - - barretenberg = { - url = "github:AztecProtocol/barretenberg"; - # All of these inputs (a.k.a. dependencies) need to align with inputs we - # use so they use the `inputs.*.follows` syntax to reference our inputs - inputs = { - nixpkgs.follows = "nixpkgs"; - flake-utils.follows = "flake-utils"; - }; - }; }; outputs = - { self, nixpkgs, crane, flake-utils, rust-overlay, barretenberg, ... }: + { self, nixpkgs, crane, flake-utils, rust-overlay, ... }: flake-utils.lib.eachDefaultSystem (system: let pkgs = import nixpkgs { inherit system; overlays = [ rust-overlay.overlays.default - barretenberg.overlays.default ]; }; - rustToolchain = pkgs.rust-bin.stable."1.66.0".default.override { + rustVersion = "1.66.1"; + + rustToolchain = pkgs.rust-bin.stable.${rustVersion}.default.override { # We include rust-src to ensure rust-analyzer works. # See https://discourse.nixos.org/t/rust-src-not-found-and-other-misadventures-of-developing-rust-on-nixos/11570/4 extensions = [ "rust-src" ]; @@ -73,73 +64,39 @@ craneLib = (crane.mkLib pkgs).overrideToolchain rustToolchain; - sharedEnvironment = { - # We enable backtraces on any failure for help with debugging - RUST_BACKTRACE = "1"; - - BARRETENBERG_ARCHIVE = builtins.fetchurl { - url = "https://github.com/AztecProtocol/barretenberg/releases/download/barretenberg-v0.4.5/acvm_backend.wasm.tar.gz"; - sha256 = "sha256:0z24yhvxc0dr13xj7y4xs9p42lzxwpazrmsrdpcgynfajkk6vqy4"; - }; - }; - - nativeEnvironment = sharedEnvironment // { - # rust-bindgen needs to know the location of libclang - LIBCLANG_PATH = "${pkgs.llvmPackages.libclang.lib}/lib"; - }; - - wasmEnvironment = sharedEnvironment // { - # We set the environment variable because barretenberg must be compiled in a special way for wasm - BARRETENBERG_BIN_DIR = "${pkgs.barretenberg-wasm}/bin"; - }; - - testEnvironment = sharedEnvironment // { }; - # The `self.rev` property is only available when the working tree is not dirty GIT_COMMIT = if (self ? rev) then self.rev else "unknown"; GIT_DIRTY = if (self ? rev) then "false" else "true"; - # We use `include_str!` macro to embed the solidity verifier template so we need to create a special - # source filter to include .sol files in addition to usual rust/cargo source files. - solidityFilter = path: _type: builtins.match ".*sol$" path != null; - # We use `.bytecode` and `.tr` files to test interactions with `bb` so we add a source filter to include these. - bytecodeFilter = path: _type: builtins.match ".*bytecode$" path != null; - witnessFilter = path: _type: builtins.match ".*tr$" path != null; - # We use `.nr` and `.toml` files in tests so we need to create a special source - # filter to include those files in addition to usual rust/cargo source files - noirFilter = path: _type: builtins.match ".*nr$" path != null; - tomlFilter = path: _type: builtins.match ".*toml$" path != null; - sourceFilter = path: type: - (solidityFilter path type) || (bytecodeFilter path type)|| (witnessFilter path type) || (noirFilter path type) || (tomlFilter path type) || (craneLib.filterCargoSources path type); - - # As per https://discourse.nixos.org/t/gcc11stdenv-and-clang/17734/7 since it seems that aarch64-linux uses - # gcc9 instead of gcc11 for the C++ stdlib, while all other targets we support provide the correct libstdc++ - stdenv = - if (pkgs.stdenv.targetPlatform.isGnu && pkgs.stdenv.targetPlatform.isAarch64) then - pkgs.overrideCC pkgs.llvmPackages.stdenv (pkgs.llvmPackages.clang.override { gccForLibs = pkgs.gcc11.cc; }) - else - pkgs.llvmPackages.stdenv; - - extraBuildInputs = pkgs.lib.optionals pkgs.stdenv.isDarwin [ + extraBuildInputs = [ ] ++ pkgs.lib.optionals pkgs.stdenv.isDarwin [ # Need libiconv and apple Security on Darwin. See https://github.com/ipetkov/crane/issues/156 pkgs.libiconv pkgs.darwin.apple_sdk.frameworks.Security - ] ++ [ - # Need to install various packages used by the `bb` binary. - pkgs.curl - stdenv.cc.cc.lib - pkgs.gcc.cc.lib - pkgs.gzip ]; - sharedArgs = { + environment = { + # We enable backtraces on any failure for help with debugging + RUST_BACKTRACE = "1"; + + # We download the Wasm version of `acvm_backend` in the barretenberg releases for the ACVM `blackbox_solver` + BARRETENBERG_ARCHIVE = pkgs.fetchurl { + url = "https://github.com/AztecProtocol/barretenberg/releases/download/barretenberg-v0.4.5/acvm_backend.wasm.tar.gz"; + sha256 = "sha256-xONt5pTKWf/YbVnX/NXl/VNBbtKd+CP7CLkB1jf0RHw="; + }; + }; + + # Configuration shared between builds + config = { # x-release-please-start-version version = "0.11.1"; # x-release-please-end src = pkgs.lib.cleanSourceWith { src = craneLib.path ./.; - filter = sourceFilter; + # Custom filter with various file extensions that we rely upon to build packages + # Currently: `.nr`, `.sol`, `.sh`, `.json`, `.md` + filter = path: type: + (builtins.match ".*\.(nr|sol|sh|json|md)$" path != null) || (craneLib.filterCargoSources path type); }; # TODO(#1198): It'd be nice to include these flags when running `cargo clippy` in a devShell. @@ -150,130 +107,90 @@ }; # Combine the environment and other configuration needed for crane to build our Rust packages - nativeArgs = nativeEnvironment // sharedArgs // { - pname = "noir-native"; - - # Use our custom stdenv to build and test our Rust project - inherit stdenv; - - nativeBuildInputs = [ - # This provides the pkg-config tool to find barretenberg & other native libraries - pkgs.pkg-config - # This provides the `lld` linker to cargo - pkgs.llvmPackages.bintools - ] ++ pkgs.lib.optionals stdenv.isLinux [ - # This is linux specific and used to patch the rpath and interpreter of the bb binary - pkgs.patchelf - ]; + nativeConfig = environment // config // { + nativeBuildInputs = [ ]; - buildInputs = [ - ] ++ extraBuildInputs; + buildInputs = [ ] ++ extraBuildInputs; }; # Combine the environmnet with cargo args needed to build wasm package - noirWasmArgs = sharedEnvironment // sharedArgs // { - pname = "noir_wasm"; - - src = ./.; + wasmConfig = environment // config // rec { + CARGO_TARGET_DIR = "./target"; - cargoExtraArgs = "--package noir_wasm --target wasm32-unknown-unknown"; + nativeBuildInputs = with pkgs; [ + which + git + jq + rustToolchain + wasm-bindgen-cli + binaryen + toml2json + ]; buildInputs = [ ] ++ extraBuildInputs; - - doCheck = false; }; - # Combine the environment with cargo args needed to build wasm package - noirc_abi_WasmArgs = sharedEnvironment // sharedArgs // { + # Build *just* the cargo dependencies, so we can reuse all of that work between runs + native-cargo-artifacts = craneLib.buildDepsOnly (nativeConfig // { + pname = "nargo"; + }); + noir-wasm-cargo-artifacts = craneLib.buildDepsOnly (wasmConfig // { + pname = "noir_wasm"; + }); + noirc-abi-wasm-cargo-artifacts = craneLib.buildDepsOnly (wasmConfig // { pname = "noirc_abi_wasm"; + }); - src = ./.; + nargo = craneLib.buildPackage (nativeConfig // { + pname = "nargo"; - cargoExtraArgs = "--package noirc_abi_wasm --target wasm32-unknown-unknown"; + inherit GIT_COMMIT GIT_DIRTY; - buildInputs = [ ] ++ extraBuildInputs; + cargoArtifacts = native-cargo-artifacts; + # We don't want to run tests because they don't work in the Nix sandbox doCheck = false; - }; - - # Conditionally download the binary based on whether it is linux or mac - bb_binary = let - platformSpecificUrl = if stdenv.hostPlatform.isLinux then - "https://github.com/AztecProtocol/barretenberg/releases/download/barretenberg-v0.4.3/bb-ubuntu.tar.gz" - else if stdenv.hostPlatform.isDarwin then - "https://github.com/AztecProtocol/barretenberg/releases/download/barretenberg-v0.4.3/barretenberg-x86_64-apple-darwin.tar.gz" - else - throw "Unsupported platform"; - - platformSpecificHash = if stdenv.hostPlatform.isLinux then - "sha256:0rcsjws87f4v28cw9734c10pg7c49apigf4lg3m0ji5vbhhmfnhr" - else if stdenv.hostPlatform.isDarwin then - "sha256:0pnsd56z0vkai7m0advawfgcvq9jbnpqm7lk98n5flqj583x3w35" - else - throw "Unsupported platform"; - in builtins.fetchurl { - url = platformSpecificUrl; - sha256 = platformSpecificHash; - }; + }); - # The `port` is parameterized to support parallel test runs without colliding static servers - testArgs = port: testEnvironment // { - BB_BINARY_PATH = "/tmp/backend_binary"; - - BB_BINARY_URL = "http://0.0.0.0:${toString port}/${builtins.baseNameOf bb_binary}"; - - # We provide `barretenberg-transcript00` from the overlay to the tests as a URL hosted via a static server - # This is necessary because the Nix sandbox has no network access and downloading during tests would fail - BARRETENBERG_TRANSCRIPT_URL = "http://0.0.0.0:${toString port}/${builtins.baseNameOf pkgs.barretenberg-transcript00}"; - - # This copies the `barretenberg-transcript00` from the Nix store into this sandbox - # which avoids exposing the entire Nix store to the static server it starts - # The static server is moved to the background and killed after checks are completed - # - # We also set the NARGO_BACKEND_CACHE_DIR environment variable to the $TMP directory so we can successfully cache - # the transcript; which isn't possible with the default path because the Nix sandbox disabled $HOME - preCheck = '' - echo "Extracting bb binary" - mkdir extracted - tar -xf ${bb_binary} -C extracted - - # Conditionally patch the binary for Linux - ${if stdenv.hostPlatform.isLinux then '' - - cp extracted/cpp/build/bin/bb /tmp/backend_binary - - echo "Patching bb binary for Linux" - patchelf --set-rpath "${stdenv.cc.cc.lib}/lib:${pkgs.gcc.cc.lib}/lib" /tmp/backend_binary - patchelf --set-interpreter ${stdenv.cc.libc}/lib/ld-linux-x86-64.so.2 /tmp/backend_binary - '' else if stdenv.hostPlatform.isDarwin then '' - cp extracted/bb /tmp/backend_binary - '' else - throw "Unsupported platform" - } - - export NARGO_BACKEND_CACHE_DIR=$TMP - cp ${pkgs.barretenberg-transcript00} . - echo "Starting simple static server" - ${pkgs.simple-http-server}/bin/simple-http-server --port ${toString port} --silent & - HTTP_SERVER_PID=$! + noir_wasm = craneLib.buildPackage (wasmConfig // rec { + pname = "noir_wasm"; + + inherit GIT_COMMIT GIT_DIRTY; + + cargoArtifacts = noir-wasm-cargo-artifacts; + + cargoExtraArgs = "--package ${pname} --target wasm32-unknown-unknown"; + + buildPhaseCargoCommand = '' + bash compiler/wasm/buildPhaseCargoCommand.sh release ''; - postCheck = '' - kill $HTTP_SERVER_PID + installPhase = '' + bash compiler/wasm/installPhase.sh ''; - }; - # Build *just* the cargo dependencies, so we can reuse all of that work between runs - native-cargo-artifacts = craneLib.buildDepsOnly nativeArgs; - noir-wasm-cargo-artifacts = craneLib.buildDepsOnly noirWasmArgs; - noirc-abi-wasm-cargo-artifacts = craneLib.buildDepsOnly noirc_abi_WasmArgs; + # We don't want to run tests because they don't work in the Nix sandbox + doCheck = false; + }); + + noirc_abi_wasm = craneLib.buildPackage (wasmConfig // rec { + pname = "noirc_abi_wasm"; - noir-native = craneLib.buildPackage (nativeArgs // { inherit GIT_COMMIT GIT_DIRTY; - cargoArtifacts = native-cargo-artifacts; + cargoArtifacts = noirc-abi-wasm-cargo-artifacts; - # We don't want to run checks or tests when just building the project + cargoExtraArgs = "--package ${pname} --target wasm32-unknown-unknown"; + + buildPhaseCargoCommand = '' + bash tooling/noirc_abi_wasm/buildPhaseCargoCommand.sh release + ''; + + installPhase = '' + bash tooling/noirc_abi_wasm/installPhase.sh + ''; + + # We don't want to run tests because they don't work in the Nix sandbox doCheck = false; }); @@ -284,32 +201,33 @@ }; }; in - rec { + { + # We use `checks` to run `cargo clippy` and `cargo fmt` since we disable checks in the primary derivations checks = { - cargo-clippy = craneLib.cargoClippy (nativeArgs // { - inherit GIT_COMMIT GIT_DIRTY; + cargo-clippy = craneLib.cargoClippy (nativeConfig // { + pname = "noir"; - cargoArtifacts = native-cargo-artifacts; - }); - - cargo-fmt = craneLib.cargoFmt (nativeArgs // { inherit GIT_COMMIT GIT_DIRTY; cargoArtifacts = native-cargo-artifacts; - doCheck = true; }); - cargo-test = craneLib.cargoTest (nativeArgs // (testArgs 8000) // { + cargo-fmt = craneLib.cargoFmt (nativeConfig // { + pname = "noir"; + inherit GIT_COMMIT GIT_DIRTY; cargoArtifacts = native-cargo-artifacts; + doCheck = true; }); }; packages = { - default = noir-native; + default = nargo; - inherit noir-native; + inherit nargo; + inherit noir_wasm; + inherit noirc_abi_wasm; # We expose the `*-cargo-artifacts` derivations so we can cache our cargo dependencies in CI inherit native-cargo-artifacts; @@ -317,16 +235,18 @@ inherit noirc-abi-wasm-cargo-artifacts; }; - # TODO(#1197): Look into installable apps with Nix flakes - # apps.default = flake-utils.lib.mkApp { drv = nargo; }; - - # Setup the environment to match the stdenv from `nix build` & `nix flake check`, and - # combine it with the environment settings, the inputs from our checks derivations, + # Setup the environment to match the environment settings, the inputs from our checks derivations, # and extra tooling via `nativeBuildInputs` - devShells.default = pkgs.mkShell.override { inherit stdenv; } (nativeEnvironment // wasmEnvironment // testEnvironment // { + devShells.default = pkgs.mkShell (environment // { inputsFrom = builtins.attrValues checks; + # Additional tools that weren't included as `nativeBuildInputs` of any of the derivations in `inputsFrom` nativeBuildInputs = with pkgs; [ + # Need to install various packages used by the `bb` binary. + # pkgs.curl + # stdenv.cc.cc.lib + # pkgs.gcc.cc.lib + # pkgs.gzip curl gzip which @@ -340,88 +260,16 @@ jq binaryen yarn - # rust-bin.stable."1.66.1".default - rustToolchain + rust-bin.stable.${rustVersion}.default rust-analyzer rustup - nodejs-18_x + nodejs-18_x ]; shellHook = '' eval "$(starship init bash)" ''; }); - - # TODO: This fails with a "section too large" error on MacOS so we should limit to linux targets - # or fix the failure - packages.wasm = craneLib.buildPackage (noirWasmArgs // { - - inherit GIT_COMMIT; - inherit GIT_DIRTY; - doCheck = false; - - cargoArtifacts = noir-wasm-cargo-artifacts; - - COMMIT_SHORT = builtins.substring 0 7 GIT_COMMIT; - VERSION_APPENDIX = if GIT_DIRTY == "true" then "-dirty" else ""; - PKG_PATH = "./pkg"; - CARGO_TARGET_DIR = "./target"; - - nativeBuildInputs = with pkgs; [ - which - git - jq - rustToolchain - wasm-bindgen-cli - binaryen - toml2json - ]; - - buildPhaseCargoCommand = '' - bash compiler/wasm/buildPhaseCargoCommand.sh release - ''; - - installPhase = '' - bash compiler/wasm/installPhase.sh - ''; - - }); - - # TODO: This fails with a "section too large" error on MacOS so we should limit to linux targets - # or fix the failure - packages.noirc_abi_wasm = craneLib.buildPackage (noirc_abi_WasmArgs // { - - inherit GIT_COMMIT; - inherit GIT_DIRTY; - doCheck = false; - - cargoArtifacts = noirc-abi-wasm-cargo-artifacts; - - COMMIT_SHORT = builtins.substring 0 7 GIT_COMMIT; - VERSION_APPENDIX = if GIT_DIRTY == "true" then "-dirty" else ""; - PKG_PATH = "./pkg"; - CARGO_TARGET_DIR = "./target"; - - nativeBuildInputs = with pkgs; [ - which - git - jq - rustToolchain - wasm-bindgen-cli - binaryen - toml2json - ]; - - buildPhaseCargoCommand = '' - bash tooling/noirc_abi_wasm/buildPhaseCargoCommand.sh release - ''; - - installPhase = '' - bash tooling/noirc_abi_wasm/installPhase.sh - ''; - - }); - }); } From 25270e955077dac75aba600601c1b8a588ab3096 Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Tue, 12 Sep 2023 15:23:05 -0700 Subject: [PATCH 02/11] chore(nix): Switch to Fenix and provide a rust-toolchain file --- flake.lock | 54 ++++++++++++++++++++++++++++----- flake.nix | 71 ++++++++++++++++---------------------------- rust-toolchain.toml | 5 ++++ wasm-bindgen-cli.nix | 10 +++++-- 4 files changed, 85 insertions(+), 55 deletions(-) create mode 100644 rust-toolchain.toml diff --git a/flake.lock b/flake.lock index 465d56c0838..e779473f0ec 100644 --- a/flake.lock +++ b/flake.lock @@ -11,9 +11,7 @@ "nixpkgs": [ "nixpkgs" ], - "rust-overlay": [ - "rust-overlay" - ] + "rust-overlay": "rust-overlay" }, "locked": { "lastModified": 1681177078, @@ -29,6 +27,27 @@ "type": "github" } }, + "fenix": { + "inputs": { + "nixpkgs": [ + "nixpkgs" + ], + "rust-analyzer-src": "rust-analyzer-src" + }, + "locked": { + "lastModified": 1694499657, + "narHash": "sha256-u/fZtLtN7VcDrMMVrdsFy93PEkaiK+tNpJT9on4SGdU=", + "owner": "nix-community", + "repo": "fenix", + "rev": "2895ff377cbb3cb6f5dd92066734b0447cb04e20", + "type": "github" + }, + "original": { + "owner": "nix-community", + "repo": "fenix", + "type": "github" + } + }, "flake-compat": { "flake": false, "locked": { @@ -82,27 +101,46 @@ "root": { "inputs": { "crane": "crane", + "fenix": "fenix", "flake-compat": "flake-compat", "flake-utils": "flake-utils", - "nixpkgs": "nixpkgs", - "rust-overlay": "rust-overlay" + "nixpkgs": "nixpkgs" + } + }, + "rust-analyzer-src": { + "flake": false, + "locked": { + "lastModified": 1694421477, + "narHash": "sha256-df6YZzR57VFzkOPwIohJfC0fRwgq6yUPbMJkKAtQyAE=", + "owner": "rust-lang", + "repo": "rust-analyzer", + "rev": "cc6c8209cbaf7df55013977cf5cc8488d6b7ff1c", + "type": "github" + }, + "original": { + "owner": "rust-lang", + "ref": "nightly", + "repo": "rust-analyzer", + "type": "github" } }, "rust-overlay": { "inputs": { "flake-utils": [ + "crane", "flake-utils" ], "nixpkgs": [ + "crane", "nixpkgs" ] }, "locked": { - "lastModified": 1681352318, - "narHash": "sha256-+kwy7bTsuW8GYrRqWRQ8T5hg6duZb5IJiHlKo1J+v9g=", + "lastModified": 1694484610, + "narHash": "sha256-aeSDkp7fkAqtVjW3QUn7vq7BKNlFul/BiGgdv7rK+mA=", "owner": "oxalica", "repo": "rust-overlay", - "rev": "aeaa11c65a5c5cebaa51652353ab3c497b9a7bbf", + "rev": "c5b977a7e6a295697fa1f9c42174fd6313b38df4", "type": "github" }, "original": { diff --git a/flake.nix b/flake.nix index 25928ba7614..3f0c1f9a8a7 100644 --- a/flake.nix +++ b/flake.nix @@ -1,6 +1,8 @@ { description = "Build the Noir programming language"; + # All of these inputs (a.k.a. dependencies) need to align with inputs we + # use so they use the `inputs.*.follows` syntax to reference our inputs inputs = { nixpkgs = { url = "github:NixOS/nixpkgs/nixos-22.11"; @@ -15,51 +17,34 @@ flake = false; }; - rust-overlay = { - url = "github:oxalica/rust-overlay"; - # All of these inputs (a.k.a. dependencies) need to align with inputs we - # use so they use the `inputs.*.follows` syntax to reference our inputs + fenix = { + url = "github:nix-community/fenix"; inputs = { nixpkgs.follows = "nixpkgs"; - flake-utils.follows = "flake-utils"; }; }; crane = { url = "github:ipetkov/crane"; - # All of these inputs (a.k.a. dependencies) need to align with inputs we - # use so they use the `inputs.*.follows` syntax to reference our inputs inputs = { nixpkgs.follows = "nixpkgs"; flake-utils.follows = "flake-utils"; flake-compat.follows = "flake-compat"; - rust-overlay.follows = "rust-overlay"; }; }; }; outputs = - { self, nixpkgs, crane, flake-utils, rust-overlay, ... }: + { self, nixpkgs, crane, flake-utils, fenix, ... }: flake-utils.lib.eachDefaultSystem (system: let pkgs = import nixpkgs { inherit system; - overlays = [ - rust-overlay.overlays.default - ]; }; - rustVersion = "1.66.1"; - - rustToolchain = pkgs.rust-bin.stable.${rustVersion}.default.override { - # We include rust-src to ensure rust-analyzer works. - # See https://discourse.nixos.org/t/rust-src-not-found-and-other-misadventures-of-developing-rust-on-nixos/11570/4 - extensions = [ "rust-src" ]; - targets = [ "wasm32-unknown-unknown" ] - ++ pkgs.lib.optional (pkgs.hostPlatform.isx86_64 && pkgs.hostPlatform.isLinux) "x86_64-unknown-linux-gnu" - ++ pkgs.lib.optional (pkgs.hostPlatform.isAarch64 && pkgs.hostPlatform.isLinux) "aarch64-unknown-linux-gnu" - ++ pkgs.lib.optional (pkgs.hostPlatform.isx86_64 && pkgs.hostPlatform.isDarwin) "x86_64-apple-darwin" - ++ pkgs.lib.optional (pkgs.hostPlatform.isAarch64 && pkgs.hostPlatform.isDarwin) "aarch64-apple-darwin"; + rustToolchain = fenix.packages.${system}.fromToolchainFile { + file = ./rust-toolchain.toml; + sha256 = "sha256-Zk2rxv6vwKFkTTidgjPm6gDsseVmmljVt201H7zuDkk="; }; craneLib = (crane.mkLib pkgs).overrideToolchain rustToolchain; @@ -106,15 +91,15 @@ cargoTestExtraArgs = "--workspace"; }; - # Combine the environment and other configuration needed for crane to build our Rust packages + # Combine the environment and other configuration needed for Crane to build our Rust packages nativeConfig = environment // config // { nativeBuildInputs = [ ]; buildInputs = [ ] ++ extraBuildInputs; }; - # Combine the environmnet with cargo args needed to build wasm package - wasmConfig = environment // config // rec { + # Combine the environmnet and other configuration needed for Crane to build our Wasm packages + wasmConfig = environment // config // { CARGO_TARGET_DIR = "./target"; nativeBuildInputs = with pkgs; [ @@ -238,32 +223,28 @@ # Setup the environment to match the environment settings, the inputs from our checks derivations, # and extra tooling via `nativeBuildInputs` devShells.default = pkgs.mkShell (environment // { - inputsFrom = builtins.attrValues checks; + inputsFrom = [ + nargo + noir_wasm + noirc_abi_wasm + ]; # Additional tools that weren't included as `nativeBuildInputs` of any of the derivations in `inputsFrom` nativeBuildInputs = with pkgs; [ - # Need to install various packages used by the `bb` binary. - # pkgs.curl - # stdenv.cc.cc.lib - # pkgs.gcc.cc.lib - # pkgs.gzip + # Rust toolchain + rustToolchain + # Other tools + starship + yarn + nodejs-18_x + # Used by the `bb` binary curl gzip - which - starship - git + # This ensures the right lldb is in the environment for running rust-lldb + llvmPackages.lldb + # Nix tools nil nixpkgs-fmt - toml2json - llvmPackages.lldb # This ensures the right lldb is in the environment for running rust-lldb - wasm-bindgen-cli - jq - binaryen - yarn - rust-bin.stable.${rustVersion}.default - rust-analyzer - rustup - nodejs-18_x ]; shellHook = '' diff --git a/rust-toolchain.toml b/rust-toolchain.toml new file mode 100644 index 00000000000..fd86146385a --- /dev/null +++ b/rust-toolchain.toml @@ -0,0 +1,5 @@ +[toolchain] +channel = "1.66.1" +components = [ "rust-src" ] +targets = [ "wasm32-unknown-unknown" ] +profile = "default" diff --git a/wasm-bindgen-cli.nix b/wasm-bindgen-cli.nix index 38b7b0a79c1..7c3910f032e 100644 --- a/wasm-bindgen-cli.nix +++ b/wasm-bindgen-cli.nix @@ -7,6 +7,7 @@ , stdenv , curl , darwin +, libiconv , runCommand }: @@ -23,7 +24,12 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.isDarwin [ curl darwin.apple_sdk.frameworks.Security ]; + buildInputs = [ openssl ] ++ lib.optionals stdenv.isDarwin [ + curl + # Need libiconv and apple Security on Darwin. See https://github.com/ipetkov/crane/issues/156 + libiconv + darwin.apple_sdk.frameworks.Security + ]; doCheck = false; @@ -34,4 +40,4 @@ rustPlatform.buildRustPackage rec { maintainers = with maintainers; [ nitsky rizary ]; mainProgram = "wasm-bindgen"; }; -} \ No newline at end of file +} From d1fae3b94a1e5458784c7daffb10168d1b9ee0eb Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Tue, 12 Sep 2023 15:24:27 -0700 Subject: [PATCH 03/11] chore(nix): Build all derivations by default --- .github/workflows/test-integration.yml | 4 ++-- compiler/wasm/installPhase.sh | 12 +++++++----- flake.nix | 6 ++++-- tooling/noirc_abi_wasm/installPhase.sh | 12 +++++++----- tooling/noirc_abi_wasm/test/node/abi_encode.test.ts | 2 +- 5 files changed, 21 insertions(+), 15 deletions(-) diff --git a/.github/workflows/test-integration.yml b/.github/workflows/test-integration.yml index 736429a37d2..af409e23cd0 100644 --- a/.github/workflows/test-integration.yml +++ b/.github/workflows/test-integration.yml @@ -87,8 +87,8 @@ jobs: - name: Run `integration-tests` run: | yarn test:integration - - - name: Alert on nightly test failure + + - name: Alert on nightly test failure uses: JasonEtco/create-an-issue@v2 if: ${{ failure() && github.event_name == 'schedule' }} env: diff --git a/compiler/wasm/installPhase.sh b/compiler/wasm/installPhase.sh index a71b3f8cd0e..e5be98a3339 100755 --- a/compiler/wasm/installPhase.sh +++ b/compiler/wasm/installPhase.sh @@ -1,8 +1,10 @@ #!/usr/bin/env bash export self_path=$(dirname "$(readlink -f "$0")") -mkdir -p $out -cp $self_path/README.md $out/ -cp $self_path/package.json $out/ -cp -r $self_path/nodejs $out/ -cp -r $self_path/web $out/ +export out_path=$out/noir_wasm + +mkdir -p $out_path +cp $self_path/README.md $out_path/ +cp $self_path/package.json $out_path/ +cp -r $self_path/nodejs $out_path/ +cp -r $self_path/web $out_path/ diff --git a/flake.nix b/flake.nix index 3f0c1f9a8a7..5bfc9e22732 100644 --- a/flake.nix +++ b/flake.nix @@ -203,13 +203,15 @@ inherit GIT_COMMIT GIT_DIRTY; cargoArtifacts = native-cargo-artifacts; - doCheck = true; }); }; packages = { - default = nargo; + # Nix flakes cannot build more than one derivation in one command (see https://github.com/NixOS/nix/issues/5591) + # so we use `symlinkJoin` to build everything as our default package. + default = pkgs.symlinkJoin { name = "noir"; paths = [ nargo noir_wasm noirc_abi_wasm ]; }; + # We also export individual packages to enable `nix build .#nargo -L`, etc. inherit nargo; inherit noir_wasm; inherit noirc_abi_wasm; diff --git a/tooling/noirc_abi_wasm/installPhase.sh b/tooling/noirc_abi_wasm/installPhase.sh index a71b3f8cd0e..d9b94f2d171 100755 --- a/tooling/noirc_abi_wasm/installPhase.sh +++ b/tooling/noirc_abi_wasm/installPhase.sh @@ -1,8 +1,10 @@ #!/usr/bin/env bash export self_path=$(dirname "$(readlink -f "$0")") -mkdir -p $out -cp $self_path/README.md $out/ -cp $self_path/package.json $out/ -cp -r $self_path/nodejs $out/ -cp -r $self_path/web $out/ +export out_path=$out/noirc_abi_wasm + +mkdir -p $out_path +cp $self_path/README.md $out_path/ +cp $self_path/package.json $out_path/ +cp -r $self_path/nodejs $out_path/ +cp -r $self_path/web $out_path/ diff --git a/tooling/noirc_abi_wasm/test/node/abi_encode.test.ts b/tooling/noirc_abi_wasm/test/node/abi_encode.test.ts index 1328967676d..8a3b6fe9ffc 100644 --- a/tooling/noirc_abi_wasm/test/node/abi_encode.test.ts +++ b/tooling/noirc_abi_wasm/test/node/abi_encode.test.ts @@ -16,4 +16,4 @@ it("recovers original inputs when abi encoding and decoding", async () => { BigInt(inputs.bar[1]) ); expect(decoded_inputs.return_value).to.be.null; -}); \ No newline at end of file +}); From 4550a6895d6113ff5c8ab51ac88f866669bb419b Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Wed, 13 Sep 2023 11:02:39 -0700 Subject: [PATCH 04/11] update wasm refs to noir_wasm --- .github/workflows/test-integration.yml | 2 +- .github/workflows/wasm.yml | 4 ++-- compiler/wasm/README.md | 4 ++-- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/.github/workflows/test-integration.yml b/.github/workflows/test-integration.yml index af409e23cd0..cb4924e57e6 100644 --- a/.github/workflows/test-integration.yml +++ b/.github/workflows/test-integration.yml @@ -51,7 +51,7 @@ jobs: - name: Build noir_wasm package run: | - nix build -L .#wasm + nix build -L .#noir_wasm echo "UPLOAD_PATH=$(readlink -f result)" >> $GITHUB_ENV cp -r ./result/nodejs ./compiler/wasm cp -r ./result/web ./compiler/wasm diff --git a/.github/workflows/wasm.yml b/.github/workflows/wasm.yml index f7b36738482..e12a7ac5173 100644 --- a/.github/workflows/wasm.yml +++ b/.github/workflows/wasm.yml @@ -17,7 +17,7 @@ jobs: strategy: matrix: target: [x86_64-unknown-linux-gnu] - + steps: - name: Checkout Noir repo uses: actions/checkout@v4 @@ -81,7 +81,7 @@ jobs: - name: Build wasm package run: | - nix build -L .#wasm + nix build -L .#noir_wasm - name: Export cache from nix store if: ${{ steps.cache.outputs.cache-hit != 'true' && github.event_name != 'merge_group' }} diff --git a/compiler/wasm/README.md b/compiler/wasm/README.md index c5e8d54a836..0b2d92b0815 100644 --- a/compiler/wasm/README.md +++ b/compiler/wasm/README.md @@ -9,11 +9,11 @@ The package also handles dependency management like how Nargo (Noir's CLI tool) Outside of the [noir repo](https://github.com/noir-lang/noir), this package can be built using the command below: ```bash -nix build -L github:noir-lang/noir/master#wasm +nix build -L github:noir-lang/noir/master#noir_wasm ``` If you are within the noir repo and would like to build local changes, you can use: ```bash -nix build -L #wasm +nix build -L #noir_wasm ``` From a74f66c1a0b880219141ca48d31704c4962bc9cd Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Wed, 13 Sep 2023 11:17:14 -0700 Subject: [PATCH 05/11] add aarch64 target --- rust-toolchain.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/rust-toolchain.toml b/rust-toolchain.toml index fd86146385a..870d0089548 100644 --- a/rust-toolchain.toml +++ b/rust-toolchain.toml @@ -1,5 +1,5 @@ [toolchain] channel = "1.66.1" components = [ "rust-src" ] -targets = [ "wasm32-unknown-unknown" ] +targets = [ "wasm32-unknown-unknown", "aarch64-apple-darwin" ] profile = "default" From 619aa3c4251a5fa6ee35d1ceb789a3fd2e9481a4 Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Wed, 13 Sep 2023 15:56:05 -0700 Subject: [PATCH 06/11] more wasm paths --- .github/workflows/abi_wasm.yml | 2 +- .github/workflows/publish-abi_wasm.yml | 2 +- .github/workflows/test-integration.yml | 12 ++++++------ .github/workflows/wasm.yml | 2 +- 4 files changed, 9 insertions(+), 9 deletions(-) diff --git a/.github/workflows/abi_wasm.yml b/.github/workflows/abi_wasm.yml index 8f219a77977..4585e7cf881 100644 --- a/.github/workflows/abi_wasm.yml +++ b/.github/workflows/abi_wasm.yml @@ -63,7 +63,7 @@ jobs: key: ${{ steps.cache.outputs.cache-primary-key }} - name: Dereference symlink - run: echo "UPLOAD_PATH=$(readlink -f result)" >> $GITHUB_ENV + run: echo "UPLOAD_PATH=$(readlink -f ./result/noirc_abi_wasm)" >> $GITHUB_ENV - name: Upload artifact uses: actions/upload-artifact@v3 diff --git a/.github/workflows/publish-abi_wasm.yml b/.github/workflows/publish-abi_wasm.yml index 3ca7b77f747..1769b4d771c 100644 --- a/.github/workflows/publish-abi_wasm.yml +++ b/.github/workflows/publish-abi_wasm.yml @@ -36,7 +36,7 @@ jobs: nix build -L .#noirc_abi_wasm - name: Discover Build Output Path - run: echo "BUILD_OUTPUT_PATH=$(readlink -f ./result)" >> $GITHUB_ENV + run: echo "BUILD_OUTPUT_PATH=$(readlink -f ./result/noirc_abi_wasm)" >> $GITHUB_ENV - name: Copy Build Output to Temporary Directory run: | diff --git a/.github/workflows/test-integration.yml b/.github/workflows/test-integration.yml index cb4924e57e6..39b6d683428 100644 --- a/.github/workflows/test-integration.yml +++ b/.github/workflows/test-integration.yml @@ -52,9 +52,9 @@ jobs: - name: Build noir_wasm package run: | nix build -L .#noir_wasm - echo "UPLOAD_PATH=$(readlink -f result)" >> $GITHUB_ENV - cp -r ./result/nodejs ./compiler/wasm - cp -r ./result/web ./compiler/wasm + echo "UPLOAD_PATH=$(readlink -f ./result/noir_wasm)" >> $GITHUB_ENV + cp -r ./result/noir_wasm/nodejs ./compiler/wasm + cp -r ./result/noir_wasm/web ./compiler/wasm - name: Upload `noir_wasm` artifact uses: actions/upload-artifact@v3 @@ -66,9 +66,9 @@ jobs: - name: Build noirc_abi_wasm package run: | nix build -L .#noirc_abi_wasm - echo "UPLOAD_PATH=$(readlink -f result)" >> $GITHUB_ENV - cp -r ./result/nodejs ./tooling/noirc_abi_wasm - cp -r ./result/web ./tooling/noirc_abi_wasm + echo "UPLOAD_PATH=$(readlink -f ./result/noirc_abi_wasm)" >> $GITHUB_ENV + cp -r ./result/noirc_abi_wasm/nodejs ./tooling/noirc_abi_wasm + cp -r ./result/noirc_abi_wasm/web ./tooling/noirc_abi_wasm - name: Upload `noirc_abi_wasm` artifact uses: actions/upload-artifact@v3 diff --git a/.github/workflows/wasm.yml b/.github/workflows/wasm.yml index e12a7ac5173..71972d5e5c5 100644 --- a/.github/workflows/wasm.yml +++ b/.github/workflows/wasm.yml @@ -96,7 +96,7 @@ jobs: key: ${{ steps.cache.outputs.cache-primary-key }} - name: Dereference symlink - run: echo "UPLOAD_PATH=$(readlink -f result)" >> $GITHUB_ENV + run: echo "UPLOAD_PATH=$(readlink -f ./result/noir_wasm)" >> $GITHUB_ENV - name: Upload artifact uses: actions/upload-artifact@v3 From 48d26b28e7b5e9a697d3f322d2b0fa05f4f2542a Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Wed, 13 Sep 2023 15:58:17 -0700 Subject: [PATCH 07/11] attempt to combine wasm deps --- flake.nix | 22 ++++++++++------------ 1 file changed, 10 insertions(+), 12 deletions(-) diff --git a/flake.nix b/flake.nix index 5bfc9e22732..8c25bb0f09f 100644 --- a/flake.nix +++ b/flake.nix @@ -102,6 +102,8 @@ wasmConfig = environment // config // { CARGO_TARGET_DIR = "./target"; + CARGO_BUILD_TARGET = "wasm32-unknown-unknown"; + nativeBuildInputs = with pkgs; [ which git @@ -117,13 +119,10 @@ # Build *just* the cargo dependencies, so we can reuse all of that work between runs native-cargo-artifacts = craneLib.buildDepsOnly (nativeConfig // { - pname = "nargo"; + pname = "native"; }); - noir-wasm-cargo-artifacts = craneLib.buildDepsOnly (wasmConfig // { - pname = "noir_wasm"; - }); - noirc-abi-wasm-cargo-artifacts = craneLib.buildDepsOnly (wasmConfig // { - pname = "noirc_abi_wasm"; + wasm-cargo-artifacts = craneLib.buildDepsOnly (wasmConfig // { + pname = "wasm"; }); nargo = craneLib.buildPackage (nativeConfig // { @@ -142,9 +141,9 @@ inherit GIT_COMMIT GIT_DIRTY; - cargoArtifacts = noir-wasm-cargo-artifacts; + cargoArtifacts = wasm-cargo-artifacts; - cargoExtraArgs = "--package ${pname} --target wasm32-unknown-unknown"; + cargoExtraArgs = "--package ${pname}"; buildPhaseCargoCommand = '' bash compiler/wasm/buildPhaseCargoCommand.sh release @@ -163,9 +162,9 @@ inherit GIT_COMMIT GIT_DIRTY; - cargoArtifacts = noirc-abi-wasm-cargo-artifacts; + cargoArtifacts = wasm-cargo-artifacts; - cargoExtraArgs = "--package ${pname} --target wasm32-unknown-unknown"; + cargoExtraArgs = "--package ${pname}"; buildPhaseCargoCommand = '' bash tooling/noirc_abi_wasm/buildPhaseCargoCommand.sh release @@ -218,8 +217,7 @@ # We expose the `*-cargo-artifacts` derivations so we can cache our cargo dependencies in CI inherit native-cargo-artifacts; - inherit noir-wasm-cargo-artifacts; - inherit noirc-abi-wasm-cargo-artifacts; + inherit wasm-cargo-artifacts; }; # Setup the environment to match the environment settings, the inputs from our checks derivations, From 8e6c31f80e8f2ff339fb4e39efbd31c5a45c5323 Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Thu, 14 Sep 2023 14:25:59 -0700 Subject: [PATCH 08/11] download to correct paths --- .github/workflows/abi_wasm.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/abi_wasm.yml b/.github/workflows/abi_wasm.yml index 4585e7cf881..2340f38e289 100644 --- a/.github/workflows/abi_wasm.yml +++ b/.github/workflows/abi_wasm.yml @@ -75,7 +75,7 @@ jobs: test: runs-on: ubuntu-latest needs: [build] - + steps: - name: Checkout sources uses: actions/checkout@v3 @@ -85,7 +85,7 @@ jobs: with: name: noirc_abi_wasm path: ./tooling/noirc_abi_wasm - + - name: Install Yarn dependencies uses: ./.github/actions/setup @@ -94,7 +94,7 @@ jobs: - name: Install Playwright uses: ./.github/actions/install-playwright - + - name: Run browser tests run: yarn workspace @noir-lang/noirc_abi test:browser From 1e8a479339e09923e58d9bdbdc019dfa76dc3b67 Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Thu, 14 Sep 2023 14:37:17 -0700 Subject: [PATCH 09/11] fix more paths --- .github/workflows/abi_wasm.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/abi_wasm.yml b/.github/workflows/abi_wasm.yml index 2340f38e289..fbbfeba2331 100644 --- a/.github/workflows/abi_wasm.yml +++ b/.github/workflows/abi_wasm.yml @@ -47,8 +47,8 @@ jobs: - name: Build noirc_abi_wasm run: | nix build -L .#noirc_abi_wasm - cp -r ./result/nodejs ./tooling/noirc_abi_wasm - cp -r ./result/web ./tooling/noirc_abi_wasm + cp -r ./result/noirc_abi_wasm/nodejs ./tooling/noirc_abi_wasm + cp -r ./result/noirc_abi_wasm/web ./tooling/noirc_abi_wasm - name: Export cache from nix store if: ${{ steps.cache.outputs.cache-hit != 'true' && github.event_name != 'merge_group' }} From c60fde98ab8b6ed09af50c2a692b87a748827b38 Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Thu, 14 Sep 2023 15:12:42 -0700 Subject: [PATCH 10/11] Revert "attempt to combine wasm deps" This reverts commit 7f8ba13947dfbf6d843b043d4859026a4caca803. --- flake.nix | 22 ++++++++++++---------- 1 file changed, 12 insertions(+), 10 deletions(-) diff --git a/flake.nix b/flake.nix index 8c25bb0f09f..5bfc9e22732 100644 --- a/flake.nix +++ b/flake.nix @@ -102,8 +102,6 @@ wasmConfig = environment // config // { CARGO_TARGET_DIR = "./target"; - CARGO_BUILD_TARGET = "wasm32-unknown-unknown"; - nativeBuildInputs = with pkgs; [ which git @@ -119,10 +117,13 @@ # Build *just* the cargo dependencies, so we can reuse all of that work between runs native-cargo-artifacts = craneLib.buildDepsOnly (nativeConfig // { - pname = "native"; + pname = "nargo"; }); - wasm-cargo-artifacts = craneLib.buildDepsOnly (wasmConfig // { - pname = "wasm"; + noir-wasm-cargo-artifacts = craneLib.buildDepsOnly (wasmConfig // { + pname = "noir_wasm"; + }); + noirc-abi-wasm-cargo-artifacts = craneLib.buildDepsOnly (wasmConfig // { + pname = "noirc_abi_wasm"; }); nargo = craneLib.buildPackage (nativeConfig // { @@ -141,9 +142,9 @@ inherit GIT_COMMIT GIT_DIRTY; - cargoArtifacts = wasm-cargo-artifacts; + cargoArtifacts = noir-wasm-cargo-artifacts; - cargoExtraArgs = "--package ${pname}"; + cargoExtraArgs = "--package ${pname} --target wasm32-unknown-unknown"; buildPhaseCargoCommand = '' bash compiler/wasm/buildPhaseCargoCommand.sh release @@ -162,9 +163,9 @@ inherit GIT_COMMIT GIT_DIRTY; - cargoArtifacts = wasm-cargo-artifacts; + cargoArtifacts = noirc-abi-wasm-cargo-artifacts; - cargoExtraArgs = "--package ${pname}"; + cargoExtraArgs = "--package ${pname} --target wasm32-unknown-unknown"; buildPhaseCargoCommand = '' bash tooling/noirc_abi_wasm/buildPhaseCargoCommand.sh release @@ -217,7 +218,8 @@ # We expose the `*-cargo-artifacts` derivations so we can cache our cargo dependencies in CI inherit native-cargo-artifacts; - inherit wasm-cargo-artifacts; + inherit noir-wasm-cargo-artifacts; + inherit noirc-abi-wasm-cargo-artifacts; }; # Setup the environment to match the environment settings, the inputs from our checks derivations, From 902e169b55f760918a8cf870c8fc394abdfb6858 Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Fri, 15 Sep 2023 10:42:21 -0700 Subject: [PATCH 11/11] switch default to all package --- flake.nix | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/flake.nix b/flake.nix index 5bfc9e22732..98ed1bcf5c2 100644 --- a/flake.nix +++ b/flake.nix @@ -207,9 +207,11 @@ }; packages = { + default = nargo; + # Nix flakes cannot build more than one derivation in one command (see https://github.com/NixOS/nix/issues/5591) - # so we use `symlinkJoin` to build everything as our default package. - default = pkgs.symlinkJoin { name = "noir"; paths = [ nargo noir_wasm noirc_abi_wasm ]; }; + # so we use `symlinkJoin` to build everything as the "all" package. + all = pkgs.symlinkJoin { name = "all"; paths = [ nargo noir_wasm noirc_abi_wasm ]; }; # We also export individual packages to enable `nix build .#nargo -L`, etc. inherit nargo;