From 18b41c0333eddce4e1e9ad3f5d5212eb9f5dec71 Mon Sep 17 00:00:00 2001 From: Gergely Nagy Date: Fri, 22 Sep 2023 21:43:51 +0200 Subject: [PATCH] Add a nix/shell action Since it's basically the same as `nix/develop`, with only the nix command changed, leverage the existing script. Signed-off-by: Gergely Nagy --- .forgejo/workflows/nix-shell.yaml | 39 +++++++++++++++++++++++++++++++ develop/bin/nix-develop | 7 +++++- shell/action.yml | 25 ++++++++++++++++++++ shell/bin/nix-shell | 1 + shell/test/flake.lock | 27 +++++++++++++++++++++ shell/test/flake.nix | 11 +++++++++ 6 files changed, 109 insertions(+), 1 deletion(-) create mode 100644 .forgejo/workflows/nix-shell.yaml create mode 100644 shell/action.yml create mode 120000 shell/bin/nix-shell create mode 100644 shell/test/flake.lock create mode 100644 shell/test/flake.nix diff --git a/.forgejo/workflows/nix-shell.yaml b/.forgejo/workflows/nix-shell.yaml new file mode 100644 index 0000000..567f6b2 --- /dev/null +++ b/.forgejo/workflows/nix-shell.yaml @@ -0,0 +1,39 @@ +--- +name: test nix/shell + +on: + push: + +jobs: + nix/shell: + runs-on: nixos-flakes + steps: + - name: checkout + uses: actions/checkout@v3 + + - name: run a command within a Nix shell + uses: ./shell + with: + flake: ./shell/test + package: "hello" + run: | + hello + + - name: ensure we're not in a dev environment + uses: ./shell + with: + flake: ./shell/test + package: "hello" + run: | + set -x + + # if we have gcc installed, we're in a dev environment. + # we don't want to be in a dev environment + type -p gcc >/dev/null && exit 1 + hello + + - name: no commands should still work + uses: ./shell + with: + flake: ./shell/test + package: "hello" diff --git a/develop/bin/nix-develop b/develop/bin/nix-develop index cd17064..e59071c 100755 --- a/develop/bin/nix-develop +++ b/develop/bin/nix-develop @@ -5,4 +5,9 @@ workdir="$(mktemp -d)" trap 'rm -rf "$workdir"' EXIT echo "${INPUT_RUN}" >"${workdir}/run.sh" -nix develop "${INPUT_FLAKE}#${INPUT_PACKAGE}" -c bash "${workdir}/run.sh" +__cmd="develop" +if [ "$(basename $0)" = "nix-shell" ]; then + __cmd="shell" +fi + +nix "${__cmd}" "${INPUT_FLAKE}#${INPUT_PACKAGE}" -c bash "${workdir}/run.sh" diff --git a/shell/action.yml b/shell/action.yml new file mode 100644 index 0000000..33d22e4 --- /dev/null +++ b/shell/action.yml @@ -0,0 +1,25 @@ +--- +name: nix-shell +author: Gergely Nagy +description: "Run commands within a Nix development environment" +inputs: + flake: + description: "The flake to use for the development environment" + default: "." + required: true + package: + description: "The package to use for the development environment" + required: false + run: + description: "Commands to run within the development environment" + required: false +runs: + using: "composite" + steps: + - id: nix-shell + shell: bash + run: $GITHUB_ACTION_PATH/bin/nix-shell + env: + INPUT_FLAKE: ${{ inputs.flake }} + INPUT_PACKAGE: ${{ inputs.package }} + INPUT_RUN: ${{ inputs.run }} diff --git a/shell/bin/nix-shell b/shell/bin/nix-shell new file mode 120000 index 0000000..21dae3e --- /dev/null +++ b/shell/bin/nix-shell @@ -0,0 +1 @@ +../../develop/bin/nix-develop \ No newline at end of file diff --git a/shell/test/flake.lock b/shell/test/flake.lock new file mode 100644 index 0000000..42930f1 --- /dev/null +++ b/shell/test/flake.lock @@ -0,0 +1,27 @@ +{ + "nodes": { + "nixpkgs": { + "locked": { + "lastModified": 1685566663, + "narHash": "sha256-btHN1czJ6rzteeCuE/PNrdssqYD2nIA4w48miQAFloM=", + "owner": "nixos", + "repo": "nixpkgs", + "rev": "4ecab3273592f27479a583fb6d975d4aba3486fe", + "type": "github" + }, + "original": { + "owner": "nixos", + "ref": "23.05", + "repo": "nixpkgs", + "type": "github" + } + }, + "root": { + "inputs": { + "nixpkgs": "nixpkgs" + } + } + }, + "root": "root", + "version": 7 +} diff --git a/shell/test/flake.nix b/shell/test/flake.nix new file mode 100644 index 0000000..e8e014d --- /dev/null +++ b/shell/test/flake.nix @@ -0,0 +1,11 @@ +{ + inputs = { + nixpkgs.url = "github:nixos/nixpkgs/23.05"; + }; + + outputs = { self, nixpkgs }: + let pkgs = nixpkgs.legacyPackages.x86_64-linux; + in { + packages.x86_64-linux.hello = pkgs.hello; + }; +}