From 7b273c7245ced8049555baae07255f2577d1c19d Mon Sep 17 00:00:00 2001 From: Patagia Date: Sun, 20 Oct 2024 17:29:28 +0000 Subject: [PATCH] Initial commit --- .envrc.recommended | 2 + .../default_merge_message/MERGE_TEMPLATE.md | 5 ++ .../default_merge_message/REBASE_TEMPLATE.md | 5 ++ .../default_merge_message/SQUASH_TEMPLATE.md | 5 ++ .gitignore | 5 ++ .woodpecker/ci.yaml | 33 ++++++++++ README.md | 3 + flake.lock | 61 +++++++++++++++++++ flake.nix | 60 ++++++++++++++++++ justfile | 28 +++++++++ 10 files changed, 207 insertions(+) create mode 100644 .envrc.recommended create mode 100644 .forgejo/default_merge_message/MERGE_TEMPLATE.md create mode 100644 .forgejo/default_merge_message/REBASE_TEMPLATE.md create mode 100644 .forgejo/default_merge_message/SQUASH_TEMPLATE.md create mode 100644 .gitignore create mode 100644 .woodpecker/ci.yaml create mode 100644 README.md create mode 100644 flake.lock create mode 100644 flake.nix create mode 100644 justfile diff --git a/.envrc.recommended b/.envrc.recommended new file mode 100644 index 0000000..a96880d --- /dev/null +++ b/.envrc.recommended @@ -0,0 +1,2 @@ +use flake +dotenv_if_exists diff --git a/.forgejo/default_merge_message/MERGE_TEMPLATE.md b/.forgejo/default_merge_message/MERGE_TEMPLATE.md new file mode 100644 index 0000000..bada210 --- /dev/null +++ b/.forgejo/default_merge_message/MERGE_TEMPLATE.md @@ -0,0 +1,5 @@ +#${PullRequestIndex} ${PullRequestTitle} + +${PullRequestDescription} + +Reviewed-on: https://patagia.dev/${BaseRepoOwnerName}/${BaseRepoName}/pulls/${PullRequestIndex} diff --git a/.forgejo/default_merge_message/REBASE_TEMPLATE.md b/.forgejo/default_merge_message/REBASE_TEMPLATE.md new file mode 100644 index 0000000..bada210 --- /dev/null +++ b/.forgejo/default_merge_message/REBASE_TEMPLATE.md @@ -0,0 +1,5 @@ +#${PullRequestIndex} ${PullRequestTitle} + +${PullRequestDescription} + +Reviewed-on: https://patagia.dev/${BaseRepoOwnerName}/${BaseRepoName}/pulls/${PullRequestIndex} diff --git a/.forgejo/default_merge_message/SQUASH_TEMPLATE.md b/.forgejo/default_merge_message/SQUASH_TEMPLATE.md new file mode 100644 index 0000000..bada210 --- /dev/null +++ b/.forgejo/default_merge_message/SQUASH_TEMPLATE.md @@ -0,0 +1,5 @@ +#${PullRequestIndex} ${PullRequestTitle} + +${PullRequestDescription} + +Reviewed-on: https://patagia.dev/${BaseRepoOwnerName}/${BaseRepoName}/pulls/${PullRequestIndex} diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..7bb31e3 --- /dev/null +++ b/.gitignore @@ -0,0 +1,5 @@ +.direnv +.env +.envrc +.git +result* diff --git a/.woodpecker/ci.yaml b/.woodpecker/ci.yaml new file mode 100644 index 0000000..9fb1152 --- /dev/null +++ b/.woodpecker/ci.yaml @@ -0,0 +1,33 @@ +when: + - event: pull_request + - event: push + branch: + - ${CI_REPO_DEFAULT_BRANCH} + +steps: + check: + image: alpine + volumes: + - nix:/nix + commands: + # install nix + - | + test -f /nix/installer || wget -O /nix/installer https://github.com/DeterminateSystems/nix-installer/releases/download/v0.18.0/nix-installer-x86_64-linux + chmod +x /nix/installer + rm -f /nix/receipt.json /nix/nix-installer + /nix/installer install linux --init=none --no-confirm + . /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh + + # configure nix + - | + mkdir -p /etc/nix + cat < /etc/nix/nix.conf + sandbox = false + experimental-features = nix-command flakes + EOF + + # build + - nix build . + + # check + - nix flake check diff --git a/README.md b/README.md new file mode 100644 index 0000000..68e5487 --- /dev/null +++ b/README.md @@ -0,0 +1,3 @@ +# My Project + +This is a template for generic new projects. diff --git a/flake.lock b/flake.lock new file mode 100644 index 0000000..35b5bcc --- /dev/null +++ b/flake.lock @@ -0,0 +1,61 @@ +{ + "nodes": { + "flake-utils": { + "inputs": { + "systems": "systems" + }, + "locked": { + "lastModified": 1726560853, + "narHash": "sha256-X6rJYSESBVr3hBoH0WbKE5KvhPU5bloyZ2L4K60/fPQ=", + "owner": "numtide", + "repo": "flake-utils", + "rev": "c1dfcf08411b08f6b8615f7d8971a2bfa81d5e8a", + "type": "github" + }, + "original": { + "owner": "numtide", + "repo": "flake-utils", + "type": "github" + } + }, + "nixpkgs": { + "locked": { + "lastModified": 1726969270, + "narHash": "sha256-8fnFlXBgM/uSvBlLWjZ0Z0sOdRBesyNdH0+esxqizGc=", + "owner": "NixOS", + "repo": "nixpkgs", + "rev": "23cbb250f3bf4f516a2d0bf03c51a30900848075", + "type": "github" + }, + "original": { + "owner": "NixOS", + "ref": "nixos-24.05", + "repo": "nixpkgs", + "type": "github" + } + }, + "root": { + "inputs": { + "flake-utils": "flake-utils", + "nixpkgs": "nixpkgs" + } + }, + "systems": { + "locked": { + "lastModified": 1681028828, + "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", + "owner": "nix-systems", + "repo": "default", + "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", + "type": "github" + }, + "original": { + "owner": "nix-systems", + "repo": "default", + "type": "github" + } + } + }, + "root": "root", + "version": 7 +} diff --git a/flake.nix b/flake.nix new file mode 100644 index 0000000..225b1ac --- /dev/null +++ b/flake.nix @@ -0,0 +1,60 @@ +{ + description = "My Project"; + + inputs = { + flake-utils.url = "github:numtide/flake-utils"; + nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.05"; + }; + + outputs = + { + self, + flake-utils, + nixpkgs, + ... + }: + flake-utils.lib.eachDefaultSystem ( + system: + let + pkgs = import nixpkgs { inherit system; }; + in + { + # Formatter for the Nix code + formatter = pkgs.nixpkgs-fmt; + + # Checks/tests for the project + checks = { + # FIXME: Add actual tests + simple-test = pkgs.runCommand "simple-test" { } '' + ${self.packages.${system}.default}/bin/my-program + touch $out + ''; + }; + + # Packages + packages = { + my-program = pkgs.writeShellScriptBin "my-program" '' + ${pkgs.ddate}/bin/ddate +'Hello, world! Today is the %e of %B%, %Y' | + ${pkgs.cowsay}/bin/cowsay + ''; + + default = self.packages.${system}.my-program; + }; + + # Development shell + devShells.default = pkgs.mkShell { + buildInputs = with pkgs; [ + just + watchexec + ]; + shellHook = '' + echo + echo "✨ Welcome to the My Project development environment! ✨" + echo "Run 'just' to see available commands." + echo + ''; + }; + + } + ); +} diff --git a/justfile b/justfile new file mode 100644 index 0000000..306a400 --- /dev/null +++ b/justfile @@ -0,0 +1,28 @@ +set shell := ["/usr/bin/env", "bash", "-euo", "pipefail", "-c"] + +[private] +default: + @just --choose + +# Run all tests +test: + nix flake check + +# Lint all source code +lint: + echo FIXME: Add linter(s) here + +# Format all source code +fmt: + echo FIXME: Add formatter here + +# Update all dependencies +update: update-nix-pkgs + +# Update nix flake packages +update-nix-pkgs: + nix flake update + +# Run local development +dev $OTEL_SERVICE_NAME="my-project": + watchexec --clear --restart --stop-signal INT --debounce 300ms -- nix run .