dadc7eb329
Whenever we create scripts that are installed to $out, we must use runtimeShell in order to get the shell that can be executed on the machine we create the package for. This is relevant for cross-compiling. The only use case for stdenv.shell are scripts that are executed as part of the build system. Usages in checkPhase are borderline however to decrease the likelyhood of people copying the wrong examples, I decided to use runtimeShell as well.
41 lines
1.3 KiB
Nix
41 lines
1.3 KiB
Nix
{ stdenv, fetchurl, runtimeShell }:
|
|
|
|
stdenv.mkDerivation {
|
|
name = "thinkingrock-binary-2.2.1";
|
|
|
|
src = fetchurl {
|
|
url = mirror://sourceforge/thinkingrock/ThinkingRock/TR%202.2.1/tr-2.2.1.tar.gz;
|
|
sha256 = "0hnwvvyc8miiz8w2g4iy7s4rgfy0kfbncgbgfzpsq6nrzq334kgm";
|
|
};
|
|
|
|
/* it would be a really bad idea to put thinkingrock tr executable in PATH!
|
|
the tr.sh script does use the coreutils tr itself
|
|
That's why I've renamed the wrapper and called it thinkingrock
|
|
However you may not rename the bin/tr script cause it will notice and throw an
|
|
"java.lang.IllegalArgumentException: Malformed branding token: thinkingrock"
|
|
exception. I hope that's fine
|
|
*/
|
|
|
|
buildPhase = ''
|
|
# only keep /bin/tr
|
|
ls -1 bin/* | grep -ve 'bin/tr''$' | xargs rm
|
|
# don't keep the other .exe file either
|
|
find . -iname "*.exe" | xargs -n1 rm
|
|
mkdir -p $out/{nix-support/tr-files,bin}
|
|
cp -r . $out/nix-support/tr-files
|
|
cat >> $out/bin/thinkingrock << EOF
|
|
#!${runtimeShell}
|
|
exec $out/nix-support/tr-files/bin/tr "$@"
|
|
EOF
|
|
chmod +x $out/bin/thinkingrock
|
|
'';
|
|
|
|
installPhase = ":";
|
|
|
|
meta = {
|
|
description = "Task management system";
|
|
homepage = http://www.thinkingrock.com.au/;
|
|
license = "CDDL"; # Common Development and Distribution License
|
|
platforms = stdenv.lib.platforms.unix;
|
|
};
|
|
}
|