gst-gmyth/m4/gst-feature.m4
branchtrunk
changeset 911 da7ce603d47f
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/gst-gmyth/m4/gst-feature.m4	Mon Feb 04 18:23:49 2008 +0000
     1.3 @@ -0,0 +1,211 @@
     1.4 +dnl Perform a check for a feature for GStreamer
     1.5 +dnl Richard Boulton <richard-alsa@tartarus.org>
     1.6 +dnl Thomas Vander Stichele <thomas@apestaart.org> added useful stuff
     1.7 +dnl Last modification: 25/06/2001
     1.8 +dnl GST_CHECK_FEATURE(FEATURE-NAME, FEATURE-DESCRIPTION,
     1.9 +dnl                   DEPENDENT-PLUGINS, TEST-FOR-FEATURE,
    1.10 +dnl                   DISABLE-BY-DEFAULT, ACTION-IF-USE, ACTION-IF-NOTUSE)
    1.11 +dnl
    1.12 +dnl This macro adds a command line argument to enable the user to enable
    1.13 +dnl or disable a feature, and if the feature is enabled, performs a supplied
    1.14 +dnl test to check if the feature is available.
    1.15 +dnl
    1.16 +dnl The test should define HAVE_<FEATURE-NAME> to "yes" or "no" depending
    1.17 +dnl on whether the feature is available.
    1.18 +dnl
    1.19 +dnl The macro will set USE_<FEATURE-NAME> to "yes" or "no" depending on
    1.20 +dnl whether the feature is to be used.
    1.21 +dnl Thomas changed this, so that when USE_<FEATURE-NAME> was already set
    1.22 +dnl to no, then it stays that way.
    1.23 +dnl
    1.24 +dnl The macro will call AM_CONDITIONAL(USE_<<FEATURE-NAME>, ...) to allow
    1.25 +dnl the feature to control what is built in Makefile.ams.  If you want
    1.26 +dnl additional actions resulting from the test, you can add them with the
    1.27 +dnl ACTION-IF-USE and ACTION-IF-NOTUSE parameters.
    1.28 +dnl 
    1.29 +dnl FEATURE-NAME        is the name of the feature, and should be in
    1.30 +dnl                     purely upper case characters.
    1.31 +dnl FEATURE-DESCRIPTION is used to describe the feature in help text for
    1.32 +dnl                     the command line argument.
    1.33 +dnl DEPENDENT-PLUGINS   lists any plugins which depend on this feature.
    1.34 +dnl TEST-FOR-FEATURE    is a test which sets HAVE_<FEATURE-NAME> to "yes"
    1.35 +dnl                     or "no" depending on whether the feature is
    1.36 +dnl                     available.
    1.37 +dnl DISABLE-BY-DEFAULT  if "disabled", the feature is disabled by default,
    1.38 +dnl                     if any other value, the feature is enabled by default.
    1.39 +dnl ACTION-IF-USE       any extra actions to perform if the feature is to be
    1.40 +dnl                     used.
    1.41 +dnl ACTION-IF-NOTUSE    any extra actions to perform if the feature is not to
    1.42 +dnl                     be used.
    1.43 +dnl
    1.44 +dnl
    1.45 +dnl thomas :
    1.46 +dnl we also added a history.  
    1.47 +dnl GST_PLUGINS_YES will contain all plugins to be built
    1.48 +dnl                 that were checked through GST_CHECK_FEATURE
    1.49 +dnl GST_PLUGINS_NO will contain those that won't be built
    1.50 +
    1.51 +AC_DEFUN([GST_CHECK_FEATURE],
    1.52 +AC_MSG_NOTICE(***)
    1.53 +AC_MSG_NOTICE(*** checking plugin: [$3] ***)
    1.54 +AC_MSG_NOTICE(***)
    1.55 +[dnl
    1.56 +builtin(define, [gst_endisable], ifelse($5, [disabled], [enable], [disable]))dnl
    1.57 +dnl if it is set to NO, then don't even consider it for building
    1.58 +NOUSE=
    1.59 +if test "x$USE_[$1]" = "xno"; then
    1.60 +  NOUSE="yes"
    1.61 +fi
    1.62 +AC_ARG_ENABLE(translit([$1], A-Z, a-z),
    1.63 +  [  ]builtin(format, --%-26s gst_endisable %s, gst_endisable-translit([$1], A-Z, a-z), [$2]ifelse([$3],,,: [$3])),
    1.64 +  [ case "${enableval}" in
    1.65 +      yes) USE_[$1]=yes;;
    1.66 +      no) USE_[$1]=no;;
    1.67 +      *) AC_MSG_ERROR(bad value ${enableval} for --enable-translit([$1], A-Z, a-z)) ;;
    1.68 +    esac],
    1.69 +  [ USE_$1=]ifelse($5, [disabled], [no], [yes]))           dnl DEFAULT
    1.70 +
    1.71 +dnl *** set it back to no if it was preset to no
    1.72 +if test "x$NOUSE" = "xyes"; then
    1.73 +  USE_[$1]="no"
    1.74 +  AC_MSG_WARN(*** $3 pre-configured not to be built)
    1.75 +fi
    1.76 +NOUSE=
    1.77 +
    1.78 +dnl *** If it's enabled
    1.79 +
    1.80 +if test x$USE_[$1] = xyes; then
    1.81 +  dnl save compile variables before the test
    1.82 +
    1.83 +  gst_check_save_LIBS=$LIBS
    1.84 +  gst_check_save_LDFLAGS=$LDFLAGS
    1.85 +  gst_check_save_CFLAGS=$CFLAGS
    1.86 +  gst_check_save_CPPFLAGS=$CPPFLAGS
    1.87 +  gst_check_save_CXXFLAGS=$CXXFLAGS
    1.88 +
    1.89 +  HAVE_[$1]=no
    1.90 +  dnl TEST_FOR_FEATURE
    1.91 +  $4
    1.92 +
    1.93 +  LIBS=$gst_check_save_LIBS
    1.94 +  LDFLAGS=$gst_check_save_LDFLAGS
    1.95 +  CFLAGS=$gst_check_save_CFLAGS
    1.96 +  CPPFLAGS=$gst_check_save_CPPFLAGS
    1.97 +  CXXFLAGS=$gst_check_save_CXXFLAGS
    1.98 +
    1.99 +  dnl If it isn't found, unset USE_[$1]
   1.100 +  if test x$HAVE_[$1] = xno; then
   1.101 +    USE_[$1]=no
   1.102 +  fi
   1.103 +fi
   1.104 +dnl *** Warn if it's disabled or not found
   1.105 +if test x$USE_[$1] = xyes; then
   1.106 +  ifelse([$6], , :, [$6])
   1.107 +  if test "x$3" != "x"; then
   1.108 +    GST_PLUGINS_YES="\t[$3]\n$GST_PLUGINS_YES"
   1.109 +  fi
   1.110 +  AC_DEFINE(HAVE_[$1], , [support for features: $3])
   1.111 +else
   1.112 +  ifelse([$3], , :, [AC_MSG_NOTICE(*** These plugins will not be built: [$3])])
   1.113 +  if test "x$3" != "x"; then
   1.114 +    GST_PLUGINS_NO="\t[$3]\n$GST_PLUGINS_NO"
   1.115 +  fi
   1.116 +  ifelse([$7], , :, [$7])
   1.117 +fi
   1.118 +dnl *** Define the conditional as appropriate
   1.119 +AM_CONDITIONAL(USE_[$1], test x$USE_[$1] = xyes)
   1.120 +])
   1.121 +
   1.122 +dnl Use a -config program which accepts --cflags and --libs parameters
   1.123 +dnl to set *_CFLAGS and *_LIBS and check existence of a feature.
   1.124 +dnl Richard Boulton <richard-alsa@tartarus.org>
   1.125 +dnl Last modification: 26/06/2001
   1.126 +dnl GST_CHECK_CONFIGPROG(FEATURE-NAME, CONFIG-PROG-FILENAME, MODULES)
   1.127 +dnl
   1.128 +dnl This check was written for GStreamer: it should be renamed and checked
   1.129 +dnl for portability if you decide to use it elsewhere.
   1.130 +dnl
   1.131 +AC_DEFUN([GST_CHECK_CONFIGPROG],
   1.132 +[
   1.133 +  AC_PATH_PROG([$1]_CONFIG, [$2], no)
   1.134 +  if test x$[$1]_CONFIG = xno; then
   1.135 +    [$1]_LIBS=
   1.136 +    [$1]_CFLAGS=
   1.137 +    HAVE_[$1]=no
   1.138 +  else
   1.139 +    if [$2] --plugin-libs [$3] &> /dev/null; then
   1.140 +      [$1]_LIBS=`[$2] --plugin-libs [$3]`
   1.141 +    else
   1.142 +      [$1]_LIBS=`[$2] --libs [$3]`
   1.143 +    fi
   1.144 +    [$1]_CFLAGS=`[$2] --cflags [$3]`
   1.145 +    HAVE_[$1]=yes
   1.146 +  fi
   1.147 +  AC_SUBST([$1]_LIBS)
   1.148 +  AC_SUBST([$1]_CFLAGS)
   1.149 +])
   1.150 +
   1.151 +dnl Use AC_CHECK_LIB and AC_CHECK_HEADER to do both tests at once
   1.152 +dnl sets HAVE_module if we have it
   1.153 +dnl Richard Boulton <richard-alsa@tartarus.org>
   1.154 +dnl Last modification: 26/06/2001
   1.155 +dnl GST_CHECK_LIBHEADER(FEATURE-NAME, LIB NAME, LIB FUNCTION, EXTRA LD FLAGS, 
   1.156 +dnl                     HEADER NAME, ACTION-IF-FOUND, ACTION-IF-NOT-FOUND)
   1.157 +dnl
   1.158 +dnl This check was written for GStreamer: it should be renamed and checked
   1.159 +dnl for portability if you decide to use it elsewhere.
   1.160 +dnl
   1.161 +AC_DEFUN([GST_CHECK_LIBHEADER],
   1.162 +[
   1.163 +  AC_CHECK_LIB([$2], [$3], HAVE_[$1]=yes, HAVE_[$1]=no,[$4])
   1.164 +  if test "x$HAVE_[$1]" = "xyes"; then
   1.165 +    AC_CHECK_HEADER([$5], :, HAVE_[$1]=no)
   1.166 +    if test "x$HAVE_[$1]" = "xyes"; then
   1.167 +      dnl execute what needs to be
   1.168 +      ifelse([$6], , :, [$6])
   1.169 +    else
   1.170 +      ifelse([$7], , :, [$7])
   1.171 +    fi
   1.172 +  else
   1.173 +    ifelse([$7], , :, [$7])
   1.174 +  fi
   1.175 +  AC_SUBST(HAVE_[$1])
   1.176 +]
   1.177 +)
   1.178 +
   1.179 +dnl 2004-02-14 Thomas - changed to get set properly and use proper output
   1.180 +dnl 2003-06-27 Benjamin Otte - changed to make this work with gstconfig.h
   1.181 +dnl
   1.182 +dnl Add a subsystem --disable flag and all the necessary symbols and substitions
   1.183 +dnl
   1.184 +dnl GST_CHECK_SUBSYSTEM_DISABLE(SYSNAME, [subsystem name])
   1.185 +dnl
   1.186 +AC_DEFUN([GST_CHECK_SUBSYSTEM_DISABLE],
   1.187 +[
   1.188 +  dnl this define will replace each literal subsys_def occurrence with
   1.189 +  dnl the lowercase hyphen-separated subsystem
   1.190 +  dnl e.g. if $1 is GST_DEBUG then subsys_def will be a macro with gst-debug
   1.191 +  define([subsys_def],translit([$1], _A-Z, -a-z))
   1.192 +
   1.193 +  AC_ARG_ENABLE(subsys_def, 
   1.194 +    AC_HELP_STRING(--disable-subsys_def, [disable $2]),
   1.195 +    [
   1.196 +      case "${enableval}" in
   1.197 +        yes) GST_DISABLE_[$1]=no ;;
   1.198 +        no) GST_DISABLE_[$1]=yes ;;
   1.199 +        *) AC_MSG_ERROR([bad value ${enableval} for --enable-subsys_def]) ;;
   1.200 +       esac
   1.201 +    ],
   1.202 +    [GST_DISABLE_[$1]=no]) dnl Default value
   1.203 +
   1.204 +  if test x$GST_DISABLE_[$1] = xyes; then
   1.205 +    AC_MSG_NOTICE([disabled subsystem [$2]])
   1.206 +    GST_DISABLE_[$1]_DEFINE="#define GST_DISABLE_$1 1" 
   1.207 +  else
   1.208 +    GST_DISABLE_[$1]_DEFINE="/* #undef GST_DISABLE_$1 */"
   1.209 +  fi
   1.210 +  AC_SUBST(GST_DISABLE_[$1]_DEFINE)
   1.211 +  undefine([subsys_def])
   1.212 +])
   1.213 +
   1.214 +