gmyth-stream/gmemcoder/m4/gst-feature.m4
author renatofilho
Fri Aug 03 15:37:32 2007 +0100 (2007-08-03)
branchtrunk
changeset 793 45c799bef1f6
permissions -rwxr-xr-x
[svn r799] -fixed volume compability with playbin; -Enable compile without gmyth dep;
renatofilho@584
     1
dnl Perform a check for a feature for GStreamer
renatofilho@584
     2
dnl Richard Boulton <richard-alsa@tartarus.org>
renatofilho@584
     3
dnl Thomas Vander Stichele <thomas@apestaart.org> added useful stuff
renatofilho@584
     4
dnl Last modification: 25/06/2001
renatofilho@584
     5
dnl GST_CHECK_FEATURE(FEATURE-NAME, FEATURE-DESCRIPTION,
renatofilho@584
     6
dnl                   DEPENDENT-PLUGINS, TEST-FOR-FEATURE,
renatofilho@584
     7
dnl                   DISABLE-BY-DEFAULT, ACTION-IF-USE, ACTION-IF-NOTUSE)
renatofilho@584
     8
dnl
renatofilho@584
     9
dnl This macro adds a command line argument to enable the user to enable
renatofilho@584
    10
dnl or disable a feature, and if the feature is enabled, performs a supplied
renatofilho@584
    11
dnl test to check if the feature is available.
renatofilho@584
    12
dnl
renatofilho@584
    13
dnl The test should define HAVE_<FEATURE-NAME> to "yes" or "no" depending
renatofilho@584
    14
dnl on whether the feature is available.
renatofilho@584
    15
dnl
renatofilho@584
    16
dnl The macro will set USE_<FEATURE-NAME> to "yes" or "no" depending on
renatofilho@584
    17
dnl whether the feature is to be used.
renatofilho@584
    18
dnl Thomas changed this, so that when USE_<FEATURE-NAME> was already set
renatofilho@584
    19
dnl to no, then it stays that way.
renatofilho@584
    20
dnl
renatofilho@584
    21
dnl The macro will call AM_CONDITIONAL(USE_<<FEATURE-NAME>, ...) to allow
renatofilho@584
    22
dnl the feature to control what is built in Makefile.ams.  If you want
renatofilho@584
    23
dnl additional actions resulting from the test, you can add them with the
renatofilho@584
    24
dnl ACTION-IF-USE and ACTION-IF-NOTUSE parameters.
renatofilho@584
    25
dnl 
renatofilho@584
    26
dnl FEATURE-NAME        is the name of the feature, and should be in
renatofilho@584
    27
dnl                     purely upper case characters.
renatofilho@584
    28
dnl FEATURE-DESCRIPTION is used to describe the feature in help text for
renatofilho@584
    29
dnl                     the command line argument.
renatofilho@584
    30
dnl DEPENDENT-PLUGINS   lists any plugins which depend on this feature.
renatofilho@584
    31
dnl TEST-FOR-FEATURE    is a test which sets HAVE_<FEATURE-NAME> to "yes"
renatofilho@584
    32
dnl                     or "no" depending on whether the feature is
renatofilho@584
    33
dnl                     available.
renatofilho@584
    34
dnl DISABLE-BY-DEFAULT  if "disabled", the feature is disabled by default,
renatofilho@584
    35
dnl                     if any other value, the feature is enabled by default.
renatofilho@584
    36
dnl ACTION-IF-USE       any extra actions to perform if the feature is to be
renatofilho@584
    37
dnl                     used.
renatofilho@584
    38
dnl ACTION-IF-NOTUSE    any extra actions to perform if the feature is not to
renatofilho@584
    39
dnl                     be used.
renatofilho@584
    40
dnl
renatofilho@584
    41
dnl
renatofilho@584
    42
dnl thomas :
renatofilho@584
    43
dnl we also added a history.  
renatofilho@584
    44
dnl GST_PLUGINS_YES will contain all plugins to be built
renatofilho@584
    45
dnl                 that were checked through GST_CHECK_FEATURE
renatofilho@584
    46
dnl GST_PLUGINS_NO will contain those that won't be built
renatofilho@584
    47
renatofilho@584
    48
AC_DEFUN([GST_CHECK_FEATURE],
renatofilho@584
    49
AC_MSG_NOTICE(***)
renatofilho@584
    50
AC_MSG_NOTICE(*** checking plugin: [$3] ***)
renatofilho@584
    51
AC_MSG_NOTICE(***)
renatofilho@584
    52
[dnl
renatofilho@584
    53
builtin(define, [gst_endisable], ifelse($5, [disabled], [enable], [disable]))dnl
renatofilho@584
    54
dnl if it is set to NO, then don't even consider it for building
renatofilho@584
    55
NOUSE=
renatofilho@584
    56
if test "x$USE_[$1]" = "xno"; then
renatofilho@584
    57
  NOUSE="yes"
renatofilho@584
    58
fi
renatofilho@584
    59
AC_ARG_ENABLE(translit([$1], A-Z, a-z),
renatofilho@584
    60
  [  ]builtin(format, --%-26s gst_endisable %s, gst_endisable-translit([$1], A-Z, a-z), [$2]ifelse([$3],,,: [$3])),
renatofilho@584
    61
  [ case "${enableval}" in
renatofilho@584
    62
      yes) USE_[$1]=yes;;
renatofilho@584
    63
      no) USE_[$1]=no;;
renatofilho@584
    64
      *) AC_MSG_ERROR(bad value ${enableval} for --enable-translit([$1], A-Z, a-z)) ;;
renatofilho@584
    65
    esac],
renatofilho@584
    66
  [ USE_$1=]ifelse($5, [disabled], [no], [yes]))           dnl DEFAULT
renatofilho@584
    67
renatofilho@584
    68
dnl *** set it back to no if it was preset to no
renatofilho@584
    69
if test "x$NOUSE" = "xyes"; then
renatofilho@584
    70
  USE_[$1]="no"
renatofilho@584
    71
  AC_MSG_WARN(*** $3 pre-configured not to be built)
renatofilho@584
    72
fi
renatofilho@584
    73
NOUSE=
renatofilho@584
    74
renatofilho@584
    75
dnl *** If it's enabled
renatofilho@584
    76
renatofilho@584
    77
if test x$USE_[$1] = xyes; then
renatofilho@584
    78
  dnl save compile variables before the test
renatofilho@584
    79
renatofilho@584
    80
  gst_check_save_LIBS=$LIBS
renatofilho@584
    81
  gst_check_save_LDFLAGS=$LDFLAGS
renatofilho@584
    82
  gst_check_save_CFLAGS=$CFLAGS
renatofilho@584
    83
  gst_check_save_CPPFLAGS=$CPPFLAGS
renatofilho@584
    84
  gst_check_save_CXXFLAGS=$CXXFLAGS
renatofilho@584
    85
renatofilho@584
    86
  HAVE_[$1]=no
renatofilho@584
    87
  dnl TEST_FOR_FEATURE
renatofilho@584
    88
  $4
renatofilho@584
    89
renatofilho@584
    90
  LIBS=$gst_check_save_LIBS
renatofilho@584
    91
  LDFLAGS=$gst_check_save_LDFLAGS
renatofilho@584
    92
  CFLAGS=$gst_check_save_CFLAGS
renatofilho@584
    93
  CPPFLAGS=$gst_check_save_CPPFLAGS
renatofilho@584
    94
  CXXFLAGS=$gst_check_save_CXXFLAGS
renatofilho@584
    95
renatofilho@584
    96
  dnl If it isn't found, unset USE_[$1]
renatofilho@584
    97
  if test x$HAVE_[$1] = xno; then
renatofilho@584
    98
    USE_[$1]=no
renatofilho@584
    99
  fi
renatofilho@584
   100
fi
renatofilho@584
   101
dnl *** Warn if it's disabled or not found
renatofilho@584
   102
if test x$USE_[$1] = xyes; then
renatofilho@584
   103
  ifelse([$6], , :, [$6])
renatofilho@584
   104
  if test "x$3" != "x"; then
renatofilho@584
   105
    GST_PLUGINS_YES="\t[$3]\n$GST_PLUGINS_YES"
renatofilho@584
   106
  fi
renatofilho@584
   107
  AC_DEFINE(HAVE_[$1], , [support for features: $3])
renatofilho@584
   108
else
renatofilho@584
   109
  ifelse([$3], , :, [AC_MSG_NOTICE(*** These plugins will not be built: [$3])])
renatofilho@584
   110
  if test "x$3" != "x"; then
renatofilho@584
   111
    GST_PLUGINS_NO="\t[$3]\n$GST_PLUGINS_NO"
renatofilho@584
   112
  fi
renatofilho@584
   113
  ifelse([$7], , :, [$7])
renatofilho@584
   114
fi
renatofilho@584
   115
dnl *** Define the conditional as appropriate
renatofilho@584
   116
AM_CONDITIONAL(USE_[$1], test x$USE_[$1] = xyes)
renatofilho@584
   117
])
renatofilho@584
   118
renatofilho@584
   119
dnl Use a -config program which accepts --cflags and --libs parameters
renatofilho@584
   120
dnl to set *_CFLAGS and *_LIBS and check existence of a feature.
renatofilho@584
   121
dnl Richard Boulton <richard-alsa@tartarus.org>
renatofilho@584
   122
dnl Last modification: 26/06/2001
renatofilho@584
   123
dnl GST_CHECK_CONFIGPROG(FEATURE-NAME, CONFIG-PROG-FILENAME, MODULES)
renatofilho@584
   124
dnl
renatofilho@584
   125
dnl This check was written for GStreamer: it should be renamed and checked
renatofilho@584
   126
dnl for portability if you decide to use it elsewhere.
renatofilho@584
   127
dnl
renatofilho@584
   128
AC_DEFUN([GST_CHECK_CONFIGPROG],
renatofilho@584
   129
[
renatofilho@584
   130
  AC_PATH_PROG([$1]_CONFIG, [$2], no)
renatofilho@584
   131
  if test x$[$1]_CONFIG = xno; then
renatofilho@584
   132
    [$1]_LIBS=
renatofilho@584
   133
    [$1]_CFLAGS=
renatofilho@584
   134
    HAVE_[$1]=no
renatofilho@584
   135
  else
renatofilho@584
   136
    if [$2] --plugin-libs [$3] &> /dev/null; then
renatofilho@584
   137
      [$1]_LIBS=`[$2] --plugin-libs [$3]`
renatofilho@584
   138
    else
renatofilho@584
   139
      [$1]_LIBS=`[$2] --libs [$3]`
renatofilho@584
   140
    fi
renatofilho@584
   141
    [$1]_CFLAGS=`[$2] --cflags [$3]`
renatofilho@584
   142
    HAVE_[$1]=yes
renatofilho@584
   143
  fi
renatofilho@584
   144
  AC_SUBST([$1]_LIBS)
renatofilho@584
   145
  AC_SUBST([$1]_CFLAGS)
renatofilho@584
   146
])
renatofilho@584
   147
renatofilho@584
   148
dnl Use AC_CHECK_LIB and AC_CHECK_HEADER to do both tests at once
renatofilho@584
   149
dnl sets HAVE_module if we have it
renatofilho@584
   150
dnl Richard Boulton <richard-alsa@tartarus.org>
renatofilho@584
   151
dnl Last modification: 26/06/2001
renatofilho@584
   152
dnl GST_CHECK_LIBHEADER(FEATURE-NAME, LIB NAME, LIB FUNCTION, EXTRA LD FLAGS, 
renatofilho@584
   153
dnl                     HEADER NAME, ACTION-IF-FOUND, ACTION-IF-NOT-FOUND)
renatofilho@584
   154
dnl
renatofilho@584
   155
dnl This check was written for GStreamer: it should be renamed and checked
renatofilho@584
   156
dnl for portability if you decide to use it elsewhere.
renatofilho@584
   157
dnl
renatofilho@584
   158
AC_DEFUN([GST_CHECK_LIBHEADER],
renatofilho@584
   159
[
renatofilho@584
   160
  AC_CHECK_LIB([$2], [$3], HAVE_[$1]=yes, HAVE_[$1]=no,[$4])
renatofilho@584
   161
  if test "x$HAVE_[$1]" = "xyes"; then
renatofilho@584
   162
    AC_CHECK_HEADER([$5], :, HAVE_[$1]=no)
renatofilho@584
   163
    if test "x$HAVE_[$1]" = "xyes"; then
renatofilho@584
   164
      dnl execute what needs to be
renatofilho@584
   165
      ifelse([$6], , :, [$6])
renatofilho@584
   166
    else
renatofilho@584
   167
      ifelse([$7], , :, [$7])
renatofilho@584
   168
    fi
renatofilho@584
   169
  else
renatofilho@584
   170
    ifelse([$7], , :, [$7])
renatofilho@584
   171
  fi
renatofilho@584
   172
  AC_SUBST(HAVE_[$1])
renatofilho@584
   173
]
renatofilho@584
   174
)
renatofilho@584
   175
renatofilho@584
   176
dnl 2004-02-14 Thomas - changed to get set properly and use proper output
renatofilho@584
   177
dnl 2003-06-27 Benjamin Otte - changed to make this work with gstconfig.h
renatofilho@584
   178
dnl
renatofilho@584
   179
dnl Add a subsystem --disable flag and all the necessary symbols and substitions
renatofilho@584
   180
dnl
renatofilho@584
   181
dnl GST_CHECK_SUBSYSTEM_DISABLE(SYSNAME, [subsystem name])
renatofilho@584
   182
dnl
renatofilho@584
   183
AC_DEFUN([GST_CHECK_SUBSYSTEM_DISABLE],
renatofilho@584
   184
[
renatofilho@584
   185
  dnl this define will replace each literal subsys_def occurrence with
renatofilho@584
   186
  dnl the lowercase hyphen-separated subsystem
renatofilho@584
   187
  dnl e.g. if $1 is GST_DEBUG then subsys_def will be a macro with gst-debug
renatofilho@584
   188
  define([subsys_def],translit([$1], _A-Z, -a-z))
renatofilho@584
   189
renatofilho@584
   190
  AC_ARG_ENABLE(subsys_def, 
renatofilho@584
   191
    AC_HELP_STRING(--disable-subsys_def, [disable $2]),
renatofilho@584
   192
    [
renatofilho@584
   193
      case "${enableval}" in
renatofilho@584
   194
        yes) GST_DISABLE_[$1]=no ;;
renatofilho@584
   195
        no) GST_DISABLE_[$1]=yes ;;
renatofilho@584
   196
        *) AC_MSG_ERROR([bad value ${enableval} for --enable-subsys_def]) ;;
renatofilho@584
   197
       esac
renatofilho@584
   198
    ],
renatofilho@584
   199
    [GST_DISABLE_[$1]=no]) dnl Default value
renatofilho@584
   200
renatofilho@584
   201
  if test x$GST_DISABLE_[$1] = xyes; then
renatofilho@584
   202
    AC_MSG_NOTICE([disabled subsystem [$2]])
renatofilho@584
   203
    GST_DISABLE_[$1]_DEFINE="#define GST_DISABLE_$1 1" 
renatofilho@584
   204
  else
renatofilho@584
   205
    GST_DISABLE_[$1]_DEFINE="/* #undef GST_DISABLE_$1 */"
renatofilho@584
   206
  fi
renatofilho@584
   207
  AC_SUBST(GST_DISABLE_[$1]_DEFINE)
renatofilho@584
   208
  undefine([subsys_def])
renatofilho@584
   209
])
renatofilho@584
   210
renatofilho@584
   211