summaryrefslogtreecommitdiff
path: root/development
diff options
context:
space:
mode:
authorStrahil Yordanov <strahilski@yahoo.com>2019-05-30 09:55:35 +0700
committerWilly Sudiarto Raharjo <willysr@slackbuilds.org>2019-05-30 09:55:35 +0700
commitcfb79ee5a955bb095a2724753b1028cf70cba0a7 (patch)
treec00e3370dd4d8fadbbc9e19c41e949b4b4c27261 /development
parent8d4e9f1e648c84153e797a07aed8910fe568d4cf (diff)
downloadslackbuilds-cfb79ee5a955bb095a2724753b1028cf70cba0a7.tar.gz
development/openjdk7: Added (Open Implementation of JDK).
Signed-off-by: Willy Sudiarto Raharjo <willysr@slackbuilds.org>
Diffstat (limited to 'development')
-rw-r--r--development/openjdk7/README32
-rw-r--r--development/openjdk7/cacertsbin0 -> 192567 bytes
-rw-r--r--development/openjdk7/openjdk7.SlackBuild160
-rw-r--r--development/openjdk7/openjdk7.info24
-rw-r--r--development/openjdk7/profile.d/openjdk7.csh4
-rw-r--r--development/openjdk7/profile.d/openjdk7.sh4
-rw-r--r--development/openjdk7/slack-desc19
7 files changed, 243 insertions, 0 deletions
diff --git a/development/openjdk7/README b/development/openjdk7/README
new file mode 100644
index 0000000000..bbb3cb612b
--- /dev/null
+++ b/development/openjdk7/README
@@ -0,0 +1,32 @@
+OpenJDK 7 is an open source implementation of version 7 of the
+Java Development Kit, Standard Edition. It includes tools for developing,
+testing, and running programs written in Java.
+
+apache-ant is a required dependency and you have to install it before
+you build 'openjdk7'. However, you do not need to install Oracle's jdk,
+since it's only a runtime dependency of apache-ant.
+
+Before installing this package please consider any other jdk's/jre's
+that you have already installed as they may cause conflicts with the
+PATH, JAVA_HOME and MANPATH variables.
+
+After installing the package you will need to logout/reboot your machine
+as it will add new files to the /etc/profile.d folder.
+
+This script may take a couple of hours to complete and will require
+about 11 GB of disk space for its temporary directory. It defaults to
+"/tmp/SBo" and you may redefine it like this:
+
+TMP=/your/temporary/dir ./openjdk7.SlackBuild
+
+The 'cacerts' binary is a TrustStore containing CA certificates which
+are used by Java applications. It is taken from the CentOS package
+'ca-certificates-2015.2.4-65.0.1.el6_6.noarch.rpm'.
+
+If you get an error like
+
+Internal compiler error: java.lang.NullPointerException at
+org.eclipse.jdt.internal.compiler.ReadManager.run(ReadManager.java:166)
+
+simply run the build again. This happens early so it shouldn't be that of a
+problem. At least 1 out of 5 runs so far have always succeded.
diff --git a/development/openjdk7/cacerts b/development/openjdk7/cacerts
new file mode 100644
index 0000000000..3c6ae3e526
--- /dev/null
+++ b/development/openjdk7/cacerts
Binary files differ
diff --git a/development/openjdk7/openjdk7.SlackBuild b/development/openjdk7/openjdk7.SlackBuild
new file mode 100644
index 0000000000..b0f74e19aa
--- /dev/null
+++ b/development/openjdk7/openjdk7.SlackBuild
@@ -0,0 +1,160 @@
+#!/bin/sh
+
+# Slackware build script for OpenJDK
+
+# Copyright 2019 Strahil Yordanov, Sofia, Bulgaria
+# All rights reserved.
+#
+# Redistribution and use of this script, with or without modification, is
+# permitted provided that the following conditions are met:
+#
+# 1. Redistributions of this script must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+#
+# THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED
+# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
+# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+function applySBoPatch() {
+ cat << EOF | patch -d ../icedtea-2.6.18/patches/boot pr64174.patch
+--- pr64174.patch.orig 2019-05-26 07:15:48.030960856 +0300
++++ pr64174.patch.new 2019-05-26 07:17:00.921955937 +0300
+@@ -1,8 +1,8 @@
+ diff -Nru openjdk-boot.orig/jdk/src/share/classes/java/util/CurrencyData.properties openjdk-boot/jdk/src/share/classes/java/util/CurrencyData.properties
+ --- openjdk-boot.orig/jdk/src/share/classes/java/util/CurrencyData.properties 2014-12-04 15:09:06.030312835 +0000
+ +++ openjdk-boot/jdk/src/share/classes/java/util/CurrencyData.properties 2014-12-04 15:10:07.527160626 +0000
+-@@ -320,7 +320,7 @@
+- # LAO PEOPLE'S DEMOCRATIC REPUBLIC
++@@ -323,7 +323,7 @@
++ # LAO PEOPLE'S DEMOCRATIC REPUBLIC (THE)
+ LA=LAK
+ # LATVIA
+ -LV=LVL;2013-12-31-22-00-00;EUR
+@@ -10,7 +10,7 @@
+ # LEBANON
+ LB=LBP
+ # LESOTHO
+-@@ -332,7 +332,7 @@
++@@ -335,7 +335,7 @@
+ # LIECHTENSTEIN
+ LI=CHF
+ # LITHUANIA
+EOF
+}
+
+PRGNAM=openjdk7
+VERSION=${VERSION:-7u221}
+BUILD=${BUILD:-1}
+TAG=${TAG:-_SBo}
+
+DVER=1.7.0_$(printf $VERSION | cut -du -f2)
+ICEDTEA=icedtea-2.6.18
+
+if [ -z "$ARCH" ]; then
+ case "$( uname -m )" in
+ i?86) ARCH=i486 ;;
+ arm*) ARCH=arm; echo "Unsupported arch $ARCH"; exit 1;;
+ *) ARCH=$( uname -m ) ;;
+ esac
+fi
+
+CWD="$(pwd)"
+TMP=${TMP:-/tmp/SBo}
+BUILD_DIR=$TMP/$PRGNAM
+PKG=$TMP/package-$PRGNAM
+OUTPUT=${OUTPUT:-/tmp}
+
+if [ "$ARCH" = "x86_64" ]; then
+ LIB_ARCH=amd64
+ LIBDIRSUFFIX="64"
+else
+ LIB_ARCH=i386
+ LIBDIRSUFFIX=""
+fi
+
+BOOT_JAVA=/usr/lib${LIBDIRSUFFIX}/jvm
+
+set -e
+
+rm -rf $BUILD_DIR $PKG
+mkdir -p $TMP $BUILD_DIR $PKG $OUTPUT
+cd $BUILD_DIR
+
+tar -xvf $CWD/${ICEDTEA}.tar.xz
+
+mkdir icedtea-build
+cd icedtea-build
+
+# Set JAVA_HOME in order to avoid conflicts with other already installed JVMs.
+JAVA_HOME=${BOOT_JAVA} PATH=${BOOT_JAVA}/bin:$PATH ../$ICEDTEA/configure \
+ --disable-docs \
+ --disable-downloading \
+ --with-jdk-home=${BOOT_JAVA} \
+ --without-rhino \
+ --disable-system-kerberos \
+ --disable-system-pcsc \
+ --disable-system-sctp \
+ --with-cacerts-file="$CWD/cacerts" \
+$(
+# cacerts is taken from this CentOS package:
+#+ http://mirror.centos.org/centos/6/os/x86_64/Packages/ca-certificates-2015.2.4-65.0.1.el6_6.noarch.rpm
+# You can list its contents with this command (after you install this package:)
+#+ 'keytool -v -list -keystore ./cacerts -storepass changeit'
+# It's old and some certificates inside have already expired but without it some java programs
+#+ may throw exceptions. It is meant as a dummy placehoder file.
+) \
+ --with-openjdk-src-zip="$CWD/openjdk.tar.bz2" \
+ --with-corba-src-zip="$CWD/corba.tar.bz2" \
+ --with-jaxp-src-zip="$CWD/jaxp.tar.bz2" \
+ --with-jaxws-src-zip="$CWD/jaxws.tar.bz2" \
+ --with-jdk-src-zip="$CWD/jdk.tar.bz2" \
+ --with-langtools-src-zip="$CWD/langtools.tar.bz2" \
+ --with-hotspot-src-zip="$CWD/hotspot.tar.bz2"
+
+applySBoPatch
+
+JAVA_HOME=${BOOT_JAVA} PATH=${BOOT_JAVA}/bin:$PATH LOG=trace make
+
+cd $PKG
+mkdir -p usr/lib${LIBDIRSUFFIX}
+cd usr/lib${LIBDIRSUFFIX}
+cp -av $BUILD_DIR/icedtea-build/openjdk.build/j2sdk-image/ $PRGNAM
+
+chown -R root.root $PKG
+find -L . \
+ \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \
+ -o -perm 511 \) -exec chmod 755 {} \; -o \
+ \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \
+ -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \;
+
+mkdir -p $PKG/etc/profile.d
+for file in $(ls "$CWD/profile.d/${PRGNAM}"*) ; do
+ cat $file | sed -e "s#lib/openjdk7#lib${LIBDIRSUFFIX}/openjdk7#" \
+ > $PKG/etc/profile.d/$(basename $file)
+done
+chmod 755 $PKG/etc/profile.d/*
+
+( cd $PKG/usr/lib${LIBDIRSUFFIX}
+ ln -sf $PRGNAM ${PRGNAM}${DVER}
+)
+
+cd $PKG/usr/lib${LIBDIRSUFFIX}
+ ln -sf ./$PRGNAM/jre/lib/${LIB_ARCH}/server/libjvm.so .
+
+mkdir -p $PKG/install
+cat $CWD/slack-desc > $PKG/install/slack-desc
+
+mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
+cp -a $PKG/usr/lib${LIBDIRSUFFIX}/$PRGNAM/{THIRD_PARTY_README,LICENSE,ASSEMBLY_EXCEPTION} \
+ $PKG/usr/doc/$PRGNAM-$VERSION
+cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
+
+cd $PKG
+/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz}
diff --git a/development/openjdk7/openjdk7.info b/development/openjdk7/openjdk7.info
new file mode 100644
index 0000000000..6181aebe57
--- /dev/null
+++ b/development/openjdk7/openjdk7.info
@@ -0,0 +1,24 @@
+PRGNAM="openjdk7"
+VERSION="7u221"
+HOMEPAGE="http://openjdk.java.net"
+DOWNLOAD="http://icedtea.classpath.org/download/source/icedtea-2.6.18.tar.xz \
+ http://icedtea.classpath.org/download/drops/icedtea7/2.6.18/openjdk.tar.bz2 \
+ http://icedtea.classpath.org/download/drops/icedtea7/2.6.18/corba.tar.bz2 \
+ http://icedtea.classpath.org/download/drops/icedtea7/2.6.18/jaxp.tar.bz2 \
+ http://icedtea.classpath.org/download/drops/icedtea7/2.6.18/jaxws.tar.bz2 \
+ http://icedtea.classpath.org/download/drops/icedtea7/2.6.18/jdk.tar.bz2 \
+ http://icedtea.classpath.org/download/drops/icedtea7/2.6.18/langtools.tar.bz2 \
+http://icedtea.classpath.org/download/drops/icedtea7/2.6.18/hotspot.tar.bz2"
+ MD5SUM="8b1e1d3478ebe4b6b594ce6f5935b56a
+ 0dc85672fb7ce07f32489e6c9c695d36
+ ff2de2b24a18964e6c7ae3d14a5569d2
+ c44cfbf6a254a72be0e1e72c86ba69ec
+ 34437f68afd087dc72a4aeb20556c688
+ 97091fe93a4fdd8d77f3bab4b2db2599
+ 47927888e6531aaf9fdf791ae5b4927b
+ 3aaa59067e12ccb66e5d85a4c439b1d6"
+DOWNLOAD_x86_64=""
+MD5SUM_x86_64=""
+REQUIRES="apache-ant"
+MAINTAINER="Strahil Yordanov"
+EMAIL="strahilski@yahoo.com"
diff --git a/development/openjdk7/profile.d/openjdk7.csh b/development/openjdk7/profile.d/openjdk7.csh
new file mode 100644
index 0000000000..0b69a36c36
--- /dev/null
+++ b/development/openjdk7/profile.d/openjdk7.csh
@@ -0,0 +1,4 @@
+#!/bin/csh
+setenv JAVA_HOME /usr/lib/openjdk7
+setenv MANPATH ${MANPATH}:${JAVA_HOME}/man
+setenv PATH ${PATH}:${JAVA_HOME}/bin:${JAVA_HOME}/jre/bin
diff --git a/development/openjdk7/profile.d/openjdk7.sh b/development/openjdk7/profile.d/openjdk7.sh
new file mode 100644
index 0000000000..e3b669d9d4
--- /dev/null
+++ b/development/openjdk7/profile.d/openjdk7.sh
@@ -0,0 +1,4 @@
+#!/bin/sh
+export JAVA_HOME=/usr/lib/openjdk7
+export MANPATH="${MANPATH}:${JAVA_HOME}/man"
+export PATH="${PATH}:${JAVA_HOME}/bin:${JAVA_HOME}/jre/bin"
diff --git a/development/openjdk7/slack-desc b/development/openjdk7/slack-desc
new file mode 100644
index 0000000000..023476abde
--- /dev/null
+++ b/development/openjdk7/slack-desc
@@ -0,0 +1,19 @@
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description.
+# Line up the first '|' above the ':' following the base package name, and
+# the '|' on the right side marks the last column you can put a character in.
+# You must make exactly 11 lines for the formatting to be correct. It's also
+# customary to leave one space after the ':' except on otherwise blank lines.
+
+ |-----handy-ruler------------------------------------------------------|
+openjdk7: openjdk (OpenJDK 7 -- Open Implementation of JDK)
+openjdk7:
+openjdk7: OpenJDK 7 is an open source implementation of version 7 of the
+openjdk7: Java Development Kit, Standard Edition. It includes tools for
+openjdk7: developing, testing, and running programs written in Java.
+openjdk7:
+openjdk7:
+openjdk7:
+openjdk7:
+openjdk7:
+openjdk7: