nixpkgs/pkgs/by-name/re/replacement/package.nix
aleksana 571c71e6f7 treewide: migrate packages to pkgs/by-name, take 1
We are migrating packages that meet below requirements:

1. using `callPackage`
2. called path is a directory
3. overriding set is empty (`{ }`)
4. not containing path expressions other than relative path (to
makenixpkgs-vet happy)
5. not referenced by nix files outside of the directory, other
than`pkgs/top-level/all-packages.nix`
6. not referencing nix files outside of the directory
7. not referencing `default.nix` (since it's changed to `package.nix`)
8. `outPath` doesn't change after migration

The tool is here: https://github.com/Aleksanaa/by-name-migrate.
2024-11-09 20:04:51 +08:00

48 lines
1.2 KiB
Nix

{ lib
, fetchFromGitHub
, python3Packages
}:
python3Packages.buildPythonApplication rec {
pname = "replacement";
version = "0.4.4";
disabled = python3Packages.isPy27;
src = fetchFromGitHub {
owner = "siriobalmelli";
repo = "replacement";
rev = "v${version}";
sha256 = "0j4lvn3rx1kqvxcsd8nhc2lgk48jyyl7qffhlkvakhy60f9lymj3";
};
propagatedBuildInputs = with python3Packages; [
ruamel-yaml
];
nativeCheckInputs = with python3Packages; [
pytestCheckHook
sh
];
meta = with lib; {
homepage = "https://github.com/siriobalmelli/replacement";
description = "Tool to execute yaml templates and output text";
mainProgram = "replacement";
longDescription = ''
Replacement is a python utility
that parses a yaml template and outputs text.
A 'template' is a YAML file containing a 'replacement' object.
A 'replacement' object contains a list of blocks,
each of which is executed in sequence.
This tool is useful in generating configuration files,
static websites and the like.
'';
license = licenses.asl20;
maintainers = with maintainers; [ siriobalmelli ];
};
}