-
-
Notifications
You must be signed in to change notification settings - Fork 14.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
WIP: openjdk: 11.0.2 -> 12
- Loading branch information
Showing
7 changed files
with
345 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,171 @@ | ||
{ stdenv, lib, fetchurl, bash, cpio, autoconf, pkgconfig, file, which, unzip, zip, cups, freetype | ||
, alsaLib, bootjdk, perl, liberation_ttf, fontconfig, zlib, lndir | ||
, libX11, libICE, libXrender, libXext, libXt, libXtst, libXi, libXinerama, libXcursor, libXrandr | ||
, libjpeg, giflib | ||
, setJavaClassPath | ||
, minimal ? false | ||
, enableJavaFX ? true, openjfx | ||
, enableGnome2 ? true, gtk3, gnome_vfs, glib, GConf | ||
}: | ||
|
||
let | ||
|
||
/** | ||
* The JDK libraries are in directories that depend on the CPU. | ||
*/ | ||
architecture = | ||
if stdenv.hostPlatform.system == "i686-linux" then | ||
"i386" | ||
else "amd64"; | ||
|
||
major = "12"; | ||
update = ".0.2"; | ||
build = "ga"; | ||
repover = "jdk-${major}${update}-${build}"; | ||
|
||
openjdk = stdenv.mkDerivation { | ||
name = "openjdk-${major}${update}-${build}"; | ||
|
||
src = fetchurl { | ||
url = "http://hg.openjdk.java.net/jdk-updates/jdk${major}u/archive/${repover}.tar.gz"; | ||
sha256 = "1ndlxmikyy298z7lqpr1bd0zxq7yx6xidj8y3c8mw9m9fy64h9c7"; | ||
}; | ||
|
||
nativeBuildInputs = [ pkgconfig ]; | ||
buildInputs = [ | ||
autoconf cpio file which unzip zip perl bootjdk zlib cups freetype alsaLib | ||
libjpeg giflib libX11 libICE libXext libXrender libXtst libXt libXtst | ||
libXi libXinerama libXcursor libXrandr lndir fontconfig | ||
] ++ lib.optionals (!minimal && enableGnome2) [ | ||
gtk3 gnome_vfs GConf glib | ||
]; | ||
|
||
patches = [ | ||
./fix-java-home-jdk10.patch | ||
./read-truststore-from-env-jdk10.patch | ||
./currency-date-range-jdk10.patch | ||
./increase-javadoc-heap.patch | ||
# -Wformat etc. are stricter in newer gccs, per | ||
# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=79677 | ||
# so grab the work-around from | ||
# https://src.fedoraproject.org/rpms/java-openjdk/pull-request/24 | ||
(fetchurl { | ||
url = https://src.fedoraproject.org/rpms/java-openjdk/raw/06c001c7d87f2e9fe4fedeef2d993bcd5d7afa2a/f/rh1673833-remove_removal_of_wformat_during_test_compilation.patch; | ||
sha256 = "082lmc30x64x583vqq00c8y0wqih3y4r0mp1c4bqq36l22qv6b6r"; | ||
}) | ||
] ++ lib.optionals (!minimal && enableGnome2) [ | ||
./swing-use-gtk-jdk10.patch | ||
]; | ||
|
||
preConfigure = '' | ||
chmod +x configure | ||
substituteInPlace configure --replace /bin/bash "${bash}/bin/bash" | ||
configureFlagsArray=( | ||
"--with-boot-jdk=${bootjdk.home}" | ||
"--enable-unlimited-crypto" | ||
"--with-zlib=system" | ||
"--with-giflib=system" | ||
"--with-stdc++lib=dynamic" | ||
# glibc 2.24 deprecated readdir_r so we need this | ||
# See https://www.mail-archive.com/[email protected]/msg49006.html | ||
"--with-extra-cflags=-Wno-error=deprecated-declarations -Wno-error=unused-result" | ||
'' | ||
+ lib.optionalString (architecture == "amd64") " \"--with-jvm-features=zgc\"" | ||
+ lib.optionalString minimal " \"--enable-headless-only\"" | ||
+ lib.optionalString (!minimal && enableJavaFX) " \"--with-import-modules=${openjfx}\"" | ||
+ ");" | ||
# https://bugzilla.redhat.com/show_bug.cgi?id=1306558 | ||
# https://github.com/JetBrains/jdk8u/commit/eaa5e0711a43d64874111254d74893fa299d5716 | ||
+ stdenv.lib.optionalString stdenv.cc.isGNU '' | ||
NIX_CFLAGS_COMPILE+=" -fno-lifetime-dse -fno-delete-null-pointer-checks -std=gnu++98 -Wno-error" | ||
''; | ||
|
||
NIX_LDFLAGS= lib.optionals (!minimal) [ | ||
"-lfontconfig" "-lcups" "-lXinerama" "-lXrandr" "-lmagic" | ||
] ++ lib.optionals (!minimal && enableGnome2) [ | ||
"-lgtk-3" "-lgio-2.0" "-lgnomevfs-2" "-lgconf-2" | ||
]; | ||
|
||
buildFlags = [ "all" ]; | ||
|
||
installPhase = '' | ||
mkdir -p $out/lib/openjdk $out/share | ||
cp -av build/*/images/jdk/* $out/lib/openjdk | ||
# Remove some broken manpages. | ||
rm -rf $out/lib/openjdk/man/ja* | ||
# Mirror some stuff in top-level. | ||
mkdir $out/include $out/share/man | ||
ln -s $out/lib/openjdk/include/* $out/include/ | ||
ln -s $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 crap from the installation. | ||
rm -rf $out/lib/openjdk/demo | ||
${lib.optionalString minimal '' | ||
rm $out/lib/openjdk/lib/{libjsound,libfontmanager}.so | ||
''} | ||
ln -s $out/lib/openjdk/bin $out/bin | ||
''; | ||
|
||
preFixup = '' | ||
# Propagate the setJavaClassPath setup hook so that any package | ||
# that depends on the JDK has $CLASSPATH set up properly. | ||
mkdir -p $out/nix-support | ||
#TODO or printWords? cf https://github.com/NixOS/nixpkgs/pull/27427#issuecomment-317293040 | ||
echo -n "${setJavaClassPath}" > $out/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 = with stdenv.lib; { | ||
homepage = http://openjdk.java.net/; | ||
license = licenses.gpl2; | ||
description = "The open-source Java Development Kit"; | ||
maintainers = with maintainers; [ edwtjo ]; | ||
platforms = ["i686-linux" "x86_64-linux"]; | ||
}; | ||
|
||
passthru = { | ||
inherit architecture; | ||
home = "${openjdk}/lib/openjdk"; | ||
}; | ||
}; | ||
in openjdk |
12 changes: 12 additions & 0 deletions
12
pkgs/development/compilers/openjdk/increase-javadoc-heap.patch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
--- a/make/Docs.gmk 2019-07-24 13:07:37.013405090 -0400 | ||
+++ b/make/Docs.gmk 2019-07-24 13:07:28.406550535 -0400 | ||
@@ -274,7 +274,7 @@ | ||
$1_INDIRECT_EXPORTS := $$(call FindTransitiveIndirectDepsForModules, $$($1_MODULES)) | ||
$1_ALL_MODULES := $$(sort $$($1_MODULES) $$($1_INDIRECT_EXPORTS)) | ||
|
||
- $1_JAVA_ARGS := -Dextlink.spec.version=$$(VERSION_SPECIFICATION) | ||
+ $1_JAVA_ARGS := -Dextlink.spec.version=$$(VERSION_SPECIFICATION) -Xmx1G | ||
|
||
ifeq ($$(ENABLE_FULL_DOCS), true) | ||
# Tell the ModuleGraph taglet to generate html links to soon-to-be-created | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,110 @@ | ||
{ stdenv, fetchurl, writeText, openjdk, bootjdk, gradleGen, pkgconfig, perl, cmake, gperf | ||
, gtk2, gtk3, libXtst, libXxf86vm, glib, alsaLib, ffmpeg, python, ruby }: | ||
|
||
let | ||
major = "12"; | ||
update = ""; | ||
build = "14"; | ||
repover = "${major}${update}+${build}"; | ||
gradle_ = (gradleGen.override { | ||
jdk = bootjdk; | ||
}).gradle_4_10; | ||
|
||
makePackage = args: stdenv.mkDerivation ({ | ||
version = "${major}${update}-${repover}"; | ||
|
||
src = fetchurl { | ||
url = "http://hg.openjdk.java.net/openjfx/${major}-dev/rt/archive/${repover}.tar.gz"; | ||
sha256 = "16jjfjkrg57wsj9mmm52i2kl3byz3ba1f9f8wwc8zwqm4cpjzliz"; | ||
}; | ||
|
||
buildInputs = [ gtk2 gtk3 libXtst libXxf86vm glib alsaLib ffmpeg ]; | ||
nativeBuildInputs = [ gradle_ perl pkgconfig cmake gperf python ruby ]; | ||
|
||
dontUseCmakeConfigure = true; | ||
|
||
config = writeText "gradle.properties" ('' | ||
CONF = Release | ||
JDK_HOME = ${bootjdk}/lib/openjdk | ||
'' + args.gradleProperties or ""); | ||
|
||
buildPhase = '' | ||
runHook preBuild | ||
export GRADLE_USER_HOME=$(mktemp -d) | ||
ln -s $config gradle.properties | ||
export NIX_CFLAGS_COMPILE="$(pkg-config --cflags glib-2.0) $NIX_CFLAGS_COMPILE" | ||
gradle --no-daemon $gradleFlags sdk | ||
runHook postBuild | ||
''; | ||
} // args); | ||
|
||
# Fake build to pre-download deps into fixed-output derivation. | ||
# We run nearly full build because I see no other way to download everything that's needed. | ||
# Anyone who knows a better way? | ||
deps = makePackage { | ||
pname = "openjfx-deps"; | ||
|
||
# perl code mavenizes pathes (com.squareup.okio/okio/1.13.0/a9283170b7305c8d92d25aff02a6ab7e45d06cbe/okio-1.13.0.jar -> com/squareup/okio/okio/1.13.0/okio-1.13.0.jar) | ||
installPhase = '' | ||
find $GRADLE_USER_HOME -type f -regex '.*/modules.*\.\(jar\|pom\)' \ | ||
| perl -pe 's#(.*/([^/]+)/([^/]+)/([^/]+)/[0-9a-f]{30,40}/([^/\s]+))$# ($x = $2) =~ tr|\.|/|; "install -Dm444 $1 \$out/$x/$3/$4/$5" #e' \ | ||
| sh | ||
rm -rf $out/tmp | ||
''; | ||
|
||
outputHashAlgo = "sha256"; | ||
outputHashMode = "recursive"; | ||
outputHash = | ||
# Downloaded AWT jars differ by platform. | ||
if stdenv.system == "x86_64-linux" then "1z5qar5l28ja4pkf5l5m48xbv3x1yrnilsv9lpf2j3vkdk9h1nci" | ||
else if stdenv.system == "i686-linux" then "0rbygvjc7w197fi5nxldqdrm6mpiyd3n45042g3gd4s5qk08spjd" | ||
else throw "Unsupported platform"; | ||
}; | ||
|
||
in makePackage { | ||
pname = "openjfx-modular-sdk"; | ||
|
||
gradleProperties = '' | ||
COMPILE_MEDIA = true | ||
COMPILE_WEBKIT = true | ||
''; | ||
|
||
preBuild = '' | ||
swtJar="$(find ${deps} -name org.eclipse.swt\*.jar)" | ||
substituteInPlace build.gradle \ | ||
--replace 'mavenCentral()' 'mavenLocal(); maven { url uri("${deps}") }' \ | ||
--replace 'name: SWT_FILE_NAME' "files('$swtJar')" | ||
''; | ||
|
||
installPhase = '' | ||
cp -r build/modular-sdk $out | ||
''; | ||
|
||
stripDebugList = [ "." ]; | ||
|
||
postFixup = '' | ||
# Remove references to bootstrap. | ||
find "$out" -name \*.so | while read lib; do | ||
new_refs="$(patchelf --print-rpath "$lib" | sed -E 's,:?${bootjdk}[^:]*,,')" | ||
patchelf --set-rpath "$new_refs" "$lib" | ||
done | ||
# Test to make sure that we don't depend on the bootstrap | ||
if grep -q -r '${bootjdk}' "$out"; then | ||
echo "Extraneous references to ${bootjdk} detected" >&2 | ||
exit 1 | ||
fi | ||
''; | ||
|
||
passthru.deps = deps; | ||
|
||
meta = with stdenv.lib; { | ||
homepage = http://openjdk.java.net/projects/openjfx/; | ||
license = openjdk.meta.license; | ||
description = "The next-generation Java client toolkit."; | ||
maintainers = with maintainers; [ abbradar ]; | ||
platforms = openjdk.meta.platforms; | ||
}; | ||
} |
Oops, something went wrong.