Merge pull request #107784 from taku0/jdk_gtk_look_and_feel
This commit is contained in:
commit
05b0e49fd9
4 changed files with 210 additions and 80 deletions
|
@ -4,16 +4,31 @@ sourcePerArch:
|
||||||
, lib
|
, lib
|
||||||
, fetchurl
|
, fetchurl
|
||||||
, autoPatchelfHook
|
, autoPatchelfHook
|
||||||
|
, makeWrapper
|
||||||
|
# minimum dependencies
|
||||||
, alsaLib
|
, alsaLib
|
||||||
, freetype
|
|
||||||
, fontconfig
|
, fontconfig
|
||||||
, zlib
|
, freetype
|
||||||
, xorg
|
|
||||||
, libffi
|
, libffi
|
||||||
|
, xorg
|
||||||
|
, zlib
|
||||||
|
# runtime dependencies
|
||||||
|
, cups
|
||||||
|
# runtime dependencies for GTK+ Look and Feel
|
||||||
|
, gtkSupport ? true
|
||||||
|
, cairo
|
||||||
|
, glib
|
||||||
|
, gtk3
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
cpuName = stdenv.hostPlatform.parsed.cpu.name;
|
cpuName = stdenv.hostPlatform.parsed.cpu.name;
|
||||||
|
runtimeDependencies = [
|
||||||
|
cups
|
||||||
|
] ++ lib.optionals gtkSupport [
|
||||||
|
cairo glib gtk3
|
||||||
|
];
|
||||||
|
runtimeLibraryPath = lib.makeLibraryPath runtimeDependencies;
|
||||||
in
|
in
|
||||||
|
|
||||||
let result = stdenv.mkDerivation rec {
|
let result = stdenv.mkDerivation rec {
|
||||||
|
@ -28,11 +43,19 @@ let result = stdenv.mkDerivation rec {
|
||||||
};
|
};
|
||||||
|
|
||||||
buildInputs = [
|
buildInputs = [
|
||||||
alsaLib freetype fontconfig zlib xorg.libX11 xorg.libXext xorg.libXtst
|
alsaLib # libasound.so wanted by lib/libjsound.so
|
||||||
xorg.libXi xorg.libXrender stdenv.cc.cc.lib
|
fontconfig
|
||||||
|
freetype
|
||||||
|
stdenv.cc.cc.lib # libstdc++.so.6
|
||||||
|
xorg.libX11
|
||||||
|
xorg.libXext
|
||||||
|
xorg.libXi
|
||||||
|
xorg.libXrender
|
||||||
|
xorg.libXtst
|
||||||
|
zlib
|
||||||
] ++ lib.optional stdenv.isAarch32 libffi;
|
] ++ lib.optional stdenv.isAarch32 libffi;
|
||||||
|
|
||||||
nativeBuildInputs = [ autoPatchelfHook ];
|
nativeBuildInputs = [ autoPatchelfHook makeWrapper ];
|
||||||
|
|
||||||
# See: https://github.com/NixOS/patchelf/issues/10
|
# See: https://github.com/NixOS/patchelf/issues/10
|
||||||
dontStrip = 1;
|
dontStrip = 1;
|
||||||
|
@ -57,6 +80,13 @@ let result = stdenv.mkDerivation rec {
|
||||||
cat <<EOF >> "$out/nix-support/setup-hook"
|
cat <<EOF >> "$out/nix-support/setup-hook"
|
||||||
if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi
|
if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
# We cannot use -exec since wrapProgram is a function but not a command.
|
||||||
|
for bin in $( find "$out" -executable -type f ); do
|
||||||
|
if patchelf --print-interpreter "$bin" &> /dev/null; then
|
||||||
|
wrapProgram "$bin" --prefix LD_LIBRARY_PATH : "${runtimeLibraryPath}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
'';
|
'';
|
||||||
|
|
||||||
preFixup = ''
|
preFixup = ''
|
||||||
|
|
|
@ -1,7 +1,37 @@
|
||||||
{ lib, stdenv, fetchurl, perl, unzip, glibc, zlib, setJavaClassPath, Foundation, openssl }:
|
{ stdenv
|
||||||
|
, lib
|
||||||
|
, fetchurl
|
||||||
|
, autoPatchelfHook
|
||||||
|
, setJavaClassPath
|
||||||
|
, makeWrapper
|
||||||
|
# minimum dependencies
|
||||||
|
, Foundation
|
||||||
|
, alsaLib
|
||||||
|
, fontconfig
|
||||||
|
, freetype
|
||||||
|
, glibc
|
||||||
|
, openssl
|
||||||
|
, perl
|
||||||
|
, unzip
|
||||||
|
, xorg
|
||||||
|
, zlib
|
||||||
|
# runtime dependencies
|
||||||
|
, cups
|
||||||
|
# runtime dependencies for GTK+ Look and Feel
|
||||||
|
, gtkSupport ? true
|
||||||
|
, cairo
|
||||||
|
, glib
|
||||||
|
, gtk3
|
||||||
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
platform = if stdenv.isDarwin then "darwin-amd64" else "linux-amd64";
|
platform = if stdenv.isDarwin then "darwin-amd64" else "linux-amd64";
|
||||||
|
runtimeDependencies = [
|
||||||
|
cups
|
||||||
|
] ++ lib.optionals gtkSupport [
|
||||||
|
cairo glib gtk3
|
||||||
|
];
|
||||||
|
runtimeLibraryPath = lib.makeLibraryPath runtimeDependencies;
|
||||||
common = javaVersion:
|
common = javaVersion:
|
||||||
let
|
let
|
||||||
javaVersionPlatform = "${javaVersion}-${platform}";
|
javaVersionPlatform = "${javaVersion}-${platform}";
|
||||||
|
@ -50,7 +80,27 @@ let
|
||||||
url = "https://github.com/graalvm/graalvm-ce-builds/releases/download/vm-${version}/wasm-installable-svm-java${javaVersionPlatform}-${version}.jar";
|
url = "https://github.com/graalvm/graalvm-ce-builds/releases/download/vm-${version}/wasm-installable-svm-java${javaVersionPlatform}-${version}.jar";
|
||||||
})
|
})
|
||||||
];
|
];
|
||||||
nativeBuildInputs = [ unzip perl ];
|
|
||||||
|
buildInputs = lib.optionals stdenv.isLinux [
|
||||||
|
alsaLib # libasound.so wanted by lib/libjsound.so
|
||||||
|
fontconfig
|
||||||
|
freetype
|
||||||
|
openssl # libssl.so wanted by languages/ruby/lib/mri/openssl.so
|
||||||
|
stdenv.cc.cc.lib # libstdc++.so.6
|
||||||
|
xorg.libX11
|
||||||
|
xorg.libXext
|
||||||
|
xorg.libXi
|
||||||
|
xorg.libXrender
|
||||||
|
xorg.libXtst
|
||||||
|
zlib
|
||||||
|
];
|
||||||
|
|
||||||
|
# Workaround for libssl.so.10 wanted by TruffleRuby
|
||||||
|
# Resulting TruffleRuby cannot use `openssl` library.
|
||||||
|
autoPatchelfIgnoreMissingDeps = true;
|
||||||
|
|
||||||
|
nativeBuildInputs = [ unzip perl autoPatchelfHook makeWrapper ];
|
||||||
|
|
||||||
unpackPhase = ''
|
unpackPhase = ''
|
||||||
unpack_jar() {
|
unpack_jar() {
|
||||||
jar=$1
|
jar=$1
|
||||||
|
@ -136,32 +186,25 @@ let
|
||||||
|
|
||||||
dontStrip = true;
|
dontStrip = true;
|
||||||
|
|
||||||
# copy-paste openjdk's preFixup
|
|
||||||
preFixup = ''
|
preFixup = ''
|
||||||
|
# We cannot use -exec since wrapProgram is a function but not a
|
||||||
|
# command.
|
||||||
|
for bin in $( find "$out" -executable -type f -not -path '*/languages/ruby/lib/gems/*' ); do
|
||||||
|
if patchelf --print-interpreter "$bin" &> /dev/null || head -n 1 "$bin" | grep '^#!' -q; then
|
||||||
|
wrapProgram "$bin" \
|
||||||
|
--prefix LD_LIBRARY_PATH : "${runtimeLibraryPath}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# copy-paste openjdk's preFixup
|
||||||
# Set JAVA_HOME automatically.
|
# Set JAVA_HOME automatically.
|
||||||
mkdir -p $out/nix-support
|
mkdir -p $out/nix-support
|
||||||
cat <<EOF > $out/nix-support/setup-hook
|
cat <<EOF > $out/nix-support/setup-hook
|
||||||
if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi
|
if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi
|
||||||
EOF
|
EOF
|
||||||
'';
|
|
||||||
|
|
||||||
postFixup = ''
|
find "$out" -name libfontmanager.so -exec \
|
||||||
rpath="${ { "8" = "$out/jre/lib/amd64/jli:$out/jre/lib/amd64/server:$out/jre/lib/amd64:$out/jre/languages/ruby/lib/cext";
|
patchelf --add-needed libfontconfig.so {} \;
|
||||||
"11" = "$out/lib/jli:$out/lib/server:$out/lib:$out/languages/ruby/lib/cext";
|
|
||||||
}.${javaVersion}
|
|
||||||
}:${
|
|
||||||
lib.makeLibraryPath [
|
|
||||||
stdenv.cc.cc.lib # libstdc++.so.6
|
|
||||||
zlib # libz.so.1
|
|
||||||
]}"
|
|
||||||
|
|
||||||
${lib.optionalString stdenv.isLinux ''
|
|
||||||
for f in $(find $out -type f -perm -0100); do
|
|
||||||
patchelf --interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" "$f" || true
|
|
||||||
patchelf --set-rpath "$rpath" "$f" || true
|
|
||||||
if ldd "$f" | fgrep 'not found'; then echo "in file $f"; fi
|
|
||||||
done
|
|
||||||
''}
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
# $out/bin/native-image needs zlib to build native executables.
|
# $out/bin/native-image needs zlib to build native executables.
|
||||||
|
|
|
@ -1,7 +1,24 @@
|
||||||
{ stdenv, lib, fetchurl, unzip, makeWrapper, setJavaClassPath
|
{ stdenv
|
||||||
, zulu, glib, libxml2, ffmpeg_3, libxslt, libGL, alsaLib
|
, lib
|
||||||
, fontconfig, freetype, pango, gtk2, cairo, gdk-pixbuf, atk, xorg
|
, fetchurl
|
||||||
, swingSupport ? true }:
|
, autoPatchelfHook
|
||||||
|
, unzip
|
||||||
|
, makeWrapper
|
||||||
|
, setJavaClassPath
|
||||||
|
, zulu
|
||||||
|
# minimum dependencies
|
||||||
|
, alsaLib
|
||||||
|
, fontconfig
|
||||||
|
, freetype
|
||||||
|
, xorg
|
||||||
|
# runtime dependencies
|
||||||
|
, cups
|
||||||
|
# runtime dependencies for GTK+ Look and Feel
|
||||||
|
, gtkSupport ? stdenv.isLinux
|
||||||
|
, cairo
|
||||||
|
, glib
|
||||||
|
, gtk3
|
||||||
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
version = "8.48.0.53";
|
version = "8.48.0.53";
|
||||||
|
@ -14,14 +31,12 @@ let
|
||||||
hash = if stdenv.isDarwin then sha256_darwin else sha256_linux;
|
hash = if stdenv.isDarwin then sha256_darwin else sha256_linux;
|
||||||
extension = if stdenv.isDarwin then "zip" else "tar.gz";
|
extension = if stdenv.isDarwin then "zip" else "tar.gz";
|
||||||
|
|
||||||
libraries = [
|
runtimeDependencies = [
|
||||||
stdenv.cc.libc glib libxml2 ffmpeg_3 libxslt libGL
|
cups
|
||||||
xorg.libXxf86vm alsaLib fontconfig freetype pango
|
] ++ lib.optionals gtkSupport [
|
||||||
gtk2 cairo gdk-pixbuf atk
|
cairo glib gtk3
|
||||||
] ++ (lib.optionals swingSupport (with xorg; [
|
];
|
||||||
xorg.libX11 xorg.libXext xorg.libXtst xorg.libXi xorg.libXp
|
runtimeLibraryPath = lib.makeLibraryPath runtimeDependencies;
|
||||||
xorg.libXt xorg.libXrender stdenv.cc.cc
|
|
||||||
]));
|
|
||||||
|
|
||||||
in stdenv.mkDerivation {
|
in stdenv.mkDerivation {
|
||||||
inherit version openjdk platform hash extension;
|
inherit version openjdk platform hash extension;
|
||||||
|
@ -33,26 +48,28 @@ in stdenv.mkDerivation {
|
||||||
sha256 = hash;
|
sha256 = hash;
|
||||||
};
|
};
|
||||||
|
|
||||||
buildInputs = [ makeWrapper ] ++ lib.optional stdenv.isDarwin unzip;
|
buildInputs = lib.optionals stdenv.isLinux [
|
||||||
|
alsaLib # libasound.so wanted by lib/libjsound.so
|
||||||
|
fontconfig
|
||||||
|
freetype
|
||||||
|
stdenv.cc.cc # libstdc++.so.6
|
||||||
|
xorg.libX11
|
||||||
|
xorg.libXext
|
||||||
|
xorg.libXi
|
||||||
|
xorg.libXrender
|
||||||
|
xorg.libXtst
|
||||||
|
];
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
autoPatchelfHook makeWrapper
|
||||||
|
] ++ lib.optionals stdenv.isDarwin [
|
||||||
|
unzip
|
||||||
|
];
|
||||||
|
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
mkdir -p $out
|
mkdir -p $out
|
||||||
cp -r ./* "$out/"
|
cp -r ./* "$out/"
|
||||||
|
|
||||||
jrePath="$out/jre"
|
|
||||||
|
|
||||||
rpath=$rpath''${rpath:+:}$jrePath/lib/amd64/jli
|
|
||||||
rpath=$rpath''${rpath:+:}$jrePath/lib/amd64/server
|
|
||||||
rpath=$rpath''${rpath:+:}$jrePath/lib/amd64/xawt
|
|
||||||
rpath=$rpath''${rpath:+:}$jrePath/lib/amd64
|
|
||||||
|
|
||||||
# set all the dynamic linkers
|
|
||||||
find $out -type f -perm -0100 \
|
|
||||||
-exec patchelf --interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \
|
|
||||||
--set-rpath "$rpath" {} \;
|
|
||||||
|
|
||||||
find $out -name "*.so" -exec patchelf --set-rpath "$rpath" {} \;
|
|
||||||
|
|
||||||
mkdir -p $out/nix-support
|
mkdir -p $out/nix-support
|
||||||
printWords ${setJavaClassPath} > $out/nix-support/propagated-build-inputs
|
printWords ${setJavaClassPath} > $out/nix-support/propagated-build-inputs
|
||||||
|
|
||||||
|
@ -60,9 +77,19 @@ in stdenv.mkDerivation {
|
||||||
cat <<EOF >> $out/nix-support/setup-hook
|
cat <<EOF >> $out/nix-support/setup-hook
|
||||||
if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi
|
if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi
|
||||||
EOF
|
EOF
|
||||||
|
'' + lib.optionalString stdenv.isLinux ''
|
||||||
|
# We cannot use -exec since wrapProgram is a function but not a command.
|
||||||
|
for bin in $( find "$out" -executable -type f ); do
|
||||||
|
if patchelf --print-interpreter "$bin" &> /dev/null; then
|
||||||
|
wrapProgram "$bin" --prefix LD_LIBRARY_PATH : "${runtimeLibraryPath}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
'';
|
'';
|
||||||
|
|
||||||
rpath = lib.strings.makeLibraryPath libraries;
|
preFixup = ''
|
||||||
|
find "$out" -name libfontmanager.so -exec \
|
||||||
|
patchelf --add-needed libfontconfig.so {} \;
|
||||||
|
'';
|
||||||
|
|
||||||
passthru = {
|
passthru = {
|
||||||
home = zulu;
|
home = zulu;
|
||||||
|
|
|
@ -1,7 +1,25 @@
|
||||||
{ stdenv, lib, fetchurl, unzip, makeWrapper, setJavaClassPath
|
{ stdenv
|
||||||
, zulu, glib, libxml2, ffmpeg_3, libxslt, libGL, alsaLib
|
, lib
|
||||||
, fontconfig, freetype, pango, gtk2, cairo, gdk-pixbuf, atk, xorg, zlib
|
, fetchurl
|
||||||
, swingSupport ? true }:
|
, autoPatchelfHook
|
||||||
|
, unzip
|
||||||
|
, makeWrapper
|
||||||
|
, setJavaClassPath
|
||||||
|
, zulu
|
||||||
|
# minimum dependencies
|
||||||
|
, alsaLib
|
||||||
|
, fontconfig
|
||||||
|
, freetype
|
||||||
|
, zlib
|
||||||
|
, xorg
|
||||||
|
# runtime dependencies
|
||||||
|
, cups
|
||||||
|
# runtime dependencies for GTK+ Look and Feel
|
||||||
|
, gtkSupport ? stdenv.isLinux
|
||||||
|
, cairo
|
||||||
|
, glib
|
||||||
|
, gtk3
|
||||||
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
version = "11.41.23";
|
version = "11.41.23";
|
||||||
|
@ -14,14 +32,12 @@ let
|
||||||
hash = if stdenv.isDarwin then sha256_darwin else sha256_linux;
|
hash = if stdenv.isDarwin then sha256_darwin else sha256_linux;
|
||||||
extension = if stdenv.isDarwin then "zip" else "tar.gz";
|
extension = if stdenv.isDarwin then "zip" else "tar.gz";
|
||||||
|
|
||||||
libraries = [
|
runtimeDependencies = [
|
||||||
stdenv.cc.libc glib libxml2 ffmpeg_3 libxslt libGL
|
cups
|
||||||
xorg.libXxf86vm alsaLib fontconfig freetype pango
|
] ++ lib.optionals gtkSupport [
|
||||||
gtk2 cairo gdk-pixbuf atk zlib
|
cairo glib gtk3
|
||||||
] ++ (lib.optionals swingSupport (with xorg; [
|
];
|
||||||
xorg.libX11 xorg.libXext xorg.libXtst xorg.libXi xorg.libXp
|
runtimeLibraryPath = lib.makeLibraryPath runtimeDependencies;
|
||||||
xorg.libXt xorg.libXrender stdenv.cc.cc
|
|
||||||
]));
|
|
||||||
|
|
||||||
in stdenv.mkDerivation {
|
in stdenv.mkDerivation {
|
||||||
inherit version openjdk platform hash extension;
|
inherit version openjdk platform hash extension;
|
||||||
|
@ -33,23 +49,29 @@ in stdenv.mkDerivation {
|
||||||
sha256 = hash;
|
sha256 = hash;
|
||||||
};
|
};
|
||||||
|
|
||||||
buildInputs = [ makeWrapper ] ++ lib.optional stdenv.isDarwin unzip;
|
buildInputs = lib.optionals stdenv.isLinux [
|
||||||
|
alsaLib # libasound.so wanted by lib/libjsound.so
|
||||||
|
fontconfig
|
||||||
|
freetype
|
||||||
|
stdenv.cc.cc # libstdc++.so.6
|
||||||
|
xorg.libX11
|
||||||
|
xorg.libXext
|
||||||
|
xorg.libXi
|
||||||
|
xorg.libXrender
|
||||||
|
xorg.libXtst
|
||||||
|
zlib
|
||||||
|
];
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
autoPatchelfHook makeWrapper
|
||||||
|
] ++ lib.optionals stdenv.isDarwin [
|
||||||
|
unzip
|
||||||
|
];
|
||||||
|
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
mkdir -p $out
|
mkdir -p $out
|
||||||
cp -r ./* "$out/"
|
cp -r ./* "$out/"
|
||||||
|
|
||||||
rpath=$rpath''${rpath:+:}$out/lib/jli
|
|
||||||
rpath=$rpath''${rpath:+:}$out/lib/server
|
|
||||||
rpath=$rpath''${rpath:+:}$out/lib
|
|
||||||
|
|
||||||
# set all the dynamic linkers
|
|
||||||
find $out -type f -perm -0100 \
|
|
||||||
-exec patchelf --interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \
|
|
||||||
--set-rpath "$rpath" {} \;
|
|
||||||
|
|
||||||
find $out -name "*.so" -exec patchelf --set-rpath "$rpath" {} \;
|
|
||||||
|
|
||||||
mkdir -p $out/nix-support
|
mkdir -p $out/nix-support
|
||||||
printWords ${setJavaClassPath} > $out/nix-support/propagated-build-inputs
|
printWords ${setJavaClassPath} > $out/nix-support/propagated-build-inputs
|
||||||
|
|
||||||
|
@ -57,9 +79,17 @@ in stdenv.mkDerivation {
|
||||||
cat <<EOF >> $out/nix-support/setup-hook
|
cat <<EOF >> $out/nix-support/setup-hook
|
||||||
if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi
|
if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi
|
||||||
EOF
|
EOF
|
||||||
|
'' + lib.optionalString stdenv.isLinux ''
|
||||||
|
# We cannot use -exec since wrapProgram is a function but not a command.
|
||||||
|
for bin in $( find "$out" -executable -type f ); do
|
||||||
|
wrapProgram "$bin" --prefix LD_LIBRARY_PATH : "${runtimeLibraryPath}"
|
||||||
|
done
|
||||||
'';
|
'';
|
||||||
|
|
||||||
rpath = lib.strings.makeLibraryPath libraries;
|
preFixup = ''
|
||||||
|
find "$out" -name libfontmanager.so -exec \
|
||||||
|
patchelf --add-needed libfontconfig.so {} \;
|
||||||
|
'';
|
||||||
|
|
||||||
passthru = {
|
passthru = {
|
||||||
home = zulu;
|
home = zulu;
|
||||||
|
|
Loading…
Reference in a new issue