gst/base/gstadapter.*: New function, like peek() but you own the data. Not terribly...
[platform/upstream/gstreamer.git] / ChangeLog
1 2005-08-16  Andy Wingo  <wingo@pobox.com>
2
3         * gst/base/gstadapter.h:
4         * gst/base/gstadapter.c (gst_adapter_take): New function, like
5         peek() but you own the data. Not terribly efficient atm.
6
7 2005-08-16  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
8
9         * gst/gstutils.c: (gst_element_found_tags_for_pad), (push_and_ref),
10         (gst_element_found_tags):
11         * gst/gstutils.h:
12           Add two utility functions for tag handling.
13
14 2005-08-16  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
15
16         * docs/manual/advanced-dataaccess.xml:
17         * docs/manual/basics-helloworld.xml:
18           Fix docs to use _bin_add() before _link(), which fixes the examples
19           with recent core versions (reported by Madhan Raj M
20           <raj_madan@rediffmail.com>, #313199).
21
22 2005-08-16  Wim Taymans  <wim@fluendo.com>
23
24         * check/gst/gstvalue.c: (GST_START_TEST), (gst_value_suite):
25         Added subtract checks.
26
27         * docs/design/part-events.txt:
28         Some more docs about newsegment
29
30         * gst/gstbin.c: (gst_bin_change_state), (bin_bus_handler):
31         Fix FIXME
32
33         * gst/gstcaps.c: (gst_caps_to_string):
34         Add comments, cleanups.
35         
36         * gst/gstelement.c: (gst_element_save_thyself):
37         cleanups
38         
39         * gst/gstvalue.c: (gst_value_collect_int_range),
40         (gst_string_unwrap), (gst_value_union_int_int_range),
41         (gst_value_union_int_range_int_range),
42         (gst_value_intersect_int_int_range),
43         (gst_value_intersect_int_range_int_range),
44         (gst_value_intersect_double_double_range),
45         (gst_value_intersect_double_range_double_range),
46         (gst_value_intersect_list), (gst_value_subtract_int_int_range),
47         (gst_value_subtract_int_range_int),
48         (gst_value_subtract_double_range_double),
49         (gst_value_subtract_double_range_double_range),
50         (gst_value_subtract_from_list), (gst_value_subtract_list),
51         (gst_value_can_compare), (gst_value_compare_fraction):
52         Cleanups, add comments, remove unneeded asserts.
53
54 2005-08-15  Thomas Vander Stichele  <thomas at apestaart dot org>
55
56         * tools/gst-launch.c: (event_loop):
57           don't convert NULL structures to strings
58
59 2005-08-15  Stefan Kost  <ensonic@users.sf.net>
60
61         * docs/gst/gstreamer-sections.txt:
62           made some defines private
63         * docs/gst/tmpl/gstconfig.sgml:
64         * docs/gst/tmpl/gstqueue.sgml:
65         * docs/gst/tmpl/gsttaglist.sgml:
66         * docs/gst/tmpl/gsttypes.sgml:
67         * docs/gst/tmpl/gstutils.sgml:
68         * docs/pwg/appendix-porting.xml:
69         * gst/base/gstbasesink.h:
70         * gst/base/gstbasesrc.c:
71         * gst/base/gstbasesrc.h:
72         * gst/elements/gstfakesink.c: (gst_fake_sink_class_init):
73         * gst/elements/gstfakesrc.c: (gst_fake_src_class_init):
74         * gst/gstelement.c: (gst_element_class_init):
75         * gst/gstpad.c: (gst_pad_class_init):
76         * gst/gstqueue.c: (gst_queue_class_init):
77         * gst/gstxml.c: (gst_xml_class_init):
78           documented all undocumented signal inline
79         * libs/gst/controller/gst-controller.h:
80           added padding
81
82 2005-08-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
83
84         * docs/pwg/appendix-porting.xml:
85           Document _set_link_function -> _set_setcaps_function.
86
87 2005-08-15  Thomas Vander Stichele  <thomas at apestaart dot org>
88
89         * check/Makefile.am:
90           add a .check target for running the check
91         * check/gst-libs/controller.c: (GST_START_TEST):
92           cosmetic fixups
93         * check/gst/gstbuffer.c: (GST_START_TEST), (gst_test_suite):
94           complete checks for gstbuffer; would be nice if I could get the
95           gcov stuff to work so I can see if I actually completed gstbuffer.c
96         * check/gstcheck.h:
97           add ASSERT_BUFFER_REFCOUNT
98
99 2005-08-13  Tim-Philipp Müller  <tim at centricular dot net>
100
101         * docs/gst/gstreamer-sections.txt:
102         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_register):
103         * gst/gsttag.h:
104           Add GST_TAG_LANGUAGE_CODE as we have in 0.8, and don't
105           spew out a warning if a tag that is already registered
106           is re-registered, unless it is re-registered with a 
107           different type (#308438).
108
109 2005-08-12  Tim-Philipp Müller  <tim at centricular dot net>
110
111         * docs/pwg/appendix-porting.xml:
112         * docs/pwg/building-state.xml:
113           Add some paragraphs about state changes in 0.9 to the PWG
114           and the porting guide, in particular about the new meaning
115           of GST_STATE_PAUSED and how to write state change functions
116           with concurrent access by multiple threads in mind.
117
118 2005-08-11  Stefan Kost  <ensonic@users.sf.net>
119
120         * docs/gst/gstreamer-docs.sgml:
121         * docs/libs/gstreamer-libs-docs.sgml:
122           added deprecation and since indexes
123         * libs/gst/controller/gst-controller.c:
124         * libs/gst/controller/gst-helper.c:
125           added since tags
126
127
128 2005-08-11  Wim Taymans  <wim@fluendo.com>
129
130         * gst/gstghostpad.c: (gst_proxy_pad_set_target_unlocked),
131         (gst_proxy_pad_set_target), (gst_proxy_pad_get_target),
132         (gst_proxy_pad_dispose), (gst_ghost_pad_do_activate_push),
133         (gst_ghost_pad_do_link), (gst_ghost_pad_set_internal),
134         (gst_ghost_pad_new_notarget), (gst_ghost_pad_get_target),
135         (gst_ghost_pad_set_target):
136         Actually implement (re)setting the target on a ghostpad
137         as described in the docs.
138
139 2005-08-10  Tim-Philipp Müller  <tim at centricular dot net>
140
141         * gst/gst.c: (gst_init_check_with_popt_table), (init_pre):
142           Check whether GST_DEBUG_NO_COLOR environment variable is
143           set and disable coloured debug output if that is the case.
144
145 2005-08-10  Tim-Philipp Müller  <tim at centricular dot net>
146
147         * gst/base/gsttypefindhelper.c: (helper_find_peek),
148         (gst_type_find_helper):
149           The memory returned by gst_type_find_peek() needs to
150           stay valid until the end of a typefind function, and
151           typefind functions may keep results from different 
152           offsets around, so we can't just unref the buffer from
153           the previous _peek(), but have to save all buffers 
154           returned by _peek() until typefinding is done and only
155           free them then.
156
157 2005-08-09  Tim-Philipp Müller  <tim at centricular dot net>
158
159         * docs/gst/gstreamer-sections.txt:
160         * gst/gstutils.h:
161           New macros: GST_ROUND_UP_2() through GST_ROUND_UP_64().
162
163 2005-08-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
164
165         * gst/base/gstbasetransform.c: (gst_base_transform_buffer_alloc):
166           Fix a pretty good memleak.
167
168 2005-08-08  Tim-Philipp Müller  <tim at centricular dot net>
169
170         * gst/gstiterator.h:
171           Fix wrong include and 'make distcheck'.
172
173 2005-08-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
174
175         * gst/gstbin.c: (bin_bus_handler):
176           Use gst_element_post_message() instead.
177
178 2005-08-08  Tim-Philipp Müller  <tim at centricular dot net>
179
180         * gst/base/gstadapter.h:
181         * gst/base/gstbasesink.h:
182         * gst/base/gstbasesrc.h:
183         * gst/base/gstbasetransform.h:
184         * gst/base/gstcollectpads.h:
185         * gst/base/gstpushsrc.h:
186         * gst/gstiterator.h:
187           Add padding to our base elements' class and instance structs and
188           to GstIterator (you will need to rebuild all plugins and apps!)
189
190 2005-08-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
191
192         * gst/gstbin.c: (bin_bus_handler):
193           Make default message forwarding from child->bus to bin->bus
194           threadsafe and make it not emit warnings if the parent has no bus.
195
196 2005-08-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
197
198         * gst/gstelement.c: (activate_pads):
199           On paused->ready, set pad->caps to NULL, as is the documented
200           behaviour in this state change. Fixes playback of series of
201           media files when visualization is enabled in Totem.
202
203 2005-08-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
204
205         * gst/elements/gstcapsfilter.c: (gst_capsfilter_set_property):
206           Allow NULL as filter-caps (which means "any").
207
208 2005-08-05  Stefan Kost  <ensonic@users.sf.net>
209
210         * docs/libs/gstreamer-libs-sections.txt:
211         * libs/gst/controller/gst-controller.c:
212         * libs/gst/controller/gst-controller.h:
213         * libs/gst/controller/gst-helper.c:
214           adding more entries to the docs and fix small doc-bugs
215
216 2005-08-05  Stefan Kost  <ensonic@users.sf.net>
217
218         * docs/gst/gstreamer-docs.sgml:
219         * docs/gst/gstreamer-sections.txt:
220         * docs/gst/gstreamer.types:
221         * docs/gst/tmpl/gstbasesink.sgml:
222         * docs/gst/tmpl/gstbasesrc.sgml:
223         * docs/gst/tmpl/gstbasetransform.sgml:
224         * docs/gst/tmpl/gstfakesrc.sgml:
225         * gst/base/gstcollectpads.c:
226         * gst/base/gstcollectpads.h:
227         * libs/gst/controller/gst-controller.c:
228         * libs/gst/controller/gst-controller.h:
229         * libs/gst/controller/gst-helper.c:
230         * libs/gst/controller/gst-interpolation.c:
231         * libs/gst/controller/lib.c:
232           added long/short desc for controller docs
233           added collectpads base class docs
234           added correct includes to base-class docs
235
236 2005-08-05  Stefan Kost  <ensonic@users.sf.net>
237
238         * check/gst-libs/controller.c: (gst_test_mono_source_get_property),
239         (gst_test_mono_source_set_property),
240         (gst_test_mono_source_class_init), (GST_START_TEST),
241         (gst_controller_suite):
242         * docs/gst/gstreamer-docs.sgml:
243         * docs/gst/gstreamer-sections.txt:
244         * docs/gst/gstreamer.types:
245         * docs/libs/gstreamer-libs-docs.sgml:
246         * docs/libs/gstreamer-libs-sections.txt:
247         * gst/base/gstadapter.c:
248         * libs/gst/controller/gst-controller.c:
249         (gst_controlled_property_new), (gst_controlled_property_free),
250         (gst_controller_new_valist),
251         (gst_controller_remove_properties_valist),
252         (gst_controller_sink_values), (_gst_controller_finalize):
253         * libs/gst/controller/gst-controller.h:
254         * libs/gst/controller/gst-helper.c:
255         (gst_object_control_properties), (gst_object_uncontrol_properties),
256         (gst_object_get_controller), (gst_object_set_controller),
257         (gst_object_sink_values), (gst_object_get_value_arrays),
258         (gst_object_get_value_array):
259           more tests (and fixes) for the controller
260           more docs for the controller
261           integrated companies docs for the adapter 
262
263 2005-08-05  Thomas Vander Stichele  <thomas at apestaart dot org>
264
265         * check/elements/gstfakesrc.c: (setup_fakesrc), (cleanup_fakesrc),
266         (GST_START_TEST), (fakesrc_suite):
267           add tests for sizetype
268
269 2005-08-04  Andy Wingo  <wingo@pobox.com>
270
271         * gst/elements/gstcapsfilter.c: Reimplement using basetransform,
272         fixes buffer_alloc proxying among other things.
273
274         * gst/base/gstbasetransform.c:
275         * gst/base/gstbasetransform.h:
276         Revert patch to gstbasetransform from 7-28 removing
277         delay_configure.
278
279         * gst/base/gstbasetransform.h (GstBaseTransformClass.get_size):
280         * gst/base/gstbasetransform.c (gst_base_transform_get_size):
281         Semantics changed, should return not the size of the output buffer
282         but the byte size of a buffer with a given caps.
283
284         * gst/base/gstbasetransform.c (gst_base_transform_getcaps): Better
285         debug object.
286         (gst_base_transform_configure_caps): Don't set out_size here: (in,
287         out) are not the pad caps until setcaps finishes.
288         (gst_base_transform_buffer_alloc): Proxy the buffer_alloc for the
289         not-in-place case as well. Deal with changing from in-place to
290         not-in-place within calling pad_alloc_buffer. Still a bit
291         concerned about the overhead here...
292
293 2005-08-03  Andy Wingo  <wingo@pobox.com>
294
295         * gst/base/gstbasetransform.c (gst_base_transform_setcaps): Not
296         fixating is an error.
297
298 2005-08-04  Edward Hervey  <edward@fluendo.com>
299
300         * gst/base/gstadapter.h: 
301         Added gst_adapter_get_type() to the header
302
303 2005-08-03  Stefan Kost  <ensonic@users.sf.net>
304
305         * check/Makefile.am:
306         * check/gst-libs/controller.c:
307         * libs/gst/controller/gst-controller.c:
308         (gst_controller_new_valist):
309           added check test suite for the controller
310         * gst/base/gstpushsrc.c:
311           fixed a doc typo
312
313 2005-08-03  Stefan Kost  <ensonic@users.sf.net>
314
315         * docs/gst/Makefile.am:
316         * docs/gst/gstreamer-docs.sgml:
317         * docs/gst/gstreamer-sections.txt:
318         * docs/gst/gstreamer.types:
319         * docs/gst/tmpl/gstfakesrc.sgml:
320         * gst/base/README:
321         * gst/base/gstbasesink.c:
322         * gst/base/gstbasesink.h:
323         * gst/base/gstbasesrc.c:
324         * gst/base/gstbasesrc.h:
325         * gst/base/gstbasetransform.c:
326         * gst/base/gstpushsrc.c:
327         * gst/base/gstpushsrc.h:
328           add short/long description docs to base classes
329           add pushsrc to the docs
330           remove consolidated doc fragments
331
332 2005-08-03  Stefan Kost  <ensonic@users.sf.net>
333
334         * configure.ac:
335         * docs/libs/Makefile.am:
336         * docs/libs/gstreamer-libs-docs.sgml:
337         * docs/libs/gstreamer-libs-sections.txt:
338         * docs/libs/gstreamer-libs.types:
339         * examples/Makefile.am:
340         * examples/controller/.cvsignore:
341         * examples/controller/Makefile.am:
342         * examples/controller/audio-example.c: (main):
343         * libs/gst/Makefile.am:
344         * libs/gst/controller/.cvsignore:
345         * libs/gst/controller/Makefile.am:
346         * libs/gst/controller/gst-controller.c:
347         (on_object_controlled_property_changed), (gst_timed_value_compare),
348         (gst_timed_value_find),
349         (gst_controlled_property_set_interpolation_mode),
350         (gst_controlled_property_new), (gst_controlled_property_free),
351         (gst_controller_find_controlled_property),
352         (gst_controller_new_valist), (gst_controller_new),
353         (gst_controller_remove_properties_valist),
354         (gst_controller_remove_properties), (gst_controller_set),
355         (gst_controller_set_from_list), (gst_controller_unset),
356         (gst_controller_get), (gst_controller_get_all),
357         (gst_controller_sink_values), (gst_controller_get_value_arrays),
358         (gst_controller_get_value_array),
359         (gst_controller_set_interpolation_mode),
360         (_gst_controller_finalize), (_gst_controller_init),
361         (_gst_controller_class_init), (gst_controller_get_type):
362         * libs/gst/controller/gst-controller.h:
363         * libs/gst/controller/gst-helper.c: (g_object_control_properties),
364         (g_object_uncontrol_properties), (g_object_get_controller),
365         (g_object_set_controller), (g_object_sink_values),
366         (g_object_get_value_arrays), (g_object_get_value_array):
367         * libs/gst/controller/gst-interpolation.c:
368         (gst_controlled_property_find_timed_value_node),
369         (interpolate_none_get), (interpolate_trigger_get),
370         (interpolate_trigger_get_value_array):
371         * libs/gst/controller/lib.c: (gst_controller_init):
372         * pkgconfig/Makefile.am:
373         * pkgconfig/gstreamer-control-uninstalled.pc.in:
374         * pkgconfig/gstreamer-control.pc.in:
375         * testsuite/Makefile.am:
376         * testsuite/controller/.cvsignore:
377         * testsuite/controller/Makefile.am:
378         * testsuite/controller/interpolator.c: (main):
379           added controller code
380           removed dparam pc files
381
382 2005-08-01  Jan Schmidt  <thaytan@mad.scientist.com>
383         * gst/base/gstcollectpads.c: (gst_collectpads_finalize),
384         (gst_collectpads_stop):
385           Broadcast the condition when shutting down, to make sure we wake all
386           threads up. Shut down pads on finalize, for safety.
387
388 2005-08-01  Jan Schmidt  <thaytan@mad.scientist.com>
389         * gst/base/gstbasetransform.c: (gst_base_transform_init),
390         (gst_base_transform_handle_buffer),
391         (gst_base_transform_change_state):
392           Handle PAUSED->READY->PAUSED transition after negotiation
393           occurred already.
394         * gst/gstmessage.c: (gst_message_init):
395           Extra piece of debug for new messages.
396
397 2005-08-01  Stefan Kost  <ensonic@users.sf.net>
398
399         * configure.ac:
400         * docs/gst/tmpl/gstbasesrc.sgml:
401         * docs/gst/tmpl/gstelement.sgml:
402         * docs/gst/tmpl/gstevent.sgml:
403         * docs/gst/tmpl/gstfakesrc.sgml:
404         * docs/gst/tmpl/gstformat.sgml:
405         * docs/gst/tmpl/gstghostpad.sgml:
406         * docs/gst/tmpl/gstpad.sgml:
407         * docs/gst/tmpl/gstquery.sgml:
408         * docs/gst/tmpl/gststructure.sgml:
409         * docs/gst/tmpl/gsttaglist.sgml:
410         * docs/gst/tmpl/gstvalue.sgml:
411         * docs/libs/gstreamer-libs-docs.sgml:
412         * docs/libs/gstreamer-libs-sections.txt:
413         * docs/libs/gstreamer-libs.types:
414         * libs/gst/Makefile.am:
415         * libs/gst/control/.cvsignore:
416         * libs/gst/control/Makefile.am:
417         * libs/gst/control/control.c:
418         * libs/gst/control/control.h:
419         * libs/gst/control/dparam.c:
420         * libs/gst/control/dparam.h:
421         * libs/gst/control/dparam_smooth.c:
422         * libs/gst/control/dparam_smooth.h:
423         * libs/gst/control/dparamcommon.h:
424         * libs/gst/control/dparammanager.c:
425         * libs/gst/control/dparammanager.h:
426         * libs/gst/control/dplinearinterp.c:
427         * libs/gst/control/dplinearinterp.h:
428         * libs/gst/control/unitconvert.c:
429         * libs/gst/control/unitconvert.h:
430         * testsuite/Makefile.am:
431         * testsuite/dynparams/.cvsignore:
432         * testsuite/dynparams/Makefile.am:
433         * testsuite/dynparams/dparamstest.c:
434         * tools/Makefile.am:
435         * tools/gst-inspect.c: (print_element_info), (main):
436         * tools/gst-xmlinspect.c: (print_element_info), (main):
437           deactivate and remove dparams (libgstcontrol)
438
439 2005-08-01  Tim-Philipp Müller  <tim at centricular dot net>
440
441         * gst/elements/gsttypefindelement.c:
442         (gst_type_find_element_have_type), (gst_type_find_element_init),
443         (stop_typefinding), (gst_type_find_element_handle_event),
444         (gst_type_find_element_chain), (gst_type_find_element_getrange):
445         * gst/elements/gsttypefindelement.h:
446           Set caps on all outgoing buffers, not just the first one.
447
448 2005-08-01  Tim-Philipp Müller  <tim at centricular dot net>
449
450         * gst/elements/gsttypefindelement.c:
451         (gst_type_find_element_have_type),
452         (gst_type_find_element_check_set_buffer_caps),
453         (gst_type_find_element_init), (stop_typefinding),
454         (gst_type_find_element_handle_event),
455         (gst_type_find_element_chain), (gst_type_find_element_getrange):
456         * gst/elements/gsttypefindelement.h:
457           Set caps on first outgoing buffer when we've found the type.
458
459 2005-08-01  Tim-Philipp Müller  <tim at centricular dot net>
460
461         * docs/gst/gstreamer-docs.sgml:
462         * docs/gst/gstreamer-sections.txt:
463         * docs/gst/tmpl/gstscheduler.sgml:
464         * docs/gst/tmpl/gstschedulerfactory.sgml:
465           Remove some old cruft from docs.
466
467 2005-07-31  Tim-Philipp Müller  <tim at centricular dot net>
468
469         * gst/gstpad.h:
470           Fix inline docs for GstPadLinkReturn.
471           
472         * gst/gststructure.c: (gst_structure_has_name):
473         * gst/gststructure.h:
474         * docs/gst/gstreamer-sections.txt:
475           New API: gst_structure_has_name().
476
477 2005-07-30  Tim-Philipp Müller  <tim at centricular dot net>
478
479         * configure.ac:
480           Use AC_SYS_LARGEFILE, which will set _FILE_OFFSET_BITS=64
481           and _LARGEFILE_SOURCE in config.h as required. Do not 
482           export those flags in our .pc files any longer (#142209).
483
484           Remove unused GST_DISABLE_OMEGA_COTHREADS stuff.
485
486         * gst/elements/gstfilesink.c: (gst_file_sink_class_init),
487         (gst_file_sink_do_seek), (gst_file_sink_event),
488         (gst_file_sink_get_current_offset), (gst_file_sink_render):
489           Redo seek/tell calls with large file support in mind; add some
490           debugging messages; add log message that tells us when large
491           file support is unavailable or not enabled for some reason.
492
493         * gst/elements/gstfilesrc.c: (gst_file_src_class_init):
494           Add log message that tells us when large file support 
495           is unavailable or not enabled for some reason.
496
497 2005-07-29  Wim Taymans  <wim@fluendo.com>
498
499         * check/gst/gstghostpad.c: (GST_START_TEST), (gst_ghost_pad_suite):
500         Added test for removing an element with ghostpad from a bin.
501         Fixed test as current implementation does the right thing.
502
503         * gst/gstghostpad.c: (gst_proxy_pad_class_init),
504         (gst_proxy_pad_do_query_type), (gst_proxy_pad_do_event),
505         (gst_proxy_pad_do_query), (gst_proxy_pad_do_internal_link),
506         (gst_proxy_pad_do_bufferalloc), (gst_proxy_pad_do_activate),
507         (gst_proxy_pad_do_activatepull), (gst_proxy_pad_do_activatepush),
508         (gst_proxy_pad_do_chain), (gst_proxy_pad_do_getrange),
509         (gst_proxy_pad_do_checkgetrange), (gst_proxy_pad_do_getcaps),
510         (gst_proxy_pad_do_acceptcaps), (gst_proxy_pad_do_fixatecaps),
511         (gst_proxy_pad_do_setcaps), (gst_proxy_pad_set_target),
512         (gst_proxy_pad_get_target), (gst_proxy_pad_init),
513         (gst_proxy_pad_dispose), (gst_proxy_pad_finalize),
514         (gst_ghost_pad_class_init), (gst_ghost_pad_do_activate_push),
515         (gst_ghost_pad_do_link), (gst_ghost_pad_do_unlink),
516         (gst_ghost_pad_set_internal), (gst_ghost_pad_dispose),
517         (gst_ghost_pad_new_notarget), (gst_ghost_pad_new),
518         (gst_ghost_pad_get_target), (gst_ghost_pad_set_target):
519         * gst/gstghostpad.h:
520         Clean up ghostpads, remove properties for internal stuff.
521         Make threadsafe.
522         Fix refcounting.
523         Prepare for switching targets, not all use cases work yet.
524
525 2005-07-29  Wim Taymans  <wim@fluendo.com>
526
527         * docs/design/part-gstghostpad.txt:
528         Small update.
529
530         * gst/gstbin.c: (unlink_pads), (gst_bin_add_func),
531         (gst_bin_remove_func):
532         Unlinking pads while holding the bin LOCK is not a good
533         idea.
534
535         * gst/gstpad.c: (gst_pad_class_init),
536         (gst_pad_link_check_hierarchy), (gst_pad_get_caps_unlocked),
537         (gst_pad_accept_caps), (gst_pad_set_caps), (gst_pad_send_event):
538         No prob setting template after creating the pad.
539
540 2005-07-29  Jan Schmidt  <thaytan@mad.scientist.com>
541
542         * gst/gstbus.c: (gst_bus_set_flushing), (gst_bus_pop),
543         (gst_bus_peek), (gst_bus_source_dispatch),
544         (gst_bus_add_watch_full), (poll_handler), (poll_timeout),
545         (poll_destroy), (poll_destroy_timeout), (gst_bus_poll):
546           gst_bus_poll may be called from other threads. Handle
547           this nicely by not making poll_data disappear off the
548           stack once gst_bus_poll returns.
549           gst_bus_peek now increments the refcount on the returned
550           message.
551
552 2005-07-29  Wim Taymans  <wim@fluendo.com>
553
554         * docs/design/part-gstghostpad.txt:
555         Overview of current GhostPad datastructures and use
556         cases for changing the target.
557
558 2005-07-28  Wim Taymans  <wim@fluendo.com>
559
560         * check/gst/gstbin.c: (GST_START_TEST), (gst_bin_suite):
561         Added checks for hierarchy consistency whan adding linked
562         elements to bins.
563
564         * check/gst/gstelement.c: (GST_START_TEST), (gst_element_suite):
565         Added check to test element scheduling without bin/pipeline.
566
567         * check/pipelines/simple_launch_lines.c: (GST_START_TEST):
568         First add elements to bin, then link.
569         
570         * gst/gstbin.c: (unlink_pads), (gst_bin_add_func),
571         (gst_bin_remove_func):
572         Unlink pads from elements added/removed from bin to maintain
573         hierarchy consistency.
574
575 2005-07-28  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
576
577         * gst/base/gstbasetransform.c: (gst_base_transform_setcaps),
578         (gst_base_transform_handle_buffer):
579         * gst/base/gstbasetransform.h:
580           Remove broken delay_configure (fixes renegotiation of software
581           scaling pipelines); remove some leftover printf()s.
582
583 2005-07-28  Wim Taymans  <wim@fluendo.com>
584
585         * check/gst/gstghostpad.c: (GST_START_TEST), (gst_ghost_pad_suite):
586         Added some more tests for wrong hierarchy
587
588         * docs/design/part-overview.txt:
589         Some updates.
590
591         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_dispose):
592         Cleanups.
593
594         * gst/gstelement.c: (gst_element_remove_pad), (gst_element_seek),
595         (gst_element_dispose):
596         Some more cleanups.
597
598         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked),
599         (gst_pad_link_check_hierarchy), (gst_pad_link_prepare),
600         (gst_pad_get_caps_unlocked), (gst_pad_accept_caps),
601         (gst_pad_set_caps), (gst_pad_send_event):
602         Check for correct hierarchy when linking pads. Moving to
603         strict requirement for ghostpads when linking elements in
604         different bins.
605
606         * gst/gstpad.h:
607         Clean ups. Added WRONG_HIERARCHY return value.
608
609 2005-07-28  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
610
611         * gst/base/gstbasetransform.c: (gst_base_transform_setcaps):
612           Better debug if no transform is possible.
613
614 2005-07-27  Wim Taymans  <wim@fluendo.com>
615
616         * docs/random/wtay/network-transp:
617         Some old doc I had.
618
619 2005-07-27  Wim Taymans  <wim@fluendo.com>
620
621         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_event),
622         (gst_dp_event_from_packet):
623         Fix serialization of seek events.
624
625 2005-07-27  Wim Taymans  <wim@fluendo.com>
626
627         * check/gst-libs/gdp.c: (GST_START_TEST):
628         * gst/elements/gstfakesink.c: (gst_fake_sink_event):
629         Fix compilation and fix event serialization.
630
631 2005-07-27  Wim Taymans  <wim@fluendo.com>
632
633         * CHANGES-0.9:
634         * docs/design/part-TODO.txt:
635         * docs/design/part-events.txt:
636         Some docs updates
637
638         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
639         (gst_base_sink_event), (gst_base_sink_do_sync),
640         (gst_base_sink_activate_push), (gst_base_sink_activate_pull):
641         * gst/base/gstbasesrc.c: (gst_base_src_send_discont),
642         (gst_base_src_do_seek), (gst_base_src_event_handler),
643         (gst_base_src_loop):
644         * gst/base/gstbasetransform.c: (gst_base_transform_transform_caps),
645         (gst_base_transform_configure_caps), (gst_base_transform_setcaps),
646         (gst_base_transform_get_size), (gst_base_transform_buffer_alloc),
647         (gst_base_transform_event), (gst_base_transform_handle_buffer),
648         (gst_base_transform_set_passthrough),
649         (gst_base_transform_is_passthrough):
650         * gst/elements/gstfakesink.c: (gst_fake_sink_event):
651         * gst/elements/gstfilesink.c: (gst_file_sink_event):
652         Event updates.
653
654         * gst/gstbuffer.h:
655         Use faster casts.
656
657         * gst/gstelement.c: (gst_element_seek):
658         * gst/gstelement.h:
659         Update gst_element_seek.
660
661         * gst/gstevent.c: (gst_event_finalize), (_gst_event_copy),
662         (gst_event_new), (gst_event_new_custom), (gst_event_get_structure),
663         (gst_event_new_flush_start), (gst_event_new_flush_stop),
664         (gst_event_new_eos), (gst_event_new_newsegment),
665         (gst_event_parse_newsegment), (gst_event_new_tag),
666         (gst_event_parse_tag), (gst_event_new_filler), (gst_event_new_qos),
667         (gst_event_parse_qos), (gst_event_new_seek),
668         (gst_event_parse_seek), (gst_event_new_navigation):
669         * gst/gstevent.h:
670         Make GstEvent use GstStructure. Add parsing code, make sure the
671         API is sufficiently generic.
672         Mark possible directions of events and serialization.
673
674         * gst/gstmessage.c: (gst_message_init), (gst_message_finalize),
675         (_gst_message_copy), (gst_message_new_segment_start),
676         (gst_message_new_segment_done), (gst_message_new_custom),
677         (gst_message_parse_segment_start),
678         (gst_message_parse_segment_done):
679         Small cleanups.
680
681         * gst/gstpad.c: (gst_pad_get_caps_unlocked), (gst_pad_accept_caps),
682         (gst_pad_set_caps), (gst_pad_send_event):
683         Update for new events. 
684         Catch events sent in wrong directions.
685
686         * gst/gstqueue.c: (gst_queue_link_src),
687         (gst_queue_handle_sink_event), (gst_queue_chain), (gst_queue_loop),
688         (gst_queue_handle_src_query):
689         Event updates.
690
691         * gst/gsttag.c:
692         * gst/gsttag.h:
693         Remove event code from this file.
694
695         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_event),
696         (gst_dp_event_from_packet):
697         Event updates.
698
699 2005-07-27  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
700
701         * gst/base/gstbasetransform.c: (gst_base_transform_getcaps),
702         (gst_base_transform_configure_caps), (gst_base_transform_setcaps),
703         (gst_base_transform_get_size), (gst_base_transform_handle_buffer):
704           Make debugging actually useful.
705
706 2005-07-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
707
708         * gst/gstpad.c: (fixate_value), (gst_pad_default_fixate),
709         (gst_pad_fixate_caps):
710           Implement default fixation once again, so that gst_pad_fixate()
711           actually does anything at all. This probably needs to be some
712           sort of a last resort, and use profile-based fixation first, but
713           since that doesn't exist yet, this is the best we have. Fixes
714           visualization in Totem.
715
716 2005-07-22  Wim Taymans  <wim@fluendo.com>
717
718         * docs/design/part-events.txt:
719         Small update.
720
721         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
722         (gst_base_sink_do_sync), (gst_base_sink_activate_push),
723         (gst_base_sink_activate_pull):
724         Some more comments.
725
726         * gst/elements/gstfakesrc.c: (gst_fake_src_class_init),
727         (gst_fake_src_create):
728         Fix handoff marshall.
729
730         * gst/elements/gstidentity.c: (gst_identity_class_init),
731         (gst_identity_transform_ip):
732         We're a real inplace element.
733
734         * gst/gstbus.c: (gst_bus_post):
735         Added some comments.
736
737         * tests/lat.c: (fakesrc), (fakesink), (simple), (queue), (main):
738         * tests/muxing/case1.c: (main):
739         * tests/sched/dynamic-pipeline.c: (main):
740         * tests/sched/interrupt1.c: (main):
741         * tests/sched/interrupt2.c: (main):
742         * tests/sched/interrupt3.c: (main):
743         * tests/sched/runxml.c: (main):
744         * tests/sched/sched-stress.c: (main):
745         * tests/seeking/seeking1.c: (event_received), (main):
746         * tests/threadstate/threadstate2.c: (bus_handler), (timeout_func),
747         (main):
748         * tests/threadstate/threadstate3.c: (main):
749         * tests/threadstate/threadstate4.c: (main):
750         * tests/threadstate/threadstate5.c: (main):
751         Fix the tests.
752
753 2005-07-21  Wim Taymans  <wim@fluendo.com>
754
755         * docs/design/part-seeking.txt:
756         Some small additions.
757
758         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
759         (gst_base_sink_get_times), (gst_base_sink_do_sync),
760         (gst_base_sink_activate_push), (gst_base_sink_activate_pull):
761         * gst/base/gstbasesink.h:
762         discont values are gint64, handle the math correctly.
763
764         * gst/base/gstbasesrc.c: (gst_base_src_loop):
765         Make the basesrc report error if the source pad is not linked.
766
767         * gst/gstqueue.c: (gst_queue_link_src), (gst_queue_chain),
768         (gst_queue_loop), (gst_queue_handle_src_query),
769         (gst_queue_src_activate_push):
770         Make queue collect data even if the srcpad is not linked.
771         Start pushing out data as soon as it is linked.
772
773         * gst/gstutils.c: (gst_element_unlink), (gst_flow_get_name):
774         * gst/gstutils.h:
775         Added gst_flow_get_name() to ease error reporting.
776
777 2005-07-20  Wim Taymans  <wim@fluendo.com>
778
779         * gst/gstmessage.c: (gst_message_new_segment_start),
780         (gst_message_new_segment_done), (gst_message_parse_segment_start),
781         (gst_message_parse_segment_done):
782         * gst/gstmessage.h:
783         Added a bunch of messages for advanced seeking.
784
785         * gst/parse/grammar.y:
786         * libs/gst/control/dparammanager.c: (gst_dpman_set_parent),
787         (gst_dpman_state_changed):
788         Fix some new-pad -> pad-added signals
789
790 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
791
792         * docs/manual/appendix-porting.xml:
793         * docs/pwg/appendix-porting.xml:
794           Document new-pad/state-change signal renames and the FixedList
795           type rename.
796
797 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
798
799         * docs/manual/advanced-autoplugging.xml:
800         * docs/manual/basics-helloworld.xml:
801         * docs/manual/basics-pads.xml:
802         * docs/random/ds/0.9-suggested-changes:
803         * gst/gstelement.c: (gst_element_class_init), (gst_element_seek):
804         * gst/gstelement.h:
805         * gst/gstevent.h:
806         * gst/gstformat.h:
807         * gst/gstquery.h:
808         * gst/gststructure.c: (gst_structure_value_get_generic_type),
809         (gst_structure_parse_array), (gst_structure_parse_value):
810         * gst/gstvalue.c: (gst_type_is_fixed),
811         (gst_value_list_prepend_value), (gst_value_list_append_value),
812         (gst_value_list_get_size), (gst_value_list_get_value),
813         (gst_value_transform_array_string), (gst_value_serialize_array),
814         (gst_value_deserialize_array), (gst_value_intersect_array),
815         (gst_value_is_fixed), (_gst_value_initialize):
816         * gst/gstvalue.h:
817           GstElement::new-pad -> pad-added, GstElement::state-change ->
818           state-changed, GstValueFixedList -> GstValueArray, add format and
819           flags as their own arguments in gst_element_seek() (should improve
820           "bindeability"), remove function generators since they don't work
821           under a whole bunch of compilers (they were deprecated already
822           anyway).
823
824 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
825
826         * gst/gstinfo.c: (_gst_debug_nameof_funcptr),
827         (_gst_debug_register_funcptr):
828         * gst/gstinfo.h:
829           Fix illegal cast on some platforms (#309253).
830
831 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
832
833         * gst/gstmessage.c: (gst_message_new_custom):
834         * gst/gstmessage.h:
835           Add _new_custom, make _new_application a macro to _new_custom.
836
837 2005-07-20  Wim Taymans  <wim@fluendo.com>
838
839         * gst/base/gstbasesrc.c: (gst_base_src_init),
840         (gst_base_src_do_seek), (gst_base_src_loop), (gst_base_src_start):
841         * gst/base/gstbasesrc.h:
842         Add a gboolean to decide when to push out a discont.
843
844         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
845         (gst_queue_loop), (gst_queue_handle_src_query),
846         (gst_queue_sink_activate_push), (gst_queue_src_activate_push),
847         (gst_queue_set_property), (gst_queue_get_property):
848         Some cleanups.
849
850         * tests/threadstate/threadstate1.c: (main):
851         Make a thread test compile and run... very silly..
852
853
854 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
855
856         * docs/manual/appendix-porting.xml:
857           Mention removal of libgstgconf-0.9.la and existence of gconf
858           elements.
859
860 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
861
862         * docs/pwg/advanced-clock.xml:
863         * docs/pwg/appendix-porting.xml:
864         * docs/pwg/intro-preface.xml:
865         * docs/pwg/other-base.xml:
866         * docs/pwg/other-manager.xml:
867         * docs/pwg/other-nton.xml:
868         * docs/pwg/other-ntoone.xml:
869         * docs/pwg/other-oneton.xml:
870         * docs/pwg/pwg.xml:
871           Document base classes, update sections of n-to-1 and 1-to-n (muxer,
872           demuxer), remove n-to-n (was never written), fix some code examples
873           and links and update the porting section to include all this.
874
875 2005-07-19  Wim Taymans  <wim@fluendo.com>
876
877         * gst/gstqueue.c: (gst_queue_init), (gst_queue_handle_sink_event),
878         (gst_queue_chain), (gst_queue_loop), (gst_queue_handle_src_event),
879         (gst_queue_handle_src_query), (gst_queue_sink_activate_push),
880         (gst_queue_src_activate_push), (gst_queue_change_state),
881         (gst_queue_get_property):
882         * gst/gstqueue.h:
883         Propagate GstFlowReturn more intelligently upstream and output
884         an ERROR/EOS when streaming stopped due to fatal error.
885
886 2005-07-19  Wim Taymans  <wim@fluendo.com>
887
888         * tools/gst-launch.c: (check_intr), (event_loop), (main):
889         Don't block forever for the state change to complete, the
890         pipeline already did with a sensible timeout.
891
892 2005-07-19  Wim Taymans  <wim@fluendo.com>
893
894         * gst/base/gstbasesrc.c: (gst_base_src_get_range):
895         Make sure we never call the create function is we
896         got deactivated.
897
898 2005-07-19  Andy Wingo  <wingo@pobox.com>
899
900         * gst/parse/parse.l: Attempt to solve bug #172815.
901
902 2005-07-19  Wim Taymans  <wim@fluendo.com>
903
904         * docs/design/part-clocks.txt:
905         * docs/design/part-events.txt:
906         * gst/base/gstbasesrc.c: (gst_base_src_do_seek):
907         Small docs updates.
908         Only update the seeking values when we are not
909         busy streaming.
910
911 2005-07-19  Jan Schmidt  <thaytan@mad.scientist.com>
912
913         * gst/base/gstbasesrc.c: (gst_base_src_loop):
914           Oops, ignore the result of gst_pad_push_event here.
915
916 2005-07-19  Jan Schmidt  <thaytan@mad.scientist.com>
917
918         * gst/base/gstbasesrc.c: (gst_base_src_loop),
919         (gst_base_src_activate_push):
920           Send discont event from the loop function, as pads
921           aren't activated yet in the activate_push handler.
922
923         * gst/gstbin.c: (bin_bus_handler):
924           Don't leak element name.
925
926 2005-07-18  Andy Wingo  <wingo@pobox.com>
927
928         * configure.ac: Use AS_LIBTOOL_TAGS.
929
930 2005-07-18  Wim Taymans  <wim@fluendo.com>
931
932         * docs/gst/gstreamer.types:
933         Remove deleted types.
934
935 2005-07-18  Wim Taymans  <wim@fluendo.com>
936
937         * check/elements/gstfakesrc.c: (GST_START_TEST):
938         * configure.ac:
939         * gst/Makefile.am:
940         * gst/gst.c: (gst_init_get_popt_table), (init_pre), (init_post),
941         (init_popt_callback):
942         * gst/gst.h:
943         * gst/gst_private.h:
944         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_add_func),
945         (gst_bin_remove_func), (gst_bin_get_state), (gst_bin_change_state):
946         * gst/gstbin.h:
947         * gst/gstbus.h:
948         * gst/gstconfig.h.in:
949         * gst/gstelement.c: (gst_element_class_init),
950         (gst_element_set_base_time), (gst_element_get_base_time),
951         (iterator_fold_with_resync), (gst_element_change_state),
952         (gst_element_dispose), (gst_element_get_bus):
953         * gst/gstelement.h:
954         * gst/gstelementfactory.h:
955         * gst/gsterror.c: (_gst_core_errors_init):
956         * gst/gsterror.h:
957         * gst/gstevent.h:
958         * gst/gstghostpad.c: (gst_ghost_pad_do_activate_push):
959         * gst/gstindex.c:
960         * gst/gstinfo.c: (_gst_debug_init):
961         * gst/gstmessage.c: (_gst_message_copy):
962         * gst/gstmessage.h:
963         * gst/gstminiobject.h:
964         * gst/gstobject.c:
965         * gst/gstobject.h:
966         * gst/gstpad.c: (gst_pad_get_caps_unlocked), (gst_pad_accept_caps),
967         (gst_pad_set_caps), (gst_pad_start_task), (gst_pad_stop_task):
968         * gst/gstpad.h:
969         * gst/gstparse.h:
970         * gst/gstpipeline.c: (gst_pipeline_init), (gst_pipeline_dispose),
971         (gst_pipeline_change_state), (gst_pipeline_set_new_stream_time),
972         (gst_pipeline_get_last_stream_time):
973         * gst/gstpipeline.h:
974         * gst/gstpluginfeature.h:
975         * gst/gstquery.h:
976         * gst/gstscheduler.c:
977         * gst/gstscheduler.h:
978         * gst/gststructure.h:
979         * gst/gsttask.c: (gst_task_get_type), (gst_task_class_init),
980         (gst_task_finalize), (gst_task_func), (gst_task_create),
981         (gst_task_set_lock), (gst_task_get_state), (gst_task_start),
982         (gst_task_stop), (gst_task_pause):
983         * gst/gsttask.h:
984         * gst/gsttypefind.h:
985         * gst/gsttypes.h:
986         * gst/registries/gstlibxmlregistry.c: (load_feature),
987         (gst_xml_registry_load), (gst_xml_registry_save_feature):
988         * gst/registries/gstxmlregistry.c:
989         (gst_xml_registry_start_element), (gst_xml_registry_save_feature):
990         * gst/schedulers/threadscheduler.c:
991         * libs/gst/control/dparammanager.h:
992         * tools/gst-inspect.c: (print_element_list),
993         (print_plugin_features), (print_element_features):
994         * tools/gst-xmlinspect.c: (print_element_list),
995         (print_plugin_info), (main):
996         Removed plugable schedulers.
997         Removed Scheduler/Manager from elements.
998         Removed gsttypes.h, rearranged includes.
999         Removed dependency pad<->element, element<>pipeline, and
1000         various others,  fix includes.
1001         implement gst_pad_get_parent() with gst_object_get_parent()
1002         Make GstTask sefcontained.
1003         Fix _get_state() on GstBin, it did not return ASYNC with a 0
1004         timeout.
1005         Fix endless loop in iterator_fold_with_resync.
1006
1007
1008 2005-07-18  Wim Taymans  <wim@fluendo.com>
1009
1010         * gst/Makefile.am:
1011         * gst/gstarch.h:
1012         Remove old file.
1013
1014 2005-07-18  Wim Taymans  <wim@fluendo.com>
1015
1016         * gst/Makefile.am:
1017         No more cothreads.h
1018
1019 2005-07-18  Wim Taymans  <wim@fluendo.com>
1020
1021         * gst/cothreads.c:
1022         * gst/cothreads.h:
1023         Let's remove these.
1024
1025 2005-07-18  Wim Taymans  <wim@fluendo.com>
1026
1027         * docs/design/part-dynamic.txt:
1028         * docs/design/part-events.txt:
1029         * docs/design/part-seeking.txt:
1030         Some more docs in the works.
1031
1032         * gst/base/gstbasetransform.c: (gst_base_transform_transform_caps),
1033         (gst_base_transform_getcaps), (gst_base_transform_configure_caps),
1034         (gst_base_transform_setcaps), (gst_base_transform_get_size),
1035         (gst_base_transform_buffer_alloc), (gst_base_transform_event),
1036         (gst_base_transform_handle_buffer),
1037         (gst_base_transform_sink_activate_push),
1038         (gst_base_transform_src_activate_pull),
1039         (gst_base_transform_set_passthrough),
1040         (gst_base_transform_is_passthrough):
1041         Refcounting fixes.
1042
1043         * gst/gstbus.c: (gst_bus_source_dispatch), (gst_bus_poll):
1044         Cleanups.
1045
1046         * gst/gstevent.c: (gst_event_finalize):
1047         Set SRC to NULL.
1048
1049         * gst/gstutils.c: (gst_element_unlink),
1050         (gst_pad_get_parent_element), (gst_pad_proxy_getcaps),
1051         (gst_pad_proxy_setcaps):
1052         * gst/gstutils.h:
1053         Add _get_parent_element() to get a pads parent as an element.
1054
1055 2005-07-18  Wim Taymans  <wim@fluendo.com>
1056
1057         * check/gst/gstbin.c: (GST_START_TEST):
1058         Remove bogus test.
1059
1060 2005-07-18  Wim Taymans  <wim@fluendo.com>
1061
1062         * gst/base/gstbasesink.c: (gst_base_sink_pad_getcaps),
1063         (gst_base_sink_pad_setcaps), (gst_base_sink_pad_buffer_alloc),
1064         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_object),
1065         (gst_base_sink_event), (gst_base_sink_do_sync),
1066         (gst_base_sink_chain), (gst_base_sink_loop),
1067         (gst_base_sink_deactivate), (gst_base_sink_activate_push),
1068         (gst_base_sink_activate_pull), (gst_base_sink_change_state):
1069         Refcounting fixes.
1070         Fix logic for returning ASYNC when not prerolled.
1071
1072 2005-07-18  Wim Taymans  <wim@fluendo.com>
1073
1074         * gst/gstqueue.c: (gst_queue_handle_sink_event):
1075         Fix nasty refcount bug.
1076
1077 2005-07-16 Philippe Khalaf <burger@speedy.org>
1078         * gst/elements/gstfdsrc.c:
1079         * gst/elements/gstfdsrc.h:
1080         * gst/elements/gstelements.c:
1081         * gst/elements/Makefile.am:
1082         Ported fdsrc to 0.9.
1083
1084 2005-07-16  Wim Taymans  <wim@fluendo.com>
1085
1086         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
1087         (gst_base_sink_do_sync):
1088         Fix compile error.
1089
1090 2005-07-16  Wim Taymans  <wim@fluendo.com>
1091
1092         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
1093         (gst_base_sink_event), (gst_base_sink_get_times),
1094         (gst_base_sink_do_sync), (gst_base_sink_change_state):
1095         * gst/base/gstbasesink.h:
1096         Store and use discont values when syncing buffers as described
1097         in design docs.
1098         
1099         * gst/base/gstbasesrc.c: (gst_base_src_send_discont),
1100         (gst_base_src_do_seek), (gst_base_src_loop), (gst_base_src_start),
1101         (gst_base_src_activate_push):
1102         Push discont event when starting.
1103
1104         * gst/elements/gstidentity.c: (gst_identity_transform):
1105         Small cleanups.
1106
1107         * gst/gstbin.c: (gst_bin_change_state):
1108         Small cleanups in base_time  distribution.
1109
1110         * gst/gstelement.c: (gst_element_set_base_time),
1111         (gst_element_get_base_time), (gst_element_change_state):
1112         * gst/gstelement.h:
1113         Added methods for the base_time of the element.
1114         Some MT fixes.
1115
1116         * gst/gstpipeline.c: (gst_pipeline_send_event),
1117         (gst_pipeline_change_state), (gst_pipeline_set_new_stream_time),
1118         (gst_pipeline_get_last_stream_time):
1119         * gst/gstpipeline.h:
1120         MT fixes.
1121         Handle seeking as described in design doc, remove stream_time
1122         hack.
1123         Cleanups clock and stream_time selection code. Added accessors
1124         for the stream_time.
1125         
1126
1127 2005-07-16  Andy Wingo  <wingo@pobox.com>
1128
1129         * gst/gsterror.c (_gst_core_errors_init): Use the magic word
1130         (#305291).
1131
1132 2005-07-16  Wim Taymans  <wim@fluendo.com>
1133
1134         * check/gst/gstbin.c: (GST_START_TEST):
1135         Make elements silent as the deep_notify refs the
1136         parent, which might make the test fail.
1137
1138         * gst/gstghostpad.c: (gst_ghost_pad_do_activate_push):
1139         Don't hold the lock for too long.
1140
1141 2005-07-16  Tim-Philipp Müller  <tim at centricular dot net>
1142
1143         * gst/base/gstbasesrc.c: (gst_base_src_default_negotiate):
1144           Don't unref the caps we passed to gst_caps_make_writable() after
1145           passing them. gst_caps_make_writable() will do that for us.
1146
1147 2005-07-15  Andy Wingo  <wingo@pobox.com>
1148
1149         * gst/gstcaps.h (gst_caps_is_simple): Removed deprecated macro
1150         (#157311).
1151
1152         * gst/elements/gstidentity.c (marshal_VOID__MINIOBJECT): Write our
1153         own marshalling function for the handoff signal. Properly type the
1154         buffer as a buffer. Fixes some warnings. Should do a more general
1155         solution.
1156         (gst_identity_class_init): Plug into the right marshaller.
1157
1158 2005-07-15  Wim Taymans  <wim@fluendo.com>
1159
1160         * docs/design/part-TODO.txt:
1161         * docs/design/part-clocks.txt:
1162         * docs/design/part-element-sink.txt:
1163         * docs/design/part-events.txt:
1164         * docs/design/part-gstpipeline.txt:
1165         Updated docs, mostly DISCONT related.
1166
1167 2005-07-15  Tim-Philipp Müller  <tim at centricular dot net>
1168
1169         * docs/pwg/building-pads.xml:
1170           s/GST_PAD_LINK_REFUSED/FALSE/ in gst_my_filter_setcaps()
1171
1172 2005-07-15  Andy Wingo  <wingo@pobox.com>
1173
1174         * tools/gst-typefind.c: Update, add copyright block.
1175
1176         * gst/base/gstbasesrc.c (gst_base_src_default_negotiate):
1177         Normalize and truncate caps before fixation.
1178
1179         * gst/gstcaps.h:
1180         * gst/gstcaps.c (gst_caps_truncate): New function, destructively
1181         discards all but the first structure from its argument.
1182
1183 2005-07-15  Wim Taymans  <wim@fluendo.com>
1184
1185         * gst/base/gstbasetransform.c: (gst_base_transform_init),
1186         (gst_base_transform_transform_caps), (gst_base_transform_getcaps),
1187         (gst_base_transform_configure_caps), (gst_base_transform_setcaps),
1188         (gst_base_transform_get_size), (gst_base_transform_buffer_alloc),
1189         (gst_base_transform_handle_buffer), (gst_base_transform_getrange),
1190         (gst_base_transform_chain), (gst_base_transform_change_state),
1191         (gst_base_transform_set_passthrough),
1192         (gst_base_transform_is_passthrough):
1193         * gst/base/gstbasetransform.h:
1194         Make passthrough work using the bufferpools.
1195         Changed API a bit, subclasses have to write into a buffer
1196         provided by the base class.
1197         More debug info in nego functions.
1198         
1199         * gst/elements/gstidentity.c: (gst_identity_init),
1200         (gst_identity_transform):
1201         Port to new base class.
1202
1203 2005-07-15  Wim Taymans  <wim@fluendo.com>
1204
1205         * gst/gstmessage.c: (gst_message_new_state_changed):
1206         * tools/gst-launch.c: (event_loop), (main):
1207         Totally dump messages in -launch with the -m option.
1208         Fix message name for State messages,
1209
1210 2005-07-14  Wim Taymans  <wim@fluendo.com>
1211
1212         * gst/base/gstbasesrc.c: (gst_base_src_loop):
1213         Post error messages on errors.
1214
1215 2005-07-14  Wim Taymans  <wim@fluendo.com>
1216
1217         * gst/gstcaps.c: (gst_caps_do_simplify):
1218         Remove debug info.
1219
1220         * gst/gsterror.h:
1221         Define error for stream stopped.
1222
1223         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
1224         (gst_proxy_pad_do_chain), (gst_proxy_pad_do_getrange):
1225         Do proper return values.
1226
1227         * gst/gstpad.c: (gst_pad_get_caps_unlocked), (gst_pad_accept_caps),
1228         (gst_pad_set_caps), (gst_pad_chain), (gst_pad_push),
1229         (gst_pad_get_range):
1230         Better return values.
1231
1232         * gst/gstpad.h:
1233         Reorganise return values, add macro to check for fatal errors.
1234
1235         * gst/gstqueue.c: (gst_queue_chain):
1236         Return proper GstFlowReturn values,
1237
1238 2005-07-14  Thomas Vander Stichele  <thomas at apestaart dot org>
1239
1240         * docs/gst/gstreamer-sections.txt:
1241         * docs/gst/gstreamer.types:
1242         * docs/gst/tmpl/gst.sgml:
1243         * docs/gst/tmpl/gstbasesink.sgml:
1244         * docs/gst/tmpl/gstbasesrc.sgml:
1245         * docs/gst/tmpl/gstbasetransform.sgml:
1246         * docs/gst/tmpl/gstbin.sgml:
1247         * docs/gst/tmpl/gstbuffer.sgml:
1248         * docs/gst/tmpl/gstcaps.sgml:
1249         * docs/gst/tmpl/gstclock.sgml:
1250         * docs/gst/tmpl/gstcompat.sgml:
1251         * docs/gst/tmpl/gstconfig.sgml:
1252         * docs/gst/tmpl/gstelement.sgml:
1253         * docs/gst/tmpl/gstelementdetails.sgml:
1254         * docs/gst/tmpl/gstelementfactory.sgml:
1255         * docs/gst/tmpl/gstenumtypes.sgml:
1256         * docs/gst/tmpl/gsterror.sgml:
1257         * docs/gst/tmpl/gstevent.sgml:
1258         * docs/gst/tmpl/gstfakesink.sgml:
1259         * docs/gst/tmpl/gstfakesrc.sgml:
1260         * docs/gst/tmpl/gstfilesink.sgml:
1261         * docs/gst/tmpl/gstfilesrc.sgml:
1262         * docs/gst/tmpl/gstfilter.sgml:
1263         * docs/gst/tmpl/gstformat.sgml:
1264         * docs/gst/tmpl/gstghostpad.sgml:
1265         * docs/gst/tmpl/gstimplementsinterface.sgml:
1266         * docs/gst/tmpl/gstindex.sgml:
1267         * docs/gst/tmpl/gstindexfactory.sgml:
1268         * docs/gst/tmpl/gstinfo.sgml:
1269         * docs/gst/tmpl/gstiterator.sgml:
1270         * docs/gst/tmpl/gstmacros.sgml:
1271         * docs/gst/tmpl/gstmemchunk.sgml:
1272         * docs/gst/tmpl/gstminiobject.sgml:
1273         * docs/gst/tmpl/gstobject.sgml:
1274         * docs/gst/tmpl/gstpad.sgml:
1275         * docs/gst/tmpl/gstpadtemplate.sgml:
1276         * docs/gst/tmpl/gstparse.sgml:
1277         * docs/gst/tmpl/gstpipeline.sgml:
1278         * docs/gst/tmpl/gstplugin.sgml:
1279         * docs/gst/tmpl/gstpluginfeature.sgml:
1280         * docs/gst/tmpl/gstquery.sgml:
1281         * docs/gst/tmpl/gstqueue.sgml:
1282         * docs/gst/tmpl/gstregistry.sgml:
1283         * docs/gst/tmpl/gstregistrypool.sgml:
1284         * docs/gst/tmpl/gstscheduler.sgml:
1285         * docs/gst/tmpl/gstschedulerfactory.sgml:
1286         * docs/gst/tmpl/gststructure.sgml:
1287         * docs/gst/tmpl/gstsystemclock.sgml:
1288         * docs/gst/tmpl/gsttaglist.sgml:
1289         * docs/gst/tmpl/gsttagsetter.sgml:
1290         * docs/gst/tmpl/gsttrace.sgml:
1291         * docs/gst/tmpl/gsttrashstack.sgml:
1292         * docs/gst/tmpl/gsttypefind.sgml:
1293         * docs/gst/tmpl/gsttypefindfactory.sgml:
1294         * docs/gst/tmpl/gsttypes.sgml:
1295         * docs/gst/tmpl/gsturihandler.sgml:
1296         * docs/gst/tmpl/gsturitype.sgml:
1297         * docs/gst/tmpl/gstutils.sgml:
1298         * docs/gst/tmpl/gstvalue.sgml:
1299         * docs/gst/tmpl/gstversion.sgml:
1300         * docs/gst/tmpl/gstxml.sgml:
1301         * docs/libs/tmpl/gstcontrol.sgml:
1302         * docs/libs/tmpl/gstdataprotocol.sgml:
1303         * docs/libs/tmpl/gstdparam.sgml:
1304         * docs/libs/tmpl/gstdplinint.sgml:
1305         * docs/libs/tmpl/gstdpman.sgml:
1306         * docs/libs/tmpl/gstdpsmooth.sgml:
1307         * docs/libs/tmpl/gstgetbits.sgml:
1308         * docs/libs/tmpl/gstunitconvert.sgml:
1309         * gst/base/gstpushsrc.c: (gst_push_src_get_type),
1310         (gst_push_src_base_init), (gst_push_src_class_init),
1311         (gst_push_src_init), (gst_push_src_create):
1312         * gst/base/gstpushsrc.h:
1313         * gst/elements/gstelements.c:
1314         * gst/elements/gstfakesink.c: (gst_fake_sink_state_error_get_type),
1315         (gst_fake_sink_base_init), (gst_fake_sink_class_init),
1316         (gst_fake_sink_init), (gst_fake_sink_set_property),
1317         (gst_fake_sink_get_property), (gst_fake_sink_get_times),
1318         (gst_fake_sink_event), (gst_fake_sink_preroll),
1319         (gst_fake_sink_render), (gst_fake_sink_change_state):
1320         * gst/elements/gstfakesink.h:
1321         * gst/elements/gstfakesrc.c: (gst_fake_src_data_get_type),
1322         (gst_fake_src_sizetype_get_type), (gst_fake_src_filltype_get_type),
1323         (gst_fake_src_base_init), (gst_fake_src_class_init),
1324         (gst_fake_src_init), (gst_fake_src_event_handler),
1325         (gst_fake_src_alloc_parent), (gst_fake_src_set_property),
1326         (gst_fake_src_get_property), (gst_fake_src_prepare_buffer),
1327         (gst_fake_src_alloc_buffer), (gst_fake_src_get_size),
1328         (gst_fake_src_create_buffer), (gst_fake_src_create),
1329         (gst_fake_src_start), (gst_fake_src_stop):
1330         * gst/elements/gstfakesrc.h:
1331         * gst/elements/gstfilesink.c: (_do_init),
1332         (gst_file_sink_base_init), (gst_file_sink_class_init),
1333         (gst_file_sink_init), (gst_file_sink_dispose),
1334         (gst_file_sink_set_location), (gst_file_sink_set_property),
1335         (gst_file_sink_get_property), (gst_file_sink_open_file),
1336         (gst_file_sink_close_file), (gst_file_sink_query),
1337         (gst_file_sink_event), (gst_file_sink_render),
1338         (gst_file_sink_change_state), (gst_file_sink_uri_get_type),
1339         (gst_file_sink_uri_get_protocols), (gst_file_sink_uri_get_uri),
1340         (gst_file_sink_uri_set_uri), (gst_file_sink_uri_handler_init):
1341         * gst/elements/gstfilesink.h:
1342         * gst/elements/gstfilesrc.c: (_do_init), (gst_file_src_base_init),
1343         (gst_file_src_class_init), (gst_file_src_init),
1344         (gst_file_src_finalize), (gst_file_src_set_location),
1345         (gst_file_src_set_property), (gst_file_src_get_property),
1346         (gst_file_src_map_region), (gst_file_src_map_small_region),
1347         (gst_file_src_create_mmap), (gst_file_src_create_read),
1348         (gst_file_src_create), (gst_file_src_is_seekable),
1349         (gst_file_src_get_size), (gst_file_src_start), (gst_file_src_stop),
1350         (gst_file_src_uri_get_type), (gst_file_src_uri_get_protocols),
1351         (gst_file_src_uri_get_uri), (gst_file_src_uri_set_uri),
1352         (gst_file_src_uri_handler_init):
1353         * gst/elements/gstfilesrc.h:
1354           more autistic cleanliness in functions/names/defines
1355
1356 2005-07-13  Andy Wingo  <wingo@pobox.com>
1357
1358         * gst/base/gstbasesrc.c (gst_base_src_start): Post an error if the
1359         source couldn't negotiate.
1360
1361         * gst/parse/grammar.y: Revert 1.54->1.55, so we now do filtered
1362         connections again.
1363
1364         * gst/gstutils.h:
1365         * gst/gstutils.c (gst_element_link_pads_filtered): New old
1366         function. I am channeling Hades. Put your boots on suckers!!!
1367
1368 2005-07-13  Thomas Vander Stichele  <thomas at apestaart dot org>
1369
1370         * testsuite/caps/Makefile.am:
1371         * testsuite/caps/value_compare.c:
1372         * testsuite/caps/value_intersect.c:
1373         * check/gst/gstvalue.c: (GST_START_TEST), (gst_value_suite):
1374           move two testsuite apps over to the check dir
1375
1376 2005-07-12  Wim Taymans  <wim@fluendo.com>
1377
1378         * gst/base/gstbasetransform.c: (gst_base_transform_setcaps):
1379         Added more debug info in the negotiate process.
1380
1381         * gst/gstmessage.h:
1382         Prepare for segment playback.
1383
1384         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_set_caps):
1385         Better debugging.
1386
1387         * gst/gstutils.c:
1388         Some more docs.
1389
1390         * tools/gst-launch.c: (main):
1391         NULL pipeline on errors.
1392
1393 2005-07-12  Andy Wingo  <wingo@pobox.com>
1394
1395         * gst/gstbuffer.c (_gst_buffer_copy): Copy the buffer whether or
1396         not it comes from a malloc region. Make sure our copy gets freed.
1397
1398 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
1399
1400         * check/gst/gstelement.c: (GST_START_TEST), (gst_element_suite):
1401         * check/gst/gstmessage.c: (GST_START_TEST):
1402         * check/gst/gststructure.c: (GST_START_TEST),
1403         (gst_structure_suite), (main):
1404           more testing
1405         * gst/gstelement.c: (gst_element_message_full):
1406           clean up GError and debug string now that they get copied
1407         * gst/gstmessage.c: (gst_message_new_error),
1408         (gst_message_new_warning), (gst_message_parse_error),
1409         (gst_message_parse_warning):
1410           use GST_TYPE_G_ERROR for structure_new, and take copies of
1411           arguments, so that we don't mess up refcounting
1412
1413 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
1414
1415         * check/Makefile.am:
1416           add per-test valgrind targets
1417         * check/gst-libs/gdp.c: (GST_START_TEST),
1418         (gst_data_protocol_suite), (main):
1419           clean up
1420
1421 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
1422
1423         * check/Makefile.am:
1424           instate more valgrindable tests
1425         * check/elements/gstfakesrc.c: (chain_func), (event_func),
1426         (GST_START_TEST), (fakesrc_suite):
1427         * check/gst/gstpad.c: (GST_START_TEST):
1428         * check/gst/gststructure.c: (GST_START_TEST):
1429           fix test leaks
1430         * docs/gst/tmpl/gstminiobject.sgml:
1431         * gst/gstpad.c: (gst_pad_finalize):
1432           fix the static mutex leak
1433
1434 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
1435
1436         * check/Makefile.am:
1437           add two more tests for valgrinding
1438         * check/gst/gstvalue.c: (GST_START_TEST):
1439           test refcount of deserialized buffer, found a leak
1440         * docs/gst/gstreamer-docs.sgml:
1441         * docs/gst/gstreamer-sections.txt:
1442         * docs/gst/gstreamer.types:
1443         * docs/gst/tmpl/gstminiobject.sgml:
1444           add miniobject to docs
1445         * gst/gstminiobject.c:
1446           add some docs
1447         * gst/gstvalue.c: (gst_value_deserialize_buffer),
1448         (gst_string_unwrap):
1449           fix a hard-to-find invalid write for one of the tests
1450           fix a leak for deserialized buffers
1451
1452 2005-07-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1453
1454         * docs/pwg/advanced-events.xml:
1455         * docs/pwg/advanced-request.xml:
1456         * docs/pwg/advanced-scheduling.xml:
1457         * docs/pwg/appendix-porting.xml:
1458         * docs/pwg/building-boiler.xml:
1459         * docs/pwg/intro-preface.xml:
1460         * docs/pwg/other-ntoone.xml:
1461           Rewrite scheduling-chapter for scheduling model in 0.9. Add lots
1462           of example code and explanation for pad activation, loop() and
1463           getrange() functions and a bit more. Remove old comments pointing
1464           to loop-functions.
1465         * examples/pwg/Makefile.am:
1466           Add loop/getrange examples.
1467
1468 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
1469
1470         * configure.ac:
1471           check for valgrind binary + some fixes
1472         * check/gst.supp:
1473           valgrind suppressions for the tests
1474         * check/Makefile.am:
1475           add a valgrind: target that valgrinds the unit tests
1476         * check/gst/gst.c: (GST_START_TEST), (gst_suite):
1477         * check/gst/gstbin.c: (pop_messages), (GST_START_TEST):
1478         * check/gst/gstbuffer.c: (GST_START_TEST), (gst_test_suite):
1479         * check/gst/gstghostpad.c:
1480           added some cleanup
1481         * check/gst/gstdata.c:
1482           removed
1483         * check/gst/gstminiobject.c: (GST_START_TEST), (thread_ref),
1484         (thread_unref), (gst_mini_object_suite), (main):
1485           added
1486         * gst/gst.c: (gst_deinit):
1487         * gst/gst.h:
1488           add a method to clean up.
1489         * gst/gstsystemclock.c: (gst_system_clock_dispose),
1490         (gst_system_clock_obtain):
1491           allow for disposing the system clock.
1492         * tools/gst-launch.c: (main):
1493           deinit
1494
1495 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
1496
1497         * docs/gst/tmpl/gstbasesrc.sgml:
1498         * docs/gst/tmpl/gstfakesrc.sgml:
1499         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
1500         (gst_base_src_init), (gst_base_src_set_property),
1501         (gst_base_src_get_property), (gst_base_src_get_range),
1502         (gst_base_src_start):
1503         * gst/base/gstbasesrc.h:
1504           add num-buffers property
1505         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
1506         (gst_fakesrc_init), (gst_fakesrc_set_property),
1507         (gst_fakesrc_get_property), (gst_fakesrc_create),
1508         (gst_fakesrc_start):
1509           remove num-buffers property
1510
1511 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
1512
1513         * docs/gst/gstreamer-sections.txt:
1514         * docs/gst/tmpl/gstbasesink.sgml:
1515         * docs/gst/tmpl/gstbasesrc.sgml:
1516         * gst/base/gstbasesink.c: (gst_base_sink_pad_getcaps),
1517         (gst_base_sink_pad_setcaps), (gst_base_sink_pad_buffer_alloc),
1518         (gst_base_sink_finalize), (gst_base_sink_set_clock),
1519         (gst_base_sink_set_property), (gst_base_sink_get_property),
1520         (gst_base_sink_handle_object), (gst_base_sink_event),
1521         (gst_base_sink_do_sync), (gst_base_sink_handle_event),
1522         (gst_base_sink_handle_buffer), (gst_base_sink_chain),
1523         (gst_base_sink_loop), (gst_base_sink_deactivate),
1524         (gst_base_sink_activate_push), (gst_base_sink_activate_pull),
1525         (gst_base_sink_change_state):
1526         * gst/base/gstbasesink.h:
1527         * gst/base/gstbasesrc.h:
1528         * gst/elements/gstfakesink.c: (gst_fakesink_get_times):
1529         * gst/elements/gstfilesink.c: (gst_filesink_class_init),
1530         (gst_filesink_init):
1531           more macro splitting
1532
1533 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
1534
1535         * gst/gstelement.c: (gst_element_get_bus):
1536           add debug
1537         * tools/gst-launch.c: (check_intr), (event_loop):
1538           fix bus leaks
1539
1540 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
1541
1542         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked):
1543           fix a caps leak
1544
1545 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
1546
1547         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
1548         (gst_base_src_finalize):
1549           add finalize method and clean up properly
1550         * gst/gstpipeline.c: (gst_pipeline_dispose):
1551           add debug
1552
1553 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
1554
1555         * check/gst/gstbin.c: (pop_messages), (GST_START_TEST),
1556         (gst_bin_suite):
1557           add more things to check
1558         * gst/gstbin.c: (gst_bin_change_state), (bin_bus_handler):
1559         * gst/gstelement.c:
1560           more debug
1561
1562 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
1563
1564         * check/elements/gstfakesrc.c: (chain_func), (event_func),
1565         (GST_START_TEST), (fakesrc_suite):
1566         * check/gst-libs/gdp.c: (GST_START_TEST):
1567         * check/gst/gst.c: (GST_START_TEST):
1568         * check/gst/gstbin.c: (GST_START_TEST), (gst_bin_suite):
1569         * check/gst/gstbuffer.c: (GST_START_TEST), (gst_test_suite):
1570         * check/gst/gstbus.c: (GST_START_TEST):
1571         * check/gst/gstcaps.c: (GST_START_TEST):
1572         * check/gst/gstdata.c: (GST_START_TEST):
1573         * check/gst/gstelement.c: (GST_START_TEST):
1574         * check/gst/gstghostpad.c: (GST_START_TEST):
1575         * check/gst/gstiterator.c: (GST_START_TEST):
1576         * check/gst/gstmessage.c: (GST_START_TEST):
1577         * check/gst/gstobject.c: (GST_START_TEST):
1578         * check/gst/gstpad.c: (GST_START_TEST):
1579         * check/gst/gststructure.c: (GST_START_TEST):
1580         * check/gst/gstsystemclock.c: (GST_START_TEST),
1581         (gst_systemclock_suite):
1582         * check/gst/gsttag.c: (GST_START_TEST), (gst_tag_suite):
1583         * check/gst/gstvalue.c: (GST_START_TEST):
1584         * check/pipelines/cleanup.c: (GST_START_TEST):
1585         * check/pipelines/simple_launch_lines.c: (GST_START_TEST):
1586         * check/states/sinks.c: (GST_START_TEST):
1587         * check/gstcheck.c: (gst_check_init):
1588         * check/gstcheck.h:
1589           add debugging category
1590           use GST_START_TEST now, so we add a debug line
1591
1592 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
1593
1594         * check/gst/gstbin.c: (START_TEST), (gst_bin_suite):
1595           add test for state change message on a bin
1596         * check/gst/gstelement.c: (START_TEST), (gst_element_suite):
1597           add another test
1598         * gst/gstbin.c: (gst_bin_init):
1599         * gst/gstbus.c: (gst_bus_init), (gst_bus_post):
1600         * gst/gstelement.c: (gst_element_post_message),
1601         (gst_element_set_state):
1602         * gst/gstelementfactory.c: (gst_element_factory_create):
1603         * gst/gstmessage.c: (gst_message_new):
1604         * gst/gstscheduler.c:
1605           various debugging additions and cleanups
1606
1607 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1608
1609         * check/Makefile.am:
1610         * check/gst/gstelement.c: (START_TEST), (gst_element_suite),
1611         (main):
1612           adding tests for elements
1613         * gst/gstelement.c: (gst_element_dispose):
1614
1615 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1616
1617         * gst/registries/gstlibxmlregistry.c: (load_feature):
1618           plug more leaks.  A simple gst_init() now is leakfree, yay.
1619
1620 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1621
1622         * gst/registries/gstlibxmlregistry.c: (read_string), (load_paths),
1623         (gst_xml_registry_load):
1624           plug another memleak
1625
1626 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1627
1628         * configure.ac:
1629           use GST_SET_ERROR_CFLAGS
1630         * docs/faq/cvs.xml:
1631           change to ERROR_CFLAGS
1632
1633 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1634
1635         * configure.ac:
1636           make GST_ERROR_CFLAGS overridable and re-enable Werror
1637         * docs/faq/cvs.xml:
1638           add a note about error CFLAGS
1639         * docs/gst/tmpl/gstfakesrc.sgml:
1640         * gst/elements/gstfakesrc.c:
1641           comment out some unused code
1642         * gst/gst.c: (split_and_iterate):
1643         * gst/registries/gstlibxmlregistry.c: (load_pad_template),
1644         (load_feature):
1645           plug some memleaks
1646
1647 2005-07-07  Thomas Vander Stichele  <thomas at apestaart dot org>
1648
1649         * common/Makefile.am:
1650         * common/gtk-doc.mak:
1651         * docs/gst/Makefile.am:
1652           factor out gtk-doc.mak
1653
1654 2005-07-07  Wim Taymans  <wim@fluendo.com>
1655
1656         * gst/schedulers/threadscheduler.c: (gst_thread_scheduler_func),
1657         (gst_thread_scheduler_dispose):
1658         Unlock the STREAM_LOCK completely.
1659
1660 2005-07-07  Thomas Vander Stichele  <thomas at apestaart dot org>
1661
1662         * check/Makefile.am:
1663         * check/elements/.cvsignore:
1664         * check/elements/gstfakesrc.c: (chain_func), (event_func),
1665         (START_TEST), (fakesrc_suite), (main):
1666         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
1667         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
1668         (gst_fakesrc_create), (gst_fakesrc_start):
1669         * gst/elements/gstfakesrc.h:
1670           adding a first element test
1671
1672 2005-07-07  Andy Wingo  <wingo@pobox.com>
1673
1674         * gst/gstbus.c (gst_bus_have_pending): Remove intensely irritating
1675         debug message.
1676
1677 2005-07-07  Wim Taymans  <wim@fluendo.com>
1678
1679         * gst/gstquery.c:
1680         * gst/gstquery.h:
1681         Remove old types
1682
1683 2005-07-07  Wim Taymans  <wim@fluendo.com>
1684
1685         * gst/base/gstbasesrc.c: (gst_base_src_get_range),
1686         (gst_base_src_default_negotiate), (gst_base_src_negotiate):
1687         Allow subclasses to implement their own negotiation.
1688
1689 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
1690
1691         * docs/design/part-gstbin.txt:
1692         * docs/design/part-gstpipeline.txt:
1693           Update design notes to reflect the movement of
1694           responsibility for bus handling from GstPipeline to
1695           GstBin
1696
1697 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
1698
1699         * configure.ac:
1700           Remove unnecessary queue2/3/4 examples.
1701
1702 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
1703
1704         * examples/Makefile.am:
1705         * examples/helloworld/helloworld.c: (event_loop), (main):
1706         * examples/queue/queue.c: (event_loop), (main):
1707         * examples/queue2/queue2.c: (main):
1708           Update a couple of the examples to work again.
1709
1710         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
1711         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_event):
1712          Spelling corrections and extra debug.
1713         
1714         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_init), (is_eos),
1715         (gst_bin_add_func), (bin_element_is_sink), (gst_bin_get_state),
1716         (gst_bin_change_state), (gst_bin_dispose), (bin_bus_handler):
1717         * gst/gstbin.h:
1718         * gst/gstpipeline.c: (gst_pipeline_init), (gst_pipeline_dispose),
1719         (gst_pipeline_change_state):
1720         * gst/gstpipeline.h:
1721           Move the bus handler for children to the GstBin, and create a
1722           separate bus for receiving messages from children to the one the
1723           bus sends 'upwards' on.
1724
1725 2005-07-06  Wim Taymans  <wim@fluendo.com>
1726
1727         * gst/base/README:
1728         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
1729         (gst_base_sink_handle_object), (gst_base_sink_loop),
1730         (gst_base_sink_change_state):
1731         * gst/base/gstbasesink.h:
1732         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
1733         (gst_base_src_init), (gst_base_src_setcaps),
1734         (gst_base_src_getcaps), (gst_base_src_loop),
1735         (gst_base_src_default_negotiate), (gst_base_src_negotiate),
1736         (gst_base_src_start), (gst_base_src_change_state):
1737         * gst/base/gstbasesrc.h:
1738         Make basesrc negotiate.
1739         Handle the case where preroll fails in basesink.
1740         Update README.
1741
1742 2005-07-06  Wim Taymans  <wim@fluendo.com>
1743
1744         * gst/gstpad.c: (gst_pad_fixate_caps), (gst_pad_accept_caps):
1745         Implement the fixate function.
1746         Clean up acceptcaps.
1747
1748 2005-07-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1749
1750         * docs/pwg/building-filterfactory.xml:
1751         * docs/pwg/pwg.xml:
1752           Remove never-written filter-factory chapter; I'll add the various
1753           base classes to part 4 ("other element types") later on.
1754
1755 2005-07-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1756
1757         * docs/pwg/advanced-negotiation.xml:
1758         * docs/pwg/building-boiler.xml:
1759         * docs/pwg/building-pads.xml:
1760         * docs/pwg/pwg.xml:
1761         * examples/pwg/Makefile.am:
1762           Add a chapter on caps negotiation, simplify the original code
1763           samples a bit w.r.t. caps negotiation, add link to the advanced
1764           section. Add a bunch of examples showing different use cases of
1765           different types of caps negotiation. Upstream renegotiation isn't
1766           fully documented yet since nobody knows how that works.
1767
1768 2005-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
1769
1770         * check/gst/gstpad.c:
1771         * check/gstcheck.c:
1772         * gst/gstpad.c: (gst_pad_get_internal_links_default):
1773           if pad has no parent, return NULL as list of internal links
1774
1775 2005-07-05  Andy Wingo  <wingo@pobox.com>
1776
1777         * gst/elements/gstfilesrc.c:
1778         * gst/elements/gstfakesrc.c: 
1779         * gst/base/gstpushsrc.c:
1780         * gst/base/gstbasesrc.h: 
1781         * gst/base/gstbasesrc.c: s/BASESRC/BASE_SRC/g.
1782         
1783 2005-07-05  Stefan Kost  <ensonic@users.sf.net>
1784
1785         * Makefile.am:
1786           better report generation target (lcov needs a patch)
1787
1788 2005-07-05  Andy Wingo  <wingo@pobox.com>
1789
1790         * gst/elements, testsuite: Null if we got it...
1791
1792 2005-07-05  Wim Taymans  <wim@fluendo.com>
1793
1794         * configure.ac:
1795         * libs/gst/dataprotocol/Makefile.am:
1796         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_validate_packet):
1797         * libs/gst/dataprotocol/dataprotocol.h:
1798         * pkgconfig/Makefile.am:
1799         * pkgconfig/gstreamer-dataprotocol-uninstalled.pc.in:
1800         * pkgconfig/gstreamer-dataprotocol.pc.in:
1801         Ported dataprotol to 0.9. 
1802         Added pkgconfig files.
1803
1804 2005-07-05  Andy Wingo  <wingo@pobox.com>
1805
1806         * gst/base/gstbasetransform.c (gst_base_transform_setcaps):
1807         Default to returning TRUE for the case when tranform_caps returns
1808         a fixed caps, like for identity or volume.
1809
1810         * check/gst/gstbus.c (pound_bus_with_messages): 
1811         * check/gst/gstmessage.c (START_TEST): 
1812         * check/pipelines/simple_launch_lines.c (got_handoff): Application
1813         message API change.
1814
1815         * gst/base/gstbasetransform.c (gst_base_transform_setcaps): More
1816         logic weaks here: always run transform_caps, trying passthrough
1817         operation only if the original caps intersects with the transform.
1818
1819         * gst/gstpad.c (gst_pad_link_check_compatible_unlocked): Debug
1820         source and sink caps.
1821
1822         * gst/base/gstbasetransform.c (gst_base_transform_getcaps):
1823         Intersect the peer caps with the pad template before going into
1824         transform_caps.
1825         (gst_base_transform_transform_caps): More debugging.
1826
1827         * gst/gstmessage.h (gst_message_new_application): Take a GstObject
1828         src argument.
1829
1830 2005-07-04  Edward Hervey  <edward@fluendo.com>
1831
1832         * gst/gstutils.c:
1833         * gst/gstutils.h:
1834         (gst_pad_add_*_probe): now returns the signal id for better wrapping
1835         in bindings.
1836
1837 2005-07-04  Andy Wingo  <wingo@pobox.com>
1838
1839         * check/gst/gstpad.c: Only set explicit caps on pads.
1840
1841 2005-07-01  Andy Wingo  <wingo@pobox.com>
1842
1843         * tests/network-clock.scm: Commentary update.
1844
1845         * gst/elements/gstidentity.c (PROP_DUPLICATE): Gone daddy gone.
1846         Didn't really make sense, not implementable with basetransform,
1847         etc.
1848         (gst_identity_transform): Unref inbuf via make_writable. Feeble
1849         attempt at implementing the sync property, needs an unlock method.
1850
1851         * gst/base/gstbasetransform.c (gst_base_transform_transform_caps):
1852         New func, by default returns the same caps (the identity
1853         transformation).
1854         (gst_base_transform_getcaps): Uses transform_caps to return
1855         something sensible.
1856         (gst_base_transform_setcaps): Complicated logic to get caps on
1857         both pads, even if they are different, and to call set_caps once
1858         for every time both pads get their caps set.
1859         (gst_base_transform_handle_buffer): Give the ref to the transform
1860         function. Allows in-place modification of the buffer.
1861
1862         * gst/base/gstbasetransform.h (transform_caps): New class method.
1863         Given caps on one side, what can I do on the other.
1864         (set_caps): Take two caps, one for each side of the element.
1865
1866         * gst/gstpad.h:
1867         * gst/gstpad.c (gst_pad_fixate_caps): Change prototype to modify
1868         caps in place. This is safe because we can check the mutability of
1869         the caps, and a good idea because fixate functions are just called
1870         as a matter of last resort. (Not actually implemented.)
1871         (gst_pad_set_caps): If the caps we're setting is actually the same
1872         as the existing pad caps, just update the pointer without calling
1873         setcaps. Assert that caps is either NULL or fixed, as per the
1874         docs.
1875
1876         * gst/gstghostpad.c: Update for fixate changes.
1877
1878 2005-07-02  Andy Wingo  <wingo@pobox.com>
1879
1880         * gst/gstcaps.c:
1881         * gst/gstcaps.h (gst_static_caps_get): Not const return, having
1882         two refcounts makes it immutable, which is enough. Doc more.
1883
1884 2005-07-02  Jan Schmidt  <thaytan@mad.scientist.com>
1885
1886         * gst/gstpad.c: (gst_pad_emit_have_data_signal):
1887           Put the mini_object into GValue as a mini_object,
1888           not a gpointer, since that's how we declared
1889           the signal.
1890
1891 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1892
1893         * examples/pwg/Makefile.am:
1894           Fix buildbot again.
1895
1896 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1897
1898         * docs/pwg/building-testapp.xml:
1899           Add extra check.
1900         * examples/pwg/Makefile.am:
1901           Fix buildbot.
1902
1903 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1904
1905         * configure.ac:
1906         * examples/Makefile.am:
1907         * examples/pwg/Makefile.am:
1908         * examples/pwg/extract.pl:
1909           Enable building the PWG examples.
1910         * docs/pwg/advanced-interfaces.xml:
1911           Add URI interface stub.
1912         * docs/pwg/advanced-types.xml:
1913         * docs/pwg/other-autoplugger.xml:
1914         * docs/pwg/appendix-porting.xml:
1915         * docs/pwg/pwg.xml:
1916           Add porting guide (mostly stubs), remove autoplugging (see ADM).
1917         * docs/pwg/building-boiler.xml:
1918         * docs/pwg/building-chainfn.xml:
1919         * docs/pwg/building-pads.xml:
1920         * docs/pwg/building-props.xml:
1921         * docs/pwg/building-state.xml:
1922         * docs/pwg/building-testapp.xml:
1923           Update the building-*.xml parts for 0.9 changes. All examples
1924           code blocks compile in examples/pwg/*.
1925
1926 2005-06-30  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1927
1928         * docs/manual/advanced-autoplugging.xml:
1929         * docs/manual/appendix-checklist.xml:
1930         * docs/manual/appendix-integration.xml:
1931         * docs/manual/highlevel-components.xml:
1932           Fix playbin/decodebin examples, update docs a bit, mention bus
1933           instead of signals in various places, mention kmplayer and
1934           kaffeine since they have a working GStreamer backend in the KDE
1935           section.
1936
1937 2005-06-30  Wim Taymans  <wim@fluendo.com>
1938
1939         * CHANGES-0.9:
1940         * docs/design/draft-ghostpads.txt:
1941         * docs/design/draft-push-pull.txt:
1942         * docs/design/draft-query.txt:
1943         * docs/design/part-TODO.txt:
1944         * docs/design/part-query.txt:
1945         Added CHANGES-0.9 doc, updated status of other docs.
1946         
1947         * gst/gstquery.h:
1948         Remove "hmm" macro
1949
1950 2005-06-30  Wim Taymans  <wim@fluendo.com>
1951
1952         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
1953         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_object),
1954         (gst_base_sink_change_state):
1955         * gst/base/gstbasesink.h:
1956         Some tweaks, only EOS and a buffer complete a preroll.
1957
1958 2005-06-30  Andy Wingo  <wingo@pobox.com>
1959
1960         * gst/gstghostpad.c (gst_ghost_pad_do_activate_push): Proxy
1961         activate_push down to the internal pad as well.
1962
1963 2005-06-30  Torsten Schoenfeld  <kaffeetisch@gmx.de>
1964
1965         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1966
1967         * gst/gsttaginterface.c:
1968           Some documentation fixes (#307394 and #307397).
1969
1970 2005-06-30  Antoine Tremblay  <hexa00@gmail.com>
1971
1972         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1973
1974         * gst/gstvalue.c: (gst_value_intersect_list):
1975           Fix memleak (#309125).
1976
1977 2005-06-30  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1978
1979         * docs/manual/advanced-dataaccess.xml:
1980           Fix fakesrc example to compile; doesn't work, bug somewhere...?
1981         * docs/manual/basics-pads.xml:
1982           Add reference for filtered caps to above chapter.
1983
1984 2005-06-30  Wim Taymans  <wim@fluendo.com>
1985
1986         * gst/gstbin.c: (clear_queue), (remove_all_from_queue),
1987         (gst_bin_change_state):
1988         Probes are gone.
1989         Lame attempt at making the state change function a bit
1990         more readable.
1991
1992 2005-06-30  Wim Taymans  <wim@fluendo.com>
1993
1994         * docs/design/part-clocks.txt:
1995         * docs/design/part-element-sink.txt:
1996         * docs/design/part-events.txt:
1997         * docs/design/part-preroll.txt:
1998         * docs/design/part-states.txt:
1999         Some more tweeks and additions to the docs.
2000
2001 2005-06-30  Wim Taymans  <wim@fluendo.com>
2002
2003         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
2004         (default_have_data), (gst_pad_class_init), (gst_pad_init),
2005         (gst_pad_emit_have_data_signal), (gst_pad_chain), (gst_pad_push),
2006         (gst_pad_check_pull_range), (gst_pad_get_range),
2007         (gst_pad_pull_range), (gst_pad_push_event), (gst_pad_send_event):
2008         * gst/gstpad.h:
2009         * gst/gstutils.c: (gst_atomic_int_set), (gst_pad_add_data_probe),
2010         (gst_pad_add_event_probe), (gst_pad_add_buffer_probe),
2011         (gst_pad_remove_data_probe), (gst_pad_remove_event_probe),
2012         (gst_pad_remove_buffer_probe):
2013         Removed atomic operations, use existing LOCK.
2014         Move exception handling out of main code path.
2015
2016 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2017
2018         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
2019         (silly_return_true_function), (gst_pad_class_init),
2020         (gst_pad_emit_have_data_signal), (gst_pad_chain), (gst_pad_push),
2021         (gst_pad_get_range), (gst_pad_pull_range), (gst_pad_push_event),
2022         (gst_pad_send_event):
2023           Fix accumulator, add default value by using _emitv() instead
2024           of _emit() for signal emission.
2025
2026 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2027
2028         * docs/manual/advanced-dataaccess.xml:
2029         * examples/manual/Makefile.am:
2030           Add probe example.
2031         * gst/gstpad.c: (_gst_do_pass_data_accumulator):
2032           Make work (??).
2033
2034 2005-06-29  Tim-Philipp Müller  <tim at centricular dot net>
2035
2036         * gst/elements/gstfilesink.c: (gst_filesink_render):
2037           Simplify code so that we don't have to handle short
2038           writes and return GST_FLOW_ERROR if an error occured.
2039
2040 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2041
2042         * docs/gst/gstreamer-docs.sgml:
2043           Remove probes more.
2044
2045 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2046
2047         * docs/gst/gstreamer-sections.txt:
2048         * docs/gst/tmpl/gstpad.sgml:
2049         * docs/gst/tmpl/gstprobe.sgml:
2050         * gst/Makefile.am:
2051         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
2052         (gst_pad_class_init), (gst_pad_init), (gst_pad_chain),
2053         (gst_pad_push), (gst_pad_get_range), (gst_pad_pull_range),
2054         (gst_pad_push_event), (gst_pad_send_event):
2055         * gst/gstpad.h:
2056         * gst/gstutils.c: (gst_pad_add_data_probe),
2057         (gst_pad_add_event_probe), (gst_pad_add_buffer_probe),
2058         (gst_pad_remove_data_probe), (gst_pad_remove_event_probe),
2059         (gst_pad_remove_buffer_probe):
2060         * gst/gstutils.h:
2061           Remove old probes, add new g-signal-based probes and some utility
2062           functions.
2063
2064 2005-06-29  Edward Hervey  <edward@fluendo.com>
2065
2066         * gst/gstelementfactory.c:
2067         * gst/gstutils.h:
2068         * gst/gstutils.c:
2069         Moved gst_element_factory_can_[sink|src]_caps() to gstutils and added
2070         the definition to the header file.
2071
2072 2005-06-29  Andy Wingo  <wingo@pobox.com>
2073
2074         * docs/gst/Makefile.am (scan-build.stamp): Totally only check
2075         plugins from the source directory.
2076
2077 2005-06-29  Wim Taymans  <wim@fluendo.com>
2078
2079         * docs/gst/tmpl/gstbuffer.sgml:
2080         * docs/gst/tmpl/gstclock.sgml:
2081         Some fixings for blantently wrong text.
2082
2083 2005-06-29  Thomas Vander Stichele  <thomas at apestaart dot org>
2084
2085         * check/Makefile.am:
2086         * gst/gst.c: (add_path_func), (init_pre):
2087         * gst/gstregistry.c: (gst_registry_add_path):
2088           add A GST_PLUGIN_PATH_ONLY env var; if it is set, it will
2089           only scan the GST_PLUGIN_PATH locations, and not add
2090           system locations
2091
2092 2005-06-29  Thomas Vander Stichele  <thomas at apestaart dot org>
2093
2094         * docs/gst/gstreamer-sections.txt:
2095         * docs/gst/tmpl/gstbasesrc.sgml:
2096         * gst/gstelement.c:
2097         * gst/gstelement.h:
2098         * gst/gstevent.c:
2099         * gst/gstutils.c:
2100           doc fixes
2101
2102 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2103
2104         * docs/manual/advanced-autoplugging.xml:
2105           Fix autoplugging example.
2106
2107 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2108
2109         * docs/manual/advanced-autoplugging.xml:
2110         * docs/manual/mime-world.fig:
2111           Try to get autoplugging working, fix type detection. Fix text
2112           in hello-world image.
2113
2114 2005-06-29  Wim Taymans  <wim@fluendo.com>
2115
2116         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
2117         (gst_base_sink_change_state):
2118         Small debug line.
2119
2120         * gst/gstclock.h:
2121         map SIGNAL and BROADCAST to the right function.
2122
2123         * gst/gstobject.h:
2124         Remove redundant braces.
2125
2126         * gst/gstpad.c: (gst_pad_set_caps):
2127         Don't call setcaps function when reseting caps to NULL.
2128
2129         * gst/gstsystemclock.c: (gst_system_clock_dispose),
2130         (gst_system_clock_async_thread), (gst_system_clock_id_wait_async),
2131         (gst_system_clock_id_unschedule):
2132         Use BROADCAST as this is what we do.
2133
2134 2005-06-29  Wim Taymans  <wim@fluendo.com>
2135
2136         * gst/base/gstbasesink.c: (gst_base_sink_handle_object):
2137         We are actually prerolling before commiting the state
2138         change. 
2139
2140 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2141
2142         * docs/manual/advanced-clocks.xml:
2143         * docs/manual/advanced-interfaces.xml:
2144         * docs/manual/advanced-metadata.xml:
2145         * docs/manual/advanced-position.xml:
2146         * docs/manual/advanced-schedulers.xml:
2147         * docs/manual/advanced-threads.xml:
2148         * docs/manual/appendix-porting.xml:
2149         * docs/manual/basics-bins.xml:
2150         * docs/manual/basics-bus.xml:
2151         * docs/manual/basics-elements.xml:
2152         * docs/manual/basics-helloworld.xml:
2153         * docs/manual/basics-pads.xml:
2154         * docs/manual/highlevel-components.xml:
2155         * docs/manual/manual.xml:
2156         * docs/manual/thread.fig:
2157           Update (until threads/scheduling) Application Development Manual;
2158           remove GstThread, add GstBus, add simple porting checklist, add
2159           documentation for tag writing, clocks, make all examples until this
2160           part compile and run.
2161         * examples/manual/Makefile.am:
2162           Update from changes to Application Development Manual; add bus
2163           example, remove thread example.
2164
2165 2005-06-28  Wim Taymans  <wim@fluendo.com>
2166
2167         * gst/gstbus.c: (gst_bus_post), (gst_bus_have_pending),
2168         (gst_bus_set_flushing), (gst_bus_pop), (gst_bus_peek),
2169         (gst_bus_source_dispatch):
2170         Add debugging messages.
2171         Make internal methods static.
2172         Handle the case where the bus is flushed in the handler.
2173         
2174         * gst/gstelement.c: (gst_element_get_bus):
2175         Fix refcount in _get_bus();
2176
2177         * gst/gstpipeline.c: (gst_pipeline_change_state),
2178         (gst_pipeline_get_clock_func):
2179         Clock refcounting fixes.
2180         Handle the case where preroll timed out more gracefully.
2181         
2182         * gst/gstsystemclock.c: (gst_system_clock_dispose):
2183         Clean up the internal thread in dispose. This is needed
2184         for subclasses that actually get disposed.
2185         
2186         * gst/schedulers/threadscheduler.c:
2187         (gst_thread_scheduler_class_init), (gst_thread_scheduler_func),
2188         (gst_thread_scheduler_dispose):
2189         Free thread pool in dispose.
2190
2191 2005-06-28  Andy Wingo  <wingo@pobox.com>
2192
2193         * tests/network-clock-utils.scm (debug, print-event): New utils.
2194
2195         * tests/network-clock.scm (*debug*, *with-graph*): New parameters.
2196         (*packet-loss*): Unified loss probability.
2197         (network-time): Report out-of-band events.
2198
2199         * tests/plot-data: Add support for out-of-band events. Hack it
2200         into this script instead of passing it down the pipe; should fix
2201         this later.
2202
2203 2005-06-28  Wim Taymans  <wim@fluendo.com>
2204
2205         * docs/gst/gstreamer.types:
2206         * docs/gst/tmpl/gstbasesrc.sgml:
2207         * docs/gst/tmpl/gstpad.sgml:
2208         Docs fixes.
2209
2210 2005-06-28  Wim Taymans  <wim@fluendo.com>
2211
2212         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
2213         (gst_proxy_pad_do_checkgetrange), (gst_proxy_pad_do_acceptcaps),
2214         (gst_proxy_pad_do_fixatecaps):
2215         Correctly proxy the check_pull_range function.
2216
2217 2005-06-28  Andy Wingo  <wingo@pobox.com>
2218
2219         * tests/network-clock.scm: Removed need for slib.
2220         
2221 2005-06-28  Wim Taymans  <wim@fluendo.com>
2222
2223         * gst/base/gstbasesink.c: (gst_basesink_set_pad_functions),
2224         (gst_basesink_preroll_queue_flush):
2225         * gst/base/gstbasesrc.c: (gst_basesrc_set_dataflow_funcs):
2226         * gst/elements/gsttee.c: (gst_tee_update_pad_functions):
2227         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
2228         (gst_proxy_pad_do_acceptcaps), (gst_proxy_pad_do_fixatecaps),
2229         (gst_proxy_pad_set_property):
2230         * gst/gstpad.c:
2231         * gst/gstpad.h:
2232         * gst/gstqueue.c: (gst_queue_init):
2233         The deprecated pad loop function is removed now.
2234
2235 2005-06-28  Andy Wingo  <wingo@pobox.com>
2236
2237         * tests/network-clock.scm (*timeout*, *send-loss*, *recv-loss*):
2238         New parameters, simulate network packet loss.
2239
2240         * tests/network-clock-utils.scm: Initialize the RNG.
2241
2242 2005-06-28  Wim Taymans  <wim@fluendo.com>
2243
2244         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_flush),
2245         (gst_basesink_event), (gst_basesink_deactivate):
2246         Flushing the preroll queue always needs to unlock the waiters.
2247
2248 2005-06-28  Edward Hervey  <edward@fluendo.com>
2249
2250         * gst/gstpipeline.c: (gst_pipeline_send_event): 
2251         Wheen a seek was successful on a pipeline, set the stream_time to the
2252         seek offset in order to have a synchronized stream_time.
2253
2254 2005-06-28  Wim Taymans  <wim@fluendo.com>
2255
2256         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
2257         (gst_proxy_pad_do_getrange), (gst_proxy_pad_do_checkgetrange),
2258         (gst_proxy_pad_do_getcaps), (gst_proxy_pad_do_acceptcaps),
2259         (gst_proxy_pad_do_fixatecaps):
2260         Call wrapper function instead of just calling the function
2261         pointers. This takes care of any locking and whatmore.
2262
2263 2005-06-28  Wim Taymans  <wim@fluendo.com>
2264
2265         * gst/gstpad.c: (gst_pad_alloc_buffer), (gst_pad_push),
2266         (gst_pad_pull_range):
2267         * gst/gstpad.h:
2268         CONNECTED -> LINKED.
2269
2270 2005-06-28  Andy Wingo  <wingo@pobox.com>
2271
2272         * *.c: Don't cast to GST_OBJECT when reffing or unreffing. Large
2273         source-munging commit!!!
2274
2275         * gst/gstobject.c (gst_object_unref, gst_object_ref) 
2276         (gst_object_sink): Take gpointer arguments, not GstObject --
2277         avoids casts. Like GLib.
2278
2279         * gst/gstghostpad.c (gst_proxy_pad_do_activate): Don't proxy
2280         activate.
2281
2282 2005-06-27  Andy Wingo  <wingo@pobox.com>
2283
2284         * gst/base/gsttypefindhelper.c (gst_type_find_helper): Unref any
2285         remaining buffer.
2286
2287         * gst/gsttrace.c (gst_alloc_trace_list_sorted): New helper,
2288         returns a sorted copy of the trace list.
2289         (gst_alloc_trace_print_live): New API, only prints traces with
2290         live objects. Sort the list.
2291         (gst_alloc_trace_print_all): Sort the list.
2292         (gst_alloc_trace_print): Align columns.
2293
2294         * gst/elements/gstttypefindelement.c:
2295         * gst/elements/gsttee.c:
2296         * gst/base/gstbasesrc.c:
2297         * gst/base/gstbasesink.c:
2298         * gst/base/gstbasetransform.c:
2299         * gst/gstqueue.c: Adapt for pad activation changes.
2300
2301         * gst/gstpipeline.c (gst_pipeline_init): Unref after parenting
2302         sched.
2303         (gst_pipeline_dispose): Drop ref on sched.
2304
2305         * gst/gstpad.c (gst_pad_init): Set the default activate func.
2306         (gst_pad_activate_default): Push mode by default.
2307         (pre_activate_switch, post_activate_switch): New stubs, things to
2308         do before and after switching activation modes on pads.
2309         (gst_pad_set_active): Take a boolean and not a mode, dispatch to
2310         the pad's activate function to choose which mode to activate.
2311         Shortcut on deactivation and call the right function directly.
2312         (gst_pad_activate_pull): New API, (de)activates a pad in pull
2313         mode.
2314         (gst_pad_activate_push): New API, same for push mode.
2315         (gst_pad_set_activate_function) 
2316         (gst_pad_set_activatepull_function) 
2317         (gst_pad_set_activatepush_function): Setters for new API.
2318
2319         * gst/gstminiobject.c (gst_mini_object_new, gst_mini_object_free):
2320         Trace all miniobjects.
2321         (gst_mini_object_make_writable): Unref the arg if we copy, like
2322         gst_caps_make_writable.
2323
2324         * gst/gstmessage.c (_gst_message_initialize): No trace init.
2325
2326         * gst/gstghostpad.c (gst_proxy_pad_do_activate) 
2327         (gst_proxy_pad_do_activatepull, gst_proxy_pad_do_activatepush):
2328         Adapt for new pad API.
2329
2330         * gst/gstevent.c (_gst_event_initialize): Don't initialize trace.
2331
2332         * gst/gstelement.h:
2333         * gst/gstelement.c (gst_element_iterate_src_pads) 
2334         (gst_element_iterate_sink_pads): New API functions.
2335         
2336         * gst/gstelement.c (iterator_fold_with_resync): New utility,
2337         should fold into gstiterator.c in some form.
2338         (gst_element_pads_activate): Simplified via use of fold and
2339         delegation of decisions to gstpad->activate.
2340
2341         * gst/gstbus.c (gst_bus_source_finalize): Set the bus to NULL,
2342         help in debugging.
2343
2344         * gst/gstbuffer.c (_gst_buffer_initialize): Ref the buffer type
2345         class once in init, like gstmessage. Didn't run into this issue
2346         but it seems correct. Don't initialize a trace, gstminiobject does
2347         that.
2348
2349         * check/pipelines/simple_launch_lines.c (test_stop_from_app): New
2350         test, runs fakesrc ! fakesink, stopping on ::handoff via a message
2351         to the bus.
2352         (assert_live_count): New util function, uses alloc traces to check
2353         cleanup.
2354
2355         * check/gst/gstghostpad.c (test_ghost_pads): More refcount checks.
2356         To be modified when unlink drops the internal pad.
2357
2358 2005-06-27  Wim Taymans  <wim@fluendo.com>
2359
2360         * gst/gstbin.c: (gst_bin_get_state), (gst_bin_iterate_state_order),
2361         (gst_bin_change_state):
2362         Cleanup the get_state() function a little, make sure it
2363         iterates the same set of elements.
2364         Added stub iterate_state_order().
2365
2366 2005-06-27  Thomas Vander Stichele  <thomas at apestaart dot org>
2367
2368         * docs/gst/gstreamer-docs.sgml:
2369         * docs/gst/gstreamer-sections.txt:
2370         * docs/gst/gstreamer.types:
2371         * docs/gst/tmpl/gstbasesink.sgml:
2372         * docs/gst/tmpl/gstbasesrc.sgml:
2373         * docs/gst/tmpl/gstbasetransform.sgml:
2374         * docs/gst/tmpl/gstelement.sgml:
2375         * docs/gst/tmpl/gstiterator.sgml:
2376         * gst/base/gstbasesrc.c:
2377         * gst/base/gstbasesrc.h:
2378         * gst/base/gstbasetransform.h:
2379         * gst/gstelement.c:
2380         * gst/gstiterator.h:
2381           adding basetransform and iterator docs
2382
2383 2005-06-27  Andy Wingo  <wingo@pobox.com>
2384
2385         * docs/design/part-activation.txt: Notes on how activation should
2386         work -- not quite implemented yet.
2387
2388 2005-06-25  Wim Taymans  <wim@fluendo.com>
2389
2390         * gst/gstghostpad.c: (gst_proxy_pad_do_chain):
2391         At least get the chain function correct, needs more
2392         fixing.
2393
2394 2005-06-25  Wim Taymans  <wim@fluendo.com>
2395
2396         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
2397         (gst_basesink_handle_object), (gst_basesink_event),
2398         (gst_basesink_do_sync), (gst_basesink_handle_event),
2399         (gst_basesink_change_state):
2400         * gst/gsttask.h:
2401         Right, two problems here: ghostpads don't take locks and
2402         glib _rec_mutex_lock_full() with depth==0 still locks.
2403         Catch illegal locking and g_warn them.
2404
2405 2005-06-25  Wim Taymans  <wim@fluendo.com>
2406
2407         * check/states/sinks.c: (START_TEST), (gst_object_suite):
2408         Have to check for completion now...
2409
2410 2005-06-25  Wim Taymans  <wim@fluendo.com>
2411
2412         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
2413         (gst_basesink_handle_object), (gst_basesink_event),
2414         (gst_basesink_do_sync), (gst_basesink_handle_event),
2415         (gst_basesink_change_state):
2416         * gst/gstpad.h:
2417         Unlock STREAM_LOCK whatever the recursion was.
2418
2419 2005-06-25  Wim Taymans  <wim@fluendo.com>
2420
2421         * gst/base/gstbasesink.c: (gst_basesink_set_property),
2422         (gst_basesink_preroll_queue_empty),
2423         (gst_basesink_preroll_queue_flush), (gst_basesink_handle_object),
2424         (gst_basesink_event), (gst_basesink_do_sync),
2425         (gst_basesink_handle_event), (gst_basesink_handle_buffer),
2426         (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate),
2427         (gst_basesink_change_state):
2428         Reworked the base sink, handle event and buffer serialisation
2429         correctly and removed possible deadlock.
2430         Handle EOS correctly.
2431
2432 2005-06-25  Wim Taymans  <wim@fluendo.com>
2433
2434         * gst/gstpipeline.c: (is_eos), (pipeline_bus_handler),
2435         (gst_pipeline_change_state):
2436         * tools/gst-launch.c: (check_intr), (event_loop), (main):
2437         Allow elements to post EOS in the state change function.
2438         Fix up -launch, make it exit the poll loop when the
2439         pipeline actually changed state.
2440         Fix up warning parsing in -launch.
2441
2442 2005-06-25  Wim Taymans  <wim@fluendo.com>
2443
2444         * gst/elements/gsttee.c: (gst_tee_chain), (gst_tee_loop),
2445         (gst_tee_sink_activate):
2446         Core takes STREAM_LOCK for us now.
2447
2448 2005-06-25  Wim Taymans  <wim@fluendo.com>
2449
2450         * gst/gstelement.c: (gst_element_get_state_func),
2451         (gst_element_set_state):
2452         * gst/gstelement.h:
2453         * gst/gstmessage.c: (gst_message_parse_error),
2454         (gst_message_parse_warning):
2455         Keep track of current target state while performing a state
2456         change so that subclasses can do something interesting.
2457         Fix parsing of warning/error messages when GError is NULL.
2458
2459 2005-06-24  Thomas Vander Stichele  <thomas at apestaart dot org>
2460
2461         * docs/gst/Makefile.am:
2462         * docs/gst/gstreamer-docs.sgml:
2463         * docs/gst/gstreamer-sections.txt:
2464         * docs/gst/gstreamer.types:
2465         * docs/gst/tmpl/gstbasesink.sgml:
2466         * docs/gst/tmpl/gstbasesrc.sgml:
2467         * docs/gst/tmpl/gstbin.sgml:
2468         * docs/gst/tmpl/gstcompat.sgml:
2469         * docs/gst/tmpl/gstfakesink.sgml:
2470         * docs/gst/tmpl/gstfakesrc.sgml:
2471         * docs/gst/tmpl/gstfilesink.sgml:
2472         * docs/gst/tmpl/gstfilesrc.sgml:
2473         * docs/gst/tmpl/gstindex.sgml:
2474         * docs/manual/appendix-quotes.xml:
2475         * gst/base/gstbasesrc.h:
2476         * gst/elements/gstfakesrc.h:
2477         * gst/gstmessage.h:
2478           start pulling in base classes and elements in our docs
2479
2480 2005-06-24  Stefan Kost  <ensonic@users.sf.net>
2481
2482         * docs/gst/Makefile.am:
2483         * docs/libs/Makefile.am:
2484           fixed make distcheck with gtk-doc 1.3
2485
2486 2005-06-23  Wim Taymans  <wim@fluendo.com>
2487
2488         * gst/gstelement.c: (gst_element_get_state_func),
2489         (gst_element_set_state), (gst_element_change_state):
2490         When the state did not change, also report NO_PREROLL
2491         when it matters.
2492
2493 2005-06-23  Wim Taymans  <wim@fluendo.com>
2494
2495         * gst/gstpad.c: (gst_pad_event_default):
2496         * gst/gstqueue.c: (gst_queue_loop):
2497         No unsafe task pausing please.
2498
2499 2005-06-23  Wim Taymans  <wim@fluendo.com>
2500
2501         * gst/schedulers/threadscheduler.c:
2502         (gst_thread_scheduler_task_start),
2503         (gst_thread_scheduler_task_pause), (gst_thread_scheduler_func):
2504         Ref the task before pushing it on the threadpool. This
2505         makes sure that we have a ref when the threadfunction is
2506         actually called.
2507
2508 2005-06-23  Andy Wingo  <wingo@pobox.com>
2509
2510         * gst/base/gstbasesrc.c (gst_basesrc_get_range): Check if the
2511         offset is greater than the file's size.
2512
2513         * gst/gstobject.h (GST_CLASS_LOCK, GST_CLASS_TRYLOCK) 
2514         (GST_CLASS_UNLOCK, GST_CLASS_GET_LOCK, GstObjectClass)
2515         * gst/gstobject.c (gst_object_class_init): Make the class lock
2516         recursive. Wim won't let me drop deep_notify. Decodebin works
2517         again, whoopdy doo.
2518
2519         * gst/gstghostpad.c (on_int_notify): Catches notify::caps on the
2520         internal pad, and hacks accordingly. Doesn't do it on the target
2521         pad because we change its caps. Probably catches all cases of
2522         interest tho.
2523         (gst_ghost_pad_set_property): Connect to notify::caps as
2524         appropritate.
2525
2526         * tests/network-clock.scm (plot-simulation): Pipe data to the
2527         elite python skript.
2528
2529         * tests/network-clock-utils.scm (define-parameter): New macro,
2530         defines a parameter that can be set via the command line.
2531         (set-parameter!, parse-parameter-arguments): Command line args
2532         parser.
2533
2534         * tests/plot-data: Simple matplotlib-based plotter, takes input on
2535         stdin.
2536
2537 2005-06-23  Jan Schmidt  <thaytan@mad.scientist.com>
2538
2539         * gst/elements/gsttypefindelement.c:
2540         (gst_type_find_element_handle_event):
2541           Don't restart typefinding on a discont.
2542         * gst/gstelement.c: (gst_element_set_state):
2543           Debug spelling fix.
2544         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_send_event):
2545           Allow changing mode of an active pad.
2546           Debug output fixes.
2547         * gst/registries/gstlibxmlregistry.c: (load_feature):
2548           Don't cast a static pad template to a normal pad template.
2549
2550 2005-06-23  Thomas Vander Stichele  <thomas at apestaart dot org>
2551
2552         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
2553         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
2554           remove gst_strtoll completely, since it didn't actually do
2555           anything more than what g_ascii_strtoull already does.
2556           check for range errors when deserializing
2557           do a cast for the unsigned cases; but further fixing needs
2558           a decision on what the interpretation of "(int)" and
2559           deserialization should be for values that fall outside the
2560           type's boundaries (ie, refuse, or interpret as casting)
2561
2562 2005-06-23  Wim Taymans  <wim@fluendo.com>
2563
2564         * check/Makefile.am:
2565         * check/states/sinks.c: (START_TEST), (gst_object_suite), (main):
2566         * docs/design/part-live-source.txt:
2567         * docs/design/part-states.txt:
2568         * gst/base/gstbasesrc.c: (gst_basesrc_init),
2569         (gst_basesrc_set_live), (gst_basesrc_is_live),
2570         (gst_basesrc_get_range), (gst_basesrc_activate),
2571         (gst_basesrc_change_state):
2572         * gst/base/gstbasesrc.h:
2573         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
2574         (gst_fakesrc_set_property), (gst_fakesrc_get_property):
2575         * gst/gstbin.c: (gst_bin_get_state), (gst_bin_change_state):
2576         * gst/gstelement.c: (gst_element_get_state_func),
2577         (gst_element_set_state):
2578         * gst/gstelement.h:
2579         * gst/gsttypes.h:
2580         * tools/gst-launch.c: (event_loop), (main):
2581         Added support for live sources and other elements that
2582         cannot do preroll.
2583         Updated design docs, added live-source design doc.
2584         Implemented live source functionality in basesrc
2585         Fix error condition in _bin_get_state()
2586         Implement live source handling in -launch.
2587         Added check for live sources.
2588         Fixed case in GstBin where elements were changed state
2589         multiple times.
2590
2591
2592 2005-06-23  Andy Wingo  <wingo@pobox.com>
2593
2594         * check/gst/gstpad.c (test_get_allowed_caps, test_refcount): Fix
2595         borken refcounting.
2596
2597         * gst/gstpad.c (gst_pad_set_caps): Remove needless refs,
2598         gst_caps_replace takes care of this for us.
2599
2600         * gst/gstghostpad.c (gst_proxy_pad_do_setcaps): Call the full
2601         gst_pad_set_caps on the target, not just its setcaps() function.
2602
2603         * tests/network-clock.scm: 
2604         * tests/network-clock-utils.scm: A network clock simulator.
2605         Something of an algorithmic testbed before doing something in C.
2606
2607 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
2608
2609         * check/Makefile.am:
2610         * check/gst/capslist.h:
2611           copy over from 0.8, and add two with bitmasks specified with
2612           (int) 0xFF...
2613         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite):
2614           add test to parse everything from capslist.h
2615         * check/gst/gststructure.c: (START_TEST), (gst_value_suite),
2616         (main):
2617           add test for structure deserialization
2618         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
2619           add tests for deserialization of strings to int types
2620         * gst/gststructure.c: (gst_structure_nth_field_name):
2621         * gst/gststructure.h:
2622           add a way to get the name of a field referenced by index
2623         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
2624           instead of checking if the resulting long long lies between
2625           min and max, we check if the long long would fit into
2626           a number of bytes for the final type.
2627           This fixes cases where a string represents 2^32 - 1, which
2628           when cast to int would be the (valid) -1, but is bigger than
2629           G_MAXINT
2630
2631 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
2632
2633         * gst/parse/grammar.y:
2634           add a log line for type deserialization
2635
2636 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
2637
2638         * check/gst/gstvalue.c: (START_TEST):
2639         * gst/gstvalue.c: (gst_value_deserialize):
2640           return long long, not int, so gint64 deserialization actually
2641           works.  Is there any flag that makes the compiler check this ?
2642           Fixes #308559
2643
2644 2005-06-22  Wim Taymans  <wim@fluendo.com>
2645
2646         * gst/gstbuffer.h:
2647         Added convenience macros for setting buffers in GValue.
2648
2649 2005-06-21  Thomas Vander Stichele  <thomas at apestaart dot org>
2650
2651         * check/gst/.cvsignore:
2652         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
2653           add a test deserializing int64, and comment part out because
2654           it fails, yay !
2655
2656 2005-06-21  Thomas Vander Stichele  <thomas at apestaart dot org>
2657
2658         * check/Makefile.am:
2659         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite), (main):
2660         * testsuite/Makefile.am:
2661         * testsuite/caps/Makefile.am:
2662         * testsuite/caps/value_serialize.c:
2663         * testsuite/test_gst_init.c:
2664           move a value_serialize test over
2665
2666 2005-06-20  Wim Taymans  <wim@fluendo.com>
2667
2668         * gst/gstpad.c:
2669         Small doc updates.
2670         
2671         * gst/gstvalue.c: (gst_value_compare_buffer),
2672         (gst_value_serialize_buffer), (gst_value_deserialize_buffer),
2673         (gst_value_compare_flags), (gst_value_serialize_flags),
2674         (gst_value_deserialize_flags), (_gst_value_initialize):
2675         Fix serialisation of buffers, they are not boxed types anymore
2676
2677 2005-06-20  Wim Taymans  <wim@fluendo.com>
2678
2679         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite):
2680         Testcase to show error in buffer-on-caps serialisation.
2681
2682 2005-06-20  Andy Wingo  <wingo@pobox.com>
2683
2684         * docs/random/wingo/porting-plugins-to-0.9: A pitiful document I
2685         will be adding to later.
2686
2687         * gst/gstsystemclock.c (gst_system_clock_init): Unlock the clock
2688         if its socks fill with rocks.
2689         (gst_system_clock_obtain): Set the name on object construction.
2690         Avoid double-checked locking.
2691
2692 2005-06-20  Tim-Philipp Müller  <tim at centricular dot net>
2693
2694         * gst/gsturi.c: (gst_element_make_from_uri):
2695           Fix potential endless loop.
2696
2697 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
2698
2699         * check/Makefile.am:
2700           add gsttag
2701         * check/gst/gsttag.c: (check_tags), (START_TEST), (gst_tag_suite),
2702         (main):
2703           move over from testsuite dir and clean up
2704         * configure.ac:
2705         * gst/gsttag.c:
2706         * testsuite/Makefile.am:
2707         * testsuite/tags/.cvsignore:
2708         * testsuite/tags/Makefile.am:
2709         * testsuite/tags/merge.c:
2710           remove testsuite/tags
2711
2712 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
2713
2714         * docs/gst/gstreamer-sections.txt:
2715         * docs/gst/tmpl/gstenumtypes.sgml:
2716         * win32/gstenumtypes.c:
2717           clean up documentation build a little
2718
2719 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
2720
2721         * check/gstcheck.h:
2722           add macros for checking refcounts on objects and caps
2723         * check/gst/gstpad.c: (START_TEST), (gst_pad_suite):
2724           add some more unit tests
2725         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked),
2726         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_get_allowed_caps):
2727           fix leaked refcounts (I hope :)) so unittest works
2728         * gst/gstpad.h:
2729           whitespace removal
2730
2731 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
2732
2733         * configure.ac: back to HEAD
2734
2735 === release 0.9.1 ===
2736
2737 2005-06-17  Thomas Vander Stichele  <thomas at apestaart dot org>
2738
2739         * NEWS:
2740         * RELEASE:
2741           updated
2742
2743 2005-06-17  Andy Wingo  <wingo@pobox.com>
2744
2745         * gst/base/gstbasesink.c (gst_basesink_chain): Remove bogus
2746         assert; it's always possible that the pad gets deactivated in
2747         between the checks in gstpad.c and the implementation. Rely on
2748         finish_preroll() to return a FLUSHING or similar instead of on the
2749         assert.
2750         
2751         * gst/base/gstbasesink.c (gst_basesink_event): Only wait for the
2752         clock and post an EOS message if we come out of finish_preroll in
2753         the playing state.
2754
2755 2005-06-16  David Schleef  <ds@schleef.org>
2756
2757         * gst/elements/gstcapsfilter.c: (gst_capsfilter_class_init),
2758         (gst_capsfilter_set_property): Allow NULL as possible value
2759         for filter_caps property, indicating GST_CAPS_ANY.
2760
2761 2005-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
2762
2763         * gst/elements/gstfakesrc.c: (gst_fakesrc_create):
2764           fix debug output
2765         * gst/schedulers/Makefile.am:
2766           use libgst prefix
2767         * gstreamer.spec.in:
2768           fix spec for it
2769
2770 2005-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
2771
2772         * gstreamer.spec.in:
2773           clean up
2774
2775 2005-06-08  Andy Wingo  <wingo@pobox.com>
2776
2777         * gst/gstutils.c: RPAD fixes all around.
2778         (gst_element_link_pads): Refcounting fixes.
2779
2780         * tools/gst-inspect.c:
2781         * tools/gst-xmlinspect.c:
2782         * parse/grammar.y:
2783         * gst/base/gsttypefindhelper.c:
2784         * gst/base/gstbasesink.c:
2785         * gst/gstqueue.c: RPAD fixes.
2786
2787         * gst/gstghostpad.h:
2788         * gst/gstghostpad.c: New ghost pad implementation as full proxy
2789         pads. The tricky thing is they provide both source and sink
2790         interfaces, since they proxy the internal pad for the external
2791         pad, and vice versa. Implement with lower-level ProxyPad objects,
2792         with the interior proxy pad as a child of the exterior ghost pad.
2793         Should write a doc on this.
2794         
2795         * gst/gstpad.h: s/RPAD/PAD/, s/RealPad/Pad/.
2796         (gst_pad_set_name, gst_pad_set_parent): Macros removed, use
2797         gst_object API.
2798         
2799         * gst/gstpad.c: Big changes. No more stub base GstPad, now all
2800         pads are real pads. No ghost pads in this file. Not documenting
2801         the myriad s/RPAD/PAD/ and REALIZE fixes.
2802         (gst_pad_class_init): Add properties for "direction" and
2803         "template". Both are construct-only, so they can't change during
2804         the life of the pad. Fixes properly deriving from GstPad.
2805         (gst_pad_custom_new, gst_pad_custom_new_from_template): Gone. For
2806         derived objects, just set properties when creating the objects via
2807         g_object_new.
2808         (gst_pad_get_parent): Implement as a function, return NULL if the
2809         parent is not an element.
2810         (gst_pad_get_real_parent, gst_pad_add_ghost_pad)
2811         (gst_pad_remove_ghost_pad, gst_pad_realize): Removed.
2812         
2813         * gst/gstobject.c (gst_object_class_init): Make name a construct
2814         property. Don't set it in the object init.
2815
2816         * gst/gstelement.c (gst_element_add_pad): Don't allow adding pads
2817         with UNKNOWN direction.
2818         (gst_element_add_ghost_pad): Remove non-orthogonal API. Replace
2819         with gst_element_add_pad (e, gst_ghost_pad_new (name, pad)).
2820         (gst_element_remove_pad): Remove ghost-pad special cases.
2821         (gst_element_pads_activate): Remove rpad cruft.
2822
2823         * gst/gstbin.c (gst_bin_change_state): Use gst_pad_get_parent to
2824         catch the pad's-parent-not-an-element case.
2825
2826         * gst/gst.h: Include gstghostpad.h.
2827
2828         * gst/gst.c (init_post): No more real, ghost pads.
2829
2830         * gst/Makefile.am: Add gstghostpad.[ch].
2831
2832         * check/Makefile.am:
2833         * check/gst/gstbin.c:
2834         * check/gst/gstghostpad.c (test_ghost_pads): Check that linking
2835         into a bin creates ghost pads, and that the refcounts are right.
2836         Partly moved from gstbin.c.
2837
2838 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
2839
2840         * check/gst-libs/.cvsignore:
2841         * check/gst/.cvsignore:
2842         * check/pipelines/.cvsignore:
2843           ignore more
2844         * check/pipelines/cleanup.c: (setup_pipeline), (run_pipeline),
2845         (START_TEST), (cleanup_suite), (main):
2846           add some tests related to cleanup after running pipelines
2847
2848 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
2849
2850         * check/gst/gstbuffer.c: (START_TEST), (gst_test_suite), (main):
2851           add a testsuite for GstBuffer
2852
2853 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
2854
2855         * gst/gstminiobject.h:
2856           add defines for accessing the refcount
2857
2858 2005-06-03  Stefan Kost  <ensonic@users.sf.net>
2859
2860         * Makefile.am: added support for html unit test coverage reports
2861
2862 2005-06-03  Jan Schmidt  <thaytan@mad.scientist.com>
2863
2864         * gst/elements/gstcapsfilter.c: (gst_capsfilter_set_property):
2865           Free existing caps if the capsfilter changes. Add a FIXME about
2866           setting those caps on the pads.
2867
2868         * gst/gstutils.c: (gst_element_get_compatible_pad), (ghost_up):
2869           Before adding a ghost pad to a parent bin, check that there isn't
2870           already one for the element on the bin. Prevents infinite recursion
2871           when using decodebin in parse pipelines. Andy says he'll rewrite the
2872           way this works anyway, so ignore the hack.
2873
2874 2005-06-02  Andy Wingo  <wingo@pobox.com>
2875
2876         * gst/elements/gsttypefindelement.c (do_pull_typefind): Query the
2877         file size, pass it on to the type find helper.
2878
2879         * gst/base/gstbasesrc.c (gst_basesrc_do_seek): Set the
2880         segment_start and segment_end properly according to the seek
2881         method. Segment_end is still a bit flaky because offset can be
2882         negative for CUR and END cases, but it takes -1 as an "unset"
2883         value.
2884
2885 2005-06-02  Wim Taymans  <wim@fluendo.com>
2886
2887         * gst/base/gstbasesink.c: (gst_basesink_pad_buffer_alloc),
2888         (gst_base_sink_buffer_alloc), (gst_basesink_preroll_queue_push),
2889         (gst_basesink_activate):
2890         * gst/base/gstbasesink.h:
2891         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
2892         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_alloc_buffer),
2893         (gst_pad_query), (gst_pad_start_task):
2894         * gst/gstpad.h:
2895         * gst/gstqueue.c: (gst_queue_bufferalloc),
2896         (gst_queue_handle_sink_event), (gst_queue_chain):
2897         Bufferalloc: return GstFlowReturn to more accuratly report
2898         why allocation failed.
2899
2900 2005-06-02  Wim Taymans  <wim@fluendo.com>
2901
2902         * gst/gstpipeline.c: (gst_pipeline_send_event):
2903         Take snapshot of state without blocking.
2904
2905 2005-06-02  Wim Taymans  <wim@fluendo.com>
2906
2907         * docs/design/part-TODO.txt:
2908         * docs/design/part-caps.txt:
2909         * docs/design/part-clocks.txt:
2910         * docs/design/part-negotiation.txt:
2911         * docs/design/part-preroll.txt:
2912         Small doc updates 
2913
2914 2005-05-30  Wim Taymans  <wim@fluendo.com>
2915
2916         * gst/elements/gstidentity.c: (gst_identity_event),
2917         (gst_identity_transform), (gst_identity_get_property):
2918         Protect last_message property as it is accessed from
2919         multiple threads.
2920
2921 2005-05-30  Wim Taymans  <wim@fluendo.com>
2922
2923         * gst/gstelement.c: (gst_element_init),
2924         (gst_element_pads_activate), (gst_element_change_state):
2925         Slicker pad activation code.
2926
2927 2005-05-30  Wim Taymans  <wim@fluendo.com>
2928
2929         * gst/Makefile.am:
2930         * gst/gstelement.h:
2931         * gst/gstelementfactory.h:
2932         * gst/gsttypes.h:
2933         Move elementfactory methods to separate .h file.
2934
2935 2005-05-30  Wim Taymans  <wim@fluendo.com>
2936
2937         * docs/design/part-overview.txt:
2938         * gst/gstsystemclock.h:
2939         Small typo fixes, doc updates.
2940
2941 2005-05-30  Wim Taymans  <wim@fluendo.com>
2942
2943         * gst/gst.c: (gst_init_get_popt_table), (init_post),
2944         (init_popt_callback):
2945         Remove cpu-opt flag.
2946
2947 2005-05-30  Wim Taymans  <wim@fluendo.com>
2948
2949         * gst/gstbuffer.c: (gst_subbuffer_finalize),
2950         (gst_buffer_create_sub), (gst_buffer_is_span_fast):
2951         * gst/gstbuffer.h:
2952         Avoid typechecking in places where not needed.
2953         Added accessor for malloc_data.
2954
2955 2005-05-30  Wim Taymans  <wim@fluendo.com>
2956
2957         * gst/gstpad.c: (gst_real_pad_init), (gst_pad_set_active),
2958         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_accept_caps),
2959         (gst_pad_configure_sink), (gst_pad_configure_src),
2960         (gst_pad_alloc_buffer), (gst_pad_query), (gst_pad_send_event),
2961         (gst_pad_start_task):
2962         Propagate errors from _set_caps() in configure_src/sink
2963         functions instead of returning TRUE.
2964         FLUSH events can travel up and downstream
2965
2966
2967 2005-05-30  Wim Taymans  <wim@fluendo.com>
2968
2969         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_push),
2970         (gst_basesink_activate):
2971         Handle EOS in preroll.
2972
2973 2005-05-30  Wim Taymans  <wim@fluendo.com>
2974
2975         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
2976         (gst_queue_loop), (gst_queue_handle_src_event):
2977         Remove old pieces of code
2978         Flushing the queue in an upstream event is a very bad idea.
2979
2980 2005-05-26  Andy Wingo  <wingo@pobox.com>
2981
2982         * gst/gstminiobject.c (gst_value_mini_object_collect): Use
2983         gst_value_set_mini_object so as to add a ref on the object (which
2984         will be removed when the value is unset).
2985
2986         * gst/elements/gstfakesink.c (gst_fakesink_class_init): Fix signal
2987         arg type in ::handoff.
2988
2989         * gst/gstelement.c (gst_element_change_state): Also deactivate
2990         pads in READY->NULL, just in case the element didn't make it to
2991         PAUSED. Wingo tested, Wim approved.
2992
2993 2005-05-26  Wim Taymans  <wim@fluendo.com>
2994
2995         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
2996         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_alloc_buffer),
2997         (gst_pad_query), (gst_pad_send_event), (gst_pad_start_task):
2998         A flushing pad cannot be used to alloc_buffer from.
2999
3000 2005-05-26  Wim Taymans  <wim@fluendo.com>
3001
3002         * gst/gstbus.c: (gst_bus_init), (gst_bus_dispose), (gst_bus_post),
3003         (gst_bus_pop), (gst_bus_source_prepare), (gst_bus_source_check),
3004         (gst_bus_source_dispatch), (gst_bus_source_finalize),
3005         (gst_bus_create_watch), (gst_bus_add_watch_full):
3006         * gst/gstbus.h:
3007         Implement a real GSource and use g_main_context_wakeup() to
3008         signal new messages instead of the socketpair.
3009
3010 2005-05-25  Wim Taymans  <wim@fluendo.com>
3011
3012         * gst/gstbin.c: (bin_element_is_sink), (has_ancestor),
3013         (bin_element_is_semi_sink), (append_child), (gst_bin_change_state):
3014         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
3015         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_query),
3016         (gst_pad_send_event), (gst_pad_start_task):
3017         * gst/gstqueue.c: (gst_queue_init), (gst_queue_locked_flush),
3018         (gst_queue_handle_sink_event), (gst_queue_chain), (gst_queue_loop),
3019         (gst_queue_sink_activate), (gst_queue_src_activate),
3020         (gst_queue_change_state):
3021         * gst/gstqueue.h:
3022         Fix state changes for non sinks. We now change sinks, then elements
3023         with unconnected srcpads, then the rest.
3024         More efficient queue unlocking in flush and state changes.
3025         Set the pad activate mode even if it does not have an activate
3026         function.
3027
3028 2005-05-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3029
3030         * gst/base/gstbasesrc.c: (gst_basesrc_activate):
3031           Don't go in pull mode for non-seekable sources.
3032         * gst/elements/gsttypefindelement.h:
3033         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
3034         (gst_type_find_element_dispose), (gst_type_find_handle_src_query),
3035         (free_entry), (stop_typefinding),
3036         (gst_type_find_element_handle_event), (find_peek),
3037         (gst_type_find_element_chain), (do_pull_typefind),
3038         (gst_type_find_element_change_state):
3039           Allow typefinding (w/o seeking) in push-mode, simplified version
3040           of what was in 0.8.
3041         * gst/gstutils.c: (gst_buffer_join):
3042         * gst/gstutils.h:
3043           gst_buffer_join() from 0.8.
3044
3045 2005-05-25  Wim Taymans  <wim@fluendo.com>
3046
3047         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
3048         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_query),
3049         (gst_pad_send_event), (gst_pad_start_task):
3050         Disable attempt at mode switching until it is figured out.
3051
3052 2005-05-25  Wim Taymans  <wim@fluendo.com>
3053
3054         * gst/base/gstadapter.c: (gst_adapter_peek), (gst_adapter_flush):
3055         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_push),
3056         (gst_basesink_finish_preroll), (gst_basesink_chain),
3057         (gst_basesink_loop), (gst_basesink_activate),
3058         (gst_basesink_change_state):
3059         * gst/base/gstbasesrc.c: (gst_basesrc_do_seek),
3060         (gst_basesrc_get_range), (gst_basesrc_loop),
3061         (gst_basesrc_activate):
3062         * gst/elements/gsttee.c: (gst_tee_sink_activate):
3063         * gst/gstpad.c: (gst_pad_dispose), (gst_real_pad_class_init),
3064         (gst_real_pad_init), (gst_real_pad_set_property),
3065         (gst_real_pad_get_property), (gst_pad_set_active),
3066         (gst_pad_is_active), (gst_pad_get_query_types), (gst_pad_unlink),
3067         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_get_real_parent),
3068         (gst_real_pad_get_caps_unlocked), (gst_pad_peer_get_caps),
3069         (gst_pad_accept_caps), (gst_pad_get_peer), (gst_pad_realize),
3070         (gst_pad_event_default_dispatch), (gst_pad_event_default),
3071         (gst_pad_dispatcher), (gst_pad_query), (gst_real_pad_dispose),
3072         (gst_pad_save_thyself), (handle_pad_block), (gst_pad_chain),
3073         (gst_pad_push), (gst_pad_get_range), (gst_pad_pull_range),
3074         (gst_pad_send_event), (gst_pad_start_task), (gst_pad_pause_task),
3075         (gst_pad_stop_task):
3076         * gst/gstpad.h:
3077         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
3078         (gst_queue_loop), (gst_queue_src_activate):
3079         * gst/gsttask.c: (gst_task_init), (gst_task_set_lock),
3080         (gst_task_get_state):
3081         * gst/gsttask.h:
3082         * gst/schedulers/threadscheduler.c:
3083         (gst_thread_scheduler_task_start), (gst_thread_scheduler_func):
3084         Implement gst_pad_pause/start/stop_task(), take STREAM lock
3085         in task function.
3086         Remove ACTIVE pad flag, use FLUSHING everywhere
3087         Added _pad_chain(), _pad_get_range() to call chain/getrange 
3088         functions.
3089         Add locks around IS_FLUSHING when reading.
3090         Take STREAM lock in chain(), get_range() functions so plugins
3091         don't need to take it anymore.
3092         
3093
3094
3095 2005-05-25  Wim Taymans  <wim@fluendo.com>
3096
3097         * tools/gst-launch.c: (event_loop):
3098         Unref message after using its contents instead of
3099         before.
3100
3101 2005-05-24  Wim Taymans  <wim@fluendo.com>
3102
3103         * docs/design/draft-ghostpads.txt:
3104         * docs/design/draft-push-pull.txt:
3105         * docs/design/draft-query.txt:
3106         * docs/design/part-overview.txt:
3107         Docs updates, added general overview doc.
3108
3109 2005-05-21  David Schleef  <ds@schleef.org>
3110
3111         * docs/gst/tmpl/old/GstBin.sgml:
3112         * docs/gst/tmpl/old/GstBuffer.sgml:
3113         * docs/gst/tmpl/old/GstCaps.sgml:
3114         * docs/gst/tmpl/old/GstClock.sgml:
3115         * docs/gst/tmpl/old/GstCompat.sgml:
3116         * docs/gst/tmpl/old/GstData.sgml:
3117         * docs/gst/tmpl/old/GstElement.sgml:
3118         * docs/gst/tmpl/old/GstEvent.sgml:
3119         * docs/gst/tmpl/old/GstIndex.sgml:
3120         * docs/gst/tmpl/old/GstStructure.sgml:
3121         * docs/gst/tmpl/old/GstTag.sgml:
3122         * docs/gst/tmpl/old/cothreads.sgml:
3123         * docs/gst/tmpl/old/cothreads_compat.sgml:
3124         * docs/gst/tmpl/old/gettext.sgml:
3125         * docs/gst/tmpl/old/gobject2gtk.sgml:
3126         * docs/gst/tmpl/old/grammar.tab.sgml:
3127         * docs/gst/tmpl/old/gst-i18n-app.sgml:
3128         * docs/gst/tmpl/old/gst-i18n-lib.sgml:
3129         * docs/gst/tmpl/old/gst_private.sgml:
3130         * docs/gst/tmpl/old/gstaggregator.sgml:
3131         * docs/gst/tmpl/old/gstarch.sgml:
3132         * docs/gst/tmpl/old/gstatomic_impl.sgml:
3133         * docs/gst/tmpl/old/gstbufferstore.sgml:
3134         * docs/gst/tmpl/old/gstdata_private.sgml:
3135         * docs/gst/tmpl/old/gstdisksink.sgml:
3136         * docs/gst/tmpl/old/gstdisksrc.sgml:
3137         * docs/gst/tmpl/old/gstelementfactory.sgml:
3138         * docs/gst/tmpl/old/gstextratypes.sgml:
3139         * docs/gst/tmpl/old/gstfakesink.sgml:
3140         * docs/gst/tmpl/old/gstfakesrc.sgml:
3141         * docs/gst/tmpl/old/gstfdsink.sgml:
3142         * docs/gst/tmpl/old/gstfdsrc.sgml:
3143         * docs/gst/tmpl/old/gstfilesink.sgml:
3144         * docs/gst/tmpl/old/gstfilesrc.sgml:
3145         * docs/gst/tmpl/old/gsthttpsrc.sgml:
3146         * docs/gst/tmpl/old/gstidentity.sgml:
3147         * docs/gst/tmpl/old/gstindexfactory.sgml:
3148         * docs/gst/tmpl/old/gstmarshal.sgml:
3149         * docs/gst/tmpl/old/gstmd5sink.sgml:
3150         * docs/gst/tmpl/old/gstmultidisksrc.sgml:
3151         * docs/gst/tmpl/old/gstmultifilesrc.sgml:
3152         * docs/gst/tmpl/old/gstpadtemplate.sgml:
3153         * docs/gst/tmpl/old/gstpipefilter.sgml:
3154         * docs/gst/tmpl/old/gstschedulerfactory.sgml:
3155         * docs/gst/tmpl/old/gstsearchfuncs.sgml:
3156         * docs/gst/tmpl/old/gstshaper.sgml:
3157         * docs/gst/tmpl/old/gstspider.sgml:
3158         * docs/gst/tmpl/old/gstspideridentity.sgml:
3159         * docs/gst/tmpl/old/gststatistics.sgml:
3160         * docs/gst/tmpl/old/gsttee.sgml:
3161         * docs/gst/tmpl/old/gsttimecache.sgml:
3162         * docs/gst/tmpl/old/gsttypefindfactory.sgml:
3163         * docs/gst/tmpl/old/gstxmlregistry.sgml:
3164         * docs/gst/tmpl/old/gthread-cothreads.sgml:
3165         * docs/gst/tmpl/old/types.sgml:
3166           I didn't intend to add these or check them in.
3167
3168 2005-05-19  David Schleef  <ds@schleef.org>
3169
3170         * configure.ac: Use -no-common everywhere.  In a sane world, it
3171           would be the default in libtool, because without it, you can't
3172           build DLLs on Windows.
3173         * docs/gst/gstreamer-docs.sgml: Remove GstCpu, GstData, GstThread
3174         * docs/gst/gstreamer-sections.txt:
3175         * docs/gst/tmpl/gstcpu.sgml:
3176         * docs/gst/tmpl/gstdata.sgml:
3177         * docs/gst/tmpl/gstthread.sgml:
3178
3179 2005-05-19  David Schleef  <ds@schleef.org>
3180
3181         * gst/gstminiobject.c: (gst_value_set_mini_object),
3182         (gst_value_take_mini_object), (gst_value_get_mini_object):
3183         * gst/gstminiobject.h: Add GValue set/get functions.
3184
3185 2005-05-19  Wim Taymans  <wim@fluendo.com>
3186
3187         * gst/gstbuffer.c: (gst_buffer_init), (gst_subbuffer_get_type),
3188         (gst_subbuffer_class_init), (gst_subbuffer_finalize),
3189         (gst_subbuffer_init), (gst_buffer_is_span_fast):
3190         * gst/gstbuffer.h:
3191         * gst/gstbus.c: (gst_bus_post):
3192         * gst/gstelement.c: (gst_element_get_random_pad):
3193         * gst/gstmessage.c: (gst_message_init), (gst_message_finalize):
3194         Make subbufer unref the parent in finalize.
3195         some more debugging info.
3196
3197
3198 2005-05-19  Wim Taymans  <wim@fluendo.com>
3199
3200         * gst/base/gstbasesink.c: (gst_basesink_class_init),
3201         (gst_basesink_init), (gst_basesink_finalize),
3202         (gst_basesink_activate), (gst_basesink_change_state):
3203         Don't free preroll queue too early.
3204
3205 2005-05-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3206
3207         * gst/Makefile.am:
3208         * gst/ROADMAP:
3209           Hi, I'm outdated. Please shoot me.
3210
3211 2005-05-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3212
3213         * gst/gstpipeline.c: (gst_pipeline_send_event):
3214           Do not access variables after they have been deleted.
3215
3216 2005-05-19  Wim Taymans  <wim@fluendo.com>
3217
3218         * tools/gst-inspect.c: (print_plugin_features):
3219         A plugin feature does unfortunatly not use the
3220         object name yet...
3221
3222 2005-05-18  Wim Taymans  <wim@fluendo.com>
3223
3224         * gst/gstbuffer.c: (gst_buffer_is_span_fast), (gst_buffer_span):
3225         Port _span() functions to new subbuffers.
3226
3227 2005-05-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3228
3229         * gst/gstbin.c: (gst_bin_add_func):
3230           Fix clock settery in bins when adding kids after the clock has
3231           been selected.
3232
3233 2005-05-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3234
3235         * gst/elements/gstidentity.c: (gst_identity_class_init):
3236           Workaround until signals support GstMiniObject.
3237
3238 2005-05-18  Jan Schmidt  <thaytan@mad.scientist.com>
3239
3240         * gst/gstbuffer.c:
3241         Oops, fix a typo GST_TYPE_BUFFER -> GST_TYPE_SUBBUFFER.
3242
3243 2005-05-18  Wim Taymans  <wim@fluendo.com>
3244
3245         * gst/base/Makefile.am:
3246         * gst/base/gstadapter.c: (gst_adapter_base_init),
3247         (gst_adapter_class_init), (gst_adapter_init),
3248         (gst_adapter_dispose), (gst_adapter_finalize), (gst_adapter_new),
3249         (gst_adapter_clear), (gst_adapter_push), (gst_adapter_peek),
3250         (gst_adapter_flush), (gst_adapter_available),
3251         (gst_adapter_available_fast):
3252         * gst/base/gstadapter.h:
3253         Ported and added adapter to the base classes.
3254
3255 2005-05-17  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
3256
3257         * gst/gst.c:
3258         * gst/gstmessage.c:
3259           Make sure the class is reffed/unreffed once before threads can be
3260           used.  Fixes #304551.
3261
3262 2005-05-17  Wim Taymans  <wim@fluendo.com>
3263
3264         * gst/base/gstbasesink.c: (gst_basesink_finish_preroll),
3265         (gst_basesink_chain_unlocked), (gst_basesink_activate):
3266         * gst/gstminiobject.c: (gst_mini_object_get_type),
3267         (gst_mini_object_free):
3268         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_query),
3269         (gst_pad_push), (gst_pad_push_event):
3270         * gst/gstqueue.c: (gst_queue_change_state):
3271         Don't queue buffers in basesink when we are flushing.
3272         Unref buffer when flushing in basesink.
3273         Flush queue when going to READY
3274         Unref buffer when _push() returns an error.
3275         Don't free MiniObject instance when refcount is incremented
3276         in _finalize() so that we can recover objects.
3277
3278 2005-05-17  Thomas Vander Stichele  <thomas at apestaart dot org>
3279
3280         * docs/manual/advanced-schedulers.xml:
3281         * docs/manual/appendix-checklist.xml:
3282         * docs/pwg/advanced-clock.xml:
3283         * docs/pwg/advanced-interfaces.xml:
3284         * docs/pwg/advanced-request.xml:
3285         * docs/pwg/advanced-types.xml:
3286         * docs/pwg/intro-preface.xml:
3287         * examples/plugins/example.c: (gst_example_get_type),
3288         (gst_example_class_init), (gst_example_chain),
3289         (gst_example_set_property), (gst_example_get_property),
3290         (gst_example_change_state), (plugin_init):
3291         * examples/plugins/example.h:
3292           small doc fixes
3293
3294 2005-05-17  Wim Taymans  <wim@fluendo.com>
3295
3296         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_set_caps),
3297         (gst_pad_alloc_buffer), (gst_pad_query), (gst_pad_push):
3298         * gst/gstqueue.c: (gst_queue_change_state):
3299         Clear queue when going to READY.
3300         Remove IN_SETCAPS flag too.
3301
3302 2005-05-17  Tim-Philipp Müller  <tim at centricular dot net>
3303
3304         * gst/base/gstbasesrc.c: (gst_basesrc_change_state):
3305           Remove implicit cast from gboolean to GstElementStateReturn;
3306           make sure we still return failure in paused => ready case if
3307           the parent class fails to change state and our own stop 
3308           vfunc succeeds.
3309
3310 2005-05-17  Wim Taymans  <wim@fluendo.com>
3311
3312         * tools/gst-launch.c: (event_loop):
3313         Message was unreffed too soon.
3314
3315 2005-05-16  Andy Wingo  <wingo@pobox.com>
3316
3317         * gst/gstbin.c (sink_iterator_filter): Err... um...
3318
3319         * check/gst/gstbin.c (test_ghost_pads): New test for the
3320         ghosting-if-elements-not-in-same-bin behavior.
3321
3322 2005-05-16  David Schleef  <ds@schleef.org>
3323
3324         * gst/gstminiobject.c: Use g_atomic_int_get() instead of
3325         accessing refcount directly.
3326
3327 2005-05-15  David Schleef  <ds@schleef.org>
3328
3329         * check/Makefile.am: remove GstData checks
3330         * check/gst-libs/gdp.c: (START_TEST): fix for API changes
3331         * gst/Makefile.am: add miniobject, remove data
3332         * gst/gst.h: add miniobject, remove data
3333         * gst/gstdata.c: remove
3334         * gst/gstdata.h: remove
3335         * gst/gstdata_private.h: remove
3336         * gst/gsttypes.h: remove GstEvent and GstMessage
3337         * gst/gstelement.c: (gst_element_post_message): fix for API changes
3338         * gst/gstmarshal.list: change BOXED -> OBJECT
3339
3340         Implement GstMiniObject.
3341         * gst/gstminiobject.c:
3342         * gst/gstminiobject.h:
3343
3344         Modify to be subclasses of GstMiniObject.
3345         * gst/gstbuffer.c: (_gst_buffer_initialize), (gst_buffer_get_type),
3346         (gst_buffer_class_init), (gst_buffer_finalize), (_gst_buffer_copy),
3347         (gst_buffer_init), (gst_buffer_new), (gst_buffer_new_and_alloc),
3348         (gst_subbuffer_get_type), (gst_subbuffer_init),
3349         (gst_buffer_create_sub), (gst_buffer_is_span_fast),
3350         (gst_buffer_span):
3351         * gst/gstbuffer.h:
3352         * gst/gstevent.c: (_gst_event_initialize), (gst_event_get_type),
3353         (gst_event_class_init), (gst_event_init), (gst_event_finalize),
3354         (_gst_event_copy), (gst_event_new):
3355         * gst/gstevent.h:
3356         * gst/gstmessage.c: (_gst_message_initialize),
3357         (gst_message_get_type), (gst_message_class_init),
3358         (gst_message_init), (gst_message_finalize), (_gst_message_copy),
3359         (gst_message_new), (gst_message_new_error),
3360         (gst_message_new_warning), (gst_message_new_tag),
3361         (gst_message_new_state_changed), (gst_message_new_application):
3362         * gst/gstmessage.h:
3363         * gst/gstprobe.c: (gst_probe_perform),
3364         (gst_probe_dispatcher_dispatch):
3365         * gst/gstprobe.h:
3366         * gst/gstquery.c: (_gst_query_initialize), (gst_query_get_type),
3367         (gst_query_class_init), (gst_query_finalize), (gst_query_init),
3368         (_gst_query_copy), (gst_query_new):
3369
3370         Update elements for GstData -> GstMiniObject changes
3371         * gst/gstquery.h:
3372         * gst/gstqueue.c: (gst_queue_finalize), (gst_queue_locked_flush),
3373         (gst_queue_chain), (gst_queue_loop):
3374         * gst/elements/gstbufferstore.c:
3375         (gst_buffer_store_add_buffer_func),
3376         (gst_buffer_store_cleared_func), (gst_buffer_store_get_buffer):
3377         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
3378         (gst_fakesink_render):
3379         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
3380         * gst/elements/gstfilesrc.c: (gst_mmap_buffer_get_type),
3381         (gst_mmap_buffer_class_init), (gst_mmap_buffer_init),
3382         (gst_mmap_buffer_finalize), (gst_filesrc_map_region),
3383         (gst_filesrc_create_read):
3384         * gst/elements/gstidentity.c: (gst_identity_class_init):
3385         * gst/elements/gsttypefindelement.c:
3386         (gst_type_find_element_src_event), (free_entry_buffers),
3387         (gst_type_find_element_handle_event):
3388         * libs/gst/dataprotocol/dataprotocol.c:
3389         (gst_dp_header_from_buffer):
3390         * libs/gst/dataprotocol/dataprotocol.h:
3391         * libs/gst/dataprotocol/dp-private.h:
3392
3393 2005-05-15  David Schleef  <ds@schleef.org>
3394
3395         * gst/elements/gstelements.c: Don't include headers that were
3396         just removed.
3397
3398 2005-05-15  David Schleef  <ds@schleef.org>
3399
3400         * gst/elements/Makefile.am: Remove some elements that don't
3401         need to be in the core (or even exist at all).
3402         * gst/elements/gstaggregator.c:
3403         * gst/elements/gstaggregator.h:
3404         * gst/elements/gstmd5sink.c:
3405         * gst/elements/gstmd5sink.h:
3406         * gst/elements/gstmultifilesrc.c:
3407         * gst/elements/gstmultifilesrc.h:
3408         * gst/elements/gstpipefilter.c:
3409         * gst/elements/gstpipefilter.h:
3410         * gst/elements/gstshaper.c:
3411         * gst/elements/gstshaper.h:
3412         * gst/elements/gststatistics.c:
3413         * gst/elements/gststatistics.h:
3414         * po/POTFILES.in: Remove above files.
3415
3416 2005-05-14  Andy Wingo  <wingo@pobox.com>
3417
3418         * gst/gstbin.c (gst_bin_iterate_sinks): Use sink_iterator_filter
3419         so as to get the refs right.
3420         (sink_iterator_filter): New function, wraps bin_element_is_sink,
3421         unreffing objects that don't pass the filter.
3422
3423         * gst/gstpipeline.c (gst_pipeline_init): Drop ref on bus after
3424         gst_element_set_bus.
3425         (gst_pipeline_dispose): Set the bus on the pipeline to NULL. In
3426         normal cases, this will destroy the bus.
3427
3428         * gst/gstutils.c (prepare_link_maybe_ghosting): Drop ref on root
3429         object.
3430
3431         * gst/gstbin.c (gst_bin_change_state): Fix state changes if a bin
3432         has no sinks.
3433
3434 2005-05-13  Andy Wingo  <wingo@pobox.com>
3435
3436         * gst/gstutils.c (gst_element_link_pads): Instead of calling
3437         gst_pad_link, call pad_link_maybe_ghosting,
3438         (pad_link_maybe_ghosting): Links pads, making sure that the
3439         elements being linked are in the same bin.
3440         (find_common_root, object_has_ancestor, ghost_up, remove_pad):
3441         Helpers for pad_link_maybe_ghosting.
3442
3443 2005-05-13  Tim-Philipp Müller  <tim at centricular dot net>
3444
3445         * configure.ac:
3446           Require GLib >= 2.4.0 (for the g_atomic_* funcs)
3447
3448 2005-05-13  Tim-Philipp Müller  <tim at centricular dot net>
3449
3450         * docs/design/part-element-source.txt:
3451           Mention GstPushSrc
3452
3453 2005-05-12  Wim Taymans  <wim@fluendo.com>
3454
3455         * gst/base/gstbasesink.c: (gst_basesink_init),
3456         (gst_basesink_activate):
3457         * gst/base/gstbasesrc.c: (gst_basesrc_unlock),
3458         (gst_basesrc_is_seekable):
3459         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_remove_func),
3460         (bin_element_is_sink), (gst_bin_change_state):
3461         * gst/gstelement.c: (gst_element_add_pad), (gst_element_query):
3462         * gst/gstelement.h:
3463         Identify sinks by their flag to avoid overly complicated
3464         checks (fow now).
3465         Do state changes even for elements not reachable from the
3466         sinks.
3467         BaseSink is a sink now :)
3468         Some more debugging info in the basesrc.
3469
3470
3471 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3472
3473         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_query):
3474           Implement _query on a bin, similar to _send_event.
3475
3476 2005-05-12  Tim-Philipp Müller  <tim at centricular dot net>
3477
3478         * gst/base/gstbasesrc.c: (gst_basesrc_do_seek):
3479           Discont event offset format should be GST_FORMAT_BYTES,
3480           not GST_FORMAT_TIME.
3481
3482 2005-05-12  Wim Taymans  <wim@fluendo.com>
3483
3484         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_get_state):
3485         Same fix as Ronald's but without the signal. 
3486
3487 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3488
3489         * gst/gstutils.c: (gst_element_query_position):
3490           No, an element is not a pad.
3491
3492 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3493
3494         * gst/gstbin.c: (gst_bin_add_func), (cb_parent_unset),
3495         (gst_bin_get_state):
3496           If a child is removed from a bin while we remove the child from
3497           the bin and while we're retrieving its state, signal this to the
3498           get_state function so we abort the wait (instead of waiting for
3499           a timeout) and can immediately re-iterate over all other elements.
3500
3501 2005-05-12  Wim Taymans  <wim@fluendo.com>
3502
3503         * gst/base/Makefile.am:
3504         * gst/base/gstbasesrc.c: (gst_basesrc_is_seekable),
3505         (gst_basesrc_start):
3506         * gst/base/gstbasesrc.h:
3507         * gst/base/gstpushsrc.c: (gst_pushsrc_get_type),
3508         (gst_pushsrc_base_init), (gst_pushsrc_class_init),
3509         (gst_pushsrc_init), (gst_pushsrc_create):
3510         * gst/base/gstpushsrc.h:
3511         Added is_seekable to BaseSrc
3512         Added simple PushSrc.
3513
3514 2005-05-11  Wim Taymans  <wim@fluendo.com>
3515
3516         * gst/gstelement.c: (gst_element_add_pad), (gst_element_query):
3517         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
3518         (gst_element_link_pads), (gst_element_query_position),
3519         (gst_element_query_convert), (intersect_caps_func),
3520         (gst_pad_query_position), (gst_pad_query_convert):
3521         Fix refcounting in utils function.
3522         No point in trying to activate a pad when it's added, it could
3523         be added from the state change function and then we deadlock, the
3524         element has to decide what to do.
3525
3526 2005-05-10  Andy Wingo  <wingo@pobox.com>
3527
3528         * gst/elements/gstfakesink.c (gst_fakesink_render): Er, emit with
3529         *all* the arguments.
3530
3531         * gst/base/gstbasetransform.c (gst_base_transform_event): Grab the
3532         stream lock if it's a FLUSH_DONE; normal flushes don't get the
3533         lock (according to the docs -- if this is wrong change the docs).
3534
3535         * gst/gstpipeline.c (gst_pipeline_change_state): Set the bus to
3536         flush messages in the NULL state.
3537
3538         * gst/gstbus.c (gst_bus_post): If a bus is flushing, unref the
3539         message immediately and return.
3540         (gst_bus_set_flushing): New function. If a bus is flushing, it
3541         flushes out any queued messages and immediately unrefs new
3542         messages. This is so when an element goes to NULL, all of the
3543         unhandled messages coming from it can be freed, and their
3544         references to the element dropped. In other words: message source
3545         ref considered harmful :P
3546
3547         * gst/gstbin.c (gst_bin_change_state): Unref peer element when
3548         we're finished with it.
3549
3550         * gst/gstmessage.c (gst_message_new_state_changed): 
3551
3552 2005-05-10  Wim Taymans  <wim@fluendo.com>
3553
3554         * gst/gstvalue.c: (gst_value_compare_flags),
3555         (gst_value_serialize_flags), (gst_value_deserialize_flags),
3556         (_gst_value_initialize):
3557         Added flags serialize/deserialize/compare code.
3558
3559 2005-05-09  Andy Wingo  <wingo@pobox.com>
3560
3561         * gst/base/gstbasetransform.c (gst_base_transform_proxy_getcaps):
3562         Intersect the peer's caps with our caps.
3563
3564 2005-05-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3565
3566         * gst/base/gsttypefindhelper.c: (helper_find_peek):
3567         * gst/elements/gsttypefindelement.c: (find_peek):
3568           Handle negative offsets better. Fixes decodebin.
3569
3570 2005-05-09  Wim Taymans  <wim@fluendo.com>
3571
3572         * gst/base/gstbasetransform.c: (gst_base_transform_proxy_getcaps),
3573         (gst_base_transform_event):
3574         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_query):
3575         Implement accept_caps.
3576         Fix silly lock/unlock mismatch in base class.
3577
3578 2005-05-09  Wim Taymans  <wim@fluendo.com>
3579
3580         * docs/design/draft-push-pull.txt:
3581         * gst/base/gstbasesrc.c: (gst_basesrc_init), (gst_basesrc_query):
3582         * gst/elements/gstfilesink.c: (gst_filesink_init),
3583         (gst_filesink_query):
3584         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
3585         (gst_type_find_handle_src_query), (find_element_get_length):
3586         * gst/gstelement.c: (gst_element_seek), (gst_element_query):
3587         * gst/gstelement.h:
3588         * gst/gstmessage.c:
3589         * gst/gstmessage.h:
3590         * gst/gstpad.c: (gst_real_pad_init), (gst_pad_get_query_types),
3591         (gst_real_pad_get_caps_unlocked),
3592         (gst_pad_get_internal_links_default), (gst_pad_get_internal_links),
3593         (gst_pad_event_default_dispatch), (gst_pad_event_default),
3594         (gst_pad_dispatcher), (gst_pad_query), (gst_pad_query_default),
3595         (gst_real_pad_dispose), (gst_real_pad_finalize),
3596         (gst_pad_load_and_link), (gst_pad_save_thyself),
3597         (gst_ghost_pad_save_thyself), (handle_pad_block), (gst_pad_push),
3598         (gst_pad_check_pull_range), (gst_pad_pull_range),
3599         (gst_pad_template_get_type), (gst_pad_template_class_init),
3600         (gst_pad_template_init), (gst_pad_template_dispose),
3601         (name_is_valid), (gst_static_pad_template_get),
3602         (gst_pad_template_new), (gst_static_pad_template_get_caps),
3603         (gst_pad_template_get_caps), (gst_pad_set_element_private),
3604         (gst_pad_get_element_private), (gst_pad_start_task),
3605         (gst_pad_pause_task), (gst_pad_stop_task),
3606         (gst_ghost_pad_get_type), (gst_ghost_pad_class_init),
3607         (gst_ghost_pad_init), (gst_ghost_pad_dispose),
3608         (gst_ghost_pad_set_property), (gst_ghost_pad_get_property),
3609         (gst_ghost_pad_new):
3610         * gst/gstpad.h:
3611         * gst/gstquery.c: (_gst_query_initialize), (gst_query_new),
3612         (gst_query_new_position), (gst_query_set_position),
3613         (gst_query_parse_position), (gst_query_new_convert),
3614         (gst_query_set_convert), (gst_query_parse_convert):
3615         * gst/gstquery.h:
3616         * gst/gstqueryutils.c:
3617         * gst/gstqueryutils.h:
3618         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
3619         (gst_queue_bufferalloc), (gst_queue_handle_sink_event),
3620         (gst_queue_handle_src_query):
3621         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
3622         (gst_element_query_position), (gst_element_query_convert),
3623         (intersect_caps_func), (gst_pad_query_position),
3624         (gst_pad_query_convert):
3625         * gst/gstutils.h:
3626         * tools/gst-inspect.c: (print_pad_info):
3627         * tools/gst-xmlinspect.c: (print_element_info):
3628         Remove old query functions. Ported old code.
3629         Added position/convert helper functions to gstutils.
3630         Reordered gstpad.c code, grouping relevant things.
3631         Remove gst_message_new(), always need to speficy a specific
3632         message.
3633
3634
3635 2005-05-09  Andy Wingo  <wingo@pobox.com>
3636
3637         * gst/gstiterator.h: Add some includes.
3638
3639         * gst/gstqueryutils.h: Include more headers.
3640
3641         * gst/gstpad.h:
3642         * gst/gstpad.c (gst_pad_query_position): New routine, replaces
3643         some uses of gst_pad_query.
3644
3645         * gst/gstqueryutils.c: Build fixes. Make parse functions ignore
3646         NULL out parameters.
3647         (gst_query_new_position): New proc, allocates a new position
3648         query.
3649
3650         * gst/Makefile.am (libgstreamer_@GST_MAJORMINOR@_la_SOURCES): Add
3651         gstqueryutils.c to the build.
3652
3653         * gst/gststructure.c (gst_structure_set_valist): Implement with
3654         the generic G_VALUE_COLLECT.
3655         
3656 2005-05-08  Edward Hervey  <bilboed@bilboed.com>
3657
3658         * gst/Makefile.am: (gst_headers):
3659         Added gstqueryutils.h to the list of headers to install, that was
3660         a 'nachty' move wingo :)
3661
3662 2005-05-06  Andy Wingo  <wingo@pobox.com>
3663
3664         * gst/gstquery.h
3665         * gst/gstquery.c (_gst_query_initialize): Extend GstQuery from
3666         GstData, init a memchunk.
3667         (standard_definitions): Add a few query types, deprecate a few.
3668         (gst_query_get_type): New proc.
3669         (_gst_query_copy, _gst_query_free, gst_query_new): GstData
3670         implementation.
3671         (gst_query_new_application, gst_query_get_structure): New public
3672         procs.
3673
3674         * docs/design/draft-query.txt: Removed LINKS from the query types,
3675         because all the rest can be dispatched to other pads -- seemed
3676         ugly to have a query that couldn't be dispatched. internal_links
3677         is fine as a pad method.
3678
3679         * gst/gstpad.h: Add query2 as a pad method, add the new functions
3680         in gstpad.c, but maintain binary compatibility for the moment.
3681         Will fix before 0.9 is out.
3682
3683         * gst/gstqueryutils.c: 
3684         * gst/gstqueryutils.h: New files, implement 3 methods for each
3685         query type: parse_query, parse_response, and set. Probably need an
3686         allocator as well.
3687
3688         * gst/gst.h: Add gstquery.h and gstqueryutils.h to the list.
3689
3690         * gst/elements/gstfilesink.c (gst_filesink_query2):
3691         * gst/base/gstbasesrc.c (gst_basesrc_query2): Replace old query,
3692         query_types, and formats methods.
3693
3694         * gst/gstpad.c (gst_pad_query2, gst_pad_query2_default)
3695         (gst_pad_set_query2_function): New functions.
3696         (gst_real_pad_init): Set query2_default as the default query2
3697         function. Basically just dispatches to internally linked pads.
3698
3699         Needs review!
3700         
3701         * gst/gstdata_private.h (_GST_DATA_INIT): Set data->refcount to 1
3702         without using the atomic operations. Only one thread can possibly
3703         be accessing the data at this point. Changed so as to avoid
3704         gst_atomic operations.
3705
3706 2005-05-06  Wim Taymans  <wim@fluendo.com>
3707
3708         * gst/gstpad.c: (gst_pad_alloc_buffer), (gst_pad_push):
3709         Also set caps if we use the fallback buffer alloc.
3710
3711 2005-05-06  Tim-Philipp Müller  <tim at centricular dot net>
3712
3713         * docs/gst/Makefile.am:
3714         * docs/gst/gstreamer-docs.sgml:
3715         * docs/gst/gstreamer-sections.txt:
3716         * docs/gst/tmpl/gstatomic.sgml:
3717         * docs/gst/tmpl/gstmemchunk.sgml:
3718         * testsuite/elements/struct_i386.h:
3719         * win32/GStreamer.vcproj:
3720         * win32/Makefile:
3721           Purge GstAtomic stuff from docs and win32 makefiles as well
3722
3723 2005-05-06  Wim Taymans  <wim@fluendo.com>
3724
3725         * gst/base/gstbasetransform.c: (gst_base_transform_proxy_getcaps):
3726         * gst/elements/gstcapsfilter.c: (gst_capsfilter_getcaps):
3727         * gst/gstpad.c: (gst_pad_peer_get_caps):
3728         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
3729         (gst_queue_bufferalloc), (gst_queue_handle_sink_event),
3730         (gst_queue_src_activate), (gst_queue_change_state):
3731         * gst/gstqueue.h:
3732         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
3733         (intersect_caps_func):
3734         Fix gst_pad_peer_get_caps(), make it return NULL if no peer.
3735         Always take QUEUE_LOCK after STREAM_LOCK or we might deadlock.
3736         Some fixes for the peer_get_caps() change.
3737
3738 2005-05-06  Wim Taymans  <wim@fluendo.com>
3739
3740         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
3741         (gst_basesink_handle_buffer), (gst_basesink_chain_unlocked),
3742         (gst_basesink_activate):
3743         Actually do something with error codes returned from the push
3744         functions.
3745
3746 2005-05-06  Wim Taymans  <wim@fluendo.com>
3747
3748         * docs/design/part-element-sink.txt:
3749         * docs/design/part-element-source.txt:
3750         * gst/base/gstbasesink.c: (gst_basesink_class_init),
3751         (gst_basesink_event), (gst_basesink_activate):
3752         * gst/base/gstbasesink.h:
3753         * gst/base/gstbasesrc.c: (gst_basesrc_init), (gst_basesrc_unlock),
3754         (gst_basesrc_activate):
3755         * gst/base/gstbasesrc.h:
3756         * gst/gstelement.c: (gst_element_pads_activate):
3757         Some more documentation.
3758         Fixed scheduling decision in _pads_activate().
3759
3760 2005-05-05  Andy Wingo  <wingo@pobox.com>
3761
3762         * check/pipelines/simple_launch_lines.c (test_2_elements): "Fix"
3763         the test suite.
3764
3765 2005-05-05  Wim Taymans  <wim@fluendo.com>
3766
3767         * gst/base/Makefile.am:
3768         * gst/base/gstbasesink.h:
3769         * gst/base/gstbasesrc.c: (gst_basesrc_init),
3770         (gst_basesrc_set_dataflow_funcs), (gst_basesrc_query):
3771         * gst/base/gstcollectpads.c: (gst_collectpads_get_type),
3772         (gst_collectpads_class_init), (gst_collectpads_init),
3773         (gst_collectpads_finalize), (gst_collectpads_new),
3774         (gst_collectpads_set_function), (gst_collectpads_add_pad),
3775         (find_pad), (gst_collectpads_remove_pad),
3776         (gst_collectpads_is_active), (gst_collectpads_collect),
3777         (gst_collectpads_collect_range), (gst_collectpads_start),
3778         (gst_collectpads_stop), (gst_collectpads_peek),
3779         (gst_collectpads_pop), (gst_collectpads_available),
3780         (gst_collectpads_read), (gst_collectpads_flush),
3781         (gst_collectpads_chain):
3782         * gst/base/gstcollectpads.h:
3783         * gst/elements/Makefile.am:
3784         * gst/elements/gstelements.c:
3785         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
3786         (gst_fakesink_get_times), (gst_fakesink_event),
3787         (gst_fakesink_preroll), (gst_fakesink_render):
3788         * gst/elements/gstfilesink.c: (gst_filesink_class_init),
3789         (gst_filesink_init), (gst_filesink_set_location),
3790         (gst_filesink_open_file), (gst_filesink_close_file),
3791         (gst_filesink_pad_query), (gst_filesink_event),
3792         (gst_filesink_render), (gst_filesink_change_state):
3793         * gst/elements/gstfilesink.h:
3794         Added object to help in making collect pad based elements.
3795         Ported filesink.
3796         Make event function in sink baseclass return gboolean.
3797
3798 2005-05-05  Wim Taymans  <wim@fluendo.com>
3799
3800         * gst/gstbin.c: (gst_bin_send_event), (compare_name),
3801         (gst_bin_get_by_name):
3802         * gst/gstbuffer.h:
3803         * gst/gstclock.c: (gst_clock_entry_new), (gst_clock_class_init),
3804         (gst_clock_finalize):
3805         * gst/gstdata.c: (gst_data_replace):
3806         * gst/gstdata.h:
3807         * gst/gstelement.c: (gst_element_request_pad),
3808         (gst_element_pads_activate):
3809         * gst/gstobject.c: (gst_object_init), (gst_object_ref),
3810         (gst_object_unref):
3811         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3812         (gst_pad_set_checkgetrange_function),
3813         (gst_pad_link_check_compatible_unlocked), (gst_pad_set_caps),
3814         (gst_pad_check_pull_range), (gst_pad_pull_range),
3815         (gst_static_pad_template_get_caps), (gst_pad_start_task),
3816         (gst_pad_pause_task), (gst_pad_stop_task):
3817         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
3818         (gst_element_request_pad), (gst_pad_proxy_getcaps):
3819         Fix name lookup in GstBin.
3820         Added _data_replace() function and _buffer_replace()
3821         Use finalize method to clean up clock.
3822         Fix refcounting on request pads.
3823         Fix pad schedule mode error.
3824         Some more object refcounting debug info,
3825
3826
3827 2005-05-04  Andy Wingo <wingo@pobox.com>
3828
3829         * check/Makefile.am:
3830         * docs/gst/tmpl/gstatomic.sgml:
3831         * docs/gst/tmpl/gstplugin.sgml:
3832         * gst/base/gstbasesink.c: (gst_basesink_activate):
3833         * gst/base/gstbasesrc.c: (gst_basesrc_class_init),
3834         (gst_basesrc_init), (gst_basesrc_set_dataflow_funcs),
3835         (gst_basesrc_query), (gst_basesrc_set_property),
3836         (gst_basesrc_get_property), (gst_basesrc_check_get_range),
3837         (gst_basesrc_activate):
3838         * gst/base/gstbasesrc.h:
3839         * gst/base/gstbasetransform.c: (gst_base_transform_sink_activate),
3840         (gst_base_transform_src_activate):
3841         * gst/elements/gstelements.c:
3842         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
3843         (gst_fakesrc_set_property), (gst_fakesrc_get_property):
3844         * gst/elements/gsttee.c: (gst_tee_sink_activate):
3845         * gst/elements/gsttypefindelement.c: (find_element_get_length),
3846         (gst_type_find_element_checkgetrange),
3847         (gst_type_find_element_activate):
3848         * gst/gstbin.c: (gst_bin_save_thyself), (gst_bin_restore_thyself):
3849         * gst/gstcaps.c: (gst_caps_do_simplify), (gst_caps_save_thyself),
3850         (gst_caps_load_thyself):
3851         * gst/gstelement.c: (gst_element_pads_activate),
3852         (gst_element_save_thyself), (gst_element_restore_thyself):
3853         * gst/gstpad.c: (gst_pad_load_and_link), (gst_pad_save_thyself),
3854         (gst_ghost_pad_save_thyself), (gst_pad_check_pull_range):
3855         * gst/gstpad.h:
3856         * gst/gstxml.c: (gst_xml_write), (gst_xml_parse_doc),
3857         (gst_xml_parse_file), (gst_xml_parse_memory),
3858         (gst_xml_get_element), (gst_xml_make_element):
3859         * gst/indexers/gstfileindex.c: (gst_file_index_load),
3860         (_file_index_id_save_xml), (gst_file_index_commit):
3861         * gst/registries/gstlibxmlregistry.c: (read_string), (read_uint),
3862         (read_enum), (load_pad_template), (load_feature), (load_plugin),
3863         (load_paths):
3864         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_caps),
3865         (gst_dp_packet_from_event), (gst_dp_caps_from_packet):
3866         * tools/gst-complete.c: (main):
3867         * tools/gst-compprep.c: (main):
3868         * tools/gst-inspect.c: (print_element_properties_info):
3869         * tools/gst-launch.c: (xmllaunch_parse_cmdline):
3870         * tools/gst-xmlinspect.c: (print_element_properties):
3871         GCC 4 fixen.
3872         
3873 2005-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
3874
3875         * gst/gstplugin.c: (gst_plugin_check_module),
3876         (gst_plugin_check_file), (gst_plugin_load_file):
3877             apply patch from #172526 to make register work on MacOSX
3878
3879 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
3880
3881         * docs/gst/tmpl/gstconfig.sgml:
3882         * gst/gstconfig.h.in:
3883           move documentation for some symbols.  Add doc for GST_PTR_FORMAT
3884         * testsuite/debug/printf_extension.c: (main):
3885           Do not use GST_PTR_FORMAT on pointers to types with
3886           sizeof < sizeof(gpointer).  Fixes test on 64-bit
3887         * testsuite/elements/property.h:
3888           use correct printf format
3889
3890 2005-05-02  Wim Taymans  <wim@fluendo.com>
3891
3892         * docs/design/draft-push-pull.txt:
3893         * docs/design/draft-query.txt:
3894         * gst/base/gstbasesrc.c: (gst_basesrc_get_range_unlocked),
3895         (gst_basesrc_start):
3896         Added draft for new query API.
3897         Added draft for better selecting scheduling methods.
3898         Make basesrc ignore length if the subclass does not support
3899         it.
3900
3901 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
3902
3903         * gst/Makefile.am:
3904           possible fixes for automake-1.5 - _LIBADD is reserved
3905
3906 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
3907
3908         * docs/faq/Makefile.am:
3909         * docs/manual/Makefile.am:
3910         * docs/manuals.mak:
3911         * docs/pwg/Makefile.am:
3912         * gst/Makefile.am:
3913           possible fixes for automake-1.5
3914
3915 2005-04-28  Wim Taymans  <wim@fluendo.com>
3916
3917         * gst/base/gstbasesink.c: (gst_basesink_base_init),
3918         (gst_basesink_pad_getcaps), (gst_basesink_init),
3919         (gst_basesink_do_sync):
3920         * gst/gstclock.c: (gst_clock_entry_new):
3921         * gst/gstevent.c: (gst_event_discont_get_value):
3922         * gst/gstpipeline.c: (pipeline_bus_handler),
3923         (gst_pipeline_change_state):
3924         * gst/gstsystemclock.c: (gst_system_clock_id_wait_unlocked):
3925         Better debugging of clocking info.
3926         Allow NULL values when getting discont values.
3927
3928 2005-04-27  Wim Taymans  <wim@fluendo.com>
3929
3930         * check/gst/gstobject.c: (START_TEST), (gst_object_suite):
3931         * check/gst/gstpad.c: (gst_pad_suite):
3932         Increase timeout for checks.
3933
3934 2005-04-27  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
3935
3936         * check/Makefile.am:
3937           fix the broken rule for cleanup.  Apparently this rule is
3938           only needed on FC2, so maybe this warrants further autotool
3939           inspection.
3940
3941 2005-04-26  Wim Taymans  <wim@fluendo.com>
3942
3943         * gst/gsttrashstack.h:
3944         Ooohh. a nasty one! After having a failed pop() from the stack,
3945         it's possible that the stack is empty. In that case, don't
3946         follow the NULL pointer.
3947
3948 2005-04-25  Wim Taymans  <wim@fluendo.com>
3949
3950         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3951         (gst_pad_set_checkgetrange_function),
3952         (gst_pad_link_check_compatible_unlocked), (gst_pad_link_prepare),
3953         (gst_pad_check_pull_range), (gst_pad_pull_range),
3954         (gst_static_pad_template_get_caps), (gst_pad_start_task),
3955         (gst_pad_pause_task), (gst_pad_stop_task):
3956         * gst/gstplugin.c: (gst_plugin_load):
3957         * gst/gstplugin.h:
3958         Remove gst_library_load as it does more harm than good with
3959         the new g_module flags.
3960         Revert bogus caps template check in pad linking, pad caps
3961         are important when linking not the template, which is more
3962         general than the current caps.
3963
3964 2005-04-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3965
3966         * gst/autoplug/.cvsignore:
3967         * gst/autoplug/Makefile.am:
3968         * gst/autoplug/gstsearchfuncs.c:
3969         * gst/autoplug/gstsearchfuncs.h:
3970         * gst/autoplug/gstspider.c:
3971         * gst/autoplug/gstspider.h:
3972         * gst/autoplug/gstspideridentity.c:
3973         * gst/autoplug/gstspideridentity.h:
3974         * gst/autoplug/spidertest.c:
3975           Die, spider, die.
3976
3977 2005-04-25  Wim Taymans  <wim@fluendo.com>
3978
3979         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3980         (gst_pad_set_checkgetrange_function), (gst_pad_check_pull_range),
3981         (gst_pad_pull_range), (gst_static_pad_template_get_caps),
3982         (gst_pad_start_task), (gst_pad_pause_task), (gst_pad_stop_task):
3983         * gst/gstpad.h:
3984         Added stubs for unimplemented functions. 
3985
3986 2005-04-24  David Schleef  <ds@schleef.org>
3987
3988         * gst/gstpad.h: Disable some unimplemented functions.  Wim,
3989         please fix.
3990
3991 2005-04-24  David Schleef  <ds@schleef.org>
3992
3993         Convert everything from GstAtomicInt to g_atomic_int_*, and
3994         remove gstatomic.
3995         * gst/Makefile.am:
3996         * gst/gstatomic.c:
3997         * gst/gstatomic.h:
3998         * gst/gstatomic_impl.h:
3999         * gst/gstbuffer.c:
4000         * gst/gstcaps.c:
4001         * gst/gstcaps.h:
4002         * gst/gstclock.c:
4003         * gst/gstclock.h:
4004         * gst/gstdata.c:
4005         * gst/gstdata.h:
4006         * gst/gstdata_private.h:
4007         * gst/gstevent.c:
4008         * gst/gstinfo.c:
4009         * gst/gstinfo.h:
4010         * gst/gstmessage.c:
4011         * gst/gstobject.c:
4012         * gst/gstobject.h:
4013         * gst/gststructure.c:
4014         * gst/gststructure.h:
4015         * gst/gstutils.c: Add gst_atomic_int_set() compaitibility function.
4016         * gst/gstutils.h:
4017
4018 2005-04-24  David Schleef  <ds@schleef.org>
4019
4020         * check/gst/gstpad.c: (START_TEST): Oh yeah, it's always nice to
4021         make the regressions tests work.  Remove some code that is no
4022         longer true.
4023         * gst/gstpad.c: (gst_pad_link_check_templates_compatible_unlocked):
4024         Disable warning for pads without templates.
4025
4026 2005-04-24  David Schleef  <ds@schleef.org>
4027
4028         * gst/gstpad.c: Remove handling of filtered caps.  Fix/merge
4029         functions that handle filtered links.
4030         * gst/gstpad.h: Remove 'appfilter' field and prototypes of
4031         removed functions.
4032         * gst/gstutils.c: Fix/remove utility functions that handle
4033         filtered caps.
4034         * gst/gstutils.h:
4035         * gst/gstvalue.c: Add serialization/deserialization of caps
4036         * gst/parse/grammar.y: Ignore filtered caps when linking.  This
4037         requires fixing so that the filter caps notation creates
4038         a capsfilter element and sets the filter_caps property.  I
4039         think everyone probably wants to keep the shorthand notation.
4040         * docs/gst/tmpl/gstelement.sgml: updates for API changes.
4041         * docs/gst/tmpl/gstpad.sgml:
4042
4043         * gst/elements/gstelements.c: Register capsfilter element.
4044         * gst/Makefile.am: fix spacing
4045         * docs/random/ds/0.9-suggested-changes: random
4046
4047 2005-04-23  David Schleef  <ds@schleef.org>
4048
4049         * gst/elements/Makefile.am:
4050         * gst/elements/gstcapsfilter.c: New element that acts like an
4051         identity, but filters caps.  Will eventually replace filtered
4052         caps in pad linking.
4053         * gst/gstutils.c: (gst_element_create_all_pads): New function
4054         to create all the ALWAYS pads that are registered with an
4055         element class.  This functionality should eventually be
4056         merged in with GstElement initialization.
4057         * gst/gstutils.h:
4058         * testsuite/trigger/README: part of trigger test code that should
4059         have been checked in a long time ago.
4060
4061 2005-04-23  David Schleef  <ds@schleef.org>
4062
4063         * gst/Makefile.am: Remove as-libtool stuff.  It's likely not
4064         needed with new versions of libtool (nobody will confirm this),
4065         and hard to carry around.
4066         * gst/autoplug/Makefile.am:
4067         * gst/base/Makefile.am:
4068         * gst/elements/Makefile.am:
4069         * gst/indexers/Makefile.am:
4070         * gst/schedulers/Makefile.am:
4071         * libs/gst/bytestream/Makefile.am:
4072         * libs/gst/control/Makefile.am:
4073         * libs/gst/dataprotocol/Makefile.am:
4074         * libs/gst/getbits/Makefile.am:
4075
4076 2005-04-21  Wim Taymans  <wim@fluendo.com>
4077
4078         * docs/design/draft-push-pull.txt:
4079         * docs/design/part-MT-refcounting.txt:
4080         * docs/design/part-TODO.txt:
4081         * docs/design/part-caps.txt:
4082         * docs/design/part-events.txt:
4083         * docs/design/part-gstbus.txt:
4084         * docs/design/part-gstpipeline.txt:
4085         * docs/design/part-messages.txt:
4086         * docs/design/part-push-pull.txt:
4087         * docs/design/part-query.txt:
4088         Some more docs.
4089
4090 2005-04-21  Wim Taymans  <wim@fluendo.com>
4091
4092         * gst/gstmessage.c: (_gst_message_copy), (_gst_message_free),
4093         (gst_message_new), (gst_message_new_error),
4094         (gst_message_new_warning), (gst_message_new_tag),
4095         (gst_message_new_state_changed), (gst_message_new_application),
4096         (gst_message_get_structure):
4097         * gst/gstmessage.h:
4098         * gst/gststructure.c: (gst_structure_set_parent_refcount),
4099         (gst_structure_copy_conditional):
4100         Use parent refcount in GstMessage to ensure GstStructure
4101         consistency.
4102         Cleaned up headers a bit.
4103         
4104
4105 2005-04-20  Wim Taymans  <wim@fluendo.com>
4106
4107         * gst/base/gstbasesink.c: (gst_basesink_base_init),
4108         (gst_basesink_pad_getcaps), (gst_basesink_init),
4109         (gst_basesink_chain_unlocked):
4110         * gst/base/gsttypefindhelper.c: (helper_find_suggest),
4111         (gst_type_find_helper):
4112         * gst/elements/gsttypefindelement.c:
4113         (gst_type_find_element_have_type), (gst_type_find_element_init),
4114         (stop_typefinding), (gst_type_find_element_handle_event),
4115         (find_suggest), (gst_type_find_element_chain),
4116         (gst_type_find_element_checkgetrange),
4117         (gst_type_find_element_getrange), (do_typefind),
4118         (gst_type_find_element_activate):
4119         * gst/gstbuffer.c: (_gst_buffer_sub_free),
4120         (gst_buffer_default_free), (gst_buffer_default_copy),
4121         (gst_buffer_set_caps):
4122         * gst/gstcaps.c: (gst_caps_ref), (gst_caps_unref),
4123         (gst_caps_replace):
4124         * gst/gstmessage.c: (gst_message_new),
4125         (gst_message_new_state_changed):
4126         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
4127         (gst_pad_set_checkgetrange_function),
4128         (gst_pad_link_prepare_filtered), (gst_pad_relink_filtered),
4129         (gst_pad_set_caps), (gst_pad_check_pull_range),
4130         (gst_pad_pull_range), (gst_static_pad_template_get_caps):
4131         * gst/gstpad.h:
4132         * gst/gsttypefind.c: (gst_type_find_register):
4133         Make gst_caps_replace() work like other _replace() functions.
4134         Use _caps_replace() where possible.
4135         Make sure _message_new() initialises its field.
4136         Add gst_static_pad_template_get_caps()
4137
4138
4139 2005-04-18  Andy Wingo  <wingo@pobox.com>
4140
4141         * gst/gstelement.c (gst_element_pads_activate): Check pull_range
4142         on the peer, not the pad. I think that was a typo. Pass an extra
4143         arg to see if random access is possible. Activate the pads as
4144         PULL_RANGE if possible.
4145
4146         * gst/elements/gstfakesrc.c: s/ARG_/PROP_/.
4147
4148         * gst/base/gstbasesrc.c (gst_basesrc_set_property) 
4149         (gst_basesrc_get_property): BLOCKSIZE is a ULONG. Rename ARG_...
4150         to PROP_....
4151
4152 2005-04-14  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4153
4154         * docs/faq/using.xml:
4155           Add note on gstreamer-properties (#154996).
4156
4157 2005-04-13  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4158
4159         * docs/random/bbb/optional-properties:
4160           Some analysis on optional properties.
4161
4162 2005-04-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4163
4164         * docs/gst/tmpl/gstelementfactory.sgml:
4165         * gst/gstelement.h:
4166         * gst/gstelementfactory.c: (gst_element_factory_init),
4167         (gst_element_factory_cleanup), (gst_element_register),
4168         (__gst_element_factory_add_static_pad_template),
4169         (gst_element_factory_get_static_pad_templates),
4170         (gst_element_factory_can_src_caps),
4171         (gst_element_factory_can_sink_caps):
4172         * gst/registries/Makefile.am:
4173         * gst/registries/gstlibxmlregistry.c: (gst_xml_registry_get_type),
4174         (gst_xml_registry_class_init), (gst_xml_registry_init),
4175         (gst_xml_registry_new), (gst_xml_registry_set_property),
4176         (gst_xml_registry_get_property), (get_time), (make_dir),
4177         (gst_xml_registry_get_perms_func),
4178         (plugin_times_older_than_recurse), (plugin_times_older_than),
4179         (gst_xml_registry_open_func), (gst_xml_registry_load_func),
4180         (gst_xml_registry_save_func), (gst_xml_registry_close_func),
4181         (add_to_char_array), (read_string), (read_uint), (read_enum),
4182         (load_pad_template), (load_feature), (load_plugin), (load_paths),
4183         (gst_xml_registry_load), (gst_xml_registry_load_plugin),
4184         (gst_xml_registry_save_caps), (gst_xml_registry_save_pad_template),
4185         (gst_xml_registry_save_feature), (gst_xml_registry_save_plugin),
4186         (gst_xml_registry_save), (gst_xml_registry_rebuild_recurse),
4187         (gst_xml_registry_rebuild):
4188         * gst/registries/gstlibxmlregistry.h:
4189         * tools/gst-compprep.c: (main):
4190         * tools/gst-inspect.c: (print_pad_templates_info):
4191         * tools/gst-xmlinspect.c: (print_element_info):
4192           Use libxml2 for registry parsing, use staticpadtemplates in
4193           elementfactories. Makes gst_init() +/- 10x faster.
4194
4195 2005-04-12  Wim Taymans  <wim@fluendo.com>
4196
4197         * gst/base/Makefile.am:
4198         * gst/base/gstbasesink.c: (gst_basesink_base_init),
4199         (gst_basesink_pad_getcaps), (gst_basesink_init),
4200         (gst_basesink_event), (gst_basesink_change_state):
4201         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
4202         (gst_basesrc_init), (gst_basesrc_query),
4203         (gst_basesrc_get_event_mask), (gst_basesrc_do_seek),
4204         (gst_basesrc_event_handler), (gst_basesrc_get_range_unlocked),
4205         (gst_basesrc_check_get_range), (gst_basesrc_loop),
4206         (gst_basesrc_unlock), (gst_basesrc_get_size), (gst_basesrc_start),
4207         (gst_basesrc_stop), (gst_basesrc_activate),
4208         (gst_basesrc_change_state):
4209         * gst/base/gsttypefindhelper.c: (helper_find_peek),
4210         (helper_find_suggest), (gst_type_find_helper):
4211         * gst/base/gsttypefindhelper.h:
4212         * gst/elements/Makefile.am:
4213         * gst/elements/gstelements.c:
4214         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
4215         (gst_fakesink_get_times), (gst_fakesink_event),
4216         (gst_fakesink_preroll), (gst_fakesink_render):
4217         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
4218         (gst_fakesrc_init), (gst_fakesrc_event_handler),
4219         (gst_fakesrc_get_property), (gst_fakesrc_create),
4220         (gst_fakesrc_start), (gst_fakesrc_stop):
4221         * gst/elements/gstfakesrc.h:
4222         * gst/elements/gstfilesrc.c: (gst_filesrc_class_init),
4223         (gst_filesrc_free_parent_mmap), (gst_filesrc_map_region),
4224         (gst_filesrc_map_small_region), (gst_filesrc_create_mmap),
4225         (gst_filesrc_create_read), (gst_filesrc_create),
4226         (gst_filesrc_is_seekable), (gst_filesrc_get_size),
4227         (gst_filesrc_start):
4228         * gst/elements/gsttypefindelement.c:
4229         (gst_type_find_element_have_type), (gst_type_find_element_init),
4230         (start_typefinding), (stop_typefinding), (push_buffer_store),
4231         (gst_type_find_element_handle_event),
4232         (gst_type_find_element_chain),
4233         (gst_type_find_element_checkgetrange),
4234         (gst_type_find_element_getrange), (do_typefind),
4235         (gst_type_find_element_activate),
4236         (gst_type_find_element_change_state):
4237         * gst/elements/gsttypefindelement.h:
4238         * gst/gstpipeline.c: (pipeline_bus_handler):
4239         Added typefind helper.
4240         Small preroll fix in the base sink.
4241         Disable typefind code in basesrc.
4242         Crude port of typefindelement.
4243         Fakesrc cleanups.
4244
4245
4246 2005-04-11  Wim Taymans  <wim@fluendo.com>
4247
4248         * check/gst/gstbus.c: (gstbus_suite):
4249         * check/gst/gstdata.c: (thread_ref), (gst_data_suite):
4250         * check/gstcheck.h:
4251           Fix up the timeout so that the test does not fail.
4252
4253 2005-04-06  Wim Taymans  <wim@fluendo.com>
4254
4255         * gst/base/README:
4256         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
4257         (gst_basesrc_init), (gst_basesrc_get_formats), (gst_basesrc_query),
4258         (gst_basesrc_get_event_mask), (gst_basesrc_do_seek),
4259         (gst_basesrc_event_handler), (gst_basesrc_get_range_unlocked),
4260         (gst_basesrc_check_get_range), (gst_basesrc_loop),
4261         (gst_basesrc_unlock), (gst_basesrc_get_size), (gst_basesrc_start),
4262         (gst_basesrc_stop), (gst_basesrc_activate),
4263         (gst_basesrc_change_state), (basesrc_find_peek),
4264         (basesrc_find_suggest), (gst_basesrc_type_find):
4265         * gst/base/gstbasesrc.h:
4266         * gst/elements/gstfilesrc.c: (gst_filesrc_base_init),
4267         (gst_filesrc_class_init), (gst_filesrc_init),
4268         (gst_filesrc_finalize), (gst_filesrc_set_location),
4269         (gst_filesrc_set_property), (gst_filesrc_get_property),
4270         (gst_filesrc_free_parent_mmap), (gst_filesrc_map_region),
4271         (gst_filesrc_map_small_region), (gst_filesrc_create_mmap),
4272         (gst_filesrc_create_read), (gst_filesrc_create),
4273         (gst_filesrc_get_size), (gst_filesrc_start), (gst_filesrc_stop):
4274         * gst/elements/gstfilesrc.h:
4275         * gst/gstelement.c: (gst_element_get_state_func),
4276         (gst_element_lost_state), (gst_element_pads_activate):
4277         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
4278         (gst_pad_set_checkgetrange_function), (gst_pad_check_pull_range),
4279         (gst_pad_pull_range):
4280         * gst/gstpad.h:
4281         More work on the generic source base class, implement seeking,
4282         query.
4283         Make filesrc extend the base source class.
4284         Added gst_pad_set_checkgetrange_function to GstPad.
4285
4286 2005-04-06  Andy Wingo  <wingo@pobox.com>
4287
4288         * pkgconfig/gstreamer-base.pc.in:
4289         * pkgconfig/gstreamer-base-uninstalled.pc.in: New files.
4290
4291         * pkgconfig/Makefile.am:
4292         * configure.ac (AC_OUTPUT): Add gstreamer-base pkgconfig files.
4293
4294 2005-04-04  Wim Taymans  <wim@fluendo.com>
4295
4296         * gst/base/Makefile.am:
4297         * gst/base/README:
4298         * gst/base/gstbasesink.c: (gst_basesink_base_init),
4299         (gst_basesink_pad_getcaps), (gst_basesink_pad_setcaps),
4300         (gst_basesink_pad_buffer_alloc), (gst_basesink_init),
4301         (gst_basesink_do_sync), (gst_basesink_chain_unlocked):
4302         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
4303         (gst_basesrc_base_init), (gst_basesrc_class_init),
4304         (gst_basesrc_init), (gst_basesrc_get_formats),
4305         (gst_basesrc_get_query_types), (gst_basesrc_query),
4306         (gst_basesrc_get_event_mask), (gst_basesrc_event_handler),
4307         (gst_basesrc_set_property), (gst_basesrc_get_property),
4308         (gst_basesrc_get_range_unlocked), (gst_basesrc_get_range),
4309         (gst_basesrc_loop), (gst_basesrc_activate),
4310         (gst_basesrc_change_state):
4311         * gst/base/gstbasesrc.h:
4312         * gst/elements/gstfakesrc.c: (gst_fakesrc_base_init),
4313         (gst_fakesrc_class_init), (gst_fakesrc_init),
4314         (gst_fakesrc_event_handler), (gst_fakesrc_set_property),
4315         (gst_fakesrc_get_property), (gst_fakesrc_create):
4316         * gst/elements/gstfakesrc.h:
4317         * gst/elements/gstfilesrc.c: (gst_filesrc_getrange),
4318         (gst_filesrc_open_file), (gst_filesrc_loop),
4319         (gst_filesrc_activate), (filesrc_find_peek),
4320         (gst_filesrc_type_find):
4321         Made base source class, make fakesrc extend it.
4322         Add comments to basesink class.
4323         Some filesrc cleanup.
4324
4325 2005-03-31  David Schleef  <ds@schleef.org>
4326
4327         * gst/gstplugin.c: (gst_plugin_check_file), (gst_plugin_load_file):
4328         Switch to using G_MODULE_BIND_LOCAL, which means plugins are now
4329         expected to link against libgstreamer.
4330         * gst/base/Makefile.am: link against libgstreamer
4331         * gst/elements/Makefile.am: same
4332
4333 2005-03-31  Andy Wingo  <wingo@pobox.com>
4334
4335         * tests/instantiate/Makefile.am:
4336         * tests/instantiate/caps.c: Add test to test speed of caps copy
4337         and free.
4338
4339         * tests/memchunk/gmemchunktest.c (main): Use alloc only on the
4340         GMemChunk to be fair.
4341
4342         * gst/gsttrashstack.h: Remove warning about using the fallback
4343         trash stack implementation, it's still faster than malloc.
4344
4345 2005-03-30  Andy Wingo  <wingo@pobox.com>
4346
4347         * tests/complexity.c: Add a copyright.
4348
4349 2005-03-31  Wim Taymans  <wim@fluendo.com>
4350
4351         * gst/base/gstbasetransform.c: (gst_base_transform_base_init),
4352         (gst_base_transform_class_init), (gst_base_transform_init),
4353         (gst_base_transform_setcaps), (gst_base_transform_handle_buffer),
4354         (gst_base_transform_get_property),
4355         (gst_base_transform_sink_activate),
4356         (gst_base_transform_src_activate),
4357         (gst_base_transform_change_state):
4358         * gst/base/gstbasetransform.h:
4359         * gst/elements/gstidentity.c: (gst_identity_class_init),
4360         (gst_identity_event), (gst_identity_check_perfect),
4361         (gst_identity_transform), (gst_identity_start),
4362         (gst_identity_stop):
4363         Added start/stop methods to transform base class so subclasses 
4364         don't need to deal with state changes even.
4365
4366 2005-03-31  Wim Taymans  <wim@fluendo.com>
4367
4368         * gst/gstevent.c: (gst_event_new_discontinuous_valist),
4369         (gst_event_new_discontinuous), (gst_event_discont_get_value):
4370         * gst/gstevent.h:
4371         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
4372         (gst_pad_pull_range):
4373         Added rate to the discont event to prepare for variable speed
4374         and reverse playback.
4375
4376 2005-03-29  David Schleef  <ds@schleef.org>
4377
4378         * configure.ac:
4379         * testsuite/trigger/Makefile.am:
4380         * testsuite/trigger/trigger.c: A little example program to show
4381         how trigger-based elements can work.
4382
4383 2005-03-29  Wim Taymans  <wim@fluendo.com>
4384
4385         * gst/base/Makefile.am:
4386         * gst/base/README:
4387         * gst/base/gstbasesink.c: (gst_basesink_get_type),
4388         (gst_basesink_base_init), (gst_basesink_class_init),
4389         (gst_basesink_pad_getcaps), (gst_basesink_init),
4390         (gst_basesink_activate), (gst_basesink_change_state):
4391         * gst/base/gstbasesink.h:
4392         * gst/base/gstbasetransform.c: (gst_base_transform_get_type),
4393         (gst_base_transform_base_init), (gst_base_transform_finalize),
4394         (gst_base_transform_class_init), (gst_base_transform_init),
4395         (gst_base_transform_proxy_getcaps), (gst_base_transform_setcaps),
4396         (gst_base_transform_event), (gst_base_transform_getrange),
4397         (gst_base_transform_chain), (gst_base_transform_handle_buffer),
4398         (gst_base_transform_set_property),
4399         (gst_base_transform_get_property),
4400         (gst_base_transform_sink_activate),
4401         (gst_base_transform_src_activate),
4402         (gst_base_transform_change_state):
4403         * gst/base/gstbasetransform.h:
4404         * gst/elements/gstidentity.c: (gst_identity_finalize),
4405         (gst_identity_class_init), (gst_identity_init),
4406         (gst_identity_event), (gst_identity_check_perfect),
4407         (gst_identity_transform), (gst_identity_set_property),
4408         (gst_identity_get_property), (gst_identity_change_state):
4409         * gst/elements/gstidentity.h:
4410         * gst/gstelement.c: (gst_element_get_state_func),
4411         (gst_element_lost_state), (gst_element_pads_activate):
4412         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
4413         (gst_pad_check_pull_range), (gst_pad_pull_range):
4414         * gst/gstpad.h:
4415         Simplify pad activation.
4416         Added function to check if pull_range can be performed.
4417         Error out when pulling inactive or flushing pads.
4418         Removed const from refcounted types as it does not make sense.
4419         Simplify pad templates in basesink
4420         Added base class for simple 1-to-1 transforms.
4421         Make identity subclass the base transform.
4422
4423 2005-03-29  Andy Wingo  <wingo@pobox.com>
4424
4425         * docs/libs/gstreamer-libs-overrides.txt: 
4426         * docs/gst/gstreamer-overrides.txt: Add these files to CVS. Now I
4427         really don't understand what's going on, but like whatever. I want
4428         green buildbot!
4429
4430         * docs/gst/Makefile.am:
4431         * docs/libs/Makefile.am: Dist the overrides files.
4432
4433         * check/Makefile.am (clean-local): Remove .libs directories.
4434
4435         * gst/elements/Makefile.am (EXTRA_DIST): Add all the attic
4436         elements to EXTRA_DIST, so po/ files are happy.
4437
4438         * po/POTFILES.in: Er, remove it here.
4439
4440         * po/POTFILES: Remove gstspider.c.
4441
4442         * configure.ac (AC_OUTPUT): Add missing testsuite makefiles.
4443
4444         * docs/libs/gstreamer-libs-docs.sgml: 
4445         * docs/libs/gstreamer-libs-sections.txt: Remove the section on
4446         bytestream.
4447
4448         * tests/complexity.c (main): Set the length of the preroll queue
4449         on the sinks to prevent a lockup.
4450
4451         * libs/gst/dataprotocol/Makefile.am: 
4452         * libs/gst/dataprotocol/dataprotocol-test.c: Remove test, it's
4453         the same as the one in check/gst-libs/gdp.c.
4454
4455         * po/, docs/gst/: Commit automatic changes to docs and po files.
4456
4457         * gst/elements/Makefile.am (libgstelements_la_LDFLAGS): Link to
4458         the versioned libgstbase.
4459
4460         * check/Makefile.am: Depend on an unversioned gst-register, seems
4461         to make autoconf happier.
4462
4463         * gst/base/Makefile.am: Make libgstbase a versioned lib.
4464
4465 2005-03-28  Wim Taymans  <wim@fluendo.com>
4466
4467         * configure.ac:
4468         * docs/design/part-gstelement.txt:
4469         * docs/design/part-negotiation.txt:
4470         * docs/design/part-preroll.txt:
4471         * docs/design/part-scheduling.txt:
4472         * docs/design/part-states.txt:
4473         * gst/Makefile.am:
4474         * gst/base/Makefile.am:
4475         * gst/base/README:
4476         * gst/base/gstbasesink.c: (gst_basesink_get_template),
4477         (gst_basesink_base_init), (gst_basesink_class_init),
4478         (gst_basesink_pad_getcaps), (gst_basesink_pad_setcaps),
4479         (gst_basesink_pad_buffer_alloc), (gst_basesink_init),
4480         (gst_basesink_set_pad_functions),
4481         (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock),
4482         (gst_basesink_set_property), (gst_basesink_get_property),
4483         (gst_base_sink_get_template), (gst_base_sink_get_caps),
4484         (gst_base_sink_set_caps), (gst_base_sink_buffer_alloc),
4485         (gst_basesink_preroll_queue_push),
4486         (gst_basesink_preroll_queue_empty),
4487         (gst_basesink_preroll_queue_flush), (gst_basesink_finish_preroll),
4488         (gst_basesink_event), (gst_basesink_get_times),
4489         (gst_basesink_do_sync), (gst_basesink_handle_buffer),
4490         (gst_basesink_chain_unlocked), (gst_basesink_chain),
4491         (gst_basesink_loop), (gst_basesink_activate),
4492         (gst_basesink_change_state):
4493         * gst/base/gstbasesink.h:
4494         * gst/elements/Makefile.am:
4495         * gst/elements/gstfakesink.c: (gst_fakesink_base_init),
4496         (gst_fakesink_class_init), (gst_fakesink_init),
4497         (gst_fakesink_set_property), (gst_fakesink_get_property),
4498         (gst_fakesink_get_times), (gst_fakesink_event),
4499         (gst_fakesink_preroll), (gst_fakesink_render),
4500         (gst_fakesink_change_state):
4501         * gst/elements/gstfakesink.h:
4502         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_manager),
4503         (gst_bin_get_state), (gst_bin_change_state), (gst_bin_send_event):
4504         * gst/gstelement.c: (gst_element_add_pad),
4505         (gst_element_get_state_func), (gst_element_abort_state),
4506         (gst_element_commit_state), (gst_element_lost_state),
4507         (gst_element_set_state), (gst_element_pads_activate):
4508         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_event_default):
4509         * gst/gstpipeline.c: (gst_pipeline_send_event),
4510         (gst_pipeline_change_state):
4511         Added state change code.
4512         Added/updated docs.
4513         Added sink base class, make fakesink extend the base class.
4514         Small cleanups in GstPipeline.
4515
4516 2005-03-26  David Schleef  <ds@schleef.org>
4517
4518         * gst/Makefile.am: remove gstcpu.[ch].  The gst_cpu functionality
4519         is broken and should be implemented in a different library.
4520         * gst/gst.c: (init_post): don't call _gst_cpu_initialize()
4521         * gst/gst.h: remove gstcpu.h
4522         * gst/gstcpu.c: remove
4523         * gst/gstcpu.h: remove
4524         * gst/Makefile.am.future: Remove this file.  It's ancient.
4525
4526 2005-03-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4527
4528         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_manager),
4529         (gst_bin_send_event):
4530           Add default event/set_manager handlers. The set_manager handler
4531           takes care that the manager is distributed over kids that were
4532           already in the bin before the manager was set. The event handler
4533           is a utility virtual function that sends the event over all sinks,
4534           so that gst_element_send_event (bin, event); has the expected
4535           behaviour.
4536         * gst/gstpad.c: (gst_pad_event_default):
4537           Re-install default event handling for discontinuities, so that
4538           seeking works without requiring hacks in applications or extra
4539           code in sinks.
4540         * gst/gstpipeline.c: (gst_pipeline_class_init),
4541         (gst_pipeline_send_event):
4542           Half hack, half utility: set a pipeline to PAUSED for seek events,
4543           since that is the only way we can guarantee a/v sync. Means that
4544           you can do gst_element_seek (pipeline, method, pos); on a pipeline
4545           and it "just works".
4546
4547 2005-03-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4548
4549         * gst/gstpipeline.c: (gst_pipeline_use_clock):
4550           Lock/unlock mismatch.
4551
4552 2005-03-25  Thomas Vander Stichele  <thomas at apestaart dot org>
4553
4554         * docs/faq/gst-uninstalled:
4555           add gst-plugins-base
4556         * docs/gst/Makefile.am:
4557           don't error out until docs are fixed
4558         * docs/gst/gstreamer.types:
4559           remove thread
4560
4561 2005-03-22  Wim Taymans  <wim@fluendo.com>
4562
4563         * check/Makefile.am:
4564         * check/gst/gstmessage.c: (START_TEST), (gst_data_suite), (main):
4565         * gst/gststructure.c: (gst_structure_set_valist),
4566         (gst_structure_copy_conditional):
4567         Activated more tests.
4568         Added message test.
4569         Added G_TYPE_POINTER to GstStructure.
4570         
4571
4572 2005-03-22  Wim Taymans  <wim@fluendo.com>
4573
4574         * docs/design/part-TODO.txt:
4575         * docs/design/part-events.txt:
4576         * docs/design/part-gstbin.txt:
4577         * docs/design/part-gstbus.txt:
4578         * docs/design/part-gstpipeline.txt:
4579         * docs/design/part-messages.txt:
4580         * gst/gstbus.c:
4581         * gst/gstmessage.c:
4582         Docs updates
4583
4584 2005-03-21  Wim Taymans  <wim@fluendo.com>
4585
4586         * gst/gstbus.c: (gst_bus_post):
4587         Fix copy-and-paste error.
4588
4589 2005-03-21  Wim Taymans  <wim@fluendo.com>
4590
4591         * check/Makefile.am:
4592         * gst/Makefile.am:
4593         * gst/elements/Makefile.am:
4594         * gst/elements/gstelements.c:
4595         * gst/elements/gstfakesink.c: (gst_fakesink_init),
4596         (gst_fakesink_event), (gst_fakesink_chain):
4597         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
4598         (gst_fakesrc_init), (gst_fakesrc_get_event_mask),
4599         (gst_fakesrc_event_handler), (gst_fakesrc_set_pad_functions),
4600         (gst_fakesrc_set_all_pad_functions), (gst_fakesrc_request_new_pad),
4601         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
4602         (gst_fakesrc_get_range_unlocked), (gst_fakesrc_get_range),
4603         (gst_fakesrc_loop), (gst_fakesrc_activate),
4604         (gst_fakesrc_change_state):
4605         * gst/elements/gstfakesrc.h:
4606         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
4607         (gst_filesrc_get_read), (gst_filesrc_getrange), (gst_filesrc_get),
4608         (gst_filesrc_open_file), (gst_filesrc_loop),
4609         (gst_filesrc_activate), (gst_filesrc_change_state),
4610         (filesrc_find_peek), (filesrc_find_suggest),
4611         (gst_filesrc_type_find):
4612         * gst/elements/gstidentity.c: (gst_identity_finalize),
4613         (gst_identity_class_init), (gst_identity_init),
4614         (gst_identity_proxy_getcaps), (identity_queue_push),
4615         (identity_queue_pop), (identity_queue_flush), (gst_identity_event),
4616         (gst_identity_getrange), (gst_identity_chain),
4617         (gst_identity_sink_loop), (gst_identity_src_loop),
4618         (gst_identity_handle_buffer), (gst_identity_set_dataflow_funcs),
4619         (gst_identity_set_property), (gst_identity_get_property),
4620         (gst_identity_change_state):
4621         * gst/elements/gstidentity.h:
4622         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_init),
4623         (gst_tee_update_pad_functions), (gst_tee_request_new_pad),
4624         (gst_tee_set_property), (gst_tee_get_property), (gst_tee_do_push),
4625         (gst_tee_handle_buffer), (gst_tee_chain), (gst_tee_loop),
4626         (gst_tee_sink_activate):
4627         * gst/elements/gsttee.h:
4628         * gst/gst.c: (gst_register_core_elements), (init_post):
4629         * gst/gst.h:
4630         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_bus),
4631         (gst_bin_set_scheduler), (gst_bin_add_func), (gst_bin_add),
4632         (gst_bin_remove_func), (gst_bin_remove), (gst_bin_get_state),
4633         (gst_bin_change_state):
4634         * gst/gstbin.h:
4635         * gst/gstbus.c: (gst_bus_get_type), (gst_bus_class_init),
4636         (gst_bus_init), (gst_bus_dispose), (gst_bus_set_property),
4637         (gst_bus_get_property), (gst_bus_new), (gst_bus_post),
4638         (gst_bus_have_pending), (gst_bus_pop), (gst_bus_peek),
4639         (gst_bus_set_sync_handler), (gst_bus_create_watch),
4640         (bus_watch_callback), (bus_watch_destroy),
4641         (gst_bus_add_watch_full), (gst_bus_add_watch), (poll_handler),
4642         (poll_timeout), (gst_bus_poll):
4643         * gst/gstbus.h:
4644         * gst/gstcaps.h:
4645         * gst/gstdata.h:
4646         * gst/gstelement.c: (gst_element_class_init), (gst_element_init),
4647         (gst_element_post_message), (gst_element_message_full),
4648         (gst_element_get_state_func), (gst_element_get_state),
4649         (gst_element_abort_state), (gst_element_commit_state),
4650         (gst_element_lost_state), (gst_element_set_state),
4651         (gst_element_pads_activate), (gst_element_change_state),
4652         (gst_element_dispose), (gst_element_set_manager_func),
4653         (gst_element_set_bus_func), (gst_element_set_scheduler_func),
4654         (gst_element_set_manager), (gst_element_get_manager),
4655         (gst_element_set_bus), (gst_element_get_bus),
4656         (gst_element_set_scheduler), (gst_element_get_scheduler):
4657         * gst/gstelement.h:
4658         * gst/gstevent.c: (gst_event_new_segment_seek),
4659         (gst_event_new_flush):
4660         * gst/gstevent.h:
4661         * gst/gstmessage.c: (_gst_message_initialize), (_gst_message_copy),
4662         (_gst_message_free), (gst_message_get_type), (gst_message_new),
4663         (gst_message_new_eos), (gst_message_new_error),
4664         (gst_message_new_warning), (gst_message_new_tag),
4665         (gst_message_new_state_changed), (gst_message_new_application),
4666         (gst_message_get_structure), (gst_message_parse_tag),
4667         (gst_message_parse_state_changed), (gst_message_parse_error),
4668         (gst_message_parse_warning):
4669         * gst/gstmessage.h:
4670         * gst/gstpad.c: (gst_real_pad_class_init), (gst_real_pad_init),
4671         (gst_real_pad_set_property), (gst_pad_set_active),
4672         (gst_pad_is_active), (gst_pad_set_blocked_async),
4673         (gst_pad_set_blocked), (gst_pad_is_blocked),
4674         (gst_pad_set_activate_function), (gst_pad_set_loop_function),
4675         (gst_pad_set_getrange_function), (gst_pad_set_acceptcaps_function),
4676         (gst_pad_set_fixatecaps_function), (gst_pad_set_setcaps_function),
4677         (gst_pad_unlink), (gst_pad_link_prepare_filtered),
4678         (gst_pad_link_filtered), (gst_pad_relink_filtered),
4679         (gst_real_pad_get_caps_unlocked), (gst_pad_get_caps),
4680         (gst_pad_peer_get_caps), (gst_pad_fixate_caps),
4681         (gst_pad_accept_caps), (gst_pad_peer_accept_caps),
4682         (gst_pad_set_caps), (gst_pad_configure_sink),
4683         (gst_pad_configure_src), (gst_pad_get_negotiated_caps),
4684         (gst_pad_get_filter_caps), (gst_pad_alloc_buffer),
4685         (gst_real_pad_dispose), (gst_real_pad_finalize),
4686         (handle_pad_block), (gst_pad_push), (gst_pad_pull_range),
4687         (gst_pad_event_default_dispatch), (gst_pad_event_default),
4688         (gst_pad_push_event), (gst_pad_send_event), (gst_pad_get_formats):
4689         * gst/gstpad.h:
4690         * gst/gstpipeline.c: (gst_pipeline_init), (is_eos),
4691         (pipeline_bus_handler), (gst_pipeline_change_state),
4692         (gst_pipeline_get_scheduler), (gst_pipeline_get_bus):
4693         * gst/gstpipeline.h:
4694         * gst/gstprobe.h:
4695         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_init),
4696         (gst_queue_finalize), (gst_queue_getcaps), (gst_queue_link_sink),
4697         (gst_queue_link_src), (gst_queue_bufferalloc),
4698         (gst_queue_locked_flush), (gst_queue_handle_sink_event),
4699         (gst_queue_is_empty), (gst_queue_is_filled), (gst_queue_chain),
4700         (gst_queue_loop), (gst_queue_handle_src_event),
4701         (gst_queue_handle_src_query), (gst_queue_src_activate),
4702         (gst_queue_change_state):
4703         * gst/gstqueue.h:
4704         * gst/gstscheduler.c: (gst_scheduler_init),
4705         (gst_scheduler_dispose), (gst_scheduler_create_task),
4706         (gst_scheduler_factory_create):
4707         * gst/gstscheduler.h:
4708         * gst/gststructure.c: (gst_structure_get_type),
4709         (gst_structure_copy_conditional):
4710         * gst/gststructure.h:
4711         * gst/gsttaginterface.h:
4712         * gst/gsttask.c: (gst_task_get_type), (gst_task_class_init),
4713         (gst_task_init), (gst_task_dispose), (gst_task_create),
4714         (gst_task_get_state), (gst_task_start), (gst_task_stop),
4715         (gst_task_pause):
4716         * gst/gsttask.h:
4717         * gst/gstthread.c:
4718         * gst/gstthread.h:
4719         * gst/gsttypes.h:
4720         * gst/schedulers/Makefile.am:
4721         * gst/schedulers/cothreads_compat.h:
4722         * gst/schedulers/entryscheduler.c:
4723         * gst/schedulers/faircothreads.c:
4724         * gst/schedulers/faircothreads.h:
4725         * gst/schedulers/fairscheduler.c:
4726         * gst/schedulers/gstbasicscheduler.c:
4727         * gst/schedulers/gstoptimalscheduler.c:
4728         * gst/schedulers/gthread-cothreads.h:
4729         * gst/schedulers/threadscheduler.c:
4730         (gst_thread_scheduler_task_get_type),
4731         (gst_thread_scheduler_task_class_init),
4732         (gst_thread_scheduler_task_init),
4733         (gst_thread_scheduler_task_start),
4734         (gst_thread_scheduler_task_stop),
4735         (gst_thread_scheduler_task_pause), (gst_thread_scheduler_get_type),
4736         (gst_thread_scheduler_class_init), (gst_thread_scheduler_func),
4737         (gst_thread_scheduler_init), (gst_thread_scheduler_create_task),
4738         (gst_thread_scheduler_setup), (gst_thread_scheduler_reset),
4739         (plugin_init):
4740         * libs/gst/Makefile.am:
4741         * libs/gst/bytestream/bytestream.c: (gst_bytestream_get_next_buf):
4742         * libs/gst/bytestream/filepad.c: (gst_file_pad_init),
4743         (gst_file_pad_parent_set):
4744         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_event),
4745         (gst_dp_event_from_packet):
4746         * tests/complexity.c: (main):
4747         * tests/mass_elements.c: (main):
4748         * testsuite/states/locked.c: (message_received), (main):
4749         * testsuite/states/parent.c: (main):
4750         * tools/gst-inspect.c: (print_element_flag_info),
4751         (print_implementation_info), (print_pad_info):
4752         * tools/gst-launch.c: (check_intr), (play_handler), (event_loop),
4753         (main):
4754         * tools/gst-md5sum.c: (event_loop), (main):
4755         * tools/gst-typefind.c: (main):
4756         * tools/gst-xmlinspect.c: (print_element_info):
4757         Next big merge.
4758         Added GstBus for mainloop integration.
4759         Added GstMessage for sending notifications on the bus.
4760         Added GstTask as an abstraction for pipeline entry points.
4761         Removed GstThread.
4762         Removed Schedulers.
4763         Simplified GstQueue for multithreaded core.
4764         Made _link threadsafe, removed old capsnego.
4765         Added STREAM_LOCK and PREROLL_LOCK in GstPad.
4766         Added pad blocking functions.
4767         Reworked scheduling functions in GstPad to prepare for
4768         scheduling updates soon.
4769         Moved events out of data stream.
4770         Simplified GstEvent types.
4771         Added return values to push/pull.
4772         Removed clocking from GstElement.
4773         Added prototypes for state change function for next merge.
4774         Removed iterate from bins and state change management.
4775         Fixed some elements, disabled others for now.
4776         Fixed -inspect and -launch.
4777         Added check for GstBus.
4778
4779 2005-03-10  Wim Taymans  <wim@fluendo.com>
4780
4781         * docs/design/part-MT-refcounting.txt:
4782         * docs/design/part-clocks.txt:
4783         * docs/design/part-gstelement.txt:
4784         * docs/design/part-gstobject.txt:
4785         * docs/design/part-standards.txt:
4786         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
4787         (gst_bin_remove_func), (gst_bin_remove):
4788         * gst/gstbin.h:
4789         * gst/gstbuffer.c:
4790         * gst/gstcaps.h:
4791         * testsuite/clock/clock1.c: (main):
4792         * testsuite/clock/clock2.c: (gst_clock_debug), (element_wait),
4793         (main):
4794         * testsuite/dlopen/loadgst.c: (do_test):
4795         * testsuite/refcounting/bin.c: (add_remove_test1),
4796         (add_remove_test2), (main):
4797         * testsuite/refcounting/element.c: (main):
4798         * testsuite/refcounting/element_pad.c: (main):
4799         * testsuite/refcounting/pad.c: (main):
4800         * tools/gst-launch.c: (sigint_handler_sighandler):
4801         * tools/gst-typefind.c: (main):
4802         Doc updates.
4803         Added doc about clock.
4804         removed gst_bin_iterate_recurse_up(), marked methods
4805         for removal.
4806         Fix more testsuites.
4807
4808 2005-03-09  Wim Taymans  <wim@fluendo.com>
4809
4810         * gst/gstpad.c: (gst_pad_get_direction),
4811         (_gst_pad_default_fixate_foreach), (gst_pad_collectv),
4812         (gst_pad_collect_valist):
4813         * testsuite/bins/interface.c: (main):
4814         * testsuite/caps/audioscale.c: (test_caps):
4815         * testsuite/caps/caps.c: (test1), (test2), (test3):
4816         * testsuite/caps/deserialize.c: (main):
4817         * testsuite/caps/enumcaps.c: (main):
4818         * testsuite/caps/filtercaps.c: (main):
4819         * testsuite/caps/intersect2.c: (main):
4820         * testsuite/caps/random.c: (main):
4821         * testsuite/caps/renegotiate.c: (my_fixate), (main):
4822         * testsuite/caps/sets.c: (check_caps):
4823         * testsuite/caps/simplify.c: (check_caps), (main):
4824         * testsuite/caps/subtract.c: (check_caps):
4825         Fix _pad_get_direction wrt ghostpads.
4826         Fix caps testsuite.
4827
4828 2005-03-09  Wim Taymans  <wim@fluendo.com>
4829
4830         * check/Makefile.am:
4831         * check/gst/gstbin.c: (START_TEST), (gst_bin_suite), (main):
4832         * check/gst/gstsystemclock.c: (START_TEST), (gst_clock_debug),
4833         (ok_callback), (error_callback), (gst_systemclock_suite), (main):
4834         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_index_func),
4835         (gst_bin_set_clock_func), (gst_bin_get_clock_func),
4836         (gst_bin_add_func), (gst_bin_add), (gst_bin_remove_func),
4837         (gst_bin_remove), (gst_bin_iterate_recurse_up),
4838         (bin_element_is_sink), (gst_bin_iterate_sinks),
4839         (gst_bin_iterate_all_by_interface):
4840         * gst/gstbin.h:
4841         * gst/gstelement.c: (gst_element_init), (gst_element_error_full),
4842         (gst_element_change_state), (gst_element_dispose),
4843         (gst_element_finalize), (gst_element_set_loop_function):
4844         * gst/gstelement.h:
4845         * gst/gstiterator.c: (find_custom_fold_func):
4846         * gst/gstpad.c: (_gst_pad_default_fixate_foreach),
4847         (gst_pad_collectv), (gst_pad_collect_valist),
4848         (gst_pad_template_new):
4849         * gst/gstpipeline.c: (gst_pipeline_class_init),
4850         (gst_pipeline_dispose), (gst_pipeline_set_property),
4851         (gst_pipeline_get_property), (gst_pipeline_get_clock_func),
4852         (gst_pipeline_get_clock), (gst_pipeline_use_clock),
4853         (gst_pipeline_set_clock), (gst_pipeline_auto_clock):
4854         * gst/gstutils.h:
4855         * gst/schedulers/entryscheduler.c:
4856         * gst/schedulers/gstbasicscheduler.c:
4857         (gst_basic_scheduler_cothreaded_chain),
4858         (gst_basic_scheduler_chain_add_element):
4859         * testsuite/bins/interface.c: (main):
4860         Added GstBin test.
4861         Added GstSystemClock test.
4862         Implemented clock distribution code in GstBin.
4863         Implemented iterate sinks method for future use.
4864         Rearranged gstelement.h
4865         Fix GstIterator comparison bug.
4866         Moved some code to GstPipeline, mostly clocking related.
4867
4868 2005-03-09  Wim Taymans  <wim@fluendo.com>
4869
4870         * configure.ac:
4871         * gst/gst_private.h:
4872         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
4873         (gst_bin_remove_func), (gst_bin_remove),
4874         (gst_bin_get_by_name_recurse_up):
4875         * gst/gstclock.c: (gst_clock_id_ref), (gst_clock_id_unref),
4876         (gst_clock_id_compare_func), (gst_clock_id_wait),
4877         (gst_clock_id_wait_async), (gst_clock_init),
4878         (gst_clock_adjust_unlocked), (gst_clock_get_time):
4879         * gst/gstelement.h:
4880         * gst/gstinfo.c: (_gst_debug_init):
4881         * gst/gstobject.h:
4882         * gst/gstpad.c: (_gst_pad_default_fixate_foreach),
4883         (gst_pad_collectv), (gst_pad_collect_valist), (gst_pad_query):
4884         * gst/gstpad.h:
4885         Bump version number, we're now 0.9.0
4886         Add future debugging category.
4887         Fix NULL _unref() in _get_by_name_recurse_up
4888         Rearrange gstpad.h.
4889         Update some docs.
4890
4891 2005-03-08  Wim Taymans  <wim@fluendo.com>
4892
4893         * gst/elements/gstaggregator.c: (gst_aggregator_class_init):
4894         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
4895         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
4896         * gst/elements/gstfdsink.c: (gst_fdsink_class_init):
4897         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init):
4898         * gst/elements/gstfilesink.c: (gst_filesink_class_init):
4899         * gst/elements/gstfilesrc.c: (gst_filesrc_class_init):
4900         * gst/elements/gstidentity.c: (gst_identity_class_init):
4901         * gst/elements/gstmd5sink.c: (gst_md5sink_class_init):
4902         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
4903         * gst/elements/gstshaper.c: (gst_shaper_class_init):
4904         * gst/elements/gststatistics.c: (gst_statistics_class_init):
4905         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_getcaps),
4906         (gst_tee_link):
4907         * gst/gstelement.c: (gst_element_class_init),
4908         (gst_element_base_class_init), (gst_element_init),
4909         (gst_element_get_random_pad), (gst_element_wait_state_change),
4910         (gst_element_change_state), (gst_element_dispose),
4911         (gst_element_finalize), (gst_element_set_loop_function):
4912         * gst/gstelement.h:
4913         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_link_src):
4914         * gst/gstthread.c: (gst_thread_class_init),
4915         (gst_thread_release_children_locks), (gst_thread_change_state):
4916         * gst/schedulers/gstbasicscheduler.c:
4917         (gst_basic_scheduler_loopfunc_wrapper),
4918         (gst_basic_scheduler_chain_wrapper),
4919         (gst_basic_scheduler_src_wrapper),
4920         (gst_basic_scheduler_remove_element):
4921         * gst/schedulers/gstoptimalscheduler.c: (schedule_group):
4922         Remove threadsafe properties. Fix elements because GObject
4923         complains when installing a property before declaring a
4924         set/get_property handler.
4925         Rearrange gstelement.h file, use STATE macros for state locks.
4926         Free mutexes in the finalize method instead of dispose.
4927
4928 2005-03-08  Wim Taymans  <wim@fluendo.com>
4929
4930         * check/gst/gstobject.c: (START_TEST), (gst_object_suite):
4931         * gst/gstthread.c: (gst_thread_release_children_locks):
4932         Added parentage check.
4933         Fix build og GstThread again.
4934
4935 2005-03-08  Wim Taymans  <wim@fluendo.com>
4936
4937         * docs/design/part-MT-refcounting.txt:
4938         * docs/design/part-conventions.txt:
4939         * docs/design/part-gstobject.txt:
4940         * docs/design/part-relations.txt:
4941         * docs/design/part-standards.txt:
4942         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
4943         (gst_bin_remove_func), (gst_bin_remove), (gst_bin_iterate_recurse),
4944         (gst_bin_get_by_name), (gst_bin_get_by_interface),
4945         (gst_bin_iterate_all_by_interface):
4946         * gst/gstbuffer.h:
4947         * gst/gstclock.h:
4948         * gst/gstelement.c: (gst_element_class_init),
4949         (gst_element_change_state), (gst_element_set_loop_function):
4950         * gst/gstelement.h:
4951         * gst/gstiterator.c:
4952         * gst/gstobject.c: (gst_object_class_init), (gst_object_ref),
4953         (gst_object_unref), (gst_object_sink), (gst_object_dispose),
4954         (gst_object_dispatch_properties_changed), (gst_object_set_name),
4955         (gst_object_set_parent), (gst_object_unparent),
4956         (gst_object_check_uniqueness):
4957         * gst/gstobject.h:
4958         Docs updates, clean up some headers.
4959
4960 2005-03-07  Wim Taymans  <wim@fluendo.com>
4961
4962         * check/.cvsignore:
4963         * check/Makefile.am:
4964         * check/gst-libs/.cvsignore:
4965         * check/gst-libs/gdp.c: (START_TEST), (gst_object_suite), (main):
4966         * check/gst/.cvsignore:
4967         * check/gst/gstbus.c: (pound_bus_with_messages), (pull_messages),
4968         (START_TEST), (gstbus_suite), (main):
4969         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite), (main):
4970         * check/gst/gstdata.c: (START_TEST), (thread_ref), (thread_unref),
4971         (gst_data_suite), (main):
4972         * check/gst/gstiterator.c: (make_list_of_ints), (START_TEST),
4973         (add_fold_func), (gstiterator_suite), (main):
4974         * check/gst/gstobject.c: (gst_fake_object_get_type), (START_TEST),
4975         (thread_name_object), (thread_name_object_default),
4976         (gst_object_name_compare), (gst_object_suite), (main):
4977         * check/gst/gstpad.c: (START_TEST), (thread_link_unlink),
4978         (gst_pad_suite), (main):
4979         * check/gstcheck.c: (gst_check_log_message_func),
4980         (gst_check_log_critical_func), (gst_check_init):
4981         * check/gstcheck.h:
4982         * check/pipelines/simple_launch_lines.c: (setup_pipeline),
4983         (run_pipeline), (START_TEST), (simple_launch_lines_suite), (main):
4984         Added checks.
4985
4986 2005-03-07  Wim Taymans  <wim@fluendo.com>
4987
4988         * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new),
4989         (gst_list_iterator_next), (gst_list_iterator_resync),
4990         (gst_list_iterator_free), (gst_iterator_new_list),
4991         (gst_iterator_pop), (gst_iterator_next), (gst_iterator_resync),
4992         (gst_iterator_free), (gst_iterator_push), (filter_next),
4993         (filter_resync), (filter_uninit), (filter_free),
4994         (gst_iterator_filter), (gst_iterator_fold), (foreach_fold_func),
4995         (gst_iterator_foreach), (find_custom_fold_func),
4996         (gst_iterator_find_custom):
4997         * gst/gstiterator.h:
4998         Added missing files.
4999
5000 2005-03-07  Wim Taymans  <wim@fluendo.com>
5001
5002         * Makefile.am:
5003         * configure.ac:
5004         * docs/design/part-MT-refcounting.txt:
5005         * docs/design/part-conventions.txt:
5006         * docs/design/part-gstobject.txt:
5007         * docs/design/part-relations.txt:
5008         * examples/mixer/mixer.c: (main):
5009         * examples/thread/thread.c: (eos), (main):
5010         * gst/Makefile.am:
5011         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_caps_intersect):
5012         * gst/autoplug/gstspider.c: (gst_spider_identity_plug),
5013         (gst_spider_plug_from_srcpad):
5014         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_getcaps),
5015         (gst_spider_identity_change_state),
5016         (gst_spider_identity_sink_loop_type_finding):
5017         * gst/elements/gstfakesrc.c: (gst_fakesrc_loop):
5018         * gst/elements/gstidentity.c: (gst_identity_init):
5019         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_getcaps),
5020         (gst_tee_link), (gst_tee_request_new_pad), (gst_tee_chain):
5021         * gst/elements/gsttypefindelement.c: (free_entry):
5022         * gst/gst.c:
5023         * gst/gst.h:
5024         * gst/gstbin.c: (gst_bin_init), (gst_bin_get_clock_func),
5025         (gst_bin_set_clock_func), (gst_bin_auto_clock),
5026         (gst_bin_set_index), (gst_bin_set_element_sched),
5027         (gst_bin_unset_element_sched), (gst_bin_add_func), (gst_bin_add),
5028         (gst_bin_remove_func), (gst_bin_remove), (iterate_child),
5029         (gst_bin_iterate_elements), (iterate_child_recurse),
5030         (gst_bin_iterate_recurse), (gst_bin_dispose), (compare_name),
5031         (gst_bin_get_by_name), (gst_bin_get_by_name_recurse_up),
5032         (compare_interface), (gst_bin_get_by_interface),
5033         (gst_bin_iterate_all_by_interface), (gst_bin_iterate_func):
5034         * gst/gstbin.h:
5035         * gst/gstbuffer.c: (gst_buffer_get_type), (_gst_buffer_sub_free),
5036         (gst_buffer_default_free), (gst_buffer_default_copy),
5037         (gst_buffer_new), (gst_buffer_get_caps), (gst_buffer_set_caps),
5038         (gst_buffer_create_sub):
5039         * gst/gstbuffer.h:
5040         * gst/gstcaps.c: (gst_caps_get_type), (gst_caps_new_empty),
5041         (_gst_caps_free), (gst_caps_make_writable), (gst_caps_ref),
5042         (gst_caps_unref), (gst_static_caps_get),
5043         (gst_caps_remove_and_get_structure), (gst_caps_append),
5044         (gst_caps_append_structure), (gst_caps_remove_structure),
5045         (gst_caps_copy_nth), (gst_caps_set_simple),
5046         (gst_caps_set_simple_valist), (gst_caps_is_fixed_foreach),
5047         (gst_structure_is_equal_foreach), (gst_caps_is_subset),
5048         (gst_caps_structure_intersect_field), (gst_caps_intersect),
5049         (gst_caps_structure_subtract_field), (gst_caps_subtract),
5050         (gst_caps_normalize_foreach), (gst_caps_compare_structures),
5051         (gst_caps_structure_figure_out_union),
5052         (gst_caps_switch_structures), (gst_caps_do_simplify),
5053         (gst_caps_replace), (gst_caps_from_string),
5054         (gst_caps_copy_conditional):
5055         * gst/gstcaps.h:
5056         * gst/gstclock.c: (gst_clock_entry_new), (gst_clock_id_ref),
5057         (_gst_clock_id_free), (gst_clock_id_unref),
5058         (gst_clock_id_compare_func), (gst_clock_id_wait),
5059         (gst_clock_id_wait_async), (gst_clock_class_init),
5060         (gst_clock_init), (gst_clock_dispose), (gst_clock_adjust_unlocked),
5061         (gst_clock_get_time), (gst_clock_set_time_adjust),
5062         (gst_clock_set_property), (gst_clock_get_property):
5063         * gst/gstclock.h:
5064         * gst/gstcompat.h:
5065         * gst/gstcpu.c: (_gst_cpu_initialize_i386), (gst_cpu_get_flags):
5066         * gst/gstdata.c: (gst_data_is_writable), (gst_data_copy_on_write):
5067         * gst/gstdata.h:
5068         * gst/gstelement.c: (gst_element_class_init), (gst_element_init),
5069         (gst_element_requires_clock), (gst_element_provides_clock),
5070         (gst_element_set_clock), (gst_element_clock_wait),
5071         (gst_element_wait), (gst_element_set_time_delay),
5072         (gst_element_is_indexable), (gst_element_add_pad),
5073         (gst_element_add_ghost_pad), (gst_element_remove_pad),
5074         (pad_compare_name), (gst_element_get_static_pad),
5075         (gst_element_request_pad), (gst_element_get_request_pad),
5076         (gst_element_get_pad), (iterate_pad), (gst_element_iterate_pads),
5077         (gst_element_class_get_pad_template_list),
5078         (gst_element_class_get_pad_template), (gst_element_error_func),
5079         (gst_element_get_random_pad), (gst_element_get_event_masks),
5080         (gst_element_send_event), (gst_element_seek),
5081         (gst_element_get_query_types), (gst_element_query),
5082         (gst_element_get_formats), (gst_element_convert),
5083         (gst_element_is_locked_state), (gst_element_set_locked_state),
5084         (gst_element_sync_state_with_parent), (gst_element_change_state),
5085         (gst_element_finalize), (gst_element_yield),
5086         (gst_element_interrupt), (gst_element_set_scheduler),
5087         (gst_element_get_scheduler), (gst_element_set_loop_function):
5088         * gst/gstelement.h:
5089         * gst/gstevent.h:
5090         * gst/gstformat.c: (_gst_format_initialize), (gst_format_register),
5091         (gst_format_get_by_nick), (gst_format_get_details),
5092         (gst_format_iterate_definitions):
5093         * gst/gstformat.h:
5094         * gst/gstindex.c: (gst_index_gtype_resolver):
5095         * gst/gstinfo.c:
5096         * gst/gstinfo.h:
5097         * gst/gstmemchunk.c: (gst_mem_chunk_alloc), (gst_mem_chunk_alloc0),
5098         (gst_mem_chunk_free):
5099         * gst/gstobject.c: (gst_object_class_init), (gst_object_init),
5100         (gst_object_ref), (gst_object_unref), (gst_object_sink),
5101         (gst_object_replace), (gst_object_dispose), (gst_object_finalize),
5102         (gst_object_dispatch_properties_changed),
5103         (gst_object_set_name_default), (gst_object_set_name),
5104         (gst_object_get_name), (gst_object_set_name_prefix),
5105         (gst_object_get_name_prefix), (gst_object_set_parent),
5106         (gst_object_get_parent), (gst_object_unparent),
5107         (gst_object_check_uniqueness), (gst_object_save_thyself),
5108         (gst_object_restore_thyself), (gst_object_real_restore_thyself),
5109         (gst_object_set_property), (gst_object_get_property),
5110         (gst_object_get_path_string):
5111         * gst/gstobject.h:
5112         * gst/gstpad.c: (gst_pad_dispose), (gst_real_pad_class_init),
5113         (gst_real_pad_init), (gst_real_pad_get_property),
5114         (gst_pad_custom_new), (gst_pad_get_direction),
5115         (gst_pad_set_active), (gst_pad_is_active),
5116         (gst_pad_set_event_function), (gst_pad_is_linked),
5117         (gst_pad_link_free), (gst_pad_link_intersect),
5118         (gst_pad_link_fixate), (gst_pad_set_caps),
5119         (gst_pad_try_set_caps_nonfixed), (gst_pad_set_pad_template),
5120         (gst_pad_get_real_parent), (gst_pad_add_ghost_pad),
5121         (gst_pad_remove_ghost_pad), (_gst_pad_default_fixate_foreach),
5122         (gst_pad_link_unnegotiate), (gst_pad_proxy_fixate),
5123         (gst_pad_get_caps), (gst_pad_peer_get_caps),
5124         (gst_pad_get_pad_template_caps), (gst_pad_get_peer),
5125         (gst_pad_realize), (gst_pad_get_allowed_caps),
5126         (gst_real_pad_dispose), (gst_real_pad_finalize),
5127         (gst_pad_collectv), (gst_pad_collect_valist),
5128         (gst_pad_template_dispose), (gst_pad_template_new),
5129         (gst_pad_get_internal_links):
5130         * gst/gstpad.h:
5131         * gst/gstpipeline.c: (gst_pipeline_dispose),
5132         (gst_pipeline_change_state):
5133         * gst/gstpipeline.h:
5134         * gst/gstplugin.c:
5135         * gst/gstpluginfeature.c: (gst_plugin_feature_get_name),
5136         (gst_plugin_feature_set_rank), (gst_plugin_feature_get_rank):
5137         * gst/gstpluginfeature.h:
5138         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
5139         * gst/gstquery.c: (_gst_query_type_initialize),
5140         (gst_query_type_register), (gst_query_type_get_by_nick),
5141         (gst_query_type_get_details), (gst_query_type_iterate_definitions):
5142         * gst/gstquery.h:
5143         * gst/gstqueue.c: (gst_queue_link_sink), (gst_queue_link_src):
5144         * gst/gstscheduler.c: (gst_scheduler_add_element),
5145         (gst_scheduler_factory_create):
5146         * gst/gststructure.c: (gst_structure_set_parent_refcount),
5147         (gst_structure_free), (gst_structure_set_name),
5148         (gst_structure_id_set_value), (gst_structure_set_value),
5149         (gst_structure_set_valist), (gst_structure_remove_field),
5150         (gst_structure_remove_fields),
5151         (gst_structure_remove_fields_valist),
5152         (gst_structure_remove_all_fields), (gst_structure_foreach),
5153         (gst_structure_map_in_place),
5154         (gst_caps_structure_fixate_field_nearest_int),
5155         (gst_caps_structure_fixate_field_nearest_double):
5156         * gst/gststructure.h:
5157         * gst/gstsystemclock.c: (gst_system_clock_class_init),
5158         (gst_system_clock_init), (gst_system_clock_dispose),
5159         (gst_system_clock_async_thread),
5160         (gst_system_clock_id_wait_unlocked), (gst_system_clock_id_wait),
5161         (gst_system_clock_id_wait_async), (gst_system_clock_id_unschedule):
5162         * gst/gstsystemclock.h:
5163         * gst/gsttag.c: (gst_tag_list_add_value_internal),
5164         (gst_tag_list_copy_foreach), (structure_foreach_wrapper):
5165         * gst/gsttaginterface.c:
5166         * gst/gstthread.c: (gst_thread_dispose),
5167         (gst_thread_release_children_locks), (gst_thread_change_state),
5168         (gst_thread_main_loop):
5169         * gst/gsttrashstack.h:
5170         * gst/gsttypefind.c: (gst_type_find_factory_dispose):
5171         * gst/gsttypes.h:
5172         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
5173         (gst_element_request_pad), (gst_element_get_pad_from_template),
5174         (gst_element_request_compatible_pad),
5175         (gst_element_get_compatible_pad_filtered),
5176         (gst_element_get_compatible_pad), (gst_element_state_get_name),
5177         (gst_element_link_pads_filtered), (gst_element_link_filtered),
5178         (gst_element_link_many), (gst_element_link),
5179         (gst_element_link_pads), (gst_element_unlink_pads),
5180         (gst_element_unlink_many), (gst_element_unlink),
5181         (gst_pad_can_link_filtered), (gst_pad_can_link),
5182         (gst_pad_use_fixed_caps), (gst_pad_get_fixed_caps_func),
5183         (gst_object_default_error), (gst_bin_add_many),
5184         (gst_bin_remove_many), (gst_element_populate_std_props),
5185         (gst_element_class_install_std_props), (gst_buffer_merge),
5186         (gst_buffer_stamp), (intersect_caps_func), (gst_pad_proxy_getcaps),
5187         (link_fold_func), (gst_pad_proxy_setcaps):
5188         * gst/gstutils.h:
5189         * gst/gstvalue.c: (gst_value_deserialize_string):
5190         * gst/parse/grammar.y:
5191         * gst/schedulers/gstbasicscheduler.c:
5192         (gst_basic_scheduler_cothreaded_chain),
5193         (gst_basic_scheduler_chain_recursive_add),
5194         (gst_basic_scheduler_pad_link):
5195         * gst/schedulers/gstoptimalscheduler.c:
5196         (get_group_schedule_function),
5197         (gst_opt_scheduler_state_transition),
5198         (gst_opt_scheduler_add_element), (element_get_reachables_func):
5199         * libs/gst/bytestream/bytestream.c:
5200         * libs/gst/dataprotocol/dataprotocol.c:
5201         (gst_dp_header_from_buffer):
5202         * po/nb.po:
5203         * po/ru.po:
5204         * tests/threadstate/threadstate2.c: (eos):
5205         * tools/gst-compprep.c: (main):
5206         * tools/gst-inspect.c: (print_field), (print_element_flag_info),
5207         (print_pad_info), (print_children_info):
5208         * tools/gst-launch.c: (idle_func), (main):
5209         * tools/gst-md5sum.c: (idle_func), (main):
5210         * tools/gst-xmlinspect.c: (print_element_info):
5211         First THREADED backport attempt, focusing on adding locks and
5212         making sure the API is threadsafe. Needs more work. More docs
5213         follow this week.
5214
5215 2005-02-24  Andy Wingo  <wingo@pobox.com>
5216
5217         * tests/bench-complexity.scm:
5218         * tests/complexity.gnuplot: New files, good for running complexity
5219         benchmarks.
5220
5221         * tests/Makefile.am:
5222         * tests/complexity.c: New test, sets up N elements, at each level
5223         teeing into M streams per element. Eeeenteresting.
5224
5225         * tests/mass_elements.gnuplot: gnuplot file for the mass_elements
5226         benchmark. Run as gnuplot mass_elements.gnuplot > foo.ps, after
5227         running bench-mass_elements.scm.
5228
5229         * tests/bench-mass_elements.scm: New script, runs mass_elements
5230         for various numbers of identities, outputting the results to a
5231         file. Requires guile 1.6. Just for testing.
5232
5233 2005-02-23  Thomas Vander Stichele  <thomas at apestaart dot org>
5234
5235         * gst/schedulers/fairscheduler.c:
5236           compile with debug disabled
5237
5238 2005-02-22  Thomas Vander Stichele  <thomas at apestaart dot org>
5239
5240         * configure.ac:
5241           hunting season on 0.9 is now OPEN
5242
5243 2005-02-22  Stefan Kost  <ensonic@users.sf.net>
5244
5245         * docs/libs/tmpl/gstcontrol.sgml:
5246         * docs/libs/tmpl/gstdparam.sgml:
5247         * docs/libs/tmpl/gstdplinint.sgml:
5248         * docs/libs/tmpl/gstdpman.sgml:
5249         * docs/libs/tmpl/gstdpsmooth.sgml:
5250         * docs/libs/tmpl/gstunitconvert.sgml:
5251           more docs for the state of dparams
5252
5253 2005-02-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5254
5255         * gst/gstelementfactory.c: (gst_element_factory_create):
5256         * gst/gstobject.c: (gst_object_init),
5257         (gst_object_set_name_default), (gst_object_set_name):
5258           name objects by default, not in gst_element_factory_create. Allows
5259           using elements created with g_object_new. (fixes #167283)
5260
5261 2005-02-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5262
5263         * gst/gstinfo.c: (_gst_debug_init), (gst_debug_log_default):
5264           make the time that debugging functions print relative to when
5265           gst_init was called
5266
5267 2005-02-18  Tim-Philipp Müller  <tim at centricular dot net>
5268
5269         * gst/gsttaginterface.c:
5270           Fix inline docs: tag setter vararg functions are NULL-terminated,
5271           GST_TAG_INVALID doesn't exist any more.
5272
5273 2005-02-18  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5274
5275         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_dump_byte_array):
5276         Allocate the 1 byte more memory that was forgotten!!!!!
5277         fixes memory corruption on 64bit platforms
5278
5279 2005-02-15  Stefan Kost  <ensonic@users.sf.net>
5280
5281         * docs/pwg/building-pads.xml:
5282         * docs/pwg/intro-basics.xml:
5283           fixed a few typos, relabeled introductionary list of types
5284         * docs/random/ensonic/dparams.txt:
5285           more notes abut dparam changes
5286         * libs/gst/control/dparam.c: (gst_dparam_attach):
5287         * libs/gst/control/dparammanager.c:
5288         * libs/gst/control/dparammanager.h:
5289           - many comments and notes on dparam implementation
5290           - new dparams are were not initialized to the default value
5291             from param spec
5292
5293 2005-02-14  Thomas Vander Stichele  <thomas at apestaart dot org>
5294
5295         submitted by: Peter Astakhov
5296
5297         * po/LINGUAS:
5298         * po/ru.po:
5299           adding Russian translation
5300
5301 2005-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
5302
5303         * configure.ac:
5304         * docs/gst/Makefile.am:
5305         * docs/libs/Makefile.am:
5306           make sure popt is added to gtk-doc flags.  Fixes #147782.
5307
5308 2005-02-09  Tim-Philipp Müller  <tim at centricular dot net>
5309
5310         * docs/faq/using.xml:
5311           Fix typo in FAQ (artssink => artsdsink)
5312
5313 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5314
5315         * tools/gst-launch.1.in:
5316           Fix typo (#166699).
5317
5318 2005-02-08  Tim-Philipp Müller  <tim at centricular dot net>
5319
5320         * docs/faq/using.xml:
5321           Add -v argument to fakesrc/fakesink gst-launch line,
5322           so that the promised output will actually show up.
5323
5324 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5325
5326         * gst/gstthread.c: (gst_thread_change_state):
5327           Implement state-change error handling (#166073).
5328
5329 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5330
5331         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
5332           Release interrupt after handling (#166250).
5333
5334 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
5335
5336         * configure.ac:
5337           back to HEAD
5338
5339 === release 0.8.9 ===
5340
5341 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
5342
5343         * NEWS:
5344         * RELEASE:
5345         * configure.ac:
5346           releasing 0.8.9, "Like Eating Glass"
5347
5348 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
5349
5350         submitted by: Clytie Siddall
5351
5352         * po/vi.po: Added Vietnamese translation
5353
5354 2005-02-07  Thomas Vander Stichele  <thomas at apestaart dot org>
5355
5356         patch by: Tim Philipp-Müller
5357
5358         * configure.ac:
5359         * gst/gstpad.c:
5360           unref data when probe function returns FALSE.  Fixes #166362
5361
5362 2005-02-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5363
5364         * gst/gst.c: (gst_init_get_popt_table):
5365           Fix typo (#166269).
5366
5367 2005-02-04  Andy Wingo  <wingo@pobox.com>
5368
5369         * gst/gstelement.c (gst_element_get_compatible_pad_template): Fix
5370         the debugging on whether the caps are compatible.
5371
5372 2005-02-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5373
5374         * docs/manual/basics-elements.xml:
5375           Fix two typos.
5376
5377 2005-02-02  Wim Taymans  <wim@fluendo.com>
5378
5379         * gst/schedulers/gstoptimalscheduler.c: (remove_decoupled),
5380         (schedule_chain), (get_invalid_call), (chain_invalid_call),
5381         (loop_group_schedule_function), (gst_opt_scheduler_iterate):
5382         Remove some FIXMEs after analysing and commenting why they
5383         are not issues.
5384
5385 2005-02-02  Wim Taymans  <wim@fluendo.com>
5386
5387         * gst/schedulers/gstoptimalscheduler.c:
5388         (gst_opt_scheduler_class_init), (gst_opt_scheduler_init),
5389         (gst_opt_scheduler_finalize), (remove_decoupled), (schedule_chain),
5390         (get_invalid_call), (chain_invalid_call),
5391         (get_group_schedule_function), (loop_group_schedule_function),
5392         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
5393         (gst_opt_scheduler_state_transition),
5394         (gst_opt_scheduler_add_element),
5395         (gst_opt_scheduler_remove_element), (gst_opt_scheduler_interrupt),
5396         (gst_opt_scheduler_error), (gst_opt_scheduler_pad_link),
5397         (gst_opt_scheduler_pad_unlink), (gst_opt_scheduler_iterate),
5398         (gst_opt_scheduler_show):
5399         Added lock to protect scheduler data structures.
5400
5401 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5402
5403         * testsuite/threads/threadi.c: (cb_data):
5404           Fix buglet in test.
5405
5406 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5407
5408         * testsuite/threads/Makefile.am:
5409         * testsuite/threads/threadi.c: (cb_data), (cb_play), (main):
5410           On Wim's request, split the test in three separately-compiled
5411           tests that each test a very specific bug. Two of them still fail,
5412           will create bugs for those. threadi.c indicates why they fail.
5413
5414 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5415
5416         * gst/schedulers/gstoptimalscheduler.c:
5417         (get_group_schedule_function):
5418           Try to work with the threading mess that queue_link is.
5419
5420 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5421
5422         * gst/gstbin.c: (gst_bin_remove_func):
5423           Explicitely make an element release locks in a group when being
5424           remove from a bin.
5425         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
5426           If there's no scheduler, always return immediately (similar to
5427           gst_element_interrupt).
5428
5429 2005-01-31  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5430
5431         * gst/gstbin.c: (gst_bin_child_state_change_func):
5432           Remove a piece of code that could never be reached.
5433         * docs/gst/gstreamer-sections.txt:
5434         * gst/gstpad.c: (gst_pad_push), (gst_pad_pull),
5435         (gst_pad_call_get_function):
5436         * gst/gstpad.h:
5437         * testsuite/pad/Makefile.am:
5438           Fix #150546, enable tests.
5439
5440 2005-01-31  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5441
5442         * docs/pwg/advanced-types.xml:
5443           Fix description for buffer-frames=0.
5444         * docs/gst/tmpl/gstbin.sgml:
5445         * gst/gstbin.c: (gst_bin_child_state_change_func),
5446         (gst_bin_change_state), (gst_bin_change_state_norecurse):
5447         * gst/gstbin.h:
5448         * testsuite/threads/Makefile.am:
5449         * testsuite/threads/threadi.c: (cb_timeout), (cb_quit), (cb_eos),
5450         (cb_state), (cb_play), (main):
5451           Fix non-recursive state changes to *really* change the state
5452           of the object, and not just call parent_class->state_change.
5453           Fix a lot of lockups caused by this. Fixes #132775. Add test
5454           for the problem. Also enable test to show #142588 (fixed).
5455         * gst/gstthread.c: (gst_thread_change_state),
5456         (gst_thread_child_state_change):
5457           Don't exit the thread if we go to NULL and are inside thread
5458           context. Instead, return control to the main thread context
5459           and exit from there.
5460         * gst/gstelement.c: (gst_element_disable_threadsafe_properties):
5461           Don't unset virtual functions, since those may still be used.
5462           That's not necessarily correct, but suffices for now.
5463         * configure.ac:
5464         * testsuite/Makefile.am:
5465         * testsuite/pad/Makefile.am:
5466         * testsuite/pad/chainnopull.c: (gst_test_sink_class_init),
5467         (gst_test_sink_base_init), (gst_test_sink_chain),
5468         (gst_test_sink_init), (main):
5469         * testsuite/pad/getnopush.c: (gst_test_src_class_init),
5470         (gst_test_src_base_init), (gst_test_src_get), (gst_test_src_init),
5471         (main):
5472         * testsuite/pad/link.c: (gst_test_element_class_init),
5473         (gst_test_element_base_init), (gst_test_src_get),
5474         (gst_test_src_loop), (gst_test_src_init), (gst_test_filter_chain),
5475         (gst_test_filter_loop), (gst_test_filter_init),
5476         (gst_test_sink_chain), (gst_test_sink_loop), (gst_test_sink_init),
5477         (cb_error), (main):
5478           Add tests to show #150546. Pass, but should fail (currently
5479           disabled from the testsuite).
5480         * gst/gstscheduler.c: (gst_scheduler_dispose):
5481           Dereference child schedulers on dispose (#94464).
5482         * testsuite/bytestream/filepadsink.c: (gst_fp_sink_init):
5483           Fix typo.
5484         * testsuite/threads/thread.c: (main):
5485           Add more debug.
5486
5487 2005-01-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5488
5489         * gst/gstpad.c: (gst_pad_push):
5490           Oops, revert previous commit, broke testsuite...
5491
5492 2005-01-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5493
5494         * gst/gstpad.c: (gst_pad_push):
5495           Add check that the pad on which the push is performed is not a
5496           get-based pad (#150546).
5497
5498 2005-01-28  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5499
5500         * gst/elements/gsttypefindelement.c:
5501         (gst_type_find_element_handle_event):
5502           Fix buffer pushing if stream EOSes during typefinding.
5503
5504 2005-01-28  Edward Hervey  <bilboed@bilboed.com>
5505
5506         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5507
5508         * gst/gstvalue.c: (gst_string_wrap):
5509           Allow NULL-strings as argument (#165365).
5510
5511 2005-01-27  Stephane Wirtel  <stephane.wirtel@belgacom.net>
5512
5513         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5514
5515         * gst/schedulers/faircothreads.c:
5516         (gst_fair_scheduler_cothread_queue_show):
5517           Fix build without debug enabled.
5518
5519 2005-01-26  Stefan Kost  <ensonic@users.sf.net>
5520
5521         * docs/gst/gstreamer-sections.txt:
5522         * docs/libs/gstreamer-libs-docs.sgml:
5523         * docs/libs/gstreamer-libs-sections.txt:
5524         * docs/libs/tmpl/gstcontrol.sgml:
5525         * docs/libs/tmpl/gstdparam.sgml:
5526         * docs/libs/tmpl/gstdplinint.sgml:
5527         * docs/libs/tmpl/gstdpman.sgml:
5528         * docs/libs/tmpl/gstdpsmooth.sgml:
5529         * docs/libs/tmpl/gstputbits.sgml:
5530         * docs/libs/tmpl/gstunitconvert.sgml:
5531         * libs/gst/control/dparam.c:
5532         * libs/gst/control/dparam.h:
5533         * libs/gst/control/dparammanager.c:
5534         (gst_dpman_add_required_dparam_callback),
5535         (gst_dpman_add_required_dparam_direct),
5536         (gst_dpman_add_required_dparam_array),
5537         (gst_dpman_remove_required_dparam), (gst_dpman_attach_dparam),
5538         (gst_dpman_get_dparam), (gst_dpman_get_dparam_type),
5539         (gst_dpman_get_manager)
5540           restructured DParam docs
5541
5542 2005-01-25  Tim-Philipp Müller  <tim at centricular dot net>
5543
5544         * gst-element-check.m4:
5545           Only check for gst-inspect if we haven't already
5546           found it in previous element check runs
5547
5548 2005-01-25  Stefan Kost  <ensonic@users.sf.net>
5549
5550         * docs/gst/Makefile.am:
5551         * docs/libs/Makefile.am:
5552           fixed install rules to treat style.css as optional
5553
5554 2005-01-24  Stefan Kost  <ensonic@users.sf.net>
5555
5556         * docs/gst/Makefile.am:
5557         * docs/libs/Makefile.am:
5558           install style.css along with docs
5559         * docs/gst/tmpl/gstbin.sgml:
5560         * docs/gst/tmpl/gstclock.sgml:
5561         * docs/gst/tmpl/gstdata.sgml:
5562         * docs/gst/tmpl/gstelement.sgml:
5563         * gst/gstbin.h:
5564         * gst/gstelement.c: (gst_element_class_init):
5565         * gst/gstelement.h:
5566           fixing incomplete docs
5567
5568 2005-01-24  Tim-Philipp Müller  <tim at centricular dot net>
5569
5570         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
5571           Don't unref seek event twice when fflush() fails
5572           
5573 2005-01-22  David Schleef  <ds@schleef.org>
5574
5575         * configure.ac: Add --disable-valgrind. (partial fix for #164890)
5576
5577 2005-01-21  Stefan Kost  <ensonic@users.sf.net>
5578
5579         * docs/gst/Makefile.am:
5580         * docs/libs/Makefile.am:
5581           added params for deprecation guards
5582         * gst/gst.c:
5583         * gst/gst.h:
5584         * gst/gsterror.c: (_gst_resource_errors_init),
5585         (_gst_stream_errors_init):
5586         * gst/gsterror.h:
5587           documented some more enums
5588
5589 2005-01-19  Jan Schmidt  <thaytan@mad.scientist.com>
5590         * gst/autoplug/gstspideridentity.c:
5591         Cosmetic fix - spider_find_peek should be static
5592         * gst/parse/parse.l:
5593         Applying fix for #164261
5594
5595 2005-01-18  Stefan Kost  <ensonic@users.sf.net>
5596
5597         * docs/gst/gstreamer-sections.txt:
5598         * docs/gst/tmpl/gstplugin.sgml:
5599         * docs/libs/gstreamer-libs-sections.txt:
5600         * docs/libs/tmpl/gstcontrol.sgml:
5601         * gst/gstbuffer.h:
5602         * gst/gsttag.h:
5603         * gst/gstvalue.c:
5604           added docs for the TAG defines
5605
5606 2005-01-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5607
5608         * gst/schedulers/gstoptimalscheduler.c: (schedule_group):
5609           Only unref entry if there is an entry.
5610
5611 2005-01-17  Wim Taymans  <wim@fluendo.com>
5612
5613         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5614         (remove_from_group), (schedule_group), (normalize_group),
5615         (gst_opt_scheduler_iterate):
5616         Also ref/unref decoupled elements before iterating the
5617         group since they are not added to the list of elements.
5618
5619 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5620
5621         * docs/manual/highlevel-components.xml:
5622           Add subtitle/streamselection as new features to playbin.
5623
5624 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5625
5626         * docs/manual/manual.xml:
5627           Re-enable dataaccess docs (oops).
5628
5629 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5630
5631         * docs/pwg/advanced-types.xml:
5632         * docs/random/mimetypes:
5633           Add documentation on libsndfile types (#163309), by Steve Baker
5634           <steve@stevebaker.org>.
5635         * gst/gstelement.c: (gst_element_release_request_pad):
5636           If an element has no explicit function, just remove the pad.
5637
5638 2005-01-17  Luca Ognibene  <luogni@tin.it>
5639
5640         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5641
5642         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load):
5643           Fix memleak (#163801).
5644
5645 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5646
5647         * gst/elements/gsttee.c: (gst_tee_getcaps), (gst_tee_link):
5648           I think this is actually more correct...
5649
5650 2005-01-16  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5651
5652         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
5653           Another workaround for memory access while destroyed in callback.
5654           Please, someone with refcount knowledge, have a look at this.
5655
5656 2005-01-15  Thomas Vander Stichele  <thomas at apestaart dot org>
5657
5658         * docs/faq/faq.xml:
5659         * docs/faq/legal.xml:
5660           move the legal Q&A here
5661
5662 2005-01-14  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5663
5664         * gst/elements/gsttee.c: (gst_tee_getcaps), (gst_tee_link),
5665         (gst_tee_request_new_pad):
5666           Fix negotiation.
5667
5668 2005-01-14  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
5669
5670         * docs/random/omega/caps2:
5671         * testsuite/caps/caps_strings:
5672           replace framerate aproximations by their real value
5673           (24000/1001, 30000/1001, 60000/1001)
5674           Partially fixes bug #164049
5675
5676 2005-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
5677
5678         * docs/gst/Makefile.am:
5679           don't fail on the stupid GstPoptOption
5680
5681 2005-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
5682
5683         * gst/gstpad.h:
5684         * gst/gstprobe.c:
5685           allow probes to work on ghost pads by realizing the pad
5686           probe debugging
5687
5688 2005-01-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5689
5690         * docs/gst/gstreamer-sections.txt:
5691         * docs/gst/tmpl/gstpad.sgml:
5692         * gst/gstpad.c: (gst_pad_set_active_recursive):
5693         * gst/gstpad.h:
5694           Add gst_pad_set_active_recursive().
5695
5696 2005-01-10  Thomas Vander Stichele  <thomas at apestaart dot org>
5697
5698         * docs/random/release:
5699           updates
5700         * gst/gst_private.h:
5701         * gst/gstinfo.c:
5702         * gst/gstobject.c:
5703           move deep_notify logging to a new category
5704         * gst/gstprobe.c:
5705         * gst/gstprobe.h:
5706           add stuff so bindings can wrap probes
5707
5708 2005-01-09  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
5709
5710         * gst/gstplugin.c: (gst_plugin_load):
5711           Fix plugin loading if plugin/lib was already loaded. Fixes
5712           #163383
5713
5714 2005-01-09  Sebastien Cote  <sc5@hermes.usherb.ca>
5715
5716         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5717
5718         * gst/gstpluginfeature.c: (gst_plugin_feature_ensure_loaded):
5719           Protect plugin loading by a mutex so it's threadsafe. Fixes
5720           #163234.
5721
5722 2005-01-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5723
5724         * gst/gstevent.c: (_gst_event_copy):
5725           Reference source object when copying events, since it'll be
5726           dereferenced on event dereferencing as well.
5727
5728 2005-01-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5729
5730         * docs/gst/gstreamer-sections.txt:
5731         * docs/gst/tmpl/gstevent.sgml:
5732         * gst/gstevent.c: (gst_event_new_filler_stamped),
5733         (gst_event_filler_get_duration):
5734         * gst/gstevent.h:
5735           Add two new functions for filler events (which are used to
5736           synchronize streams if one of them is not having any data
5737           for a while) without interrupting the actual data-stream.
5738           Basically a no-op.
5739         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
5740         (gst_queue_link_sink), (gst_queue_link_src),
5741         (gst_queue_change_state):
5742           Allow for renegotiation while filled. Required for stream
5743           switching while playing.
5744
5745 2005-01-08  Benjamin Otte  <otte@gnome.org>
5746
5747         * gst/gstelement.c: (gst_element_link_many):
5748           fix up g_return_if_fail's
5749         * po/LINGUAS:
5750         * po/de.po:
5751           add German translation, that was somehow not included
5752
5753 2005-01-08  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
5754
5755         * docs/random/mimetypes:
5756           add 2 more 4CC code for DV (HDTV and SDTV-LongPlay profiles)
5757           do not add them to riff-lib as they are not common
5758
5759 2005-01-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5760
5761         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
5762           Check for existence of probe after performing the probe before
5763           re-accessing it to prevent segfaults caused by removal of the
5764           probe in the callback.
5765
5766 2005-01-05  David Schleef  <ds@schleef.org>
5767
5768         * testsuite/registry/Makefile.am:
5769         * testsuite/registry/gst-print-formats.c:
5770         (print_pad_templates_info), (print_element_list),
5771         (print_typefind_list), (list_sort_func), (get_typefind_mime_list),
5772         (g_list_uniqify), (get_pad_templates_info),
5773         (get_element_mime_list), (print_mime_list), (main): A little
5774         program that looks through the registry to find elements of
5775         a given type.  Not particularly interesting as a test, except
5776         that there's no other test covering the same area.
5777
5778 2005-01-05  David Schleef  <ds@schleef.org>
5779
5780         * tools/gst-launch.c: (idle_func), (fault_handler_sighandler),
5781         (fault_handler_sigaction), (fault_spin),
5782         (sigint_handler_sighandler), (play_handler), (main): Fix deadlocks
5783         in signal.h-type signal handlers by not calling forbidden functions,
5784         including gst_element_set_state().
5785
5786 2005-01-05  David Schleef  <ds@schleef.org>
5787
5788         * gst/gstvalue.h: Mark _gst_reserved[] as private
5789
5790 2005-01-05  David Schleef  <ds@schleef.org>
5791
5792         * gst/gstvalue.c: Fix doc build problem.
5793
5794 2005-01-05  David Schleef  <ds@schleef.org>
5795
5796         * gst/gstvalue.c: Add some documentation
5797
5798 2005-01-05  Stefan Kost  <ensonic@users.sf.net>
5799
5800         * docs/README:
5801           another shell oneliner for empty return value docs
5802         * gst/gstcaps.c:
5803         * gst/gstvalue.c:
5804         * libs/gst/control/dparam.c:
5805           more doc fixes (parameters and return values)
5806
5807 2005-01-05  Vincent Torri  <torri@iecn.u-nancy.fr>
5808
5809         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5810
5811         * gst/gstregistry.h:
5812         * gst/registries/gstxmlregistry.c:
5813           Fix macro's for Mingw (fixes #162276).
5814
5815 2005-01-04  Stefan Kost  <ensonic@users.sf.net>
5816
5817         * docs/README:
5818           quick shell oneliner to find undocumented members
5819         * docs/gst/tmpl/gstplugin.sgml:
5820         * docs/gst/tmpl/gstscheduler.sgml:
5821         * docs/gst/tmpl/gstthread.sgml:
5822           more enumtypes cleanup
5823         * gst/gsterror.h:
5824           activated documentation comments, now someone needs to document
5825           the enums :(
5826
5827 2005-01-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5828
5829         * docs/manual/manual.xml:
5830           Add dataaccess part (doh!).
5831
5832 2005-01-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5833
5834         * docs/manual/advanced-autoplugging.xml:
5835           Fix typo (intiate -> initiate).
5836
5837 2005-01-02  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5838
5839         * docs/random/bbb/streamselection:
5840           Add some notes on how to handle multi-subtitle/-audio streams.
5841
5842 2004-12-30  Stefan Kost  <ensonic@users.sf.net>
5843
5844         * docs/gst/gstreamer-docs.sgml:
5845         * docs/gst/gstreamer-sections.txt:
5846         * docs/gst/tmpl/gstenumtypes.sgml:
5847         * docs/gst/tmpl/gsterror.sgml:
5848         * docs/gst/tmpl/gstevent.sgml:
5849         * docs/gst/tmpl/gstpad.sgml:
5850         * docs/gst/tmpl/gstpadtemplate.sgml:
5851         * docs/gst/tmpl/gstthread.sgml:
5852           removed gstenumtypes section from docs and put all the enums into
5853           their sections
5854
5855 2004-12-27  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
5856
5857         * gst/gstplugin.c:
5858           document gst_library_load a bit more (riff special case + return
5859           value if already loaded)
5860         * testsuite/bytestream/filepadsink.c:
5861           plugin name is 'gstbytestream', not 'bytestream'
5862
5863 2004-12-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5864
5865         * docs/random/bbb/subtitles:
5866           Add some first mind rumblings on proper subtitle support.
5867
5868 2004-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
5869
5870         * po/ca.po:
5871         * po/sv.po:
5872           updated translations
5873
5874 2004-12-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5875
5876         * docs/manual/advanced-dataaccess.xml:
5877           Add section on how to use fakesrc/fakesink/identity in your
5878           application, plus section on how to embed plugins. Also mention
5879           probes.
5880         * docs/manual/appendix-checklist.xml:
5881         * docs/manual/appendix-debugging.xml:
5882         * docs/manual/appendix-gnome.xml:
5883         * docs/manual/appendix-integration.xml:
5884           Debug -> checklist, GNOME -> integration, add sections on Linux,
5885           KDE integration and add other things useful for application
5886           development.
5887         * docs/manual/manual.xml:
5888           Remove some fixmes, update some file pointers.
5889         * docs/pwg/appendix-checklist.xml:
5890           Fix typo.
5891         * docs/pwg/building-boiler.xml:
5892           Remove ugly header and add commented fixme.
5893         * docs/pwg/pwg.xml:
5894           Add fixme.
5895         * examples/manual/Makefile.am:
5896           Add example for added docs.
5897
5898 2004-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
5899
5900         * configure.ac:
5901           back to HEAD
5902
5903 === release 0.8.8 ===
5904
5905 2004-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
5906
5907         * NEWS:
5908         * RELEASE:
5909         * configure.ac:
5910           Releasing 0.8.8, "I'll Take Care Of You"
5911
5912 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
5913
5914         * configure.ac:
5915           second prerelease
5916
5917 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
5918
5919         patch by: Wim Taymans
5920
5921         * gst/gstbin.c:
5922           Fix for #159852 - make iterate emission threadsafe
5923
5924 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
5925
5926         * docs/faq/cvs.xml:
5927           notes about new fdo account request
5928
5929 2004-12-20  Stefan Kost  <ensonic@users.sf.net>
5930
5931         * docs/gst/gstreamer-docs.sgml:
5932         * docs/gst/tmpl/gstenumtypes.sgml:
5933         * docs/gst/tmpl/gstplugin.sgml:
5934         * docs/libs/gstreamer-libs-docs.sgml:
5935           Added missing short docs. Added ids for navigation.
5936
5937 2004-12-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5938
5939         * docs/manual/advanced-autoplugging.xml:
5940         * docs/manual/advanced-schedulers.xml:
5941         * docs/manual/advanced-threads.xml:
5942           Rewrites. Remove cothreads, go a bit into opt specifically,
5943           document threads and their gotchas, and do some technical stuff
5944           on autoplugging plus add some working examples. Fixes #157395.
5945         * examples/manual/Makefile.am:
5946           Add typefind/autoplugger example (one that actually works).
5947           Remove queue example since it's a duplicate of the thread one.
5948
5949 2004-12-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5950
5951         * gst/gstvalue.c: (gst_value_deserialize_string):
5952           use deprecated g_value_set_string_take_ownership to keep compatible
5953           with glib 2.2
5954
5955 2004-12-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5956
5957         * gst/gstvalue.c: (gst_value_deserialize_string):
5958           revert last patch, only dom a g_utf8_validate now before accepting
5959           the string - caps parsing strips " from strings so we can't rely on
5960           them
5961         * testsuite/caps/value_serialize.c: (test_string_deserialization):
5962           disable a test that tested the above and comment it
5963
5964 2004-12-16  Steve Lhomme <steve.lhomme@free.fr>
5965
5966         Patch reviewed by David Schleef  <ds@schleef.org>
5967
5968         * win32/gstenumtypes.c: Update from gst/gstenumtypes.c (See
5969         bug #153882)
5970         * win32/gstenumtypes.h: same
5971
5972 2004-12-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5973
5974         * gst/gstpad.c: (gst_pad_query):
5975           Do query on realized pad, similar to how convert/send_event handle
5976           this. Also makes sense, since this pad belongs to the function to
5977           which this query will be sent. Fixes #158163.
5978
5979 2004-12-16  Christian Fredrik Kalager Schaller  <uraeus@gnome.org>
5980
5981         * docs/manual/appendix-programs.xml: fix pipeline to actually work
5982
5983 2004-12-16  Christian Fredrik Kalager Schaller  <christian@fluendo.com>
5984
5985         * docs/faq/general.xml: fix pipeline to actually work
5986
5987 2004-12-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5988
5989         * gst/gstvalue.c: (gst_value_deserialize_string):
5990           check that a simple string that gets deserialized does not contain
5991           invalid characters
5992         * testsuite/caps/value_serialize.c: (test_string_deserialization):
5993           remove a test that tested a wring behaviour
5994
5995 2004-12-16  Matt Kraai  <kraai@alumni.cmu.edu>
5996
5997         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5998
5999         * docs/manual/intro-motivation.xml:
6000           Fix typos.
6001
6002 2004-12-16  Edward Hervey  <bilboed@bilboed.com>
6003
6004         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6005
6006         * docs/gst/tmpl/gstprobe.sgml:
6007           Fix documentation of probe callback - it is supposed to return
6008           FALSE, not TRUE, to remove data from the stream (#159087).
6009
6010 2004-12-16  Daniel Gazard  <dany42@free.fr>
6011
6012         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6013
6014         * gst/gstelementfactory.c: (gst_element_factory_create):
6015           Fix compile failure if compiling without libxml2 support (#149936).
6016
6017 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6018
6019         * docs/manual/advanced-autoplugging.xml:
6020         * docs/manual/highlevel-components.xml:
6021           Move spider from autoplugging to components. Autoplugging is for
6022           internals, not for solutions. ;-).
6023
6024 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6025
6026         * docs/random/ds/0.9-suggested-changes:
6027           Make note on device/location/uri property names.
6028
6029 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6030
6031         * docs/manual/advanced-autoplugging.xml:
6032         * docs/manual/advanced-clocks.xml:
6033         * docs/manual/advanced-interfaces.xml:
6034         * docs/manual/advanced-metadata.xml:
6035         * docs/manual/advanced-position.xml:
6036         * docs/manual/advanced-schedulers.xml:
6037         * docs/manual/advanced-threads.xml:
6038         * docs/manual/appendix-gnome.xml:
6039         * docs/manual/appendix-programs.xml:
6040         * docs/manual/appendix-quotes.xml:
6041         * docs/manual/autoplugging.xml:
6042         * docs/manual/basics-bins.xml:
6043         * docs/manual/basics-data.xml:
6044         * docs/manual/basics-elements.xml:
6045         * docs/manual/basics-helloworld.xml:
6046         * docs/manual/basics-init.xml:
6047         * docs/manual/basics-pads.xml:
6048         * docs/manual/basics-plugins.xml:
6049         * docs/manual/bins-api.xml:
6050         * docs/manual/bins.xml:
6051         * docs/manual/buffers-api.xml:
6052         * docs/manual/buffers.xml:
6053         * docs/manual/clocks.xml:
6054         * docs/manual/components.xml:
6055         * docs/manual/cothreads.xml:
6056         * docs/manual/debugging.xml:
6057         * docs/manual/dparams-app.xml:
6058         * docs/manual/dynamic.xml:
6059         * docs/manual/elements-api.xml:
6060         * docs/manual/elements.xml:
6061         * docs/manual/factories.xml:
6062         * docs/manual/gnome.xml:
6063         * docs/manual/goals.xml:
6064         * docs/manual/helloworld.xml:
6065         * docs/manual/helloworld2.xml:
6066         * docs/manual/highlevel-components.xml:
6067         * docs/manual/highlevel-xml.xml:
6068         * docs/manual/init-api.xml:
6069         * docs/manual/intro-basics.xml:
6070         * docs/manual/intro-motivation.xml:
6071         * docs/manual/intro-preface.xml:
6072         * docs/manual/intro.xml:
6073         * docs/manual/links-api.xml:
6074         * docs/manual/links.xml:
6075         * docs/manual/manual.xml:
6076         * docs/manual/motivation.xml:
6077         * docs/manual/pads-api.xml:
6078         * docs/manual/pads.xml:
6079         * docs/manual/plugins-api.xml:
6080         * docs/manual/plugins.xml:
6081         * docs/manual/programs.xml:
6082         * docs/manual/queues.xml:
6083         * docs/manual/quotes.xml:
6084         * docs/manual/schedulers.xml:
6085         * docs/manual/states-api.xml:
6086         * docs/manual/states.xml:
6087         * docs/manual/threads.xml:
6088         * docs/manual/typedetection.xml:
6089         * docs/manual/win32.xml:
6090         * docs/manual/xml.xml:
6091           Try 2. This time, include a short preface as a "general
6092           introduction", also add code blocks around all code samples
6093           so they get compiled. We still need a way to tell readers
6094           the filename of the code sample. In some cases, don't show
6095           all code in the documentation, but do include it in the generated
6096           code. This allows for focussing on specific bits in the docs,
6097           while still having a full test application available.
6098         * examples/manual/Makefile.am:
6099           Fix up examples for new ADM. Add several of the new examples that
6100           were either added or were missing from the build system.
6101         * examples/manual/extract.pl:
6102           Allow nameless blocks.
6103
6104 2004-12-15  Thomas Vander Stichele  <thomas at apestaart dot org>
6105
6106         * docs/manual/elements-api.xml:
6107         * docs/manual/helloworld.xml:
6108         * examples/manual/extract.pl:
6109           fix last example.  Add example of adding code blocks that are not
6110           shown in docbook output.
6111
6112 2004-12-15  Thomas Vander Stichele  <thomas at apestaart dot org>
6113
6114         * docs/manual/dynamic.xml:
6115         * docs/manual/elements-api.xml:
6116         * docs/manual/gnome.xml:
6117         * docs/manual/helloworld2.xml:
6118         * docs/manual/init-api.xml:
6119         * docs/manual/queues.xml:
6120         * docs/manual/threads.xml:
6121         * docs/manual/xml.xml:
6122         * examples/manual/extract.pl:
6123           Make it possible to extract example code from separate blocks.
6124           Should make Ronald happy.
6125
6126 2004-12-15  Wim Taymans  <wim@fluendo.com>
6127
6128         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
6129         (remove_from_group), (group_elements_set_visited),
6130         (normalize_group), (gst_opt_scheduler_iterate):
6131         Fix bug where a flag was not updated on a decoupled entry point 
6132         because we were just checking the group element list and decoupled
6133         elements are not in that list..
6134
6135 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6136
6137         * docs/manual/advanced-autoplugging.xml:
6138         * docs/manual/advanced-clocks.xml:
6139         * docs/manual/advanced-dparams.xml:
6140         * docs/manual/advanced-interfaces.xml:
6141         * docs/manual/advanced-metadata.xml:
6142         * docs/manual/advanced-position.xml:
6143         * docs/manual/advanced-schedulers.xml:
6144         * docs/manual/advanced-threads.xml:
6145         * docs/manual/appendix-debugging.xml:
6146         * docs/manual/appendix-gnome.xml:
6147         * docs/manual/appendix-programs.xml:
6148         * docs/manual/appendix-quotes.xml:
6149         * docs/manual/appendix-win32.xml:
6150         * docs/manual/autoplugging.xml:
6151         * docs/manual/basics-bins.xml:
6152         * docs/manual/basics-data.xml:
6153         * docs/manual/basics-elements.xml:
6154         * docs/manual/basics-helloworld.xml:
6155         * docs/manual/basics-init.xml:
6156         * docs/manual/basics-pads.xml:
6157         * docs/manual/basics-plugins.xml:
6158         * docs/manual/bins-api.xml:
6159         * docs/manual/bins.xml:
6160         * docs/manual/buffers-api.xml:
6161         * docs/manual/buffers.xml:
6162         * docs/manual/clocks.xml:
6163         * docs/manual/components.xml:
6164         * docs/manual/cothreads.xml:
6165         * docs/manual/debugging.xml:
6166         * docs/manual/dparams-app.xml:
6167         * docs/manual/dynamic.xml:
6168         * docs/manual/elements-api.xml:
6169         * docs/manual/elements.xml:
6170         * docs/manual/factories.xml:
6171         * docs/manual/gnome.xml:
6172         * docs/manual/goals.xml:
6173         * docs/manual/helloworld.xml:
6174         * docs/manual/helloworld2.xml:
6175         * docs/manual/highlevel-components.xml:
6176         * docs/manual/highlevel-xml.xml:
6177         * docs/manual/init-api.xml:
6178         * docs/manual/intro-motivation.xml:
6179         * docs/manual/intro-preface.xml:
6180         * docs/manual/intro.xml:
6181         * docs/manual/links-api.xml:
6182         * docs/manual/links.xml:
6183         * docs/manual/manual.xml:
6184         * docs/manual/motivation.xml:
6185         * docs/manual/pads-api.xml:
6186         * docs/manual/pads.xml:
6187         * docs/manual/plugins-api.xml:
6188         * docs/manual/plugins.xml:
6189         * docs/manual/programs.xml:
6190         * docs/manual/queues.xml:
6191         * docs/manual/quotes.xml:
6192         * docs/manual/schedulers.xml:
6193         * docs/manual/states-api.xml:
6194         * docs/manual/states.xml:
6195         * docs/manual/threads.xml:
6196         * docs/manual/typedetection.xml:
6197         * docs/manual/win32.xml:
6198         * docs/manual/xml.xml:
6199           First try at rewriting the ADM. Needs lotsamore work, but some
6200           parts might already be somewhat useful.
6201         * docs/pwg/advanced-interfaces.xml:
6202           Remove properties interface, it never actually existed (except for
6203           on my HD...).
6204
6205 2004-12-13  David Schleef  <ds@schleef.org>
6206
6207         * gst/gstpad.c: (gst_pad_set_explicit_caps): Allow caps to
6208         be NULL (bug #160220).
6209
6210 2004-12-13  David Schleef  <ds@schleef.org>
6211
6212         * configure.ac: remove all mmx stuff, because it's not used.
6213         * docs/random/ds/0.9-suggested-changes: additional notes
6214         * include/Makefile.am: we don't use these anymore
6215         * include/mmx.h: remove
6216         * include/sse.h: remove
6217
6218 2004-12-13  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
6219
6220         * docs/random/mimetypes:
6221           Add FOURCC code for h264 codec (VSSH)
6222           Add alternate FOURCC codes for h263 related codecs
6223
6224 2004-12-10  Stefan Kost  <ensonic@users.sf.net>
6225
6226         * docs/manual/programs.xml:
6227           Added more gst-launch examples.
6228
6229 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6230
6231         * gst/gstqueue.c: (gst_queue_handle_src_query):
6232           Check for availability again.
6233
6234 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6235
6236         * gst/gstcaps.c: (gst_caps_compare_structures):
6237           Simple caps go first. This has the nice side-effect of fixing an
6238           obscure warning.
6239
6240 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6241
6242         * gst/gstversion.h.in:
6243           Protect header.
6244
6245 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6246
6247         * gst/schedulers/gstoptimalscheduler.c:
6248         (gst_opt_scheduler_schedule_run_queue), (schedule_chain),
6249         (gst_opt_scheduler_get_wrapper):
6250           When we're recursing into a chain run, only run the directly
6251           related group, not all queued ones. This will fix a possible
6252           deadlock in chains with more than two groups.
6253
6254 2004-12-08  Thomas Vander Stichele  <thomas at apestaart dot org>
6255
6256         * autogen.sh:
6257           remove patch if autopoint fails
6258
6259 2004-12-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6260
6261         * docs/gst/gstreamer-sections.txt:
6262           Document Thomas' addition, fix build, make Luis the sheriff happy.
6263
6264 2004-12-07  Thomas Vander Stichele  <thomas at apestaart dot org>
6265
6266         * gst/gstplugin.c:
6267         * gst/gstplugin.h:
6268           add accessor for version field
6269
6270 2004-12-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6271
6272         submitted by: Luca Ferretti <elle.uca@infinito.it>
6273
6274         * po/LINGUAS:
6275         * po/it.po:
6276           New tranlation added: Italian
6277
6278 2004-12-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6279
6280         * gst/gstpad.c: (gst_pad_is_negotiated),
6281         (gst_pad_get_negotiated_caps):
6282           GST_RPAD_* will only operate on a RealPad (it casts the pointer,
6283           it doesn't actually check the contents), so be sure to hand it
6284           a RealPad else we'll crash.
6285
6286 2004-12-03  Wim Taymans  <wim@fluendo.com>
6287
6288         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
6289         (gst_queue_link), (gst_queue_handle_src_query):
6290         Reverted to 1.110 until this makes the testsuite and various
6291         apps work.
6292
6293 2004-12-01  Christian Fredrik Kalager Schaller <christian@fluendo.com>
6294
6295         * docs/upload.mak: fix included CVS conflict strings
6296
6297 2004-12-01  William Jon McCann  <mccann@jhu.edu>
6298
6299         Reviewed by: Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6300
6301         * gst/gstelement.c: (gst_element_error_full):
6302           Use g_error_new_literal because error text may have
6303           percentage signs in it. Fixes #160019.
6304
6305 2004-12-01  Benjamin Otte  <otte@gnome.org>
6306
6307         * gst/elements/gstbufferstore.c:
6308         (gst_buffer_store_add_buffer_func):
6309           don't try to make subbuffers bigger than they can be. (fixes
6310           #159970)
6311
6312 2004-11-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6313
6314         * docs/gst/gstreamer-sections.txt:
6315         * docs/gst/tmpl/gstvalue.sgml:
6316           Add new function to docs to fix build.
6317
6318 2004-11-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6319
6320         * gst/gstcaps.c: (gst_caps_is_fixed_foreach):
6321         * gst/gstpad.c: (_gst_pad_default_fixate_value),
6322         (_gst_pad_default_fixate_foreach):
6323         * gst/gstvalue.c: (gst_type_is_fixed), (gst_value_is_fixed):
6324         * gst/gstvalue.h:
6325           Deprecate _type_is_fixed, use _value_is_fixed instead, since
6326           in some cases (arrays), the fixedness depends on the content.
6327         * gst/gstqueue.c: (gst_queue_handle_src_query):
6328           Check for availability before doing something.
6329
6330 2004-11-29  Wim Taymans  <wim@fluendo.com>
6331
6332         * testsuite/threads/Makefile.am:
6333         * testsuite/threads/signals.c: (gst_test_get_type),
6334         (gst_test_class_init), (gst_test_init), (gst_test_dispose),
6335         (gst_test_set_property), (gst_test_get_property),
6336         (gst_test_do_signal1), (signal2_handler), (gst_test_do_signal2),
6337         (gst_test_do_prop), (run_thread), (main):
6338         Added a bunch of testcases that show threadsafety bugs in glib.
6339
6340 2004-11-29  Stefan Kost  <ensonic@users.sf.net>
6341
6342         * docs/manual/programs.xml:
6343           Added a first batch of gst-launch examples, as provided by Ronald
6344           and others from the devel-mlist
6345
6346 2004-11-28  Benjamin Otte  <otte@gnome.org>
6347
6348         * gst/gstelement.c: (gst_element_negotiate_pads):
6349           simplify
6350         * gst/gstvalue.c: (gst_string_wrap), (gst_string_unwrap),
6351         (gst_value_serialize_string), (gst_value_deserialize_string):
6352           add unwrapping of previously wrapped strings. Fix bug in wrapping
6353           while at it.
6354         * testsuite/caps/value_serialize.c: (test1),
6355         (test_string_serialization), (test_string_deserialization), (main):
6356           add tests for string (de)serialization
6357
6358 2004-11-26  Wim Taymans  <wim@fluendo.com>
6359
6360         * testsuite/threads/159566.c: (object_deep_notify), (main):
6361         * testsuite/threads/Makefile.am:
6362         Added testsuite to show bug #159566
6363
6364 2004-11-25  Wim Taymans  <wim@fluendo.com>
6365
6366         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_change_state),
6367         (gst_thread_child_state_change), (gst_thread_main_loop):
6368         Ref the thread object in the GThread mainloop. Break out of the
6369         thread mainloop if it holds the last ref. This properly exits
6370         the threads when disposing the thread from its own context. It
6371         also avoids possible deadlocks in the dispose function.
6372
6373 2004-11-24  Martin Soto  <martinsoto@users.sourceforge.net>
6374
6375         * gst/gstqueue.c (gst_queue_link_sink): Grab the lock only when
6376         it is necessary to wait.
6377
6378 2004-11-24  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6379
6380         * docs/pwg/building-boiler.xml:
6381           Make description somewhat clearer.
6382
6383 2004-11-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6384
6385         * docs/upload.mak:
6386           Apparently docs changed location on FDO's server.
6387
6388 2004-11-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6389
6390         * docs/pwg/appendix-checklist.xml:
6391           Add some random notes on things to check when writing an element.
6392           This list can be extended as people see fit.
6393
6394 2004-11-23  Martin Soto  <martinsoto@users.sourceforge.net>
6395
6396         * gst/gstqueue.c (gst_queue_init, gst_queue_link_sink)
6397         (gst_queue_link_src): Allow for renegotiating the caps of the sink
6398         pad. The queue will now wait until it is empty and forward the new
6399         caps to the source.
6400         * gst/gstbin.c (gst_bin_set_element_sched)
6401         (gst_bin_unset_element_sched): Make sure that all elements and
6402         links are registered and unregistered with the scheduler exactly
6403         once. This elaborates on a fix by Benjamin Otte, but
6404         guarantees that decoupled elements are also registered.
6405
6406 2004-11-11  Thomas Vander Stichele  <thomas at apestaart dot org>
6407
6408         * docs/manual/quotes.xml:
6409           add a quote
6410         * configure.ac:
6411         * gst/gst.c:
6412         * gst/gstinfo.c:
6413           add LIBDIR and move init message higher up so it's at the start
6414
6415 2004-11-08  Christian Fredrik Kalager Schaller  <christian@fluendo.com>
6416
6417         * gst/schedulers/Makefile.am: fix disted build fair by including .h file
6418         * gstreamer.spec.in: add fair
6419
6420 2004-11-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6421
6422         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
6423         * gst/elements/gstidentity.c: (gst_identity_class_init):
6424           Use G_SIGNAL_TYPE_STATIC_SCOPE, patch by Christophe Fergeau
6425           <teuf@gnome.org> (#157263).
6426         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
6427         (gst_type_find_handle_src_query):
6428           Subtract size of internally stored data from position queries.
6429
6430 2004-11-07  Martin Soto  <martinsoto@users.sourceforge.net>
6431
6432         * gst/schedulers/fairscheduler.c:
6433         * gst/schedulers/faircothreads.c:
6434         * gst/schedulers/faircothreads.h:
6435         New cothread based scheduler: Fair scheduler.
6436         * gst/schedulers/gthread-cothreads.h: 
6437         Add the standard #if around the whole file.
6438         Defining symbol GTHREAD_COTHREADS_NO_DEFINITIONS will now prevent
6439         compilation of the functions defined in this file. This is
6440         necessary to be able to use this file as a normal header.
6441         * gst/schedulers/Makefile.am: Add compiling support for fair
6442         scheduler.
6443         * docs/gst/Makefile.am (IGNORE_HFILES): Exclude internal fair
6444         scheduler cothreads layer from documentation generation.
6445
6446 2004-11-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6447
6448         * gst/autoplug/gstspideridentity.c:
6449         (gst_spider_identity_sink_loop_type_finding):
6450           Don't crash if that function is not implemented.
6451
6452 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6453
6454         * docs/pwg/advanced-types.xml:
6455           Another typo.
6456
6457 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6458
6459         * docs/pwg/intro-preface.xml:
6460           Hm, ok, so the brackets weren't really useful...
6461         * docs/pwg/other-ntoone.xml:
6462           Fix embarassing typo.
6463
6464 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6465
6466         * docs/pwg/intro-preface.xml:
6467           Rewrite preface.
6468
6469 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6470
6471         * docs/pwg/advanced-scheduling.xml:
6472         * docs/pwg/advanced-tagging.xml:
6473         * docs/pwg/advanced-types.xml:
6474         * docs/pwg/building-boiler.xml:
6475         * docs/pwg/building-chainfn.xml:
6476         * docs/pwg/building-signals.xml:
6477         * docs/pwg/building-state.xml:
6478         * docs/pwg/building-testapp.xml:
6479         * docs/pwg/intro-basics.xml:
6480         * docs/pwg/other-manager.xml:
6481         * docs/pwg/other-source.xml:
6482           Typo fixes.
6483         * docs/pwg/other-manager.xml:
6484           Add some first content. No example code yet.
6485         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
6486           Remove double newlines.
6487
6488 2004-11-04  Wim Taymans  <wim@fluendo.com>
6489
6490         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
6491         (remove_from_group), (normalize_group), (group_migrate_connected),
6492         (gst_opt_scheduler_iterate):
6493         * testsuite/schedulers/.cvsignore:
6494         * testsuite/schedulers/Makefile.am:
6495         * testsuite/schedulers/queue_link.c: (main):
6496         Added testcase for scheduler segfault.
6497         Fix scheduler segfault when removing a decoupled
6498         entry point as the last element from a group.
6499
6500 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
6501
6502         * gst/gstmarshal.list: add missing marshaller, fixes build
6503
6504 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
6505
6506         * docs/random/signal: added notes about using BOXED for GstBuffer
6507         signal marshallers, not POINTER
6508
6509 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
6510
6511         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
6512         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init): more
6513         POINTER=>BOXED changes to marshal GstBuffers
6514
6515 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
6516
6517         * gst/elements/gstidentity.c: (gst_identity_class_init): GstBuffer is 
6518         a boxed type, marshal the signal with VOID__BOXED, not VOID__POINTER
6519
6520 2004-11-03  Stefan Kost  <ensonic@users.sf.net>
6521
6522         * docs/gst/gstreamer-sections.txt:
6523         * docs/gst/tmpl/gstcaps.sgml:
6524         * docs/gst/tmpl/gsterror.sgml:
6525         * docs/gst/tmpl/gstinfo.sgml:
6526         * docs/gst/tmpl/gstmacros.sgml:
6527         * docs/gst/tmpl/gstutils.sgml:
6528         * docs/random/ensonic/interfaces.txt:
6529         * gst/gstinfo.h:
6530           added some more docs, removed two obsolete defines
6531
6532 2004-11-02  Kjartan Maraas <as at gnome.org>
6533
6534         reviewed by: Wim Taymans, Ronald Bultje.
6535
6536         * gst/cothreads.c: (cothread_create):
6537         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_remove_func),
6538         (gst_bin_child_state_change_func):
6539         * gst/gstbuffer.c: (gst_buffer_span):
6540         * gst/gstelement.c: (gst_element_get_index),
6541         (gst_element_get_event_masks), (gst_element_get_query_types),
6542         (gst_element_get_formats):
6543         * gst/gsterror.c: (_gst_core_errors_init),
6544         (_gst_library_errors_init), (_gst_resource_errors_init),
6545         (_gst_stream_errors_init):
6546         * gst/gstobject.c: (gst_object_default_deep_notify):
6547         * gst/gstpad.c: (gst_pad_get_event_masks),
6548         (gst_pad_get_internal_links_default):
6549         * gst/gstplugin.c: (gst_plugin_register_func),
6550         (gst_plugin_get_module):
6551         * gst/gststructure.c: (gst_structure_get_string),
6552         (gst_structure_get_abbrs), (gst_structure_from_abbr),
6553         (gst_structure_to_abbr):
6554         * gst/gstutils.c: (gst_print_element_args):
6555         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
6556         (setup_group_scheduler), (gst_opt_scheduler_iterate):
6557         Aplied part of patch #157127: Cleanup of issues reported by 
6558         sparse.
6559         Also do not try to use cothreads when there is no cothread
6560         context yet.
6561
6562 2004-11-02  Sebastien Cote <sc5 at hermes.usherb.ca>
6563
6564         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
6565         (gst_opt_scheduler_iterate):
6566         Applied patch #154061. Running a pipeline in which an element 
6567         calls GST_ELEMENT_ERROR in the chain function, the opt 
6568         scheduler doesn't unref the chain so it never gets freed.
6569
6570 2004-11-02  Wim Taymans  <wim@fluendo.com>
6571
6572         * gst/gststructure.c: (gst_structure_get_abbrs),
6573         (gst_structure_from_abbr), (gst_structure_to_abbr):
6574         Remove that ugly if-then thing in the code that converts
6575         between strings and types.
6576
6577 2004-11-02  Wim Taymans  <wim@fluendo.com>
6578
6579         * gst/gstscheduler.c: (gst_scheduler_add_element),
6580         (gst_scheduler_remove_element), (gst_scheduler_state_transition):
6581         Aplied clock distribution patch, this should fix bug
6582         #148787.
6583
6584 2004-10-27  Thomas Vander Stichele  <thomas at apestaart dot org>
6585
6586         Submitted by: Kjartan Maraas <kmaraas@broadpark.no>
6587
6588         * po/LINGUAS:
6589         * po/nb.po:
6590           Added Norwegian Bokmaal translation
6591
6592 2004-10-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6593
6594         * tools/gst-inspect.c: (print_signal_info):
6595           print signal arguments as pointers if they are
6596
6597 2004-10-22  Stefan Kost  <ensonic@users.sf.net>
6598
6599         * docs/pwg/building-boiler.xml:
6600           exchanged GTK_ macros with G_TYPE macros (as pointed out by mathrick)
6601
6602 2004-10-19  Wim Taymans  <wim at fluendo dot com>
6603
6604         * gst/parse/parse.l:
6605         * testsuite/parse/parse1.c: (main):
6606         Since parse can do 'element name=a:b' make 'a:b.' work as
6607         well. 
6608         Added testcase to verify fix.
6609
6610 2004-10-19  Wim Taymans  <wim at fluendo dot com>
6611
6612         * tools/gst-inspect.c: (print_pad_info), (print_plugin_features):
6613         Use the realpad when printing the direction.
6614         Add extra \n when printing extensions of typefind factories.
6615
6616 2004-10-13  David Schleef  <ds@schleef.org>
6617
6618         * examples/manual/Makefile.am: $< isn't portable in Makefile
6619         rules.
6620
6621 2004-10-13  Stefan Kost  <ensonic@users.sf.net>
6622
6623         * docs/gst/tmpl/gstobject.sgml:
6624         * docs/gst/tmpl/gstplugin.sgml:
6625         * docs/gst/tmpl/gstpluginfeature.sgml:
6626         * docs/gst/tmpl/gstregistry.sgml:
6627         * docs/gst/tmpl/gstversion.sgml:
6628         * gst/gstbin.c:
6629           more api documentation
6630         * gst/gstplugin.c: (gst_plugin_register_func),
6631         (gst_plugin_check_file), (gst_plugin_load_file):
6632           better error signaling and logging
6633
6634 2004-10-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6635
6636         * gst/gstqueue.c: (gst_queue_init), (gst_queue_handle_src_query):
6637           Subtract current queue contents from position queries.
6638
6639 2004-10-11  Johan Dahlin  <johan@gnome.org>
6640
6641         * gst/gsturi.c (gst_uri_get_location): unescape string
6642         (gst_uri_construct): escape string.
6643
6644 2004-10-11  Benjamin Otte  <otte@gnome.org>
6645
6646         * gst/gstpad.c: (gst_pad_renegotiate), (gst_pad_try_set_caps),
6647         (gst_pad_try_set_caps_nonfixed):
6648           allow renegotiation of unconnected pads (as inside spider). Simply
6649           return OK if unconnected - mimic try_set_caps there.
6650
6651 2004-10-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6652
6653         * gst/gstbin.c: (gst_bin_sync_children_state):
6654           Add missing break.
6655
6656 2004-10-09  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6657
6658         * gst/elements/gstfakesrc.c: (gst_fakesrc_get):
6659         Set element to EOS before sending EOS event
6660
6661 2004-10-08  Wim Taymans  <wim at fluendo dot com>
6662
6663         * gst/elements/gsttypefindelement.c:
6664         (gst_type_find_element_handle_event):
6665         Handle EOS events when doing the transition from
6666         typefind to data passing. This should fix the
6667         infinite loops in short files.
6668
6669 2004-10-07  Wim Taymans  <wim at fluendo dot com>
6670
6671         * gst/gstthread.c: (gst_thread_change_state),
6672         (gst_thread_child_state_change):
6673         Make sure no iteration happens while performing
6674         the state change as it could mess up the internal
6675         consistency of the thread state.
6676
6677 2004-10-07  Wim Taymans  <wim at fluendo dot com>
6678
6679         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_sync),
6680         (gst_thread_change_state), (gst_thread_child_state_change):
6681         Do not try to grab the iterate lock in the state change method
6682         when we are in the same thread as the iterate or else we
6683         could deadlock. Some other cleanups.
6684
6685 2004-10-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6686
6687         * configure.ac:
6688           bump nano to cvs
6689
6690 === release 0.8.7 ===
6691
6692 2004-10-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6693
6694         * configure.ac:
6695         * NEWS:
6696         * RELEASE:
6697         * configure.ac:
6698           releasing 0.8.7, "A Cruise"
6699
6700 2004-10-06  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
6701
6702         * docs/random/mimetypes:
6703         Add an entry for Sony ATRAC3 audio format with mime-type
6704         used by rmdemux et riff-read
6705
6706 2004-10-06  Wim Taymans  <wim at fluendo dot com>
6707
6708         * gst/elements/gsttypefindelement.c: (stop_typefinding):
6709         Push the buffer store instead of clearing it in case that
6710         the stream is not seekable.
6711
6712 2004-10-06  Wim Taymans  <wim at fluendo dot com>
6713
6714         * gst/gstthread.c: (gst_thread_init), (gst_thread_change_state),
6715         (gst_thread_main_loop):
6716         Lock the iteration and the state change so that automatic
6717         negotiation and fixation does not happen at the same time
6718         as the in stream negotiation.
6719
6720 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
6721
6722         * configure.ac:
6723           bump nano to cvs
6724
6725 === release 0.8.6 ===
6726
6727 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
6728
6729         * configure.ac:
6730         * NEWS:
6731         * RELEASE:
6732         * configure.ac:
6733           releasing 0.8.6, "Narc"
6734
6735 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
6736
6737         * configure.ac:
6738           prerel bump
6739
6740 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
6741
6742         patch by: Steve Lhomme
6743
6744         * gst/elements/gstfakesrc.c:
6745         * gst/elements/gstidentity.c:
6746         * gst/gstthread.c:
6747           Fix for #153881
6748
6749 2004-10-01  Wim Taymans  <wim at fluendo dot com>
6750
6751         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_crc):
6752         Fix threadsafety of the crc checking function.
6753
6754 2004-09-26  Thomas Vander Stichele  <thomas at apestaart dot org>
6755
6756         patch by: Ronald Bultje
6757
6758         * gst/elements/gsttypefindelement.c: (stop_typefinding),
6759         (gst_type_find_element_handle_event),
6760         (gst_type_find_element_chain):
6761         * gst/elements/gsttypefindelement.h:
6762          #153657.
6763          Filter out discont event from seekable sources when typefind
6764          asks them to seek.  Fixes typefind with demuxers for
6765          avi, asf and matroska.
6766
6767 2004-09-26  Thomas Vander Stichele  <thomas at apestaart dot org>
6768
6769         * docs/gst/gstreamer-sections.txt:
6770         * gst/gstcaps.c:
6771         * gst/gstcaps.h:
6772         * gst/gstpad.c:
6773           Revert preferred caps: (#147789)
6774
6775 2004-09-19  Steve Lhomme  <steve.lhomme@free.fr>
6776
6777         * win32/dirent.c:
6778           fix a memory leak
6779
6780 2004-09-10  Thomas Vander Stichele  <thomas at apestaart dot org>
6781
6782         * configure.ac:
6783           bump for prerelease
6784
6785 2004-09-09  Thomas Vander Stichele  <thomas at apestaart dot org>
6786
6787         * docs/Makefile.am:
6788         * docs/manual/elements-api.xml:
6789           restructure so that common stuff is shown first
6790         * docs/manual/init-api.xml:
6791           convert to examples
6792         * docs/manual/manual.xml:
6793         * docs/manuals.mak:
6794         * docs/url.entities:
6795           link to API on the website, possibly override later in build
6796         * examples/manual/.cvsignore:
6797           ignore more
6798         * examples/manual/Makefile.am:
6799           add more examples
6800         * examples/manual/extract.pl:
6801           error out on failure
6802
6803 2004-09-08  Thomas Vander Stichele  <thomas at apestaart dot org>
6804
6805         * docs/gst/tmpl/gstthread.sgml:
6806         * docs/manual/init-api.xml:
6807         * examples/manual/Makefile.am:
6808           convert two code bits to examples
6809
6810 2004-09-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6811
6812         * gst/gstelement.c: (gst_element_change_state):
6813           Well, actually, I was about to remove this insane assert when
6814           I noticed Wim already did that. A warning is nice so we can
6815           fix actual ugs (using --g-fatal-warnings and backtraces), so
6816           I added that instead.
6817
6818 2004-09-06  Wim Taymans  <wim@fluendo.com>
6819
6820         * gst/gstelement.c: (gst_element_threadsafe_properties_pre_run),
6821         (gst_element_threadsafe_properties_post_run),
6822         (gst_element_set_state), (gst_element_change_state):
6823         Added extra refcounting around various places. 
6824
6825 2004-09-06  Wim Taymans  <wim@fluendo.com>
6826
6827         * gst/gstpad.c: (gst_pad_link_call_link_functions):
6828         Fix debug info.
6829
6830 2004-09-06  Wim Taymans  <wim@fluendo.com>
6831
6832         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
6833         (remove_from_group):
6834         Some more debug info.
6835
6836 2004-09-03  Wim Taymans  <wim@fluendo.com>
6837
6838         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
6839         (gst_fakesrc_init), (gst_fakesrc_set_clock),
6840         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
6841         (gst_fakesrc_get), (gst_fakesrc_change_state):
6842         * gst/elements/gstfakesrc.h:
6843         * gst/elements/gstidentity.c: (gst_identity_class_init),
6844         (gst_identity_init), (gst_identity_chain),
6845         (gst_identity_set_property), (gst_identity_get_property),
6846         (gst_identity_change_state):
6847         * gst/elements/gstidentity.h:
6848         Added datarate properties to limit the datarate.
6849
6850 2004-08-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6851
6852         * gst/autoplug/gstspider.c: (plugin_init):
6853           don't set a rank. We don't want to autoplug by inserting spiders.
6854
6855 2004-08-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6856
6857         * gst/autoplug/gstspider.c: (gst_spider_class_init),
6858         (gst_spider_identity_plug):
6859           add a template for spider's sink
6860         * gst/gst.c: (gst_register_core_elements):
6861           queue's rank should be NULL, we don't want spider to add it.
6862
6863 2004-08-18  David Schleef  <ds@schleef.org>
6864
6865         * docs/gst/Makefile.am: Remove --ignore-fail-on-non-empty (#150331)
6866         * docs/libs/Makefile.am: same
6867         * docs/gst/tmpl/gstxml.sgml: Remove GstXMLNs
6868         * docs/random/ds/0.9-planning: random additions
6869         * docs/random/ds/0.9-suggested-changes: same
6870         * gst/gstxml.h: remove vestigal GstXMLNs definition
6871
6872         Preferred caps: (#147789)
6873         * docs/gst/gstreamer-sections.txt: Add symbols
6874         * docs/gst/tmpl/gstcaps.sgml: Add symbols
6875         * gst/gstcaps.c: (gst_caps_copy), (gst_caps_free),
6876         (gst_caps_append), (gst_caps_copy_1), (gst_caps_intersect),
6877         (gst_caps_union), (gst_caps_save_thyself), (gst_caps_load_thyself),
6878         (gst_caps_get_preferred), (gst_caps_set_preferred),
6879         (gst_caps_get_structure_by_id), (gst_caps_prefer_foreach),
6880         (gst_caps_use_preferred): Handle caps preferences
6881         * gst/gstcaps.h: Add caps preferences
6882         * gst/gstpad.c: (gst_pad_link_get_preferred),
6883         (gst_pad_link_fixate), (gst_pad_link_call_link_functions),
6884         (gst_pad_renegotiate), (gst_pad_guess_preferred),
6885         (gst_pad_get_caps), (gst_pad_push):  Use caps preferences for
6886         negotiation.
6887
6888 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6889
6890         * gst/autoplug/gstspideridentity.c:
6891         (gst_spider_identity_request_new_pad):
6892         * gst/elements/gstaggregator.c: (gst_aggregator_base_init),
6893         (gst_aggregator_init):
6894         * gst/elements/gstfakesink.c: (gst_fakesink_base_init),
6895         (gst_fakesink_init):
6896         * gst/elements/gstfakesrc.c: (gst_fakesrc_base_init),
6897         (gst_fakesrc_init):
6898         * gst/elements/gstfdsink.c: (gst_fdsink_base_init),
6899         (gst_fdsink_init):
6900         * gst/elements/gstfdsrc.c: (gst_fdsrc_base_init), (gst_fdsrc_init):
6901         * gst/elements/gstfilesink.c: (gst_filesink_base_init),
6902         (gst_filesink_init):
6903         * gst/elements/gstfilesrc.c: (gst_filesrc_base_init),
6904         (gst_filesrc_init):
6905         * gst/elements/gstidentity.c: (gst_identity_base_init),
6906         (gst_identity_init):
6907         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_base_init),
6908         (gst_multifilesrc_init):
6909         * gst/elements/gstpipefilter.c: (gst_pipefilter_base_init),
6910         (gst_pipefilter_init):
6911         * gst/elements/gststatistics.c: (gst_statistics_base_init),
6912         (gst_statistics_init):
6913         * gst/elements/gsttee.c: (gst_tee_base_init), (gst_tee_init):
6914         * gst/gstqueue.c: (gst_queue_base_init), (gst_queue_init):
6915           s/gst_pad_new/&_from_template/
6916           register pad templates in the base_init function
6917           add static pad template definitions
6918
6919 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6920
6921         * testsuite/bytestream/gstbstest.c: (gst_bstest_init):
6922         * testsuite/dynparams/dparamstest.c: (gst_dptest_init):
6923         * testsuite/refcounting/pad.c: (main):
6924         * testsuite/refcounting/thread.c: (create_thread_ghostpads):
6925           s/gst_pad_new/&_from_template/
6926           prepare deprecation of gst_pad_new
6927
6928 2004-08-17  Thomas Vander Stichele  <thomas at apestaart dot org>
6929
6930         patch by: Luca Ognibene <skaboy81@virgilio.it>
6931
6932         * gst/gstcaps.c:
6933         * gst/gstelement.c:
6934         * gst/gstpad.c:
6935         * gst/gstxml.c:
6936           fix memleaks.  Fixes #150001
6937
6938 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6939
6940         * docs/random/ds/0.9-suggested-changes:
6941           add notes - mostly about pad templates
6942
6943 2004-08-16  Steve Lhomme  <steve.lhomme@free.fr>
6944
6945         * win32/GStreamer.vcproj:
6946           temporary locale files are .gmo not .mo
6947
6948 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
6949
6950         * configure.ac: bump nano to cvs
6951
6952 === release 0.8.5 ===
6953
6954 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
6955
6956         * configure.ac:
6957           releasing 0.8.5, "Stuttgart"
6958         * NEWS:
6959         * RELEASE:
6960         * configure.ac:
6961         * docs/random/release:
6962           updates for release
6963
6964 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
6965
6966         patch by: Wim Taymans (wim@fluendo.com)
6967
6968         * gst/gstbuffer.c:
6969         * gst/gstindex.h:
6970         * libs/gst/dataprotocol/dataprotocol.c:
6971           copy KEY_UNIT and DELTA_UNIT flags correctly.  Fixes #150242
6972
6973 2004-08-13  Thomas Vander Stichele  <thomas at apestaart dot org>
6974
6975         * Makefile.am:
6976         * win32/MANIFEST:
6977           add win32 dir to the build.  Fixes #149981.
6978
6979 2004-08-13  Thomas Vander Stichele  <thomas at apestaart dot org>
6980
6981         * configure.ac:
6982           bump libtool versioning
6983         * gst/gststructure.c:
6984           mark function as static
6985         * po/af.po:
6986         * po/az.po:
6987         * po/ca.po:
6988         * po/cs.po:
6989         * po/en_GB.po:
6990         * po/fr.po:
6991         * po/nl.po:
6992         * po/sq.po:
6993         * po/sr.po:
6994         * po/sv.po:
6995         * po/tr.po:
6996         * po/uk.po:
6997           translations update
6998         * win32/README.txt:
6999           trademark protection
7000
7001 2004-08-12  Thomas Vander Stichele  <thomas at apestaart dot org>
7002
7003         * configure.ac:
7004           fix GST_ORIGIN
7005           set GST_PACKAGE to source, and distinguish between release and other
7006         * tools/gst-inspect.c:
7007           print out plugin an element factory is part of so we see this info
7008
7009 2004-08-12  Thomas Vander Stichele  <thomas at apestaart dot org>
7010
7011         * docs/gst/gstreamer-sections.txt:
7012         * docs/gst/tmpl/gstbuffer.sgml:
7013         * docs/gst/tmpl/gstschedulerfactory.sgml:
7014           reorder docs a little, make GstBuffer's more sensible.
7015         * gst/gstbuffer.h:
7016           API: added GST_BUFFER_FLAG_DELTA_UNIT
7017         * gst/gstscheduler.c:
7018           comment API addition
7019
7020 2004-08-12  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7021
7022         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
7023           work with non-regular files that can be mmapped (like /dev/zero)
7024         * gst/elements/gsttypefindelement.c: (gst_type_find_element_chain):
7025           get rid of typefinds that require a seek when we can't seek instead
7026           of trying them over and over again
7027         * tools/gst-launch.c: (idle_func), (error_cb), (main):
7028           return non-zero failure value when the pipeline was interrupted or
7029           an error occurred
7030
7031 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
7032
7033         * win32/config.h:
7034         * win32/GStreamer.vcproj:
7035           compile and install the locales
7036
7037 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
7038
7039         * gst/gstvalue.c:
7040           fix a possible memory leak under Windows
7041
7042 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
7043
7044         * win32/GStreamer.vcproj:
7045           fix a memory leak that occured under Windows
7046         * win32/gstreamer.def:
7047           add gst_scheduler_register
7048
7049 2004-08-11  Benjamin Otte  <otte@gnome.org>
7050
7051         * docs/gst/gstreamer-sections.txt:
7052         * gst/gstscheduler.c: (gst_scheduler_register):
7053         * gst/gstscheduler.h:
7054           API:
7055           add gst_scheduler_register shortcut similar to gst_element_register
7056         * gst/schedulers/entryscheduler.c: (plugin_init):
7057         * gst/schedulers/gstbasicscheduler.c: (plugin_init):
7058         * gst/schedulers/gstoptimalscheduler.c: (plugin_init):
7059           use it
7060
7061 2004-08-10  Steve Lhomme  <steve.lhomme@free.fr>
7062
7063         * gst/gstvalue.h:
7064           fix a memory leak that occured under Windows
7065
7066 2004-08-10  Colin Walters  <walters@redhat.com>
7067
7068         * gst/registries/gstxmlregistry.c (gst_xml_registry_open_func):
7069         Don't use O_EXCL to open temporary registry.  It will prevent
7070         registry creation if a temporary one already exists, which
7071         is unnecessary.
7072
7073 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
7074
7075         * docs/gst/gstreamer-sections.txt:
7076         * docs/gst/tmpl/gstvalue.sgml:
7077           remove some valuable stuff from the documentation due to the use of GST_EXPORT
7078
7079 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
7080
7081         * win32/gstbytestream.vcproj:
7082         * win32/gstelements.vcproj:
7083         * win32/gstgetbits.vcproj:
7084         * win32/gst-inspect.vcproj:
7085         * win32/gst-launch.vcproj:
7086         * win32/gstoptimalscheduler.vcproj:
7087         * win32/GStreamer.vcproj:
7088         * win32/gst-register.vcproj:
7089         * win32/gstspider.vcproj:
7090           update the include and lib dirs to fit standard libraries as
7091           described in the Win32 manual
7092
7093 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
7094
7095         * win32/config.h:
7096         * win32/gstversion.h:
7097           enable NLS again, push the version number for the coming 0.8.5 release
7098
7099 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
7100
7101         * gst/gstvalue.h:
7102           export gst_type_XXX for windows DLLs
7103
7104 2004-08-09  Thomas Vander Stichele  <thomas at apestaart dot org>
7105
7106         * docs/faq/gst-uninstalled:
7107           fix PKG_CONFIG_PATH and PYTHONPATH
7108         * gst/schedulers/Makefile.am:
7109           cleanup
7110         * libs/gst/bytestream/bytestream.c:
7111           remove newline
7112         * po/LINGUAS:
7113         * po/sq.po:
7114           adding Albanian translation (Laurent Dhima)
7115         * po/cs.po:
7116           updated
7117
7118 2004-08-05  Thomas Vander Stichele  <thomas at apestaart dot org>
7119
7120         * po/ca.po:
7121         * po/sv.po:
7122           updated translations
7123
7124 2004-08-04  Benjamin Otte  <otte@gnome.org>
7125
7126         * tests/mass_elements.c: (main):
7127           allow specifying src and sink element explicitly, so I can test
7128           videotestsrc instead of fakesrc
7129
7130 2004-08-04  Benjamin Otte  <otte@gnome.org>
7131
7132         * gst/gststructure.c: (gst_structure_id_empty_new_with_size),
7133         (gst_structure_id_empty_new), (gst_structure_empty_new),
7134         (gst_structure_copy):
7135           add gst_structure_id_empty_new_with_size to allow preallocating
7136           value array sizes. Use this in gst_structure_copy to get rid of
7137           reallocs.
7138           don't do quark=>string=>quark when copying structures
7139
7140 2004-08-03  Steve Lhomme  <steve.lhomme@free.fr>
7141
7142         * docs/manual/win32.xml:
7143         * win32/README.txt:
7144           update documentation with the clean version of dependencies
7145
7146 2004-08-03  Benjamin Otte  <otte@gnome.org>
7147
7148         * gst/schedulers/entryscheduler.c:
7149         (gst_entry_scheduler_remove_element):
7150           fix for GST_DISABLE_DEBUG
7151         * tools/gst-launch.c: (print_tag):
7152           fixes for G_DISABLE_ASSERT
7153
7154 2004-08-03  Benjamin Otte  <otte@gnome.org>
7155
7156         * gst/gst.c: (gst_register_core_elements):
7157           fix for G_DISABLE_ASSERT
7158         * gst/gstinfo.c: (__gst_in_valgrind):
7159           add for GST_DISABLE_DEBUG
7160
7161 2004-08-03  Benjamin Otte  <otte@gnome.org>
7162
7163         * gst/parse/parse.l:
7164           fix for G_DISABLE_ASSERT
7165
7166 2004-08-03  Wim Taymans  <wim@fluendo.com>
7167
7168         * gst/gstbin.c: (gst_bin_get_type),
7169         (gst_bin_child_state_change_func):
7170         * gst/gstthread.c: (gst_thread_change_state):
7171         Backported some debug logging from a reverted patch
7172         Don't try to destroy the thread twice. Added some more
7173         debugging in GstThread. Unlock and signal even if we
7174         are in the thread context.
7175
7176 2004-08-03  Thomas Vander Stichele  <thomas at apestaart dot org>
7177
7178         * po/uk.po:
7179           updated translation
7180
7181 2004-07-30  David Schleef  <ds@schleef.org>
7182
7183         * gst/gstatomic_impl.h: Enable atomic code for x86_64
7184
7185 2004-07-29  David Schleef  <ds@schleef.org>
7186
7187         * libs/gst/dataprotocol/dataprotocol-test.c: (conversion_test):
7188         Use GST_READ_GUINTxx_BE(), since it accesses unaligned memory.
7189
7190 2004-07-29  Thomas Vander Stichele  <thomas at apestaart dot org>
7191
7192         * gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
7193         (gst_bin_add_func), (gst_bin_remove_func),
7194         (gst_bin_child_state_change), (gst_bin_child_state_change_func),
7195         (set_kid_state_func), (gst_bin_change_state), (gst_bin_set_state),
7196         (gst_bin_change_state_norecurse), (gst_bin_dispose),
7197         (gst_bin_sync_children_state):
7198         * gst/gstbin.h:
7199         * gst/gstthread.c: (gst_thread_class_init), (gst_thread_release),
7200         (gst_thread_change_state):
7201         * testsuite/states/Makefile.am:
7202           revert state change patches as agreed so we can rework them
7203           gradually
7204
7205 2004-07-29  Benjamin Otte  <otte@gnome.org>
7206
7207         * libs/gst/control/Makefile.am:
7208           link to libgstreamer (fixes Debian bug 262019, see
7209           http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=262019 )
7210
7211 2004-07-29  Wim Taymans  <wim@fluendo.com>
7212
7213         * testsuite/caps/fraction-convert.c: (check_from_double_convert),
7214         (check_from_fraction_convert), (transform_test), (main):
7215         Make the test less pedantic about float roundoff errors.
7216
7217 2004-07-29  Benjamin Otte  <otte@gnome.org>
7218
7219         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file),
7220         (gst_filesrc_srcpad_event):
7221           make seek events to before start/after end of file not fail, but
7222           seek to start/end instead
7223         * testsuite/caps/fraction-convert.c: (check_from_double_convert):
7224           add more output
7225
7226 2004-07-29  Benjamin Otte  <otte@gnome.org>
7227
7228         * gst/gstpad.c: (gst_pad_set_explicit_caps):
7229           check that caps are fixed
7230         * gst/gstpad.c: (gst_pad_template_new):
7231           don't try to simplify caps, costs too much time on gst_init
7232         * gst/gstplugin.c: (gst_plugin_add_feature):
7233           G_ERROR if features are added twice
7234         * gst/gsttypefind.c: (gst_type_find_register):
7235         * gst/gstelementfactory.c: (gst_element_register):
7236           don't add features twice
7237         * docs/random/ds/0.9-suggested-changes:
7238           add note about possible gst_init optimization
7239
7240 2004-07-28  David Schleef  <ds@schleef.org>
7241
7242         * testsuite/elements/Makefile.am:
7243         * testsuite/elements/struct_i386.h:
7244         * testsuite/elements/struct_size.c: (main):  A little test
7245         to keep distcheck from working if someone changes a structure
7246         size accidentally.
7247
7248 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
7249
7250         * docs/libs/Makefile.am:
7251         * docs/libs/gstreamer-libs-docs.sgml:
7252         * docs/libs/gstreamer-libs-sections.txt:
7253         * docs/libs/tmpl/gstbytestream.sgml:
7254         * docs/libs/tmpl/gstcontrol.sgml:
7255         * docs/libs/tmpl/gstdataprotocol.sgml:
7256         * docs/libs/tmpl/gstgetbits.sgml:
7257         * libs/gst/bytestream/Makefile.am:
7258         * libs/gst/bytestream/bytestream.c:
7259         * libs/gst/bytestream/bytestream.h:
7260         * libs/gst/control/Makefile.am:
7261         * libs/gst/dataprotocol/Makefile.am:
7262         * libs/gst/getbits/Makefile.am:
7263         * libs/gst/getbits/getbits.h:
7264           various doc and style fixes, adding bytestream to libs docs.
7265
7266 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
7267
7268         * docs/gst/gstreamer-docs.sgml:
7269         * docs/libs/Makefile.am:
7270         * docs/libs/gstreamer-libs-docs.sgml:
7271         * docs/libs/gstreamer-libs-sections.txt:
7272         * libs/gst/control/dparam.c:
7273           more doc fixes.  gst-libs docs now build the same way as gst.
7274
7275 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
7276
7277         * configure.ac:
7278         * testsuite/Makefile.am:
7279         * testsuite/bins/Makefile.am:
7280         * testsuite/caps/Makefile.am:
7281         * testsuite/cleanup/Makefile.am:
7282         * testsuite/clock/Makefile.am:
7283         * testsuite/debug/Makefile.am:
7284         * testsuite/dlopen/Makefile.am:
7285         * testsuite/dynparams/Makefile.am:
7286         * testsuite/elements/.cvsignore:
7287         * testsuite/elements/Makefile.am:
7288         * testsuite/enumcaps/Makefile.am:
7289         * testsuite/enumcaps/enumcaps.c:
7290         * testsuite/ghostpads/Makefile.am:
7291         * testsuite/indexers/Makefile.am:
7292         * testsuite/negotiation/Makefile.am:
7293         * testsuite/parse/Makefile.am:
7294         * testsuite/plugin/Makefile.am:
7295         * testsuite/refcounting/Makefile.am:
7296         * testsuite/schedulers/.cvsignore:
7297         * testsuite/states/Makefile.am:
7298         * testsuite/tags/Makefile.am:
7299         * testsuite/threads/Makefile.am:
7300           fold enumcaps into caps dir
7301           clean up Makefile.am's for testsuite
7302
7303 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
7304
7305         * docs/gst/Makefile.am:
7306         * docs/libs/Makefile.am:
7307           clean up docs build.  Fixes needless rebuilding of template files.
7308
7309 2004-07-28  Wim Taymans  <wim@fluendo.com>
7310
7311         * gst/gstbin.c: (set_kid_state_func), (gst_bin_set_state):
7312         * gst/gstthread.c: (gst_thread_release), (gst_thread_set_state):
7313         Make sure that a bin state change tries to keep the children
7314         in sync. 
7315         Added debug logging to the thread.
7316
7317 2004-07-27  Steve Lhomme  <steve.lhomme@free.fr>
7318
7319         * win32/GStreamer.vcproj:
7320         * win32/gstreamer.def:
7321           more exports for the plugins
7322
7323 2004-07-27  Steve Lhomme  <steve.lhomme@free.fr>
7324
7325         * win32/gstgetbits.vcproj:
7326         * win32/gstgetbits.def:
7327         * win32/msvc71.sln:
7328           add support for the getbits plugin
7329
7330 2004-07-27  Wim Taymans  <wim@fluendo.com>
7331
7332         * gst/gstvalue.c: (gst_value_transform_double_fraction),
7333         (gst_value_transform_fraction_double), (_gst_value_initialize):
7334         * testsuite/caps/Makefile.am:
7335         * testsuite/caps/fraction-convert.c: (check_from_double_convert),
7336         (check_from_fraction_convert), (transform_test), (main):
7337         Added transform functions between double and fraction.
7338         Added testcase to verify transforms
7339
7340 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
7341
7342         * win32/GStreamer.vcproj:
7343           rename GStreamer-0.8.lib to libgstreamer.lib
7344
7345 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
7346
7347         * win32/gstelements.vcproj:
7348         * win32/gstoptimalscheduler.vcproj:
7349           fixes for the Release build
7350
7351 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
7352
7353         * win32/config.h:
7354           update the version number
7355
7356 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
7357
7358         * win32/GStreamer.vcproj:
7359           add gstinterface to the build
7360
7361 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
7362
7363         * win32/gstreamer.def:
7364           add many definitions needed by plugins,
7365           GST_CAT_DEFAULT only available in the Debug build ?
7366
7367 2004-07-26  Thomas Vander Stichele  <thomas at apestaart dot org>
7368
7369         * gst/gstelement.c: (gst_element_set_eos_recursive):
7370           various whitespace fixes.
7371           doc fix, fixes #148497
7372
7373 2004-07-25  Benjamin Otte  <otte@gnome.org>
7374
7375         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link):
7376           don't delay links on the sink elements, it causes unnegotiated
7377           links.
7378         * gst/elements/gsttypefindelement.c:
7379         (gst_type_find_element_base_init):
7380           add our padtemplates, we indeed do have some.
7381         * gst/elements/gsttypefindelement.c:
7382         (gst_type_find_element_handle_event),
7383         (gst_type_find_element_chain):
7384           don't push data when typefinding failed.
7385         * gst/gstpad.c: (gst_pad_link_fixate):
7386           check that no fixate function returns empty caps.
7387         * gst/gstpad.c: (gst_pad_push):
7388           check that the link is negotiated before data gets pushed.
7389         * tools/gst-register.c: (main):
7390           don't assert (fixes #148283)
7391
7392 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
7393
7394         * docs/gst/gstreamer-sections.txt:
7395         * docs/gst/tmpl/gstconfig.sgml:
7396           add GST_PLUGIN_EXPORT definition
7397
7398 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
7399
7400         * gst/gstplugin.h:
7401         * gst/gstconfig.h.in:
7402         * win32/gstconfig.h:
7403         * win32/gstelements.def:
7404         * win32/gstelements.vcproj:
7405         * win32/gstoptimalscheduler.def:
7406         * win32/gstoptimalscheduler.vcproj:
7407         * win32/gstspider.def:
7408         * win32/gstspider.vcproj:
7409           remove unused .def files and export symbols using GST_PLUGIN_DEFINE
7410
7411 2004-07-25  Thomas Vander Stichele  <thomas at apestaart dot org>
7412
7413         * docs/gst/gstreamer-sections.txt:
7414           remove GST_CAT_DEFAULT because the type has changed
7415
7416 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
7417
7418         * win32/gstbytestream.vcproj:
7419         * win32/gstelements.vcproj:
7420         * win32/gst-inspect.vcproj:
7421         * win32/gst-launch.vcproj:
7422         * win32/gstoptimalscheduler.vcproj:
7423         * win32/GStreamer.vcproj:
7424         * win32/gst-register.vcproj:
7425         * win32/gstspider.vcproj:
7426         * win32/msvc71.sln:
7427           Copy the files where needed after building, The testsuite will be
7428           built separately
7429
7430 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
7431
7432         * win32/config.h:
7433         * win32/README.txt:
7434         * docs/manual/win32.xml:
7435         Fixed the plugin and GStreamer location
7436
7437 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7438
7439         * win32/gstreamer.def:
7440         More exports for the plugins
7441
7442 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7443
7444         * gst/gstinfo.h:
7445         Marc was right, we need to export literally GST_CAT_DEFAULT
7446
7447 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7448
7449         * win32/config.h:
7450         NLS crashes in gettext, disabled until this is solved
7451
7452 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7453
7454         * win32/gst-inspect.vcproj:
7455         * win32/gst-launch.vcproj:
7456         Should use NLS when available
7457
7458 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7459
7460         * gst/registries/gstxmlregistry.c:
7461         removing the file doesn't seem to be a good idea on Linux
7462
7463 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7464
7465         * gst/registries/gstxmlregistry.c:
7466         Remove the registry before renaming the tempfile (needed for Windows)
7467
7468 2004-07-23  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7469
7470         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init),
7471         (gst_multifilesrc_init), (gst_multifilesrc_set_property),
7472         (gst_multifilesrc_get_property), (gst_multifilesrc_get):
7473         * gst/elements/gstmultifilesrc.h:
7474         Added newmedia property so it generates newmedia events between each
7475         file when property is set, as well as fixed eos handling
7476
7477 2004-07-22  David Schleef  <ds@schleef.org>
7478
7479         * gst/gststructure.c: (gst_structure_id_empty_new),
7480         (gst_structure_empty_new):  Set type field correctly.
7481         * gst/gststructure.h: Check type field correctly.
7482         * testsuite/caps/Makefile.am:
7483         * testsuite/caps/structure.c: (test1), (main): Add a very small
7484         test for structures.
7485
7486 2004-07-22  David Schleef  <ds@schleef.org>
7487
7488         * docs/random/ds/0.9-suggested-changes: more comments
7489         * tools/gst-launch.c: (idle_func): Fix hard-to-translate string.
7490
7491 2004-07-22  Benjamin Otte  <otte@gnome.org>
7492
7493         * gst/gstelementfactory.c: (gst_element_register):
7494           set the factory in the class struct, so gst_element_get_factory
7495           actually works
7496         * gst/parse/grammar.y:
7497           set element to playing when it gets unlocked as we can't rely on the
7498           bin state - all elements in the bin state might still be locked in
7499           NULL)
7500
7501 2004-07-22  Benjamin Otte  <otte@gnome.org>
7502
7503         * gst/gstelement.c: (gst_element_set_state_func):
7504           make this a static function
7505
7506 2004-07-22  Wim Taymans  <wim@fluendo.com>
7507
7508         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
7509         (gst_opt_scheduler_pad_link):
7510         fix 147894-2 and the group_link problem.
7511
7512 2004-07-22  Wim Taymans  <wim@fluendo.com>
7513
7514         * testsuite/schedulers/147894-2.c: (queue_empty), (queue_filled),
7515         (handoff_identity), (main):
7516         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
7517         (handoff_identity), (main):
7518         * testsuite/schedulers/Makefile.am:
7519         * testsuite/schedulers/group_link.c: (main):
7520         Show bug in scheduler when linking chain and loop based element 
7521         where the chain based element was not yet in a group.
7522
7523 2004-07-21  Benjamin Otte  <otte@gnome.org>
7524
7525         * gst/.cvsignore:
7526         * gst/autoplug/.cvsignore:
7527         * gst/elements/.cvsignore:
7528         * gst/indexers/.cvsignore:
7529         * libs/gst/bytestream/.cvsignore:
7530         * libs/gst/control/.cvsignore:
7531         * libs/gst/getbits/.cvsignore:
7532         * testsuite/states/.cvsignore:
7533         * testsuite/threads/.cvsignore:
7534           keep this up to date, since I seem to be the only one who cares
7535           about not missing files on commits (editor's note: no you don't,
7536           but feel free to change them at the time you add stuff instead
7537           of later on)
7538
7539 2004-07-21  Benjamin Otte  <otte@gnome.org>
7540
7541         * gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
7542         (gst_bin_fix_state), (gst_bin_add_func), (gst_bin_remove_func),
7543         (gst_bin_child_state_change_func), (set_kid_state_func),
7544         (gst_bin_set_state), (gst_bin_change_state_norecurse):
7545           make state changes work correctly and reentrant (so removing
7546           elements from bins during state changes of bins doesn't cause
7547           segfaults or even wrong states)
7548           add debugging category and debugging output to print children states
7549         * gst/gstbin.c: (gst_bin_dispose): 
7550           add some assertion checks
7551         * gst/gstbin.h:
7552         * gst/gstbin.c: (gst_bin_sync_children_state):
7553           deprecate this function - it just does gst_bin_set_state (bin,
7554           GST_STATE (bin)) 
7555         * testsuite/threads/queue.c: (main):
7556           don't use gst_bin_sync_children_state anymore
7557         * testsuite/states/Makefile.am:
7558         * testsuite/states/bin.c:
7559           test that the state changes of bins work as expected
7560         * gst/gstthread.c: (gst_thread_class_init), (gst_thread_set_state):
7561           some adjustments to change states correctly, too
7562         * gst/gstthread.c: (gst_thread_change_state):
7563           don't enable/disable "threadsafe" properties, they're unused and
7564           cause random segfaults
7565         * testsuite/threads/Makefile.am:
7566           the queue check randomly passes now, ignore it
7567
7568 2004-07-21  Benjamin Otte  <otte@gnome.org>
7569
7570         * gst/gstpad.c:
7571           check if data is NULL before outputting debug info. (fixes #145100)
7572
7573 2004-07-21  Benjamin Otte  <otte@gnome.org>
7574
7575         * gst/schedulers/entryscheduler.c:
7576         (gst_entry_scheduler_loop_wrapper),
7577         (gst_entry_scheduler_chain_wrapper),
7578         (gst_entry_scheduler_get_wrapper):
7579           reset the state when the cothread starts, so we don't get assertion
7580           failures on restarting of cothreads
7581
7582 2004-07-20  Benjamin Otte  <otte@gnome.org>
7583
7584         * gst/gstelement.c: (gst_element_link_pads_filtered):
7585           use correct sinkpad, if only sinkpad is specified, but not srcpad
7586           (fixes #147889)
7587         * gst/gstelement.c: (gst_element_set_state_func),
7588         (gst_element_change_state): ref/unref the element, signal handlers
7589         could get rid of the element otherwise
7590
7591 2004-07-20  Ronald Bultje  <rbultje@ronald.bitfreak.net>
7592
7593         * docs/random/ds/0.9-suggested-changes:
7594           Make note about renaming fixed-list to array.
7595         * gst/gstvalue.c: (gst_value_intersect_fixed_list),
7596         (_gst_value_initialize):
7597           Add array intersections.
7598         * testsuite/caps/intersect2.c: (main):
7599           Add test for array intersections.
7600
7601 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7602
7603         * configure.ac: back to cvs
7604
7605 === release 0.8.4 ===
7606
7607 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7608
7609         * configure.ac:
7610           releasing 0.8.4, "Paella"
7611           bump libtool versioning
7612
7613 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7614
7615         * po/LINGUAS:
7616         * po/ca.po:
7617           adding Catalan translation (Jordi Mallach)
7618
7619 2004-07-20  Wim Taymans  <wim@fluendo.com>
7620
7621         * testsuite/schedulers/147894-2.c: (queue_empty), (queue_filled),
7622         (handoff_identity), (main):
7623         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
7624         (handoff_identity), (main):
7625         * testsuite/schedulers/Makefile.am:
7626         Added failing testcase for variant of #147894
7627
7628 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7629
7630         patch by: David Moore
7631
7632         * gst/schedulers/gstoptimalscheduler.c: (group_has_element),
7633         (schedule_group), (gst_opt_scheduler_schedule_run_queue),
7634         (group_migrate_connected):
7635         * testsuite/schedulers/Makefile.am:
7636           fix for #142813 (Deadlock in optimal scheduler)
7637
7638 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7639
7640         patch by: Wim Taymans
7641
7642         * gst/schedulers/gstoptimalscheduler.c: (group_has_element),
7643         (gst_opt_scheduler_schedule_run_queue),
7644         (gst_opt_scheduler_get_wrapper), (get_group),
7645         (group_migrate_connected):
7646         * testsuite/schedulers/Makefile.am:
7647           fix for #147819 (Add some checks in the opt scheduler)
7648
7649 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7650
7651         patch by: Benjamin Otte
7652
7653         * gst/gstelementfactory.c: (__gst_element_details_set):
7654           fix for #147929: running gst-register in non-utf8 locale can cause
7655           invalid registry
7656
7657 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7658
7659         patch by: Wim Taymans
7660
7661         * gst/schedulers/gstoptimalscheduler.c: (group_num_elements),
7662         (group_has_element), (element_get_reachables_func),
7663         (group_migrate_connected):
7664           fix for #147894 (opt scheduler decoupled elements mismanagement)
7665         * testsuite/schedulers/Makefile.am:
7666           testsuite app now passes
7667
7668 2004-07-19  Wim Taymans  <wim@fluendo.com>
7669
7670         * testsuite/schedulers/147819.c: (handoff_identity1),
7671         (handoff_identity2), (main):
7672         * testsuite/schedulers/Makefile.am:
7673         Added testcase for bug 147819
7674
7675 2004-07-19  Wim Taymans  <wim@fluendo.com>
7676
7677         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
7678         (handoff_identity), (main):
7679         * testsuite/schedulers/Makefile.am:
7680         Added testcase for bug 147894
7681
7682 2004-07-16  Wim Taymans  <wim@fluendo.com>
7683
7684         * testsuite/schedulers/142183-2.c: (handoff_identity), (main):
7685         * testsuite/schedulers/142183.c: (handoff_identity), (main):
7686         * testsuite/schedulers/Makefile.am:
7687         Added testsuite for bug 142183 in its two incarnations. Refcount
7688         is not increased for scheduled elements and threadsafe properties
7689         mutexes are not properly unlocked.
7690
7691 2004-07-16  Wim Taymans  <wim@fluendo.com>
7692
7693         * gst/schedulers/gstoptimalscheduler.c: (gst_opt_scheduler_init),
7694         (create_chain), (destroy_chain), (create_group), (destroy_group),
7695         (add_to_group), (merge_groups), (group_elements), (group_inc_link),
7696         (group_dec_link), (gst_opt_scheduler_pad_link),
7697         (group_inc_links_for_element), (group_migrate_connected):
7698         Call group_inc_link with the proper src->sink ordering -- 
7699         break this, and we break sort_chain. patch from wingo for bug
7700         147713.
7701         Partially revert patch 1.89. When adding a loop based element to 
7702         the scheduler, the links to other groups are automatically followed
7703         and incremented. This should not happen because the bin will call
7704         pad_link explicitly for those connection, resulting in them counted 
7705         twice. Results in assertion failure on pipeline cleanup.
7706
7707 2004-07-16  Wim Taymans  <wim@fluendo.com>
7708
7709         * testsuite/schedulers/143777-2.c: (main):
7710         * testsuite/schedulers/147713.c: (handoff_src), (handoff_sink),
7711         (main):
7712         * testsuite/schedulers/Makefile.am:
7713         Added cleanup code to testcase 143777-2.
7714         Added testcase to show bug 147713, does not really show the
7715         deadlock as I can't figure out how to trigger it, but it does
7716         demonstrate bad ordering in the scheduler.
7717
7718 2004-07-16  Thomas Vander Stichele  <thomas at apestaart dot org>
7719
7720         * gst/gstvalue.c: (gst_value_deserialize_fraction):
7721           change strndup to g_strndup.  Fixes #147707
7722
7723 2004-07-16  Thomas Vander Stichele  <thomas at apestaart dot org>
7724
7725         * po/af.po:
7726         * po/az.po:
7727         * po/cs.po:
7728         * po/en_GB.po:
7729         * po/fr.po:
7730         * po/nl.po:
7731         * po/sr.po:
7732         * po/sv.po:
7733         * po/tr.po:
7734         * po/uk.po:
7735           updated translations
7736
7737 2004-07-16  Benjamin Otte  <otte@gnome.org>
7738
7739         * gst/gstvalue.c: (gst_greatest_common_divisor):
7740           use ints and return ints, fractions only use ints, too, so this
7741           avoids accidently casting multiplications to unsigned
7742         (gst_value_lcopy_fraction): it's ints, not uint32
7743         (gst_value_set_fraction): disallow minint, multiplying and negation
7744           are broken with it
7745         (gst_value_fraction_multiply): fix to make large numbers work and get
7746         rid of the assumption that the multiplication of two ints fits an
7747         int64 - dunno if that's true for all systems
7748         * testsuite/caps/Makefile.am:
7749         * testsuite/caps/fraction-multiply-and-zero.c:
7750         (check_multiplication), (check_equal), (zero_test), (main):
7751           add tests for all the stuff above
7752         * testsuite/caps/value_compare.c: (test1):
7753           fix comment
7754         * tests/.cvsignore:
7755         * testsuite/caps/.cvsignore:
7756         * testsuite/debug/.cvsignore:
7757         * testsuite/dlopen/.cvsignore:
7758         * testsuite/states/.cvsignore:
7759           get up to date
7760
7761 2004-07-16  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7762
7763         * docs/manual/bins-api.xml:
7764         * docs/manual/factories.xml:
7765         * docs/manual/helloworld.xml:
7766         * docs/manual/links-api.xml: 
7767           fixes for out of date info, incorrect info and grammar
7768
7769 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7770
7771         * docs/manual/pads.xml:
7772         * docs/manual/pads-api.xml: grammar fix
7773
7774 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7775
7776         * docs/manual/pads-api.xml: typo + grammar fix
7777
7778 2004-07-15  Thomas Vander Stichele  <thomas at apestaart dot org>
7779
7780         * docs/gst/gstreamer-sections.txt:
7781           add new symbols
7782         * docs/gst/tmpl/gstelement.sgml:
7783         * docs/gst/tmpl/gstpad.sgml:
7784         * docs/gst/tmpl/gsttypes.sgml:
7785         * docs/gst/tmpl/gstvalue.sgml:
7786           update docs
7787         * gst/gststructure.c: (gst_structure_set_valist),
7788         (gst_structure_from_abbr), (gst_structure_to_abbr):
7789         * gst/gstvalue.c: (gst_value_compare_double), (gst_type_is_fixed),
7790         (gst_greatest_common_divisor), (gst_value_init_fraction),
7791         (gst_value_copy_fraction), (gst_value_collect_fraction),
7792         (gst_value_lcopy_fraction), (gst_value_set_fraction),
7793         (gst_value_get_fraction_numerator),
7794         (gst_value_get_fraction_denominator),
7795         (gst_value_fraction_multiply), (gst_value_serialize_fraction),
7796         (gst_value_deserialize_fraction),
7797         (gst_value_transform_fraction_string),
7798         (gst_value_transform_string_fraction),
7799         (gst_value_compare_fraction), (_gst_value_initialize):
7800         * gst/gstvalue.h:
7801           adding GstFraction GValue type, get/set, and multiply
7802         * testsuite/caps/Makefile.am:
7803         * testsuite/caps/fraction.c: (test), (main):
7804         * testsuite/caps/string-conversions.c: (main):
7805         * testsuite/caps/value_compare.c: (test1), (main):
7806           add regression tests for GstFraction
7807
7808 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7809         
7810         * docs/manual/init-api.xml: Grammar fix
7811
7812 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7813
7814         * docs/manual/states.xml: Fix inconsistent information
7815
7816 2004-07-15  Thomas Vander Stichele  <thomas at apestaart dot org>
7817
7818         * gst/gstelement.c: (gst_element_set_state):
7819         * gst/gstpad.c: (gst_pad_try_set_caps):
7820         * gst/gststructure.c:
7821         * gst/gstthread.c: (gst_thread_child_state_change):
7822         * gst/gstvalue.c: (gst_value_compare_double):
7823         * gst/gstvalue.h:
7824         * testsuite/parse/parse1.c: (main):
7825           debugging additions and style cleanups
7826
7827 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7828
7829         * docs/manual/states.xml: Grammar fix
7830
7831 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7832
7833         * docs/manual/pads.xml: Grammar fix
7834
7835 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7836
7837         * docs/manual/elements.xml: Fixed image reference
7838
7839 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7840
7841         * docs/manual/goals.xml: Grammar fix
7842
7843 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7844
7845         * docs/manual/motivation.xml:
7846         Bonobo is no longer "emerging" and added sentence regarding tcp plugins
7847
7848 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7849
7850         * docs/manual/motivation.xml: Fix spelling
7851
7852 2004-07-15  Benjamin Otte  <otte@gnome.org>
7853
7854         * gst/gstelement.h: 
7855           Don't GST_ERROR_OBJECT empty strings - Solaris doesn't like NULL
7856           strings.
7857         * gst/gstelement.c (gst_element_class_init):
7858           GError's are boxed, not objects
7859         * gst/gstmarshal.list:
7860           update list for the fixed error signal
7861
7862 2004-07-14  Andy Wingo  <wingo@pobox.com>
7863
7864         * gst/gsttag.c: Add a tag merge func for pointers. The header was
7865         there all along, but the function wasn't. (guile-gstreamer's build
7866         system uses the address of the function -- I wasn't actually
7867         trying to use this.)
7868
7869 2004-07-14  Andy Wingo  <wingo@pobox.com>
7870
7871         * gst/gstpad.c (gst_pad_try_set_caps): Naive link functions (such
7872         as gst_pad_proxy_pad_link) just link to every other pad when they
7873         are called. In the case where the graph has cycles, this will mean
7874         that a call to try_set_caps will recurse. Allow this recursion
7875         and return OK, while we wait for the first try_set_caps to give a
7876         proper return value.
7877         (gst_pad_link_call_link_functions): Since this function is the
7878         only one to set the NEGOTIATING flag on a pad, if the flag is set
7879         it means that the link functions have indirectly recursed. If this
7880         happens, error out to avoid infinite recursion and an eventual
7881         SEGV.
7882         (gst_real_pad_class_init): Remove a crufty GtkObject comment.
7883         (gst_pad_proxy_getcaps): Intersect the result with the template
7884         caps to ensure that the return value is valid.
7885
7886 2004-07-14  Andy Wingo  <wingo@pobox.com>
7887
7888         * gst/gstdata.c (gst_data_is_writable): s/>=/>/. If there is only
7889         one refcount, the calling function is the owner of the buffer.
7890
7891 2004-07-14  Wim Taymans  <wim@fluendo.com>
7892
7893         * gst/schedulers/gstoptimalscheduler.c: (group_dec_link),
7894         (gst_opt_scheduler_pad_link), (group_migrate_connected):
7895         Fix stupid warning when an element is to be migrated but
7896         is already migrated.
7897
7898 2004-07-14  Wim Taymans  <wim@fluendo.com>
7899
7900         * gst/schedulers/gstoptimalscheduler.c: (group_dec_link),
7901         (gst_opt_scheduler_pad_link), (group_migrate_connected):
7902         Make sure that a single non-loop-based element does not 
7903         end up in a group. This fixes the testsuite again.
7904
7905 2004-07-14  Wim Taymans  <wim@fluendo.com>
7906
7907         * gst/schedulers/gstoptimalscheduler.c: (create_group),
7908         (add_to_group), (merge_groups), (schedule_group),
7909         (gst_opt_scheduler_get_wrapper), (group_elements),
7910         (group_dec_link), (gst_opt_scheduler_pad_link),
7911         (group_migrate_connected), (gst_opt_scheduler_pad_unlink),
7912         (gst_opt_scheduler_iterate):
7913         move isolated groups to a new chain.
7914         Emit a warning instead of segfaulting in some error cases.
7915         Fix a bug where the link count between groups was not calculated 
7916         correctly. Fixes #144510.
7917
7918 2004-07-13  Steve Lhomme  <steve.lhomme@free.fr>
7919         * gst/elements/gstfilesrc.c:
7920           Binary files support under Windows now OK
7921       
7922 2004-07-13  Benjamin Otte  <otte@gnome.org>
7923
7924           compatibility fixes for Solaris 8/gcc 2.95
7925         * configure.ac:
7926           include libintl libs in LDFLAGS
7927         * gstvalue.c (gst_value_deserialize_buffer):
7928           cast isxdigit stuff to int to silence compiler warning
7929
7930 2004-07-12  Benjamin Otte  <otte@gnome.org>
7931
7932         * gst/gsttypes.h:
7933           get rid of GST_O_READONLY, GST_FILE_MODE_READ and
7934           GST_FILE_MODE_WRITE, I don't want them in the exported headers. It
7935           just causes support madness
7936         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
7937           make it work without this
7938         * gst/indexers/gstfileindex.c: (_file_index_id_save_entries),
7939         (gst_file_index_commit):
7940           glib IO channels don't want binary mode
7941         * testsuite/bytestream/filepadsink.c: (main):
7942         * testsuite/bytestream/test1.c: (read_param_file):
7943           use "rb" instead of GST_FILE_MODE_READ, it works on POSIX systems
7944
7945 2004-07-12  Benjamin Otte  <otte@gnome.org>
7946
7947         * gst/gstelement.c: (gst_element_class_init),
7948         (gst_element_set_state), (gst_element_set_state_func):
7949           virutalize gst_element_set_state, use set_state member in class
7950           struct that was already added in 0.7 for this.
7951         * gst/gstbin.c: (gst_bin_foreach), (set_kid_state_func), 
7952         (gst_bin_change_state):
7953           make gst_bin_foreach works similar to other foreach functions, plug
7954           memleaks in it. Make functions using it work with the new approach.
7955           Document gst_bin_foreach, so it can be exported if we want to
7956         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_state):
7957           use virtualized set_state to make set_state on bins set the state of
7958           all its children.
7959
7960 2004-07-12  Benjamin Otte  <otte@gnome.org>
7961
7962         * configure.ac:
7963           require valgrind >= 2.1 (fixes Gentoo bug 53967, see
7964           http://bugs.gentoo.org/show_bug.cgi?id=53967)
7965         * gst/gstpad.c: (gst_pad_alloc_buffer):
7966           allow buffer_alloc functions to return NULL and allocate a normal
7967           buffer in that case
7968
7969 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
7970         * gst/elements/gstfilesink.c:
7971         * gst/elements/gstfilesrc.c:
7972         * gst/indexers/gstfileindex.c:
7973         * gst/gsttypes.h:
7974         * testsuite/bytestream/filepadsink.c:
7975         * testsuite/bytestream/test1.c:
7976           Handle binary files under Windows
7977
7978 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
7979         * docs/manual/win32.xml:
7980         * win32/config.h:
7981         * win32/gst-register.vcproj:
7982         * win32/gstreamer.def:
7983           Update to another gettext public build
7984
7985 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
7986         * gst/gstplugin.c:
7987           Fix an impossible C syntax
7988         * win32/config.h:
7989           Disable i18n under Windows for the moment
7990         * win32/gst-register.vcproj:
7991           Use this configuration
7992
7993 2004-07-12  Jan Schmidt  <thaytan@mad.scientis.com>
7994         * docs/manual/quotes.xml:
7995           Keep the quotes file alive
7996         * docs/random/ds/0.9-suggested-changes:
7997           Add the suggestion of including a 'rowstride' as part of video
7998           format caps
7999
8000 2004-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
8001
8002         * gst/gstelement.c: (gst_element_set_state),
8003         (gst_element_change_state):
8004           d'oh.  Set PENDING state correctly before forcing bin to change.
8005         * gst/gststructure.c: (gst_structure_value_get_generic_type),
8006         (gst_structure_parse_fixed_list):
8007         * gst/schedulers/gstoptimalscheduler.c:
8008         (gst_opt_scheduler_state_transition):
8009         * testsuite/states/parent.c: (main):
8010           remove comment now that it's fixed.
8011
8012 2004-07-11  Benjamin Otte  <otte@gnome.org>
8013
8014         * gst/gstclock.h:
8015           GST_SECOND shouldn't cause a conversion to unsigned.
8016         * testsuite/clock/.cvsignore:
8017         * testsuite/clock/Makefile.am:
8018         * testsuite/clock/signedness.c: (main):
8019           make sure it never will again
8020
8021 2004-07-11  Andy Wingo  <wingo@pobox.com>
8022
8023         * gst/gstbin.c (gst_bin_add_func): If we're adding an element
8024         whose state is higher than the bin state, raise the bin state to
8025         ensure that bin state := highest child state.
8026         
8027 2004-07-11  Andy Wingo  <wingo@pobox.com>
8028
8029         * gst/gstbin.c (gst_bin_foreach): New static function. Calls a
8030         procedure on the children of a bin. Assumes that the procedure can
8031         change the set of children.
8032         (set_kid_state_func): New static function.
8033         (gst_bin_change_state): Use gst_bin_foreach to call
8034         set_kid_state_func. Fixes a bug: if a child had a state-change
8035         handler that removes it from the bin, there would be a segfault.
8036         Hopefully it should also work in the case where the state-change
8037         handler on one child adds or removes other children. In any case,
8038         fixes should go to gst_bin_foreach.
8039
8040 2004-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
8041
8042         * gst/gstelement.c: (gst_element_set_state):
8043           compatibility fix for latest plugins release.  Change loop back
8044           to while {}
8045
8046 2004-07-09  Wim Taymans  <wim@fluendo.com>
8047
8048         * gst/gstbin.c: (gst_bin_remove), (gst_bin_dispose):
8049         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_catch),
8050         (gst_thread_main_loop):
8051         Since remove is virtual in GstBin we must not assume the 
8052         elements GList to have anothing useful.
8053         Add some more logging to GstThread and be a bit more paranoid
8054         when resetting the scheduler.
8055         Set the state of the bin to NULL before removing the children.
8056
8057 2004-07-09  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
8058
8059         * testsuite/threads/Makefile.am:
8060         * testsuite/threads/threadg.c:
8061           added test to check if problem when removing all elements from a
8062           GstThread before setting GstThread state to NULL
8063
8064 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8065
8066         * docs/gst/tmpl/gstelement.sgml:
8067         * docs/gst/tmpl/gsttypes.sgml:
8068         * gst/gstbin.c: (gst_bin_change_state):
8069         * gst/gstelement.c: (gst_element_set_state),
8070         (gst_element_change_state):
8071           rework so that for bins we try to set the state on all children
8072           as well even if the bin is in the correct state already.
8073           change while to do so at least one iteration is done.
8074           For regular elements, we fall back to the previous behaviour for
8075           now since we first need a new plugins release.
8076         * testsuite/states/parent.c: (main):
8077           test for this case
8078           Fixes #123774
8079
8080 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8081
8082         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_finalize),
8083         (gst_queue_chain), (gst_queue_get), (gst_queue_handle_src_event),
8084         (gst_queue_release_locks), (gst_queue_change_state),
8085         (gst_queue_set_property):
8086           add proper lock debugging.  Change dispose to finalize, since
8087           we're freeing mutexes and other stuff which should happen only once.
8088
8089 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8090
8091         * docs/gst/tmpl/gstelement.sgml:
8092         * docs/gst/tmpl/gstplugin.sgml:
8093         * docs/gst/tmpl/gsttypes.sgml:
8094         * docs/pwg/building-state.xml:
8095         * gst/elements/gstfakesrc.c: (gst_fakesrc_change_state):
8096         * gst/gstelement.c: (gst_element_change_state):
8097         * gst/gstthread.c: (gst_thread_change_state):
8098           catch wrong state changes in element base class.
8099
8100 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8101
8102         * gst/gstinfo.h:
8103           clean up layout a little.
8104
8105 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8106
8107         * configure.ac:
8108         * testsuite/Makefile.am:
8109         * testsuite/states/Makefile.am:
8110         * testsuite/states/parent.c: (main):
8111           re-enable states testsuite dir.  Add test for state changes and
8112           parent behaviour
8113
8114 2004-07-09  Wim Taymans  <wim@fluendo.com>
8115
8116         * gst/schedulers/gstoptimalscheduler.c:
8117         (gst_opt_scheduler_pad_link), (group_elements_set_visited),
8118         (element_get_reachables_func), (element_get_reachables),
8119         (debug_element), (rechain_group), (group_migrate_connected),
8120         (gst_opt_scheduler_pad_unlink):
8121         Do not try to migrate decoupled elements to a new group since
8122         they are not added to groups.
8123
8124 2004-07-08  Benjamin Otte  <otte@gnome.org>
8125
8126         * gst/gstelement.c: (gst_element_error_func):
8127           make reentrant (= allow removing elements in error handler)
8128
8129 2004-07-08  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8130
8131         * gst/gstpad.c: (gst_pad_event_default_dispatch),
8132         (gst_pad_send_event), (gst_pad_call_chain_function):
8133           events sent to elements below PAUSED cannot be handled, so
8134           don't try to
8135
8136 2004-07-08  Wim Taymans  <wim@fluendo.com>
8137
8138         * gst/schedulers/gstoptimalscheduler.c:
8139         (chain_recursively_migrate_group), (create_group),
8140         (schedule_group), (gst_opt_scheduler_pad_link),
8141         (group_elements_set_visited), (element_get_reachables_func),
8142         (element_get_reachables), (group_can_reach_group), (debug_element),
8143         (rechain_group), (group_migrate_connected),
8144         (gst_opt_scheduler_pad_unlink):
8145         * testsuite/schedulers/Makefile.am:
8146         Implemented group splitting and rechaining.
8147         Fixes 143777 and 143777-2 in the testsuite.
8148
8149 2004-07-08  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8150
8151         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_chain):
8152           extra debugging
8153         * gst/gstevent.h:
8154         * gst/gstinfo.c: (gst_debug_log_default):
8155           print time nicely.  add thread pointer until someone figures out
8156           a completely portable way of getting at thread id's.
8157         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_try),
8158         (_invent_event), (gst_pad_pull), (gst_pad_event_default_dispatch),
8159         (gst_pad_call_chain_function):
8160           extra debugging
8161         * gst/schedulers/gstoptimalscheduler.c:
8162         (get_group_schedule_function), (loop_group_schedule_function),
8163         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
8164         (pad_clear_queued), (gst_opt_scheduler_iterate):
8165           rename BUFPEN and friends to DATAPEN since that's what they are.
8166
8167 2004-07-07  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8168
8169         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_chain):
8170         * gst/gstbuffer.h:
8171         * gst/gstpad.c:
8172           cleanups and debugging
8173
8174 2004-07-07  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8175
8176         * configure.ac:
8177         * gst/gstvalue.c: (gst_value_compare_enum),
8178         (gst_value_serialize_enum), (gst_value_deserialize_enum),
8179         (gst_value_can_compare), (gst_value_compare):
8180         * testsuite/Makefile.am:
8181         * testsuite/enumcaps/Makefile.am:
8182         * testsuite/enumcaps/enumcaps.c:
8183           Fix enum serialization, deserialization, comparison in caps, add
8184           a test to ensure that this continues working in the future.
8185
8186 2004-07-06  David Schleef  <ds@schleef.org>
8187
8188         * gst/gstcaps.c: (gst_caps_save_thyself), (gst_caps_load_thyself):
8189         Fix memleak.
8190
8191 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8192
8193         * gst/gstplugin.c: (gst_plugin_check_file), (gst_plugin_load_file):
8194         * gst/gstplugin.h:
8195         * gst/registries/gstxmlregistry.c:
8196         (plugin_times_older_than_recurse), (plugin_times_older_than),
8197         (gst_xml_registry_parse_padtemplate):
8198           only rebuild registry when actual plugins have a newer time than
8199           the registry.  Fixes #145520
8200
8201 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8202
8203         * docs/manual/manual.xml:
8204         * docs/manual/win32.xml:
8205           add chapter on win32 building.  fixes #142422
8206
8207 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8208
8209         patch by: Sebastien Cote <sc5 at hermes.usherb.ca>
8210
8211         * gst/autoplug/gstspider.c: (gst_spider_init),
8212         (gst_spider_dispose):
8213           fix spider memleaks.  fixes #137863
8214
8215 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8216
8217         patch by: Joe Marcus Clarke <marcus at freebsd dot org>
8218
8219         * gst/schedulers/gstoptimalscheduler.c:
8220         (gst_opt_scheduler_pad_unlink):
8221           fix SIGBUS error, fixes #145338
8222
8223 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8224
8225         * gst/gstobject.c: (gst_object_replace):
8226         * gst/gstscheduler.c: (gst_scheduler_get_clock):
8227         * gst/gstsystemclock.c: (gst_system_clock_obtain):
8228           clean up clock lifecycle.  Fixes #109831
8229
8230 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8231
8232         * po/LINGUAS:
8233         * po/cs.po:
8234           added Czech translation (Miloslav Trmac)
8235
8236 2004-07-04  David Schleef  <ds@schleef.org>
8237
8238         * tools/Makefile.am:
8239         * tools/gst-xmlinspect.1.in:  Add man page. (bug #140219)
8240
8241 2004-07-04  David Schleef  <ds@schleef.org>
8242
8243         * common/m4/gst-doc.m4: Check for docbook2html 0.6.10 (bug #139909)
8244
8245 2004-07-04  Thomas Vander Stichele  <thomas at apestaart dot org>
8246
8247         * gst/gstbin.c: (gst_bin_restore_thyself):
8248           chain to parent restore so the bins get restored correctly
8249           in the editor
8250
8251 2004-07-03  David Schleef  <ds@schleef.org>
8252
8253         * gst/gstcaps.c: (gst_caps_save_thyself), (gst_caps_load_thyself):
8254         Actually do something in these functions, like before the big
8255         caps change.  (bug #145137)
8256
8257 2004-07-03  Thomas Vander Stichele  <thomas at apestaart dot org>
8258
8259         * gst/gstelement.c: (gst_element_get_compatible_pad_template),
8260         (gst_element_get_compatible_pad_filtered):
8261         * gst/gstthread.c: (gst_thread_main_loop):
8262           more debugging
8263
8264 2004-07-02  David Schleef  <ds@schleef.org>
8265
8266         * gst/gstinfo.h: wrap #pragmas in #ifdefs for the correct compiler
8267         * gst/gstobject.h:
8268         * gst/gstparse.h:
8269         * gst/gsttrace.h:
8270         * gst/gstxml.h:
8271
8272 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
8273
8274         * gst/gstpad.c: (gst_pad_check_schedulers),
8275         (gst_pad_can_link_filtered), (gst_pad_link_filtered),
8276         (gst_pad_link_prepare):
8277           revert until testsuite is fixed
8278
8279 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
8280
8281         * testsuite/Makefile.am:
8282         * testsuite/caps/filtercaps.c: (main):
8283         * testsuite/clock/clock1.c: (main):
8284         * testsuite/dynparams/dparamstest.c: (gst_dptest_chain), (main):
8285           fix some more tests
8286
8287 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
8288
8289         * testsuite/cleanup/cleanup1.c: (create_pipeline):
8290         * testsuite/cleanup/cleanup2.c: (create_pipeline):
8291         * testsuite/cleanup/cleanup4.c: (main):
8292           fix testsuite
8293
8294 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
8295
8296         * libs/gst/control/control.c:
8297         * libs/gst/control/dparam.c:
8298         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_get_type):
8299         * libs/gst/control/dparammanager.c:
8300         * libs/gst/control/dparammanager.h:
8301         * testsuite/dynparams/Makefile.am:
8302         * testsuite/dynparams/dparamstest.c: (gst_dptest_base_init),
8303         (gst_dptest_change_state), (gst_dptest_chain), (main):
8304           fix testcase for dparams
8305           add debugging category
8306
8307 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
8308
8309         * testsuite/Rules:
8310           change path
8311
8312 2004-07-02  Benjamin Otte  <otte@gnome.org>
8313
8314         * tests/.cvsignore:
8315         * tests/Makefile.am:
8316         * tests/mass_elements.c: (gst_get_current_time), (main):
8317           add simple benchmark to test various speeds of fakesrc ! identity !
8318           identity ! ... ! fakesink.
8319           Usage: mass_elements [num_identities] [num_buffers]
8320           If not specified they default to 1000.
8321
8322 2004-07-02  Benjamin Otte  <otte@gnome.org>
8323
8324         * gst/gstpad.c: (gst_pad_check_schedulers),
8325         (gst_pad_can_link_filtered), (gst_pad_link_filtered),
8326         (gst_pad_link_prepare):
8327           check that pads that get linked belong to the same manager. The old
8328           code allowed linking elements before putting them into bins, so it
8329           worked to link them and then put them in different threads, which
8330           lead to weird behaviour.
8331           Since this effectively disallows linking elements before putting
8332           them in a bin, some applications might not work after this and error
8333           out. If these applications are too critical, we might need to revert
8334           that patch. Please test this before the next release...
8335
8336 2004-06-28  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8337
8338         * gst/gstpad.c: (gst_pad_get_caps):
8339           throw an error if the getcaps function does not return a subset of
8340           the template caps.
8341         * libs/gst/bytestream/filepad.c: (gst_file_pad_chain):
8342           make disconts without position info an error in debugging
8343         * tests/spidey_bench.c: (handoff), (main):
8344           don't count first try when averaging
8345
8346 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
8347
8348         * gst/gstplugin.c: (gst_plugin_load_file):
8349           figure out problem with dynamic test
8350
8351 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
8352
8353         * docs/gst/Makefile.am:
8354           fix docs build
8355
8356 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
8357
8358         * po/POTFILES.in:
8359         * po/af.po:
8360         * po/az.po:
8361         * po/en_GB.po:
8362         * po/fr.po:
8363         * po/nl.po:
8364         * po/sr.po:
8365         * po/sv.po:
8366         * po/tr.po:
8367         * po/uk.po:
8368         * tools/gst-register.c: (plugin_added_func), (main):
8369           i18n-ize -register, fix plural
8370
8371 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
8372
8373         * gst/elements/gstidentity.c: (gst_identity_class_init),
8374         (gst_identity_init), (gst_identity_chain),
8375         (gst_identity_set_property), (gst_identity_get_property):
8376         * gst/elements/gstidentity.h:
8377           check for perfect stream
8378
8379 2004-06-25  Thomas Vander Stichele  <thomas at apestaart dot org>
8380
8381         * gst/elements/gstidentity.c: (gst_identity_chain):
8382           print offset_end
8383
8384 2004-06-25  Thomas Vander Stichele  <thomas at apestaart dot org>
8385
8386         * docs/gst/Makefile.am:
8387         * docs/gst/gstreamer-docs.sgml:
8388           doc fixes
8389
8390 2004-06-24  David Schleef  <ds@schleef.org>
8391
8392         * autogen.sh:  Remove call to env, since the buildbot isn't
8393         broken anymore.
8394
8395 2004-06-24  Wim Taymans  <wim@fluendo.com>
8396
8397         * gst/elements/Makefile.am:
8398         * gst/elements/gstelements.c:
8399         * gst/elements/gstmultifdsink.c: (gst_multifdsink_base_init),
8400         (gst_multifdsink_class_init), (gst_multifdsink_init),
8401         (gst_multifdsink_add), (gst_multifdsink_remove),
8402         (gst_multifdsink_clear), (gst_multifdsink_chain),
8403         (gst_multifdsink_set_property), (gst_multifdsink_get_property):
8404         * gst/elements/gstmultifdsink.h:
8405         Added an element that writes to multiple filedescriptors at once.
8406
8407 2004-06-24  Benjamin Otte  <otte@gnome.org>
8408
8409         * gst/parse/grammar.y:
8410           don't try to link elements before they have been added to bins
8411
8412 2004-06-24  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8413
8414         * libs/gst/bytestream/filepad.c: (gst_file_pad_available),
8415         (gst_file_pad_get_length):
8416         * libs/gst/bytestream/filepad.h:
8417           add 2 new functions
8418
8419 2004-06-22  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
8420
8421         * docs/gst/gstreamer-sections.txt:
8422         remove from docs, the define that Benjamin removed from gstelement.h
8423
8424 2004-06-22  Benjamin Otte  <otte@gnome.org>
8425
8426         * gst/gstelement.h:
8427           remove define that referenced a nonexisting GstElement struct member
8428
8429 2004-06-20  Benjamin Otte  <otte@gnome.org>
8430
8431         * gst/gstdata.c: (gst_data_is_writable):
8432           whoops, return values were wrong, so writable data was marked as
8433           non-writable and vice versa. (fixes #143953, spotted by Francis
8434           Labonte)
8435           Shows how rarely we need to copy data ;)
8436
8437 2004-06-20  Benjamin Otte  <otte@gnome.org>
8438
8439         * testsuite/schedulers/.cvsignore:
8440         * testsuite/schedulers/Makefile.am:
8441         * testsuite/schedulers/143777-2.c: (main):
8442           add test for opt breakage in bug #143777
8443
8444 2004-06-20  Benjamin Otte  <otte@gnome.org>
8445
8446         * gst/gstpad.c: (gst_pad_call_chain_function):
8447           check for if we were unlinked while inside the chainfunction (fixes
8448           entrygthread having issues with #143777)
8449         * testsuite/schedulers/143777.c: (main):
8450         * testsuite/schedulers/Makefile.am:
8451           add a test for that fix
8452
8453 2004-06-20  Benjamin Otte  <otte@gnome.org>
8454
8455         * gst/gstvalue.c: (gst_value_set_int_range):
8456           test that start is smaller then end
8457         * libs/gst/bytestream/Makefile.am:
8458         * libs/gst/bytestream/filepad.c: 
8459         * libs/gst/bytestream/filepad.h:
8460           add GstFilePad - a pad that behaves like a FILE*
8461         * testsuite/bytestream/.cvsignore:
8462         * testsuite/bytestream/Makefile.am:
8463         * testsuite/bytestream/filepadsink.c: 
8464           test for the GstFilePad
8465
8466 2004-06-18  Thomas Vander Stichele  <thomas at apestaart dot org>
8467
8468         * gst/elements/gstidentity.c: (gst_identity_class_init),
8469         (gst_identity_init), (gst_identity_set_clock),
8470         (gst_identity_chain), (gst_identity_set_property),
8471         (gst_identity_get_property):
8472         * gst/elements/gstidentity.h:
8473         * gst/gstclock.c: (gst_clock_id_wait):
8474           add a "sync" property to sync to the clock
8475
8476 2004-06-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8477
8478         * gst/gstelementfactory.c: (gst_element_factory_create):
8479           make the freakin "elementfactory bla has no type" message more
8480           useful. So we actually can do something when someone shows up
8481           complaining about it.
8482
8483 2004-06-15  Johan Dahlin  <johan@gnome.org>
8484
8485         * tools/gst-inspect.c (main): Fallback to plugin if no element is
8486         found. This matches the old behavior better. Thanks to Thomas for
8487         pointing out.
8488
8489 2004-06-14  David Schleef  <ds@schleef.org>
8490
8491         * gst/gstcpu.c: (gst_cpuid_i386): Fix problem when using
8492         -fomit-frame-pointer.  Appears to generate correct code in
8493         other cases as well.
8494
8495 2004-06-14  Johan Dahlin  <johan@gnome.org>
8496
8497         * tools/gst-inspect.c (main): Add two new command line options: -a
8498         to print all elements and -n to print the name on each line. Also
8499         fix some error reporting.
8500         (main): Simplify, remove -n and always print names if -a is specified
8501
8502 2004-06-13  Steve Lhomme  <steve.lhomme@free.fr>
8503
8504         * win32/gstconfig.h:
8505         * win32/GSTreamer.vcproj:
8506         * win32/Makefile:
8507         * gst/gstconfig.h.in:
8508         * gst/gst.h:
8509         * gst/gstbin.h:
8510         * gst/gstelement.h:
8511         * gst/gstevent.h:
8512         * gst/gstobject.h:
8513         * gst/gstpad.h:
8514         * docs/gst/gstreamer-sections.txt:
8515         * docs/gst/tmpl/gstconfig.sgml:
8516           rename GSTREAMER_EXPORT(S) to GST_EXPORT(S)
8517
8518 2004-06-13  Jan Schmidt  <thaytan@mad.scientist.com>
8519         * docs/gst/gstreamer-sections.txt:
8520         * docs/gst/tmpl/gstconfig.sgml:
8521         Add the GSTREAMER_EXPORT macro to the docs
8522
8523 2004-06-13  Jan Schmidt  <thaytan@mad.scientist.com>
8524
8525         * tools/gst-compprep.c: (handle_xmlerror), (main):
8526         Add a check for the version that introduced SetStructuredError to fix
8527         the build on FC1
8528
8529 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8530
8531         * win32/msvc71.sln:
8532         * win32/testsuite/:
8533           prepare to compile the testsuite with MSVC
8534
8535 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8536
8537         * docs/manual/win32.xml:
8538           attempt to transform the Win32 README into an XML doc
8539
8540 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8541
8542         * gst/gst.c:
8543         * gst/gstbin.*:
8544         * gst/config.h.in:
8545         * gst/gstelement.*:
8546         * gst/gstevent.h:
8547         * gst/gstobject.*:
8548         * gst/gstpad.h:
8549         * tools/gst-register.c:
8550         * win32/gstreamer.def:
8551           extern symbols are now exported for the Windows DLL
8552
8553 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8554
8555         * gst/gstinfo.h:
8556           fix a problem to enable/disable DEBUG under MSVC
8557
8558 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8559
8560         * win32/:
8561           enable more debug code in DEBUG build
8562
8563 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8564
8565         * win32/config.h:
8566         * gst/gst-i18n-app.h:
8567           enable NLS under Windows
8568
8569 2004-06-12  Jan Schmidt  <thaytan@mad.scientist.com>
8570         * tools/gst-compprep.c: (handle_xmlerror), (main):
8571           Make an error that baffled me a bit clearer
8572
8573 2004-06-12  Thomas Vander Stichele  <thomas at apestaart dot org>
8574
8575         * gst/gstqueue.c:
8576           don't use g_queue_get_length () because it's 2.4, use ->length
8577
8578 2004-06-11  Steve Lhomme  <steve.lhomme@free.fr>
8579
8580         reviewed by Benjamin Otte  <in7y118@public.uni-hamburg.de>
8581
8582         * tools/gst-inspect.c: (print_signal_info):
8583           don't free random data twice. (fixes #144185)
8584
8585 2004-06-11  Thomas Vander Stichele  <thomas at apestaart dot org>
8586
8587         * gst/gstqueue.c:
8588         * gst/gstqueue.h:
8589           fix removing from the wrong queue on event timeout
8590           fix disposing of the event queue by casting correctly
8591           add mutexes for handling the event queue
8592           someone was sleeping when fixing queue last time around :)
8593
8594 2004-06-10  Johan Dahlin  <johan@gnome.org>
8595
8596         * gst/gst.c (gst_init_check_with_popt_table): Do not fail on
8597         errors, like gtk. It makes it more useful in bindings.  Fixes #141692.
8598
8599 2004-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
8600
8601         * docs/random/gdp:
8602         * libs/gst/dataprotocol/dataprotocol-test.c: (buffer_test):
8603         * libs/gst/dataprotocol/dataprotocol.c:
8604         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
8605         (gst_dp_buffer_from_header):
8606         * libs/gst/dataprotocol/dataprotocol.h:
8607         * libs/gst/dataprotocol/dp-private.h:
8608           rev version to 0.1, add buffer flags and copy them
8609
8610 2004-06-09  Johan Dahlin  <johan@gnome.org>
8611
8612         * gst/gstbuffer.c (gst_buffer_default_copy): Don't forget to merge
8613         the flags from the buffer we're copying.
8614
8615 2004-06-09  Wim Taymans  <wim@fluendo.com>
8616
8617         * gst/elements/gstfakesink.c: (gst_fakesink_chain):
8618         * gst/elements/gstidentity.c: (gst_identity_init),
8619         (gst_identity_chain):
8620         Print more buffer info in fakesink.
8621         Make identity output similar to fakesink.
8622
8623 2004-06-07  Daniel Gazard  <dany42@free.fr>
8624
8625         reviewed by Benjamin Otte  <otte@gnome.org>
8626
8627         * configure.ac:
8628           fix cross compiling not working. (fixes #143741)
8629
8630 2004-06-07  Benjamin Otte  <otte@gnome.org>
8631
8632         * gst/gstelement.c: (gst_element_set_time_delay):
8633           add failure check
8634         * gst/gstinfo.h:
8635           put brackets around macro arguments of GST_TIME_ARGS, add note to
8636           move it to correct header in 0.9
8637
8638 2004-06-07  Benjamin Otte  <otte@gnome.org>
8639
8640         * gst/indexers/gstfileindex.c: (gst_file_index_get_writer_id),
8641         (gst_file_index_load), (_file_index_id_save_entries),
8642         (gst_file_index_commit), (gst_file_index_add_association),
8643         (gst_file_index_add_entry), (gst_file_index_get_assoc_entry),
8644         (gst_file_index_plugin_init):
8645           make debugging use a default category
8646
8647 2004-06-06  David Moore  <dcm@acm.org>
8648
8649         reviewed by Benjamin Otte  <otte@gnome.org>
8650
8651         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init),
8652         (gst_fdsrc_change_state):
8653           reset offset counter when going READY => PAUSED. (fixes #142903)
8654
8655 2004-06-06  ed@catmur.co.uk
8656
8657         reviewed by Benjamin Otte  <otte@gnome.org>
8658
8659         * gst/registries/gstxmlregistry.c:
8660         (gst_xml_registry_rebuild_recurse):
8661           don't rely on g_dir_open to figure out if a file is a directory, use
8662           explicit G_TEST_IS_DIR. Reiserfs4 allows opening files as
8663           directories. (fixes #142850)
8664
8665 2004-06-06  Benjamin Otte  <otte@gnome.org>
8666
8667         * gst/gstqueue.c: (gst_queue_dispose), (gst_queue_change_state):
8668           fix memory leaks (fixes #142795). Initial patch by Sebastien Cote
8669         * libs/gst/bytestream/adapter.c:
8670         * libs/gst/bytestream/adapter.h:
8671           fix copyright in header and typo in debugging category name
8672
8673 2004-06-05  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8674
8675         * configure.ac:
8676           bump nano to cvs
8677
8678 === release 0.8.3 ===
8679
8680 2004-06-05  Thomas Vander Stichele  <thomas at apestaart dot org>
8681
8682         * configure.ac:
8683           update libtool versioning
8684           do a new release
8685         * docs/gst/tmpl/gstelement.sgml:
8686         * docs/gst/tmpl/gsttypes.sgml:
8687         * gst/gstinfo.c: (_gst_debug_init):
8688           put back GST_CAT_DATAFLOW to fix API breakage
8689
8690 2004-06-04  David Schleef  <ds@schleef.org>
8691
8692         * autogen.sh: Add a temporary 'env' to test buildbot problems.
8693
8694 2004-06-04  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8695
8696         * configure.ac:
8697           bump nano to cvs
8698
8699 === release 0.8.2 ===
8700
8701 2004-06-03  Thomas Vander Stichele  <thomas at apestaart dot org>
8702
8703         * gst/gst.c: (parse_debug_list), (gst_init_check_with_popt_table):
8704           check GST_DEBUG environment variable which is parsed the same way
8705           as --gst-debug=
8706
8707 2004-05-28  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8708
8709         * gst/elements    : gstaggregator.c gstfakesink.c gstfakesrc.c
8710                             gstmd5sink.c gstshaper.c gsttee.c
8711                             gsttypefindelement.c
8712         * gst/schedulers  : gstbasicscheduler.c gstoptimalscheduler.c
8713
8714           - removing trailing commas at end of enums
8715             it is correct C99 code but C90 compilers would complain
8716             (AIX, Forte, ...)
8717             ('should' fix #143290, at least partially)
8718
8719 2004-05-27  Wim Taymans  <wim@fluendo.com>
8720
8721         * gst/schedulers/gstoptimalscheduler.c: (remove_from_chain),
8722         (chain_group_set_enabled), (create_group), (add_to_group),
8723         (merge_groups), (setup_group_scheduler), (group_elements),
8724         (gst_opt_scheduler_iterate), (gst_opt_scheduler_show):
8725         Don't try to follow the pad connections with other groups
8726         when a loop based element is added to the scheduler because
8727         the bin will inform the scheduler about the pad links a little
8728         later.
8729
8730 2004-05-27  Wim Taymans  <wim@fluendo.com>
8731
8732         * gst/schedulers/gstoptimalscheduler.c: (add_to_chain),
8733         (remove_from_chain), (chain_group_set_enabled),
8734         (setup_group_scheduler), (group_element_set_enabled),
8735         (gst_opt_scheduler_state_transition), (gst_opt_scheduler_iterate),
8736         (gst_opt_scheduler_show):
8737         Elements without a group can do a state change as well, just wait
8738         with the setup of the scheduling function when it is added to a
8739         chain.
8740
8741 2004-05-27  Wim Taymans  <wim@fluendo.com>
8742
8743         * gst/schedulers/gstoptimalscheduler.c: (add_to_chain),
8744         (remove_from_chain), (chain_group_set_enabled), (add_to_group),
8745         (merge_groups), (setup_group_scheduler),
8746         (group_inc_links_for_element), (gst_opt_scheduler_iterate),
8747         (gst_opt_scheduler_show):
8748         Fixes to maintain internal consistency of the scheduler data
8749         structures. 
8750          - adding an enabled group to a chain should increment the
8751            number of enabled elements in that chain.
8752          - removing an enabled group from a chain could disable the
8753            chain.
8754          - removing a disabled group from a chain could enable the
8755            chain.
8756          - add g_assert when internal inconsistency is detected.
8757          - adding an element to a group could increase the number of
8758            links this group has with other groups.
8759          - merging two groups also merges the chains.
8760          - also show group links in the _show method.
8761            
8762
8763 2004-05-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8764
8765         * gst/gstcaps.c: (gst_caps_structure_simplify):
8766           don't print error messages when there is no error
8767         * gst/gstvalue.c: (gst_value_compare_int_range):
8768           compare the second value, too
8769         * testsuite/caps/Makefile.am:
8770         * testsuite/caps/random.c: (assert_on_error), (main):
8771           add tests to make sure the two things above are checked for
8772
8773 2004-05-24  Thomas Vander Stichele  <thomas at apestaart dot org>
8774
8775         * configure.ac:
8776         * libs/gst/dataprotocol/Makefile.am:
8777         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_caps):
8778         * libs/gst/dataprotocol/dataprotocol.h:
8779           wrap header in GST_ENABLE_NEW.  make code use it
8780
8781 2004-05-23  Johan Dahlin  <johan@gnome.org>
8782
8783         * tools/gst-inspect.c (main): Cleanup most parts of it, don't be
8784         so verbose and print GstElement signal names all the time.
8785
8786 2004-05-22  David Schleef  <ds@schleef.org>
8787
8788         * gst/registries/gstxmlregistry.c:
8789         (gst_xml_registry_parse_padtemplate): Fix warning on OS X.
8790         (bug #142957)
8791
8792 2004-05-22  Thomas Vander Stichele  <thomas at apestaart dot org>
8793
8794         * configure.ac:
8795           scrub cflags for glib2 so gcc doesn't complain when glib is in
8796           /usr/local
8797
8798 2004-05-21  Johan Dahlin  <johan@gnome.org>
8799
8800         * gst/gstcpu.c (gst_cpuid_i386): Protect some gcc asm stuff with
8801         __GNUC__, patch from Brian Cameron, fixes bug #142804
8802
8803 2004-05-20  David Schleef  <ds@schleef.org>
8804
8805         * gst/gstindex.c: (gst_index_compare_func): Fix overflows in
8806         comparison code.  (bug #142819)
8807
8808 2004-05-20  Wim Taymans  <wim@fluendo.com>
8809
8810         * gst/gstbuffer.c: (gst_buffer_default_copy):
8811         * gst/gstbuffer.h:
8812         Added Comment to a flag.
8813         copy relevant flags in _buffer_copy.
8814
8815 2004-05-20  Thomas Vander Stichele  <thomas at apestaart dot org>
8816
8817         reviewed by: Wim Taymans <wim at fluendo dot com>
8818
8819         * gst/gstbuffer.h:
8820           add GST_BUFFER_IN_CAPS buffer flag
8821         * gst/gststructure.c: (gst_structure_value_get_generic_type),
8822         (gst_structure_parse_any_list), (gst_structure_parse_list),
8823         (gst_structure_parse_fixed_list), (gst_structure_parse_value):
8824         * gst/gstvalue.c: (gst_value_serialize_any_list),
8825         (gst_value_transform_any_list_string),
8826         (gst_value_list_prepend_value), (gst_value_list_append_value),
8827         (gst_value_list_get_size), (gst_value_list_get_value),
8828         (gst_value_transform_list_string),
8829         (gst_value_transform_fixed_list_string),
8830         (gst_value_serialize_list), (gst_value_serialize_fixed_list),
8831         (gst_value_deserialize_fixed_list), (gst_type_is_fixed),
8832         (_gst_value_initialize):
8833         * gst/gstvalue.h:
8834           add a GST_TYPE_FIXED_LIST which is fixed by definition and uses
8835           < , > as a format.
8836         * testsuite/caps/string-conversions.c: (main):
8837           add regression tests for < >
8838
8839 2004-05-20  Johan Dahlin  <johan@gnome.org>
8840
8841         * docs/gst/Makefile.am (all-local): Re-add
8842
8843 2004-05-20  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8844
8845         * docs/gst/Makefile.am:
8846         * docs/gst/gstreamer-docs.sgml:
8847         * docs/libs/Makefile.am:
8848         * docs/libs/gstreamer-libs-docs.sgml:
8849           fix distcheck issues
8850
8851 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
8852
8853         * libs/gst/dataprotocol/Makefile.am:
8854           add to autotest
8855
8856 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
8857
8858         * libs/gst/dataprotocol/Makefile.am:
8859         * libs/gst/dataprotocol/dataprotocol.c:
8860         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
8861         (gst_dp_packet_from_event), (gst_dp_event_from_packet):
8862         * libs/gst/dataprotocol/dp-private.h:
8863           use GST macros to read/write fixed length ints
8864           add some more asserts
8865
8866 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
8867
8868         * docs/libs/gstreamer-libs-docs.sgml:
8869         * docs/libs/gstreamer-libs-sections.txt:
8870           remove idct and putbits
8871         * configure.ac:
8872         * docs/libs/tmpl/gstdataprotocol.sgml:
8873         * libs/gst/Makefile.am:
8874         * libs/gst/dataprotocol/Makefile.am:
8875         * libs/gst/dataprotocol/dataprotocol-test.c: (conversion_test),
8876         (buffer_test), (caps_test), (event_test), (main):
8877         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_crc),
8878         (gst_dp_dump_byte_array), (gst_dp_init),
8879         (gst_dp_header_payload_length), (gst_dp_header_payload_type),
8880         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
8881         (gst_dp_packet_from_event), (gst_dp_buffer_from_header),
8882         (gst_dp_caps_from_packet), (gst_dp_event_from_packet),
8883         (gst_dp_validate_header), (gst_dp_validate_payload),
8884         (gst_dp_validate_packet), (plugin_init):
8885         * libs/gst/dataprotocol/dataprotocol.h:
8886         * libs/gst/dataprotocol/dp-private.h:
8887           add dataprotocol
8888
8889 2004-05-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8890
8891         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
8892           fix int variable deserialization and add a helper so we can actually
8893           debug this.
8894
8895 2004-05-18  David Schleef  <ds@schleef.org>
8896
8897         * testsuite/debug/commandline.c: (main): Call ./commandline, not
8898           argv[0].  Calling yourself is probably not the best way to
8899           construct a test like this, btw.
8900
8901 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8902
8903         * gst/gstbin.c: (gst_bin_iterate_func), (gst_bin_iterate):
8904           don't claim to be more intelligent than a scheduler when the
8905           scheduler claims the pipeline is stopped
8906         * gst/schedulers/entryscheduler.c: (safe_cothread_switch),
8907         (safe_cothread_destroy),
8908         (gst_entry_scheduler_remove_all_cothreads),
8909         (gst_entry_scheduler_reset), (_remove_cothread),
8910         (gst_entry_scheduler_state_transition):
8911           hold off cothread destruction if we're not in main cothread
8912         * configure.ac:
8913         * testsuite/Makefile.am:
8914           add new test dir
8915         * testsuite/schedulers/.cvsignore:
8916         * testsuite/schedulers/Makefile.am:
8917           add tests
8918         * testsuite/schedulers/relink.c: (cb_handoff), (main):
8919           check relinking and adding/removing elements from a running pipeline
8920         * testsuite/schedulers/unlink.c: (cb_handoff), (main):
8921           check unlinking in a running pipeline
8922         * testsuite/schedulers/unref.c: (cb_handoff), (main):
8923           check unreffing a running pipeline
8924         * testsuite/schedulers/useless_iteration.c: (main):
8925           check iterating a pipeline that contains running threads works
8926
8927 2004-05-18  David Schleef  <ds@schleef.org>
8928
8929         * docs/gst/Makefile.am: Add all-local target for when HAVE_GTK_DOC
8930           is false.
8931
8932 2004-05-18  Wim Taymans  <wim@fluendo.com>
8933
8934         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
8935         (setup_group_scheduler), (gst_opt_scheduler_pad_link):
8936         Fixed an error introduced with patch for 1.63. When setting
8937         a get based element as the entry point in a group, make sure
8938         to mark the group as GET based.
8939
8940 2004-05-18  Wim Taymans  <wim@fluendo.com>
8941
8942         * gst/schedulers/gstoptimalscheduler.c: (create_group),
8943         (setup_group_scheduler), (loop_group_schedule_function),
8944         (gst_opt_scheduler_pad_link):
8945         Added some more debug info and fixed a bug where the group
8946         type was set to LOOP but it was in fact unknown.
8947
8948 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8949
8950         * gst/schedulers/entryscheduler.c: (gst_entry_scheduler_reset):
8951           make resetting scheduler work twice in a row
8952
8953 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8954
8955         * gst/gstvalue.c: (gst_strtoll), (CREATE_SERIALIZATION),
8956         (CREATE_USERIALIZATION), (_gst_value_initialize),
8957         (gst_value_compare_float), (gst_value_serialize_float),
8958         (gst_value_deserialize_float), (gst_value_compare_enum),
8959         (gst_value_serialize_enum), (gst_value_deserialize_enum):
8960           add serialization and comparison functions for long, int64, enum and
8961           float values
8962         * gst/gstvalue.c: (gst_value_serialize), (gst_value_deserialize):
8963           use best serialization function in type hierarchy instead of only a
8964           matching one. This is required for enums to work.
8965         * gst/parse/grammar.y:
8966           use gst_caps_deserialize
8967         * testsuite/parse/Makefile.am:
8968           parse1 now works
8969         * testsuite/parse/parse1.c: (main):
8970           remove aggregator check, aggregator is broken, this test works now
8971           but fails because of bug #138012
8972         * testsuite/parse/parse2.c: (main):
8973           s/xvideosink/xvimagesink - this test looks a lot like we should
8974           disable it
8975
8976 2004-05-13  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8977
8978         * gst/gstelement.c: (gst_element_class_init):
8979           whoops, store the signal id correctly
8980         * gst/schedulers/gstbasicscheduler.c:
8981         (gst_basic_scheduler_chain_wrapper):
8982           detect infinfinfinfinfinf^Cinite loops in chain wrapper when the
8983           chain function isn't linked
8984
8985 2004-05-13  Jan Schmidt  <thaytan@mad.scientist.com>
8986         * configure.ac:
8987         Add $GST_PKG_CFLAGS back into GST_INT_CFLAGS so I have large file
8988         support until we decide where the flags should be used
8989         * gst/elements/gstfilesrc.c: (gst_filesrc_srcpad_query):
8990         Use GST_FORMAT_BYTES when GST_FORMAT_DEFAULT is passed
8991         * gst/gstpad.c: (gst_pad_link_call_link_functions):
8992         Output refused caps in the debug info
8993
8994 2004-05-13  Thomas Vander Stichele  <thomas at apestaart dot org>
8995
8996         * gst/elements/gstidentity.c: (gst_identity_chain):
8997           add duration debug
8998         * gst/gstinfo.c: (gst_debug_log_default):
8999           add timestamp
9000
9001 2004-05-13  Benjamin Otte  <otte@gnome.org>
9002
9003         * gst/gstpipeline.c: (gst_pipeline_dispose),
9004         (gst_pipeline_change_state):
9005           call gst_scheduler_reset on dispose (fixes #141416)
9006
9007 2004-05-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9008
9009         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
9010           compute mapsize correctly
9011         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
9012           use correct datatypes when calling a varargs function
9013         * gst/elements/gsttypefindelement.c: (stop_typefinding):
9014           push a DISCONT event as first thing
9015         * gst/gst_private.h:
9016         * gst/gstinfo.c: (_gst_debug_init):
9017           remove GST_DATAFLOW debugging category
9018         * gst/gstbin.c: (gst_bin_iterate):
9019           use GST_SCHEDULING category
9020         * gst/gstpad.c: (gst_pad_get_type), (_invent_event),
9021         (gst_pad_push), (gst_pad_pull), (gst_pad_call_chain_function),
9022         (gst_pad_call_get_function):
9023           add GST_DATAFLOW to easily track flow of buffers or events.
9024         * gst/gstqueue.c: (gst_queue_get_type),
9025         (gst_queue_handle_pending_events), (gst_queue_chain),
9026         (gst_queue_get), (gst_queue_handle_src_event):
9027           use own static debugging category GST_DATAFLOW for dataflow,
9028           use DEBUG category for showing which path events go, use LOG
9029           category for buffers.
9030
9031 2004-05-10  David Schleef  <ds@schleef.org>
9032
9033         * docs/gst/gstreamer-sections.txt: Add gst_element_no_more_pads.
9034
9035 2004-05-10  David Schleef  <ds@schleef.org>
9036
9037         * docs/gst/Makefile.am: Dear gtk-doc, please print out the unused
9038         symbols, because otherwise we don't know what they are.  Thanks,
9039         the GStreamer team.
9040         * gst/registries/gstxmlregistry.c: (make_dir): Remove a spurious ;
9041
9042 2004-05-10  David Schleef  <ds@schleef.org>
9043
9044         (from Steve Lhomme)
9045         * win32/Makefile: When using make clean the MS Visual Studio makefiles
9046         are deleted.  Fix.
9047         * win32/Makefile.inspect:
9048         * win32/Makefile.launch:
9049         * win32/Makefile.register:
9050
9051 2004-05-10  David Schleef  <ds@schleef.org>
9052
9053         * gst/gstinfo.h: Add missing inline function.
9054         * gst/gsttrace.c: add include
9055         * gst/parse/grammar.y: remove unused code
9056         * gst/registries/gstxmlregistry.c: (make_dir): make mkdir call
9057         more portable.
9058         * tools/gst-register.c: wrap unistd.h
9059         
9060         More additions/fixes from Steve for the MSVC build.
9061         * win32/GStreamer.vcproj:
9062         * win32/Makefile:
9063         * win32/Makefile.inspect:
9064         * win32/Makefile.launch:
9065         * win32/Makefile.register:
9066         * win32/README.txt:
9067         * win32/gst-inspect.vcproj:
9068         * win32/gst-launch.vcproj:
9069         * win32/gst-register.vcproj:
9070         * win32/gstbytestream.def:
9071         * win32/gstbytestream.vcproj:
9072         * win32/gstconfig.h:
9073         * win32/gstelements.def:
9074         * win32/gstelements.vcproj:
9075         * win32/gstenumtypes.c:
9076         * win32/gstenumtypes.h:
9077         * win32/gstoptimalscheduler.def:
9078         * win32/gstoptimalscheduler.vcproj:
9079         * win32/gstreamer.def:
9080         * win32/gstspider.def:
9081         * win32/gstspider.vcproj:
9082         * win32/gstversion.h:
9083         * win32/msvc71.sln:
9084
9085 2004-05-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9086
9087         * gst/gstelement.c: (gst_element_class_init),
9088         (gst_element_no_more_pads):
9089         * gst/gstelement.h:
9090           add gst_element_no_more_pads and the "no-more-pads" signal
9091
9092 2004-05-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9093
9094         * gst/gstregistry.c: (gst_registry_add_plugin):
9095           refuse to add plugins when a plugin with same name is already
9096           registered. Fixes a bunch of "How to remove plugins?" issues.
9097           May lead to other problems though, let's test
9098
9099 2004-05-10  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9100
9101         * testsuite/caps/caps_strings : audio/ac3 => audio/x-ac3
9102         * docs/manual/pads-api.xml : audio/wav => audio/x-wav
9103         * docs/random/uraeus/gstreamer_and_midi.txt : audio/wav => audio/x-wav
9104
9105 2004-05-09  Thomas Vander Stichele  <thomas at apestaart dot org>
9106
9107         * tests/Makefile.am: fix am16 issue
9108
9109 2004-05-09  Benjamin Otte  <otte@gnome.org>
9110
9111         * libs/gst/bytestream/Makefile.am:
9112           we should indeed add .c files to makefiles or they won't be built
9113           (d'oh)
9114
9115 2004-05-08  Benjamin Otte  <otte@gnome.org>
9116
9117         * gst/gstpad.c: (gst_pad_proxy_fixate):
9118           really reduce the set of caps
9119
9120 2004-05-08  Benjamin Otte  <otte@gnome.org>
9121
9122         * tests/Makefile.am:
9123         * tests/spidey_bench.c: (handoff), (main):
9124           add benchmark to test how long spider needs to create a pipeline
9125
9126 2004-05-08  Benjamin Otte  <otte@gnome.org>
9127
9128         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_unnegotiate):
9129           mark links as unengaged when unnegotiating instead of deactivating.
9130           This way pads aren't marked as unengaged when going PLAYING=>PAUSED
9131
9132 2004-05-08  Benjamin Otte  <otte@gnome.org>
9133
9134         * docs/manual/helloworld.xml:
9135           s/audiosink/osssink (patch by Patrick Guimond)
9136
9137 2004-05-07  David Schleef  <ds@schleef.org>
9138
9139         * configure.ac: Make sure GST_INT_CFLAGS is not clobbered,
9140         since it contains important stuff.
9141
9142 2004-05-07  David Schleef  <ds@schleef.org>
9143
9144         * testsuite/caps/caps.c: (test3), (main): A check for appending
9145         ANY caps.
9146
9147 2004-05-07  David Schleef  <ds@schleef.org>
9148
9149         * common/m4/as-compiler-flag.m4: Properly quote arguments,
9150         which may contain commas.  Fixes detection of -Wa,-mregnames
9151
9152 2004-05-06  David Schleef  <ds@schleef.org>
9153
9154         Changes to handle compilers that don't have variadic macro
9155         support.  In particular, glib headers define some inlines
9156         that need G_LOG_DOMAIN defined.  Additional fixes for MSVC
9157         builds.
9158         * gst/Makefile.am:
9159         * gst/cothreads.c:
9160         * gst/elements/gstfdsink.c:
9161         * gst/elements/gstfdsrc.c:
9162         * gst/elements/gstfilesink.c:
9163         * gst/elements/gstfilesrc.c:
9164         * gst/gst_private.h:
9165         * gst/gstatomic.c:
9166         * gst/gstcaps.c: (gst_caps_append):
9167         * gst/gstcpu.c: (gst_cpuid_i386):
9168         * gst/gstelement.c:
9169         * gst/gsterror.c:
9170         * gst/gstfilter.c:
9171         * gst/gstinfo.h:
9172         * gst/gstprobe.c:
9173         * gst/gstquery.c:
9174         * gst/gstregistry.c:
9175         * gst/gststructure.c:
9176         * gst/gsttaginterface.c:
9177         * gst/gsttrace.c: (gst_trace_new):
9178         * gst/gsttrashstack.c:
9179         * gst/gsturi.c:
9180         * gst/gstvalue.c:
9181         * gst/parse/grammar.y:
9182         * gst/parse/parse.l:
9183         * tools/gst-inspect.c: (main):
9184         * tools/gst-launch.c: (main):
9185         * tools/gst-xmlinspect.c: (PUT_STRING):
9186
9187 2004-05-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9188
9189         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
9190         (gst_filesrc_change_state), (gst_filesrc_srcpad_event):
9191         * gst/elements/gstfilesrc.h:
9192           send NEW_MEDIA events correctly
9193         * gst/elements/gsttypefindelement.c: (start_typefinding),
9194         (gst_type_find_element_handle_event):
9195           restart typefinding when we get a NEW_MEDIA event
9196         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_change_state),
9197         (gst_bin_dispose):
9198           don't die when someone removes elements in callbacks
9199         * gst/gstelement.c: (gst_element_change_state):
9200           improve debugging
9201         * gst/gstpad.c: (gst_pad_pull), (gst_pad_call_chain_function):
9202           we need a NEW_MEDIA event to engage a link
9203         * gst/gsttrace.c: (gst_trace_new), (gst_alloc_trace_set_flags_all):
9204           don't g_print debugging stuff
9205         * testsuite/caps/simplify.c: (check_caps):
9206
9207 2004-05-04  Benjamin Otte  <otte@gnome.org>
9208
9209         * gst/parse/grammar.y:
9210           use GST_ERROR instead of g_warning, and always throw a GST_ERROR 
9211
9212 2004-05-04  Benjamin Otte  <otte@gnome.org>
9213
9214         * testsuite/caps/renegotiate.c: (main):
9215           improve output in error case
9216
9217 2004-05-04  Benjamin Otte  <otte@gnome.org>
9218
9219         * gst/parse/grammar.y:
9220           fix assert to not trigger when there's no error argument
9221         * gst/parse/parse.l:
9222           fix definition of caps to allow more than two structures
9223         * testsuite/caps/Makefile.am:
9224         * testsuite/caps/renegotiate.c: (main):
9225           it's sinesrc and works in that case
9226
9227 2004-05-04  Wim Taymans  <wim@fluendo.com>
9228
9229         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
9230         (group_dec_link), (gst_opt_scheduler_pad_unlink):
9231         when removing an element from a group, we always need to
9232         decrement the link count that this group had with other 
9233         groups through the element.
9234         added an extra assert to catch inconsistencies when decrementing
9235         the link count.
9236
9237 2004-05-04  Thomas Vander Stichele  <thomas at apestaart dot org>
9238
9239         * configure.ac:
9240         * docs/gst/Makefile.am:
9241         * docs/gst/gstreamer-sections.txt:
9242         * docs/gst/tmpl/gstcompat.sgml:
9243         * examples/appreader/Makefile.am:
9244         * examples/cutter/Makefile.am:
9245         * examples/events/Makefile.am:
9246         * examples/helloworld/Makefile.am:
9247         * examples/helloworld2/Makefile.am:
9248         * examples/launch/Makefile.am:
9249         * examples/manual/Makefile.am:
9250         * examples/mixer/Makefile.am:
9251         * examples/pingpong/Makefile.am:
9252         * examples/plugins/Makefile.am:
9253         * examples/queue/Makefile.am:
9254         * examples/queue2/Makefile.am:
9255         * examples/queue3/Makefile.am:
9256         * examples/queue4/Makefile.am:
9257         * examples/retag/Makefile.am:
9258         * examples/thread/Makefile.am:
9259         * examples/typefind/Makefile.am:
9260         * examples/xml/Makefile.am:
9261         * gst/Makefile.am:
9262         * gst/autoplug/Makefile.am:
9263         * gst/elements/Makefile.am:
9264         * gst/gstcompat.h:
9265         * gst/indexers/Makefile.am:
9266         * gst/parse/Makefile.am:
9267         * gst/registries/Makefile.am:
9268         * gst/schedulers/Makefile.am:
9269         * libs/gst/bytestream/Makefile.am:
9270         * libs/gst/control/Makefile.am:
9271         * libs/gst/getbits/Makefile.am:
9272         * po/af.po:
9273         * po/az.po:
9274         * po/en_GB.po:
9275         * po/fr.po:
9276         * po/nl.po:
9277         * po/sr.po:
9278         * po/sv.po:
9279         * po/tr.po:
9280         * po/uk.po:
9281         * tests/Makefile.am:
9282         * tests/bufspeed/Makefile.am:
9283         * tests/instantiate/Makefile.am:
9284         * tests/memchunk/Makefile.am:
9285         * tests/muxing/Makefile.am:
9286         * tests/negotiation/Makefile.am:
9287         * tests/probes/Makefile.am:
9288         * tests/sched/Makefile.am:
9289         * tests/seeking/Makefile.am:
9290         * tests/threadstate/Makefile.am:
9291         * testsuite/caps/Makefile.am:
9292         * testsuite/cleanup/Makefile.am:
9293         * testsuite/dlopen/Makefile.am:
9294         * testsuite/dynparams/Makefile.am:
9295         * testsuite/plugin/Makefile.am:
9296         * testsuite/states/Makefile.am:
9297         * tools/Makefile.am:
9298           reorganize compile/link flags to be consistent
9299           put gst_info in gstcompat.h and actually use GST_DISABLE_DEPRECATED
9300
9301 2004-05-04  David Schleef  <ds@schleef.org>
9302
9303         The "once more, with feeling" check-in.
9304         * testsuite/caps/Makefile.am: dist caps_strings
9305         * testsuite/caps/renegotiate.c: (main): This test triggers a
9306           segfault in the core.  Marking as failing.
9307
9308 2004-05-03  David Schleef  <ds@schleef.org>
9309
9310         * testsuite/caps/deserialize.c: (main): Fix problems noticed
9311           by the build bots.
9312         * testsuite/caps/renegotiate.c: (main): Same.
9313
9314 2004-05-03  David Schleef  <ds@schleef.org>
9315
9316         * testsuite/caps/renegotiate.c: (my_fixate), (main): Another test.
9317
9318 2004-05-03  David Schleef  <ds@schleef.org>
9319
9320         * testsuite/caps/deserialize.c: (main): Use the srcdir environment
9321           variable to find our source file.
9322
9323 2004-05-03  David Schleef  <ds@schleef.org>
9324
9325         * configure.ac:  Link plugins with libgstreamer and dependent
9326           libraries
9327         * testsuite/caps/Makefile.am:
9328         * testsuite/caps/caps_strings:
9329         * testsuite/caps/deserialize.c: (main): Add a little test to slog
9330           through a file of caps strings and test each one
9331
9332 2004-05-04  Benjamin Otte  <otte@gnome.org>
9333
9334         * libs/gst/bytestream/Makefile.am:
9335         * libs/gst/bytestream/adapter.c: 
9336         * libs/gst/bytestream/adapter.h:
9337           add GstAdapter, similar to bytestream, but doesn't require ugly event
9338           handling or uglier loopbased elements
9339
9340 2004-05-03  David Schleef  <ds@schleef.org>
9341
9342         * testsuite/caps/Makefile.am: Fix spelling of Ηρατοσθενες
9343         * testsuite/caps/erathostenes.c:
9344         * testsuite/caps/eratosthenes.c: (eratosthenes), (main):
9345
9346 2004-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
9347
9348         * docs/pwg/pwg.xml:
9349           remove hardcoded stylesheet path (duh)
9350         * docs/random/release:
9351         * docs/gst/gstreamer-sections.txt:
9352         * gst/Makefile.am:
9353         * gst/gst.h:
9354         * gst/gst_private.h:
9355         * gst/gstcaps.c:
9356         * gst/gstevent.c:
9357         * gst/gstformat.c:
9358         * gst/gstinfo.c:
9359         * gst/gstinfo.h:
9360         * gst/gstinterface.c:
9361         * gst/gstmemchunk.c:
9362         * gst/gstprobe.c:
9363         * gst/gstquery.c:
9364         * gst/gstregistry.c:
9365         * gst/gstregistrypool.c:
9366         * gst/gststructure.c:
9367         * gst/gsttaginterface.c:
9368         * gst/gstthread.c:
9369         * gst/gsttrace.c:
9370         * gst/gsttypefind.c: (gst_type_find_factory_get_type):
9371         * gst/gsturi.c:
9372         * gst/gstvalue.c:
9373           deprecate gst_info; remove gstlog.h
9374    
9375
9376 2004-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
9377
9378         * Makefile.am:
9379         * po/en_GB.po:
9380         * po/sv.po:
9381         * po/uk.po:
9382           updated translations
9383
9384 2004-05-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9385
9386         * gst/gstbin.c: (gst_bin_dispose):
9387           better debugging
9388
9389 2004-05-03  Johan Dahlin  <johan@gnome.org>
9390
9391         * gst/schedulers/gstoptimalscheduler.c
9392         (gst_opt_scheduler_pad_unlink): Check if element is non-NULL and
9393         really is a GstElement. Avoids critical when running gst-launch -v
9394         and a oggdemux/decoding pipeline.
9395
9396 2004-05-02  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9397
9398         * docs/gst/tmpl/gstpipeline.sgml :
9399         * docs/manual/elements-api.xml :
9400                 doc fix by Patrick Guimond (Protector) from devel ML
9401                 reviewed by ronald
9402
9403 2004-05-02  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9404
9405         * docs/gst/Makefile.am :
9406         * docs/libs/Makefile.am :
9407                 apply a patch from Arwed v. Merkatz so that gtk-doc
9408                 generated docs install (same for .devhelp file)
9409                 (fixes part 1 of #138836)
9410
9411 2004-04-30  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9412
9413         * docs/faq/dependencies.xml: typo
9414         * docs/faq/getting.xml :
9415             - fix download URL for new gstreamer site
9416             - hide sf.net download page as latest version aren't there
9417             - fix apt URLs
9418             - fill "get via CVS" paragraph (link to dev page on the site)
9419         * docs/faq/general.xml:
9420             hide status tables as they no more exists
9421             change case on plugins license file to reflect reality
9422         * docs/faq/troubleshooting.xml:
9423             remove the wiki question/answer as there is no more wiki
9424
9425 2004-04-30  Thomas Vander Stichele  <thomas at apestaart dot org>
9426
9427         * gst/gsterror.h:
9428           include the headers needed for declarations used in this header
9429
9430 2004-04-30  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9431
9432         * docs/random/uraeus/gstreamer_and_midi.txt :
9433           add .kar (midi + karaoke/lyrics 'track') doc to midi doc.
9434           (fixes #132288)
9435
9436 2004-04-30  Sebastien Cote  <sc5@hermes.usherb.ca>
9437
9438         reviewed by Benjamin Otte  <otte@gnome.org>
9439
9440         * gst/schedulers/gthread-cothreads.h:
9441           free allocated data for main cothread, too when destroying context
9442           (fixes #141417)
9443
9444 2004-04-29  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9445
9446         * docs/manual/goals.xml : remove duplicated paragraph at end 
9447         of doc page (fixes #141448)
9448
9449 2004-04-29  David Schleef  <ds@schleef.org>
9450
9451         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
9452         Patch from Sebastien Cote to fix leakage of events. (bug #141414)
9453
9454 2004-04-29  Thomas Vander Stichele  <thomas at apestaart dot org>
9455
9456         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
9457           fix property
9458         * gst/gstcaps.c:
9459           fix doc string
9460         * po/POTFILES.in:
9461           rename typefind source file
9462
9463 2004-04-28  David Schleef  <ds@schleef.org>
9464
9465         Several new files from Steve Lhomme's MSVC patch (bug #141317):
9466         * win32/GStreamer.vcproj:
9467         * win32/Makefile:
9468         * win32/config.h:
9469         * win32/dirent.c: (_topendir), (_treaddir), (_tclosedir),
9470         (_trewinddir), (_ttelldir), (_tseekdir):
9471         * win32/dirent.h:
9472         * win32/gst-inspect.vcproj:
9473         * win32/gst-launch.vcproj:
9474         * win32/gst-register.vcproj:
9475         * win32/gstbytestream.vcproj:
9476         * win32/gstelements.vcproj:
9477         * win32/gstoptimalscheduler.vcproj:
9478         * win32/gstspider.vcproj:
9479         * win32/gtchar.h:
9480         * win32/mman.c: (mmap), (mprotect), (msync), (munmap):
9481         * win32/mman.h:
9482         * win32/mman.inl:
9483         * win32/msvc71.sln:
9484
9485 2004-04-29  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9486
9487         * gst/gst.c: (init_post):
9488         * gst/gstinfo.c:
9489           remove useless _gst_progname stuff
9490         * tools/gst-inspect.c: (print_field), (print_caps):
9491           improve caps output
9492
9493 2004-04-28  David Schleef  <ds@schleef.org>
9494
9495         Disable parsing of a lot of files that aren't part of the
9496         exported API.  Move corresponding template files to old/,
9497         waiting for removal when they don't contain anything
9498         interesting.
9499         * docs/gst/Makefile.am:
9500         * docs/gst/gstreamer-sections.txt:
9501         * docs/gst/tmpl/cothreads.sgml:
9502         * docs/gst/tmpl/cothreads_compat.sgml:
9503         * docs/gst/tmpl/gettext.sgml:
9504         * docs/gst/tmpl/gobject2gtk.sgml:
9505         * docs/gst/tmpl/grammar.tab.sgml:
9506         * docs/gst/tmpl/gst-i18n-app.sgml:
9507         * docs/gst/tmpl/gst-i18n-lib.sgml:
9508         * docs/gst/tmpl/gst_private.sgml:
9509         * docs/gst/tmpl/gstaggregator.sgml:
9510         * docs/gst/tmpl/gstarch.sgml:
9511         * docs/gst/tmpl/gstatomic_impl.sgml:
9512         * docs/gst/tmpl/gstbufferstore.sgml:
9513         * docs/gst/tmpl/gstdata_private.sgml:
9514         * docs/gst/tmpl/gstdisksink.sgml:
9515         * docs/gst/tmpl/gstdisksrc.sgml:
9516         * docs/gst/tmpl/gstelementfactory.sgml:
9517         * docs/gst/tmpl/gstextratypes.sgml:
9518         * docs/gst/tmpl/gstfakesink.sgml:
9519         * docs/gst/tmpl/gstfakesrc.sgml:
9520         * docs/gst/tmpl/gstfdsink.sgml:
9521         * docs/gst/tmpl/gstfdsrc.sgml:
9522         * docs/gst/tmpl/gstfilesink.sgml:
9523         * docs/gst/tmpl/gstfilesrc.sgml:
9524         * docs/gst/tmpl/gsthttpsrc.sgml:
9525         * docs/gst/tmpl/gstidentity.sgml:
9526         * docs/gst/tmpl/gstindexfactory.sgml:
9527         * docs/gst/tmpl/gstmarshal.sgml:
9528         * docs/gst/tmpl/gstmd5sink.sgml:
9529         * docs/gst/tmpl/gstmultidisksrc.sgml:
9530         * docs/gst/tmpl/gstmultifilesrc.sgml:
9531         * docs/gst/tmpl/gstpadtemplate.sgml:
9532         * docs/gst/tmpl/gstpipefilter.sgml:
9533         * docs/gst/tmpl/gstschedulerfactory.sgml:
9534         * docs/gst/tmpl/gstsearchfuncs.sgml:
9535         * docs/gst/tmpl/gstshaper.sgml:
9536         * docs/gst/tmpl/gstspider.sgml:
9537         * docs/gst/tmpl/gstspideridentity.sgml:
9538         * docs/gst/tmpl/gststatistics.sgml:
9539         * docs/gst/tmpl/gsttee.sgml:
9540         * docs/gst/tmpl/gsttimecache.sgml:
9541         * docs/gst/tmpl/gsttypefind.sgml:
9542         * docs/gst/tmpl/gsttypefindfactory.sgml:
9543         * docs/gst/tmpl/gstxmlregistry.sgml:
9544         * docs/gst/tmpl/gthread-cothreads.sgml:
9545         * docs/gst/tmpl/old/cothreads.sgml:
9546         * docs/gst/tmpl/old/cothreads_compat.sgml:
9547         * docs/gst/tmpl/old/gettext.sgml:
9548         * docs/gst/tmpl/old/gobject2gtk.sgml:
9549         * docs/gst/tmpl/old/grammar.tab.sgml:
9550         * docs/gst/tmpl/old/gst-i18n-app.sgml:
9551         * docs/gst/tmpl/old/gst-i18n-lib.sgml:
9552         * docs/gst/tmpl/old/gst_private.sgml:
9553         * docs/gst/tmpl/old/gstaggregator.sgml:
9554         * docs/gst/tmpl/old/gstarch.sgml:
9555         * docs/gst/tmpl/old/gstatomic_impl.sgml:
9556         * docs/gst/tmpl/old/gstbufferstore.sgml:
9557         * docs/gst/tmpl/old/gstdata_private.sgml:
9558         * docs/gst/tmpl/old/gstdisksink.sgml:
9559         * docs/gst/tmpl/old/gstdisksrc.sgml:
9560         * docs/gst/tmpl/old/gstelementfactory.sgml:
9561         * docs/gst/tmpl/old/gstextratypes.sgml:
9562         * docs/gst/tmpl/old/gstfakesink.sgml:
9563         * docs/gst/tmpl/old/gstfakesrc.sgml:
9564         * docs/gst/tmpl/old/gstfdsink.sgml:
9565         * docs/gst/tmpl/old/gstfdsrc.sgml:
9566         * docs/gst/tmpl/old/gstfilesink.sgml:
9567         * docs/gst/tmpl/old/gstfilesrc.sgml:
9568         * docs/gst/tmpl/old/gsthttpsrc.sgml:
9569         * docs/gst/tmpl/old/gstidentity.sgml:
9570         * docs/gst/tmpl/old/gstindexfactory.sgml:
9571         * docs/gst/tmpl/old/gstmarshal.sgml:
9572         * docs/gst/tmpl/old/gstmd5sink.sgml:
9573         * docs/gst/tmpl/old/gstmultidisksrc.sgml:
9574         * docs/gst/tmpl/old/gstmultifilesrc.sgml:
9575         * docs/gst/tmpl/old/gstpadtemplate.sgml:
9576         * docs/gst/tmpl/old/gstpipefilter.sgml:
9577         * docs/gst/tmpl/old/gstschedulerfactory.sgml:
9578         * docs/gst/tmpl/old/gstsearchfuncs.sgml:
9579         * docs/gst/tmpl/old/gstshaper.sgml:
9580         * docs/gst/tmpl/old/gstspider.sgml:
9581         * docs/gst/tmpl/old/gstspideridentity.sgml:
9582         * docs/gst/tmpl/old/gststatistics.sgml:
9583         * docs/gst/tmpl/old/gsttee.sgml:
9584         * docs/gst/tmpl/old/gsttimecache.sgml:
9585         * docs/gst/tmpl/old/gsttypefindfactory.sgml:
9586         * docs/gst/tmpl/old/gstxmlregistry.sgml:
9587         * docs/gst/tmpl/old/gthread-cothreads.sgml:
9588         * docs/gst/tmpl/old/types.sgml:
9589         * docs/gst/tmpl/types.sgml:
9590
9591         Rename gsttypefind.[ch] back to gsttypefindelement.[ch], since
9592         gtkdoc-scan doesn't like files with the same name in different
9593         directories.
9594         * gst/elements/Makefile.am:
9595         * gst/elements/gstelements.c:
9596         * gst/elements/gsttypefind.c: 
9597         * gst/elements/gsttypefind.h:
9598         * gst/elements/gsttypefindelement.c:
9599         * gst/elements/gsttypefindelement.h:
9600
9601 2004-04-28  David Schleef  <ds@schleef.org>
9602
9603         A bunch of portability fixes, derived from Steve Lhomme's MSVC
9604         patch (bug #141317):
9605         * gst/gst-i18n-lib.h: Allow disabling gettext.
9606         * gst/gstatomic_impl.h: disable warning when it's dumb.
9607         * gst/gstclock.c: fix include
9608         * gst/gstcompat.h: fix variadic macro
9609         * gst/gstinfo.c: fix include
9610         * gst/gstmacros.h: add defines for inlines on MSVC
9611         * gst/gstplugin.c: fix includes
9612         * gst/gstregistry.c: fix includes
9613         * gst/gstregistry.h: use S_IREAD, etc., if S_IRUSR isn't defined
9614         * gst/gstsystemclock.c: fix include
9615         * gst/gsttrace.c: (gst_trace_new), (gst_trace_text_flush): use
9616         S_IREAD if S_IRUSR isn't defined.  fix use of non-portable functions
9617         * gst/registries/gstxmlregistry.c:
9618         (gst_xml_registry_parse_element_factory): fix use of non-portable
9619         functions
9620         * libs/gst/control/dparam.h: Remove trailing comma in enum definition
9621         * libs/gst/control/dparammanager.h: same
9622
9623 2004-04-28  David Schleef  <ds@schleef.org>
9624
9625         Move a bunch of unused files to old/ with names that are
9626         not case-insensitive-unique.  These files still contain some
9627         useful information that needs to be merged into gstbin.sgml,
9628         etc., so they shouldn't be deleted yet.
9629         * docs/gst/tmpl/GstBin.sgml:
9630         * docs/gst/tmpl/GstBuffer.sgml:
9631         * docs/gst/tmpl/GstCaps.sgml:
9632         * docs/gst/tmpl/GstClock.sgml:
9633         * docs/gst/tmpl/GstCompat.sgml:
9634         * docs/gst/tmpl/GstData.sgml:
9635         * docs/gst/tmpl/GstElement.sgml:
9636         * docs/gst/tmpl/GstEvent.sgml:
9637         * docs/gst/tmpl/GstIndex.sgml:
9638         * docs/gst/tmpl/GstStructure.sgml:
9639         * docs/gst/tmpl/GstTag.sgml:
9640         * docs/gst/tmpl/old/GstBin.sgml:
9641         * docs/gst/tmpl/old/GstBuffer.sgml:
9642         * docs/gst/tmpl/old/GstCaps.sgml:
9643         * docs/gst/tmpl/old/GstClock.sgml:
9644         * docs/gst/tmpl/old/GstCompat.sgml:
9645         * docs/gst/tmpl/old/GstData.sgml:
9646         * docs/gst/tmpl/old/GstElement.sgml:
9647         * docs/gst/tmpl/old/GstEvent.sgml:
9648         * docs/gst/tmpl/old/GstIndex.sgml:
9649         * docs/gst/tmpl/old/GstStructure.sgml:
9650         * docs/gst/tmpl/old/GstTag.sgml:
9651
9652 2004-04-28  David Schleef  <ds@schleef.org>
9653
9654         * gst/gstcaps.c: (gst_caps_copy), (gst_caps_free),
9655         (gst_caps_append), (gst_caps_append_structure),
9656         (gst_caps_get_size), (gst_caps_get_structure), (gst_caps_copy_1),
9657         (gst_caps_set_simple), (gst_caps_set_simple_valist),
9658         (gst_caps_is_any), (gst_caps_is_empty), (gst_caps_is_chained),
9659         (gst_caps_is_fixed), (gst_caps_is_always_compatible),
9660         (gst_caps_intersect), (gst_caps_normalize),
9661         (gst_caps_transform_to_string):  Patch from Tim-Philipp Müller
9662         to fix GST_CAPS() and GST_IS_CAPS(). (bug #141304)
9663         * gst/gstcaps.h: use GST_IS_CAPS().
9664
9665 2004-04-26  David Schleef  <ds@schleef.org>
9666
9667         * gst/gstcpu.c: (gst_cpuid_i386): Don't clobber ebx in inline
9668         assembly.  gcc doesn't handle it correctly. (bug #141083)
9669         * gst/gsttrashstack.h: same
9670
9671 2004-04-25  Benjamin Otte  <otte@gnome.org>
9672
9673         * gst/gstelement.c: (gst_element_change_state):
9674           fix assertion to do an int comparison
9675
9676 2004-04-25  Benjamin Otte  <otte@gnome.org>
9677
9678         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
9679           better debugging output on error
9680
9681 2004-04-25  Benjamin Otte  <otte@gnome.org>
9682
9683         * gst/gstcaps.c: (gst_caps_subtract):
9684           fix memleak
9685
9686 2004-04-23  Benjamin Otte  <otte@gnome.org>
9687
9688         * gst/gstvalue.c: (gst_value_compare_buffer),
9689         (_gst_value_initialize):
9690           add comparison function for buffers
9691
9692 2004-04-22  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9693
9694         * docs/pwg/pwg.xml:
9695           Just found out that this so-called "ima-wav" format is really
9696           just "dvi adpcm" (according to the MS WAV documentation). So
9697           renaming it. We didn't use it yet anyway.
9698
9699 2004-04-23  Benjamin Otte  <otte@gnome.org>
9700
9701         * gst/gstcaps.c: (gst_caps_is_always_compatible):
9702           call gst_caps_is_subset
9703
9704 2004-04-23  Benjamin Otte  <otte@gnome.org>
9705
9706         * gst/gstcaps.c: (gst_caps_subtract), (gst_caps_is_equal), 
9707         (gst_caps_is_subset):
9708           add documentation
9709
9710 2004-04-23  Benjamin Otte  <otte@gnome.org>
9711           
9712         * gst/gstcaps.c: (gst_caps_structure_subtract_field),
9713         (gst_caps_structure_subtract), (gst_caps_subtract),
9714         (gst_caps_structure_figure_out_union),
9715         (gst_caps_structure_simplify), (gst_caps_do_simplify):
9716           fix simplifying and subtracting not working correctly with optional
9717           properties
9718           solve assorted problems that make it now simplify ebven more
9719         * docs/gst/tmpl/gstcaps.sgml:
9720         * gst/gstcaps.h:
9721           make gst_caps_do_simplify return a bool to indicate if it simplified
9722         * testsuite/caps/simplify.c: (main):
9723           add more checks. The tests is quite a bit useless right now because
9724           the core is heavily simplifying itself.
9725         * testsuite/caps/caps.h:
9726           fix caps to contain all optional properties
9727
9728 2004-04-22  Benjamin Otte  <otte@gnome.org>
9729
9730         * docs/gst/tmpl/gstcaps.sgml:
9731         * docs/gst/tmpl/gstfilesrc.sgml:
9732         * docs/gst/tmpl/gststructure.sgml:
9733         * docs/gst/tmpl/gstvalue.sgml:
9734           update for recent API changes
9735         * gst/gstcaps.c: (gst_caps_do_simplify):
9736           fix to stop trying with a freed structure
9737         * gst/gstpad.c: (gst_pad_link_fixate):
9738           simplify caps
9739         * gst/gstpad.c: (gst_pad_template_get_caps_by_name):
9740           remove C++ comment
9741         * gst/gstpad.h:
9742           deprecate gst_pad_template_get_caps_by_name, it doesn't work anyway
9743         * gst/gststructure.c: (gst_structure_value_get_generic_type),
9744         (gst_structure_to_string):
9745           keep the correct type when using lists of ranges
9746         * gst/gstvalue.c: (gst_value_list_prepend_value),
9747         (gst_value_list_append_value):
9748           copy the value before adding to the list (d'oh)
9749         * gst/gstvalue.c: (gst_value_subtract_int_range_int),
9750         (gst_value_subtract_int_range_int_range):
9751           handle overflows correctly
9752         * gst/gstvalue.c: (gst_value_subtract_from_list):
9753           fix memleak
9754         * testsuite/caps/caps.h:
9755           add a caps that caused segfaults
9756
9757 2004-04-22  Benjamin Otte  <otte@gnome.org>
9758
9759         * testsuite/refcounting/pad.c: (main):
9760           fix test
9761
9762 2004-04-22  Benjamin Otte  <otte@gnome.org>
9763
9764         * gst/gstcaps.c: (gst_caps_subtract):
9765           allow subtracting ANY and EMPTY from ANY caps
9766
9767 2004-04-22  Benjamin Otte  <otte@gnome.org>
9768
9769         * gst/gstcaps.c: (gst_caps_append), (gst_caps_intersect),
9770         (gst_caps_union):
9771           only simplify in functions that create new caps. Simplifying in
9772           gst_caps_append breaks tests.
9773
9774 2004-04-22  Benjamin Otte  <otte@gnome.org>
9775
9776         * gst/gstcaps.c: (gst_caps_structure_simplify):
9777           unset GValue after use
9778         * gst/gstcaps.c: (gst_caps_append), 
9779         * gst/gstpad.c: (gst_pad_link_fixate), (gst_pad_template_new):
9780           use gst_caps_simplify (reduces registry size by 30%)
9781         * gst/gstpad.c: (gst_pad_template_new):
9782           don't allow NULL caps
9783
9784 2004-04-22  Benjamin Otte  <otte@gnome.org>
9785
9786         * docs/gst/gstreamer-sections.txt:
9787           add gst_caps_do_simplify
9788         * gst/gstcaps.c:
9789           add documentation for gst_caps_do_simplify
9790         * gst/gstvalue.h:
9791           fix typo in gst_value_register_subtract_func declaration for gst-doc
9792
9793 2004-04-22  Benjamin Otte  <otte@gnome.org>
9794
9795         * gst/gstcaps.c: (gst_caps_from_string_inplace):
9796           fix bug when converting from empty string.
9797         * gst/gstcaps.c: (gst_caps_new_any), (gst_caps_new_simple),
9798         (gst_caps_new_full_valist), (gst_caps_copy), (gst_caps_copy_1):
9799           use gst_caps_new_empty to allocate a new caps. Only that function
9800           allocates memory for caps now.
9801         * gst/gstcaps.c: (gst_caps_remove_and_get_structure),
9802         (gst_caps_remove_structure):
9803           add ability to remove one structure (but not to header yet)
9804         * gst/gstcaps.c: (gst_caps_compare_structures),
9805         (gst_caps_simplify), (gst_caps_structure_figure_out_union),
9806         (gst_caps_structure_simplify), (gst_caps_do_simplify),
9807         * gst/gstcaps.h:
9808           add gst_caps_do_simplify that tries to simplify a caps in place.
9809           Deprecate old gst_caps_simplify function.
9810         * testsuite/caps/caps.h:
9811           add caps.h containing a common set of caps to test against.
9812         * testsuite/caps/sets.c: (check_caps), (main):
9813           use it.
9814         * testsuite/caps/.cvsignore:
9815         * testsuite/caps/Makefile.am:
9816         * testsuite/caps/simplify.c: (check_caps), (main):
9817           add test to check correctness and efficency of caps simplification.
9818
9819 2004-04-22  Sebastien Cote <sc5@hermes.usherb.ca>
9820
9821         reviewed by Benjamin Otte  <otte@gnome.org>
9822
9823         * gst/gstparse.c: (_gst_parse_escape):
9824           Free the GString used in _gst_parse_escape()
9825
9826 2004-04-21  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9827
9828         * gst/gstpad.c: (gst_pad_link_negotiate):
9829           refuse to link if the link is not possible
9830         * configure.ac:
9831         * testsuite/Makefile.am:
9832         * testsuite/negotiation/.cvsignore:
9833         * testsuite/negotiation/Makefile.am:
9834         * testsuite/negotiation/pad_link.c: (main):
9835           add test that checks the above behaviour
9836
9837 2004-04-21  Thomas Vander Stichele  <thomas at apestaart dot org>
9838
9839         * docs/gst/gstreamer-sections.txt:
9840           add newly added API
9841
9842 2004-04-21  Thomas Vander Stichele  <thomas at apestaart dot org>
9843
9844         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
9845         (gst_filesrc_get_mmap), (gst_filesrc_get_read), (gst_filesrc_get),
9846         (gst_filesrc_open_file), (gst_filesrc_close_file),
9847         (gst_filesrc_srcpad_query), (gst_filesrc_srcpad_event):
9848         * gst/elements/gstfilesrc.h:
9849           add support for non-regular files (#140734)
9850
9851 2004-04-21  Benjamin Otte  <otte@gnome.org>
9852
9853         * gst/gstpad.c: (gst_pad_link_fixate):
9854           add sophisticated error checking code to see if fixation functions
9855           did their fixation right
9856
9857 2004-04-21  Benjamin Otte  <otte@gnome.org>
9858
9859         * gst/gstcaps.c: (gst_caps_append), (gst_caps_union):
9860           check for ANY caps before appending/unioning
9861         * gst/gstcaps.c: (gst_caps_is_subset),
9862         (gst_caps_is_equal), (gst_caps_structure_subtract_field),
9863         (gst_caps_structure_subtract), (gst_caps_subtract):
9864         * gst/gstcaps.h:
9865           add gst_caps_is_equal, gst_caps_is_subset and gst_caps_subtract to
9866           the API. deprecate gst_caps_is_equal_fixed
9867         * gst/gstpad.c: (gst_pad_try_set_caps):
9868         * gst/gstqueue.c: (gst_queue_link):
9869           s/gst_caps_is_equal_fixed/gst_caps_is_equal/
9870         * gst/gststructure.c: (gst_structure_get_name_id):
9871         * gst/gststructure.h:
9872           add function gst_structure_get_name_id
9873         * gst/gstvalue.c: (gst_value_subtract_int_int_range),
9874         (gst_value_create_new_range), (gst_value_subtract_int_range_int),
9875         (gst_value_subtract_int_range_int_range),
9876         (gst_value_subtract_double_double_range),
9877         (gst_value_subtract_double_range_double),
9878         (gst_value_subtract_double_range_double_range),
9879         (gst_value_subtract_from_list), (gst_value_subtract_list),
9880         (gst_value_can_intersect), (gst_value_subtract),
9881         (gst_value_can_subtract), (gst_value_register_subtract_func),
9882         (_gst_value_initialize):
9883         * gst/gstvalue.h:
9884           add support for subtracting values from each other. Note that
9885           subtracting means subtracting as in set theory. Required for caps
9886           stuff above.
9887         * testsuite/caps/.cvsignore:
9888         * testsuite/caps/Makefile.am:
9889         * testsuite/caps/erathostenes.c: (erathostenes), (main):
9890         * testsuite/caps/sets.c: (check_caps), (main):
9891         * testsuite/caps/subtract.c: (check_caps), (main):
9892           add tests for subtraction and equality code.
9893
9894 2004-04-20  David Schleef  <ds@schleef.org>
9895
9896         * gst/autoplug/Makefile.am:  Fix some little buglets in last checkin.
9897         * gst/indexers/Makefile.am:
9898         * gst/schedulers/Makefile.am:
9899         * libs/gst/bytestream/Makefile.am:
9900         * libs/gst/control/Makefile.am:
9901         * libs/gst/getbits/Makefile.am:
9902
9903 2004-04-20  David Schleef  <ds@schleef.org>
9904
9905         * common/as-libtool.mak: Fine-tune DLL building.
9906         * configure.ac: Link plugins against libgstreamer.  Define plugindir
9907         (like gst-plugins)
9908         * examples/plugins/Makefile.am: remove plugindir
9909         * gst/autoplug/Makefile.am: DLL building fixes
9910         * gst/elements/Makefile.am: DLL building fixes.  Disable pipefilter on
9911         Windows.
9912         * gst/elements/gstelements.c: Conditionally disable pipefilter.
9913         * gst/indexers/Makefile.am: DLL building fixes
9914         * gst/schedulers/Makefile.am: DLL building fixes.
9915         * libs/gst/bytestream/Makefile.am: DLL building fixes.
9916         * libs/gst/control/Makefile.am: same
9917         * libs/gst/getbits/Makefile.am: same
9918         * testsuite/Makefile.am: New dlopen directory
9919         * testsuite/dlopen/Makefile.am: Tests to check if libgstreamer works
9920         when dlopened.
9921         * testsuite/dlopen/dlopen_gst.c: (main): same
9922         * testsuite/dlopen/loadgst.c: (do_test): same
9923
9924 2004-04-20  David Schleef  <ds@schleef.org>
9925
9926         * gst/parse/grammar.y:  Apply patch from Sebastien Cote
9927         <sc5@hermes.usherb.ca> to fix a memleak. (bug #140594)
9928
9929 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
9930
9931         * gst/gstelement.c: (gst_element_wait),
9932         (gst_element_set_time_delay), (gst_element_change_state):
9933           Use GST_TIME_*
9934
9935 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9936
9937         * gst/autoplug/gstspider.c: (gst_spider_link_sometimes),
9938         (gst_spider_identity_plug):
9939           improve debugging messages
9940         * gst/gstbin.c: (gst_bin_remove_func):
9941           make sure the state_change function is only called with simple state
9942           transitions
9943
9944 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
9945
9946         * gst/elements/gstfakesink.c: (gst_fakesink_state_error_get_type),
9947         (gst_fakesink_set_property), (gst_fakesink_chain):
9948         * gst/elements/gstfakesrc.c: (gst_fakesrc_set_property):
9949         * gst/elements/gstfdsrc.c: (gst_fdsrc_set_property):
9950         * gst/elements/gstfilesrc.c: (gst_filesrc_set_property):
9951         * gst/elements/gstidentity.c: (gst_identity_chain),
9952         (gst_identity_set_property):
9953         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_set_property):
9954         * gst/elements/gstpipefilter.c: (gst_pipefilter_set_property):
9955           add warnings to _set_property for unknown arguments
9956           use GST_TIME_FORMAT/GST_TIME_ARGS for timestamp printing
9957
9958 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
9959
9960         * Makefile.am:
9961         * docs/manuals.mak:
9962           add .po file download snippet
9963           fix a bug in the doc makefile
9964
9965 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
9966
9967         * Makefile.am:
9968         * po/LINGUAS:
9969         * po/en_GB.po:
9970           Added en_GB translation (Gareth Owen)
9971
9972 2004-04-20  Johan Dahlin  <johan@gnome.org>
9973
9974         * gst/gstpad.c (_invent_event): Clean up
9975
9976 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9977
9978         * testsuite/caps/filtercaps.c: (main):
9979           fix test to test things correctly (caps are complicated)
9980
9981 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9982
9983         * testsuite/caps/Makefile.am:
9984         * testsuite/caps/filtercaps.c: (main):
9985           add test (that doesn't work right now, but should)
9986
9987 2004-04-19  David Schleef  <ds@schleef.org>
9988
9989         * configure.ac: Add test for allowing unaligned access.  Add define
9990         to put in gstconfig.h.
9991         * docs/gst/gstreamer-sections.txt: New symbols
9992         * docs/gst/tmpl/gstcompat.sgml: Check in changes made by gtkdoc
9993         * docs/gst/tmpl/gstfilesrc.sgml:
9994         * docs/gst/tmpl/gstparse.sgml:
9995         * docs/gst/tmpl/gsttypes.sgml:
9996         * docs/gst/tmpl/gstutils.sgml:
9997         * docs/gst/tmpl/gstvalue.sgml:
9998         * gst/gstconfig.h.in: Add GST_HAVE_UNALIGNED_ACCESS
9999         * gst/gstutils.h: Add macros for unaligned memory access.  Useful
10000         on most !i386/!powerpc architectures.  From Daniel Gazard
10001         <daniel.gazard@free.fr>.  (bug #140156)
10002         * po/af.po: Check in changes made by gettext.
10003         * po/az.po:
10004         * po/fr.po:
10005         * po/nl.po:
10006         * po/sr.po:
10007         * po/sv.po:
10008
10009 2004-04-20  Benjamin Otte  <otte@gnome.org>
10010
10011         * gst/schedulers/entryscheduler.c: 
10012         (gst_entry_scheduler_yield):
10013           refuse to yield when decoupled elements insist on doing that.
10014           At least it's better than crashing
10015
10016 2004-04-19  David Schleef  <ds@schleef.org>
10017
10018         * docs/libs/Makefile.am: Change sinclude to include
10019         * docs/gst/Makefile.am: same
10020         * pkgconfig/Makefile.am:  Remove GNU-ism from makefile target
10021
10022 2004-04-19  Thomas Vander Stichele  <thomas at apestaart dot org>
10023
10024         * po/LINGUAS:
10025         * po/uk.po:
10026           Added Ukrainian translation (Maxim V. Dziumanenko)
10027
10028 2004-04-19  Johan Dahlin  <johan@gnome.org>
10029
10030         * gst/parse/grammar.y (__gst_parse_chain_free): Don't do null
10031         checking here, do it before calling the function.
10032         Clean up, use for loops instead of while loops while iterating
10033         over lists.
10034
10035         * gst/autoplug/gstspider.c (gst_spider_request_new_pad): Fix typo
10036         in debug message.
10037         (gst_spider_create_and_plug): Improve debug message.
10038         General: Replace while loops which iterates over GLists with for
10039         loops. Which are much cleaner, improves readability, especially
10040         for gst_spider_identity_plug
10041
10042         * gst/gstpad.c (_invent_event): Fix parameters to warning macros,
10043         fixes bug 140477
10044
10045 2004-04-18  Thomas Vander Stichele  <thomas at apestaart dot org>
10046
10047         * po/LINGUAS:
10048         * po/tr.po:
10049           Added Turkish translation (Baris Cicek)
10050
10051 2004-04-18  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10052
10053         * docs/faq/troubleshooting.xml:
10054           Mention gst-register in the FAQ (fixes 139045).
10055
10056 2004-04-17  Thomas Vander Stichele  <thomas at apestaart dot org>
10057
10058         * docs/gst/gstreamer-sections.txt:
10059
10060 2004-04-17  Benjamin Otte  <otte@gnome.org>
10061
10062         * gst/gstelement.c: (gst_element_dispose):
10063           simplify
10064         * gst/gstpad.c: (gst_pad_call_chain_function):
10065           don't create loads of events due to bad macro usage
10066
10067 2004-04-16  David Schleef  <ds@schleef.org>
10068
10069         * gst/gstcaps.c: (gst_caps_is_fixed_foreach):
10070         * gst/gstpad.c: (_gst_pad_default_fixate_foreach):
10071         * gst/gstvalue.c: (gst_value_serialize_buffer),
10072         (gst_value_deserialize_buffer), (gst_type_is_fixed),
10073         (_gst_value_initialize): Create a new function gst_type_is_fixed()
10074         to indicate types that are fixed wrt caps or not.  Switching to
10075         this function fixes (bug #140298).
10076         * gst/gstvalue.h:
10077
10078 2004-04-16  David Schleef  <ds@schleef.org>
10079
10080         * common/m4/gst-arch.m4:  Implmenent a whitelist and blacklist
10081         for GST_UNALIGNED_ACESS, since we essentially know which archs
10082         are ok.
10083
10084 2004-04-17  Benjamin Otte  <otte@gnome.org>
10085
10086         * docs/gst/Makefile.am:
10087           ignore gst/parse directory when building docs (fixes #140205)
10088
10089 2004-04-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10090
10091         * testsuite/refcounting/mem.c: (vmsize):
10092           do error checking
10093
10094 2004-04-16  Johan Dahlin  <johan@gnome.org>
10095
10096         * docs/gst/gstreamer-sections.txt: Add gst_pad_call_chain_function
10097         and gst_pad_call_get_function.
10098
10099 2004-04-15  David Schleef  <ds@schleef.org>
10100
10101         * common/m4/gst-arch.m4: Add GST_UNALIGNED_ACCESS() macro that
10102         checks if we can access unaligned memory.
10103         * configure.ac: Use it.
10104
10105 2004-04-16  Benjamin Otte  <otte@gnome.org>
10106
10107         * gst/elements/gstfilesrc.c: (gst_filesrc_init), (gst_filesrc_get),
10108         (gst_filesrc_change_state), (gst_filesrc_srcpad_event):
10109         * gst/elements/gstfilesrc.h:
10110           s/seek_happened/need_discont/ and require discont before sending any
10111           data
10112
10113 2004-04-15  David Schleef  <ds@schleef.org>
10114
10115         * gst/gstvalue.c: (gst_value_serialize_buffer),
10116         (gst_value_deserialize_buffer), (_gst_value_initialize):
10117         Register these types as fundamental types. (bug #140015)
10118
10119 2004-04-16  Benjamin Otte  <otte@gnome.org>
10120
10121         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_new),
10122         (gst_pad_link_free), (gst_pad_link_try), (_invent_event),
10123         (gst_pad_pull):
10124           implement enforcing discont events before buffers are passed. This
10125           allows state changes of only some elements and later correctly going
10126           on where they left off (or in short: you can now set audio sinks to
10127           NULL to release the device when the pipeline is paused)
10128         * gst/gstpad.c: (gst_pad_call_chain_function),
10129         (gst_pad_call_get_function):
10130         * gst/gstpad.h:
10131           add gst_pad_call_chain_function and gst_pad_call_get_function for
10132           scheduler interaction. They are required because of the changes
10133           above.
10134         * gst/schedulers/entryscheduler.c: (get_buffer),
10135         (gst_entry_scheduler_chain_wrapper),
10136         (gst_entry_scheduler_get_wrapper),
10137         (gst_entry_scheduler_state_transition),
10138         (gst_entry_scheduler_pad_link):
10139         * gst/schedulers/gstbasicscheduler.c:
10140         (gst_basic_scheduler_chain_wrapper),
10141         (gst_basic_scheduler_src_wrapper),
10142         (gst_basic_scheduler_chainhandler_proxy),
10143         (gst_basic_scheduler_gethandler_proxy),
10144         (gst_basic_scheduler_cothreaded_chain),
10145         (gst_basic_scheduler_chain_elements):
10146         * gst/schedulers/gstoptimalscheduler.c:
10147         (get_group_schedule_function), (pad_clear_queued),
10148         (gst_opt_scheduler_pad_link):
10149           use the new functions instead of calling get/chain-functions
10150           directly.
10151
10152 2004-04-15  David Schleef  <ds@schleef.org>
10153
10154         * docs/gst/gstreamer-sections.txt: Remove deprecated symbols.
10155         * docs/gst/tmpl/gstinfo.sgml: same
10156         * docs/gst/tmpl/gstutils.sgml: Remove a bunch of bogus crap that
10157         gtk-doc put here.
10158         * gst/gstutils.h: Remove the \ that was confusing gtk-doc.
10159         * examples/queue/queue.c: (main):  We iterate pipelines, not
10160         bins.  (bug #139996)
10161
10162 2004-04-15  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10163
10164         * docs/pwg/advanced-types.xml:
10165           Add MS RLE support. Also document Qt RLE although I have no sample
10166           files for that yet. And document an extra property for ADPCM.
10167
10168 2004-04-15  David Schleef  <ds@schleef.org>
10169
10170         * gst/gstplugin.c: (_gst_plugin_fault_handler_restore),
10171         (_gst_plugin_fault_handler_setup):  Disable more stuff on
10172         Windows.
10173
10174 2004-04-15  David Schleef  <ds@schleef.org>
10175
10176         * gst/gstinfo.c: (_gst_debug_init): Change some internal
10177         symbol names to not conflict with new gstinfo.h symbols.
10178         * gst/gstinfo.h: Add inline functions for all those crazy
10179         compilers that don't know how to handle variadic macros (MSVC).
10180
10181 2004-04-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10182
10183         * configure.ac: bump nano to 1
10184
10185 === release 0.8.1 ===
10186
10187 2004-04-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10188
10189         * NEWS:
10190         * RELEASE:
10191         * configure.ac:
10192           releasing 0.8.1, "Snow Brigade"
10193
10194 2004-04-14  David Schleef  <ds@schleef.org>
10195
10196         * testsuite/Makefile.am: define tests_ignore
10197         * testsuite/Rules: Added new tests_ignore, which get compiled,
10198         but not run (generally because they're inconsistent or have
10199         heisenbugs).  Now we can ensure all the .c files compile in
10200         testsuite/.
10201         * testsuite/bins/Makefile.am: define tests_ignore
10202         * testsuite/bytestream/Makefile.am:
10203         * testsuite/caps/Makefile.am:
10204         * testsuite/clock/Makefile.am:
10205         * testsuite/debug/Makefile.am:
10206         * testsuite/debug/global.c: (gst_debug_log_one),
10207         (gst_debug_log_two): Fix compilation problem.
10208         * testsuite/dynparams/Makefile.am:
10209         * testsuite/elements/Makefile.am:
10210         * testsuite/ghostpads/Makefile.am:
10211         * testsuite/indexers/Makefile.am:
10212         * testsuite/parse/Makefile.am:
10213         * testsuite/plugin/Makefile.am:
10214         * testsuite/refcounting/Makefile.am:
10215         * testsuite/refcounting/element_pad.c: (main): Don't return leak
10216         results, because it's not calculated correctly.
10217         * testsuite/refcounting/pad.c: (main): same
10218         * testsuite/states/Makefile.am:
10219         * testsuite/tags/Makefile.am:
10220         * testsuite/threads/Makefile.am:
10221
10222 2004-04-14  David Schleef  <ds@schleef.org>
10223
10224         * gst/gstcpu.c: (gst_cpuid_i386): Add workaround for gcc-3.2
10225         generating bad code around the cpu detection asm code.
10226
10227 2004-04-14  Thomas Vander Stichele  <thomas at apestaart dot org>
10228
10229         * tools/gst-inspect.c: (print_element_info):
10230           print numeric version of rank as well, since we added some - 1
10231           rank values to elements
10232
10233 2004-04-13  David Schleef  <ds@schleef.org>
10234
10235         * configure.ac:  Disable various code when compiling for MinGW.
10236         * gst/elements/Makefile.am:
10237         * gst/elements/gstelements.c:
10238         * gst/elements/gstfdsrc.c: (gst_fdsrc_get):
10239         * gst/elements/gstfilesrc.c: (gst_filesrc_init), (gst_filesrc_get):
10240         * gst/registries/gstxmlregistry.c: (make_dir):
10241
10242 2004-04-13  David Schleef  <ds@schleef.org>
10243
10244         * gst/Makefile.am:
10245         * gst/gstcpu.c: (gst_cpuid_i386): Convert asm source into inline
10246         assembly.
10247         * gst/gstcpuid_i386.s: remove
10248
10249 2004-04-13  David Schleef  <ds@schleef.org>
10250
10251         * docs/gst/tmpl/gstaggregator.sgml: Random checkin because gtk-doc
10252         seems to think it needs to be done.
10253         * docs/gst/tmpl/gstfakesink.sgml:
10254         * docs/gst/tmpl/gstfakesrc.sgml:
10255         * docs/gst/tmpl/gstfdsink.sgml:
10256         * docs/gst/tmpl/gstfdsrc.sgml:
10257         * docs/gst/tmpl/gstfilesink.sgml:
10258         * docs/gst/tmpl/gstfilesrc.sgml:
10259         * docs/gst/tmpl/gstidentity.sgml:
10260         * docs/gst/tmpl/gstmd5sink.sgml:
10261         * docs/gst/tmpl/gstmultifilesrc.sgml:
10262         * docs/gst/tmpl/gstpipefilter.sgml:
10263         * docs/gst/tmpl/gstshaper.sgml:
10264         * docs/gst/tmpl/gstspider.sgml:
10265         * docs/gst/tmpl/gstspideridentity.sgml:
10266         * docs/gst/tmpl/gststatistics.sgml:
10267         * docs/gst/tmpl/gsttee.sgml:
10268         * docs/gst/tmpl/gsttypefind.sgml:
10269         * docs/gst/tmpl/gstutils.sgml:
10270
10271 2004-04-13  David Schleef  <ds@schleef.org>
10272
10273         * configure.ac: Changes to remove POSIXisms (mmap in this case)
10274         and to build DLLs on Windows.
10275         * gst/Makefile.am:
10276         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
10277         (gst_filesrc_open_file):
10278         * gst/schedulers/Makefile.am:
10279
10280 2004-04-13  David Schleef  <ds@schleef.org>
10281
10282         * gst/gstcaps.c: (gst_caps_structure_fixate_field_nearest_int),
10283         (gst_caps_structure_fixate_field_nearest_double):  Fix bug in
10284         fixating lists.
10285
10286 2004-04-12  David Schleef  <ds@schleef.org>
10287
10288         * gst/gstbuffer.c: (_gst_buffer_initialize), (gst_buffer_get_type),
10289         (gst_buffer_free_chunk): Added gst_buffer_get_type() and changed
10290         to using it.
10291         * gst/gstbuffer.h: Changed GST_BUFFER_TYPE to gst_buffer_get_type()
10292         * gst/gstcaps.c: (gst_caps_is_fixed_foreach): Buffer is a fixed type
10293         * gst/gstpad.c: (_gst_pad_default_fixate_foreach): same
10294         * gst/gststructure.c: (gst_structure_set_valist),
10295         (gst_structure_from_abbr), (gst_structure_to_abbr): Add vararg
10296         support for buffers.
10297         * gst/gsttag.c: (gst_tag_register): Constify a prototype that was
10298         intended to be const.
10299         * gst/gsttag.h: same
10300         * gst/gstvalue.c: (gst_value_serialize_buffer),
10301         (gst_value_deserialize_buffer), (_gst_value_initialize):  Add code
10302         to (de)serialize buffers.
10303         * testsuite/caps/Makefile.am:  Add a bit of buffer testing
10304         * testsuite/caps/string-conversions.c: (main):
10305         * testsuite/caps/value_serialize.c: add new test
10306
10307 2004-04-11  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10308
10309         * docs/pwg/advanced-types.xml:
10310           Document MS video 1 (video/x-msvideocodec) mimetype/format.
10311
10312 2004-04-11  Benjamin Otte  <otte@gnome.org>
10313
10314         * gst/schedulers/gstbasicscheduler.c: (plugin_init):
10315           rename categories to basic_*
10316         * gst/schedulers/gstbasicscheduler.c: 
10317         (gst_basic_scheduler_chain_wrapper),
10318         (gst_basic_scheduler_chainhandler_proxy),
10319         (gst_basic_scheduler_gethandler_proxy),
10320         (gst_basic_scheduler_eventhandler_proxy):
10321           debugging category fixes - put common stuff in log category
10322         * gst/schedulers/gstbasicscheduler.c: 
10323         (gst_basic_scheduler_chain_elements):
10324           dirty fix: call gst_basic_scheduler_cothreaded_chain when already
10325           active and linking two active chains
10326
10327 2004-04-10  Benjamin Otte  <otte@gnome.org>
10328
10329         * docs/pwg/intro-preface.xml:
10330           fix dead links and remove reference to Wiki
10331
10332 2004-04-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10333
10334         * gst/schedulers/gstbasicscheduler.c:
10335           make sure we can switch back to the main function if we're still in
10336           the main function (supposed to fix #139617)
10337         * gst/schedulers/gthread-cothreads.h:
10338           don't throw an error when switching to the same cothread
10339
10340 2004-04-09  Benjamin Otte  <otte@gnome.org>
10341
10342         * gst/gstbin.c: (gst_bin_get_type):
10343         * gst/gstclock.c: (gst_clock_get_type):
10344         * gst/gstindex.c: (gst_index_get_type):
10345         * gst/gstobject.c: (gst_object_get_type),
10346         (gst_signal_object_get_type):
10347         * gst/gstpad.c: (gst_pad_get_type), (gst_real_pad_get_type),
10348         (gst_pad_template_get_type), (gst_ghost_pad_get_type):
10349         * gst/gstpluginfeature.c: (gst_plugin_feature_get_type):
10350         * gst/gstqueue.c: (gst_queue_get_type):
10351         * gst/gstregistry.c: (gst_registry_get_type):
10352         * gst/gstsystemclock.c: (gst_system_clock_get_type):
10353         * gst/gstthread.c: (gst_thread_get_type):
10354           don't use memchunks for these objects, use malloc instead
10355
10356 2004-04-08  Thomas Vander Stichele  <thomas at apestaart dot org>
10357
10358         * docs/gst/.cvsignore:
10359         * docs/gst/Makefile.am:
10360         * docs/gst/gstreamer-sections.txt:
10361         * docs/gst/tmpl/gstaggregator.sgml:
10362         * docs/gst/tmpl/gstbuffer.sgml:
10363         * docs/gst/tmpl/gstclock.sgml:
10364         * docs/gst/tmpl/gstelement.sgml:
10365         * docs/gst/tmpl/gstfakesink.sgml:
10366         * docs/gst/tmpl/gstfakesrc.sgml:
10367         * docs/gst/tmpl/gstfdsink.sgml:
10368         * docs/gst/tmpl/gstfdsrc.sgml:
10369         * docs/gst/tmpl/gstfilesink.sgml:
10370         * docs/gst/tmpl/gstfilesrc.sgml:
10371         * docs/gst/tmpl/gstidentity.sgml:
10372         * docs/gst/tmpl/gstindex.sgml:
10373         * docs/gst/tmpl/gstinfo.sgml:
10374         * docs/gst/tmpl/gstmd5sink.sgml:
10375         * docs/gst/tmpl/gstmultifilesrc.sgml:
10376         * docs/gst/tmpl/gstpad.sgml:
10377         * docs/gst/tmpl/gstpipefilter.sgml:
10378         * docs/gst/tmpl/gstpipeline.sgml:
10379         * docs/gst/tmpl/gstpluginfeature.sgml:
10380         * docs/gst/tmpl/gstqueue.sgml:
10381         * docs/gst/tmpl/gstregistry.sgml:
10382         * docs/gst/tmpl/gstscheduler.sgml:
10383         * docs/gst/tmpl/gstshaper.sgml:
10384         * docs/gst/tmpl/gstspider.sgml:
10385         * docs/gst/tmpl/gstspideridentity.sgml:
10386         * docs/gst/tmpl/gststatistics.sgml:
10387         * docs/gst/tmpl/gstsystemclock.sgml:
10388         * docs/gst/tmpl/gsttee.sgml:
10389         * docs/gst/tmpl/gstthread.sgml:
10390         * docs/gst/tmpl/gsttypefind.sgml:
10391         * docs/gst/tmpl/gstutils.sgml:
10392           further doc build fixes
10393
10394 2004-04-07  Thomas Vander Stichele  <thomas at apestaart dot org>
10395
10396         * docs/gst/Makefile.am:
10397           make docs exit on scanning problems
10398           fix nonsrcdir build issues
10399         * docs/gst/gstreamer-sections.txt:
10400           adding stuff from -unused
10401         * gst/gstqueue.h:
10402           create GstQueueSize
10403         * gst/schedulers/cothreads_compat.h:
10404           fix cothread warnings
10405
10406 2004-04-07  Thomas Vander Stichele  <thomas at apestaart dot org>
10407
10408         * docs/gst/gstreamer-sections.txt:
10409           remove defines deprecated by Benjamin
10410
10411 2004-04-07  Benjamin Otte  <otte@gnome.org>
10412
10413         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
10414           when the buffer is complete, don't check if other buffers are needed
10415         * gst/elements/gstfilesrc.c: (gst_filesrc_srcpad_event):
10416           check that the offset is >0 so we don't try to read before the
10417           beginning of the file
10418         * gst/gstpad.c: (gst_pad_set_pad_template):
10419           sink the template, so we don't end up with 130k pad templates
10420
10421 2004-04-06  Benjamin Otte  <otte@gnome.org>
10422
10423         * gst/autoplug/gstspider.c: (gst_spider_link_add):
10424           don't ref the element, adding already reffed it. And we didn't unref
10425           it later anyway... (huge memleak when you used many spider elements)
10426         * gst/gstelement.c: (gst_element_base_class_finalize):
10427         * gst/gstelementfactory.c: (gst_element_factory_cleanup),
10428         (gst_element_register):
10429         * gst/gsturi.c: (gst_element_make_from_uri):
10430           use gst_object_(un)ref instead of g_object(un)ref
10431
10432 2004-04-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10433
10434         * gst/gstbuffer.h:
10435           remove macro that wouldn't work anymore because struct member has
10436           been removed.
10437         * gst/schedulers/entryscheduler.c: (schedule_forward):
10438           fix segfault for unconnected pads
10439         
10440 2004-04-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10441
10442         reviewed by David Schleef <ds@schleef.org>
10443
10444         * gst/gstinfo.h:
10445           *_FORMAT modifiers should require putting a % in front of them for
10446           consistency reasons.
10447
10448 2004-04-05  Colin Walters  <walters@redhat.com>
10449
10450         * configure.ac (VALGRIND_CFLAGS, VALGRIND_LIBS): Remove spurious
10451         space.
10452
10453 2004-04-05  Benjamin Otte  <otte@gnome.org>
10454
10455         * configure.ac:
10456         * gst/Makefile.am:
10457         * gst/gst_private.h:
10458         * gst/gstinfo.c: (__gst_in_valgrind), (_gst_debug_init):
10459           add support for detecting if GStreamer runs inside valgrind.
10460           requires valgrind (d'oh) and --enable-debug for correct cdetection.
10461           print a big message in valgrind that GStreamer has detected it's
10462           running inside and might now use different code.
10463         * gst/gstmemchunk.c: (populate), (free_area),
10464         (gst_mem_chunk_destroy), (gst_mem_chunk_alloc),
10465         (gst_mem_chunk_free):
10466           flag memchunks for valgrind, so it can detect leaking of chunks.
10467           This allows detecting leaks of GstBuffer and GstEvent correctly
10468           inside valgrind.
10469
10470 2004-04-05  David Schleef  <ds@schleef.org>
10471
10472         * gst/gsttrace.h:  Fix #ifdef nesting (bug #139109) Patch from
10473           jensgr@gmx.net (Jens Granseuer)
10474
10475 2004-04-05  David Schleef  <ds@schleef.org>
10476
10477         * gst/gstbuffer.c: (_gst_buffer_sub_free),
10478         (gst_buffer_default_free), (gst_buffer_default_copy),
10479         (gst_buffer_alloc_chunk), (gst_buffer_free_chunk),
10480         (gst_buffer_new), (gst_buffer_create_sub):  Allocate GstBuffer
10481         structures in one place.
10482
10483 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10484
10485         * gst/gstinfo.h: adding Ronald's timestamp debugging defines
10486           (GST_TIME_FORMAT, GST_TIME_ARGS)
10487
10488 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10489
10490         * testsuite/elements/Makefile.am:
10491           disable test until it stops breaking make distcheck
10492
10493 2004-04-05  Johan Dahlin  <johan@gnome.org>
10494
10495         * po/sv.po: Updated translation
10496
10497 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10498
10499         * gst/gstplugin.c: (gst_plugin_load_file):
10500           fix segfault for when original plugin was loaded statically
10501
10502 2004-04-05  Benjamin Otte  <otte@gnome.org>
10503
10504         * testsuite/debug/category.c: (main):
10505         * testsuite/debug/commandline.c: (main):
10506         * testsuite/debug/output.c: (main):
10507           fix tests to work again with debugging enabled
10508
10509 2004-04-05  Benjamin Otte  <otte@gnome.org>
10510
10511         * gst/schedulers/gstbasicscheduler.c:
10512         (gst_basic_scheduler_pad_link):
10513           fix to work with recent scheduling changes
10514
10515 2004-04-05  Benjamin Otte  <otte@gnome.org>
10516
10517         * gst/schedulers/entryscheduler.c: (some functions, dunno which,
10518         prepareChangeLog doesn't work when cvs indents):
10519           don't throw an error when no element can be scheduled, there's too
10520           many weird reasons why it doesn't work. Return STOPPED instead.
10521           decoupled elemts' schedulability doesn't depend on bufpens.
10522
10523 2004-04-04  Benjamin Otte  <otte@gnome.org>
10524
10525         * gst/schedulers/gstbasicscheduler.c:
10526         (gst_basic_scheduler_pad_select):
10527           fix uninitialized variable warnings
10528
10529 2004-04-04  Benjamin Otte  <otte@gnome.org>
10530
10531         * gst/gstpad.c: (gst_pad_collect_valist):
10532           fix uninitialized variable warning
10533         * gst/schedulers/entryscheduler.c: (schedule_forward):
10534           fix shadowed variable
10535
10536 2004-04-04  Benjamin Otte  <otte@gnome.org>
10537
10538         * gst/gstpad.c: (gst_pad_collect_array), (gst_pad_collectv),
10539         (gst_pad_collect), (gst_pad_collect_valist), (gst_pad_selectv),
10540         (gst_pad_select):
10541         * gst/gstpad.h:
10542         * gst/gstscheduler.c: (gst_scheduler_pad_select),
10543         (gst_scheduler_lock_element), (gst_scheduler_unlock_element):
10544         * gst/gstscheduler.h:
10545           implement gst_pad_collect as replacement for gst_pad_select.
10546           deprecate gst_pad_select and gst_scheduler_(un)lock_element
10547           add new flag GST_SCHEDULER_FLAG_NEW_API for API that implements the
10548           new pad_select, lock and unlock calls.
10549         * gst/cothreads.c: (cothread_destroy), (cothread_switch):
10550         * gst/cothreads.h:
10551         * gst/schedulers/cothreads_compat.h:
10552         * gst/schedulers/gthread-cothreads.h:
10553           remove unused cothread_lock and cothread_unlock calls
10554         * gst/schedulers/entryscheduler.c:
10555         (gst_entry_scheduler_class_init), (gst_entry_scheduler_init),
10556         (_can_schedule_loop), (gst_entry_scheduler_get_handler),
10557         (gst_entry_scheduler_pad_select):
10558           update to new API
10559         * gst/schedulers/gstbasicscheduler.c:
10560         (gst_basic_scheduler_class_init), (gst_basic_scheduler_init),
10561         (gst_basic_scheduler_pad_select):
10562           remove useless lock and unlock calls, update pad_select to new API
10563           (untested)
10564         * gst/schedulers/gstoptimalscheduler.c:
10565         (gst_opt_scheduler_class_init):
10566           remove useless select, lock and unlock function calls
10567         * gst/elements/gstaggregator.c: (gst_aggregator_loop):
10568           use gst_pad_collect instead of gst_pad_select
10569
10570 2004-04-04  Benjamin Otte  <otte@gnome.org>
10571
10572         * gst/schedulers/entryscheduler.c: (_can_schedule_get),
10573         (can_schedule_pad), (can_schedule), (schedule), (schedule_forward),
10574         (schedule_next_element), (print_entry):
10575           add can_schedule_pad to handle element states.
10576           add schedule_forward to select the correct entry to schedule next
10577
10578 2004-04-03  Benjamin Otte  <otte@gnome.org>
10579
10580         * gst/schedulers/entryscheduler.c: 
10581           remove unused variable, fix error inside Rb, fix compile warning in
10582           unreachable code
10583
10584 2004-04-03  Benjamin Otte  <otte@gnome.org>
10585
10586         * gst/schedulers/entryscheduler.c:
10587           completely revamp the inner workings, so it's a lot easier to
10588           understand and extend
10589
10590 2004-04-03  Andy Wingo  <wingo@pobox.com>
10591
10592         * gst/schedulers/gstoptimalscheduler.c (GstOptSchedulerGroupLink):
10593         Rename ->group1 and ->group2 to ->src and ->sink, respectively.
10594         This allows better introspection of pipeline topology.
10595         (add_to_chain): Don't do trickery to put loop elements first;
10596         rather, queue a chain sort by marking the chain as dirty.
10597         (remove_from_chain): Mark the chain dirty.
10598         (sort_chain): New function. Sorts the group list so that terminal
10599         sinks are first. This means elements on the sink side will be
10600         preferentially sscheduled before elements on the src side of the
10601         pipeline.
10602         (chain_recursively_migrate_group): Use OTHER_GROUP_LINK.
10603         (schedule_chain): If the chain is marked DIRTY, call sort_chain.
10604         (gst_opt_scheduler_pad_link, gst_opt_scheduler_pad_unlink)
10605         (group_inc_link): Change argument and variable names to match the
10606         new link structure member names (src and sink).
10607         (group_dec_link): Add some description
10608
10609 2004-04-03  Benjamin Otte  <otte@gnome.org>
10610
10611         * gst/autoplug/gstspider.c: (gst_spider_identity_plug):
10612         * gst/gstinfo.h:
10613         * testsuite/debug/category.c: (main):
10614         * testsuite/debug/commandline.c: (main):
10615         * testsuite/debug/output.c: (main):
10616         * testsuite/debug/printf_extension.c: (main):
10617           fix to successfully build and test with --disable-gst-debug
10618           configure switch (fixes #138705)
10619
10620 2004-04-03  Benjamin Otte  <otte@gnome.org>
10621
10622         * docs/pwg/building-boiler.xml:
10623           add cvs login line and s/anonymous/anoncvs/
10624
10625 2004-04-03  Tim-Phillip Müller  <t.i.m@zen.co.uk>
10626
10627         reviewed by Benjamin Otte  <otte@gnome.org>
10628
10629         * gst/gststructure.c: (gst_structure_free):
10630           memleak fix: free fields array (partial fix for #134839)
10631
10632 2004-04-01  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10633
10634         * docs/random/ds/0.9-suggested-changes:
10635           Add a note to change handoff use in fakesrc to be usable in
10636           a more generic way (fakesrc should be renamed to appsrc or so).
10637         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
10638           Change signal type to scope, so we can fill the buffer in the
10639           handoff handler (that's the whole use of this signal...).
10640
10641 2004-04-01  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10642
10643         * docs/pwg/other-ntoone.xml:
10644           Document muxers and n-to-1 elements.
10645
10646 2004-04-01  Martin Soto  <martinsoto@users.sourceforge.net>
10647
10648         * gst/registries/gstxmlregistry.c
10649         (gst_xml_registry_rebuild_recurse): Fix the algorithm to
10650         determine if a file is a G_MODULE. The old one discards paths
10651         containing "so" somewhere in the middle. My home directory is
10652         called "soto". Go figure...
10653
10654 2004-03-31  David Schleef  <ds@schleef.org>
10655
10656         * gst/gstbuffer.c: (gst_buffer_join):  Add function gst_buffer_join()
10657         to eventually deprecate gst_buffer_merge().  (bug: #136408)
10658         * gst/gstbuffer.h:
10659
10660 2004-03-31  David Schleef  <ds@schleef.org>
10661
10662         * gst/gstvalue.c: (gst_value_union_int_int_range),
10663         (gst_value_union_int_range_int_range), (gst_value_can_union),
10664         (gst_value_union), (_gst_value_initialize):  Add some union
10665         implementations.  We didn't have any previously.
10666         * testsuite/caps/Makefile.am:
10667         * testsuite/caps/audioscale.c: (gst_audioscale_expand_value),
10668         (gst_audioscale_getcaps), (test_caps), (main): A little test
10669         that is the same as the caps manipulation in audioscale.
10670
10671 2004-03-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10672
10673         * docs/faq/general.xml:
10674           add entry about "does gst support format X?"
10675
10676 2004-03-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10677
10678         * gst/gstthread.c:
10679           fix docs
10680         * gst/gstutils.h:
10681           fix GST_BOILERPLATE_FULL to not throw casting errors on C++
10682
10683 2004-03-30  Benjamin Otte  <otte@gnome.org>
10684
10685         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
10686           set the offset of the buffer to the requested offset
10687         * gst/elements/gsttypefind.c: (stop_typefinding):
10688           revert patch 1.18 (which I unfortunately don't know the reason for).
10689           This is needed to allow downstream elements to seek. Otherwise
10690           typefind might overwrite a previous seek by downstream elements.
10691           This lead to errors with id3tag and typefind on some mp3s.
10692         * gst/schedulers/entryscheduler.c: (COTHREADS_TYPE),
10693         (gst_entry_scheduler_iterate):
10694           be more verbose when debugging
10695
10696 2004-03-30  Thomas Vander Stichele  <thomas at apestaart dot org>
10697
10698         * gst/gstcaps.c: (gst_caps_from_string_inplace):
10699           make sure we don't get NULL strings
10700
10701 2004-03-30  Thomas Vander Stichele  <thomas at apestaart dot org>
10702
10703         * gst/gstcaps.c:
10704         * gst/gstelement.c:
10705         * gst/gstelementfactory.c: (gst_element_factory_get_type):
10706         * gst/gstindex.c: (gst_index_resolver_get_type),
10707         (gst_index_get_type), (gst_index_factory_get_type):
10708         * gst/gstinfo.c:
10709         * gst/gstpad.c:
10710         * gst/gstplugin.c:
10711         * gst/gsturi.c: (gst_uri_handler_get_type):
10712         * gst/gstvalue.c:
10713           first batch of documentation fixes
10714
10715 2004-03-29  David Schleef  <ds@schleef.org>
10716
10717         * docs/gst/Makefile.am:  Disable a bunch of headers from being scanned
10718         * docs/gst/gstreamer-docs.sgml:  More hacking
10719         * docs/gst/gstreamer-sections.txt:
10720         * docs/gst/tmpl/cothreads_compat.sgml:
10721         * docs/gst/tmpl/gstcaps.sgml:
10722         * docs/gst/tmpl/gstclock.sgml:
10723         * docs/gst/tmpl/gstelement.sgml:
10724         * docs/gst/tmpl/gstevent.sgml:
10725         * docs/gst/tmpl/gstpad.sgml:
10726         * docs/gst/tmpl/gstutils.sgml:
10727         * docs/gst/tmpl/gstxml.sgml:
10728         * docs/gst/tmpl/gthread-cothreads.sgml:
10729         * docs/random/ds/0.9-suggested-changes:
10730         * gst/elements/gstfakesink.h: doc fixes
10731         * gst/elements/gstfakesrc.h: doc fixes
10732         * gst/gstcaps.c: doc fixes
10733         * gst/gstcaps.h: doc fixes
10734         * gst/gstelement.c: doc fixes
10735         * gst/gstelement.h: doc fixes
10736         * gst/gstindex.c: doc fixes
10737         * gst/gstinfo.c: doc fixes
10738         * gst/gstpad.c: doc fixes
10739         * gst/gstpad.h: doc fixes
10740         * gst/gstplugin.c: doc fixes
10741         * gst/gsttypefind.h: doc fixes
10742         * gst/gsturi.c: doc fixes
10743         * gst/gstvalue.c: doc fixes
10744
10745 2004-03-29  Colin Walters  <walters@redhat.com>
10746
10747         * gst/registries/gstxmlregistry.c (get_time)
10748         (plugin_times_older_than_recurse):
10749         Use the result of stat to determine whether a path is a file,
10750         so we don't attempt to opendir() files.
10751
10752 2004-03-29  Benjamin Otte  <otte@gnome.org>
10753
10754         * gst/gstpad.c: (gst_pad_set_explicit_caps):
10755           print caps in debugging output when setting caps failed
10756         * gst/schedulers/entryscheduler.c: (COTHREADS_TYPE),
10757         (schedule_next_element), (get_buffer), (run_chainhandler),
10758         (element_may_start), (gst_entry_scheduler_chain_handler),
10759         (gst_entry_scheduler_get_handler),
10760         (gst_entry_scheduler_state_transition),
10761         (gst_entry_scheduler_pad_link):
10762           make this scheduler a testcase for mandatory
10763           discont-before-first-buffer which is needed if we want to allow apps
10764           to release the sound device.
10765           add SCHED_ASSERT macro to print scheduler state before an assertion
10766           triggers.
10767
10768 2004-03-29  Benjamin Otte  <otte@gnome.org>
10769
10770         * COPYING:
10771           replace by LGPL (former COPYING.LIB). The core is completely
10772           licensed LGPL.
10773         * COPYING.LIB:
10774           remove
10775
10776 2004-03-29  Thomas Vander Stichele  <thomas at apestaart dot org>
10777
10778         * po/af.po:
10779         * po/sv.po:
10780           updated Afrikaans and Swedish
10781
10782 2004-03-29  Thomas Vander Stichele  <thomas at apestaart dot org>
10783
10784         * po/LINGUAS:
10785         * po/az.po:
10786           adding Azerbaijani (Mətin Əmirov)
10787
10788 2004-03-28  Martin Soto  <martinsoto@users.sourceforge.net>
10789
10790         * gst/gstelement.h: 
10791         * gst/gstelement.c (gst_element_set_time_delay): New function for
10792         setting element time taking into account a hardware buffering
10793         delay.
10794         (gst_element_set_time): Now just an invocation of
10795         gst_element_set_time_delay.
10796         * gst/gstclock.h: 
10797         * gst/gstclock.c (gst_clock_get_event_time_delay): New function
10798         allowing to set event times in the future.
10799         (gst_clock_get_event_time): Now just an invocation of
10800         gst_clock_get_event_time_delay.
10801
10802 2004-03-28  Benjamin Otte  <otte@gnome.org>
10803
10804         * gst/gstbin.c: (gst_bin_set_element_sched),
10805         (gst_bin_unset_element_sched):
10806           don't add decoupled elements to schedulers - otherwise it's
10807           impossible to control if a link to a decoupled element was already
10808           removed from a scheduler or not.
10809         * gst/schedulers/cothreads_compat.h:
10810         * gst/schedulers/gthread-cothreads.h:
10811           add COTHREADS_TYPE macro. Make do_cothread_set_func a macro so there
10812           is no "unused" warning.
10813         * gst/schedulers/Makefile.am:
10814         * gst/schedulers/entryscheduler.c:
10815           add new scheduler, based on ideas from talking to David and Martin.
10816           It's supposed to be small and correct. Currently it's also slow (but
10817           it's not noticable)
10818         * examples/retag/retag.c: (main):
10819         * testsuite/bytestream/test1.c: (main):
10820           fix missing NULLs at end of variadic functions
10821         * testsuite/elements/.cvsignore:
10822           update
10823
10824 2004-03-28  Jan Schmidt  <thaytan@mad.scientist.com>
10825
10826         * gst/gstevent.h:
10827         Added GST_EVENT_ANY for GstEvents that pass a GstStructure
10828
10829 2004-03-25  David Schleef  <ds@schleef.org>
10830
10831         * docs/gst/gstreamer-sections.txt:  More doc hacking.
10832         * docs/gst/tmpl/gstaggregator.sgml:
10833         * docs/gst/tmpl/gstautoplugfactory.sgml:
10834         * docs/gst/tmpl/gstbin.sgml:
10835         * docs/gst/tmpl/gstbuffer.sgml:
10836         * docs/gst/tmpl/gstbufferstore.sgml:
10837         * docs/gst/tmpl/gstfakesink.sgml:
10838         * docs/gst/tmpl/gstfakesrc.sgml:
10839         * docs/gst/tmpl/gstmd5sink.sgml:
10840         * docs/gst/tmpl/gstreamer-unused.sgml:
10841         * docs/gst/tmpl/gstsearchfuncs.sgml:
10842         * docs/gst/tmpl/gstshaper.sgml:
10843         * docs/gst/tmpl/gstspider.sgml:
10844         * docs/gst/tmpl/gsttee.sgml:
10845         * docs/gst/tmpl/gstutils.sgml:
10846         * docs/gst/tmpl/gstvalue.sgml:
10847         * docs/gst/tmpl/gstxml.sgml:
10848         * gst/Makefile.am:  Remove gstthreaddummy.c.  It never worked,
10849         and we don't support it.
10850         * gst/gst.c: (gst_init_get_popt_table), (init_pre), (init_post),
10851         (gst_use_threads), (gst_has_threads): same
10852         * gst/gstthreaddummy.c: same
10853         * gst/autoplug/gstspider.c: Make gst_spider_details static.
10854         * gst/autoplug/gstspider.h: same
10855         * gst/elements/gstaggregator.h: Remove bogus function from header
10856         * gst/elements/gstfakesink.h: same
10857         * gst/elements/gstfakesrc.h: same
10858         * gst/elements/gstmd5sink.h: same
10859         * gst/elements/gstshaper.h: same
10860         * gst/elements/gsttee.h: same
10861         * gst/gstbin.c: doc fixes
10862         * gst/gstbin.h: Remove unused definition.
10863         * gst/gstbuffer.c: doc fixes
10864         * gst/gstcaps.c: (gst_caps_is_always_compatible): doc fixes
10865         * gst/gstfilter.c: doc fixes
10866         * gst/gsttag.c: doc fixes
10867         * gst/gstvalue.c: doc fixes
10868
10869 2004-03-25  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10870
10871         * docs/pwg/advanced-types.xml:
10872           Document typefinding.
10873         * docs/pwg/other-oneton.xml:
10874           Document one-to-n elements, demuxers and parsers.
10875
10876 2004-03-25  Tim-Philipp Müller <t.i.m@zen.co.uk>
10877
10878         reviewed by: David Schleef  <ds@schleef.org>
10879
10880         * configure.ac: Check bison version (bug #127838)
10881
10882 2004-03-25  David Schleef  <ds@schleef.org>
10883
10884         * docs/gst/gstreamer-docs.sgml: More fine tuning.
10885         * docs/gst/gstreamer-sections.txt:
10886         * docs/gst/tmpl/gstautoplug.sgml:
10887         * docs/gst/tmpl/gststaticautoplug.sgml:
10888         * docs/gst/tmpl/gststaticautoplugrender.sgml:
10889         * docs/gst/tmpl/gstutils.sgml:
10890         * docs/gst/tmpl/gstxml.sgml:
10891
10892 2004-03-24  David Schleef  <ds@schleef.org>
10893
10894         * docs/gst/gstreamer-docs.sgml:  I got tired of the reference
10895         manual being such complete crap, that I decided to do major
10896         hacking of it.  This checkin replaces any fine tuning that
10897         may have been done previously, with the benefit of actually
10898         being complete for much of the API that was changed since
10899         0.6.  Further fine tuning will occur shortly.  (bug #134721)
10900         * docs/gst/gstreamer-sections.txt:
10901         * docs/gst/tmpl/GstBin.sgml:
10902         * docs/gst/tmpl/GstBuffer.sgml:
10903         * docs/gst/tmpl/GstCaps.sgml:
10904         * docs/gst/tmpl/GstClock.sgml:
10905         * docs/gst/tmpl/GstCompat.sgml:
10906         * docs/gst/tmpl/GstData.sgml:
10907         * docs/gst/tmpl/GstElement.sgml:
10908         * docs/gst/tmpl/GstEvent.sgml:
10909         * docs/gst/tmpl/GstIndex.sgml:
10910         * docs/gst/tmpl/GstStructure.sgml:
10911         * docs/gst/tmpl/GstTag.sgml:
10912         * docs/gst/tmpl/cothreads.sgml:
10913         * docs/gst/tmpl/cothreads_compat.sgml:
10914         * docs/gst/tmpl/gettext.sgml:
10915         * docs/gst/tmpl/grammar.tab.sgml:
10916         * docs/gst/tmpl/gst-i18n-app.sgml:
10917         * docs/gst/tmpl/gst-i18n-lib.sgml:
10918         * docs/gst/tmpl/gst.sgml:
10919         * docs/gst/tmpl/gst_private.sgml:
10920         * docs/gst/tmpl/gstaggregator.sgml:
10921         * docs/gst/tmpl/gstarch.sgml:
10922         * docs/gst/tmpl/gstatomic.sgml:
10923         * docs/gst/tmpl/gstatomic_impl.sgml:
10924         * docs/gst/tmpl/gstbin.sgml:
10925         * docs/gst/tmpl/gstbuffer.sgml:
10926         * docs/gst/tmpl/gstbufferstore.sgml:
10927         * docs/gst/tmpl/gstcaps.sgml:
10928         * docs/gst/tmpl/gstclock.sgml:
10929         * docs/gst/tmpl/gstcompat.sgml:
10930         * docs/gst/tmpl/gstconfig.sgml:
10931         * docs/gst/tmpl/gstcpu.sgml:
10932         * docs/gst/tmpl/gstdata.sgml:
10933         * docs/gst/tmpl/gstdata_private.sgml:
10934         * docs/gst/tmpl/gstelement.sgml:
10935         * docs/gst/tmpl/gstenumtypes.sgml:
10936         * docs/gst/tmpl/gsterror.sgml:
10937         * docs/gst/tmpl/gstevent.sgml:
10938         * docs/gst/tmpl/gstfakesink.sgml:
10939         * docs/gst/tmpl/gstfakesrc.sgml:
10940         * docs/gst/tmpl/gstfilesink.sgml:
10941         * docs/gst/tmpl/gstfilter.sgml:
10942         * docs/gst/tmpl/gstindex.sgml:
10943         * docs/gst/tmpl/gstinfo.sgml:
10944         * docs/gst/tmpl/gstinterface.sgml:
10945         * docs/gst/tmpl/gstlog.sgml:
10946         * docs/gst/tmpl/gstmacros.sgml:
10947         * docs/gst/tmpl/gstmarshal.sgml:
10948         * docs/gst/tmpl/gstmd5sink.sgml:
10949         * docs/gst/tmpl/gstmultifilesrc.sgml:
10950         * docs/gst/tmpl/gstobject.sgml:
10951         * docs/gst/tmpl/gstpad.sgml:
10952         * docs/gst/tmpl/gstparse.sgml:
10953         * docs/gst/tmpl/gstpipeline.sgml:
10954         * docs/gst/tmpl/gstplugin.sgml:
10955         * docs/gst/tmpl/gstpluginfeature.sgml:
10956         * docs/gst/tmpl/gstqueue.sgml:
10957         * docs/gst/tmpl/gstreamer-unused.sgml:
10958         * docs/gst/tmpl/gstregistry.sgml:
10959         * docs/gst/tmpl/gstregistrypool.sgml:
10960         * docs/gst/tmpl/gstscheduler.sgml:
10961         * docs/gst/tmpl/gstsearchfuncs.sgml:
10962         * docs/gst/tmpl/gstshaper.sgml:
10963         * docs/gst/tmpl/gstspider.sgml:
10964         * docs/gst/tmpl/gstspideridentity.sgml:
10965         * docs/gst/tmpl/gststructure.sgml:
10966         * docs/gst/tmpl/gstsystemclock.sgml:
10967         * docs/gst/tmpl/gsttag.sgml:
10968         * docs/gst/tmpl/gsttaginterface.sgml:
10969         * docs/gst/tmpl/gsttee.sgml:
10970         * docs/gst/tmpl/gstthread.sgml:
10971         * docs/gst/tmpl/gsttrace.sgml:
10972         * docs/gst/tmpl/gsttrashstack.sgml:
10973         * docs/gst/tmpl/gsttypefind.sgml:
10974         * docs/gst/tmpl/gsttypes.sgml:
10975         * docs/gst/tmpl/gsturi.sgml:
10976         * docs/gst/tmpl/gsturitype.sgml:
10977         * docs/gst/tmpl/gstutils.sgml:
10978         * docs/gst/tmpl/gstvalue.sgml:
10979         * docs/gst/tmpl/gstversion.sgml:
10980         * docs/gst/tmpl/gstxml.sgml:
10981         * docs/gst/tmpl/gstxmlregistry.sgml:
10982         * docs/gst/tmpl/gthread-cothreads.sgml:
10983         * docs/gst/tmpl/types.sgml:
10984
10985 2004-03-24  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10986
10987         * docs/pwg/other-sink.xml:
10988         * docs/pwg/other-source.xml:
10989           Documentation on how to write source and sink elements. Other
10990           stuff in chapter 4 (1-to-n/demuxer, n-to-1/muxer, n-to-n,
10991           manager, autoplugger) are all still pending.
10992
10993 2004-03-25  Benjamin Otte  <otte@gnome.org>
10994
10995         * testsuite/elements/Makefile.am:
10996         * testsuite/elements/gst-compprep-check:
10997           add check to make sure gst-compprep works
10998         * testsuite/elements/gst-inspect-check.in:
10999           improve initialization output
11000         * testsuite/Makefile.am:
11001         * testsuite/gst-inspect-check:
11002           remove old file
11003
11004 2004-03-24  David Schleef  <ds@schleef.org>
11005
11006         * testsuite/elements/Makefile.am:
11007         * testsuite/elements/gst-inspect-check.in: Add gst-inspect-check
11008         to the testsuite.
11009
11010 2004-03-24  Benjamin Otte  <otte@gnome.org>
11011
11012         * libs/gst/control/dparam.c: (gst_dparam_attach),
11013         (gst_dparam_detach):
11014         * libs/gst/control/dparammanager.c: (gst_dpman_init):
11015           fix lvalue casts for real
11016
11017 2004-03-24  Benjamin Otte  <otte@gnome.org>
11018
11019         * gst/schedulers/gstbasicscheduler.c:
11020         (gst_basic_scheduler_src_wrapper):
11021         * gst/schedulers/gstoptimalscheduler.c:
11022         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
11023         (pad_clear_queued), (gst_opt_scheduler_add_element),
11024         (gst_opt_scheduler_remove_element):
11025           fix GStreamer to not have issues with lvalue casts anymore (fixes
11026           #136841)
11027
11028 2004-03-24  Benjamin Otte  <otte@gnome.org>
11029
11030         * gst/gstelement.c:
11031           add documentation about a gobject quirk where the object hasn't the
11032           correct class pointer set on initialization
11033         * gst/schedulers/gstbasicscheduler.c:
11034         (gst_basic_scheduler_src_wrapper):
11035           make sure to not run into an infinite loop
11036
11037 2004-03-22  Benjamin Otte  <otte@gnome.org>
11038
11039         * gst/gstutils.c: (gst_util_dump_mem):
11040         * gst/gstutils.h:
11041           first argument of gst_util_dump_mem should be const
11042
11043 2004-03-22  Johan Dahlin  <johan@gnome.org>
11044
11045         * gst/gstvalue.h: Clean up a little bit.
11046
11047 2004-03-21  Tim-Philipp Müller <t.i.m@zen.co.uk>
11048
11049         reviewed by Benjamin Otte  <otte@gnome.org>
11050
11051         * gst/autoplug/gstspider.c: (gst_spider_dispose):
11052         * gst/elements/gstaggregator.c: (gst_aggregator_finalize),
11053         (gst_aggregator_class_init), (gst_aggregator_init):
11054         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
11055         (gst_filesrc_dispose), (gst_filesrc_set_location):
11056         * gst/elements/gstidentity.c: (gst_identity_finalize),
11057         (gst_identity_class_init), (gst_identity_chain):
11058         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_open_file):
11059         * gst/elements/gststatistics.c: (gst_statistics_finalize),
11060         (gst_statistics_class_init):
11061         * gst/elements/gsttee.c: (gst_tee_finalize), (gst_tee_class_init),
11062         (gst_tee_get_property):
11063           clean up used memory in this elements correctly on teardown (closes
11064           #137279)
11065
11066 2004-03-20  Colin Walters  <walters@redhat.com>
11067
11068         * gst/registries/gstxmlregistry.c:
11069         (gst_xml_registry_open_func, gst_xml_registry_close_func): Make
11070         registry saving atomic.
11071
11072 2004-03-20  Colin Walters  <walters@redhat.com>
11073
11074         * gst/registries/gstxmlregistry.c (gst_xml_registry_get_perms_func):
11075         Just use
11076         access() instead of actually creating and deleting files.
11077
11078 2004-03-18  David Schleef  <ds@schleef.org>
11079
11080         * configure.ac:  Remove HAVE_ATOMIC_H test, since it's unused.
11081         (bug #137625)
11082
11083 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
11084
11085         * po/sv.po: updated translation (Christian Rose)
11086
11087 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
11088
11089         * gst/elements/gstfilesink.c: (gst_filesink_get_formats),
11090         (gst_filesink_get_query_types), (_do_init),
11091         (gst_filesink_handle_event), (gst_filesink_uri_get_protocols):
11092           return FALSE silently
11093         * po/af.po: updated translation (Petri Jooste)
11094
11095 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
11096
11097         * Makefile.am:
11098         * configure.ac:
11099           dist common properly
11100         * po/af.po:
11101         * po/fr.po:
11102         * po/nl.po:
11103         * po/sr.po:
11104         * po/sv.po:
11105           refreshing translations
11106
11107 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
11108
11109         * po/LINGUAS:
11110         * po/sv.po:
11111         * po/af.po:
11112           adding Swedish (Christian Rose) and Afrikaans (Petri Jooste)
11113
11114 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
11115
11116         * Makefile.am: use common/release.mak
11117
11118 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
11119
11120         * docs/faq/gst-uninstalled:
11121           adding gst-monkeysaudio to the list of possible plugin dirs
11122
11123 2004-03-16  David Schleef  <ds@schleef.org>
11124
11125         * gst/gst.c: (gst_get_popt_options), (gst_init_get_popt_table),
11126         (gst_init_check_with_popt_table):  Fix some gettext strings to
11127         make them easier to translate.  Required making the strings
11128         non-const.
11129
11130 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
11131
11132         * configure.ac: bump nano to 1
11133
11134 === release 0.8.0 ===
11135
11136 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
11137
11138         * configure.ac: release 0.8.0, "Executive Slacks"
11139
11140 2004-03-16  Johan Dahlin  <johan@gnome.org>
11141
11142         * gst/schedulers/gstoptimalscheduler.c
11143         (gst_opt_scheduler_pad_unlink): Remove double ;,
11144         spotted by Scott Wheeler
11145
11146 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
11147
11148         * configure.ac: bump libtool version
11149
11150 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
11151
11152         * gst/gstcaps.h:
11153         * gst/gststructure.h:
11154           add reserved padding
11155
11156 2004-03-15  Benjamin Otte  <otte@gnome.org>
11157
11158         * gst/elements/gstfdsrc.c: (gst_fdsrc_get):
11159           set the first parameter for select call correctly.
11160           (fixes #137230)
11161
11162 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
11163
11164         * *.c,*.h: don't mix tabs and spaces
11165
11166 2004-03-15  Johan Dahlin  <johan@gnome.org>
11167
11168         * gst/schedulers/gstoptimalscheduler.c
11169         (gst_opt_scheduler_pad_unlink): Fix bug that causes totem to
11170         crash on MPEG playback. My boolean arithmetic is a bit rusty.
11171
11172         * tools/Makefile.am (EXTRA_DIST): Add gst-indent
11173         
11174 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
11175
11176         * testsuite/Rules:
11177           fix gst-register rules
11178
11179 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
11180
11181         * testsuite/Rules:
11182           use versioned gst-register
11183
11184 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
11185
11186         * docs/libs/gstreamer-libs-sections.txt:
11187           remove </SUBSECTION>
11188         * gst/gstplugin.c:
11189         * gst/gstregistry.c: (gst_registry_add_plugin):
11190         * gst/registries/gstxmlregistry.c: (gst_xml_registry_get_type),
11191         (gst_xml_registry_open_func), (gst_xml_registry_close_func):
11192           add debugging and fix some comment blocks
11193
11194 2004-03-15  Johan Dahlin  <johan@gnome.org>
11195
11196         * *.h: Revert indent changes.
11197         
11198 2004-03-14  Thomas Vander Stichele  <thomas at apestaart dot org>
11199
11200         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load_plugin):
11201           g_error_free the g_error
11202         * tools/gst-feedback-m.m:
11203           check for other versions of gstreamer
11204         * tools/gst-indent:
11205           use sh, not bash
11206
11207 2004-03-14  Thomas Vander Stichele  <thomas at apestaart dot org>
11208
11209         * tools/gst-register.c: do not spill paths when registries are not
11210           writable, until we fix the "user running gst-register" case.
11211
11212 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11213
11214         * *.c, *.h: commit of gst-indent run on core
11215
11216 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11217
11218         * tools/gst-indent:
11219         * tools/Makefile.am:
11220           add our indentation style as a script
11221
11222 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11223
11224         * po/sr.po:
11225         * po/LINGUAS:
11226           added Serbian translation
11227
11228 2004-03-13  Benjamin Otte  <otte@gnome.org>
11229
11230         * gst/gstelement.c:
11231           add documentation note about gst_element_found_tags_for_pad not
11232           being usable in getfunctions. (see #137042)
11233
11234 2004-03-12  David Schleef  <ds@schleef.org>
11235
11236         * gst/gstcaps.h: jdahlin, what are you smoking?  We can't just
11237         change API right now!  Readd gst_caps_is_simple() macro.
11238         * gst/gstelement.c: (gst_element_base_class_finalize): Fix
11239         uninitialized variable.  I'd bet this caused crashes.
11240         * gst/gstinfo.c: (gst_debug_print_object):  Fix 64-bit cleanliness.
11241
11242 2004-03-12  Johan Dahlin  <johan@gnome.org>
11243
11244         * gst/gstcaps.h (GST_CAPS_IS_SIMPLE): Capitalize macro
11245         * gst/gstcaps.h: Clean up
11246
11247         * gst/gst.c (init_post): call gst_caps_get_type() instead of
11248         _gst_caps_initalize()
11249
11250         * gst/gstcaps.c: Style fixes, stay closer to glib and friends
11251         (_gst_caps_initialize): Remove, in favor for gst_caps_get_type()
11252
11253         * gst/gststructure.c (gst_structure_get_type): Ditto
11254
11255         * gst/gststructure.h: Ditto
11256         
11257 2004-03-11  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11258
11259         * gst/gstqueue.c: (gst_queue_init):
11260           Reset default max. values in queues. Reason is simply to avoid
11261           braindead use. If you want wider values, use the properties. The
11262           default is supposed to always work. Wider values would make this
11263           beast a memory hog by default (250 full-PAL RGB32 video frames?
11264           That's 440 MB! No thank you).
11265
11266 2004-03-10  David Schleef  <ds@schleef.org>
11267
11268         * tools/gst-run.c: (main):  Fix crash when no relevant tools
11269         were found.  (bug #136793)
11270
11271 2004-03-10  Johan Dahlin  <johan@gnome.org>
11272
11273         * gst/schedulers/gstoptimalscheduler.c
11274         (gst_opt_scheduler_pad_unlink): Implement unlink for elements with
11275         links to elements within the same group, so we can finally remove
11276         that annoying warning. Refactor the code a little bit
11277         (group_dec_links_for_element): Split out
11278
11279 2004-03-09  David Schleef  <ds@schleef.org>
11280
11281         * docs/manual/dparams-app.xml:  Fix to handle double dparams.
11282         (bug #134863)
11283
11284 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
11285
11286         * configure.ac: first bug fix due to major/minor bump
11287
11288 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
11289
11290         * configure.ac: bump nano to 1
11291
11292 === release 0.7.6 ===
11293
11294 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
11295
11296         * NEWS:
11297         * RELEASE:
11298         * configure.ac:
11299           releasing 0.7.6, "Almost"
11300         * po/fr.po:
11301         * po/nl.po:
11302         * tools/Makefile.am:
11303         * tools/gst-feedback-m.m:
11304           unversioned source
11305
11306 2004-03-09  Johan Dahlin  <johan@gnome.org>
11307
11308         Reviewed by: Thomas Vander Stichele
11309
11310         * gst/gstelement.c (gst_element_class_init): register second
11311         parameter as GST_TYPE_G_ERROR instead of G_TYPE_POINTER, so
11312         language bindings can (de)marshall correctly.
11313
11314         * gst/gsterror.h: Add GST_TYPE_G_ERROR and cleanup a little bit
11315
11316         * gst/gsterror.c (gst_g_error_get_type): New function
11317
11318         * gst/gstmarshal.list: Remove VOID:OBJECT,POINTER,STRING, replace
11319         with VOID:OBJECT,OBJECT,STRING 
11320
11321 2004-03-10  Jan Schmidt  <thaytan@mad.scientist.com>
11322
11323         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load):
11324         Free a leaked g_timer on early returns.
11325
11326 2004-03-08  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11327
11328         * docs/pwg/advanced-types.xml:
11329           Add cinepak description.
11330
11331 2004-03-07  David Schleef  <ds@schleef.org>
11332
11333         * docs/random/mimetypes:  Added cinepak description
11334
11335 2004-03-07  Andy Wingo  <wingo@pobox.com>
11336
11337         * gst/gstbin.c (gst_bin_remove): Debugging fixes.
11338
11339         * gst/schedulers/gstoptimalscheduler.c (destroy_group): Assert
11340         there are no links to other groups when a group is destroyed.
11341         (gst_opt_scheduler_pad_unlink): If the unlink means an element is
11342         removed from a group, make sure the link count to elements linked
11343         to other pads is appropriately decremented. This really fixes
11344         #135672.
11345
11346         The 1.60->1.61 patch has been reapplied in light of this fix.
11347
11348         * gst/gstelement.c (gst_element_dispose): Really protect against
11349         multiple invocations this time.
11350
11351 2004-03-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11352
11353         * docs/gst/gstreamer-sections.txt:
11354         * docs/gst/tmpl/gsttag.sgml:
11355           remove some deprecated functions, document some existing ones
11356         * gst/gsttag.c: (gst_tag_get_flag):
11357         * gst/gsttag.h:
11358           add accessor function
11359
11360 2004-03-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11361
11362         * docs/gst/gstreamer-sections.txt:
11363         * docs/gst/tmpl/gsttag.sgml:
11364         * docs/gst/tmpl/gstxml.sgml:
11365         * gst/gsttag.c: (gst_tag_get_flag):
11366         * gst/gsttag.h:
11367
11368 2004-03-06  Christophe Fergeau  <teuf@gnome.org>
11369
11370         * gst/autoplug/gstspider.c: (gst_spider_identity_plug): fixed caps
11371         leak
11372
11373 2004-03-05  David Schleef  <ds@schleef.org>
11374
11375         * REQUIREMENTS: Add bison and flex.
11376         * configure.ac: Fix comment about bison.
11377         * docs/random/ds/0.9-suggested-changes: yer ma
11378         * tools/gst-inspect.c: (print_element_info):  Fix warning.
11379
11380 2004-03-05  Benjamin Otte  <otte@gnome.org>
11381
11382         * gst/gstelement.c: (gst_element_error_full):
11383           revert recent recursive state changing commit - messing with other
11384           elements' states is evil and should be done by apps only.
11385
11386 2004-03-05  Benjamin Otte  <otte@gnome.org>
11387
11388         * gst/gstelement.c: (gst_element_get_compatible_pad_template):
11389           check for empty intersection instead of NULL caps
11390         (gst_element_get_compatible_pad_filtered):
11391           remove old workaround that is only a bug nowadays
11392
11393 2004-03-05  Thomas Vander Stichele  <thomas at apestaart dot org>
11394
11395         * gst/gstelement.c: (gst_element_error_full):
11396           make elements try to recursively change state to PAUSED on all
11397           parents after an error to suppress ensuing warnings
11398         * gst/parse/grammar.y:
11399           make it check if it was able to sync the state, and throw an error
11400           if not, so stuff like
11401           oggdemux ! vorbisdec ! osssink gets caught
11402
11403 2004-03-05  Thomas Vander Stichele  <thomas at apestaart dot org>
11404
11405         * configure.ac: use ${libdir} for PLUGINS_DIR since on 64bit
11406           it contains lib64; use AS_AC_EXPAND to handle it properly
11407
11408 2004-03-05  David Schleef  <ds@schleef.org>
11409
11410         * gst/gstcpuid_i386.s:  Remove unused code
11411         * libs/gst/getbits/getbits.c: (gst_getbits_init),
11412         (gst_getbits_newbuf): Remove MMX code
11413         * libs/gst/getbits/getbits.h: Remove MMX code
11414
11415 2004-03-04  David I. Lehn  <dlehn@users.sourceforge.net>
11416
11417         * debian/.cvsignore:
11418         * debian/README.Debian:
11419         * debian/changelog:
11420         * debian/control:
11421         * debian/control.in:
11422         * debian/copyright:
11423         * debian/gstreamer-core-libs-dev.files:
11424         * debian/gstreamer-core-libs.files:
11425         * debian/gstreamer-core.files:
11426         * debian/gstreamer-core.postinst:
11427         * debian/gstreamer-core.postrm:
11428         * debian/gstreamer-doc.files:
11429         * debian/gstreamer-doc.links:
11430         * debian/gstreamer-doc.lintian:
11431         * debian/gstreamer-runtime.files:
11432         * debian/gstreamer-runtime.manpages:
11433         * debian/gstreamer-runtime.postinst:
11434         * debian/gstreamer-runtime.postrm:
11435         * debian/gstreamer-tools.files:
11436         * debian/gstreamer-tools.manpages:
11437         * debian/libgstreamer-dev.files:
11438         * debian/libgstreamer0.4.1.files:
11439         * debian/libgstreamerVERSION.files:
11440         * debian/rules:
11441         Debian package info not maintained here.
11442
11443 2004-03-04  Thomas Vander Stichele  <thomas at apestaart dot org>
11444
11445         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
11446         * gst/gstbin.c: (gst_bin_class_init):
11447         * gst/gstelement.c: (gst_element_class_init):
11448         * gst/gstindex.c: (gst_index_class_init):
11449         * gst/gstobject.c: (gst_object_class_init),
11450         (gst_signal_object_class_init):
11451         * gst/gstpad.c: (gst_pad_template_class_init):
11452         * gst/gstregistry.c: (gst_registry_class_init):
11453         * gst/gsturi.c: (gst_uri_handler_base_init):
11454         * gst/gstxml.c: (gst_xml_class_init):
11455         * libs/gst/control/dparam.c: (gst_dparam_class_init):
11456         * libs/gst/control/dparammanager.c: (gst_dpman_class_init):
11457           make all signal names use dashes instead of underscore
11458
11459 2004-03-03  Thomas Vander Stichele  <thomas at apestaart dot org>
11460
11461         * configure.ac: AC_SUBST GLIB_ONLY CFLAGS and LIBS
11462
11463 2004-03-03  Benjamin Otte  <otte@gnome.org>
11464
11465         * gst/schedulers/gstoptimalscheduler.c:
11466           revert last commit by Andy Wingo. It causes segfaults on unreffing
11467           in Rhythmbox. (see bug #135672)
11468
11469 2004-03-02  Christophe Fergeau  <teuf@gnome.org>
11470
11471         * po/fr.po: fix typo
11472
11473 2004-03-02  Christophe Fergeau  <teuf@gnome.org>
11474
11475         * tools/gst-inspect.c: (main): 
11476         * tools/gst-launch.c: (main): add calls to bind_textdomain_codeset
11477
11478 2004-03-02  Thomas Vander Stichele  <thomas at apestaart dot org>
11479
11480         * configure.ac:
11481           get GLIB_ONLY and POPT flags for the nonversioned binaries
11482         * tools/Makefile.am:
11483           use them
11484
11485 2004-03-02  Thomas Vander Stichele  <thomas at apestaart dot org>
11486
11487         * gst/gst.c: (init_post):
11488           change so that GST_REGISTRY now is where the global registry gets
11489           saved, since that is where plugins now get attached to first, and
11490           spilled over to the user registry.  Note that in the case of using
11491           GST_REGISTRY env var, we don't want to affect any real registries
11492           beyond the one given by this var, and thus we don't set a user
11493           registry to spill to.  So make sure GST_REGISTRY is writable.
11494
11495 2004-03-01  David Schleef  <ds@schleef.org>
11496
11497         * AUTHORS:  Added some names.  Add yourself if you're missing.
11498
11499 2004-03-01  David Schleef  <ds@schleef.org>
11500
11501         * MAINTAINERS: Add
11502
11503 2004-03-01  Thomas Vander Stichele  <thomas at apestaart dot org>
11504
11505         * configure.ac:
11506           remove whitespace
11507         * docs/gst/tmpl/gstbuffer.sgml:
11508         * docs/gst/tmpl/gstdata.sgml:
11509         * docs/gst/tmpl/gstreamer-unused.sgml:
11510         * docs/gst/tmpl/gstxml.sgml:
11511           doc update
11512         * docs/manuals.mak:
11513           add a FIXME
11514         * docs/pwg/intro-preface.xml:
11515         * docs/pwg/pwg.xml:
11516           remove GNOME
11517         * gst/gst.c: (init_post):
11518           try GST_PLUGIN_PATH paths for the _global_registry first
11519         * gst/gstelement.h:
11520           add the error message as well, otherwise (null) debug info doesn't
11521           make much sense
11522         * tools/gst-register.c: (main):
11523           spill paths to next registry if this registry is not writable
11524         * po/fr.po:
11525         * po/nl.po:
11526           translation updates
11527
11528 2004-03-01  Johan Dahlin  <johan@gnome.org>
11529
11530         * gst/gstbuffer.c (_gst_buffer_initialize): 
11531         * gst/gstdata.c (gst_data_get_type): 
11532         * gst/gstevent.c (_gst_event_initialize): Use gst_data_copy,
11533         instead of ref, since some applications that uses GBoxed
11534         routines depends on a function that actually returns a copy.
11535
11536 2004-02-27  Benjamin Otte  <otte@gnome.org>
11537
11538         * gst/gstbuffer.h:
11539           remove gst_buffer_free, use gst_data_unref
11540         * gst/gstdata.c: (gst_data_get_type):
11541           use refcounting in GstData GBoxed registration
11542         * gst/gstdata.h:
11543           remove gst_data_free, use gst_data_unref
11544
11545 2004-02-27  Johan Dahlin  <johan@gnome.org>
11546
11547         * gst/gstdata.c (gst_data_get_type): New function, register
11548         GstData as a GBoxed type.
11549
11550         * gst/gstdata.h (GST_TYPE_DATA): New macro
11551
11552 2004-02-27  Thomas Vander Stichele  <thomas at apestaart dot org>
11553
11554         * Makefile.am:
11555         * gstreamer.spec.in:
11556           put back RELEASE
11557         * gst/Makefile.am:
11558           clean up non-disting of built files
11559         * testsuite/debug/commandline.c:
11560           test fix for option rename
11561
11562 2004-02-26  David Schleef  <ds@schleef.org>
11563
11564         * configure.ac:  We don't really need glib-2.3.  Also remove
11565         some unneeded checks for library functions.
11566         * gst/Makefile.am:  Instead, we need to not dist files created
11567         by glib-genmarshal.
11568
11569 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11570
11571         * configure.ac:
11572           bump glib required version to 2.3.0 for g_value_takes_boxed
11573
11574  2004-02-25  Christian Fredrik Kalager Schaller <uraeus@gnome.org>
11575
11576         * common/m4/gst-docs.m4
11577         change flavour text from enable to disable as enable is our default
11578         closes bug Bug 135304
11579
11580 === release 0.7.5 ===
11581  
11582  2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11583  
11584         * NEWS:
11585           instate NEWS file
11586         * Makefile.am:
11587         * gstreamer.spec.in:
11588         * RELEASE:
11589           put back release
11590         * configure.ac:
11591         * docs/random/release:
11592           more updates
11593
11594 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11595
11596         * gst/gsttag.c: (_gst_tag_initialize):
11597         * po/fr.po:
11598         * po/nl.po:
11599           remove hyphen from codec tags
11600
11601 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11602
11603         * gst/parse/Makefile.am:
11604           fix dependency so that a make from a clean build works the first
11605           time
11606
11607 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11608
11609         * docs/random/release:
11610           update release strategy
11611         * po/fr.po:
11612           auto-update po file
11613         * po/nl.po:
11614           update dutch translation
11615
11616 2004-02-25  Thomas Vander Stichele  <thomas at apestaart dot org>
11617
11618         * docs/manual/debugging.xml:
11619         fix manual for new debugging system
11620
11621 2004-02-25  Andy Wingo  <wingo@pobox.com>
11622
11623         * gst/gstpad.c (gst_pad_link_prepare): Re-add
11624         gst_pad_link_prepare. Please email the list with specific reasons
11625         for reverting.
11626
11627 2004-02-24  Andy Wingo  <wingo@pobox.com>
11628
11629         * gst/gstelement.c (gst_element_dispose): Protect against multiple
11630         invocations.
11631
11632         * gst/schedulers/gstoptimalscheduler.c:
11633         I added a mess of prototypes at the top of the file by way of
11634         documentation. Some of the operations on chains and groups were
11635         re-organized.
11636
11637         (create_group): Added a type argument so if the group is enabled,
11638         the setup_group_scheduler knows what to do.
11639         (group_elements): Added a type argument here, too, to be passed on
11640         to create_group.
11641         (group_element_set_enabled): If an unlinked PLAYING element is
11642         added to a bin, we have to create a new group to hold the element,
11643         and this function will be called before the group is added to the
11644         chain. Thus we have a valid case for group->chain==NULL. Instead
11645         of calling chain_group_set_enabled, just set the flag on the group
11646         (the chain's status will be set when the group is added to it).
11647         (gst_opt_scheduler_state_transition, chain_group_set_enabled):
11648         Setup the group scheduler when the group is enabled, not
11649         specifically when an element goes PAUSED->PLAYING. This means
11650         PLAYING elements can be added, linked, and scheduled into a
11651         PLAYING pipeline, as was intended.
11652         (add_to_group): Don't ref the group twice. I don't know when this
11653         double-ref got in here. Removing it has the potential to cause
11654         segfaults if other parts of the scheduler are buggy. If you find
11655         that the scheduler is segfaulting for you, put in an extra ref
11656         here and see if that hacks over the underlying issue. Of course,
11657         then find out what code is unreffing a group it doesn't own...
11658         (create_group): Make the extra refcount floating, and remove it
11659         after adding the element. This means that...
11660         (unref_group): Destroy when the refcount reaches 0, not 1, like
11661         every other refcounted object in the known universe.
11662         (remove_from_group): When a group becomes empty, set it to be not
11663         active, and remove it from its chain. Don't unref it again,
11664         there's no floating reference any more.
11665         (destroy_group): We have to remove the group from the chain in
11666         remove_from_group (rather than here) to break refcounting cycles
11667         (the chain always has a ref on the group). So assert that
11668         group->chain==NULL.
11669         (ref_group_by_count): Removed, it was commented out anyway.
11670         (merge_chains): Use the remove_from_chain and add_to_chain
11671         primitives to do the reparenting, instead of rolling our own
11672         implementation.
11673         (add_to_chain): The first non-disabled group in the chain's group
11674         list will be the entry point for the chain. Because buffers can
11675         accumulate in loop elements' peer bufpens, we preferentially
11676         schedule loop groups before get groups to avoid unnecessary
11677         execution of get-based groups when the bufpens are already full.
11678         (gst_opt_scheduler_schedule_run_queue): Debug fixes.
11679         (get_group_schedule_function): Ditto.
11680         (loop_group_schedule_function): Ditto.
11681         (gst_opt_scheduler_loop_wrapper): Ditto.
11682         (gst_opt_scheduler_iterate): Ditto.
11683
11684         I understand the opt scheduler now, yippee!
11685
11686         * gst/gstpad.c: All throughout, added FIXMEs to look at for 0.9.
11687         (gst_pad_get_name, gst_pad_set_chain_function) 
11688         (gst_pad_set_get_function, gst_pad_set_event_function) 
11689         (gst_pad_set_event_mask_function, gst_pad_get_event_masks) 
11690         (gst_pad_get_event_masks_default, gst_pad_set_convert_function) 
11691         (gst_pad_set_query_function, gst_pad_get_query_types) 
11692         (gst_pad_get_query_types_default) 
11693         (gst_pad_set_internal_link_function) 
11694         (gst_pad_set_formats_function, gst_pad_set_link_function) 
11695         (gst_pad_set_fixate_function, gst_pad_set_getcaps_function) 
11696         (gst_pad_set_bufferalloc_function, gst_pad_unlink) 
11697         (gst_pad_renegotiate, gst_pad_set_parent, gst_pad_get_parent) 
11698         (gst_pad_add_ghost_pad, gst_pad_proxy_getcaps) 
11699         (gst_pad_proxy_pad_link, gst_pad_proxy_fixate) 
11700         (gst_pad_get_pad_template_caps, gst_pad_check_compatibility) 
11701         (gst_pad_get_peer, gst_pad_get_allowed_caps) 
11702         (gst_pad_alloc_buffer, gst_pad_push, gst_pad_pull) 
11703         (gst_pad_selectv, gst_pad_select, gst_pad_template_get_caps) 
11704         (gst_pad_event_default_dispatch, gst_pad_event_default) 
11705         (gst_pad_dispatcher, gst_pad_send_event, gst_pad_convert_default) 
11706         (gst_pad_convert, gst_pad_query_default, gst_pad_query) 
11707         (gst_pad_get_formats_default, gst_pad_get_formats): Better
11708         argument checks, and some doc fixes.
11709
11710         (gst_pad_custom_new_from_template): Um, does anyone
11711         use these functions? Actually make a custom pad instead of a
11712         normal one.
11713         (gst_pad_try_set_caps): Transpose some checks.
11714         (gst_pad_try_set_caps_nonfixed): Same, and use a macro to check if
11715         the pad is in negotiation.
11716         (gst_pad_try_relink_filtered): Use pad_link_prepare.
11717         
11718         * gst/gstelement.c: Remove prototypes also defined in gstclock.h.
11719
11720         * gst/gstelement.h: 
11721         * gst/gstclock.h: Un-deprecate the old clocking API, as discussed
11722         on the list.
11723
11724 2004-02-24  Thomas Vander Stichele  <thomas at apestaart dot org>
11725
11726         * gst/gstbin.c: (gst_bin_add):
11727           add error for not being able to add elements
11728
11729 2004-02-22  Julien MOUTTE <julien@moutte.net>
11730
11731         * gst/gsttag.c: (_gst_tag_initialize): Registering 2 new tags,
11732         audio-codec and video-codec.
11733
11734 2004-02-22  Benjamin Otte  <otte@gnome.org>
11735
11736         reported by: Padraig O'Briain <padraig.obriain@sun.com>
11737
11738         * autogen.sh:
11739           replace test -e with test -x for mkinstalldirs to be more portable.
11740           (fixes #134816)
11741
11742 2004-02-22  Benjamin Otte  <otte@gnome.org>
11743
11744         * gst/gstpad.c:
11745           revert last patch from Andy, it makes gst_pad_can_link_filtered much
11746           too noisy
11747         * gst/gsttag.c: (_gst_tag_initialize):
11748         * gst/gsttag.h:
11749           add GST_TAG_ALBUM_VOLUME_{COUNT,NUMBER}
11750         * libs/gst/control/dparam.c: (gst_dparam_attach):
11751         * libs/gst/control/dparammanager.c: (gst_dpman_attach_dparam):
11752           check that types for attached dparams match
11753
11754 2004-02-22  Thomas Vander Stichele  <thomas at apestaart dot org>
11755
11756         * gst/elements/gstfilesink.c: (gst_filesink_open_file):
11757         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
11758         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_open_file):
11759           fix errors
11760
11761 2004-02-20  Andy Wingo  <wingo@pobox.com>
11762
11763         * gst/gstbin.c:
11764         * gst/gstbuffer.c:
11765         * gst/gstplugin.c:
11766         * gst/registries/gstxmlregistry.c: 
11767         * gst/schedulers/gstoptimalscheduler.c: Debugging tweaks.
11768
11769         * gst/gstelement.c (gst_element_set_scheduler): Debugging fixes.
11770         (gst_element_add_pad): DEBUG->INFO, some fixes.
11771         (gst_element_get_compatible_pad_template): Just see if the
11772         templates' caps intersect, not if one is a strict subset of the
11773         other. This conforms more to what gst_pad_link_intersect() does.
11774         (gst_element_class_add_pad_template): Don't memcpy the pad
11775         template, just ref it.
11776         (gst_element_get_compatible_pad_filtered): Clean up debug messages
11777
11778         * gst/gstpad.c (gst_pad_can_link_filtered): Debug a true result.
11779         (gst_pad_link_filtered): Debug changes.
11780         (gst_pad_link_prepare): New function, consolidated from
11781         can_link_filtered and link_filtered.
11782
11783         * gst/parse/grammar.y (gst_parse_perform_link): Made INFO output
11784         look more like that of the functions in gstelement.c
11785
11786         * gst/gstinfo.c (gst_debug_print_object): Put a space before the
11787         object, and return the empty string if object is NULL.
11788
11789         * gst/parse/parse.l: Remove trailing newlines when calling PRINT.
11790         * gst/parse/grammar.y (YYFPRINTF): Log bison debugging info via
11791         LOG, not DEBUG. We still get flex info on debug.
11792
11793         * gst/registries/gstxmlregistry.c (gst_xml_registry_load): Make
11794         debug string more verbose.
11795         (plugin_times_older_than): DEBUG->LOG.
11796
11797 2004-02-20  Julien MOUTTE <julien@moutte.net>
11798
11799         * gst/gsttag.h: Adding video-codec and audio-codec for demuxers which
11800         will emit found_tag for each stream they demux with the codec.
11801
11802 2004-02-20  Benjamin Otte  <otte@gnome.org>
11803
11804         * gst/gstevent.c: (_gst_event_copy), (_gst_event_free):
11805           copy navigation event correctly. Check freeing tag lists. 
11806         * gst/gstthread.c: (gst_thread_change_state):
11807           don't abort() on state changing mess - it might happen because of
11808           bugs.
11809         * gst/gstvalue.c: (gst_value_set_caps), (gst_value_get_caps):
11810           use boxed functions
11811         * gst/gstvalue.h:
11812           fix GST_VALUE_HOLDS_CAPS
11813
11814 2004-02-19  David Schleef  <ds@schleef.org>
11815
11816         * gst/gstinfo.h:  Copy G_STRFUNC implementation from glib-2.4
11817         and use it for GST_FUNCTION.  (bug #134750)
11818
11819 2004-02-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11820
11821         * po/fr.po:
11822         * po/nl.po:
11823           updating translations
11824
11825 2004-02-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11826
11827         * tools/gst-run.c: (get_candidates), (main): some fixes from jdahlin
11828
11829 2004-02-18  kost@imn.htwk-leipzig.de
11830
11831         reviewed by: David Schleef  <ds@schleef.org>
11832
11833         * docs/libs/gstreamer-libs-sections.txt:  Add missing sections
11834         for libgstcontrol.
11835
11836 2004-02-18  David Schleef  <ds@schleef.org>
11837
11838         * libs/gst/control/dparam.c: (gst_dparam_class_init):
11839         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_class_init),
11840         (gst_dpsmooth_new): Additional fixes to get double dparams working.
11841         * tools/gst-inspect.c: (print_element_info): Support dumping of
11842         double dparam information.
11843
11844 2004-02-17  David Schleef  <ds@schleef.org>
11845
11846         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
11847         Use G_TYPE_STRING in signal prototype instead of G_TYPE_POINTER.
11848         * gst/elements/gsttypefind.c: (gst_type_find_element_class_init):
11849         Use GST_TYPE_CAPS in signal prototype.
11850         * gst/gstcaps.c: (_gst_caps_initialize), (gst_caps_copy_conditional):
11851         Convert GST_TYPE_CAPS to boxed.
11852         * gst/gstelement.c: (gst_element_class_init):
11853         Use GST_TYPE_TAG_LIST in signal prototype.
11854         * gst/gstindex.c: (gst_index_class_init):
11855         * gst/gstindex.h:
11856         Add GST_TYPE_INDEX_ENTRY type.
11857         * gst/gstmarshal.list:
11858         Add necessary marshal types.
11859         * gst/gstpad.c: (gst_real_pad_class_init),
11860         (_gst_real_pad_fixate_accumulator), (gst_pad_link_fixate),
11861         (gst_pad_recover_caps_error):
11862         Use GST_TYPE_CAPS in signal prototypes.  Fix some debugging strings.
11863         * gst/gststructure.c: (_gst_structure_initialize),
11864         (gst_structure_copy), (_gst_structure_copy_conditional):
11865         * gst/gststructure.h:
11866         Convert GST_TYPE_STRUCTURE to boxed.
11867         * gst/gsttag.c: (gst_tag_list_get_type):
11868         * gst/gsttag.h:
11869         Add GST_TYPE_TAG_LIST type.
11870
11871 2004-02-17  Julien MOUTTE  <julien@moutte.net>
11872
11873         * gst/gstpad.c: (gst_pad_try_set_caps): Reverting my change according
11874         to what we agreed with david.
11875         * gst/gstpad.h: adding GST_PAD_IS_NEGOTIATING macro.
11876
11877 2004-02-17  Thomas Vander Stichele  <thomas at apestaart dot org>
11878
11879         * po/nl.po: update translation
11880
11881 2004-02-17  Thomas Vander Stichele  <thomas at apestaart dot org>
11882
11883         * gst/autoplug/gstspider.c: (gst_spider_identity_plug):
11884           throw an error if spider is trying to play a mime type there is
11885           no decoder for
11886         * po/POTFILES.in:
11887           add gst/autoplug/gstspider.c for translation
11888
11889 2004-02-17  Julien MOUTTE  <julien@moutte.net>
11890
11891         * gst/gstpad.c: (gst_pad_try_set_caps): We are nice people. Return 
11892         silently when the pad is negotiating.
11893
11894 2004-02-16  Thomas Vander Stichele  <thomas at apestaart dot org>
11895
11896         * docs/faq/Makefile.am:
11897           add script to run gstreamer uninstalled 
11898         * docs/faq/faq.xml:
11899         * docs/faq/developing.xml:
11900         * docs/faq/gst-uninstalled:
11901           extract script to run gstreamer uninstalled
11902         * docs/manuals.mak:
11903           add EXTRA_SOURCES variable for Makefile.am's to set to
11904           use additional SOURCE files for the doc build
11905
11906 2004-02-16  Thomas Vander Stichele  <thomas at apestaart dot org>
11907
11908         * gst/gstatomic_impl.h: Fedora 2 test package patch for S390
11909
11910 2004-02-15  Julien MOUTTE  <julien@moutte.net>
11911
11912         * gst/gstbin.c: (gst_bin_change_state), (gst_bin_iterate): Fix a big
11913         bug that was breaking pipelines like sinesrc ! { queue ! osssink } when
11914         an error was thrown by osssink. Basically a state change failure for
11915         an element in a different scheduling group was considered as
11916         successful, which means that caps nego was going on and weird stuff
11917         happened. Like I wrote in the comment there, if someone wants to
11918         revert that please drop me a mail explaining why because I really see
11919         no point in keeping that broken behaviour there.
11920         * gst/gstqueue.c: (gst_queue_get): Add a safety check as the queue CAN
11921         be empty, we then return NULL which will trigger a nice error when 
11922         pulling from the pad.
11923
11924 2004-02-13  David Schleef  <ds@schleef.org>
11925
11926         * libs/gst/control/dparam.c: (gst_dparam_class_init),
11927         (gst_dparam_get_property), (gst_dparam_set_property),
11928         (gst_dparam_do_update_default):
11929         * libs/gst/control/dparam.h:
11930         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_class_init),
11931         (gst_dpsmooth_new), (gst_dpsmooth_set_property),
11932         (gst_dpsmooth_get_property), (gst_dpsmooth_value_changed_double),
11933         (gst_dpsmooth_do_update_double):
11934         * libs/gst/control/dparam_smooth.h:
11935         * libs/gst/control/dparammanager.c:
11936         (gst_dpman_inline_direct_update):
11937         Add support for double dparams.
11938
11939 2004-02-13  David Schleef  <ds@schleef.org>
11940
11941         * gst/elements/gstfdsrc.c: (gst_fdsrc_get): Use GST_TIME_TO_TIMEVAL()
11942         * gst/gstclock.h: Avoid using 64-bit % operator (slow!)
11943
11944 2004-02-13  Mattias Wadman  <mattias@sudac.org>
11945
11946         reviewed by: David Schleef  <ds@schleef.org>
11947
11948         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init),
11949         (gst_fdsrc_init), (gst_fdsrc_set_property),
11950         (gst_fdsrc_get_property), (gst_fdsrc_get):
11951         * gst/elements/gstfdsrc.h:  Adds timeout property to fdsrc,
11952         and sends an EOS event if file descriptor reading times out.
11953
11954 2004-02-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11955
11956         * configure.ac:
11957           add calls to AM_CONDITIONAL for subsystems for automake 1.6.x
11958
11959 2004-02-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11960
11961         * configure.ac: pass required libxml version as argument
11962         (bug reported by Christophe Fergeau)
11963
11964 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
11965   
11966         * docs/gst/gstreamer-docs.sgml:
11967         * docs/gst/tmpl/gstxml.sgml:
11968         * docs/libs/gstreamer-libs-docs.sgml:
11969           version API docs
11970
11971 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
11972
11973         * gst/gstinfo.c:
11974         * gst/gstregistrypool.c: (gst_registry_pool_plugin_filter),
11975         (gst_registry_pool_feature_filter):
11976         * gst/gstthread.c: (gst_thread_class_init):
11977         * gst/gstvalue.c:
11978           add includes exposed by building without libxml
11979         * gst/indexers/Makefile.am:
11980           do not build fileindex when LOADSAVE disabled; we should have
11981           a better libxml check later since fileindex depends on xml, not
11982           LOADSAVE or REGISTRY
11983         * libs/gst/control/Makefile.am:
11984           link with m
11985         * tools/Makefile.am:
11986           fix wrong source code for gst-xmlinspect
11987
11988 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
11989
11990         * configure.ac:
11991           fix gcov help output
11992           move calls to and use new GST_CHECK_DISABLE_SUBSYSTEM
11993         * docs/random/release:
11994           some updated releasing notes
11995         * gstreamer.spec.in:
11996           more updates
11997
11998 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
11999
12000         * docs/faq/faq.xml:
12001         * docs/manual/manual.xml:
12002         * docs/pwg/pwg.xml:
12003         * docs/pwg/titlepage.xml:
12004           put version in documentation
12005
12006 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12007
12008         * tools/Makefile.am: fix man page installation
12009
12010 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12011
12012         * configure.ac:
12013           don't check for libxml when load/save and registry disabled (#105844)
12014         * gstreamer.spec.in:
12015           sync with fedora candidate spec
12016
12017 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12018
12019         * po/fr.po:
12020         * po/nl.po:
12021           replace multidisksrc with multifilesrc
12022
12023 2004-02-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12024
12025         * po/POTFILES.in:
12026           update to multidisksrc => multifilesrc file renaming (#134145)
12027
12028 2004-02-11  David Schleef  <ds@schleef.org>
12029
12030         * docs/gst/tmpl/gstcaps.sgml:  Fix stuff that mentions GstProps
12031         * docs/gst/tmpl/gstpadtemplate.sgml: same
12032         * docs/gst/tmpl/gstreamer-unused.sgml: Remove GstProps
12033         * gst/gstobject.c: (gst_object_set_name_default): Do the memleak
12034         fixing dance.
12035         * gst/gstutils.c: Remove disabled code that uses GstProps.
12036         * gst/registries/gstxmlregistry.h: same
12037         * docs/random/ds/0.9-suggested-changes: random notes
12038
12039 2004-02-11  kost@imn.htwk-leipzig.de
12040
12041         reviewed by: David Schleef  <ds@schleef.org>
12042
12043         * gst/gstclock.c: (gst_clock_entry_new): fixes structure
12044         initialisation of clock (bug #134128)
12045
12046 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
12047
12048         * configure.ac:
12049         * gst/elements/Makefile.am:
12050         * gst/elements/gstelements.c:
12051         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_base_init),
12052         (gst_multifilesrc_class_init), (gst_multifilesrc_init),
12053         (gst_multifilesrc_set_property), (gst_multifilesrc_get_property),
12054         (gst_multifilesrc_get), (gst_multifilesrc_open_file),
12055         (gst_multifilesrc_close_file), (gst_multifilesrc_change_state):
12056         * gst/elements/gstmultifilesrc.h:
12057           rename multidisksrc to multifilesrc (part of #122200)
12058
12059 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
12060
12061         * docs/manuals.mak:
12062           fix automake complaints
12063         * gst-element-check.m4:
12064           fix unquotedness
12065
12066 2004-02-11  David Schleef  <ds@schleef.org>
12067
12068         * docs/gst/Makefile.am: Call gst_init() in built gstreamer-scan.
12069         * gst/gstatomic_impl.h: Disable sparc implementation.
12070
12071 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
12072
12073         * gst-element-check.m4:
12074           fix underquoted macros as reported by automake 1.8.x (#133800)
12075         * configure.ac:
12076           require gettext 0.11.5 so ulonglong.m4 gets checked out and copied
12077           by autopoint (fixes #132996)
12078
12079 2004-02-10  Andy Wingo  <wingo@pobox.com>
12080
12081         * gst/gstpad.c (gst_pad_custom_new): Add a FIXME, this is a hacky
12082         way to do inheritance.
12083         (gst_pad_get_event_masks, gst_pad_get_event_masks_default) 
12084         (gst_pad_get_query_types, gst_pad_get_query_types_default):
12085         Routine docs.
12086         (gst_pad_set_link_function, gst_pad_set_fixate_function) 
12087         (gst_pad_set_getcaps_function): Doc from Dave's negotation random
12088         doc.
12089         (gst_pad_unlink, gst_pad_is_linked): Docs.
12090         (gst_pad_renegotiate): A brief description of capsnego.
12091         (gst_pad_try_set_caps): Document.
12092         (gst_pad_try_set_caps_nonfixed): Document.
12093         (gst_pad_can_link_filtered, gst_pad_link_filtered): Doc fixes.
12094         (gst_pad_set_parent): Deprecated (although not out of the API).
12095         (gst_pad_get_parent): Deprecated, although many plugins use this.
12096         (gst_pad_add_ghost_pad, gst_pad_remove_ghost_pad): Doc that these
12097         are private and will go away in 0.9.
12098         (gst_pad_perform_negotiate): Doc.
12099         (gst_pad_link_unnegotiate): I think this is meant to be static.
12100         (gst_pad_get_negotiated_caps, gst_pad_get_pad_template_caps) 
12101         (gst_pad_template_get_caps_by_name, gst_pad_check_compatibility) 
12102         (gst_pad_get_peer): Doc updates.
12103         (gst_pad_caps_change_notify): Doc.
12104         (gst_pad_alloc_buffer, gst_pad_push, gst_static_pad_template_get) 
12105         (gst_ghost_pad_new): Doc fixes.
12106
12107         * gst/gstobject.c (gst_object_get_parent, gst_object_unparent) 
12108         (gst_object_check_uniqueness): 
12109
12110         * gst/gstelement.c (gst_element_add_pad) 
12111         (gst_element_add_ghost_pad, gst_element_remove_pad) 
12112         (gst_element_remove_ghost_pad, gst_element_get_pad) 
12113         (gst_element_get_static_pad, gst_element_get_pad_list) 
12114         (gst_element_class_get_pad_template_list) 
12115         (gst_element_class_get_pad_template): Work on the docs.
12116         (gst_element_get_pad_template_list): Uses the class method.
12117         (gst_element_get_compatible_pad_template): Docs, and consolidate
12118         some test conditions. 
12119         (gst_element_get_pad_from_template): New static function.
12120         (gst_element_request_compatible_pad): Docs, and work with
12121         non-request compatible templates. 
12122         (gst_element_get_compatible_pad_filtered): Docs and remove
12123         redundant checks.
12124         (gst_element_get_compatible_pad, gst_element_link_pads_filtered) 
12125         (gst_element_link_filtered, gst_element_link_many) 
12126         (gst_element_link, gst_element_link_pads) 
12127         (gst_element_unlink_many): Docs.
12128
12129 2004-02-05  Andy Wingo  <wingo@pobox.com>
12130
12131         * gst/gstpad.c (_gst_real_pad_fixate_accumulator):
12132         s/pointer/boxed/.
12133
12134         * gst/gstmarshal.list (VOID:BOXED, BOXED:BOXED): New marshallers.
12135
12136         * gst/gstpad.c (gst_real_pad_class_init): Use a BOXED:BOXED
12137         marshaller for ::fixate, and VOID:BOXED for ::caps-nego-failed,
12138         with the type=GST_TYPE_CAPS. This allows language bindings to know
12139         what kind of data they're dealing with.
12140
12141         * gst/gstcaps.c (_gst_caps_value_init): GBoxed values initialize
12142         to NULL when g_value_init is called. GstCaps, which rolls its own
12143         type implementation, now does the same instead of allocating empty
12144         caps.
12145         (_gst_caps_initialize, _gst_caps_collect_value,
12146         _gst_caps_lcopy_value): Provide collect_value and lcopy_value type
12147         table methods. This allows G_VALUE_COLLECT to work.
12148
12149 2004-02-05  Andy Wingo  <wingo@pobox.com>
12150
12151         * configure.ac:
12152         * testsuite/Makefile.am (SUBDIRS): 
12153         * testsuite/ghostpads/Makefile.am: 
12154         * testsuite/ghostpads/ghostpads.c: A new test for ghost pads.
12155
12156         * gst/gstpad.c (gst_pad_add_ghost_pad, gst_pad_remove_ghost_pad):
12157         These two routines are the only ones that set
12158         GST_GPAD_REALPAD(gpad), the ghost pad list, and the ghost pad's
12159         pad template. They should be made static, depending on ABI needs.
12160         (gst_real_pad_dispose): Handle the case of ghost pads without a
12161         parent. Assert after dealing with ghost pads that the ghost pad
12162         list is empty.
12163         (gst_ghost_pad_class_init): New property added, ::real-pad. Can be
12164         set after creation.
12165         (gst_ghost_pad_dispose): Set ::real-pad to NULL.
12166         (gst_ghost_pad_set_property, gst_ghost_pad_get_property): New
12167         functions. set_property will call add_ghost_pad/remove_ghost_pad
12168         as appropriate.
12169         (gst_ghost_pad_new): All the work is offloaded to g_object_new.
12170
12171         * gst/gstelement.c (gst_element_add_pad): Handle ghost pads as well.
12172         (gst_element_add_ghost_pad): Remove code duplicated from _add_pad.
12173         (gst_element_remove_pad): Handle ghost pads as well.
12174         (gst_element_remove_ghost_pad): Deprecated (could be removed,
12175         depending on API-stability needs).
12176
12177 2004-02-05  Andy Wingo  <wingo@pobox.com>
12178
12179         * gst/gstbin.[ch]: (gst_bin_get_by_interface): GTypes are scalars,
12180         of course they're const
12181
12182 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
12183
12184         * tools/Makefile.am:
12185         * tools/gst-feedback:
12186         * tools/gst-feedback-0.7:
12187           make gst-feedback versioned too for consistency
12188
12189 2004-02-11  David Schleef  <ds@schleef.org>
12190
12191         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
12192         (gst_pad_try_set_caps): Fix format strings for GST_PTR_FORMAT.
12193
12194 2004-02-10  Julien MOUTTE <julien@moutte.net>
12195
12196         * gst/gstevent.c: (_gst_event_free): Sometimes a tag event arrives but
12197         the structure does not contain a valid tag list. Adding a safety check
12198         to remove a noisy warning in that case.
12199
12200 2004-02-10  Thomas Vander Stichele  <thomas at apestaart dot org>
12201
12202         * gst/gst.c: fix name to be in line with others
12203
12204 2004-02-09  Julien MOUTTE <julien@moutte.net>
12205
12206         * libs/gst/bytestream/bytestream.c: (gst_bytestream_peek): We should
12207         not shout that loud when len is 0. Just return 0 silently.
12208
12209 2004-02-09  Julien MOUTTE  <julien@moutte.net>
12210
12211         * gst/gstdata.c: (gst_data_ref): Adding a categorized debug on data_ref
12212         because data_unref has one and I prefer the debug to be symetric.
12213         * gst/gstqueue.c: (gst_queue_locked_flush): Fix a huge memleak. Buffers
12214         were refed when added to the queue and unrefed only once when the queue
12215         was flushed. Now the flush handler unref the buffers two times : first
12216         unref for the ref added when pushing in the queue's tail and second
12217         unref to destroy the flushed buffer.
12218
12219 2004-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
12220
12221         * docs/pwg/building-boiler.xml: fix cvs checkout documentation
12222
12223 2004-02-06  David Schleef  <ds@schleef.org>
12224
12225         * docs/random/ds/0.9-suggested-changes: Random ramblings
12226         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap): Cast size_t
12227         to int before printing.
12228         * gst/parse/grammar.y: Fix gcc-2.95 style variadic macros.
12229         * gst/parse/parse.l: same.  See bug #129600
12230
12231 2004-02-06  David Schleef  <ds@schleef.org>
12232
12233         * gst/gstindex.c: (gst_index_add_format), (gst_index_add_id),
12234         (gst_index_add_entry), (gst_index_add_associationv),
12235         (gst_index_add_association): Add gst_index_add_associationv()
12236         and clean up gst_index_add_association(). #127133
12237
12238 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
12239
12240         * autogen.sh: check out common with right tag if CVS/Tag exists
12241
12242 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
12243
12244         * testsuite/ghostpads/ghostpads.c: (main):
12245           fix testsuite from segfaulting
12246
12247 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
12248
12249         * Makefile.am: add release target
12250         * configure.ac: bump nano to 1
12251         * docs/random/release:
12252
12253 2004-02-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12254
12255         * gst/gstcaps.h:
12256         * gst/gstelement.c: (gst_element_base_class_init),
12257         (gst_element_class_set_details), (gst_element_clear_pad_caps):
12258         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
12259         (gst_pad_try_set_caps), (gst_pad_can_link_filtered),
12260         (gst_real_pad_dispose):
12261         * gst/gststructure.c: (gst_structure_free),
12262         (gst_structure_from_string):
12263           put reverted patch back in
12264         * gst/gstelement.c: (gst_element_remove_pad):
12265           free explicit caps if they're set
12266         * gst/gstpad.c: (_gst_pad_default_fixate_func):
12267           copy the structure when fixating
12268
12269 2004-02-05  David Schleef  <ds@schleef.org>
12270
12271         * gst/gstmarshal.list:
12272         * gst/gstpad.c: (gst_real_pad_class_init),
12273         (_gst_real_pad_fixate_accumulator):
12274         Revert POINTER->BOXED change in signal marshaller.
12275
12276 === release 0.7.4 ===
12277                                                                                 
12278 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
12279                                                                                 
12280         * NEWS: GStreamer 0.7.4 "Wooden Eels" released
12281         * configure.ac: changed for release
12282
12283 2004-02-05  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
12284
12285         * gstreamer.spec.in:
12286           bump required version of gtk-doc
12287
12288 2004-02-05  Thomas Vander Stichele  <thomas at apestaart dot org>
12289
12290         * gst/gstcaps.h:
12291         * gst/gstelement.c: (gst_element_base_class_init),
12292         (gst_element_class_set_details), (gst_element_clear_pad_caps):
12293         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
12294         (gst_pad_try_set_caps), (gst_pad_can_link_filtered),
12295         (gst_real_pad_dispose):
12296         * gst/gststructure.c: (gst_structure_free),
12297         (gst_structure_from_string):
12298           revert patch that breaks applications, reapply after release
12299           to get this fixed properly
12300
12301 2004-02-05  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12302
12303         * gst/gsttag.c: (_gst_tag_initialize):
12304         * gst/gsttag.h:
12305           remove duplicated field GST_TAG_APPLICATION. It's GST_TAG_ENCODER
12306
12307 2004-02-04  David Schleef  <ds@schleef.org>
12308
12309         Fix some memleaks:
12310         * gst/autoplug/gstspider.c: (gst_spider_request_new_pad),
12311         (gst_spider_plug_from_srcpad):
12312         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link):
12313
12314 2004-02-04  David Schleef  <ds@schleef.org>
12315
12316         * gst/gstelement.c: (gst_element_clear_pad_caps): Make sure we have
12317         a GstRealPad before accessing its structure members.
12318
12319 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12320
12321         * gst/gstclock.c: (gst_clock_init), (gst_clock_set_speed),
12322         (gst_clock_get_speed):
12323         * gst/gstclock.h:
12324           reset padding, remove unused fields
12325
12326 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12327
12328         * gst/autoplug/gstspideridentity.c:
12329         (gst_spider_identity_sink_loop_type_finding):
12330           use get_allowed_caps, not get_caps (fixes #132519)
12331         * gst/elements/gsttypefind.c: (stop_typefinding):
12332           use correct order when sending buffers and seeking
12333
12334 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
12335
12336         * configure.ac:
12337         * gst/gstelement.h:
12338         * gst/gstpad.h:
12339         * gst/gstqueue.h:
12340           upgrade libtool CURRENT, reset padding
12341
12342 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
12343
12344         * configure.ac:
12345           bump to prerelease
12346           put back AM_PROG_LIBTOOL to make libtoolize stop complaining
12347
12348 2004-02-04  David Schleef  <ds@schleef.org>
12349
12350         * docs/random/ds/0.9-suggested-changes: random notes
12351         * gst/elements/gstfakesrc.c: (gst_fakesrc_get_formats),
12352         (gst_fakesrc_get_query_types), (gst_fakesrc_get_event_mask):
12353         Replace GST_PAD_EVENT_MASK_FUNCTION() (et al.) with its
12354         expansion.
12355         * gst/elements/gstfilesink.c: (gst_filesink_get_formats),
12356         (gst_filesink_get_query_types): same
12357         * gst/elements/gstfilesrc.c: (gst_filesrc_get_event_mask),
12358         (gst_filesrc_get_query_types), (gst_filesrc_get_formats): same
12359         * gst/gstcaps.h: deprecate GST_DEBUG_CAPS(), and fix the macro
12360         to use new GST_PTR_FORMAT.
12361         * gst/gstelement.h: deprecate function factory macros
12362         GST_ELEMENT_QUERY_TYPE_FUNCTION(), GST_ELEMENT_EVENT_MASK_FUNCTION().
12363         These are our last variadic macros that can't be replaced with
12364         inlines.  Celebrate!  Also fix a typo in an #ifdef that was
12365         attempting to deprecate gst_element_clock_wait().
12366         * gst/gstevent.h: same
12367         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
12368         (gst_pad_try_set_caps): replace GST_DEBUG_CAPS() with GST_DEBUG()
12369         * gst/gstpad.h: deprecate function factory macros similar to above.
12370
12371 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
12372
12373         * configure.ac:
12374         * tools/Makefile.am:
12375         * tools/gst-run.c: (popt_callback), (hash_print_key),
12376         (find_highest_version), (unmangle_libtool), (get_dir_of_binary),
12377         (get_candidates), (main):
12378           add new source file to generate non-versioned wrapper binaries
12379           for our tools.
12380
12381 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12382
12383         * gst/gstevent.c: (_gst_event_free):
12384           actually break; inside the switch statement
12385         * gst/parse/grammar.y:
12386           fix memleak where GValues weren't unset
12387
12388 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12389
12390         * gst/gststructure.c: (gst_structure_from_string):
12391           fix huge memleak
12392         * gst/elements/gsttypefind.c: (gst_type_find_element_have_type),
12393         (new_entry), (gst_type_find_element_chain):
12394         * gst/gstelement.c: (gst_element_base_class_init),
12395         (gst_element_class_set_details):
12396         * gst/gstpad.c: (gst_pad_can_link_filtered):
12397           fix smaller memleaks
12398         * gst/gstpad.c: (gst_real_pad_dispose):
12399           check that explicit caps are gone
12400         * gst/gststructure.c: (gst_structure_free):
12401           actually free the structure
12402         * gst/gstelement.c: (gst_element_clear_pad_caps):
12403           unset explicit caps
12404
12405 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
12406
12407         * tools/Makefile.am:
12408           use AM_CFLAGS since all the CFLAGS are the same
12409           use AM_LDFAGS
12410
12411 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
12412
12413         * docs/manual/gnome.xml:
12414           expand example a little
12415         * gst/gst.c: (gst_init_with_popt_table),
12416         (gst_init_check_with_popt_table), (init_pre), (init_popt_callback):
12417           make sure popt option displays are done with right textdomain
12418           use GstPoptOption type
12419         * gst/gst.h:
12420           create GstPoptOption type
12421
12422 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
12423
12424         * gst/gsterror.c: (_gst_stream_errors_init):
12425         * gst/gsterror.h:
12426           adding error type for no codec
12427         * po/POTFILES.in:
12428           add gst-inspect
12429         * po/nl.po:
12430           update dutch translation
12431         * tools/gst-inspect.c: (print_element_list), (main):
12432           do proper internationalization
12433         * tools/gst-launch.c: (idle_func):
12434           remove commented out function call
12435
12436 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
12437
12438         * docs/README:
12439           add some error fixing notes
12440         * docs/gst/gstreamer-sections.txt:
12441           remove double entries
12442         * docs/gst/tmpl/gstbin.sgml:
12443         * docs/gst/tmpl/gstclock.sgml:
12444           remove override
12445         * docs/gst/tmpl/gstelement.sgml:
12446         * docs/gst/tmpl/gstindex.sgml:
12447         * docs/gst/tmpl/gstobject.sgml:
12448         * docs/gst/tmpl/gstpadtemplate.sgml:
12449         * docs/gst/tmpl/gstreamer-unused.sgml:
12450         * docs/gst/tmpl/gsttag.sgml:
12451         * docs/gst/tmpl/gstthread.sgml:
12452         * docs/gst/tmpl/gstxml.sgml:
12453         * gst/gsttag.h:
12454           sync header prototypes with c decls
12455         * gst/gsttaginterface.c:
12456           fix doc headers
12457
12458 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12459
12460         * gst/parse/Makefile.am:
12461         * gst/gstobject.h:
12462           get rid of gstmarshal.h dependency. It's not needed.
12463         * gst/gst.h:
12464         * gst/elements/gstfakesink.c:
12465         * gst/elements/gstfakesrc.c:
12466         * gst/elements/gstidentity.c:
12467         * gst/gstbin.c:
12468         * gst/gstelement.c:
12469         * gst/gstindex.c:
12470         * gst/gstobject.c:
12471         * gst/gstpad.c:
12472         * gst/gstthread.c:
12473         * gst/gstxml.c:
12474         * libs/gst/control/dparam.c:
12475         * libs/gst/control/dparammanager.c:
12476           include gstmarshal.h.
12477         Fixes #132045
12478
12479 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12480
12481         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
12482         (gst_filesrc_dispose), (gst_filesrc_free_parent_mmap),
12483         (gst_filesrc_map_region), (gst_filesrc_get_mmap):
12484         * gst/elements/gstfilesrc.h:
12485           don't ref the filesrc when creating mmaped buffers. Don't keep a
12486           list of not-yet-destroyed buffers.
12487         * gst/gstbuffer.h:
12488           Deprecated BST_BUFFER_FREE_FUNC and GST_BUFFER_COPY_FUNC
12489
12490 2004-02-02  Thomas Vander Stichele  <thomas at apestaart dot org>
12491
12492         * gst/gst.c: (init_pre):
12493           remove textdomain
12494
12495 2004-02-02  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12496
12497         * docs/pwg/advanced-events.xml:
12498         * docs/pwg/advanced-scheduling.xml:
12499         * docs/pwg/intro-basics.xml:
12500         * docs/pwg/other-manager.xml:
12501         * docs/pwg/other-nton.xml:
12502         * docs/pwg/other-ntoone.xml:
12503         * docs/pwg/other-oneton.xml:
12504         * docs/pwg/pwg.xml:
12505           All sort of documentation... Forgot what. Point is that I want this
12506           in before I leave. The 'other-*' will be the last section and will
12507           explain issues specific to these type of elements.
12508
12509 2004-02-02  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12510
12511         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
12512         (gst_filesrc_get_read):
12513           set all the values on buffers that we can
12514
12515 2004-02-02  David Schleef  <ds@schleef.org>
12516
12517         Change usage of isblah() to g_ascii_isblah() to be more locale
12518         independent.  (#133076)
12519         * gst/gsturi.c: (gst_uri_protocol_check_internal):
12520         * gst/gstutils.c:
12521         * gst/parse/parse.l:
12522
12523 2004-02-02  Jon Trowbridge  <trow@gnu.org>
12524
12525         reviewed by: David Schleef  <ds@schleef.org>
12526
12527         Fix memory leaks:
12528         * gst/gstcaps.c: (gst_caps_to_string):
12529         * gst/registries/gstxmlregistry.c:
12530         (gst_xml_registry_add_path_list_func),
12531         (gst_xml_registry_parse_padtemplate):
12532
12533 2004-02-02  Thomas Vander Stichele  <thomas at apestaart dot org>
12534
12535         * gst/gstelement.c: (gst_element_default_error):
12536           suffix error messages with period
12537
12538 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
12539
12540         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
12541         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
12542         * gst/gsterror.c: (gst_error_get_message):
12543           Suffix with dots
12544         * po/fr.po:
12545         * po/nl.po:
12546           Update translation files
12547
12548 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
12549
12550         * gst/autoplug/gstspideridentity.c:
12551         (gst_spider_identity_sink_loop_type_finding):
12552         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
12553         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
12554         (gst_filesink_close_file), (gst_filesink_handle_event),
12555         (gst_filesink_chain):
12556         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
12557         (gst_filesrc_get_read), (gst_filesrc_open_file):
12558         * gst/elements/gstidentity.c: (gst_identity_chain):
12559         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
12560         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
12561         (gst_pipefilter_chain), (gst_pipefilter_open_file):
12562         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
12563         * gst/gsterror.c: (_gst_core_errors_init),
12564         (_gst_library_errors_init), (_gst_resource_errors_init),
12565         (_gst_stream_errors_init), (gst_error_get_message):
12566         * gst/gstpad.c: (gst_pad_set_explicit_caps),
12567         (gst_pad_recover_caps_error), (gst_pad_pull):
12568         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
12569         * gst/schedulers/gstbasicscheduler.c:
12570         (gst_basic_scheduler_chainhandler_proxy),
12571         (gst_basic_scheduler_gethandler_proxy),
12572         (gst_basic_scheduler_cothreaded_chain):
12573           Suffix error messages with period.
12574           Use (NULL) instead of NULL
12575
12576 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
12577
12578         * docs/gst/tmpl/gstelement.sgml:
12579         * docs/gst/tmpl/gstxml.sgml:
12580         * gst/gstelement.c: (gst_element_error_full):
12581           add element path to error
12582
12583 2004-01-31  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12584
12585         * docs/random/mimetypes:
12586           update raw int/float info
12587         * gst/gsttag.c: (_gst_tag_initialize):
12588         * gst/gsttag.h:
12589           add GST_TAG_ENCODER
12590
12591 2004-01-30  David Schleef  <ds@schleef.org>
12592
12593         * gst/cothreads.c: Add another fallback if MAP_ANONYMOUS is
12594           missing (#132991)
12595
12596 2004-01-30  Laurent Vivier <Laurent.Vivier@bull.net>
12597
12598         reviewed by Benjamin Otte 
12599           parts of the patch submitted in bug #113913
12600
12601         * configure.ac:
12602           use AC_C_INLINE. Use = instead of == with test
12603         * examples/plugins/example.c:
12604         * gst/autoplug/gstspideridentity.c:
12605         * gst/elements/gstfdsrc.c:
12606         * gst/elements/gstfilesrc.c:
12607         * gst/elements/gstidentity.c:
12608         * gst/elements/gstmultidisksrc.c:
12609         * gst/elements/gststatistics.c:
12610         * gst/gstelement.c:
12611         * gst/gstobject.c:
12612         * gst/gstpad.c:
12613         * gst/gstpipeline.c:
12614         * gst/gstthread.c:
12615           don't end enums with a comma
12616         * gst/gstindex.c: (gst_index_compare_func):
12617           do explicit casting to gint
12618         * gst/gsttrace.c: (gst_trace_text_flush):
12619           #define strsize as a macro
12620
12621 2004-01-30  Thomas Vander Stichele  <thomas at apestaart dot org>
12622
12623         * docs/README:
12624         * docs/gst/gstreamer-docs.sgml:
12625         * docs/gst/gstreamer-sections.txt:
12626         * docs/gst/tmpl/gstelement.sgml:
12627         * docs/gst/tmpl/gsterror.sgml:
12628         * docs/gst/tmpl/gstinterface.sgml:
12629         * docs/gst/tmpl/gstreamer-unused.sgml:
12630         * docs/gst/tmpl/gststructure.sgml:
12631         * docs/gst/tmpl/gsttag.sgml:
12632         * docs/gst/tmpl/gsttaginterface.sgml:
12633         * docs/gst/tmpl/gstvalue.sgml:
12634         make sure all API ends up in the built docs
12635         * gst/gstinterface.c:
12636         * gst/gststructure.c: (gst_structure_id_set_value),
12637         (gst_structure_set_value), (gst_structure_id_get_value):
12638         * gst/gststructure.h:
12639         * gst/gstvalue.h:
12640         sync .h with .c declarations
12641
12642 2004-01-30  Julien Moutte  <julien@moutte.net>
12643
12644         * libs/gst/bytestream/bytestream.c: Reverting my event handling patch.
12645         Ronald will fix riffread.
12646
12647 2004-01-30  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12648
12649         * docs/pwg/advanced-interfaces.xml:
12650           Added tuner interface docs.
12651
12652 2004-01-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12653
12654         * docs/random/mimetypes:
12655           correct Theora information
12656         * gst/gstelement.h:
12657           make GST_ELEMENT_ERROR do a GST_ERROR_OBJECT
12658
12659 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
12660
12661         * gst/gstelement.c: (gst_element_error_full):
12662         * gst/gstelement.h:
12663           GST_ELEMENT_ERROR in enum -> _IN_ERROR
12664
12665 2004-01-29  Julien MOUTTE  <julien@moutte.net>
12666
12667         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
12668         (gst_filesrc_uri_handler_init): Fixing seeking by making FLUSH happen
12669         again and even before DISCONT.
12670         * gst/gstpad.c: (gst_pad_event_default): Remove a unused switch case.
12671         * libs/gst/bytestream/bytestream.c: (gst_bytestream_get_next_buf): Fix
12672         bytestream so that it's not stopping to fill the bytestream if events
12673         different than EOS or DISCONT are received. Instead it process them so
12674         that they go downstream.
12675
12676 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
12677
12678         * docs/gst/tmpl/gstelement.sgml:
12679         * docs/gst/tmpl/gstreamer-unused.sgml:
12680         * docs/gst/tmpl/gstxml.sgml:
12681         * gst/autoplug/gstspideridentity.c:
12682         (gst_spider_identity_sink_loop_type_finding):
12683         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
12684         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
12685         (gst_filesink_close_file), (gst_filesink_handle_event),
12686         (gst_filesink_chain):
12687         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
12688         (gst_filesrc_get_read), (gst_filesrc_open_file):
12689         * gst/elements/gstidentity.c: (gst_identity_chain):
12690         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
12691         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
12692         (gst_pipefilter_chain), (gst_pipefilter_open_file):
12693         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
12694         * gst/gstelement.h:
12695         * gst/gstpad.c: (gst_pad_set_explicit_caps),
12696         (gst_pad_recover_caps_error), (gst_pad_pull):
12697         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
12698         * gst/schedulers/gstbasicscheduler.c:
12699         (gst_basic_scheduler_chainhandler_proxy),
12700         (gst_basic_scheduler_gethandler_proxy),
12701         (gst_basic_scheduler_cothreaded_chain):
12702           gst_element_error -> GST_ELEMENT_ERROR
12703
12704 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
12705
12706         * docs/Makefile.am:
12707         * docs/gst/tmpl/gstelement.sgml:
12708         * docs/gst/tmpl/gstxml.sgml:
12709         * docs/manuals.mak:
12710         * docs/pwg/advanced-request.xml:
12711         * docs/pwg/advanced-scheduling.xml:
12712         * docs/pwg/advanced-tagging.xml:
12713           fix non-validating docbook using CDATA
12714           make sure make check-local gets run first to check if it validates
12715
12716 2004-01-29  Julien MOUTTE <julien@moutte.net>
12717
12718         * docs/pwg/advanced-events.xml: Adding documentation on advanced event
12719         handling (up and downstream).
12720         * docs/pwg/advanced-interfaces.xml: Make it coherent with the
12721         my_filter thing.
12722
12723 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12724
12725         * docs/pwg/advanced-tagging.xml:
12726           Add docs about tag writing.
12727
12728 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12729
12730         * docs/pwg/advanced-tagging.xml:
12731           Add a part about tag reading and application signalling... Tag
12732           writing still needs to be documented.
12733         * gst/elements/gstfilesrc.c: (gst_filesrc_set_location):
12734           We can set file locations in READY, too.
12735
12736 2004-01-29  Julien MOUTTE <julien@moutte.net>
12737
12738         * docs/random/ds/element-checklist: Adding some notes about src
12739         events.
12740
12741 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12742
12743         * docs/random/mimetypes:
12744           Update docs to point to correct elements for various mimetypes, and
12745           some more errors pointed out by Stéphane LOEUILLET (aka LeRoutier)
12746           <stephane.loeuillet@tiscali.fr>.
12747
12748 2004-01-28  David Schleef  <ds@schleef.org>
12749
12750         * docs/pwg/intro-basics.xml: rewrite bufferpool stuff.
12751
12752 2004-01-29  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12753
12754         * docs/random/mimetypes:
12755           update docs for audio/x-raw-float. Add "buffer-frames=0 means
12756           undefined"
12757         * gst/elements/gstfilesrc.c: (gst_filesrc_set_location):
12758           make it only work in NULL.
12759         * gst/gstcaps.c:
12760           don't posion NULL caps
12761         * gst/gstelement.c: (gst_element_set_time):
12762           add debugging statement
12763         * gst/gstelement.c: (gst_element_emit_found_tag),
12764         (gst_element_found_tag_func), (gst_element_found_tags):
12765         * gst/gstelement.h:
12766           These functions take const taglists
12767         * gst/gstpad.c: (gst_pad_proxy_getcaps):
12768           fix memleak
12769         * gst/gstpad.c: (gst_pad_event_default):
12770           make more effort on handling discont and clocks, g_warn if everything
12771           fails
12772         * gst/gststructure.c: (gst_structure_remove_fields),
12773         (gst_structure_remove_fields_valist):
12774         * gst/gststructure.h:
12775           add gst_structure_remove_fields(_valist)
12776         * gst/gsttag.c:
12777           fix doc glitch
12778
12779 2004-01-28  David Schleef  <ds@schleef.org>
12780
12781         * docs/random/ds/element-checklist: Notes about gst_caps_to_string()
12782         * gst/registries/gstxmlregistry.c: (gst_xml_registry_save_caps):
12783         Fix memory leakage of gst_caps_to_string().
12784
12785         Use GST_PTR_FORMAT instead of gst_caps_to_string():
12786         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_sp):
12787         * gst/autoplug/gstspideridentity.c: (spider_find_suggest),
12788         (gst_spider_identity_sink_loop_type_finding):
12789         * gst/elements/gsttypefind.c: (gst_type_find_element_have_type),
12790         (find_suggest):
12791         * gst/gstpad.c: (gst_pad_try_relink_filtered),
12792         (gst_pad_set_explicit_caps):
12793         * gst/parse/grammar.y:
12794
12795 2004-01-28  David Schleef  <ds@schleef.org>
12796
12797         * configure.ac: Add detection for HAVE_PRINTF_EXTENSION and
12798         GST_PRINTF_EXTENSION_FORMAT_DEFINE.
12799         * docs/random/ds/0.9-suggested-changes: Notes from Company.
12800         * gst/gstcaps.c: (gst_caps_to_string): Add comment.
12801         * gst/gstconfig.h.in: Add define for GST_PTR_FORMAT
12802         * gst/gstinfo.c: (_gst_debug_init), (gst_debug_print_object),
12803         (gst_debug_log_default), (_gst_info_printf_extension),
12804         (_gst_info_printf_extension_arginfo):  Add printf extension.
12805         * gst/gstinfo.h: remove G_GNUC_PRINTF, because it doesn't work with %P
12806         * gst/gststructure.c: (gst_structure_to_string),
12807         (_gst_structure_parse_value): Use gst_value_deserialize() and
12808         remove old code.
12809         * gst/gstvalue.c: (gst_value_deserialize_fourcc),
12810         (gst_value_deserialize_boolean), (gst_strtoi),
12811         (gst_value_deserialize_int), (gst_value_deserialize_double),
12812         (gst_value_deserialize_string), (gst_value_deserialize): Implement
12813         a bunch of deserialize functions and gst_value_deserialize.
12814         * gst/gstvalue.h: er, _de_serialize, not unserialize
12815         * testsuite/caps/string-conversions.c: (main): We don't currently
12816         handle (float) in caps, so convert these to (double).
12817         * testsuite/debug/Makefile.am: Add new test for the printf extension
12818         * testsuite/debug/printf_extension.c: (main): same
12819
12820 2004-01-28  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12821
12822         * docs/random/company/time:
12823           Add some docs about clocking and time
12824
12825 2004-01-28  Julien MOUTTE <julien@moutte.net>
12826
12827         * docs/pwg/advanced-interfaces.xml: Adding XOverlay documentation.
12828
12829 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12830
12831         * docs/pwg/advanced-clock.xml:
12832         * docs/pwg/advanced-dparams.xml:
12833         * docs/pwg/advanced-events.xml:
12834         * docs/pwg/advanced-interfaces.xml:
12835         * docs/pwg/advanced-midi.xml:
12836         * docs/pwg/advanced-request.xml:
12837         * docs/pwg/advanced-scheduling.xml:
12838         * docs/pwg/advanced-tagging.xml:
12839         * docs/pwg/advanced-types.xml:
12840         * docs/pwg/appendix-checklist.xml:
12841         * docs/pwg/building-boiler.xml:
12842         * docs/pwg/building-chainfn.xml:
12843         * docs/pwg/building-filterfactory.xml:
12844         * docs/pwg/building-pads.xml:
12845         * docs/pwg/building-props.xml:
12846         * docs/pwg/building-signals.xml:
12847         * docs/pwg/building-state.xml:
12848         * docs/pwg/building-testapp.xml:
12849         * docs/pwg/intro-basics.xml:
12850         * docs/pwg/intro-preface.xml:
12851         * docs/pwg/other-autoplugger.xml:
12852         * docs/pwg/other-sink.xml:
12853         * docs/pwg/other-source.xml:
12854         * docs/pwg/titlepage.xml:
12855           fix up id's
12856
12857 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12858
12859         * docs/95NonPath:
12860         * docs/HACKING:
12861         * docs/README:
12862         * docs/building-the-docs-on-debian:
12863           collect relevant bits of doc info
12864
12865 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12866
12867         * docs/pwg/advanced_tagging.xml:
12868           Half-assed commit so Thomas can re-arrange document IDs here to be
12869           consistent, too.
12870
12871 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12872
12873         * docs/manual/autoplugging.xml:
12874         * docs/manual/bins-api.xml:
12875         * docs/manual/bins.xml:
12876         * docs/manual/buffers-api.xml:
12877         * docs/manual/buffers.xml:
12878         * docs/manual/clocks.xml:
12879         * docs/manual/components.xml:
12880         * docs/manual/cothreads.xml:
12881         * docs/manual/debugging.xml:
12882         * docs/manual/dparams-app.xml:
12883         * docs/manual/dynamic.xml:
12884         * docs/manual/elements-api.xml:
12885         * docs/manual/elements.xml:
12886         * docs/manual/factories.xml:
12887         * docs/manual/gnome.xml:
12888         * docs/manual/goals.xml:
12889         * docs/manual/helloworld.xml:
12890         * docs/manual/helloworld2.xml:
12891         * docs/manual/init-api.xml:
12892         * docs/manual/intro.xml:
12893         * docs/manual/links-api.xml:
12894         * docs/manual/links.xml:
12895         * docs/manual/manual.xml:
12896         * docs/manual/motivation.xml:
12897         * docs/manual/pads-api.xml:
12898         * docs/manual/pads.xml:
12899         * docs/manual/plugins-api.xml:
12900         * docs/manual/plugins.xml:
12901         * docs/manual/programs.xml:
12902         * docs/manual/queues.xml:
12903         * docs/manual/quotes.xml:
12904         * docs/manual/schedulers.xml:
12905         * docs/manual/states-api.xml:
12906         * docs/manual/states.xml:
12907         * docs/manual/threads.xml:
12908         * docs/manual/typedetection.xml:
12909         * docs/manual/xml.xml:
12910           use chapter, part, section or misc as id starts for all bits
12911
12912 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12913
12914         * docs/gst/gstreamer-sections.txt:
12915           Fix up TITLE of the sections
12916
12917 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12918
12919         * docs/pwg/advanced_interfaces.xml:
12920           Add documentation on propertyprobing.
12921         * docs/pwg/advanced_events.xml:
12922         * docs/pwg/advanced_tagging.xml:
12923         * docs/pwg/building_boiler.xml:
12924         * docs/pwg/building_filterfactory.xml:
12925         * docs/pwg/pwg.xml:
12926           Move filterfactory and tagging into their own chapter, add a chapter
12927           on events. all these are empty placeholders that will be filled in
12928           some day.
12929
12930 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12931
12932         * docs/pwg/advanced_interfaces.xml:
12933           Docs for mixer interface. Also a check for website uploading.
12934
12935 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12936
12937         * docs/HACKING:
12938         * docs/Makefile.am:
12939         * docs/faq/Makefile.am:
12940         * docs/gst/Makefile.am:
12941         * docs/gst/tmpl/gstelement.sgml:
12942         * docs/gst/tmpl/gstplugin.sgml:
12943         * docs/gst/tmpl/gstreamer-unused.sgml:
12944         * docs/libs/Makefile.am:
12945         * docs/manual/Makefile.am:
12946         * docs/manuals.mak:
12947         * docs/pwg/Makefile.am:
12948         * docs/upload.mak:
12949           Separate out upload target and make it similar for
12950           both docbook and gtk-doc docs
12951
12952 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12953
12954         * docs/manuals.mak:
12955           Fix upload target to work with freedesktop
12956
12957 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12958
12959         * docs/pwg/advanced_types.xml:
12960           Add notes on creating your own types.
12961         * docs/pwg/building_boiler.xml:
12962         * docs/pwg/building_pads.xml:
12963         * docs/pwg/building_state.xml:
12964           Add some stuff about how to retrieve values from structures, how
12965           that relates to types and change layout slightly again to be almost
12966           perfect.
12967
12968 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12969
12970         * docs/pwg/advanced_dparams.xml:
12971         * docs/pwg/advanced_scheduling.xml:
12972           Change index layout slightly.
12973
12974 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12975
12976         * docs/pwg/advanced_clock.xml:
12977         * docs/pwg/advanced_interfaces.xml:
12978         * docs/pwg/advanced_midi.xml:
12979           General placeholders for now.
12980         * docs/pwg/advanced_request.xml:
12981           Explanation about sometimes and request pads.
12982         * docs/pwg/advanced_scheduling.xml:
12983           Concept of bytestream, loopfunctions and schedulers.
12984         * docs/pwg/building_boiler.xml:
12985           Add something about plugin-init.
12986
12987 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12988
12989         * docs/pwg/building_pads.xml:
12990           Fix broken docbook
12991
12992 2004-01-27  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12993
12994         * docs/pwg/advanced_interfaces.xml:
12995         * docs/pwg/pwg.xml:
12996           Add as a placeholder for future filling-in.
12997         * docs/pwg/basics_autoplugging.xml:
12998         * docs/pwg/basics_buffers.xml:
12999         * docs/pwg/basics_elements.xml:
13000         * docs/pwg/basics_events.xml:
13001         * docs/pwg/basics_plugins.xml:
13002         * docs/pwg/basics_types.xml:
13003           Remove, because unused (this is all in intro_basics.xml).
13004         * docs/pwg/building_signals.xml:
13005           Short intro to signals + reference to GObject docs - we really
13006           shouldn't go into these sort of things to deply because we don't
13007           use them that extensively anyway.
13008         * docs/pwg/building_state.xml:
13009           Explanation of states. Benjamin, please check.
13010         * docs/pwg/building_testapp.xml:
13011           Put everything in one page - putting only a few lines of content
13012           per page doesn't really make sense.
13013
13014           Time to get into the advanced topics. ;).
13015
13016 2004-01-27  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13017
13018         * docs/pwg/advanced_types.xml:
13019           Finish documenting the current state of mimetypes.
13020         * docs/pwg/building_boiler.xml:
13021         * docs/pwg/building_chainfn.xml:
13022         * docs/pwg/building_pads.xml:
13023         * docs/pwg/building_props.xml:
13024         * docs/pwg/building_testapp.xml:
13025           Start documenting the "how to build a simple audio filter" part
13026           of the PWG. Most stuff is ready by now. Stuff remaining: signals,
13027           states and (maybe?) a short introduction to capsnego in the chapter
13028           on pads (building_pads.xml). Capsnego should probably be explained
13029           fully in advanced_capsnego.xml or so.
13030
13031 2004-01-26  David Schleef  <ds@schleef.org>
13032
13033         * gst/gstpad.c: (gst_pad_try_set_caps_nonfixed):
13034         * gst/gstpad.h: Add new function to allow element to (somewhat)
13035         specify non-fixed caps on a pad.
13036         * gst/gstqueue.c: (gst_queue_chain): Remove noisy g_object_notify()
13037         that I added a few weeks ago.
13038
13039 2004-01-26  David Schleef  <ds@schleef.org>
13040
13041         * gst/gstpad.c: (gst_pad_try_set_caps): Revert last change
13042           making try_set_caps() work with non-fixed caps.
13043
13044 2004-01-26  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13045
13046         * docs/pwg/advanced_types.xml:
13047         * docs/pwg/intro_basics.xml:
13048         * docs/pwg/intro_preface.xml:
13049         * docs/pwg/pwg.xml:
13050         * docs/pwg/titlepage.xml:
13051           First try to resurrect the PWG. I'm halfway integrating the mimetypes
13052           in here (docs/random/mimetypes), and will from there on work on both
13053           updating outdated parts and adding missing parts.
13054           That doesn't mean I'll fix it completely, but I'll try at least. ;).
13055
13056 2004-01-26  Thomas Vander Stichele  <thomas at apestaart dot org>
13057
13058         * gst/gsterror.h: reinstate GST_LIBRARY_ERROR_ENCODE until
13059           policy is set
13060
13061 2004-01-26  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13062
13063         * gst/gstelement.h:
13064           remove gst_element_factory_get_version. It doesn't exist anymore.
13065         * gst/gstplugin.c:
13066         * gst/gstplugin.h:
13067           remove gst_plugin_set_name and change gst_plugin_get_longname to
13068           gst_plugin_get_description to match code.
13069         * gst/gsterror.h:
13070           remove GST_LIBRARY_ERROR_ENCODE. It's GST_STREAM_ERROR_ENCODE.
13071         * gst/gstpad.c: (gst_pad_try_set_caps):
13072           make it work with nonfixed caps.
13073           Note that even in the nonfixed case the link function of the pad
13074           that tries to set caps isn't called.
13075
13076 2004-01-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13077
13078         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
13079           fix bug where buffer was not assembled correctly
13080         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_init):
13081           silence by default
13082         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
13083           only seek if there's no more buffers that could work without seeking
13084
13085 2004-01-23  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13086
13087         * gst/gsttag.c: (_gst_tag_initialize):
13088         * gst/gsttag.h:
13089           Add application tag (for encoding/muxing app).
13090
13091 2004-01-23  Thomas Vander Stichele  <thomas at apestaart dot org>
13092
13093         * autogen.sh:
13094           make autopoint force, and libtoolize not copy
13095         * common/m4/as-docbook.m4:
13096           added docbook xml catalog setup check
13097         * common/m4/gst-doc.m4:
13098           use docbook check
13099
13100 2004-01-22  Thomas Vander Stichele  <thomas at apestaart dot org>
13101
13102         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_register):
13103         * gst/gsttag.h:
13104           add GstTagFlag
13105
13106 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13107
13108         * docs/gst/gstreamer-sections.txt:
13109         * docs/gst/tmpl/gst.sgml:
13110         * docs/gst/tmpl/gstbuffer.sgml:
13111         * docs/gst/tmpl/gstclock.sgml:
13112         * docs/gst/tmpl/gstelement.sgml:
13113         * docs/gst/tmpl/gstreamer-unused.sgml:
13114         * docs/gst/tmpl/gstxml.sgml:
13115           sync latest API changes to docs
13116
13117 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13118
13119         * gst/gstpluginfeature.c:
13120           fix doc snippet
13121         * tools/gst-inspect.c: (print_element_list):
13122           fix output of typefind
13123           add GPL header
13124         * tools/gst-launch.c:
13125           add GPL header
13126
13127 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13128
13129         * gst/elements/Makefile.am:
13130         * gst/elements/gstelements.c:
13131         * gst/elements/gsttypefindelement.c:
13132         * gst/elements/gsttypefindelement.h:
13133         * po/POTFILES.in:
13134         * po/fr.po:
13135         * po/nl.po:
13136           renamed gsttypefindelement to gsttypefind, conserving CVS history
13137
13138 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13139
13140         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_list_add_valist):
13141         * gst/gsttag.h:
13142           add some tags used in ogg as well
13143           fix _ in replaygain tags
13144
13145 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13146
13147         * gst/gsterror.h:
13148           fix wrong GST_LIBRARY_ERROR_ENCODE addition
13149
13150 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13151
13152         * gst/gstelement.c: (gst_element_error_full):
13153         * gst/gstelement.h:
13154           change _extended to _full
13155
13156 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13157
13158         reviewed by: <delete if not using a buddy>
13159
13160         * docs/gst/tmpl/gst.sgml:
13161         * docs/gst/tmpl/gstbuffer.sgml:
13162         * docs/gst/tmpl/gstclock.sgml:
13163         * docs/gst/tmpl/gstelement.sgml:
13164         * docs/gst/tmpl/gstreamer-unused.sgml:
13165         * docs/gst/tmpl/gstxml.sgml:
13166         * gst/gstelement.c: (gst_element_error_full):
13167         * gst/gstelement.h:
13168
13169 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13170
13171         * gst/gstelement.h: fix _gst_element_error_printf prototype
13172
13173 2004-01-20  David Schleef  <ds@schleef.org>
13174
13175         * gst/gststructure.c: (gst_structure_to_string):
13176         Convert function to use gst_value_serialize().
13177         * gst/gstvalue.c: (gst_value_serialize_list),
13178         (gst_value_serialize_fourcc), (gst_value_serialize_int_range),
13179         (gst_value_serialize_double_range), (gst_value_serialize_boolean),
13180         (gst_value_serialize_int), (gst_value_serialize_double),
13181         (gst_string_wrap), (gst_value_serialize_string),
13182         (gst_value_serialize), (gst_value_deserialize):
13183         * gst/gstvalue.h:
13184         Add implementations for serialize.
13185
13186 2004-01-20  Julien MOUTTE  <julien@moutte.net>
13187
13188         * gst/gsterror.h: xvidenc.c needs GST_LIBRARY_ERROR_ENCODE. Dunno if
13189         we want to keep that one in the future or change xvidenc.c to use 
13190         another error.
13191
13192 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13193
13194         * gst/gstelement.c: (_gst_element_error_printf):
13195         * gst/gstelement.h:
13196           privatise function
13197
13198 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13199
13200         * docs/random/error:
13201           doc explaining error system
13202         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
13203           cleanup
13204
13205 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13206
13207         * gst/gst-i18n-app.h:
13208         * gst/gst-i18n-lib.h:
13209           remove inclusion of config.h
13210         * po/POTFILES.in:
13211         * po/nl.po:
13212           add gst/gstelement.c
13213
13214 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13215
13216         * po/nl.po: updated Dutch translation
13217
13218 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13219
13220         * gst/gsterror.c: (_gst_core_errors_init),
13221         (_gst_library_errors_init), (_gst_resource_errors_init),
13222         (_gst_stream_errors_init):
13223         remove ending punctuation dots
13224
13225 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13226
13227         * gst/elements/gstfilesink.c: (gst_filesink_open_file):
13228         * gst/elements/gstfilesrc.c: (gst_filesrc_get_read):
13229         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
13230         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
13231         (gst_pipefilter_chain), (gst_pipefilter_open_file):
13232         use GST_ERROR_SYSTEM
13233
13234 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13235
13236         * gst/gstelement.c: (gst_element_error_printf),
13237         (gst_element_error_extended):
13238         * gst/gstelement.h:
13239           add a helper printf function so we can have NULL values passed.
13240
13241 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13242
13243         * gst/gstelement.h:
13244           add G_STMT macros to gst_element_error, which isn't strictly
13245           necessary but people tell me to anyway.
13246
13247 2004-01-18  Thomas Vander Stichele  <thomas at apestaart dot org>
13248
13249         * gst/Makefile.am:
13250         * gst/autoplug/gstspideridentity.c:
13251         (gst_spider_identity_sink_loop_type_finding):
13252         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
13253         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
13254         (gst_filesink_close_file), (gst_filesink_handle_event),
13255         (gst_filesink_chain):
13256         * gst/elements/gstfilesrc.c: (gst_filesrc_set_property),
13257         (gst_filesrc_map_region), (gst_filesrc_get_read),
13258         (gst_filesrc_open_file):
13259         * gst/elements/gstidentity.c: (gst_identity_chain):
13260         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
13261         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
13262         (gst_pipefilter_chain), (gst_pipefilter_open_file):
13263         * gst/elements/gsttypefindelement.c: (gst_type_find_element_chain):
13264         * gst/gst.h:
13265         * gst/gst_private.h:
13266         * gst/gstelement.c: (gst_element_class_init),
13267         (gst_element_default_error), (gst_element_error_func),
13268         (gst_element_error_extended):
13269         * gst/gstelement.h:
13270         * gst/gsterror.c: (_gst_core_errors_init),
13271         (_gst_library_errors_init), (_gst_resource_errors_init),
13272         (_gst_stream_errors_init), (gst_error_get_message):
13273         * gst/gsterror.h:
13274         * gst/gstinfo.c: (_gst_debug_init):
13275         * gst/gstmarshal.list:
13276         * gst/gstpad.c: (gst_pad_set_explicit_caps),
13277         (gst_pad_recover_caps_error), (gst_pad_pull):
13278         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
13279         * gst/schedulers/gstbasicscheduler.c:
13280         (gst_basic_scheduler_chainhandler_proxy),
13281         (gst_basic_scheduler_gethandler_proxy),
13282         (gst_basic_scheduler_cothreaded_chain):
13283         * po/POTFILES.in:
13284         * po/fr.po:
13285         * po/nl.po:
13286           change error signal
13287           add error categories
13288
13289 2004-01-18  Jeremy Simon  <jesimon@libertysurf.fr>
13290
13291         * gst/gsttag.c: (_gst_tag_initialize):
13292         * gst/gsttag.h:
13293         Add replaygain tag
13294
13295 2004-01-18  Colin Walters  <walters@verbum.org>
13296
13297         * examples/retag/retag.c: Call gst_init before processing
13298         program args.  Add g_assert to _link_many call.
13299
13300 2004-01-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13301
13302         * gst/gstpad.c: (gst_pad_alloc_buffer):
13303           Return a newly allocated buffer when the pad has no peer.
13304
13305 2004-01-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13306
13307         * gst/gstclock.c: (gst_clock_get_time):
13308           make it compile with gcc 2.95 again.
13309           Patch by Scott Wheeler
13310
13311 2004-01-15  David Schleef  <ds@schleef.org>
13312
13313         * gst/gstcaps.h:
13314         Added gst_caps_is_simple() macro.
13315         * testsuite/caps/caps.c: (test1):
13316         * testsuite/caps/intersect2.c: (main):
13317         * testsuite/caps/intersection.c: (main):
13318         Fixes to make 'make check' work again after removing
13319         gst_caps_is_chained().
13320
13321 2004-01-15  Leif Johnson <leif@ambient.2y.net>
13322
13323         * docs/random/uraeus/gstreamer_and_midi.txt: Rather large edits
13324         and additions to the MIDI document.
13325
13326 2004-01-15  David Schleef  <ds@schleef.org>
13327
13328         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered),
13329         (gst_element_link_pads_filtered): Use GST_PAD_ macros instead
13330         of GST_RPAD_, since we don't know if it's a real or ghost pad.
13331
13332 2004-01-15  David Schleef  <ds@schleef.org>
13333
13334         * gst/gstqueue.c:
13335         * gst/gstqueue.h:
13336         Fix the spelling of "treshold" and make min_threshold actually
13337         affect the queue.
13338
13339 2004-01-15  David Schleef  <ds@schleef.org>
13340
13341         * gst/gstcaps.c:
13342         Add lots of documentation.
13343         * gst/gstcaps.h:
13344         Deprecate a few functions.
13345         * gst/gstpad.c:
13346         Removed use of deprecated functions.
13347
13348 2004-01-15  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13349
13350         * gst/gstpad.c: (gst_pad_is_linked):
13351         * gst/gstpad.h:
13352           implement gst_pad_is_linked
13353         * gst/gstelement.h:
13354           reserve space for initiate_state_change
13355
13356 2004-01-15  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13357
13358         * gst/autoplug/gstspideridentity.c:
13359         (gst_spider_identity_sink_loop_type_finding):
13360           break infinite loop by just returning instead of looping
13361         * gst/gstclock.c: (gst_clock_class_init), (gst_clock_set_property):
13362           set event time difference correctly. Set it to 1 second instead
13363           of 100ms to be more tolerant
13364         * gst/gstelement.c: (gst_element_set_time):
13365           add debugging output
13366
13367 2004-01-14  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13368
13369         * gst/gstqueue.c: (gst_queue_getcaps), (gst_queue_link):
13370           query if buffers are inside the pool, ignore events
13371
13372 2004-01-13  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13373
13374         * gst/gstclock.c: (gst_clock_class_init), (gst_clock_init),
13375         (gst_clock_set_speed), (gst_clock_set_active),
13376         (gst_clock_is_active), (gst_clock_reset),
13377         (gst_clock_handle_discont):
13378         * gst/gstclock.h:
13379           deprecate old interface and disable functions that aren't in use
13380           anymore.
13381         * gst/gstelement.h:
13382         * gst/gstelement.c: (gst_element_get_time), (gst_element_wait),
13383         (gst_element_set_time), (gst_element_adjust_time):
13384           add concept of "element time" and functions to get/set this time.
13385         * gst/gstelement.c: (gst_element_change_state):
13386           update element time correctly.
13387         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered):
13388           This is a debug message, not a g_critical.
13389         * gst/gstpad.c: (gst_pad_event_default):
13390           handle discontinuous events right with element time.
13391         * gst/gstscheduler.c: (gst_scheduler_state_transition):
13392           update to clocking fixes.
13393           set clocks on elements in READY=>PAUSED. The old behaviour caused
13394           a wrong element time on the first element that started playing.
13395         * gst/schedulers/gstbasicscheduler.c:
13396         (gst_basic_scheduler_class_init):
13397         * gst/schedulers/gstoptimalscheduler.c:
13398         (gst_opt_scheduler_class_init):
13399           remove code that just implements the default behaviour.
13400         * gst/elements/gstfakesink.c: (gst_fakesink_chain):
13401           update to use new clocking functions
13402         * testsuite/clock/clock1.c: (gst_clock_debug), (main):
13403         * testsuite/clock/clock2.c: (gst_clock_debug), (main):
13404           update to test new element time.
13405         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_getcaps):
13406           use _get_allowed_caps instead of _get_caps. This catches filtered
13407           caps correctly.
13408         * testsuite/debug/commandline.c:
13409           update for new GST_DEBUG syntax.
13410         * testsuite/threads/Makefile.am:
13411           disable a test that only works sometimes.
13412
13413 2004-01-13  Julien MOUTTE <julien@moutte.net>
13414
13415         * po/LINGUAS: Adding fr.
13416         * po/fr.po: Adding french translation.
13417
13418 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13419
13420         * gst/parse/grammar.y:
13421         * po/POTFILES.in:
13422         * po/nl.po:
13423         * tools/gst-launch.c: (xmllaunch_parse_cmdline), (main):
13424           translate parsing error messages
13425
13426 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13427
13428         * po/POTFILES.in: adding gst-launch
13429         * po/nl.po: updated translation, all 99 strings translated
13430         * tools/gst-launch.c: (idle_func), (xmllaunch_parse_cmdline),
13431         (found_tag), (sigint_handler_sighandler), (play_handler), (main):
13432           fix strings for translation
13433
13434 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13435
13436         * gst/gst.c:
13437           - capitalize beginnings of popt options
13438           - fix strings for translation
13439           - change gst-debug format from =N1=V1:N2=V2 to =N1:V1,N2:V2
13440
13441 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13442
13443         * po/README: add some notes on how to update translations
13444
13445 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13446
13447         * ABOUT-NLS: removed, is autogenerated from autopoint
13448         * autogen.sh: add autopoint stuff
13449         * configure.ac: fix up gettext stuff
13450         * gst/Makefile.am: add i18n headers to noinst_HEADERS
13451         * gst/elements/gsttypefindelement.c: add header include
13452         * gst/gettext.h: add header, copy from system-installed header
13453         * gst/gst-i18n-app.h: to be included by each app having translations
13454         * gst/gst-i18n-lib.h: to be included by each lib having translations
13455         * gst/gst.c: (init_pre): fix up gettext calls
13456         * gst/gst_private.h: remove i18n stuff, moving to separate headers
13457         * po/LINGUAS: the new way to specify translations present
13458         * po/Makefile.in.in: removed from cvs, autogenerated from autopoint
13459         * po/Makevars: the variables filled in for GStreamer
13460         * po/POTFILES.in: added new files with translations
13461         * po/de.po: has new strings
13462         * po/nl.po: readded, has new strings
13463
13464 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13465
13466         * gst/gsttag.c: fix some strings marked for translation
13467
13468 2004-01-13  Iain <iain@prettypeople.org>
13469
13470         * gst/schedulers/gstoptimalscheduler.c (add_to_group): Reference the
13471         group when we add an element to it, cos we unref it when we remove one
13472
13473 2004-01-12  Thomas Vander Stichele  <thomas at apestaart dot org>
13474
13475         * testsuite/debug/commandline.c: (debug_not_reached):
13476         * testsuite/debug/output.c: (check_message):
13477           fix testsuite
13478
13479 2004-01-12  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13480
13481         * examples/cutter/.cvsignore:
13482         * examples/helloworld/.cvsignore:
13483         * examples/launch/.cvsignore:
13484         * examples/manual/.cvsignore:
13485         * examples/mixer/.cvsignore:
13486         * examples/pingpong/.cvsignore:
13487         * examples/plugins/.cvsignore:
13488         * examples/queue/.cvsignore:
13489         * examples/queue2/.cvsignore:
13490         * examples/queue3/.cvsignore:
13491         * examples/queue4/.cvsignore:
13492         * examples/retag/.cvsignore:
13493         * examples/thread/.cvsignore:
13494         * examples/typefind/.cvsignore:
13495         * examples/xml/.cvsignore:
13496         * gst/.cvsignore:
13497         * gst/autoplug/.cvsignore:
13498         * gst/elements/.cvsignore:
13499         * gst/indexers/.cvsignore:
13500         * gst/parse/.cvsignore:
13501         * gst/registries/.cvsignore:
13502         * gst/schedulers/.cvsignore:
13503         * libs/gst/bytestream/.cvsignore:
13504         * libs/gst/control/.cvsignore:
13505         * libs/gst/getbits/.cvsignore:
13506         * tests/.cvsignore:
13507         * tests/bufspeed/.cvsignore:
13508         * tests/instantiate/.cvsignore:
13509         * tests/memchunk/.cvsignore:
13510         * tests/muxing/.cvsignore:
13511         * tests/sched/.cvsignore:
13512         * tests/seeking/.cvsignore:
13513         * tests/threadstate/.cvsignore:
13514         * testsuite/.cvsignore:
13515         * testsuite/caps/.cvsignore:
13516         * testsuite/cleanup/.cvsignore:
13517         * testsuite/dynparams/.cvsignore:
13518         * testsuite/plugin/.cvsignore:
13519         * tools/.cvsignore:
13520           update - this is huge, because it includes *.bb, *.bbg and *.da files
13521           which are generated for gcov.
13522
13523 2004-01-11  David Schleef  <ds@schleef.org>
13524
13525         * gst/gststructure.c: (gst_strtoi), (gst_value_from_string): Add
13526         a function to parse integers in ways that strto[u]l() does not.
13527
13528 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13529
13530         * tools/gst-inspect.c: (print_caps):
13531           improve output of caps a bit
13532
13533 2004-01-11  David Schleef  <ds@schleef.org>
13534
13535         * gst/gstbuffer.c: (gst_buffer_create_sub): Subbuffers should
13536         inherit correct flags (READONLY and DONTKEEP).
13537
13538 2004-01-11  David Schleef  <ds@schleef.org>
13539
13540         * gst/elements/gstfilesrc.c: (gst_filesrc_free_parent_mmap),
13541         (gst_filesrc_map_region):
13542         * gst/gstbuffer.c: (_gst_buffer_initialize),
13543         (_gst_buffer_sub_free), (gst_buffer_default_copy),
13544         (gst_buffer_new), (gst_buffer_create_sub),
13545         (gst_buffer_is_span_fast), (gst_buffer_span):
13546         * gst/gstbuffer.h:
13547         Change GstBuffer private structure element names. (all files)
13548         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
13549         (gst_queue_link):
13550         * gst/gstqueue.h:
13551         Implement getcaps/pad_link functions that handle the case where
13552         there are data in the queue.
13553
13554 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13555
13556         * gst/elements/gstbufferstore.c:
13557           initialize debugging structure correctly
13558         * gst/elements/gsttee.c: (gst_tee_set_property):
13559           g_object_notify when property was changed
13560         * gst/elements/gsttypefindelement.c:
13561         (gst_type_find_element_change_state):
13562           clear caps correctly
13563
13564 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13565
13566         * gst/gstqueue.c: (gst_queue_init):
13567           Use better defaults for when a queue should block. This
13568           gets rid of jerky playback for quite a few files.
13569           It takes more memory.
13570
13571 2004-01-10  Thomas Vander Stichele  <thomas at apestaart dot org>
13572
13573         (gst_xml_registry_parse_padtemplate):
13574           make critical message slightly more useful
13575
13576 2004-01-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13577
13578         * gst/gstinfo.c: (gst_debug_log), (gst_debug_log_valist),
13579         (gst_debug_message_get), (gst_debug_log_default):
13580         * gst/gstinfo.h:
13581           Change gst_debug_log(_valist) to take a const format string.
13582           Change prototype of log function and functions using those to 
13583           take a GstDebugMessage instead of a string that requires using
13584           gst_debug_message_get.
13585
13586 2004-01-08  David Schleef  <ds@schleef.org>
13587
13588         * Makefile.am:
13589         * configure.ac:
13590         Add option --enable-gcov to build GStreamer with -fprofile-arcs
13591         and -ftest-coverage, which allows gcov to show information about
13592         testsuite coverage.
13593
13594 2004-01-08  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13595
13596         * gst/gstutils.h:
13597           Add GST_BOILERPLATE(_FULL), GST_PARENT_CALL and
13598           GST_PARENT_CALL_WITH_DEFAULT
13599         * gst/elements/gstaggregator.c: 
13600         * gst/elements/gstbufferstore.c: 
13601         * gst/elements/gstfakesink.c: 
13602         * gst/elements/gstfakesrc.c: 
13603         * gst/elements/gstfdsink.c: 
13604         * gst/elements/gstfdsrc.c: 
13605         * gst/elements/gstfilesink.c: 
13606         * gst/elements/gstfilesrc.c: 
13607         * gst/elements/gstidentity.c: 
13608         * gst/elements/gstmd5sink.c: 
13609         * gst/elements/gstmultidisksrc.c:
13610         * gst/elements/gstpipefilter.c: 
13611         * gst/elements/gstshaper.c:
13612         * gst/elements/gststatistics.c:
13613         * gst/elements/gsttee.c:
13614         * gst/elements/gsttypefindelement.c:
13615           use them.
13616
13617 2004-01-07  Thomas Vander Stichele  <thomas at apestaart dot org>
13618
13619         * docs/gst/gstreamer-docs.sgml: remove props
13620         * docs/gst/gstreamer-sections.txt: remove props
13621         * docs/gst/tmpl/gst.sgml:
13622         * docs/gst/tmpl/gstbin.sgml:
13623         * docs/gst/tmpl/gstbuffer.sgml:
13624         * docs/gst/tmpl/gstcaps.sgml:
13625         * docs/gst/tmpl/gstclock.sgml:
13626         * docs/gst/tmpl/gstelement.sgml:
13627         * docs/gst/tmpl/gstindex.sgml:
13628         * docs/gst/tmpl/gstobject.sgml:
13629         * docs/gst/tmpl/gstpad.sgml:
13630         * docs/gst/tmpl/gstpadtemplate.sgml:
13631         * docs/gst/tmpl/gstreamer-unused.sgml:
13632         * docs/gst/tmpl/gstthread.sgml:
13633         * docs/gst/tmpl/gstxml.sgml:
13634           sync with code reorganization
13635
13636 2004-01-07  Jan Schmidt  <thaytan@mad.scientist.com>
13637
13638         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered):
13639         Make the 'Could not find compatible pad' message more informative.
13640
13641 2004-01-07  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13642                                                                                 
13643         * gst/elements/gstfilesink.c: (gst_filesink_set_location):
13644           Fix for if we pass NULL as property to location.
13645         * gst/elements/gstpipefilter.c: (gst_pipefilter_init),
13646         (gst_pipefilter_handle_event), (gst_pipefilter_chain):
13647           Fix for instantiate-test (see below).
13648         * gst/gststructure.c: (_gst_structure_parse_value):
13649           Fix compile error on gcc-2.96.
13650         * configure.ac:
13651         * tests/Makefile.am:
13652         * tests/instantiate/Makefile.am:
13653         * tests/instantiate/create.c: (create_all_elements), (main):
13654           Add a test that instantiates all elements. This makes it easy to
13655           track dead code for old API/design (like setting event functions
13656           on sink pads and so on).
13657
13658 2004-01-06  Jan Schmidt  <thaytan@mad.scientist.com>
13659
13660         * gst/gstcaps.c: (gst_caps_append_structure):
13661           Move the poisoning to allow a NULL structure
13662         * gst/gstevent.c: (_gst_event_free):
13663           When freeing a navigation event, free the structure
13664           also
13665
13666 2004-01-04  David Schleef  <ds@schleef.org>
13667
13668         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_request_new_pad):
13669         Remove usage of gst_pad_proxy_fixate.
13670         * gst/gstcaps.c: (gst_caps_append), (gst_caps_append_structure),
13671         (gst_caps_split_one), (gst_caps_replace):
13672         Add poisoning code.
13673         * gst/gstmarshal.list:
13674         Add pointer__pointer for fixate signal
13675         * gst/gstpad.c: (gst_real_pad_class_init),
13676         (_gst_real_pad_fixate_accumulator), (gst_pad_link_fixate),
13677         (_gst_pad_default_fixate_func), (gst_pad_proxy_fixate),
13678         (gst_pad_set_explicit_caps), (gst_pad_template_new):
13679         Add poisoning code. Add fixate signal on RealPad. Change
13680         set_explicit_caps() to take const GstCaps, like try_set_caps().
13681         * gst/gstpad.h:
13682         * testsuite/caps/Makefile.am:
13683         * testsuite/caps/app_fixate.c: Add a test for the fixate signal
13684
13685 2004-01-03  David Schleef  <ds@schleef.org>
13686
13687         * gst/elements/gsttypefindelement.c:
13688         (gst_type_find_element_have_type), (gst_type_find_element_init):
13689         Use gst_pad_use_explicit_caps for src pad.
13690         * gst/gstpad.c: (gst_pad_try_set_caps):  Check that link exists
13691         before using it.
13692
13693 2004-01-03  David Schleef  <ds@schleef.org>
13694
13695         * gst/gstelement.c: (gst_element_link_pads_filtered),
13696         (gst_element_negotiate_pads): Fix to allow DELAYED to indicate
13697         that linking was successful.
13698         * gst/gstpad.c: (gst_pad_link_free),
13699         (gst_pad_link_call_link_functions), (gst_pad_link_negotiate),
13700         (gst_pad_link_try), (gst_pad_link_unnegotiate),
13701         (gst_pad_unnegotiate), (gst_pad_set_explicit_caps): Pass
13702         GstPadLinkReturn correctly between functions, and don't fail
13703         when DELAYED is used (DELAYED is very important).  Better
13704         cleanup on unlinking and unnegotiation.  Should fix some spider
13705         bugs.
13706
13707 2004-01-02  David Schleef  <ds@schleef.org>
13708
13709         * gst/gstelement.c: (gst_element_class_init),
13710         (gst_element_base_class_init): ->padtemplates should be cleared
13711         in base_init, since we need to have a fresh list for every
13712         class.  (Alternately, we chould copy the list and share the
13713         actual pad templates (not the list), but that would require
13714         changing every plugin to move pad template registration from
13715         base_init to class_init.)
13716
13717 2004-01-03  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13718
13719         * gst/gstelement.c: (gst_element_class_add_pad_template):
13720           Refuse registering a pad template if another pad template
13721           with the same name already exists (#114715).
13722
13723 2004-01-02  David Schleef  <ds@schleef.org>
13724
13725         * gst/gstcaps.c: (_gst_structure_is_equal_foreach),
13726         (gst_caps_is_equal_fixed): Add new function.
13727         * gst/gstcaps.h: ditto.
13728         * gst/gstpad.c: (gst_real_pad_class_init),
13729         (gst_pad_link_call_link_functions), (gst_pad_try_set_caps),
13730         (gst_pad_set_explicit_caps), (gst_pad_get_caps):  In try_set_caps,
13731         check new caps against existing caps -- if they're the same, return
13732         OK without renegotiating.  caps-nego-failed signal fixed so that
13733         the marshaller isn't VOID__OBJECT.  Also changed to G_TYPE_POINTER
13734         to save an extra caps copy.  Don't complete negotiation if a pad
13735         link function returns DELAYED.
13736
13737 2004-01-02  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13738
13739         * gst/gstpad.c: (gst_pad_try_relink_filtered):
13740           Fix wrong g_return_if_fail
13741
13742 2004-01-03  Jan Schmidt  <thaytan@mad.scientist.com>
13743
13744         * gst/gstbin.c: (gst_bin_class_init):
13745         Change the marshalling of element_added/element_removed
13746         to use gst_marshal_VOID__OBJECT, since gst_marshal_VOID__POINTER 
13747         complains that GST_TYPE_ELEMENT is not G_TYPE_POINTER
13748
13749 2004-01-01  David Schleef  <ds@schleef.org>
13750
13751         * gst/gstpad.c: (gst_pad_set_explicit_caps),
13752         (gst_pad_explicit_getcaps), (gst_pad_explicit_link),
13753         (gst_pad_use_explicit_caps):
13754         * gst/gstpad.h:
13755         Add new functions.  gst_pad_use_explicit_caps() sets up a pad
13756         to use an internal getcaps and link fuction so that negotiation
13757         always results in the explicitly set caps.
13758         gst_pad_set_explicit_caps() sets the explicit caps.  These functions
13759         are particularly useful for decoders.
13760
13761 2003-12-31  David Schleef  <ds@schleef.org>
13762
13763         * gst/elements/gstidentity.c: (gst_identity_class_init),
13764         (gst_identity_init), (gst_identity_chain),
13765         (gst_identity_set_property), (gst_identity_get_property):
13766         * gst/elements/gstidentity.h:
13767         * gst/gstqueue.c: (gst_queue_init):
13768           Negotiation fixes.
13769
13770 2003-12-31  David Schleef  <ds@schleef.org>
13771
13772         * gst/gstcaps.c: (gst_caps_intersect),
13773         (_gst_caps_normalize_foreach), (gst_caps_normalize):
13774           Implement gst_caps_normalize().
13775         * testsuite/caps/normalisation.c: (main):
13776           Add an additional test
13777
13778 2003-12-31  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13779
13780         * gst/gstqueue.c: (gst_queue_init):
13781           use gst_pad_proxy_getcaps()
13782
13783 2003-12-31  David Schleef  <ds@schleef.org>
13784
13785         * gst/elements/gstshaper.c: (gst_shaper_link):
13786         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_request_new_pad):
13787         * gst/gstqueue.c: (gst_queue_link):
13788           Negotiation fixes.
13789
13790 2003-12-31  David Schleef  <ds@schleef.org>
13791
13792         * gst/gstpad.c: (gst_pad_proxy_pad_link), (gst_pad_proxy_fixate):
13793         * gst/gstpad.h: Add functions that are useful as default pad
13794         link and fixate functions for elements.
13795
13796 2003-12-30  David Schleef  <ds@schleef.org>
13797
13798         * gst/gstpad.c: (gst_pad_link_try):
13799           Fix segfault when attempting to return to old caps
13800
13801 2003-12-29  David Schleef  <ds@schleef.org>
13802
13803         * gst/gstcaps.c: (gst_caps_normalize), (simplify_foreach),
13804         (gst_caps_structure_simplify), (gst_caps_simplify):
13805         * gst/gstcaps.h:
13806           Add simplify function
13807         * gst/gstpad.c: (gst_pad_link_try), (gst_pad_try_set_caps),
13808         (gst_pad_perform_negotiate), (gst_pad_is_negotiated):
13809         * gst/gstpad.h:
13810           Copy over srcnotify, sinknotify when calling old pad_link
13811           functions.  Add new is_negotiated() function.
13812         * gst/gststructure.c: (gst_structure_copy):
13813           Fix an incredibly stupid bug that should have been noticed
13814           weeks ago.  _copy() returned the argument, not the new copy.
13815
13816 2003-12-27  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13817
13818         * gst/gstcaps.c: (gst_caps_append):
13819           add sanity checks
13820         * gst/gstcaps.h: (gst_caps_debug):
13821           remove, it doesn't exist anymore.
13822         * gst/gstelement.c: (gst_element_threadsafe_properties_pre_run),
13823         (gst_element_threadsafe_properties_post_run):
13824           make debugging messages not clutter up THREAD debug category
13825         (gst_element_negotiate_pads), (gst_element_clear_pad_caps),
13826         (gst_element_change_state):
13827           update to new caps API
13828         * gst/gstinterface.c: (gst_implements_interface_cast):
13829           don't put vital code in g_return_if_fail
13830         * gst/gstpad.c: (gst_pad_link_try), (gst_pad_try_set_caps), 
13831         (gst_pad_link_filtered):
13832           add pst_pad_try_link and use it.
13833         (gst_pad_perform_negotiate), (gst_pad_renegotiate):
13834           implement correctly, deprecate first one.
13835         (gst_pad_link_unnegotiate), (gst_pad_unnegotiate):
13836           add and implement.
13837         (gst_pad_try_relink_filtered), (gst_pad_relink_filtered):
13838           implement.
13839         (gst_pad_get_negotiated_caps):
13840           add and implement. Make GST_PAD_CAPS call this function.
13841         (gst_pad_get_caps):
13842           remove unneeded check..
13843         (gst_pad_recover_caps_error):
13844           disable, always return FALSE.
13845         (gst_real_pad_dispose):
13846           don't free caps and appfilter anymore, they're unused.
13847         * gst/gstpad.h:
13848           Reflect changes mentioned above.
13849         * gst/gstsystemclock.c: (gst_system_clock_wait):
13850           Make 'clock is way behind' a debugging message.
13851         * gst/gstthread.c: (gst_thread_change_state):
13852           Fix debugging message
13853
13854 2003-12-25  Thomas Vander Stichele  <thomas at apestaart dot org>
13855
13856         * gst/gstinfo.h:
13857           fix GST_DEBUG_CATEGORY_INIT gtk-doc description
13858         * docs/gst/tmpl/gstreamer-unused.sgml:
13859           removed all traces of cvs conflicts
13860
13861 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
13862
13863         * configure.ac:
13864         * gst/schedulers/cothreads_compat.h:
13865         * libs/Makefile.am:
13866           remove last instances of wingo cothread usage
13867
13868 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
13869
13870         * gst/gstplugin.c:
13871         * gst/gstversion.h.in:
13872         * gst/parse/grammar.y:
13873           change comment block from /** to /* when not gtk-doc comments
13874
13875 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
13876
13877         * gst/gst.c: whitespace and doc style fixes
13878
13879 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
13880
13881         * gst/gstformat.h: remove trailing whitespace from enum for gtk-doc
13882
13883 2003-12-24  Colin Walters  <walters@verbum.org>
13884
13885         * gst/elements/gsttypefindelement.c:
13886           gst/elements/gsttypefindelement.h: Make GstCaps parameter const.
13887           Copy caps parameter. Use _POINTER to marshal caps instead of _BOXED.
13888           Don't double-free caps.
13889
13890 2003-12-23  David Schleef  <ds@schleef.org>
13891
13892         * gst/gstelement.c, gst/gstpad.c, gst/parse/grammar.y,
13893           gst/gstcaps.c, gst/autoplug/gstspideridentity.c:
13894           Many little fixes and additions of debug statements to
13895           get rhythmbox working.
13896
13897 2003-12-23  Colin Walters  <walters@verbum.org>
13898
13899         * gst/autoplug/gstspideridentity.c (gst_spider_identity_sink_loop_type_finding):
13900         Use GST_PAD_LINK_SUCCESSFUL.
13901
13902 2003-12-23  David Schleef  <ds@schleef.org>
13903
13904         * gst/elements/gstaggregator.c:
13905         * gst/elements/gsttee.c:
13906           Use gst_pad_proxy_getcaps().
13907         * gst/gstpad.c:
13908         * gst/gstpad.h:
13909           Add gst_pad_proxy_getcaps(), which filter elements can use
13910           as a generic getcaps implementation.
13911           Fix gst_pad_get_allowed_caps().  It just wasn't doing what
13912           was advertised.
13913
13914 2003-12-23  David Schleef  <ds@schleef.org>
13915
13916         * gst/gstpad.c:
13917           Rearrange/rewrite much of the pad negotiation code, since it
13918           resembled pasta.  This actually changes the way some
13919           negotiation works, since the previous code was inconsistent
13920           depending on how it was invoked.  Add (internal) structure
13921           GstPadLink, which is used to hold some information (more in
13922           the future) about the link between two pads.  Fixes a number
13923           of bugs, including random lossage of filter caps when the
13924           initial negotiation is delayed.  A few functions are still
13925           unimplemented.
13926         * gst/gstpad.h:
13927           Add GST_PAD_LINK_{SUCESSFUL|FAILED}() macros.  Please use
13928           these when testing GstPadLinkReturn values instead of comparing
13929           directly.
13930
13931 2003-12-23  David Schleef  <ds@schleef.org>
13932
13933         * gst/gstvalue.c: 
13934         * gst/gstvalue.h:
13935           Rearrange lots of code.  Change registration of compare function
13936           into registration of compare/serialize/deserialize functions.
13937           Doesn't include implementation of gst_value_[de]serialize(),
13938           but that should be easy.
13939
13940 2003-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
13941
13942         * docs/gst/gstreamer-sections.txt:
13943         * docs/gst/tmpl/gstprops.sgml: removed
13944         * docs/gst/tmpl/gstreamer-bufferpool.sgml: removed
13945           David removed props and caps code, so let's remove their docs as well.
13946           Removed all no longer existing symbols from gstreamer-sections.txt
13947           
13948 2003-12-22  Colin Walters  <walters@verbum.org>
13949
13950         * gst/gsttaginterface.c, gst/gsttaginterface.h,
13951           gst/gsttag.c, gst/gsttag.h:  Add interface to setting GValues
13952           of tags directly.
13953
13954 2003-12-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13955
13956         * gst/elements/gstelements.c:
13957           Set ranks of elements to NONE, so the autoplugger doesn't use them.
13958         * gst/elements/gstshaper.c: (gst_shaper_getcaps):
13959           Fix proxying to new CAPS stuff. Don't call get_allowed_caps but
13960           gst_caps (peer).
13961
13962 2003-12-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13963
13964         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_caps_intersect):
13965         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link),
13966         (gst_spider_identity_getcaps), (gst_spider_identity_change_state),
13967         (gst_spider_identity_sink_loop_type_finding):
13968         * gst/autoplug/gstspideridentity.h:
13969           Fix autoplugging in spider element, so it works with new caps.
13970           This was mainly caused by identifying empty caps incorrectly.
13971
13972 2003-12-22  David Schleef  <ds@schleef.org>
13973
13974         * gststructure.c, gstvalue.c, gstvalue.h: Add
13975           gst_value_init_and_copy() and use it, to avoid silly mistakes in
13976           using g_value_copy()
13977
13978 2003-12-21  David Schleef  <ds@schleef.org>
13979
13980         * many, many files: Merge CAPS branch.  This includes:
13981           - implemention of GstValue and several GstValue types
13982           - implemention of GstStructure
13983           - entire rewrite of GstCaps
13984           - removal of GstProps
13985           - many changes to GstPad to compensate for new caps paradigm
13986           - removal of GstBufferpool
13987         * gst/Makefile.am, gst/gst.h, gst/gstpad.h, gst/gsttypefind.h,
13988         gstvalue.h, gst/gstcaps[2]*.[ch]:
13989           - rename gstcaps2.[ch] to gstcaps.[ch]
13990
13991 2003-12-21  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13992
13993         * gst/gstqueue.c: (gst_queue_handle_pending_events),
13994         (gst_queue_chain), (gst_queue_handle_src_event):
13995           implement timeout for sending events. Workaround for if the
13996           pipeline on this queue is not passing any data.
13997
13998 2003-12-21  Ronald Bultje <rbultje@ronald.bitfreak.net>
13999                                                                                 
14000         * ChangeLog: moved to gstreamer/docs/random/old/ChangeLog.gstreamer
14001         * moved CVS to freedesktop.org