check/gst/gstevents.c: Fix error message output so I might be able to tell why the...
[platform/upstream/gstreamer.git] / ChangeLog
1 2005-08-18  Jan Schmidt  <thaytan@mad.scientist.com>
2
3         * check/gst/gstevents.c: (GST_START_TEST), (event_probe),
4         (test_event), (timediff), (gstevents_suite):
5            Fix error message output so I might be able to tell why the
6            test works here but fails on the build farm.
7
8 2005-08-18  Jan Schmidt  <thaytan@mad.scientist.com>
9
10         * check/Makefile.am:
11         * check/gst/gstevents.c: (GST_START_TEST), (event_probe),
12         (test_event), (timediff), (gstevents_suite), (main):
13           I wrote a test!
14
15         * docs/design/part-seeking.txt:
16           Spelling correction
17
18         * docs/gst/tmpl/gstevent.sgml:
19         * docs/gst/tmpl/gstfakesrc.sgml:
20           Docs updates.
21
22         * gst/base/gstbasesink.c: (gst_base_sink_handle_object):
23           Treat a buffer-without-newsegment the same as a receiving 
24           a newsegment not in time format, and disable syncing to the clock
25           with a warning.
26
27         * gst/gstbus.c: (gst_bus_set_sync_handler):
28           Assert if anyone tries to replace the existing sync_handler for bus, 
29           as only the owner should be setting it.
30
31         * gst/gstevent.h:
32           Have a fixed set of custom event enums with events identified by
33           their structure name (as in 0.8), rather than a free-for-all
34           allowing collisions between enum values from different plugins.
35
36         * gst/gstpad.c: (gst_pad_class_init):
37           Docs change.
38           
39         * gst/gstqueue.c: (gst_queue_handle_sink_event):
40           Handle out-of-band downstream events from the sending thread.
41
42 2005-08-17  Andy Wingo  <wingo@pobox.com>
43
44         * gst/gstpipeline.c (gst_pipeline_change_state): Interpret
45         play-timeout==0 to mean no timeout at all. In that case, don't
46         bother with a get_state or a warning, just return directly, even
47         if it's ASYNC.
48
49         * gst/base/gstbasetransform.c: Debug changes.
50
51         * gst/gstutils.h:
52         * gst/gstutils.c (gst_bin_watch_for_state_change): Add function to
53         ensure bins post state change messages. A bit of a hack but I can't
54         think of a way to avoid it.
55
56         * check/gst/gstbin.c (test_watch_for_state_change): Added test.
57
58 2005-08-16  Andy Wingo  <wingo@pobox.com>
59
60         * gst/base/gstadapter.h:
61         * gst/base/gstadapter.c (gst_adapter_take): New function, like
62         peek() but you own the data. Not terribly efficient atm.
63
64 2005-08-16  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
65
66         * gst/gstutils.c: (gst_element_found_tags_for_pad), (push_and_ref),
67         (gst_element_found_tags):
68         * gst/gstutils.h:
69           Add two utility functions for tag handling.
70
71 2005-08-16  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
72
73         * docs/manual/advanced-dataaccess.xml:
74         * docs/manual/basics-helloworld.xml:
75           Fix docs to use _bin_add() before _link(), which fixes the examples
76           with recent core versions (reported by Madhan Raj M
77           <raj_madan@rediffmail.com>, #313199).
78
79 2005-08-16  Wim Taymans  <wim@fluendo.com>
80
81         * check/gst/gstvalue.c: (GST_START_TEST), (gst_value_suite):
82         Added subtract checks.
83
84         * docs/design/part-events.txt:
85         Some more docs about newsegment
86
87         * gst/gstbin.c: (gst_bin_change_state), (bin_bus_handler):
88         Fix FIXME
89
90         * gst/gstcaps.c: (gst_caps_to_string):
91         Add comments, cleanups.
92         
93         * gst/gstelement.c: (gst_element_save_thyself):
94         cleanups
95         
96         * gst/gstvalue.c: (gst_value_collect_int_range),
97         (gst_string_unwrap), (gst_value_union_int_int_range),
98         (gst_value_union_int_range_int_range),
99         (gst_value_intersect_int_int_range),
100         (gst_value_intersect_int_range_int_range),
101         (gst_value_intersect_double_double_range),
102         (gst_value_intersect_double_range_double_range),
103         (gst_value_intersect_list), (gst_value_subtract_int_int_range),
104         (gst_value_subtract_int_range_int),
105         (gst_value_subtract_double_range_double),
106         (gst_value_subtract_double_range_double_range),
107         (gst_value_subtract_from_list), (gst_value_subtract_list),
108         (gst_value_can_compare), (gst_value_compare_fraction):
109         Cleanups, add comments, remove unneeded asserts.
110
111 2005-08-15  Thomas Vander Stichele  <thomas at apestaart dot org>
112
113         * tools/gst-launch.c: (event_loop):
114           don't convert NULL structures to strings
115
116 2005-08-15  Stefan Kost  <ensonic@users.sf.net>
117
118         * docs/gst/gstreamer-sections.txt:
119           made some defines private
120         * docs/gst/tmpl/gstconfig.sgml:
121         * docs/gst/tmpl/gstqueue.sgml:
122         * docs/gst/tmpl/gsttaglist.sgml:
123         * docs/gst/tmpl/gsttypes.sgml:
124         * docs/gst/tmpl/gstutils.sgml:
125         * docs/pwg/appendix-porting.xml:
126         * gst/base/gstbasesink.h:
127         * gst/base/gstbasesrc.c:
128         * gst/base/gstbasesrc.h:
129         * gst/elements/gstfakesink.c: (gst_fake_sink_class_init):
130         * gst/elements/gstfakesrc.c: (gst_fake_src_class_init):
131         * gst/gstelement.c: (gst_element_class_init):
132         * gst/gstpad.c: (gst_pad_class_init):
133         * gst/gstqueue.c: (gst_queue_class_init):
134         * gst/gstxml.c: (gst_xml_class_init):
135           documented all undocumented signal inline
136         * libs/gst/controller/gst-controller.h:
137           added padding
138
139 2005-08-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
140
141         * docs/pwg/appendix-porting.xml:
142           Document _set_link_function -> _set_setcaps_function.
143
144 2005-08-15  Thomas Vander Stichele  <thomas at apestaart dot org>
145
146         * check/Makefile.am:
147           add a .check target for running the check
148         * check/gst-libs/controller.c: (GST_START_TEST):
149           cosmetic fixups
150         * check/gst/gstbuffer.c: (GST_START_TEST), (gst_test_suite):
151           complete checks for gstbuffer; would be nice if I could get the
152           gcov stuff to work so I can see if I actually completed gstbuffer.c
153         * check/gstcheck.h:
154           add ASSERT_BUFFER_REFCOUNT
155
156 2005-08-13  Tim-Philipp Müller  <tim at centricular dot net>
157
158         * docs/gst/gstreamer-sections.txt:
159         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_register):
160         * gst/gsttag.h:
161           Add GST_TAG_LANGUAGE_CODE as we have in 0.8, and don't
162           spew out a warning if a tag that is already registered
163           is re-registered, unless it is re-registered with a 
164           different type (#308438).
165
166 2005-08-12  Tim-Philipp Müller  <tim at centricular dot net>
167
168         * docs/pwg/appendix-porting.xml:
169         * docs/pwg/building-state.xml:
170           Add some paragraphs about state changes in 0.9 to the PWG
171           and the porting guide, in particular about the new meaning
172           of GST_STATE_PAUSED and how to write state change functions
173           with concurrent access by multiple threads in mind.
174
175 2005-08-11  Stefan Kost  <ensonic@users.sf.net>
176
177         * docs/gst/gstreamer-docs.sgml:
178         * docs/libs/gstreamer-libs-docs.sgml:
179           added deprecation and since indexes
180         * libs/gst/controller/gst-controller.c:
181         * libs/gst/controller/gst-helper.c:
182           added since tags
183
184
185 2005-08-11  Wim Taymans  <wim@fluendo.com>
186
187         * gst/gstghostpad.c: (gst_proxy_pad_set_target_unlocked),
188         (gst_proxy_pad_set_target), (gst_proxy_pad_get_target),
189         (gst_proxy_pad_dispose), (gst_ghost_pad_do_activate_push),
190         (gst_ghost_pad_do_link), (gst_ghost_pad_set_internal),
191         (gst_ghost_pad_new_notarget), (gst_ghost_pad_get_target),
192         (gst_ghost_pad_set_target):
193         Actually implement (re)setting the target on a ghostpad
194         as described in the docs.
195
196 2005-08-10  Tim-Philipp Müller  <tim at centricular dot net>
197
198         * gst/gst.c: (gst_init_check_with_popt_table), (init_pre):
199           Check whether GST_DEBUG_NO_COLOR environment variable is
200           set and disable coloured debug output if that is the case.
201
202 2005-08-10  Tim-Philipp Müller  <tim at centricular dot net>
203
204         * gst/base/gsttypefindhelper.c: (helper_find_peek),
205         (gst_type_find_helper):
206           The memory returned by gst_type_find_peek() needs to
207           stay valid until the end of a typefind function, and
208           typefind functions may keep results from different 
209           offsets around, so we can't just unref the buffer from
210           the previous _peek(), but have to save all buffers 
211           returned by _peek() until typefinding is done and only
212           free them then.
213
214 2005-08-09  Tim-Philipp Müller  <tim at centricular dot net>
215
216         * docs/gst/gstreamer-sections.txt:
217         * gst/gstutils.h:
218           New macros: GST_ROUND_UP_2() through GST_ROUND_UP_64().
219
220 2005-08-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
221
222         * gst/base/gstbasetransform.c: (gst_base_transform_buffer_alloc):
223           Fix a pretty good memleak.
224
225 2005-08-08  Tim-Philipp Müller  <tim at centricular dot net>
226
227         * gst/gstiterator.h:
228           Fix wrong include and 'make distcheck'.
229
230 2005-08-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
231
232         * gst/gstbin.c: (bin_bus_handler):
233           Use gst_element_post_message() instead.
234
235 2005-08-08  Tim-Philipp Müller  <tim at centricular dot net>
236
237         * gst/base/gstadapter.h:
238         * gst/base/gstbasesink.h:
239         * gst/base/gstbasesrc.h:
240         * gst/base/gstbasetransform.h:
241         * gst/base/gstcollectpads.h:
242         * gst/base/gstpushsrc.h:
243         * gst/gstiterator.h:
244           Add padding to our base elements' class and instance structs and
245           to GstIterator (you will need to rebuild all plugins and apps!)
246
247 2005-08-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
248
249         * gst/gstbin.c: (bin_bus_handler):
250           Make default message forwarding from child->bus to bin->bus
251           threadsafe and make it not emit warnings if the parent has no bus.
252
253 2005-08-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
254
255         * gst/gstelement.c: (activate_pads):
256           On paused->ready, set pad->caps to NULL, as is the documented
257           behaviour in this state change. Fixes playback of series of
258           media files when visualization is enabled in Totem.
259
260 2005-08-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
261
262         * gst/elements/gstcapsfilter.c: (gst_capsfilter_set_property):
263           Allow NULL as filter-caps (which means "any").
264
265 2005-08-05  Stefan Kost  <ensonic@users.sf.net>
266
267         * docs/libs/gstreamer-libs-sections.txt:
268         * libs/gst/controller/gst-controller.c:
269         * libs/gst/controller/gst-controller.h:
270         * libs/gst/controller/gst-helper.c:
271           adding more entries to the docs and fix small doc-bugs
272
273 2005-08-05  Stefan Kost  <ensonic@users.sf.net>
274
275         * docs/gst/gstreamer-docs.sgml:
276         * docs/gst/gstreamer-sections.txt:
277         * docs/gst/gstreamer.types:
278         * docs/gst/tmpl/gstbasesink.sgml:
279         * docs/gst/tmpl/gstbasesrc.sgml:
280         * docs/gst/tmpl/gstbasetransform.sgml:
281         * docs/gst/tmpl/gstfakesrc.sgml:
282         * gst/base/gstcollectpads.c:
283         * gst/base/gstcollectpads.h:
284         * libs/gst/controller/gst-controller.c:
285         * libs/gst/controller/gst-controller.h:
286         * libs/gst/controller/gst-helper.c:
287         * libs/gst/controller/gst-interpolation.c:
288         * libs/gst/controller/lib.c:
289           added long/short desc for controller docs
290           added collectpads base class docs
291           added correct includes to base-class docs
292
293 2005-08-05  Stefan Kost  <ensonic@users.sf.net>
294
295         * check/gst-libs/controller.c: (gst_test_mono_source_get_property),
296         (gst_test_mono_source_set_property),
297         (gst_test_mono_source_class_init), (GST_START_TEST),
298         (gst_controller_suite):
299         * docs/gst/gstreamer-docs.sgml:
300         * docs/gst/gstreamer-sections.txt:
301         * docs/gst/gstreamer.types:
302         * docs/libs/gstreamer-libs-docs.sgml:
303         * docs/libs/gstreamer-libs-sections.txt:
304         * gst/base/gstadapter.c:
305         * libs/gst/controller/gst-controller.c:
306         (gst_controlled_property_new), (gst_controlled_property_free),
307         (gst_controller_new_valist),
308         (gst_controller_remove_properties_valist),
309         (gst_controller_sink_values), (_gst_controller_finalize):
310         * libs/gst/controller/gst-controller.h:
311         * libs/gst/controller/gst-helper.c:
312         (gst_object_control_properties), (gst_object_uncontrol_properties),
313         (gst_object_get_controller), (gst_object_set_controller),
314         (gst_object_sink_values), (gst_object_get_value_arrays),
315         (gst_object_get_value_array):
316           more tests (and fixes) for the controller
317           more docs for the controller
318           integrated companies docs for the adapter 
319
320 2005-08-05  Thomas Vander Stichele  <thomas at apestaart dot org>
321
322         * check/elements/gstfakesrc.c: (setup_fakesrc), (cleanup_fakesrc),
323         (GST_START_TEST), (fakesrc_suite):
324           add tests for sizetype
325
326 2005-08-04  Andy Wingo  <wingo@pobox.com>
327
328         * gst/elements/gstcapsfilter.c: Reimplement using basetransform,
329         fixes buffer_alloc proxying among other things.
330
331         * gst/base/gstbasetransform.c:
332         * gst/base/gstbasetransform.h:
333         Revert patch to gstbasetransform from 7-28 removing
334         delay_configure.
335
336         * gst/base/gstbasetransform.h (GstBaseTransformClass.get_size):
337         * gst/base/gstbasetransform.c (gst_base_transform_get_size):
338         Semantics changed, should return not the size of the output buffer
339         but the byte size of a buffer with a given caps.
340
341         * gst/base/gstbasetransform.c (gst_base_transform_getcaps): Better
342         debug object.
343         (gst_base_transform_configure_caps): Don't set out_size here: (in,
344         out) are not the pad caps until setcaps finishes.
345         (gst_base_transform_buffer_alloc): Proxy the buffer_alloc for the
346         not-in-place case as well. Deal with changing from in-place to
347         not-in-place within calling pad_alloc_buffer. Still a bit
348         concerned about the overhead here...
349
350 2005-08-03  Andy Wingo  <wingo@pobox.com>
351
352         * gst/base/gstbasetransform.c (gst_base_transform_setcaps): Not
353         fixating is an error.
354
355 2005-08-04  Edward Hervey  <edward@fluendo.com>
356
357         * gst/base/gstadapter.h: 
358         Added gst_adapter_get_type() to the header
359
360 2005-08-03  Stefan Kost  <ensonic@users.sf.net>
361
362         * check/Makefile.am:
363         * check/gst-libs/controller.c:
364         * libs/gst/controller/gst-controller.c:
365         (gst_controller_new_valist):
366           added check test suite for the controller
367         * gst/base/gstpushsrc.c:
368           fixed a doc typo
369
370 2005-08-03  Stefan Kost  <ensonic@users.sf.net>
371
372         * docs/gst/Makefile.am:
373         * docs/gst/gstreamer-docs.sgml:
374         * docs/gst/gstreamer-sections.txt:
375         * docs/gst/gstreamer.types:
376         * docs/gst/tmpl/gstfakesrc.sgml:
377         * gst/base/README:
378         * gst/base/gstbasesink.c:
379         * gst/base/gstbasesink.h:
380         * gst/base/gstbasesrc.c:
381         * gst/base/gstbasesrc.h:
382         * gst/base/gstbasetransform.c:
383         * gst/base/gstpushsrc.c:
384         * gst/base/gstpushsrc.h:
385           add short/long description docs to base classes
386           add pushsrc to the docs
387           remove consolidated doc fragments
388
389 2005-08-03  Stefan Kost  <ensonic@users.sf.net>
390
391         * configure.ac:
392         * docs/libs/Makefile.am:
393         * docs/libs/gstreamer-libs-docs.sgml:
394         * docs/libs/gstreamer-libs-sections.txt:
395         * docs/libs/gstreamer-libs.types:
396         * examples/Makefile.am:
397         * examples/controller/.cvsignore:
398         * examples/controller/Makefile.am:
399         * examples/controller/audio-example.c: (main):
400         * libs/gst/Makefile.am:
401         * libs/gst/controller/.cvsignore:
402         * libs/gst/controller/Makefile.am:
403         * libs/gst/controller/gst-controller.c:
404         (on_object_controlled_property_changed), (gst_timed_value_compare),
405         (gst_timed_value_find),
406         (gst_controlled_property_set_interpolation_mode),
407         (gst_controlled_property_new), (gst_controlled_property_free),
408         (gst_controller_find_controlled_property),
409         (gst_controller_new_valist), (gst_controller_new),
410         (gst_controller_remove_properties_valist),
411         (gst_controller_remove_properties), (gst_controller_set),
412         (gst_controller_set_from_list), (gst_controller_unset),
413         (gst_controller_get), (gst_controller_get_all),
414         (gst_controller_sink_values), (gst_controller_get_value_arrays),
415         (gst_controller_get_value_array),
416         (gst_controller_set_interpolation_mode),
417         (_gst_controller_finalize), (_gst_controller_init),
418         (_gst_controller_class_init), (gst_controller_get_type):
419         * libs/gst/controller/gst-controller.h:
420         * libs/gst/controller/gst-helper.c: (g_object_control_properties),
421         (g_object_uncontrol_properties), (g_object_get_controller),
422         (g_object_set_controller), (g_object_sink_values),
423         (g_object_get_value_arrays), (g_object_get_value_array):
424         * libs/gst/controller/gst-interpolation.c:
425         (gst_controlled_property_find_timed_value_node),
426         (interpolate_none_get), (interpolate_trigger_get),
427         (interpolate_trigger_get_value_array):
428         * libs/gst/controller/lib.c: (gst_controller_init):
429         * pkgconfig/Makefile.am:
430         * pkgconfig/gstreamer-control-uninstalled.pc.in:
431         * pkgconfig/gstreamer-control.pc.in:
432         * testsuite/Makefile.am:
433         * testsuite/controller/.cvsignore:
434         * testsuite/controller/Makefile.am:
435         * testsuite/controller/interpolator.c: (main):
436           added controller code
437           removed dparam pc files
438
439 2005-08-01  Jan Schmidt  <thaytan@mad.scientist.com>
440         * gst/base/gstcollectpads.c: (gst_collectpads_finalize),
441         (gst_collectpads_stop):
442           Broadcast the condition when shutting down, to make sure we wake all
443           threads up. Shut down pads on finalize, for safety.
444
445 2005-08-01  Jan Schmidt  <thaytan@mad.scientist.com>
446         * gst/base/gstbasetransform.c: (gst_base_transform_init),
447         (gst_base_transform_handle_buffer),
448         (gst_base_transform_change_state):
449           Handle PAUSED->READY->PAUSED transition after negotiation
450           occurred already.
451         * gst/gstmessage.c: (gst_message_init):
452           Extra piece of debug for new messages.
453
454 2005-08-01  Stefan Kost  <ensonic@users.sf.net>
455
456         * configure.ac:
457         * docs/gst/tmpl/gstbasesrc.sgml:
458         * docs/gst/tmpl/gstelement.sgml:
459         * docs/gst/tmpl/gstevent.sgml:
460         * docs/gst/tmpl/gstfakesrc.sgml:
461         * docs/gst/tmpl/gstformat.sgml:
462         * docs/gst/tmpl/gstghostpad.sgml:
463         * docs/gst/tmpl/gstpad.sgml:
464         * docs/gst/tmpl/gstquery.sgml:
465         * docs/gst/tmpl/gststructure.sgml:
466         * docs/gst/tmpl/gsttaglist.sgml:
467         * docs/gst/tmpl/gstvalue.sgml:
468         * docs/libs/gstreamer-libs-docs.sgml:
469         * docs/libs/gstreamer-libs-sections.txt:
470         * docs/libs/gstreamer-libs.types:
471         * libs/gst/Makefile.am:
472         * libs/gst/control/.cvsignore:
473         * libs/gst/control/Makefile.am:
474         * libs/gst/control/control.c:
475         * libs/gst/control/control.h:
476         * libs/gst/control/dparam.c:
477         * libs/gst/control/dparam.h:
478         * libs/gst/control/dparam_smooth.c:
479         * libs/gst/control/dparam_smooth.h:
480         * libs/gst/control/dparamcommon.h:
481         * libs/gst/control/dparammanager.c:
482         * libs/gst/control/dparammanager.h:
483         * libs/gst/control/dplinearinterp.c:
484         * libs/gst/control/dplinearinterp.h:
485         * libs/gst/control/unitconvert.c:
486         * libs/gst/control/unitconvert.h:
487         * testsuite/Makefile.am:
488         * testsuite/dynparams/.cvsignore:
489         * testsuite/dynparams/Makefile.am:
490         * testsuite/dynparams/dparamstest.c:
491         * tools/Makefile.am:
492         * tools/gst-inspect.c: (print_element_info), (main):
493         * tools/gst-xmlinspect.c: (print_element_info), (main):
494           deactivate and remove dparams (libgstcontrol)
495
496 2005-08-01  Tim-Philipp Müller  <tim at centricular dot net>
497
498         * gst/elements/gsttypefindelement.c:
499         (gst_type_find_element_have_type), (gst_type_find_element_init),
500         (stop_typefinding), (gst_type_find_element_handle_event),
501         (gst_type_find_element_chain), (gst_type_find_element_getrange):
502         * gst/elements/gsttypefindelement.h:
503           Set caps on all outgoing buffers, not just the first one.
504
505 2005-08-01  Tim-Philipp Müller  <tim at centricular dot net>
506
507         * gst/elements/gsttypefindelement.c:
508         (gst_type_find_element_have_type),
509         (gst_type_find_element_check_set_buffer_caps),
510         (gst_type_find_element_init), (stop_typefinding),
511         (gst_type_find_element_handle_event),
512         (gst_type_find_element_chain), (gst_type_find_element_getrange):
513         * gst/elements/gsttypefindelement.h:
514           Set caps on first outgoing buffer when we've found the type.
515
516 2005-08-01  Tim-Philipp Müller  <tim at centricular dot net>
517
518         * docs/gst/gstreamer-docs.sgml:
519         * docs/gst/gstreamer-sections.txt:
520         * docs/gst/tmpl/gstscheduler.sgml:
521         * docs/gst/tmpl/gstschedulerfactory.sgml:
522           Remove some old cruft from docs.
523
524 2005-07-31  Tim-Philipp Müller  <tim at centricular dot net>
525
526         * gst/gstpad.h:
527           Fix inline docs for GstPadLinkReturn.
528           
529         * gst/gststructure.c: (gst_structure_has_name):
530         * gst/gststructure.h:
531         * docs/gst/gstreamer-sections.txt:
532           New API: gst_structure_has_name().
533
534 2005-07-30  Tim-Philipp Müller  <tim at centricular dot net>
535
536         * configure.ac:
537           Use AC_SYS_LARGEFILE, which will set _FILE_OFFSET_BITS=64
538           and _LARGEFILE_SOURCE in config.h as required. Do not 
539           export those flags in our .pc files any longer (#142209).
540
541           Remove unused GST_DISABLE_OMEGA_COTHREADS stuff.
542
543         * gst/elements/gstfilesink.c: (gst_file_sink_class_init),
544         (gst_file_sink_do_seek), (gst_file_sink_event),
545         (gst_file_sink_get_current_offset), (gst_file_sink_render):
546           Redo seek/tell calls with large file support in mind; add some
547           debugging messages; add log message that tells us when large
548           file support is unavailable or not enabled for some reason.
549
550         * gst/elements/gstfilesrc.c: (gst_file_src_class_init):
551           Add log message that tells us when large file support 
552           is unavailable or not enabled for some reason.
553
554 2005-07-29  Wim Taymans  <wim@fluendo.com>
555
556         * check/gst/gstghostpad.c: (GST_START_TEST), (gst_ghost_pad_suite):
557         Added test for removing an element with ghostpad from a bin.
558         Fixed test as current implementation does the right thing.
559
560         * gst/gstghostpad.c: (gst_proxy_pad_class_init),
561         (gst_proxy_pad_do_query_type), (gst_proxy_pad_do_event),
562         (gst_proxy_pad_do_query), (gst_proxy_pad_do_internal_link),
563         (gst_proxy_pad_do_bufferalloc), (gst_proxy_pad_do_activate),
564         (gst_proxy_pad_do_activatepull), (gst_proxy_pad_do_activatepush),
565         (gst_proxy_pad_do_chain), (gst_proxy_pad_do_getrange),
566         (gst_proxy_pad_do_checkgetrange), (gst_proxy_pad_do_getcaps),
567         (gst_proxy_pad_do_acceptcaps), (gst_proxy_pad_do_fixatecaps),
568         (gst_proxy_pad_do_setcaps), (gst_proxy_pad_set_target),
569         (gst_proxy_pad_get_target), (gst_proxy_pad_init),
570         (gst_proxy_pad_dispose), (gst_proxy_pad_finalize),
571         (gst_ghost_pad_class_init), (gst_ghost_pad_do_activate_push),
572         (gst_ghost_pad_do_link), (gst_ghost_pad_do_unlink),
573         (gst_ghost_pad_set_internal), (gst_ghost_pad_dispose),
574         (gst_ghost_pad_new_notarget), (gst_ghost_pad_new),
575         (gst_ghost_pad_get_target), (gst_ghost_pad_set_target):
576         * gst/gstghostpad.h:
577         Clean up ghostpads, remove properties for internal stuff.
578         Make threadsafe.
579         Fix refcounting.
580         Prepare for switching targets, not all use cases work yet.
581
582 2005-07-29  Wim Taymans  <wim@fluendo.com>
583
584         * docs/design/part-gstghostpad.txt:
585         Small update.
586
587         * gst/gstbin.c: (unlink_pads), (gst_bin_add_func),
588         (gst_bin_remove_func):
589         Unlinking pads while holding the bin LOCK is not a good
590         idea.
591
592         * gst/gstpad.c: (gst_pad_class_init),
593         (gst_pad_link_check_hierarchy), (gst_pad_get_caps_unlocked),
594         (gst_pad_accept_caps), (gst_pad_set_caps), (gst_pad_send_event):
595         No prob setting template after creating the pad.
596
597 2005-07-29  Jan Schmidt  <thaytan@mad.scientist.com>
598
599         * gst/gstbus.c: (gst_bus_set_flushing), (gst_bus_pop),
600         (gst_bus_peek), (gst_bus_source_dispatch),
601         (gst_bus_add_watch_full), (poll_handler), (poll_timeout),
602         (poll_destroy), (poll_destroy_timeout), (gst_bus_poll):
603           gst_bus_poll may be called from other threads. Handle
604           this nicely by not making poll_data disappear off the
605           stack once gst_bus_poll returns.
606           gst_bus_peek now increments the refcount on the returned
607           message.
608
609 2005-07-29  Wim Taymans  <wim@fluendo.com>
610
611         * docs/design/part-gstghostpad.txt:
612         Overview of current GhostPad datastructures and use
613         cases for changing the target.
614
615 2005-07-28  Wim Taymans  <wim@fluendo.com>
616
617         * check/gst/gstbin.c: (GST_START_TEST), (gst_bin_suite):
618         Added checks for hierarchy consistency whan adding linked
619         elements to bins.
620
621         * check/gst/gstelement.c: (GST_START_TEST), (gst_element_suite):
622         Added check to test element scheduling without bin/pipeline.
623
624         * check/pipelines/simple_launch_lines.c: (GST_START_TEST):
625         First add elements to bin, then link.
626         
627         * gst/gstbin.c: (unlink_pads), (gst_bin_add_func),
628         (gst_bin_remove_func):
629         Unlink pads from elements added/removed from bin to maintain
630         hierarchy consistency.
631
632 2005-07-28  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
633
634         * gst/base/gstbasetransform.c: (gst_base_transform_setcaps),
635         (gst_base_transform_handle_buffer):
636         * gst/base/gstbasetransform.h:
637           Remove broken delay_configure (fixes renegotiation of software
638           scaling pipelines); remove some leftover printf()s.
639
640 2005-07-28  Wim Taymans  <wim@fluendo.com>
641
642         * check/gst/gstghostpad.c: (GST_START_TEST), (gst_ghost_pad_suite):
643         Added some more tests for wrong hierarchy
644
645         * docs/design/part-overview.txt:
646         Some updates.
647
648         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_dispose):
649         Cleanups.
650
651         * gst/gstelement.c: (gst_element_remove_pad), (gst_element_seek),
652         (gst_element_dispose):
653         Some more cleanups.
654
655         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked),
656         (gst_pad_link_check_hierarchy), (gst_pad_link_prepare),
657         (gst_pad_get_caps_unlocked), (gst_pad_accept_caps),
658         (gst_pad_set_caps), (gst_pad_send_event):
659         Check for correct hierarchy when linking pads. Moving to
660         strict requirement for ghostpads when linking elements in
661         different bins.
662
663         * gst/gstpad.h:
664         Clean ups. Added WRONG_HIERARCHY return value.
665
666 2005-07-28  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
667
668         * gst/base/gstbasetransform.c: (gst_base_transform_setcaps):
669           Better debug if no transform is possible.
670
671 2005-07-27  Wim Taymans  <wim@fluendo.com>
672
673         * docs/random/wtay/network-transp:
674         Some old doc I had.
675
676 2005-07-27  Wim Taymans  <wim@fluendo.com>
677
678         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_event),
679         (gst_dp_event_from_packet):
680         Fix serialization of seek events.
681
682 2005-07-27  Wim Taymans  <wim@fluendo.com>
683
684         * check/gst-libs/gdp.c: (GST_START_TEST):
685         * gst/elements/gstfakesink.c: (gst_fake_sink_event):
686         Fix compilation and fix event serialization.
687
688 2005-07-27  Wim Taymans  <wim@fluendo.com>
689
690         * CHANGES-0.9:
691         * docs/design/part-TODO.txt:
692         * docs/design/part-events.txt:
693         Some docs updates
694
695         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
696         (gst_base_sink_event), (gst_base_sink_do_sync),
697         (gst_base_sink_activate_push), (gst_base_sink_activate_pull):
698         * gst/base/gstbasesrc.c: (gst_base_src_send_discont),
699         (gst_base_src_do_seek), (gst_base_src_event_handler),
700         (gst_base_src_loop):
701         * gst/base/gstbasetransform.c: (gst_base_transform_transform_caps),
702         (gst_base_transform_configure_caps), (gst_base_transform_setcaps),
703         (gst_base_transform_get_size), (gst_base_transform_buffer_alloc),
704         (gst_base_transform_event), (gst_base_transform_handle_buffer),
705         (gst_base_transform_set_passthrough),
706         (gst_base_transform_is_passthrough):
707         * gst/elements/gstfakesink.c: (gst_fake_sink_event):
708         * gst/elements/gstfilesink.c: (gst_file_sink_event):
709         Event updates.
710
711         * gst/gstbuffer.h:
712         Use faster casts.
713
714         * gst/gstelement.c: (gst_element_seek):
715         * gst/gstelement.h:
716         Update gst_element_seek.
717
718         * gst/gstevent.c: (gst_event_finalize), (_gst_event_copy),
719         (gst_event_new), (gst_event_new_custom), (gst_event_get_structure),
720         (gst_event_new_flush_start), (gst_event_new_flush_stop),
721         (gst_event_new_eos), (gst_event_new_newsegment),
722         (gst_event_parse_newsegment), (gst_event_new_tag),
723         (gst_event_parse_tag), (gst_event_new_filler), (gst_event_new_qos),
724         (gst_event_parse_qos), (gst_event_new_seek),
725         (gst_event_parse_seek), (gst_event_new_navigation):
726         * gst/gstevent.h:
727         Make GstEvent use GstStructure. Add parsing code, make sure the
728         API is sufficiently generic.
729         Mark possible directions of events and serialization.
730
731         * gst/gstmessage.c: (gst_message_init), (gst_message_finalize),
732         (_gst_message_copy), (gst_message_new_segment_start),
733         (gst_message_new_segment_done), (gst_message_new_custom),
734         (gst_message_parse_segment_start),
735         (gst_message_parse_segment_done):
736         Small cleanups.
737
738         * gst/gstpad.c: (gst_pad_get_caps_unlocked), (gst_pad_accept_caps),
739         (gst_pad_set_caps), (gst_pad_send_event):
740         Update for new events. 
741         Catch events sent in wrong directions.
742
743         * gst/gstqueue.c: (gst_queue_link_src),
744         (gst_queue_handle_sink_event), (gst_queue_chain), (gst_queue_loop),
745         (gst_queue_handle_src_query):
746         Event updates.
747
748         * gst/gsttag.c:
749         * gst/gsttag.h:
750         Remove event code from this file.
751
752         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_event),
753         (gst_dp_event_from_packet):
754         Event updates.
755
756 2005-07-27  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
757
758         * gst/base/gstbasetransform.c: (gst_base_transform_getcaps),
759         (gst_base_transform_configure_caps), (gst_base_transform_setcaps),
760         (gst_base_transform_get_size), (gst_base_transform_handle_buffer):
761           Make debugging actually useful.
762
763 2005-07-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
764
765         * gst/gstpad.c: (fixate_value), (gst_pad_default_fixate),
766         (gst_pad_fixate_caps):
767           Implement default fixation once again, so that gst_pad_fixate()
768           actually does anything at all. This probably needs to be some
769           sort of a last resort, and use profile-based fixation first, but
770           since that doesn't exist yet, this is the best we have. Fixes
771           visualization in Totem.
772
773 2005-07-22  Wim Taymans  <wim@fluendo.com>
774
775         * docs/design/part-events.txt:
776         Small update.
777
778         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
779         (gst_base_sink_do_sync), (gst_base_sink_activate_push),
780         (gst_base_sink_activate_pull):
781         Some more comments.
782
783         * gst/elements/gstfakesrc.c: (gst_fake_src_class_init),
784         (gst_fake_src_create):
785         Fix handoff marshall.
786
787         * gst/elements/gstidentity.c: (gst_identity_class_init),
788         (gst_identity_transform_ip):
789         We're a real inplace element.
790
791         * gst/gstbus.c: (gst_bus_post):
792         Added some comments.
793
794         * tests/lat.c: (fakesrc), (fakesink), (simple), (queue), (main):
795         * tests/muxing/case1.c: (main):
796         * tests/sched/dynamic-pipeline.c: (main):
797         * tests/sched/interrupt1.c: (main):
798         * tests/sched/interrupt2.c: (main):
799         * tests/sched/interrupt3.c: (main):
800         * tests/sched/runxml.c: (main):
801         * tests/sched/sched-stress.c: (main):
802         * tests/seeking/seeking1.c: (event_received), (main):
803         * tests/threadstate/threadstate2.c: (bus_handler), (timeout_func),
804         (main):
805         * tests/threadstate/threadstate3.c: (main):
806         * tests/threadstate/threadstate4.c: (main):
807         * tests/threadstate/threadstate5.c: (main):
808         Fix the tests.
809
810 2005-07-21  Wim Taymans  <wim@fluendo.com>
811
812         * docs/design/part-seeking.txt:
813         Some small additions.
814
815         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
816         (gst_base_sink_get_times), (gst_base_sink_do_sync),
817         (gst_base_sink_activate_push), (gst_base_sink_activate_pull):
818         * gst/base/gstbasesink.h:
819         discont values are gint64, handle the math correctly.
820
821         * gst/base/gstbasesrc.c: (gst_base_src_loop):
822         Make the basesrc report error if the source pad is not linked.
823
824         * gst/gstqueue.c: (gst_queue_link_src), (gst_queue_chain),
825         (gst_queue_loop), (gst_queue_handle_src_query),
826         (gst_queue_src_activate_push):
827         Make queue collect data even if the srcpad is not linked.
828         Start pushing out data as soon as it is linked.
829
830         * gst/gstutils.c: (gst_element_unlink), (gst_flow_get_name):
831         * gst/gstutils.h:
832         Added gst_flow_get_name() to ease error reporting.
833
834 2005-07-20  Wim Taymans  <wim@fluendo.com>
835
836         * gst/gstmessage.c: (gst_message_new_segment_start),
837         (gst_message_new_segment_done), (gst_message_parse_segment_start),
838         (gst_message_parse_segment_done):
839         * gst/gstmessage.h:
840         Added a bunch of messages for advanced seeking.
841
842         * gst/parse/grammar.y:
843         * libs/gst/control/dparammanager.c: (gst_dpman_set_parent),
844         (gst_dpman_state_changed):
845         Fix some new-pad -> pad-added signals
846
847 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
848
849         * docs/manual/appendix-porting.xml:
850         * docs/pwg/appendix-porting.xml:
851           Document new-pad/state-change signal renames and the FixedList
852           type rename.
853
854 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
855
856         * docs/manual/advanced-autoplugging.xml:
857         * docs/manual/basics-helloworld.xml:
858         * docs/manual/basics-pads.xml:
859         * docs/random/ds/0.9-suggested-changes:
860         * gst/gstelement.c: (gst_element_class_init), (gst_element_seek):
861         * gst/gstelement.h:
862         * gst/gstevent.h:
863         * gst/gstformat.h:
864         * gst/gstquery.h:
865         * gst/gststructure.c: (gst_structure_value_get_generic_type),
866         (gst_structure_parse_array), (gst_structure_parse_value):
867         * gst/gstvalue.c: (gst_type_is_fixed),
868         (gst_value_list_prepend_value), (gst_value_list_append_value),
869         (gst_value_list_get_size), (gst_value_list_get_value),
870         (gst_value_transform_array_string), (gst_value_serialize_array),
871         (gst_value_deserialize_array), (gst_value_intersect_array),
872         (gst_value_is_fixed), (_gst_value_initialize):
873         * gst/gstvalue.h:
874           GstElement::new-pad -> pad-added, GstElement::state-change ->
875           state-changed, GstValueFixedList -> GstValueArray, add format and
876           flags as their own arguments in gst_element_seek() (should improve
877           "bindeability"), remove function generators since they don't work
878           under a whole bunch of compilers (they were deprecated already
879           anyway).
880
881 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
882
883         * gst/gstinfo.c: (_gst_debug_nameof_funcptr),
884         (_gst_debug_register_funcptr):
885         * gst/gstinfo.h:
886           Fix illegal cast on some platforms (#309253).
887
888 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
889
890         * gst/gstmessage.c: (gst_message_new_custom):
891         * gst/gstmessage.h:
892           Add _new_custom, make _new_application a macro to _new_custom.
893
894 2005-07-20  Wim Taymans  <wim@fluendo.com>
895
896         * gst/base/gstbasesrc.c: (gst_base_src_init),
897         (gst_base_src_do_seek), (gst_base_src_loop), (gst_base_src_start):
898         * gst/base/gstbasesrc.h:
899         Add a gboolean to decide when to push out a discont.
900
901         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
902         (gst_queue_loop), (gst_queue_handle_src_query),
903         (gst_queue_sink_activate_push), (gst_queue_src_activate_push),
904         (gst_queue_set_property), (gst_queue_get_property):
905         Some cleanups.
906
907         * tests/threadstate/threadstate1.c: (main):
908         Make a thread test compile and run... very silly..
909
910
911 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
912
913         * docs/manual/appendix-porting.xml:
914           Mention removal of libgstgconf-0.9.la and existence of gconf
915           elements.
916
917 2005-07-20  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
918
919         * docs/pwg/advanced-clock.xml:
920         * docs/pwg/appendix-porting.xml:
921         * docs/pwg/intro-preface.xml:
922         * docs/pwg/other-base.xml:
923         * docs/pwg/other-manager.xml:
924         * docs/pwg/other-nton.xml:
925         * docs/pwg/other-ntoone.xml:
926         * docs/pwg/other-oneton.xml:
927         * docs/pwg/pwg.xml:
928           Document base classes, update sections of n-to-1 and 1-to-n (muxer,
929           demuxer), remove n-to-n (was never written), fix some code examples
930           and links and update the porting section to include all this.
931
932 2005-07-19  Wim Taymans  <wim@fluendo.com>
933
934         * gst/gstqueue.c: (gst_queue_init), (gst_queue_handle_sink_event),
935         (gst_queue_chain), (gst_queue_loop), (gst_queue_handle_src_event),
936         (gst_queue_handle_src_query), (gst_queue_sink_activate_push),
937         (gst_queue_src_activate_push), (gst_queue_change_state),
938         (gst_queue_get_property):
939         * gst/gstqueue.h:
940         Propagate GstFlowReturn more intelligently upstream and output
941         an ERROR/EOS when streaming stopped due to fatal error.
942
943 2005-07-19  Wim Taymans  <wim@fluendo.com>
944
945         * tools/gst-launch.c: (check_intr), (event_loop), (main):
946         Don't block forever for the state change to complete, the
947         pipeline already did with a sensible timeout.
948
949 2005-07-19  Wim Taymans  <wim@fluendo.com>
950
951         * gst/base/gstbasesrc.c: (gst_base_src_get_range):
952         Make sure we never call the create function is we
953         got deactivated.
954
955 2005-07-19  Andy Wingo  <wingo@pobox.com>
956
957         * gst/parse/parse.l: Attempt to solve bug #172815.
958
959 2005-07-19  Wim Taymans  <wim@fluendo.com>
960
961         * docs/design/part-clocks.txt:
962         * docs/design/part-events.txt:
963         * gst/base/gstbasesrc.c: (gst_base_src_do_seek):
964         Small docs updates.
965         Only update the seeking values when we are not
966         busy streaming.
967
968 2005-07-19  Jan Schmidt  <thaytan@mad.scientist.com>
969
970         * gst/base/gstbasesrc.c: (gst_base_src_loop):
971           Oops, ignore the result of gst_pad_push_event here.
972
973 2005-07-19  Jan Schmidt  <thaytan@mad.scientist.com>
974
975         * gst/base/gstbasesrc.c: (gst_base_src_loop),
976         (gst_base_src_activate_push):
977           Send discont event from the loop function, as pads
978           aren't activated yet in the activate_push handler.
979
980         * gst/gstbin.c: (bin_bus_handler):
981           Don't leak element name.
982
983 2005-07-18  Andy Wingo  <wingo@pobox.com>
984
985         * configure.ac: Use AS_LIBTOOL_TAGS.
986
987 2005-07-18  Wim Taymans  <wim@fluendo.com>
988
989         * docs/gst/gstreamer.types:
990         Remove deleted types.
991
992 2005-07-18  Wim Taymans  <wim@fluendo.com>
993
994         * check/elements/gstfakesrc.c: (GST_START_TEST):
995         * configure.ac:
996         * gst/Makefile.am:
997         * gst/gst.c: (gst_init_get_popt_table), (init_pre), (init_post),
998         (init_popt_callback):
999         * gst/gst.h:
1000         * gst/gst_private.h:
1001         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_add_func),
1002         (gst_bin_remove_func), (gst_bin_get_state), (gst_bin_change_state):
1003         * gst/gstbin.h:
1004         * gst/gstbus.h:
1005         * gst/gstconfig.h.in:
1006         * gst/gstelement.c: (gst_element_class_init),
1007         (gst_element_set_base_time), (gst_element_get_base_time),
1008         (iterator_fold_with_resync), (gst_element_change_state),
1009         (gst_element_dispose), (gst_element_get_bus):
1010         * gst/gstelement.h:
1011         * gst/gstelementfactory.h:
1012         * gst/gsterror.c: (_gst_core_errors_init):
1013         * gst/gsterror.h:
1014         * gst/gstevent.h:
1015         * gst/gstghostpad.c: (gst_ghost_pad_do_activate_push):
1016         * gst/gstindex.c:
1017         * gst/gstinfo.c: (_gst_debug_init):
1018         * gst/gstmessage.c: (_gst_message_copy):
1019         * gst/gstmessage.h:
1020         * gst/gstminiobject.h:
1021         * gst/gstobject.c:
1022         * gst/gstobject.h:
1023         * gst/gstpad.c: (gst_pad_get_caps_unlocked), (gst_pad_accept_caps),
1024         (gst_pad_set_caps), (gst_pad_start_task), (gst_pad_stop_task):
1025         * gst/gstpad.h:
1026         * gst/gstparse.h:
1027         * gst/gstpipeline.c: (gst_pipeline_init), (gst_pipeline_dispose),
1028         (gst_pipeline_change_state), (gst_pipeline_set_new_stream_time),
1029         (gst_pipeline_get_last_stream_time):
1030         * gst/gstpipeline.h:
1031         * gst/gstpluginfeature.h:
1032         * gst/gstquery.h:
1033         * gst/gstscheduler.c:
1034         * gst/gstscheduler.h:
1035         * gst/gststructure.h:
1036         * gst/gsttask.c: (gst_task_get_type), (gst_task_class_init),
1037         (gst_task_finalize), (gst_task_func), (gst_task_create),
1038         (gst_task_set_lock), (gst_task_get_state), (gst_task_start),
1039         (gst_task_stop), (gst_task_pause):
1040         * gst/gsttask.h:
1041         * gst/gsttypefind.h:
1042         * gst/gsttypes.h:
1043         * gst/registries/gstlibxmlregistry.c: (load_feature),
1044         (gst_xml_registry_load), (gst_xml_registry_save_feature):
1045         * gst/registries/gstxmlregistry.c:
1046         (gst_xml_registry_start_element), (gst_xml_registry_save_feature):
1047         * gst/schedulers/threadscheduler.c:
1048         * libs/gst/control/dparammanager.h:
1049         * tools/gst-inspect.c: (print_element_list),
1050         (print_plugin_features), (print_element_features):
1051         * tools/gst-xmlinspect.c: (print_element_list),
1052         (print_plugin_info), (main):
1053         Removed plugable schedulers.
1054         Removed Scheduler/Manager from elements.
1055         Removed gsttypes.h, rearranged includes.
1056         Removed dependency pad<->element, element<>pipeline, and
1057         various others,  fix includes.
1058         implement gst_pad_get_parent() with gst_object_get_parent()
1059         Make GstTask sefcontained.
1060         Fix _get_state() on GstBin, it did not return ASYNC with a 0
1061         timeout.
1062         Fix endless loop in iterator_fold_with_resync.
1063
1064
1065 2005-07-18  Wim Taymans  <wim@fluendo.com>
1066
1067         * gst/Makefile.am:
1068         * gst/gstarch.h:
1069         Remove old file.
1070
1071 2005-07-18  Wim Taymans  <wim@fluendo.com>
1072
1073         * gst/Makefile.am:
1074         No more cothreads.h
1075
1076 2005-07-18  Wim Taymans  <wim@fluendo.com>
1077
1078         * gst/cothreads.c:
1079         * gst/cothreads.h:
1080         Let's remove these.
1081
1082 2005-07-18  Wim Taymans  <wim@fluendo.com>
1083
1084         * docs/design/part-dynamic.txt:
1085         * docs/design/part-events.txt:
1086         * docs/design/part-seeking.txt:
1087         Some more docs in the works.
1088
1089         * gst/base/gstbasetransform.c: (gst_base_transform_transform_caps),
1090         (gst_base_transform_getcaps), (gst_base_transform_configure_caps),
1091         (gst_base_transform_setcaps), (gst_base_transform_get_size),
1092         (gst_base_transform_buffer_alloc), (gst_base_transform_event),
1093         (gst_base_transform_handle_buffer),
1094         (gst_base_transform_sink_activate_push),
1095         (gst_base_transform_src_activate_pull),
1096         (gst_base_transform_set_passthrough),
1097         (gst_base_transform_is_passthrough):
1098         Refcounting fixes.
1099
1100         * gst/gstbus.c: (gst_bus_source_dispatch), (gst_bus_poll):
1101         Cleanups.
1102
1103         * gst/gstevent.c: (gst_event_finalize):
1104         Set SRC to NULL.
1105
1106         * gst/gstutils.c: (gst_element_unlink),
1107         (gst_pad_get_parent_element), (gst_pad_proxy_getcaps),
1108         (gst_pad_proxy_setcaps):
1109         * gst/gstutils.h:
1110         Add _get_parent_element() to get a pads parent as an element.
1111
1112 2005-07-18  Wim Taymans  <wim@fluendo.com>
1113
1114         * check/gst/gstbin.c: (GST_START_TEST):
1115         Remove bogus test.
1116
1117 2005-07-18  Wim Taymans  <wim@fluendo.com>
1118
1119         * gst/base/gstbasesink.c: (gst_base_sink_pad_getcaps),
1120         (gst_base_sink_pad_setcaps), (gst_base_sink_pad_buffer_alloc),
1121         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_object),
1122         (gst_base_sink_event), (gst_base_sink_do_sync),
1123         (gst_base_sink_chain), (gst_base_sink_loop),
1124         (gst_base_sink_deactivate), (gst_base_sink_activate_push),
1125         (gst_base_sink_activate_pull), (gst_base_sink_change_state):
1126         Refcounting fixes.
1127         Fix logic for returning ASYNC when not prerolled.
1128
1129 2005-07-18  Wim Taymans  <wim@fluendo.com>
1130
1131         * gst/gstqueue.c: (gst_queue_handle_sink_event):
1132         Fix nasty refcount bug.
1133
1134 2005-07-16 Philippe Khalaf <burger@speedy.org>
1135         * gst/elements/gstfdsrc.c:
1136         * gst/elements/gstfdsrc.h:
1137         * gst/elements/gstelements.c:
1138         * gst/elements/Makefile.am:
1139         Ported fdsrc to 0.9.
1140
1141 2005-07-16  Wim Taymans  <wim@fluendo.com>
1142
1143         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
1144         (gst_base_sink_do_sync):
1145         Fix compile error.
1146
1147 2005-07-16  Wim Taymans  <wim@fluendo.com>
1148
1149         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
1150         (gst_base_sink_event), (gst_base_sink_get_times),
1151         (gst_base_sink_do_sync), (gst_base_sink_change_state):
1152         * gst/base/gstbasesink.h:
1153         Store and use discont values when syncing buffers as described
1154         in design docs.
1155         
1156         * gst/base/gstbasesrc.c: (gst_base_src_send_discont),
1157         (gst_base_src_do_seek), (gst_base_src_loop), (gst_base_src_start),
1158         (gst_base_src_activate_push):
1159         Push discont event when starting.
1160
1161         * gst/elements/gstidentity.c: (gst_identity_transform):
1162         Small cleanups.
1163
1164         * gst/gstbin.c: (gst_bin_change_state):
1165         Small cleanups in base_time  distribution.
1166
1167         * gst/gstelement.c: (gst_element_set_base_time),
1168         (gst_element_get_base_time), (gst_element_change_state):
1169         * gst/gstelement.h:
1170         Added methods for the base_time of the element.
1171         Some MT fixes.
1172
1173         * gst/gstpipeline.c: (gst_pipeline_send_event),
1174         (gst_pipeline_change_state), (gst_pipeline_set_new_stream_time),
1175         (gst_pipeline_get_last_stream_time):
1176         * gst/gstpipeline.h:
1177         MT fixes.
1178         Handle seeking as described in design doc, remove stream_time
1179         hack.
1180         Cleanups clock and stream_time selection code. Added accessors
1181         for the stream_time.
1182         
1183
1184 2005-07-16  Andy Wingo  <wingo@pobox.com>
1185
1186         * gst/gsterror.c (_gst_core_errors_init): Use the magic word
1187         (#305291).
1188
1189 2005-07-16  Wim Taymans  <wim@fluendo.com>
1190
1191         * check/gst/gstbin.c: (GST_START_TEST):
1192         Make elements silent as the deep_notify refs the
1193         parent, which might make the test fail.
1194
1195         * gst/gstghostpad.c: (gst_ghost_pad_do_activate_push):
1196         Don't hold the lock for too long.
1197
1198 2005-07-16  Tim-Philipp Müller  <tim at centricular dot net>
1199
1200         * gst/base/gstbasesrc.c: (gst_base_src_default_negotiate):
1201           Don't unref the caps we passed to gst_caps_make_writable() after
1202           passing them. gst_caps_make_writable() will do that for us.
1203
1204 2005-07-15  Andy Wingo  <wingo@pobox.com>
1205
1206         * gst/gstcaps.h (gst_caps_is_simple): Removed deprecated macro
1207         (#157311).
1208
1209         * gst/elements/gstidentity.c (marshal_VOID__MINIOBJECT): Write our
1210         own marshalling function for the handoff signal. Properly type the
1211         buffer as a buffer. Fixes some warnings. Should do a more general
1212         solution.
1213         (gst_identity_class_init): Plug into the right marshaller.
1214
1215 2005-07-15  Wim Taymans  <wim@fluendo.com>
1216
1217         * docs/design/part-TODO.txt:
1218         * docs/design/part-clocks.txt:
1219         * docs/design/part-element-sink.txt:
1220         * docs/design/part-events.txt:
1221         * docs/design/part-gstpipeline.txt:
1222         Updated docs, mostly DISCONT related.
1223
1224 2005-07-15  Tim-Philipp Müller  <tim at centricular dot net>
1225
1226         * docs/pwg/building-pads.xml:
1227           s/GST_PAD_LINK_REFUSED/FALSE/ in gst_my_filter_setcaps()
1228
1229 2005-07-15  Andy Wingo  <wingo@pobox.com>
1230
1231         * tools/gst-typefind.c: Update, add copyright block.
1232
1233         * gst/base/gstbasesrc.c (gst_base_src_default_negotiate):
1234         Normalize and truncate caps before fixation.
1235
1236         * gst/gstcaps.h:
1237         * gst/gstcaps.c (gst_caps_truncate): New function, destructively
1238         discards all but the first structure from its argument.
1239
1240 2005-07-15  Wim Taymans  <wim@fluendo.com>
1241
1242         * gst/base/gstbasetransform.c: (gst_base_transform_init),
1243         (gst_base_transform_transform_caps), (gst_base_transform_getcaps),
1244         (gst_base_transform_configure_caps), (gst_base_transform_setcaps),
1245         (gst_base_transform_get_size), (gst_base_transform_buffer_alloc),
1246         (gst_base_transform_handle_buffer), (gst_base_transform_getrange),
1247         (gst_base_transform_chain), (gst_base_transform_change_state),
1248         (gst_base_transform_set_passthrough),
1249         (gst_base_transform_is_passthrough):
1250         * gst/base/gstbasetransform.h:
1251         Make passthrough work using the bufferpools.
1252         Changed API a bit, subclasses have to write into a buffer
1253         provided by the base class.
1254         More debug info in nego functions.
1255         
1256         * gst/elements/gstidentity.c: (gst_identity_init),
1257         (gst_identity_transform):
1258         Port to new base class.
1259
1260 2005-07-15  Wim Taymans  <wim@fluendo.com>
1261
1262         * gst/gstmessage.c: (gst_message_new_state_changed):
1263         * tools/gst-launch.c: (event_loop), (main):
1264         Totally dump messages in -launch with the -m option.
1265         Fix message name for State messages,
1266
1267 2005-07-14  Wim Taymans  <wim@fluendo.com>
1268
1269         * gst/base/gstbasesrc.c: (gst_base_src_loop):
1270         Post error messages on errors.
1271
1272 2005-07-14  Wim Taymans  <wim@fluendo.com>
1273
1274         * gst/gstcaps.c: (gst_caps_do_simplify):
1275         Remove debug info.
1276
1277         * gst/gsterror.h:
1278         Define error for stream stopped.
1279
1280         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
1281         (gst_proxy_pad_do_chain), (gst_proxy_pad_do_getrange):
1282         Do proper return values.
1283
1284         * gst/gstpad.c: (gst_pad_get_caps_unlocked), (gst_pad_accept_caps),
1285         (gst_pad_set_caps), (gst_pad_chain), (gst_pad_push),
1286         (gst_pad_get_range):
1287         Better return values.
1288
1289         * gst/gstpad.h:
1290         Reorganise return values, add macro to check for fatal errors.
1291
1292         * gst/gstqueue.c: (gst_queue_chain):
1293         Return proper GstFlowReturn values,
1294
1295 2005-07-14  Thomas Vander Stichele  <thomas at apestaart dot org>
1296
1297         * docs/gst/gstreamer-sections.txt:
1298         * docs/gst/gstreamer.types:
1299         * docs/gst/tmpl/gst.sgml:
1300         * docs/gst/tmpl/gstbasesink.sgml:
1301         * docs/gst/tmpl/gstbasesrc.sgml:
1302         * docs/gst/tmpl/gstbasetransform.sgml:
1303         * docs/gst/tmpl/gstbin.sgml:
1304         * docs/gst/tmpl/gstbuffer.sgml:
1305         * docs/gst/tmpl/gstcaps.sgml:
1306         * docs/gst/tmpl/gstclock.sgml:
1307         * docs/gst/tmpl/gstcompat.sgml:
1308         * docs/gst/tmpl/gstconfig.sgml:
1309         * docs/gst/tmpl/gstelement.sgml:
1310         * docs/gst/tmpl/gstelementdetails.sgml:
1311         * docs/gst/tmpl/gstelementfactory.sgml:
1312         * docs/gst/tmpl/gstenumtypes.sgml:
1313         * docs/gst/tmpl/gsterror.sgml:
1314         * docs/gst/tmpl/gstevent.sgml:
1315         * docs/gst/tmpl/gstfakesink.sgml:
1316         * docs/gst/tmpl/gstfakesrc.sgml:
1317         * docs/gst/tmpl/gstfilesink.sgml:
1318         * docs/gst/tmpl/gstfilesrc.sgml:
1319         * docs/gst/tmpl/gstfilter.sgml:
1320         * docs/gst/tmpl/gstformat.sgml:
1321         * docs/gst/tmpl/gstghostpad.sgml:
1322         * docs/gst/tmpl/gstimplementsinterface.sgml:
1323         * docs/gst/tmpl/gstindex.sgml:
1324         * docs/gst/tmpl/gstindexfactory.sgml:
1325         * docs/gst/tmpl/gstinfo.sgml:
1326         * docs/gst/tmpl/gstiterator.sgml:
1327         * docs/gst/tmpl/gstmacros.sgml:
1328         * docs/gst/tmpl/gstmemchunk.sgml:
1329         * docs/gst/tmpl/gstminiobject.sgml:
1330         * docs/gst/tmpl/gstobject.sgml:
1331         * docs/gst/tmpl/gstpad.sgml:
1332         * docs/gst/tmpl/gstpadtemplate.sgml:
1333         * docs/gst/tmpl/gstparse.sgml:
1334         * docs/gst/tmpl/gstpipeline.sgml:
1335         * docs/gst/tmpl/gstplugin.sgml:
1336         * docs/gst/tmpl/gstpluginfeature.sgml:
1337         * docs/gst/tmpl/gstquery.sgml:
1338         * docs/gst/tmpl/gstqueue.sgml:
1339         * docs/gst/tmpl/gstregistry.sgml:
1340         * docs/gst/tmpl/gstregistrypool.sgml:
1341         * docs/gst/tmpl/gstscheduler.sgml:
1342         * docs/gst/tmpl/gstschedulerfactory.sgml:
1343         * docs/gst/tmpl/gststructure.sgml:
1344         * docs/gst/tmpl/gstsystemclock.sgml:
1345         * docs/gst/tmpl/gsttaglist.sgml:
1346         * docs/gst/tmpl/gsttagsetter.sgml:
1347         * docs/gst/tmpl/gsttrace.sgml:
1348         * docs/gst/tmpl/gsttrashstack.sgml:
1349         * docs/gst/tmpl/gsttypefind.sgml:
1350         * docs/gst/tmpl/gsttypefindfactory.sgml:
1351         * docs/gst/tmpl/gsttypes.sgml:
1352         * docs/gst/tmpl/gsturihandler.sgml:
1353         * docs/gst/tmpl/gsturitype.sgml:
1354         * docs/gst/tmpl/gstutils.sgml:
1355         * docs/gst/tmpl/gstvalue.sgml:
1356         * docs/gst/tmpl/gstversion.sgml:
1357         * docs/gst/tmpl/gstxml.sgml:
1358         * docs/libs/tmpl/gstcontrol.sgml:
1359         * docs/libs/tmpl/gstdataprotocol.sgml:
1360         * docs/libs/tmpl/gstdparam.sgml:
1361         * docs/libs/tmpl/gstdplinint.sgml:
1362         * docs/libs/tmpl/gstdpman.sgml:
1363         * docs/libs/tmpl/gstdpsmooth.sgml:
1364         * docs/libs/tmpl/gstgetbits.sgml:
1365         * docs/libs/tmpl/gstunitconvert.sgml:
1366         * gst/base/gstpushsrc.c: (gst_push_src_get_type),
1367         (gst_push_src_base_init), (gst_push_src_class_init),
1368         (gst_push_src_init), (gst_push_src_create):
1369         * gst/base/gstpushsrc.h:
1370         * gst/elements/gstelements.c:
1371         * gst/elements/gstfakesink.c: (gst_fake_sink_state_error_get_type),
1372         (gst_fake_sink_base_init), (gst_fake_sink_class_init),
1373         (gst_fake_sink_init), (gst_fake_sink_set_property),
1374         (gst_fake_sink_get_property), (gst_fake_sink_get_times),
1375         (gst_fake_sink_event), (gst_fake_sink_preroll),
1376         (gst_fake_sink_render), (gst_fake_sink_change_state):
1377         * gst/elements/gstfakesink.h:
1378         * gst/elements/gstfakesrc.c: (gst_fake_src_data_get_type),
1379         (gst_fake_src_sizetype_get_type), (gst_fake_src_filltype_get_type),
1380         (gst_fake_src_base_init), (gst_fake_src_class_init),
1381         (gst_fake_src_init), (gst_fake_src_event_handler),
1382         (gst_fake_src_alloc_parent), (gst_fake_src_set_property),
1383         (gst_fake_src_get_property), (gst_fake_src_prepare_buffer),
1384         (gst_fake_src_alloc_buffer), (gst_fake_src_get_size),
1385         (gst_fake_src_create_buffer), (gst_fake_src_create),
1386         (gst_fake_src_start), (gst_fake_src_stop):
1387         * gst/elements/gstfakesrc.h:
1388         * gst/elements/gstfilesink.c: (_do_init),
1389         (gst_file_sink_base_init), (gst_file_sink_class_init),
1390         (gst_file_sink_init), (gst_file_sink_dispose),
1391         (gst_file_sink_set_location), (gst_file_sink_set_property),
1392         (gst_file_sink_get_property), (gst_file_sink_open_file),
1393         (gst_file_sink_close_file), (gst_file_sink_query),
1394         (gst_file_sink_event), (gst_file_sink_render),
1395         (gst_file_sink_change_state), (gst_file_sink_uri_get_type),
1396         (gst_file_sink_uri_get_protocols), (gst_file_sink_uri_get_uri),
1397         (gst_file_sink_uri_set_uri), (gst_file_sink_uri_handler_init):
1398         * gst/elements/gstfilesink.h:
1399         * gst/elements/gstfilesrc.c: (_do_init), (gst_file_src_base_init),
1400         (gst_file_src_class_init), (gst_file_src_init),
1401         (gst_file_src_finalize), (gst_file_src_set_location),
1402         (gst_file_src_set_property), (gst_file_src_get_property),
1403         (gst_file_src_map_region), (gst_file_src_map_small_region),
1404         (gst_file_src_create_mmap), (gst_file_src_create_read),
1405         (gst_file_src_create), (gst_file_src_is_seekable),
1406         (gst_file_src_get_size), (gst_file_src_start), (gst_file_src_stop),
1407         (gst_file_src_uri_get_type), (gst_file_src_uri_get_protocols),
1408         (gst_file_src_uri_get_uri), (gst_file_src_uri_set_uri),
1409         (gst_file_src_uri_handler_init):
1410         * gst/elements/gstfilesrc.h:
1411           more autistic cleanliness in functions/names/defines
1412
1413 2005-07-13  Andy Wingo  <wingo@pobox.com>
1414
1415         * gst/base/gstbasesrc.c (gst_base_src_start): Post an error if the
1416         source couldn't negotiate.
1417
1418         * gst/parse/grammar.y: Revert 1.54->1.55, so we now do filtered
1419         connections again.
1420
1421         * gst/gstutils.h:
1422         * gst/gstutils.c (gst_element_link_pads_filtered): New old
1423         function. I am channeling Hades. Put your boots on suckers!!!
1424
1425 2005-07-13  Thomas Vander Stichele  <thomas at apestaart dot org>
1426
1427         * testsuite/caps/Makefile.am:
1428         * testsuite/caps/value_compare.c:
1429         * testsuite/caps/value_intersect.c:
1430         * check/gst/gstvalue.c: (GST_START_TEST), (gst_value_suite):
1431           move two testsuite apps over to the check dir
1432
1433 2005-07-12  Wim Taymans  <wim@fluendo.com>
1434
1435         * gst/base/gstbasetransform.c: (gst_base_transform_setcaps):
1436         Added more debug info in the negotiate process.
1437
1438         * gst/gstmessage.h:
1439         Prepare for segment playback.
1440
1441         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_set_caps):
1442         Better debugging.
1443
1444         * gst/gstutils.c:
1445         Some more docs.
1446
1447         * tools/gst-launch.c: (main):
1448         NULL pipeline on errors.
1449
1450 2005-07-12  Andy Wingo  <wingo@pobox.com>
1451
1452         * gst/gstbuffer.c (_gst_buffer_copy): Copy the buffer whether or
1453         not it comes from a malloc region. Make sure our copy gets freed.
1454
1455 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
1456
1457         * check/gst/gstelement.c: (GST_START_TEST), (gst_element_suite):
1458         * check/gst/gstmessage.c: (GST_START_TEST):
1459         * check/gst/gststructure.c: (GST_START_TEST),
1460         (gst_structure_suite), (main):
1461           more testing
1462         * gst/gstelement.c: (gst_element_message_full):
1463           clean up GError and debug string now that they get copied
1464         * gst/gstmessage.c: (gst_message_new_error),
1465         (gst_message_new_warning), (gst_message_parse_error),
1466         (gst_message_parse_warning):
1467           use GST_TYPE_G_ERROR for structure_new, and take copies of
1468           arguments, so that we don't mess up refcounting
1469
1470 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
1471
1472         * check/Makefile.am:
1473           add per-test valgrind targets
1474         * check/gst-libs/gdp.c: (GST_START_TEST),
1475         (gst_data_protocol_suite), (main):
1476           clean up
1477
1478 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
1479
1480         * check/Makefile.am:
1481           instate more valgrindable tests
1482         * check/elements/gstfakesrc.c: (chain_func), (event_func),
1483         (GST_START_TEST), (fakesrc_suite):
1484         * check/gst/gstpad.c: (GST_START_TEST):
1485         * check/gst/gststructure.c: (GST_START_TEST):
1486           fix test leaks
1487         * docs/gst/tmpl/gstminiobject.sgml:
1488         * gst/gstpad.c: (gst_pad_finalize):
1489           fix the static mutex leak
1490
1491 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
1492
1493         * check/Makefile.am:
1494           add two more tests for valgrinding
1495         * check/gst/gstvalue.c: (GST_START_TEST):
1496           test refcount of deserialized buffer, found a leak
1497         * docs/gst/gstreamer-docs.sgml:
1498         * docs/gst/gstreamer-sections.txt:
1499         * docs/gst/gstreamer.types:
1500         * docs/gst/tmpl/gstminiobject.sgml:
1501           add miniobject to docs
1502         * gst/gstminiobject.c:
1503           add some docs
1504         * gst/gstvalue.c: (gst_value_deserialize_buffer),
1505         (gst_string_unwrap):
1506           fix a hard-to-find invalid write for one of the tests
1507           fix a leak for deserialized buffers
1508
1509 2005-07-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1510
1511         * docs/pwg/advanced-events.xml:
1512         * docs/pwg/advanced-request.xml:
1513         * docs/pwg/advanced-scheduling.xml:
1514         * docs/pwg/appendix-porting.xml:
1515         * docs/pwg/building-boiler.xml:
1516         * docs/pwg/intro-preface.xml:
1517         * docs/pwg/other-ntoone.xml:
1518           Rewrite scheduling-chapter for scheduling model in 0.9. Add lots
1519           of example code and explanation for pad activation, loop() and
1520           getrange() functions and a bit more. Remove old comments pointing
1521           to loop-functions.
1522         * examples/pwg/Makefile.am:
1523           Add loop/getrange examples.
1524
1525 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
1526
1527         * configure.ac:
1528           check for valgrind binary + some fixes
1529         * check/gst.supp:
1530           valgrind suppressions for the tests
1531         * check/Makefile.am:
1532           add a valgrind: target that valgrinds the unit tests
1533         * check/gst/gst.c: (GST_START_TEST), (gst_suite):
1534         * check/gst/gstbin.c: (pop_messages), (GST_START_TEST):
1535         * check/gst/gstbuffer.c: (GST_START_TEST), (gst_test_suite):
1536         * check/gst/gstghostpad.c:
1537           added some cleanup
1538         * check/gst/gstdata.c:
1539           removed
1540         * check/gst/gstminiobject.c: (GST_START_TEST), (thread_ref),
1541         (thread_unref), (gst_mini_object_suite), (main):
1542           added
1543         * gst/gst.c: (gst_deinit):
1544         * gst/gst.h:
1545           add a method to clean up.
1546         * gst/gstsystemclock.c: (gst_system_clock_dispose),
1547         (gst_system_clock_obtain):
1548           allow for disposing the system clock.
1549         * tools/gst-launch.c: (main):
1550           deinit
1551
1552 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
1553
1554         * docs/gst/tmpl/gstbasesrc.sgml:
1555         * docs/gst/tmpl/gstfakesrc.sgml:
1556         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
1557         (gst_base_src_init), (gst_base_src_set_property),
1558         (gst_base_src_get_property), (gst_base_src_get_range),
1559         (gst_base_src_start):
1560         * gst/base/gstbasesrc.h:
1561           add num-buffers property
1562         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
1563         (gst_fakesrc_init), (gst_fakesrc_set_property),
1564         (gst_fakesrc_get_property), (gst_fakesrc_create),
1565         (gst_fakesrc_start):
1566           remove num-buffers property
1567
1568 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
1569
1570         * docs/gst/gstreamer-sections.txt:
1571         * docs/gst/tmpl/gstbasesink.sgml:
1572         * docs/gst/tmpl/gstbasesrc.sgml:
1573         * gst/base/gstbasesink.c: (gst_base_sink_pad_getcaps),
1574         (gst_base_sink_pad_setcaps), (gst_base_sink_pad_buffer_alloc),
1575         (gst_base_sink_finalize), (gst_base_sink_set_clock),
1576         (gst_base_sink_set_property), (gst_base_sink_get_property),
1577         (gst_base_sink_handle_object), (gst_base_sink_event),
1578         (gst_base_sink_do_sync), (gst_base_sink_handle_event),
1579         (gst_base_sink_handle_buffer), (gst_base_sink_chain),
1580         (gst_base_sink_loop), (gst_base_sink_deactivate),
1581         (gst_base_sink_activate_push), (gst_base_sink_activate_pull),
1582         (gst_base_sink_change_state):
1583         * gst/base/gstbasesink.h:
1584         * gst/base/gstbasesrc.h:
1585         * gst/elements/gstfakesink.c: (gst_fakesink_get_times):
1586         * gst/elements/gstfilesink.c: (gst_filesink_class_init),
1587         (gst_filesink_init):
1588           more macro splitting
1589
1590 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
1591
1592         * gst/gstelement.c: (gst_element_get_bus):
1593           add debug
1594         * tools/gst-launch.c: (check_intr), (event_loop):
1595           fix bus leaks
1596
1597 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
1598
1599         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked):
1600           fix a caps leak
1601
1602 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
1603
1604         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
1605         (gst_base_src_finalize):
1606           add finalize method and clean up properly
1607         * gst/gstpipeline.c: (gst_pipeline_dispose):
1608           add debug
1609
1610 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
1611
1612         * check/gst/gstbin.c: (pop_messages), (GST_START_TEST),
1613         (gst_bin_suite):
1614           add more things to check
1615         * gst/gstbin.c: (gst_bin_change_state), (bin_bus_handler):
1616         * gst/gstelement.c:
1617           more debug
1618
1619 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
1620
1621         * check/elements/gstfakesrc.c: (chain_func), (event_func),
1622         (GST_START_TEST), (fakesrc_suite):
1623         * check/gst-libs/gdp.c: (GST_START_TEST):
1624         * check/gst/gst.c: (GST_START_TEST):
1625         * check/gst/gstbin.c: (GST_START_TEST), (gst_bin_suite):
1626         * check/gst/gstbuffer.c: (GST_START_TEST), (gst_test_suite):
1627         * check/gst/gstbus.c: (GST_START_TEST):
1628         * check/gst/gstcaps.c: (GST_START_TEST):
1629         * check/gst/gstdata.c: (GST_START_TEST):
1630         * check/gst/gstelement.c: (GST_START_TEST):
1631         * check/gst/gstghostpad.c: (GST_START_TEST):
1632         * check/gst/gstiterator.c: (GST_START_TEST):
1633         * check/gst/gstmessage.c: (GST_START_TEST):
1634         * check/gst/gstobject.c: (GST_START_TEST):
1635         * check/gst/gstpad.c: (GST_START_TEST):
1636         * check/gst/gststructure.c: (GST_START_TEST):
1637         * check/gst/gstsystemclock.c: (GST_START_TEST),
1638         (gst_systemclock_suite):
1639         * check/gst/gsttag.c: (GST_START_TEST), (gst_tag_suite):
1640         * check/gst/gstvalue.c: (GST_START_TEST):
1641         * check/pipelines/cleanup.c: (GST_START_TEST):
1642         * check/pipelines/simple_launch_lines.c: (GST_START_TEST):
1643         * check/states/sinks.c: (GST_START_TEST):
1644         * check/gstcheck.c: (gst_check_init):
1645         * check/gstcheck.h:
1646           add debugging category
1647           use GST_START_TEST now, so we add a debug line
1648
1649 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
1650
1651         * check/gst/gstbin.c: (START_TEST), (gst_bin_suite):
1652           add test for state change message on a bin
1653         * check/gst/gstelement.c: (START_TEST), (gst_element_suite):
1654           add another test
1655         * gst/gstbin.c: (gst_bin_init):
1656         * gst/gstbus.c: (gst_bus_init), (gst_bus_post):
1657         * gst/gstelement.c: (gst_element_post_message),
1658         (gst_element_set_state):
1659         * gst/gstelementfactory.c: (gst_element_factory_create):
1660         * gst/gstmessage.c: (gst_message_new):
1661         * gst/gstscheduler.c:
1662           various debugging additions and cleanups
1663
1664 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1665
1666         * check/Makefile.am:
1667         * check/gst/gstelement.c: (START_TEST), (gst_element_suite),
1668         (main):
1669           adding tests for elements
1670         * gst/gstelement.c: (gst_element_dispose):
1671
1672 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1673
1674         * gst/registries/gstlibxmlregistry.c: (load_feature):
1675           plug more leaks.  A simple gst_init() now is leakfree, yay.
1676
1677 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1678
1679         * gst/registries/gstlibxmlregistry.c: (read_string), (load_paths),
1680         (gst_xml_registry_load):
1681           plug another memleak
1682
1683 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1684
1685         * configure.ac:
1686           use GST_SET_ERROR_CFLAGS
1687         * docs/faq/cvs.xml:
1688           change to ERROR_CFLAGS
1689
1690 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1691
1692         * configure.ac:
1693           make GST_ERROR_CFLAGS overridable and re-enable Werror
1694         * docs/faq/cvs.xml:
1695           add a note about error CFLAGS
1696         * docs/gst/tmpl/gstfakesrc.sgml:
1697         * gst/elements/gstfakesrc.c:
1698           comment out some unused code
1699         * gst/gst.c: (split_and_iterate):
1700         * gst/registries/gstlibxmlregistry.c: (load_pad_template),
1701         (load_feature):
1702           plug some memleaks
1703
1704 2005-07-07  Thomas Vander Stichele  <thomas at apestaart dot org>
1705
1706         * common/Makefile.am:
1707         * common/gtk-doc.mak:
1708         * docs/gst/Makefile.am:
1709           factor out gtk-doc.mak
1710
1711 2005-07-07  Wim Taymans  <wim@fluendo.com>
1712
1713         * gst/schedulers/threadscheduler.c: (gst_thread_scheduler_func),
1714         (gst_thread_scheduler_dispose):
1715         Unlock the STREAM_LOCK completely.
1716
1717 2005-07-07  Thomas Vander Stichele  <thomas at apestaart dot org>
1718
1719         * check/Makefile.am:
1720         * check/elements/.cvsignore:
1721         * check/elements/gstfakesrc.c: (chain_func), (event_func),
1722         (START_TEST), (fakesrc_suite), (main):
1723         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
1724         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
1725         (gst_fakesrc_create), (gst_fakesrc_start):
1726         * gst/elements/gstfakesrc.h:
1727           adding a first element test
1728
1729 2005-07-07  Andy Wingo  <wingo@pobox.com>
1730
1731         * gst/gstbus.c (gst_bus_have_pending): Remove intensely irritating
1732         debug message.
1733
1734 2005-07-07  Wim Taymans  <wim@fluendo.com>
1735
1736         * gst/gstquery.c:
1737         * gst/gstquery.h:
1738         Remove old types
1739
1740 2005-07-07  Wim Taymans  <wim@fluendo.com>
1741
1742         * gst/base/gstbasesrc.c: (gst_base_src_get_range),
1743         (gst_base_src_default_negotiate), (gst_base_src_negotiate):
1744         Allow subclasses to implement their own negotiation.
1745
1746 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
1747
1748         * docs/design/part-gstbin.txt:
1749         * docs/design/part-gstpipeline.txt:
1750           Update design notes to reflect the movement of
1751           responsibility for bus handling from GstPipeline to
1752           GstBin
1753
1754 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
1755
1756         * configure.ac:
1757           Remove unnecessary queue2/3/4 examples.
1758
1759 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
1760
1761         * examples/Makefile.am:
1762         * examples/helloworld/helloworld.c: (event_loop), (main):
1763         * examples/queue/queue.c: (event_loop), (main):
1764         * examples/queue2/queue2.c: (main):
1765           Update a couple of the examples to work again.
1766
1767         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
1768         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_event):
1769          Spelling corrections and extra debug.
1770         
1771         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_init), (is_eos),
1772         (gst_bin_add_func), (bin_element_is_sink), (gst_bin_get_state),
1773         (gst_bin_change_state), (gst_bin_dispose), (bin_bus_handler):
1774         * gst/gstbin.h:
1775         * gst/gstpipeline.c: (gst_pipeline_init), (gst_pipeline_dispose),
1776         (gst_pipeline_change_state):
1777         * gst/gstpipeline.h:
1778           Move the bus handler for children to the GstBin, and create a
1779           separate bus for receiving messages from children to the one the
1780           bus sends 'upwards' on.
1781
1782 2005-07-06  Wim Taymans  <wim@fluendo.com>
1783
1784         * gst/base/README:
1785         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
1786         (gst_base_sink_handle_object), (gst_base_sink_loop),
1787         (gst_base_sink_change_state):
1788         * gst/base/gstbasesink.h:
1789         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
1790         (gst_base_src_init), (gst_base_src_setcaps),
1791         (gst_base_src_getcaps), (gst_base_src_loop),
1792         (gst_base_src_default_negotiate), (gst_base_src_negotiate),
1793         (gst_base_src_start), (gst_base_src_change_state):
1794         * gst/base/gstbasesrc.h:
1795         Make basesrc negotiate.
1796         Handle the case where preroll fails in basesink.
1797         Update README.
1798
1799 2005-07-06  Wim Taymans  <wim@fluendo.com>
1800
1801         * gst/gstpad.c: (gst_pad_fixate_caps), (gst_pad_accept_caps):
1802         Implement the fixate function.
1803         Clean up acceptcaps.
1804
1805 2005-07-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1806
1807         * docs/pwg/building-filterfactory.xml:
1808         * docs/pwg/pwg.xml:
1809           Remove never-written filter-factory chapter; I'll add the various
1810           base classes to part 4 ("other element types") later on.
1811
1812 2005-07-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1813
1814         * docs/pwg/advanced-negotiation.xml:
1815         * docs/pwg/building-boiler.xml:
1816         * docs/pwg/building-pads.xml:
1817         * docs/pwg/pwg.xml:
1818         * examples/pwg/Makefile.am:
1819           Add a chapter on caps negotiation, simplify the original code
1820           samples a bit w.r.t. caps negotiation, add link to the advanced
1821           section. Add a bunch of examples showing different use cases of
1822           different types of caps negotiation. Upstream renegotiation isn't
1823           fully documented yet since nobody knows how that works.
1824
1825 2005-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
1826
1827         * check/gst/gstpad.c:
1828         * check/gstcheck.c:
1829         * gst/gstpad.c: (gst_pad_get_internal_links_default):
1830           if pad has no parent, return NULL as list of internal links
1831
1832 2005-07-05  Andy Wingo  <wingo@pobox.com>
1833
1834         * gst/elements/gstfilesrc.c:
1835         * gst/elements/gstfakesrc.c: 
1836         * gst/base/gstpushsrc.c:
1837         * gst/base/gstbasesrc.h: 
1838         * gst/base/gstbasesrc.c: s/BASESRC/BASE_SRC/g.
1839         
1840 2005-07-05  Stefan Kost  <ensonic@users.sf.net>
1841
1842         * Makefile.am:
1843           better report generation target (lcov needs a patch)
1844
1845 2005-07-05  Andy Wingo  <wingo@pobox.com>
1846
1847         * gst/elements, testsuite: Null if we got it...
1848
1849 2005-07-05  Wim Taymans  <wim@fluendo.com>
1850
1851         * configure.ac:
1852         * libs/gst/dataprotocol/Makefile.am:
1853         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_validate_packet):
1854         * libs/gst/dataprotocol/dataprotocol.h:
1855         * pkgconfig/Makefile.am:
1856         * pkgconfig/gstreamer-dataprotocol-uninstalled.pc.in:
1857         * pkgconfig/gstreamer-dataprotocol.pc.in:
1858         Ported dataprotol to 0.9. 
1859         Added pkgconfig files.
1860
1861 2005-07-05  Andy Wingo  <wingo@pobox.com>
1862
1863         * gst/base/gstbasetransform.c (gst_base_transform_setcaps):
1864         Default to returning TRUE for the case when tranform_caps returns
1865         a fixed caps, like for identity or volume.
1866
1867         * check/gst/gstbus.c (pound_bus_with_messages): 
1868         * check/gst/gstmessage.c (START_TEST): 
1869         * check/pipelines/simple_launch_lines.c (got_handoff): Application
1870         message API change.
1871
1872         * gst/base/gstbasetransform.c (gst_base_transform_setcaps): More
1873         logic weaks here: always run transform_caps, trying passthrough
1874         operation only if the original caps intersects with the transform.
1875
1876         * gst/gstpad.c (gst_pad_link_check_compatible_unlocked): Debug
1877         source and sink caps.
1878
1879         * gst/base/gstbasetransform.c (gst_base_transform_getcaps):
1880         Intersect the peer caps with the pad template before going into
1881         transform_caps.
1882         (gst_base_transform_transform_caps): More debugging.
1883
1884         * gst/gstmessage.h (gst_message_new_application): Take a GstObject
1885         src argument.
1886
1887 2005-07-04  Edward Hervey  <edward@fluendo.com>
1888
1889         * gst/gstutils.c:
1890         * gst/gstutils.h:
1891         (gst_pad_add_*_probe): now returns the signal id for better wrapping
1892         in bindings.
1893
1894 2005-07-04  Andy Wingo  <wingo@pobox.com>
1895
1896         * check/gst/gstpad.c: Only set explicit caps on pads.
1897
1898 2005-07-01  Andy Wingo  <wingo@pobox.com>
1899
1900         * tests/network-clock.scm: Commentary update.
1901
1902         * gst/elements/gstidentity.c (PROP_DUPLICATE): Gone daddy gone.
1903         Didn't really make sense, not implementable with basetransform,
1904         etc.
1905         (gst_identity_transform): Unref inbuf via make_writable. Feeble
1906         attempt at implementing the sync property, needs an unlock method.
1907
1908         * gst/base/gstbasetransform.c (gst_base_transform_transform_caps):
1909         New func, by default returns the same caps (the identity
1910         transformation).
1911         (gst_base_transform_getcaps): Uses transform_caps to return
1912         something sensible.
1913         (gst_base_transform_setcaps): Complicated logic to get caps on
1914         both pads, even if they are different, and to call set_caps once
1915         for every time both pads get their caps set.
1916         (gst_base_transform_handle_buffer): Give the ref to the transform
1917         function. Allows in-place modification of the buffer.
1918
1919         * gst/base/gstbasetransform.h (transform_caps): New class method.
1920         Given caps on one side, what can I do on the other.
1921         (set_caps): Take two caps, one for each side of the element.
1922
1923         * gst/gstpad.h:
1924         * gst/gstpad.c (gst_pad_fixate_caps): Change prototype to modify
1925         caps in place. This is safe because we can check the mutability of
1926         the caps, and a good idea because fixate functions are just called
1927         as a matter of last resort. (Not actually implemented.)
1928         (gst_pad_set_caps): If the caps we're setting is actually the same
1929         as the existing pad caps, just update the pointer without calling
1930         setcaps. Assert that caps is either NULL or fixed, as per the
1931         docs.
1932
1933         * gst/gstghostpad.c: Update for fixate changes.
1934
1935 2005-07-02  Andy Wingo  <wingo@pobox.com>
1936
1937         * gst/gstcaps.c:
1938         * gst/gstcaps.h (gst_static_caps_get): Not const return, having
1939         two refcounts makes it immutable, which is enough. Doc more.
1940
1941 2005-07-02  Jan Schmidt  <thaytan@mad.scientist.com>
1942
1943         * gst/gstpad.c: (gst_pad_emit_have_data_signal):
1944           Put the mini_object into GValue as a mini_object,
1945           not a gpointer, since that's how we declared
1946           the signal.
1947
1948 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1949
1950         * examples/pwg/Makefile.am:
1951           Fix buildbot again.
1952
1953 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1954
1955         * docs/pwg/building-testapp.xml:
1956           Add extra check.
1957         * examples/pwg/Makefile.am:
1958           Fix buildbot.
1959
1960 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1961
1962         * configure.ac:
1963         * examples/Makefile.am:
1964         * examples/pwg/Makefile.am:
1965         * examples/pwg/extract.pl:
1966           Enable building the PWG examples.
1967         * docs/pwg/advanced-interfaces.xml:
1968           Add URI interface stub.
1969         * docs/pwg/advanced-types.xml:
1970         * docs/pwg/other-autoplugger.xml:
1971         * docs/pwg/appendix-porting.xml:
1972         * docs/pwg/pwg.xml:
1973           Add porting guide (mostly stubs), remove autoplugging (see ADM).
1974         * docs/pwg/building-boiler.xml:
1975         * docs/pwg/building-chainfn.xml:
1976         * docs/pwg/building-pads.xml:
1977         * docs/pwg/building-props.xml:
1978         * docs/pwg/building-state.xml:
1979         * docs/pwg/building-testapp.xml:
1980           Update the building-*.xml parts for 0.9 changes. All examples
1981           code blocks compile in examples/pwg/*.
1982
1983 2005-06-30  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1984
1985         * docs/manual/advanced-autoplugging.xml:
1986         * docs/manual/appendix-checklist.xml:
1987         * docs/manual/appendix-integration.xml:
1988         * docs/manual/highlevel-components.xml:
1989           Fix playbin/decodebin examples, update docs a bit, mention bus
1990           instead of signals in various places, mention kmplayer and
1991           kaffeine since they have a working GStreamer backend in the KDE
1992           section.
1993
1994 2005-06-30  Wim Taymans  <wim@fluendo.com>
1995
1996         * CHANGES-0.9:
1997         * docs/design/draft-ghostpads.txt:
1998         * docs/design/draft-push-pull.txt:
1999         * docs/design/draft-query.txt:
2000         * docs/design/part-TODO.txt:
2001         * docs/design/part-query.txt:
2002         Added CHANGES-0.9 doc, updated status of other docs.
2003         
2004         * gst/gstquery.h:
2005         Remove "hmm" macro
2006
2007 2005-06-30  Wim Taymans  <wim@fluendo.com>
2008
2009         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
2010         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_object),
2011         (gst_base_sink_change_state):
2012         * gst/base/gstbasesink.h:
2013         Some tweaks, only EOS and a buffer complete a preroll.
2014
2015 2005-06-30  Andy Wingo  <wingo@pobox.com>
2016
2017         * gst/gstghostpad.c (gst_ghost_pad_do_activate_push): Proxy
2018         activate_push down to the internal pad as well.
2019
2020 2005-06-30  Torsten Schoenfeld  <kaffeetisch@gmx.de>
2021
2022         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2023
2024         * gst/gsttaginterface.c:
2025           Some documentation fixes (#307394 and #307397).
2026
2027 2005-06-30  Antoine Tremblay  <hexa00@gmail.com>
2028
2029         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2030
2031         * gst/gstvalue.c: (gst_value_intersect_list):
2032           Fix memleak (#309125).
2033
2034 2005-06-30  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2035
2036         * docs/manual/advanced-dataaccess.xml:
2037           Fix fakesrc example to compile; doesn't work, bug somewhere...?
2038         * docs/manual/basics-pads.xml:
2039           Add reference for filtered caps to above chapter.
2040
2041 2005-06-30  Wim Taymans  <wim@fluendo.com>
2042
2043         * gst/gstbin.c: (clear_queue), (remove_all_from_queue),
2044         (gst_bin_change_state):
2045         Probes are gone.
2046         Lame attempt at making the state change function a bit
2047         more readable.
2048
2049 2005-06-30  Wim Taymans  <wim@fluendo.com>
2050
2051         * docs/design/part-clocks.txt:
2052         * docs/design/part-element-sink.txt:
2053         * docs/design/part-events.txt:
2054         * docs/design/part-preroll.txt:
2055         * docs/design/part-states.txt:
2056         Some more tweeks and additions to the docs.
2057
2058 2005-06-30  Wim Taymans  <wim@fluendo.com>
2059
2060         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
2061         (default_have_data), (gst_pad_class_init), (gst_pad_init),
2062         (gst_pad_emit_have_data_signal), (gst_pad_chain), (gst_pad_push),
2063         (gst_pad_check_pull_range), (gst_pad_get_range),
2064         (gst_pad_pull_range), (gst_pad_push_event), (gst_pad_send_event):
2065         * gst/gstpad.h:
2066         * gst/gstutils.c: (gst_atomic_int_set), (gst_pad_add_data_probe),
2067         (gst_pad_add_event_probe), (gst_pad_add_buffer_probe),
2068         (gst_pad_remove_data_probe), (gst_pad_remove_event_probe),
2069         (gst_pad_remove_buffer_probe):
2070         Removed atomic operations, use existing LOCK.
2071         Move exception handling out of main code path.
2072
2073 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2074
2075         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
2076         (silly_return_true_function), (gst_pad_class_init),
2077         (gst_pad_emit_have_data_signal), (gst_pad_chain), (gst_pad_push),
2078         (gst_pad_get_range), (gst_pad_pull_range), (gst_pad_push_event),
2079         (gst_pad_send_event):
2080           Fix accumulator, add default value by using _emitv() instead
2081           of _emit() for signal emission.
2082
2083 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2084
2085         * docs/manual/advanced-dataaccess.xml:
2086         * examples/manual/Makefile.am:
2087           Add probe example.
2088         * gst/gstpad.c: (_gst_do_pass_data_accumulator):
2089           Make work (??).
2090
2091 2005-06-29  Tim-Philipp Müller  <tim at centricular dot net>
2092
2093         * gst/elements/gstfilesink.c: (gst_filesink_render):
2094           Simplify code so that we don't have to handle short
2095           writes and return GST_FLOW_ERROR if an error occured.
2096
2097 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2098
2099         * docs/gst/gstreamer-docs.sgml:
2100           Remove probes more.
2101
2102 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2103
2104         * docs/gst/gstreamer-sections.txt:
2105         * docs/gst/tmpl/gstpad.sgml:
2106         * docs/gst/tmpl/gstprobe.sgml:
2107         * gst/Makefile.am:
2108         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
2109         (gst_pad_class_init), (gst_pad_init), (gst_pad_chain),
2110         (gst_pad_push), (gst_pad_get_range), (gst_pad_pull_range),
2111         (gst_pad_push_event), (gst_pad_send_event):
2112         * gst/gstpad.h:
2113         * gst/gstutils.c: (gst_pad_add_data_probe),
2114         (gst_pad_add_event_probe), (gst_pad_add_buffer_probe),
2115         (gst_pad_remove_data_probe), (gst_pad_remove_event_probe),
2116         (gst_pad_remove_buffer_probe):
2117         * gst/gstutils.h:
2118           Remove old probes, add new g-signal-based probes and some utility
2119           functions.
2120
2121 2005-06-29  Edward Hervey  <edward@fluendo.com>
2122
2123         * gst/gstelementfactory.c:
2124         * gst/gstutils.h:
2125         * gst/gstutils.c:
2126         Moved gst_element_factory_can_[sink|src]_caps() to gstutils and added
2127         the definition to the header file.
2128
2129 2005-06-29  Andy Wingo  <wingo@pobox.com>
2130
2131         * docs/gst/Makefile.am (scan-build.stamp): Totally only check
2132         plugins from the source directory.
2133
2134 2005-06-29  Wim Taymans  <wim@fluendo.com>
2135
2136         * docs/gst/tmpl/gstbuffer.sgml:
2137         * docs/gst/tmpl/gstclock.sgml:
2138         Some fixings for blantently wrong text.
2139
2140 2005-06-29  Thomas Vander Stichele  <thomas at apestaart dot org>
2141
2142         * check/Makefile.am:
2143         * gst/gst.c: (add_path_func), (init_pre):
2144         * gst/gstregistry.c: (gst_registry_add_path):
2145           add A GST_PLUGIN_PATH_ONLY env var; if it is set, it will
2146           only scan the GST_PLUGIN_PATH locations, and not add
2147           system locations
2148
2149 2005-06-29  Thomas Vander Stichele  <thomas at apestaart dot org>
2150
2151         * docs/gst/gstreamer-sections.txt:
2152         * docs/gst/tmpl/gstbasesrc.sgml:
2153         * gst/gstelement.c:
2154         * gst/gstelement.h:
2155         * gst/gstevent.c:
2156         * gst/gstutils.c:
2157           doc fixes
2158
2159 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2160
2161         * docs/manual/advanced-autoplugging.xml:
2162           Fix autoplugging example.
2163
2164 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2165
2166         * docs/manual/advanced-autoplugging.xml:
2167         * docs/manual/mime-world.fig:
2168           Try to get autoplugging working, fix type detection. Fix text
2169           in hello-world image.
2170
2171 2005-06-29  Wim Taymans  <wim@fluendo.com>
2172
2173         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
2174         (gst_base_sink_change_state):
2175         Small debug line.
2176
2177         * gst/gstclock.h:
2178         map SIGNAL and BROADCAST to the right function.
2179
2180         * gst/gstobject.h:
2181         Remove redundant braces.
2182
2183         * gst/gstpad.c: (gst_pad_set_caps):
2184         Don't call setcaps function when reseting caps to NULL.
2185
2186         * gst/gstsystemclock.c: (gst_system_clock_dispose),
2187         (gst_system_clock_async_thread), (gst_system_clock_id_wait_async),
2188         (gst_system_clock_id_unschedule):
2189         Use BROADCAST as this is what we do.
2190
2191 2005-06-29  Wim Taymans  <wim@fluendo.com>
2192
2193         * gst/base/gstbasesink.c: (gst_base_sink_handle_object):
2194         We are actually prerolling before commiting the state
2195         change. 
2196
2197 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2198
2199         * docs/manual/advanced-clocks.xml:
2200         * docs/manual/advanced-interfaces.xml:
2201         * docs/manual/advanced-metadata.xml:
2202         * docs/manual/advanced-position.xml:
2203         * docs/manual/advanced-schedulers.xml:
2204         * docs/manual/advanced-threads.xml:
2205         * docs/manual/appendix-porting.xml:
2206         * docs/manual/basics-bins.xml:
2207         * docs/manual/basics-bus.xml:
2208         * docs/manual/basics-elements.xml:
2209         * docs/manual/basics-helloworld.xml:
2210         * docs/manual/basics-pads.xml:
2211         * docs/manual/highlevel-components.xml:
2212         * docs/manual/manual.xml:
2213         * docs/manual/thread.fig:
2214           Update (until threads/scheduling) Application Development Manual;
2215           remove GstThread, add GstBus, add simple porting checklist, add
2216           documentation for tag writing, clocks, make all examples until this
2217           part compile and run.
2218         * examples/manual/Makefile.am:
2219           Update from changes to Application Development Manual; add bus
2220           example, remove thread example.
2221
2222 2005-06-28  Wim Taymans  <wim@fluendo.com>
2223
2224         * gst/gstbus.c: (gst_bus_post), (gst_bus_have_pending),
2225         (gst_bus_set_flushing), (gst_bus_pop), (gst_bus_peek),
2226         (gst_bus_source_dispatch):
2227         Add debugging messages.
2228         Make internal methods static.
2229         Handle the case where the bus is flushed in the handler.
2230         
2231         * gst/gstelement.c: (gst_element_get_bus):
2232         Fix refcount in _get_bus();
2233
2234         * gst/gstpipeline.c: (gst_pipeline_change_state),
2235         (gst_pipeline_get_clock_func):
2236         Clock refcounting fixes.
2237         Handle the case where preroll timed out more gracefully.
2238         
2239         * gst/gstsystemclock.c: (gst_system_clock_dispose):
2240         Clean up the internal thread in dispose. This is needed
2241         for subclasses that actually get disposed.
2242         
2243         * gst/schedulers/threadscheduler.c:
2244         (gst_thread_scheduler_class_init), (gst_thread_scheduler_func),
2245         (gst_thread_scheduler_dispose):
2246         Free thread pool in dispose.
2247
2248 2005-06-28  Andy Wingo  <wingo@pobox.com>
2249
2250         * tests/network-clock-utils.scm (debug, print-event): New utils.
2251
2252         * tests/network-clock.scm (*debug*, *with-graph*): New parameters.
2253         (*packet-loss*): Unified loss probability.
2254         (network-time): Report out-of-band events.
2255
2256         * tests/plot-data: Add support for out-of-band events. Hack it
2257         into this script instead of passing it down the pipe; should fix
2258         this later.
2259
2260 2005-06-28  Wim Taymans  <wim@fluendo.com>
2261
2262         * docs/gst/gstreamer.types:
2263         * docs/gst/tmpl/gstbasesrc.sgml:
2264         * docs/gst/tmpl/gstpad.sgml:
2265         Docs fixes.
2266
2267 2005-06-28  Wim Taymans  <wim@fluendo.com>
2268
2269         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
2270         (gst_proxy_pad_do_checkgetrange), (gst_proxy_pad_do_acceptcaps),
2271         (gst_proxy_pad_do_fixatecaps):
2272         Correctly proxy the check_pull_range function.
2273
2274 2005-06-28  Andy Wingo  <wingo@pobox.com>
2275
2276         * tests/network-clock.scm: Removed need for slib.
2277         
2278 2005-06-28  Wim Taymans  <wim@fluendo.com>
2279
2280         * gst/base/gstbasesink.c: (gst_basesink_set_pad_functions),
2281         (gst_basesink_preroll_queue_flush):
2282         * gst/base/gstbasesrc.c: (gst_basesrc_set_dataflow_funcs):
2283         * gst/elements/gsttee.c: (gst_tee_update_pad_functions):
2284         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
2285         (gst_proxy_pad_do_acceptcaps), (gst_proxy_pad_do_fixatecaps),
2286         (gst_proxy_pad_set_property):
2287         * gst/gstpad.c:
2288         * gst/gstpad.h:
2289         * gst/gstqueue.c: (gst_queue_init):
2290         The deprecated pad loop function is removed now.
2291
2292 2005-06-28  Andy Wingo  <wingo@pobox.com>
2293
2294         * tests/network-clock.scm (*timeout*, *send-loss*, *recv-loss*):
2295         New parameters, simulate network packet loss.
2296
2297         * tests/network-clock-utils.scm: Initialize the RNG.
2298
2299 2005-06-28  Wim Taymans  <wim@fluendo.com>
2300
2301         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_flush),
2302         (gst_basesink_event), (gst_basesink_deactivate):
2303         Flushing the preroll queue always needs to unlock the waiters.
2304
2305 2005-06-28  Edward Hervey  <edward@fluendo.com>
2306
2307         * gst/gstpipeline.c: (gst_pipeline_send_event): 
2308         Wheen a seek was successful on a pipeline, set the stream_time to the
2309         seek offset in order to have a synchronized stream_time.
2310
2311 2005-06-28  Wim Taymans  <wim@fluendo.com>
2312
2313         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
2314         (gst_proxy_pad_do_getrange), (gst_proxy_pad_do_checkgetrange),
2315         (gst_proxy_pad_do_getcaps), (gst_proxy_pad_do_acceptcaps),
2316         (gst_proxy_pad_do_fixatecaps):
2317         Call wrapper function instead of just calling the function
2318         pointers. This takes care of any locking and whatmore.
2319
2320 2005-06-28  Wim Taymans  <wim@fluendo.com>
2321
2322         * gst/gstpad.c: (gst_pad_alloc_buffer), (gst_pad_push),
2323         (gst_pad_pull_range):
2324         * gst/gstpad.h:
2325         CONNECTED -> LINKED.
2326
2327 2005-06-28  Andy Wingo  <wingo@pobox.com>
2328
2329         * *.c: Don't cast to GST_OBJECT when reffing or unreffing. Large
2330         source-munging commit!!!
2331
2332         * gst/gstobject.c (gst_object_unref, gst_object_ref) 
2333         (gst_object_sink): Take gpointer arguments, not GstObject --
2334         avoids casts. Like GLib.
2335
2336         * gst/gstghostpad.c (gst_proxy_pad_do_activate): Don't proxy
2337         activate.
2338
2339 2005-06-27  Andy Wingo  <wingo@pobox.com>
2340
2341         * gst/base/gsttypefindhelper.c (gst_type_find_helper): Unref any
2342         remaining buffer.
2343
2344         * gst/gsttrace.c (gst_alloc_trace_list_sorted): New helper,
2345         returns a sorted copy of the trace list.
2346         (gst_alloc_trace_print_live): New API, only prints traces with
2347         live objects. Sort the list.
2348         (gst_alloc_trace_print_all): Sort the list.
2349         (gst_alloc_trace_print): Align columns.
2350
2351         * gst/elements/gstttypefindelement.c:
2352         * gst/elements/gsttee.c:
2353         * gst/base/gstbasesrc.c:
2354         * gst/base/gstbasesink.c:
2355         * gst/base/gstbasetransform.c:
2356         * gst/gstqueue.c: Adapt for pad activation changes.
2357
2358         * gst/gstpipeline.c (gst_pipeline_init): Unref after parenting
2359         sched.
2360         (gst_pipeline_dispose): Drop ref on sched.
2361
2362         * gst/gstpad.c (gst_pad_init): Set the default activate func.
2363         (gst_pad_activate_default): Push mode by default.
2364         (pre_activate_switch, post_activate_switch): New stubs, things to
2365         do before and after switching activation modes on pads.
2366         (gst_pad_set_active): Take a boolean and not a mode, dispatch to
2367         the pad's activate function to choose which mode to activate.
2368         Shortcut on deactivation and call the right function directly.
2369         (gst_pad_activate_pull): New API, (de)activates a pad in pull
2370         mode.
2371         (gst_pad_activate_push): New API, same for push mode.
2372         (gst_pad_set_activate_function) 
2373         (gst_pad_set_activatepull_function) 
2374         (gst_pad_set_activatepush_function): Setters for new API.
2375
2376         * gst/gstminiobject.c (gst_mini_object_new, gst_mini_object_free):
2377         Trace all miniobjects.
2378         (gst_mini_object_make_writable): Unref the arg if we copy, like
2379         gst_caps_make_writable.
2380
2381         * gst/gstmessage.c (_gst_message_initialize): No trace init.
2382
2383         * gst/gstghostpad.c (gst_proxy_pad_do_activate) 
2384         (gst_proxy_pad_do_activatepull, gst_proxy_pad_do_activatepush):
2385         Adapt for new pad API.
2386
2387         * gst/gstevent.c (_gst_event_initialize): Don't initialize trace.
2388
2389         * gst/gstelement.h:
2390         * gst/gstelement.c (gst_element_iterate_src_pads) 
2391         (gst_element_iterate_sink_pads): New API functions.
2392         
2393         * gst/gstelement.c (iterator_fold_with_resync): New utility,
2394         should fold into gstiterator.c in some form.
2395         (gst_element_pads_activate): Simplified via use of fold and
2396         delegation of decisions to gstpad->activate.
2397
2398         * gst/gstbus.c (gst_bus_source_finalize): Set the bus to NULL,
2399         help in debugging.
2400
2401         * gst/gstbuffer.c (_gst_buffer_initialize): Ref the buffer type
2402         class once in init, like gstmessage. Didn't run into this issue
2403         but it seems correct. Don't initialize a trace, gstminiobject does
2404         that.
2405
2406         * check/pipelines/simple_launch_lines.c (test_stop_from_app): New
2407         test, runs fakesrc ! fakesink, stopping on ::handoff via a message
2408         to the bus.
2409         (assert_live_count): New util function, uses alloc traces to check
2410         cleanup.
2411
2412         * check/gst/gstghostpad.c (test_ghost_pads): More refcount checks.
2413         To be modified when unlink drops the internal pad.
2414
2415 2005-06-27  Wim Taymans  <wim@fluendo.com>
2416
2417         * gst/gstbin.c: (gst_bin_get_state), (gst_bin_iterate_state_order),
2418         (gst_bin_change_state):
2419         Cleanup the get_state() function a little, make sure it
2420         iterates the same set of elements.
2421         Added stub iterate_state_order().
2422
2423 2005-06-27  Thomas Vander Stichele  <thomas at apestaart dot org>
2424
2425         * docs/gst/gstreamer-docs.sgml:
2426         * docs/gst/gstreamer-sections.txt:
2427         * docs/gst/gstreamer.types:
2428         * docs/gst/tmpl/gstbasesink.sgml:
2429         * docs/gst/tmpl/gstbasesrc.sgml:
2430         * docs/gst/tmpl/gstbasetransform.sgml:
2431         * docs/gst/tmpl/gstelement.sgml:
2432         * docs/gst/tmpl/gstiterator.sgml:
2433         * gst/base/gstbasesrc.c:
2434         * gst/base/gstbasesrc.h:
2435         * gst/base/gstbasetransform.h:
2436         * gst/gstelement.c:
2437         * gst/gstiterator.h:
2438           adding basetransform and iterator docs
2439
2440 2005-06-27  Andy Wingo  <wingo@pobox.com>
2441
2442         * docs/design/part-activation.txt: Notes on how activation should
2443         work -- not quite implemented yet.
2444
2445 2005-06-25  Wim Taymans  <wim@fluendo.com>
2446
2447         * gst/gstghostpad.c: (gst_proxy_pad_do_chain):
2448         At least get the chain function correct, needs more
2449         fixing.
2450
2451 2005-06-25  Wim Taymans  <wim@fluendo.com>
2452
2453         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
2454         (gst_basesink_handle_object), (gst_basesink_event),
2455         (gst_basesink_do_sync), (gst_basesink_handle_event),
2456         (gst_basesink_change_state):
2457         * gst/gsttask.h:
2458         Right, two problems here: ghostpads don't take locks and
2459         glib _rec_mutex_lock_full() with depth==0 still locks.
2460         Catch illegal locking and g_warn them.
2461
2462 2005-06-25  Wim Taymans  <wim@fluendo.com>
2463
2464         * check/states/sinks.c: (START_TEST), (gst_object_suite):
2465         Have to check for completion now...
2466
2467 2005-06-25  Wim Taymans  <wim@fluendo.com>
2468
2469         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
2470         (gst_basesink_handle_object), (gst_basesink_event),
2471         (gst_basesink_do_sync), (gst_basesink_handle_event),
2472         (gst_basesink_change_state):
2473         * gst/gstpad.h:
2474         Unlock STREAM_LOCK whatever the recursion was.
2475
2476 2005-06-25  Wim Taymans  <wim@fluendo.com>
2477
2478         * gst/base/gstbasesink.c: (gst_basesink_set_property),
2479         (gst_basesink_preroll_queue_empty),
2480         (gst_basesink_preroll_queue_flush), (gst_basesink_handle_object),
2481         (gst_basesink_event), (gst_basesink_do_sync),
2482         (gst_basesink_handle_event), (gst_basesink_handle_buffer),
2483         (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate),
2484         (gst_basesink_change_state):
2485         Reworked the base sink, handle event and buffer serialisation
2486         correctly and removed possible deadlock.
2487         Handle EOS correctly.
2488
2489 2005-06-25  Wim Taymans  <wim@fluendo.com>
2490
2491         * gst/gstpipeline.c: (is_eos), (pipeline_bus_handler),
2492         (gst_pipeline_change_state):
2493         * tools/gst-launch.c: (check_intr), (event_loop), (main):
2494         Allow elements to post EOS in the state change function.
2495         Fix up -launch, make it exit the poll loop when the
2496         pipeline actually changed state.
2497         Fix up warning parsing in -launch.
2498
2499 2005-06-25  Wim Taymans  <wim@fluendo.com>
2500
2501         * gst/elements/gsttee.c: (gst_tee_chain), (gst_tee_loop),
2502         (gst_tee_sink_activate):
2503         Core takes STREAM_LOCK for us now.
2504
2505 2005-06-25  Wim Taymans  <wim@fluendo.com>
2506
2507         * gst/gstelement.c: (gst_element_get_state_func),
2508         (gst_element_set_state):
2509         * gst/gstelement.h:
2510         * gst/gstmessage.c: (gst_message_parse_error),
2511         (gst_message_parse_warning):
2512         Keep track of current target state while performing a state
2513         change so that subclasses can do something interesting.
2514         Fix parsing of warning/error messages when GError is NULL.
2515
2516 2005-06-24  Thomas Vander Stichele  <thomas at apestaart dot org>
2517
2518         * docs/gst/Makefile.am:
2519         * docs/gst/gstreamer-docs.sgml:
2520         * docs/gst/gstreamer-sections.txt:
2521         * docs/gst/gstreamer.types:
2522         * docs/gst/tmpl/gstbasesink.sgml:
2523         * docs/gst/tmpl/gstbasesrc.sgml:
2524         * docs/gst/tmpl/gstbin.sgml:
2525         * docs/gst/tmpl/gstcompat.sgml:
2526         * docs/gst/tmpl/gstfakesink.sgml:
2527         * docs/gst/tmpl/gstfakesrc.sgml:
2528         * docs/gst/tmpl/gstfilesink.sgml:
2529         * docs/gst/tmpl/gstfilesrc.sgml:
2530         * docs/gst/tmpl/gstindex.sgml:
2531         * docs/manual/appendix-quotes.xml:
2532         * gst/base/gstbasesrc.h:
2533         * gst/elements/gstfakesrc.h:
2534         * gst/gstmessage.h:
2535           start pulling in base classes and elements in our docs
2536
2537 2005-06-24  Stefan Kost  <ensonic@users.sf.net>
2538
2539         * docs/gst/Makefile.am:
2540         * docs/libs/Makefile.am:
2541           fixed make distcheck with gtk-doc 1.3
2542
2543 2005-06-23  Wim Taymans  <wim@fluendo.com>
2544
2545         * gst/gstelement.c: (gst_element_get_state_func),
2546         (gst_element_set_state), (gst_element_change_state):
2547         When the state did not change, also report NO_PREROLL
2548         when it matters.
2549
2550 2005-06-23  Wim Taymans  <wim@fluendo.com>
2551
2552         * gst/gstpad.c: (gst_pad_event_default):
2553         * gst/gstqueue.c: (gst_queue_loop):
2554         No unsafe task pausing please.
2555
2556 2005-06-23  Wim Taymans  <wim@fluendo.com>
2557
2558         * gst/schedulers/threadscheduler.c:
2559         (gst_thread_scheduler_task_start),
2560         (gst_thread_scheduler_task_pause), (gst_thread_scheduler_func):
2561         Ref the task before pushing it on the threadpool. This
2562         makes sure that we have a ref when the threadfunction is
2563         actually called.
2564
2565 2005-06-23  Andy Wingo  <wingo@pobox.com>
2566
2567         * gst/base/gstbasesrc.c (gst_basesrc_get_range): Check if the
2568         offset is greater than the file's size.
2569
2570         * gst/gstobject.h (GST_CLASS_LOCK, GST_CLASS_TRYLOCK) 
2571         (GST_CLASS_UNLOCK, GST_CLASS_GET_LOCK, GstObjectClass)
2572         * gst/gstobject.c (gst_object_class_init): Make the class lock
2573         recursive. Wim won't let me drop deep_notify. Decodebin works
2574         again, whoopdy doo.
2575
2576         * gst/gstghostpad.c (on_int_notify): Catches notify::caps on the
2577         internal pad, and hacks accordingly. Doesn't do it on the target
2578         pad because we change its caps. Probably catches all cases of
2579         interest tho.
2580         (gst_ghost_pad_set_property): Connect to notify::caps as
2581         appropritate.
2582
2583         * tests/network-clock.scm (plot-simulation): Pipe data to the
2584         elite python skript.
2585
2586         * tests/network-clock-utils.scm (define-parameter): New macro,
2587         defines a parameter that can be set via the command line.
2588         (set-parameter!, parse-parameter-arguments): Command line args
2589         parser.
2590
2591         * tests/plot-data: Simple matplotlib-based plotter, takes input on
2592         stdin.
2593
2594 2005-06-23  Jan Schmidt  <thaytan@mad.scientist.com>
2595
2596         * gst/elements/gsttypefindelement.c:
2597         (gst_type_find_element_handle_event):
2598           Don't restart typefinding on a discont.
2599         * gst/gstelement.c: (gst_element_set_state):
2600           Debug spelling fix.
2601         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_send_event):
2602           Allow changing mode of an active pad.
2603           Debug output fixes.
2604         * gst/registries/gstlibxmlregistry.c: (load_feature):
2605           Don't cast a static pad template to a normal pad template.
2606
2607 2005-06-23  Thomas Vander Stichele  <thomas at apestaart dot org>
2608
2609         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
2610         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
2611           remove gst_strtoll completely, since it didn't actually do
2612           anything more than what g_ascii_strtoull already does.
2613           check for range errors when deserializing
2614           do a cast for the unsigned cases; but further fixing needs
2615           a decision on what the interpretation of "(int)" and
2616           deserialization should be for values that fall outside the
2617           type's boundaries (ie, refuse, or interpret as casting)
2618
2619 2005-06-23  Wim Taymans  <wim@fluendo.com>
2620
2621         * check/Makefile.am:
2622         * check/states/sinks.c: (START_TEST), (gst_object_suite), (main):
2623         * docs/design/part-live-source.txt:
2624         * docs/design/part-states.txt:
2625         * gst/base/gstbasesrc.c: (gst_basesrc_init),
2626         (gst_basesrc_set_live), (gst_basesrc_is_live),
2627         (gst_basesrc_get_range), (gst_basesrc_activate),
2628         (gst_basesrc_change_state):
2629         * gst/base/gstbasesrc.h:
2630         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
2631         (gst_fakesrc_set_property), (gst_fakesrc_get_property):
2632         * gst/gstbin.c: (gst_bin_get_state), (gst_bin_change_state):
2633         * gst/gstelement.c: (gst_element_get_state_func),
2634         (gst_element_set_state):
2635         * gst/gstelement.h:
2636         * gst/gsttypes.h:
2637         * tools/gst-launch.c: (event_loop), (main):
2638         Added support for live sources and other elements that
2639         cannot do preroll.
2640         Updated design docs, added live-source design doc.
2641         Implemented live source functionality in basesrc
2642         Fix error condition in _bin_get_state()
2643         Implement live source handling in -launch.
2644         Added check for live sources.
2645         Fixed case in GstBin where elements were changed state
2646         multiple times.
2647
2648
2649 2005-06-23  Andy Wingo  <wingo@pobox.com>
2650
2651         * check/gst/gstpad.c (test_get_allowed_caps, test_refcount): Fix
2652         borken refcounting.
2653
2654         * gst/gstpad.c (gst_pad_set_caps): Remove needless refs,
2655         gst_caps_replace takes care of this for us.
2656
2657         * gst/gstghostpad.c (gst_proxy_pad_do_setcaps): Call the full
2658         gst_pad_set_caps on the target, not just its setcaps() function.
2659
2660         * tests/network-clock.scm: 
2661         * tests/network-clock-utils.scm: A network clock simulator.
2662         Something of an algorithmic testbed before doing something in C.
2663
2664 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
2665
2666         * check/Makefile.am:
2667         * check/gst/capslist.h:
2668           copy over from 0.8, and add two with bitmasks specified with
2669           (int) 0xFF...
2670         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite):
2671           add test to parse everything from capslist.h
2672         * check/gst/gststructure.c: (START_TEST), (gst_value_suite),
2673         (main):
2674           add test for structure deserialization
2675         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
2676           add tests for deserialization of strings to int types
2677         * gst/gststructure.c: (gst_structure_nth_field_name):
2678         * gst/gststructure.h:
2679           add a way to get the name of a field referenced by index
2680         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
2681           instead of checking if the resulting long long lies between
2682           min and max, we check if the long long would fit into
2683           a number of bytes for the final type.
2684           This fixes cases where a string represents 2^32 - 1, which
2685           when cast to int would be the (valid) -1, but is bigger than
2686           G_MAXINT
2687
2688 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
2689
2690         * gst/parse/grammar.y:
2691           add a log line for type deserialization
2692
2693 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
2694
2695         * check/gst/gstvalue.c: (START_TEST):
2696         * gst/gstvalue.c: (gst_value_deserialize):
2697           return long long, not int, so gint64 deserialization actually
2698           works.  Is there any flag that makes the compiler check this ?
2699           Fixes #308559
2700
2701 2005-06-22  Wim Taymans  <wim@fluendo.com>
2702
2703         * gst/gstbuffer.h:
2704         Added convenience macros for setting buffers in GValue.
2705
2706 2005-06-21  Thomas Vander Stichele  <thomas at apestaart dot org>
2707
2708         * check/gst/.cvsignore:
2709         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
2710           add a test deserializing int64, and comment part out because
2711           it fails, yay !
2712
2713 2005-06-21  Thomas Vander Stichele  <thomas at apestaart dot org>
2714
2715         * check/Makefile.am:
2716         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite), (main):
2717         * testsuite/Makefile.am:
2718         * testsuite/caps/Makefile.am:
2719         * testsuite/caps/value_serialize.c:
2720         * testsuite/test_gst_init.c:
2721           move a value_serialize test over
2722
2723 2005-06-20  Wim Taymans  <wim@fluendo.com>
2724
2725         * gst/gstpad.c:
2726         Small doc updates.
2727         
2728         * gst/gstvalue.c: (gst_value_compare_buffer),
2729         (gst_value_serialize_buffer), (gst_value_deserialize_buffer),
2730         (gst_value_compare_flags), (gst_value_serialize_flags),
2731         (gst_value_deserialize_flags), (_gst_value_initialize):
2732         Fix serialisation of buffers, they are not boxed types anymore
2733
2734 2005-06-20  Wim Taymans  <wim@fluendo.com>
2735
2736         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite):
2737         Testcase to show error in buffer-on-caps serialisation.
2738
2739 2005-06-20  Andy Wingo  <wingo@pobox.com>
2740
2741         * docs/random/wingo/porting-plugins-to-0.9: A pitiful document I
2742         will be adding to later.
2743
2744         * gst/gstsystemclock.c (gst_system_clock_init): Unlock the clock
2745         if its socks fill with rocks.
2746         (gst_system_clock_obtain): Set the name on object construction.
2747         Avoid double-checked locking.
2748
2749 2005-06-20  Tim-Philipp Müller  <tim at centricular dot net>
2750
2751         * gst/gsturi.c: (gst_element_make_from_uri):
2752           Fix potential endless loop.
2753
2754 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
2755
2756         * check/Makefile.am:
2757           add gsttag
2758         * check/gst/gsttag.c: (check_tags), (START_TEST), (gst_tag_suite),
2759         (main):
2760           move over from testsuite dir and clean up
2761         * configure.ac:
2762         * gst/gsttag.c:
2763         * testsuite/Makefile.am:
2764         * testsuite/tags/.cvsignore:
2765         * testsuite/tags/Makefile.am:
2766         * testsuite/tags/merge.c:
2767           remove testsuite/tags
2768
2769 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
2770
2771         * docs/gst/gstreamer-sections.txt:
2772         * docs/gst/tmpl/gstenumtypes.sgml:
2773         * win32/gstenumtypes.c:
2774           clean up documentation build a little
2775
2776 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
2777
2778         * check/gstcheck.h:
2779           add macros for checking refcounts on objects and caps
2780         * check/gst/gstpad.c: (START_TEST), (gst_pad_suite):
2781           add some more unit tests
2782         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked),
2783         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_get_allowed_caps):
2784           fix leaked refcounts (I hope :)) so unittest works
2785         * gst/gstpad.h:
2786           whitespace removal
2787
2788 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
2789
2790         * configure.ac: back to HEAD
2791
2792 === release 0.9.1 ===
2793
2794 2005-06-17  Thomas Vander Stichele  <thomas at apestaart dot org>
2795
2796         * NEWS:
2797         * RELEASE:
2798           updated
2799
2800 2005-06-17  Andy Wingo  <wingo@pobox.com>
2801
2802         * gst/base/gstbasesink.c (gst_basesink_chain): Remove bogus
2803         assert; it's always possible that the pad gets deactivated in
2804         between the checks in gstpad.c and the implementation. Rely on
2805         finish_preroll() to return a FLUSHING or similar instead of on the
2806         assert.
2807         
2808         * gst/base/gstbasesink.c (gst_basesink_event): Only wait for the
2809         clock and post an EOS message if we come out of finish_preroll in
2810         the playing state.
2811
2812 2005-06-16  David Schleef  <ds@schleef.org>
2813
2814         * gst/elements/gstcapsfilter.c: (gst_capsfilter_class_init),
2815         (gst_capsfilter_set_property): Allow NULL as possible value
2816         for filter_caps property, indicating GST_CAPS_ANY.
2817
2818 2005-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
2819
2820         * gst/elements/gstfakesrc.c: (gst_fakesrc_create):
2821           fix debug output
2822         * gst/schedulers/Makefile.am:
2823           use libgst prefix
2824         * gstreamer.spec.in:
2825           fix spec for it
2826
2827 2005-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
2828
2829         * gstreamer.spec.in:
2830           clean up
2831
2832 2005-06-08  Andy Wingo  <wingo@pobox.com>
2833
2834         * gst/gstutils.c: RPAD fixes all around.
2835         (gst_element_link_pads): Refcounting fixes.
2836
2837         * tools/gst-inspect.c:
2838         * tools/gst-xmlinspect.c:
2839         * parse/grammar.y:
2840         * gst/base/gsttypefindhelper.c:
2841         * gst/base/gstbasesink.c:
2842         * gst/gstqueue.c: RPAD fixes.
2843
2844         * gst/gstghostpad.h:
2845         * gst/gstghostpad.c: New ghost pad implementation as full proxy
2846         pads. The tricky thing is they provide both source and sink
2847         interfaces, since they proxy the internal pad for the external
2848         pad, and vice versa. Implement with lower-level ProxyPad objects,
2849         with the interior proxy pad as a child of the exterior ghost pad.
2850         Should write a doc on this.
2851         
2852         * gst/gstpad.h: s/RPAD/PAD/, s/RealPad/Pad/.
2853         (gst_pad_set_name, gst_pad_set_parent): Macros removed, use
2854         gst_object API.
2855         
2856         * gst/gstpad.c: Big changes. No more stub base GstPad, now all
2857         pads are real pads. No ghost pads in this file. Not documenting
2858         the myriad s/RPAD/PAD/ and REALIZE fixes.
2859         (gst_pad_class_init): Add properties for "direction" and
2860         "template". Both are construct-only, so they can't change during
2861         the life of the pad. Fixes properly deriving from GstPad.
2862         (gst_pad_custom_new, gst_pad_custom_new_from_template): Gone. For
2863         derived objects, just set properties when creating the objects via
2864         g_object_new.
2865         (gst_pad_get_parent): Implement as a function, return NULL if the
2866         parent is not an element.
2867         (gst_pad_get_real_parent, gst_pad_add_ghost_pad)
2868         (gst_pad_remove_ghost_pad, gst_pad_realize): Removed.
2869         
2870         * gst/gstobject.c (gst_object_class_init): Make name a construct
2871         property. Don't set it in the object init.
2872
2873         * gst/gstelement.c (gst_element_add_pad): Don't allow adding pads
2874         with UNKNOWN direction.
2875         (gst_element_add_ghost_pad): Remove non-orthogonal API. Replace
2876         with gst_element_add_pad (e, gst_ghost_pad_new (name, pad)).
2877         (gst_element_remove_pad): Remove ghost-pad special cases.
2878         (gst_element_pads_activate): Remove rpad cruft.
2879
2880         * gst/gstbin.c (gst_bin_change_state): Use gst_pad_get_parent to
2881         catch the pad's-parent-not-an-element case.
2882
2883         * gst/gst.h: Include gstghostpad.h.
2884
2885         * gst/gst.c (init_post): No more real, ghost pads.
2886
2887         * gst/Makefile.am: Add gstghostpad.[ch].
2888
2889         * check/Makefile.am:
2890         * check/gst/gstbin.c:
2891         * check/gst/gstghostpad.c (test_ghost_pads): Check that linking
2892         into a bin creates ghost pads, and that the refcounts are right.
2893         Partly moved from gstbin.c.
2894
2895 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
2896
2897         * check/gst-libs/.cvsignore:
2898         * check/gst/.cvsignore:
2899         * check/pipelines/.cvsignore:
2900           ignore more
2901         * check/pipelines/cleanup.c: (setup_pipeline), (run_pipeline),
2902         (START_TEST), (cleanup_suite), (main):
2903           add some tests related to cleanup after running pipelines
2904
2905 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
2906
2907         * check/gst/gstbuffer.c: (START_TEST), (gst_test_suite), (main):
2908           add a testsuite for GstBuffer
2909
2910 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
2911
2912         * gst/gstminiobject.h:
2913           add defines for accessing the refcount
2914
2915 2005-06-03  Stefan Kost  <ensonic@users.sf.net>
2916
2917         * Makefile.am: added support for html unit test coverage reports
2918
2919 2005-06-03  Jan Schmidt  <thaytan@mad.scientist.com>
2920
2921         * gst/elements/gstcapsfilter.c: (gst_capsfilter_set_property):
2922           Free existing caps if the capsfilter changes. Add a FIXME about
2923           setting those caps on the pads.
2924
2925         * gst/gstutils.c: (gst_element_get_compatible_pad), (ghost_up):
2926           Before adding a ghost pad to a parent bin, check that there isn't
2927           already one for the element on the bin. Prevents infinite recursion
2928           when using decodebin in parse pipelines. Andy says he'll rewrite the
2929           way this works anyway, so ignore the hack.
2930
2931 2005-06-02  Andy Wingo  <wingo@pobox.com>
2932
2933         * gst/elements/gsttypefindelement.c (do_pull_typefind): Query the
2934         file size, pass it on to the type find helper.
2935
2936         * gst/base/gstbasesrc.c (gst_basesrc_do_seek): Set the
2937         segment_start and segment_end properly according to the seek
2938         method. Segment_end is still a bit flaky because offset can be
2939         negative for CUR and END cases, but it takes -1 as an "unset"
2940         value.
2941
2942 2005-06-02  Wim Taymans  <wim@fluendo.com>
2943
2944         * gst/base/gstbasesink.c: (gst_basesink_pad_buffer_alloc),
2945         (gst_base_sink_buffer_alloc), (gst_basesink_preroll_queue_push),
2946         (gst_basesink_activate):
2947         * gst/base/gstbasesink.h:
2948         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
2949         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_alloc_buffer),
2950         (gst_pad_query), (gst_pad_start_task):
2951         * gst/gstpad.h:
2952         * gst/gstqueue.c: (gst_queue_bufferalloc),
2953         (gst_queue_handle_sink_event), (gst_queue_chain):
2954         Bufferalloc: return GstFlowReturn to more accuratly report
2955         why allocation failed.
2956
2957 2005-06-02  Wim Taymans  <wim@fluendo.com>
2958
2959         * gst/gstpipeline.c: (gst_pipeline_send_event):
2960         Take snapshot of state without blocking.
2961
2962 2005-06-02  Wim Taymans  <wim@fluendo.com>
2963
2964         * docs/design/part-TODO.txt:
2965         * docs/design/part-caps.txt:
2966         * docs/design/part-clocks.txt:
2967         * docs/design/part-negotiation.txt:
2968         * docs/design/part-preroll.txt:
2969         Small doc updates 
2970
2971 2005-05-30  Wim Taymans  <wim@fluendo.com>
2972
2973         * gst/elements/gstidentity.c: (gst_identity_event),
2974         (gst_identity_transform), (gst_identity_get_property):
2975         Protect last_message property as it is accessed from
2976         multiple threads.
2977
2978 2005-05-30  Wim Taymans  <wim@fluendo.com>
2979
2980         * gst/gstelement.c: (gst_element_init),
2981         (gst_element_pads_activate), (gst_element_change_state):
2982         Slicker pad activation code.
2983
2984 2005-05-30  Wim Taymans  <wim@fluendo.com>
2985
2986         * gst/Makefile.am:
2987         * gst/gstelement.h:
2988         * gst/gstelementfactory.h:
2989         * gst/gsttypes.h:
2990         Move elementfactory methods to separate .h file.
2991
2992 2005-05-30  Wim Taymans  <wim@fluendo.com>
2993
2994         * docs/design/part-overview.txt:
2995         * gst/gstsystemclock.h:
2996         Small typo fixes, doc updates.
2997
2998 2005-05-30  Wim Taymans  <wim@fluendo.com>
2999
3000         * gst/gst.c: (gst_init_get_popt_table), (init_post),
3001         (init_popt_callback):
3002         Remove cpu-opt flag.
3003
3004 2005-05-30  Wim Taymans  <wim@fluendo.com>
3005
3006         * gst/gstbuffer.c: (gst_subbuffer_finalize),
3007         (gst_buffer_create_sub), (gst_buffer_is_span_fast):
3008         * gst/gstbuffer.h:
3009         Avoid typechecking in places where not needed.
3010         Added accessor for malloc_data.
3011
3012 2005-05-30  Wim Taymans  <wim@fluendo.com>
3013
3014         * gst/gstpad.c: (gst_real_pad_init), (gst_pad_set_active),
3015         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_accept_caps),
3016         (gst_pad_configure_sink), (gst_pad_configure_src),
3017         (gst_pad_alloc_buffer), (gst_pad_query), (gst_pad_send_event),
3018         (gst_pad_start_task):
3019         Propagate errors from _set_caps() in configure_src/sink
3020         functions instead of returning TRUE.
3021         FLUSH events can travel up and downstream
3022
3023
3024 2005-05-30  Wim Taymans  <wim@fluendo.com>
3025
3026         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_push),
3027         (gst_basesink_activate):
3028         Handle EOS in preroll.
3029
3030 2005-05-30  Wim Taymans  <wim@fluendo.com>
3031
3032         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
3033         (gst_queue_loop), (gst_queue_handle_src_event):
3034         Remove old pieces of code
3035         Flushing the queue in an upstream event is a very bad idea.
3036
3037 2005-05-26  Andy Wingo  <wingo@pobox.com>
3038
3039         * gst/gstminiobject.c (gst_value_mini_object_collect): Use
3040         gst_value_set_mini_object so as to add a ref on the object (which
3041         will be removed when the value is unset).
3042
3043         * gst/elements/gstfakesink.c (gst_fakesink_class_init): Fix signal
3044         arg type in ::handoff.
3045
3046         * gst/gstelement.c (gst_element_change_state): Also deactivate
3047         pads in READY->NULL, just in case the element didn't make it to
3048         PAUSED. Wingo tested, Wim approved.
3049
3050 2005-05-26  Wim Taymans  <wim@fluendo.com>
3051
3052         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
3053         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_alloc_buffer),
3054         (gst_pad_query), (gst_pad_send_event), (gst_pad_start_task):
3055         A flushing pad cannot be used to alloc_buffer from.
3056
3057 2005-05-26  Wim Taymans  <wim@fluendo.com>
3058
3059         * gst/gstbus.c: (gst_bus_init), (gst_bus_dispose), (gst_bus_post),
3060         (gst_bus_pop), (gst_bus_source_prepare), (gst_bus_source_check),
3061         (gst_bus_source_dispatch), (gst_bus_source_finalize),
3062         (gst_bus_create_watch), (gst_bus_add_watch_full):
3063         * gst/gstbus.h:
3064         Implement a real GSource and use g_main_context_wakeup() to
3065         signal new messages instead of the socketpair.
3066
3067 2005-05-25  Wim Taymans  <wim@fluendo.com>
3068
3069         * gst/gstbin.c: (bin_element_is_sink), (has_ancestor),
3070         (bin_element_is_semi_sink), (append_child), (gst_bin_change_state):
3071         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
3072         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_query),
3073         (gst_pad_send_event), (gst_pad_start_task):
3074         * gst/gstqueue.c: (gst_queue_init), (gst_queue_locked_flush),
3075         (gst_queue_handle_sink_event), (gst_queue_chain), (gst_queue_loop),
3076         (gst_queue_sink_activate), (gst_queue_src_activate),
3077         (gst_queue_change_state):
3078         * gst/gstqueue.h:
3079         Fix state changes for non sinks. We now change sinks, then elements
3080         with unconnected srcpads, then the rest.
3081         More efficient queue unlocking in flush and state changes.
3082         Set the pad activate mode even if it does not have an activate
3083         function.
3084
3085 2005-05-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3086
3087         * gst/base/gstbasesrc.c: (gst_basesrc_activate):
3088           Don't go in pull mode for non-seekable sources.
3089         * gst/elements/gsttypefindelement.h:
3090         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
3091         (gst_type_find_element_dispose), (gst_type_find_handle_src_query),
3092         (free_entry), (stop_typefinding),
3093         (gst_type_find_element_handle_event), (find_peek),
3094         (gst_type_find_element_chain), (do_pull_typefind),
3095         (gst_type_find_element_change_state):
3096           Allow typefinding (w/o seeking) in push-mode, simplified version
3097           of what was in 0.8.
3098         * gst/gstutils.c: (gst_buffer_join):
3099         * gst/gstutils.h:
3100           gst_buffer_join() from 0.8.
3101
3102 2005-05-25  Wim Taymans  <wim@fluendo.com>
3103
3104         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
3105         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_query),
3106         (gst_pad_send_event), (gst_pad_start_task):
3107         Disable attempt at mode switching until it is figured out.
3108
3109 2005-05-25  Wim Taymans  <wim@fluendo.com>
3110
3111         * gst/base/gstadapter.c: (gst_adapter_peek), (gst_adapter_flush):
3112         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_push),
3113         (gst_basesink_finish_preroll), (gst_basesink_chain),
3114         (gst_basesink_loop), (gst_basesink_activate),
3115         (gst_basesink_change_state):
3116         * gst/base/gstbasesrc.c: (gst_basesrc_do_seek),
3117         (gst_basesrc_get_range), (gst_basesrc_loop),
3118         (gst_basesrc_activate):
3119         * gst/elements/gsttee.c: (gst_tee_sink_activate):
3120         * gst/gstpad.c: (gst_pad_dispose), (gst_real_pad_class_init),
3121         (gst_real_pad_init), (gst_real_pad_set_property),
3122         (gst_real_pad_get_property), (gst_pad_set_active),
3123         (gst_pad_is_active), (gst_pad_get_query_types), (gst_pad_unlink),
3124         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_get_real_parent),
3125         (gst_real_pad_get_caps_unlocked), (gst_pad_peer_get_caps),
3126         (gst_pad_accept_caps), (gst_pad_get_peer), (gst_pad_realize),
3127         (gst_pad_event_default_dispatch), (gst_pad_event_default),
3128         (gst_pad_dispatcher), (gst_pad_query), (gst_real_pad_dispose),
3129         (gst_pad_save_thyself), (handle_pad_block), (gst_pad_chain),
3130         (gst_pad_push), (gst_pad_get_range), (gst_pad_pull_range),
3131         (gst_pad_send_event), (gst_pad_start_task), (gst_pad_pause_task),
3132         (gst_pad_stop_task):
3133         * gst/gstpad.h:
3134         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
3135         (gst_queue_loop), (gst_queue_src_activate):
3136         * gst/gsttask.c: (gst_task_init), (gst_task_set_lock),
3137         (gst_task_get_state):
3138         * gst/gsttask.h:
3139         * gst/schedulers/threadscheduler.c:
3140         (gst_thread_scheduler_task_start), (gst_thread_scheduler_func):
3141         Implement gst_pad_pause/start/stop_task(), take STREAM lock
3142         in task function.
3143         Remove ACTIVE pad flag, use FLUSHING everywhere
3144         Added _pad_chain(), _pad_get_range() to call chain/getrange 
3145         functions.
3146         Add locks around IS_FLUSHING when reading.
3147         Take STREAM lock in chain(), get_range() functions so plugins
3148         don't need to take it anymore.
3149         
3150
3151
3152 2005-05-25  Wim Taymans  <wim@fluendo.com>
3153
3154         * tools/gst-launch.c: (event_loop):
3155         Unref message after using its contents instead of
3156         before.
3157
3158 2005-05-24  Wim Taymans  <wim@fluendo.com>
3159
3160         * docs/design/draft-ghostpads.txt:
3161         * docs/design/draft-push-pull.txt:
3162         * docs/design/draft-query.txt:
3163         * docs/design/part-overview.txt:
3164         Docs updates, added general overview doc.
3165
3166 2005-05-21  David Schleef  <ds@schleef.org>
3167
3168         * docs/gst/tmpl/old/GstBin.sgml:
3169         * docs/gst/tmpl/old/GstBuffer.sgml:
3170         * docs/gst/tmpl/old/GstCaps.sgml:
3171         * docs/gst/tmpl/old/GstClock.sgml:
3172         * docs/gst/tmpl/old/GstCompat.sgml:
3173         * docs/gst/tmpl/old/GstData.sgml:
3174         * docs/gst/tmpl/old/GstElement.sgml:
3175         * docs/gst/tmpl/old/GstEvent.sgml:
3176         * docs/gst/tmpl/old/GstIndex.sgml:
3177         * docs/gst/tmpl/old/GstStructure.sgml:
3178         * docs/gst/tmpl/old/GstTag.sgml:
3179         * docs/gst/tmpl/old/cothreads.sgml:
3180         * docs/gst/tmpl/old/cothreads_compat.sgml:
3181         * docs/gst/tmpl/old/gettext.sgml:
3182         * docs/gst/tmpl/old/gobject2gtk.sgml:
3183         * docs/gst/tmpl/old/grammar.tab.sgml:
3184         * docs/gst/tmpl/old/gst-i18n-app.sgml:
3185         * docs/gst/tmpl/old/gst-i18n-lib.sgml:
3186         * docs/gst/tmpl/old/gst_private.sgml:
3187         * docs/gst/tmpl/old/gstaggregator.sgml:
3188         * docs/gst/tmpl/old/gstarch.sgml:
3189         * docs/gst/tmpl/old/gstatomic_impl.sgml:
3190         * docs/gst/tmpl/old/gstbufferstore.sgml:
3191         * docs/gst/tmpl/old/gstdata_private.sgml:
3192         * docs/gst/tmpl/old/gstdisksink.sgml:
3193         * docs/gst/tmpl/old/gstdisksrc.sgml:
3194         * docs/gst/tmpl/old/gstelementfactory.sgml:
3195         * docs/gst/tmpl/old/gstextratypes.sgml:
3196         * docs/gst/tmpl/old/gstfakesink.sgml:
3197         * docs/gst/tmpl/old/gstfakesrc.sgml:
3198         * docs/gst/tmpl/old/gstfdsink.sgml:
3199         * docs/gst/tmpl/old/gstfdsrc.sgml:
3200         * docs/gst/tmpl/old/gstfilesink.sgml:
3201         * docs/gst/tmpl/old/gstfilesrc.sgml:
3202         * docs/gst/tmpl/old/gsthttpsrc.sgml:
3203         * docs/gst/tmpl/old/gstidentity.sgml:
3204         * docs/gst/tmpl/old/gstindexfactory.sgml:
3205         * docs/gst/tmpl/old/gstmarshal.sgml:
3206         * docs/gst/tmpl/old/gstmd5sink.sgml:
3207         * docs/gst/tmpl/old/gstmultidisksrc.sgml:
3208         * docs/gst/tmpl/old/gstmultifilesrc.sgml:
3209         * docs/gst/tmpl/old/gstpadtemplate.sgml:
3210         * docs/gst/tmpl/old/gstpipefilter.sgml:
3211         * docs/gst/tmpl/old/gstschedulerfactory.sgml:
3212         * docs/gst/tmpl/old/gstsearchfuncs.sgml:
3213         * docs/gst/tmpl/old/gstshaper.sgml:
3214         * docs/gst/tmpl/old/gstspider.sgml:
3215         * docs/gst/tmpl/old/gstspideridentity.sgml:
3216         * docs/gst/tmpl/old/gststatistics.sgml:
3217         * docs/gst/tmpl/old/gsttee.sgml:
3218         * docs/gst/tmpl/old/gsttimecache.sgml:
3219         * docs/gst/tmpl/old/gsttypefindfactory.sgml:
3220         * docs/gst/tmpl/old/gstxmlregistry.sgml:
3221         * docs/gst/tmpl/old/gthread-cothreads.sgml:
3222         * docs/gst/tmpl/old/types.sgml:
3223           I didn't intend to add these or check them in.
3224
3225 2005-05-19  David Schleef  <ds@schleef.org>
3226
3227         * configure.ac: Use -no-common everywhere.  In a sane world, it
3228           would be the default in libtool, because without it, you can't
3229           build DLLs on Windows.
3230         * docs/gst/gstreamer-docs.sgml: Remove GstCpu, GstData, GstThread
3231         * docs/gst/gstreamer-sections.txt:
3232         * docs/gst/tmpl/gstcpu.sgml:
3233         * docs/gst/tmpl/gstdata.sgml:
3234         * docs/gst/tmpl/gstthread.sgml:
3235
3236 2005-05-19  David Schleef  <ds@schleef.org>
3237
3238         * gst/gstminiobject.c: (gst_value_set_mini_object),
3239         (gst_value_take_mini_object), (gst_value_get_mini_object):
3240         * gst/gstminiobject.h: Add GValue set/get functions.
3241
3242 2005-05-19  Wim Taymans  <wim@fluendo.com>
3243
3244         * gst/gstbuffer.c: (gst_buffer_init), (gst_subbuffer_get_type),
3245         (gst_subbuffer_class_init), (gst_subbuffer_finalize),
3246         (gst_subbuffer_init), (gst_buffer_is_span_fast):
3247         * gst/gstbuffer.h:
3248         * gst/gstbus.c: (gst_bus_post):
3249         * gst/gstelement.c: (gst_element_get_random_pad):
3250         * gst/gstmessage.c: (gst_message_init), (gst_message_finalize):
3251         Make subbufer unref the parent in finalize.
3252         some more debugging info.
3253
3254
3255 2005-05-19  Wim Taymans  <wim@fluendo.com>
3256
3257         * gst/base/gstbasesink.c: (gst_basesink_class_init),
3258         (gst_basesink_init), (gst_basesink_finalize),
3259         (gst_basesink_activate), (gst_basesink_change_state):
3260         Don't free preroll queue too early.
3261
3262 2005-05-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3263
3264         * gst/Makefile.am:
3265         * gst/ROADMAP:
3266           Hi, I'm outdated. Please shoot me.
3267
3268 2005-05-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3269
3270         * gst/gstpipeline.c: (gst_pipeline_send_event):
3271           Do not access variables after they have been deleted.
3272
3273 2005-05-19  Wim Taymans  <wim@fluendo.com>
3274
3275         * tools/gst-inspect.c: (print_plugin_features):
3276         A plugin feature does unfortunatly not use the
3277         object name yet...
3278
3279 2005-05-18  Wim Taymans  <wim@fluendo.com>
3280
3281         * gst/gstbuffer.c: (gst_buffer_is_span_fast), (gst_buffer_span):
3282         Port _span() functions to new subbuffers.
3283
3284 2005-05-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3285
3286         * gst/gstbin.c: (gst_bin_add_func):
3287           Fix clock settery in bins when adding kids after the clock has
3288           been selected.
3289
3290 2005-05-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3291
3292         * gst/elements/gstidentity.c: (gst_identity_class_init):
3293           Workaround until signals support GstMiniObject.
3294
3295 2005-05-18  Jan Schmidt  <thaytan@mad.scientist.com>
3296
3297         * gst/gstbuffer.c:
3298         Oops, fix a typo GST_TYPE_BUFFER -> GST_TYPE_SUBBUFFER.
3299
3300 2005-05-18  Wim Taymans  <wim@fluendo.com>
3301
3302         * gst/base/Makefile.am:
3303         * gst/base/gstadapter.c: (gst_adapter_base_init),
3304         (gst_adapter_class_init), (gst_adapter_init),
3305         (gst_adapter_dispose), (gst_adapter_finalize), (gst_adapter_new),
3306         (gst_adapter_clear), (gst_adapter_push), (gst_adapter_peek),
3307         (gst_adapter_flush), (gst_adapter_available),
3308         (gst_adapter_available_fast):
3309         * gst/base/gstadapter.h:
3310         Ported and added adapter to the base classes.
3311
3312 2005-05-17  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
3313
3314         * gst/gst.c:
3315         * gst/gstmessage.c:
3316           Make sure the class is reffed/unreffed once before threads can be
3317           used.  Fixes #304551.
3318
3319 2005-05-17  Wim Taymans  <wim@fluendo.com>
3320
3321         * gst/base/gstbasesink.c: (gst_basesink_finish_preroll),
3322         (gst_basesink_chain_unlocked), (gst_basesink_activate):
3323         * gst/gstminiobject.c: (gst_mini_object_get_type),
3324         (gst_mini_object_free):
3325         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_query),
3326         (gst_pad_push), (gst_pad_push_event):
3327         * gst/gstqueue.c: (gst_queue_change_state):
3328         Don't queue buffers in basesink when we are flushing.
3329         Unref buffer when flushing in basesink.
3330         Flush queue when going to READY
3331         Unref buffer when _push() returns an error.
3332         Don't free MiniObject instance when refcount is incremented
3333         in _finalize() so that we can recover objects.
3334
3335 2005-05-17  Thomas Vander Stichele  <thomas at apestaart dot org>
3336
3337         * docs/manual/advanced-schedulers.xml:
3338         * docs/manual/appendix-checklist.xml:
3339         * docs/pwg/advanced-clock.xml:
3340         * docs/pwg/advanced-interfaces.xml:
3341         * docs/pwg/advanced-request.xml:
3342         * docs/pwg/advanced-types.xml:
3343         * docs/pwg/intro-preface.xml:
3344         * examples/plugins/example.c: (gst_example_get_type),
3345         (gst_example_class_init), (gst_example_chain),
3346         (gst_example_set_property), (gst_example_get_property),
3347         (gst_example_change_state), (plugin_init):
3348         * examples/plugins/example.h:
3349           small doc fixes
3350
3351 2005-05-17  Wim Taymans  <wim@fluendo.com>
3352
3353         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_set_caps),
3354         (gst_pad_alloc_buffer), (gst_pad_query), (gst_pad_push):
3355         * gst/gstqueue.c: (gst_queue_change_state):
3356         Clear queue when going to READY.
3357         Remove IN_SETCAPS flag too.
3358
3359 2005-05-17  Tim-Philipp Müller  <tim at centricular dot net>
3360
3361         * gst/base/gstbasesrc.c: (gst_basesrc_change_state):
3362           Remove implicit cast from gboolean to GstElementStateReturn;
3363           make sure we still return failure in paused => ready case if
3364           the parent class fails to change state and our own stop 
3365           vfunc succeeds.
3366
3367 2005-05-17  Wim Taymans  <wim@fluendo.com>
3368
3369         * tools/gst-launch.c: (event_loop):
3370         Message was unreffed too soon.
3371
3372 2005-05-16  Andy Wingo  <wingo@pobox.com>
3373
3374         * gst/gstbin.c (sink_iterator_filter): Err... um...
3375
3376         * check/gst/gstbin.c (test_ghost_pads): New test for the
3377         ghosting-if-elements-not-in-same-bin behavior.
3378
3379 2005-05-16  David Schleef  <ds@schleef.org>
3380
3381         * gst/gstminiobject.c: Use g_atomic_int_get() instead of
3382         accessing refcount directly.
3383
3384 2005-05-15  David Schleef  <ds@schleef.org>
3385
3386         * check/Makefile.am: remove GstData checks
3387         * check/gst-libs/gdp.c: (START_TEST): fix for API changes
3388         * gst/Makefile.am: add miniobject, remove data
3389         * gst/gst.h: add miniobject, remove data
3390         * gst/gstdata.c: remove
3391         * gst/gstdata.h: remove
3392         * gst/gstdata_private.h: remove
3393         * gst/gsttypes.h: remove GstEvent and GstMessage
3394         * gst/gstelement.c: (gst_element_post_message): fix for API changes
3395         * gst/gstmarshal.list: change BOXED -> OBJECT
3396
3397         Implement GstMiniObject.
3398         * gst/gstminiobject.c:
3399         * gst/gstminiobject.h:
3400
3401         Modify to be subclasses of GstMiniObject.
3402         * gst/gstbuffer.c: (_gst_buffer_initialize), (gst_buffer_get_type),
3403         (gst_buffer_class_init), (gst_buffer_finalize), (_gst_buffer_copy),
3404         (gst_buffer_init), (gst_buffer_new), (gst_buffer_new_and_alloc),
3405         (gst_subbuffer_get_type), (gst_subbuffer_init),
3406         (gst_buffer_create_sub), (gst_buffer_is_span_fast),
3407         (gst_buffer_span):
3408         * gst/gstbuffer.h:
3409         * gst/gstevent.c: (_gst_event_initialize), (gst_event_get_type),
3410         (gst_event_class_init), (gst_event_init), (gst_event_finalize),
3411         (_gst_event_copy), (gst_event_new):
3412         * gst/gstevent.h:
3413         * gst/gstmessage.c: (_gst_message_initialize),
3414         (gst_message_get_type), (gst_message_class_init),
3415         (gst_message_init), (gst_message_finalize), (_gst_message_copy),
3416         (gst_message_new), (gst_message_new_error),
3417         (gst_message_new_warning), (gst_message_new_tag),
3418         (gst_message_new_state_changed), (gst_message_new_application):
3419         * gst/gstmessage.h:
3420         * gst/gstprobe.c: (gst_probe_perform),
3421         (gst_probe_dispatcher_dispatch):
3422         * gst/gstprobe.h:
3423         * gst/gstquery.c: (_gst_query_initialize), (gst_query_get_type),
3424         (gst_query_class_init), (gst_query_finalize), (gst_query_init),
3425         (_gst_query_copy), (gst_query_new):
3426
3427         Update elements for GstData -> GstMiniObject changes
3428         * gst/gstquery.h:
3429         * gst/gstqueue.c: (gst_queue_finalize), (gst_queue_locked_flush),
3430         (gst_queue_chain), (gst_queue_loop):
3431         * gst/elements/gstbufferstore.c:
3432         (gst_buffer_store_add_buffer_func),
3433         (gst_buffer_store_cleared_func), (gst_buffer_store_get_buffer):
3434         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
3435         (gst_fakesink_render):
3436         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
3437         * gst/elements/gstfilesrc.c: (gst_mmap_buffer_get_type),
3438         (gst_mmap_buffer_class_init), (gst_mmap_buffer_init),
3439         (gst_mmap_buffer_finalize), (gst_filesrc_map_region),
3440         (gst_filesrc_create_read):
3441         * gst/elements/gstidentity.c: (gst_identity_class_init):
3442         * gst/elements/gsttypefindelement.c:
3443         (gst_type_find_element_src_event), (free_entry_buffers),
3444         (gst_type_find_element_handle_event):
3445         * libs/gst/dataprotocol/dataprotocol.c:
3446         (gst_dp_header_from_buffer):
3447         * libs/gst/dataprotocol/dataprotocol.h:
3448         * libs/gst/dataprotocol/dp-private.h:
3449
3450 2005-05-15  David Schleef  <ds@schleef.org>
3451
3452         * gst/elements/gstelements.c: Don't include headers that were
3453         just removed.
3454
3455 2005-05-15  David Schleef  <ds@schleef.org>
3456
3457         * gst/elements/Makefile.am: Remove some elements that don't
3458         need to be in the core (or even exist at all).
3459         * gst/elements/gstaggregator.c:
3460         * gst/elements/gstaggregator.h:
3461         * gst/elements/gstmd5sink.c:
3462         * gst/elements/gstmd5sink.h:
3463         * gst/elements/gstmultifilesrc.c:
3464         * gst/elements/gstmultifilesrc.h:
3465         * gst/elements/gstpipefilter.c:
3466         * gst/elements/gstpipefilter.h:
3467         * gst/elements/gstshaper.c:
3468         * gst/elements/gstshaper.h:
3469         * gst/elements/gststatistics.c:
3470         * gst/elements/gststatistics.h:
3471         * po/POTFILES.in: Remove above files.
3472
3473 2005-05-14  Andy Wingo  <wingo@pobox.com>
3474
3475         * gst/gstbin.c (gst_bin_iterate_sinks): Use sink_iterator_filter
3476         so as to get the refs right.
3477         (sink_iterator_filter): New function, wraps bin_element_is_sink,
3478         unreffing objects that don't pass the filter.
3479
3480         * gst/gstpipeline.c (gst_pipeline_init): Drop ref on bus after
3481         gst_element_set_bus.
3482         (gst_pipeline_dispose): Set the bus on the pipeline to NULL. In
3483         normal cases, this will destroy the bus.
3484
3485         * gst/gstutils.c (prepare_link_maybe_ghosting): Drop ref on root
3486         object.
3487
3488         * gst/gstbin.c (gst_bin_change_state): Fix state changes if a bin
3489         has no sinks.
3490
3491 2005-05-13  Andy Wingo  <wingo@pobox.com>
3492
3493         * gst/gstutils.c (gst_element_link_pads): Instead of calling
3494         gst_pad_link, call pad_link_maybe_ghosting,
3495         (pad_link_maybe_ghosting): Links pads, making sure that the
3496         elements being linked are in the same bin.
3497         (find_common_root, object_has_ancestor, ghost_up, remove_pad):
3498         Helpers for pad_link_maybe_ghosting.
3499
3500 2005-05-13  Tim-Philipp Müller  <tim at centricular dot net>
3501
3502         * configure.ac:
3503           Require GLib >= 2.4.0 (for the g_atomic_* funcs)
3504
3505 2005-05-13  Tim-Philipp Müller  <tim at centricular dot net>
3506
3507         * docs/design/part-element-source.txt:
3508           Mention GstPushSrc
3509
3510 2005-05-12  Wim Taymans  <wim@fluendo.com>
3511
3512         * gst/base/gstbasesink.c: (gst_basesink_init),
3513         (gst_basesink_activate):
3514         * gst/base/gstbasesrc.c: (gst_basesrc_unlock),
3515         (gst_basesrc_is_seekable):
3516         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_remove_func),
3517         (bin_element_is_sink), (gst_bin_change_state):
3518         * gst/gstelement.c: (gst_element_add_pad), (gst_element_query):
3519         * gst/gstelement.h:
3520         Identify sinks by their flag to avoid overly complicated
3521         checks (fow now).
3522         Do state changes even for elements not reachable from the
3523         sinks.
3524         BaseSink is a sink now :)
3525         Some more debugging info in the basesrc.
3526
3527
3528 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3529
3530         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_query):
3531           Implement _query on a bin, similar to _send_event.
3532
3533 2005-05-12  Tim-Philipp Müller  <tim at centricular dot net>
3534
3535         * gst/base/gstbasesrc.c: (gst_basesrc_do_seek):
3536           Discont event offset format should be GST_FORMAT_BYTES,
3537           not GST_FORMAT_TIME.
3538
3539 2005-05-12  Wim Taymans  <wim@fluendo.com>
3540
3541         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_get_state):
3542         Same fix as Ronald's but without the signal. 
3543
3544 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3545
3546         * gst/gstutils.c: (gst_element_query_position):
3547           No, an element is not a pad.
3548
3549 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3550
3551         * gst/gstbin.c: (gst_bin_add_func), (cb_parent_unset),
3552         (gst_bin_get_state):
3553           If a child is removed from a bin while we remove the child from
3554           the bin and while we're retrieving its state, signal this to the
3555           get_state function so we abort the wait (instead of waiting for
3556           a timeout) and can immediately re-iterate over all other elements.
3557
3558 2005-05-12  Wim Taymans  <wim@fluendo.com>
3559
3560         * gst/base/Makefile.am:
3561         * gst/base/gstbasesrc.c: (gst_basesrc_is_seekable),
3562         (gst_basesrc_start):
3563         * gst/base/gstbasesrc.h:
3564         * gst/base/gstpushsrc.c: (gst_pushsrc_get_type),
3565         (gst_pushsrc_base_init), (gst_pushsrc_class_init),
3566         (gst_pushsrc_init), (gst_pushsrc_create):
3567         * gst/base/gstpushsrc.h:
3568         Added is_seekable to BaseSrc
3569         Added simple PushSrc.
3570
3571 2005-05-11  Wim Taymans  <wim@fluendo.com>
3572
3573         * gst/gstelement.c: (gst_element_add_pad), (gst_element_query):
3574         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
3575         (gst_element_link_pads), (gst_element_query_position),
3576         (gst_element_query_convert), (intersect_caps_func),
3577         (gst_pad_query_position), (gst_pad_query_convert):
3578         Fix refcounting in utils function.
3579         No point in trying to activate a pad when it's added, it could
3580         be added from the state change function and then we deadlock, the
3581         element has to decide what to do.
3582
3583 2005-05-10  Andy Wingo  <wingo@pobox.com>
3584
3585         * gst/elements/gstfakesink.c (gst_fakesink_render): Er, emit with
3586         *all* the arguments.
3587
3588         * gst/base/gstbasetransform.c (gst_base_transform_event): Grab the
3589         stream lock if it's a FLUSH_DONE; normal flushes don't get the
3590         lock (according to the docs -- if this is wrong change the docs).
3591
3592         * gst/gstpipeline.c (gst_pipeline_change_state): Set the bus to
3593         flush messages in the NULL state.
3594
3595         * gst/gstbus.c (gst_bus_post): If a bus is flushing, unref the
3596         message immediately and return.
3597         (gst_bus_set_flushing): New function. If a bus is flushing, it
3598         flushes out any queued messages and immediately unrefs new
3599         messages. This is so when an element goes to NULL, all of the
3600         unhandled messages coming from it can be freed, and their
3601         references to the element dropped. In other words: message source
3602         ref considered harmful :P
3603
3604         * gst/gstbin.c (gst_bin_change_state): Unref peer element when
3605         we're finished with it.
3606
3607         * gst/gstmessage.c (gst_message_new_state_changed): 
3608
3609 2005-05-10  Wim Taymans  <wim@fluendo.com>
3610
3611         * gst/gstvalue.c: (gst_value_compare_flags),
3612         (gst_value_serialize_flags), (gst_value_deserialize_flags),
3613         (_gst_value_initialize):
3614         Added flags serialize/deserialize/compare code.
3615
3616 2005-05-09  Andy Wingo  <wingo@pobox.com>
3617
3618         * gst/base/gstbasetransform.c (gst_base_transform_proxy_getcaps):
3619         Intersect the peer's caps with our caps.
3620
3621 2005-05-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3622
3623         * gst/base/gsttypefindhelper.c: (helper_find_peek):
3624         * gst/elements/gsttypefindelement.c: (find_peek):
3625           Handle negative offsets better. Fixes decodebin.
3626
3627 2005-05-09  Wim Taymans  <wim@fluendo.com>
3628
3629         * gst/base/gstbasetransform.c: (gst_base_transform_proxy_getcaps),
3630         (gst_base_transform_event):
3631         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_query):
3632         Implement accept_caps.
3633         Fix silly lock/unlock mismatch in base class.
3634
3635 2005-05-09  Wim Taymans  <wim@fluendo.com>
3636
3637         * docs/design/draft-push-pull.txt:
3638         * gst/base/gstbasesrc.c: (gst_basesrc_init), (gst_basesrc_query):
3639         * gst/elements/gstfilesink.c: (gst_filesink_init),
3640         (gst_filesink_query):
3641         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
3642         (gst_type_find_handle_src_query), (find_element_get_length):
3643         * gst/gstelement.c: (gst_element_seek), (gst_element_query):
3644         * gst/gstelement.h:
3645         * gst/gstmessage.c:
3646         * gst/gstmessage.h:
3647         * gst/gstpad.c: (gst_real_pad_init), (gst_pad_get_query_types),
3648         (gst_real_pad_get_caps_unlocked),
3649         (gst_pad_get_internal_links_default), (gst_pad_get_internal_links),
3650         (gst_pad_event_default_dispatch), (gst_pad_event_default),
3651         (gst_pad_dispatcher), (gst_pad_query), (gst_pad_query_default),
3652         (gst_real_pad_dispose), (gst_real_pad_finalize),
3653         (gst_pad_load_and_link), (gst_pad_save_thyself),
3654         (gst_ghost_pad_save_thyself), (handle_pad_block), (gst_pad_push),
3655         (gst_pad_check_pull_range), (gst_pad_pull_range),
3656         (gst_pad_template_get_type), (gst_pad_template_class_init),
3657         (gst_pad_template_init), (gst_pad_template_dispose),
3658         (name_is_valid), (gst_static_pad_template_get),
3659         (gst_pad_template_new), (gst_static_pad_template_get_caps),
3660         (gst_pad_template_get_caps), (gst_pad_set_element_private),
3661         (gst_pad_get_element_private), (gst_pad_start_task),
3662         (gst_pad_pause_task), (gst_pad_stop_task),
3663         (gst_ghost_pad_get_type), (gst_ghost_pad_class_init),
3664         (gst_ghost_pad_init), (gst_ghost_pad_dispose),
3665         (gst_ghost_pad_set_property), (gst_ghost_pad_get_property),
3666         (gst_ghost_pad_new):
3667         * gst/gstpad.h:
3668         * gst/gstquery.c: (_gst_query_initialize), (gst_query_new),
3669         (gst_query_new_position), (gst_query_set_position),
3670         (gst_query_parse_position), (gst_query_new_convert),
3671         (gst_query_set_convert), (gst_query_parse_convert):
3672         * gst/gstquery.h:
3673         * gst/gstqueryutils.c:
3674         * gst/gstqueryutils.h:
3675         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
3676         (gst_queue_bufferalloc), (gst_queue_handle_sink_event),
3677         (gst_queue_handle_src_query):
3678         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
3679         (gst_element_query_position), (gst_element_query_convert),
3680         (intersect_caps_func), (gst_pad_query_position),
3681         (gst_pad_query_convert):
3682         * gst/gstutils.h:
3683         * tools/gst-inspect.c: (print_pad_info):
3684         * tools/gst-xmlinspect.c: (print_element_info):
3685         Remove old query functions. Ported old code.
3686         Added position/convert helper functions to gstutils.
3687         Reordered gstpad.c code, grouping relevant things.
3688         Remove gst_message_new(), always need to speficy a specific
3689         message.
3690
3691
3692 2005-05-09  Andy Wingo  <wingo@pobox.com>
3693
3694         * gst/gstiterator.h: Add some includes.
3695
3696         * gst/gstqueryutils.h: Include more headers.
3697
3698         * gst/gstpad.h:
3699         * gst/gstpad.c (gst_pad_query_position): New routine, replaces
3700         some uses of gst_pad_query.
3701
3702         * gst/gstqueryutils.c: Build fixes. Make parse functions ignore
3703         NULL out parameters.
3704         (gst_query_new_position): New proc, allocates a new position
3705         query.
3706
3707         * gst/Makefile.am (libgstreamer_@GST_MAJORMINOR@_la_SOURCES): Add
3708         gstqueryutils.c to the build.
3709
3710         * gst/gststructure.c (gst_structure_set_valist): Implement with
3711         the generic G_VALUE_COLLECT.
3712         
3713 2005-05-08  Edward Hervey  <bilboed@bilboed.com>
3714
3715         * gst/Makefile.am: (gst_headers):
3716         Added gstqueryutils.h to the list of headers to install, that was
3717         a 'nachty' move wingo :)
3718
3719 2005-05-06  Andy Wingo  <wingo@pobox.com>
3720
3721         * gst/gstquery.h
3722         * gst/gstquery.c (_gst_query_initialize): Extend GstQuery from
3723         GstData, init a memchunk.
3724         (standard_definitions): Add a few query types, deprecate a few.
3725         (gst_query_get_type): New proc.
3726         (_gst_query_copy, _gst_query_free, gst_query_new): GstData
3727         implementation.
3728         (gst_query_new_application, gst_query_get_structure): New public
3729         procs.
3730
3731         * docs/design/draft-query.txt: Removed LINKS from the query types,
3732         because all the rest can be dispatched to other pads -- seemed
3733         ugly to have a query that couldn't be dispatched. internal_links
3734         is fine as a pad method.
3735
3736         * gst/gstpad.h: Add query2 as a pad method, add the new functions
3737         in gstpad.c, but maintain binary compatibility for the moment.
3738         Will fix before 0.9 is out.
3739
3740         * gst/gstqueryutils.c: 
3741         * gst/gstqueryutils.h: New files, implement 3 methods for each
3742         query type: parse_query, parse_response, and set. Probably need an
3743         allocator as well.
3744
3745         * gst/gst.h: Add gstquery.h and gstqueryutils.h to the list.
3746
3747         * gst/elements/gstfilesink.c (gst_filesink_query2):
3748         * gst/base/gstbasesrc.c (gst_basesrc_query2): Replace old query,
3749         query_types, and formats methods.
3750
3751         * gst/gstpad.c (gst_pad_query2, gst_pad_query2_default)
3752         (gst_pad_set_query2_function): New functions.
3753         (gst_real_pad_init): Set query2_default as the default query2
3754         function. Basically just dispatches to internally linked pads.
3755
3756         Needs review!
3757         
3758         * gst/gstdata_private.h (_GST_DATA_INIT): Set data->refcount to 1
3759         without using the atomic operations. Only one thread can possibly
3760         be accessing the data at this point. Changed so as to avoid
3761         gst_atomic operations.
3762
3763 2005-05-06  Wim Taymans  <wim@fluendo.com>
3764
3765         * gst/gstpad.c: (gst_pad_alloc_buffer), (gst_pad_push):
3766         Also set caps if we use the fallback buffer alloc.
3767
3768 2005-05-06  Tim-Philipp Müller  <tim at centricular dot net>
3769
3770         * docs/gst/Makefile.am:
3771         * docs/gst/gstreamer-docs.sgml:
3772         * docs/gst/gstreamer-sections.txt:
3773         * docs/gst/tmpl/gstatomic.sgml:
3774         * docs/gst/tmpl/gstmemchunk.sgml:
3775         * testsuite/elements/struct_i386.h:
3776         * win32/GStreamer.vcproj:
3777         * win32/Makefile:
3778           Purge GstAtomic stuff from docs and win32 makefiles as well
3779
3780 2005-05-06  Wim Taymans  <wim@fluendo.com>
3781
3782         * gst/base/gstbasetransform.c: (gst_base_transform_proxy_getcaps):
3783         * gst/elements/gstcapsfilter.c: (gst_capsfilter_getcaps):
3784         * gst/gstpad.c: (gst_pad_peer_get_caps):
3785         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
3786         (gst_queue_bufferalloc), (gst_queue_handle_sink_event),
3787         (gst_queue_src_activate), (gst_queue_change_state):
3788         * gst/gstqueue.h:
3789         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
3790         (intersect_caps_func):
3791         Fix gst_pad_peer_get_caps(), make it return NULL if no peer.
3792         Always take QUEUE_LOCK after STREAM_LOCK or we might deadlock.
3793         Some fixes for the peer_get_caps() change.
3794
3795 2005-05-06  Wim Taymans  <wim@fluendo.com>
3796
3797         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
3798         (gst_basesink_handle_buffer), (gst_basesink_chain_unlocked),
3799         (gst_basesink_activate):
3800         Actually do something with error codes returned from the push
3801         functions.
3802
3803 2005-05-06  Wim Taymans  <wim@fluendo.com>
3804
3805         * docs/design/part-element-sink.txt:
3806         * docs/design/part-element-source.txt:
3807         * gst/base/gstbasesink.c: (gst_basesink_class_init),
3808         (gst_basesink_event), (gst_basesink_activate):
3809         * gst/base/gstbasesink.h:
3810         * gst/base/gstbasesrc.c: (gst_basesrc_init), (gst_basesrc_unlock),
3811         (gst_basesrc_activate):
3812         * gst/base/gstbasesrc.h:
3813         * gst/gstelement.c: (gst_element_pads_activate):
3814         Some more documentation.
3815         Fixed scheduling decision in _pads_activate().
3816
3817 2005-05-05  Andy Wingo  <wingo@pobox.com>
3818
3819         * check/pipelines/simple_launch_lines.c (test_2_elements): "Fix"
3820         the test suite.
3821
3822 2005-05-05  Wim Taymans  <wim@fluendo.com>
3823
3824         * gst/base/Makefile.am:
3825         * gst/base/gstbasesink.h:
3826         * gst/base/gstbasesrc.c: (gst_basesrc_init),
3827         (gst_basesrc_set_dataflow_funcs), (gst_basesrc_query):
3828         * gst/base/gstcollectpads.c: (gst_collectpads_get_type),
3829         (gst_collectpads_class_init), (gst_collectpads_init),
3830         (gst_collectpads_finalize), (gst_collectpads_new),
3831         (gst_collectpads_set_function), (gst_collectpads_add_pad),
3832         (find_pad), (gst_collectpads_remove_pad),
3833         (gst_collectpads_is_active), (gst_collectpads_collect),
3834         (gst_collectpads_collect_range), (gst_collectpads_start),
3835         (gst_collectpads_stop), (gst_collectpads_peek),
3836         (gst_collectpads_pop), (gst_collectpads_available),
3837         (gst_collectpads_read), (gst_collectpads_flush),
3838         (gst_collectpads_chain):
3839         * gst/base/gstcollectpads.h:
3840         * gst/elements/Makefile.am:
3841         * gst/elements/gstelements.c:
3842         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
3843         (gst_fakesink_get_times), (gst_fakesink_event),
3844         (gst_fakesink_preroll), (gst_fakesink_render):
3845         * gst/elements/gstfilesink.c: (gst_filesink_class_init),
3846         (gst_filesink_init), (gst_filesink_set_location),
3847         (gst_filesink_open_file), (gst_filesink_close_file),
3848         (gst_filesink_pad_query), (gst_filesink_event),
3849         (gst_filesink_render), (gst_filesink_change_state):
3850         * gst/elements/gstfilesink.h:
3851         Added object to help in making collect pad based elements.
3852         Ported filesink.
3853         Make event function in sink baseclass return gboolean.
3854
3855 2005-05-05  Wim Taymans  <wim@fluendo.com>
3856
3857         * gst/gstbin.c: (gst_bin_send_event), (compare_name),
3858         (gst_bin_get_by_name):
3859         * gst/gstbuffer.h:
3860         * gst/gstclock.c: (gst_clock_entry_new), (gst_clock_class_init),
3861         (gst_clock_finalize):
3862         * gst/gstdata.c: (gst_data_replace):
3863         * gst/gstdata.h:
3864         * gst/gstelement.c: (gst_element_request_pad),
3865         (gst_element_pads_activate):
3866         * gst/gstobject.c: (gst_object_init), (gst_object_ref),
3867         (gst_object_unref):
3868         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3869         (gst_pad_set_checkgetrange_function),
3870         (gst_pad_link_check_compatible_unlocked), (gst_pad_set_caps),
3871         (gst_pad_check_pull_range), (gst_pad_pull_range),
3872         (gst_static_pad_template_get_caps), (gst_pad_start_task),
3873         (gst_pad_pause_task), (gst_pad_stop_task):
3874         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
3875         (gst_element_request_pad), (gst_pad_proxy_getcaps):
3876         Fix name lookup in GstBin.
3877         Added _data_replace() function and _buffer_replace()
3878         Use finalize method to clean up clock.
3879         Fix refcounting on request pads.
3880         Fix pad schedule mode error.
3881         Some more object refcounting debug info,
3882
3883
3884 2005-05-04  Andy Wingo <wingo@pobox.com>
3885
3886         * check/Makefile.am:
3887         * docs/gst/tmpl/gstatomic.sgml:
3888         * docs/gst/tmpl/gstplugin.sgml:
3889         * gst/base/gstbasesink.c: (gst_basesink_activate):
3890         * gst/base/gstbasesrc.c: (gst_basesrc_class_init),
3891         (gst_basesrc_init), (gst_basesrc_set_dataflow_funcs),
3892         (gst_basesrc_query), (gst_basesrc_set_property),
3893         (gst_basesrc_get_property), (gst_basesrc_check_get_range),
3894         (gst_basesrc_activate):
3895         * gst/base/gstbasesrc.h:
3896         * gst/base/gstbasetransform.c: (gst_base_transform_sink_activate),
3897         (gst_base_transform_src_activate):
3898         * gst/elements/gstelements.c:
3899         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
3900         (gst_fakesrc_set_property), (gst_fakesrc_get_property):
3901         * gst/elements/gsttee.c: (gst_tee_sink_activate):
3902         * gst/elements/gsttypefindelement.c: (find_element_get_length),
3903         (gst_type_find_element_checkgetrange),
3904         (gst_type_find_element_activate):
3905         * gst/gstbin.c: (gst_bin_save_thyself), (gst_bin_restore_thyself):
3906         * gst/gstcaps.c: (gst_caps_do_simplify), (gst_caps_save_thyself),
3907         (gst_caps_load_thyself):
3908         * gst/gstelement.c: (gst_element_pads_activate),
3909         (gst_element_save_thyself), (gst_element_restore_thyself):
3910         * gst/gstpad.c: (gst_pad_load_and_link), (gst_pad_save_thyself),
3911         (gst_ghost_pad_save_thyself), (gst_pad_check_pull_range):
3912         * gst/gstpad.h:
3913         * gst/gstxml.c: (gst_xml_write), (gst_xml_parse_doc),
3914         (gst_xml_parse_file), (gst_xml_parse_memory),
3915         (gst_xml_get_element), (gst_xml_make_element):
3916         * gst/indexers/gstfileindex.c: (gst_file_index_load),
3917         (_file_index_id_save_xml), (gst_file_index_commit):
3918         * gst/registries/gstlibxmlregistry.c: (read_string), (read_uint),
3919         (read_enum), (load_pad_template), (load_feature), (load_plugin),
3920         (load_paths):
3921         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_caps),
3922         (gst_dp_packet_from_event), (gst_dp_caps_from_packet):
3923         * tools/gst-complete.c: (main):
3924         * tools/gst-compprep.c: (main):
3925         * tools/gst-inspect.c: (print_element_properties_info):
3926         * tools/gst-launch.c: (xmllaunch_parse_cmdline):
3927         * tools/gst-xmlinspect.c: (print_element_properties):
3928         GCC 4 fixen.
3929         
3930 2005-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
3931
3932         * gst/gstplugin.c: (gst_plugin_check_module),
3933         (gst_plugin_check_file), (gst_plugin_load_file):
3934             apply patch from #172526 to make register work on MacOSX
3935
3936 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
3937
3938         * docs/gst/tmpl/gstconfig.sgml:
3939         * gst/gstconfig.h.in:
3940           move documentation for some symbols.  Add doc for GST_PTR_FORMAT
3941         * testsuite/debug/printf_extension.c: (main):
3942           Do not use GST_PTR_FORMAT on pointers to types with
3943           sizeof < sizeof(gpointer).  Fixes test on 64-bit
3944         * testsuite/elements/property.h:
3945           use correct printf format
3946
3947 2005-05-02  Wim Taymans  <wim@fluendo.com>
3948
3949         * docs/design/draft-push-pull.txt:
3950         * docs/design/draft-query.txt:
3951         * gst/base/gstbasesrc.c: (gst_basesrc_get_range_unlocked),
3952         (gst_basesrc_start):
3953         Added draft for new query API.
3954         Added draft for better selecting scheduling methods.
3955         Make basesrc ignore length if the subclass does not support
3956         it.
3957
3958 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
3959
3960         * gst/Makefile.am:
3961           possible fixes for automake-1.5 - _LIBADD is reserved
3962
3963 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
3964
3965         * docs/faq/Makefile.am:
3966         * docs/manual/Makefile.am:
3967         * docs/manuals.mak:
3968         * docs/pwg/Makefile.am:
3969         * gst/Makefile.am:
3970           possible fixes for automake-1.5
3971
3972 2005-04-28  Wim Taymans  <wim@fluendo.com>
3973
3974         * gst/base/gstbasesink.c: (gst_basesink_base_init),
3975         (gst_basesink_pad_getcaps), (gst_basesink_init),
3976         (gst_basesink_do_sync):
3977         * gst/gstclock.c: (gst_clock_entry_new):
3978         * gst/gstevent.c: (gst_event_discont_get_value):
3979         * gst/gstpipeline.c: (pipeline_bus_handler),
3980         (gst_pipeline_change_state):
3981         * gst/gstsystemclock.c: (gst_system_clock_id_wait_unlocked):
3982         Better debugging of clocking info.
3983         Allow NULL values when getting discont values.
3984
3985 2005-04-27  Wim Taymans  <wim@fluendo.com>
3986
3987         * check/gst/gstobject.c: (START_TEST), (gst_object_suite):
3988         * check/gst/gstpad.c: (gst_pad_suite):
3989         Increase timeout for checks.
3990
3991 2005-04-27  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
3992
3993         * check/Makefile.am:
3994           fix the broken rule for cleanup.  Apparently this rule is
3995           only needed on FC2, so maybe this warrants further autotool
3996           inspection.
3997
3998 2005-04-26  Wim Taymans  <wim@fluendo.com>
3999
4000         * gst/gsttrashstack.h:
4001         Ooohh. a nasty one! After having a failed pop() from the stack,
4002         it's possible that the stack is empty. In that case, don't
4003         follow the NULL pointer.
4004
4005 2005-04-25  Wim Taymans  <wim@fluendo.com>
4006
4007         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
4008         (gst_pad_set_checkgetrange_function),
4009         (gst_pad_link_check_compatible_unlocked), (gst_pad_link_prepare),
4010         (gst_pad_check_pull_range), (gst_pad_pull_range),
4011         (gst_static_pad_template_get_caps), (gst_pad_start_task),
4012         (gst_pad_pause_task), (gst_pad_stop_task):
4013         * gst/gstplugin.c: (gst_plugin_load):
4014         * gst/gstplugin.h:
4015         Remove gst_library_load as it does more harm than good with
4016         the new g_module flags.
4017         Revert bogus caps template check in pad linking, pad caps
4018         are important when linking not the template, which is more
4019         general than the current caps.
4020
4021 2005-04-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4022
4023         * gst/autoplug/.cvsignore:
4024         * gst/autoplug/Makefile.am:
4025         * gst/autoplug/gstsearchfuncs.c:
4026         * gst/autoplug/gstsearchfuncs.h:
4027         * gst/autoplug/gstspider.c:
4028         * gst/autoplug/gstspider.h:
4029         * gst/autoplug/gstspideridentity.c:
4030         * gst/autoplug/gstspideridentity.h:
4031         * gst/autoplug/spidertest.c:
4032           Die, spider, die.
4033
4034 2005-04-25  Wim Taymans  <wim@fluendo.com>
4035
4036         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
4037         (gst_pad_set_checkgetrange_function), (gst_pad_check_pull_range),
4038         (gst_pad_pull_range), (gst_static_pad_template_get_caps),
4039         (gst_pad_start_task), (gst_pad_pause_task), (gst_pad_stop_task):
4040         * gst/gstpad.h:
4041         Added stubs for unimplemented functions. 
4042
4043 2005-04-24  David Schleef  <ds@schleef.org>
4044
4045         * gst/gstpad.h: Disable some unimplemented functions.  Wim,
4046         please fix.
4047
4048 2005-04-24  David Schleef  <ds@schleef.org>
4049
4050         Convert everything from GstAtomicInt to g_atomic_int_*, and
4051         remove gstatomic.
4052         * gst/Makefile.am:
4053         * gst/gstatomic.c:
4054         * gst/gstatomic.h:
4055         * gst/gstatomic_impl.h:
4056         * gst/gstbuffer.c:
4057         * gst/gstcaps.c:
4058         * gst/gstcaps.h:
4059         * gst/gstclock.c:
4060         * gst/gstclock.h:
4061         * gst/gstdata.c:
4062         * gst/gstdata.h:
4063         * gst/gstdata_private.h:
4064         * gst/gstevent.c:
4065         * gst/gstinfo.c:
4066         * gst/gstinfo.h:
4067         * gst/gstmessage.c:
4068         * gst/gstobject.c:
4069         * gst/gstobject.h:
4070         * gst/gststructure.c:
4071         * gst/gststructure.h:
4072         * gst/gstutils.c: Add gst_atomic_int_set() compaitibility function.
4073         * gst/gstutils.h:
4074
4075 2005-04-24  David Schleef  <ds@schleef.org>
4076
4077         * check/gst/gstpad.c: (START_TEST): Oh yeah, it's always nice to
4078         make the regressions tests work.  Remove some code that is no
4079         longer true.
4080         * gst/gstpad.c: (gst_pad_link_check_templates_compatible_unlocked):
4081         Disable warning for pads without templates.
4082
4083 2005-04-24  David Schleef  <ds@schleef.org>
4084
4085         * gst/gstpad.c: Remove handling of filtered caps.  Fix/merge
4086         functions that handle filtered links.
4087         * gst/gstpad.h: Remove 'appfilter' field and prototypes of
4088         removed functions.
4089         * gst/gstutils.c: Fix/remove utility functions that handle
4090         filtered caps.
4091         * gst/gstutils.h:
4092         * gst/gstvalue.c: Add serialization/deserialization of caps
4093         * gst/parse/grammar.y: Ignore filtered caps when linking.  This
4094         requires fixing so that the filter caps notation creates
4095         a capsfilter element and sets the filter_caps property.  I
4096         think everyone probably wants to keep the shorthand notation.
4097         * docs/gst/tmpl/gstelement.sgml: updates for API changes.
4098         * docs/gst/tmpl/gstpad.sgml:
4099
4100         * gst/elements/gstelements.c: Register capsfilter element.
4101         * gst/Makefile.am: fix spacing
4102         * docs/random/ds/0.9-suggested-changes: random
4103
4104 2005-04-23  David Schleef  <ds@schleef.org>
4105
4106         * gst/elements/Makefile.am:
4107         * gst/elements/gstcapsfilter.c: New element that acts like an
4108         identity, but filters caps.  Will eventually replace filtered
4109         caps in pad linking.
4110         * gst/gstutils.c: (gst_element_create_all_pads): New function
4111         to create all the ALWAYS pads that are registered with an
4112         element class.  This functionality should eventually be
4113         merged in with GstElement initialization.
4114         * gst/gstutils.h:
4115         * testsuite/trigger/README: part of trigger test code that should
4116         have been checked in a long time ago.
4117
4118 2005-04-23  David Schleef  <ds@schleef.org>
4119
4120         * gst/Makefile.am: Remove as-libtool stuff.  It's likely not
4121         needed with new versions of libtool (nobody will confirm this),
4122         and hard to carry around.
4123         * gst/autoplug/Makefile.am:
4124         * gst/base/Makefile.am:
4125         * gst/elements/Makefile.am:
4126         * gst/indexers/Makefile.am:
4127         * gst/schedulers/Makefile.am:
4128         * libs/gst/bytestream/Makefile.am:
4129         * libs/gst/control/Makefile.am:
4130         * libs/gst/dataprotocol/Makefile.am:
4131         * libs/gst/getbits/Makefile.am:
4132
4133 2005-04-21  Wim Taymans  <wim@fluendo.com>
4134
4135         * docs/design/draft-push-pull.txt:
4136         * docs/design/part-MT-refcounting.txt:
4137         * docs/design/part-TODO.txt:
4138         * docs/design/part-caps.txt:
4139         * docs/design/part-events.txt:
4140         * docs/design/part-gstbus.txt:
4141         * docs/design/part-gstpipeline.txt:
4142         * docs/design/part-messages.txt:
4143         * docs/design/part-push-pull.txt:
4144         * docs/design/part-query.txt:
4145         Some more docs.
4146
4147 2005-04-21  Wim Taymans  <wim@fluendo.com>
4148
4149         * gst/gstmessage.c: (_gst_message_copy), (_gst_message_free),
4150         (gst_message_new), (gst_message_new_error),
4151         (gst_message_new_warning), (gst_message_new_tag),
4152         (gst_message_new_state_changed), (gst_message_new_application),
4153         (gst_message_get_structure):
4154         * gst/gstmessage.h:
4155         * gst/gststructure.c: (gst_structure_set_parent_refcount),
4156         (gst_structure_copy_conditional):
4157         Use parent refcount in GstMessage to ensure GstStructure
4158         consistency.
4159         Cleaned up headers a bit.
4160         
4161
4162 2005-04-20  Wim Taymans  <wim@fluendo.com>
4163
4164         * gst/base/gstbasesink.c: (gst_basesink_base_init),
4165         (gst_basesink_pad_getcaps), (gst_basesink_init),
4166         (gst_basesink_chain_unlocked):
4167         * gst/base/gsttypefindhelper.c: (helper_find_suggest),
4168         (gst_type_find_helper):
4169         * gst/elements/gsttypefindelement.c:
4170         (gst_type_find_element_have_type), (gst_type_find_element_init),
4171         (stop_typefinding), (gst_type_find_element_handle_event),
4172         (find_suggest), (gst_type_find_element_chain),
4173         (gst_type_find_element_checkgetrange),
4174         (gst_type_find_element_getrange), (do_typefind),
4175         (gst_type_find_element_activate):
4176         * gst/gstbuffer.c: (_gst_buffer_sub_free),
4177         (gst_buffer_default_free), (gst_buffer_default_copy),
4178         (gst_buffer_set_caps):
4179         * gst/gstcaps.c: (gst_caps_ref), (gst_caps_unref),
4180         (gst_caps_replace):
4181         * gst/gstmessage.c: (gst_message_new),
4182         (gst_message_new_state_changed):
4183         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
4184         (gst_pad_set_checkgetrange_function),
4185         (gst_pad_link_prepare_filtered), (gst_pad_relink_filtered),
4186         (gst_pad_set_caps), (gst_pad_check_pull_range),
4187         (gst_pad_pull_range), (gst_static_pad_template_get_caps):
4188         * gst/gstpad.h:
4189         * gst/gsttypefind.c: (gst_type_find_register):
4190         Make gst_caps_replace() work like other _replace() functions.
4191         Use _caps_replace() where possible.
4192         Make sure _message_new() initialises its field.
4193         Add gst_static_pad_template_get_caps()
4194
4195
4196 2005-04-18  Andy Wingo  <wingo@pobox.com>
4197
4198         * gst/gstelement.c (gst_element_pads_activate): Check pull_range
4199         on the peer, not the pad. I think that was a typo. Pass an extra
4200         arg to see if random access is possible. Activate the pads as
4201         PULL_RANGE if possible.
4202
4203         * gst/elements/gstfakesrc.c: s/ARG_/PROP_/.
4204
4205         * gst/base/gstbasesrc.c (gst_basesrc_set_property) 
4206         (gst_basesrc_get_property): BLOCKSIZE is a ULONG. Rename ARG_...
4207         to PROP_....
4208
4209 2005-04-14  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4210
4211         * docs/faq/using.xml:
4212           Add note on gstreamer-properties (#154996).
4213
4214 2005-04-13  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4215
4216         * docs/random/bbb/optional-properties:
4217           Some analysis on optional properties.
4218
4219 2005-04-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4220
4221         * docs/gst/tmpl/gstelementfactory.sgml:
4222         * gst/gstelement.h:
4223         * gst/gstelementfactory.c: (gst_element_factory_init),
4224         (gst_element_factory_cleanup), (gst_element_register),
4225         (__gst_element_factory_add_static_pad_template),
4226         (gst_element_factory_get_static_pad_templates),
4227         (gst_element_factory_can_src_caps),
4228         (gst_element_factory_can_sink_caps):
4229         * gst/registries/Makefile.am:
4230         * gst/registries/gstlibxmlregistry.c: (gst_xml_registry_get_type),
4231         (gst_xml_registry_class_init), (gst_xml_registry_init),
4232         (gst_xml_registry_new), (gst_xml_registry_set_property),
4233         (gst_xml_registry_get_property), (get_time), (make_dir),
4234         (gst_xml_registry_get_perms_func),
4235         (plugin_times_older_than_recurse), (plugin_times_older_than),
4236         (gst_xml_registry_open_func), (gst_xml_registry_load_func),
4237         (gst_xml_registry_save_func), (gst_xml_registry_close_func),
4238         (add_to_char_array), (read_string), (read_uint), (read_enum),
4239         (load_pad_template), (load_feature), (load_plugin), (load_paths),
4240         (gst_xml_registry_load), (gst_xml_registry_load_plugin),
4241         (gst_xml_registry_save_caps), (gst_xml_registry_save_pad_template),
4242         (gst_xml_registry_save_feature), (gst_xml_registry_save_plugin),
4243         (gst_xml_registry_save), (gst_xml_registry_rebuild_recurse),
4244         (gst_xml_registry_rebuild):
4245         * gst/registries/gstlibxmlregistry.h:
4246         * tools/gst-compprep.c: (main):
4247         * tools/gst-inspect.c: (print_pad_templates_info):
4248         * tools/gst-xmlinspect.c: (print_element_info):
4249           Use libxml2 for registry parsing, use staticpadtemplates in
4250           elementfactories. Makes gst_init() +/- 10x faster.
4251
4252 2005-04-12  Wim Taymans  <wim@fluendo.com>
4253
4254         * gst/base/Makefile.am:
4255         * gst/base/gstbasesink.c: (gst_basesink_base_init),
4256         (gst_basesink_pad_getcaps), (gst_basesink_init),
4257         (gst_basesink_event), (gst_basesink_change_state):
4258         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
4259         (gst_basesrc_init), (gst_basesrc_query),
4260         (gst_basesrc_get_event_mask), (gst_basesrc_do_seek),
4261         (gst_basesrc_event_handler), (gst_basesrc_get_range_unlocked),
4262         (gst_basesrc_check_get_range), (gst_basesrc_loop),
4263         (gst_basesrc_unlock), (gst_basesrc_get_size), (gst_basesrc_start),
4264         (gst_basesrc_stop), (gst_basesrc_activate),
4265         (gst_basesrc_change_state):
4266         * gst/base/gsttypefindhelper.c: (helper_find_peek),
4267         (helper_find_suggest), (gst_type_find_helper):
4268         * gst/base/gsttypefindhelper.h:
4269         * gst/elements/Makefile.am:
4270         * gst/elements/gstelements.c:
4271         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
4272         (gst_fakesink_get_times), (gst_fakesink_event),
4273         (gst_fakesink_preroll), (gst_fakesink_render):
4274         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
4275         (gst_fakesrc_init), (gst_fakesrc_event_handler),
4276         (gst_fakesrc_get_property), (gst_fakesrc_create),
4277         (gst_fakesrc_start), (gst_fakesrc_stop):
4278         * gst/elements/gstfakesrc.h:
4279         * gst/elements/gstfilesrc.c: (gst_filesrc_class_init),
4280         (gst_filesrc_free_parent_mmap), (gst_filesrc_map_region),
4281         (gst_filesrc_map_small_region), (gst_filesrc_create_mmap),
4282         (gst_filesrc_create_read), (gst_filesrc_create),
4283         (gst_filesrc_is_seekable), (gst_filesrc_get_size),
4284         (gst_filesrc_start):
4285         * gst/elements/gsttypefindelement.c:
4286         (gst_type_find_element_have_type), (gst_type_find_element_init),
4287         (start_typefinding), (stop_typefinding), (push_buffer_store),
4288         (gst_type_find_element_handle_event),
4289         (gst_type_find_element_chain),
4290         (gst_type_find_element_checkgetrange),
4291         (gst_type_find_element_getrange), (do_typefind),
4292         (gst_type_find_element_activate),
4293         (gst_type_find_element_change_state):
4294         * gst/elements/gsttypefindelement.h:
4295         * gst/gstpipeline.c: (pipeline_bus_handler):
4296         Added typefind helper.
4297         Small preroll fix in the base sink.
4298         Disable typefind code in basesrc.
4299         Crude port of typefindelement.
4300         Fakesrc cleanups.
4301
4302
4303 2005-04-11  Wim Taymans  <wim@fluendo.com>
4304
4305         * check/gst/gstbus.c: (gstbus_suite):
4306         * check/gst/gstdata.c: (thread_ref), (gst_data_suite):
4307         * check/gstcheck.h:
4308           Fix up the timeout so that the test does not fail.
4309
4310 2005-04-06  Wim Taymans  <wim@fluendo.com>
4311
4312         * gst/base/README:
4313         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
4314         (gst_basesrc_init), (gst_basesrc_get_formats), (gst_basesrc_query),
4315         (gst_basesrc_get_event_mask), (gst_basesrc_do_seek),
4316         (gst_basesrc_event_handler), (gst_basesrc_get_range_unlocked),
4317         (gst_basesrc_check_get_range), (gst_basesrc_loop),
4318         (gst_basesrc_unlock), (gst_basesrc_get_size), (gst_basesrc_start),
4319         (gst_basesrc_stop), (gst_basesrc_activate),
4320         (gst_basesrc_change_state), (basesrc_find_peek),
4321         (basesrc_find_suggest), (gst_basesrc_type_find):
4322         * gst/base/gstbasesrc.h:
4323         * gst/elements/gstfilesrc.c: (gst_filesrc_base_init),
4324         (gst_filesrc_class_init), (gst_filesrc_init),
4325         (gst_filesrc_finalize), (gst_filesrc_set_location),
4326         (gst_filesrc_set_property), (gst_filesrc_get_property),
4327         (gst_filesrc_free_parent_mmap), (gst_filesrc_map_region),
4328         (gst_filesrc_map_small_region), (gst_filesrc_create_mmap),
4329         (gst_filesrc_create_read), (gst_filesrc_create),
4330         (gst_filesrc_get_size), (gst_filesrc_start), (gst_filesrc_stop):
4331         * gst/elements/gstfilesrc.h:
4332         * gst/gstelement.c: (gst_element_get_state_func),
4333         (gst_element_lost_state), (gst_element_pads_activate):
4334         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
4335         (gst_pad_set_checkgetrange_function), (gst_pad_check_pull_range),
4336         (gst_pad_pull_range):
4337         * gst/gstpad.h:
4338         More work on the generic source base class, implement seeking,
4339         query.
4340         Make filesrc extend the base source class.
4341         Added gst_pad_set_checkgetrange_function to GstPad.
4342
4343 2005-04-06  Andy Wingo  <wingo@pobox.com>
4344
4345         * pkgconfig/gstreamer-base.pc.in:
4346         * pkgconfig/gstreamer-base-uninstalled.pc.in: New files.
4347
4348         * pkgconfig/Makefile.am:
4349         * configure.ac (AC_OUTPUT): Add gstreamer-base pkgconfig files.
4350
4351 2005-04-04  Wim Taymans  <wim@fluendo.com>
4352
4353         * gst/base/Makefile.am:
4354         * gst/base/README:
4355         * gst/base/gstbasesink.c: (gst_basesink_base_init),
4356         (gst_basesink_pad_getcaps), (gst_basesink_pad_setcaps),
4357         (gst_basesink_pad_buffer_alloc), (gst_basesink_init),
4358         (gst_basesink_do_sync), (gst_basesink_chain_unlocked):
4359         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
4360         (gst_basesrc_base_init), (gst_basesrc_class_init),
4361         (gst_basesrc_init), (gst_basesrc_get_formats),
4362         (gst_basesrc_get_query_types), (gst_basesrc_query),
4363         (gst_basesrc_get_event_mask), (gst_basesrc_event_handler),
4364         (gst_basesrc_set_property), (gst_basesrc_get_property),
4365         (gst_basesrc_get_range_unlocked), (gst_basesrc_get_range),
4366         (gst_basesrc_loop), (gst_basesrc_activate),
4367         (gst_basesrc_change_state):
4368         * gst/base/gstbasesrc.h:
4369         * gst/elements/gstfakesrc.c: (gst_fakesrc_base_init),
4370         (gst_fakesrc_class_init), (gst_fakesrc_init),
4371         (gst_fakesrc_event_handler), (gst_fakesrc_set_property),
4372         (gst_fakesrc_get_property), (gst_fakesrc_create):
4373         * gst/elements/gstfakesrc.h:
4374         * gst/elements/gstfilesrc.c: (gst_filesrc_getrange),
4375         (gst_filesrc_open_file), (gst_filesrc_loop),
4376         (gst_filesrc_activate), (filesrc_find_peek),
4377         (gst_filesrc_type_find):
4378         Made base source class, make fakesrc extend it.
4379         Add comments to basesink class.
4380         Some filesrc cleanup.
4381
4382 2005-03-31  David Schleef  <ds@schleef.org>
4383
4384         * gst/gstplugin.c: (gst_plugin_check_file), (gst_plugin_load_file):
4385         Switch to using G_MODULE_BIND_LOCAL, which means plugins are now
4386         expected to link against libgstreamer.
4387         * gst/base/Makefile.am: link against libgstreamer
4388         * gst/elements/Makefile.am: same
4389
4390 2005-03-31  Andy Wingo  <wingo@pobox.com>
4391
4392         * tests/instantiate/Makefile.am:
4393         * tests/instantiate/caps.c: Add test to test speed of caps copy
4394         and free.
4395
4396         * tests/memchunk/gmemchunktest.c (main): Use alloc only on the
4397         GMemChunk to be fair.
4398
4399         * gst/gsttrashstack.h: Remove warning about using the fallback
4400         trash stack implementation, it's still faster than malloc.
4401
4402 2005-03-30  Andy Wingo  <wingo@pobox.com>
4403
4404         * tests/complexity.c: Add a copyright.
4405
4406 2005-03-31  Wim Taymans  <wim@fluendo.com>
4407
4408         * gst/base/gstbasetransform.c: (gst_base_transform_base_init),
4409         (gst_base_transform_class_init), (gst_base_transform_init),
4410         (gst_base_transform_setcaps), (gst_base_transform_handle_buffer),
4411         (gst_base_transform_get_property),
4412         (gst_base_transform_sink_activate),
4413         (gst_base_transform_src_activate),
4414         (gst_base_transform_change_state):
4415         * gst/base/gstbasetransform.h:
4416         * gst/elements/gstidentity.c: (gst_identity_class_init),
4417         (gst_identity_event), (gst_identity_check_perfect),
4418         (gst_identity_transform), (gst_identity_start),
4419         (gst_identity_stop):
4420         Added start/stop methods to transform base class so subclasses 
4421         don't need to deal with state changes even.
4422
4423 2005-03-31  Wim Taymans  <wim@fluendo.com>
4424
4425         * gst/gstevent.c: (gst_event_new_discontinuous_valist),
4426         (gst_event_new_discontinuous), (gst_event_discont_get_value):
4427         * gst/gstevent.h:
4428         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
4429         (gst_pad_pull_range):
4430         Added rate to the discont event to prepare for variable speed
4431         and reverse playback.
4432
4433 2005-03-29  David Schleef  <ds@schleef.org>
4434
4435         * configure.ac:
4436         * testsuite/trigger/Makefile.am:
4437         * testsuite/trigger/trigger.c: A little example program to show
4438         how trigger-based elements can work.
4439
4440 2005-03-29  Wim Taymans  <wim@fluendo.com>
4441
4442         * gst/base/Makefile.am:
4443         * gst/base/README:
4444         * gst/base/gstbasesink.c: (gst_basesink_get_type),
4445         (gst_basesink_base_init), (gst_basesink_class_init),
4446         (gst_basesink_pad_getcaps), (gst_basesink_init),
4447         (gst_basesink_activate), (gst_basesink_change_state):
4448         * gst/base/gstbasesink.h:
4449         * gst/base/gstbasetransform.c: (gst_base_transform_get_type),
4450         (gst_base_transform_base_init), (gst_base_transform_finalize),
4451         (gst_base_transform_class_init), (gst_base_transform_init),
4452         (gst_base_transform_proxy_getcaps), (gst_base_transform_setcaps),
4453         (gst_base_transform_event), (gst_base_transform_getrange),
4454         (gst_base_transform_chain), (gst_base_transform_handle_buffer),
4455         (gst_base_transform_set_property),
4456         (gst_base_transform_get_property),
4457         (gst_base_transform_sink_activate),
4458         (gst_base_transform_src_activate),
4459         (gst_base_transform_change_state):
4460         * gst/base/gstbasetransform.h:
4461         * gst/elements/gstidentity.c: (gst_identity_finalize),
4462         (gst_identity_class_init), (gst_identity_init),
4463         (gst_identity_event), (gst_identity_check_perfect),
4464         (gst_identity_transform), (gst_identity_set_property),
4465         (gst_identity_get_property), (gst_identity_change_state):
4466         * gst/elements/gstidentity.h:
4467         * gst/gstelement.c: (gst_element_get_state_func),
4468         (gst_element_lost_state), (gst_element_pads_activate):
4469         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
4470         (gst_pad_check_pull_range), (gst_pad_pull_range):
4471         * gst/gstpad.h:
4472         Simplify pad activation.
4473         Added function to check if pull_range can be performed.
4474         Error out when pulling inactive or flushing pads.
4475         Removed const from refcounted types as it does not make sense.
4476         Simplify pad templates in basesink
4477         Added base class for simple 1-to-1 transforms.
4478         Make identity subclass the base transform.
4479
4480 2005-03-29  Andy Wingo  <wingo@pobox.com>
4481
4482         * docs/libs/gstreamer-libs-overrides.txt: 
4483         * docs/gst/gstreamer-overrides.txt: Add these files to CVS. Now I
4484         really don't understand what's going on, but like whatever. I want
4485         green buildbot!
4486
4487         * docs/gst/Makefile.am:
4488         * docs/libs/Makefile.am: Dist the overrides files.
4489
4490         * check/Makefile.am (clean-local): Remove .libs directories.
4491
4492         * gst/elements/Makefile.am (EXTRA_DIST): Add all the attic
4493         elements to EXTRA_DIST, so po/ files are happy.
4494
4495         * po/POTFILES.in: Er, remove it here.
4496
4497         * po/POTFILES: Remove gstspider.c.
4498
4499         * configure.ac (AC_OUTPUT): Add missing testsuite makefiles.
4500
4501         * docs/libs/gstreamer-libs-docs.sgml: 
4502         * docs/libs/gstreamer-libs-sections.txt: Remove the section on
4503         bytestream.
4504
4505         * tests/complexity.c (main): Set the length of the preroll queue
4506         on the sinks to prevent a lockup.
4507
4508         * libs/gst/dataprotocol/Makefile.am: 
4509         * libs/gst/dataprotocol/dataprotocol-test.c: Remove test, it's
4510         the same as the one in check/gst-libs/gdp.c.
4511
4512         * po/, docs/gst/: Commit automatic changes to docs and po files.
4513
4514         * gst/elements/Makefile.am (libgstelements_la_LDFLAGS): Link to
4515         the versioned libgstbase.
4516
4517         * check/Makefile.am: Depend on an unversioned gst-register, seems
4518         to make autoconf happier.
4519
4520         * gst/base/Makefile.am: Make libgstbase a versioned lib.
4521
4522 2005-03-28  Wim Taymans  <wim@fluendo.com>
4523
4524         * configure.ac:
4525         * docs/design/part-gstelement.txt:
4526         * docs/design/part-negotiation.txt:
4527         * docs/design/part-preroll.txt:
4528         * docs/design/part-scheduling.txt:
4529         * docs/design/part-states.txt:
4530         * gst/Makefile.am:
4531         * gst/base/Makefile.am:
4532         * gst/base/README:
4533         * gst/base/gstbasesink.c: (gst_basesink_get_template),
4534         (gst_basesink_base_init), (gst_basesink_class_init),
4535         (gst_basesink_pad_getcaps), (gst_basesink_pad_setcaps),
4536         (gst_basesink_pad_buffer_alloc), (gst_basesink_init),
4537         (gst_basesink_set_pad_functions),
4538         (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock),
4539         (gst_basesink_set_property), (gst_basesink_get_property),
4540         (gst_base_sink_get_template), (gst_base_sink_get_caps),
4541         (gst_base_sink_set_caps), (gst_base_sink_buffer_alloc),
4542         (gst_basesink_preroll_queue_push),
4543         (gst_basesink_preroll_queue_empty),
4544         (gst_basesink_preroll_queue_flush), (gst_basesink_finish_preroll),
4545         (gst_basesink_event), (gst_basesink_get_times),
4546         (gst_basesink_do_sync), (gst_basesink_handle_buffer),
4547         (gst_basesink_chain_unlocked), (gst_basesink_chain),
4548         (gst_basesink_loop), (gst_basesink_activate),
4549         (gst_basesink_change_state):
4550         * gst/base/gstbasesink.h:
4551         * gst/elements/Makefile.am:
4552         * gst/elements/gstfakesink.c: (gst_fakesink_base_init),
4553         (gst_fakesink_class_init), (gst_fakesink_init),
4554         (gst_fakesink_set_property), (gst_fakesink_get_property),
4555         (gst_fakesink_get_times), (gst_fakesink_event),
4556         (gst_fakesink_preroll), (gst_fakesink_render),
4557         (gst_fakesink_change_state):
4558         * gst/elements/gstfakesink.h:
4559         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_manager),
4560         (gst_bin_get_state), (gst_bin_change_state), (gst_bin_send_event):
4561         * gst/gstelement.c: (gst_element_add_pad),
4562         (gst_element_get_state_func), (gst_element_abort_state),
4563         (gst_element_commit_state), (gst_element_lost_state),
4564         (gst_element_set_state), (gst_element_pads_activate):
4565         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_event_default):
4566         * gst/gstpipeline.c: (gst_pipeline_send_event),
4567         (gst_pipeline_change_state):
4568         Added state change code.
4569         Added/updated docs.
4570         Added sink base class, make fakesink extend the base class.
4571         Small cleanups in GstPipeline.
4572
4573 2005-03-26  David Schleef  <ds@schleef.org>
4574
4575         * gst/Makefile.am: remove gstcpu.[ch].  The gst_cpu functionality
4576         is broken and should be implemented in a different library.
4577         * gst/gst.c: (init_post): don't call _gst_cpu_initialize()
4578         * gst/gst.h: remove gstcpu.h
4579         * gst/gstcpu.c: remove
4580         * gst/gstcpu.h: remove
4581         * gst/Makefile.am.future: Remove this file.  It's ancient.
4582
4583 2005-03-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4584
4585         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_manager),
4586         (gst_bin_send_event):
4587           Add default event/set_manager handlers. The set_manager handler
4588           takes care that the manager is distributed over kids that were
4589           already in the bin before the manager was set. The event handler
4590           is a utility virtual function that sends the event over all sinks,
4591           so that gst_element_send_event (bin, event); has the expected
4592           behaviour.
4593         * gst/gstpad.c: (gst_pad_event_default):
4594           Re-install default event handling for discontinuities, so that
4595           seeking works without requiring hacks in applications or extra
4596           code in sinks.
4597         * gst/gstpipeline.c: (gst_pipeline_class_init),
4598         (gst_pipeline_send_event):
4599           Half hack, half utility: set a pipeline to PAUSED for seek events,
4600           since that is the only way we can guarantee a/v sync. Means that
4601           you can do gst_element_seek (pipeline, method, pos); on a pipeline
4602           and it "just works".
4603
4604 2005-03-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4605
4606         * gst/gstpipeline.c: (gst_pipeline_use_clock):
4607           Lock/unlock mismatch.
4608
4609 2005-03-25  Thomas Vander Stichele  <thomas at apestaart dot org>
4610
4611         * docs/faq/gst-uninstalled:
4612           add gst-plugins-base
4613         * docs/gst/Makefile.am:
4614           don't error out until docs are fixed
4615         * docs/gst/gstreamer.types:
4616           remove thread
4617
4618 2005-03-22  Wim Taymans  <wim@fluendo.com>
4619
4620         * check/Makefile.am:
4621         * check/gst/gstmessage.c: (START_TEST), (gst_data_suite), (main):
4622         * gst/gststructure.c: (gst_structure_set_valist),
4623         (gst_structure_copy_conditional):
4624         Activated more tests.
4625         Added message test.
4626         Added G_TYPE_POINTER to GstStructure.
4627         
4628
4629 2005-03-22  Wim Taymans  <wim@fluendo.com>
4630
4631         * docs/design/part-TODO.txt:
4632         * docs/design/part-events.txt:
4633         * docs/design/part-gstbin.txt:
4634         * docs/design/part-gstbus.txt:
4635         * docs/design/part-gstpipeline.txt:
4636         * docs/design/part-messages.txt:
4637         * gst/gstbus.c:
4638         * gst/gstmessage.c:
4639         Docs updates
4640
4641 2005-03-21  Wim Taymans  <wim@fluendo.com>
4642
4643         * gst/gstbus.c: (gst_bus_post):
4644         Fix copy-and-paste error.
4645
4646 2005-03-21  Wim Taymans  <wim@fluendo.com>
4647
4648         * check/Makefile.am:
4649         * gst/Makefile.am:
4650         * gst/elements/Makefile.am:
4651         * gst/elements/gstelements.c:
4652         * gst/elements/gstfakesink.c: (gst_fakesink_init),
4653         (gst_fakesink_event), (gst_fakesink_chain):
4654         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
4655         (gst_fakesrc_init), (gst_fakesrc_get_event_mask),
4656         (gst_fakesrc_event_handler), (gst_fakesrc_set_pad_functions),
4657         (gst_fakesrc_set_all_pad_functions), (gst_fakesrc_request_new_pad),
4658         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
4659         (gst_fakesrc_get_range_unlocked), (gst_fakesrc_get_range),
4660         (gst_fakesrc_loop), (gst_fakesrc_activate),
4661         (gst_fakesrc_change_state):
4662         * gst/elements/gstfakesrc.h:
4663         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
4664         (gst_filesrc_get_read), (gst_filesrc_getrange), (gst_filesrc_get),
4665         (gst_filesrc_open_file), (gst_filesrc_loop),
4666         (gst_filesrc_activate), (gst_filesrc_change_state),
4667         (filesrc_find_peek), (filesrc_find_suggest),
4668         (gst_filesrc_type_find):
4669         * gst/elements/gstidentity.c: (gst_identity_finalize),
4670         (gst_identity_class_init), (gst_identity_init),
4671         (gst_identity_proxy_getcaps), (identity_queue_push),
4672         (identity_queue_pop), (identity_queue_flush), (gst_identity_event),
4673         (gst_identity_getrange), (gst_identity_chain),
4674         (gst_identity_sink_loop), (gst_identity_src_loop),
4675         (gst_identity_handle_buffer), (gst_identity_set_dataflow_funcs),
4676         (gst_identity_set_property), (gst_identity_get_property),
4677         (gst_identity_change_state):
4678         * gst/elements/gstidentity.h:
4679         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_init),
4680         (gst_tee_update_pad_functions), (gst_tee_request_new_pad),
4681         (gst_tee_set_property), (gst_tee_get_property), (gst_tee_do_push),
4682         (gst_tee_handle_buffer), (gst_tee_chain), (gst_tee_loop),
4683         (gst_tee_sink_activate):
4684         * gst/elements/gsttee.h:
4685         * gst/gst.c: (gst_register_core_elements), (init_post):
4686         * gst/gst.h:
4687         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_bus),
4688         (gst_bin_set_scheduler), (gst_bin_add_func), (gst_bin_add),
4689         (gst_bin_remove_func), (gst_bin_remove), (gst_bin_get_state),
4690         (gst_bin_change_state):
4691         * gst/gstbin.h:
4692         * gst/gstbus.c: (gst_bus_get_type), (gst_bus_class_init),
4693         (gst_bus_init), (gst_bus_dispose), (gst_bus_set_property),
4694         (gst_bus_get_property), (gst_bus_new), (gst_bus_post),
4695         (gst_bus_have_pending), (gst_bus_pop), (gst_bus_peek),
4696         (gst_bus_set_sync_handler), (gst_bus_create_watch),
4697         (bus_watch_callback), (bus_watch_destroy),
4698         (gst_bus_add_watch_full), (gst_bus_add_watch), (poll_handler),
4699         (poll_timeout), (gst_bus_poll):
4700         * gst/gstbus.h:
4701         * gst/gstcaps.h:
4702         * gst/gstdata.h:
4703         * gst/gstelement.c: (gst_element_class_init), (gst_element_init),
4704         (gst_element_post_message), (gst_element_message_full),
4705         (gst_element_get_state_func), (gst_element_get_state),
4706         (gst_element_abort_state), (gst_element_commit_state),
4707         (gst_element_lost_state), (gst_element_set_state),
4708         (gst_element_pads_activate), (gst_element_change_state),
4709         (gst_element_dispose), (gst_element_set_manager_func),
4710         (gst_element_set_bus_func), (gst_element_set_scheduler_func),
4711         (gst_element_set_manager), (gst_element_get_manager),
4712         (gst_element_set_bus), (gst_element_get_bus),
4713         (gst_element_set_scheduler), (gst_element_get_scheduler):
4714         * gst/gstelement.h:
4715         * gst/gstevent.c: (gst_event_new_segment_seek),
4716         (gst_event_new_flush):
4717         * gst/gstevent.h:
4718         * gst/gstmessage.c: (_gst_message_initialize), (_gst_message_copy),
4719         (_gst_message_free), (gst_message_get_type), (gst_message_new),
4720         (gst_message_new_eos), (gst_message_new_error),
4721         (gst_message_new_warning), (gst_message_new_tag),
4722         (gst_message_new_state_changed), (gst_message_new_application),
4723         (gst_message_get_structure), (gst_message_parse_tag),
4724         (gst_message_parse_state_changed), (gst_message_parse_error),
4725         (gst_message_parse_warning):
4726         * gst/gstmessage.h:
4727         * gst/gstpad.c: (gst_real_pad_class_init), (gst_real_pad_init),
4728         (gst_real_pad_set_property), (gst_pad_set_active),
4729         (gst_pad_is_active), (gst_pad_set_blocked_async),
4730         (gst_pad_set_blocked), (gst_pad_is_blocked),
4731         (gst_pad_set_activate_function), (gst_pad_set_loop_function),
4732         (gst_pad_set_getrange_function), (gst_pad_set_acceptcaps_function),
4733         (gst_pad_set_fixatecaps_function), (gst_pad_set_setcaps_function),
4734         (gst_pad_unlink), (gst_pad_link_prepare_filtered),
4735         (gst_pad_link_filtered), (gst_pad_relink_filtered),
4736         (gst_real_pad_get_caps_unlocked), (gst_pad_get_caps),
4737         (gst_pad_peer_get_caps), (gst_pad_fixate_caps),
4738         (gst_pad_accept_caps), (gst_pad_peer_accept_caps),
4739         (gst_pad_set_caps), (gst_pad_configure_sink),
4740         (gst_pad_configure_src), (gst_pad_get_negotiated_caps),
4741         (gst_pad_get_filter_caps), (gst_pad_alloc_buffer),
4742         (gst_real_pad_dispose), (gst_real_pad_finalize),
4743         (handle_pad_block), (gst_pad_push), (gst_pad_pull_range),
4744         (gst_pad_event_default_dispatch), (gst_pad_event_default),
4745         (gst_pad_push_event), (gst_pad_send_event), (gst_pad_get_formats):
4746         * gst/gstpad.h:
4747         * gst/gstpipeline.c: (gst_pipeline_init), (is_eos),
4748         (pipeline_bus_handler), (gst_pipeline_change_state),
4749         (gst_pipeline_get_scheduler), (gst_pipeline_get_bus):
4750         * gst/gstpipeline.h:
4751         * gst/gstprobe.h:
4752         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_init),
4753         (gst_queue_finalize), (gst_queue_getcaps), (gst_queue_link_sink),
4754         (gst_queue_link_src), (gst_queue_bufferalloc),
4755         (gst_queue_locked_flush), (gst_queue_handle_sink_event),
4756         (gst_queue_is_empty), (gst_queue_is_filled), (gst_queue_chain),
4757         (gst_queue_loop), (gst_queue_handle_src_event),
4758         (gst_queue_handle_src_query), (gst_queue_src_activate),
4759         (gst_queue_change_state):
4760         * gst/gstqueue.h:
4761         * gst/gstscheduler.c: (gst_scheduler_init),
4762         (gst_scheduler_dispose), (gst_scheduler_create_task),
4763         (gst_scheduler_factory_create):
4764         * gst/gstscheduler.h:
4765         * gst/gststructure.c: (gst_structure_get_type),
4766         (gst_structure_copy_conditional):
4767         * gst/gststructure.h:
4768         * gst/gsttaginterface.h:
4769         * gst/gsttask.c: (gst_task_get_type), (gst_task_class_init),
4770         (gst_task_init), (gst_task_dispose), (gst_task_create),
4771         (gst_task_get_state), (gst_task_start), (gst_task_stop),
4772         (gst_task_pause):
4773         * gst/gsttask.h:
4774         * gst/gstthread.c:
4775         * gst/gstthread.h:
4776         * gst/gsttypes.h:
4777         * gst/schedulers/Makefile.am:
4778         * gst/schedulers/cothreads_compat.h:
4779         * gst/schedulers/entryscheduler.c:
4780         * gst/schedulers/faircothreads.c:
4781         * gst/schedulers/faircothreads.h:
4782         * gst/schedulers/fairscheduler.c:
4783         * gst/schedulers/gstbasicscheduler.c:
4784         * gst/schedulers/gstoptimalscheduler.c:
4785         * gst/schedulers/gthread-cothreads.h:
4786         * gst/schedulers/threadscheduler.c:
4787         (gst_thread_scheduler_task_get_type),
4788         (gst_thread_scheduler_task_class_init),
4789         (gst_thread_scheduler_task_init),
4790         (gst_thread_scheduler_task_start),
4791         (gst_thread_scheduler_task_stop),
4792         (gst_thread_scheduler_task_pause), (gst_thread_scheduler_get_type),
4793         (gst_thread_scheduler_class_init), (gst_thread_scheduler_func),
4794         (gst_thread_scheduler_init), (gst_thread_scheduler_create_task),
4795         (gst_thread_scheduler_setup), (gst_thread_scheduler_reset),
4796         (plugin_init):
4797         * libs/gst/Makefile.am:
4798         * libs/gst/bytestream/bytestream.c: (gst_bytestream_get_next_buf):
4799         * libs/gst/bytestream/filepad.c: (gst_file_pad_init),
4800         (gst_file_pad_parent_set):
4801         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_event),
4802         (gst_dp_event_from_packet):
4803         * tests/complexity.c: (main):
4804         * tests/mass_elements.c: (main):
4805         * testsuite/states/locked.c: (message_received), (main):
4806         * testsuite/states/parent.c: (main):
4807         * tools/gst-inspect.c: (print_element_flag_info),
4808         (print_implementation_info), (print_pad_info):
4809         * tools/gst-launch.c: (check_intr), (play_handler), (event_loop),
4810         (main):
4811         * tools/gst-md5sum.c: (event_loop), (main):
4812         * tools/gst-typefind.c: (main):
4813         * tools/gst-xmlinspect.c: (print_element_info):
4814         Next big merge.
4815         Added GstBus for mainloop integration.
4816         Added GstMessage for sending notifications on the bus.
4817         Added GstTask as an abstraction for pipeline entry points.
4818         Removed GstThread.
4819         Removed Schedulers.
4820         Simplified GstQueue for multithreaded core.
4821         Made _link threadsafe, removed old capsnego.
4822         Added STREAM_LOCK and PREROLL_LOCK in GstPad.
4823         Added pad blocking functions.
4824         Reworked scheduling functions in GstPad to prepare for
4825         scheduling updates soon.
4826         Moved events out of data stream.
4827         Simplified GstEvent types.
4828         Added return values to push/pull.
4829         Removed clocking from GstElement.
4830         Added prototypes for state change function for next merge.
4831         Removed iterate from bins and state change management.
4832         Fixed some elements, disabled others for now.
4833         Fixed -inspect and -launch.
4834         Added check for GstBus.
4835
4836 2005-03-10  Wim Taymans  <wim@fluendo.com>
4837
4838         * docs/design/part-MT-refcounting.txt:
4839         * docs/design/part-clocks.txt:
4840         * docs/design/part-gstelement.txt:
4841         * docs/design/part-gstobject.txt:
4842         * docs/design/part-standards.txt:
4843         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
4844         (gst_bin_remove_func), (gst_bin_remove):
4845         * gst/gstbin.h:
4846         * gst/gstbuffer.c:
4847         * gst/gstcaps.h:
4848         * testsuite/clock/clock1.c: (main):
4849         * testsuite/clock/clock2.c: (gst_clock_debug), (element_wait),
4850         (main):
4851         * testsuite/dlopen/loadgst.c: (do_test):
4852         * testsuite/refcounting/bin.c: (add_remove_test1),
4853         (add_remove_test2), (main):
4854         * testsuite/refcounting/element.c: (main):
4855         * testsuite/refcounting/element_pad.c: (main):
4856         * testsuite/refcounting/pad.c: (main):
4857         * tools/gst-launch.c: (sigint_handler_sighandler):
4858         * tools/gst-typefind.c: (main):
4859         Doc updates.
4860         Added doc about clock.
4861         removed gst_bin_iterate_recurse_up(), marked methods
4862         for removal.
4863         Fix more testsuites.
4864
4865 2005-03-09  Wim Taymans  <wim@fluendo.com>
4866
4867         * gst/gstpad.c: (gst_pad_get_direction),
4868         (_gst_pad_default_fixate_foreach), (gst_pad_collectv),
4869         (gst_pad_collect_valist):
4870         * testsuite/bins/interface.c: (main):
4871         * testsuite/caps/audioscale.c: (test_caps):
4872         * testsuite/caps/caps.c: (test1), (test2), (test3):
4873         * testsuite/caps/deserialize.c: (main):
4874         * testsuite/caps/enumcaps.c: (main):
4875         * testsuite/caps/filtercaps.c: (main):
4876         * testsuite/caps/intersect2.c: (main):
4877         * testsuite/caps/random.c: (main):
4878         * testsuite/caps/renegotiate.c: (my_fixate), (main):
4879         * testsuite/caps/sets.c: (check_caps):
4880         * testsuite/caps/simplify.c: (check_caps), (main):
4881         * testsuite/caps/subtract.c: (check_caps):
4882         Fix _pad_get_direction wrt ghostpads.
4883         Fix caps testsuite.
4884
4885 2005-03-09  Wim Taymans  <wim@fluendo.com>
4886
4887         * check/Makefile.am:
4888         * check/gst/gstbin.c: (START_TEST), (gst_bin_suite), (main):
4889         * check/gst/gstsystemclock.c: (START_TEST), (gst_clock_debug),
4890         (ok_callback), (error_callback), (gst_systemclock_suite), (main):
4891         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_index_func),
4892         (gst_bin_set_clock_func), (gst_bin_get_clock_func),
4893         (gst_bin_add_func), (gst_bin_add), (gst_bin_remove_func),
4894         (gst_bin_remove), (gst_bin_iterate_recurse_up),
4895         (bin_element_is_sink), (gst_bin_iterate_sinks),
4896         (gst_bin_iterate_all_by_interface):
4897         * gst/gstbin.h:
4898         * gst/gstelement.c: (gst_element_init), (gst_element_error_full),
4899         (gst_element_change_state), (gst_element_dispose),
4900         (gst_element_finalize), (gst_element_set_loop_function):
4901         * gst/gstelement.h:
4902         * gst/gstiterator.c: (find_custom_fold_func):
4903         * gst/gstpad.c: (_gst_pad_default_fixate_foreach),
4904         (gst_pad_collectv), (gst_pad_collect_valist),
4905         (gst_pad_template_new):
4906         * gst/gstpipeline.c: (gst_pipeline_class_init),
4907         (gst_pipeline_dispose), (gst_pipeline_set_property),
4908         (gst_pipeline_get_property), (gst_pipeline_get_clock_func),
4909         (gst_pipeline_get_clock), (gst_pipeline_use_clock),
4910         (gst_pipeline_set_clock), (gst_pipeline_auto_clock):
4911         * gst/gstutils.h:
4912         * gst/schedulers/entryscheduler.c:
4913         * gst/schedulers/gstbasicscheduler.c:
4914         (gst_basic_scheduler_cothreaded_chain),
4915         (gst_basic_scheduler_chain_add_element):
4916         * testsuite/bins/interface.c: (main):
4917         Added GstBin test.
4918         Added GstSystemClock test.
4919         Implemented clock distribution code in GstBin.
4920         Implemented iterate sinks method for future use.
4921         Rearranged gstelement.h
4922         Fix GstIterator comparison bug.
4923         Moved some code to GstPipeline, mostly clocking related.
4924
4925 2005-03-09  Wim Taymans  <wim@fluendo.com>
4926
4927         * configure.ac:
4928         * gst/gst_private.h:
4929         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
4930         (gst_bin_remove_func), (gst_bin_remove),
4931         (gst_bin_get_by_name_recurse_up):
4932         * gst/gstclock.c: (gst_clock_id_ref), (gst_clock_id_unref),
4933         (gst_clock_id_compare_func), (gst_clock_id_wait),
4934         (gst_clock_id_wait_async), (gst_clock_init),
4935         (gst_clock_adjust_unlocked), (gst_clock_get_time):
4936         * gst/gstelement.h:
4937         * gst/gstinfo.c: (_gst_debug_init):
4938         * gst/gstobject.h:
4939         * gst/gstpad.c: (_gst_pad_default_fixate_foreach),
4940         (gst_pad_collectv), (gst_pad_collect_valist), (gst_pad_query):
4941         * gst/gstpad.h:
4942         Bump version number, we're now 0.9.0
4943         Add future debugging category.
4944         Fix NULL _unref() in _get_by_name_recurse_up
4945         Rearrange gstpad.h.
4946         Update some docs.
4947
4948 2005-03-08  Wim Taymans  <wim@fluendo.com>
4949
4950         * gst/elements/gstaggregator.c: (gst_aggregator_class_init):
4951         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
4952         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
4953         * gst/elements/gstfdsink.c: (gst_fdsink_class_init):
4954         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init):
4955         * gst/elements/gstfilesink.c: (gst_filesink_class_init):
4956         * gst/elements/gstfilesrc.c: (gst_filesrc_class_init):
4957         * gst/elements/gstidentity.c: (gst_identity_class_init):
4958         * gst/elements/gstmd5sink.c: (gst_md5sink_class_init):
4959         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
4960         * gst/elements/gstshaper.c: (gst_shaper_class_init):
4961         * gst/elements/gststatistics.c: (gst_statistics_class_init):
4962         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_getcaps),
4963         (gst_tee_link):
4964         * gst/gstelement.c: (gst_element_class_init),
4965         (gst_element_base_class_init), (gst_element_init),
4966         (gst_element_get_random_pad), (gst_element_wait_state_change),
4967         (gst_element_change_state), (gst_element_dispose),
4968         (gst_element_finalize), (gst_element_set_loop_function):
4969         * gst/gstelement.h:
4970         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_link_src):
4971         * gst/gstthread.c: (gst_thread_class_init),
4972         (gst_thread_release_children_locks), (gst_thread_change_state):
4973         * gst/schedulers/gstbasicscheduler.c:
4974         (gst_basic_scheduler_loopfunc_wrapper),
4975         (gst_basic_scheduler_chain_wrapper),
4976         (gst_basic_scheduler_src_wrapper),
4977         (gst_basic_scheduler_remove_element):
4978         * gst/schedulers/gstoptimalscheduler.c: (schedule_group):
4979         Remove threadsafe properties. Fix elements because GObject
4980         complains when installing a property before declaring a
4981         set/get_property handler.
4982         Rearrange gstelement.h file, use STATE macros for state locks.
4983         Free mutexes in the finalize method instead of dispose.
4984
4985 2005-03-08  Wim Taymans  <wim@fluendo.com>
4986
4987         * check/gst/gstobject.c: (START_TEST), (gst_object_suite):
4988         * gst/gstthread.c: (gst_thread_release_children_locks):
4989         Added parentage check.
4990         Fix build og GstThread again.
4991
4992 2005-03-08  Wim Taymans  <wim@fluendo.com>
4993
4994         * docs/design/part-MT-refcounting.txt:
4995         * docs/design/part-conventions.txt:
4996         * docs/design/part-gstobject.txt:
4997         * docs/design/part-relations.txt:
4998         * docs/design/part-standards.txt:
4999         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
5000         (gst_bin_remove_func), (gst_bin_remove), (gst_bin_iterate_recurse),
5001         (gst_bin_get_by_name), (gst_bin_get_by_interface),
5002         (gst_bin_iterate_all_by_interface):
5003         * gst/gstbuffer.h:
5004         * gst/gstclock.h:
5005         * gst/gstelement.c: (gst_element_class_init),
5006         (gst_element_change_state), (gst_element_set_loop_function):
5007         * gst/gstelement.h:
5008         * gst/gstiterator.c:
5009         * gst/gstobject.c: (gst_object_class_init), (gst_object_ref),
5010         (gst_object_unref), (gst_object_sink), (gst_object_dispose),
5011         (gst_object_dispatch_properties_changed), (gst_object_set_name),
5012         (gst_object_set_parent), (gst_object_unparent),
5013         (gst_object_check_uniqueness):
5014         * gst/gstobject.h:
5015         Docs updates, clean up some headers.
5016
5017 2005-03-07  Wim Taymans  <wim@fluendo.com>
5018
5019         * check/.cvsignore:
5020         * check/Makefile.am:
5021         * check/gst-libs/.cvsignore:
5022         * check/gst-libs/gdp.c: (START_TEST), (gst_object_suite), (main):
5023         * check/gst/.cvsignore:
5024         * check/gst/gstbus.c: (pound_bus_with_messages), (pull_messages),
5025         (START_TEST), (gstbus_suite), (main):
5026         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite), (main):
5027         * check/gst/gstdata.c: (START_TEST), (thread_ref), (thread_unref),
5028         (gst_data_suite), (main):
5029         * check/gst/gstiterator.c: (make_list_of_ints), (START_TEST),
5030         (add_fold_func), (gstiterator_suite), (main):
5031         * check/gst/gstobject.c: (gst_fake_object_get_type), (START_TEST),
5032         (thread_name_object), (thread_name_object_default),
5033         (gst_object_name_compare), (gst_object_suite), (main):
5034         * check/gst/gstpad.c: (START_TEST), (thread_link_unlink),
5035         (gst_pad_suite), (main):
5036         * check/gstcheck.c: (gst_check_log_message_func),
5037         (gst_check_log_critical_func), (gst_check_init):
5038         * check/gstcheck.h:
5039         * check/pipelines/simple_launch_lines.c: (setup_pipeline),
5040         (run_pipeline), (START_TEST), (simple_launch_lines_suite), (main):
5041         Added checks.
5042
5043 2005-03-07  Wim Taymans  <wim@fluendo.com>
5044
5045         * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new),
5046         (gst_list_iterator_next), (gst_list_iterator_resync),
5047         (gst_list_iterator_free), (gst_iterator_new_list),
5048         (gst_iterator_pop), (gst_iterator_next), (gst_iterator_resync),
5049         (gst_iterator_free), (gst_iterator_push), (filter_next),
5050         (filter_resync), (filter_uninit), (filter_free),
5051         (gst_iterator_filter), (gst_iterator_fold), (foreach_fold_func),
5052         (gst_iterator_foreach), (find_custom_fold_func),
5053         (gst_iterator_find_custom):
5054         * gst/gstiterator.h:
5055         Added missing files.
5056
5057 2005-03-07  Wim Taymans  <wim@fluendo.com>
5058
5059         * Makefile.am:
5060         * configure.ac:
5061         * docs/design/part-MT-refcounting.txt:
5062         * docs/design/part-conventions.txt:
5063         * docs/design/part-gstobject.txt:
5064         * docs/design/part-relations.txt:
5065         * examples/mixer/mixer.c: (main):
5066         * examples/thread/thread.c: (eos), (main):
5067         * gst/Makefile.am:
5068         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_caps_intersect):
5069         * gst/autoplug/gstspider.c: (gst_spider_identity_plug),
5070         (gst_spider_plug_from_srcpad):
5071         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_getcaps),
5072         (gst_spider_identity_change_state),
5073         (gst_spider_identity_sink_loop_type_finding):
5074         * gst/elements/gstfakesrc.c: (gst_fakesrc_loop):
5075         * gst/elements/gstidentity.c: (gst_identity_init):
5076         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_getcaps),
5077         (gst_tee_link), (gst_tee_request_new_pad), (gst_tee_chain):
5078         * gst/elements/gsttypefindelement.c: (free_entry):
5079         * gst/gst.c:
5080         * gst/gst.h:
5081         * gst/gstbin.c: (gst_bin_init), (gst_bin_get_clock_func),
5082         (gst_bin_set_clock_func), (gst_bin_auto_clock),
5083         (gst_bin_set_index), (gst_bin_set_element_sched),
5084         (gst_bin_unset_element_sched), (gst_bin_add_func), (gst_bin_add),
5085         (gst_bin_remove_func), (gst_bin_remove), (iterate_child),
5086         (gst_bin_iterate_elements), (iterate_child_recurse),
5087         (gst_bin_iterate_recurse), (gst_bin_dispose), (compare_name),
5088         (gst_bin_get_by_name), (gst_bin_get_by_name_recurse_up),
5089         (compare_interface), (gst_bin_get_by_interface),
5090         (gst_bin_iterate_all_by_interface), (gst_bin_iterate_func):
5091         * gst/gstbin.h:
5092         * gst/gstbuffer.c: (gst_buffer_get_type), (_gst_buffer_sub_free),
5093         (gst_buffer_default_free), (gst_buffer_default_copy),
5094         (gst_buffer_new), (gst_buffer_get_caps), (gst_buffer_set_caps),
5095         (gst_buffer_create_sub):
5096         * gst/gstbuffer.h:
5097         * gst/gstcaps.c: (gst_caps_get_type), (gst_caps_new_empty),
5098         (_gst_caps_free), (gst_caps_make_writable), (gst_caps_ref),
5099         (gst_caps_unref), (gst_static_caps_get),
5100         (gst_caps_remove_and_get_structure), (gst_caps_append),
5101         (gst_caps_append_structure), (gst_caps_remove_structure),
5102         (gst_caps_copy_nth), (gst_caps_set_simple),
5103         (gst_caps_set_simple_valist), (gst_caps_is_fixed_foreach),
5104         (gst_structure_is_equal_foreach), (gst_caps_is_subset),
5105         (gst_caps_structure_intersect_field), (gst_caps_intersect),
5106         (gst_caps_structure_subtract_field), (gst_caps_subtract),
5107         (gst_caps_normalize_foreach), (gst_caps_compare_structures),
5108         (gst_caps_structure_figure_out_union),
5109         (gst_caps_switch_structures), (gst_caps_do_simplify),
5110         (gst_caps_replace), (gst_caps_from_string),
5111         (gst_caps_copy_conditional):
5112         * gst/gstcaps.h:
5113         * gst/gstclock.c: (gst_clock_entry_new), (gst_clock_id_ref),
5114         (_gst_clock_id_free), (gst_clock_id_unref),
5115         (gst_clock_id_compare_func), (gst_clock_id_wait),
5116         (gst_clock_id_wait_async), (gst_clock_class_init),
5117         (gst_clock_init), (gst_clock_dispose), (gst_clock_adjust_unlocked),
5118         (gst_clock_get_time), (gst_clock_set_time_adjust),
5119         (gst_clock_set_property), (gst_clock_get_property):
5120         * gst/gstclock.h:
5121         * gst/gstcompat.h:
5122         * gst/gstcpu.c: (_gst_cpu_initialize_i386), (gst_cpu_get_flags):
5123         * gst/gstdata.c: (gst_data_is_writable), (gst_data_copy_on_write):
5124         * gst/gstdata.h:
5125         * gst/gstelement.c: (gst_element_class_init), (gst_element_init),
5126         (gst_element_requires_clock), (gst_element_provides_clock),
5127         (gst_element_set_clock), (gst_element_clock_wait),
5128         (gst_element_wait), (gst_element_set_time_delay),
5129         (gst_element_is_indexable), (gst_element_add_pad),
5130         (gst_element_add_ghost_pad), (gst_element_remove_pad),
5131         (pad_compare_name), (gst_element_get_static_pad),
5132         (gst_element_request_pad), (gst_element_get_request_pad),
5133         (gst_element_get_pad), (iterate_pad), (gst_element_iterate_pads),
5134         (gst_element_class_get_pad_template_list),
5135         (gst_element_class_get_pad_template), (gst_element_error_func),
5136         (gst_element_get_random_pad), (gst_element_get_event_masks),
5137         (gst_element_send_event), (gst_element_seek),
5138         (gst_element_get_query_types), (gst_element_query),
5139         (gst_element_get_formats), (gst_element_convert),
5140         (gst_element_is_locked_state), (gst_element_set_locked_state),
5141         (gst_element_sync_state_with_parent), (gst_element_change_state),
5142         (gst_element_finalize), (gst_element_yield),
5143         (gst_element_interrupt), (gst_element_set_scheduler),
5144         (gst_element_get_scheduler), (gst_element_set_loop_function):
5145         * gst/gstelement.h:
5146         * gst/gstevent.h:
5147         * gst/gstformat.c: (_gst_format_initialize), (gst_format_register),
5148         (gst_format_get_by_nick), (gst_format_get_details),
5149         (gst_format_iterate_definitions):
5150         * gst/gstformat.h:
5151         * gst/gstindex.c: (gst_index_gtype_resolver):
5152         * gst/gstinfo.c:
5153         * gst/gstinfo.h:
5154         * gst/gstmemchunk.c: (gst_mem_chunk_alloc), (gst_mem_chunk_alloc0),
5155         (gst_mem_chunk_free):
5156         * gst/gstobject.c: (gst_object_class_init), (gst_object_init),
5157         (gst_object_ref), (gst_object_unref), (gst_object_sink),
5158         (gst_object_replace), (gst_object_dispose), (gst_object_finalize),
5159         (gst_object_dispatch_properties_changed),
5160         (gst_object_set_name_default), (gst_object_set_name),
5161         (gst_object_get_name), (gst_object_set_name_prefix),
5162         (gst_object_get_name_prefix), (gst_object_set_parent),
5163         (gst_object_get_parent), (gst_object_unparent),
5164         (gst_object_check_uniqueness), (gst_object_save_thyself),
5165         (gst_object_restore_thyself), (gst_object_real_restore_thyself),
5166         (gst_object_set_property), (gst_object_get_property),
5167         (gst_object_get_path_string):
5168         * gst/gstobject.h:
5169         * gst/gstpad.c: (gst_pad_dispose), (gst_real_pad_class_init),
5170         (gst_real_pad_init), (gst_real_pad_get_property),
5171         (gst_pad_custom_new), (gst_pad_get_direction),
5172         (gst_pad_set_active), (gst_pad_is_active),
5173         (gst_pad_set_event_function), (gst_pad_is_linked),
5174         (gst_pad_link_free), (gst_pad_link_intersect),
5175         (gst_pad_link_fixate), (gst_pad_set_caps),
5176         (gst_pad_try_set_caps_nonfixed), (gst_pad_set_pad_template),
5177         (gst_pad_get_real_parent), (gst_pad_add_ghost_pad),
5178         (gst_pad_remove_ghost_pad), (_gst_pad_default_fixate_foreach),
5179         (gst_pad_link_unnegotiate), (gst_pad_proxy_fixate),
5180         (gst_pad_get_caps), (gst_pad_peer_get_caps),
5181         (gst_pad_get_pad_template_caps), (gst_pad_get_peer),
5182         (gst_pad_realize), (gst_pad_get_allowed_caps),
5183         (gst_real_pad_dispose), (gst_real_pad_finalize),
5184         (gst_pad_collectv), (gst_pad_collect_valist),
5185         (gst_pad_template_dispose), (gst_pad_template_new),
5186         (gst_pad_get_internal_links):
5187         * gst/gstpad.h:
5188         * gst/gstpipeline.c: (gst_pipeline_dispose),
5189         (gst_pipeline_change_state):
5190         * gst/gstpipeline.h:
5191         * gst/gstplugin.c:
5192         * gst/gstpluginfeature.c: (gst_plugin_feature_get_name),
5193         (gst_plugin_feature_set_rank), (gst_plugin_feature_get_rank):
5194         * gst/gstpluginfeature.h:
5195         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
5196         * gst/gstquery.c: (_gst_query_type_initialize),
5197         (gst_query_type_register), (gst_query_type_get_by_nick),
5198         (gst_query_type_get_details), (gst_query_type_iterate_definitions):
5199         * gst/gstquery.h:
5200         * gst/gstqueue.c: (gst_queue_link_sink), (gst_queue_link_src):
5201         * gst/gstscheduler.c: (gst_scheduler_add_element),
5202         (gst_scheduler_factory_create):
5203         * gst/gststructure.c: (gst_structure_set_parent_refcount),
5204         (gst_structure_free), (gst_structure_set_name),
5205         (gst_structure_id_set_value), (gst_structure_set_value),
5206         (gst_structure_set_valist), (gst_structure_remove_field),
5207         (gst_structure_remove_fields),
5208         (gst_structure_remove_fields_valist),
5209         (gst_structure_remove_all_fields), (gst_structure_foreach),
5210         (gst_structure_map_in_place),
5211         (gst_caps_structure_fixate_field_nearest_int),
5212         (gst_caps_structure_fixate_field_nearest_double):
5213         * gst/gststructure.h:
5214         * gst/gstsystemclock.c: (gst_system_clock_class_init),
5215         (gst_system_clock_init), (gst_system_clock_dispose),
5216         (gst_system_clock_async_thread),
5217         (gst_system_clock_id_wait_unlocked), (gst_system_clock_id_wait),
5218         (gst_system_clock_id_wait_async), (gst_system_clock_id_unschedule):
5219         * gst/gstsystemclock.h:
5220         * gst/gsttag.c: (gst_tag_list_add_value_internal),
5221         (gst_tag_list_copy_foreach), (structure_foreach_wrapper):
5222         * gst/gsttaginterface.c:
5223         * gst/gstthread.c: (gst_thread_dispose),
5224         (gst_thread_release_children_locks), (gst_thread_change_state),
5225         (gst_thread_main_loop):
5226         * gst/gsttrashstack.h:
5227         * gst/gsttypefind.c: (gst_type_find_factory_dispose):
5228         * gst/gsttypes.h:
5229         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
5230         (gst_element_request_pad), (gst_element_get_pad_from_template),
5231         (gst_element_request_compatible_pad),
5232         (gst_element_get_compatible_pad_filtered),
5233         (gst_element_get_compatible_pad), (gst_element_state_get_name),
5234         (gst_element_link_pads_filtered), (gst_element_link_filtered),
5235         (gst_element_link_many), (gst_element_link),
5236         (gst_element_link_pads), (gst_element_unlink_pads),
5237         (gst_element_unlink_many), (gst_element_unlink),
5238         (gst_pad_can_link_filtered), (gst_pad_can_link),
5239         (gst_pad_use_fixed_caps), (gst_pad_get_fixed_caps_func),
5240         (gst_object_default_error), (gst_bin_add_many),
5241         (gst_bin_remove_many), (gst_element_populate_std_props),
5242         (gst_element_class_install_std_props), (gst_buffer_merge),
5243         (gst_buffer_stamp), (intersect_caps_func), (gst_pad_proxy_getcaps),
5244         (link_fold_func), (gst_pad_proxy_setcaps):
5245         * gst/gstutils.h:
5246         * gst/gstvalue.c: (gst_value_deserialize_string):
5247         * gst/parse/grammar.y:
5248         * gst/schedulers/gstbasicscheduler.c:
5249         (gst_basic_scheduler_cothreaded_chain),
5250         (gst_basic_scheduler_chain_recursive_add),
5251         (gst_basic_scheduler_pad_link):
5252         * gst/schedulers/gstoptimalscheduler.c:
5253         (get_group_schedule_function),
5254         (gst_opt_scheduler_state_transition),
5255         (gst_opt_scheduler_add_element), (element_get_reachables_func):
5256         * libs/gst/bytestream/bytestream.c:
5257         * libs/gst/dataprotocol/dataprotocol.c:
5258         (gst_dp_header_from_buffer):
5259         * po/nb.po:
5260         * po/ru.po:
5261         * tests/threadstate/threadstate2.c: (eos):
5262         * tools/gst-compprep.c: (main):
5263         * tools/gst-inspect.c: (print_field), (print_element_flag_info),
5264         (print_pad_info), (print_children_info):
5265         * tools/gst-launch.c: (idle_func), (main):
5266         * tools/gst-md5sum.c: (idle_func), (main):
5267         * tools/gst-xmlinspect.c: (print_element_info):
5268         First THREADED backport attempt, focusing on adding locks and
5269         making sure the API is threadsafe. Needs more work. More docs
5270         follow this week.
5271
5272 2005-02-24  Andy Wingo  <wingo@pobox.com>
5273
5274         * tests/bench-complexity.scm:
5275         * tests/complexity.gnuplot: New files, good for running complexity
5276         benchmarks.
5277
5278         * tests/Makefile.am:
5279         * tests/complexity.c: New test, sets up N elements, at each level
5280         teeing into M streams per element. Eeeenteresting.
5281
5282         * tests/mass_elements.gnuplot: gnuplot file for the mass_elements
5283         benchmark. Run as gnuplot mass_elements.gnuplot > foo.ps, after
5284         running bench-mass_elements.scm.
5285
5286         * tests/bench-mass_elements.scm: New script, runs mass_elements
5287         for various numbers of identities, outputting the results to a
5288         file. Requires guile 1.6. Just for testing.
5289
5290 2005-02-23  Thomas Vander Stichele  <thomas at apestaart dot org>
5291
5292         * gst/schedulers/fairscheduler.c:
5293           compile with debug disabled
5294
5295 2005-02-22  Thomas Vander Stichele  <thomas at apestaart dot org>
5296
5297         * configure.ac:
5298           hunting season on 0.9 is now OPEN
5299
5300 2005-02-22  Stefan Kost  <ensonic@users.sf.net>
5301
5302         * docs/libs/tmpl/gstcontrol.sgml:
5303         * docs/libs/tmpl/gstdparam.sgml:
5304         * docs/libs/tmpl/gstdplinint.sgml:
5305         * docs/libs/tmpl/gstdpman.sgml:
5306         * docs/libs/tmpl/gstdpsmooth.sgml:
5307         * docs/libs/tmpl/gstunitconvert.sgml:
5308           more docs for the state of dparams
5309
5310 2005-02-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5311
5312         * gst/gstelementfactory.c: (gst_element_factory_create):
5313         * gst/gstobject.c: (gst_object_init),
5314         (gst_object_set_name_default), (gst_object_set_name):
5315           name objects by default, not in gst_element_factory_create. Allows
5316           using elements created with g_object_new. (fixes #167283)
5317
5318 2005-02-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5319
5320         * gst/gstinfo.c: (_gst_debug_init), (gst_debug_log_default):
5321           make the time that debugging functions print relative to when
5322           gst_init was called
5323
5324 2005-02-18  Tim-Philipp Müller  <tim at centricular dot net>
5325
5326         * gst/gsttaginterface.c:
5327           Fix inline docs: tag setter vararg functions are NULL-terminated,
5328           GST_TAG_INVALID doesn't exist any more.
5329
5330 2005-02-18  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5331
5332         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_dump_byte_array):
5333         Allocate the 1 byte more memory that was forgotten!!!!!
5334         fixes memory corruption on 64bit platforms
5335
5336 2005-02-15  Stefan Kost  <ensonic@users.sf.net>
5337
5338         * docs/pwg/building-pads.xml:
5339         * docs/pwg/intro-basics.xml:
5340           fixed a few typos, relabeled introductionary list of types
5341         * docs/random/ensonic/dparams.txt:
5342           more notes abut dparam changes
5343         * libs/gst/control/dparam.c: (gst_dparam_attach):
5344         * libs/gst/control/dparammanager.c:
5345         * libs/gst/control/dparammanager.h:
5346           - many comments and notes on dparam implementation
5347           - new dparams are were not initialized to the default value
5348             from param spec
5349
5350 2005-02-14  Thomas Vander Stichele  <thomas at apestaart dot org>
5351
5352         submitted by: Peter Astakhov
5353
5354         * po/LINGUAS:
5355         * po/ru.po:
5356           adding Russian translation
5357
5358 2005-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
5359
5360         * configure.ac:
5361         * docs/gst/Makefile.am:
5362         * docs/libs/Makefile.am:
5363           make sure popt is added to gtk-doc flags.  Fixes #147782.
5364
5365 2005-02-09  Tim-Philipp Müller  <tim at centricular dot net>
5366
5367         * docs/faq/using.xml:
5368           Fix typo in FAQ (artssink => artsdsink)
5369
5370 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5371
5372         * tools/gst-launch.1.in:
5373           Fix typo (#166699).
5374
5375 2005-02-08  Tim-Philipp Müller  <tim at centricular dot net>
5376
5377         * docs/faq/using.xml:
5378           Add -v argument to fakesrc/fakesink gst-launch line,
5379           so that the promised output will actually show up.
5380
5381 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5382
5383         * gst/gstthread.c: (gst_thread_change_state):
5384           Implement state-change error handling (#166073).
5385
5386 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5387
5388         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
5389           Release interrupt after handling (#166250).
5390
5391 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
5392
5393         * configure.ac:
5394           back to HEAD
5395
5396 === release 0.8.9 ===
5397
5398 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
5399
5400         * NEWS:
5401         * RELEASE:
5402         * configure.ac:
5403           releasing 0.8.9, "Like Eating Glass"
5404
5405 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
5406
5407         submitted by: Clytie Siddall
5408
5409         * po/vi.po: Added Vietnamese translation
5410
5411 2005-02-07  Thomas Vander Stichele  <thomas at apestaart dot org>
5412
5413         patch by: Tim Philipp-Müller
5414
5415         * configure.ac:
5416         * gst/gstpad.c:
5417           unref data when probe function returns FALSE.  Fixes #166362
5418
5419 2005-02-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5420
5421         * gst/gst.c: (gst_init_get_popt_table):
5422           Fix typo (#166269).
5423
5424 2005-02-04  Andy Wingo  <wingo@pobox.com>
5425
5426         * gst/gstelement.c (gst_element_get_compatible_pad_template): Fix
5427         the debugging on whether the caps are compatible.
5428
5429 2005-02-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5430
5431         * docs/manual/basics-elements.xml:
5432           Fix two typos.
5433
5434 2005-02-02  Wim Taymans  <wim@fluendo.com>
5435
5436         * gst/schedulers/gstoptimalscheduler.c: (remove_decoupled),
5437         (schedule_chain), (get_invalid_call), (chain_invalid_call),
5438         (loop_group_schedule_function), (gst_opt_scheduler_iterate):
5439         Remove some FIXMEs after analysing and commenting why they
5440         are not issues.
5441
5442 2005-02-02  Wim Taymans  <wim@fluendo.com>
5443
5444         * gst/schedulers/gstoptimalscheduler.c:
5445         (gst_opt_scheduler_class_init), (gst_opt_scheduler_init),
5446         (gst_opt_scheduler_finalize), (remove_decoupled), (schedule_chain),
5447         (get_invalid_call), (chain_invalid_call),
5448         (get_group_schedule_function), (loop_group_schedule_function),
5449         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
5450         (gst_opt_scheduler_state_transition),
5451         (gst_opt_scheduler_add_element),
5452         (gst_opt_scheduler_remove_element), (gst_opt_scheduler_interrupt),
5453         (gst_opt_scheduler_error), (gst_opt_scheduler_pad_link),
5454         (gst_opt_scheduler_pad_unlink), (gst_opt_scheduler_iterate),
5455         (gst_opt_scheduler_show):
5456         Added lock to protect scheduler data structures.
5457
5458 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5459
5460         * testsuite/threads/threadi.c: (cb_data):
5461           Fix buglet in test.
5462
5463 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5464
5465         * testsuite/threads/Makefile.am:
5466         * testsuite/threads/threadi.c: (cb_data), (cb_play), (main):
5467           On Wim's request, split the test in three separately-compiled
5468           tests that each test a very specific bug. Two of them still fail,
5469           will create bugs for those. threadi.c indicates why they fail.
5470
5471 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5472
5473         * gst/schedulers/gstoptimalscheduler.c:
5474         (get_group_schedule_function):
5475           Try to work with the threading mess that queue_link is.
5476
5477 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5478
5479         * gst/gstbin.c: (gst_bin_remove_func):
5480           Explicitely make an element release locks in a group when being
5481           remove from a bin.
5482         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
5483           If there's no scheduler, always return immediately (similar to
5484           gst_element_interrupt).
5485
5486 2005-01-31  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5487
5488         * gst/gstbin.c: (gst_bin_child_state_change_func):
5489           Remove a piece of code that could never be reached.
5490         * docs/gst/gstreamer-sections.txt:
5491         * gst/gstpad.c: (gst_pad_push), (gst_pad_pull),
5492         (gst_pad_call_get_function):
5493         * gst/gstpad.h:
5494         * testsuite/pad/Makefile.am:
5495           Fix #150546, enable tests.
5496
5497 2005-01-31  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5498
5499         * docs/pwg/advanced-types.xml:
5500           Fix description for buffer-frames=0.
5501         * docs/gst/tmpl/gstbin.sgml:
5502         * gst/gstbin.c: (gst_bin_child_state_change_func),
5503         (gst_bin_change_state), (gst_bin_change_state_norecurse):
5504         * gst/gstbin.h:
5505         * testsuite/threads/Makefile.am:
5506         * testsuite/threads/threadi.c: (cb_timeout), (cb_quit), (cb_eos),
5507         (cb_state), (cb_play), (main):
5508           Fix non-recursive state changes to *really* change the state
5509           of the object, and not just call parent_class->state_change.
5510           Fix a lot of lockups caused by this. Fixes #132775. Add test
5511           for the problem. Also enable test to show #142588 (fixed).
5512         * gst/gstthread.c: (gst_thread_change_state),
5513         (gst_thread_child_state_change):
5514           Don't exit the thread if we go to NULL and are inside thread
5515           context. Instead, return control to the main thread context
5516           and exit from there.
5517         * gst/gstelement.c: (gst_element_disable_threadsafe_properties):
5518           Don't unset virtual functions, since those may still be used.
5519           That's not necessarily correct, but suffices for now.
5520         * configure.ac:
5521         * testsuite/Makefile.am:
5522         * testsuite/pad/Makefile.am:
5523         * testsuite/pad/chainnopull.c: (gst_test_sink_class_init),
5524         (gst_test_sink_base_init), (gst_test_sink_chain),
5525         (gst_test_sink_init), (main):
5526         * testsuite/pad/getnopush.c: (gst_test_src_class_init),
5527         (gst_test_src_base_init), (gst_test_src_get), (gst_test_src_init),
5528         (main):
5529         * testsuite/pad/link.c: (gst_test_element_class_init),
5530         (gst_test_element_base_init), (gst_test_src_get),
5531         (gst_test_src_loop), (gst_test_src_init), (gst_test_filter_chain),
5532         (gst_test_filter_loop), (gst_test_filter_init),
5533         (gst_test_sink_chain), (gst_test_sink_loop), (gst_test_sink_init),
5534         (cb_error), (main):
5535           Add tests to show #150546. Pass, but should fail (currently
5536           disabled from the testsuite).
5537         * gst/gstscheduler.c: (gst_scheduler_dispose):
5538           Dereference child schedulers on dispose (#94464).
5539         * testsuite/bytestream/filepadsink.c: (gst_fp_sink_init):
5540           Fix typo.
5541         * testsuite/threads/thread.c: (main):
5542           Add more debug.
5543
5544 2005-01-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5545
5546         * gst/gstpad.c: (gst_pad_push):
5547           Oops, revert previous commit, broke testsuite...
5548
5549 2005-01-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5550
5551         * gst/gstpad.c: (gst_pad_push):
5552           Add check that the pad on which the push is performed is not a
5553           get-based pad (#150546).
5554
5555 2005-01-28  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5556
5557         * gst/elements/gsttypefindelement.c:
5558         (gst_type_find_element_handle_event):
5559           Fix buffer pushing if stream EOSes during typefinding.
5560
5561 2005-01-28  Edward Hervey  <bilboed@bilboed.com>
5562
5563         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5564
5565         * gst/gstvalue.c: (gst_string_wrap):
5566           Allow NULL-strings as argument (#165365).
5567
5568 2005-01-27  Stephane Wirtel  <stephane.wirtel@belgacom.net>
5569
5570         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5571
5572         * gst/schedulers/faircothreads.c:
5573         (gst_fair_scheduler_cothread_queue_show):
5574           Fix build without debug enabled.
5575
5576 2005-01-26  Stefan Kost  <ensonic@users.sf.net>
5577
5578         * docs/gst/gstreamer-sections.txt:
5579         * docs/libs/gstreamer-libs-docs.sgml:
5580         * docs/libs/gstreamer-libs-sections.txt:
5581         * docs/libs/tmpl/gstcontrol.sgml:
5582         * docs/libs/tmpl/gstdparam.sgml:
5583         * docs/libs/tmpl/gstdplinint.sgml:
5584         * docs/libs/tmpl/gstdpman.sgml:
5585         * docs/libs/tmpl/gstdpsmooth.sgml:
5586         * docs/libs/tmpl/gstputbits.sgml:
5587         * docs/libs/tmpl/gstunitconvert.sgml:
5588         * libs/gst/control/dparam.c:
5589         * libs/gst/control/dparam.h:
5590         * libs/gst/control/dparammanager.c:
5591         (gst_dpman_add_required_dparam_callback),
5592         (gst_dpman_add_required_dparam_direct),
5593         (gst_dpman_add_required_dparam_array),
5594         (gst_dpman_remove_required_dparam), (gst_dpman_attach_dparam),
5595         (gst_dpman_get_dparam), (gst_dpman_get_dparam_type),
5596         (gst_dpman_get_manager)
5597           restructured DParam docs
5598
5599 2005-01-25  Tim-Philipp Müller  <tim at centricular dot net>
5600
5601         * gst-element-check.m4:
5602           Only check for gst-inspect if we haven't already
5603           found it in previous element check runs
5604
5605 2005-01-25  Stefan Kost  <ensonic@users.sf.net>
5606
5607         * docs/gst/Makefile.am:
5608         * docs/libs/Makefile.am:
5609           fixed install rules to treat style.css as optional
5610
5611 2005-01-24  Stefan Kost  <ensonic@users.sf.net>
5612
5613         * docs/gst/Makefile.am:
5614         * docs/libs/Makefile.am:
5615           install style.css along with docs
5616         * docs/gst/tmpl/gstbin.sgml:
5617         * docs/gst/tmpl/gstclock.sgml:
5618         * docs/gst/tmpl/gstdata.sgml:
5619         * docs/gst/tmpl/gstelement.sgml:
5620         * gst/gstbin.h:
5621         * gst/gstelement.c: (gst_element_class_init):
5622         * gst/gstelement.h:
5623           fixing incomplete docs
5624
5625 2005-01-24  Tim-Philipp Müller  <tim at centricular dot net>
5626
5627         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
5628           Don't unref seek event twice when fflush() fails
5629           
5630 2005-01-22  David Schleef  <ds@schleef.org>
5631
5632         * configure.ac: Add --disable-valgrind. (partial fix for #164890)
5633
5634 2005-01-21  Stefan Kost  <ensonic@users.sf.net>
5635
5636         * docs/gst/Makefile.am:
5637         * docs/libs/Makefile.am:
5638           added params for deprecation guards
5639         * gst/gst.c:
5640         * gst/gst.h:
5641         * gst/gsterror.c: (_gst_resource_errors_init),
5642         (_gst_stream_errors_init):
5643         * gst/gsterror.h:
5644           documented some more enums
5645
5646 2005-01-19  Jan Schmidt  <thaytan@mad.scientist.com>
5647         * gst/autoplug/gstspideridentity.c:
5648         Cosmetic fix - spider_find_peek should be static
5649         * gst/parse/parse.l:
5650         Applying fix for #164261
5651
5652 2005-01-18  Stefan Kost  <ensonic@users.sf.net>
5653
5654         * docs/gst/gstreamer-sections.txt:
5655         * docs/gst/tmpl/gstplugin.sgml:
5656         * docs/libs/gstreamer-libs-sections.txt:
5657         * docs/libs/tmpl/gstcontrol.sgml:
5658         * gst/gstbuffer.h:
5659         * gst/gsttag.h:
5660         * gst/gstvalue.c:
5661           added docs for the TAG defines
5662
5663 2005-01-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5664
5665         * gst/schedulers/gstoptimalscheduler.c: (schedule_group):
5666           Only unref entry if there is an entry.
5667
5668 2005-01-17  Wim Taymans  <wim@fluendo.com>
5669
5670         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5671         (remove_from_group), (schedule_group), (normalize_group),
5672         (gst_opt_scheduler_iterate):
5673         Also ref/unref decoupled elements before iterating the
5674         group since they are not added to the list of elements.
5675
5676 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5677
5678         * docs/manual/highlevel-components.xml:
5679           Add subtitle/streamselection as new features to playbin.
5680
5681 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5682
5683         * docs/manual/manual.xml:
5684           Re-enable dataaccess docs (oops).
5685
5686 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5687
5688         * docs/pwg/advanced-types.xml:
5689         * docs/random/mimetypes:
5690           Add documentation on libsndfile types (#163309), by Steve Baker
5691           <steve@stevebaker.org>.
5692         * gst/gstelement.c: (gst_element_release_request_pad):
5693           If an element has no explicit function, just remove the pad.
5694
5695 2005-01-17  Luca Ognibene  <luogni@tin.it>
5696
5697         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5698
5699         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load):
5700           Fix memleak (#163801).
5701
5702 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5703
5704         * gst/elements/gsttee.c: (gst_tee_getcaps), (gst_tee_link):
5705           I think this is actually more correct...
5706
5707 2005-01-16  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5708
5709         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
5710           Another workaround for memory access while destroyed in callback.
5711           Please, someone with refcount knowledge, have a look at this.
5712
5713 2005-01-15  Thomas Vander Stichele  <thomas at apestaart dot org>
5714
5715         * docs/faq/faq.xml:
5716         * docs/faq/legal.xml:
5717           move the legal Q&A here
5718
5719 2005-01-14  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5720
5721         * gst/elements/gsttee.c: (gst_tee_getcaps), (gst_tee_link),
5722         (gst_tee_request_new_pad):
5723           Fix negotiation.
5724
5725 2005-01-14  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
5726
5727         * docs/random/omega/caps2:
5728         * testsuite/caps/caps_strings:
5729           replace framerate aproximations by their real value
5730           (24000/1001, 30000/1001, 60000/1001)
5731           Partially fixes bug #164049
5732
5733 2005-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
5734
5735         * docs/gst/Makefile.am:
5736           don't fail on the stupid GstPoptOption
5737
5738 2005-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
5739
5740         * gst/gstpad.h:
5741         * gst/gstprobe.c:
5742           allow probes to work on ghost pads by realizing the pad
5743           probe debugging
5744
5745 2005-01-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5746
5747         * docs/gst/gstreamer-sections.txt:
5748         * docs/gst/tmpl/gstpad.sgml:
5749         * gst/gstpad.c: (gst_pad_set_active_recursive):
5750         * gst/gstpad.h:
5751           Add gst_pad_set_active_recursive().
5752
5753 2005-01-10  Thomas Vander Stichele  <thomas at apestaart dot org>
5754
5755         * docs/random/release:
5756           updates
5757         * gst/gst_private.h:
5758         * gst/gstinfo.c:
5759         * gst/gstobject.c:
5760           move deep_notify logging to a new category
5761         * gst/gstprobe.c:
5762         * gst/gstprobe.h:
5763           add stuff so bindings can wrap probes
5764
5765 2005-01-09  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
5766
5767         * gst/gstplugin.c: (gst_plugin_load):
5768           Fix plugin loading if plugin/lib was already loaded. Fixes
5769           #163383
5770
5771 2005-01-09  Sebastien Cote  <sc5@hermes.usherb.ca>
5772
5773         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5774
5775         * gst/gstpluginfeature.c: (gst_plugin_feature_ensure_loaded):
5776           Protect plugin loading by a mutex so it's threadsafe. Fixes
5777           #163234.
5778
5779 2005-01-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5780
5781         * gst/gstevent.c: (_gst_event_copy):
5782           Reference source object when copying events, since it'll be
5783           dereferenced on event dereferencing as well.
5784
5785 2005-01-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5786
5787         * docs/gst/gstreamer-sections.txt:
5788         * docs/gst/tmpl/gstevent.sgml:
5789         * gst/gstevent.c: (gst_event_new_filler_stamped),
5790         (gst_event_filler_get_duration):
5791         * gst/gstevent.h:
5792           Add two new functions for filler events (which are used to
5793           synchronize streams if one of them is not having any data
5794           for a while) without interrupting the actual data-stream.
5795           Basically a no-op.
5796         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
5797         (gst_queue_link_sink), (gst_queue_link_src),
5798         (gst_queue_change_state):
5799           Allow for renegotiation while filled. Required for stream
5800           switching while playing.
5801
5802 2005-01-08  Benjamin Otte  <otte@gnome.org>
5803
5804         * gst/gstelement.c: (gst_element_link_many):
5805           fix up g_return_if_fail's
5806         * po/LINGUAS:
5807         * po/de.po:
5808           add German translation, that was somehow not included
5809
5810 2005-01-08  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
5811
5812         * docs/random/mimetypes:
5813           add 2 more 4CC code for DV (HDTV and SDTV-LongPlay profiles)
5814           do not add them to riff-lib as they are not common
5815
5816 2005-01-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5817
5818         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
5819           Check for existence of probe after performing the probe before
5820           re-accessing it to prevent segfaults caused by removal of the
5821           probe in the callback.
5822
5823 2005-01-05  David Schleef  <ds@schleef.org>
5824
5825         * testsuite/registry/Makefile.am:
5826         * testsuite/registry/gst-print-formats.c:
5827         (print_pad_templates_info), (print_element_list),
5828         (print_typefind_list), (list_sort_func), (get_typefind_mime_list),
5829         (g_list_uniqify), (get_pad_templates_info),
5830         (get_element_mime_list), (print_mime_list), (main): A little
5831         program that looks through the registry to find elements of
5832         a given type.  Not particularly interesting as a test, except
5833         that there's no other test covering the same area.
5834
5835 2005-01-05  David Schleef  <ds@schleef.org>
5836
5837         * tools/gst-launch.c: (idle_func), (fault_handler_sighandler),
5838         (fault_handler_sigaction), (fault_spin),
5839         (sigint_handler_sighandler), (play_handler), (main): Fix deadlocks
5840         in signal.h-type signal handlers by not calling forbidden functions,
5841         including gst_element_set_state().
5842
5843 2005-01-05  David Schleef  <ds@schleef.org>
5844
5845         * gst/gstvalue.h: Mark _gst_reserved[] as private
5846
5847 2005-01-05  David Schleef  <ds@schleef.org>
5848
5849         * gst/gstvalue.c: Fix doc build problem.
5850
5851 2005-01-05  David Schleef  <ds@schleef.org>
5852
5853         * gst/gstvalue.c: Add some documentation
5854
5855 2005-01-05  Stefan Kost  <ensonic@users.sf.net>
5856
5857         * docs/README:
5858           another shell oneliner for empty return value docs
5859         * gst/gstcaps.c:
5860         * gst/gstvalue.c:
5861         * libs/gst/control/dparam.c:
5862           more doc fixes (parameters and return values)
5863
5864 2005-01-05  Vincent Torri  <torri@iecn.u-nancy.fr>
5865
5866         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5867
5868         * gst/gstregistry.h:
5869         * gst/registries/gstxmlregistry.c:
5870           Fix macro's for Mingw (fixes #162276).
5871
5872 2005-01-04  Stefan Kost  <ensonic@users.sf.net>
5873
5874         * docs/README:
5875           quick shell oneliner to find undocumented members
5876         * docs/gst/tmpl/gstplugin.sgml:
5877         * docs/gst/tmpl/gstscheduler.sgml:
5878         * docs/gst/tmpl/gstthread.sgml:
5879           more enumtypes cleanup
5880         * gst/gsterror.h:
5881           activated documentation comments, now someone needs to document
5882           the enums :(
5883
5884 2005-01-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5885
5886         * docs/manual/manual.xml:
5887           Add dataaccess part (doh!).
5888
5889 2005-01-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5890
5891         * docs/manual/advanced-autoplugging.xml:
5892           Fix typo (intiate -> initiate).
5893
5894 2005-01-02  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5895
5896         * docs/random/bbb/streamselection:
5897           Add some notes on how to handle multi-subtitle/-audio streams.
5898
5899 2004-12-30  Stefan Kost  <ensonic@users.sf.net>
5900
5901         * docs/gst/gstreamer-docs.sgml:
5902         * docs/gst/gstreamer-sections.txt:
5903         * docs/gst/tmpl/gstenumtypes.sgml:
5904         * docs/gst/tmpl/gsterror.sgml:
5905         * docs/gst/tmpl/gstevent.sgml:
5906         * docs/gst/tmpl/gstpad.sgml:
5907         * docs/gst/tmpl/gstpadtemplate.sgml:
5908         * docs/gst/tmpl/gstthread.sgml:
5909           removed gstenumtypes section from docs and put all the enums into
5910           their sections
5911
5912 2004-12-27  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
5913
5914         * gst/gstplugin.c:
5915           document gst_library_load a bit more (riff special case + return
5916           value if already loaded)
5917         * testsuite/bytestream/filepadsink.c:
5918           plugin name is 'gstbytestream', not 'bytestream'
5919
5920 2004-12-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5921
5922         * docs/random/bbb/subtitles:
5923           Add some first mind rumblings on proper subtitle support.
5924
5925 2004-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
5926
5927         * po/ca.po:
5928         * po/sv.po:
5929           updated translations
5930
5931 2004-12-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5932
5933         * docs/manual/advanced-dataaccess.xml:
5934           Add section on how to use fakesrc/fakesink/identity in your
5935           application, plus section on how to embed plugins. Also mention
5936           probes.
5937         * docs/manual/appendix-checklist.xml:
5938         * docs/manual/appendix-debugging.xml:
5939         * docs/manual/appendix-gnome.xml:
5940         * docs/manual/appendix-integration.xml:
5941           Debug -> checklist, GNOME -> integration, add sections on Linux,
5942           KDE integration and add other things useful for application
5943           development.
5944         * docs/manual/manual.xml:
5945           Remove some fixmes, update some file pointers.
5946         * docs/pwg/appendix-checklist.xml:
5947           Fix typo.
5948         * docs/pwg/building-boiler.xml:
5949           Remove ugly header and add commented fixme.
5950         * docs/pwg/pwg.xml:
5951           Add fixme.
5952         * examples/manual/Makefile.am:
5953           Add example for added docs.
5954
5955 2004-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
5956
5957         * configure.ac:
5958           back to HEAD
5959
5960 === release 0.8.8 ===
5961
5962 2004-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
5963
5964         * NEWS:
5965         * RELEASE:
5966         * configure.ac:
5967           Releasing 0.8.8, "I'll Take Care Of You"
5968
5969 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
5970
5971         * configure.ac:
5972           second prerelease
5973
5974 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
5975
5976         patch by: Wim Taymans
5977
5978         * gst/gstbin.c:
5979           Fix for #159852 - make iterate emission threadsafe
5980
5981 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
5982
5983         * docs/faq/cvs.xml:
5984           notes about new fdo account request
5985
5986 2004-12-20  Stefan Kost  <ensonic@users.sf.net>
5987
5988         * docs/gst/gstreamer-docs.sgml:
5989         * docs/gst/tmpl/gstenumtypes.sgml:
5990         * docs/gst/tmpl/gstplugin.sgml:
5991         * docs/libs/gstreamer-libs-docs.sgml:
5992           Added missing short docs. Added ids for navigation.
5993
5994 2004-12-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5995
5996         * docs/manual/advanced-autoplugging.xml:
5997         * docs/manual/advanced-schedulers.xml:
5998         * docs/manual/advanced-threads.xml:
5999           Rewrites. Remove cothreads, go a bit into opt specifically,
6000           document threads and their gotchas, and do some technical stuff
6001           on autoplugging plus add some working examples. Fixes #157395.
6002         * examples/manual/Makefile.am:
6003           Add typefind/autoplugger example (one that actually works).
6004           Remove queue example since it's a duplicate of the thread one.
6005
6006 2004-12-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6007
6008         * gst/gstvalue.c: (gst_value_deserialize_string):
6009           use deprecated g_value_set_string_take_ownership to keep compatible
6010           with glib 2.2
6011
6012 2004-12-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6013
6014         * gst/gstvalue.c: (gst_value_deserialize_string):
6015           revert last patch, only dom a g_utf8_validate now before accepting
6016           the string - caps parsing strips " from strings so we can't rely on
6017           them
6018         * testsuite/caps/value_serialize.c: (test_string_deserialization):
6019           disable a test that tested the above and comment it
6020
6021 2004-12-16  Steve Lhomme <steve.lhomme@free.fr>
6022
6023         Patch reviewed by David Schleef  <ds@schleef.org>
6024
6025         * win32/gstenumtypes.c: Update from gst/gstenumtypes.c (See
6026         bug #153882)
6027         * win32/gstenumtypes.h: same
6028
6029 2004-12-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6030
6031         * gst/gstpad.c: (gst_pad_query):
6032           Do query on realized pad, similar to how convert/send_event handle
6033           this. Also makes sense, since this pad belongs to the function to
6034           which this query will be sent. Fixes #158163.
6035
6036 2004-12-16  Christian Fredrik Kalager Schaller  <uraeus@gnome.org>
6037
6038         * docs/manual/appendix-programs.xml: fix pipeline to actually work
6039
6040 2004-12-16  Christian Fredrik Kalager Schaller  <christian@fluendo.com>
6041
6042         * docs/faq/general.xml: fix pipeline to actually work
6043
6044 2004-12-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6045
6046         * gst/gstvalue.c: (gst_value_deserialize_string):
6047           check that a simple string that gets deserialized does not contain
6048           invalid characters
6049         * testsuite/caps/value_serialize.c: (test_string_deserialization):
6050           remove a test that tested a wring behaviour
6051
6052 2004-12-16  Matt Kraai  <kraai@alumni.cmu.edu>
6053
6054         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6055
6056         * docs/manual/intro-motivation.xml:
6057           Fix typos.
6058
6059 2004-12-16  Edward Hervey  <bilboed@bilboed.com>
6060
6061         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6062
6063         * docs/gst/tmpl/gstprobe.sgml:
6064           Fix documentation of probe callback - it is supposed to return
6065           FALSE, not TRUE, to remove data from the stream (#159087).
6066
6067 2004-12-16  Daniel Gazard  <dany42@free.fr>
6068
6069         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6070
6071         * gst/gstelementfactory.c: (gst_element_factory_create):
6072           Fix compile failure if compiling without libxml2 support (#149936).
6073
6074 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6075
6076         * docs/manual/advanced-autoplugging.xml:
6077         * docs/manual/highlevel-components.xml:
6078           Move spider from autoplugging to components. Autoplugging is for
6079           internals, not for solutions. ;-).
6080
6081 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6082
6083         * docs/random/ds/0.9-suggested-changes:
6084           Make note on device/location/uri property names.
6085
6086 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6087
6088         * docs/manual/advanced-autoplugging.xml:
6089         * docs/manual/advanced-clocks.xml:
6090         * docs/manual/advanced-interfaces.xml:
6091         * docs/manual/advanced-metadata.xml:
6092         * docs/manual/advanced-position.xml:
6093         * docs/manual/advanced-schedulers.xml:
6094         * docs/manual/advanced-threads.xml:
6095         * docs/manual/appendix-gnome.xml:
6096         * docs/manual/appendix-programs.xml:
6097         * docs/manual/appendix-quotes.xml:
6098         * docs/manual/autoplugging.xml:
6099         * docs/manual/basics-bins.xml:
6100         * docs/manual/basics-data.xml:
6101         * docs/manual/basics-elements.xml:
6102         * docs/manual/basics-helloworld.xml:
6103         * docs/manual/basics-init.xml:
6104         * docs/manual/basics-pads.xml:
6105         * docs/manual/basics-plugins.xml:
6106         * docs/manual/bins-api.xml:
6107         * docs/manual/bins.xml:
6108         * docs/manual/buffers-api.xml:
6109         * docs/manual/buffers.xml:
6110         * docs/manual/clocks.xml:
6111         * docs/manual/components.xml:
6112         * docs/manual/cothreads.xml:
6113         * docs/manual/debugging.xml:
6114         * docs/manual/dparams-app.xml:
6115         * docs/manual/dynamic.xml:
6116         * docs/manual/elements-api.xml:
6117         * docs/manual/elements.xml:
6118         * docs/manual/factories.xml:
6119         * docs/manual/gnome.xml:
6120         * docs/manual/goals.xml:
6121         * docs/manual/helloworld.xml:
6122         * docs/manual/helloworld2.xml:
6123         * docs/manual/highlevel-components.xml:
6124         * docs/manual/highlevel-xml.xml:
6125         * docs/manual/init-api.xml:
6126         * docs/manual/intro-basics.xml:
6127         * docs/manual/intro-motivation.xml:
6128         * docs/manual/intro-preface.xml:
6129         * docs/manual/intro.xml:
6130         * docs/manual/links-api.xml:
6131         * docs/manual/links.xml:
6132         * docs/manual/manual.xml:
6133         * docs/manual/motivation.xml:
6134         * docs/manual/pads-api.xml:
6135         * docs/manual/pads.xml:
6136         * docs/manual/plugins-api.xml:
6137         * docs/manual/plugins.xml:
6138         * docs/manual/programs.xml:
6139         * docs/manual/queues.xml:
6140         * docs/manual/quotes.xml:
6141         * docs/manual/schedulers.xml:
6142         * docs/manual/states-api.xml:
6143         * docs/manual/states.xml:
6144         * docs/manual/threads.xml:
6145         * docs/manual/typedetection.xml:
6146         * docs/manual/win32.xml:
6147         * docs/manual/xml.xml:
6148           Try 2. This time, include a short preface as a "general
6149           introduction", also add code blocks around all code samples
6150           so they get compiled. We still need a way to tell readers
6151           the filename of the code sample. In some cases, don't show
6152           all code in the documentation, but do include it in the generated
6153           code. This allows for focussing on specific bits in the docs,
6154           while still having a full test application available.
6155         * examples/manual/Makefile.am:
6156           Fix up examples for new ADM. Add several of the new examples that
6157           were either added or were missing from the build system.
6158         * examples/manual/extract.pl:
6159           Allow nameless blocks.
6160
6161 2004-12-15  Thomas Vander Stichele  <thomas at apestaart dot org>
6162
6163         * docs/manual/elements-api.xml:
6164         * docs/manual/helloworld.xml:
6165         * examples/manual/extract.pl:
6166           fix last example.  Add example of adding code blocks that are not
6167           shown in docbook output.
6168
6169 2004-12-15  Thomas Vander Stichele  <thomas at apestaart dot org>
6170
6171         * docs/manual/dynamic.xml:
6172         * docs/manual/elements-api.xml:
6173         * docs/manual/gnome.xml:
6174         * docs/manual/helloworld2.xml:
6175         * docs/manual/init-api.xml:
6176         * docs/manual/queues.xml:
6177         * docs/manual/threads.xml:
6178         * docs/manual/xml.xml:
6179         * examples/manual/extract.pl:
6180           Make it possible to extract example code from separate blocks.
6181           Should make Ronald happy.
6182
6183 2004-12-15  Wim Taymans  <wim@fluendo.com>
6184
6185         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
6186         (remove_from_group), (group_elements_set_visited),
6187         (normalize_group), (gst_opt_scheduler_iterate):
6188         Fix bug where a flag was not updated on a decoupled entry point 
6189         because we were just checking the group element list and decoupled
6190         elements are not in that list..
6191
6192 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6193
6194         * docs/manual/advanced-autoplugging.xml:
6195         * docs/manual/advanced-clocks.xml:
6196         * docs/manual/advanced-dparams.xml:
6197         * docs/manual/advanced-interfaces.xml:
6198         * docs/manual/advanced-metadata.xml:
6199         * docs/manual/advanced-position.xml:
6200         * docs/manual/advanced-schedulers.xml:
6201         * docs/manual/advanced-threads.xml:
6202         * docs/manual/appendix-debugging.xml:
6203         * docs/manual/appendix-gnome.xml:
6204         * docs/manual/appendix-programs.xml:
6205         * docs/manual/appendix-quotes.xml:
6206         * docs/manual/appendix-win32.xml:
6207         * docs/manual/autoplugging.xml:
6208         * docs/manual/basics-bins.xml:
6209         * docs/manual/basics-data.xml:
6210         * docs/manual/basics-elements.xml:
6211         * docs/manual/basics-helloworld.xml:
6212         * docs/manual/basics-init.xml:
6213         * docs/manual/basics-pads.xml:
6214         * docs/manual/basics-plugins.xml:
6215         * docs/manual/bins-api.xml:
6216         * docs/manual/bins.xml:
6217         * docs/manual/buffers-api.xml:
6218         * docs/manual/buffers.xml:
6219         * docs/manual/clocks.xml:
6220         * docs/manual/components.xml:
6221         * docs/manual/cothreads.xml:
6222         * docs/manual/debugging.xml:
6223         * docs/manual/dparams-app.xml:
6224         * docs/manual/dynamic.xml:
6225         * docs/manual/elements-api.xml:
6226         * docs/manual/elements.xml:
6227         * docs/manual/factories.xml:
6228         * docs/manual/gnome.xml:
6229         * docs/manual/goals.xml:
6230         * docs/manual/helloworld.xml:
6231         * docs/manual/helloworld2.xml:
6232         * docs/manual/highlevel-components.xml:
6233         * docs/manual/highlevel-xml.xml:
6234         * docs/manual/init-api.xml:
6235         * docs/manual/intro-motivation.xml:
6236         * docs/manual/intro-preface.xml:
6237         * docs/manual/intro.xml:
6238         * docs/manual/links-api.xml:
6239         * docs/manual/links.xml:
6240         * docs/manual/manual.xml:
6241         * docs/manual/motivation.xml:
6242         * docs/manual/pads-api.xml:
6243         * docs/manual/pads.xml:
6244         * docs/manual/plugins-api.xml:
6245         * docs/manual/plugins.xml:
6246         * docs/manual/programs.xml:
6247         * docs/manual/queues.xml:
6248         * docs/manual/quotes.xml:
6249         * docs/manual/schedulers.xml:
6250         * docs/manual/states-api.xml:
6251         * docs/manual/states.xml:
6252         * docs/manual/threads.xml:
6253         * docs/manual/typedetection.xml:
6254         * docs/manual/win32.xml:
6255         * docs/manual/xml.xml:
6256           First try at rewriting the ADM. Needs lotsamore work, but some
6257           parts might already be somewhat useful.
6258         * docs/pwg/advanced-interfaces.xml:
6259           Remove properties interface, it never actually existed (except for
6260           on my HD...).
6261
6262 2004-12-13  David Schleef  <ds@schleef.org>
6263
6264         * gst/gstpad.c: (gst_pad_set_explicit_caps): Allow caps to
6265         be NULL (bug #160220).
6266
6267 2004-12-13  David Schleef  <ds@schleef.org>
6268
6269         * configure.ac: remove all mmx stuff, because it's not used.
6270         * docs/random/ds/0.9-suggested-changes: additional notes
6271         * include/Makefile.am: we don't use these anymore
6272         * include/mmx.h: remove
6273         * include/sse.h: remove
6274
6275 2004-12-13  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
6276
6277         * docs/random/mimetypes:
6278           Add FOURCC code for h264 codec (VSSH)
6279           Add alternate FOURCC codes for h263 related codecs
6280
6281 2004-12-10  Stefan Kost  <ensonic@users.sf.net>
6282
6283         * docs/manual/programs.xml:
6284           Added more gst-launch examples.
6285
6286 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6287
6288         * gst/gstqueue.c: (gst_queue_handle_src_query):
6289           Check for availability again.
6290
6291 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6292
6293         * gst/gstcaps.c: (gst_caps_compare_structures):
6294           Simple caps go first. This has the nice side-effect of fixing an
6295           obscure warning.
6296
6297 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6298
6299         * gst/gstversion.h.in:
6300           Protect header.
6301
6302 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6303
6304         * gst/schedulers/gstoptimalscheduler.c:
6305         (gst_opt_scheduler_schedule_run_queue), (schedule_chain),
6306         (gst_opt_scheduler_get_wrapper):
6307           When we're recursing into a chain run, only run the directly
6308           related group, not all queued ones. This will fix a possible
6309           deadlock in chains with more than two groups.
6310
6311 2004-12-08  Thomas Vander Stichele  <thomas at apestaart dot org>
6312
6313         * autogen.sh:
6314           remove patch if autopoint fails
6315
6316 2004-12-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6317
6318         * docs/gst/gstreamer-sections.txt:
6319           Document Thomas' addition, fix build, make Luis the sheriff happy.
6320
6321 2004-12-07  Thomas Vander Stichele  <thomas at apestaart dot org>
6322
6323         * gst/gstplugin.c:
6324         * gst/gstplugin.h:
6325           add accessor for version field
6326
6327 2004-12-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6328
6329         submitted by: Luca Ferretti <elle.uca@infinito.it>
6330
6331         * po/LINGUAS:
6332         * po/it.po:
6333           New tranlation added: Italian
6334
6335 2004-12-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6336
6337         * gst/gstpad.c: (gst_pad_is_negotiated),
6338         (gst_pad_get_negotiated_caps):
6339           GST_RPAD_* will only operate on a RealPad (it casts the pointer,
6340           it doesn't actually check the contents), so be sure to hand it
6341           a RealPad else we'll crash.
6342
6343 2004-12-03  Wim Taymans  <wim@fluendo.com>
6344
6345         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
6346         (gst_queue_link), (gst_queue_handle_src_query):
6347         Reverted to 1.110 until this makes the testsuite and various
6348         apps work.
6349
6350 2004-12-01  Christian Fredrik Kalager Schaller <christian@fluendo.com>
6351
6352         * docs/upload.mak: fix included CVS conflict strings
6353
6354 2004-12-01  William Jon McCann  <mccann@jhu.edu>
6355
6356         Reviewed by: Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6357
6358         * gst/gstelement.c: (gst_element_error_full):
6359           Use g_error_new_literal because error text may have
6360           percentage signs in it. Fixes #160019.
6361
6362 2004-12-01  Benjamin Otte  <otte@gnome.org>
6363
6364         * gst/elements/gstbufferstore.c:
6365         (gst_buffer_store_add_buffer_func):
6366           don't try to make subbuffers bigger than they can be. (fixes
6367           #159970)
6368
6369 2004-11-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6370
6371         * docs/gst/gstreamer-sections.txt:
6372         * docs/gst/tmpl/gstvalue.sgml:
6373           Add new function to docs to fix build.
6374
6375 2004-11-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6376
6377         * gst/gstcaps.c: (gst_caps_is_fixed_foreach):
6378         * gst/gstpad.c: (_gst_pad_default_fixate_value),
6379         (_gst_pad_default_fixate_foreach):
6380         * gst/gstvalue.c: (gst_type_is_fixed), (gst_value_is_fixed):
6381         * gst/gstvalue.h:
6382           Deprecate _type_is_fixed, use _value_is_fixed instead, since
6383           in some cases (arrays), the fixedness depends on the content.
6384         * gst/gstqueue.c: (gst_queue_handle_src_query):
6385           Check for availability before doing something.
6386
6387 2004-11-29  Wim Taymans  <wim@fluendo.com>
6388
6389         * testsuite/threads/Makefile.am:
6390         * testsuite/threads/signals.c: (gst_test_get_type),
6391         (gst_test_class_init), (gst_test_init), (gst_test_dispose),
6392         (gst_test_set_property), (gst_test_get_property),
6393         (gst_test_do_signal1), (signal2_handler), (gst_test_do_signal2),
6394         (gst_test_do_prop), (run_thread), (main):
6395         Added a bunch of testcases that show threadsafety bugs in glib.
6396
6397 2004-11-29  Stefan Kost  <ensonic@users.sf.net>
6398
6399         * docs/manual/programs.xml:
6400           Added a first batch of gst-launch examples, as provided by Ronald
6401           and others from the devel-mlist
6402
6403 2004-11-28  Benjamin Otte  <otte@gnome.org>
6404
6405         * gst/gstelement.c: (gst_element_negotiate_pads):
6406           simplify
6407         * gst/gstvalue.c: (gst_string_wrap), (gst_string_unwrap),
6408         (gst_value_serialize_string), (gst_value_deserialize_string):
6409           add unwrapping of previously wrapped strings. Fix bug in wrapping
6410           while at it.
6411         * testsuite/caps/value_serialize.c: (test1),
6412         (test_string_serialization), (test_string_deserialization), (main):
6413           add tests for string (de)serialization
6414
6415 2004-11-26  Wim Taymans  <wim@fluendo.com>
6416
6417         * testsuite/threads/159566.c: (object_deep_notify), (main):
6418         * testsuite/threads/Makefile.am:
6419         Added testsuite to show bug #159566
6420
6421 2004-11-25  Wim Taymans  <wim@fluendo.com>
6422
6423         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_change_state),
6424         (gst_thread_child_state_change), (gst_thread_main_loop):
6425         Ref the thread object in the GThread mainloop. Break out of the
6426         thread mainloop if it holds the last ref. This properly exits
6427         the threads when disposing the thread from its own context. It
6428         also avoids possible deadlocks in the dispose function.
6429
6430 2004-11-24  Martin Soto  <martinsoto@users.sourceforge.net>
6431
6432         * gst/gstqueue.c (gst_queue_link_sink): Grab the lock only when
6433         it is necessary to wait.
6434
6435 2004-11-24  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6436
6437         * docs/pwg/building-boiler.xml:
6438           Make description somewhat clearer.
6439
6440 2004-11-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6441
6442         * docs/upload.mak:
6443           Apparently docs changed location on FDO's server.
6444
6445 2004-11-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6446
6447         * docs/pwg/appendix-checklist.xml:
6448           Add some random notes on things to check when writing an element.
6449           This list can be extended as people see fit.
6450
6451 2004-11-23  Martin Soto  <martinsoto@users.sourceforge.net>
6452
6453         * gst/gstqueue.c (gst_queue_init, gst_queue_link_sink)
6454         (gst_queue_link_src): Allow for renegotiating the caps of the sink
6455         pad. The queue will now wait until it is empty and forward the new
6456         caps to the source.
6457         * gst/gstbin.c (gst_bin_set_element_sched)
6458         (gst_bin_unset_element_sched): Make sure that all elements and
6459         links are registered and unregistered with the scheduler exactly
6460         once. This elaborates on a fix by Benjamin Otte, but
6461         guarantees that decoupled elements are also registered.
6462
6463 2004-11-11  Thomas Vander Stichele  <thomas at apestaart dot org>
6464
6465         * docs/manual/quotes.xml:
6466           add a quote
6467         * configure.ac:
6468         * gst/gst.c:
6469         * gst/gstinfo.c:
6470           add LIBDIR and move init message higher up so it's at the start
6471
6472 2004-11-08  Christian Fredrik Kalager Schaller  <christian@fluendo.com>
6473
6474         * gst/schedulers/Makefile.am: fix disted build fair by including .h file
6475         * gstreamer.spec.in: add fair
6476
6477 2004-11-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6478
6479         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
6480         * gst/elements/gstidentity.c: (gst_identity_class_init):
6481           Use G_SIGNAL_TYPE_STATIC_SCOPE, patch by Christophe Fergeau
6482           <teuf@gnome.org> (#157263).
6483         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
6484         (gst_type_find_handle_src_query):
6485           Subtract size of internally stored data from position queries.
6486
6487 2004-11-07  Martin Soto  <martinsoto@users.sourceforge.net>
6488
6489         * gst/schedulers/fairscheduler.c:
6490         * gst/schedulers/faircothreads.c:
6491         * gst/schedulers/faircothreads.h:
6492         New cothread based scheduler: Fair scheduler.
6493         * gst/schedulers/gthread-cothreads.h: 
6494         Add the standard #if around the whole file.
6495         Defining symbol GTHREAD_COTHREADS_NO_DEFINITIONS will now prevent
6496         compilation of the functions defined in this file. This is
6497         necessary to be able to use this file as a normal header.
6498         * gst/schedulers/Makefile.am: Add compiling support for fair
6499         scheduler.
6500         * docs/gst/Makefile.am (IGNORE_HFILES): Exclude internal fair
6501         scheduler cothreads layer from documentation generation.
6502
6503 2004-11-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6504
6505         * gst/autoplug/gstspideridentity.c:
6506         (gst_spider_identity_sink_loop_type_finding):
6507           Don't crash if that function is not implemented.
6508
6509 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6510
6511         * docs/pwg/advanced-types.xml:
6512           Another typo.
6513
6514 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6515
6516         * docs/pwg/intro-preface.xml:
6517           Hm, ok, so the brackets weren't really useful...
6518         * docs/pwg/other-ntoone.xml:
6519           Fix embarassing typo.
6520
6521 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6522
6523         * docs/pwg/intro-preface.xml:
6524           Rewrite preface.
6525
6526 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6527
6528         * docs/pwg/advanced-scheduling.xml:
6529         * docs/pwg/advanced-tagging.xml:
6530         * docs/pwg/advanced-types.xml:
6531         * docs/pwg/building-boiler.xml:
6532         * docs/pwg/building-chainfn.xml:
6533         * docs/pwg/building-signals.xml:
6534         * docs/pwg/building-state.xml:
6535         * docs/pwg/building-testapp.xml:
6536         * docs/pwg/intro-basics.xml:
6537         * docs/pwg/other-manager.xml:
6538         * docs/pwg/other-source.xml:
6539           Typo fixes.
6540         * docs/pwg/other-manager.xml:
6541           Add some first content. No example code yet.
6542         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
6543           Remove double newlines.
6544
6545 2004-11-04  Wim Taymans  <wim@fluendo.com>
6546
6547         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
6548         (remove_from_group), (normalize_group), (group_migrate_connected),
6549         (gst_opt_scheduler_iterate):
6550         * testsuite/schedulers/.cvsignore:
6551         * testsuite/schedulers/Makefile.am:
6552         * testsuite/schedulers/queue_link.c: (main):
6553         Added testcase for scheduler segfault.
6554         Fix scheduler segfault when removing a decoupled
6555         entry point as the last element from a group.
6556
6557 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
6558
6559         * gst/gstmarshal.list: add missing marshaller, fixes build
6560
6561 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
6562
6563         * docs/random/signal: added notes about using BOXED for GstBuffer
6564         signal marshallers, not POINTER
6565
6566 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
6567
6568         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
6569         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init): more
6570         POINTER=>BOXED changes to marshal GstBuffers
6571
6572 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
6573
6574         * gst/elements/gstidentity.c: (gst_identity_class_init): GstBuffer is 
6575         a boxed type, marshal the signal with VOID__BOXED, not VOID__POINTER
6576
6577 2004-11-03  Stefan Kost  <ensonic@users.sf.net>
6578
6579         * docs/gst/gstreamer-sections.txt:
6580         * docs/gst/tmpl/gstcaps.sgml:
6581         * docs/gst/tmpl/gsterror.sgml:
6582         * docs/gst/tmpl/gstinfo.sgml:
6583         * docs/gst/tmpl/gstmacros.sgml:
6584         * docs/gst/tmpl/gstutils.sgml:
6585         * docs/random/ensonic/interfaces.txt:
6586         * gst/gstinfo.h:
6587           added some more docs, removed two obsolete defines
6588
6589 2004-11-02  Kjartan Maraas <as at gnome.org>
6590
6591         reviewed by: Wim Taymans, Ronald Bultje.
6592
6593         * gst/cothreads.c: (cothread_create):
6594         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_remove_func),
6595         (gst_bin_child_state_change_func):
6596         * gst/gstbuffer.c: (gst_buffer_span):
6597         * gst/gstelement.c: (gst_element_get_index),
6598         (gst_element_get_event_masks), (gst_element_get_query_types),
6599         (gst_element_get_formats):
6600         * gst/gsterror.c: (_gst_core_errors_init),
6601         (_gst_library_errors_init), (_gst_resource_errors_init),
6602         (_gst_stream_errors_init):
6603         * gst/gstobject.c: (gst_object_default_deep_notify):
6604         * gst/gstpad.c: (gst_pad_get_event_masks),
6605         (gst_pad_get_internal_links_default):
6606         * gst/gstplugin.c: (gst_plugin_register_func),
6607         (gst_plugin_get_module):
6608         * gst/gststructure.c: (gst_structure_get_string),
6609         (gst_structure_get_abbrs), (gst_structure_from_abbr),
6610         (gst_structure_to_abbr):
6611         * gst/gstutils.c: (gst_print_element_args):
6612         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
6613         (setup_group_scheduler), (gst_opt_scheduler_iterate):
6614         Aplied part of patch #157127: Cleanup of issues reported by 
6615         sparse.
6616         Also do not try to use cothreads when there is no cothread
6617         context yet.
6618
6619 2004-11-02  Sebastien Cote <sc5 at hermes.usherb.ca>
6620
6621         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
6622         (gst_opt_scheduler_iterate):
6623         Applied patch #154061. Running a pipeline in which an element 
6624         calls GST_ELEMENT_ERROR in the chain function, the opt 
6625         scheduler doesn't unref the chain so it never gets freed.
6626
6627 2004-11-02  Wim Taymans  <wim@fluendo.com>
6628
6629         * gst/gststructure.c: (gst_structure_get_abbrs),
6630         (gst_structure_from_abbr), (gst_structure_to_abbr):
6631         Remove that ugly if-then thing in the code that converts
6632         between strings and types.
6633
6634 2004-11-02  Wim Taymans  <wim@fluendo.com>
6635
6636         * gst/gstscheduler.c: (gst_scheduler_add_element),
6637         (gst_scheduler_remove_element), (gst_scheduler_state_transition):
6638         Aplied clock distribution patch, this should fix bug
6639         #148787.
6640
6641 2004-10-27  Thomas Vander Stichele  <thomas at apestaart dot org>
6642
6643         Submitted by: Kjartan Maraas <kmaraas@broadpark.no>
6644
6645         * po/LINGUAS:
6646         * po/nb.po:
6647           Added Norwegian Bokmaal translation
6648
6649 2004-10-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6650
6651         * tools/gst-inspect.c: (print_signal_info):
6652           print signal arguments as pointers if they are
6653
6654 2004-10-22  Stefan Kost  <ensonic@users.sf.net>
6655
6656         * docs/pwg/building-boiler.xml:
6657           exchanged GTK_ macros with G_TYPE macros (as pointed out by mathrick)
6658
6659 2004-10-19  Wim Taymans  <wim at fluendo dot com>
6660
6661         * gst/parse/parse.l:
6662         * testsuite/parse/parse1.c: (main):
6663         Since parse can do 'element name=a:b' make 'a:b.' work as
6664         well. 
6665         Added testcase to verify fix.
6666
6667 2004-10-19  Wim Taymans  <wim at fluendo dot com>
6668
6669         * tools/gst-inspect.c: (print_pad_info), (print_plugin_features):
6670         Use the realpad when printing the direction.
6671         Add extra \n when printing extensions of typefind factories.
6672
6673 2004-10-13  David Schleef  <ds@schleef.org>
6674
6675         * examples/manual/Makefile.am: $< isn't portable in Makefile
6676         rules.
6677
6678 2004-10-13  Stefan Kost  <ensonic@users.sf.net>
6679
6680         * docs/gst/tmpl/gstobject.sgml:
6681         * docs/gst/tmpl/gstplugin.sgml:
6682         * docs/gst/tmpl/gstpluginfeature.sgml:
6683         * docs/gst/tmpl/gstregistry.sgml:
6684         * docs/gst/tmpl/gstversion.sgml:
6685         * gst/gstbin.c:
6686           more api documentation
6687         * gst/gstplugin.c: (gst_plugin_register_func),
6688         (gst_plugin_check_file), (gst_plugin_load_file):
6689           better error signaling and logging
6690
6691 2004-10-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6692
6693         * gst/gstqueue.c: (gst_queue_init), (gst_queue_handle_src_query):
6694           Subtract current queue contents from position queries.
6695
6696 2004-10-11  Johan Dahlin  <johan@gnome.org>
6697
6698         * gst/gsturi.c (gst_uri_get_location): unescape string
6699         (gst_uri_construct): escape string.
6700
6701 2004-10-11  Benjamin Otte  <otte@gnome.org>
6702
6703         * gst/gstpad.c: (gst_pad_renegotiate), (gst_pad_try_set_caps),
6704         (gst_pad_try_set_caps_nonfixed):
6705           allow renegotiation of unconnected pads (as inside spider). Simply
6706           return OK if unconnected - mimic try_set_caps there.
6707
6708 2004-10-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6709
6710         * gst/gstbin.c: (gst_bin_sync_children_state):
6711           Add missing break.
6712
6713 2004-10-09  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6714
6715         * gst/elements/gstfakesrc.c: (gst_fakesrc_get):
6716         Set element to EOS before sending EOS event
6717
6718 2004-10-08  Wim Taymans  <wim at fluendo dot com>
6719
6720         * gst/elements/gsttypefindelement.c:
6721         (gst_type_find_element_handle_event):
6722         Handle EOS events when doing the transition from
6723         typefind to data passing. This should fix the
6724         infinite loops in short files.
6725
6726 2004-10-07  Wim Taymans  <wim at fluendo dot com>
6727
6728         * gst/gstthread.c: (gst_thread_change_state),
6729         (gst_thread_child_state_change):
6730         Make sure no iteration happens while performing
6731         the state change as it could mess up the internal
6732         consistency of the thread state.
6733
6734 2004-10-07  Wim Taymans  <wim at fluendo dot com>
6735
6736         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_sync),
6737         (gst_thread_change_state), (gst_thread_child_state_change):
6738         Do not try to grab the iterate lock in the state change method
6739         when we are in the same thread as the iterate or else we
6740         could deadlock. Some other cleanups.
6741
6742 2004-10-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6743
6744         * configure.ac:
6745           bump nano to cvs
6746
6747 === release 0.8.7 ===
6748
6749 2004-10-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6750
6751         * configure.ac:
6752         * NEWS:
6753         * RELEASE:
6754         * configure.ac:
6755           releasing 0.8.7, "A Cruise"
6756
6757 2004-10-06  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
6758
6759         * docs/random/mimetypes:
6760         Add an entry for Sony ATRAC3 audio format with mime-type
6761         used by rmdemux et riff-read
6762
6763 2004-10-06  Wim Taymans  <wim at fluendo dot com>
6764
6765         * gst/elements/gsttypefindelement.c: (stop_typefinding):
6766         Push the buffer store instead of clearing it in case that
6767         the stream is not seekable.
6768
6769 2004-10-06  Wim Taymans  <wim at fluendo dot com>
6770
6771         * gst/gstthread.c: (gst_thread_init), (gst_thread_change_state),
6772         (gst_thread_main_loop):
6773         Lock the iteration and the state change so that automatic
6774         negotiation and fixation does not happen at the same time
6775         as the in stream negotiation.
6776
6777 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
6778
6779         * configure.ac:
6780           bump nano to cvs
6781
6782 === release 0.8.6 ===
6783
6784 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
6785
6786         * configure.ac:
6787         * NEWS:
6788         * RELEASE:
6789         * configure.ac:
6790           releasing 0.8.6, "Narc"
6791
6792 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
6793
6794         * configure.ac:
6795           prerel bump
6796
6797 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
6798
6799         patch by: Steve Lhomme
6800
6801         * gst/elements/gstfakesrc.c:
6802         * gst/elements/gstidentity.c:
6803         * gst/gstthread.c:
6804           Fix for #153881
6805
6806 2004-10-01  Wim Taymans  <wim at fluendo dot com>
6807
6808         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_crc):
6809         Fix threadsafety of the crc checking function.
6810
6811 2004-09-26  Thomas Vander Stichele  <thomas at apestaart dot org>
6812
6813         patch by: Ronald Bultje
6814
6815         * gst/elements/gsttypefindelement.c: (stop_typefinding),
6816         (gst_type_find_element_handle_event),
6817         (gst_type_find_element_chain):
6818         * gst/elements/gsttypefindelement.h:
6819          #153657.
6820          Filter out discont event from seekable sources when typefind
6821          asks them to seek.  Fixes typefind with demuxers for
6822          avi, asf and matroska.
6823
6824 2004-09-26  Thomas Vander Stichele  <thomas at apestaart dot org>
6825
6826         * docs/gst/gstreamer-sections.txt:
6827         * gst/gstcaps.c:
6828         * gst/gstcaps.h:
6829         * gst/gstpad.c:
6830           Revert preferred caps: (#147789)
6831
6832 2004-09-19  Steve Lhomme  <steve.lhomme@free.fr>
6833
6834         * win32/dirent.c:
6835           fix a memory leak
6836
6837 2004-09-10  Thomas Vander Stichele  <thomas at apestaart dot org>
6838
6839         * configure.ac:
6840           bump for prerelease
6841
6842 2004-09-09  Thomas Vander Stichele  <thomas at apestaart dot org>
6843
6844         * docs/Makefile.am:
6845         * docs/manual/elements-api.xml:
6846           restructure so that common stuff is shown first
6847         * docs/manual/init-api.xml:
6848           convert to examples
6849         * docs/manual/manual.xml:
6850         * docs/manuals.mak:
6851         * docs/url.entities:
6852           link to API on the website, possibly override later in build
6853         * examples/manual/.cvsignore:
6854           ignore more
6855         * examples/manual/Makefile.am:
6856           add more examples
6857         * examples/manual/extract.pl:
6858           error out on failure
6859
6860 2004-09-08  Thomas Vander Stichele  <thomas at apestaart dot org>
6861
6862         * docs/gst/tmpl/gstthread.sgml:
6863         * docs/manual/init-api.xml:
6864         * examples/manual/Makefile.am:
6865           convert two code bits to examples
6866
6867 2004-09-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
6868
6869         * gst/gstelement.c: (gst_element_change_state):
6870           Well, actually, I was about to remove this insane assert when
6871           I noticed Wim already did that. A warning is nice so we can
6872           fix actual ugs (using --g-fatal-warnings and backtraces), so
6873           I added that instead.
6874
6875 2004-09-06  Wim Taymans  <wim@fluendo.com>
6876
6877         * gst/gstelement.c: (gst_element_threadsafe_properties_pre_run),
6878         (gst_element_threadsafe_properties_post_run),
6879         (gst_element_set_state), (gst_element_change_state):
6880         Added extra refcounting around various places. 
6881
6882 2004-09-06  Wim Taymans  <wim@fluendo.com>
6883
6884         * gst/gstpad.c: (gst_pad_link_call_link_functions):
6885         Fix debug info.
6886
6887 2004-09-06  Wim Taymans  <wim@fluendo.com>
6888
6889         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
6890         (remove_from_group):
6891         Some more debug info.
6892
6893 2004-09-03  Wim Taymans  <wim@fluendo.com>
6894
6895         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
6896         (gst_fakesrc_init), (gst_fakesrc_set_clock),
6897         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
6898         (gst_fakesrc_get), (gst_fakesrc_change_state):
6899         * gst/elements/gstfakesrc.h:
6900         * gst/elements/gstidentity.c: (gst_identity_class_init),
6901         (gst_identity_init), (gst_identity_chain),
6902         (gst_identity_set_property), (gst_identity_get_property),
6903         (gst_identity_change_state):
6904         * gst/elements/gstidentity.h:
6905         Added datarate properties to limit the datarate.
6906
6907 2004-08-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6908
6909         * gst/autoplug/gstspider.c: (plugin_init):
6910           don't set a rank. We don't want to autoplug by inserting spiders.
6911
6912 2004-08-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6913
6914         * gst/autoplug/gstspider.c: (gst_spider_class_init),
6915         (gst_spider_identity_plug):
6916           add a template for spider's sink
6917         * gst/gst.c: (gst_register_core_elements):
6918           queue's rank should be NULL, we don't want spider to add it.
6919
6920 2004-08-18  David Schleef  <ds@schleef.org>
6921
6922         * docs/gst/Makefile.am: Remove --ignore-fail-on-non-empty (#150331)
6923         * docs/libs/Makefile.am: same
6924         * docs/gst/tmpl/gstxml.sgml: Remove GstXMLNs
6925         * docs/random/ds/0.9-planning: random additions
6926         * docs/random/ds/0.9-suggested-changes: same
6927         * gst/gstxml.h: remove vestigal GstXMLNs definition
6928
6929         Preferred caps: (#147789)
6930         * docs/gst/gstreamer-sections.txt: Add symbols
6931         * docs/gst/tmpl/gstcaps.sgml: Add symbols
6932         * gst/gstcaps.c: (gst_caps_copy), (gst_caps_free),
6933         (gst_caps_append), (gst_caps_copy_1), (gst_caps_intersect),
6934         (gst_caps_union), (gst_caps_save_thyself), (gst_caps_load_thyself),
6935         (gst_caps_get_preferred), (gst_caps_set_preferred),
6936         (gst_caps_get_structure_by_id), (gst_caps_prefer_foreach),
6937         (gst_caps_use_preferred): Handle caps preferences
6938         * gst/gstcaps.h: Add caps preferences
6939         * gst/gstpad.c: (gst_pad_link_get_preferred),
6940         (gst_pad_link_fixate), (gst_pad_link_call_link_functions),
6941         (gst_pad_renegotiate), (gst_pad_guess_preferred),
6942         (gst_pad_get_caps), (gst_pad_push):  Use caps preferences for
6943         negotiation.
6944
6945 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6946
6947         * gst/autoplug/gstspideridentity.c:
6948         (gst_spider_identity_request_new_pad):
6949         * gst/elements/gstaggregator.c: (gst_aggregator_base_init),
6950         (gst_aggregator_init):
6951         * gst/elements/gstfakesink.c: (gst_fakesink_base_init),
6952         (gst_fakesink_init):
6953         * gst/elements/gstfakesrc.c: (gst_fakesrc_base_init),
6954         (gst_fakesrc_init):
6955         * gst/elements/gstfdsink.c: (gst_fdsink_base_init),
6956         (gst_fdsink_init):
6957         * gst/elements/gstfdsrc.c: (gst_fdsrc_base_init), (gst_fdsrc_init):
6958         * gst/elements/gstfilesink.c: (gst_filesink_base_init),
6959         (gst_filesink_init):
6960         * gst/elements/gstfilesrc.c: (gst_filesrc_base_init),
6961         (gst_filesrc_init):
6962         * gst/elements/gstidentity.c: (gst_identity_base_init),
6963         (gst_identity_init):
6964         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_base_init),
6965         (gst_multifilesrc_init):
6966         * gst/elements/gstpipefilter.c: (gst_pipefilter_base_init),
6967         (gst_pipefilter_init):
6968         * gst/elements/gststatistics.c: (gst_statistics_base_init),
6969         (gst_statistics_init):
6970         * gst/elements/gsttee.c: (gst_tee_base_init), (gst_tee_init):
6971         * gst/gstqueue.c: (gst_queue_base_init), (gst_queue_init):
6972           s/gst_pad_new/&_from_template/
6973           register pad templates in the base_init function
6974           add static pad template definitions
6975
6976 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6977
6978         * testsuite/bytestream/gstbstest.c: (gst_bstest_init):
6979         * testsuite/dynparams/dparamstest.c: (gst_dptest_init):
6980         * testsuite/refcounting/pad.c: (main):
6981         * testsuite/refcounting/thread.c: (create_thread_ghostpads):
6982           s/gst_pad_new/&_from_template/
6983           prepare deprecation of gst_pad_new
6984
6985 2004-08-17  Thomas Vander Stichele  <thomas at apestaart dot org>
6986
6987         patch by: Luca Ognibene <skaboy81@virgilio.it>
6988
6989         * gst/gstcaps.c:
6990         * gst/gstelement.c:
6991         * gst/gstpad.c:
6992         * gst/gstxml.c:
6993           fix memleaks.  Fixes #150001
6994
6995 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6996
6997         * docs/random/ds/0.9-suggested-changes:
6998           add notes - mostly about pad templates
6999
7000 2004-08-16  Steve Lhomme  <steve.lhomme@free.fr>
7001
7002         * win32/GStreamer.vcproj:
7003           temporary locale files are .gmo not .mo
7004
7005 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
7006
7007         * configure.ac: bump nano to cvs
7008
7009 === release 0.8.5 ===
7010
7011 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
7012
7013         * configure.ac:
7014           releasing 0.8.5, "Stuttgart"
7015         * NEWS:
7016         * RELEASE:
7017         * configure.ac:
7018         * docs/random/release:
7019           updates for release
7020
7021 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
7022
7023         patch by: Wim Taymans (wim@fluendo.com)
7024
7025         * gst/gstbuffer.c:
7026         * gst/gstindex.h:
7027         * libs/gst/dataprotocol/dataprotocol.c:
7028           copy KEY_UNIT and DELTA_UNIT flags correctly.  Fixes #150242
7029
7030 2004-08-13  Thomas Vander Stichele  <thomas at apestaart dot org>
7031
7032         * Makefile.am:
7033         * win32/MANIFEST:
7034           add win32 dir to the build.  Fixes #149981.
7035
7036 2004-08-13  Thomas Vander Stichele  <thomas at apestaart dot org>
7037
7038         * configure.ac:
7039           bump libtool versioning
7040         * gst/gststructure.c:
7041           mark function as static
7042         * po/af.po:
7043         * po/az.po:
7044         * po/ca.po:
7045         * po/cs.po:
7046         * po/en_GB.po:
7047         * po/fr.po:
7048         * po/nl.po:
7049         * po/sq.po:
7050         * po/sr.po:
7051         * po/sv.po:
7052         * po/tr.po:
7053         * po/uk.po:
7054           translations update
7055         * win32/README.txt:
7056           trademark protection
7057
7058 2004-08-12  Thomas Vander Stichele  <thomas at apestaart dot org>
7059
7060         * configure.ac:
7061           fix GST_ORIGIN
7062           set GST_PACKAGE to source, and distinguish between release and other
7063         * tools/gst-inspect.c:
7064           print out plugin an element factory is part of so we see this info
7065
7066 2004-08-12  Thomas Vander Stichele  <thomas at apestaart dot org>
7067
7068         * docs/gst/gstreamer-sections.txt:
7069         * docs/gst/tmpl/gstbuffer.sgml:
7070         * docs/gst/tmpl/gstschedulerfactory.sgml:
7071           reorder docs a little, make GstBuffer's more sensible.
7072         * gst/gstbuffer.h:
7073           API: added GST_BUFFER_FLAG_DELTA_UNIT
7074         * gst/gstscheduler.c:
7075           comment API addition
7076
7077 2004-08-12  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7078
7079         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
7080           work with non-regular files that can be mmapped (like /dev/zero)
7081         * gst/elements/gsttypefindelement.c: (gst_type_find_element_chain):
7082           get rid of typefinds that require a seek when we can't seek instead
7083           of trying them over and over again
7084         * tools/gst-launch.c: (idle_func), (error_cb), (main):
7085           return non-zero failure value when the pipeline was interrupted or
7086           an error occurred
7087
7088 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
7089
7090         * win32/config.h:
7091         * win32/GStreamer.vcproj:
7092           compile and install the locales
7093
7094 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
7095
7096         * gst/gstvalue.c:
7097           fix a possible memory leak under Windows
7098
7099 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
7100
7101         * win32/GStreamer.vcproj:
7102           fix a memory leak that occured under Windows
7103         * win32/gstreamer.def:
7104           add gst_scheduler_register
7105
7106 2004-08-11  Benjamin Otte  <otte@gnome.org>
7107
7108         * docs/gst/gstreamer-sections.txt:
7109         * gst/gstscheduler.c: (gst_scheduler_register):
7110         * gst/gstscheduler.h:
7111           API:
7112           add gst_scheduler_register shortcut similar to gst_element_register
7113         * gst/schedulers/entryscheduler.c: (plugin_init):
7114         * gst/schedulers/gstbasicscheduler.c: (plugin_init):
7115         * gst/schedulers/gstoptimalscheduler.c: (plugin_init):
7116           use it
7117
7118 2004-08-10  Steve Lhomme  <steve.lhomme@free.fr>
7119
7120         * gst/gstvalue.h:
7121           fix a memory leak that occured under Windows
7122
7123 2004-08-10  Colin Walters  <walters@redhat.com>
7124
7125         * gst/registries/gstxmlregistry.c (gst_xml_registry_open_func):
7126         Don't use O_EXCL to open temporary registry.  It will prevent
7127         registry creation if a temporary one already exists, which
7128         is unnecessary.
7129
7130 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
7131
7132         * docs/gst/gstreamer-sections.txt:
7133         * docs/gst/tmpl/gstvalue.sgml:
7134           remove some valuable stuff from the documentation due to the use of GST_EXPORT
7135
7136 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
7137
7138         * win32/gstbytestream.vcproj:
7139         * win32/gstelements.vcproj:
7140         * win32/gstgetbits.vcproj:
7141         * win32/gst-inspect.vcproj:
7142         * win32/gst-launch.vcproj:
7143         * win32/gstoptimalscheduler.vcproj:
7144         * win32/GStreamer.vcproj:
7145         * win32/gst-register.vcproj:
7146         * win32/gstspider.vcproj:
7147           update the include and lib dirs to fit standard libraries as
7148           described in the Win32 manual
7149
7150 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
7151
7152         * win32/config.h:
7153         * win32/gstversion.h:
7154           enable NLS again, push the version number for the coming 0.8.5 release
7155
7156 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
7157
7158         * gst/gstvalue.h:
7159           export gst_type_XXX for windows DLLs
7160
7161 2004-08-09  Thomas Vander Stichele  <thomas at apestaart dot org>
7162
7163         * docs/faq/gst-uninstalled:
7164           fix PKG_CONFIG_PATH and PYTHONPATH
7165         * gst/schedulers/Makefile.am:
7166           cleanup
7167         * libs/gst/bytestream/bytestream.c:
7168           remove newline
7169         * po/LINGUAS:
7170         * po/sq.po:
7171           adding Albanian translation (Laurent Dhima)
7172         * po/cs.po:
7173           updated
7174
7175 2004-08-05  Thomas Vander Stichele  <thomas at apestaart dot org>
7176
7177         * po/ca.po:
7178         * po/sv.po:
7179           updated translations
7180
7181 2004-08-04  Benjamin Otte  <otte@gnome.org>
7182
7183         * tests/mass_elements.c: (main):
7184           allow specifying src and sink element explicitly, so I can test
7185           videotestsrc instead of fakesrc
7186
7187 2004-08-04  Benjamin Otte  <otte@gnome.org>
7188
7189         * gst/gststructure.c: (gst_structure_id_empty_new_with_size),
7190         (gst_structure_id_empty_new), (gst_structure_empty_new),
7191         (gst_structure_copy):
7192           add gst_structure_id_empty_new_with_size to allow preallocating
7193           value array sizes. Use this in gst_structure_copy to get rid of
7194           reallocs.
7195           don't do quark=>string=>quark when copying structures
7196
7197 2004-08-03  Steve Lhomme  <steve.lhomme@free.fr>
7198
7199         * docs/manual/win32.xml:
7200         * win32/README.txt:
7201           update documentation with the clean version of dependencies
7202
7203 2004-08-03  Benjamin Otte  <otte@gnome.org>
7204
7205         * gst/schedulers/entryscheduler.c:
7206         (gst_entry_scheduler_remove_element):
7207           fix for GST_DISABLE_DEBUG
7208         * tools/gst-launch.c: (print_tag):
7209           fixes for G_DISABLE_ASSERT
7210
7211 2004-08-03  Benjamin Otte  <otte@gnome.org>
7212
7213         * gst/gst.c: (gst_register_core_elements):
7214           fix for G_DISABLE_ASSERT
7215         * gst/gstinfo.c: (__gst_in_valgrind):
7216           add for GST_DISABLE_DEBUG
7217
7218 2004-08-03  Benjamin Otte  <otte@gnome.org>
7219
7220         * gst/parse/parse.l:
7221           fix for G_DISABLE_ASSERT
7222
7223 2004-08-03  Wim Taymans  <wim@fluendo.com>
7224
7225         * gst/gstbin.c: (gst_bin_get_type),
7226         (gst_bin_child_state_change_func):
7227         * gst/gstthread.c: (gst_thread_change_state):
7228         Backported some debug logging from a reverted patch
7229         Don't try to destroy the thread twice. Added some more
7230         debugging in GstThread. Unlock and signal even if we
7231         are in the thread context.
7232
7233 2004-08-03  Thomas Vander Stichele  <thomas at apestaart dot org>
7234
7235         * po/uk.po:
7236           updated translation
7237
7238 2004-07-30  David Schleef  <ds@schleef.org>
7239
7240         * gst/gstatomic_impl.h: Enable atomic code for x86_64
7241
7242 2004-07-29  David Schleef  <ds@schleef.org>
7243
7244         * libs/gst/dataprotocol/dataprotocol-test.c: (conversion_test):
7245         Use GST_READ_GUINTxx_BE(), since it accesses unaligned memory.
7246
7247 2004-07-29  Thomas Vander Stichele  <thomas at apestaart dot org>
7248
7249         * gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
7250         (gst_bin_add_func), (gst_bin_remove_func),
7251         (gst_bin_child_state_change), (gst_bin_child_state_change_func),
7252         (set_kid_state_func), (gst_bin_change_state), (gst_bin_set_state),
7253         (gst_bin_change_state_norecurse), (gst_bin_dispose),
7254         (gst_bin_sync_children_state):
7255         * gst/gstbin.h:
7256         * gst/gstthread.c: (gst_thread_class_init), (gst_thread_release),
7257         (gst_thread_change_state):
7258         * testsuite/states/Makefile.am:
7259           revert state change patches as agreed so we can rework them
7260           gradually
7261
7262 2004-07-29  Benjamin Otte  <otte@gnome.org>
7263
7264         * libs/gst/control/Makefile.am:
7265           link to libgstreamer (fixes Debian bug 262019, see
7266           http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=262019 )
7267
7268 2004-07-29  Wim Taymans  <wim@fluendo.com>
7269
7270         * testsuite/caps/fraction-convert.c: (check_from_double_convert),
7271         (check_from_fraction_convert), (transform_test), (main):
7272         Make the test less pedantic about float roundoff errors.
7273
7274 2004-07-29  Benjamin Otte  <otte@gnome.org>
7275
7276         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file),
7277         (gst_filesrc_srcpad_event):
7278           make seek events to before start/after end of file not fail, but
7279           seek to start/end instead
7280         * testsuite/caps/fraction-convert.c: (check_from_double_convert):
7281           add more output
7282
7283 2004-07-29  Benjamin Otte  <otte@gnome.org>
7284
7285         * gst/gstpad.c: (gst_pad_set_explicit_caps):
7286           check that caps are fixed
7287         * gst/gstpad.c: (gst_pad_template_new):
7288           don't try to simplify caps, costs too much time on gst_init
7289         * gst/gstplugin.c: (gst_plugin_add_feature):
7290           G_ERROR if features are added twice
7291         * gst/gsttypefind.c: (gst_type_find_register):
7292         * gst/gstelementfactory.c: (gst_element_register):
7293           don't add features twice
7294         * docs/random/ds/0.9-suggested-changes:
7295           add note about possible gst_init optimization
7296
7297 2004-07-28  David Schleef  <ds@schleef.org>
7298
7299         * testsuite/elements/Makefile.am:
7300         * testsuite/elements/struct_i386.h:
7301         * testsuite/elements/struct_size.c: (main):  A little test
7302         to keep distcheck from working if someone changes a structure
7303         size accidentally.
7304
7305 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
7306
7307         * docs/libs/Makefile.am:
7308         * docs/libs/gstreamer-libs-docs.sgml:
7309         * docs/libs/gstreamer-libs-sections.txt:
7310         * docs/libs/tmpl/gstbytestream.sgml:
7311         * docs/libs/tmpl/gstcontrol.sgml:
7312         * docs/libs/tmpl/gstdataprotocol.sgml:
7313         * docs/libs/tmpl/gstgetbits.sgml:
7314         * libs/gst/bytestream/Makefile.am:
7315         * libs/gst/bytestream/bytestream.c:
7316         * libs/gst/bytestream/bytestream.h:
7317         * libs/gst/control/Makefile.am:
7318         * libs/gst/dataprotocol/Makefile.am:
7319         * libs/gst/getbits/Makefile.am:
7320         * libs/gst/getbits/getbits.h:
7321           various doc and style fixes, adding bytestream to libs docs.
7322
7323 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
7324
7325         * docs/gst/gstreamer-docs.sgml:
7326         * docs/libs/Makefile.am:
7327         * docs/libs/gstreamer-libs-docs.sgml:
7328         * docs/libs/gstreamer-libs-sections.txt:
7329         * libs/gst/control/dparam.c:
7330           more doc fixes.  gst-libs docs now build the same way as gst.
7331
7332 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
7333
7334         * configure.ac:
7335         * testsuite/Makefile.am:
7336         * testsuite/bins/Makefile.am:
7337         * testsuite/caps/Makefile.am:
7338         * testsuite/cleanup/Makefile.am:
7339         * testsuite/clock/Makefile.am:
7340         * testsuite/debug/Makefile.am:
7341         * testsuite/dlopen/Makefile.am:
7342         * testsuite/dynparams/Makefile.am:
7343         * testsuite/elements/.cvsignore:
7344         * testsuite/elements/Makefile.am:
7345         * testsuite/enumcaps/Makefile.am:
7346         * testsuite/enumcaps/enumcaps.c:
7347         * testsuite/ghostpads/Makefile.am:
7348         * testsuite/indexers/Makefile.am:
7349         * testsuite/negotiation/Makefile.am:
7350         * testsuite/parse/Makefile.am:
7351         * testsuite/plugin/Makefile.am:
7352         * testsuite/refcounting/Makefile.am:
7353         * testsuite/schedulers/.cvsignore:
7354         * testsuite/states/Makefile.am:
7355         * testsuite/tags/Makefile.am:
7356         * testsuite/threads/Makefile.am:
7357           fold enumcaps into caps dir
7358           clean up Makefile.am's for testsuite
7359
7360 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
7361
7362         * docs/gst/Makefile.am:
7363         * docs/libs/Makefile.am:
7364           clean up docs build.  Fixes needless rebuilding of template files.
7365
7366 2004-07-28  Wim Taymans  <wim@fluendo.com>
7367
7368         * gst/gstbin.c: (set_kid_state_func), (gst_bin_set_state):
7369         * gst/gstthread.c: (gst_thread_release), (gst_thread_set_state):
7370         Make sure that a bin state change tries to keep the children
7371         in sync. 
7372         Added debug logging to the thread.
7373
7374 2004-07-27  Steve Lhomme  <steve.lhomme@free.fr>
7375
7376         * win32/GStreamer.vcproj:
7377         * win32/gstreamer.def:
7378           more exports for the plugins
7379
7380 2004-07-27  Steve Lhomme  <steve.lhomme@free.fr>
7381
7382         * win32/gstgetbits.vcproj:
7383         * win32/gstgetbits.def:
7384         * win32/msvc71.sln:
7385           add support for the getbits plugin
7386
7387 2004-07-27  Wim Taymans  <wim@fluendo.com>
7388
7389         * gst/gstvalue.c: (gst_value_transform_double_fraction),
7390         (gst_value_transform_fraction_double), (_gst_value_initialize):
7391         * testsuite/caps/Makefile.am:
7392         * testsuite/caps/fraction-convert.c: (check_from_double_convert),
7393         (check_from_fraction_convert), (transform_test), (main):
7394         Added transform functions between double and fraction.
7395         Added testcase to verify transforms
7396
7397 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
7398
7399         * win32/GStreamer.vcproj:
7400           rename GStreamer-0.8.lib to libgstreamer.lib
7401
7402 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
7403
7404         * win32/gstelements.vcproj:
7405         * win32/gstoptimalscheduler.vcproj:
7406           fixes for the Release build
7407
7408 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
7409
7410         * win32/config.h:
7411           update the version number
7412
7413 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
7414
7415         * win32/GStreamer.vcproj:
7416           add gstinterface to the build
7417
7418 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
7419
7420         * win32/gstreamer.def:
7421           add many definitions needed by plugins,
7422           GST_CAT_DEFAULT only available in the Debug build ?
7423
7424 2004-07-26  Thomas Vander Stichele  <thomas at apestaart dot org>
7425
7426         * gst/gstelement.c: (gst_element_set_eos_recursive):
7427           various whitespace fixes.
7428           doc fix, fixes #148497
7429
7430 2004-07-25  Benjamin Otte  <otte@gnome.org>
7431
7432         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link):
7433           don't delay links on the sink elements, it causes unnegotiated
7434           links.
7435         * gst/elements/gsttypefindelement.c:
7436         (gst_type_find_element_base_init):
7437           add our padtemplates, we indeed do have some.
7438         * gst/elements/gsttypefindelement.c:
7439         (gst_type_find_element_handle_event),
7440         (gst_type_find_element_chain):
7441           don't push data when typefinding failed.
7442         * gst/gstpad.c: (gst_pad_link_fixate):
7443           check that no fixate function returns empty caps.
7444         * gst/gstpad.c: (gst_pad_push):
7445           check that the link is negotiated before data gets pushed.
7446         * tools/gst-register.c: (main):
7447           don't assert (fixes #148283)
7448
7449 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
7450
7451         * docs/gst/gstreamer-sections.txt:
7452         * docs/gst/tmpl/gstconfig.sgml:
7453           add GST_PLUGIN_EXPORT definition
7454
7455 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
7456
7457         * gst/gstplugin.h:
7458         * gst/gstconfig.h.in:
7459         * win32/gstconfig.h:
7460         * win32/gstelements.def:
7461         * win32/gstelements.vcproj:
7462         * win32/gstoptimalscheduler.def:
7463         * win32/gstoptimalscheduler.vcproj:
7464         * win32/gstspider.def:
7465         * win32/gstspider.vcproj:
7466           remove unused .def files and export symbols using GST_PLUGIN_DEFINE
7467
7468 2004-07-25  Thomas Vander Stichele  <thomas at apestaart dot org>
7469
7470         * docs/gst/gstreamer-sections.txt:
7471           remove GST_CAT_DEFAULT because the type has changed
7472
7473 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
7474
7475         * win32/gstbytestream.vcproj:
7476         * win32/gstelements.vcproj:
7477         * win32/gst-inspect.vcproj:
7478         * win32/gst-launch.vcproj:
7479         * win32/gstoptimalscheduler.vcproj:
7480         * win32/GStreamer.vcproj:
7481         * win32/gst-register.vcproj:
7482         * win32/gstspider.vcproj:
7483         * win32/msvc71.sln:
7484           Copy the files where needed after building, The testsuite will be
7485           built separately
7486
7487 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
7488
7489         * win32/config.h:
7490         * win32/README.txt:
7491         * docs/manual/win32.xml:
7492         Fixed the plugin and GStreamer location
7493
7494 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7495
7496         * win32/gstreamer.def:
7497         More exports for the plugins
7498
7499 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7500
7501         * gst/gstinfo.h:
7502         Marc was right, we need to export literally GST_CAT_DEFAULT
7503
7504 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7505
7506         * win32/config.h:
7507         NLS crashes in gettext, disabled until this is solved
7508
7509 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7510
7511         * win32/gst-inspect.vcproj:
7512         * win32/gst-launch.vcproj:
7513         Should use NLS when available
7514
7515 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7516
7517         * gst/registries/gstxmlregistry.c:
7518         removing the file doesn't seem to be a good idea on Linux
7519
7520 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
7521
7522         * gst/registries/gstxmlregistry.c:
7523         Remove the registry before renaming the tempfile (needed for Windows)
7524
7525 2004-07-23  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7526
7527         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init),
7528         (gst_multifilesrc_init), (gst_multifilesrc_set_property),
7529         (gst_multifilesrc_get_property), (gst_multifilesrc_get):
7530         * gst/elements/gstmultifilesrc.h:
7531         Added newmedia property so it generates newmedia events between each
7532         file when property is set, as well as fixed eos handling
7533
7534 2004-07-22  David Schleef  <ds@schleef.org>
7535
7536         * gst/gststructure.c: (gst_structure_id_empty_new),
7537         (gst_structure_empty_new):  Set type field correctly.
7538         * gst/gststructure.h: Check type field correctly.
7539         * testsuite/caps/Makefile.am:
7540         * testsuite/caps/structure.c: (test1), (main): Add a very small
7541         test for structures.
7542
7543 2004-07-22  David Schleef  <ds@schleef.org>
7544
7545         * docs/random/ds/0.9-suggested-changes: more comments
7546         * tools/gst-launch.c: (idle_func): Fix hard-to-translate string.
7547
7548 2004-07-22  Benjamin Otte  <otte@gnome.org>
7549
7550         * gst/gstelementfactory.c: (gst_element_register):
7551           set the factory in the class struct, so gst_element_get_factory
7552           actually works
7553         * gst/parse/grammar.y:
7554           set element to playing when it gets unlocked as we can't rely on the
7555           bin state - all elements in the bin state might still be locked in
7556           NULL)
7557
7558 2004-07-22  Benjamin Otte  <otte@gnome.org>
7559
7560         * gst/gstelement.c: (gst_element_set_state_func):
7561           make this a static function
7562
7563 2004-07-22  Wim Taymans  <wim@fluendo.com>
7564
7565         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
7566         (gst_opt_scheduler_pad_link):
7567         fix 147894-2 and the group_link problem.
7568
7569 2004-07-22  Wim Taymans  <wim@fluendo.com>
7570
7571         * testsuite/schedulers/147894-2.c: (queue_empty), (queue_filled),
7572         (handoff_identity), (main):
7573         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
7574         (handoff_identity), (main):
7575         * testsuite/schedulers/Makefile.am:
7576         * testsuite/schedulers/group_link.c: (main):
7577         Show bug in scheduler when linking chain and loop based element 
7578         where the chain based element was not yet in a group.
7579
7580 2004-07-21  Benjamin Otte  <otte@gnome.org>
7581
7582         * gst/.cvsignore:
7583         * gst/autoplug/.cvsignore:
7584         * gst/elements/.cvsignore:
7585         * gst/indexers/.cvsignore:
7586         * libs/gst/bytestream/.cvsignore:
7587         * libs/gst/control/.cvsignore:
7588         * libs/gst/getbits/.cvsignore:
7589         * testsuite/states/.cvsignore:
7590         * testsuite/threads/.cvsignore:
7591           keep this up to date, since I seem to be the only one who cares
7592           about not missing files on commits (editor's note: no you don't,
7593           but feel free to change them at the time you add stuff instead
7594           of later on)
7595
7596 2004-07-21  Benjamin Otte  <otte@gnome.org>
7597
7598         * gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
7599         (gst_bin_fix_state), (gst_bin_add_func), (gst_bin_remove_func),
7600         (gst_bin_child_state_change_func), (set_kid_state_func),
7601         (gst_bin_set_state), (gst_bin_change_state_norecurse):
7602           make state changes work correctly and reentrant (so removing
7603           elements from bins during state changes of bins doesn't cause
7604           segfaults or even wrong states)
7605           add debugging category and debugging output to print children states
7606         * gst/gstbin.c: (gst_bin_dispose): 
7607           add some assertion checks
7608         * gst/gstbin.h:
7609         * gst/gstbin.c: (gst_bin_sync_children_state):
7610           deprecate this function - it just does gst_bin_set_state (bin,
7611           GST_STATE (bin)) 
7612         * testsuite/threads/queue.c: (main):
7613           don't use gst_bin_sync_children_state anymore
7614         * testsuite/states/Makefile.am:
7615         * testsuite/states/bin.c:
7616           test that the state changes of bins work as expected
7617         * gst/gstthread.c: (gst_thread_class_init), (gst_thread_set_state):
7618           some adjustments to change states correctly, too
7619         * gst/gstthread.c: (gst_thread_change_state):
7620           don't enable/disable "threadsafe" properties, they're unused and
7621           cause random segfaults
7622         * testsuite/threads/Makefile.am:
7623           the queue check randomly passes now, ignore it
7624
7625 2004-07-21  Benjamin Otte  <otte@gnome.org>
7626
7627         * gst/gstpad.c:
7628           check if data is NULL before outputting debug info. (fixes #145100)
7629
7630 2004-07-21  Benjamin Otte  <otte@gnome.org>
7631
7632         * gst/schedulers/entryscheduler.c:
7633         (gst_entry_scheduler_loop_wrapper),
7634         (gst_entry_scheduler_chain_wrapper),
7635         (gst_entry_scheduler_get_wrapper):
7636           reset the state when the cothread starts, so we don't get assertion
7637           failures on restarting of cothreads
7638
7639 2004-07-20  Benjamin Otte  <otte@gnome.org>
7640
7641         * gst/gstelement.c: (gst_element_link_pads_filtered):
7642           use correct sinkpad, if only sinkpad is specified, but not srcpad
7643           (fixes #147889)
7644         * gst/gstelement.c: (gst_element_set_state_func),
7645         (gst_element_change_state): ref/unref the element, signal handlers
7646         could get rid of the element otherwise
7647
7648 2004-07-20  Ronald Bultje  <rbultje@ronald.bitfreak.net>
7649
7650         * docs/random/ds/0.9-suggested-changes:
7651           Make note about renaming fixed-list to array.
7652         * gst/gstvalue.c: (gst_value_intersect_fixed_list),
7653         (_gst_value_initialize):
7654           Add array intersections.
7655         * testsuite/caps/intersect2.c: (main):
7656           Add test for array intersections.
7657
7658 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7659
7660         * configure.ac: back to cvs
7661
7662 === release 0.8.4 ===
7663
7664 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7665
7666         * configure.ac:
7667           releasing 0.8.4, "Paella"
7668           bump libtool versioning
7669
7670 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7671
7672         * po/LINGUAS:
7673         * po/ca.po:
7674           adding Catalan translation (Jordi Mallach)
7675
7676 2004-07-20  Wim Taymans  <wim@fluendo.com>
7677
7678         * testsuite/schedulers/147894-2.c: (queue_empty), (queue_filled),
7679         (handoff_identity), (main):
7680         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
7681         (handoff_identity), (main):
7682         * testsuite/schedulers/Makefile.am:
7683         Added failing testcase for variant of #147894
7684
7685 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7686
7687         patch by: David Moore
7688
7689         * gst/schedulers/gstoptimalscheduler.c: (group_has_element),
7690         (schedule_group), (gst_opt_scheduler_schedule_run_queue),
7691         (group_migrate_connected):
7692         * testsuite/schedulers/Makefile.am:
7693           fix for #142813 (Deadlock in optimal scheduler)
7694
7695 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7696
7697         patch by: Wim Taymans
7698
7699         * gst/schedulers/gstoptimalscheduler.c: (group_has_element),
7700         (gst_opt_scheduler_schedule_run_queue),
7701         (gst_opt_scheduler_get_wrapper), (get_group),
7702         (group_migrate_connected):
7703         * testsuite/schedulers/Makefile.am:
7704           fix for #147819 (Add some checks in the opt scheduler)
7705
7706 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7707
7708         patch by: Benjamin Otte
7709
7710         * gst/gstelementfactory.c: (__gst_element_details_set):
7711           fix for #147929: running gst-register in non-utf8 locale can cause
7712           invalid registry
7713
7714 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7715
7716         patch by: Wim Taymans
7717
7718         * gst/schedulers/gstoptimalscheduler.c: (group_num_elements),
7719         (group_has_element), (element_get_reachables_func),
7720         (group_migrate_connected):
7721           fix for #147894 (opt scheduler decoupled elements mismanagement)
7722         * testsuite/schedulers/Makefile.am:
7723           testsuite app now passes
7724
7725 2004-07-19  Wim Taymans  <wim@fluendo.com>
7726
7727         * testsuite/schedulers/147819.c: (handoff_identity1),
7728         (handoff_identity2), (main):
7729         * testsuite/schedulers/Makefile.am:
7730         Added testcase for bug 147819
7731
7732 2004-07-19  Wim Taymans  <wim@fluendo.com>
7733
7734         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
7735         (handoff_identity), (main):
7736         * testsuite/schedulers/Makefile.am:
7737         Added testcase for bug 147894
7738
7739 2004-07-16  Wim Taymans  <wim@fluendo.com>
7740
7741         * testsuite/schedulers/142183-2.c: (handoff_identity), (main):
7742         * testsuite/schedulers/142183.c: (handoff_identity), (main):
7743         * testsuite/schedulers/Makefile.am:
7744         Added testsuite for bug 142183 in its two incarnations. Refcount
7745         is not increased for scheduled elements and threadsafe properties
7746         mutexes are not properly unlocked.
7747
7748 2004-07-16  Wim Taymans  <wim@fluendo.com>
7749
7750         * gst/schedulers/gstoptimalscheduler.c: (gst_opt_scheduler_init),
7751         (create_chain), (destroy_chain), (create_group), (destroy_group),
7752         (add_to_group), (merge_groups), (group_elements), (group_inc_link),
7753         (group_dec_link), (gst_opt_scheduler_pad_link),
7754         (group_inc_links_for_element), (group_migrate_connected):
7755         Call group_inc_link with the proper src->sink ordering -- 
7756         break this, and we break sort_chain. patch from wingo for bug
7757         147713.
7758         Partially revert patch 1.89. When adding a loop based element to 
7759         the scheduler, the links to other groups are automatically followed
7760         and incremented. This should not happen because the bin will call
7761         pad_link explicitly for those connection, resulting in them counted 
7762         twice. Results in assertion failure on pipeline cleanup.
7763
7764 2004-07-16  Wim Taymans  <wim@fluendo.com>
7765
7766         * testsuite/schedulers/143777-2.c: (main):
7767         * testsuite/schedulers/147713.c: (handoff_src), (handoff_sink),
7768         (main):
7769         * testsuite/schedulers/Makefile.am:
7770         Added cleanup code to testcase 143777-2.
7771         Added testcase to show bug 147713, does not really show the
7772         deadlock as I can't figure out how to trigger it, but it does
7773         demonstrate bad ordering in the scheduler.
7774
7775 2004-07-16  Thomas Vander Stichele  <thomas at apestaart dot org>
7776
7777         * gst/gstvalue.c: (gst_value_deserialize_fraction):
7778           change strndup to g_strndup.  Fixes #147707
7779
7780 2004-07-16  Thomas Vander Stichele  <thomas at apestaart dot org>
7781
7782         * po/af.po:
7783         * po/az.po:
7784         * po/cs.po:
7785         * po/en_GB.po:
7786         * po/fr.po:
7787         * po/nl.po:
7788         * po/sr.po:
7789         * po/sv.po:
7790         * po/tr.po:
7791         * po/uk.po:
7792           updated translations
7793
7794 2004-07-16  Benjamin Otte  <otte@gnome.org>
7795
7796         * gst/gstvalue.c: (gst_greatest_common_divisor):
7797           use ints and return ints, fractions only use ints, too, so this
7798           avoids accidently casting multiplications to unsigned
7799         (gst_value_lcopy_fraction): it's ints, not uint32
7800         (gst_value_set_fraction): disallow minint, multiplying and negation
7801           are broken with it
7802         (gst_value_fraction_multiply): fix to make large numbers work and get
7803         rid of the assumption that the multiplication of two ints fits an
7804         int64 - dunno if that's true for all systems
7805         * testsuite/caps/Makefile.am:
7806         * testsuite/caps/fraction-multiply-and-zero.c:
7807         (check_multiplication), (check_equal), (zero_test), (main):
7808           add tests for all the stuff above
7809         * testsuite/caps/value_compare.c: (test1):
7810           fix comment
7811         * tests/.cvsignore:
7812         * testsuite/caps/.cvsignore:
7813         * testsuite/debug/.cvsignore:
7814         * testsuite/dlopen/.cvsignore:
7815         * testsuite/states/.cvsignore:
7816           get up to date
7817
7818 2004-07-16  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7819
7820         * docs/manual/bins-api.xml:
7821         * docs/manual/factories.xml:
7822         * docs/manual/helloworld.xml:
7823         * docs/manual/links-api.xml: 
7824           fixes for out of date info, incorrect info and grammar
7825
7826 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7827
7828         * docs/manual/pads.xml:
7829         * docs/manual/pads-api.xml: grammar fix
7830
7831 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7832
7833         * docs/manual/pads-api.xml: typo + grammar fix
7834
7835 2004-07-15  Thomas Vander Stichele  <thomas at apestaart dot org>
7836
7837         * docs/gst/gstreamer-sections.txt:
7838           add new symbols
7839         * docs/gst/tmpl/gstelement.sgml:
7840         * docs/gst/tmpl/gstpad.sgml:
7841         * docs/gst/tmpl/gsttypes.sgml:
7842         * docs/gst/tmpl/gstvalue.sgml:
7843           update docs
7844         * gst/gststructure.c: (gst_structure_set_valist),
7845         (gst_structure_from_abbr), (gst_structure_to_abbr):
7846         * gst/gstvalue.c: (gst_value_compare_double), (gst_type_is_fixed),
7847         (gst_greatest_common_divisor), (gst_value_init_fraction),
7848         (gst_value_copy_fraction), (gst_value_collect_fraction),
7849         (gst_value_lcopy_fraction), (gst_value_set_fraction),
7850         (gst_value_get_fraction_numerator),
7851         (gst_value_get_fraction_denominator),
7852         (gst_value_fraction_multiply), (gst_value_serialize_fraction),
7853         (gst_value_deserialize_fraction),
7854         (gst_value_transform_fraction_string),
7855         (gst_value_transform_string_fraction),
7856         (gst_value_compare_fraction), (_gst_value_initialize):
7857         * gst/gstvalue.h:
7858           adding GstFraction GValue type, get/set, and multiply
7859         * testsuite/caps/Makefile.am:
7860         * testsuite/caps/fraction.c: (test), (main):
7861         * testsuite/caps/string-conversions.c: (main):
7862         * testsuite/caps/value_compare.c: (test1), (main):
7863           add regression tests for GstFraction
7864
7865 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7866         
7867         * docs/manual/init-api.xml: Grammar fix
7868
7869 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7870
7871         * docs/manual/states.xml: Fix inconsistent information
7872
7873 2004-07-15  Thomas Vander Stichele  <thomas at apestaart dot org>
7874
7875         * gst/gstelement.c: (gst_element_set_state):
7876         * gst/gstpad.c: (gst_pad_try_set_caps):
7877         * gst/gststructure.c:
7878         * gst/gstthread.c: (gst_thread_child_state_change):
7879         * gst/gstvalue.c: (gst_value_compare_double):
7880         * gst/gstvalue.h:
7881         * testsuite/parse/parse1.c: (main):
7882           debugging additions and style cleanups
7883
7884 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7885
7886         * docs/manual/states.xml: Grammar fix
7887
7888 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7889
7890         * docs/manual/pads.xml: Grammar fix
7891
7892 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7893
7894         * docs/manual/elements.xml: Fixed image reference
7895
7896 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7897
7898         * docs/manual/goals.xml: Grammar fix
7899
7900 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7901
7902         * docs/manual/motivation.xml:
7903         Bonobo is no longer "emerging" and added sentence regarding tcp plugins
7904
7905 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7906
7907         * docs/manual/motivation.xml: Fix spelling
7908
7909 2004-07-15  Benjamin Otte  <otte@gnome.org>
7910
7911         * gst/gstelement.h: 
7912           Don't GST_ERROR_OBJECT empty strings - Solaris doesn't like NULL
7913           strings.
7914         * gst/gstelement.c (gst_element_class_init):
7915           GError's are boxed, not objects
7916         * gst/gstmarshal.list:
7917           update list for the fixed error signal
7918
7919 2004-07-14  Andy Wingo  <wingo@pobox.com>
7920
7921         * gst/gsttag.c: Add a tag merge func for pointers. The header was
7922         there all along, but the function wasn't. (guile-gstreamer's build
7923         system uses the address of the function -- I wasn't actually
7924         trying to use this.)
7925
7926 2004-07-14  Andy Wingo  <wingo@pobox.com>
7927
7928         * gst/gstpad.c (gst_pad_try_set_caps): Naive link functions (such
7929         as gst_pad_proxy_pad_link) just link to every other pad when they
7930         are called. In the case where the graph has cycles, this will mean
7931         that a call to try_set_caps will recurse. Allow this recursion
7932         and return OK, while we wait for the first try_set_caps to give a
7933         proper return value.
7934         (gst_pad_link_call_link_functions): Since this function is the
7935         only one to set the NEGOTIATING flag on a pad, if the flag is set
7936         it means that the link functions have indirectly recursed. If this
7937         happens, error out to avoid infinite recursion and an eventual
7938         SEGV.
7939         (gst_real_pad_class_init): Remove a crufty GtkObject comment.
7940         (gst_pad_proxy_getcaps): Intersect the result with the template
7941         caps to ensure that the return value is valid.
7942
7943 2004-07-14  Andy Wingo  <wingo@pobox.com>
7944
7945         * gst/gstdata.c (gst_data_is_writable): s/>=/>/. If there is only
7946         one refcount, the calling function is the owner of the buffer.
7947
7948 2004-07-14  Wim Taymans  <wim@fluendo.com>
7949
7950         * gst/schedulers/gstoptimalscheduler.c: (group_dec_link),
7951         (gst_opt_scheduler_pad_link), (group_migrate_connected):
7952         Fix stupid warning when an element is to be migrated but
7953         is already migrated.
7954
7955 2004-07-14  Wim Taymans  <wim@fluendo.com>
7956
7957         * gst/schedulers/gstoptimalscheduler.c: (group_dec_link),
7958         (gst_opt_scheduler_pad_link), (group_migrate_connected):
7959         Make sure that a single non-loop-based element does not 
7960         end up in a group. This fixes the testsuite again.
7961
7962 2004-07-14  Wim Taymans  <wim@fluendo.com>
7963
7964         * gst/schedulers/gstoptimalscheduler.c: (create_group),
7965         (add_to_group), (merge_groups), (schedule_group),
7966         (gst_opt_scheduler_get_wrapper), (group_elements),
7967         (group_dec_link), (gst_opt_scheduler_pad_link),
7968         (group_migrate_connected), (gst_opt_scheduler_pad_unlink),
7969         (gst_opt_scheduler_iterate):
7970         move isolated groups to a new chain.
7971         Emit a warning instead of segfaulting in some error cases.
7972         Fix a bug where the link count between groups was not calculated 
7973         correctly. Fixes #144510.
7974
7975 2004-07-13  Steve Lhomme  <steve.lhomme@free.fr>
7976         * gst/elements/gstfilesrc.c:
7977           Binary files support under Windows now OK
7978       
7979 2004-07-13  Benjamin Otte  <otte@gnome.org>
7980
7981           compatibility fixes for Solaris 8/gcc 2.95
7982         * configure.ac:
7983           include libintl libs in LDFLAGS
7984         * gstvalue.c (gst_value_deserialize_buffer):
7985           cast isxdigit stuff to int to silence compiler warning
7986
7987 2004-07-12  Benjamin Otte  <otte@gnome.org>
7988
7989         * gst/gsttypes.h:
7990           get rid of GST_O_READONLY, GST_FILE_MODE_READ and
7991           GST_FILE_MODE_WRITE, I don't want them in the exported headers. It
7992           just causes support madness
7993         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
7994           make it work without this
7995         * gst/indexers/gstfileindex.c: (_file_index_id_save_entries),
7996         (gst_file_index_commit):
7997           glib IO channels don't want binary mode
7998         * testsuite/bytestream/filepadsink.c: (main):
7999         * testsuite/bytestream/test1.c: (read_param_file):
8000           use "rb" instead of GST_FILE_MODE_READ, it works on POSIX systems
8001
8002 2004-07-12  Benjamin Otte  <otte@gnome.org>
8003
8004         * gst/gstelement.c: (gst_element_class_init),
8005         (gst_element_set_state), (gst_element_set_state_func):
8006           virutalize gst_element_set_state, use set_state member in class
8007           struct that was already added in 0.7 for this.
8008         * gst/gstbin.c: (gst_bin_foreach), (set_kid_state_func), 
8009         (gst_bin_change_state):
8010           make gst_bin_foreach works similar to other foreach functions, plug
8011           memleaks in it. Make functions using it work with the new approach.
8012           Document gst_bin_foreach, so it can be exported if we want to
8013         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_state):
8014           use virtualized set_state to make set_state on bins set the state of
8015           all its children.
8016
8017 2004-07-12  Benjamin Otte  <otte@gnome.org>
8018
8019         * configure.ac:
8020           require valgrind >= 2.1 (fixes Gentoo bug 53967, see
8021           http://bugs.gentoo.org/show_bug.cgi?id=53967)
8022         * gst/gstpad.c: (gst_pad_alloc_buffer):
8023           allow buffer_alloc functions to return NULL and allocate a normal
8024           buffer in that case
8025
8026 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
8027         * gst/elements/gstfilesink.c:
8028         * gst/elements/gstfilesrc.c:
8029         * gst/indexers/gstfileindex.c:
8030         * gst/gsttypes.h:
8031         * testsuite/bytestream/filepadsink.c:
8032         * testsuite/bytestream/test1.c:
8033           Handle binary files under Windows
8034
8035 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
8036         * docs/manual/win32.xml:
8037         * win32/config.h:
8038         * win32/gst-register.vcproj:
8039         * win32/gstreamer.def:
8040           Update to another gettext public build
8041
8042 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
8043         * gst/gstplugin.c:
8044           Fix an impossible C syntax
8045         * win32/config.h:
8046           Disable i18n under Windows for the moment
8047         * win32/gst-register.vcproj:
8048           Use this configuration
8049
8050 2004-07-12  Jan Schmidt  <thaytan@mad.scientis.com>
8051         * docs/manual/quotes.xml:
8052           Keep the quotes file alive
8053         * docs/random/ds/0.9-suggested-changes:
8054           Add the suggestion of including a 'rowstride' as part of video
8055           format caps
8056
8057 2004-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
8058
8059         * gst/gstelement.c: (gst_element_set_state),
8060         (gst_element_change_state):
8061           d'oh.  Set PENDING state correctly before forcing bin to change.
8062         * gst/gststructure.c: (gst_structure_value_get_generic_type),
8063         (gst_structure_parse_fixed_list):
8064         * gst/schedulers/gstoptimalscheduler.c:
8065         (gst_opt_scheduler_state_transition):
8066         * testsuite/states/parent.c: (main):
8067           remove comment now that it's fixed.
8068
8069 2004-07-11  Benjamin Otte  <otte@gnome.org>
8070
8071         * gst/gstclock.h:
8072           GST_SECOND shouldn't cause a conversion to unsigned.
8073         * testsuite/clock/.cvsignore:
8074         * testsuite/clock/Makefile.am:
8075         * testsuite/clock/signedness.c: (main):
8076           make sure it never will again
8077
8078 2004-07-11  Andy Wingo  <wingo@pobox.com>
8079
8080         * gst/gstbin.c (gst_bin_add_func): If we're adding an element
8081         whose state is higher than the bin state, raise the bin state to
8082         ensure that bin state := highest child state.
8083         
8084 2004-07-11  Andy Wingo  <wingo@pobox.com>
8085
8086         * gst/gstbin.c (gst_bin_foreach): New static function. Calls a
8087         procedure on the children of a bin. Assumes that the procedure can
8088         change the set of children.
8089         (set_kid_state_func): New static function.
8090         (gst_bin_change_state): Use gst_bin_foreach to call
8091         set_kid_state_func. Fixes a bug: if a child had a state-change
8092         handler that removes it from the bin, there would be a segfault.
8093         Hopefully it should also work in the case where the state-change
8094         handler on one child adds or removes other children. In any case,
8095         fixes should go to gst_bin_foreach.
8096
8097 2004-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
8098
8099         * gst/gstelement.c: (gst_element_set_state):
8100           compatibility fix for latest plugins release.  Change loop back
8101           to while {}
8102
8103 2004-07-09  Wim Taymans  <wim@fluendo.com>
8104
8105         * gst/gstbin.c: (gst_bin_remove), (gst_bin_dispose):
8106         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_catch),
8107         (gst_thread_main_loop):
8108         Since remove is virtual in GstBin we must not assume the 
8109         elements GList to have anothing useful.
8110         Add some more logging to GstThread and be a bit more paranoid
8111         when resetting the scheduler.
8112         Set the state of the bin to NULL before removing the children.
8113
8114 2004-07-09  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
8115
8116         * testsuite/threads/Makefile.am:
8117         * testsuite/threads/threadg.c:
8118           added test to check if problem when removing all elements from a
8119           GstThread before setting GstThread state to NULL
8120
8121 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8122
8123         * docs/gst/tmpl/gstelement.sgml:
8124         * docs/gst/tmpl/gsttypes.sgml:
8125         * gst/gstbin.c: (gst_bin_change_state):
8126         * gst/gstelement.c: (gst_element_set_state),
8127         (gst_element_change_state):
8128           rework so that for bins we try to set the state on all children
8129           as well even if the bin is in the correct state already.
8130           change while to do so at least one iteration is done.
8131           For regular elements, we fall back to the previous behaviour for
8132           now since we first need a new plugins release.
8133         * testsuite/states/parent.c: (main):
8134           test for this case
8135           Fixes #123774
8136
8137 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8138
8139         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_finalize),
8140         (gst_queue_chain), (gst_queue_get), (gst_queue_handle_src_event),
8141         (gst_queue_release_locks), (gst_queue_change_state),
8142         (gst_queue_set_property):
8143           add proper lock debugging.  Change dispose to finalize, since
8144           we're freeing mutexes and other stuff which should happen only once.
8145
8146 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8147
8148         * docs/gst/tmpl/gstelement.sgml:
8149         * docs/gst/tmpl/gstplugin.sgml:
8150         * docs/gst/tmpl/gsttypes.sgml:
8151         * docs/pwg/building-state.xml:
8152         * gst/elements/gstfakesrc.c: (gst_fakesrc_change_state):
8153         * gst/gstelement.c: (gst_element_change_state):
8154         * gst/gstthread.c: (gst_thread_change_state):
8155           catch wrong state changes in element base class.
8156
8157 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8158
8159         * gst/gstinfo.h:
8160           clean up layout a little.
8161
8162 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8163
8164         * configure.ac:
8165         * testsuite/Makefile.am:
8166         * testsuite/states/Makefile.am:
8167         * testsuite/states/parent.c: (main):
8168           re-enable states testsuite dir.  Add test for state changes and
8169           parent behaviour
8170
8171 2004-07-09  Wim Taymans  <wim@fluendo.com>
8172
8173         * gst/schedulers/gstoptimalscheduler.c:
8174         (gst_opt_scheduler_pad_link), (group_elements_set_visited),
8175         (element_get_reachables_func), (element_get_reachables),
8176         (debug_element), (rechain_group), (group_migrate_connected),
8177         (gst_opt_scheduler_pad_unlink):
8178         Do not try to migrate decoupled elements to a new group since
8179         they are not added to groups.
8180
8181 2004-07-08  Benjamin Otte  <otte@gnome.org>
8182
8183         * gst/gstelement.c: (gst_element_error_func):
8184           make reentrant (= allow removing elements in error handler)
8185
8186 2004-07-08  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8187
8188         * gst/gstpad.c: (gst_pad_event_default_dispatch),
8189         (gst_pad_send_event), (gst_pad_call_chain_function):
8190           events sent to elements below PAUSED cannot be handled, so
8191           don't try to
8192
8193 2004-07-08  Wim Taymans  <wim@fluendo.com>
8194
8195         * gst/schedulers/gstoptimalscheduler.c:
8196         (chain_recursively_migrate_group), (create_group),
8197         (schedule_group), (gst_opt_scheduler_pad_link),
8198         (group_elements_set_visited), (element_get_reachables_func),
8199         (element_get_reachables), (group_can_reach_group), (debug_element),
8200         (rechain_group), (group_migrate_connected),
8201         (gst_opt_scheduler_pad_unlink):
8202         * testsuite/schedulers/Makefile.am:
8203         Implemented group splitting and rechaining.
8204         Fixes 143777 and 143777-2 in the testsuite.
8205
8206 2004-07-08  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8207
8208         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_chain):
8209           extra debugging
8210         * gst/gstevent.h:
8211         * gst/gstinfo.c: (gst_debug_log_default):
8212           print time nicely.  add thread pointer until someone figures out
8213           a completely portable way of getting at thread id's.
8214         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_try),
8215         (_invent_event), (gst_pad_pull), (gst_pad_event_default_dispatch),
8216         (gst_pad_call_chain_function):
8217           extra debugging
8218         * gst/schedulers/gstoptimalscheduler.c:
8219         (get_group_schedule_function), (loop_group_schedule_function),
8220         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
8221         (pad_clear_queued), (gst_opt_scheduler_iterate):
8222           rename BUFPEN and friends to DATAPEN since that's what they are.
8223
8224 2004-07-07  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8225
8226         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_chain):
8227         * gst/gstbuffer.h:
8228         * gst/gstpad.c:
8229           cleanups and debugging
8230
8231 2004-07-07  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8232
8233         * configure.ac:
8234         * gst/gstvalue.c: (gst_value_compare_enum),
8235         (gst_value_serialize_enum), (gst_value_deserialize_enum),
8236         (gst_value_can_compare), (gst_value_compare):
8237         * testsuite/Makefile.am:
8238         * testsuite/enumcaps/Makefile.am:
8239         * testsuite/enumcaps/enumcaps.c:
8240           Fix enum serialization, deserialization, comparison in caps, add
8241           a test to ensure that this continues working in the future.
8242
8243 2004-07-06  David Schleef  <ds@schleef.org>
8244
8245         * gst/gstcaps.c: (gst_caps_save_thyself), (gst_caps_load_thyself):
8246         Fix memleak.
8247
8248 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8249
8250         * gst/gstplugin.c: (gst_plugin_check_file), (gst_plugin_load_file):
8251         * gst/gstplugin.h:
8252         * gst/registries/gstxmlregistry.c:
8253         (plugin_times_older_than_recurse), (plugin_times_older_than),
8254         (gst_xml_registry_parse_padtemplate):
8255           only rebuild registry when actual plugins have a newer time than
8256           the registry.  Fixes #145520
8257
8258 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8259
8260         * docs/manual/manual.xml:
8261         * docs/manual/win32.xml:
8262           add chapter on win32 building.  fixes #142422
8263
8264 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8265
8266         patch by: Sebastien Cote <sc5 at hermes.usherb.ca>
8267
8268         * gst/autoplug/gstspider.c: (gst_spider_init),
8269         (gst_spider_dispose):
8270           fix spider memleaks.  fixes #137863
8271
8272 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8273
8274         patch by: Joe Marcus Clarke <marcus at freebsd dot org>
8275
8276         * gst/schedulers/gstoptimalscheduler.c:
8277         (gst_opt_scheduler_pad_unlink):
8278           fix SIGBUS error, fixes #145338
8279
8280 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8281
8282         * gst/gstobject.c: (gst_object_replace):
8283         * gst/gstscheduler.c: (gst_scheduler_get_clock):
8284         * gst/gstsystemclock.c: (gst_system_clock_obtain):
8285           clean up clock lifecycle.  Fixes #109831
8286
8287 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
8288
8289         * po/LINGUAS:
8290         * po/cs.po:
8291           added Czech translation (Miloslav Trmac)
8292
8293 2004-07-04  David Schleef  <ds@schleef.org>
8294
8295         * tools/Makefile.am:
8296         * tools/gst-xmlinspect.1.in:  Add man page. (bug #140219)
8297
8298 2004-07-04  David Schleef  <ds@schleef.org>
8299
8300         * common/m4/gst-doc.m4: Check for docbook2html 0.6.10 (bug #139909)
8301
8302 2004-07-04  Thomas Vander Stichele  <thomas at apestaart dot org>
8303
8304         * gst/gstbin.c: (gst_bin_restore_thyself):
8305           chain to parent restore so the bins get restored correctly
8306           in the editor
8307
8308 2004-07-03  David Schleef  <ds@schleef.org>
8309
8310         * gst/gstcaps.c: (gst_caps_save_thyself), (gst_caps_load_thyself):
8311         Actually do something in these functions, like before the big
8312         caps change.  (bug #145137)
8313
8314 2004-07-03  Thomas Vander Stichele  <thomas at apestaart dot org>
8315
8316         * gst/gstelement.c: (gst_element_get_compatible_pad_template),
8317         (gst_element_get_compatible_pad_filtered):
8318         * gst/gstthread.c: (gst_thread_main_loop):
8319           more debugging
8320
8321 2004-07-02  David Schleef  <ds@schleef.org>
8322
8323         * gst/gstinfo.h: wrap #pragmas in #ifdefs for the correct compiler
8324         * gst/gstobject.h:
8325         * gst/gstparse.h:
8326         * gst/gsttrace.h:
8327         * gst/gstxml.h:
8328
8329 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
8330
8331         * gst/gstpad.c: (gst_pad_check_schedulers),
8332         (gst_pad_can_link_filtered), (gst_pad_link_filtered),
8333         (gst_pad_link_prepare):
8334           revert until testsuite is fixed
8335
8336 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
8337
8338         * testsuite/Makefile.am:
8339         * testsuite/caps/filtercaps.c: (main):
8340         * testsuite/clock/clock1.c: (main):
8341         * testsuite/dynparams/dparamstest.c: (gst_dptest_chain), (main):
8342           fix some more tests
8343
8344 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
8345
8346         * testsuite/cleanup/cleanup1.c: (create_pipeline):
8347         * testsuite/cleanup/cleanup2.c: (create_pipeline):
8348         * testsuite/cleanup/cleanup4.c: (main):
8349           fix testsuite
8350
8351 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
8352
8353         * libs/gst/control/control.c:
8354         * libs/gst/control/dparam.c:
8355         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_get_type):
8356         * libs/gst/control/dparammanager.c:
8357         * libs/gst/control/dparammanager.h:
8358         * testsuite/dynparams/Makefile.am:
8359         * testsuite/dynparams/dparamstest.c: (gst_dptest_base_init),
8360         (gst_dptest_change_state), (gst_dptest_chain), (main):
8361           fix testcase for dparams
8362           add debugging category
8363
8364 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
8365
8366         * testsuite/Rules:
8367           change path
8368
8369 2004-07-02  Benjamin Otte  <otte@gnome.org>
8370
8371         * tests/.cvsignore:
8372         * tests/Makefile.am:
8373         * tests/mass_elements.c: (gst_get_current_time), (main):
8374           add simple benchmark to test various speeds of fakesrc ! identity !
8375           identity ! ... ! fakesink.
8376           Usage: mass_elements [num_identities] [num_buffers]
8377           If not specified they default to 1000.
8378
8379 2004-07-02  Benjamin Otte  <otte@gnome.org>
8380
8381         * gst/gstpad.c: (gst_pad_check_schedulers),
8382         (gst_pad_can_link_filtered), (gst_pad_link_filtered),
8383         (gst_pad_link_prepare):
8384           check that pads that get linked belong to the same manager. The old
8385           code allowed linking elements before putting them into bins, so it
8386           worked to link them and then put them in different threads, which
8387           lead to weird behaviour.
8388           Since this effectively disallows linking elements before putting
8389           them in a bin, some applications might not work after this and error
8390           out. If these applications are too critical, we might need to revert
8391           that patch. Please test this before the next release...
8392
8393 2004-06-28  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8394
8395         * gst/gstpad.c: (gst_pad_get_caps):
8396           throw an error if the getcaps function does not return a subset of
8397           the template caps.
8398         * libs/gst/bytestream/filepad.c: (gst_file_pad_chain):
8399           make disconts without position info an error in debugging
8400         * tests/spidey_bench.c: (handoff), (main):
8401           don't count first try when averaging
8402
8403 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
8404
8405         * gst/gstplugin.c: (gst_plugin_load_file):
8406           figure out problem with dynamic test
8407
8408 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
8409
8410         * docs/gst/Makefile.am:
8411           fix docs build
8412
8413 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
8414
8415         * po/POTFILES.in:
8416         * po/af.po:
8417         * po/az.po:
8418         * po/en_GB.po:
8419         * po/fr.po:
8420         * po/nl.po:
8421         * po/sr.po:
8422         * po/sv.po:
8423         * po/tr.po:
8424         * po/uk.po:
8425         * tools/gst-register.c: (plugin_added_func), (main):
8426           i18n-ize -register, fix plural
8427
8428 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
8429
8430         * gst/elements/gstidentity.c: (gst_identity_class_init),
8431         (gst_identity_init), (gst_identity_chain),
8432         (gst_identity_set_property), (gst_identity_get_property):
8433         * gst/elements/gstidentity.h:
8434           check for perfect stream
8435
8436 2004-06-25  Thomas Vander Stichele  <thomas at apestaart dot org>
8437
8438         * gst/elements/gstidentity.c: (gst_identity_chain):
8439           print offset_end
8440
8441 2004-06-25  Thomas Vander Stichele  <thomas at apestaart dot org>
8442
8443         * docs/gst/Makefile.am:
8444         * docs/gst/gstreamer-docs.sgml:
8445           doc fixes
8446
8447 2004-06-24  David Schleef  <ds@schleef.org>
8448
8449         * autogen.sh:  Remove call to env, since the buildbot isn't
8450         broken anymore.
8451
8452 2004-06-24  Wim Taymans  <wim@fluendo.com>
8453
8454         * gst/elements/Makefile.am:
8455         * gst/elements/gstelements.c:
8456         * gst/elements/gstmultifdsink.c: (gst_multifdsink_base_init),
8457         (gst_multifdsink_class_init), (gst_multifdsink_init),
8458         (gst_multifdsink_add), (gst_multifdsink_remove),
8459         (gst_multifdsink_clear), (gst_multifdsink_chain),
8460         (gst_multifdsink_set_property), (gst_multifdsink_get_property):
8461         * gst/elements/gstmultifdsink.h:
8462         Added an element that writes to multiple filedescriptors at once.
8463
8464 2004-06-24  Benjamin Otte  <otte@gnome.org>
8465
8466         * gst/parse/grammar.y:
8467           don't try to link elements before they have been added to bins
8468
8469 2004-06-24  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8470
8471         * libs/gst/bytestream/filepad.c: (gst_file_pad_available),
8472         (gst_file_pad_get_length):
8473         * libs/gst/bytestream/filepad.h:
8474           add 2 new functions
8475
8476 2004-06-22  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
8477
8478         * docs/gst/gstreamer-sections.txt:
8479         remove from docs, the define that Benjamin removed from gstelement.h
8480
8481 2004-06-22  Benjamin Otte  <otte@gnome.org>
8482
8483         * gst/gstelement.h:
8484           remove define that referenced a nonexisting GstElement struct member
8485
8486 2004-06-20  Benjamin Otte  <otte@gnome.org>
8487
8488         * gst/gstdata.c: (gst_data_is_writable):
8489           whoops, return values were wrong, so writable data was marked as
8490           non-writable and vice versa. (fixes #143953, spotted by Francis
8491           Labonte)
8492           Shows how rarely we need to copy data ;)
8493
8494 2004-06-20  Benjamin Otte  <otte@gnome.org>
8495
8496         * testsuite/schedulers/.cvsignore:
8497         * testsuite/schedulers/Makefile.am:
8498         * testsuite/schedulers/143777-2.c: (main):
8499           add test for opt breakage in bug #143777
8500
8501 2004-06-20  Benjamin Otte  <otte@gnome.org>
8502
8503         * gst/gstpad.c: (gst_pad_call_chain_function):
8504           check for if we were unlinked while inside the chainfunction (fixes
8505           entrygthread having issues with #143777)
8506         * testsuite/schedulers/143777.c: (main):
8507         * testsuite/schedulers/Makefile.am:
8508           add a test for that fix
8509
8510 2004-06-20  Benjamin Otte  <otte@gnome.org>
8511
8512         * gst/gstvalue.c: (gst_value_set_int_range):
8513           test that start is smaller then end
8514         * libs/gst/bytestream/Makefile.am:
8515         * libs/gst/bytestream/filepad.c: 
8516         * libs/gst/bytestream/filepad.h:
8517           add GstFilePad - a pad that behaves like a FILE*
8518         * testsuite/bytestream/.cvsignore:
8519         * testsuite/bytestream/Makefile.am:
8520         * testsuite/bytestream/filepadsink.c: 
8521           test for the GstFilePad
8522
8523 2004-06-18  Thomas Vander Stichele  <thomas at apestaart dot org>
8524
8525         * gst/elements/gstidentity.c: (gst_identity_class_init),
8526         (gst_identity_init), (gst_identity_set_clock),
8527         (gst_identity_chain), (gst_identity_set_property),
8528         (gst_identity_get_property):
8529         * gst/elements/gstidentity.h:
8530         * gst/gstclock.c: (gst_clock_id_wait):
8531           add a "sync" property to sync to the clock
8532
8533 2004-06-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8534
8535         * gst/gstelementfactory.c: (gst_element_factory_create):
8536           make the freakin "elementfactory bla has no type" message more
8537           useful. So we actually can do something when someone shows up
8538           complaining about it.
8539
8540 2004-06-15  Johan Dahlin  <johan@gnome.org>
8541
8542         * tools/gst-inspect.c (main): Fallback to plugin if no element is
8543         found. This matches the old behavior better. Thanks to Thomas for
8544         pointing out.
8545
8546 2004-06-14  David Schleef  <ds@schleef.org>
8547
8548         * gst/gstcpu.c: (gst_cpuid_i386): Fix problem when using
8549         -fomit-frame-pointer.  Appears to generate correct code in
8550         other cases as well.
8551
8552 2004-06-14  Johan Dahlin  <johan@gnome.org>
8553
8554         * tools/gst-inspect.c (main): Add two new command line options: -a
8555         to print all elements and -n to print the name on each line. Also
8556         fix some error reporting.
8557         (main): Simplify, remove -n and always print names if -a is specified
8558
8559 2004-06-13  Steve Lhomme  <steve.lhomme@free.fr>
8560
8561         * win32/gstconfig.h:
8562         * win32/GSTreamer.vcproj:
8563         * win32/Makefile:
8564         * gst/gstconfig.h.in:
8565         * gst/gst.h:
8566         * gst/gstbin.h:
8567         * gst/gstelement.h:
8568         * gst/gstevent.h:
8569         * gst/gstobject.h:
8570         * gst/gstpad.h:
8571         * docs/gst/gstreamer-sections.txt:
8572         * docs/gst/tmpl/gstconfig.sgml:
8573           rename GSTREAMER_EXPORT(S) to GST_EXPORT(S)
8574
8575 2004-06-13  Jan Schmidt  <thaytan@mad.scientist.com>
8576         * docs/gst/gstreamer-sections.txt:
8577         * docs/gst/tmpl/gstconfig.sgml:
8578         Add the GSTREAMER_EXPORT macro to the docs
8579
8580 2004-06-13  Jan Schmidt  <thaytan@mad.scientist.com>
8581
8582         * tools/gst-compprep.c: (handle_xmlerror), (main):
8583         Add a check for the version that introduced SetStructuredError to fix
8584         the build on FC1
8585
8586 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8587
8588         * win32/msvc71.sln:
8589         * win32/testsuite/:
8590           prepare to compile the testsuite with MSVC
8591
8592 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8593
8594         * docs/manual/win32.xml:
8595           attempt to transform the Win32 README into an XML doc
8596
8597 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8598
8599         * gst/gst.c:
8600         * gst/gstbin.*:
8601         * gst/config.h.in:
8602         * gst/gstelement.*:
8603         * gst/gstevent.h:
8604         * gst/gstobject.*:
8605         * gst/gstpad.h:
8606         * tools/gst-register.c:
8607         * win32/gstreamer.def:
8608           extern symbols are now exported for the Windows DLL
8609
8610 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8611
8612         * gst/gstinfo.h:
8613           fix a problem to enable/disable DEBUG under MSVC
8614
8615 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8616
8617         * win32/:
8618           enable more debug code in DEBUG build
8619
8620 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
8621
8622         * win32/config.h:
8623         * gst/gst-i18n-app.h:
8624           enable NLS under Windows
8625
8626 2004-06-12  Jan Schmidt  <thaytan@mad.scientist.com>
8627         * tools/gst-compprep.c: (handle_xmlerror), (main):
8628           Make an error that baffled me a bit clearer
8629
8630 2004-06-12  Thomas Vander Stichele  <thomas at apestaart dot org>
8631
8632         * gst/gstqueue.c:
8633           don't use g_queue_get_length () because it's 2.4, use ->length
8634
8635 2004-06-11  Steve Lhomme  <steve.lhomme@free.fr>
8636
8637         reviewed by Benjamin Otte  <in7y118@public.uni-hamburg.de>
8638
8639         * tools/gst-inspect.c: (print_signal_info):
8640           don't free random data twice. (fixes #144185)
8641
8642 2004-06-11  Thomas Vander Stichele  <thomas at apestaart dot org>
8643
8644         * gst/gstqueue.c:
8645         * gst/gstqueue.h:
8646           fix removing from the wrong queue on event timeout
8647           fix disposing of the event queue by casting correctly
8648           add mutexes for handling the event queue
8649           someone was sleeping when fixing queue last time around :)
8650
8651 2004-06-10  Johan Dahlin  <johan@gnome.org>
8652
8653         * gst/gst.c (gst_init_check_with_popt_table): Do not fail on
8654         errors, like gtk. It makes it more useful in bindings.  Fixes #141692.
8655
8656 2004-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
8657
8658         * docs/random/gdp:
8659         * libs/gst/dataprotocol/dataprotocol-test.c: (buffer_test):
8660         * libs/gst/dataprotocol/dataprotocol.c:
8661         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
8662         (gst_dp_buffer_from_header):
8663         * libs/gst/dataprotocol/dataprotocol.h:
8664         * libs/gst/dataprotocol/dp-private.h:
8665           rev version to 0.1, add buffer flags and copy them
8666
8667 2004-06-09  Johan Dahlin  <johan@gnome.org>
8668
8669         * gst/gstbuffer.c (gst_buffer_default_copy): Don't forget to merge
8670         the flags from the buffer we're copying.
8671
8672 2004-06-09  Wim Taymans  <wim@fluendo.com>
8673
8674         * gst/elements/gstfakesink.c: (gst_fakesink_chain):
8675         * gst/elements/gstidentity.c: (gst_identity_init),
8676         (gst_identity_chain):
8677         Print more buffer info in fakesink.
8678         Make identity output similar to fakesink.
8679
8680 2004-06-07  Daniel Gazard  <dany42@free.fr>
8681
8682         reviewed by Benjamin Otte  <otte@gnome.org>
8683
8684         * configure.ac:
8685           fix cross compiling not working. (fixes #143741)
8686
8687 2004-06-07  Benjamin Otte  <otte@gnome.org>
8688
8689         * gst/gstelement.c: (gst_element_set_time_delay):
8690           add failure check
8691         * gst/gstinfo.h:
8692           put brackets around macro arguments of GST_TIME_ARGS, add note to
8693           move it to correct header in 0.9
8694
8695 2004-06-07  Benjamin Otte  <otte@gnome.org>
8696
8697         * gst/indexers/gstfileindex.c: (gst_file_index_get_writer_id),
8698         (gst_file_index_load), (_file_index_id_save_entries),
8699         (gst_file_index_commit), (gst_file_index_add_association),
8700         (gst_file_index_add_entry), (gst_file_index_get_assoc_entry),
8701         (gst_file_index_plugin_init):
8702           make debugging use a default category
8703
8704 2004-06-06  David Moore  <dcm@acm.org>
8705
8706         reviewed by Benjamin Otte  <otte@gnome.org>
8707
8708         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init),
8709         (gst_fdsrc_change_state):
8710           reset offset counter when going READY => PAUSED. (fixes #142903)
8711
8712 2004-06-06  ed@catmur.co.uk
8713
8714         reviewed by Benjamin Otte  <otte@gnome.org>
8715
8716         * gst/registries/gstxmlregistry.c:
8717         (gst_xml_registry_rebuild_recurse):
8718           don't rely on g_dir_open to figure out if a file is a directory, use
8719           explicit G_TEST_IS_DIR. Reiserfs4 allows opening files as
8720           directories. (fixes #142850)
8721
8722 2004-06-06  Benjamin Otte  <otte@gnome.org>
8723
8724         * gst/gstqueue.c: (gst_queue_dispose), (gst_queue_change_state):
8725           fix memory leaks (fixes #142795). Initial patch by Sebastien Cote
8726         * libs/gst/bytestream/adapter.c:
8727         * libs/gst/bytestream/adapter.h:
8728           fix copyright in header and typo in debugging category name
8729
8730 2004-06-05  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8731
8732         * configure.ac:
8733           bump nano to cvs
8734
8735 === release 0.8.3 ===
8736
8737 2004-06-05  Thomas Vander Stichele  <thomas at apestaart dot org>
8738
8739         * configure.ac:
8740           update libtool versioning
8741           do a new release
8742         * docs/gst/tmpl/gstelement.sgml:
8743         * docs/gst/tmpl/gsttypes.sgml:
8744         * gst/gstinfo.c: (_gst_debug_init):
8745           put back GST_CAT_DATAFLOW to fix API breakage
8746
8747 2004-06-04  David Schleef  <ds@schleef.org>
8748
8749         * autogen.sh: Add a temporary 'env' to test buildbot problems.
8750
8751 2004-06-04  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8752
8753         * configure.ac:
8754           bump nano to cvs
8755
8756 === release 0.8.2 ===
8757
8758 2004-06-03  Thomas Vander Stichele  <thomas at apestaart dot org>
8759
8760         * gst/gst.c: (parse_debug_list), (gst_init_check_with_popt_table):
8761           check GST_DEBUG environment variable which is parsed the same way
8762           as --gst-debug=
8763
8764 2004-05-28  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8765
8766         * gst/elements    : gstaggregator.c gstfakesink.c gstfakesrc.c
8767                             gstmd5sink.c gstshaper.c gsttee.c
8768                             gsttypefindelement.c
8769         * gst/schedulers  : gstbasicscheduler.c gstoptimalscheduler.c
8770
8771           - removing trailing commas at end of enums
8772             it is correct C99 code but C90 compilers would complain
8773             (AIX, Forte, ...)
8774             ('should' fix #143290, at least partially)
8775
8776 2004-05-27  Wim Taymans  <wim@fluendo.com>
8777
8778         * gst/schedulers/gstoptimalscheduler.c: (remove_from_chain),
8779         (chain_group_set_enabled), (create_group), (add_to_group),
8780         (merge_groups), (setup_group_scheduler), (group_elements),
8781         (gst_opt_scheduler_iterate), (gst_opt_scheduler_show):
8782         Don't try to follow the pad connections with other groups
8783         when a loop based element is added to the scheduler because
8784         the bin will inform the scheduler about the pad links a little
8785         later.
8786
8787 2004-05-27  Wim Taymans  <wim@fluendo.com>
8788
8789         * gst/schedulers/gstoptimalscheduler.c: (add_to_chain),
8790         (remove_from_chain), (chain_group_set_enabled),
8791         (setup_group_scheduler), (group_element_set_enabled),
8792         (gst_opt_scheduler_state_transition), (gst_opt_scheduler_iterate),
8793         (gst_opt_scheduler_show):
8794         Elements without a group can do a state change as well, just wait
8795         with the setup of the scheduling function when it is added to a
8796         chain.
8797
8798 2004-05-27  Wim Taymans  <wim@fluendo.com>
8799
8800         * gst/schedulers/gstoptimalscheduler.c: (add_to_chain),
8801         (remove_from_chain), (chain_group_set_enabled), (add_to_group),
8802         (merge_groups), (setup_group_scheduler),
8803         (group_inc_links_for_element), (gst_opt_scheduler_iterate),
8804         (gst_opt_scheduler_show):
8805         Fixes to maintain internal consistency of the scheduler data
8806         structures. 
8807          - adding an enabled group to a chain should increment the
8808            number of enabled elements in that chain.
8809          - removing an enabled group from a chain could disable the
8810            chain.
8811          - removing a disabled group from a chain could enable the
8812            chain.
8813          - add g_assert when internal inconsistency is detected.
8814          - adding an element to a group could increase the number of
8815            links this group has with other groups.
8816          - merging two groups also merges the chains.
8817          - also show group links in the _show method.
8818            
8819
8820 2004-05-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8821
8822         * gst/gstcaps.c: (gst_caps_structure_simplify):
8823           don't print error messages when there is no error
8824         * gst/gstvalue.c: (gst_value_compare_int_range):
8825           compare the second value, too
8826         * testsuite/caps/Makefile.am:
8827         * testsuite/caps/random.c: (assert_on_error), (main):
8828           add tests to make sure the two things above are checked for
8829
8830 2004-05-24  Thomas Vander Stichele  <thomas at apestaart dot org>
8831
8832         * configure.ac:
8833         * libs/gst/dataprotocol/Makefile.am:
8834         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_caps):
8835         * libs/gst/dataprotocol/dataprotocol.h:
8836           wrap header in GST_ENABLE_NEW.  make code use it
8837
8838 2004-05-23  Johan Dahlin  <johan@gnome.org>
8839
8840         * tools/gst-inspect.c (main): Cleanup most parts of it, don't be
8841         so verbose and print GstElement signal names all the time.
8842
8843 2004-05-22  David Schleef  <ds@schleef.org>
8844
8845         * gst/registries/gstxmlregistry.c:
8846         (gst_xml_registry_parse_padtemplate): Fix warning on OS X.
8847         (bug #142957)
8848
8849 2004-05-22  Thomas Vander Stichele  <thomas at apestaart dot org>
8850
8851         * configure.ac:
8852           scrub cflags for glib2 so gcc doesn't complain when glib is in
8853           /usr/local
8854
8855 2004-05-21  Johan Dahlin  <johan@gnome.org>
8856
8857         * gst/gstcpu.c (gst_cpuid_i386): Protect some gcc asm stuff with
8858         __GNUC__, patch from Brian Cameron, fixes bug #142804
8859
8860 2004-05-20  David Schleef  <ds@schleef.org>
8861
8862         * gst/gstindex.c: (gst_index_compare_func): Fix overflows in
8863         comparison code.  (bug #142819)
8864
8865 2004-05-20  Wim Taymans  <wim@fluendo.com>
8866
8867         * gst/gstbuffer.c: (gst_buffer_default_copy):
8868         * gst/gstbuffer.h:
8869         Added Comment to a flag.
8870         copy relevant flags in _buffer_copy.
8871
8872 2004-05-20  Thomas Vander Stichele  <thomas at apestaart dot org>
8873
8874         reviewed by: Wim Taymans <wim at fluendo dot com>
8875
8876         * gst/gstbuffer.h:
8877           add GST_BUFFER_IN_CAPS buffer flag
8878         * gst/gststructure.c: (gst_structure_value_get_generic_type),
8879         (gst_structure_parse_any_list), (gst_structure_parse_list),
8880         (gst_structure_parse_fixed_list), (gst_structure_parse_value):
8881         * gst/gstvalue.c: (gst_value_serialize_any_list),
8882         (gst_value_transform_any_list_string),
8883         (gst_value_list_prepend_value), (gst_value_list_append_value),
8884         (gst_value_list_get_size), (gst_value_list_get_value),
8885         (gst_value_transform_list_string),
8886         (gst_value_transform_fixed_list_string),
8887         (gst_value_serialize_list), (gst_value_serialize_fixed_list),
8888         (gst_value_deserialize_fixed_list), (gst_type_is_fixed),
8889         (_gst_value_initialize):
8890         * gst/gstvalue.h:
8891           add a GST_TYPE_FIXED_LIST which is fixed by definition and uses
8892           < , > as a format.
8893         * testsuite/caps/string-conversions.c: (main):
8894           add regression tests for < >
8895
8896 2004-05-20  Johan Dahlin  <johan@gnome.org>
8897
8898         * docs/gst/Makefile.am (all-local): Re-add
8899
8900 2004-05-20  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
8901
8902         * docs/gst/Makefile.am:
8903         * docs/gst/gstreamer-docs.sgml:
8904         * docs/libs/Makefile.am:
8905         * docs/libs/gstreamer-libs-docs.sgml:
8906           fix distcheck issues
8907
8908 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
8909
8910         * libs/gst/dataprotocol/Makefile.am:
8911           add to autotest
8912
8913 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
8914
8915         * libs/gst/dataprotocol/Makefile.am:
8916         * libs/gst/dataprotocol/dataprotocol.c:
8917         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
8918         (gst_dp_packet_from_event), (gst_dp_event_from_packet):
8919         * libs/gst/dataprotocol/dp-private.h:
8920           use GST macros to read/write fixed length ints
8921           add some more asserts
8922
8923 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
8924
8925         * docs/libs/gstreamer-libs-docs.sgml:
8926         * docs/libs/gstreamer-libs-sections.txt:
8927           remove idct and putbits
8928         * configure.ac:
8929         * docs/libs/tmpl/gstdataprotocol.sgml:
8930         * libs/gst/Makefile.am:
8931         * libs/gst/dataprotocol/Makefile.am:
8932         * libs/gst/dataprotocol/dataprotocol-test.c: (conversion_test),
8933         (buffer_test), (caps_test), (event_test), (main):
8934         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_crc),
8935         (gst_dp_dump_byte_array), (gst_dp_init),
8936         (gst_dp_header_payload_length), (gst_dp_header_payload_type),
8937         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
8938         (gst_dp_packet_from_event), (gst_dp_buffer_from_header),
8939         (gst_dp_caps_from_packet), (gst_dp_event_from_packet),
8940         (gst_dp_validate_header), (gst_dp_validate_payload),
8941         (gst_dp_validate_packet), (plugin_init):
8942         * libs/gst/dataprotocol/dataprotocol.h:
8943         * libs/gst/dataprotocol/dp-private.h:
8944           add dataprotocol
8945
8946 2004-05-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8947
8948         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
8949           fix int variable deserialization and add a helper so we can actually
8950           debug this.
8951
8952 2004-05-18  David Schleef  <ds@schleef.org>
8953
8954         * testsuite/debug/commandline.c: (main): Call ./commandline, not
8955           argv[0].  Calling yourself is probably not the best way to
8956           construct a test like this, btw.
8957
8958 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8959
8960         * gst/gstbin.c: (gst_bin_iterate_func), (gst_bin_iterate):
8961           don't claim to be more intelligent than a scheduler when the
8962           scheduler claims the pipeline is stopped
8963         * gst/schedulers/entryscheduler.c: (safe_cothread_switch),
8964         (safe_cothread_destroy),
8965         (gst_entry_scheduler_remove_all_cothreads),
8966         (gst_entry_scheduler_reset), (_remove_cothread),
8967         (gst_entry_scheduler_state_transition):
8968           hold off cothread destruction if we're not in main cothread
8969         * configure.ac:
8970         * testsuite/Makefile.am:
8971           add new test dir
8972         * testsuite/schedulers/.cvsignore:
8973         * testsuite/schedulers/Makefile.am:
8974           add tests
8975         * testsuite/schedulers/relink.c: (cb_handoff), (main):
8976           check relinking and adding/removing elements from a running pipeline
8977         * testsuite/schedulers/unlink.c: (cb_handoff), (main):
8978           check unlinking in a running pipeline
8979         * testsuite/schedulers/unref.c: (cb_handoff), (main):
8980           check unreffing a running pipeline
8981         * testsuite/schedulers/useless_iteration.c: (main):
8982           check iterating a pipeline that contains running threads works
8983
8984 2004-05-18  David Schleef  <ds@schleef.org>
8985
8986         * docs/gst/Makefile.am: Add all-local target for when HAVE_GTK_DOC
8987           is false.
8988
8989 2004-05-18  Wim Taymans  <wim@fluendo.com>
8990
8991         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
8992         (setup_group_scheduler), (gst_opt_scheduler_pad_link):
8993         Fixed an error introduced with patch for 1.63. When setting
8994         a get based element as the entry point in a group, make sure
8995         to mark the group as GET based.
8996
8997 2004-05-18  Wim Taymans  <wim@fluendo.com>
8998
8999         * gst/schedulers/gstoptimalscheduler.c: (create_group),
9000         (setup_group_scheduler), (loop_group_schedule_function),
9001         (gst_opt_scheduler_pad_link):
9002         Added some more debug info and fixed a bug where the group
9003         type was set to LOOP but it was in fact unknown.
9004
9005 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9006
9007         * gst/schedulers/entryscheduler.c: (gst_entry_scheduler_reset):
9008           make resetting scheduler work twice in a row
9009
9010 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9011
9012         * gst/gstvalue.c: (gst_strtoll), (CREATE_SERIALIZATION),
9013         (CREATE_USERIALIZATION), (_gst_value_initialize),
9014         (gst_value_compare_float), (gst_value_serialize_float),
9015         (gst_value_deserialize_float), (gst_value_compare_enum),
9016         (gst_value_serialize_enum), (gst_value_deserialize_enum):
9017           add serialization and comparison functions for long, int64, enum and
9018           float values
9019         * gst/gstvalue.c: (gst_value_serialize), (gst_value_deserialize):
9020           use best serialization function in type hierarchy instead of only a
9021           matching one. This is required for enums to work.
9022         * gst/parse/grammar.y:
9023           use gst_caps_deserialize
9024         * testsuite/parse/Makefile.am:
9025           parse1 now works
9026         * testsuite/parse/parse1.c: (main):
9027           remove aggregator check, aggregator is broken, this test works now
9028           but fails because of bug #138012
9029         * testsuite/parse/parse2.c: (main):
9030           s/xvideosink/xvimagesink - this test looks a lot like we should
9031           disable it
9032
9033 2004-05-13  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9034
9035         * gst/gstelement.c: (gst_element_class_init):
9036           whoops, store the signal id correctly
9037         * gst/schedulers/gstbasicscheduler.c:
9038         (gst_basic_scheduler_chain_wrapper):
9039           detect infinfinfinfinfinf^Cinite loops in chain wrapper when the
9040           chain function isn't linked
9041
9042 2004-05-13  Jan Schmidt  <thaytan@mad.scientist.com>
9043         * configure.ac:
9044         Add $GST_PKG_CFLAGS back into GST_INT_CFLAGS so I have large file
9045         support until we decide where the flags should be used
9046         * gst/elements/gstfilesrc.c: (gst_filesrc_srcpad_query):
9047         Use GST_FORMAT_BYTES when GST_FORMAT_DEFAULT is passed
9048         * gst/gstpad.c: (gst_pad_link_call_link_functions):
9049         Output refused caps in the debug info
9050
9051 2004-05-13  Thomas Vander Stichele  <thomas at apestaart dot org>
9052
9053         * gst/elements/gstidentity.c: (gst_identity_chain):
9054           add duration debug
9055         * gst/gstinfo.c: (gst_debug_log_default):
9056           add timestamp
9057
9058 2004-05-13  Benjamin Otte  <otte@gnome.org>
9059
9060         * gst/gstpipeline.c: (gst_pipeline_dispose),
9061         (gst_pipeline_change_state):
9062           call gst_scheduler_reset on dispose (fixes #141416)
9063
9064 2004-05-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9065
9066         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
9067           compute mapsize correctly
9068         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
9069           use correct datatypes when calling a varargs function
9070         * gst/elements/gsttypefindelement.c: (stop_typefinding):
9071           push a DISCONT event as first thing
9072         * gst/gst_private.h:
9073         * gst/gstinfo.c: (_gst_debug_init):
9074           remove GST_DATAFLOW debugging category
9075         * gst/gstbin.c: (gst_bin_iterate):
9076           use GST_SCHEDULING category
9077         * gst/gstpad.c: (gst_pad_get_type), (_invent_event),
9078         (gst_pad_push), (gst_pad_pull), (gst_pad_call_chain_function),
9079         (gst_pad_call_get_function):
9080           add GST_DATAFLOW to easily track flow of buffers or events.
9081         * gst/gstqueue.c: (gst_queue_get_type),
9082         (gst_queue_handle_pending_events), (gst_queue_chain),
9083         (gst_queue_get), (gst_queue_handle_src_event):
9084           use own static debugging category GST_DATAFLOW for dataflow,
9085           use DEBUG category for showing which path events go, use LOG
9086           category for buffers.
9087
9088 2004-05-10  David Schleef  <ds@schleef.org>
9089
9090         * docs/gst/gstreamer-sections.txt: Add gst_element_no_more_pads.
9091
9092 2004-05-10  David Schleef  <ds@schleef.org>
9093
9094         * docs/gst/Makefile.am: Dear gtk-doc, please print out the unused
9095         symbols, because otherwise we don't know what they are.  Thanks,
9096         the GStreamer team.
9097         * gst/registries/gstxmlregistry.c: (make_dir): Remove a spurious ;
9098
9099 2004-05-10  David Schleef  <ds@schleef.org>
9100
9101         (from Steve Lhomme)
9102         * win32/Makefile: When using make clean the MS Visual Studio makefiles
9103         are deleted.  Fix.
9104         * win32/Makefile.inspect:
9105         * win32/Makefile.launch:
9106         * win32/Makefile.register:
9107
9108 2004-05-10  David Schleef  <ds@schleef.org>
9109
9110         * gst/gstinfo.h: Add missing inline function.
9111         * gst/gsttrace.c: add include
9112         * gst/parse/grammar.y: remove unused code
9113         * gst/registries/gstxmlregistry.c: (make_dir): make mkdir call
9114         more portable.
9115         * tools/gst-register.c: wrap unistd.h
9116         
9117         More additions/fixes from Steve for the MSVC build.
9118         * win32/GStreamer.vcproj:
9119         * win32/Makefile:
9120         * win32/Makefile.inspect:
9121         * win32/Makefile.launch:
9122         * win32/Makefile.register:
9123         * win32/README.txt:
9124         * win32/gst-inspect.vcproj:
9125         * win32/gst-launch.vcproj:
9126         * win32/gst-register.vcproj:
9127         * win32/gstbytestream.def:
9128         * win32/gstbytestream.vcproj:
9129         * win32/gstconfig.h:
9130         * win32/gstelements.def:
9131         * win32/gstelements.vcproj:
9132         * win32/gstenumtypes.c:
9133         * win32/gstenumtypes.h:
9134         * win32/gstoptimalscheduler.def:
9135         * win32/gstoptimalscheduler.vcproj:
9136         * win32/gstreamer.def:
9137         * win32/gstspider.def:
9138         * win32/gstspider.vcproj:
9139         * win32/gstversion.h:
9140         * win32/msvc71.sln:
9141
9142 2004-05-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9143
9144         * gst/gstelement.c: (gst_element_class_init),
9145         (gst_element_no_more_pads):
9146         * gst/gstelement.h:
9147           add gst_element_no_more_pads and the "no-more-pads" signal
9148
9149 2004-05-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9150
9151         * gst/gstregistry.c: (gst_registry_add_plugin):
9152           refuse to add plugins when a plugin with same name is already
9153           registered. Fixes a bunch of "How to remove plugins?" issues.
9154           May lead to other problems though, let's test
9155
9156 2004-05-10  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9157
9158         * testsuite/caps/caps_strings : audio/ac3 => audio/x-ac3
9159         * docs/manual/pads-api.xml : audio/wav => audio/x-wav
9160         * docs/random/uraeus/gstreamer_and_midi.txt : audio/wav => audio/x-wav
9161
9162 2004-05-09  Thomas Vander Stichele  <thomas at apestaart dot org>
9163
9164         * tests/Makefile.am: fix am16 issue
9165
9166 2004-05-09  Benjamin Otte  <otte@gnome.org>
9167
9168         * libs/gst/bytestream/Makefile.am:
9169           we should indeed add .c files to makefiles or they won't be built
9170           (d'oh)
9171
9172 2004-05-08  Benjamin Otte  <otte@gnome.org>
9173
9174         * gst/gstpad.c: (gst_pad_proxy_fixate):
9175           really reduce the set of caps
9176
9177 2004-05-08  Benjamin Otte  <otte@gnome.org>
9178
9179         * tests/Makefile.am:
9180         * tests/spidey_bench.c: (handoff), (main):
9181           add benchmark to test how long spider needs to create a pipeline
9182
9183 2004-05-08  Benjamin Otte  <otte@gnome.org>
9184
9185         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_unnegotiate):
9186           mark links as unengaged when unnegotiating instead of deactivating.
9187           This way pads aren't marked as unengaged when going PLAYING=>PAUSED
9188
9189 2004-05-08  Benjamin Otte  <otte@gnome.org>
9190
9191         * docs/manual/helloworld.xml:
9192           s/audiosink/osssink (patch by Patrick Guimond)
9193
9194 2004-05-07  David Schleef  <ds@schleef.org>
9195
9196         * configure.ac: Make sure GST_INT_CFLAGS is not clobbered,
9197         since it contains important stuff.
9198
9199 2004-05-07  David Schleef  <ds@schleef.org>
9200
9201         * testsuite/caps/caps.c: (test3), (main): A check for appending
9202         ANY caps.
9203
9204 2004-05-07  David Schleef  <ds@schleef.org>
9205
9206         * common/m4/as-compiler-flag.m4: Properly quote arguments,
9207         which may contain commas.  Fixes detection of -Wa,-mregnames
9208
9209 2004-05-06  David Schleef  <ds@schleef.org>
9210
9211         Changes to handle compilers that don't have variadic macro
9212         support.  In particular, glib headers define some inlines
9213         that need G_LOG_DOMAIN defined.  Additional fixes for MSVC
9214         builds.
9215         * gst/Makefile.am:
9216         * gst/cothreads.c:
9217         * gst/elements/gstfdsink.c:
9218         * gst/elements/gstfdsrc.c:
9219         * gst/elements/gstfilesink.c:
9220         * gst/elements/gstfilesrc.c:
9221         * gst/gst_private.h:
9222         * gst/gstatomic.c:
9223         * gst/gstcaps.c: (gst_caps_append):
9224         * gst/gstcpu.c: (gst_cpuid_i386):
9225         * gst/gstelement.c:
9226         * gst/gsterror.c:
9227         * gst/gstfilter.c:
9228         * gst/gstinfo.h:
9229         * gst/gstprobe.c:
9230         * gst/gstquery.c:
9231         * gst/gstregistry.c:
9232         * gst/gststructure.c:
9233         * gst/gsttaginterface.c:
9234         * gst/gsttrace.c: (gst_trace_new):
9235         * gst/gsttrashstack.c:
9236         * gst/gsturi.c:
9237         * gst/gstvalue.c:
9238         * gst/parse/grammar.y:
9239         * gst/parse/parse.l:
9240         * tools/gst-inspect.c: (main):
9241         * tools/gst-launch.c: (main):
9242         * tools/gst-xmlinspect.c: (PUT_STRING):
9243
9244 2004-05-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9245
9246         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
9247         (gst_filesrc_change_state), (gst_filesrc_srcpad_event):
9248         * gst/elements/gstfilesrc.h:
9249           send NEW_MEDIA events correctly
9250         * gst/elements/gsttypefindelement.c: (start_typefinding),
9251         (gst_type_find_element_handle_event):
9252           restart typefinding when we get a NEW_MEDIA event
9253         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_change_state),
9254         (gst_bin_dispose):
9255           don't die when someone removes elements in callbacks
9256         * gst/gstelement.c: (gst_element_change_state):
9257           improve debugging
9258         * gst/gstpad.c: (gst_pad_pull), (gst_pad_call_chain_function):
9259           we need a NEW_MEDIA event to engage a link
9260         * gst/gsttrace.c: (gst_trace_new), (gst_alloc_trace_set_flags_all):
9261           don't g_print debugging stuff
9262         * testsuite/caps/simplify.c: (check_caps):
9263
9264 2004-05-04  Benjamin Otte  <otte@gnome.org>
9265
9266         * gst/parse/grammar.y:
9267           use GST_ERROR instead of g_warning, and always throw a GST_ERROR 
9268
9269 2004-05-04  Benjamin Otte  <otte@gnome.org>
9270
9271         * testsuite/caps/renegotiate.c: (main):
9272           improve output in error case
9273
9274 2004-05-04  Benjamin Otte  <otte@gnome.org>
9275
9276         * gst/parse/grammar.y:
9277           fix assert to not trigger when there's no error argument
9278         * gst/parse/parse.l:
9279           fix definition of caps to allow more than two structures
9280         * testsuite/caps/Makefile.am:
9281         * testsuite/caps/renegotiate.c: (main):
9282           it's sinesrc and works in that case
9283
9284 2004-05-04  Wim Taymans  <wim@fluendo.com>
9285
9286         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
9287         (group_dec_link), (gst_opt_scheduler_pad_unlink):
9288         when removing an element from a group, we always need to
9289         decrement the link count that this group had with other 
9290         groups through the element.
9291         added an extra assert to catch inconsistencies when decrementing
9292         the link count.
9293
9294 2004-05-04  Thomas Vander Stichele  <thomas at apestaart dot org>
9295
9296         * configure.ac:
9297         * docs/gst/Makefile.am:
9298         * docs/gst/gstreamer-sections.txt:
9299         * docs/gst/tmpl/gstcompat.sgml:
9300         * examples/appreader/Makefile.am:
9301         * examples/cutter/Makefile.am:
9302         * examples/events/Makefile.am:
9303         * examples/helloworld/Makefile.am:
9304         * examples/helloworld2/Makefile.am:
9305         * examples/launch/Makefile.am:
9306         * examples/manual/Makefile.am:
9307         * examples/mixer/Makefile.am:
9308         * examples/pingpong/Makefile.am:
9309         * examples/plugins/Makefile.am:
9310         * examples/queue/Makefile.am:
9311         * examples/queue2/Makefile.am:
9312         * examples/queue3/Makefile.am:
9313         * examples/queue4/Makefile.am:
9314         * examples/retag/Makefile.am:
9315         * examples/thread/Makefile.am:
9316         * examples/typefind/Makefile.am:
9317         * examples/xml/Makefile.am:
9318         * gst/Makefile.am:
9319         * gst/autoplug/Makefile.am:
9320         * gst/elements/Makefile.am:
9321         * gst/gstcompat.h:
9322         * gst/indexers/Makefile.am:
9323         * gst/parse/Makefile.am:
9324         * gst/registries/Makefile.am:
9325         * gst/schedulers/Makefile.am:
9326         * libs/gst/bytestream/Makefile.am:
9327         * libs/gst/control/Makefile.am:
9328         * libs/gst/getbits/Makefile.am:
9329         * po/af.po:
9330         * po/az.po:
9331         * po/en_GB.po:
9332         * po/fr.po:
9333         * po/nl.po:
9334         * po/sr.po:
9335         * po/sv.po:
9336         * po/tr.po:
9337         * po/uk.po:
9338         * tests/Makefile.am:
9339         * tests/bufspeed/Makefile.am:
9340         * tests/instantiate/Makefile.am:
9341         * tests/memchunk/Makefile.am:
9342         * tests/muxing/Makefile.am:
9343         * tests/negotiation/Makefile.am:
9344         * tests/probes/Makefile.am:
9345         * tests/sched/Makefile.am:
9346         * tests/seeking/Makefile.am:
9347         * tests/threadstate/Makefile.am:
9348         * testsuite/caps/Makefile.am:
9349         * testsuite/cleanup/Makefile.am:
9350         * testsuite/dlopen/Makefile.am:
9351         * testsuite/dynparams/Makefile.am:
9352         * testsuite/plugin/Makefile.am:
9353         * testsuite/states/Makefile.am:
9354         * tools/Makefile.am:
9355           reorganize compile/link flags to be consistent
9356           put gst_info in gstcompat.h and actually use GST_DISABLE_DEPRECATED
9357
9358 2004-05-04  David Schleef  <ds@schleef.org>
9359
9360         The "once more, with feeling" check-in.
9361         * testsuite/caps/Makefile.am: dist caps_strings
9362         * testsuite/caps/renegotiate.c: (main): This test triggers a
9363           segfault in the core.  Marking as failing.
9364
9365 2004-05-03  David Schleef  <ds@schleef.org>
9366
9367         * testsuite/caps/deserialize.c: (main): Fix problems noticed
9368           by the build bots.
9369         * testsuite/caps/renegotiate.c: (main): Same.
9370
9371 2004-05-03  David Schleef  <ds@schleef.org>
9372
9373         * testsuite/caps/renegotiate.c: (my_fixate), (main): Another test.
9374
9375 2004-05-03  David Schleef  <ds@schleef.org>
9376
9377         * testsuite/caps/deserialize.c: (main): Use the srcdir environment
9378           variable to find our source file.
9379
9380 2004-05-03  David Schleef  <ds@schleef.org>
9381
9382         * configure.ac:  Link plugins with libgstreamer and dependent
9383           libraries
9384         * testsuite/caps/Makefile.am:
9385         * testsuite/caps/caps_strings:
9386         * testsuite/caps/deserialize.c: (main): Add a little test to slog
9387           through a file of caps strings and test each one
9388
9389 2004-05-04  Benjamin Otte  <otte@gnome.org>
9390
9391         * libs/gst/bytestream/Makefile.am:
9392         * libs/gst/bytestream/adapter.c: 
9393         * libs/gst/bytestream/adapter.h:
9394           add GstAdapter, similar to bytestream, but doesn't require ugly event
9395           handling or uglier loopbased elements
9396
9397 2004-05-03  David Schleef  <ds@schleef.org>
9398
9399         * testsuite/caps/Makefile.am: Fix spelling of Ηρατοσθενες
9400         * testsuite/caps/erathostenes.c:
9401         * testsuite/caps/eratosthenes.c: (eratosthenes), (main):
9402
9403 2004-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
9404
9405         * docs/pwg/pwg.xml:
9406           remove hardcoded stylesheet path (duh)
9407         * docs/random/release:
9408         * docs/gst/gstreamer-sections.txt:
9409         * gst/Makefile.am:
9410         * gst/gst.h:
9411         * gst/gst_private.h:
9412         * gst/gstcaps.c:
9413         * gst/gstevent.c:
9414         * gst/gstformat.c:
9415         * gst/gstinfo.c:
9416         * gst/gstinfo.h:
9417         * gst/gstinterface.c:
9418         * gst/gstmemchunk.c:
9419         * gst/gstprobe.c:
9420         * gst/gstquery.c:
9421         * gst/gstregistry.c:
9422         * gst/gstregistrypool.c:
9423         * gst/gststructure.c:
9424         * gst/gsttaginterface.c:
9425         * gst/gstthread.c:
9426         * gst/gsttrace.c:
9427         * gst/gsttypefind.c: (gst_type_find_factory_get_type):
9428         * gst/gsturi.c:
9429         * gst/gstvalue.c:
9430           deprecate gst_info; remove gstlog.h
9431    
9432
9433 2004-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
9434
9435         * Makefile.am:
9436         * po/en_GB.po:
9437         * po/sv.po:
9438         * po/uk.po:
9439           updated translations
9440
9441 2004-05-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9442
9443         * gst/gstbin.c: (gst_bin_dispose):
9444           better debugging
9445
9446 2004-05-03  Johan Dahlin  <johan@gnome.org>
9447
9448         * gst/schedulers/gstoptimalscheduler.c
9449         (gst_opt_scheduler_pad_unlink): Check if element is non-NULL and
9450         really is a GstElement. Avoids critical when running gst-launch -v
9451         and a oggdemux/decoding pipeline.
9452
9453 2004-05-02  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9454
9455         * docs/gst/tmpl/gstpipeline.sgml :
9456         * docs/manual/elements-api.xml :
9457                 doc fix by Patrick Guimond (Protector) from devel ML
9458                 reviewed by ronald
9459
9460 2004-05-02  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9461
9462         * docs/gst/Makefile.am :
9463         * docs/libs/Makefile.am :
9464                 apply a patch from Arwed v. Merkatz so that gtk-doc
9465                 generated docs install (same for .devhelp file)
9466                 (fixes part 1 of #138836)
9467
9468 2004-04-30  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9469
9470         * docs/faq/dependencies.xml: typo
9471         * docs/faq/getting.xml :
9472             - fix download URL for new gstreamer site
9473             - hide sf.net download page as latest version aren't there
9474             - fix apt URLs
9475             - fill "get via CVS" paragraph (link to dev page on the site)
9476         * docs/faq/general.xml:
9477             hide status tables as they no more exists
9478             change case on plugins license file to reflect reality
9479         * docs/faq/troubleshooting.xml:
9480             remove the wiki question/answer as there is no more wiki
9481
9482 2004-04-30  Thomas Vander Stichele  <thomas at apestaart dot org>
9483
9484         * gst/gsterror.h:
9485           include the headers needed for declarations used in this header
9486
9487 2004-04-30  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9488
9489         * docs/random/uraeus/gstreamer_and_midi.txt :
9490           add .kar (midi + karaoke/lyrics 'track') doc to midi doc.
9491           (fixes #132288)
9492
9493 2004-04-30  Sebastien Cote  <sc5@hermes.usherb.ca>
9494
9495         reviewed by Benjamin Otte  <otte@gnome.org>
9496
9497         * gst/schedulers/gthread-cothreads.h:
9498           free allocated data for main cothread, too when destroying context
9499           (fixes #141417)
9500
9501 2004-04-29  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
9502
9503         * docs/manual/goals.xml : remove duplicated paragraph at end 
9504         of doc page (fixes #141448)
9505
9506 2004-04-29  David Schleef  <ds@schleef.org>
9507
9508         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
9509         Patch from Sebastien Cote to fix leakage of events. (bug #141414)
9510
9511 2004-04-29  Thomas Vander Stichele  <thomas at apestaart dot org>
9512
9513         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
9514           fix property
9515         * gst/gstcaps.c:
9516           fix doc string
9517         * po/POTFILES.in:
9518           rename typefind source file
9519
9520 2004-04-28  David Schleef  <ds@schleef.org>
9521
9522         Several new files from Steve Lhomme's MSVC patch (bug #141317):
9523         * win32/GStreamer.vcproj:
9524         * win32/Makefile:
9525         * win32/config.h:
9526         * win32/dirent.c: (_topendir), (_treaddir), (_tclosedir),
9527         (_trewinddir), (_ttelldir), (_tseekdir):
9528         * win32/dirent.h:
9529         * win32/gst-inspect.vcproj:
9530         * win32/gst-launch.vcproj:
9531         * win32/gst-register.vcproj:
9532         * win32/gstbytestream.vcproj:
9533         * win32/gstelements.vcproj:
9534         * win32/gstoptimalscheduler.vcproj:
9535         * win32/gstspider.vcproj:
9536         * win32/gtchar.h:
9537         * win32/mman.c: (mmap), (mprotect), (msync), (munmap):
9538         * win32/mman.h:
9539         * win32/mman.inl:
9540         * win32/msvc71.sln:
9541
9542 2004-04-29  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9543
9544         * gst/gst.c: (init_post):
9545         * gst/gstinfo.c:
9546           remove useless _gst_progname stuff
9547         * tools/gst-inspect.c: (print_field), (print_caps):
9548           improve caps output
9549
9550 2004-04-28  David Schleef  <ds@schleef.org>
9551
9552         Disable parsing of a lot of files that aren't part of the
9553         exported API.  Move corresponding template files to old/,
9554         waiting for removal when they don't contain anything
9555         interesting.
9556         * docs/gst/Makefile.am:
9557         * docs/gst/gstreamer-sections.txt:
9558         * docs/gst/tmpl/cothreads.sgml:
9559         * docs/gst/tmpl/cothreads_compat.sgml:
9560         * docs/gst/tmpl/gettext.sgml:
9561         * docs/gst/tmpl/gobject2gtk.sgml:
9562         * docs/gst/tmpl/grammar.tab.sgml:
9563         * docs/gst/tmpl/gst-i18n-app.sgml:
9564         * docs/gst/tmpl/gst-i18n-lib.sgml:
9565         * docs/gst/tmpl/gst_private.sgml:
9566         * docs/gst/tmpl/gstaggregator.sgml:
9567         * docs/gst/tmpl/gstarch.sgml:
9568         * docs/gst/tmpl/gstatomic_impl.sgml:
9569         * docs/gst/tmpl/gstbufferstore.sgml:
9570         * docs/gst/tmpl/gstdata_private.sgml:
9571         * docs/gst/tmpl/gstdisksink.sgml:
9572         * docs/gst/tmpl/gstdisksrc.sgml:
9573         * docs/gst/tmpl/gstelementfactory.sgml:
9574         * docs/gst/tmpl/gstextratypes.sgml:
9575         * docs/gst/tmpl/gstfakesink.sgml:
9576         * docs/gst/tmpl/gstfakesrc.sgml:
9577         * docs/gst/tmpl/gstfdsink.sgml:
9578         * docs/gst/tmpl/gstfdsrc.sgml:
9579         * docs/gst/tmpl/gstfilesink.sgml:
9580         * docs/gst/tmpl/gstfilesrc.sgml:
9581         * docs/gst/tmpl/gsthttpsrc.sgml:
9582         * docs/gst/tmpl/gstidentity.sgml:
9583         * docs/gst/tmpl/gstindexfactory.sgml:
9584         * docs/gst/tmpl/gstmarshal.sgml:
9585         * docs/gst/tmpl/gstmd5sink.sgml:
9586         * docs/gst/tmpl/gstmultidisksrc.sgml:
9587         * docs/gst/tmpl/gstmultifilesrc.sgml:
9588         * docs/gst/tmpl/gstpadtemplate.sgml:
9589         * docs/gst/tmpl/gstpipefilter.sgml:
9590         * docs/gst/tmpl/gstschedulerfactory.sgml:
9591         * docs/gst/tmpl/gstsearchfuncs.sgml:
9592         * docs/gst/tmpl/gstshaper.sgml:
9593         * docs/gst/tmpl/gstspider.sgml:
9594         * docs/gst/tmpl/gstspideridentity.sgml:
9595         * docs/gst/tmpl/gststatistics.sgml:
9596         * docs/gst/tmpl/gsttee.sgml:
9597         * docs/gst/tmpl/gsttimecache.sgml:
9598         * docs/gst/tmpl/gsttypefind.sgml:
9599         * docs/gst/tmpl/gsttypefindfactory.sgml:
9600         * docs/gst/tmpl/gstxmlregistry.sgml:
9601         * docs/gst/tmpl/gthread-cothreads.sgml:
9602         * docs/gst/tmpl/old/cothreads.sgml:
9603         * docs/gst/tmpl/old/cothreads_compat.sgml:
9604         * docs/gst/tmpl/old/gettext.sgml:
9605         * docs/gst/tmpl/old/gobject2gtk.sgml:
9606         * docs/gst/tmpl/old/grammar.tab.sgml:
9607         * docs/gst/tmpl/old/gst-i18n-app.sgml:
9608         * docs/gst/tmpl/old/gst-i18n-lib.sgml:
9609         * docs/gst/tmpl/old/gst_private.sgml:
9610         * docs/gst/tmpl/old/gstaggregator.sgml:
9611         * docs/gst/tmpl/old/gstarch.sgml:
9612         * docs/gst/tmpl/old/gstatomic_impl.sgml:
9613         * docs/gst/tmpl/old/gstbufferstore.sgml:
9614         * docs/gst/tmpl/old/gstdata_private.sgml:
9615         * docs/gst/tmpl/old/gstdisksink.sgml:
9616         * docs/gst/tmpl/old/gstdisksrc.sgml:
9617         * docs/gst/tmpl/old/gstelementfactory.sgml:
9618         * docs/gst/tmpl/old/gstextratypes.sgml:
9619         * docs/gst/tmpl/old/gstfakesink.sgml:
9620         * docs/gst/tmpl/old/gstfakesrc.sgml:
9621         * docs/gst/tmpl/old/gstfdsink.sgml:
9622         * docs/gst/tmpl/old/gstfdsrc.sgml:
9623         * docs/gst/tmpl/old/gstfilesink.sgml:
9624         * docs/gst/tmpl/old/gstfilesrc.sgml:
9625         * docs/gst/tmpl/old/gsthttpsrc.sgml:
9626         * docs/gst/tmpl/old/gstidentity.sgml:
9627         * docs/gst/tmpl/old/gstindexfactory.sgml:
9628         * docs/gst/tmpl/old/gstmarshal.sgml:
9629         * docs/gst/tmpl/old/gstmd5sink.sgml:
9630         * docs/gst/tmpl/old/gstmultidisksrc.sgml:
9631         * docs/gst/tmpl/old/gstmultifilesrc.sgml:
9632         * docs/gst/tmpl/old/gstpadtemplate.sgml:
9633         * docs/gst/tmpl/old/gstpipefilter.sgml:
9634         * docs/gst/tmpl/old/gstschedulerfactory.sgml:
9635         * docs/gst/tmpl/old/gstsearchfuncs.sgml:
9636         * docs/gst/tmpl/old/gstshaper.sgml:
9637         * docs/gst/tmpl/old/gstspider.sgml:
9638         * docs/gst/tmpl/old/gstspideridentity.sgml:
9639         * docs/gst/tmpl/old/gststatistics.sgml:
9640         * docs/gst/tmpl/old/gsttee.sgml:
9641         * docs/gst/tmpl/old/gsttimecache.sgml:
9642         * docs/gst/tmpl/old/gsttypefindfactory.sgml:
9643         * docs/gst/tmpl/old/gstxmlregistry.sgml:
9644         * docs/gst/tmpl/old/gthread-cothreads.sgml:
9645         * docs/gst/tmpl/old/types.sgml:
9646         * docs/gst/tmpl/types.sgml:
9647
9648         Rename gsttypefind.[ch] back to gsttypefindelement.[ch], since
9649         gtkdoc-scan doesn't like files with the same name in different
9650         directories.
9651         * gst/elements/Makefile.am:
9652         * gst/elements/gstelements.c:
9653         * gst/elements/gsttypefind.c: 
9654         * gst/elements/gsttypefind.h:
9655         * gst/elements/gsttypefindelement.c:
9656         * gst/elements/gsttypefindelement.h:
9657
9658 2004-04-28  David Schleef  <ds@schleef.org>
9659
9660         A bunch of portability fixes, derived from Steve Lhomme's MSVC
9661         patch (bug #141317):
9662         * gst/gst-i18n-lib.h: Allow disabling gettext.
9663         * gst/gstatomic_impl.h: disable warning when it's dumb.
9664         * gst/gstclock.c: fix include
9665         * gst/gstcompat.h: fix variadic macro
9666         * gst/gstinfo.c: fix include
9667         * gst/gstmacros.h: add defines for inlines on MSVC
9668         * gst/gstplugin.c: fix includes
9669         * gst/gstregistry.c: fix includes
9670         * gst/gstregistry.h: use S_IREAD, etc., if S_IRUSR isn't defined
9671         * gst/gstsystemclock.c: fix include
9672         * gst/gsttrace.c: (gst_trace_new), (gst_trace_text_flush): use
9673         S_IREAD if S_IRUSR isn't defined.  fix use of non-portable functions
9674         * gst/registries/gstxmlregistry.c:
9675         (gst_xml_registry_parse_element_factory): fix use of non-portable
9676         functions
9677         * libs/gst/control/dparam.h: Remove trailing comma in enum definition
9678         * libs/gst/control/dparammanager.h: same
9679
9680 2004-04-28  David Schleef  <ds@schleef.org>
9681
9682         Move a bunch of unused files to old/ with names that are
9683         not case-insensitive-unique.  These files still contain some
9684         useful information that needs to be merged into gstbin.sgml,
9685         etc., so they shouldn't be deleted yet.
9686         * docs/gst/tmpl/GstBin.sgml:
9687         * docs/gst/tmpl/GstBuffer.sgml:
9688         * docs/gst/tmpl/GstCaps.sgml:
9689         * docs/gst/tmpl/GstClock.sgml:
9690         * docs/gst/tmpl/GstCompat.sgml:
9691         * docs/gst/tmpl/GstData.sgml:
9692         * docs/gst/tmpl/GstElement.sgml:
9693         * docs/gst/tmpl/GstEvent.sgml:
9694         * docs/gst/tmpl/GstIndex.sgml:
9695         * docs/gst/tmpl/GstStructure.sgml:
9696         * docs/gst/tmpl/GstTag.sgml:
9697         * docs/gst/tmpl/old/GstBin.sgml:
9698         * docs/gst/tmpl/old/GstBuffer.sgml:
9699         * docs/gst/tmpl/old/GstCaps.sgml:
9700         * docs/gst/tmpl/old/GstClock.sgml:
9701         * docs/gst/tmpl/old/GstCompat.sgml:
9702         * docs/gst/tmpl/old/GstData.sgml:
9703         * docs/gst/tmpl/old/GstElement.sgml:
9704         * docs/gst/tmpl/old/GstEvent.sgml:
9705         * docs/gst/tmpl/old/GstIndex.sgml:
9706         * docs/gst/tmpl/old/GstStructure.sgml:
9707         * docs/gst/tmpl/old/GstTag.sgml:
9708
9709 2004-04-28  David Schleef  <ds@schleef.org>
9710
9711         * gst/gstcaps.c: (gst_caps_copy), (gst_caps_free),
9712         (gst_caps_append), (gst_caps_append_structure),
9713         (gst_caps_get_size), (gst_caps_get_structure), (gst_caps_copy_1),
9714         (gst_caps_set_simple), (gst_caps_set_simple_valist),
9715         (gst_caps_is_any), (gst_caps_is_empty), (gst_caps_is_chained),
9716         (gst_caps_is_fixed), (gst_caps_is_always_compatible),
9717         (gst_caps_intersect), (gst_caps_normalize),
9718         (gst_caps_transform_to_string):  Patch from Tim-Philipp Müller
9719         to fix GST_CAPS() and GST_IS_CAPS(). (bug #141304)
9720         * gst/gstcaps.h: use GST_IS_CAPS().
9721
9722 2004-04-26  David Schleef  <ds@schleef.org>
9723
9724         * gst/gstcpu.c: (gst_cpuid_i386): Don't clobber ebx in inline
9725         assembly.  gcc doesn't handle it correctly. (bug #141083)
9726         * gst/gsttrashstack.h: same
9727
9728 2004-04-25  Benjamin Otte  <otte@gnome.org>
9729
9730         * gst/gstelement.c: (gst_element_change_state):
9731           fix assertion to do an int comparison
9732
9733 2004-04-25  Benjamin Otte  <otte@gnome.org>
9734
9735         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
9736           better debugging output on error
9737
9738 2004-04-25  Benjamin Otte  <otte@gnome.org>
9739
9740         * gst/gstcaps.c: (gst_caps_subtract):
9741           fix memleak
9742
9743 2004-04-23  Benjamin Otte  <otte@gnome.org>
9744
9745         * gst/gstvalue.c: (gst_value_compare_buffer),
9746         (_gst_value_initialize):
9747           add comparison function for buffers
9748
9749 2004-04-22  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9750
9751         * docs/pwg/pwg.xml:
9752           Just found out that this so-called "ima-wav" format is really
9753           just "dvi adpcm" (according to the MS WAV documentation). So
9754           renaming it. We didn't use it yet anyway.
9755
9756 2004-04-23  Benjamin Otte  <otte@gnome.org>
9757
9758         * gst/gstcaps.c: (gst_caps_is_always_compatible):
9759           call gst_caps_is_subset
9760
9761 2004-04-23  Benjamin Otte  <otte@gnome.org>
9762
9763         * gst/gstcaps.c: (gst_caps_subtract), (gst_caps_is_equal), 
9764         (gst_caps_is_subset):
9765           add documentation
9766
9767 2004-04-23  Benjamin Otte  <otte@gnome.org>
9768           
9769         * gst/gstcaps.c: (gst_caps_structure_subtract_field),
9770         (gst_caps_structure_subtract), (gst_caps_subtract),
9771         (gst_caps_structure_figure_out_union),
9772         (gst_caps_structure_simplify), (gst_caps_do_simplify):
9773           fix simplifying and subtracting not working correctly with optional
9774           properties
9775           solve assorted problems that make it now simplify ebven more
9776         * docs/gst/tmpl/gstcaps.sgml:
9777         * gst/gstcaps.h:
9778           make gst_caps_do_simplify return a bool to indicate if it simplified
9779         * testsuite/caps/simplify.c: (main):
9780           add more checks. The tests is quite a bit useless right now because
9781           the core is heavily simplifying itself.
9782         * testsuite/caps/caps.h:
9783           fix caps to contain all optional properties
9784
9785 2004-04-22  Benjamin Otte  <otte@gnome.org>
9786
9787         * docs/gst/tmpl/gstcaps.sgml:
9788         * docs/gst/tmpl/gstfilesrc.sgml:
9789         * docs/gst/tmpl/gststructure.sgml:
9790         * docs/gst/tmpl/gstvalue.sgml:
9791           update for recent API changes
9792         * gst/gstcaps.c: (gst_caps_do_simplify):
9793           fix to stop trying with a freed structure
9794         * gst/gstpad.c: (gst_pad_link_fixate):
9795           simplify caps
9796         * gst/gstpad.c: (gst_pad_template_get_caps_by_name):
9797           remove C++ comment
9798         * gst/gstpad.h:
9799           deprecate gst_pad_template_get_caps_by_name, it doesn't work anyway
9800         * gst/gststructure.c: (gst_structure_value_get_generic_type),
9801         (gst_structure_to_string):
9802           keep the correct type when using lists of ranges
9803         * gst/gstvalue.c: (gst_value_list_prepend_value),
9804         (gst_value_list_append_value):
9805           copy the value before adding to the list (d'oh)
9806         * gst/gstvalue.c: (gst_value_subtract_int_range_int),
9807         (gst_value_subtract_int_range_int_range):
9808           handle overflows correctly
9809         * gst/gstvalue.c: (gst_value_subtract_from_list):
9810           fix memleak
9811         * testsuite/caps/caps.h:
9812           add a caps that caused segfaults
9813
9814 2004-04-22  Benjamin Otte  <otte@gnome.org>
9815
9816         * testsuite/refcounting/pad.c: (main):
9817           fix test
9818
9819 2004-04-22  Benjamin Otte  <otte@gnome.org>
9820
9821         * gst/gstcaps.c: (gst_caps_subtract):
9822           allow subtracting ANY and EMPTY from ANY caps
9823
9824 2004-04-22  Benjamin Otte  <otte@gnome.org>
9825
9826         * gst/gstcaps.c: (gst_caps_append), (gst_caps_intersect),
9827         (gst_caps_union):
9828           only simplify in functions that create new caps. Simplifying in
9829           gst_caps_append breaks tests.
9830
9831 2004-04-22  Benjamin Otte  <otte@gnome.org>
9832
9833         * gst/gstcaps.c: (gst_caps_structure_simplify):
9834           unset GValue after use
9835         * gst/gstcaps.c: (gst_caps_append), 
9836         * gst/gstpad.c: (gst_pad_link_fixate), (gst_pad_template_new):
9837           use gst_caps_simplify (reduces registry size by 30%)
9838         * gst/gstpad.c: (gst_pad_template_new):
9839           don't allow NULL caps
9840
9841 2004-04-22  Benjamin Otte  <otte@gnome.org>
9842
9843         * docs/gst/gstreamer-sections.txt:
9844           add gst_caps_do_simplify
9845         * gst/gstcaps.c:
9846           add documentation for gst_caps_do_simplify
9847         * gst/gstvalue.h:
9848           fix typo in gst_value_register_subtract_func declaration for gst-doc
9849
9850 2004-04-22  Benjamin Otte  <otte@gnome.org>
9851
9852         * gst/gstcaps.c: (gst_caps_from_string_inplace):
9853           fix bug when converting from empty string.
9854         * gst/gstcaps.c: (gst_caps_new_any), (gst_caps_new_simple),
9855         (gst_caps_new_full_valist), (gst_caps_copy), (gst_caps_copy_1):
9856           use gst_caps_new_empty to allocate a new caps. Only that function
9857           allocates memory for caps now.
9858         * gst/gstcaps.c: (gst_caps_remove_and_get_structure),
9859         (gst_caps_remove_structure):
9860           add ability to remove one structure (but not to header yet)
9861         * gst/gstcaps.c: (gst_caps_compare_structures),
9862         (gst_caps_simplify), (gst_caps_structure_figure_out_union),
9863         (gst_caps_structure_simplify), (gst_caps_do_simplify),
9864         * gst/gstcaps.h:
9865           add gst_caps_do_simplify that tries to simplify a caps in place.
9866           Deprecate old gst_caps_simplify function.
9867         * testsuite/caps/caps.h:
9868           add caps.h containing a common set of caps to test against.
9869         * testsuite/caps/sets.c: (check_caps), (main):
9870           use it.
9871         * testsuite/caps/.cvsignore:
9872         * testsuite/caps/Makefile.am:
9873         * testsuite/caps/simplify.c: (check_caps), (main):
9874           add test to check correctness and efficency of caps simplification.
9875
9876 2004-04-22  Sebastien Cote <sc5@hermes.usherb.ca>
9877
9878         reviewed by Benjamin Otte  <otte@gnome.org>
9879
9880         * gst/gstparse.c: (_gst_parse_escape):
9881           Free the GString used in _gst_parse_escape()
9882
9883 2004-04-21  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9884
9885         * gst/gstpad.c: (gst_pad_link_negotiate):
9886           refuse to link if the link is not possible
9887         * configure.ac:
9888         * testsuite/Makefile.am:
9889         * testsuite/negotiation/.cvsignore:
9890         * testsuite/negotiation/Makefile.am:
9891         * testsuite/negotiation/pad_link.c: (main):
9892           add test that checks the above behaviour
9893
9894 2004-04-21  Thomas Vander Stichele  <thomas at apestaart dot org>
9895
9896         * docs/gst/gstreamer-sections.txt:
9897           add newly added API
9898
9899 2004-04-21  Thomas Vander Stichele  <thomas at apestaart dot org>
9900
9901         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
9902         (gst_filesrc_get_mmap), (gst_filesrc_get_read), (gst_filesrc_get),
9903         (gst_filesrc_open_file), (gst_filesrc_close_file),
9904         (gst_filesrc_srcpad_query), (gst_filesrc_srcpad_event):
9905         * gst/elements/gstfilesrc.h:
9906           add support for non-regular files (#140734)
9907
9908 2004-04-21  Benjamin Otte  <otte@gnome.org>
9909
9910         * gst/gstpad.c: (gst_pad_link_fixate):
9911           add sophisticated error checking code to see if fixation functions
9912           did their fixation right
9913
9914 2004-04-21  Benjamin Otte  <otte@gnome.org>
9915
9916         * gst/gstcaps.c: (gst_caps_append), (gst_caps_union):
9917           check for ANY caps before appending/unioning
9918         * gst/gstcaps.c: (gst_caps_is_subset),
9919         (gst_caps_is_equal), (gst_caps_structure_subtract_field),
9920         (gst_caps_structure_subtract), (gst_caps_subtract):
9921         * gst/gstcaps.h:
9922           add gst_caps_is_equal, gst_caps_is_subset and gst_caps_subtract to
9923           the API. deprecate gst_caps_is_equal_fixed
9924         * gst/gstpad.c: (gst_pad_try_set_caps):
9925         * gst/gstqueue.c: (gst_queue_link):
9926           s/gst_caps_is_equal_fixed/gst_caps_is_equal/
9927         * gst/gststructure.c: (gst_structure_get_name_id):
9928         * gst/gststructure.h:
9929           add function gst_structure_get_name_id
9930         * gst/gstvalue.c: (gst_value_subtract_int_int_range),
9931         (gst_value_create_new_range), (gst_value_subtract_int_range_int),
9932         (gst_value_subtract_int_range_int_range),
9933         (gst_value_subtract_double_double_range),
9934         (gst_value_subtract_double_range_double),
9935         (gst_value_subtract_double_range_double_range),
9936         (gst_value_subtract_from_list), (gst_value_subtract_list),
9937         (gst_value_can_intersect), (gst_value_subtract),
9938         (gst_value_can_subtract), (gst_value_register_subtract_func),
9939         (_gst_value_initialize):
9940         * gst/gstvalue.h:
9941           add support for subtracting values from each other. Note that
9942           subtracting means subtracting as in set theory. Required for caps
9943           stuff above.
9944         * testsuite/caps/.cvsignore:
9945         * testsuite/caps/Makefile.am:
9946         * testsuite/caps/erathostenes.c: (erathostenes), (main):
9947         * testsuite/caps/sets.c: (check_caps), (main):
9948         * testsuite/caps/subtract.c: (check_caps), (main):
9949           add tests for subtraction and equality code.
9950
9951 2004-04-20  David Schleef  <ds@schleef.org>
9952
9953         * gst/autoplug/Makefile.am:  Fix some little buglets in last checkin.
9954         * gst/indexers/Makefile.am:
9955         * gst/schedulers/Makefile.am:
9956         * libs/gst/bytestream/Makefile.am:
9957         * libs/gst/control/Makefile.am:
9958         * libs/gst/getbits/Makefile.am:
9959
9960 2004-04-20  David Schleef  <ds@schleef.org>
9961
9962         * common/as-libtool.mak: Fine-tune DLL building.
9963         * configure.ac: Link plugins against libgstreamer.  Define plugindir
9964         (like gst-plugins)
9965         * examples/plugins/Makefile.am: remove plugindir
9966         * gst/autoplug/Makefile.am: DLL building fixes
9967         * gst/elements/Makefile.am: DLL building fixes.  Disable pipefilter on
9968         Windows.
9969         * gst/elements/gstelements.c: Conditionally disable pipefilter.
9970         * gst/indexers/Makefile.am: DLL building fixes
9971         * gst/schedulers/Makefile.am: DLL building fixes.
9972         * libs/gst/bytestream/Makefile.am: DLL building fixes.
9973         * libs/gst/control/Makefile.am: same
9974         * libs/gst/getbits/Makefile.am: same
9975         * testsuite/Makefile.am: New dlopen directory
9976         * testsuite/dlopen/Makefile.am: Tests to check if libgstreamer works
9977         when dlopened.
9978         * testsuite/dlopen/dlopen_gst.c: (main): same
9979         * testsuite/dlopen/loadgst.c: (do_test): same
9980
9981 2004-04-20  David Schleef  <ds@schleef.org>
9982
9983         * gst/parse/grammar.y:  Apply patch from Sebastien Cote
9984         <sc5@hermes.usherb.ca> to fix a memleak. (bug #140594)
9985
9986 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
9987
9988         * gst/gstelement.c: (gst_element_wait),
9989         (gst_element_set_time_delay), (gst_element_change_state):
9990           Use GST_TIME_*
9991
9992 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9993
9994         * gst/autoplug/gstspider.c: (gst_spider_link_sometimes),
9995         (gst_spider_identity_plug):
9996           improve debugging messages
9997         * gst/gstbin.c: (gst_bin_remove_func):
9998           make sure the state_change function is only called with simple state
9999           transitions
10000
10001 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
10002
10003         * gst/elements/gstfakesink.c: (gst_fakesink_state_error_get_type),
10004         (gst_fakesink_set_property), (gst_fakesink_chain):
10005         * gst/elements/gstfakesrc.c: (gst_fakesrc_set_property):
10006         * gst/elements/gstfdsrc.c: (gst_fdsrc_set_property):
10007         * gst/elements/gstfilesrc.c: (gst_filesrc_set_property):
10008         * gst/elements/gstidentity.c: (gst_identity_chain),
10009         (gst_identity_set_property):
10010         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_set_property):
10011         * gst/elements/gstpipefilter.c: (gst_pipefilter_set_property):
10012           add warnings to _set_property for unknown arguments
10013           use GST_TIME_FORMAT/GST_TIME_ARGS for timestamp printing
10014
10015 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
10016
10017         * Makefile.am:
10018         * docs/manuals.mak:
10019           add .po file download snippet
10020           fix a bug in the doc makefile
10021
10022 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
10023
10024         * Makefile.am:
10025         * po/LINGUAS:
10026         * po/en_GB.po:
10027           Added en_GB translation (Gareth Owen)
10028
10029 2004-04-20  Johan Dahlin  <johan@gnome.org>
10030
10031         * gst/gstpad.c (_invent_event): Clean up
10032
10033 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10034
10035         * testsuite/caps/filtercaps.c: (main):
10036           fix test to test things correctly (caps are complicated)
10037
10038 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10039
10040         * testsuite/caps/Makefile.am:
10041         * testsuite/caps/filtercaps.c: (main):
10042           add test (that doesn't work right now, but should)
10043
10044 2004-04-19  David Schleef  <ds@schleef.org>
10045
10046         * configure.ac: Add test for allowing unaligned access.  Add define
10047         to put in gstconfig.h.
10048         * docs/gst/gstreamer-sections.txt: New symbols
10049         * docs/gst/tmpl/gstcompat.sgml: Check in changes made by gtkdoc
10050         * docs/gst/tmpl/gstfilesrc.sgml:
10051         * docs/gst/tmpl/gstparse.sgml:
10052         * docs/gst/tmpl/gsttypes.sgml:
10053         * docs/gst/tmpl/gstutils.sgml:
10054         * docs/gst/tmpl/gstvalue.sgml:
10055         * gst/gstconfig.h.in: Add GST_HAVE_UNALIGNED_ACCESS
10056         * gst/gstutils.h: Add macros for unaligned memory access.  Useful
10057         on most !i386/!powerpc architectures.  From Daniel Gazard
10058         <daniel.gazard@free.fr>.  (bug #140156)
10059         * po/af.po: Check in changes made by gettext.
10060         * po/az.po:
10061         * po/fr.po:
10062         * po/nl.po:
10063         * po/sr.po:
10064         * po/sv.po:
10065
10066 2004-04-20  Benjamin Otte  <otte@gnome.org>
10067
10068         * gst/schedulers/entryscheduler.c: 
10069         (gst_entry_scheduler_yield):
10070           refuse to yield when decoupled elements insist on doing that.
10071           At least it's better than crashing
10072
10073 2004-04-19  David Schleef  <ds@schleef.org>
10074
10075         * docs/libs/Makefile.am: Change sinclude to include
10076         * docs/gst/Makefile.am: same
10077         * pkgconfig/Makefile.am:  Remove GNU-ism from makefile target
10078
10079 2004-04-19  Thomas Vander Stichele  <thomas at apestaart dot org>
10080
10081         * po/LINGUAS:
10082         * po/uk.po:
10083           Added Ukrainian translation (Maxim V. Dziumanenko)
10084
10085 2004-04-19  Johan Dahlin  <johan@gnome.org>
10086
10087         * gst/parse/grammar.y (__gst_parse_chain_free): Don't do null
10088         checking here, do it before calling the function.
10089         Clean up, use for loops instead of while loops while iterating
10090         over lists.
10091
10092         * gst/autoplug/gstspider.c (gst_spider_request_new_pad): Fix typo
10093         in debug message.
10094         (gst_spider_create_and_plug): Improve debug message.
10095         General: Replace while loops which iterates over GLists with for
10096         loops. Which are much cleaner, improves readability, especially
10097         for gst_spider_identity_plug
10098
10099         * gst/gstpad.c (_invent_event): Fix parameters to warning macros,
10100         fixes bug 140477
10101
10102 2004-04-18  Thomas Vander Stichele  <thomas at apestaart dot org>
10103
10104         * po/LINGUAS:
10105         * po/tr.po:
10106           Added Turkish translation (Baris Cicek)
10107
10108 2004-04-18  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10109
10110         * docs/faq/troubleshooting.xml:
10111           Mention gst-register in the FAQ (fixes 139045).
10112
10113 2004-04-17  Thomas Vander Stichele  <thomas at apestaart dot org>
10114
10115         * docs/gst/gstreamer-sections.txt:
10116
10117 2004-04-17  Benjamin Otte  <otte@gnome.org>
10118
10119         * gst/gstelement.c: (gst_element_dispose):
10120           simplify
10121         * gst/gstpad.c: (gst_pad_call_chain_function):
10122           don't create loads of events due to bad macro usage
10123
10124 2004-04-16  David Schleef  <ds@schleef.org>
10125
10126         * gst/gstcaps.c: (gst_caps_is_fixed_foreach):
10127         * gst/gstpad.c: (_gst_pad_default_fixate_foreach):
10128         * gst/gstvalue.c: (gst_value_serialize_buffer),
10129         (gst_value_deserialize_buffer), (gst_type_is_fixed),
10130         (_gst_value_initialize): Create a new function gst_type_is_fixed()
10131         to indicate types that are fixed wrt caps or not.  Switching to
10132         this function fixes (bug #140298).
10133         * gst/gstvalue.h:
10134
10135 2004-04-16  David Schleef  <ds@schleef.org>
10136
10137         * common/m4/gst-arch.m4:  Implmenent a whitelist and blacklist
10138         for GST_UNALIGNED_ACESS, since we essentially know which archs
10139         are ok.
10140
10141 2004-04-17  Benjamin Otte  <otte@gnome.org>
10142
10143         * docs/gst/Makefile.am:
10144           ignore gst/parse directory when building docs (fixes #140205)
10145
10146 2004-04-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10147
10148         * testsuite/refcounting/mem.c: (vmsize):
10149           do error checking
10150
10151 2004-04-16  Johan Dahlin  <johan@gnome.org>
10152
10153         * docs/gst/gstreamer-sections.txt: Add gst_pad_call_chain_function
10154         and gst_pad_call_get_function.
10155
10156 2004-04-15  David Schleef  <ds@schleef.org>
10157
10158         * common/m4/gst-arch.m4: Add GST_UNALIGNED_ACCESS() macro that
10159         checks if we can access unaligned memory.
10160         * configure.ac: Use it.
10161
10162 2004-04-16  Benjamin Otte  <otte@gnome.org>
10163
10164         * gst/elements/gstfilesrc.c: (gst_filesrc_init), (gst_filesrc_get),
10165         (gst_filesrc_change_state), (gst_filesrc_srcpad_event):
10166         * gst/elements/gstfilesrc.h:
10167           s/seek_happened/need_discont/ and require discont before sending any
10168           data
10169
10170 2004-04-15  David Schleef  <ds@schleef.org>
10171
10172         * gst/gstvalue.c: (gst_value_serialize_buffer),
10173         (gst_value_deserialize_buffer), (_gst_value_initialize):
10174         Register these types as fundamental types. (bug #140015)
10175
10176 2004-04-16  Benjamin Otte  <otte@gnome.org>
10177
10178         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_new),
10179         (gst_pad_link_free), (gst_pad_link_try), (_invent_event),
10180         (gst_pad_pull):
10181           implement enforcing discont events before buffers are passed. This
10182           allows state changes of only some elements and later correctly going
10183           on where they left off (or in short: you can now set audio sinks to
10184           NULL to release the device when the pipeline is paused)
10185         * gst/gstpad.c: (gst_pad_call_chain_function),
10186         (gst_pad_call_get_function):
10187         * gst/gstpad.h:
10188           add gst_pad_call_chain_function and gst_pad_call_get_function for
10189           scheduler interaction. They are required because of the changes
10190           above.
10191         * gst/schedulers/entryscheduler.c: (get_buffer),
10192         (gst_entry_scheduler_chain_wrapper),
10193         (gst_entry_scheduler_get_wrapper),
10194         (gst_entry_scheduler_state_transition),
10195         (gst_entry_scheduler_pad_link):
10196         * gst/schedulers/gstbasicscheduler.c:
10197         (gst_basic_scheduler_chain_wrapper),
10198         (gst_basic_scheduler_src_wrapper),
10199         (gst_basic_scheduler_chainhandler_proxy),
10200         (gst_basic_scheduler_gethandler_proxy),
10201         (gst_basic_scheduler_cothreaded_chain),
10202         (gst_basic_scheduler_chain_elements):
10203         * gst/schedulers/gstoptimalscheduler.c:
10204         (get_group_schedule_function), (pad_clear_queued),
10205         (gst_opt_scheduler_pad_link):
10206           use the new functions instead of calling get/chain-functions
10207           directly.
10208
10209 2004-04-15  David Schleef  <ds@schleef.org>
10210
10211         * docs/gst/gstreamer-sections.txt: Remove deprecated symbols.
10212         * docs/gst/tmpl/gstinfo.sgml: same
10213         * docs/gst/tmpl/gstutils.sgml: Remove a bunch of bogus crap that
10214         gtk-doc put here.
10215         * gst/gstutils.h: Remove the \ that was confusing gtk-doc.
10216         * examples/queue/queue.c: (main):  We iterate pipelines, not
10217         bins.  (bug #139996)
10218
10219 2004-04-15  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10220
10221         * docs/pwg/advanced-types.xml:
10222           Add MS RLE support. Also document Qt RLE although I have no sample
10223           files for that yet. And document an extra property for ADPCM.
10224
10225 2004-04-15  David Schleef  <ds@schleef.org>
10226
10227         * gst/gstplugin.c: (_gst_plugin_fault_handler_restore),
10228         (_gst_plugin_fault_handler_setup):  Disable more stuff on
10229         Windows.
10230
10231 2004-04-15  David Schleef  <ds@schleef.org>
10232
10233         * gst/gstinfo.c: (_gst_debug_init): Change some internal
10234         symbol names to not conflict with new gstinfo.h symbols.
10235         * gst/gstinfo.h: Add inline functions for all those crazy
10236         compilers that don't know how to handle variadic macros (MSVC).
10237
10238 2004-04-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10239
10240         * configure.ac: bump nano to 1
10241
10242 === release 0.8.1 ===
10243
10244 2004-04-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10245
10246         * NEWS:
10247         * RELEASE:
10248         * configure.ac:
10249           releasing 0.8.1, "Snow Brigade"
10250
10251 2004-04-14  David Schleef  <ds@schleef.org>
10252
10253         * testsuite/Makefile.am: define tests_ignore
10254         * testsuite/Rules: Added new tests_ignore, which get compiled,
10255         but not run (generally because they're inconsistent or have
10256         heisenbugs).  Now we can ensure all the .c files compile in
10257         testsuite/.
10258         * testsuite/bins/Makefile.am: define tests_ignore
10259         * testsuite/bytestream/Makefile.am:
10260         * testsuite/caps/Makefile.am:
10261         * testsuite/clock/Makefile.am:
10262         * testsuite/debug/Makefile.am:
10263         * testsuite/debug/global.c: (gst_debug_log_one),
10264         (gst_debug_log_two): Fix compilation problem.
10265         * testsuite/dynparams/Makefile.am:
10266         * testsuite/elements/Makefile.am:
10267         * testsuite/ghostpads/Makefile.am:
10268         * testsuite/indexers/Makefile.am:
10269         * testsuite/parse/Makefile.am:
10270         * testsuite/plugin/Makefile.am:
10271         * testsuite/refcounting/Makefile.am:
10272         * testsuite/refcounting/element_pad.c: (main): Don't return leak
10273         results, because it's not calculated correctly.
10274         * testsuite/refcounting/pad.c: (main): same
10275         * testsuite/states/Makefile.am:
10276         * testsuite/tags/Makefile.am:
10277         * testsuite/threads/Makefile.am:
10278
10279 2004-04-14  David Schleef  <ds@schleef.org>
10280
10281         * gst/gstcpu.c: (gst_cpuid_i386): Add workaround for gcc-3.2
10282         generating bad code around the cpu detection asm code.
10283
10284 2004-04-14  Thomas Vander Stichele  <thomas at apestaart dot org>
10285
10286         * tools/gst-inspect.c: (print_element_info):
10287           print numeric version of rank as well, since we added some - 1
10288           rank values to elements
10289
10290 2004-04-13  David Schleef  <ds@schleef.org>
10291
10292         * configure.ac:  Disable various code when compiling for MinGW.
10293         * gst/elements/Makefile.am:
10294         * gst/elements/gstelements.c:
10295         * gst/elements/gstfdsrc.c: (gst_fdsrc_get):
10296         * gst/elements/gstfilesrc.c: (gst_filesrc_init), (gst_filesrc_get):
10297         * gst/registries/gstxmlregistry.c: (make_dir):
10298
10299 2004-04-13  David Schleef  <ds@schleef.org>
10300
10301         * gst/Makefile.am:
10302         * gst/gstcpu.c: (gst_cpuid_i386): Convert asm source into inline
10303         assembly.
10304         * gst/gstcpuid_i386.s: remove
10305
10306 2004-04-13  David Schleef  <ds@schleef.org>
10307
10308         * docs/gst/tmpl/gstaggregator.sgml: Random checkin because gtk-doc
10309         seems to think it needs to be done.
10310         * docs/gst/tmpl/gstfakesink.sgml:
10311         * docs/gst/tmpl/gstfakesrc.sgml:
10312         * docs/gst/tmpl/gstfdsink.sgml:
10313         * docs/gst/tmpl/gstfdsrc.sgml:
10314         * docs/gst/tmpl/gstfilesink.sgml:
10315         * docs/gst/tmpl/gstfilesrc.sgml:
10316         * docs/gst/tmpl/gstidentity.sgml:
10317         * docs/gst/tmpl/gstmd5sink.sgml:
10318         * docs/gst/tmpl/gstmultifilesrc.sgml:
10319         * docs/gst/tmpl/gstpipefilter.sgml:
10320         * docs/gst/tmpl/gstshaper.sgml:
10321         * docs/gst/tmpl/gstspider.sgml:
10322         * docs/gst/tmpl/gstspideridentity.sgml:
10323         * docs/gst/tmpl/gststatistics.sgml:
10324         * docs/gst/tmpl/gsttee.sgml:
10325         * docs/gst/tmpl/gsttypefind.sgml:
10326         * docs/gst/tmpl/gstutils.sgml:
10327
10328 2004-04-13  David Schleef  <ds@schleef.org>
10329
10330         * configure.ac: Changes to remove POSIXisms (mmap in this case)
10331         and to build DLLs on Windows.
10332         * gst/Makefile.am:
10333         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
10334         (gst_filesrc_open_file):
10335         * gst/schedulers/Makefile.am:
10336
10337 2004-04-13  David Schleef  <ds@schleef.org>
10338
10339         * gst/gstcaps.c: (gst_caps_structure_fixate_field_nearest_int),
10340         (gst_caps_structure_fixate_field_nearest_double):  Fix bug in
10341         fixating lists.
10342
10343 2004-04-12  David Schleef  <ds@schleef.org>
10344
10345         * gst/gstbuffer.c: (_gst_buffer_initialize), (gst_buffer_get_type),
10346         (gst_buffer_free_chunk): Added gst_buffer_get_type() and changed
10347         to using it.
10348         * gst/gstbuffer.h: Changed GST_BUFFER_TYPE to gst_buffer_get_type()
10349         * gst/gstcaps.c: (gst_caps_is_fixed_foreach): Buffer is a fixed type
10350         * gst/gstpad.c: (_gst_pad_default_fixate_foreach): same
10351         * gst/gststructure.c: (gst_structure_set_valist),
10352         (gst_structure_from_abbr), (gst_structure_to_abbr): Add vararg
10353         support for buffers.
10354         * gst/gsttag.c: (gst_tag_register): Constify a prototype that was
10355         intended to be const.
10356         * gst/gsttag.h: same
10357         * gst/gstvalue.c: (gst_value_serialize_buffer),
10358         (gst_value_deserialize_buffer), (_gst_value_initialize):  Add code
10359         to (de)serialize buffers.
10360         * testsuite/caps/Makefile.am:  Add a bit of buffer testing
10361         * testsuite/caps/string-conversions.c: (main):
10362         * testsuite/caps/value_serialize.c: add new test
10363
10364 2004-04-11  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10365
10366         * docs/pwg/advanced-types.xml:
10367           Document MS video 1 (video/x-msvideocodec) mimetype/format.
10368
10369 2004-04-11  Benjamin Otte  <otte@gnome.org>
10370
10371         * gst/schedulers/gstbasicscheduler.c: (plugin_init):
10372           rename categories to basic_*
10373         * gst/schedulers/gstbasicscheduler.c: 
10374         (gst_basic_scheduler_chain_wrapper),
10375         (gst_basic_scheduler_chainhandler_proxy),
10376         (gst_basic_scheduler_gethandler_proxy),
10377         (gst_basic_scheduler_eventhandler_proxy):
10378           debugging category fixes - put common stuff in log category
10379         * gst/schedulers/gstbasicscheduler.c: 
10380         (gst_basic_scheduler_chain_elements):
10381           dirty fix: call gst_basic_scheduler_cothreaded_chain when already
10382           active and linking two active chains
10383
10384 2004-04-10  Benjamin Otte  <otte@gnome.org>
10385
10386         * docs/pwg/intro-preface.xml:
10387           fix dead links and remove reference to Wiki
10388
10389 2004-04-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10390
10391         * gst/schedulers/gstbasicscheduler.c:
10392           make sure we can switch back to the main function if we're still in
10393           the main function (supposed to fix #139617)
10394         * gst/schedulers/gthread-cothreads.h:
10395           don't throw an error when switching to the same cothread
10396
10397 2004-04-09  Benjamin Otte  <otte@gnome.org>
10398
10399         * gst/gstbin.c: (gst_bin_get_type):
10400         * gst/gstclock.c: (gst_clock_get_type):
10401         * gst/gstindex.c: (gst_index_get_type):
10402         * gst/gstobject.c: (gst_object_get_type),
10403         (gst_signal_object_get_type):
10404         * gst/gstpad.c: (gst_pad_get_type), (gst_real_pad_get_type),
10405         (gst_pad_template_get_type), (gst_ghost_pad_get_type):
10406         * gst/gstpluginfeature.c: (gst_plugin_feature_get_type):
10407         * gst/gstqueue.c: (gst_queue_get_type):
10408         * gst/gstregistry.c: (gst_registry_get_type):
10409         * gst/gstsystemclock.c: (gst_system_clock_get_type):
10410         * gst/gstthread.c: (gst_thread_get_type):
10411           don't use memchunks for these objects, use malloc instead
10412
10413 2004-04-08  Thomas Vander Stichele  <thomas at apestaart dot org>
10414
10415         * docs/gst/.cvsignore:
10416         * docs/gst/Makefile.am:
10417         * docs/gst/gstreamer-sections.txt:
10418         * docs/gst/tmpl/gstaggregator.sgml:
10419         * docs/gst/tmpl/gstbuffer.sgml:
10420         * docs/gst/tmpl/gstclock.sgml:
10421         * docs/gst/tmpl/gstelement.sgml:
10422         * docs/gst/tmpl/gstfakesink.sgml:
10423         * docs/gst/tmpl/gstfakesrc.sgml:
10424         * docs/gst/tmpl/gstfdsink.sgml:
10425         * docs/gst/tmpl/gstfdsrc.sgml:
10426         * docs/gst/tmpl/gstfilesink.sgml:
10427         * docs/gst/tmpl/gstfilesrc.sgml:
10428         * docs/gst/tmpl/gstidentity.sgml:
10429         * docs/gst/tmpl/gstindex.sgml:
10430         * docs/gst/tmpl/gstinfo.sgml:
10431         * docs/gst/tmpl/gstmd5sink.sgml:
10432         * docs/gst/tmpl/gstmultifilesrc.sgml:
10433         * docs/gst/tmpl/gstpad.sgml:
10434         * docs/gst/tmpl/gstpipefilter.sgml:
10435         * docs/gst/tmpl/gstpipeline.sgml:
10436         * docs/gst/tmpl/gstpluginfeature.sgml:
10437         * docs/gst/tmpl/gstqueue.sgml:
10438         * docs/gst/tmpl/gstregistry.sgml:
10439         * docs/gst/tmpl/gstscheduler.sgml:
10440         * docs/gst/tmpl/gstshaper.sgml:
10441         * docs/gst/tmpl/gstspider.sgml:
10442         * docs/gst/tmpl/gstspideridentity.sgml:
10443         * docs/gst/tmpl/gststatistics.sgml:
10444         * docs/gst/tmpl/gstsystemclock.sgml:
10445         * docs/gst/tmpl/gsttee.sgml:
10446         * docs/gst/tmpl/gstthread.sgml:
10447         * docs/gst/tmpl/gsttypefind.sgml:
10448         * docs/gst/tmpl/gstutils.sgml:
10449           further doc build fixes
10450
10451 2004-04-07  Thomas Vander Stichele  <thomas at apestaart dot org>
10452
10453         * docs/gst/Makefile.am:
10454           make docs exit on scanning problems
10455           fix nonsrcdir build issues
10456         * docs/gst/gstreamer-sections.txt:
10457           adding stuff from -unused
10458         * gst/gstqueue.h:
10459           create GstQueueSize
10460         * gst/schedulers/cothreads_compat.h:
10461           fix cothread warnings
10462
10463 2004-04-07  Thomas Vander Stichele  <thomas at apestaart dot org>
10464
10465         * docs/gst/gstreamer-sections.txt:
10466           remove defines deprecated by Benjamin
10467
10468 2004-04-07  Benjamin Otte  <otte@gnome.org>
10469
10470         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
10471           when the buffer is complete, don't check if other buffers are needed
10472         * gst/elements/gstfilesrc.c: (gst_filesrc_srcpad_event):
10473           check that the offset is >0 so we don't try to read before the
10474           beginning of the file
10475         * gst/gstpad.c: (gst_pad_set_pad_template):
10476           sink the template, so we don't end up with 130k pad templates
10477
10478 2004-04-06  Benjamin Otte  <otte@gnome.org>
10479
10480         * gst/autoplug/gstspider.c: (gst_spider_link_add):
10481           don't ref the element, adding already reffed it. And we didn't unref
10482           it later anyway... (huge memleak when you used many spider elements)
10483         * gst/gstelement.c: (gst_element_base_class_finalize):
10484         * gst/gstelementfactory.c: (gst_element_factory_cleanup),
10485         (gst_element_register):
10486         * gst/gsturi.c: (gst_element_make_from_uri):
10487           use gst_object_(un)ref instead of g_object(un)ref
10488
10489 2004-04-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10490
10491         * gst/gstbuffer.h:
10492           remove macro that wouldn't work anymore because struct member has
10493           been removed.
10494         * gst/schedulers/entryscheduler.c: (schedule_forward):
10495           fix segfault for unconnected pads
10496         
10497 2004-04-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10498
10499         reviewed by David Schleef <ds@schleef.org>
10500
10501         * gst/gstinfo.h:
10502           *_FORMAT modifiers should require putting a % in front of them for
10503           consistency reasons.
10504
10505 2004-04-05  Colin Walters  <walters@redhat.com>
10506
10507         * configure.ac (VALGRIND_CFLAGS, VALGRIND_LIBS): Remove spurious
10508         space.
10509
10510 2004-04-05  Benjamin Otte  <otte@gnome.org>
10511
10512         * configure.ac:
10513         * gst/Makefile.am:
10514         * gst/gst_private.h:
10515         * gst/gstinfo.c: (__gst_in_valgrind), (_gst_debug_init):
10516           add support for detecting if GStreamer runs inside valgrind.
10517           requires valgrind (d'oh) and --enable-debug for correct cdetection.
10518           print a big message in valgrind that GStreamer has detected it's
10519           running inside and might now use different code.
10520         * gst/gstmemchunk.c: (populate), (free_area),
10521         (gst_mem_chunk_destroy), (gst_mem_chunk_alloc),
10522         (gst_mem_chunk_free):
10523           flag memchunks for valgrind, so it can detect leaking of chunks.
10524           This allows detecting leaks of GstBuffer and GstEvent correctly
10525           inside valgrind.
10526
10527 2004-04-05  David Schleef  <ds@schleef.org>
10528
10529         * gst/gsttrace.h:  Fix #ifdef nesting (bug #139109) Patch from
10530           jensgr@gmx.net (Jens Granseuer)
10531
10532 2004-04-05  David Schleef  <ds@schleef.org>
10533
10534         * gst/gstbuffer.c: (_gst_buffer_sub_free),
10535         (gst_buffer_default_free), (gst_buffer_default_copy),
10536         (gst_buffer_alloc_chunk), (gst_buffer_free_chunk),
10537         (gst_buffer_new), (gst_buffer_create_sub):  Allocate GstBuffer
10538         structures in one place.
10539
10540 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10541
10542         * gst/gstinfo.h: adding Ronald's timestamp debugging defines
10543           (GST_TIME_FORMAT, GST_TIME_ARGS)
10544
10545 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10546
10547         * testsuite/elements/Makefile.am:
10548           disable test until it stops breaking make distcheck
10549
10550 2004-04-05  Johan Dahlin  <johan@gnome.org>
10551
10552         * po/sv.po: Updated translation
10553
10554 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10555
10556         * gst/gstplugin.c: (gst_plugin_load_file):
10557           fix segfault for when original plugin was loaded statically
10558
10559 2004-04-05  Benjamin Otte  <otte@gnome.org>
10560
10561         * testsuite/debug/category.c: (main):
10562         * testsuite/debug/commandline.c: (main):
10563         * testsuite/debug/output.c: (main):
10564           fix tests to work again with debugging enabled
10565
10566 2004-04-05  Benjamin Otte  <otte@gnome.org>
10567
10568         * gst/schedulers/gstbasicscheduler.c:
10569         (gst_basic_scheduler_pad_link):
10570           fix to work with recent scheduling changes
10571
10572 2004-04-05  Benjamin Otte  <otte@gnome.org>
10573
10574         * gst/schedulers/entryscheduler.c: (some functions, dunno which,
10575         prepareChangeLog doesn't work when cvs indents):
10576           don't throw an error when no element can be scheduled, there's too
10577           many weird reasons why it doesn't work. Return STOPPED instead.
10578           decoupled elemts' schedulability doesn't depend on bufpens.
10579
10580 2004-04-04  Benjamin Otte  <otte@gnome.org>
10581
10582         * gst/schedulers/gstbasicscheduler.c:
10583         (gst_basic_scheduler_pad_select):
10584           fix uninitialized variable warnings
10585
10586 2004-04-04  Benjamin Otte  <otte@gnome.org>
10587
10588         * gst/gstpad.c: (gst_pad_collect_valist):
10589           fix uninitialized variable warning
10590         * gst/schedulers/entryscheduler.c: (schedule_forward):
10591           fix shadowed variable
10592
10593 2004-04-04  Benjamin Otte  <otte@gnome.org>
10594
10595         * gst/gstpad.c: (gst_pad_collect_array), (gst_pad_collectv),
10596         (gst_pad_collect), (gst_pad_collect_valist), (gst_pad_selectv),
10597         (gst_pad_select):
10598         * gst/gstpad.h:
10599         * gst/gstscheduler.c: (gst_scheduler_pad_select),
10600         (gst_scheduler_lock_element), (gst_scheduler_unlock_element):
10601         * gst/gstscheduler.h:
10602           implement gst_pad_collect as replacement for gst_pad_select.
10603           deprecate gst_pad_select and gst_scheduler_(un)lock_element
10604           add new flag GST_SCHEDULER_FLAG_NEW_API for API that implements the
10605           new pad_select, lock and unlock calls.
10606         * gst/cothreads.c: (cothread_destroy), (cothread_switch):
10607         * gst/cothreads.h:
10608         * gst/schedulers/cothreads_compat.h:
10609         * gst/schedulers/gthread-cothreads.h:
10610           remove unused cothread_lock and cothread_unlock calls
10611         * gst/schedulers/entryscheduler.c:
10612         (gst_entry_scheduler_class_init), (gst_entry_scheduler_init),
10613         (_can_schedule_loop), (gst_entry_scheduler_get_handler),
10614         (gst_entry_scheduler_pad_select):
10615           update to new API
10616         * gst/schedulers/gstbasicscheduler.c:
10617         (gst_basic_scheduler_class_init), (gst_basic_scheduler_init),
10618         (gst_basic_scheduler_pad_select):
10619           remove useless lock and unlock calls, update pad_select to new API
10620           (untested)
10621         * gst/schedulers/gstoptimalscheduler.c:
10622         (gst_opt_scheduler_class_init):
10623           remove useless select, lock and unlock function calls
10624         * gst/elements/gstaggregator.c: (gst_aggregator_loop):
10625           use gst_pad_collect instead of gst_pad_select
10626
10627 2004-04-04  Benjamin Otte  <otte@gnome.org>
10628
10629         * gst/schedulers/entryscheduler.c: (_can_schedule_get),
10630         (can_schedule_pad), (can_schedule), (schedule), (schedule_forward),
10631         (schedule_next_element), (print_entry):
10632           add can_schedule_pad to handle element states.
10633           add schedule_forward to select the correct entry to schedule next
10634
10635 2004-04-03  Benjamin Otte  <otte@gnome.org>
10636
10637         * gst/schedulers/entryscheduler.c: 
10638           remove unused variable, fix error inside Rb, fix compile warning in
10639           unreachable code
10640
10641 2004-04-03  Benjamin Otte  <otte@gnome.org>
10642
10643         * gst/schedulers/entryscheduler.c:
10644           completely revamp the inner workings, so it's a lot easier to
10645           understand and extend
10646
10647 2004-04-03  Andy Wingo  <wingo@pobox.com>
10648
10649         * gst/schedulers/gstoptimalscheduler.c (GstOptSchedulerGroupLink):
10650         Rename ->group1 and ->group2 to ->src and ->sink, respectively.
10651         This allows better introspection of pipeline topology.
10652         (add_to_chain): Don't do trickery to put loop elements first;
10653         rather, queue a chain sort by marking the chain as dirty.
10654         (remove_from_chain): Mark the chain dirty.
10655         (sort_chain): New function. Sorts the group list so that terminal
10656         sinks are first. This means elements on the sink side will be
10657         preferentially sscheduled before elements on the src side of the
10658         pipeline.
10659         (chain_recursively_migrate_group): Use OTHER_GROUP_LINK.
10660         (schedule_chain): If the chain is marked DIRTY, call sort_chain.
10661         (gst_opt_scheduler_pad_link, gst_opt_scheduler_pad_unlink)
10662         (group_inc_link): Change argument and variable names to match the
10663         new link structure member names (src and sink).
10664         (group_dec_link): Add some description
10665
10666 2004-04-03  Benjamin Otte  <otte@gnome.org>
10667
10668         * gst/autoplug/gstspider.c: (gst_spider_identity_plug):
10669         * gst/gstinfo.h:
10670         * testsuite/debug/category.c: (main):
10671         * testsuite/debug/commandline.c: (main):
10672         * testsuite/debug/output.c: (main):
10673         * testsuite/debug/printf_extension.c: (main):
10674           fix to successfully build and test with --disable-gst-debug
10675           configure switch (fixes #138705)
10676
10677 2004-04-03  Benjamin Otte  <otte@gnome.org>
10678
10679         * docs/pwg/building-boiler.xml:
10680           add cvs login line and s/anonymous/anoncvs/
10681
10682 2004-04-03  Tim-Phillip Müller  <t.i.m@zen.co.uk>
10683
10684         reviewed by Benjamin Otte  <otte@gnome.org>
10685
10686         * gst/gststructure.c: (gst_structure_free):
10687           memleak fix: free fields array (partial fix for #134839)
10688
10689 2004-04-01  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10690
10691         * docs/random/ds/0.9-suggested-changes:
10692           Add a note to change handoff use in fakesrc to be usable in
10693           a more generic way (fakesrc should be renamed to appsrc or so).
10694         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
10695           Change signal type to scope, so we can fill the buffer in the
10696           handoff handler (that's the whole use of this signal...).
10697
10698 2004-04-01  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10699
10700         * docs/pwg/other-ntoone.xml:
10701           Document muxers and n-to-1 elements.
10702
10703 2004-04-01  Martin Soto  <martinsoto@users.sourceforge.net>
10704
10705         * gst/registries/gstxmlregistry.c
10706         (gst_xml_registry_rebuild_recurse): Fix the algorithm to
10707         determine if a file is a G_MODULE. The old one discards paths
10708         containing "so" somewhere in the middle. My home directory is
10709         called "soto". Go figure...
10710
10711 2004-03-31  David Schleef  <ds@schleef.org>
10712
10713         * gst/gstbuffer.c: (gst_buffer_join):  Add function gst_buffer_join()
10714         to eventually deprecate gst_buffer_merge().  (bug: #136408)
10715         * gst/gstbuffer.h:
10716
10717 2004-03-31  David Schleef  <ds@schleef.org>
10718
10719         * gst/gstvalue.c: (gst_value_union_int_int_range),
10720         (gst_value_union_int_range_int_range), (gst_value_can_union),
10721         (gst_value_union), (_gst_value_initialize):  Add some union
10722         implementations.  We didn't have any previously.
10723         * testsuite/caps/Makefile.am:
10724         * testsuite/caps/audioscale.c: (gst_audioscale_expand_value),
10725         (gst_audioscale_getcaps), (test_caps), (main): A little test
10726         that is the same as the caps manipulation in audioscale.
10727
10728 2004-03-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10729
10730         * docs/faq/general.xml:
10731           add entry about "does gst support format X?"
10732
10733 2004-03-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10734
10735         * gst/gstthread.c:
10736           fix docs
10737         * gst/gstutils.h:
10738           fix GST_BOILERPLATE_FULL to not throw casting errors on C++
10739
10740 2004-03-30  Benjamin Otte  <otte@gnome.org>
10741
10742         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
10743           set the offset of the buffer to the requested offset
10744         * gst/elements/gsttypefind.c: (stop_typefinding):
10745           revert patch 1.18 (which I unfortunately don't know the reason for).
10746           This is needed to allow downstream elements to seek. Otherwise
10747           typefind might overwrite a previous seek by downstream elements.
10748           This lead to errors with id3tag and typefind on some mp3s.
10749         * gst/schedulers/entryscheduler.c: (COTHREADS_TYPE),
10750         (gst_entry_scheduler_iterate):
10751           be more verbose when debugging
10752
10753 2004-03-30  Thomas Vander Stichele  <thomas at apestaart dot org>
10754
10755         * gst/gstcaps.c: (gst_caps_from_string_inplace):
10756           make sure we don't get NULL strings
10757
10758 2004-03-30  Thomas Vander Stichele  <thomas at apestaart dot org>
10759
10760         * gst/gstcaps.c:
10761         * gst/gstelement.c:
10762         * gst/gstelementfactory.c: (gst_element_factory_get_type):
10763         * gst/gstindex.c: (gst_index_resolver_get_type),
10764         (gst_index_get_type), (gst_index_factory_get_type):
10765         * gst/gstinfo.c:
10766         * gst/gstpad.c:
10767         * gst/gstplugin.c:
10768         * gst/gsturi.c: (gst_uri_handler_get_type):
10769         * gst/gstvalue.c:
10770           first batch of documentation fixes
10771
10772 2004-03-29  David Schleef  <ds@schleef.org>
10773
10774         * docs/gst/Makefile.am:  Disable a bunch of headers from being scanned
10775         * docs/gst/gstreamer-docs.sgml:  More hacking
10776         * docs/gst/gstreamer-sections.txt:
10777         * docs/gst/tmpl/cothreads_compat.sgml:
10778         * docs/gst/tmpl/gstcaps.sgml:
10779         * docs/gst/tmpl/gstclock.sgml:
10780         * docs/gst/tmpl/gstelement.sgml:
10781         * docs/gst/tmpl/gstevent.sgml:
10782         * docs/gst/tmpl/gstpad.sgml:
10783         * docs/gst/tmpl/gstutils.sgml:
10784         * docs/gst/tmpl/gstxml.sgml:
10785         * docs/gst/tmpl/gthread-cothreads.sgml:
10786         * docs/random/ds/0.9-suggested-changes:
10787         * gst/elements/gstfakesink.h: doc fixes
10788         * gst/elements/gstfakesrc.h: doc fixes
10789         * gst/gstcaps.c: doc fixes
10790         * gst/gstcaps.h: doc fixes
10791         * gst/gstelement.c: doc fixes
10792         * gst/gstelement.h: doc fixes
10793         * gst/gstindex.c: doc fixes
10794         * gst/gstinfo.c: doc fixes
10795         * gst/gstpad.c: doc fixes
10796         * gst/gstpad.h: doc fixes
10797         * gst/gstplugin.c: doc fixes
10798         * gst/gsttypefind.h: doc fixes
10799         * gst/gsturi.c: doc fixes
10800         * gst/gstvalue.c: doc fixes
10801
10802 2004-03-29  Colin Walters  <walters@redhat.com>
10803
10804         * gst/registries/gstxmlregistry.c (get_time)
10805         (plugin_times_older_than_recurse):
10806         Use the result of stat to determine whether a path is a file,
10807         so we don't attempt to opendir() files.
10808
10809 2004-03-29  Benjamin Otte  <otte@gnome.org>
10810
10811         * gst/gstpad.c: (gst_pad_set_explicit_caps):
10812           print caps in debugging output when setting caps failed
10813         * gst/schedulers/entryscheduler.c: (COTHREADS_TYPE),
10814         (schedule_next_element), (get_buffer), (run_chainhandler),
10815         (element_may_start), (gst_entry_scheduler_chain_handler),
10816         (gst_entry_scheduler_get_handler),
10817         (gst_entry_scheduler_state_transition),
10818         (gst_entry_scheduler_pad_link):
10819           make this scheduler a testcase for mandatory
10820           discont-before-first-buffer which is needed if we want to allow apps
10821           to release the sound device.
10822           add SCHED_ASSERT macro to print scheduler state before an assertion
10823           triggers.
10824
10825 2004-03-29  Benjamin Otte  <otte@gnome.org>
10826
10827         * COPYING:
10828           replace by LGPL (former COPYING.LIB). The core is completely
10829           licensed LGPL.
10830         * COPYING.LIB:
10831           remove
10832
10833 2004-03-29  Thomas Vander Stichele  <thomas at apestaart dot org>
10834
10835         * po/af.po:
10836         * po/sv.po:
10837           updated Afrikaans and Swedish
10838
10839 2004-03-29  Thomas Vander Stichele  <thomas at apestaart dot org>
10840
10841         * po/LINGUAS:
10842         * po/az.po:
10843           adding Azerbaijani (Mətin Əmirov)
10844
10845 2004-03-28  Martin Soto  <martinsoto@users.sourceforge.net>
10846
10847         * gst/gstelement.h: 
10848         * gst/gstelement.c (gst_element_set_time_delay): New function for
10849         setting element time taking into account a hardware buffering
10850         delay.
10851         (gst_element_set_time): Now just an invocation of
10852         gst_element_set_time_delay.
10853         * gst/gstclock.h: 
10854         * gst/gstclock.c (gst_clock_get_event_time_delay): New function
10855         allowing to set event times in the future.
10856         (gst_clock_get_event_time): Now just an invocation of
10857         gst_clock_get_event_time_delay.
10858
10859 2004-03-28  Benjamin Otte  <otte@gnome.org>
10860
10861         * gst/gstbin.c: (gst_bin_set_element_sched),
10862         (gst_bin_unset_element_sched):
10863           don't add decoupled elements to schedulers - otherwise it's
10864           impossible to control if a link to a decoupled element was already
10865           removed from a scheduler or not.
10866         * gst/schedulers/cothreads_compat.h:
10867         * gst/schedulers/gthread-cothreads.h:
10868           add COTHREADS_TYPE macro. Make do_cothread_set_func a macro so there
10869           is no "unused" warning.
10870         * gst/schedulers/Makefile.am:
10871         * gst/schedulers/entryscheduler.c:
10872           add new scheduler, based on ideas from talking to David and Martin.
10873           It's supposed to be small and correct. Currently it's also slow (but
10874           it's not noticable)
10875         * examples/retag/retag.c: (main):
10876         * testsuite/bytestream/test1.c: (main):
10877           fix missing NULLs at end of variadic functions
10878         * testsuite/elements/.cvsignore:
10879           update
10880
10881 2004-03-28  Jan Schmidt  <thaytan@mad.scientist.com>
10882
10883         * gst/gstevent.h:
10884         Added GST_EVENT_ANY for GstEvents that pass a GstStructure
10885
10886 2004-03-25  David Schleef  <ds@schleef.org>
10887
10888         * docs/gst/gstreamer-sections.txt:  More doc hacking.
10889         * docs/gst/tmpl/gstaggregator.sgml:
10890         * docs/gst/tmpl/gstautoplugfactory.sgml:
10891         * docs/gst/tmpl/gstbin.sgml:
10892         * docs/gst/tmpl/gstbuffer.sgml:
10893         * docs/gst/tmpl/gstbufferstore.sgml:
10894         * docs/gst/tmpl/gstfakesink.sgml:
10895         * docs/gst/tmpl/gstfakesrc.sgml:
10896         * docs/gst/tmpl/gstmd5sink.sgml:
10897         * docs/gst/tmpl/gstreamer-unused.sgml:
10898         * docs/gst/tmpl/gstsearchfuncs.sgml:
10899         * docs/gst/tmpl/gstshaper.sgml:
10900         * docs/gst/tmpl/gstspider.sgml:
10901         * docs/gst/tmpl/gsttee.sgml:
10902         * docs/gst/tmpl/gstutils.sgml:
10903         * docs/gst/tmpl/gstvalue.sgml:
10904         * docs/gst/tmpl/gstxml.sgml:
10905         * gst/Makefile.am:  Remove gstthreaddummy.c.  It never worked,
10906         and we don't support it.
10907         * gst/gst.c: (gst_init_get_popt_table), (init_pre), (init_post),
10908         (gst_use_threads), (gst_has_threads): same
10909         * gst/gstthreaddummy.c: same
10910         * gst/autoplug/gstspider.c: Make gst_spider_details static.
10911         * gst/autoplug/gstspider.h: same
10912         * gst/elements/gstaggregator.h: Remove bogus function from header
10913         * gst/elements/gstfakesink.h: same
10914         * gst/elements/gstfakesrc.h: same
10915         * gst/elements/gstmd5sink.h: same
10916         * gst/elements/gstshaper.h: same
10917         * gst/elements/gsttee.h: same
10918         * gst/gstbin.c: doc fixes
10919         * gst/gstbin.h: Remove unused definition.
10920         * gst/gstbuffer.c: doc fixes
10921         * gst/gstcaps.c: (gst_caps_is_always_compatible): doc fixes
10922         * gst/gstfilter.c: doc fixes
10923         * gst/gsttag.c: doc fixes
10924         * gst/gstvalue.c: doc fixes
10925
10926 2004-03-25  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10927
10928         * docs/pwg/advanced-types.xml:
10929           Document typefinding.
10930         * docs/pwg/other-oneton.xml:
10931           Document one-to-n elements, demuxers and parsers.
10932
10933 2004-03-25  Tim-Philipp Müller <t.i.m@zen.co.uk>
10934
10935         reviewed by: David Schleef  <ds@schleef.org>
10936
10937         * configure.ac: Check bison version (bug #127838)
10938
10939 2004-03-25  David Schleef  <ds@schleef.org>
10940
10941         * docs/gst/gstreamer-docs.sgml: More fine tuning.
10942         * docs/gst/gstreamer-sections.txt:
10943         * docs/gst/tmpl/gstautoplug.sgml:
10944         * docs/gst/tmpl/gststaticautoplug.sgml:
10945         * docs/gst/tmpl/gststaticautoplugrender.sgml:
10946         * docs/gst/tmpl/gstutils.sgml:
10947         * docs/gst/tmpl/gstxml.sgml:
10948
10949 2004-03-24  David Schleef  <ds@schleef.org>
10950
10951         * docs/gst/gstreamer-docs.sgml:  I got tired of the reference
10952         manual being such complete crap, that I decided to do major
10953         hacking of it.  This checkin replaces any fine tuning that
10954         may have been done previously, with the benefit of actually
10955         being complete for much of the API that was changed since
10956         0.6.  Further fine tuning will occur shortly.  (bug #134721)
10957         * docs/gst/gstreamer-sections.txt:
10958         * docs/gst/tmpl/GstBin.sgml:
10959         * docs/gst/tmpl/GstBuffer.sgml:
10960         * docs/gst/tmpl/GstCaps.sgml:
10961         * docs/gst/tmpl/GstClock.sgml:
10962         * docs/gst/tmpl/GstCompat.sgml:
10963         * docs/gst/tmpl/GstData.sgml:
10964         * docs/gst/tmpl/GstElement.sgml:
10965         * docs/gst/tmpl/GstEvent.sgml:
10966         * docs/gst/tmpl/GstIndex.sgml:
10967         * docs/gst/tmpl/GstStructure.sgml:
10968         * docs/gst/tmpl/GstTag.sgml:
10969         * docs/gst/tmpl/cothreads.sgml:
10970         * docs/gst/tmpl/cothreads_compat.sgml:
10971         * docs/gst/tmpl/gettext.sgml:
10972         * docs/gst/tmpl/grammar.tab.sgml:
10973         * docs/gst/tmpl/gst-i18n-app.sgml:
10974         * docs/gst/tmpl/gst-i18n-lib.sgml:
10975         * docs/gst/tmpl/gst.sgml:
10976         * docs/gst/tmpl/gst_private.sgml:
10977         * docs/gst/tmpl/gstaggregator.sgml:
10978         * docs/gst/tmpl/gstarch.sgml:
10979         * docs/gst/tmpl/gstatomic.sgml:
10980         * docs/gst/tmpl/gstatomic_impl.sgml:
10981         * docs/gst/tmpl/gstbin.sgml:
10982         * docs/gst/tmpl/gstbuffer.sgml:
10983         * docs/gst/tmpl/gstbufferstore.sgml:
10984         * docs/gst/tmpl/gstcaps.sgml:
10985         * docs/gst/tmpl/gstclock.sgml:
10986         * docs/gst/tmpl/gstcompat.sgml:
10987         * docs/gst/tmpl/gstconfig.sgml:
10988         * docs/gst/tmpl/gstcpu.sgml:
10989         * docs/gst/tmpl/gstdata.sgml:
10990         * docs/gst/tmpl/gstdata_private.sgml:
10991         * docs/gst/tmpl/gstelement.sgml:
10992         * docs/gst/tmpl/gstenumtypes.sgml:
10993         * docs/gst/tmpl/gsterror.sgml:
10994         * docs/gst/tmpl/gstevent.sgml:
10995         * docs/gst/tmpl/gstfakesink.sgml:
10996         * docs/gst/tmpl/gstfakesrc.sgml:
10997         * docs/gst/tmpl/gstfilesink.sgml:
10998         * docs/gst/tmpl/gstfilter.sgml:
10999         * docs/gst/tmpl/gstindex.sgml:
11000         * docs/gst/tmpl/gstinfo.sgml:
11001         * docs/gst/tmpl/gstinterface.sgml:
11002         * docs/gst/tmpl/gstlog.sgml:
11003         * docs/gst/tmpl/gstmacros.sgml:
11004         * docs/gst/tmpl/gstmarshal.sgml:
11005         * docs/gst/tmpl/gstmd5sink.sgml:
11006         * docs/gst/tmpl/gstmultifilesrc.sgml:
11007         * docs/gst/tmpl/gstobject.sgml:
11008         * docs/gst/tmpl/gstpad.sgml:
11009         * docs/gst/tmpl/gstparse.sgml:
11010         * docs/gst/tmpl/gstpipeline.sgml:
11011         * docs/gst/tmpl/gstplugin.sgml:
11012         * docs/gst/tmpl/gstpluginfeature.sgml:
11013         * docs/gst/tmpl/gstqueue.sgml:
11014         * docs/gst/tmpl/gstreamer-unused.sgml:
11015         * docs/gst/tmpl/gstregistry.sgml:
11016         * docs/gst/tmpl/gstregistrypool.sgml:
11017         * docs/gst/tmpl/gstscheduler.sgml:
11018         * docs/gst/tmpl/gstsearchfuncs.sgml:
11019         * docs/gst/tmpl/gstshaper.sgml:
11020         * docs/gst/tmpl/gstspider.sgml:
11021         * docs/gst/tmpl/gstspideridentity.sgml:
11022         * docs/gst/tmpl/gststructure.sgml:
11023         * docs/gst/tmpl/gstsystemclock.sgml:
11024         * docs/gst/tmpl/gsttag.sgml:
11025         * docs/gst/tmpl/gsttaginterface.sgml:
11026         * docs/gst/tmpl/gsttee.sgml:
11027         * docs/gst/tmpl/gstthread.sgml:
11028         * docs/gst/tmpl/gsttrace.sgml:
11029         * docs/gst/tmpl/gsttrashstack.sgml:
11030         * docs/gst/tmpl/gsttypefind.sgml:
11031         * docs/gst/tmpl/gsttypes.sgml:
11032         * docs/gst/tmpl/gsturi.sgml:
11033         * docs/gst/tmpl/gsturitype.sgml:
11034         * docs/gst/tmpl/gstutils.sgml:
11035         * docs/gst/tmpl/gstvalue.sgml:
11036         * docs/gst/tmpl/gstversion.sgml:
11037         * docs/gst/tmpl/gstxml.sgml:
11038         * docs/gst/tmpl/gstxmlregistry.sgml:
11039         * docs/gst/tmpl/gthread-cothreads.sgml:
11040         * docs/gst/tmpl/types.sgml:
11041
11042 2004-03-24  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11043
11044         * docs/pwg/other-sink.xml:
11045         * docs/pwg/other-source.xml:
11046           Documentation on how to write source and sink elements. Other
11047           stuff in chapter 4 (1-to-n/demuxer, n-to-1/muxer, n-to-n,
11048           manager, autoplugger) are all still pending.
11049
11050 2004-03-25  Benjamin Otte  <otte@gnome.org>
11051
11052         * testsuite/elements/Makefile.am:
11053         * testsuite/elements/gst-compprep-check:
11054           add check to make sure gst-compprep works
11055         * testsuite/elements/gst-inspect-check.in:
11056           improve initialization output
11057         * testsuite/Makefile.am:
11058         * testsuite/gst-inspect-check:
11059           remove old file
11060
11061 2004-03-24  David Schleef  <ds@schleef.org>
11062
11063         * testsuite/elements/Makefile.am:
11064         * testsuite/elements/gst-inspect-check.in: Add gst-inspect-check
11065         to the testsuite.
11066
11067 2004-03-24  Benjamin Otte  <otte@gnome.org>
11068
11069         * libs/gst/control/dparam.c: (gst_dparam_attach),
11070         (gst_dparam_detach):
11071         * libs/gst/control/dparammanager.c: (gst_dpman_init):
11072           fix lvalue casts for real
11073
11074 2004-03-24  Benjamin Otte  <otte@gnome.org>
11075
11076         * gst/schedulers/gstbasicscheduler.c:
11077         (gst_basic_scheduler_src_wrapper):
11078         * gst/schedulers/gstoptimalscheduler.c:
11079         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
11080         (pad_clear_queued), (gst_opt_scheduler_add_element),
11081         (gst_opt_scheduler_remove_element):
11082           fix GStreamer to not have issues with lvalue casts anymore (fixes
11083           #136841)
11084
11085 2004-03-24  Benjamin Otte  <otte@gnome.org>
11086
11087         * gst/gstelement.c:
11088           add documentation about a gobject quirk where the object hasn't the
11089           correct class pointer set on initialization
11090         * gst/schedulers/gstbasicscheduler.c:
11091         (gst_basic_scheduler_src_wrapper):
11092           make sure to not run into an infinite loop
11093
11094 2004-03-22  Benjamin Otte  <otte@gnome.org>
11095
11096         * gst/gstutils.c: (gst_util_dump_mem):
11097         * gst/gstutils.h:
11098           first argument of gst_util_dump_mem should be const
11099
11100 2004-03-22  Johan Dahlin  <johan@gnome.org>
11101
11102         * gst/gstvalue.h: Clean up a little bit.
11103
11104 2004-03-21  Tim-Philipp Müller <t.i.m@zen.co.uk>
11105
11106         reviewed by Benjamin Otte  <otte@gnome.org>
11107
11108         * gst/autoplug/gstspider.c: (gst_spider_dispose):
11109         * gst/elements/gstaggregator.c: (gst_aggregator_finalize),
11110         (gst_aggregator_class_init), (gst_aggregator_init):
11111         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
11112         (gst_filesrc_dispose), (gst_filesrc_set_location):
11113         * gst/elements/gstidentity.c: (gst_identity_finalize),
11114         (gst_identity_class_init), (gst_identity_chain):
11115         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_open_file):
11116         * gst/elements/gststatistics.c: (gst_statistics_finalize),
11117         (gst_statistics_class_init):
11118         * gst/elements/gsttee.c: (gst_tee_finalize), (gst_tee_class_init),
11119         (gst_tee_get_property):
11120           clean up used memory in this elements correctly on teardown (closes
11121           #137279)
11122
11123 2004-03-20  Colin Walters  <walters@redhat.com>
11124
11125         * gst/registries/gstxmlregistry.c:
11126         (gst_xml_registry_open_func, gst_xml_registry_close_func): Make
11127         registry saving atomic.
11128
11129 2004-03-20  Colin Walters  <walters@redhat.com>
11130
11131         * gst/registries/gstxmlregistry.c (gst_xml_registry_get_perms_func):
11132         Just use
11133         access() instead of actually creating and deleting files.
11134
11135 2004-03-18  David Schleef  <ds@schleef.org>
11136
11137         * configure.ac:  Remove HAVE_ATOMIC_H test, since it's unused.
11138         (bug #137625)
11139
11140 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
11141
11142         * po/sv.po: updated translation (Christian Rose)
11143
11144 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
11145
11146         * gst/elements/gstfilesink.c: (gst_filesink_get_formats),
11147         (gst_filesink_get_query_types), (_do_init),
11148         (gst_filesink_handle_event), (gst_filesink_uri_get_protocols):
11149           return FALSE silently
11150         * po/af.po: updated translation (Petri Jooste)
11151
11152 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
11153
11154         * Makefile.am:
11155         * configure.ac:
11156           dist common properly
11157         * po/af.po:
11158         * po/fr.po:
11159         * po/nl.po:
11160         * po/sr.po:
11161         * po/sv.po:
11162           refreshing translations
11163
11164 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
11165
11166         * po/LINGUAS:
11167         * po/sv.po:
11168         * po/af.po:
11169           adding Swedish (Christian Rose) and Afrikaans (Petri Jooste)
11170
11171 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
11172
11173         * Makefile.am: use common/release.mak
11174
11175 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
11176
11177         * docs/faq/gst-uninstalled:
11178           adding gst-monkeysaudio to the list of possible plugin dirs
11179
11180 2004-03-16  David Schleef  <ds@schleef.org>
11181
11182         * gst/gst.c: (gst_get_popt_options), (gst_init_get_popt_table),
11183         (gst_init_check_with_popt_table):  Fix some gettext strings to
11184         make them easier to translate.  Required making the strings
11185         non-const.
11186
11187 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
11188
11189         * configure.ac: bump nano to 1
11190
11191 === release 0.8.0 ===
11192
11193 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
11194
11195         * configure.ac: release 0.8.0, "Executive Slacks"
11196
11197 2004-03-16  Johan Dahlin  <johan@gnome.org>
11198
11199         * gst/schedulers/gstoptimalscheduler.c
11200         (gst_opt_scheduler_pad_unlink): Remove double ;,
11201         spotted by Scott Wheeler
11202
11203 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
11204
11205         * configure.ac: bump libtool version
11206
11207 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
11208
11209         * gst/gstcaps.h:
11210         * gst/gststructure.h:
11211           add reserved padding
11212
11213 2004-03-15  Benjamin Otte  <otte@gnome.org>
11214
11215         * gst/elements/gstfdsrc.c: (gst_fdsrc_get):
11216           set the first parameter for select call correctly.
11217           (fixes #137230)
11218
11219 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
11220
11221         * *.c,*.h: don't mix tabs and spaces
11222
11223 2004-03-15  Johan Dahlin  <johan@gnome.org>
11224
11225         * gst/schedulers/gstoptimalscheduler.c
11226         (gst_opt_scheduler_pad_unlink): Fix bug that causes totem to
11227         crash on MPEG playback. My boolean arithmetic is a bit rusty.
11228
11229         * tools/Makefile.am (EXTRA_DIST): Add gst-indent
11230         
11231 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
11232
11233         * testsuite/Rules:
11234           fix gst-register rules
11235
11236 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
11237
11238         * testsuite/Rules:
11239           use versioned gst-register
11240
11241 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
11242
11243         * docs/libs/gstreamer-libs-sections.txt:
11244           remove </SUBSECTION>
11245         * gst/gstplugin.c:
11246         * gst/gstregistry.c: (gst_registry_add_plugin):
11247         * gst/registries/gstxmlregistry.c: (gst_xml_registry_get_type),
11248         (gst_xml_registry_open_func), (gst_xml_registry_close_func):
11249           add debugging and fix some comment blocks
11250
11251 2004-03-15  Johan Dahlin  <johan@gnome.org>
11252
11253         * *.h: Revert indent changes.
11254         
11255 2004-03-14  Thomas Vander Stichele  <thomas at apestaart dot org>
11256
11257         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load_plugin):
11258           g_error_free the g_error
11259         * tools/gst-feedback-m.m:
11260           check for other versions of gstreamer
11261         * tools/gst-indent:
11262           use sh, not bash
11263
11264 2004-03-14  Thomas Vander Stichele  <thomas at apestaart dot org>
11265
11266         * tools/gst-register.c: do not spill paths when registries are not
11267           writable, until we fix the "user running gst-register" case.
11268
11269 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11270
11271         * *.c, *.h: commit of gst-indent run on core
11272
11273 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11274
11275         * tools/gst-indent:
11276         * tools/Makefile.am:
11277           add our indentation style as a script
11278
11279 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11280
11281         * po/sr.po:
11282         * po/LINGUAS:
11283           added Serbian translation
11284
11285 2004-03-13  Benjamin Otte  <otte@gnome.org>
11286
11287         * gst/gstelement.c:
11288           add documentation note about gst_element_found_tags_for_pad not
11289           being usable in getfunctions. (see #137042)
11290
11291 2004-03-12  David Schleef  <ds@schleef.org>
11292
11293         * gst/gstcaps.h: jdahlin, what are you smoking?  We can't just
11294         change API right now!  Readd gst_caps_is_simple() macro.
11295         * gst/gstelement.c: (gst_element_base_class_finalize): Fix
11296         uninitialized variable.  I'd bet this caused crashes.
11297         * gst/gstinfo.c: (gst_debug_print_object):  Fix 64-bit cleanliness.
11298
11299 2004-03-12  Johan Dahlin  <johan@gnome.org>
11300
11301         * gst/gstcaps.h (GST_CAPS_IS_SIMPLE): Capitalize macro
11302         * gst/gstcaps.h: Clean up
11303
11304         * gst/gst.c (init_post): call gst_caps_get_type() instead of
11305         _gst_caps_initalize()
11306
11307         * gst/gstcaps.c: Style fixes, stay closer to glib and friends
11308         (_gst_caps_initialize): Remove, in favor for gst_caps_get_type()
11309
11310         * gst/gststructure.c (gst_structure_get_type): Ditto
11311
11312         * gst/gststructure.h: Ditto
11313         
11314 2004-03-11  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11315
11316         * gst/gstqueue.c: (gst_queue_init):
11317           Reset default max. values in queues. Reason is simply to avoid
11318           braindead use. If you want wider values, use the properties. The
11319           default is supposed to always work. Wider values would make this
11320           beast a memory hog by default (250 full-PAL RGB32 video frames?
11321           That's 440 MB! No thank you).
11322
11323 2004-03-10  David Schleef  <ds@schleef.org>
11324
11325         * tools/gst-run.c: (main):  Fix crash when no relevant tools
11326         were found.  (bug #136793)
11327
11328 2004-03-10  Johan Dahlin  <johan@gnome.org>
11329
11330         * gst/schedulers/gstoptimalscheduler.c
11331         (gst_opt_scheduler_pad_unlink): Implement unlink for elements with
11332         links to elements within the same group, so we can finally remove
11333         that annoying warning. Refactor the code a little bit
11334         (group_dec_links_for_element): Split out
11335
11336 2004-03-09  David Schleef  <ds@schleef.org>
11337
11338         * docs/manual/dparams-app.xml:  Fix to handle double dparams.
11339         (bug #134863)
11340
11341 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
11342
11343         * configure.ac: first bug fix due to major/minor bump
11344
11345 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
11346
11347         * configure.ac: bump nano to 1
11348
11349 === release 0.7.6 ===
11350
11351 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
11352
11353         * NEWS:
11354         * RELEASE:
11355         * configure.ac:
11356           releasing 0.7.6, "Almost"
11357         * po/fr.po:
11358         * po/nl.po:
11359         * tools/Makefile.am:
11360         * tools/gst-feedback-m.m:
11361           unversioned source
11362
11363 2004-03-09  Johan Dahlin  <johan@gnome.org>
11364
11365         Reviewed by: Thomas Vander Stichele
11366
11367         * gst/gstelement.c (gst_element_class_init): register second
11368         parameter as GST_TYPE_G_ERROR instead of G_TYPE_POINTER, so
11369         language bindings can (de)marshall correctly.
11370
11371         * gst/gsterror.h: Add GST_TYPE_G_ERROR and cleanup a little bit
11372
11373         * gst/gsterror.c (gst_g_error_get_type): New function
11374
11375         * gst/gstmarshal.list: Remove VOID:OBJECT,POINTER,STRING, replace
11376         with VOID:OBJECT,OBJECT,STRING 
11377
11378 2004-03-10  Jan Schmidt  <thaytan@mad.scientist.com>
11379
11380         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load):
11381         Free a leaked g_timer on early returns.
11382
11383 2004-03-08  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11384
11385         * docs/pwg/advanced-types.xml:
11386           Add cinepak description.
11387
11388 2004-03-07  David Schleef  <ds@schleef.org>
11389
11390         * docs/random/mimetypes:  Added cinepak description
11391
11392 2004-03-07  Andy Wingo  <wingo@pobox.com>
11393
11394         * gst/gstbin.c (gst_bin_remove): Debugging fixes.
11395
11396         * gst/schedulers/gstoptimalscheduler.c (destroy_group): Assert
11397         there are no links to other groups when a group is destroyed.
11398         (gst_opt_scheduler_pad_unlink): If the unlink means an element is
11399         removed from a group, make sure the link count to elements linked
11400         to other pads is appropriately decremented. This really fixes
11401         #135672.
11402
11403         The 1.60->1.61 patch has been reapplied in light of this fix.
11404
11405         * gst/gstelement.c (gst_element_dispose): Really protect against
11406         multiple invocations this time.
11407
11408 2004-03-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11409
11410         * docs/gst/gstreamer-sections.txt:
11411         * docs/gst/tmpl/gsttag.sgml:
11412           remove some deprecated functions, document some existing ones
11413         * gst/gsttag.c: (gst_tag_get_flag):
11414         * gst/gsttag.h:
11415           add accessor function
11416
11417 2004-03-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11418
11419         * docs/gst/gstreamer-sections.txt:
11420         * docs/gst/tmpl/gsttag.sgml:
11421         * docs/gst/tmpl/gstxml.sgml:
11422         * gst/gsttag.c: (gst_tag_get_flag):
11423         * gst/gsttag.h:
11424
11425 2004-03-06  Christophe Fergeau  <teuf@gnome.org>
11426
11427         * gst/autoplug/gstspider.c: (gst_spider_identity_plug): fixed caps
11428         leak
11429
11430 2004-03-05  David Schleef  <ds@schleef.org>
11431
11432         * REQUIREMENTS: Add bison and flex.
11433         * configure.ac: Fix comment about bison.
11434         * docs/random/ds/0.9-suggested-changes: yer ma
11435         * tools/gst-inspect.c: (print_element_info):  Fix warning.
11436
11437 2004-03-05  Benjamin Otte  <otte@gnome.org>
11438
11439         * gst/gstelement.c: (gst_element_error_full):
11440           revert recent recursive state changing commit - messing with other
11441           elements' states is evil and should be done by apps only.
11442
11443 2004-03-05  Benjamin Otte  <otte@gnome.org>
11444
11445         * gst/gstelement.c: (gst_element_get_compatible_pad_template):
11446           check for empty intersection instead of NULL caps
11447         (gst_element_get_compatible_pad_filtered):
11448           remove old workaround that is only a bug nowadays
11449
11450 2004-03-05  Thomas Vander Stichele  <thomas at apestaart dot org>
11451
11452         * gst/gstelement.c: (gst_element_error_full):
11453           make elements try to recursively change state to PAUSED on all
11454           parents after an error to suppress ensuing warnings
11455         * gst/parse/grammar.y:
11456           make it check if it was able to sync the state, and throw an error
11457           if not, so stuff like
11458           oggdemux ! vorbisdec ! osssink gets caught
11459
11460 2004-03-05  Thomas Vander Stichele  <thomas at apestaart dot org>
11461
11462         * configure.ac: use ${libdir} for PLUGINS_DIR since on 64bit
11463           it contains lib64; use AS_AC_EXPAND to handle it properly
11464
11465 2004-03-05  David Schleef  <ds@schleef.org>
11466
11467         * gst/gstcpuid_i386.s:  Remove unused code
11468         * libs/gst/getbits/getbits.c: (gst_getbits_init),
11469         (gst_getbits_newbuf): Remove MMX code
11470         * libs/gst/getbits/getbits.h: Remove MMX code
11471
11472 2004-03-04  David I. Lehn  <dlehn@users.sourceforge.net>
11473
11474         * debian/.cvsignore:
11475         * debian/README.Debian:
11476         * debian/changelog:
11477         * debian/control:
11478         * debian/control.in:
11479         * debian/copyright:
11480         * debian/gstreamer-core-libs-dev.files:
11481         * debian/gstreamer-core-libs.files:
11482         * debian/gstreamer-core.files:
11483         * debian/gstreamer-core.postinst:
11484         * debian/gstreamer-core.postrm:
11485         * debian/gstreamer-doc.files:
11486         * debian/gstreamer-doc.links:
11487         * debian/gstreamer-doc.lintian:
11488         * debian/gstreamer-runtime.files:
11489         * debian/gstreamer-runtime.manpages:
11490         * debian/gstreamer-runtime.postinst:
11491         * debian/gstreamer-runtime.postrm:
11492         * debian/gstreamer-tools.files:
11493         * debian/gstreamer-tools.manpages:
11494         * debian/libgstreamer-dev.files:
11495         * debian/libgstreamer0.4.1.files:
11496         * debian/libgstreamerVERSION.files:
11497         * debian/rules:
11498         Debian package info not maintained here.
11499
11500 2004-03-04  Thomas Vander Stichele  <thomas at apestaart dot org>
11501
11502         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
11503         * gst/gstbin.c: (gst_bin_class_init):
11504         * gst/gstelement.c: (gst_element_class_init):
11505         * gst/gstindex.c: (gst_index_class_init):
11506         * gst/gstobject.c: (gst_object_class_init),
11507         (gst_signal_object_class_init):
11508         * gst/gstpad.c: (gst_pad_template_class_init):
11509         * gst/gstregistry.c: (gst_registry_class_init):
11510         * gst/gsturi.c: (gst_uri_handler_base_init):
11511         * gst/gstxml.c: (gst_xml_class_init):
11512         * libs/gst/control/dparam.c: (gst_dparam_class_init):
11513         * libs/gst/control/dparammanager.c: (gst_dpman_class_init):
11514           make all signal names use dashes instead of underscore
11515
11516 2004-03-03  Thomas Vander Stichele  <thomas at apestaart dot org>
11517
11518         * configure.ac: AC_SUBST GLIB_ONLY CFLAGS and LIBS
11519
11520 2004-03-03  Benjamin Otte  <otte@gnome.org>
11521
11522         * gst/schedulers/gstoptimalscheduler.c:
11523           revert last commit by Andy Wingo. It causes segfaults on unreffing
11524           in Rhythmbox. (see bug #135672)
11525
11526 2004-03-02  Christophe Fergeau  <teuf@gnome.org>
11527
11528         * po/fr.po: fix typo
11529
11530 2004-03-02  Christophe Fergeau  <teuf@gnome.org>
11531
11532         * tools/gst-inspect.c: (main): 
11533         * tools/gst-launch.c: (main): add calls to bind_textdomain_codeset
11534
11535 2004-03-02  Thomas Vander Stichele  <thomas at apestaart dot org>
11536
11537         * configure.ac:
11538           get GLIB_ONLY and POPT flags for the nonversioned binaries
11539         * tools/Makefile.am:
11540           use them
11541
11542 2004-03-02  Thomas Vander Stichele  <thomas at apestaart dot org>
11543
11544         * gst/gst.c: (init_post):
11545           change so that GST_REGISTRY now is where the global registry gets
11546           saved, since that is where plugins now get attached to first, and
11547           spilled over to the user registry.  Note that in the case of using
11548           GST_REGISTRY env var, we don't want to affect any real registries
11549           beyond the one given by this var, and thus we don't set a user
11550           registry to spill to.  So make sure GST_REGISTRY is writable.
11551
11552 2004-03-01  David Schleef  <ds@schleef.org>
11553
11554         * AUTHORS:  Added some names.  Add yourself if you're missing.
11555
11556 2004-03-01  David Schleef  <ds@schleef.org>
11557
11558         * MAINTAINERS: Add
11559
11560 2004-03-01  Thomas Vander Stichele  <thomas at apestaart dot org>
11561
11562         * configure.ac:
11563           remove whitespace
11564         * docs/gst/tmpl/gstbuffer.sgml:
11565         * docs/gst/tmpl/gstdata.sgml:
11566         * docs/gst/tmpl/gstreamer-unused.sgml:
11567         * docs/gst/tmpl/gstxml.sgml:
11568           doc update
11569         * docs/manuals.mak:
11570           add a FIXME
11571         * docs/pwg/intro-preface.xml:
11572         * docs/pwg/pwg.xml:
11573           remove GNOME
11574         * gst/gst.c: (init_post):
11575           try GST_PLUGIN_PATH paths for the _global_registry first
11576         * gst/gstelement.h:
11577           add the error message as well, otherwise (null) debug info doesn't
11578           make much sense
11579         * tools/gst-register.c: (main):
11580           spill paths to next registry if this registry is not writable
11581         * po/fr.po:
11582         * po/nl.po:
11583           translation updates
11584
11585 2004-03-01  Johan Dahlin  <johan@gnome.org>
11586
11587         * gst/gstbuffer.c (_gst_buffer_initialize): 
11588         * gst/gstdata.c (gst_data_get_type): 
11589         * gst/gstevent.c (_gst_event_initialize): Use gst_data_copy,
11590         instead of ref, since some applications that uses GBoxed
11591         routines depends on a function that actually returns a copy.
11592
11593 2004-02-27  Benjamin Otte  <otte@gnome.org>
11594
11595         * gst/gstbuffer.h:
11596           remove gst_buffer_free, use gst_data_unref
11597         * gst/gstdata.c: (gst_data_get_type):
11598           use refcounting in GstData GBoxed registration
11599         * gst/gstdata.h:
11600           remove gst_data_free, use gst_data_unref
11601
11602 2004-02-27  Johan Dahlin  <johan@gnome.org>
11603
11604         * gst/gstdata.c (gst_data_get_type): New function, register
11605         GstData as a GBoxed type.
11606
11607         * gst/gstdata.h (GST_TYPE_DATA): New macro
11608
11609 2004-02-27  Thomas Vander Stichele  <thomas at apestaart dot org>
11610
11611         * Makefile.am:
11612         * gstreamer.spec.in:
11613           put back RELEASE
11614         * gst/Makefile.am:
11615           clean up non-disting of built files
11616         * testsuite/debug/commandline.c:
11617           test fix for option rename
11618
11619 2004-02-26  David Schleef  <ds@schleef.org>
11620
11621         * configure.ac:  We don't really need glib-2.3.  Also remove
11622         some unneeded checks for library functions.
11623         * gst/Makefile.am:  Instead, we need to not dist files created
11624         by glib-genmarshal.
11625
11626 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11627
11628         * configure.ac:
11629           bump glib required version to 2.3.0 for g_value_takes_boxed
11630
11631  2004-02-25  Christian Fredrik Kalager Schaller <uraeus@gnome.org>
11632
11633         * common/m4/gst-docs.m4
11634         change flavour text from enable to disable as enable is our default
11635         closes bug Bug 135304
11636
11637 === release 0.7.5 ===
11638  
11639  2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11640  
11641         * NEWS:
11642           instate NEWS file
11643         * Makefile.am:
11644         * gstreamer.spec.in:
11645         * RELEASE:
11646           put back release
11647         * configure.ac:
11648         * docs/random/release:
11649           more updates
11650
11651 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11652
11653         * gst/gsttag.c: (_gst_tag_initialize):
11654         * po/fr.po:
11655         * po/nl.po:
11656           remove hyphen from codec tags
11657
11658 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11659
11660         * gst/parse/Makefile.am:
11661           fix dependency so that a make from a clean build works the first
11662           time
11663
11664 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11665
11666         * docs/random/release:
11667           update release strategy
11668         * po/fr.po:
11669           auto-update po file
11670         * po/nl.po:
11671           update dutch translation
11672
11673 2004-02-25  Thomas Vander Stichele  <thomas at apestaart dot org>
11674
11675         * docs/manual/debugging.xml:
11676         fix manual for new debugging system
11677
11678 2004-02-25  Andy Wingo  <wingo@pobox.com>
11679
11680         * gst/gstpad.c (gst_pad_link_prepare): Re-add
11681         gst_pad_link_prepare. Please email the list with specific reasons
11682         for reverting.
11683
11684 2004-02-24  Andy Wingo  <wingo@pobox.com>
11685
11686         * gst/gstelement.c (gst_element_dispose): Protect against multiple
11687         invocations.
11688
11689         * gst/schedulers/gstoptimalscheduler.c:
11690         I added a mess of prototypes at the top of the file by way of
11691         documentation. Some of the operations on chains and groups were
11692         re-organized.
11693
11694         (create_group): Added a type argument so if the group is enabled,
11695         the setup_group_scheduler knows what to do.
11696         (group_elements): Added a type argument here, too, to be passed on
11697         to create_group.
11698         (group_element_set_enabled): If an unlinked PLAYING element is
11699         added to a bin, we have to create a new group to hold the element,
11700         and this function will be called before the group is added to the
11701         chain. Thus we have a valid case for group->chain==NULL. Instead
11702         of calling chain_group_set_enabled, just set the flag on the group
11703         (the chain's status will be set when the group is added to it).
11704         (gst_opt_scheduler_state_transition, chain_group_set_enabled):
11705         Setup the group scheduler when the group is enabled, not
11706         specifically when an element goes PAUSED->PLAYING. This means
11707         PLAYING elements can be added, linked, and scheduled into a
11708         PLAYING pipeline, as was intended.
11709         (add_to_group): Don't ref the group twice. I don't know when this
11710         double-ref got in here. Removing it has the potential to cause
11711         segfaults if other parts of the scheduler are buggy. If you find
11712         that the scheduler is segfaulting for you, put in an extra ref
11713         here and see if that hacks over the underlying issue. Of course,
11714         then find out what code is unreffing a group it doesn't own...
11715         (create_group): Make the extra refcount floating, and remove it
11716         after adding the element. This means that...
11717         (unref_group): Destroy when the refcount reaches 0, not 1, like
11718         every other refcounted object in the known universe.
11719         (remove_from_group): When a group becomes empty, set it to be not
11720         active, and remove it from its chain. Don't unref it again,
11721         there's no floating reference any more.
11722         (destroy_group): We have to remove the group from the chain in
11723         remove_from_group (rather than here) to break refcounting cycles
11724         (the chain always has a ref on the group). So assert that
11725         group->chain==NULL.
11726         (ref_group_by_count): Removed, it was commented out anyway.
11727         (merge_chains): Use the remove_from_chain and add_to_chain
11728         primitives to do the reparenting, instead of rolling our own
11729         implementation.
11730         (add_to_chain): The first non-disabled group in the chain's group
11731         list will be the entry point for the chain. Because buffers can
11732         accumulate in loop elements' peer bufpens, we preferentially
11733         schedule loop groups before get groups to avoid unnecessary
11734         execution of get-based groups when the bufpens are already full.
11735         (gst_opt_scheduler_schedule_run_queue): Debug fixes.
11736         (get_group_schedule_function): Ditto.
11737         (loop_group_schedule_function): Ditto.
11738         (gst_opt_scheduler_loop_wrapper): Ditto.
11739         (gst_opt_scheduler_iterate): Ditto.
11740
11741         I understand the opt scheduler now, yippee!
11742
11743         * gst/gstpad.c: All throughout, added FIXMEs to look at for 0.9.
11744         (gst_pad_get_name, gst_pad_set_chain_function) 
11745         (gst_pad_set_get_function, gst_pad_set_event_function) 
11746         (gst_pad_set_event_mask_function, gst_pad_get_event_masks) 
11747         (gst_pad_get_event_masks_default, gst_pad_set_convert_function) 
11748         (gst_pad_set_query_function, gst_pad_get_query_types) 
11749         (gst_pad_get_query_types_default) 
11750         (gst_pad_set_internal_link_function) 
11751         (gst_pad_set_formats_function, gst_pad_set_link_function) 
11752         (gst_pad_set_fixate_function, gst_pad_set_getcaps_function) 
11753         (gst_pad_set_bufferalloc_function, gst_pad_unlink) 
11754         (gst_pad_renegotiate, gst_pad_set_parent, gst_pad_get_parent) 
11755         (gst_pad_add_ghost_pad, gst_pad_proxy_getcaps) 
11756         (gst_pad_proxy_pad_link, gst_pad_proxy_fixate) 
11757         (gst_pad_get_pad_template_caps, gst_pad_check_compatibility) 
11758         (gst_pad_get_peer, gst_pad_get_allowed_caps) 
11759         (gst_pad_alloc_buffer, gst_pad_push, gst_pad_pull) 
11760         (gst_pad_selectv, gst_pad_select, gst_pad_template_get_caps) 
11761         (gst_pad_event_default_dispatch, gst_pad_event_default) 
11762         (gst_pad_dispatcher, gst_pad_send_event, gst_pad_convert_default) 
11763         (gst_pad_convert, gst_pad_query_default, gst_pad_query) 
11764         (gst_pad_get_formats_default, gst_pad_get_formats): Better
11765         argument checks, and some doc fixes.
11766
11767         (gst_pad_custom_new_from_template): Um, does anyone
11768         use these functions? Actually make a custom pad instead of a
11769         normal one.
11770         (gst_pad_try_set_caps): Transpose some checks.
11771         (gst_pad_try_set_caps_nonfixed): Same, and use a macro to check if
11772         the pad is in negotiation.
11773         (gst_pad_try_relink_filtered): Use pad_link_prepare.
11774         
11775         * gst/gstelement.c: Remove prototypes also defined in gstclock.h.
11776
11777         * gst/gstelement.h: 
11778         * gst/gstclock.h: Un-deprecate the old clocking API, as discussed
11779         on the list.
11780
11781 2004-02-24  Thomas Vander Stichele  <thomas at apestaart dot org>
11782
11783         * gst/gstbin.c: (gst_bin_add):
11784           add error for not being able to add elements
11785
11786 2004-02-22  Julien MOUTTE <julien@moutte.net>
11787
11788         * gst/gsttag.c: (_gst_tag_initialize): Registering 2 new tags,
11789         audio-codec and video-codec.
11790
11791 2004-02-22  Benjamin Otte  <otte@gnome.org>
11792
11793         reported by: Padraig O'Briain <padraig.obriain@sun.com>
11794
11795         * autogen.sh:
11796           replace test -e with test -x for mkinstalldirs to be more portable.
11797           (fixes #134816)
11798
11799 2004-02-22  Benjamin Otte  <otte@gnome.org>
11800
11801         * gst/gstpad.c:
11802           revert last patch from Andy, it makes gst_pad_can_link_filtered much
11803           too noisy
11804         * gst/gsttag.c: (_gst_tag_initialize):
11805         * gst/gsttag.h:
11806           add GST_TAG_ALBUM_VOLUME_{COUNT,NUMBER}
11807         * libs/gst/control/dparam.c: (gst_dparam_attach):
11808         * libs/gst/control/dparammanager.c: (gst_dpman_attach_dparam):
11809           check that types for attached dparams match
11810
11811 2004-02-22  Thomas Vander Stichele  <thomas at apestaart dot org>
11812
11813         * gst/elements/gstfilesink.c: (gst_filesink_open_file):
11814         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
11815         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_open_file):
11816           fix errors
11817
11818 2004-02-20  Andy Wingo  <wingo@pobox.com>
11819
11820         * gst/gstbin.c:
11821         * gst/gstbuffer.c:
11822         * gst/gstplugin.c:
11823         * gst/registries/gstxmlregistry.c: 
11824         * gst/schedulers/gstoptimalscheduler.c: Debugging tweaks.
11825
11826         * gst/gstelement.c (gst_element_set_scheduler): Debugging fixes.
11827         (gst_element_add_pad): DEBUG->INFO, some fixes.
11828         (gst_element_get_compatible_pad_template): Just see if the
11829         templates' caps intersect, not if one is a strict subset of the
11830         other. This conforms more to what gst_pad_link_intersect() does.
11831         (gst_element_class_add_pad_template): Don't memcpy the pad
11832         template, just ref it.
11833         (gst_element_get_compatible_pad_filtered): Clean up debug messages
11834
11835         * gst/gstpad.c (gst_pad_can_link_filtered): Debug a true result.
11836         (gst_pad_link_filtered): Debug changes.
11837         (gst_pad_link_prepare): New function, consolidated from
11838         can_link_filtered and link_filtered.
11839
11840         * gst/parse/grammar.y (gst_parse_perform_link): Made INFO output
11841         look more like that of the functions in gstelement.c
11842
11843         * gst/gstinfo.c (gst_debug_print_object): Put a space before the
11844         object, and return the empty string if object is NULL.
11845
11846         * gst/parse/parse.l: Remove trailing newlines when calling PRINT.
11847         * gst/parse/grammar.y (YYFPRINTF): Log bison debugging info via
11848         LOG, not DEBUG. We still get flex info on debug.
11849
11850         * gst/registries/gstxmlregistry.c (gst_xml_registry_load): Make
11851         debug string more verbose.
11852         (plugin_times_older_than): DEBUG->LOG.
11853
11854 2004-02-20  Julien MOUTTE <julien@moutte.net>
11855
11856         * gst/gsttag.h: Adding video-codec and audio-codec for demuxers which
11857         will emit found_tag for each stream they demux with the codec.
11858
11859 2004-02-20  Benjamin Otte  <otte@gnome.org>
11860
11861         * gst/gstevent.c: (_gst_event_copy), (_gst_event_free):
11862           copy navigation event correctly. Check freeing tag lists. 
11863         * gst/gstthread.c: (gst_thread_change_state):
11864           don't abort() on state changing mess - it might happen because of
11865           bugs.
11866         * gst/gstvalue.c: (gst_value_set_caps), (gst_value_get_caps):
11867           use boxed functions
11868         * gst/gstvalue.h:
11869           fix GST_VALUE_HOLDS_CAPS
11870
11871 2004-02-19  David Schleef  <ds@schleef.org>
11872
11873         * gst/gstinfo.h:  Copy G_STRFUNC implementation from glib-2.4
11874         and use it for GST_FUNCTION.  (bug #134750)
11875
11876 2004-02-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11877
11878         * po/fr.po:
11879         * po/nl.po:
11880           updating translations
11881
11882 2004-02-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11883
11884         * tools/gst-run.c: (get_candidates), (main): some fixes from jdahlin
11885
11886 2004-02-18  kost@imn.htwk-leipzig.de
11887
11888         reviewed by: David Schleef  <ds@schleef.org>
11889
11890         * docs/libs/gstreamer-libs-sections.txt:  Add missing sections
11891         for libgstcontrol.
11892
11893 2004-02-18  David Schleef  <ds@schleef.org>
11894
11895         * libs/gst/control/dparam.c: (gst_dparam_class_init):
11896         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_class_init),
11897         (gst_dpsmooth_new): Additional fixes to get double dparams working.
11898         * tools/gst-inspect.c: (print_element_info): Support dumping of
11899         double dparam information.
11900
11901 2004-02-17  David Schleef  <ds@schleef.org>
11902
11903         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
11904         Use G_TYPE_STRING in signal prototype instead of G_TYPE_POINTER.
11905         * gst/elements/gsttypefind.c: (gst_type_find_element_class_init):
11906         Use GST_TYPE_CAPS in signal prototype.
11907         * gst/gstcaps.c: (_gst_caps_initialize), (gst_caps_copy_conditional):
11908         Convert GST_TYPE_CAPS to boxed.
11909         * gst/gstelement.c: (gst_element_class_init):
11910         Use GST_TYPE_TAG_LIST in signal prototype.
11911         * gst/gstindex.c: (gst_index_class_init):
11912         * gst/gstindex.h:
11913         Add GST_TYPE_INDEX_ENTRY type.
11914         * gst/gstmarshal.list:
11915         Add necessary marshal types.
11916         * gst/gstpad.c: (gst_real_pad_class_init),
11917         (_gst_real_pad_fixate_accumulator), (gst_pad_link_fixate),
11918         (gst_pad_recover_caps_error):
11919         Use GST_TYPE_CAPS in signal prototypes.  Fix some debugging strings.
11920         * gst/gststructure.c: (_gst_structure_initialize),
11921         (gst_structure_copy), (_gst_structure_copy_conditional):
11922         * gst/gststructure.h:
11923         Convert GST_TYPE_STRUCTURE to boxed.
11924         * gst/gsttag.c: (gst_tag_list_get_type):
11925         * gst/gsttag.h:
11926         Add GST_TYPE_TAG_LIST type.
11927
11928 2004-02-17  Julien MOUTTE  <julien@moutte.net>
11929
11930         * gst/gstpad.c: (gst_pad_try_set_caps): Reverting my change according
11931         to what we agreed with david.
11932         * gst/gstpad.h: adding GST_PAD_IS_NEGOTIATING macro.
11933
11934 2004-02-17  Thomas Vander Stichele  <thomas at apestaart dot org>
11935
11936         * po/nl.po: update translation
11937
11938 2004-02-17  Thomas Vander Stichele  <thomas at apestaart dot org>
11939
11940         * gst/autoplug/gstspider.c: (gst_spider_identity_plug):
11941           throw an error if spider is trying to play a mime type there is
11942           no decoder for
11943         * po/POTFILES.in:
11944           add gst/autoplug/gstspider.c for translation
11945
11946 2004-02-17  Julien MOUTTE  <julien@moutte.net>
11947
11948         * gst/gstpad.c: (gst_pad_try_set_caps): We are nice people. Return 
11949         silently when the pad is negotiating.
11950
11951 2004-02-16  Thomas Vander Stichele  <thomas at apestaart dot org>
11952
11953         * docs/faq/Makefile.am:
11954           add script to run gstreamer uninstalled 
11955         * docs/faq/faq.xml:
11956         * docs/faq/developing.xml:
11957         * docs/faq/gst-uninstalled:
11958           extract script to run gstreamer uninstalled
11959         * docs/manuals.mak:
11960           add EXTRA_SOURCES variable for Makefile.am's to set to
11961           use additional SOURCE files for the doc build
11962
11963 2004-02-16  Thomas Vander Stichele  <thomas at apestaart dot org>
11964
11965         * gst/gstatomic_impl.h: Fedora 2 test package patch for S390
11966
11967 2004-02-15  Julien MOUTTE  <julien@moutte.net>
11968
11969         * gst/gstbin.c: (gst_bin_change_state), (gst_bin_iterate): Fix a big
11970         bug that was breaking pipelines like sinesrc ! { queue ! osssink } when
11971         an error was thrown by osssink. Basically a state change failure for
11972         an element in a different scheduling group was considered as
11973         successful, which means that caps nego was going on and weird stuff
11974         happened. Like I wrote in the comment there, if someone wants to
11975         revert that please drop me a mail explaining why because I really see
11976         no point in keeping that broken behaviour there.
11977         * gst/gstqueue.c: (gst_queue_get): Add a safety check as the queue CAN
11978         be empty, we then return NULL which will trigger a nice error when 
11979         pulling from the pad.
11980
11981 2004-02-13  David Schleef  <ds@schleef.org>
11982
11983         * libs/gst/control/dparam.c: (gst_dparam_class_init),
11984         (gst_dparam_get_property), (gst_dparam_set_property),
11985         (gst_dparam_do_update_default):
11986         * libs/gst/control/dparam.h:
11987         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_class_init),
11988         (gst_dpsmooth_new), (gst_dpsmooth_set_property),
11989         (gst_dpsmooth_get_property), (gst_dpsmooth_value_changed_double),
11990         (gst_dpsmooth_do_update_double):
11991         * libs/gst/control/dparam_smooth.h:
11992         * libs/gst/control/dparammanager.c:
11993         (gst_dpman_inline_direct_update):
11994         Add support for double dparams.
11995
11996 2004-02-13  David Schleef  <ds@schleef.org>
11997
11998         * gst/elements/gstfdsrc.c: (gst_fdsrc_get): Use GST_TIME_TO_TIMEVAL()
11999         * gst/gstclock.h: Avoid using 64-bit % operator (slow!)
12000
12001 2004-02-13  Mattias Wadman  <mattias@sudac.org>
12002
12003         reviewed by: David Schleef  <ds@schleef.org>
12004
12005         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init),
12006         (gst_fdsrc_init), (gst_fdsrc_set_property),
12007         (gst_fdsrc_get_property), (gst_fdsrc_get):
12008         * gst/elements/gstfdsrc.h:  Adds timeout property to fdsrc,
12009         and sends an EOS event if file descriptor reading times out.
12010
12011 2004-02-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12012
12013         * configure.ac:
12014           add calls to AM_CONDITIONAL for subsystems for automake 1.6.x
12015
12016 2004-02-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12017
12018         * configure.ac: pass required libxml version as argument
12019         (bug reported by Christophe Fergeau)
12020
12021 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12022   
12023         * docs/gst/gstreamer-docs.sgml:
12024         * docs/gst/tmpl/gstxml.sgml:
12025         * docs/libs/gstreamer-libs-docs.sgml:
12026           version API docs
12027
12028 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12029
12030         * gst/gstinfo.c:
12031         * gst/gstregistrypool.c: (gst_registry_pool_plugin_filter),
12032         (gst_registry_pool_feature_filter):
12033         * gst/gstthread.c: (gst_thread_class_init):
12034         * gst/gstvalue.c:
12035           add includes exposed by building without libxml
12036         * gst/indexers/Makefile.am:
12037           do not build fileindex when LOADSAVE disabled; we should have
12038           a better libxml check later since fileindex depends on xml, not
12039           LOADSAVE or REGISTRY
12040         * libs/gst/control/Makefile.am:
12041           link with m
12042         * tools/Makefile.am:
12043           fix wrong source code for gst-xmlinspect
12044
12045 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12046
12047         * configure.ac:
12048           fix gcov help output
12049           move calls to and use new GST_CHECK_DISABLE_SUBSYSTEM
12050         * docs/random/release:
12051           some updated releasing notes
12052         * gstreamer.spec.in:
12053           more updates
12054
12055 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12056
12057         * docs/faq/faq.xml:
12058         * docs/manual/manual.xml:
12059         * docs/pwg/pwg.xml:
12060         * docs/pwg/titlepage.xml:
12061           put version in documentation
12062
12063 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12064
12065         * tools/Makefile.am: fix man page installation
12066
12067 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12068
12069         * configure.ac:
12070           don't check for libxml when load/save and registry disabled (#105844)
12071         * gstreamer.spec.in:
12072           sync with fedora candidate spec
12073
12074 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12075
12076         * po/fr.po:
12077         * po/nl.po:
12078           replace multidisksrc with multifilesrc
12079
12080 2004-02-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12081
12082         * po/POTFILES.in:
12083           update to multidisksrc => multifilesrc file renaming (#134145)
12084
12085 2004-02-11  David Schleef  <ds@schleef.org>
12086
12087         * docs/gst/tmpl/gstcaps.sgml:  Fix stuff that mentions GstProps
12088         * docs/gst/tmpl/gstpadtemplate.sgml: same
12089         * docs/gst/tmpl/gstreamer-unused.sgml: Remove GstProps
12090         * gst/gstobject.c: (gst_object_set_name_default): Do the memleak
12091         fixing dance.
12092         * gst/gstutils.c: Remove disabled code that uses GstProps.
12093         * gst/registries/gstxmlregistry.h: same
12094         * docs/random/ds/0.9-suggested-changes: random notes
12095
12096 2004-02-11  kost@imn.htwk-leipzig.de
12097
12098         reviewed by: David Schleef  <ds@schleef.org>
12099
12100         * gst/gstclock.c: (gst_clock_entry_new): fixes structure
12101         initialisation of clock (bug #134128)
12102
12103 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
12104
12105         * configure.ac:
12106         * gst/elements/Makefile.am:
12107         * gst/elements/gstelements.c:
12108         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_base_init),
12109         (gst_multifilesrc_class_init), (gst_multifilesrc_init),
12110         (gst_multifilesrc_set_property), (gst_multifilesrc_get_property),
12111         (gst_multifilesrc_get), (gst_multifilesrc_open_file),
12112         (gst_multifilesrc_close_file), (gst_multifilesrc_change_state):
12113         * gst/elements/gstmultifilesrc.h:
12114           rename multidisksrc to multifilesrc (part of #122200)
12115
12116 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
12117
12118         * docs/manuals.mak:
12119           fix automake complaints
12120         * gst-element-check.m4:
12121           fix unquotedness
12122
12123 2004-02-11  David Schleef  <ds@schleef.org>
12124
12125         * docs/gst/Makefile.am: Call gst_init() in built gstreamer-scan.
12126         * gst/gstatomic_impl.h: Disable sparc implementation.
12127
12128 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
12129
12130         * gst-element-check.m4:
12131           fix underquoted macros as reported by automake 1.8.x (#133800)
12132         * configure.ac:
12133           require gettext 0.11.5 so ulonglong.m4 gets checked out and copied
12134           by autopoint (fixes #132996)
12135
12136 2004-02-10  Andy Wingo  <wingo@pobox.com>
12137
12138         * gst/gstpad.c (gst_pad_custom_new): Add a FIXME, this is a hacky
12139         way to do inheritance.
12140         (gst_pad_get_event_masks, gst_pad_get_event_masks_default) 
12141         (gst_pad_get_query_types, gst_pad_get_query_types_default):
12142         Routine docs.
12143         (gst_pad_set_link_function, gst_pad_set_fixate_function) 
12144         (gst_pad_set_getcaps_function): Doc from Dave's negotation random
12145         doc.
12146         (gst_pad_unlink, gst_pad_is_linked): Docs.
12147         (gst_pad_renegotiate): A brief description of capsnego.
12148         (gst_pad_try_set_caps): Document.
12149         (gst_pad_try_set_caps_nonfixed): Document.
12150         (gst_pad_can_link_filtered, gst_pad_link_filtered): Doc fixes.
12151         (gst_pad_set_parent): Deprecated (although not out of the API).
12152         (gst_pad_get_parent): Deprecated, although many plugins use this.
12153         (gst_pad_add_ghost_pad, gst_pad_remove_ghost_pad): Doc that these
12154         are private and will go away in 0.9.
12155         (gst_pad_perform_negotiate): Doc.
12156         (gst_pad_link_unnegotiate): I think this is meant to be static.
12157         (gst_pad_get_negotiated_caps, gst_pad_get_pad_template_caps) 
12158         (gst_pad_template_get_caps_by_name, gst_pad_check_compatibility) 
12159         (gst_pad_get_peer): Doc updates.
12160         (gst_pad_caps_change_notify): Doc.
12161         (gst_pad_alloc_buffer, gst_pad_push, gst_static_pad_template_get) 
12162         (gst_ghost_pad_new): Doc fixes.
12163
12164         * gst/gstobject.c (gst_object_get_parent, gst_object_unparent) 
12165         (gst_object_check_uniqueness): 
12166
12167         * gst/gstelement.c (gst_element_add_pad) 
12168         (gst_element_add_ghost_pad, gst_element_remove_pad) 
12169         (gst_element_remove_ghost_pad, gst_element_get_pad) 
12170         (gst_element_get_static_pad, gst_element_get_pad_list) 
12171         (gst_element_class_get_pad_template_list) 
12172         (gst_element_class_get_pad_template): Work on the docs.
12173         (gst_element_get_pad_template_list): Uses the class method.
12174         (gst_element_get_compatible_pad_template): Docs, and consolidate
12175         some test conditions. 
12176         (gst_element_get_pad_from_template): New static function.
12177         (gst_element_request_compatible_pad): Docs, and work with
12178         non-request compatible templates. 
12179         (gst_element_get_compatible_pad_filtered): Docs and remove
12180         redundant checks.
12181         (gst_element_get_compatible_pad, gst_element_link_pads_filtered) 
12182         (gst_element_link_filtered, gst_element_link_many) 
12183         (gst_element_link, gst_element_link_pads) 
12184         (gst_element_unlink_many): Docs.
12185
12186 2004-02-05  Andy Wingo  <wingo@pobox.com>
12187
12188         * gst/gstpad.c (_gst_real_pad_fixate_accumulator):
12189         s/pointer/boxed/.
12190
12191         * gst/gstmarshal.list (VOID:BOXED, BOXED:BOXED): New marshallers.
12192
12193         * gst/gstpad.c (gst_real_pad_class_init): Use a BOXED:BOXED
12194         marshaller for ::fixate, and VOID:BOXED for ::caps-nego-failed,
12195         with the type=GST_TYPE_CAPS. This allows language bindings to know
12196         what kind of data they're dealing with.
12197
12198         * gst/gstcaps.c (_gst_caps_value_init): GBoxed values initialize
12199         to NULL when g_value_init is called. GstCaps, which rolls its own
12200         type implementation, now does the same instead of allocating empty
12201         caps.
12202         (_gst_caps_initialize, _gst_caps_collect_value,
12203         _gst_caps_lcopy_value): Provide collect_value and lcopy_value type
12204         table methods. This allows G_VALUE_COLLECT to work.
12205
12206 2004-02-05  Andy Wingo  <wingo@pobox.com>
12207
12208         * configure.ac:
12209         * testsuite/Makefile.am (SUBDIRS): 
12210         * testsuite/ghostpads/Makefile.am: 
12211         * testsuite/ghostpads/ghostpads.c: A new test for ghost pads.
12212
12213         * gst/gstpad.c (gst_pad_add_ghost_pad, gst_pad_remove_ghost_pad):
12214         These two routines are the only ones that set
12215         GST_GPAD_REALPAD(gpad), the ghost pad list, and the ghost pad's
12216         pad template. They should be made static, depending on ABI needs.
12217         (gst_real_pad_dispose): Handle the case of ghost pads without a
12218         parent. Assert after dealing with ghost pads that the ghost pad
12219         list is empty.
12220         (gst_ghost_pad_class_init): New property added, ::real-pad. Can be
12221         set after creation.
12222         (gst_ghost_pad_dispose): Set ::real-pad to NULL.
12223         (gst_ghost_pad_set_property, gst_ghost_pad_get_property): New
12224         functions. set_property will call add_ghost_pad/remove_ghost_pad
12225         as appropriate.
12226         (gst_ghost_pad_new): All the work is offloaded to g_object_new.
12227
12228         * gst/gstelement.c (gst_element_add_pad): Handle ghost pads as well.
12229         (gst_element_add_ghost_pad): Remove code duplicated from _add_pad.
12230         (gst_element_remove_pad): Handle ghost pads as well.
12231         (gst_element_remove_ghost_pad): Deprecated (could be removed,
12232         depending on API-stability needs).
12233
12234 2004-02-05  Andy Wingo  <wingo@pobox.com>
12235
12236         * gst/gstbin.[ch]: (gst_bin_get_by_interface): GTypes are scalars,
12237         of course they're const
12238
12239 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
12240
12241         * tools/Makefile.am:
12242         * tools/gst-feedback:
12243         * tools/gst-feedback-0.7:
12244           make gst-feedback versioned too for consistency
12245
12246 2004-02-11  David Schleef  <ds@schleef.org>
12247
12248         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
12249         (gst_pad_try_set_caps): Fix format strings for GST_PTR_FORMAT.
12250
12251 2004-02-10  Julien MOUTTE <julien@moutte.net>
12252
12253         * gst/gstevent.c: (_gst_event_free): Sometimes a tag event arrives but
12254         the structure does not contain a valid tag list. Adding a safety check
12255         to remove a noisy warning in that case.
12256
12257 2004-02-10  Thomas Vander Stichele  <thomas at apestaart dot org>
12258
12259         * gst/gst.c: fix name to be in line with others
12260
12261 2004-02-09  Julien MOUTTE <julien@moutte.net>
12262
12263         * libs/gst/bytestream/bytestream.c: (gst_bytestream_peek): We should
12264         not shout that loud when len is 0. Just return 0 silently.
12265
12266 2004-02-09  Julien MOUTTE  <julien@moutte.net>
12267
12268         * gst/gstdata.c: (gst_data_ref): Adding a categorized debug on data_ref
12269         because data_unref has one and I prefer the debug to be symetric.
12270         * gst/gstqueue.c: (gst_queue_locked_flush): Fix a huge memleak. Buffers
12271         were refed when added to the queue and unrefed only once when the queue
12272         was flushed. Now the flush handler unref the buffers two times : first
12273         unref for the ref added when pushing in the queue's tail and second
12274         unref to destroy the flushed buffer.
12275
12276 2004-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
12277
12278         * docs/pwg/building-boiler.xml: fix cvs checkout documentation
12279
12280 2004-02-06  David Schleef  <ds@schleef.org>
12281
12282         * docs/random/ds/0.9-suggested-changes: Random ramblings
12283         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap): Cast size_t
12284         to int before printing.
12285         * gst/parse/grammar.y: Fix gcc-2.95 style variadic macros.
12286         * gst/parse/parse.l: same.  See bug #129600
12287
12288 2004-02-06  David Schleef  <ds@schleef.org>
12289
12290         * gst/gstindex.c: (gst_index_add_format), (gst_index_add_id),
12291         (gst_index_add_entry), (gst_index_add_associationv),
12292         (gst_index_add_association): Add gst_index_add_associationv()
12293         and clean up gst_index_add_association(). #127133
12294
12295 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
12296
12297         * autogen.sh: check out common with right tag if CVS/Tag exists
12298
12299 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
12300
12301         * testsuite/ghostpads/ghostpads.c: (main):
12302           fix testsuite from segfaulting
12303
12304 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
12305
12306         * Makefile.am: add release target
12307         * configure.ac: bump nano to 1
12308         * docs/random/release:
12309
12310 2004-02-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12311
12312         * gst/gstcaps.h:
12313         * gst/gstelement.c: (gst_element_base_class_init),
12314         (gst_element_class_set_details), (gst_element_clear_pad_caps):
12315         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
12316         (gst_pad_try_set_caps), (gst_pad_can_link_filtered),
12317         (gst_real_pad_dispose):
12318         * gst/gststructure.c: (gst_structure_free),
12319         (gst_structure_from_string):
12320           put reverted patch back in
12321         * gst/gstelement.c: (gst_element_remove_pad):
12322           free explicit caps if they're set
12323         * gst/gstpad.c: (_gst_pad_default_fixate_func):
12324           copy the structure when fixating
12325
12326 2004-02-05  David Schleef  <ds@schleef.org>
12327
12328         * gst/gstmarshal.list:
12329         * gst/gstpad.c: (gst_real_pad_class_init),
12330         (_gst_real_pad_fixate_accumulator):
12331         Revert POINTER->BOXED change in signal marshaller.
12332
12333 === release 0.7.4 ===
12334                                                                                 
12335 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
12336                                                                                 
12337         * NEWS: GStreamer 0.7.4 "Wooden Eels" released
12338         * configure.ac: changed for release
12339
12340 2004-02-05  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
12341
12342         * gstreamer.spec.in:
12343           bump required version of gtk-doc
12344
12345 2004-02-05  Thomas Vander Stichele  <thomas at apestaart dot org>
12346
12347         * gst/gstcaps.h:
12348         * gst/gstelement.c: (gst_element_base_class_init),
12349         (gst_element_class_set_details), (gst_element_clear_pad_caps):
12350         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
12351         (gst_pad_try_set_caps), (gst_pad_can_link_filtered),
12352         (gst_real_pad_dispose):
12353         * gst/gststructure.c: (gst_structure_free),
12354         (gst_structure_from_string):
12355           revert patch that breaks applications, reapply after release
12356           to get this fixed properly
12357
12358 2004-02-05  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12359
12360         * gst/gsttag.c: (_gst_tag_initialize):
12361         * gst/gsttag.h:
12362           remove duplicated field GST_TAG_APPLICATION. It's GST_TAG_ENCODER
12363
12364 2004-02-04  David Schleef  <ds@schleef.org>
12365
12366         Fix some memleaks:
12367         * gst/autoplug/gstspider.c: (gst_spider_request_new_pad),
12368         (gst_spider_plug_from_srcpad):
12369         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link):
12370
12371 2004-02-04  David Schleef  <ds@schleef.org>
12372
12373         * gst/gstelement.c: (gst_element_clear_pad_caps): Make sure we have
12374         a GstRealPad before accessing its structure members.
12375
12376 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12377
12378         * gst/gstclock.c: (gst_clock_init), (gst_clock_set_speed),
12379         (gst_clock_get_speed):
12380         * gst/gstclock.h:
12381           reset padding, remove unused fields
12382
12383 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12384
12385         * gst/autoplug/gstspideridentity.c:
12386         (gst_spider_identity_sink_loop_type_finding):
12387           use get_allowed_caps, not get_caps (fixes #132519)
12388         * gst/elements/gsttypefind.c: (stop_typefinding):
12389           use correct order when sending buffers and seeking
12390
12391 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
12392
12393         * configure.ac:
12394         * gst/gstelement.h:
12395         * gst/gstpad.h:
12396         * gst/gstqueue.h:
12397           upgrade libtool CURRENT, reset padding
12398
12399 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
12400
12401         * configure.ac:
12402           bump to prerelease
12403           put back AM_PROG_LIBTOOL to make libtoolize stop complaining
12404
12405 2004-02-04  David Schleef  <ds@schleef.org>
12406
12407         * docs/random/ds/0.9-suggested-changes: random notes
12408         * gst/elements/gstfakesrc.c: (gst_fakesrc_get_formats),
12409         (gst_fakesrc_get_query_types), (gst_fakesrc_get_event_mask):
12410         Replace GST_PAD_EVENT_MASK_FUNCTION() (et al.) with its
12411         expansion.
12412         * gst/elements/gstfilesink.c: (gst_filesink_get_formats),
12413         (gst_filesink_get_query_types): same
12414         * gst/elements/gstfilesrc.c: (gst_filesrc_get_event_mask),
12415         (gst_filesrc_get_query_types), (gst_filesrc_get_formats): same
12416         * gst/gstcaps.h: deprecate GST_DEBUG_CAPS(), and fix the macro
12417         to use new GST_PTR_FORMAT.
12418         * gst/gstelement.h: deprecate function factory macros
12419         GST_ELEMENT_QUERY_TYPE_FUNCTION(), GST_ELEMENT_EVENT_MASK_FUNCTION().
12420         These are our last variadic macros that can't be replaced with
12421         inlines.  Celebrate!  Also fix a typo in an #ifdef that was
12422         attempting to deprecate gst_element_clock_wait().
12423         * gst/gstevent.h: same
12424         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
12425         (gst_pad_try_set_caps): replace GST_DEBUG_CAPS() with GST_DEBUG()
12426         * gst/gstpad.h: deprecate function factory macros similar to above.
12427
12428 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
12429
12430         * configure.ac:
12431         * tools/Makefile.am:
12432         * tools/gst-run.c: (popt_callback), (hash_print_key),
12433         (find_highest_version), (unmangle_libtool), (get_dir_of_binary),
12434         (get_candidates), (main):
12435           add new source file to generate non-versioned wrapper binaries
12436           for our tools.
12437
12438 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12439
12440         * gst/gstevent.c: (_gst_event_free):
12441           actually break; inside the switch statement
12442         * gst/parse/grammar.y:
12443           fix memleak where GValues weren't unset
12444
12445 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12446
12447         * gst/gststructure.c: (gst_structure_from_string):
12448           fix huge memleak
12449         * gst/elements/gsttypefind.c: (gst_type_find_element_have_type),
12450         (new_entry), (gst_type_find_element_chain):
12451         * gst/gstelement.c: (gst_element_base_class_init),
12452         (gst_element_class_set_details):
12453         * gst/gstpad.c: (gst_pad_can_link_filtered):
12454           fix smaller memleaks
12455         * gst/gstpad.c: (gst_real_pad_dispose):
12456           check that explicit caps are gone
12457         * gst/gststructure.c: (gst_structure_free):
12458           actually free the structure
12459         * gst/gstelement.c: (gst_element_clear_pad_caps):
12460           unset explicit caps
12461
12462 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
12463
12464         * tools/Makefile.am:
12465           use AM_CFLAGS since all the CFLAGS are the same
12466           use AM_LDFAGS
12467
12468 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
12469
12470         * docs/manual/gnome.xml:
12471           expand example a little
12472         * gst/gst.c: (gst_init_with_popt_table),
12473         (gst_init_check_with_popt_table), (init_pre), (init_popt_callback):
12474           make sure popt option displays are done with right textdomain
12475           use GstPoptOption type
12476         * gst/gst.h:
12477           create GstPoptOption type
12478
12479 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
12480
12481         * gst/gsterror.c: (_gst_stream_errors_init):
12482         * gst/gsterror.h:
12483           adding error type for no codec
12484         * po/POTFILES.in:
12485           add gst-inspect
12486         * po/nl.po:
12487           update dutch translation
12488         * tools/gst-inspect.c: (print_element_list), (main):
12489           do proper internationalization
12490         * tools/gst-launch.c: (idle_func):
12491           remove commented out function call
12492
12493 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
12494
12495         * docs/README:
12496           add some error fixing notes
12497         * docs/gst/gstreamer-sections.txt:
12498           remove double entries
12499         * docs/gst/tmpl/gstbin.sgml:
12500         * docs/gst/tmpl/gstclock.sgml:
12501           remove override
12502         * docs/gst/tmpl/gstelement.sgml:
12503         * docs/gst/tmpl/gstindex.sgml:
12504         * docs/gst/tmpl/gstobject.sgml:
12505         * docs/gst/tmpl/gstpadtemplate.sgml:
12506         * docs/gst/tmpl/gstreamer-unused.sgml:
12507         * docs/gst/tmpl/gsttag.sgml:
12508         * docs/gst/tmpl/gstthread.sgml:
12509         * docs/gst/tmpl/gstxml.sgml:
12510         * gst/gsttag.h:
12511           sync header prototypes with c decls
12512         * gst/gsttaginterface.c:
12513           fix doc headers
12514
12515 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12516
12517         * gst/parse/Makefile.am:
12518         * gst/gstobject.h:
12519           get rid of gstmarshal.h dependency. It's not needed.
12520         * gst/gst.h:
12521         * gst/elements/gstfakesink.c:
12522         * gst/elements/gstfakesrc.c:
12523         * gst/elements/gstidentity.c:
12524         * gst/gstbin.c:
12525         * gst/gstelement.c:
12526         * gst/gstindex.c:
12527         * gst/gstobject.c:
12528         * gst/gstpad.c:
12529         * gst/gstthread.c:
12530         * gst/gstxml.c:
12531         * libs/gst/control/dparam.c:
12532         * libs/gst/control/dparammanager.c:
12533           include gstmarshal.h.
12534         Fixes #132045
12535
12536 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12537
12538         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
12539         (gst_filesrc_dispose), (gst_filesrc_free_parent_mmap),
12540         (gst_filesrc_map_region), (gst_filesrc_get_mmap):
12541         * gst/elements/gstfilesrc.h:
12542           don't ref the filesrc when creating mmaped buffers. Don't keep a
12543           list of not-yet-destroyed buffers.
12544         * gst/gstbuffer.h:
12545           Deprecated BST_BUFFER_FREE_FUNC and GST_BUFFER_COPY_FUNC
12546
12547 2004-02-02  Thomas Vander Stichele  <thomas at apestaart dot org>
12548
12549         * gst/gst.c: (init_pre):
12550           remove textdomain
12551
12552 2004-02-02  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12553
12554         * docs/pwg/advanced-events.xml:
12555         * docs/pwg/advanced-scheduling.xml:
12556         * docs/pwg/intro-basics.xml:
12557         * docs/pwg/other-manager.xml:
12558         * docs/pwg/other-nton.xml:
12559         * docs/pwg/other-ntoone.xml:
12560         * docs/pwg/other-oneton.xml:
12561         * docs/pwg/pwg.xml:
12562           All sort of documentation... Forgot what. Point is that I want this
12563           in before I leave. The 'other-*' will be the last section and will
12564           explain issues specific to these type of elements.
12565
12566 2004-02-02  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12567
12568         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
12569         (gst_filesrc_get_read):
12570           set all the values on buffers that we can
12571
12572 2004-02-02  David Schleef  <ds@schleef.org>
12573
12574         Change usage of isblah() to g_ascii_isblah() to be more locale
12575         independent.  (#133076)
12576         * gst/gsturi.c: (gst_uri_protocol_check_internal):
12577         * gst/gstutils.c:
12578         * gst/parse/parse.l:
12579
12580 2004-02-02  Jon Trowbridge  <trow@gnu.org>
12581
12582         reviewed by: David Schleef  <ds@schleef.org>
12583
12584         Fix memory leaks:
12585         * gst/gstcaps.c: (gst_caps_to_string):
12586         * gst/registries/gstxmlregistry.c:
12587         (gst_xml_registry_add_path_list_func),
12588         (gst_xml_registry_parse_padtemplate):
12589
12590 2004-02-02  Thomas Vander Stichele  <thomas at apestaart dot org>
12591
12592         * gst/gstelement.c: (gst_element_default_error):
12593           suffix error messages with period
12594
12595 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
12596
12597         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
12598         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
12599         * gst/gsterror.c: (gst_error_get_message):
12600           Suffix with dots
12601         * po/fr.po:
12602         * po/nl.po:
12603           Update translation files
12604
12605 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
12606
12607         * gst/autoplug/gstspideridentity.c:
12608         (gst_spider_identity_sink_loop_type_finding):
12609         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
12610         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
12611         (gst_filesink_close_file), (gst_filesink_handle_event),
12612         (gst_filesink_chain):
12613         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
12614         (gst_filesrc_get_read), (gst_filesrc_open_file):
12615         * gst/elements/gstidentity.c: (gst_identity_chain):
12616         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
12617         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
12618         (gst_pipefilter_chain), (gst_pipefilter_open_file):
12619         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
12620         * gst/gsterror.c: (_gst_core_errors_init),
12621         (_gst_library_errors_init), (_gst_resource_errors_init),
12622         (_gst_stream_errors_init), (gst_error_get_message):
12623         * gst/gstpad.c: (gst_pad_set_explicit_caps),
12624         (gst_pad_recover_caps_error), (gst_pad_pull):
12625         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
12626         * gst/schedulers/gstbasicscheduler.c:
12627         (gst_basic_scheduler_chainhandler_proxy),
12628         (gst_basic_scheduler_gethandler_proxy),
12629         (gst_basic_scheduler_cothreaded_chain):
12630           Suffix error messages with period.
12631           Use (NULL) instead of NULL
12632
12633 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
12634
12635         * docs/gst/tmpl/gstelement.sgml:
12636         * docs/gst/tmpl/gstxml.sgml:
12637         * gst/gstelement.c: (gst_element_error_full):
12638           add element path to error
12639
12640 2004-01-31  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12641
12642         * docs/random/mimetypes:
12643           update raw int/float info
12644         * gst/gsttag.c: (_gst_tag_initialize):
12645         * gst/gsttag.h:
12646           add GST_TAG_ENCODER
12647
12648 2004-01-30  David Schleef  <ds@schleef.org>
12649
12650         * gst/cothreads.c: Add another fallback if MAP_ANONYMOUS is
12651           missing (#132991)
12652
12653 2004-01-30  Laurent Vivier <Laurent.Vivier@bull.net>
12654
12655         reviewed by Benjamin Otte 
12656           parts of the patch submitted in bug #113913
12657
12658         * configure.ac:
12659           use AC_C_INLINE. Use = instead of == with test
12660         * examples/plugins/example.c:
12661         * gst/autoplug/gstspideridentity.c:
12662         * gst/elements/gstfdsrc.c:
12663         * gst/elements/gstfilesrc.c:
12664         * gst/elements/gstidentity.c:
12665         * gst/elements/gstmultidisksrc.c:
12666         * gst/elements/gststatistics.c:
12667         * gst/gstelement.c:
12668         * gst/gstobject.c:
12669         * gst/gstpad.c:
12670         * gst/gstpipeline.c:
12671         * gst/gstthread.c:
12672           don't end enums with a comma
12673         * gst/gstindex.c: (gst_index_compare_func):
12674           do explicit casting to gint
12675         * gst/gsttrace.c: (gst_trace_text_flush):
12676           #define strsize as a macro
12677
12678 2004-01-30  Thomas Vander Stichele  <thomas at apestaart dot org>
12679
12680         * docs/README:
12681         * docs/gst/gstreamer-docs.sgml:
12682         * docs/gst/gstreamer-sections.txt:
12683         * docs/gst/tmpl/gstelement.sgml:
12684         * docs/gst/tmpl/gsterror.sgml:
12685         * docs/gst/tmpl/gstinterface.sgml:
12686         * docs/gst/tmpl/gstreamer-unused.sgml:
12687         * docs/gst/tmpl/gststructure.sgml:
12688         * docs/gst/tmpl/gsttag.sgml:
12689         * docs/gst/tmpl/gsttaginterface.sgml:
12690         * docs/gst/tmpl/gstvalue.sgml:
12691         make sure all API ends up in the built docs
12692         * gst/gstinterface.c:
12693         * gst/gststructure.c: (gst_structure_id_set_value),
12694         (gst_structure_set_value), (gst_structure_id_get_value):
12695         * gst/gststructure.h:
12696         * gst/gstvalue.h:
12697         sync .h with .c declarations
12698
12699 2004-01-30  Julien Moutte  <julien@moutte.net>
12700
12701         * libs/gst/bytestream/bytestream.c: Reverting my event handling patch.
12702         Ronald will fix riffread.
12703
12704 2004-01-30  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12705
12706         * docs/pwg/advanced-interfaces.xml:
12707           Added tuner interface docs.
12708
12709 2004-01-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12710
12711         * docs/random/mimetypes:
12712           correct Theora information
12713         * gst/gstelement.h:
12714           make GST_ELEMENT_ERROR do a GST_ERROR_OBJECT
12715
12716 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
12717
12718         * gst/gstelement.c: (gst_element_error_full):
12719         * gst/gstelement.h:
12720           GST_ELEMENT_ERROR in enum -> _IN_ERROR
12721
12722 2004-01-29  Julien MOUTTE  <julien@moutte.net>
12723
12724         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
12725         (gst_filesrc_uri_handler_init): Fixing seeking by making FLUSH happen
12726         again and even before DISCONT.
12727         * gst/gstpad.c: (gst_pad_event_default): Remove a unused switch case.
12728         * libs/gst/bytestream/bytestream.c: (gst_bytestream_get_next_buf): Fix
12729         bytestream so that it's not stopping to fill the bytestream if events
12730         different than EOS or DISCONT are received. Instead it process them so
12731         that they go downstream.
12732
12733 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
12734
12735         * docs/gst/tmpl/gstelement.sgml:
12736         * docs/gst/tmpl/gstreamer-unused.sgml:
12737         * docs/gst/tmpl/gstxml.sgml:
12738         * gst/autoplug/gstspideridentity.c:
12739         (gst_spider_identity_sink_loop_type_finding):
12740         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
12741         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
12742         (gst_filesink_close_file), (gst_filesink_handle_event),
12743         (gst_filesink_chain):
12744         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
12745         (gst_filesrc_get_read), (gst_filesrc_open_file):
12746         * gst/elements/gstidentity.c: (gst_identity_chain):
12747         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
12748         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
12749         (gst_pipefilter_chain), (gst_pipefilter_open_file):
12750         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
12751         * gst/gstelement.h:
12752         * gst/gstpad.c: (gst_pad_set_explicit_caps),
12753         (gst_pad_recover_caps_error), (gst_pad_pull):
12754         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
12755         * gst/schedulers/gstbasicscheduler.c:
12756         (gst_basic_scheduler_chainhandler_proxy),
12757         (gst_basic_scheduler_gethandler_proxy),
12758         (gst_basic_scheduler_cothreaded_chain):
12759           gst_element_error -> GST_ELEMENT_ERROR
12760
12761 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
12762
12763         * docs/Makefile.am:
12764         * docs/gst/tmpl/gstelement.sgml:
12765         * docs/gst/tmpl/gstxml.sgml:
12766         * docs/manuals.mak:
12767         * docs/pwg/advanced-request.xml:
12768         * docs/pwg/advanced-scheduling.xml:
12769         * docs/pwg/advanced-tagging.xml:
12770           fix non-validating docbook using CDATA
12771           make sure make check-local gets run first to check if it validates
12772
12773 2004-01-29  Julien MOUTTE <julien@moutte.net>
12774
12775         * docs/pwg/advanced-events.xml: Adding documentation on advanced event
12776         handling (up and downstream).
12777         * docs/pwg/advanced-interfaces.xml: Make it coherent with the
12778         my_filter thing.
12779
12780 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12781
12782         * docs/pwg/advanced-tagging.xml:
12783           Add docs about tag writing.
12784
12785 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12786
12787         * docs/pwg/advanced-tagging.xml:
12788           Add a part about tag reading and application signalling... Tag
12789           writing still needs to be documented.
12790         * gst/elements/gstfilesrc.c: (gst_filesrc_set_location):
12791           We can set file locations in READY, too.
12792
12793 2004-01-29  Julien MOUTTE <julien@moutte.net>
12794
12795         * docs/random/ds/element-checklist: Adding some notes about src
12796         events.
12797
12798 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12799
12800         * docs/random/mimetypes:
12801           Update docs to point to correct elements for various mimetypes, and
12802           some more errors pointed out by Stéphane LOEUILLET (aka LeRoutier)
12803           <stephane.loeuillet@tiscali.fr>.
12804
12805 2004-01-28  David Schleef  <ds@schleef.org>
12806
12807         * docs/pwg/intro-basics.xml: rewrite bufferpool stuff.
12808
12809 2004-01-29  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12810
12811         * docs/random/mimetypes:
12812           update docs for audio/x-raw-float. Add "buffer-frames=0 means
12813           undefined"
12814         * gst/elements/gstfilesrc.c: (gst_filesrc_set_location):
12815           make it only work in NULL.
12816         * gst/gstcaps.c:
12817           don't posion NULL caps
12818         * gst/gstelement.c: (gst_element_set_time):
12819           add debugging statement
12820         * gst/gstelement.c: (gst_element_emit_found_tag),
12821         (gst_element_found_tag_func), (gst_element_found_tags):
12822         * gst/gstelement.h:
12823           These functions take const taglists
12824         * gst/gstpad.c: (gst_pad_proxy_getcaps):
12825           fix memleak
12826         * gst/gstpad.c: (gst_pad_event_default):
12827           make more effort on handling discont and clocks, g_warn if everything
12828           fails
12829         * gst/gststructure.c: (gst_structure_remove_fields),
12830         (gst_structure_remove_fields_valist):
12831         * gst/gststructure.h:
12832           add gst_structure_remove_fields(_valist)
12833         * gst/gsttag.c:
12834           fix doc glitch
12835
12836 2004-01-28  David Schleef  <ds@schleef.org>
12837
12838         * docs/random/ds/element-checklist: Notes about gst_caps_to_string()
12839         * gst/registries/gstxmlregistry.c: (gst_xml_registry_save_caps):
12840         Fix memory leakage of gst_caps_to_string().
12841
12842         Use GST_PTR_FORMAT instead of gst_caps_to_string():
12843         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_sp):
12844         * gst/autoplug/gstspideridentity.c: (spider_find_suggest),
12845         (gst_spider_identity_sink_loop_type_finding):
12846         * gst/elements/gsttypefind.c: (gst_type_find_element_have_type),
12847         (find_suggest):
12848         * gst/gstpad.c: (gst_pad_try_relink_filtered),
12849         (gst_pad_set_explicit_caps):
12850         * gst/parse/grammar.y:
12851
12852 2004-01-28  David Schleef  <ds@schleef.org>
12853
12854         * configure.ac: Add detection for HAVE_PRINTF_EXTENSION and
12855         GST_PRINTF_EXTENSION_FORMAT_DEFINE.
12856         * docs/random/ds/0.9-suggested-changes: Notes from Company.
12857         * gst/gstcaps.c: (gst_caps_to_string): Add comment.
12858         * gst/gstconfig.h.in: Add define for GST_PTR_FORMAT
12859         * gst/gstinfo.c: (_gst_debug_init), (gst_debug_print_object),
12860         (gst_debug_log_default), (_gst_info_printf_extension),
12861         (_gst_info_printf_extension_arginfo):  Add printf extension.
12862         * gst/gstinfo.h: remove G_GNUC_PRINTF, because it doesn't work with %P
12863         * gst/gststructure.c: (gst_structure_to_string),
12864         (_gst_structure_parse_value): Use gst_value_deserialize() and
12865         remove old code.
12866         * gst/gstvalue.c: (gst_value_deserialize_fourcc),
12867         (gst_value_deserialize_boolean), (gst_strtoi),
12868         (gst_value_deserialize_int), (gst_value_deserialize_double),
12869         (gst_value_deserialize_string), (gst_value_deserialize): Implement
12870         a bunch of deserialize functions and gst_value_deserialize.
12871         * gst/gstvalue.h: er, _de_serialize, not unserialize
12872         * testsuite/caps/string-conversions.c: (main): We don't currently
12873         handle (float) in caps, so convert these to (double).
12874         * testsuite/debug/Makefile.am: Add new test for the printf extension
12875         * testsuite/debug/printf_extension.c: (main): same
12876
12877 2004-01-28  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12878
12879         * docs/random/company/time:
12880           Add some docs about clocking and time
12881
12882 2004-01-28  Julien MOUTTE <julien@moutte.net>
12883
12884         * docs/pwg/advanced-interfaces.xml: Adding XOverlay documentation.
12885
12886 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12887
12888         * docs/pwg/advanced-clock.xml:
12889         * docs/pwg/advanced-dparams.xml:
12890         * docs/pwg/advanced-events.xml:
12891         * docs/pwg/advanced-interfaces.xml:
12892         * docs/pwg/advanced-midi.xml:
12893         * docs/pwg/advanced-request.xml:
12894         * docs/pwg/advanced-scheduling.xml:
12895         * docs/pwg/advanced-tagging.xml:
12896         * docs/pwg/advanced-types.xml:
12897         * docs/pwg/appendix-checklist.xml:
12898         * docs/pwg/building-boiler.xml:
12899         * docs/pwg/building-chainfn.xml:
12900         * docs/pwg/building-filterfactory.xml:
12901         * docs/pwg/building-pads.xml:
12902         * docs/pwg/building-props.xml:
12903         * docs/pwg/building-signals.xml:
12904         * docs/pwg/building-state.xml:
12905         * docs/pwg/building-testapp.xml:
12906         * docs/pwg/intro-basics.xml:
12907         * docs/pwg/intro-preface.xml:
12908         * docs/pwg/other-autoplugger.xml:
12909         * docs/pwg/other-sink.xml:
12910         * docs/pwg/other-source.xml:
12911         * docs/pwg/titlepage.xml:
12912           fix up id's
12913
12914 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12915
12916         * docs/95NonPath:
12917         * docs/HACKING:
12918         * docs/README:
12919         * docs/building-the-docs-on-debian:
12920           collect relevant bits of doc info
12921
12922 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12923
12924         * docs/pwg/advanced_tagging.xml:
12925           Half-assed commit so Thomas can re-arrange document IDs here to be
12926           consistent, too.
12927
12928 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12929
12930         * docs/manual/autoplugging.xml:
12931         * docs/manual/bins-api.xml:
12932         * docs/manual/bins.xml:
12933         * docs/manual/buffers-api.xml:
12934         * docs/manual/buffers.xml:
12935         * docs/manual/clocks.xml:
12936         * docs/manual/components.xml:
12937         * docs/manual/cothreads.xml:
12938         * docs/manual/debugging.xml:
12939         * docs/manual/dparams-app.xml:
12940         * docs/manual/dynamic.xml:
12941         * docs/manual/elements-api.xml:
12942         * docs/manual/elements.xml:
12943         * docs/manual/factories.xml:
12944         * docs/manual/gnome.xml:
12945         * docs/manual/goals.xml:
12946         * docs/manual/helloworld.xml:
12947         * docs/manual/helloworld2.xml:
12948         * docs/manual/init-api.xml:
12949         * docs/manual/intro.xml:
12950         * docs/manual/links-api.xml:
12951         * docs/manual/links.xml:
12952         * docs/manual/manual.xml:
12953         * docs/manual/motivation.xml:
12954         * docs/manual/pads-api.xml:
12955         * docs/manual/pads.xml:
12956         * docs/manual/plugins-api.xml:
12957         * docs/manual/plugins.xml:
12958         * docs/manual/programs.xml:
12959         * docs/manual/queues.xml:
12960         * docs/manual/quotes.xml:
12961         * docs/manual/schedulers.xml:
12962         * docs/manual/states-api.xml:
12963         * docs/manual/states.xml:
12964         * docs/manual/threads.xml:
12965         * docs/manual/typedetection.xml:
12966         * docs/manual/xml.xml:
12967           use chapter, part, section or misc as id starts for all bits
12968
12969 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12970
12971         * docs/gst/gstreamer-sections.txt:
12972           Fix up TITLE of the sections
12973
12974 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12975
12976         * docs/pwg/advanced_interfaces.xml:
12977           Add documentation on propertyprobing.
12978         * docs/pwg/advanced_events.xml:
12979         * docs/pwg/advanced_tagging.xml:
12980         * docs/pwg/building_boiler.xml:
12981         * docs/pwg/building_filterfactory.xml:
12982         * docs/pwg/pwg.xml:
12983           Move filterfactory and tagging into their own chapter, add a chapter
12984           on events. all these are empty placeholders that will be filled in
12985           some day.
12986
12987 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12988
12989         * docs/pwg/advanced_interfaces.xml:
12990           Docs for mixer interface. Also a check for website uploading.
12991
12992 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
12993
12994         * docs/HACKING:
12995         * docs/Makefile.am:
12996         * docs/faq/Makefile.am:
12997         * docs/gst/Makefile.am:
12998         * docs/gst/tmpl/gstelement.sgml:
12999         * docs/gst/tmpl/gstplugin.sgml:
13000         * docs/gst/tmpl/gstreamer-unused.sgml:
13001         * docs/libs/Makefile.am:
13002         * docs/manual/Makefile.am:
13003         * docs/manuals.mak:
13004         * docs/pwg/Makefile.am:
13005         * docs/upload.mak:
13006           Separate out upload target and make it similar for
13007           both docbook and gtk-doc docs
13008
13009 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
13010
13011         * docs/manuals.mak:
13012           Fix upload target to work with freedesktop
13013
13014 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13015
13016         * docs/pwg/advanced_types.xml:
13017           Add notes on creating your own types.
13018         * docs/pwg/building_boiler.xml:
13019         * docs/pwg/building_pads.xml:
13020         * docs/pwg/building_state.xml:
13021           Add some stuff about how to retrieve values from structures, how
13022           that relates to types and change layout slightly again to be almost
13023           perfect.
13024
13025 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13026
13027         * docs/pwg/advanced_dparams.xml:
13028         * docs/pwg/advanced_scheduling.xml:
13029           Change index layout slightly.
13030
13031 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13032
13033         * docs/pwg/advanced_clock.xml:
13034         * docs/pwg/advanced_interfaces.xml:
13035         * docs/pwg/advanced_midi.xml:
13036           General placeholders for now.
13037         * docs/pwg/advanced_request.xml:
13038           Explanation about sometimes and request pads.
13039         * docs/pwg/advanced_scheduling.xml:
13040           Concept of bytestream, loopfunctions and schedulers.
13041         * docs/pwg/building_boiler.xml:
13042           Add something about plugin-init.
13043
13044 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
13045
13046         * docs/pwg/building_pads.xml:
13047           Fix broken docbook
13048
13049 2004-01-27  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13050
13051         * docs/pwg/advanced_interfaces.xml:
13052         * docs/pwg/pwg.xml:
13053           Add as a placeholder for future filling-in.
13054         * docs/pwg/basics_autoplugging.xml:
13055         * docs/pwg/basics_buffers.xml:
13056         * docs/pwg/basics_elements.xml:
13057         * docs/pwg/basics_events.xml:
13058         * docs/pwg/basics_plugins.xml:
13059         * docs/pwg/basics_types.xml:
13060           Remove, because unused (this is all in intro_basics.xml).
13061         * docs/pwg/building_signals.xml:
13062           Short intro to signals + reference to GObject docs - we really
13063           shouldn't go into these sort of things to deply because we don't
13064           use them that extensively anyway.
13065         * docs/pwg/building_state.xml:
13066           Explanation of states. Benjamin, please check.
13067         * docs/pwg/building_testapp.xml:
13068           Put everything in one page - putting only a few lines of content
13069           per page doesn't really make sense.
13070
13071           Time to get into the advanced topics. ;).
13072
13073 2004-01-27  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13074
13075         * docs/pwg/advanced_types.xml:
13076           Finish documenting the current state of mimetypes.
13077         * docs/pwg/building_boiler.xml:
13078         * docs/pwg/building_chainfn.xml:
13079         * docs/pwg/building_pads.xml:
13080         * docs/pwg/building_props.xml:
13081         * docs/pwg/building_testapp.xml:
13082           Start documenting the "how to build a simple audio filter" part
13083           of the PWG. Most stuff is ready by now. Stuff remaining: signals,
13084           states and (maybe?) a short introduction to capsnego in the chapter
13085           on pads (building_pads.xml). Capsnego should probably be explained
13086           fully in advanced_capsnego.xml or so.
13087
13088 2004-01-26  David Schleef  <ds@schleef.org>
13089
13090         * gst/gstpad.c: (gst_pad_try_set_caps_nonfixed):
13091         * gst/gstpad.h: Add new function to allow element to (somewhat)
13092         specify non-fixed caps on a pad.
13093         * gst/gstqueue.c: (gst_queue_chain): Remove noisy g_object_notify()
13094         that I added a few weeks ago.
13095
13096 2004-01-26  David Schleef  <ds@schleef.org>
13097
13098         * gst/gstpad.c: (gst_pad_try_set_caps): Revert last change
13099           making try_set_caps() work with non-fixed caps.
13100
13101 2004-01-26  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13102
13103         * docs/pwg/advanced_types.xml:
13104         * docs/pwg/intro_basics.xml:
13105         * docs/pwg/intro_preface.xml:
13106         * docs/pwg/pwg.xml:
13107         * docs/pwg/titlepage.xml:
13108           First try to resurrect the PWG. I'm halfway integrating the mimetypes
13109           in here (docs/random/mimetypes), and will from there on work on both
13110           updating outdated parts and adding missing parts.
13111           That doesn't mean I'll fix it completely, but I'll try at least. ;).
13112
13113 2004-01-26  Thomas Vander Stichele  <thomas at apestaart dot org>
13114
13115         * gst/gsterror.h: reinstate GST_LIBRARY_ERROR_ENCODE until
13116           policy is set
13117
13118 2004-01-26  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13119
13120         * gst/gstelement.h:
13121           remove gst_element_factory_get_version. It doesn't exist anymore.
13122         * gst/gstplugin.c:
13123         * gst/gstplugin.h:
13124           remove gst_plugin_set_name and change gst_plugin_get_longname to
13125           gst_plugin_get_description to match code.
13126         * gst/gsterror.h:
13127           remove GST_LIBRARY_ERROR_ENCODE. It's GST_STREAM_ERROR_ENCODE.
13128         * gst/gstpad.c: (gst_pad_try_set_caps):
13129           make it work with nonfixed caps.
13130           Note that even in the nonfixed case the link function of the pad
13131           that tries to set caps isn't called.
13132
13133 2004-01-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13134
13135         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
13136           fix bug where buffer was not assembled correctly
13137         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_init):
13138           silence by default
13139         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
13140           only seek if there's no more buffers that could work without seeking
13141
13142 2004-01-23  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13143
13144         * gst/gsttag.c: (_gst_tag_initialize):
13145         * gst/gsttag.h:
13146           Add application tag (for encoding/muxing app).
13147
13148 2004-01-23  Thomas Vander Stichele  <thomas at apestaart dot org>
13149
13150         * autogen.sh:
13151           make autopoint force, and libtoolize not copy
13152         * common/m4/as-docbook.m4:
13153           added docbook xml catalog setup check
13154         * common/m4/gst-doc.m4:
13155           use docbook check
13156
13157 2004-01-22  Thomas Vander Stichele  <thomas at apestaart dot org>
13158
13159         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_register):
13160         * gst/gsttag.h:
13161           add GstTagFlag
13162
13163 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13164
13165         * docs/gst/gstreamer-sections.txt:
13166         * docs/gst/tmpl/gst.sgml:
13167         * docs/gst/tmpl/gstbuffer.sgml:
13168         * docs/gst/tmpl/gstclock.sgml:
13169         * docs/gst/tmpl/gstelement.sgml:
13170         * docs/gst/tmpl/gstreamer-unused.sgml:
13171         * docs/gst/tmpl/gstxml.sgml:
13172           sync latest API changes to docs
13173
13174 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13175
13176         * gst/gstpluginfeature.c:
13177           fix doc snippet
13178         * tools/gst-inspect.c: (print_element_list):
13179           fix output of typefind
13180           add GPL header
13181         * tools/gst-launch.c:
13182           add GPL header
13183
13184 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13185
13186         * gst/elements/Makefile.am:
13187         * gst/elements/gstelements.c:
13188         * gst/elements/gsttypefindelement.c:
13189         * gst/elements/gsttypefindelement.h:
13190         * po/POTFILES.in:
13191         * po/fr.po:
13192         * po/nl.po:
13193           renamed gsttypefindelement to gsttypefind, conserving CVS history
13194
13195 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13196
13197         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_list_add_valist):
13198         * gst/gsttag.h:
13199           add some tags used in ogg as well
13200           fix _ in replaygain tags
13201
13202 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13203
13204         * gst/gsterror.h:
13205           fix wrong GST_LIBRARY_ERROR_ENCODE addition
13206
13207 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13208
13209         * gst/gstelement.c: (gst_element_error_full):
13210         * gst/gstelement.h:
13211           change _extended to _full
13212
13213 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13214
13215         reviewed by: <delete if not using a buddy>
13216
13217         * docs/gst/tmpl/gst.sgml:
13218         * docs/gst/tmpl/gstbuffer.sgml:
13219         * docs/gst/tmpl/gstclock.sgml:
13220         * docs/gst/tmpl/gstelement.sgml:
13221         * docs/gst/tmpl/gstreamer-unused.sgml:
13222         * docs/gst/tmpl/gstxml.sgml:
13223         * gst/gstelement.c: (gst_element_error_full):
13224         * gst/gstelement.h:
13225
13226 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
13227
13228         * gst/gstelement.h: fix _gst_element_error_printf prototype
13229
13230 2004-01-20  David Schleef  <ds@schleef.org>
13231
13232         * gst/gststructure.c: (gst_structure_to_string):
13233         Convert function to use gst_value_serialize().
13234         * gst/gstvalue.c: (gst_value_serialize_list),
13235         (gst_value_serialize_fourcc), (gst_value_serialize_int_range),
13236         (gst_value_serialize_double_range), (gst_value_serialize_boolean),
13237         (gst_value_serialize_int), (gst_value_serialize_double),
13238         (gst_string_wrap), (gst_value_serialize_string),
13239         (gst_value_serialize), (gst_value_deserialize):
13240         * gst/gstvalue.h:
13241         Add implementations for serialize.
13242
13243 2004-01-20  Julien MOUTTE  <julien@moutte.net>
13244
13245         * gst/gsterror.h: xvidenc.c needs GST_LIBRARY_ERROR_ENCODE. Dunno if
13246         we want to keep that one in the future or change xvidenc.c to use 
13247         another error.
13248
13249 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13250
13251         * gst/gstelement.c: (_gst_element_error_printf):
13252         * gst/gstelement.h:
13253           privatise function
13254
13255 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13256
13257         * docs/random/error:
13258           doc explaining error system
13259         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
13260           cleanup
13261
13262 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13263
13264         * gst/gst-i18n-app.h:
13265         * gst/gst-i18n-lib.h:
13266           remove inclusion of config.h
13267         * po/POTFILES.in:
13268         * po/nl.po:
13269           add gst/gstelement.c
13270
13271 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13272
13273         * po/nl.po: updated Dutch translation
13274
13275 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13276
13277         * gst/gsterror.c: (_gst_core_errors_init),
13278         (_gst_library_errors_init), (_gst_resource_errors_init),
13279         (_gst_stream_errors_init):
13280         remove ending punctuation dots
13281
13282 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13283
13284         * gst/elements/gstfilesink.c: (gst_filesink_open_file):
13285         * gst/elements/gstfilesrc.c: (gst_filesrc_get_read):
13286         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
13287         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
13288         (gst_pipefilter_chain), (gst_pipefilter_open_file):
13289         use GST_ERROR_SYSTEM
13290
13291 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13292
13293         * gst/gstelement.c: (gst_element_error_printf),
13294         (gst_element_error_extended):
13295         * gst/gstelement.h:
13296           add a helper printf function so we can have NULL values passed.
13297
13298 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
13299
13300         * gst/gstelement.h:
13301           add G_STMT macros to gst_element_error, which isn't strictly
13302           necessary but people tell me to anyway.
13303
13304 2004-01-18  Thomas Vander Stichele  <thomas at apestaart dot org>
13305
13306         * gst/Makefile.am:
13307         * gst/autoplug/gstspideridentity.c:
13308         (gst_spider_identity_sink_loop_type_finding):
13309         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
13310         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
13311         (gst_filesink_close_file), (gst_filesink_handle_event),
13312         (gst_filesink_chain):
13313         * gst/elements/gstfilesrc.c: (gst_filesrc_set_property),
13314         (gst_filesrc_map_region), (gst_filesrc_get_read),
13315         (gst_filesrc_open_file):
13316         * gst/elements/gstidentity.c: (gst_identity_chain):
13317         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
13318         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
13319         (gst_pipefilter_chain), (gst_pipefilter_open_file):
13320         * gst/elements/gsttypefindelement.c: (gst_type_find_element_chain):
13321         * gst/gst.h:
13322         * gst/gst_private.h:
13323         * gst/gstelement.c: (gst_element_class_init),
13324         (gst_element_default_error), (gst_element_error_func),
13325         (gst_element_error_extended):
13326         * gst/gstelement.h:
13327         * gst/gsterror.c: (_gst_core_errors_init),
13328         (_gst_library_errors_init), (_gst_resource_errors_init),
13329         (_gst_stream_errors_init), (gst_error_get_message):
13330         * gst/gsterror.h:
13331         * gst/gstinfo.c: (_gst_debug_init):
13332         * gst/gstmarshal.list:
13333         * gst/gstpad.c: (gst_pad_set_explicit_caps),
13334         (gst_pad_recover_caps_error), (gst_pad_pull):
13335         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
13336         * gst/schedulers/gstbasicscheduler.c:
13337         (gst_basic_scheduler_chainhandler_proxy),
13338         (gst_basic_scheduler_gethandler_proxy),
13339         (gst_basic_scheduler_cothreaded_chain):
13340         * po/POTFILES.in:
13341         * po/fr.po:
13342         * po/nl.po:
13343           change error signal
13344           add error categories
13345
13346 2004-01-18  Jeremy Simon  <jesimon@libertysurf.fr>
13347
13348         * gst/gsttag.c: (_gst_tag_initialize):
13349         * gst/gsttag.h:
13350         Add replaygain tag
13351
13352 2004-01-18  Colin Walters  <walters@verbum.org>
13353
13354         * examples/retag/retag.c: Call gst_init before processing
13355         program args.  Add g_assert to _link_many call.
13356
13357 2004-01-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13358
13359         * gst/gstpad.c: (gst_pad_alloc_buffer):
13360           Return a newly allocated buffer when the pad has no peer.
13361
13362 2004-01-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13363
13364         * gst/gstclock.c: (gst_clock_get_time):
13365           make it compile with gcc 2.95 again.
13366           Patch by Scott Wheeler
13367
13368 2004-01-15  David Schleef  <ds@schleef.org>
13369
13370         * gst/gstcaps.h:
13371         Added gst_caps_is_simple() macro.
13372         * testsuite/caps/caps.c: (test1):
13373         * testsuite/caps/intersect2.c: (main):
13374         * testsuite/caps/intersection.c: (main):
13375         Fixes to make 'make check' work again after removing
13376         gst_caps_is_chained().
13377
13378 2004-01-15  Leif Johnson <leif@ambient.2y.net>
13379
13380         * docs/random/uraeus/gstreamer_and_midi.txt: Rather large edits
13381         and additions to the MIDI document.
13382
13383 2004-01-15  David Schleef  <ds@schleef.org>
13384
13385         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered),
13386         (gst_element_link_pads_filtered): Use GST_PAD_ macros instead
13387         of GST_RPAD_, since we don't know if it's a real or ghost pad.
13388
13389 2004-01-15  David Schleef  <ds@schleef.org>
13390
13391         * gst/gstqueue.c:
13392         * gst/gstqueue.h:
13393         Fix the spelling of "treshold" and make min_threshold actually
13394         affect the queue.
13395
13396 2004-01-15  David Schleef  <ds@schleef.org>
13397
13398         * gst/gstcaps.c:
13399         Add lots of documentation.
13400         * gst/gstcaps.h:
13401         Deprecate a few functions.
13402         * gst/gstpad.c:
13403         Removed use of deprecated functions.
13404
13405 2004-01-15  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13406
13407         * gst/gstpad.c: (gst_pad_is_linked):
13408         * gst/gstpad.h:
13409           implement gst_pad_is_linked
13410         * gst/gstelement.h:
13411           reserve space for initiate_state_change
13412
13413 2004-01-15  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13414
13415         * gst/autoplug/gstspideridentity.c:
13416         (gst_spider_identity_sink_loop_type_finding):
13417           break infinite loop by just returning instead of looping
13418         * gst/gstclock.c: (gst_clock_class_init), (gst_clock_set_property):
13419           set event time difference correctly. Set it to 1 second instead
13420           of 100ms to be more tolerant
13421         * gst/gstelement.c: (gst_element_set_time):
13422           add debugging output
13423
13424 2004-01-14  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13425
13426         * gst/gstqueue.c: (gst_queue_getcaps), (gst_queue_link):
13427           query if buffers are inside the pool, ignore events
13428
13429 2004-01-13  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13430
13431         * gst/gstclock.c: (gst_clock_class_init), (gst_clock_init),
13432         (gst_clock_set_speed), (gst_clock_set_active),
13433         (gst_clock_is_active), (gst_clock_reset),
13434         (gst_clock_handle_discont):
13435         * gst/gstclock.h:
13436           deprecate old interface and disable functions that aren't in use
13437           anymore.
13438         * gst/gstelement.h:
13439         * gst/gstelement.c: (gst_element_get_time), (gst_element_wait),
13440         (gst_element_set_time), (gst_element_adjust_time):
13441           add concept of "element time" and functions to get/set this time.
13442         * gst/gstelement.c: (gst_element_change_state):
13443           update element time correctly.
13444         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered):
13445           This is a debug message, not a g_critical.
13446         * gst/gstpad.c: (gst_pad_event_default):
13447           handle discontinuous events right with element time.
13448         * gst/gstscheduler.c: (gst_scheduler_state_transition):
13449           update to clocking fixes.
13450           set clocks on elements in READY=>PAUSED. The old behaviour caused
13451           a wrong element time on the first element that started playing.
13452         * gst/schedulers/gstbasicscheduler.c:
13453         (gst_basic_scheduler_class_init):
13454         * gst/schedulers/gstoptimalscheduler.c:
13455         (gst_opt_scheduler_class_init):
13456           remove code that just implements the default behaviour.
13457         * gst/elements/gstfakesink.c: (gst_fakesink_chain):
13458           update to use new clocking functions
13459         * testsuite/clock/clock1.c: (gst_clock_debug), (main):
13460         * testsuite/clock/clock2.c: (gst_clock_debug), (main):
13461           update to test new element time.
13462         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_getcaps):
13463           use _get_allowed_caps instead of _get_caps. This catches filtered
13464           caps correctly.
13465         * testsuite/debug/commandline.c:
13466           update for new GST_DEBUG syntax.
13467         * testsuite/threads/Makefile.am:
13468           disable a test that only works sometimes.
13469
13470 2004-01-13  Julien MOUTTE <julien@moutte.net>
13471
13472         * po/LINGUAS: Adding fr.
13473         * po/fr.po: Adding french translation.
13474
13475 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13476
13477         * gst/parse/grammar.y:
13478         * po/POTFILES.in:
13479         * po/nl.po:
13480         * tools/gst-launch.c: (xmllaunch_parse_cmdline), (main):
13481           translate parsing error messages
13482
13483 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13484
13485         * po/POTFILES.in: adding gst-launch
13486         * po/nl.po: updated translation, all 99 strings translated
13487         * tools/gst-launch.c: (idle_func), (xmllaunch_parse_cmdline),
13488         (found_tag), (sigint_handler_sighandler), (play_handler), (main):
13489           fix strings for translation
13490
13491 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13492
13493         * gst/gst.c:
13494           - capitalize beginnings of popt options
13495           - fix strings for translation
13496           - change gst-debug format from =N1=V1:N2=V2 to =N1:V1,N2:V2
13497
13498 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13499
13500         * po/README: add some notes on how to update translations
13501
13502 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13503
13504         * ABOUT-NLS: removed, is autogenerated from autopoint
13505         * autogen.sh: add autopoint stuff
13506         * configure.ac: fix up gettext stuff
13507         * gst/Makefile.am: add i18n headers to noinst_HEADERS
13508         * gst/elements/gsttypefindelement.c: add header include
13509         * gst/gettext.h: add header, copy from system-installed header
13510         * gst/gst-i18n-app.h: to be included by each app having translations
13511         * gst/gst-i18n-lib.h: to be included by each lib having translations
13512         * gst/gst.c: (init_pre): fix up gettext calls
13513         * gst/gst_private.h: remove i18n stuff, moving to separate headers
13514         * po/LINGUAS: the new way to specify translations present
13515         * po/Makefile.in.in: removed from cvs, autogenerated from autopoint
13516         * po/Makevars: the variables filled in for GStreamer
13517         * po/POTFILES.in: added new files with translations
13518         * po/de.po: has new strings
13519         * po/nl.po: readded, has new strings
13520
13521 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
13522
13523         * gst/gsttag.c: fix some strings marked for translation
13524
13525 2004-01-13  Iain <iain@prettypeople.org>
13526
13527         * gst/schedulers/gstoptimalscheduler.c (add_to_group): Reference the
13528         group when we add an element to it, cos we unref it when we remove one
13529
13530 2004-01-12  Thomas Vander Stichele  <thomas at apestaart dot org>
13531
13532         * testsuite/debug/commandline.c: (debug_not_reached):
13533         * testsuite/debug/output.c: (check_message):
13534           fix testsuite
13535
13536 2004-01-12  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13537
13538         * examples/cutter/.cvsignore:
13539         * examples/helloworld/.cvsignore:
13540         * examples/launch/.cvsignore:
13541         * examples/manual/.cvsignore:
13542         * examples/mixer/.cvsignore:
13543         * examples/pingpong/.cvsignore:
13544         * examples/plugins/.cvsignore:
13545         * examples/queue/.cvsignore:
13546         * examples/queue2/.cvsignore:
13547         * examples/queue3/.cvsignore:
13548         * examples/queue4/.cvsignore:
13549         * examples/retag/.cvsignore:
13550         * examples/thread/.cvsignore:
13551         * examples/typefind/.cvsignore:
13552         * examples/xml/.cvsignore:
13553         * gst/.cvsignore:
13554         * gst/autoplug/.cvsignore:
13555         * gst/elements/.cvsignore:
13556         * gst/indexers/.cvsignore:
13557         * gst/parse/.cvsignore:
13558         * gst/registries/.cvsignore:
13559         * gst/schedulers/.cvsignore:
13560         * libs/gst/bytestream/.cvsignore:
13561         * libs/gst/control/.cvsignore:
13562         * libs/gst/getbits/.cvsignore:
13563         * tests/.cvsignore:
13564         * tests/bufspeed/.cvsignore:
13565         * tests/instantiate/.cvsignore:
13566         * tests/memchunk/.cvsignore:
13567         * tests/muxing/.cvsignore:
13568         * tests/sched/.cvsignore:
13569         * tests/seeking/.cvsignore:
13570         * tests/threadstate/.cvsignore:
13571         * testsuite/.cvsignore:
13572         * testsuite/caps/.cvsignore:
13573         * testsuite/cleanup/.cvsignore:
13574         * testsuite/dynparams/.cvsignore:
13575         * testsuite/plugin/.cvsignore:
13576         * tools/.cvsignore:
13577           update - this is huge, because it includes *.bb, *.bbg and *.da files
13578           which are generated for gcov.
13579
13580 2004-01-11  David Schleef  <ds@schleef.org>
13581
13582         * gst/gststructure.c: (gst_strtoi), (gst_value_from_string): Add
13583         a function to parse integers in ways that strto[u]l() does not.
13584
13585 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13586
13587         * tools/gst-inspect.c: (print_caps):
13588           improve output of caps a bit
13589
13590 2004-01-11  David Schleef  <ds@schleef.org>
13591
13592         * gst/gstbuffer.c: (gst_buffer_create_sub): Subbuffers should
13593         inherit correct flags (READONLY and DONTKEEP).
13594
13595 2004-01-11  David Schleef  <ds@schleef.org>
13596
13597         * gst/elements/gstfilesrc.c: (gst_filesrc_free_parent_mmap),
13598         (gst_filesrc_map_region):
13599         * gst/gstbuffer.c: (_gst_buffer_initialize),
13600         (_gst_buffer_sub_free), (gst_buffer_default_copy),
13601         (gst_buffer_new), (gst_buffer_create_sub),
13602         (gst_buffer_is_span_fast), (gst_buffer_span):
13603         * gst/gstbuffer.h:
13604         Change GstBuffer private structure element names. (all files)
13605         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
13606         (gst_queue_link):
13607         * gst/gstqueue.h:
13608         Implement getcaps/pad_link functions that handle the case where
13609         there are data in the queue.
13610
13611 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13612
13613         * gst/elements/gstbufferstore.c:
13614           initialize debugging structure correctly
13615         * gst/elements/gsttee.c: (gst_tee_set_property):
13616           g_object_notify when property was changed
13617         * gst/elements/gsttypefindelement.c:
13618         (gst_type_find_element_change_state):
13619           clear caps correctly
13620
13621 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13622
13623         * gst/gstqueue.c: (gst_queue_init):
13624           Use better defaults for when a queue should block. This
13625           gets rid of jerky playback for quite a few files.
13626           It takes more memory.
13627
13628 2004-01-10  Thomas Vander Stichele  <thomas at apestaart dot org>
13629
13630         (gst_xml_registry_parse_padtemplate):
13631           make critical message slightly more useful
13632
13633 2004-01-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13634
13635         * gst/gstinfo.c: (gst_debug_log), (gst_debug_log_valist),
13636         (gst_debug_message_get), (gst_debug_log_default):
13637         * gst/gstinfo.h:
13638           Change gst_debug_log(_valist) to take a const format string.
13639           Change prototype of log function and functions using those to 
13640           take a GstDebugMessage instead of a string that requires using
13641           gst_debug_message_get.
13642
13643 2004-01-08  David Schleef  <ds@schleef.org>
13644
13645         * Makefile.am:
13646         * configure.ac:
13647         Add option --enable-gcov to build GStreamer with -fprofile-arcs
13648         and -ftest-coverage, which allows gcov to show information about
13649         testsuite coverage.
13650
13651 2004-01-08  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13652
13653         * gst/gstutils.h:
13654           Add GST_BOILERPLATE(_FULL), GST_PARENT_CALL and
13655           GST_PARENT_CALL_WITH_DEFAULT
13656         * gst/elements/gstaggregator.c: 
13657         * gst/elements/gstbufferstore.c: 
13658         * gst/elements/gstfakesink.c: 
13659         * gst/elements/gstfakesrc.c: 
13660         * gst/elements/gstfdsink.c: 
13661         * gst/elements/gstfdsrc.c: 
13662         * gst/elements/gstfilesink.c: 
13663         * gst/elements/gstfilesrc.c: 
13664         * gst/elements/gstidentity.c: 
13665         * gst/elements/gstmd5sink.c: 
13666         * gst/elements/gstmultidisksrc.c:
13667         * gst/elements/gstpipefilter.c: 
13668         * gst/elements/gstshaper.c:
13669         * gst/elements/gststatistics.c:
13670         * gst/elements/gsttee.c:
13671         * gst/elements/gsttypefindelement.c:
13672           use them.
13673
13674 2004-01-07  Thomas Vander Stichele  <thomas at apestaart dot org>
13675
13676         * docs/gst/gstreamer-docs.sgml: remove props
13677         * docs/gst/gstreamer-sections.txt: remove props
13678         * docs/gst/tmpl/gst.sgml:
13679         * docs/gst/tmpl/gstbin.sgml:
13680         * docs/gst/tmpl/gstbuffer.sgml:
13681         * docs/gst/tmpl/gstcaps.sgml:
13682         * docs/gst/tmpl/gstclock.sgml:
13683         * docs/gst/tmpl/gstelement.sgml:
13684         * docs/gst/tmpl/gstindex.sgml:
13685         * docs/gst/tmpl/gstobject.sgml:
13686         * docs/gst/tmpl/gstpad.sgml:
13687         * docs/gst/tmpl/gstpadtemplate.sgml:
13688         * docs/gst/tmpl/gstreamer-unused.sgml:
13689         * docs/gst/tmpl/gstthread.sgml:
13690         * docs/gst/tmpl/gstxml.sgml:
13691           sync with code reorganization
13692
13693 2004-01-07  Jan Schmidt  <thaytan@mad.scientist.com>
13694
13695         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered):
13696         Make the 'Could not find compatible pad' message more informative.
13697
13698 2004-01-07  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13699                                                                                 
13700         * gst/elements/gstfilesink.c: (gst_filesink_set_location):
13701           Fix for if we pass NULL as property to location.
13702         * gst/elements/gstpipefilter.c: (gst_pipefilter_init),
13703         (gst_pipefilter_handle_event), (gst_pipefilter_chain):
13704           Fix for instantiate-test (see below).
13705         * gst/gststructure.c: (_gst_structure_parse_value):
13706           Fix compile error on gcc-2.96.
13707         * configure.ac:
13708         * tests/Makefile.am:
13709         * tests/instantiate/Makefile.am:
13710         * tests/instantiate/create.c: (create_all_elements), (main):
13711           Add a test that instantiates all elements. This makes it easy to
13712           track dead code for old API/design (like setting event functions
13713           on sink pads and so on).
13714
13715 2004-01-06  Jan Schmidt  <thaytan@mad.scientist.com>
13716
13717         * gst/gstcaps.c: (gst_caps_append_structure):
13718           Move the poisoning to allow a NULL structure
13719         * gst/gstevent.c: (_gst_event_free):
13720           When freeing a navigation event, free the structure
13721           also
13722
13723 2004-01-04  David Schleef  <ds@schleef.org>
13724
13725         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_request_new_pad):
13726         Remove usage of gst_pad_proxy_fixate.
13727         * gst/gstcaps.c: (gst_caps_append), (gst_caps_append_structure),
13728         (gst_caps_split_one), (gst_caps_replace):
13729         Add poisoning code.
13730         * gst/gstmarshal.list:
13731         Add pointer__pointer for fixate signal
13732         * gst/gstpad.c: (gst_real_pad_class_init),
13733         (_gst_real_pad_fixate_accumulator), (gst_pad_link_fixate),
13734         (_gst_pad_default_fixate_func), (gst_pad_proxy_fixate),
13735         (gst_pad_set_explicit_caps), (gst_pad_template_new):
13736         Add poisoning code. Add fixate signal on RealPad. Change
13737         set_explicit_caps() to take const GstCaps, like try_set_caps().
13738         * gst/gstpad.h:
13739         * testsuite/caps/Makefile.am:
13740         * testsuite/caps/app_fixate.c: Add a test for the fixate signal
13741
13742 2004-01-03  David Schleef  <ds@schleef.org>
13743
13744         * gst/elements/gsttypefindelement.c:
13745         (gst_type_find_element_have_type), (gst_type_find_element_init):
13746         Use gst_pad_use_explicit_caps for src pad.
13747         * gst/gstpad.c: (gst_pad_try_set_caps):  Check that link exists
13748         before using it.
13749
13750 2004-01-03  David Schleef  <ds@schleef.org>
13751
13752         * gst/gstelement.c: (gst_element_link_pads_filtered),
13753         (gst_element_negotiate_pads): Fix to allow DELAYED to indicate
13754         that linking was successful.
13755         * gst/gstpad.c: (gst_pad_link_free),
13756         (gst_pad_link_call_link_functions), (gst_pad_link_negotiate),
13757         (gst_pad_link_try), (gst_pad_link_unnegotiate),
13758         (gst_pad_unnegotiate), (gst_pad_set_explicit_caps): Pass
13759         GstPadLinkReturn correctly between functions, and don't fail
13760         when DELAYED is used (DELAYED is very important).  Better
13761         cleanup on unlinking and unnegotiation.  Should fix some spider
13762         bugs.
13763
13764 2004-01-02  David Schleef  <ds@schleef.org>
13765
13766         * gst/gstelement.c: (gst_element_class_init),
13767         (gst_element_base_class_init): ->padtemplates should be cleared
13768         in base_init, since we need to have a fresh list for every
13769         class.  (Alternately, we chould copy the list and share the
13770         actual pad templates (not the list), but that would require
13771         changing every plugin to move pad template registration from
13772         base_init to class_init.)
13773
13774 2004-01-03  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13775
13776         * gst/gstelement.c: (gst_element_class_add_pad_template):
13777           Refuse registering a pad template if another pad template
13778           with the same name already exists (#114715).
13779
13780 2004-01-02  David Schleef  <ds@schleef.org>
13781
13782         * gst/gstcaps.c: (_gst_structure_is_equal_foreach),
13783         (gst_caps_is_equal_fixed): Add new function.
13784         * gst/gstcaps.h: ditto.
13785         * gst/gstpad.c: (gst_real_pad_class_init),
13786         (gst_pad_link_call_link_functions), (gst_pad_try_set_caps),
13787         (gst_pad_set_explicit_caps), (gst_pad_get_caps):  In try_set_caps,
13788         check new caps against existing caps -- if they're the same, return
13789         OK without renegotiating.  caps-nego-failed signal fixed so that
13790         the marshaller isn't VOID__OBJECT.  Also changed to G_TYPE_POINTER
13791         to save an extra caps copy.  Don't complete negotiation if a pad
13792         link function returns DELAYED.
13793
13794 2004-01-02  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13795
13796         * gst/gstpad.c: (gst_pad_try_relink_filtered):
13797           Fix wrong g_return_if_fail
13798
13799 2004-01-03  Jan Schmidt  <thaytan@mad.scientist.com>
13800
13801         * gst/gstbin.c: (gst_bin_class_init):
13802         Change the marshalling of element_added/element_removed
13803         to use gst_marshal_VOID__OBJECT, since gst_marshal_VOID__POINTER 
13804         complains that GST_TYPE_ELEMENT is not G_TYPE_POINTER
13805
13806 2004-01-01  David Schleef  <ds@schleef.org>
13807
13808         * gst/gstpad.c: (gst_pad_set_explicit_caps),
13809         (gst_pad_explicit_getcaps), (gst_pad_explicit_link),
13810         (gst_pad_use_explicit_caps):
13811         * gst/gstpad.h:
13812         Add new functions.  gst_pad_use_explicit_caps() sets up a pad
13813         to use an internal getcaps and link fuction so that negotiation
13814         always results in the explicitly set caps.
13815         gst_pad_set_explicit_caps() sets the explicit caps.  These functions
13816         are particularly useful for decoders.
13817
13818 2003-12-31  David Schleef  <ds@schleef.org>
13819
13820         * gst/elements/gstidentity.c: (gst_identity_class_init),
13821         (gst_identity_init), (gst_identity_chain),
13822         (gst_identity_set_property), (gst_identity_get_property):
13823         * gst/elements/gstidentity.h:
13824         * gst/gstqueue.c: (gst_queue_init):
13825           Negotiation fixes.
13826
13827 2003-12-31  David Schleef  <ds@schleef.org>
13828
13829         * gst/gstcaps.c: (gst_caps_intersect),
13830         (_gst_caps_normalize_foreach), (gst_caps_normalize):
13831           Implement gst_caps_normalize().
13832         * testsuite/caps/normalisation.c: (main):
13833           Add an additional test
13834
13835 2003-12-31  Ronald Bultje  <rbultje@ronald.bitfreak.net>
13836
13837         * gst/gstqueue.c: (gst_queue_init):
13838           use gst_pad_proxy_getcaps()
13839
13840 2003-12-31  David Schleef  <ds@schleef.org>
13841
13842         * gst/elements/gstshaper.c: (gst_shaper_link):
13843         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_request_new_pad):
13844         * gst/gstqueue.c: (gst_queue_link):
13845           Negotiation fixes.
13846
13847 2003-12-31  David Schleef  <ds@schleef.org>
13848
13849         * gst/gstpad.c: (gst_pad_proxy_pad_link), (gst_pad_proxy_fixate):
13850         * gst/gstpad.h: Add functions that are useful as default pad
13851         link and fixate functions for elements.
13852
13853 2003-12-30  David Schleef  <ds@schleef.org>
13854
13855         * gst/gstpad.c: (gst_pad_link_try):
13856           Fix segfault when attempting to return to old caps
13857
13858 2003-12-29  David Schleef  <ds@schleef.org>
13859
13860         * gst/gstcaps.c: (gst_caps_normalize), (simplify_foreach),
13861         (gst_caps_structure_simplify), (gst_caps_simplify):
13862         * gst/gstcaps.h:
13863           Add simplify function
13864         * gst/gstpad.c: (gst_pad_link_try), (gst_pad_try_set_caps),
13865         (gst_pad_perform_negotiate), (gst_pad_is_negotiated):
13866         * gst/gstpad.h:
13867           Copy over srcnotify, sinknotify when calling old pad_link
13868           functions.  Add new is_negotiated() function.
13869         * gst/gststructure.c: (gst_structure_copy):
13870           Fix an incredibly stupid bug that should have been noticed
13871           weeks ago.  _copy() returned the argument, not the new copy.
13872
13873 2003-12-27  Benjamin Otte  <in7y118@public.uni-hamburg.de>
13874
13875         * gst/gstcaps.c: (gst_caps_append):
13876           add sanity checks
13877         * gst/gstcaps.h: (gst_caps_debug):
13878           remove, it doesn't exist anymore.
13879         * gst/gstelement.c: (gst_element_threadsafe_properties_pre_run),
13880         (gst_element_threadsafe_properties_post_run):
13881           make debugging messages not clutter up THREAD debug category
13882         (gst_element_negotiate_pads), (gst_element_clear_pad_caps),
13883         (gst_element_change_state):
13884           update to new caps API
13885         * gst/gstinterface.c: (gst_implements_interface_cast):
13886           don't put vital code in g_return_if_fail
13887         * gst/gstpad.c: (gst_pad_link_try), (gst_pad_try_set_caps), 
13888         (gst_pad_link_filtered):
13889           add pst_pad_try_link and use it.
13890         (gst_pad_perform_negotiate), (gst_pad_renegotiate):
13891           implement correctly, deprecate first one.
13892         (gst_pad_link_unnegotiate), (gst_pad_unnegotiate):
13893           add and implement.
13894         (gst_pad_try_relink_filtered), (gst_pad_relink_filtered):
13895           implement.
13896         (gst_pad_get_negotiated_caps):
13897           add and implement. Make GST_PAD_CAPS call this function.
13898         (gst_pad_get_caps):
13899           remove unneeded check..
13900         (gst_pad_recover_caps_error):
13901           disable, always return FALSE.
13902         (gst_real_pad_dispose):
13903           don't free caps and appfilter anymore, they're unused.
13904         * gst/gstpad.h:
13905           Reflect changes mentioned above.
13906         * gst/gstsystemclock.c: (gst_system_clock_wait):
13907           Make 'clock is way behind' a debugging message.
13908         * gst/gstthread.c: (gst_thread_change_state):
13909           Fix debugging message
13910
13911 2003-12-25  Thomas Vander Stichele  <thomas at apestaart dot org>
13912
13913         * gst/gstinfo.h:
13914           fix GST_DEBUG_CATEGORY_INIT gtk-doc description
13915         * docs/gst/tmpl/gstreamer-unused.sgml:
13916           removed all traces of cvs conflicts
13917
13918 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
13919
13920         * configure.ac:
13921         * gst/schedulers/cothreads_compat.h:
13922         * libs/Makefile.am:
13923           remove last instances of wingo cothread usage
13924
13925 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
13926
13927         * gst/gstplugin.c:
13928         * gst/gstversion.h.in:
13929         * gst/parse/grammar.y:
13930           change comment block from /** to /* when not gtk-doc comments
13931
13932 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
13933
13934         * gst/gst.c: whitespace and doc style fixes
13935
13936 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
13937
13938         * gst/gstformat.h: remove trailing whitespace from enum for gtk-doc
13939
13940 2003-12-24  Colin Walters  <walters@verbum.org>
13941
13942         * gst/elements/gsttypefindelement.c:
13943           gst/elements/gsttypefindelement.h: Make GstCaps parameter const.
13944           Copy caps parameter. Use _POINTER to marshal caps instead of _BOXED.
13945           Don't double-free caps.
13946
13947 2003-12-23  David Schleef  <ds@schleef.org>
13948
13949         * gst/gstelement.c, gst/gstpad.c, gst/parse/grammar.y,
13950           gst/gstcaps.c, gst/autoplug/gstspideridentity.c:
13951           Many little fixes and additions of debug statements to
13952           get rhythmbox working.
13953
13954 2003-12-23  Colin Walters  <walters@verbum.org>
13955
13956         * gst/autoplug/gstspideridentity.c (gst_spider_identity_sink_loop_type_finding):
13957         Use GST_PAD_LINK_SUCCESSFUL.
13958
13959 2003-12-23  David Schleef  <ds@schleef.org>
13960
13961         * gst/elements/gstaggregator.c:
13962         * gst/elements/gsttee.c:
13963           Use gst_pad_proxy_getcaps().
13964         * gst/gstpad.c:
13965         * gst/gstpad.h:
13966           Add gst_pad_proxy_getcaps(), which filter elements can use
13967           as a generic getcaps implementation.
13968           Fix gst_pad_get_allowed_caps().  It just wasn't doing what
13969           was advertised.
13970
13971 2003-12-23  David Schleef  <ds@schleef.org>
13972
13973         * gst/gstpad.c:
13974           Rearrange/rewrite much of the pad negotiation code, since it
13975           resembled pasta.  This actually changes the way some
13976           negotiation works, since the previous code was inconsistent
13977           depending on how it was invoked.  Add (internal) structure
13978           GstPadLink, which is used to hold some information (more in
13979           the future) about the link between two pads.  Fixes a number
13980           of bugs, including random lossage of filter caps when the
13981           initial negotiation is delayed.  A few functions are still
13982           unimplemented.
13983         * gst/gstpad.h:
13984           Add GST_PAD_LINK_{SUCESSFUL|FAILED}() macros.  Please use
13985           these when testing GstPadLinkReturn values instead of comparing
13986           directly.
13987
13988 2003-12-23  David Schleef  <ds@schleef.org>
13989
13990         * gst/gstvalue.c: 
13991         * gst/gstvalue.h:
13992           Rearrange lots of code.  Change registration of compare function
13993           into registration of compare/serialize/deserialize functions.
13994           Doesn't include implementation of gst_value_[de]serialize(),
13995           but that should be easy.
13996
13997 2003-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
13998
13999         * docs/gst/gstreamer-sections.txt:
14000         * docs/gst/tmpl/gstprops.sgml: removed
14001         * docs/gst/tmpl/gstreamer-bufferpool.sgml: removed
14002           David removed props and caps code, so let's remove their docs as well.
14003           Removed all no longer existing symbols from gstreamer-sections.txt
14004           
14005 2003-12-22  Colin Walters  <walters@verbum.org>
14006
14007         * gst/gsttaginterface.c, gst/gsttaginterface.h,
14008           gst/gsttag.c, gst/gsttag.h:  Add interface to setting GValues
14009           of tags directly.
14010
14011 2003-12-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
14012
14013         * gst/elements/gstelements.c:
14014           Set ranks of elements to NONE, so the autoplugger doesn't use them.
14015         * gst/elements/gstshaper.c: (gst_shaper_getcaps):
14016           Fix proxying to new CAPS stuff. Don't call get_allowed_caps but
14017           gst_caps (peer).
14018
14019 2003-12-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
14020
14021         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_caps_intersect):
14022         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link),
14023         (gst_spider_identity_getcaps), (gst_spider_identity_change_state),
14024         (gst_spider_identity_sink_loop_type_finding):
14025         * gst/autoplug/gstspideridentity.h:
14026           Fix autoplugging in spider element, so it works with new caps.
14027           This was mainly caused by identifying empty caps incorrectly.
14028
14029 2003-12-22  David Schleef  <ds@schleef.org>
14030
14031         * gststructure.c, gstvalue.c, gstvalue.h: Add
14032           gst_value_init_and_copy() and use it, to avoid silly mistakes in
14033           using g_value_copy()
14034
14035 2003-12-21  David Schleef  <ds@schleef.org>
14036
14037         * many, many files: Merge CAPS branch.  This includes:
14038           - implemention of GstValue and several GstValue types
14039           - implemention of GstStructure
14040           - entire rewrite of GstCaps
14041           - removal of GstProps
14042           - many changes to GstPad to compensate for new caps paradigm
14043           - removal of GstBufferpool
14044         * gst/Makefile.am, gst/gst.h, gst/gstpad.h, gst/gsttypefind.h,
14045         gstvalue.h, gst/gstcaps[2]*.[ch]:
14046           - rename gstcaps2.[ch] to gstcaps.[ch]
14047
14048 2003-12-21  Ronald Bultje  <rbultje@ronald.bitfreak.net>
14049
14050         * gst/gstqueue.c: (gst_queue_handle_pending_events),
14051         (gst_queue_chain), (gst_queue_handle_src_event):
14052           implement timeout for sending events. Workaround for if the
14053           pipeline on this queue is not passing any data.
14054
14055 2003-12-21  Ronald Bultje <rbultje@ronald.bitfreak.net>
14056                                                                                 
14057         * ChangeLog: moved to gstreamer/docs/random/old/ChangeLog.gstreamer
14058         * moved CVS to freedesktop.org