[rfc][icedtea-web] get the custom jre in shell-launchers too
Adam Domurad
adomurad at redhat.com
Wed Mar 20 12:47:18 PDT 2013
On 03/20/2013 06:54 AM, Jiri Vanek wrote:
> On 02/22/2013 05:21 PM, Adam Domurad wrote:
>> On 02/22/2013 09:43 AM, Jiri Vanek wrote:
>>> And finally bash launchers can check for the custom jre value too....
>>>
>>>
>>> J.
>>>
>>> ps: part of.. you know...
>>> pps: does this really replace all the c code!??!?! /me started to
>>> like bash
>>
>> It would be nice if C++ had a regex library. (added in C++11, but I
>> doubt we'll see icedtea-web move
>> to C++11.)
>>
>> Actually during my internship I started to quite like hacking stuff
>> with bash. Great & modular
>> 'standard library' :-)
>>
>>> diff -r ad2e15f15a75 launcher/itweb-settings.in
>>> --- a/launcher/itweb-settings.in Thu Feb 21 15:26:38 2013 -0500
>>> +++ b/launcher/itweb-settings.in Fri Feb 22 15:41:10 2013 +0100
>>> @@ -7,6 +7,16 @@
>>> BINARY_LOCATION=@ITWEB_SETTINGS_BIN_LOCATION@
>>> PROGRAM_NAME=itweb-settings
>>>
>>> +a="^deployment.jre.dir *= *"
>>
>> 'a' could probably get a better name here, ie 'JRE_PROPERTY' or
>> some-such.
>>
>>> +CUSTOM_JRE=`grep "$a" ~/.icedtea/deployment.properties 2>/dev/null
>>> | sed "s/$a//g"`
>>> +if [ "x$CUSTOM_JRE" = "x" ] ; then
>>> + CUSTOM_JRE=`grep "$a" /etc/.java/.deploy/deployment.properties
>>> 2>/dev/null | sed "s/$a//g"`
>>> +fi;
>>> +if [ "x$CUSTOM_JRE" != "x" ] ; then
>>> + JAVA=$CUSTOM_JRE/bin/java
>>> + CP=$CUSTOM_JRE/lib/rt.jar
>>
>> AFAIK this CP= is not needed in itweb-settings.in.
>>
>>> +fi;
>>> +
>>> ${JAVA} ${LAUNCHER_BOOTCLASSPATH} ${LAUNCHER_FLAGS} \
>>> -Dicedtea-web.bin.name=${PROGRAM_NAME} \
>>> -Dicedtea-web.bin.location=${BINARY_LOCATION} \
>>> diff -r ad2e15f15a75 launcher/javaws.in
>>> --- a/launcher/javaws.in Thu Feb 21 15:26:38 2013 -0500
>>> +++ b/launcher/javaws.in Fri Feb 22 15:41:10 2013 +0100
>>> @@ -9,6 +9,16 @@
>>> PROGRAM_NAME=javaws
>>> CP=@JRE@/lib/rt.jar
>>>
>>> +a="^deployment.jre.dir *= *"
>>> +CUSTOM_JRE=`grep "$a" ~/.icedtea/deployment.properties 2>/dev/null
>>> | sed "s/$a//g"`
>>> +if [ "x$CUSTOM_JRE" = "x" ] ; then
>>> + CUSTOM_JRE=`grep "$a" /etc/.java/.deploy/deployment.properties
>>> 2>/dev/null | sed "s/$a//g"`
>>> +fi;
>>> +if [ "x$CUSTOM_JRE" != "x" ] ; then
>>
>> This is funny. Are you trying to test for a non-empty string ?
>> [ "$CUSTOM_JRE" != "" ] works fine. ( [ $CUSTOM_JRE != "x" ] is the
>> one that does not )
>> Since we have a default, it may also be worth checking [ -e
>> "$CUSTOM_JRE" ] (file exists) here (and
>> above).
>>
>>> + JAVA=$CUSTOM_JRE/bin/java
>>> + CP=$CUSTOM_JRE/lib/rt.jar
>>> +fi;
>>> +
>>> JAVA_ARGS=( )
>>> ARGS=( )
>>> COMMAND=()
>>
>> Overall this is quite OK, if we do end up including the JRE path in
>> the deployment properties file.
>> Maybe though it will make life simpler if it's in its own file, eg
>> '.icedtea/jre-path'?
>>
>> You have a very valid point about the fact that we should avoid
>> spawning a Java instance just to get
>> the JVM arguments, however.
>> We might still want to parse the properties file for this, or we
>> could place it in the file with the
>> JRE path.
>> Considering that we need to extract this property from bash, C &
>> Java, it might make sense to use
>> the simplest format possible though. It would be very bad if a small
>> mistake in how the property
>> file is treated in Bash or C causes ITW not to be able to run.
>>
>> Anyway properties file is not an overly scary format, but still worth
>> thinking about.
>>
>> Happy hacking,
>> -Adam
>
>
> So I think this can go inside. Oook?
>
> J.
Overall it looks fine, but...
> diff -r e6c51c4b4d20 -r a9920eea7c17 launcher/itweb-settings.in
> --- a/launcher/itweb-settings.in Wed Mar 13 14:51:20 2013 +0100
> +++ b/launcher/itweb-settings.in Mon Mar 18 11:30:39 2013 +0100
> @@ -7,6 +7,15 @@
> BINARY_LOCATION=@ITWEB_SETTINGS_BIN_LOCATION@
> PROGRAM_NAME=itweb-settings
>
> +CUSTOM_JRE_REGEX="^deployment.jre.dir *= *"
> +CUSTOM_JRE=`grep "$CUSTOM_JRE_REGEX" ~/.icedtea/deployment.properties
> 2>/dev/null | sed "s/$CUSTOM_JRE_REGEX//g"`
> +if [ "x$CUSTOM_JRE" = "x" ] ; then
> + CUSTOM_JRE=`grep "$CUSTOM_JRE_REGEX"
> /etc/.java/.deploy/deployment.properties 2>/dev/null | sed
> "s/$CUSTOM_JRE_REGEX//g"`
> +fi;
> +if [ "x$CUSTOM_JRE" != "x" ] ; then
> + JAVA=$CUSTOM_JRE/bin/java
> +fi;
> +
> ${JAVA} ${LAUNCHER_BOOTCLASSPATH} ${LAUNCHER_FLAGS} \
> -Dicedtea-web.bin.name=${PROGRAM_NAME} \
> -Dicedtea-web.bin.location=${BINARY_LOCATION} \
> diff -r e6c51c4b4d20 -r a9920eea7c17 launcher/javaws.in
> --- a/launcher/javaws.in Wed Mar 13 14:51:20 2013 +0100
> +++ b/launcher/javaws.in Mon Mar 18 11:30:39 2013 +0100
> @@ -9,6 +9,16 @@
> PROGRAM_NAME=javaws
> CP=@JRE@/lib/rt.jar
>
> +CUSTOM_JRE_REGEX="^deployment.jre.dir *= *"
> +CUSTOM_JRE=`grep "$CUSTOM_JRE_REGEX" ~/.icedtea/deployment.properties
> 2>/dev/null | sed "s/$CUSTOM_JRE_REGEX//g"`
> +if [ "x$CUSTOM_JRE" = "x" ] ; then
Please just use [ "$CUSTOM_JRE" = "" ] instead of this mysterious thing.
> + CUSTOM_JRE=`grep "$CUSTOM_JRE_REGEX"
> /etc/.java/.deploy/deployment.properties 2>/dev/null | sed
> "s/$CUSTOM_JRE_REGEX//g"`
> +fi;
> +if [ "x$CUSTOM_JRE" != "x" ] ; then
Please just use [ "$CUSTOM_JRE" != "" ] instead of this mysterious thing.
> + JAVA=$CUSTOM_JRE/bin/java
> + CP=$CUSTOM_JRE/lib/rt.jar
> +fi;
> +
> JAVA_ARGS=( )
> ARGS=( )
> COMMAND=()
-Adam
More information about the distro-pkg-dev
mailing list