nixpkgs/pkgs/by-name/ka/kanif/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

36 lines
1.4 KiB
Nix

{ lib, stdenv, fetchurl, perl , taktuk}:
stdenv.mkDerivation rec {
version = "1.2.2";
pname = "kanif";
src = fetchurl {
url = "https://gforge.inria.fr/frs/download.php/26773/${pname}-${version}.tar.gz";
sha256 = "3f0c549428dfe88457c1db293cfac2a22b203f872904c3abf372651ac12e5879";
};
preBuild = ''
substituteInPlace ./kanif --replace "/usr/bin/perl" "${perl}/bin/perl"
substituteInPlace ./kanif --replace '$taktuk_command = "taktuk";' '$taktuk_command = "${taktuk}/bin/taktuk";'
'';
meta = {
description = "Cluster management and administration swiss army knife";
longDescription = ''
Kanif is a tool for high performance computing clusters management and
administration. It combines the main functionalities of well-known cluster
management tools such as c3, pdsh and dsh, and mimics their syntax. It
provides three tools to run the same command on several nodes ("parallel
ssh", using the 'kash' command), to broadcast the copy of files or
directories to several nodes ('kaput' command), and to gather several
remote files or directories locally ('kaget' command). It relies on TakTuk
for efficiency and scalability.'';
homepage = "http://taktuk.gforge.inria.fr/kanif";
license = lib.licenses.gpl2;
maintainers = [ lib.maintainers.bzizou ];
platforms = lib.platforms.linux;
};
}