[icedtea-web] RFC: add a new autoconf macro IT_FIND_OPTIONAL_JAR
Dr Andrew John Hughes
ahughes at redhat.com
Tue Mar 8 09:33:08 PST 2011
On 10:44 Tue 08 Mar , Omair Majid wrote:
> Hi,
>
> The attached patch adds a new autoconf macro IT_FIND_OPTIONAL_JAR. This
> macro can be used to find jars that enable optional features in
> icedtea-web. I will be removing IT_FIND_RHINO_JAR in a separate patch.
>
> I will be using this to add support for junit.jar (for running unit
> tests) as well as tagsoup.jar (for parsing malformed jnlp file).
>
> Any thoughts or comments?
>
> ChangeLog:
>
> 2011-03-08 Omair Majid <omajid at redhat.com>
>
> * acinclude.m4 (IT_FIND_OPTIONAL_JAR): New macro.
> * configure.ac: Do not call IT_FIND_RHINO. Use IT_FIND_OPTIONAL_JAR
> instead.
>
> Cheers,
> Omair
Good idea. I assume this is based on IT_FIND_RHINO. Comments inline.
> diff -r 07924a054c63 acinclude.m4
> --- a/acinclude.m4 Mon Mar 07 17:09:22 2011 -0500
> +++ b/acinclude.m4 Tue Mar 08 10:38:44 2011 -0500
> @@ -250,6 +250,72 @@
> AC_SUBST(ECJ_JAR)
> ])
>
> +#
> +# IT_FIND_OPTIONAL_JAR
> +# --------------------
> +# Find an optional jar required for building and running
> +#
> +# $1 : jar/feature name
> +# $2 : used to set $2_JAR and WITH_$2
> +# $3 (optional) : used to specify extra file paths for searching
> +#
> +# Sets $2_JAR to the jar location (or blank if not found)
> +# Defines WITH_$2 if jar is found
> +#
> +AC_DEFUN([IT_FIND_OPTIONAL_JAR],
> +[
> + AC_MSG_CHECKING([for $1 jar])
> + AC_ARG_WITH([$1],
> + [AS_HELP_STRING(--with-$1,specify location of the $1 jar)],
> + [
> + case "${withval}" in
> + yes)
> + $2_JAR=yes
> + ;;
> + no)
> + $2_JAR=no
> + ;;
> + *)
> + if test -f "${withval}"; then
> + $2_JAR="${withval}"
> + elif test -z "${withval}"; then
> + $2_JAR=yes
> + else
> + AC_MSG_RESULT([not found])
> + AC_MSG_ERROR("The $1 jar ${withval} was not found.")
> + fi
> + ;;
> + esac
> + ],
> + [
> + $2_JAR=yes
> + ])
> + it_extra_paths_$1="$3"
> + if test "x${$2_JAR}" = "xyes"; then
> + for path in ${it_extra_paths_$1}; do
> + if test -f ${path}; then
> + $2_JAR=${path}
> + break;
> + fi
> + done
> + if test x"${$2_JAR}" = "xyes"; then
> + if test -f "/usr/share/java/$1.jar"; then
> + $2_JAR=/usr/share/java/$1.jar
> + fi
> + if test x"${$2_JAR}" = "xyes"; then
> + $2_JAR=no
> + fi
> + fi
> + fi
> + AC_MSG_RESULT(${$2_JAR})
> + AM_CONDITIONAL(WITH_$2, test x"${$2_JAR}" != "xno")
> +dnl Clear RHINO_JAR if it doesn't contain a valid filename
Comment needs fixing to say $2_JAR.
> + if test x"${$2_JAR}" = "xno"; then
> + $2_JAR=
> + fi
> + AC_SUBST($2_JAR)
> +])
> +
> AC_DEFUN([IT_FIND_RHINO_JAR],
> [
> AC_MSG_CHECKING([whether to include Javascript support via Rhino])
> diff -r 07924a054c63 configure.ac
> --- a/configure.ac Mon Mar 07 17:09:22 2011 -0500
> +++ b/configure.ac Tue Mar 08 10:38:44 2011 -0500
> @@ -33,7 +33,6 @@
> FIND_JAR
> FIND_ECJ_JAR
> IT_FIND_JAVADOC
> -IT_FIND_RHINO_JAR
> AC_CONFIG_FILES([javac], [chmod +x javac])
>
> IT_SET_VERSION
> @@ -50,6 +49,14 @@
> AC_SUBST(X11_CFLAGS)
> AC_SUBST(X11_LIBS)
>
> +IT_FIND_OPTIONAL_JAR([rhino], RHINO, [/usr/share/java/js.jar /usr/share/rhino-1.6/lib/js.jar])
Split this after 'RHINO,'.
> +if test -n "${RHINO_JAR}" ; then
> + RHINO_AVAILABLE=true
> +else
> + RHINO_AVAILABLE=false
> +fi
> +AC_SUBST(RHINO_AVAILABLE)
> +
Maybe a general version of this should also be in the macro.
> dnl PR46074 (gcc) - Missing java.net cookie code required by IcedTea plugin
> dnl IT563 - NetX uses sun.security code
> dnl IT564 - NetX depends on sun.misc.BASE64Encoder
--
Andrew :)
Free Java Software Engineer
Red Hat, Inc. (http://www.redhat.com)
Support Free Java!
Contribute to GNU Classpath and IcedTea
http://www.gnu.org/software/classpath
http://icedtea.classpath.org
PGP Key: F5862A37 (https://keys.indymedia.org/)
Fingerprint = EA30 D855 D50F 90CD F54D 0698 0713 C3ED F586 2A37
More information about the distro-pkg-dev
mailing list