Unverified Commit edcff388 authored by Sandro Jäckel's avatar Sandro Jäckel Committed by GitHub
Browse files

Merge pull request #283049 from onemoresuza/bonsai

bonsai: refactor derivation and move to pkgs/by-name
parents e02ee26d aa385c97
Loading
Loading
Loading
Loading
+54 −0
Original line number Diff line number Diff line
@@ -6,52 +6,39 @@
, hareThirdParty
}:

stdenv.mkDerivation rec {
stdenv.mkDerivation (finalAttrs: {
  pname = "bonsai";
  version = "1.0.2";

  src = fetchFromSourcehut {
    owner = "~stacyharper";
    repo = "bonsai";
    rev = "v${version}";
    rev = "v${finalAttrs.version}";
    hash = "sha256-Yosf07KUOQv4O5111tLGgI270g0KVGwzdTPtPOsTcP8=";
  };

  postPatch = ''
    substituteInPlace Makefile \
      --replace 'hare build' 'hare build $(HARE_TARGET_FLAGS)'
  '';

  nativeBuildInputs = [
    hare
    hareThirdParty.hare-ev
    hareThirdParty.hare-json
  ];

  buildInputs = with hareThirdParty; [
    hare-ev
    hare-json
  makeFlags = [
    "PREFIX=${builtins.placeholder "out"}"
    "HARECACHE=.harecache"
    "HAREFLAGS=-qa${stdenv.hostPlatform.uname.processor}"
  ];

  env.HARE_TARGET_FLAGS =
    if stdenv.hostPlatform.isAarch64 then
      "-a aarch64"
    else if stdenv.hostPlatform.isRiscV64 then
      "-a riscv64"
    else if stdenv.hostPlatform.isx86_64 then
      "-a x86_64"
    else
      "";
  # TODO: hare setup-hook is supposed to do this for us.
  # It does it correctly for native compilation, but not cross compilation: wrong offset?
  env.HAREPATH = with hareThirdParty; "${hare-json}/src/hare/third-party:${hare-ev}/src/hare/third-party";

  preConfigure = ''
    export HARECACHE=$(mktemp -d)
  '';

  installFlags = [ "PREFIX=$(out)" ];
  enableParallelBuilding = true;

  doCheck = true;

  postPatch = ''
    substituteInPlace Makefile \
      --replace 'hare build' 'hare build $(HAREFLAGS)' \
      --replace 'hare test' 'hare test $(HAREFLAGS)'
  '';

  passthru.updateScript = gitUpdater {
    rev-prefix = "v";
  };
@@ -59,8 +46,9 @@ stdenv.mkDerivation rec {
  meta = with lib; {
    description = "Finite State Machine structured as a tree";
    homepage = "https://git.sr.ht/~stacyharper/bonsai";
    license = licenses.agpl3;
    license = licenses.agpl3Plus;
    maintainers = with maintainers; [ colinsane ];
    platforms = platforms.linux;
    mainProgram = "bonsaictl";
  };
}
})
+0 −2
Original line number Diff line number Diff line
@@ -1751,8 +1751,6 @@ with pkgs;
  bikeshed = python3Packages.callPackage ../applications/misc/bikeshed { };
  bonsai = callPackage ../tools/misc/bonsai { };
  cie-middleware-linux = callPackage ../tools/security/cie-middleware-linux { };
  cidrgrep = callPackage ../tools/text/cidrgrep { };