All of lore.kernel.org
 help / color / mirror / Atom feed
From: Don Slutz <dslutz@verizon.com>
To: Roger Pau Monne <roger.pau@citrix.com>, xen-devel@lists.xenproject.org
Cc: Ian Jackson <ian.jackson@citrix.com>,
	Ian Campbell <ian.campbell@citrix.com>,
	Don Slutz <dslutz@verizon.com>
Subject: Re: [PATCH v2] tools: require OCaml version 3.09.3 or greater
Date: Tue, 11 Feb 2014 11:22:35 -0500	[thread overview]
Message-ID: <52FA4E4B.2000906@terremark.com> (raw)
In-Reply-To: <1392115104-22828-1-git-send-email-roger.pau@citrix.com>

On 02/11/14 05:38, Roger Pau Monne wrote:
> Signed-off-by: Roger Pau Monné <roger.pau@citrix.com>
> Cc: Don Slutz <dslutz@verizon.com>
> Cc: Ian Campbell <ian.campbell@citrix.com>
> Cc: Ian Jackson <ian.jackson@citrix.com>
> ---
> I've removed Don's "Tested-by" because the patch has changed, could
> you please re-test it Don?
>
> Please run autogen.sh after applying.

I have retested after applying, and autogen.sh ran cleanly for me on Fedora 17 system.  Fails (as expected on CentOS 5.10).

So you can add

Tested-by: Don Slutz <dslutz@verizon.com>

    -Don Slutz

> ---
>   m4/ax_compare_version.m4 |  179 ++++++++++++++++++++++++++++++++++++++++++++++
>   tools/configure.ac       |    7 ++
>   2 files changed, 186 insertions(+), 0 deletions(-)
>   create mode 100644 m4/ax_compare_version.m4
>
> diff --git a/m4/ax_compare_version.m4 b/m4/ax_compare_version.m4
> new file mode 100644
> index 0000000..26f4dec
> --- /dev/null
> +++ b/m4/ax_compare_version.m4
> @@ -0,0 +1,179 @@
> +# Fetched from http://git.savannah.gnu.org/gitweb/?p=autoconf-archive.git;a=blob_plain;f=m4/ax_compare_version.m4
> +# Commit ID: 27948f49ca30e4222bb7cdd55182bd7341ac50c5
> +# ===========================================================================
> +#    http://www.gnu.org/software/autoconf-archive/ax_compare_version.html
> +# ===========================================================================
> +#
> +# SYNOPSIS
> +#
> +#   AX_COMPARE_VERSION(VERSION_A, OP, VERSION_B, [ACTION-IF-TRUE], [ACTION-IF-FALSE])
> +#
> +# DESCRIPTION
> +#
> +#   This macro compares two version strings. Due to the various number of
> +#   minor-version numbers that can exist, and the fact that string
> +#   comparisons are not compatible with numeric comparisons, this is not
> +#   necessarily trivial to do in a autoconf script. This macro makes doing
> +#   these comparisons easy.
> +#
> +#   The six basic comparisons are available, as well as checking equality
> +#   limited to a certain number of minor-version levels.
> +#
> +#   The operator OP determines what type of comparison to do, and can be one
> +#   of:
> +#
> +#    eq  - equal (test A == B)
> +#    ne  - not equal (test A != B)
> +#    le  - less than or equal (test A <= B)
> +#    ge  - greater than or equal (test A >= B)
> +#    lt  - less than (test A < B)
> +#    gt  - greater than (test A > B)
> +#
> +#   Additionally, the eq and ne operator can have a number after it to limit
> +#   the test to that number of minor versions.
> +#
> +#    eq0 - equal up to the length of the shorter version
> +#    ne0 - not equal up to the length of the shorter version
> +#    eqN - equal up to N sub-version levels
> +#    neN - not equal up to N sub-version levels
> +#
> +#   When the condition is true, shell commands ACTION-IF-TRUE are run,
> +#   otherwise shell commands ACTION-IF-FALSE are run. The environment
> +#   variable 'ax_compare_version' is always set to either 'true' or 'false'
> +#   as well.
> +#
> +#   Examples:
> +#
> +#     AX_COMPARE_VERSION([3.15.7],[lt],[3.15.8])
> +#     AX_COMPARE_VERSION([3.15],[lt],[3.15.8])
> +#
> +#   would both be true.
> +#
> +#     AX_COMPARE_VERSION([3.15.7],[eq],[3.15.8])
> +#     AX_COMPARE_VERSION([3.15],[gt],[3.15.8])
> +#
> +#   would both be false.
> +#
> +#     AX_COMPARE_VERSION([3.15.7],[eq2],[3.15.8])
> +#
> +#   would be true because it is only comparing two minor versions.
> +#
> +#     AX_COMPARE_VERSION([3.15.7],[eq0],[3.15])
> +#
> +#   would be true because it is only comparing the lesser number of minor
> +#   versions of the two values.
> +#
> +#   Note: The characters that separate the version numbers do not matter. An
> +#   empty string is the same as version 0. OP is evaluated by autoconf, not
> +#   configure, so must be a string, not a variable.
> +#
> +#   The author would like to acknowledge Guido Draheim whose advice about
> +#   the m4_case and m4_ifvaln functions make this macro only include the
> +#   portions necessary to perform the specific comparison specified by the
> +#   OP argument in the final configure script.
> +#
> +# LICENSE
> +#
> +#   Copyright (c) 2008 Tim Toolan <toolan@ele.uri.edu>
> +#
> +#   Copying and distribution of this file, with or without modification, are
> +#   permitted in any medium without royalty provided the copyright notice
> +#   and this notice are preserved. This file is offered as-is, without any
> +#   warranty.
> +
> +#serial 11
> +
> +dnl #########################################################################
> +AC_DEFUN([AX_COMPARE_VERSION], [
> +  AC_REQUIRE([AC_PROG_AWK])
> +
> +  # Used to indicate true or false condition
> +  ax_compare_version=false
> +
> +  # Convert the two version strings to be compared into a format that
> +  # allows a simple string comparison.  The end result is that a version
> +  # string of the form 1.12.5-r617 will be converted to the form
> +  # 0001001200050617.  In other words, each number is zero padded to four
> +  # digits, and non digits are removed.
> +  AS_VAR_PUSHDEF([A],[ax_compare_version_A])
> +  A=`echo "$1" | sed -e 's/\([[0-9]]*\)/Z\1Z/g' \
> +                     -e 's/Z\([[0-9]]\)Z/Z0\1Z/g' \
> +                     -e 's/Z\([[0-9]][[0-9]]\)Z/Z0\1Z/g' \
> +                     -e 's/Z\([[0-9]][[0-9]][[0-9]]\)Z/Z0\1Z/g' \
> +                     -e 's/[[^0-9]]//g'`
> +
> +  AS_VAR_PUSHDEF([B],[ax_compare_version_B])
> +  B=`echo "$3" | sed -e 's/\([[0-9]]*\)/Z\1Z/g' \
> +                     -e 's/Z\([[0-9]]\)Z/Z0\1Z/g' \
> +                     -e 's/Z\([[0-9]][[0-9]]\)Z/Z0\1Z/g' \
> +                     -e 's/Z\([[0-9]][[0-9]][[0-9]]\)Z/Z0\1Z/g' \
> +                     -e 's/[[^0-9]]//g'`
> +
> +  dnl # In the case of le, ge, lt, and gt, the strings are sorted as necessary
> +  dnl # then the first line is used to determine if the condition is true.
> +  dnl # The sed right after the echo is to remove any indented white space.
> +  m4_case(m4_tolower($2),
> +  [lt],[
> +    ax_compare_version=`echo "x$A
> +x$B" | sed 's/^ *//' | sort -r | sed "s/x${A}/false/;s/x${B}/true/;1q"`
> +  ],
> +  [gt],[
> +    ax_compare_version=`echo "x$A
> +x$B" | sed 's/^ *//' | sort | sed "s/x${A}/false/;s/x${B}/true/;1q"`
> +  ],
> +  [le],[
> +    ax_compare_version=`echo "x$A
> +x$B" | sed 's/^ *//' | sort | sed "s/x${A}/true/;s/x${B}/false/;1q"`
> +  ],
> +  [ge],[
> +    ax_compare_version=`echo "x$A
> +x$B" | sed 's/^ *//' | sort -r | sed "s/x${A}/true/;s/x${B}/false/;1q"`
> +  ],[
> +    dnl Split the operator from the subversion count if present.
> +    m4_bmatch(m4_substr($2,2),
> +    [0],[
> +      # A count of zero means use the length of the shorter version.
> +      # Determine the number of characters in A and B.
> +      ax_compare_version_len_A=`echo "$A" | $AWK '{print(length)}'`
> +      ax_compare_version_len_B=`echo "$B" | $AWK '{print(length)}'`
> +
> +      # Set A to no more than B's length and B to no more than A's length.
> +      A=`echo "$A" | sed "s/\(.\{$ax_compare_version_len_B\}\).*/\1/"`
> +      B=`echo "$B" | sed "s/\(.\{$ax_compare_version_len_A\}\).*/\1/"`
> +    ],
> +    [[0-9]+],[
> +      # A count greater than zero means use only that many subversions
> +      A=`echo "$A" | sed "s/\(\([[0-9]]\{4\}\)\{m4_substr($2,2)\}\).*/\1/"`
> +      B=`echo "$B" | sed "s/\(\([[0-9]]\{4\}\)\{m4_substr($2,2)\}\).*/\1/"`
> +    ],
> +    [.+],[
> +      AC_WARNING(
> +        [illegal OP numeric parameter: $2])
> +    ],[])
> +
> +    # Pad zeros at end of numbers to make same length.
> +    ax_compare_version_tmp_A="$A`echo $B | sed 's/./0/g'`"
> +    B="$B`echo $A | sed 's/./0/g'`"
> +    A="$ax_compare_version_tmp_A"
> +
> +    # Check for equality or inequality as necessary.
> +    m4_case(m4_tolower(m4_substr($2,0,2)),
> +    [eq],[
> +      test "x$A" = "x$B" && ax_compare_version=true
> +    ],
> +    [ne],[
> +      test "x$A" != "x$B" && ax_compare_version=true
> +    ],[
> +      AC_WARNING([illegal OP parameter: $2])
> +    ])
> +  ])
> +
> +  AS_VAR_POPDEF([A])dnl
> +  AS_VAR_POPDEF([B])dnl
> +
> +  dnl # Execute ACTION-IF-TRUE / ACTION-IF-FALSE.
> +  if test "$ax_compare_version" = "true" ; then
> +    m4_ifvaln([$4],[$4],[:])dnl
> +    m4_ifvaln([$5],[else $5])dnl
> +  fi
> +]) dnl AX_COMPARE_VERSION
> diff --git a/tools/configure.ac b/tools/configure.ac
> index 0754f0e..3496c12 100644
> --- a/tools/configure.ac
> +++ b/tools/configure.ac
> @@ -46,6 +46,7 @@ m4_include([../m4/pthread.m4])
>   m4_include([../m4/ptyfuncs.m4])
>   m4_include([../m4/extfs.m4])
>   m4_include([../m4/fetcher.m4])
> +m4_include([../m4/ax_compare_version.m4])
>   
>   # Enable/disable options
>   AX_ARG_DEFAULT_DISABLE([githttp], [Download GIT repositories via HTTP])
> @@ -161,6 +162,12 @@ AS_IF([test "x$ocamltools" = "xy"], [
>           AS_IF([test "x$enable_ocamltools" = "xyes"], [
>               AC_MSG_ERROR([Ocaml tools enabled, but unable to find Ocaml])])
>           ocamltools="n"
> +    ], [
> +        AX_COMPARE_VERSION([$OCAMLVERSION], [lt], [3.09.3], [
> +            AS_IF([test "x$enable_ocamltools" = "xyes"], [
> +                AC_MSG_ERROR([Your version of OCaml: $OCAMLVERSION is not supported])])
> +            ocamltools="n"
> +        ])
>       ])
>   ])
>   AS_IF([test "x$xsmpolicy" = "xy"], [


_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xen.org
http://lists.xen.org/xen-devel

  parent reply	other threads:[~2014-02-11 16:22 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-02-11 10:38 [PATCH v2] tools: require OCaml version 3.09.3 or greater Roger Pau Monne
2014-02-11 12:49 ` Ian Campbell
2014-02-11 13:02   ` Roger Pau Monné
2014-02-11 16:23     ` Don Slutz
2014-02-11 16:22 ` Don Slutz [this message]
2014-03-12 14:50   ` Ian Campbell
2014-04-25 12:14     ` Ian Campbell
2014-04-30 15:04       ` Ian Jackson
2014-04-30 15:10         ` Ian Campbell
2014-04-30 23:01           ` Don Slutz
2014-05-02 16:28             ` Ian Jackson
2014-05-22 15:39               ` Ian Jackson

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=52FA4E4B.2000906@terremark.com \
    --to=dslutz@verizon.com \
    --cc=ian.campbell@citrix.com \
    --cc=ian.jackson@citrix.com \
    --cc=roger.pau@citrix.com \
    --cc=xen-devel@lists.xenproject.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.