Compare commits

..

No commits in common. "e0f2da3174ed70e7bf5754d36f235b89b68cf746" and "290d05da88deb7220afb711b383a8b1b17648e42" have entirely different histories.

3 changed files with 35 additions and 42 deletions

View File

@ -1,5 +1,3 @@
# ml2 ts=2 sts=2 sw=2
{ {
description = "A simple Go package"; description = "A simple Go package";
@ -24,26 +22,46 @@
# 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.callPackage ./nix/package.nix { version = version; }; tt = pkgs.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=";
};
});
# 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"

View File

@ -1,4 +0,0 @@
# ml2 ts=2 sts=2 sw=2
with import <nixpkgs> {};
{version ? "HEAD"}: callPackage ./package.nix {inherit version;}

View File

@ -1,21 +0,0 @@
# ml2 ts=2 sts=2 sw=2
{buildGoModule, version ? "HEAD"}: 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=";
}