nixpkgs/pkgs/applications/misc/dasel/default.nix

47 lines
1.4 KiB
Nix
Raw Normal View History

{ lib
2020-11-04 21:21:54 +01:00
, buildGoModule
, fetchFromGitHub
}:
buildGoModule rec {
pname = "dasel";
2021-11-10 22:26:25 +01:00
version = "1.22.1";
2020-11-04 21:21:54 +01:00
src = fetchFromGitHub {
owner = "TomWright";
2021-11-10 22:26:25 +01:00
repo = "dasel";
2020-11-04 21:21:54 +01:00
rev = "v${version}";
2021-11-10 22:26:25 +01:00
sha256 = "091s3hyz9p892garanm9zmkbsn6hn3bnnrz7h3dqsyi58806d5yr";
2020-11-04 21:21:54 +01:00
};
2022-01-30 04:25:30 +01:00
vendorSha256 = "1y0k03lg9dh3bpi10xzv03h7gq7h0hgggs304p78p3jkr8pmkqss";
2020-11-04 21:21:54 +01:00
ldflags = [
"-s" "-w" "-X github.com/tomwright/dasel/internal.Version=${version}"
];
2020-12-04 07:22:07 +01:00
2020-12-20 20:41:51 +01:00
doInstallCheck = true;
installCheckPhase = ''
if [[ "$("$out/bin/${pname}" --version)" == "${pname} version ${version}" ]]; then
echo "" | $out/bin/dasel put object -p yaml -t string -t int "my.favourites" colour=red number=3 | grep -q red
echo '${pname} smoke check passed'
else
echo '${pname} smoke check failed'
return 1
fi
'';
meta = with lib; {
2020-11-04 21:21:54 +01:00
description = "Query and update data structures from the command line";
longDescription = ''
Dasel (short for data-selector) allows you to query and modify data structures using selector strings.
Comparable to jq / yq, but supports JSON, YAML, TOML and XML with zero runtime dependencies.
'';
homepage = "https://github.com/TomWright/dasel";
2021-11-10 22:26:25 +01:00
changelog = "https://github.com/TomWright/dasel/blob/v${version}/CHANGELOG.md";
2020-11-04 21:21:54 +01:00
license = licenses.mit;
platforms = platforms.unix;
maintainers = with maintainers; [ _0x4A6F ];
};
}