mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-27 18:50:48 +00:00
GStreamer multimedia framework
2b6b70f42c
Original commit message from CVS: * ext/flac/gstflacdec.c: (gst_flacdec_src_query): Only return true if we actually filled something in. Prevents player applications from showing a random length for flac files. * gst-libs/gst/riff/riff-read.c: (gst_riff_read_class_init), (gst_riff_read_use_event), (gst_riff_read_handle_event), (gst_riff_read_seek), (gst_riff_read_skip), (gst_riff_read_strh), (gst_riff_read_strf_vids_with_data), (gst_riff_read_strf_auds_with_data), (gst_riff_read_strf_iavs): OK, ok, so I implemented event handling. Apparently it's normal that we receive random events at random points without asking for it. * gst/avi/gstavidemux.c: (gst_avi_demux_reset), (gst_avi_demux_src_convert), (gst_avi_demux_handle_src_query), (gst_avi_demux_handle_src_event), (gst_avi_demux_stream_index), (gst_avi_demux_sync), (gst_avi_demux_stream_scan), (gst_avi_demux_massage_index), (gst_avi_demux_stream_header), (gst_avi_demux_handle_seek), (gst_avi_demux_process_next_entry), (gst_avi_demux_stream_data), (gst_avi_demux_loop): * gst/avi/gstavidemux.h: Implement non-lineair chunk handling and subchunk processing. The first solves playback of AVI files where the audio and video data of individual buffers that we read are not synchronized. This should not happen according to the wonderful AVI specs, but of course it does happen in reality. It is also a prerequisite for the second. Subchunk processing allows us to cut chunks in small pieces and process each of these pieces separately. This is required because I've seen several AVI files with incredibly large audio chunks, even some files with only one audio chunk for the whole file. This allows for proper playback including seeking. This patch is supposed to fix all AVI A/V sync issues. * gst/flx/gstflxdec.c: (gst_flxdec_class_init), (flx_decode_chunks), (flx_decode_color), (gst_flxdec_loop): Work. * gst/modplug/gstmodplug.cc: Proper return value setting for the query() function. * gst/playback/gstplaybasebin.c: (setup_source): Being in non-playing state (after, e.g., EOS) is not necessarily a bad thing. Allow for that. This fixes playback of short files. They don't actually playback fully now, because the clock already runs. This means that small files (<500kB) with a small length (<2sec) will still not or barely play. Other files, such as mod or flx, will work correctly, however. |
||
---|---|---|
common@ded6dc5186 | ||
examples | ||
ext | ||
gconf | ||
gst | ||
gst-libs | ||
m4 | ||
pkgconfig | ||
po | ||
scripts | ||
sys | ||
win32 | ||
.gitignore | ||
.gitmodules | ||
AUTHORS | ||
autogen.sh | ||
ChangeLog | ||
configure.ac | ||
COPYING | ||
COPYING.LIB | ||
gst-plugins.spec.in | ||
INSTALL | ||
LICENSE | ||
LICENSE_readme | ||
MAINTAINERS | ||
Makefile.am | ||
NEWS | ||
README | ||
RELEASE | ||
REQUIREMENTS | ||
TODO |
WHAT IT IS ---------- This is gst-plugins, a set of plug-ins for GStreamer. COMPILING FROM SOURCE --------------------- - make sure you compiled and at least did a test-run of GStreamer (core) - check output of ./configure --help to see if any options apply to you - configure the source tree: - if you installed GStreamer, then do: ./configure If configure complains about missing GStreamer, you should try ./configure --with-pkg-config-path=prefix/lib/pkgconfig where prefix should be replaced by the prefix you used to configure GStreamer. (Be mindful NOT to ADD a trailing / to that option !) If this doesn't fix it, you have other issues ;) - if you didn't install GStreamer, you can still compile the plug-ins. Add the path to gstreamer-uninstalled.pc (which lives in the gstreamer source tree) to PKG_CONFIG_PATH or run configure --with-pkg-config-path=(path to gstreamer uninstalled) - the output of configure will give you a list of plug-ins with external dependencies (ie, depending on other libs, see below). By no means should you try to get them all built on your first run. This is hard enough as it is ;) Resist the urge to get the most features for now. It doesn't list all of the non-depending plug-ins, which get built regardless (unless you explicitly asked it not to). - build the tree: make If any plug-in causes a problem at this stage, you should re-configure with --disable-(dependency) and doublecheck if configure reports this plug-in as being disabled. Then re-run make. - install: - if you installed GStreamer, and want to install the plug-ins as well, run make install and, as root, run gst-register - if you installed GStreamer, but don't want to install the plug-ins, run gst-register --gst-plugin-path=. - if you didn't install GStreamer, then do path/to/gstreamer/tools/gst-register --gst-plugin-path=. (Replace path/to/gstreamer obviously) - test: - run gst-launch sinesrc ! fakesink and prefix gst-launch with the path to gstreamer/tools if you didn't install GStreamer. If this doesn't give any errors, you can abort it. - try replacing fakesink with your choice of osssink/esdsink/artsdsink/alsasink/jacksink (depending on what output method you have available) and see if you hear a C tone. - After this, you should look into installing an application, like gst-player, gst-editor or monkey-media with rhythmbox. COMPILING FROM CVS ------------------ When building from CVS sources, you will need to run autogen.sh to generate the build system files. GStreamer is cutting-edge stuff. To be a CVS developer, you need what used to be considered cutting-edge tools. ATM, most of us have at least these versions : * autoconf 2.52 (NOT 2.52d) * automake 1.5 * gettext 0.11.5 * libtool 1.4 (NOT Gentoo's genetic failure 1.4.2) * pkg-config 0.8.0 autogen.sh will check for these versions and complain if you don't have them. You can also specify specific versions of automake and autoconf with --with-automake and --with-autoconf Check autogen.sh options by running autogen.sh --help autogen.sh can pass on arguments to configure - you just need to separate them from autogen.sh with -- between the two. prefix has been added to autogen.sh but will be passed on to configure because some build scripts like that. You will probably have to pass at least --with-pkg-config-path to autogen.sh to point to the CVS version of GStreamer. When you have done this once, you can use autoregen.sh to re-autogen with the last passed options as a handy shortcut. Use it. After the autogen.sh stage, you can follow the directions listed in "COMPILING FROM SOURCE" PLUG-IN DEPENDENCIES AND LICENSES --------------------------------- GStreamer is developed under the terms of the LGPL (see LICENSE file for details). Some of our plug-ins however rely on libraries which are available under other licenses. This means that if you are using an application which has a non-GPL compatible license (for instance a closed-source application) with GStreamer, you have to make sure not to use GPL-linked plug-ins. When using GPL-linked plug-ins, GStreamer is for all practical reasons under the GPL itself. The plug-ins which use a GPL library are as follows: cdparanoia libcdparanoia (http://www.xiph.org/paranoia/) aasink aalib (http://aa-project.sourceforge.net/aalib/) xmms libxmms (http://www.xmms.org) decdvd ac3dec,mpeg2dec (http://linuxvideo.org/mpeg2dec/,http://linuxvideo.org/ac3dec/)a mad mad (http://www.mars.org/home/rob/proj/mpeg/) Plug-ins which use an LGPL library are as follows: colorspace Hermes (http://www.clanlib.org/hermes/) httpsrc libghttp (ftp.gnome.org/pub/GNOME/stable/sources/libghttp/) alsasink alsa (http://alsa-project.org) arts aRts (http://arts-project.org) sdlsink libsdl (http://www.libsdl.org) gnomevfssource gnome-vfs (ftp.gnome.org//pub/GNOME/stable/sources/gnome-vfs) gnomevfssink gnome-vfs esdsink libesd (ftp.gnome.org/pub/GNOME/stable/sources/esound) icastsend libshout (http://www.icecast.org) lame libmp3lame (http://www.mp3dev.org/mp3/) gst1394 libraw1394 (http://linux1394.sourceforge.net) flac libFLAC (http://flac.sourceforge.net) RTP ortp (http://www.linphone.org/ortp/) Plug-ins which use a BSD covered library are as follows: vorbisenc libogg/libvorbis (http://www.xiph.org/ogg/vorbis) vorbisdec libogg/libvorbis Plug-ins based on libraries with other free licenses: xvideosink libXv (MIT X11 / X Consortium license) gsm libgsm (MIT license http://kbs.cs.tu-berlin.de/~jutta/toast.html) Plug-ins using non-free libraries: wincodec win32ddl (http://divx.euro.ru/)