nixpkgs: remove all Java 7 expressions
JDK 7 was technically EOL'd a while ago, although RedHat etc are still doing updates I believe. However, JDK 8 is the default in the tree and really used everywhere, and JDK 7 isn't seeing many updates by current maintainers, so dropping it seems appropriate. Signed-off-by: Austin Seipp <aseipp@pobox.com>
This commit is contained in:
parent
bdb06c0936
commit
5d5ed30150
@ -1,244 +0,0 @@
|
|||||||
{ stdenv, fetchurl, unzip, zip, procps, coreutils, alsaLib, ant, freetype
|
|
||||||
, which, bootjdk, nettools, xorg, file, cups
|
|
||||||
, fontconfig, cpio, cacert, perl, setJavaClassPath
|
|
||||||
, minimal ? false
|
|
||||||
}:
|
|
||||||
|
|
||||||
let
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The JRE libraries are in directories that depend on the CPU.
|
|
||||||
*/
|
|
||||||
architecture =
|
|
||||||
if stdenv.system == "i686-linux" then
|
|
||||||
"i386"
|
|
||||||
else if stdenv.system == "x86_64-linux" then
|
|
||||||
"amd64"
|
|
||||||
else
|
|
||||||
throw "openjdk requires i686-linux or x86_64 linux";
|
|
||||||
|
|
||||||
update = "111";
|
|
||||||
|
|
||||||
build = "01";
|
|
||||||
|
|
||||||
# On x86 for heap sizes over 700MB disable SEGMEXEC and PAGEEXEC as well.
|
|
||||||
paxflags = if stdenv.isi686 then "msp" else "m";
|
|
||||||
|
|
||||||
baseurl = "http://hg.openjdk.java.net/jdk7u/jdk7u";
|
|
||||||
repover = "jdk7u${update}-b${build}";
|
|
||||||
jdk7 = fetchurl {
|
|
||||||
url = "${baseurl}/archive/${repover}.tar.gz";
|
|
||||||
sha256 = "0wgb7hr2gipx1jg28fnsjh7xa744sh1mgr6z3xivmnsfy3dm91gi";
|
|
||||||
};
|
|
||||||
langtools = fetchurl {
|
|
||||||
url = "${baseurl}/langtools/archive/${repover}.tar.gz";
|
|
||||||
sha256 = "0x1xs923h6sma02cbp1whg735x8vcndh5k01b7rkf714g6rxwa0y";
|
|
||||||
};
|
|
||||||
hotspot = fetchurl {
|
|
||||||
url = "${baseurl}/hotspot/archive/${repover}.tar.gz";
|
|
||||||
sha256 = "187apnsvnd4cfa7ss5g59dbh7x5ah8f1lwa2wvjfv055h2cmphpn";
|
|
||||||
};
|
|
||||||
corba = fetchurl {
|
|
||||||
url = "${baseurl}/corba/archive/${repover}.tar.gz";
|
|
||||||
sha256 = "0vmxf5sgjcmkm7i1scanaa2x75a1byj8b36vcajlr6j7qmdx6r8c";
|
|
||||||
};
|
|
||||||
jdk = fetchurl {
|
|
||||||
url = "${baseurl}/jdk/archive/${repover}.tar.gz";
|
|
||||||
sha256 = "1f8f2dgrjhx8aw1gzawrf8qggf5j0dygsla08bbsxhx5mc5a6cka";
|
|
||||||
};
|
|
||||||
jaxws = fetchurl {
|
|
||||||
url = "${baseurl}/jaxws/archive/${repover}.tar.gz";
|
|
||||||
sha256 = "03982ajxm0hzany1jg009ym84vryx7a8qfi6wcgjxyxvk8vnz37c";
|
|
||||||
};
|
|
||||||
jaxp = fetchurl {
|
|
||||||
url = "${baseurl}/jaxp/archive/${repover}.tar.gz";
|
|
||||||
sha256 = "0578h04y1ha60yjplsa8lqdjds9s2lxzgs9ybm9rs1rqzxmm0xmy";
|
|
||||||
};
|
|
||||||
openjdk = stdenv.mkDerivation rec {
|
|
||||||
name = "openjdk-7u${update}b${build}";
|
|
||||||
|
|
||||||
srcs = [ jdk7 langtools hotspot corba jdk jaxws jaxp ];
|
|
||||||
sourceRoot = ".";
|
|
||||||
|
|
||||||
outputs = [ "out" "jre" ];
|
|
||||||
|
|
||||||
buildInputs =
|
|
||||||
[ unzip procps ant which zip cpio nettools alsaLib
|
|
||||||
xorg.libX11 xorg.libXt xorg.libXext xorg.libXrender xorg.libXtst
|
|
||||||
xorg.libXi xorg.libXinerama xorg.libXcursor xorg.lndir
|
|
||||||
fontconfig perl file bootjdk
|
|
||||||
];
|
|
||||||
|
|
||||||
NIX_CFLAGS_COMPILE = [
|
|
||||||
"-Wno-error=deprecated-declarations"
|
|
||||||
"-Wno-error=format-overflow" # newly detected by gcc7
|
|
||||||
];
|
|
||||||
|
|
||||||
NIX_LDFLAGS = if minimal then null else "-lfontconfig -lXcursor -lXinerama";
|
|
||||||
|
|
||||||
postUnpack = ''
|
|
||||||
ls | grep jdk | grep -v '^jdk7u' | awk -F- '{print $1}' | while read p; do
|
|
||||||
mv $p-* $(ls | grep '^jdk7u')/$p
|
|
||||||
done
|
|
||||||
cd jdk7u-*
|
|
||||||
|
|
||||||
sed -i -e "s@/usr/bin/test@${coreutils}/bin/test@" \
|
|
||||||
-e "s@/bin/ls@${coreutils}/bin/ls@" \
|
|
||||||
hotspot/make/linux/makefiles/sa.make
|
|
||||||
|
|
||||||
sed -i "s@/bin/echo -e@${coreutils}/bin/echo -e@" \
|
|
||||||
{jdk,corba}/make/common/shared/Defs-utils.gmk
|
|
||||||
|
|
||||||
tar xf ${cups.src}
|
|
||||||
cupsDir=$(echo $(pwd)/cups-*)
|
|
||||||
makeFlagsArray+=(CUPS_HEADERS_PATH=$cupsDir)
|
|
||||||
'';
|
|
||||||
|
|
||||||
patches = [
|
|
||||||
./cppflags-include-fix.patch
|
|
||||||
./fix-java-home.patch
|
|
||||||
./paxctl.patch
|
|
||||||
./read-truststore-from-env.patch
|
|
||||||
./currency-date-range.patch
|
|
||||||
];
|
|
||||||
|
|
||||||
NIX_NO_SELF_RPATH = true;
|
|
||||||
|
|
||||||
makeFlags = [
|
|
||||||
"SORT=${coreutils}/bin/sort"
|
|
||||||
"ALSA_INCLUDE=${alsaLib.dev}/include/alsa/version.h"
|
|
||||||
"FREETYPE_HEADERS_PATH=${freetype.dev}/include"
|
|
||||||
"FREETYPE_LIB_PATH=${freetype.out}/lib"
|
|
||||||
"MILESTONE=${update}"
|
|
||||||
"BUILD_NUMBER=b${build}"
|
|
||||||
"USRBIN_PATH="
|
|
||||||
"COMPILER_PATH="
|
|
||||||
"DEVTOOLS_PATH="
|
|
||||||
"UNIXCOMMAND_PATH="
|
|
||||||
"BOOTDIR=${bootjdk.home}"
|
|
||||||
"STATIC_CXX=false"
|
|
||||||
"UNLIMITED_CRYPTO=1"
|
|
||||||
"FULL_DEBUG_SYMBOLS=0"
|
|
||||||
] ++ stdenv.lib.optional minimal "BUILD_HEADLESS=1";
|
|
||||||
|
|
||||||
configurePhase = "true";
|
|
||||||
|
|
||||||
preBuild = ''
|
|
||||||
# We also need to PaX-mark in the middle of the build
|
|
||||||
substituteInPlace hotspot/make/linux/makefiles/launcher.make \
|
|
||||||
--replace XXX_PAXFLAGS_XXX ${paxflags}
|
|
||||||
substituteInPlace jdk/make/common/Program.gmk \
|
|
||||||
--replace XXX_PAXFLAGS_XXX ${paxflags}
|
|
||||||
'';
|
|
||||||
|
|
||||||
installPhase = ''
|
|
||||||
mkdir -p $out/lib/openjdk $out/share $jre/lib/openjdk
|
|
||||||
|
|
||||||
cp -av build/*/j2sdk-image/* $out/lib/openjdk
|
|
||||||
|
|
||||||
# Move some stuff to top-level.
|
|
||||||
mv $out/lib/openjdk/include $out/include
|
|
||||||
mv $out/lib/openjdk/man $out/share/man
|
|
||||||
|
|
||||||
# jni.h expects jni_md.h to be in the header search path.
|
|
||||||
ln -s $out/include/linux/*_md.h $out/include/
|
|
||||||
|
|
||||||
# Remove some broken manpages.
|
|
||||||
rm -rf $out/share/man/ja*
|
|
||||||
|
|
||||||
# Remove crap from the installation.
|
|
||||||
rm -rf $out/lib/openjdk/demo $out/lib/openjdk/sample
|
|
||||||
|
|
||||||
# Move the JRE to a separate output.
|
|
||||||
mv $out/lib/openjdk/jre $jre/lib/openjdk/
|
|
||||||
mkdir $out/lib/openjdk/jre
|
|
||||||
lndir $jre/lib/openjdk/jre $out/lib/openjdk/jre
|
|
||||||
|
|
||||||
rm -rf $out/lib/openjdk/jre/bin
|
|
||||||
ln -s $out/lib/openjdk/bin $out/lib/openjdk/jre/bin
|
|
||||||
|
|
||||||
# Set PaX markings
|
|
||||||
exes=$(file $out/lib/openjdk/bin/* $jre/lib/openjdk/jre/bin/* 2> /dev/null | grep -E 'ELF.*(executable|shared object)' | sed -e 's/: .*$//')
|
|
||||||
echo "to mark: *$exes*"
|
|
||||||
for file in $exes; do
|
|
||||||
echo "marking *$file*"
|
|
||||||
paxmark ${paxflags} "$file"
|
|
||||||
done
|
|
||||||
|
|
||||||
# Remove duplicate binaries.
|
|
||||||
for i in $(cd $out/lib/openjdk/bin && echo *); do
|
|
||||||
if [ "$i" = java ]; then continue; fi
|
|
||||||
if cmp -s $out/lib/openjdk/bin/$i $jre/lib/openjdk/jre/bin/$i; then
|
|
||||||
ln -sfn $jre/lib/openjdk/jre/bin/$i $out/lib/openjdk/bin/$i
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# Generate certificates.
|
|
||||||
pushd $jre/lib/openjdk/jre/lib/security
|
|
||||||
rm cacerts
|
|
||||||
perl ${./generate-cacerts.pl} $jre/lib/openjdk/jre/bin/keytool ${cacert}/etc/ssl/certs/ca-bundle.crt
|
|
||||||
popd
|
|
||||||
|
|
||||||
ln -s $out/lib/openjdk/bin $out/bin
|
|
||||||
ln -s $jre/lib/openjdk/jre/bin $jre/bin
|
|
||||||
''; # */
|
|
||||||
|
|
||||||
# FIXME: this is unnecessary once the multiple-outputs branch is merged.
|
|
||||||
preFixup = ''
|
|
||||||
prefix=$jre stripDirs "$stripDebugList" "''${stripDebugFlags:--S}"
|
|
||||||
patchELF $jre
|
|
||||||
propagatedBuildInputs+=" $jre"
|
|
||||||
|
|
||||||
# Propagate the setJavaClassPath setup hook from the JRE so that
|
|
||||||
# any package that depends on the JRE has $CLASSPATH set up
|
|
||||||
# properly.
|
|
||||||
mkdir -p $jre/nix-support
|
|
||||||
printWords ${setJavaClassPath} > $jre/nix-support/propagated-build-inputs
|
|
||||||
|
|
||||||
# Set JAVA_HOME automatically.
|
|
||||||
mkdir -p $out/nix-support
|
|
||||||
cat <<EOF > $out/nix-support/setup-hook
|
|
||||||
if [ -z "\$JAVA_HOME" ]; then export JAVA_HOME=$out/lib/openjdk; fi
|
|
||||||
EOF
|
|
||||||
'';
|
|
||||||
|
|
||||||
postFixup = ''
|
|
||||||
# Build the set of output library directories to rpath against
|
|
||||||
LIBDIRS=""
|
|
||||||
for output in $outputs; do
|
|
||||||
LIBDIRS="$(find $(eval echo \$$output) -name \*.so\* -exec dirname {} \; | sort | uniq | tr '\n' ':'):$LIBDIRS"
|
|
||||||
done
|
|
||||||
|
|
||||||
# Add the local library paths to remove dependencies on the bootstrap
|
|
||||||
for output in $outputs; do
|
|
||||||
OUTPUTDIR="$(eval echo \$$output)"
|
|
||||||
BINLIBS="$(find $OUTPUTDIR/bin/ -type f; find $OUTPUTDIR -name \*.so\*)"
|
|
||||||
echo "$BINLIBS" | while read i; do
|
|
||||||
patchelf --set-rpath "$LIBDIRS:$(patchelf --print-rpath "$i")" "$i" || true
|
|
||||||
patchelf --shrink-rpath "$i" || true
|
|
||||||
done
|
|
||||||
done
|
|
||||||
|
|
||||||
# Test to make sure that we don't depend on the bootstrap
|
|
||||||
for output in $outputs; do
|
|
||||||
if grep -q -r '${bootjdk}' $(eval echo \$$output); then
|
|
||||||
echo "Extraneous references to ${bootjdk} detected"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
'';
|
|
||||||
|
|
||||||
meta = {
|
|
||||||
homepage = http://openjdk.java.net/;
|
|
||||||
license = stdenv.lib.licenses.gpl2;
|
|
||||||
description = "The open-source Java Development Kit";
|
|
||||||
maintainers = [ stdenv.lib.maintainers.eelco ];
|
|
||||||
platforms = stdenv.lib.platforms.linux;
|
|
||||||
};
|
|
||||||
|
|
||||||
passthru = {
|
|
||||||
inherit architecture;
|
|
||||||
home = "${openjdk}/lib/openjdk";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
in openjdk
|
|
@ -19,11 +19,6 @@ let
|
|||||||
url = "https://www.dropbox.com/s/a0lsq2ig4uguky5/openjdk8-bootstrap-x86_64-linux.tar.xz?dl=1";
|
url = "https://www.dropbox.com/s/a0lsq2ig4uguky5/openjdk8-bootstrap-x86_64-linux.tar.xz?dl=1";
|
||||||
sha256 = "18zqx6jhm3lizn9hh6ryyqc9dz3i96pwaz8f6nxfllk70qi5gvks";
|
sha256 = "18zqx6jhm3lizn9hh6ryyqc9dz3i96pwaz8f6nxfllk70qi5gvks";
|
||||||
}
|
}
|
||||||
else if version == "7" then
|
|
||||||
fetchurl {
|
|
||||||
url = "https://www.dropbox.com/s/rssfbeommrfbsjf/openjdk7-bootstrap-x86_64-linux.tar.xz?dl=1";
|
|
||||||
sha256 = "024gg2sgg4labxbc1nhn8lxls2p7d9h3b82hnsahwaja2pm1hbra";
|
|
||||||
}
|
|
||||||
else throw "No bootstrap for version")
|
else throw "No bootstrap for version")
|
||||||
else if stdenv.hostPlatform.system == "i686-linux" then
|
else if stdenv.hostPlatform.system == "i686-linux" then
|
||||||
(if version == "10" then
|
(if version == "10" then
|
||||||
@ -36,11 +31,6 @@ let
|
|||||||
url = "https://www.dropbox.com/s/rneqjhlerijsw74/openjdk8-bootstrap-i686-linux.tar.xz?dl=1";
|
url = "https://www.dropbox.com/s/rneqjhlerijsw74/openjdk8-bootstrap-i686-linux.tar.xz?dl=1";
|
||||||
sha256 = "1yx04xh8bqz7amg12d13rw5vwa008rav59mxjw1b9s6ynkvfgqq9";
|
sha256 = "1yx04xh8bqz7amg12d13rw5vwa008rav59mxjw1b9s6ynkvfgqq9";
|
||||||
}
|
}
|
||||||
else if version == "7" then
|
|
||||||
fetchurl {
|
|
||||||
url = "https://www.dropbox.com/s/6xe64td7eg2wurs/openjdk7-bootstrap-i686-linux.tar.xz?dl=1";
|
|
||||||
sha256 = "0xwqjk1zx8akziw8q9sbjc1rs8s7c0w6mw67jdmmi26cwwp8ijnx";
|
|
||||||
}
|
|
||||||
else throw "No bootstrap for version")
|
else throw "No bootstrap for version")
|
||||||
else throw "No bootstrap for system";
|
else throw "No bootstrap for system";
|
||||||
|
|
||||||
|
@ -6325,10 +6325,6 @@ with pkgs;
|
|||||||
|
|
||||||
gwt240 = callPackage ../development/compilers/gwt/2.4.0.nix { };
|
gwt240 = callPackage ../development/compilers/gwt/2.4.0.nix { };
|
||||||
|
|
||||||
icedtea7_web = callPackage ../development/compilers/icedtea-web {
|
|
||||||
jdk = jdk7;
|
|
||||||
};
|
|
||||||
|
|
||||||
icedtea8_web = callPackage ../development/compilers/icedtea-web {
|
icedtea8_web = callPackage ../development/compilers/icedtea-web {
|
||||||
jdk = jdk8;
|
jdk = jdk8;
|
||||||
};
|
};
|
||||||
@ -6366,15 +6362,6 @@ with pkgs;
|
|||||||
|
|
||||||
hugs = callPackage ../development/interpreters/hugs { };
|
hugs = callPackage ../development/interpreters/hugs { };
|
||||||
|
|
||||||
openjdk7 =
|
|
||||||
if stdenv.isDarwin then
|
|
||||||
callPackage ../development/compilers/openjdk-darwin { }
|
|
||||||
else
|
|
||||||
callPackage ../development/compilers/openjdk/7.nix {
|
|
||||||
ant = apacheAnt_1_9;
|
|
||||||
bootjdk = callPackage ../development/compilers/openjdk/bootstrap.nix { version = "7"; };
|
|
||||||
};
|
|
||||||
|
|
||||||
openjdk8 =
|
openjdk8 =
|
||||||
if stdenv.isDarwin then
|
if stdenv.isDarwin then
|
||||||
callPackage ../development/compilers/openjdk-darwin/8.nix { }
|
callPackage ../development/compilers/openjdk-darwin/8.nix { }
|
||||||
@ -6392,11 +6379,6 @@ with pkgs;
|
|||||||
|
|
||||||
openjdk = openjdk8;
|
openjdk = openjdk8;
|
||||||
|
|
||||||
jdk7 = openjdk7 // { outputs = [ "out" ]; };
|
|
||||||
jre7 = lib.setName "openjre-${lib.getVersion pkgs.openjdk7.jre}"
|
|
||||||
(lib.addMetaAttrs { outputsToInstall = [ "jre" ]; }
|
|
||||||
(openjdk7.jre // { outputs = [ "jre" ]; }));
|
|
||||||
|
|
||||||
jdk8 = if stdenv.isArm || stdenv.isAarch64 then oraclejdk8 else openjdk8 // { outputs = [ "out" ]; };
|
jdk8 = if stdenv.isArm || stdenv.isAarch64 then oraclejdk8 else openjdk8 // { outputs = [ "out" ]; };
|
||||||
jre8 = if stdenv.isArm || stdenv.isAarch64 then oraclejre8 else lib.setName "openjre-${lib.getVersion pkgs.openjdk8.jre}"
|
jre8 = if stdenv.isArm || stdenv.isAarch64 then oraclejre8 else lib.setName "openjre-${lib.getVersion pkgs.openjdk8.jre}"
|
||||||
(lib.addMetaAttrs { outputsToInstall = [ "jre" ]; }
|
(lib.addMetaAttrs { outputsToInstall = [ "jre" ]; }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user