GStreamer multimedia framework
Find a file
Andy Wingo 7c0804b15c testsuite/caps/value_serialize.c: merge from HEAD.
Original commit message from CVS:
2005-02-10  Andy Wingo  <wingo@pobox.com>

* testsuite/caps/value_serialize.c: merge from HEAD.

* testsuite/caps/subtract.c:
* testsuite/caps/filtercaps.c:
* testsuite/caps/enumcaps.c:
* testsuite/caps/deserialize.c:
* testsuite/caps/caps.c:
* testsuite/caps/audioscale.c: Unref caps, not free.

* testsuite/caps/caps_strings: Merged from HEAD.

* gst/elements/gstidentity.c (gst_identity_proxy_getcaps): Getcaps
implementation for identity.

* gst/gststructure.h
* gst/gststructure.c
(gst_caps_structure_fixate_field_nearest_double):
(gst_caps_structure_fixate_field_nearest_int): Moved from
gstcaps.c because we need the private IS_MUTABLE macro.
(IS_MUTABLE): New macro, determines if a
structure is mutable or not.
(gst_structure_free): Don't allow free while holding a pointer to
a parent's refcount.
(gst_structure_set_name): Check for writability.
(gst_structure_id_set_value): Same.
(gst_structure_set_value): Same.
(gst_structure_set_valist): Same.
(gst_structure_remove_field): Same.
(gst_structure_remove_all_fields): Same.
(gst_structure_map_in_place): New routine, like _foreach but
allows the function to mutate the value (via a non-const
prototype). Check for writability.
(gst_structure_foreach): Redefine to only take non-mutating
functions.

* gst/gstcaps.c (IS_WRITABLE): New macro, returns TRUE if the caps
are writable.
(gst_caps_copy): Add some docs about mutability, etc.
(_gst_caps_free): Set the parent refcount pointer on structures to
NULL before freeing them.
(gst_caps_ref): Document.
(gst_caps_make_writable): Doc.
(gst_caps_make_writable): Changed to make_writable, get_writable
sounds too much like retrieving a property.
(gst_caps_copy_1): Removed, not very useful.
(gst_caps_ref_by_count): Removed, no need to have something GLib
doesn't.
(gst_caps_copy_conditional): Ref instead of copying.
(gst_static_caps_get): Retain a reference to the returned caps, so
that the static caps will remain immutable.
(gst_caps_remove_and_get_structure): Set the parent refcount to
NULL when removing the structure.
(gst_caps_append): Fix to work with structure parent refcounts.
Check for writability.
(gst_caps_append_structure): Check for writability, work with
parent refcounts.
(gst_caps_remove_structure): Check for writability.
(gst_caps_set_simple): Check for writability.
(gst_caps_set_simple_valist): Check for writability.
(gst_caps_is_fixed_foreach): Update for non-mutating foreach.
(gst_structure_is_equal_foreach): Same.
(gst_caps_structure_intersect_field): Same.
(gst_caps_structure_subtract_field): Same. Make static.
(gst_caps_normalize_foreach): Same.
(gst_caps_structure_figure_out_union): Same.
(gst_caps_switch_structures): New static function, switches out
structures inside a caps, taking care of parent_refcount setting.

* gst/gstpad.c (gst_pad_get_allowed_caps): Remove the restriction
on only src pads, wim von masterhack claims it was bogus.

* testsuite/caps/Makefile.am
* testsuite/caps/app_fixate.c: Removed app_fixate test, things are
done a bit differently in THREADED.
2005-02-10 19:40:23 +00:00
check adding gstdata tests, cleaning up source files 2004-12-21 15:51:09 +00:00
common@b2638c1007 add _get/_set_name_prefix() for debugging. Update docs. 2004-12-14 11:47:44 +00:00
components don't mix tabs and spaces 2004-03-15 19:27:17 +00:00
docs docs/design/part-events.txt: Added event doc. 2005-02-10 18:17:19 +00:00
examples examples/manual/Makefile.am: $< isn't portable in Makefile rules. 2004-10-13 23:53:41 +00:00
gst testsuite/caps/value_serialize.c: merge from HEAD. 2005-02-10 19:40:23 +00:00
include Revert again, this time without post-commit reindent hooks to put back the indentation :-) 2004-03-15 14:43:35 +00:00
libs Clock updates, remove deprecated methods, simplify operations. 2004-12-31 10:44:46 +00:00
pkgconfig docs/libs/Makefile.am: Change sinclude to include 2004-04-19 22:54:58 +00:00
plugins testsuite/caps/value_serialize.c: merge from HEAD. 2005-02-10 19:40:23 +00:00
po Bus cleanups. 2005-01-11 14:58:12 +00:00
scripts check out cvs code, autogen, make, make distcheck if you have spare machines at work sitting idly during the night, r... 2001-12-14 09:44:11 +00:00
tests testsuite/caps/value_serialize.c: merge from HEAD. 2005-02-10 19:40:23 +00:00
testsuite testsuite/caps/value_serialize.c: merge from HEAD. 2005-02-10 19:40:23 +00:00
tools Fix the md5sum by implementing tha GMainLoop. 2005-01-26 14:29:05 +00:00
win32 fix a memory leak in win32/dirent.c 2004-09-19 07:58:13 +00:00
.gitignore ignore some more 2004-03-15 17:26:30 +00:00
.gitmodules Added a first stab at a better clocking system. 2002-02-03 20:07:09 +00:00
AUTHORS AUTHORS: Added some names. Add yourself if you're missing. 2004-03-01 21:00:55 +00:00
autogen.sh commiting wim's preliminary threaded work to a branch 2004-12-08 17:40:37 +00:00
ChangeLog testsuite/caps/value_serialize.c: merge from HEAD. 2005-02-10 19:40:23 +00:00
configure.ac testsuite/bytestream: Removed, getrange replaces bytestream in 2005-02-10 11:23:06 +00:00
COPYING COPYING: replace by LGPL (former COPYING.LIB). The core is completely licensed LGPL. 2004-03-29 13:32:32 +00:00
DEVEL more registry fixes 2002-04-12 18:50:48 +00:00
DOCBUILDING fix really old / no more relevant info on devhelp support/integration 2004-09-27 19:59:08 +00:00
gst-element-check.m4 fixing automake warnings 2004-02-11 18:21:51 +00:00
gst-element-check.m4.in fixing automake warnings 2004-02-11 18:21:51 +00:00
gstreamer.spec.in fix problem with gst-feedback 2005-01-11 12:34:04 +00:00
idiottest.mak idiottest was failing because of change of PLUGIN_USE_SRCDIR to 2001-06-19 12:53:05 +00:00
INSTALL initial checkin 2000-01-30 09:03:00 +00:00
LICENSE Adding explicit license information, since quite a large number of source files don't have the LGPL header. This is ... 2000-08-05 03:53:00 +00:00
MAINTAINERS MAINTAINERS: Add 2004-03-01 20:54:13 +00:00
Makefile.am adding unit testing 2004-12-13 14:49:11 +00:00
NEWS releasing 0.8.7 2004-10-06 17:05:12 +00:00
README Trigger build 2004-02-16 10:30:11 +00:00
RELEASE releasing 0.8.7 2004-10-06 17:05:12 +00:00
REQUIREMENTS REQUIREMENTS: Add bison and flex. 2004-03-06 04:54:06 +00:00
stamp.h.in initial checkin 2000-01-30 09:03:00 +00:00
TODO update TODO 2003-02-12 23:33:55 +00:00

WHAT IT IS
----------
This is GStreamer, a framework for streaming media.  The
fundamental design comes from the video pipeline at Oregon Graduate
Institute, as well as some ideas from DirectMedia.  It's based on plug-ins
that will provide the various codec and other functionality.  The
interface hopefully is generic enough for various companies (ahem, Apple)
to release binary codecs for Linux, until such time as they get a clue and
release the source.

COMPILING FROM SOURCE
---------------------
- check output of ./configure --help to see if any options apply to you
- run
  ./configure
  make

  to build GStreamer.
- if you want to install it (not required), run
  make install
- You should create a registry for things to work.
  If you ran make install in the previous step, run
  gst-register
  as root.

  If you didn't install, run
  tools/gst-register
  as a normal user.

- try out a simple test:
  gst-launch fakesrc num_buffers=5 ! fakesink
  (If you didn't install GStreamer, again prefix gst-launch with tools/)

  If it outputs a bunch of messages from fakesrc and fakesink, everything is
  ok.

- After this, you're ready to install gst-plugins, which will provide the
  functionality you're probably looking for by now, so go on and read
  that README.

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
* 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.

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"