From cfb79ee5a955bb095a2724753b1028cf70cba0a7 Mon Sep 17 00:00:00 2001 From: Strahil Yordanov Date: Thu, 30 May 2019 09:55:35 +0700 Subject: development/openjdk7: Added (Open Implementation of JDK). Signed-off-by: Willy Sudiarto Raharjo --- development/openjdk7/README | 32 ++++++ development/openjdk7/cacerts | Bin 0 -> 192567 bytes development/openjdk7/openjdk7.SlackBuild | 160 ++++++++++++++++++++++++++++ development/openjdk7/openjdk7.info | 24 +++++ development/openjdk7/profile.d/openjdk7.csh | 4 + development/openjdk7/profile.d/openjdk7.sh | 4 + development/openjdk7/slack-desc | 19 ++++ 7 files changed, 243 insertions(+) create mode 100644 development/openjdk7/README create mode 100644 development/openjdk7/cacerts create mode 100644 development/openjdk7/openjdk7.SlackBuild create mode 100644 development/openjdk7/openjdk7.info create mode 100644 development/openjdk7/profile.d/openjdk7.csh create mode 100644 development/openjdk7/profile.d/openjdk7.sh create mode 100644 development/openjdk7/slack-desc (limited to 'development') 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 Binary files /dev/null and b/development/openjdk7/cacerts 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: -- cgit v1.2.3