summaryrefslogtreecommitdiff
path: root/m4
diff options
context:
space:
mode:
authorFrantišek Dvořák <valtri@users.sourceforge.net>2004-02-28 19:56:41 +0000
committerFrantišek Dvořák <valtri@users.sourceforge.net>2004-02-28 19:56:41 +0000
commita657c3df2f453941b115de0ece3ad8d849d58a6b (patch)
tree8546f3fa258309d8169853ebd7bf24fb95ccb7c1 /m4
parent29508eee9641ffeba9b372da6197f5176c2c58dc (diff)
downloadxine-lib-a657c3df2f453941b115de0ece3ad8d849d58a6b.tar.gz
xine-lib-a657c3df2f453941b115de0ece3ad8d849d58a6b.tar.bz2
New caca video output plugin - color ASCII art.
CVS patchset: 6191 CVS date: 2004/02/28 19:56:41
Diffstat (limited to 'm4')
-rw-r--r--m4/Makefile.am1
-rw-r--r--m4/caca.m4163
2 files changed, 164 insertions, 0 deletions
diff --git a/m4/Makefile.am b/m4/Makefile.am
index f01b7e597..cbfc67273 100644
--- a/m4/Makefile.am
+++ b/m4/Makefile.am
@@ -13,6 +13,7 @@ EXTRA_DIST = \
alsa.m4 \
arts.m4 \
as.m4 \
+ caca.m4 \
codeset.m4 \
dvdnav.m4 \
esd.m4 \
diff --git a/m4/caca.m4 b/m4/caca.m4
new file mode 100644
index 000000000..269f69f22
--- /dev/null
+++ b/m4/caca.m4
@@ -0,0 +1,163 @@
+dnl Configure paths and dependencies for libcaca.
+dnl
+dnl Jeffrey S Smith <whydoubt@yahoo.com> 09-Dec-2003
+dnl based on aa.m4 as found in xinelib
+dnl
+dnl AM_PATH_CACA([MINIMUM-VERSION, [ACTION-IF-FOUND [,ACTION-IF-NOT-FOUND ]]])
+dnl Test for CACA, and define CACA_CFLAGS, CACA_LIBS.
+dnl
+dnl ***********************
+dnl 09-Dec-2003
+dnl * new m4 for libcaca
+dnl
+AC_DEFUN([AM_PATH_CACA],
+[dnl
+dnl
+AC_ARG_WITH(caca-prefix,
+ [ --with-caca-prefix=PFX Prefix where CACA is installed (optional)],
+ caca_config_prefix="$withval", caca_config_prefix="")
+AC_ARG_WITH(caca-exec-prefix,
+ [ --with-caca-exec-prefix=PFX Exec prefix where CACA is installed (optional)],
+ caca_config_exec_prefix="$withval", caca_config_exec_prefix="")
+AC_ARG_ENABLE(cacatest,
+ [ --disable-cacatest Do not try to compile and run a test CACA program],, enable_cacatest=yes)
+
+ if test x$caca_config_exec_prefix != x ; then
+ caca_config_args="$caca_config_args --exec-prefix=$caca_config_exec_prefix"
+ if test x${CACA_CONFIG+set} != xset ; then
+ CACA_CONFIG=$caca_config_exec_prefix/bin/caca-config
+ fi
+ fi
+ if test x$caca_config_prefix != x ; then
+ caca_config_args="$caca_config_args --prefix=$caca_config_prefix"
+ if test x${CACA_CONFIG+set} != xset ; then
+ CACA_CONFIG=$caca_config_prefix/bin/caca-config
+ fi
+ fi
+
+ min_caca_version=ifelse([$1], ,0.3,$1)
+
+ if test x"$enable_cacatest" != "xyes"; then
+ AC_MSG_CHECKING([for CACA version >= $min_caca_version])
+ else
+ if test ! -x "$CACA_CONFIG"; then
+ CACA_CONFIG=""
+ fi
+ AC_PATH_PROG(CACA_CONFIG, caca-config, no)
+
+ if test "$CACA_CONFIG" = "no" ; then
+dnl
+dnl caca-config is missing
+dnl
+ no_caca=yes
+ else
+ AC_MSG_CHECKING([for CACA version >= $min_caca_version])
+ no_caca=""
+ CACA_CFLAGS=`$CACA_CONFIG $caca_config_args --cflags`
+ CACA_LIBS=`$CACA_CONFIG $caca_config_args --plugin-libs`
+ caca_major_version=`$CACA_CONFIG $caca_config_args --version | \
+ sed 's/\([[0-9]]*\).\([[0-9]]*\)/\1/'`
+ caca_minor_version=`$CACA_CONFIG $caca_config_args --version | \
+ sed 's/\([[0-9]]*\).\([[0-9]]*\)/\2/'`
+
+ ac_save_CFLAGS="$CFLAGS"
+ ac_save_LIBS="$LIBS"
+ CFLAGS="$CFLAGS $CACA_CFLAGS"
+ LIBS="$CACA_LIBS $LIBS"
+dnl
+dnl Now check if the installed CACA is sufficiently new. (Also sanity
+dnl checks the results of caca-config to some extent)
+dnl
+ AC_LANG_SAVE()
+ AC_LANG_C()
+ rm -f conf.cacatest
+ AC_TRY_RUN([
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <caca.h>
+
+int main ()
+{
+ int major, minor;
+ char *tmp_version;
+
+ system("touch conf.cacatest");
+
+ tmp_version = (char *) strdup("$min_caca_version");
+ if (sscanf(tmp_version, "%d.%d", &major, &minor) != 2) {
+ printf("%s, bad version string\n", "$min_caca_version");
+ exit(1);
+ }
+
+ if (($caca_major_version > major) ||
+ (($caca_major_version == major) && ($caca_minor_version >= minor)))
+ {
+ return 0;
+ }
+ else
+ {
+ printf("\n*** 'caca-config --version' returned %d.%d, but the minimum version\n", $caca_major_version, $caca_minor_version);
+ printf("*** of CACA required is %d.%d. If caca-config is correct, then it is\n", major, minor);
+ printf("*** best to upgrade to the required version.\n");
+ printf("*** If caca-config was wrong, set the environment variable CACA_CONFIG\n");
+ printf("*** to point to the correct copy of caca-config, and remove the file\n");
+ printf("*** config.cache before re-running configure\n");
+ return 1;
+ }
+}
+
+],, no_caca=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
+
+ CFLAGS="$ac_save_CFLAGS"
+ LIBS="$ac_save_LIBS"
+ fi
+ fi dnl CACA_CONFIG
+
+ if test "x$no_caca" = x; then
+ AC_MSG_RESULT(yes)
+ ifelse([$2], , :, [$2])
+ else
+ AC_MSG_RESULT(no)
+ if test "$CACA_CONFIG" = "no"; then
+ echo "*** The caca-config program installed by CACA could not be found"
+ echo "*** If CACA was installed in PREFIX, make sure PREFIX/bin is in"
+ echo "*** your path, or use --with-caca-prefix to set the prefix"
+ echo "*** where CACA is installed."
+ else
+ if test -f conf.cacatest ; then
+ :
+ else
+ echo "*** Could not run CACA test program, checking why..."
+ CFLAGS="$CFLAGS $CACA_CFLAGS"
+ LIBS="$LIBS $CACA_LIBS"
+ AC_TRY_LINK([
+#include <stdio.h>
+#include <caca.h>
+], [ return 0; ],
+ [ echo "*** The test program compiled, but did not run. This usually means"
+ echo "*** that the run-time linker is not finding CACA or finding the wrong"
+ echo "*** version of CACA. If it is not finding CACA, you'll need to set your"
+ echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
+ echo "*** to the installed location Also, make sure you have run ldconfig if that"
+ echo "*** is required on your system"
+ echo "***"
+ echo "*** If you have an old version installed, it is best to remove it, although"
+ echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"
+ echo "***"],
+ [ echo "*** The test program failed to compile or link. See the file config.log for the"
+ echo "*** exact error that occured. This usually means CACA was incorrectly installed"
+ echo "*** or that you have moved CACA since it was installed." ])
+ CFLAGS="$ac_save_CFLAGS"
+ LIBS="$ac_save_LIBS"
+ fi
+ fi
+ CACA_CFLAGS=""
+ CACA_LIBS=""
+ ifelse([$3], , :, [$3])
+ fi
+ AC_SUBST(CACA_CFLAGS)
+ AC_SUBST(CACA_LIBS)
+ AC_LANG_RESTORE()
+ rm -f conf.cacatest
+])