summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--eclass/java-pkg.eclass3
-rw-r--r--eclass/java-utils.eclass33
2 files changed, 21 insertions, 15 deletions
diff --git a/eclass/java-pkg.eclass b/eclass/java-pkg.eclass
index 978cab2dd85c..c74661f0bb90 100644
--- a/eclass/java-pkg.eclass
+++ b/eclass/java-pkg.eclass
@@ -1,8 +1,7 @@
# Copyright 1999-2004 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/eclass/java-pkg.eclass,v 1.16 2004/10/16 21:32:09 axxo Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/java-pkg.eclass,v 1.17 2004/10/19 13:10:41 axxo Exp $
-inherit base
ECLASS=java-pkg
INHERITED="${INHERITED} ${ECLASS}"
IUSE="${IUSE}"
diff --git a/eclass/java-utils.eclass b/eclass/java-utils.eclass
index 3400d69efc6d..71a4b7fbd48f 100644
--- a/eclass/java-utils.eclass
+++ b/eclass/java-utils.eclass
@@ -19,10 +19,11 @@ EXPORT_FUNCTIONS pkg_setup
java-utils_pkg_setup() {
java-utils_ensure-jdk
+
+ java-utils_vm-version-sufficient
}
java-utils_setup-vm() {
-
local vendor=`java-utils_get-vm-vendor`
if [ ${vendor} = "sun-jdk" ] && java-utils_is-vm-version-ge 1 5; then
addpredict "/dev/random"
@@ -47,7 +48,7 @@ java-utils_is-vm-jdk() {
return 0
else
return 1
- fi
+ fi
}
java-utils_get-vm-vendor() {
@@ -60,6 +61,13 @@ java-utils_get-vm-version() {
echo ${version}
}
+java-utils_vm-version-sufficient() {
+ local version=$(echo ${DEPEND} | sed -e 's:.*virtual/jdk-\?\([^$ ]*\).*:\1:' -e 's:\.: :g')
+ if [ "${version}" != "" ]; then
+ java-utils_ensure-vm-version-ge ${version}
+ fi
+}
+
java-utils_ensure-vm-version-ge() {
if ! java-utils_is-vm-version-ge $@ ; then
eerror "This package requires a Java VM version >= $@"
@@ -69,18 +77,17 @@ java-utils_ensure-vm-version-ge() {
}
java-utils_is-vm-version-ge() {
- local user_major=${1-0}
- local user_minor=${2-0}
- local user_patch=${3-0}
+ local user_major=${1:-0}
+ local user_minor=${2:-0}
+ local user_patch=${3:-0}
local user_version=${user_major}.${user_minor}.${user_patch}
-
- local vm_version=`java-utils_get-vm-version`
-
- local ver_rx="([0-9]+)\.([0-9]+)\.([0-9]+)(.*)"
- local vm_major=$(echo ${vm_version} | sed -r "s/${ver_rx}/\1/")
- local vm_minor=$(echo ${vm_version} | sed -r "s/${ver_rx}/\2/")
- local vm_patch=$(echo ${vm_version} | sed -r "s/${ver_rx}/\3/")
- local vm_extra=$(echo ${vm_version} | sed -r "s/${ver_rx}/\4/")
+
+ local vm_version=$(java-utils_get-vm-version)
+
+ local vm_major=$(echo ${vm_version} | cut -d. -f1)
+ local vm_minor=$(echo ${vm_version} | cut -d. -f2)
+ local vm_patch=$(echo ${vm_version} | cut -d. -f3)
+ local vm_extra=$(echo ${vm_version} | cut -d. -f4)
if [ ${vm_major} -ge ${user_major} ] && [ ${vm_minor} -gt ${user_minor} ] ; then
echo "Detected a JDK >= ${user_version}"