freenet: rewrite wrapper to not depend on PATH

This commit is contained in:
Shell Turner 2016-01-03 14:33:56 +00:00
parent 0d5542bc85
commit f229791454
2 changed files with 47 additions and 35 deletions

View File

@ -1,4 +1,4 @@
{ stdenv, fetchurl, fetchgit, ant, jdk, makeWrapper }: { stdenv, fetchurl, fetchgit, ant, jdk, bash, coreutils, substituteAll }:
let let
freenet_ext = fetchurl { freenet_ext = fetchurl {
@ -15,10 +15,9 @@ let
sha256 = "109zn9w8axdkjwhkkcm2s8dvib0mq0n8imjgs3r8hvi128cjsmg9"; sha256 = "109zn9w8axdkjwhkkcm2s8dvib0mq0n8imjgs3r8hvi128cjsmg9";
}; };
version = "build01470"; version = "build01470";
in
stdenv.mkDerivation {
name = "freenet-${version}";
freenet-jars = stdenv.mkDerivation {
name = "freenet-jars-${version}";
src = fetchgit { src = fetchgit {
url = https://github.com/freenet/fred; url = https://github.com/freenet/fred;
@ -34,27 +33,38 @@ stdenv.mkDerivation {
sed 's/@unknown@/${version}/g' -i build-clean.xml sed 's/@unknown@/${version}/g' -i build-clean.xml
''; '';
buildInputs = [ ant jdk makeWrapper ]; buildInputs = [ ant jdk ];
buildPhase = "ant package-only"; buildPhase = "ant package-only";
freenetWrapper = ./freenetWrapper;
installPhase = '' installPhase = ''
mkdir -p $out/share/freenet $out/bin mkdir -p $out/share/freenet
cp lib/bcprov-jdk15on-152.jar $out/share/freenet cp lib/bcprov-jdk15on-152.jar $out/share/freenet
cp lib/freenet/freenet-ext.jar $out/share/freenet cp lib/freenet/freenet-ext.jar $out/share/freenet
cp dist/freenet.jar $out/share/freenet cp dist/freenet.jar $out/share/freenet
'';
};
cat <<EOF > $out/bin/freenet.wrapped in stdenv.mkDerivation {
#!${stdenv.shell} name = "freenet-${version}";
${jdk.jre}/bin/java -cp $out/share/freenet/bcprov-jdk15on-152.jar:$out/share/freenet/freenet-ext.jar:$out/share/freenet/freenet.jar \\ inherit version;
-Xmx1024M freenet.node.NodeStarter
EOF src = substituteAll {
chmod +x $out/bin/freenet.wrapped src = ./freenetWrapper;
makeWrapper $freenetWrapper $out/bin/freenet \ inherit bash coreutils seednodes;
--set FREENET_ROOT "$out" \ freenet = freenet-jars;
--set FREENET_SEEDNODES "${seednodes}" jre = jdk.jre;
};
jars = freenet-jars;
phases = [ "installPhase" ];
installPhase = ''
mkdir -p $out/bin
cp $src $out/bin/freenet
chmod +x $out/bin/freenet
ln -s ${freenet-jars}/share $out/share
''; '';
meta = { meta = {

View File

@ -1,4 +1,6 @@
#! /usr/bin/env bash #! @bash@/bin/bash
PATH=@coreutils@/bin:$PATH
export FREENET_HOME="$HOME/.local/share/freenet" export FREENET_HOME="$HOME/.local/share/freenet"
if [ -n "$XDG_DATA_HOME" ] if [ -n "$XDG_DATA_HOME" ]
@ -9,8 +11,8 @@ if [ ! -d $FREENET_HOME ]; then
mkdir -p $FREENET_HOME mkdir -p $FREENET_HOME
fi fi
cp -u $FREENET_SEEDNODES $FREENET_HOME/seednodes.fref cp -u @seednodes@ $FREENET_HOME/seednodes.fref
chmod u+rw $FREENET_HOME/seednodes.fref chmod u+rw $FREENET_HOME/seednodes.fref
cd $FREENET_HOME cd $FREENET_HOME
exec $FREENET_ROOT/bin/freenet.wrapped "$@" @jre@/bin/java -cp @freenet@/share/freenet/bcprov-jdk15on-152.jar:@freenet@/share/freenet/freenet-ext.jar:@freenet@/share/freenet/freenet.jar -Xmx1024M freenet.node.NodeStarter