extracted the nix package into it's own package

This commit is contained in:
Robin Bärtschi 2025-03-09 12:18:58 +01:00
parent 290d05da88
commit 70cfdb5e95
2 changed files with 37 additions and 35 deletions

View File

@ -1,3 +1,5 @@
# ml2 ts=2 sts=2 sw=2
{ {
description = "A simple Go package"; description = "A simple Go package";
@ -22,46 +24,26 @@
# Nixpkgs instantiated for supported system types. # Nixpkgs instantiated for supported system types.
nixpkgsFor = forAllSystems (system: import nixpkgs { inherit system; }); nixpkgsFor = forAllSystems (system: import nixpkgs { inherit system; });
in in {
{
# Provide some binary packages for selected system types. # Provide some binary packages for selected system types.
packages = forAllSystems (system: packages = forAllSystems (system:
let let
pkgs = nixpkgsFor.${system}; pkgs = nixpkgsFor.${system};
in in
{ {
tt = pkgs.buildGoModule { tt = pkgs.callPackage ./nix/package.nix { version = version; };
pname = "tt"; });
inherit version;
# In 'nix develop', we don't need a copy of the source tree
# in the Nix store.
src = ./.;
# This hash locks the dependencies of this package. It is
# necessary because of how Go requires network access to resolve
# VCS. See https://www.tweag.io/blog/2021-03-04-gomod2nix/ for
# details. Normally one can build with a fake hash and rely on native Go
# mechanisms to tell you what the hash should be or determine what
# it should be "out-of-band" with other tooling (eg. gomod2nix).
# To begin with it is recommended to set this, but one must
# remember to bump this hash when your dependencies change.
# vendorHash = pkgs.lib.fakeHash;
vendorHash = "sha256-cpjMZr+kP+XyXRxK4YI/lGHl97IROFVVz8DrID0vi6E=";
};
});
# Add dependencies that are only needed for development # Add dependencies that are only needed for development
devShells = forAllSystems (system: devShells = forAllSystems (system:
let let
pkgs = nixpkgsFor.${system}; pkgs = nixpkgsFor.${system};
in in
{ {
default = pkgs.mkShell { default = pkgs.mkShell {
buildInputs = with pkgs; [ go gopls gotools go-tools qbe (if system == "x86_64-linux" then [fasm] else []) ]; buildInputs = with pkgs; [ go gopls gotools go-tools qbe (if system == "x86_64-linux" then [fasm] else []) ];
}; };
}); });
# The default package for 'nix build'. This makes sense if the # The default package for 'nix build'. This makes sense if the
# flake provides only one package or there is a clear "main" # flake provides only one package or there is a clear "main"

20
nix/package.nix Normal file
View File

@ -0,0 +1,20 @@
# ml2 ts=2 sts=2 sw=2
{buildGoModule, version}: buildGoModule {
pname = "tt";
inherit version;
# In 'nix develop', we don't need a copy of the source tree
# in the Nix store.
src = ./.;
# This hash locks the dependencies of this package. It is
# necessary because of how Go requires network access to resolve
# VCS. See https://www.tweag.io/blog/2021-03-04-gomod2nix/ for
# details. Normally one can build with a fake hash and rely on native Go
# mechanisms to tell you what the hash should be or determine what
# it should be "out-of-band" with other tooling (eg. gomod2nix).
# To begin with it is recommended to set this, but one must
# remember to bump this hash when your dependencies change.
# vendorHash = pkgs.lib.fakeHash;
vendorHash = "sha256-cpjMZr+kP+XyXRxK4YI/lGHl97IROFVVz8DrID0vi6E=";
}