diff options
author | Darren Salt <linux@youmustbejoking.demon.co.uk> | 2008-04-06 19:41:43 +0100 |
---|---|---|
committer | Darren Salt <linux@youmustbejoking.demon.co.uk> | 2008-04-06 19:41:43 +0100 |
commit | 40a1c7da2f5cfb6ed7210cbea192acd1b0231c41 (patch) | |
tree | 7ee720d1b7e6692ad26e277e5fa08f928642a533 | |
parent | 039b044abf0830eebf90e54d575a179a4ac0f0e1 (diff) | |
parent | b1c711f131520ce268b6403bb7e61595300c5b81 (diff) | |
download | xine-lib-40a1c7da2f5cfb6ed7210cbea192acd1b0231c41.tar.gz xine-lib-40a1c7da2f5cfb6ed7210cbea192acd1b0231c41.tar.bz2 |
Merge from 1.1; adapt xine-list for 1.2.
--HG--
rename : debian/libxine1.install => debian/libxine2.install
rename : src/demuxers/demux_ogg.c => src/combined/xine_ogg_demuxer.c
-rw-r--r-- | .hgignore | 2 | ||||
-rw-r--r-- | ChangeLog | 3 | ||||
-rw-r--r-- | configure.ac | 3 | ||||
-rw-r--r-- | debian/libxine2.install | 1 | ||||
-rw-r--r-- | doc/man/en/Makefile.am | 12 | ||||
-rw-r--r-- | doc/man/en/xine-config.1 | 6 | ||||
-rw-r--r-- | doc/man/en/xine-list.1.in | 40 | ||||
-rw-r--r-- | m4/getopt_long.m4 | 34 | ||||
-rw-r--r-- | misc/Makefile.am | 4 | ||||
-rw-r--r-- | misc/libxine.pc.in | 3 | ||||
-rw-r--r-- | misc/xine-config.in | 7 | ||||
-rw-r--r-- | misc/xine-list.c | 159 | ||||
-rw-r--r-- | src/combined/xine_ogg_demuxer.c | 3 | ||||
-rw-r--r-- | src/demuxers/ebml.c | 2 | ||||
-rwxr-xr-x | version.sh | 3 |
15 files changed, 276 insertions, 6 deletions
@@ -64,6 +64,7 @@ doc/faq/faq.html doc/faq/faq.txt doc/hackersguide/*.png doc/hackersguide/hackersguide.html +doc/man/*/xine-list-*.1 doc/Doxyfile include/xine/version.h @@ -75,6 +76,7 @@ misc/relchk.sh misc/xine-config misc/xine-lib.spec misc/xine-fontconv +misc/xine-list-* misc/cdda_server po/POTFILES @@ -67,6 +67,9 @@ xine-lib (1.1.90) (Unreleased) xine-lib (1.1.12) 2008-??-?? * Fixed and improved the PulseAudio driver. * Fixed a regression in 1.1.11.1 which broke Quicktime container handling. + * And another, this time in the Matroska demuxer. + * Added a tool to assist with generating front ends' desktop files. It + lists MIME types & filename extensions known to the installed xine-lib. xine-lib (1.1.11.1) 2008-03-30 * Security fixes: diff --git a/configure.ac b/configure.ac index 35ccb16b5..2a92ade01 100644 --- a/configure.ac +++ b/configure.ac @@ -66,6 +66,8 @@ AC_DEFINE_UNQUOTED([XINE_SUB], [$XINE_SUB], [xine sub version number]) XINE_PATCH=XINE_VERSION_PATCH AC_SUBST(XINE_PATCH) AC_DEFINE_UNQUOTED([XINE_PATCH], [$XINE_PATCH], [xine patch version number]) +XINE_SERIES=XINE_VERSION_SERIES +AC_SUBST(XINE_SERIES) XINE_LT_CURRENT=__XINE_LT_CURRENT AC_SUBST(XINE_LT_CURRENT) @@ -898,6 +900,7 @@ AC_CHECK_FUNCS([pthread_mutex_timedlock], [AC_LIBOBJ([timedlock])]) LIBS="$ac_save_LIBS" +AC_GETOPT_LONG dnl -------------------------- dnl checks for system services diff --git a/debian/libxine2.install b/debian/libxine2.install index 8c97ee196..980d1ed4a 100644 --- a/debian/libxine2.install +++ b/debian/libxine2.install @@ -1,3 +1,4 @@ +usr/bin/xine-list* usr/lib/libxine*.so.* usr/lib/xine/plugins/*/post/*.so usr/lib/xine/plugins/*/*.so diff --git a/doc/man/en/Makefile.am b/doc/man/en/Makefile.am index ee0296033..8cdf212a6 100644 --- a/doc/man/en/Makefile.am +++ b/doc/man/en/Makefile.am @@ -1,5 +1,13 @@ include $(top_srcdir)/misc/Makefile.common -man_MANS = xine-config.1 xine.5 +STATICMANS = xine-config.1 xine.5 +DYNAMICMANS = xine-list-@XINE_SERIES@.1 -EXTRA_DIST = $(man_MANS) +man_MANS = $(STATICMANS) $(DYNAMICMANS) + +BUILT_SOURCES = $(DYNAMICMANS) +DISTCLEANFILES = $(DYNAMICMANS) +EXTRA_DIST = $(STATICMANS) $(suffix .in,$(DYNAMICMANS)) + +xine-list-@XINE_SERIES@.1: xine-list.1.in + (echo '.ds xl xine\-list\-@XINE_MAJOR@.@XINE_MINOR@'; cat $<) >$@ diff --git a/doc/man/en/xine-config.1 b/doc/man/en/xine-config.1 index 9031714dc..034cd405c 100644 --- a/doc/man/en/xine-config.1 +++ b/doc/man/en/xine-config.1 @@ -39,6 +39,8 @@ Passed on unmodified. Print the compiler flags (for C and Objective C, respectively) that are necessary to compile a program that uses \fIlibxine\fP. .TP 8 +.B \-\-bindir +.TQ 8 .B \-\-plugindir .TQ 8 .B \-\-datadir @@ -48,8 +50,8 @@ necessary to compile a program that uses \fIlibxine\fP. .B \-\-localedir \-\-variable=... .br -Print the directory where, respectively, \fIlibxine\fP plugins, data files, -scripts and locale data are stored/expected. +Print the directory where, respectively, \fIlibxine\fP binaries, plugins, +data files, scripts and locale data are stored/expected. .TP 8 .B \-\-prefix=PREFIX \-\-define\-variable=prefix=PREFIX diff --git a/doc/man/en/xine-list.1.in b/doc/man/en/xine-list.1.in new file mode 100644 index 000000000..e159852c8 --- /dev/null +++ b/doc/man/en/xine-list.1.in @@ -0,0 +1,40 @@ +.TH XINE 1 2001-08-28 "The xine project" +.SH NAME +\*(xl - get supported filetype information from xine-lib +.SH SYNOPSIS +.B \*(xl +[\fPoptions...\fI] +.SH DESCRIPTION +.PP +\fI\*(xl\fP is a tool that is used to list the MIME type and filename +extension information known and supported by the installed \fIxine-lib\fP. +It is of use in filling in MIME information in front ends' desktop files. +. +.SH OPTIONS +.l +\fIxine\-list\fP accepts the following options: +.TP 8 +.B \-m +.B \-\-mime\-types +List the MIME types known to \fIxine-lib\fP. (This is the default action.) +.TP 8 +.B \-e +.B \-\-extensions +List the file types (filename extensions) known to \fIxine-lib\fP. +.TP 8 +.B \-a +.B \-\-all +List the MIME types known to \fIxine-lib\fP, along with their filename +extensions and descriptions. +.TP 8 +.B \-p +.B \-\-pretty\-print +Add line feeds; print each item on a line of its own. +.SH COPYRIGHT +Copyright \(co 2008 the xine project. + +Permission to use, copy, modify, and distribute this software and its +documentation for any purpose and without fee is hereby granted, provided +that the above copyright notice appear in all copies and that both that +copyright notice and this permission notice appear in supporting +documentation. diff --git a/m4/getopt_long.m4 b/m4/getopt_long.m4 new file mode 100644 index 000000000..39f41ffc2 --- /dev/null +++ b/m4/getopt_long.m4 @@ -0,0 +1,34 @@ +dnl --------------------------------------------- +dnl Check for GNU getopt_long() +dnl --------------------------------------------- + +AC_DEFUN([AC_GETOPT_LONG], [ + AC_MSG_CHECKING(for GNU getopt_long) + AC_RUN_IFELSE([AC_LANG_SOURCE([[ +#include <stdio.h> +#include <stdlib.h> +#include <getopt.h> + +static struct option long_options[] = { + {"help" , no_argument, 0, 1 }, + {"version" , no_argument, 0, 2 }, + {0 , no_argument, 0, 0 } +}; + +int main (int argc, char **argv) { + int option_index = 0; + int c; + opterr = 0; + while ((c = getopt_long (argc, argv, "?hv", + long_options, &option_index)) != EOF) + ; + return 0; +} + ]])], + [AC_MSG_RESULT(yes); + ac_getopt_long=yes; + AC_DEFINE(HAVE_GETOPT_LONG,,[Define this if you have GNU getopt_long() implemented])], + [AC_MSG_RESULT(no); ac_getopt_long=no], + [AC_MSG_RESULT(no); ac_getopt_long=no]) + AM_CONDITIONAL(HAVE_GETOPT_LONG, test x"$ac_getopt_long" = "xyes") +]) diff --git a/misc/Makefile.am b/misc/Makefile.am index cd013b752..783f269f7 100644 --- a/misc/Makefile.am +++ b/misc/Makefile.am @@ -13,9 +13,13 @@ EXTRA_DIST = build_rpms.sh \ fonts/cetus.ttf bin_SCRIPTS = xine-config +bin_PROGRAMS = xine-list-@XINE_SERIES@ pkgconfig_DATA=libxine.pc +xine_list_@XINE_SERIES@_SOURCES = xine-list.c +xine_list_@XINE_SERIES@_LDADD = $(XINE_LIB) + fontdir = $(pkgdatadir)/fonts dist_font_DATA = \ fonts/cetus-16.xinefont.gz \ diff --git a/misc/libxine.pc.in b/misc/libxine.pc.in index a6565bad0..754acc5ca 100644 --- a/misc/libxine.pc.in +++ b/misc/libxine.pc.in @@ -1,5 +1,6 @@ prefix=@prefix@ exec_prefix=@exec_prefix@ +bindir=@bindir@ libdir=@libdir@ includedir=@includedir@ @@ -15,6 +16,8 @@ scriptdir=@XINE_SCRIPTPATH@ localedir=@XINE_LOCALEDIR@ objcflags=@OBJCFLAGS@ +xine_list=${bindir}/xine-list-@XINE_SERIES@ + Name: libxine Description: The xine engine library Version: @XINE_MAJOR@.@XINE_MINOR@.@XINE_SUB@@XINE_PATCH@ diff --git a/misc/xine-config.in b/misc/xine-config.in index 1492d739b..e1192cf46 100644 --- a/misc/xine-config.in +++ b/misc/xine-config.in @@ -23,10 +23,12 @@ Options: [--libs] [--acflags] [--cflags] + [--bindir] [--plugindir] [--datadir] [--scriptdir] [--localedir] + [--xine-list] [--objcflags] EOF exit $1 @@ -58,9 +60,12 @@ while test $# -gt 0; do --cflags|--libs) args="$args${args+ }$1" ;; - --prefix|--acflags|--plugindir|--datadir|--scriptdir|--localedir|--objcflags) + --prefix|--acflags|--bindir|--plugindir|--datadir|--scriptdir|--localedir|--objcflags) args="$args${args+ }--variable=${1#--}" ;; + --xine-list) + args="$args${args+ }--variable=xine_list" + ;; --exec-prefix) args="$args${args+ }--variable=exec_prefix" ;; diff --git a/misc/xine-list.c b/misc/xine-list.c new file mode 100644 index 000000000..ec7b7f694 --- /dev/null +++ b/misc/xine-list.c @@ -0,0 +1,159 @@ +/* + * Copyright (C) 2008 the xine-project + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 + * USA + */ + +#include <xine.h> + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <getopt.h> + +#define XINE_LIST_VERSION_N(x,y) #x"."#y +#define XINE_LIST_VERSION XINE_LIST_VERSION_N(XINE_MAJOR_VERSION,XINE_MINOR_VERSION) + +int main (int argc, char *argv[]) +{ + int optstate = 0; + int which = 'm'; + int lf = 0; + + for (;;) + { +#define OPTS "hvaemp" +#ifdef HAVE_GETOPT_LONG + static const struct option longopts[] = { + { "help", no_argument, NULL, 'h' }, + { "version", no_argument, NULL, 'v' }, + { "mime-types", no_argument, NULL, 'm' }, + { "extensions", no_argument, NULL, 'e' }, + { "all", no_argument, NULL, 'a' }, + { NULL } + }; + int index = 0; + int opt = getopt_long (argc, argv, OPTS, longopts, &index); +#else + int opt = getopt(argc, argv, OPTS); +#endif + if (opt == -1) + break; + + switch (opt) + { + case 'h': + optstate |= 1; + break; + case 'v': + optstate |= 4; + break; + case 'a': + case 'e': + case 'm': + which = opt; + break; + case 'p': + lf = 1; + break; + default: + optstate |= 2; + break; + } + } + + if (optstate & 1) + printf ("\ +xine-list-"XINE_LIST_VERSION" %s\n\ +using xine-lib %s\n\ +usage: %s [options]\n\ +options:\n\ + -h, --help this help text\n\ + -m, --mime-types list just the supported MIME types\n\ + -e, --extensions list just the recognised filename extensions\n\ + -a, --all list everything\n\ + -p, --pretty-print add line feeds\n\ +\n", XINE_VERSION, xine_get_version_string (), argv[0]); + else if (optstate & 4) + printf ("\ +xine-list %s\n\ +using xine-lib %s\n\ +(c) 2008 the xine project team\n\ +This is free software; see the source for copying conditions. There is NO\n\ +warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE,\n\ +to the extent permitted by law.\n", + XINE_VERSION, xine_get_version_string ()); + + if (optstate & 2) + { + fputs ("xine-list: invalid option (try -h or --help)\n", stderr); + return 1; + } + + if (optstate) + return 0; + + xine_t *xine = xine_new (); + xine_init (xine); + + char *text = NULL; + char *sep, *sep2; + switch (which) + { + case 'a': + case 'm': + text = xine_get_mime_types (xine); + if (!text || !*text) + goto read_fail; + sep = sep2 = text - 1; + for (;;) + { + text = sep + 1; + sep = strchr (text, ';') ? : text + strlen (text); + sep2 = which == 'a' ? sep : strchr (text, ':') ? : sep; + if (!*sep) + break; + if (printf ("%.*s;", (int)(sep2 - text), text) < 0 || (lf && puts ("") < 0)) + goto write_fail; + } + break; + + case 'e': + text = xine_get_file_extensions (xine); + if (!text || !*text) + goto read_fail; + sep = text - 1; + do + { + text = sep + 1; + sep = strchr (text, ' ') ? : text + strlen (text); + if (sep[-1] != '/' && + printf ("%.*s%s", (int)(sep - text), text, lf ? "\n" : *sep ? " " : "") < 0) + goto write_fail; + } while (*sep); + break; + } + + return 0; + + read_fail: + fputs ("xine-list: failed to read types info\n", stderr); + return 1; + + write_fail: + perror ("xine-list"); + return 1; +} diff --git a/src/combined/xine_ogg_demuxer.c b/src/combined/xine_ogg_demuxer.c index 25fed94d9..52788612f 100644 --- a/src/combined/xine_ogg_demuxer.c +++ b/src/combined/xine_ogg_demuxer.c @@ -2110,6 +2110,9 @@ static void *ogg_init_class (xine_t *xine, void *data) { this->demux_class.identifier = "OGG"; this->demux_class.mimetypes = "application/ogg: ogx: Ogg Stream;" + "application/x-ogm: ogx: Ogg Stream;" + "application/x-ogm-audio: oga: Ogg Audio;" + "application/x-ogm-video: ogv: Ogg Video;" "application/x-ogg: ogx: Ogg Stream;" "audio/ogg: oga: Ogg Audio;" "audio/x-ogg: oga: Ogg Audio;" diff --git a/src/demuxers/ebml.c b/src/demuxers/ebml.c index 97bf0a615..1e9a456d2 100644 --- a/src/demuxers/ebml.c +++ b/src/demuxers/ebml.c @@ -321,7 +321,7 @@ char *ebml_alloc_read_ascii (ebml_parser_t *ebml, ebml_elem_t *elem) if (text) { text[elem->len] = '\0'; - if (ebml_read_ascii (ebml, &elem, text)) + if (ebml_read_ascii (ebml, elem, text)) return text; free (text); } diff --git a/version.sh b/version.sh index 9e5611126..9db0b1562 100755 --- a/version.sh +++ b/version.sh @@ -32,6 +32,8 @@ XINE_VERSION_MAJOR=1 XINE_VERSION_MINOR=1 XINE_VERSION_SUB=90 XINE_VERSION_PATCH= +# Release series number (usually $XINE_MAJOR.$XINE_MINOR) +XINE_VERSION_SERIES=1.2 XINE_LT_CURRENT=2 XINE_LT_REVISION=0 @@ -50,6 +52,7 @@ echo "m4_define([XINE_VERSION_SUB], [${XINE_VERSION_SUB}])dnl" echo "m4_define([XINE_VERSION_PATCH], [${XINE_VERSION_PATCH}])dnl" echo "m4_define([XINE_VERSION_SUFFIX], [${XINE_VERSION_SUFFIX}])dnl" echo "m4_define([XINE_VERSION_SPEC], [${XINE_VERSION_SPEC}])dnl" +echo "m4_define([XINE_VERSION_SERIES], [${XINE_VERSION_SERIES}])dnl" echo "m4_define([__XINE_LT_CURRENT], [${XINE_LT_CURRENT}])dnl" echo "m4_define([__XINE_LT_REVISION], [${XINE_LT_REVISION}])dnl" echo "m4_define([__XINE_LT_AGE], [${XINE_LT_AGE}])dnl" |