nixpkgs/pkgs/development/tools/mani/default.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

48 lines
1.5 KiB
Nix
Raw Normal View History

2021-11-17 16:08:42 +00:00
{ buildGoModule, fetchFromGitHub, lib, installShellFiles, git, makeWrapper}:
buildGoModule rec {
pname = "mani";
2022-09-11 20:26:36 +00:00
version = "0.22.0";
2021-11-17 16:08:42 +00:00
src = fetchFromGitHub {
owner = "alajmo";
repo = "mani";
rev = "v${version}";
2022-09-11 20:26:36 +00:00
sha256 = "sha256-2WuUQt9q19JYlfAyoGFRVpiLmsMbN45cYdF16j+jhhk=";
2021-11-17 16:08:42 +00:00
};
2022-09-11 20:26:36 +00:00
vendorSha256 = "sha256-9DP6SRcvHtZhkk2XoYesC1mhfq06KsLs0X02AG9vwJ8=";
2021-11-17 16:08:42 +00:00
nativeBuildInputs = [ installShellFiles makeWrapper ];
ldflags = [ "-s" "-w" "-X github.com/alajmo/mani/cmd.version=${version}" ];
2021-11-17 16:08:42 +00:00
postInstall = ''
installShellCompletion --cmd mani \
--bash <($out/bin/mani completion bash) \
--fish <($out/bin/mani completion fish) \
--zsh <($out/bin/mani completion zsh)
wrapProgram $out/bin/mani \
--prefix PATH : ${lib.makeBinPath [ git ]}
'';
# Skip tests
# The repo's test folder has a README.md with detailed information. I don't
# know how to wrap the dependencies for these integration tests so skip for now.
doCheck = false;
meta = with lib; {
description = "CLI tool to help you manage multiple repositories";
longDescription = ''
mani is a CLI tool that helps you manage multiple repositories. It's useful
when you are working with microservices, multi-project systems, many
libraries or just a bunch of repositories and want a central place for
pulling all repositories and running commands over them.
'';
homepage = "https://manicli.com/";
changelog = "https://github.com/alajmo/mani/releases/tag/v${version}";
license = licenses.mit;
};
}