unofficial mirror of guix-devel@gnu.org 
 help / color / mirror / code / Atom feed
From: Ricardo Wurmus <ricardo.wurmus@mdc-berlin.de>
To: "Ludovic Courtès" <ludo@gnu.org>
Cc: Guix-devel <guix-devel@gnu.org>
Subject: Re: WIP: IcedTea7
Date: Wed, 15 Apr 2015 17:44:03 +0200	[thread overview]
Message-ID: <idjmw29xupo.fsf@bimsb-sys02.mdc-berlin.net> (raw)
In-Reply-To: <idjiodh1t4x.fsf@bimsb-sys02.mdc-berlin.net>

[-- Attachment #1: Type: text/plain, Size: 7770 bytes --]

Also with the latest release of IcedTea (2.5.5) I get the same linker
error.  I obviously do not get this with IcedTea 1.13.x.  Here's the
matching section of the build logs for IcedTea 1.13.7 where you see
... nothing bad at all happening:

~~~~~~~~
...
make[6]: Entering directory '/buildtmp/nix-build-icedtea6-1.13.7.drv-0/icedtea6-1.13.7/openjdk-ecj/jdk/make/sun/headless'
logname: no login name
/gnu/store/4sqgnc9bc1kmn058yp4xnj4vpydmfzpq-gcc-4.8.4/bin/gcc  -O2   -fno-strict-aliasing -fPIC -W -Wall  -Wno-unused -Wno-parentheses -pipe -fno-omit-frame-pointer -D_LITTLE_ENDIAN -g  -g -DHEADLESS=true  -DARCH='"amd64"' -Damd64 -DLINUX -DRELEASE='"1.6.0_35"' -D_LARGEFILE64_SOURCE -D_GNU_SOURCE -D_REENTRANT -D_LP64=1 -I. -I/buildtmp/nix-build-icedtea6-1.13.7.drv-0/icedtea6-1.13.7/openjdk.build-ecj/tmp/sun/sun.awt/headless/CClassHeaders -I../../../src/solaris/javavm/export -I../../../src/share/javavm/export -I../../../src/share/javavm/include -I../../../src/solaris/javavm/include -I../../../src/share/native/common -I../../../src/solaris/native/common -I../../../src/share/native/sun/awt -I../../../src/solaris/native/sun/awt   -DHEADLESS=true -I/gnu/store/7g64rkm6gl8j5w29sfayip0pbvwylbkr-cups-2.0.1/include -I../../../src/share/native/sun/awt/debug -I../../../src/share/native/sun/awt/../font -I../../../src/solaris/native/sun/awt/../font -I../../../src/share/native/sun/awt/image -I../../../src/share/native/sun/awt/image/cvutils -I../../../src/share/native/sun/awt/shell -I../../../src/share/native/sun/awt/alphacomposite -I../../../src/share/native/sun/awt/medialib -I../../../src/solaris/native/sun/awt/medialib -I../../../src/share/native/sun/awt/../java2d -I../../../src/solaris/native/sun/awt/../java2d -I../../../src/share/native/sun/awt/../java2d/loops -I../../../src/share/native/sun/awt/../java2d/pipe -I../../../src/share/native/sun/awt/../java2d/opengl -I../../../src/solaris/native/sun/awt/../java2d/opengl -I../../../src/solaris/native/sun/awt/../java2d/x11 -I../../../src/share/native/sun/awt/../dc/doe -I../../../src/share/native/sun/awt/../dc/path -I../../../src/solaris/native/sun/awt/../jdga -I../../../src/solaris/native/sun/awt  -I/X11R6/include/X11/extensions -I/usr/include/X11/extensions  -c -o /buildtmp/nix-build-icedtea6-1.13.7.drv-0/icedtea6-1.13.7/openjdk.build-ecj/tmp/sun/sun.awt/headless/obj64/awt_Font.o  ../../../src/solaris/native/sun/awt/awt_Font.c
/gnu/store/4sqgnc9bc1kmn058yp4xnj4vpydmfzpq-gcc-4.8.4/bin/gcc  -O2   -fno-strict-aliasing -fPIC -W -Wall  -Wno-unused -Wno-parentheses -pipe -fno-omit-frame-pointer -D_LITTLE_ENDIAN -g  -g -DHEADLESS=true  -DARCH='"amd64"' -Damd64 -DLINUX -DRELEASE='"1.6.0_35"' -D_LARGEFILE64_SOURCE -D_GNU_SOURCE -D_REENTRANT -D_LP64=1 -I. -I/buildtmp/nix-build-icedtea6-1.13.7.drv-0/icedtea6-1.13.7/openjdk.build-ecj/tmp/sun/sun.awt/headless/CClassHeaders -I../../../src/solaris/javavm/export -I../../../src/share/javavm/export -I../../../src/share/javavm/include -I../../../src/solaris/javavm/include -I../../../src/share/native/common -I../../../src/solaris/native/common -I../../../src/share/native/sun/awt -I../../../src/solaris/native/sun/awt   -DHEADLESS=true -I/gnu/store/7g64rkm6gl8j5w29sfayip0pbvwylbkr-cups-2.0.1/include -I../../../src/share/native/sun/awt/debug -I../../../src/share/native/sun/awt/../font -I../../../src/solaris/native/sun/awt/../font -I../../../src/share/native/sun/awt/image -I../../../src/share/native/sun/awt/image/cvutils -I../../../src/share/native/sun/awt/shell -I../../../src/share/native/sun/awt/alphacomposite -I../../../src/share/native/sun/awt/medialib -I../../../src/solaris/native/sun/awt/medialib -I../../../src/share/native/sun/awt/../java2d -I../../../src/solaris/native/sun/awt/../java2d -I../../../src/share/native/sun/awt/../java2d/loops -I../../../src/share/native/sun/awt/../java2d/pipe -I../../../src/share/native/sun/awt/../java2d/opengl -I../../../src/solaris/native/sun/awt/../java2d/opengl -I../../../src/solaris/native/sun/awt/../java2d/x11 -I../../../src/share/native/sun/awt/../dc/doe -I../../../src/share/native/sun/awt/../dc/path -I../../../src/solaris/native/sun/awt/../jdga -I../../../src/solaris/native/sun/awt  -I/X11R6/include/X11/extensions -I/usr/include/X11/extensions  -c -o /buildtmp/nix-build-icedtea6-1.13.7.drv-0/icedtea6-1.13.7/openjdk.build-ecj/tmp/sun/sun.awt/headless/obj64/awt_MToolkit.o  ../../../src/solaris/native/sun/awt/awt_MToolkit.c
../../../src/solaris/native/sun/awt/awt_Font.c: In function ‘Java_java_awt_Font_initIDs’:
../../../src/solaris/native/sun/awt/awt_Font.c:86:12: warning: unused parameter ‘env’ [-Wunused-parameter]
   (JNIEnv *env, jclass cls)
            ^
../../../src/solaris/native/sun/awt/awt_Font.c:86:24: warning: unused parameter ‘cls’ [-Wunused-parameter]
   (JNIEnv *env, jclass cls)
                        ^
../../../src/solaris/native/sun/awt/awt_Font.c: In function ‘Java_sun_awt_FontDescriptor_initIDs’:
../../../src/solaris/native/sun/awt/awt_Font.c:173:12: warning: unused parameter ‘env’ [-Wunused-parameter]
   (JNIEnv *env, jclass cls)
            ^
../../../src/solaris/native/sun/awt/awt_Font.c:173:24: warning: unused parameter ‘cls’ [-Wunused-parameter]
   (JNIEnv *env, jclass cls)
                        ^
../../../src/solaris/native/sun/awt/awt_Font.c: In function ‘Java_sun_awt_PlatformFont_initIDs’:
../../../src/solaris/native/sun/awt/awt_Font.c:218:12: warning: unused parameter ‘env’ [-Wunused-parameter]
   (JNIEnv *env, jclass cls)
            ^
../../../src/solaris/native/sun/awt/awt_Font.c:218:24: warning: unused parameter ‘cls’ [-Wunused-parameter]
   (JNIEnv *env, jclass cls)
                        ^
/gnu/store/4sqgnc9bc1kmn058yp4xnj4vpydmfzpq-gcc-4.8.4/bin/gcc  -O2   -fno-strict-aliasing -fPIC -W -Wall  -Wno-unused -Wno-parentheses -pipe -fno-omit-frame-pointer -D_LITTLE_ENDIAN -g  -g -DHEADLESS=true  -DARCH='"amd64"' -Damd64 -DLINUX -DRELEASE='"1.6.0_35"' -D_LARGEFILE64_SOURCE -D_GNU_SOURCE -D_REENTRANT -D_LP64=1 -I. -I/buildtmp/nix-build-icedtea6-1.13.7.drv-0/icedtea6-1.13.7/openjdk.build-ecj/tmp/sun/sun.awt/headless/CClassHeaders -I../../../src/solaris/javavm/export -I../../../src/share/javavm/export -I../../../src/share/javavm/include -I../../../src/solaris/javavm/include -I../../../src/share/native/common -I../../../src/solaris/native/common -I../../../src/share/native/sun/awt -I../../../src/solaris/native/sun/awt   -DHEADLESS=true -I/gnu/store/7g64rkm6gl8j5w29sfayip0pbvwylbkr-cups-2.0.1/include -I../../../src/share/native/sun/awt/debug -I../../../src/share/native/sun/awt/../font -I../../../src/solaris/native/sun/awt/../font -I../../../src/share/native/sun/awt/image -I../../../src/share/native/sun/awt/image/cvutils -I../../../src/share/native/sun/awt/shell -I../../../src/share/native/sun/awt/alphacomposite -I../../../src/share/native/sun/awt/medialib -I../../../src/solaris/native/sun/awt/medialib -I../../../src/share/native/sun/awt/../java2d -I../../../src/solaris/native/sun/awt/../java2d -I../../../src/share/native/sun/awt/../java2d/loops -I../../../src/share/native/sun/awt/../java2d/pipe -I../../../src/share/native/sun/awt/../java2d/opengl -I../../../src/solaris/native/sun/awt/../java2d/opengl -I../../../src/solaris/native/sun/awt/../java2d/x11 -I../../../src/share/native/sun/awt/../dc/doe -I../../../src/share/native/sun/awt/../dc/path -I../../../src/solaris/native/sun/awt/../jdga -I../../../src/solaris/native/sun/awt  -I/X11R6/include/X11/extensions -I/usr/include/X11/extensions  -c -o /buildtmp/nix-build-icedtea6-1.13.7.drv-0/icedtea6-1.13.7/openjdk.build-ecj/tmp/sun/sun.awt/headless/obj64/fontpath.o  ../../../src/solaris/native/sun/awt/fontpath.c
...
~~~~~~~~

Attached is the latest recipe for IcedTea7, version 2.5.5.


[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-WIP-icedtea7.patch --]
[-- Type: text/x-patch, Size: 9308 bytes --]

From 42756d081274ff38e833cb093c7be3fc252a2013 Mon Sep 17 00:00:00 2001
From: Ricardo Wurmus <ricardo.wurmus@mdc-berlin.de>
Date: Tue, 24 Mar 2015 12:09:29 +0100
Subject: [PATCH] WIP: icedtea7

---
 gnu/packages/java.scm | 156 +++++++++++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 155 insertions(+), 1 deletion(-)

diff --git a/gnu/packages/java.scm b/gnu/packages/java.scm
index 00ee5a1..a2e7a0e 100644
--- a/gnu/packages/java.scm
+++ b/gnu/packages/java.scm
@@ -20,6 +20,7 @@
   #:use-module ((guix licenses) #:prefix license:)
   #:use-module (guix packages)
   #:use-module (guix download)
+  #:use-module (guix utils)
   #:use-module (guix build-system gnu)
   #:use-module (gnu packages)
   #:use-module (gnu packages attr)
@@ -45,7 +46,8 @@
   #:use-module (gnu packages xml)
   #:use-module (gnu packages xorg)
   #:use-module (gnu packages zip)
-  #:use-module (gnu packages texinfo))
+  #:use-module (gnu packages texinfo)
+  #:use-module ((srfi srfi-1) #:select (fold alist-delete)))
 
 (define-public ant
   (package
@@ -562,3 +564,155 @@ build process and its dependencies, whereas Make uses Makefile format.")
     ;; IcedTea is released under the GPL2 + Classpath exception, which is the
     ;; same license as both GNU Classpath and OpenJDK.
     (license license:gpl2+)))
+
+(define-public icedtea7
+  (let* ((version "2.5.5")
+         (drop (lambda (name hash)
+                 (origin
+                   (method url-fetch)
+                   (uri (string-append
+                         "http://icedtea.classpath.org/download/drops/"
+                         "/icedtea7/" version "/" name ".tar.bz2"))
+                   (sha256 (base32 hash))))))
+    (package (inherit icedtea6)
+      (name "icedtea7")
+      (version version)
+      (source (origin
+                (method url-fetch)
+                (uri (string-append
+                      "http://icedtea.wildebeest.org/download/source/icedtea-"
+                      version ".tar.xz"))
+                (sha256
+                 (base32
+                  "1irxk2ndwsfk4c1zbzb5h3rpwv2bc9bhfjvz6p4dws5476vsxrq9"))
+                (modules '((guix build utils)))
+                (snippet
+                 '(substitute* "Makefile.in"
+                    ;; do not leak information about the build host
+                    (("DISTRIBUTION_ID=\"\\$\\(DIST_ID\\)\"")
+                     "DISTRIBUTION_ID=\"\\\"guix\\\"\"")))))
+      (arguments
+       `(#:parallel-build? #f
+         ,@(substitute-keyword-arguments `(#:modules ((guix build gnu-build-system)
+                                                      (guix build utils)
+                                                      (srfi srfi-1)
+                                                      (srfi srfi-26))
+                                                     ,@(package-arguments icedtea6))
+             ((#:configure-flags flags)
+              `(let ((jdk (assoc-ref %build-inputs "icedtea6"))
+                     (ant (assoc-ref %build-inputs "ant")))
+                 `("--disable-bootstrap"
+                   ;;"--disable-bootstrap-tools"
+                   "--without-rhino"
+                   "--enable-nss"
+                   "--enable-infinality"
+                   "--enable-system-gio"
+                   "--enable-system-gtk"
+                   "--enable-system-gif"
+                   "--enable-system-png"
+                   "--enable-system-jpeg"
+                   "--enable-system-zlib"
+                   "--enable-system-lcms"
+                   "--enable-system-fontconfig"
+                   "--disable-downloading"
+                   "--disable-xrender" ;; TODO: more X11 extensions are needed
+                                        ;see /usr/include/X11/extensions
+                   ;;"--with-openjdk-src-dir=./openjdk"
+                   ,(string-append "--with-ant-home=" ant)
+                   ,(string-append "--with-jdk-home=" jdk)
+                   )))
+             ((#:phases phases)
+              `(alist-replace
+                'unpack
+                (lambda* (#:key source inputs #:allow-other-keys)
+                  (let ((target (string-append "icedtea-" ,version)))
+                    (and (zero? (system* "tar" "xvf" source))
+                         (chdir target)
+                         (mkdir "openjdk")
+                         (mkdir "openjdk/corba")
+                         (mkdir "openjdk/jdk")
+                         (mkdir "openjdk/hotspot")
+                         (zero? (system* "tar" "xvjf" (assoc-ref inputs "openjdk-drop")
+                                         "-C" "openjdk" "--strip-components=1"))
+                         (zero? (system* "tar" "xvjf" (assoc-ref inputs "corba-drop")
+                                         "-C" "openjdk/corba" "--strip-components=1"))
+                         (zero? (system* "tar" "xvjf" (assoc-ref inputs "jdk-drop")
+                                         "-C" "openjdk/jdk" "--strip-components=1"))
+                         (zero? (system* "tar" "xvjf" (assoc-ref inputs "hotspot-drop")
+                                         "-C" "openjdk/hotspot" "--strip-components=1")))
+                    (format #t "copying stuff\n")
+                    ;; TODO: we already unpack them.  Can I disable the tarball check?
+                    (copy-file (assoc-ref inputs "openjdk-drop")   "openjdk.tar.bz2")
+                    (copy-file (assoc-ref inputs "corba-drop")     "corba.tar.bz2")
+                    (copy-file (assoc-ref inputs "hotspot-drop")   "hotspot.tar.bz2")
+
+                    (copy-file (assoc-ref inputs "jaxp-drop")      "jaxp.tar.bz2")
+                    (copy-file (assoc-ref inputs "jaxws-drop")     "jaxws.tar.bz2")
+                    (copy-file (assoc-ref inputs "jdk-drop")       "jdk.tar.bz2")
+                    (copy-file (assoc-ref inputs "langtools-drop") "langtools.tar.bz2")))
+                (alist-replace
+                 'set-additional-paths
+                 (lambda* (#:key inputs #:allow-other-keys)
+                   (substitute* "openjdk/jdk/make/common/shared/Sanity.gmk"
+                     (("ALSA_INCLUDE=/usr/include/alsa/version.h")
+                      (string-append "ALSA_INCLUDE="
+                                     (assoc-ref inputs "alsa-lib")
+                                     "/include/alsa/version.h")))
+                   (setenv "CC" "gcc")
+                   (setenv "JAVA_HOME"
+                           (assoc-ref %build-inputs "icedtea6"))
+                   (setenv "ALT_PREVIOUS_RELEASE_IMAGE"
+                           (assoc-ref inputs "icedtea6"))
+                   (setenv "CPATH"
+                           (string-append (assoc-ref inputs "libxrender")
+                                          "/include/X11/extensions" ":"
+                                          (assoc-ref inputs "libxtst")
+                                          "/include/X11/extensions" ":"
+                                          (assoc-ref inputs "libxinerama")
+                                          "/include/X11/extensions" ":"
+                                          (or (getenv "CPATH") "")))
+                   (setenv "ALT_CUPS_HEADERS_PATH"
+                           (string-append (assoc-ref inputs "cups")
+                                          "/include"))
+                   (setenv "ALT_FREETYPE_HEADERS_PATH"
+                           (string-append (assoc-ref inputs "freetype")
+                                          "/include"))
+                   (setenv "ALT_FREETYPE_LIB_PATH"
+                           (string-append (assoc-ref inputs "freetype")
+                                          "/lib")))
+                 (alist-delete 'patch-patches ,phases)))))))
+      (native-inputs
+       `(("ant" ,ant)
+         ("icedtea6" ,icedtea6 "jdk")
+         ("openjdk7-src"
+          ,(origin
+             (method url-fetch)
+             (uri (string-append
+                   "http://download.java.net/openjdk/jdk7/"
+                   "promoted/b147/openjdk-7-fcs-src-b147-27_jun_2011.zip"))
+             (sha256
+              (base32
+               "1qhwlz9y5qmwmja4qnxg6sn3pgsg1i11fb9j41w8l26acyhk34rs"))))
+         ("openjdk-drop"
+          ,(drop "openjdk"
+                 "03gxqn17cxwl1nspnwigacaqd28p02d45f396j5f4kkbzfnbl0ak"))
+         ("corba-drop"
+          ,(drop "corba"
+                 "0ldcckknn2f92jv1144cnn0z3wmvxln28wc00rc6xxblnjcnamzh"))
+         ("jaxp-drop"
+          ,(drop "jaxp"
+                 "0mnjdziffcnyqlyvf8dw1hrl4kiiwmh8ia0ym417wgvnjpaihci9"))
+         ("jaxws-drop"
+          ,(drop "jaxws"
+                 "1gkmypnhygx2mxhca3ngy620k993wi2cc1wysc0np06y1rkx1mkn"))
+         ("jdk-drop"
+          ,(drop "jdk"
+                 "10x43mqjfn43jlckic0nyf7apyyjyr910cdmmvy41kvw8ljhvg61"))
+         ("langtools-drop"
+          ,(drop "langtools"
+                 "0q5nqc14r6vmhxgikw3wgdcc0r9symp830v13isnv8qdjgm6kcki"))
+         ("hotspot-drop"
+          ,(drop "hotspot"
+                 "1yqxfd2jwbm5y41wscyfx8h0fr3h8ny2g2mda5iwd8sikxsaj96p"))
+         ,@(fold alist-delete (package-native-inputs icedtea6)
+                 '("openjdk6-src" "ant-bootstrap" "gcj")))))))
-- 
2.1.0


[-- Attachment #3: Type: text/plain, Size: 49 bytes --]


I would appreciate any suggestions.

~~ Ricardo

      reply	other threads:[~2015-04-15 15:44 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-03-24 11:10 WIP: IcedTea7 Ricardo Wurmus
2015-03-29 13:20 ` Ludovic Courtès
2015-03-31  8:13   ` Ricardo Wurmus
2015-04-15 15:44     ` Ricardo Wurmus [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://guix.gnu.org/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=idjmw29xupo.fsf@bimsb-sys02.mdc-berlin.net \
    --to=ricardo.wurmus@mdc-berlin.de \
    --cc=guix-devel@gnu.org \
    --cc=ludo@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/guix.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).