[java-policy] 68/198: [java-common] Integrating to java-wrappers modifications suggested by Eric Lavarde
Emmanuel Bourg
ebourg-guest at moszumanska.debian.org
Wed Sep 23 07:49:31 UTC 2015
This is an automated email from the git hooks/post-receive script.
ebourg-guest pushed a commit to branch master
in repository java-policy.
commit 0db55da4425df906eae67b57cd674ae4b65d96a6
Author: Vincent Fourmond <fourmond at debian.org>
Date: Mon Jan 7 21:17:55 2008 +0000
[java-common] Integrating to java-wrappers modifications suggested by Eric Lavarde
---
wrappers/java-wrappers.7 | 45 ++++++++++++++++++
wrappers/java-wrappers.sh | 117 ++++++++++++++++++++++++++++++++++++----------
2 files changed, 137 insertions(+), 25 deletions(-)
diff --git a/wrappers/java-wrappers.7 b/wrappers/java-wrappers.7
index 25a850b..28c48ad 100644
--- a/wrappers/java-wrappers.7
+++ b/wrappers/java-wrappers.7
@@ -46,6 +46,20 @@ command that will be run. If this variable is set, it disables all
lookup for a java runtime.
.TP
+.B JAVA_BINDIR
+Specifies a directory that will be looked for a
+.I java
+or a
+.I jdb
+executable (depending on the setting of
+.IR JAVA_DEBUGGER ).
+It has precedence over
+.I JAVA_HOME
+but not over
+.IR JAVA_CMD .
+
+
+.TP
.B JAVA_HOME
A path to a java runtime. If this variable is set, all lookup for a
java runtime is disabled, except that if no
@@ -84,6 +98,18 @@ This is probably the most important variable; if it set, the wrapper
will print out useful information as it goes by its business, such as
which runtime it did find, and which command is run eventually.
+.TP
+.B JAVA_JARPATH
+The path where the wrappers will go looking for
+.I jar
+archives. If not set, the wrapper will look into the default
+directory,
+.IR /usr/share/java .
+.B Warning :
+the wrapper will not look anywhere else than in
+.IR JAVA_JARPATH .
+Setting it incorrectly will most probably result in early crashes.
+
.SH EXAMPLES
The examples all rely on
@@ -103,11 +129,30 @@ Force rasterizer to run with
.I JAVA_HOME=/usr/lib/kaffe rasterizer
+The same, but using
+.IR JAVA_BINDIR :
+
+.I JAVA_BINDIR=/usr/lib/kaffe/bin rasterizer
+
Debug rasterizer with Sun's debugger, while printing debugging
information from the wrapper:
.I DEBUG_WRAPPER=1 JAVA_CMD=/usr/lib/jvm/java-6-sun/bin/jdb rasterizer
+.SH BUGS
+
+Care has been taken to make the wrappers bug-free. If that was not
+the case, please file a bug report against
+.B java-common
+with a java-wrappers in the title.
+
+If you wish to submit any problem with a java executable relying on
+.BR java-wrappers ,
+please also submit the output of the command run with
+.IR DEBUG_WRAPPER=1 .
+It will save one mail exchange and therefore potentially reduce the
+time it will take to fix the bug.
+
.SH SEE ALSO
.BR java (1),
diff --git a/wrappers/java-wrappers.sh b/wrappers/java-wrappers.sh
index faa2152..27d50cd 100644
--- a/wrappers/java-wrappers.sh
+++ b/wrappers/java-wrappers.sh
@@ -15,11 +15,6 @@
# License along with this library; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
-# Some initializations:
-[ "$DESTDIR" ] || DESTDIR=
-[ "$JAVA_CLASSPATH" ] || JAVA_CLASSPATH=
-
-
# Display a debugging message
java_debug() {
if [ "$DEBUG_WRAPPER" ]; then
@@ -38,6 +33,24 @@ java_fail() {
exit 1;
}
+# Some initializations:
+if [ "$JAVA_CLASSPATH" ]; then
+ java_debug "Building classpath on JAVA_CLASSPATH = '$JAVA_CLASSPATH'"
+else
+ JAVA_CLASSPATH=
+fi
+if [ "$DESTDIR" ]; then
+ java_debug "Using DESTDIR = '$DESTDIR'"
+else
+ DESTDIR=""
+fi
+
+if [ "$JAVA_JARPATH" ]; then
+ java_debug "Jar lookup is done in JAVA_JARPATH = '$JAVA_JARPATH'"
+else
+ JAVA_JARPATH=$DESTDIR/usr/share/java
+fi
+
# Try to find a Java runtime and set JAVA_HOME and JAVA_CMD accordingly.
# If JAVA_CMD exists, nothing is done. If JAVA_HOME exists, only that
@@ -58,7 +71,13 @@ java_fail() {
# This information is currently *far from complete* !!!
find_java_runtime() {
# First, known runtimes:
- sun_java="/usr/lib/jvm/java-6-sun /usr/lib/jvm/java-1.5.0-sun /usr/lib/j2sdk1.4-sun /usr/lib/j2*1.[456]-sun"
+
+ sun5="/usr/lib/jvm/java-1.5.0-sun /usr/lib/j2*1.5-sun"
+ sun4="/usr/lib/j2*1.4-sun"
+ sun6="/usr/lib/jvm/java-6-sun /usr/lib/j2*1.6-sun"
+
+ sun_java="$sun4 $sun5 $sun6"
+
gcj2="/usr/lib/jvm/java-*-gcj-4.* "
sablevm="/usr/lib/sablevm"
kaffe="/usr/lib/kaffe /usr/lib/kaffe/pthreads /usr/lib/kaffe/jthreads"
@@ -81,8 +100,27 @@ find_java_runtime() {
xml_extra="/usr/lib/jvm/java-6-sun /usr/lib/jvm/java-1.5.0-sun"
if [ "$JAVA_CMD" ]; then
- java_debug "Using already set JAVA_CMD = $JAVA_CMD"
- return 0; # Nothing to do
+ if which "$JAVA_CMD" > /dev/null; then
+ java_debug "Using already set JAVA_CMD = '$JAVA_CMD' => '"`which "$JAVA_CMD"`"'"
+ return 0; # Nothing to do
+ else
+ java_warning "JAVA_CMD was set to '$JAVA_CMD', but which(1) does not find it."
+ java_warning "Therefore ignoring JAVA_CMD"
+ fi
+ fi
+
+ if [ -z "$JAVA_BINDIR" ]; then
+ if [ "$JAVA_DEBUGGER" ] && [ -x "$JAVA_BINDIR/jdb" ]; then
+ JAVA_CMD="$JAVA_BINDIR/jdb"
+ elif [ -x "$JAVA_BINDIR/java" ]; then
+ JAVA_CMD="$JAVA_BINDIR/java"
+ fi
+ if [ "$JAVA_CMD" ]; then
+ java_debug "Using '$JAVA_CMD' from JAVA_BINDIR = '$JAVA_BINDIR'"
+ return 0;
+ else
+ java_warning "JAVA_BINDIR = '$JAVA_BINDIR' does not point to a java binary"
+ fi
fi
if [ -z "$JAVA_HOME" ]; then
@@ -97,7 +135,11 @@ find_java_runtime() {
;;
sun) DIRS=$sun_java
;;
- sun6) DIRS=/usr/lib/jvm/java-6-sun
+ sunmax5) DIRS="$sun4 $sun5"
+ ;;
+ sunmin5) DIRS="$sun5 $sun6"
+ ;;
+ sun6) DIRS=$sun6
;;
fullxml) DIRS=$xml_extra
;;
@@ -111,6 +153,8 @@ find_java_runtime() {
break;
fi
done
+ else
+ java_debug "Using provided JAVA_HOME = '$JAVA_HOME'"
fi
if [ "$JAVA_HOME" ] ; then
if [ "$JAVA_DEBUGGER" ] && [ -x "$JAVA_HOME/bin/jdb" ]; then
@@ -118,8 +162,8 @@ find_java_runtime() {
else
JAVA_CMD="$JAVA_HOME/bin/java"
fi
- java_debug "Found JAVA_HOME = $JAVA_HOME"
- java_debug "Found JAVA_CMD = $JAVA_CMD"
+ java_debug "Found JAVA_HOME = '$JAVA_HOME'"
+ java_debug "Found JAVA_CMD = '$JAVA_CMD'"
return 0 # Fine
else
java_warning "No java runtime was found for flavor '${1:-none}'"
@@ -134,16 +178,36 @@ require_java_runtime() {
java_fail "Unable to find an appropriate java runtime. See java_wrappers(7) for help"
}
+# Looks for a jar file and returns its location as the
+# found_jar variable, or fails if no jar was found.
+locate_jar() {
+ jar="$1"
+ if [ -r $JAVA_JARPATH/$jar ]; then
+ found_jar=$JAVA_JARPATH/$jar
+ elif [ -r $JAVA_JARPATH/$jar.jar ]; then
+ found_jar=$JAVA_JARPATH/$jar.jar
+ elif [ -r $jar ]; then
+ # Maybe issue a warning that jars should not be looked
+ # for absolutely ?
+ found_jar=$JAVA_JARPATH/$jar
+ elif [ -r $jar.jar ]; then
+ # Maybe issue a warning that jars should not be looked
+ # for absolutely ?
+ found_jar=$JAVA_JARPATH/$jar.jar
+ else
+ return 1 # Not found
+ fi
+ return 0 # Found
+}
+
# Find jars and add them to the classpath
find_jars() {
looked_for_jars=1
for jar in $@ ; do
- if [ -r $DESTDIR/usr/share/java/$jar ]; then
- JAVA_CLASSPATH=$JAVA_CLASSPATH:$DESTDIR/usr/share/java/$jar
- elif [ -r $DESTDIR/usr/share/java/$jar.jar ]; then
- JAVA_CLASSPATH=$JAVA_CLASSPATH:$DESTDIR/usr/share/java/$jar.jar
+ if locate_jar $jar; then
+ JAVA_CLASSPATH=$JAVA_CLASSPATH:$found_jar
else
- java_warning "Unable to locate $jar in $DESTDIR/usr/share/java/"
+ java_warning "Unable to locate $jar in $JAVA_JARPATH"
fi
done
}
@@ -153,32 +217,30 @@ find_jars() {
find_one_jar_in() {
looked_for_jars=1
for jar in $@ ; do
- if [ -r $DESTDIR/usr/share/java/$jar ]; then
- JAVA_CLASSPATH=$JAVA_CLASSPATH:$DESTDIR/usr/share/java/$jar
- return 0
- elif [ -r $DESTDIR/usr/share/java/$jar.jar ]; then
- JAVA_CLASSPATH=$JAVA_CLASSPATH:$DESTDIR/usr/share/java/$jar.jar
+ if locate_jar $jar; do
+ JAVA_CLASSPATH=$JAVA_CLASSPATH:$found_jar
return 0
fi
done
- java_warning "Could fine none of $@ in $DESTDIR/usr/share/java/"
+ java_warning "Could fine none of $@ in $JAVA_JARPATH"
return 1
}
# Runs the program !
run_java() {
if [ -z "$JAVA_CMD" ]; then
- java_warning "No JAVA_CMD set for run_java, using JAVA_CMD = java"
+ java_warning "No JAVA_CMD set for run_java, falling back to JAVA_CMD = java"
JAVA_CMD=java
fi
if [ "$FORCE_CLASSPATH" ]; then
- java_debug "Using unmodified classpath : $FORCE_CLASSPATH";
+ java_debug "Using imposed classpath : FORCE_CLASSPATH = '$FORCE_CLASSPATH'";
cp="-classpath $FORCE_CLASSPATH";
elif [ "$JAVA_CLASSPATH" ]; then
cp="-classpath $JAVA_CLASSPATH";
else
cp="";
fi
+ java_debug "Environment variable CLASSPATH is '$CLASSPATH'"
java_debug "Runnning $JAVA_CMD $JAVA_ARGS $cp $@"
exec $JAVA_CMD $JAVA_ARGS $cp "$@"
}
@@ -190,5 +252,10 @@ run_jar() {
java_warning "It is most likely useless to use find_jar when running"
java_warning "a class with run_jar (-classpath is ignored)"
fi
- run_java -jar "$@"
+ if locate_jar $1; then
+ shift
+ run_java -jar "$@"
+ else
+ java_fail "Unable to find jar $1 in $JAVA_JARPATH"
+ fi
}
\ No newline at end of file
--
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-java/java-policy.git
More information about the pkg-java-commits
mailing list