gst/gsterror.c (_gst_core_errors_init): Use the magic word..
[platform/upstream/gstreamer.git] / ChangeLog
1 2005-07-16  Andy Wingo  <wingo@pobox.com>
2
3         * gst/gsterror.c (_gst_core_errors_init): Use the magic word..
4
5 2005-07-16  Wim Taymans  <wim@fluendo.com>
6
7         * check/gst/gstbin.c: (GST_START_TEST):
8         Make elements silent as the deep_notify refs the
9         parent, which might make the test fail.
10
11         * gst/gstghostpad.c: (gst_ghost_pad_do_activate_push):
12         Don't hold the lock for too long.
13
14 2005-07-16  Tim-Philipp Müller  <tim at centricular dot net>
15
16         * gst/base/gstbasesrc.c: (gst_base_src_default_negotiate):
17           Don't unref the caps we passed to gst_caps_make_writable() after
18           passing them. gst_caps_make_writable() will do that for us.
19
20 2005-07-15  Andy Wingo  <wingo@pobox.com>
21
22         * gst/gstcaps.h (gst_caps_is_simple): Removed deprecated macro
23         (#157311).
24
25         * gst/elements/gstidentity.c (marshal_VOID__MINIOBJECT): Write our
26         own marshalling function for the handoff signal. Properly type the
27         buffer as a buffer. Fixes some warnings. Should do a more general
28         solution.
29         (gst_identity_class_init): Plug into the right marshaller.
30
31 2005-07-15  Wim Taymans  <wim@fluendo.com>
32
33         * docs/design/part-TODO.txt:
34         * docs/design/part-clocks.txt:
35         * docs/design/part-element-sink.txt:
36         * docs/design/part-events.txt:
37         * docs/design/part-gstpipeline.txt:
38         Updated docs, mostly DISCONT related.
39
40 2005-07-15  Tim-Philipp Müller  <tim at centricular dot net>
41
42         * docs/pwg/building-pads.xml:
43           s/GST_PAD_LINK_REFUSED/FALSE/ in gst_my_filter_setcaps()
44
45 2005-07-15  Andy Wingo  <wingo@pobox.com>
46
47         * tools/gst-typefind.c: Update, add copyright block.
48
49         * gst/base/gstbasesrc.c (gst_base_src_default_negotiate):
50         Normalize and truncate caps before fixation.
51
52         * gst/gstcaps.h:
53         * gst/gstcaps.c (gst_caps_truncate): New function, destructively
54         discards all but the first structure from its argument.
55
56 2005-07-15  Wim Taymans  <wim@fluendo.com>
57
58         * gst/base/gstbasetransform.c: (gst_base_transform_init),
59         (gst_base_transform_transform_caps), (gst_base_transform_getcaps),
60         (gst_base_transform_configure_caps), (gst_base_transform_setcaps),
61         (gst_base_transform_get_size), (gst_base_transform_buffer_alloc),
62         (gst_base_transform_handle_buffer), (gst_base_transform_getrange),
63         (gst_base_transform_chain), (gst_base_transform_change_state),
64         (gst_base_transform_set_passthrough),
65         (gst_base_transform_is_passthrough):
66         * gst/base/gstbasetransform.h:
67         Make passthrough work using the bufferpools.
68         Changed API a bit, subclasses have to write into a buffer
69         provided by the base class.
70         More debug info in nego functions.
71         
72         * gst/elements/gstidentity.c: (gst_identity_init),
73         (gst_identity_transform):
74         Port to new base class.
75
76 2005-07-15  Wim Taymans  <wim@fluendo.com>
77
78         * gst/gstmessage.c: (gst_message_new_state_changed):
79         * tools/gst-launch.c: (event_loop), (main):
80         Totally dump messages in -launch with the -m option.
81         Fix message name for State messages,
82
83 2005-07-14  Wim Taymans  <wim@fluendo.com>
84
85         * gst/base/gstbasesrc.c: (gst_base_src_loop):
86         Post error messages on errors.
87
88 2005-07-14  Wim Taymans  <wim@fluendo.com>
89
90         * gst/gstcaps.c: (gst_caps_do_simplify):
91         Remove debug info.
92
93         * gst/gsterror.h:
94         Define error for stream stopped.
95
96         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
97         (gst_proxy_pad_do_chain), (gst_proxy_pad_do_getrange):
98         Do proper return values.
99
100         * gst/gstpad.c: (gst_pad_get_caps_unlocked), (gst_pad_accept_caps),
101         (gst_pad_set_caps), (gst_pad_chain), (gst_pad_push),
102         (gst_pad_get_range):
103         Better return values.
104
105         * gst/gstpad.h:
106         Reorganise return values, add macro to check for fatal errors.
107
108         * gst/gstqueue.c: (gst_queue_chain):
109         Return proper GstFlowReturn values,
110
111 2005-07-14  Thomas Vander Stichele  <thomas at apestaart dot org>
112
113         * docs/gst/gstreamer-sections.txt:
114         * docs/gst/gstreamer.types:
115         * docs/gst/tmpl/gst.sgml:
116         * docs/gst/tmpl/gstbasesink.sgml:
117         * docs/gst/tmpl/gstbasesrc.sgml:
118         * docs/gst/tmpl/gstbasetransform.sgml:
119         * docs/gst/tmpl/gstbin.sgml:
120         * docs/gst/tmpl/gstbuffer.sgml:
121         * docs/gst/tmpl/gstcaps.sgml:
122         * docs/gst/tmpl/gstclock.sgml:
123         * docs/gst/tmpl/gstcompat.sgml:
124         * docs/gst/tmpl/gstconfig.sgml:
125         * docs/gst/tmpl/gstelement.sgml:
126         * docs/gst/tmpl/gstelementdetails.sgml:
127         * docs/gst/tmpl/gstelementfactory.sgml:
128         * docs/gst/tmpl/gstenumtypes.sgml:
129         * docs/gst/tmpl/gsterror.sgml:
130         * docs/gst/tmpl/gstevent.sgml:
131         * docs/gst/tmpl/gstfakesink.sgml:
132         * docs/gst/tmpl/gstfakesrc.sgml:
133         * docs/gst/tmpl/gstfilesink.sgml:
134         * docs/gst/tmpl/gstfilesrc.sgml:
135         * docs/gst/tmpl/gstfilter.sgml:
136         * docs/gst/tmpl/gstformat.sgml:
137         * docs/gst/tmpl/gstghostpad.sgml:
138         * docs/gst/tmpl/gstimplementsinterface.sgml:
139         * docs/gst/tmpl/gstindex.sgml:
140         * docs/gst/tmpl/gstindexfactory.sgml:
141         * docs/gst/tmpl/gstinfo.sgml:
142         * docs/gst/tmpl/gstiterator.sgml:
143         * docs/gst/tmpl/gstmacros.sgml:
144         * docs/gst/tmpl/gstmemchunk.sgml:
145         * docs/gst/tmpl/gstminiobject.sgml:
146         * docs/gst/tmpl/gstobject.sgml:
147         * docs/gst/tmpl/gstpad.sgml:
148         * docs/gst/tmpl/gstpadtemplate.sgml:
149         * docs/gst/tmpl/gstparse.sgml:
150         * docs/gst/tmpl/gstpipeline.sgml:
151         * docs/gst/tmpl/gstplugin.sgml:
152         * docs/gst/tmpl/gstpluginfeature.sgml:
153         * docs/gst/tmpl/gstquery.sgml:
154         * docs/gst/tmpl/gstqueue.sgml:
155         * docs/gst/tmpl/gstregistry.sgml:
156         * docs/gst/tmpl/gstregistrypool.sgml:
157         * docs/gst/tmpl/gstscheduler.sgml:
158         * docs/gst/tmpl/gstschedulerfactory.sgml:
159         * docs/gst/tmpl/gststructure.sgml:
160         * docs/gst/tmpl/gstsystemclock.sgml:
161         * docs/gst/tmpl/gsttaglist.sgml:
162         * docs/gst/tmpl/gsttagsetter.sgml:
163         * docs/gst/tmpl/gsttrace.sgml:
164         * docs/gst/tmpl/gsttrashstack.sgml:
165         * docs/gst/tmpl/gsttypefind.sgml:
166         * docs/gst/tmpl/gsttypefindfactory.sgml:
167         * docs/gst/tmpl/gsttypes.sgml:
168         * docs/gst/tmpl/gsturihandler.sgml:
169         * docs/gst/tmpl/gsturitype.sgml:
170         * docs/gst/tmpl/gstutils.sgml:
171         * docs/gst/tmpl/gstvalue.sgml:
172         * docs/gst/tmpl/gstversion.sgml:
173         * docs/gst/tmpl/gstxml.sgml:
174         * docs/libs/tmpl/gstcontrol.sgml:
175         * docs/libs/tmpl/gstdataprotocol.sgml:
176         * docs/libs/tmpl/gstdparam.sgml:
177         * docs/libs/tmpl/gstdplinint.sgml:
178         * docs/libs/tmpl/gstdpman.sgml:
179         * docs/libs/tmpl/gstdpsmooth.sgml:
180         * docs/libs/tmpl/gstgetbits.sgml:
181         * docs/libs/tmpl/gstunitconvert.sgml:
182         * gst/base/gstpushsrc.c: (gst_push_src_get_type),
183         (gst_push_src_base_init), (gst_push_src_class_init),
184         (gst_push_src_init), (gst_push_src_create):
185         * gst/base/gstpushsrc.h:
186         * gst/elements/gstelements.c:
187         * gst/elements/gstfakesink.c: (gst_fake_sink_state_error_get_type),
188         (gst_fake_sink_base_init), (gst_fake_sink_class_init),
189         (gst_fake_sink_init), (gst_fake_sink_set_property),
190         (gst_fake_sink_get_property), (gst_fake_sink_get_times),
191         (gst_fake_sink_event), (gst_fake_sink_preroll),
192         (gst_fake_sink_render), (gst_fake_sink_change_state):
193         * gst/elements/gstfakesink.h:
194         * gst/elements/gstfakesrc.c: (gst_fake_src_data_get_type),
195         (gst_fake_src_sizetype_get_type), (gst_fake_src_filltype_get_type),
196         (gst_fake_src_base_init), (gst_fake_src_class_init),
197         (gst_fake_src_init), (gst_fake_src_event_handler),
198         (gst_fake_src_alloc_parent), (gst_fake_src_set_property),
199         (gst_fake_src_get_property), (gst_fake_src_prepare_buffer),
200         (gst_fake_src_alloc_buffer), (gst_fake_src_get_size),
201         (gst_fake_src_create_buffer), (gst_fake_src_create),
202         (gst_fake_src_start), (gst_fake_src_stop):
203         * gst/elements/gstfakesrc.h:
204         * gst/elements/gstfilesink.c: (_do_init),
205         (gst_file_sink_base_init), (gst_file_sink_class_init),
206         (gst_file_sink_init), (gst_file_sink_dispose),
207         (gst_file_sink_set_location), (gst_file_sink_set_property),
208         (gst_file_sink_get_property), (gst_file_sink_open_file),
209         (gst_file_sink_close_file), (gst_file_sink_query),
210         (gst_file_sink_event), (gst_file_sink_render),
211         (gst_file_sink_change_state), (gst_file_sink_uri_get_type),
212         (gst_file_sink_uri_get_protocols), (gst_file_sink_uri_get_uri),
213         (gst_file_sink_uri_set_uri), (gst_file_sink_uri_handler_init):
214         * gst/elements/gstfilesink.h:
215         * gst/elements/gstfilesrc.c: (_do_init), (gst_file_src_base_init),
216         (gst_file_src_class_init), (gst_file_src_init),
217         (gst_file_src_finalize), (gst_file_src_set_location),
218         (gst_file_src_set_property), (gst_file_src_get_property),
219         (gst_file_src_map_region), (gst_file_src_map_small_region),
220         (gst_file_src_create_mmap), (gst_file_src_create_read),
221         (gst_file_src_create), (gst_file_src_is_seekable),
222         (gst_file_src_get_size), (gst_file_src_start), (gst_file_src_stop),
223         (gst_file_src_uri_get_type), (gst_file_src_uri_get_protocols),
224         (gst_file_src_uri_get_uri), (gst_file_src_uri_set_uri),
225         (gst_file_src_uri_handler_init):
226         * gst/elements/gstfilesrc.h:
227           more autistic cleanliness in functions/names/defines
228
229 2005-07-13  Andy Wingo  <wingo@pobox.com>
230
231         * gst/base/gstbasesrc.c (gst_base_src_start): Post an error if the
232         source couldn't negotiate.
233
234         * gst/parse/grammar.y: Revert 1.54->1.55, so we now do filtered
235         connections again.
236
237         * gst/gstutils.h:
238         * gst/gstutils.c (gst_element_link_pads_filtered): New old
239         function. I am channeling Hades. Put your boots on suckers!!!
240
241 2005-07-13  Thomas Vander Stichele  <thomas at apestaart dot org>
242
243         * testsuite/caps/Makefile.am:
244         * testsuite/caps/value_compare.c:
245         * testsuite/caps/value_intersect.c:
246         * check/gst/gstvalue.c: (GST_START_TEST), (gst_value_suite):
247           move two testsuite apps over to the check dir
248
249 2005-07-12  Wim Taymans  <wim@fluendo.com>
250
251         * gst/base/gstbasetransform.c: (gst_base_transform_setcaps):
252         Added more debug info in the negotiate process.
253
254         * gst/gstmessage.h:
255         Prepare for segment playback.
256
257         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_set_caps):
258         Better debugging.
259
260         * gst/gstutils.c:
261         Some more docs.
262
263         * tools/gst-launch.c: (main):
264         NULL pipeline on errors.
265
266 2005-07-12  Andy Wingo  <wingo@pobox.com>
267
268         * gst/gstbuffer.c (_gst_buffer_copy): Copy the buffer whether or
269         not it comes from a malloc region. Make sure our copy gets freed.
270
271 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
272
273         * check/gst/gstelement.c: (GST_START_TEST), (gst_element_suite):
274         * check/gst/gstmessage.c: (GST_START_TEST):
275         * check/gst/gststructure.c: (GST_START_TEST),
276         (gst_structure_suite), (main):
277           more testing
278         * gst/gstelement.c: (gst_element_message_full):
279           clean up GError and debug string now that they get copied
280         * gst/gstmessage.c: (gst_message_new_error),
281         (gst_message_new_warning), (gst_message_parse_error),
282         (gst_message_parse_warning):
283           use GST_TYPE_G_ERROR for structure_new, and take copies of
284           arguments, so that we don't mess up refcounting
285
286 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
287
288         * check/Makefile.am:
289           add per-test valgrind targets
290         * check/gst-libs/gdp.c: (GST_START_TEST),
291         (gst_data_protocol_suite), (main):
292           clean up
293
294 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
295
296         * check/Makefile.am:
297           instate more valgrindable tests
298         * check/elements/gstfakesrc.c: (chain_func), (event_func),
299         (GST_START_TEST), (fakesrc_suite):
300         * check/gst/gstpad.c: (GST_START_TEST):
301         * check/gst/gststructure.c: (GST_START_TEST):
302           fix test leaks
303         * docs/gst/tmpl/gstminiobject.sgml:
304         * gst/gstpad.c: (gst_pad_finalize):
305           fix the static mutex leak
306
307 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
308
309         * check/Makefile.am:
310           add two more tests for valgrinding
311         * check/gst/gstvalue.c: (GST_START_TEST):
312           test refcount of deserialized buffer, found a leak
313         * docs/gst/gstreamer-docs.sgml:
314         * docs/gst/gstreamer-sections.txt:
315         * docs/gst/gstreamer.types:
316         * docs/gst/tmpl/gstminiobject.sgml:
317           add miniobject to docs
318         * gst/gstminiobject.c:
319           add some docs
320         * gst/gstvalue.c: (gst_value_deserialize_buffer),
321         (gst_string_unwrap):
322           fix a hard-to-find invalid write for one of the tests
323           fix a leak for deserialized buffers
324
325 2005-07-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
326
327         * docs/pwg/advanced-events.xml:
328         * docs/pwg/advanced-request.xml:
329         * docs/pwg/advanced-scheduling.xml:
330         * docs/pwg/appendix-porting.xml:
331         * docs/pwg/building-boiler.xml:
332         * docs/pwg/intro-preface.xml:
333         * docs/pwg/other-ntoone.xml:
334           Rewrite scheduling-chapter for scheduling model in 0.9. Add lots
335           of example code and explanation for pad activation, loop() and
336           getrange() functions and a bit more. Remove old comments pointing
337           to loop-functions.
338         * examples/pwg/Makefile.am:
339           Add loop/getrange examples.
340
341 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
342
343         * configure.ac:
344           check for valgrind binary + some fixes
345         * check/gst.supp:
346           valgrind suppressions for the tests
347         * check/Makefile.am:
348           add a valgrind: target that valgrinds the unit tests
349         * check/gst/gst.c: (GST_START_TEST), (gst_suite):
350         * check/gst/gstbin.c: (pop_messages), (GST_START_TEST):
351         * check/gst/gstbuffer.c: (GST_START_TEST), (gst_test_suite):
352         * check/gst/gstghostpad.c:
353           added some cleanup
354         * check/gst/gstdata.c:
355           removed
356         * check/gst/gstminiobject.c: (GST_START_TEST), (thread_ref),
357         (thread_unref), (gst_mini_object_suite), (main):
358           added
359         * gst/gst.c: (gst_deinit):
360         * gst/gst.h:
361           add a method to clean up.
362         * gst/gstsystemclock.c: (gst_system_clock_dispose),
363         (gst_system_clock_obtain):
364           allow for disposing the system clock.
365         * tools/gst-launch.c: (main):
366           deinit
367
368 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
369
370         * docs/gst/tmpl/gstbasesrc.sgml:
371         * docs/gst/tmpl/gstfakesrc.sgml:
372         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
373         (gst_base_src_init), (gst_base_src_set_property),
374         (gst_base_src_get_property), (gst_base_src_get_range),
375         (gst_base_src_start):
376         * gst/base/gstbasesrc.h:
377           add num-buffers property
378         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
379         (gst_fakesrc_init), (gst_fakesrc_set_property),
380         (gst_fakesrc_get_property), (gst_fakesrc_create),
381         (gst_fakesrc_start):
382           remove num-buffers property
383
384 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
385
386         * docs/gst/gstreamer-sections.txt:
387         * docs/gst/tmpl/gstbasesink.sgml:
388         * docs/gst/tmpl/gstbasesrc.sgml:
389         * gst/base/gstbasesink.c: (gst_base_sink_pad_getcaps),
390         (gst_base_sink_pad_setcaps), (gst_base_sink_pad_buffer_alloc),
391         (gst_base_sink_finalize), (gst_base_sink_set_clock),
392         (gst_base_sink_set_property), (gst_base_sink_get_property),
393         (gst_base_sink_handle_object), (gst_base_sink_event),
394         (gst_base_sink_do_sync), (gst_base_sink_handle_event),
395         (gst_base_sink_handle_buffer), (gst_base_sink_chain),
396         (gst_base_sink_loop), (gst_base_sink_deactivate),
397         (gst_base_sink_activate_push), (gst_base_sink_activate_pull),
398         (gst_base_sink_change_state):
399         * gst/base/gstbasesink.h:
400         * gst/base/gstbasesrc.h:
401         * gst/elements/gstfakesink.c: (gst_fakesink_get_times):
402         * gst/elements/gstfilesink.c: (gst_filesink_class_init),
403         (gst_filesink_init):
404           more macro splitting
405
406 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
407
408         * gst/gstelement.c: (gst_element_get_bus):
409           add debug
410         * tools/gst-launch.c: (check_intr), (event_loop):
411           fix bus leaks
412
413 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
414
415         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked):
416           fix a caps leak
417
418 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
419
420         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
421         (gst_base_src_finalize):
422           add finalize method and clean up properly
423         * gst/gstpipeline.c: (gst_pipeline_dispose):
424           add debug
425
426 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
427
428         * check/gst/gstbin.c: (pop_messages), (GST_START_TEST),
429         (gst_bin_suite):
430           add more things to check
431         * gst/gstbin.c: (gst_bin_change_state), (bin_bus_handler):
432         * gst/gstelement.c:
433           more debug
434
435 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
436
437         * check/elements/gstfakesrc.c: (chain_func), (event_func),
438         (GST_START_TEST), (fakesrc_suite):
439         * check/gst-libs/gdp.c: (GST_START_TEST):
440         * check/gst/gst.c: (GST_START_TEST):
441         * check/gst/gstbin.c: (GST_START_TEST), (gst_bin_suite):
442         * check/gst/gstbuffer.c: (GST_START_TEST), (gst_test_suite):
443         * check/gst/gstbus.c: (GST_START_TEST):
444         * check/gst/gstcaps.c: (GST_START_TEST):
445         * check/gst/gstdata.c: (GST_START_TEST):
446         * check/gst/gstelement.c: (GST_START_TEST):
447         * check/gst/gstghostpad.c: (GST_START_TEST):
448         * check/gst/gstiterator.c: (GST_START_TEST):
449         * check/gst/gstmessage.c: (GST_START_TEST):
450         * check/gst/gstobject.c: (GST_START_TEST):
451         * check/gst/gstpad.c: (GST_START_TEST):
452         * check/gst/gststructure.c: (GST_START_TEST):
453         * check/gst/gstsystemclock.c: (GST_START_TEST),
454         (gst_systemclock_suite):
455         * check/gst/gsttag.c: (GST_START_TEST), (gst_tag_suite):
456         * check/gst/gstvalue.c: (GST_START_TEST):
457         * check/pipelines/cleanup.c: (GST_START_TEST):
458         * check/pipelines/simple_launch_lines.c: (GST_START_TEST):
459         * check/states/sinks.c: (GST_START_TEST):
460         * check/gstcheck.c: (gst_check_init):
461         * check/gstcheck.h:
462           add debugging category
463           use GST_START_TEST now, so we add a debug line
464
465 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
466
467         * check/gst/gstbin.c: (START_TEST), (gst_bin_suite):
468           add test for state change message on a bin
469         * check/gst/gstelement.c: (START_TEST), (gst_element_suite):
470           add another test
471         * gst/gstbin.c: (gst_bin_init):
472         * gst/gstbus.c: (gst_bus_init), (gst_bus_post):
473         * gst/gstelement.c: (gst_element_post_message),
474         (gst_element_set_state):
475         * gst/gstelementfactory.c: (gst_element_factory_create):
476         * gst/gstmessage.c: (gst_message_new):
477         * gst/gstscheduler.c:
478           various debugging additions and cleanups
479
480 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
481
482         * check/Makefile.am:
483         * check/gst/gstelement.c: (START_TEST), (gst_element_suite),
484         (main):
485           adding tests for elements
486         * gst/gstelement.c: (gst_element_dispose):
487
488 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
489
490         * gst/registries/gstlibxmlregistry.c: (load_feature):
491           plug more leaks.  A simple gst_init() now is leakfree, yay.
492
493 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
494
495         * gst/registries/gstlibxmlregistry.c: (read_string), (load_paths),
496         (gst_xml_registry_load):
497           plug another memleak
498
499 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
500
501         * configure.ac:
502           use GST_SET_ERROR_CFLAGS
503         * docs/faq/cvs.xml:
504           change to ERROR_CFLAGS
505
506 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
507
508         * configure.ac:
509           make GST_ERROR_CFLAGS overridable and re-enable Werror
510         * docs/faq/cvs.xml:
511           add a note about error CFLAGS
512         * docs/gst/tmpl/gstfakesrc.sgml:
513         * gst/elements/gstfakesrc.c:
514           comment out some unused code
515         * gst/gst.c: (split_and_iterate):
516         * gst/registries/gstlibxmlregistry.c: (load_pad_template),
517         (load_feature):
518           plug some memleaks
519
520 2005-07-07  Thomas Vander Stichele  <thomas at apestaart dot org>
521
522         * common/Makefile.am:
523         * common/gtk-doc.mak:
524         * docs/gst/Makefile.am:
525           factor out gtk-doc.mak
526
527 2005-07-07  Wim Taymans  <wim@fluendo.com>
528
529         * gst/schedulers/threadscheduler.c: (gst_thread_scheduler_func),
530         (gst_thread_scheduler_dispose):
531         Unlock the STREAM_LOCK completely.
532
533 2005-07-07  Thomas Vander Stichele  <thomas at apestaart dot org>
534
535         * check/Makefile.am:
536         * check/elements/.cvsignore:
537         * check/elements/gstfakesrc.c: (chain_func), (event_func),
538         (START_TEST), (fakesrc_suite), (main):
539         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
540         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
541         (gst_fakesrc_create), (gst_fakesrc_start):
542         * gst/elements/gstfakesrc.h:
543           adding a first element test
544
545 2005-07-07  Andy Wingo  <wingo@pobox.com>
546
547         * gst/gstbus.c (gst_bus_have_pending): Remove intensely irritating
548         debug message.
549
550 2005-07-07  Wim Taymans  <wim@fluendo.com>
551
552         * gst/gstquery.c:
553         * gst/gstquery.h:
554         Remove old types
555
556 2005-07-07  Wim Taymans  <wim@fluendo.com>
557
558         * gst/base/gstbasesrc.c: (gst_base_src_get_range),
559         (gst_base_src_default_negotiate), (gst_base_src_negotiate):
560         Allow subclasses to implement their own negotiation.
561
562 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
563
564         * docs/design/part-gstbin.txt:
565         * docs/design/part-gstpipeline.txt:
566           Update design notes to reflect the movement of
567           responsibility for bus handling from GstPipeline to
568           GstBin
569
570 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
571
572         * configure.ac:
573           Remove unnecessary queue2/3/4 examples.
574
575 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
576
577         * examples/Makefile.am:
578         * examples/helloworld/helloworld.c: (event_loop), (main):
579         * examples/queue/queue.c: (event_loop), (main):
580         * examples/queue2/queue2.c: (main):
581           Update a couple of the examples to work again.
582
583         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
584         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_event):
585          Spelling corrections and extra debug.
586         
587         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_init), (is_eos),
588         (gst_bin_add_func), (bin_element_is_sink), (gst_bin_get_state),
589         (gst_bin_change_state), (gst_bin_dispose), (bin_bus_handler):
590         * gst/gstbin.h:
591         * gst/gstpipeline.c: (gst_pipeline_init), (gst_pipeline_dispose),
592         (gst_pipeline_change_state):
593         * gst/gstpipeline.h:
594           Move the bus handler for children to the GstBin, and create a
595           separate bus for receiving messages from children to the one the
596           bus sends 'upwards' on.
597
598 2005-07-06  Wim Taymans  <wim@fluendo.com>
599
600         * gst/base/README:
601         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
602         (gst_base_sink_handle_object), (gst_base_sink_loop),
603         (gst_base_sink_change_state):
604         * gst/base/gstbasesink.h:
605         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
606         (gst_base_src_init), (gst_base_src_setcaps),
607         (gst_base_src_getcaps), (gst_base_src_loop),
608         (gst_base_src_default_negotiate), (gst_base_src_negotiate),
609         (gst_base_src_start), (gst_base_src_change_state):
610         * gst/base/gstbasesrc.h:
611         Make basesrc negotiate.
612         Handle the case where preroll fails in basesink.
613         Update README.
614
615 2005-07-06  Wim Taymans  <wim@fluendo.com>
616
617         * gst/gstpad.c: (gst_pad_fixate_caps), (gst_pad_accept_caps):
618         Implement the fixate function.
619         Clean up acceptcaps.
620
621 2005-07-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
622
623         * docs/pwg/building-filterfactory.xml:
624         * docs/pwg/pwg.xml:
625           Remove never-written filter-factory chapter; I'll add the various
626           base classes to part 4 ("other element types") later on.
627
628 2005-07-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
629
630         * docs/pwg/advanced-negotiation.xml:
631         * docs/pwg/building-boiler.xml:
632         * docs/pwg/building-pads.xml:
633         * docs/pwg/pwg.xml:
634         * examples/pwg/Makefile.am:
635           Add a chapter on caps negotiation, simplify the original code
636           samples a bit w.r.t. caps negotiation, add link to the advanced
637           section. Add a bunch of examples showing different use cases of
638           different types of caps negotiation. Upstream renegotiation isn't
639           fully documented yet since nobody knows how that works.
640
641 2005-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
642
643         * check/gst/gstpad.c:
644         * check/gstcheck.c:
645         * gst/gstpad.c: (gst_pad_get_internal_links_default):
646           if pad has no parent, return NULL as list of internal links
647
648 2005-07-05  Andy Wingo  <wingo@pobox.com>
649
650         * gst/elements/gstfilesrc.c:
651         * gst/elements/gstfakesrc.c: 
652         * gst/base/gstpushsrc.c:
653         * gst/base/gstbasesrc.h: 
654         * gst/base/gstbasesrc.c: s/BASESRC/BASE_SRC/g.
655         
656 2005-07-05  Stefan Kost  <ensonic@users.sf.net>
657
658         * Makefile.am:
659           better report generation target (lcov needs a patch)
660
661 2005-07-05  Andy Wingo  <wingo@pobox.com>
662
663         * gst/elements, testsuite: Null if we got it...
664
665 2005-07-05  Wim Taymans  <wim@fluendo.com>
666
667         * configure.ac:
668         * libs/gst/dataprotocol/Makefile.am:
669         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_validate_packet):
670         * libs/gst/dataprotocol/dataprotocol.h:
671         * pkgconfig/Makefile.am:
672         * pkgconfig/gstreamer-dataprotocol-uninstalled.pc.in:
673         * pkgconfig/gstreamer-dataprotocol.pc.in:
674         Ported dataprotol to 0.9. 
675         Added pkgconfig files.
676
677 2005-07-05  Andy Wingo  <wingo@pobox.com>
678
679         * gst/base/gstbasetransform.c (gst_base_transform_setcaps):
680         Default to returning TRUE for the case when tranform_caps returns
681         a fixed caps, like for identity or volume.
682
683         * check/gst/gstbus.c (pound_bus_with_messages): 
684         * check/gst/gstmessage.c (START_TEST): 
685         * check/pipelines/simple_launch_lines.c (got_handoff): Application
686         message API change.
687
688         * gst/base/gstbasetransform.c (gst_base_transform_setcaps): More
689         logic weaks here: always run transform_caps, trying passthrough
690         operation only if the original caps intersects with the transform.
691
692         * gst/gstpad.c (gst_pad_link_check_compatible_unlocked): Debug
693         source and sink caps.
694
695         * gst/base/gstbasetransform.c (gst_base_transform_getcaps):
696         Intersect the peer caps with the pad template before going into
697         transform_caps.
698         (gst_base_transform_transform_caps): More debugging.
699
700         * gst/gstmessage.h (gst_message_new_application): Take a GstObject
701         src argument.
702
703 2005-07-04  Edward Hervey  <edward@fluendo.com>
704
705         * gst/gstutils.c:
706         * gst/gstutils.h:
707         (gst_pad_add_*_probe): now returns the signal id for better wrapping
708         in bindings.
709
710 2005-07-04  Andy Wingo  <wingo@pobox.com>
711
712         * check/gst/gstpad.c: Only set explicit caps on pads.
713
714 2005-07-01  Andy Wingo  <wingo@pobox.com>
715
716         * tests/network-clock.scm: Commentary update.
717
718         * gst/elements/gstidentity.c (PROP_DUPLICATE): Gone daddy gone.
719         Didn't really make sense, not implementable with basetransform,
720         etc.
721         (gst_identity_transform): Unref inbuf via make_writable. Feeble
722         attempt at implementing the sync property, needs an unlock method.
723
724         * gst/base/gstbasetransform.c (gst_base_transform_transform_caps):
725         New func, by default returns the same caps (the identity
726         transformation).
727         (gst_base_transform_getcaps): Uses transform_caps to return
728         something sensible.
729         (gst_base_transform_setcaps): Complicated logic to get caps on
730         both pads, even if they are different, and to call set_caps once
731         for every time both pads get their caps set.
732         (gst_base_transform_handle_buffer): Give the ref to the transform
733         function. Allows in-place modification of the buffer.
734
735         * gst/base/gstbasetransform.h (transform_caps): New class method.
736         Given caps on one side, what can I do on the other.
737         (set_caps): Take two caps, one for each side of the element.
738
739         * gst/gstpad.h:
740         * gst/gstpad.c (gst_pad_fixate_caps): Change prototype to modify
741         caps in place. This is safe because we can check the mutability of
742         the caps, and a good idea because fixate functions are just called
743         as a matter of last resort. (Not actually implemented.)
744         (gst_pad_set_caps): If the caps we're setting is actually the same
745         as the existing pad caps, just update the pointer without calling
746         setcaps. Assert that caps is either NULL or fixed, as per the
747         docs.
748
749         * gst/gstghostpad.c: Update for fixate changes.
750
751 2005-07-02  Andy Wingo  <wingo@pobox.com>
752
753         * gst/gstcaps.c:
754         * gst/gstcaps.h (gst_static_caps_get): Not const return, having
755         two refcounts makes it immutable, which is enough. Doc more.
756
757 2005-07-02  Jan Schmidt  <thaytan@mad.scientist.com>
758
759         * gst/gstpad.c: (gst_pad_emit_have_data_signal):
760           Put the mini_object into GValue as a mini_object,
761           not a gpointer, since that's how we declared
762           the signal.
763
764 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
765
766         * examples/pwg/Makefile.am:
767           Fix buildbot again.
768
769 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
770
771         * docs/pwg/building-testapp.xml:
772           Add extra check.
773         * examples/pwg/Makefile.am:
774           Fix buildbot.
775
776 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
777
778         * configure.ac:
779         * examples/Makefile.am:
780         * examples/pwg/Makefile.am:
781         * examples/pwg/extract.pl:
782           Enable building the PWG examples.
783         * docs/pwg/advanced-interfaces.xml:
784           Add URI interface stub.
785         * docs/pwg/advanced-types.xml:
786         * docs/pwg/other-autoplugger.xml:
787         * docs/pwg/appendix-porting.xml:
788         * docs/pwg/pwg.xml:
789           Add porting guide (mostly stubs), remove autoplugging (see ADM).
790         * docs/pwg/building-boiler.xml:
791         * docs/pwg/building-chainfn.xml:
792         * docs/pwg/building-pads.xml:
793         * docs/pwg/building-props.xml:
794         * docs/pwg/building-state.xml:
795         * docs/pwg/building-testapp.xml:
796           Update the building-*.xml parts for 0.9 changes. All examples
797           code blocks compile in examples/pwg/*.
798
799 2005-06-30  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
800
801         * docs/manual/advanced-autoplugging.xml:
802         * docs/manual/appendix-checklist.xml:
803         * docs/manual/appendix-integration.xml:
804         * docs/manual/highlevel-components.xml:
805           Fix playbin/decodebin examples, update docs a bit, mention bus
806           instead of signals in various places, mention kmplayer and
807           kaffeine since they have a working GStreamer backend in the KDE
808           section.
809
810 2005-06-30  Wim Taymans  <wim@fluendo.com>
811
812         * CHANGES-0.9:
813         * docs/design/draft-ghostpads.txt:
814         * docs/design/draft-push-pull.txt:
815         * docs/design/draft-query.txt:
816         * docs/design/part-TODO.txt:
817         * docs/design/part-query.txt:
818         Added CHANGES-0.9 doc, updated status of other docs.
819         
820         * gst/gstquery.h:
821         Remove "hmm" macro
822
823 2005-06-30  Wim Taymans  <wim@fluendo.com>
824
825         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
826         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_object),
827         (gst_base_sink_change_state):
828         * gst/base/gstbasesink.h:
829         Some tweaks, only EOS and a buffer complete a preroll.
830
831 2005-06-30  Andy Wingo  <wingo@pobox.com>
832
833         * gst/gstghostpad.c (gst_ghost_pad_do_activate_push): Proxy
834         activate_push down to the internal pad as well.
835
836 2005-06-30  Torsten Schoenfeld  <kaffeetisch@gmx.de>
837
838         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
839
840         * gst/gsttaginterface.c:
841           Some documentation fixes (#307394 and #307397).
842
843 2005-06-30  Antoine Tremblay  <hexa00@gmail.com>
844
845         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
846
847         * gst/gstvalue.c: (gst_value_intersect_list):
848           Fix memleak (#309125).
849
850 2005-06-30  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
851
852         * docs/manual/advanced-dataaccess.xml:
853           Fix fakesrc example to compile; doesn't work, bug somewhere...?
854         * docs/manual/basics-pads.xml:
855           Add reference for filtered caps to above chapter.
856
857 2005-06-30  Wim Taymans  <wim@fluendo.com>
858
859         * gst/gstbin.c: (clear_queue), (remove_all_from_queue),
860         (gst_bin_change_state):
861         Probes are gone.
862         Lame attempt at making the state change function a bit
863         more readable.
864
865 2005-06-30  Wim Taymans  <wim@fluendo.com>
866
867         * docs/design/part-clocks.txt:
868         * docs/design/part-element-sink.txt:
869         * docs/design/part-events.txt:
870         * docs/design/part-preroll.txt:
871         * docs/design/part-states.txt:
872         Some more tweeks and additions to the docs.
873
874 2005-06-30  Wim Taymans  <wim@fluendo.com>
875
876         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
877         (default_have_data), (gst_pad_class_init), (gst_pad_init),
878         (gst_pad_emit_have_data_signal), (gst_pad_chain), (gst_pad_push),
879         (gst_pad_check_pull_range), (gst_pad_get_range),
880         (gst_pad_pull_range), (gst_pad_push_event), (gst_pad_send_event):
881         * gst/gstpad.h:
882         * gst/gstutils.c: (gst_atomic_int_set), (gst_pad_add_data_probe),
883         (gst_pad_add_event_probe), (gst_pad_add_buffer_probe),
884         (gst_pad_remove_data_probe), (gst_pad_remove_event_probe),
885         (gst_pad_remove_buffer_probe):
886         Removed atomic operations, use existing LOCK.
887         Move exception handling out of main code path.
888
889 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
890
891         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
892         (silly_return_true_function), (gst_pad_class_init),
893         (gst_pad_emit_have_data_signal), (gst_pad_chain), (gst_pad_push),
894         (gst_pad_get_range), (gst_pad_pull_range), (gst_pad_push_event),
895         (gst_pad_send_event):
896           Fix accumulator, add default value by using _emitv() instead
897           of _emit() for signal emission.
898
899 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
900
901         * docs/manual/advanced-dataaccess.xml:
902         * examples/manual/Makefile.am:
903           Add probe example.
904         * gst/gstpad.c: (_gst_do_pass_data_accumulator):
905           Make work (??).
906
907 2005-06-29  Tim-Philipp Müller  <tim at centricular dot net>
908
909         * gst/elements/gstfilesink.c: (gst_filesink_render):
910           Simplify code so that we don't have to handle short
911           writes and return GST_FLOW_ERROR if an error occured.
912
913 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
914
915         * docs/gst/gstreamer-docs.sgml:
916           Remove probes more.
917
918 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
919
920         * docs/gst/gstreamer-sections.txt:
921         * docs/gst/tmpl/gstpad.sgml:
922         * docs/gst/tmpl/gstprobe.sgml:
923         * gst/Makefile.am:
924         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
925         (gst_pad_class_init), (gst_pad_init), (gst_pad_chain),
926         (gst_pad_push), (gst_pad_get_range), (gst_pad_pull_range),
927         (gst_pad_push_event), (gst_pad_send_event):
928         * gst/gstpad.h:
929         * gst/gstutils.c: (gst_pad_add_data_probe),
930         (gst_pad_add_event_probe), (gst_pad_add_buffer_probe),
931         (gst_pad_remove_data_probe), (gst_pad_remove_event_probe),
932         (gst_pad_remove_buffer_probe):
933         * gst/gstutils.h:
934           Remove old probes, add new g-signal-based probes and some utility
935           functions.
936
937 2005-06-29  Edward Hervey  <edward@fluendo.com>
938
939         * gst/gstelementfactory.c:
940         * gst/gstutils.h:
941         * gst/gstutils.c:
942         Moved gst_element_factory_can_[sink|src]_caps() to gstutils and added
943         the definition to the header file.
944
945 2005-06-29  Andy Wingo  <wingo@pobox.com>
946
947         * docs/gst/Makefile.am (scan-build.stamp): Totally only check
948         plugins from the source directory.
949
950 2005-06-29  Wim Taymans  <wim@fluendo.com>
951
952         * docs/gst/tmpl/gstbuffer.sgml:
953         * docs/gst/tmpl/gstclock.sgml:
954         Some fixings for blantently wrong text.
955
956 2005-06-29  Thomas Vander Stichele  <thomas at apestaart dot org>
957
958         * check/Makefile.am:
959         * gst/gst.c: (add_path_func), (init_pre):
960         * gst/gstregistry.c: (gst_registry_add_path):
961           add A GST_PLUGIN_PATH_ONLY env var; if it is set, it will
962           only scan the GST_PLUGIN_PATH locations, and not add
963           system locations
964
965 2005-06-29  Thomas Vander Stichele  <thomas at apestaart dot org>
966
967         * docs/gst/gstreamer-sections.txt:
968         * docs/gst/tmpl/gstbasesrc.sgml:
969         * gst/gstelement.c:
970         * gst/gstelement.h:
971         * gst/gstevent.c:
972         * gst/gstutils.c:
973           doc fixes
974
975 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
976
977         * docs/manual/advanced-autoplugging.xml:
978           Fix autoplugging example.
979
980 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
981
982         * docs/manual/advanced-autoplugging.xml:
983         * docs/manual/mime-world.fig:
984           Try to get autoplugging working, fix type detection. Fix text
985           in hello-world image.
986
987 2005-06-29  Wim Taymans  <wim@fluendo.com>
988
989         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
990         (gst_base_sink_change_state):
991         Small debug line.
992
993         * gst/gstclock.h:
994         map SIGNAL and BROADCAST to the right function.
995
996         * gst/gstobject.h:
997         Remove redundant braces.
998
999         * gst/gstpad.c: (gst_pad_set_caps):
1000         Don't call setcaps function when reseting caps to NULL.
1001
1002         * gst/gstsystemclock.c: (gst_system_clock_dispose),
1003         (gst_system_clock_async_thread), (gst_system_clock_id_wait_async),
1004         (gst_system_clock_id_unschedule):
1005         Use BROADCAST as this is what we do.
1006
1007 2005-06-29  Wim Taymans  <wim@fluendo.com>
1008
1009         * gst/base/gstbasesink.c: (gst_base_sink_handle_object):
1010         We are actually prerolling before commiting the state
1011         change. 
1012
1013 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1014
1015         * docs/manual/advanced-clocks.xml:
1016         * docs/manual/advanced-interfaces.xml:
1017         * docs/manual/advanced-metadata.xml:
1018         * docs/manual/advanced-position.xml:
1019         * docs/manual/advanced-schedulers.xml:
1020         * docs/manual/advanced-threads.xml:
1021         * docs/manual/appendix-porting.xml:
1022         * docs/manual/basics-bins.xml:
1023         * docs/manual/basics-bus.xml:
1024         * docs/manual/basics-elements.xml:
1025         * docs/manual/basics-helloworld.xml:
1026         * docs/manual/basics-pads.xml:
1027         * docs/manual/highlevel-components.xml:
1028         * docs/manual/manual.xml:
1029         * docs/manual/thread.fig:
1030           Update (until threads/scheduling) Application Development Manual;
1031           remove GstThread, add GstBus, add simple porting checklist, add
1032           documentation for tag writing, clocks, make all examples until this
1033           part compile and run.
1034         * examples/manual/Makefile.am:
1035           Update from changes to Application Development Manual; add bus
1036           example, remove thread example.
1037
1038 2005-06-28  Wim Taymans  <wim@fluendo.com>
1039
1040         * gst/gstbus.c: (gst_bus_post), (gst_bus_have_pending),
1041         (gst_bus_set_flushing), (gst_bus_pop), (gst_bus_peek),
1042         (gst_bus_source_dispatch):
1043         Add debugging messages.
1044         Make internal methods static.
1045         Handle the case where the bus is flushed in the handler.
1046         
1047         * gst/gstelement.c: (gst_element_get_bus):
1048         Fix refcount in _get_bus();
1049
1050         * gst/gstpipeline.c: (gst_pipeline_change_state),
1051         (gst_pipeline_get_clock_func):
1052         Clock refcounting fixes.
1053         Handle the case where preroll timed out more gracefully.
1054         
1055         * gst/gstsystemclock.c: (gst_system_clock_dispose):
1056         Clean up the internal thread in dispose. This is needed
1057         for subclasses that actually get disposed.
1058         
1059         * gst/schedulers/threadscheduler.c:
1060         (gst_thread_scheduler_class_init), (gst_thread_scheduler_func),
1061         (gst_thread_scheduler_dispose):
1062         Free thread pool in dispose.
1063
1064 2005-06-28  Andy Wingo  <wingo@pobox.com>
1065
1066         * tests/network-clock-utils.scm (debug, print-event): New utils.
1067
1068         * tests/network-clock.scm (*debug*, *with-graph*): New parameters.
1069         (*packet-loss*): Unified loss probability.
1070         (network-time): Report out-of-band events.
1071
1072         * tests/plot-data: Add support for out-of-band events. Hack it
1073         into this script instead of passing it down the pipe; should fix
1074         this later.
1075
1076 2005-06-28  Wim Taymans  <wim@fluendo.com>
1077
1078         * docs/gst/gstreamer.types:
1079         * docs/gst/tmpl/gstbasesrc.sgml:
1080         * docs/gst/tmpl/gstpad.sgml:
1081         Docs fixes.
1082
1083 2005-06-28  Wim Taymans  <wim@fluendo.com>
1084
1085         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
1086         (gst_proxy_pad_do_checkgetrange), (gst_proxy_pad_do_acceptcaps),
1087         (gst_proxy_pad_do_fixatecaps):
1088         Correctly proxy the check_pull_range function.
1089
1090 2005-06-28  Andy Wingo  <wingo@pobox.com>
1091
1092         * tests/network-clock.scm: Removed need for slib.
1093         
1094 2005-06-28  Wim Taymans  <wim@fluendo.com>
1095
1096         * gst/base/gstbasesink.c: (gst_basesink_set_pad_functions),
1097         (gst_basesink_preroll_queue_flush):
1098         * gst/base/gstbasesrc.c: (gst_basesrc_set_dataflow_funcs):
1099         * gst/elements/gsttee.c: (gst_tee_update_pad_functions):
1100         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
1101         (gst_proxy_pad_do_acceptcaps), (gst_proxy_pad_do_fixatecaps),
1102         (gst_proxy_pad_set_property):
1103         * gst/gstpad.c:
1104         * gst/gstpad.h:
1105         * gst/gstqueue.c: (gst_queue_init):
1106         The deprecated pad loop function is removed now.
1107
1108 2005-06-28  Andy Wingo  <wingo@pobox.com>
1109
1110         * tests/network-clock.scm (*timeout*, *send-loss*, *recv-loss*):
1111         New parameters, simulate network packet loss.
1112
1113         * tests/network-clock-utils.scm: Initialize the RNG.
1114
1115 2005-06-28  Wim Taymans  <wim@fluendo.com>
1116
1117         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_flush),
1118         (gst_basesink_event), (gst_basesink_deactivate):
1119         Flushing the preroll queue always needs to unlock the waiters.
1120
1121 2005-06-28  Edward Hervey  <edward@fluendo.com>
1122
1123         * gst/gstpipeline.c: (gst_pipeline_send_event): 
1124         Wheen a seek was successful on a pipeline, set the stream_time to the
1125         seek offset in order to have a synchronized stream_time.
1126
1127 2005-06-28  Wim Taymans  <wim@fluendo.com>
1128
1129         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
1130         (gst_proxy_pad_do_getrange), (gst_proxy_pad_do_checkgetrange),
1131         (gst_proxy_pad_do_getcaps), (gst_proxy_pad_do_acceptcaps),
1132         (gst_proxy_pad_do_fixatecaps):
1133         Call wrapper function instead of just calling the function
1134         pointers. This takes care of any locking and whatmore.
1135
1136 2005-06-28  Wim Taymans  <wim@fluendo.com>
1137
1138         * gst/gstpad.c: (gst_pad_alloc_buffer), (gst_pad_push),
1139         (gst_pad_pull_range):
1140         * gst/gstpad.h:
1141         CONNECTED -> LINKED.
1142
1143 2005-06-28  Andy Wingo  <wingo@pobox.com>
1144
1145         * *.c: Don't cast to GST_OBJECT when reffing or unreffing. Large
1146         source-munging commit!!!
1147
1148         * gst/gstobject.c (gst_object_unref, gst_object_ref) 
1149         (gst_object_sink): Take gpointer arguments, not GstObject --
1150         avoids casts. Like GLib.
1151
1152         * gst/gstghostpad.c (gst_proxy_pad_do_activate): Don't proxy
1153         activate.
1154
1155 2005-06-27  Andy Wingo  <wingo@pobox.com>
1156
1157         * gst/base/gsttypefindhelper.c (gst_type_find_helper): Unref any
1158         remaining buffer.
1159
1160         * gst/gsttrace.c (gst_alloc_trace_list_sorted): New helper,
1161         returns a sorted copy of the trace list.
1162         (gst_alloc_trace_print_live): New API, only prints traces with
1163         live objects. Sort the list.
1164         (gst_alloc_trace_print_all): Sort the list.
1165         (gst_alloc_trace_print): Align columns.
1166
1167         * gst/elements/gstttypefindelement.c:
1168         * gst/elements/gsttee.c:
1169         * gst/base/gstbasesrc.c:
1170         * gst/base/gstbasesink.c:
1171         * gst/base/gstbasetransform.c:
1172         * gst/gstqueue.c: Adapt for pad activation changes.
1173
1174         * gst/gstpipeline.c (gst_pipeline_init): Unref after parenting
1175         sched.
1176         (gst_pipeline_dispose): Drop ref on sched.
1177
1178         * gst/gstpad.c (gst_pad_init): Set the default activate func.
1179         (gst_pad_activate_default): Push mode by default.
1180         (pre_activate_switch, post_activate_switch): New stubs, things to
1181         do before and after switching activation modes on pads.
1182         (gst_pad_set_active): Take a boolean and not a mode, dispatch to
1183         the pad's activate function to choose which mode to activate.
1184         Shortcut on deactivation and call the right function directly.
1185         (gst_pad_activate_pull): New API, (de)activates a pad in pull
1186         mode.
1187         (gst_pad_activate_push): New API, same for push mode.
1188         (gst_pad_set_activate_function) 
1189         (gst_pad_set_activatepull_function) 
1190         (gst_pad_set_activatepush_function): Setters for new API.
1191
1192         * gst/gstminiobject.c (gst_mini_object_new, gst_mini_object_free):
1193         Trace all miniobjects.
1194         (gst_mini_object_make_writable): Unref the arg if we copy, like
1195         gst_caps_make_writable.
1196
1197         * gst/gstmessage.c (_gst_message_initialize): No trace init.
1198
1199         * gst/gstghostpad.c (gst_proxy_pad_do_activate) 
1200         (gst_proxy_pad_do_activatepull, gst_proxy_pad_do_activatepush):
1201         Adapt for new pad API.
1202
1203         * gst/gstevent.c (_gst_event_initialize): Don't initialize trace.
1204
1205         * gst/gstelement.h:
1206         * gst/gstelement.c (gst_element_iterate_src_pads) 
1207         (gst_element_iterate_sink_pads): New API functions.
1208         
1209         * gst/gstelement.c (iterator_fold_with_resync): New utility,
1210         should fold into gstiterator.c in some form.
1211         (gst_element_pads_activate): Simplified via use of fold and
1212         delegation of decisions to gstpad->activate.
1213
1214         * gst/gstbus.c (gst_bus_source_finalize): Set the bus to NULL,
1215         help in debugging.
1216
1217         * gst/gstbuffer.c (_gst_buffer_initialize): Ref the buffer type
1218         class once in init, like gstmessage. Didn't run into this issue
1219         but it seems correct. Don't initialize a trace, gstminiobject does
1220         that.
1221
1222         * check/pipelines/simple_launch_lines.c (test_stop_from_app): New
1223         test, runs fakesrc ! fakesink, stopping on ::handoff via a message
1224         to the bus.
1225         (assert_live_count): New util function, uses alloc traces to check
1226         cleanup.
1227
1228         * check/gst/gstghostpad.c (test_ghost_pads): More refcount checks.
1229         To be modified when unlink drops the internal pad.
1230
1231 2005-06-27  Wim Taymans  <wim@fluendo.com>
1232
1233         * gst/gstbin.c: (gst_bin_get_state), (gst_bin_iterate_state_order),
1234         (gst_bin_change_state):
1235         Cleanup the get_state() function a little, make sure it
1236         iterates the same set of elements.
1237         Added stub iterate_state_order().
1238
1239 2005-06-27  Thomas Vander Stichele  <thomas at apestaart dot org>
1240
1241         * docs/gst/gstreamer-docs.sgml:
1242         * docs/gst/gstreamer-sections.txt:
1243         * docs/gst/gstreamer.types:
1244         * docs/gst/tmpl/gstbasesink.sgml:
1245         * docs/gst/tmpl/gstbasesrc.sgml:
1246         * docs/gst/tmpl/gstbasetransform.sgml:
1247         * docs/gst/tmpl/gstelement.sgml:
1248         * docs/gst/tmpl/gstiterator.sgml:
1249         * gst/base/gstbasesrc.c:
1250         * gst/base/gstbasesrc.h:
1251         * gst/base/gstbasetransform.h:
1252         * gst/gstelement.c:
1253         * gst/gstiterator.h:
1254           adding basetransform and iterator docs
1255
1256 2005-06-27  Andy Wingo  <wingo@pobox.com>
1257
1258         * docs/design/part-activation.txt: Notes on how activation should
1259         work -- not quite implemented yet.
1260
1261 2005-06-25  Wim Taymans  <wim@fluendo.com>
1262
1263         * gst/gstghostpad.c: (gst_proxy_pad_do_chain):
1264         At least get the chain function correct, needs more
1265         fixing.
1266
1267 2005-06-25  Wim Taymans  <wim@fluendo.com>
1268
1269         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
1270         (gst_basesink_handle_object), (gst_basesink_event),
1271         (gst_basesink_do_sync), (gst_basesink_handle_event),
1272         (gst_basesink_change_state):
1273         * gst/gsttask.h:
1274         Right, two problems here: ghostpads don't take locks and
1275         glib _rec_mutex_lock_full() with depth==0 still locks.
1276         Catch illegal locking and g_warn them.
1277
1278 2005-06-25  Wim Taymans  <wim@fluendo.com>
1279
1280         * check/states/sinks.c: (START_TEST), (gst_object_suite):
1281         Have to check for completion now...
1282
1283 2005-06-25  Wim Taymans  <wim@fluendo.com>
1284
1285         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
1286         (gst_basesink_handle_object), (gst_basesink_event),
1287         (gst_basesink_do_sync), (gst_basesink_handle_event),
1288         (gst_basesink_change_state):
1289         * gst/gstpad.h:
1290         Unlock STREAM_LOCK whatever the recursion was.
1291
1292 2005-06-25  Wim Taymans  <wim@fluendo.com>
1293
1294         * gst/base/gstbasesink.c: (gst_basesink_set_property),
1295         (gst_basesink_preroll_queue_empty),
1296         (gst_basesink_preroll_queue_flush), (gst_basesink_handle_object),
1297         (gst_basesink_event), (gst_basesink_do_sync),
1298         (gst_basesink_handle_event), (gst_basesink_handle_buffer),
1299         (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate),
1300         (gst_basesink_change_state):
1301         Reworked the base sink, handle event and buffer serialisation
1302         correctly and removed possible deadlock.
1303         Handle EOS correctly.
1304
1305 2005-06-25  Wim Taymans  <wim@fluendo.com>
1306
1307         * gst/gstpipeline.c: (is_eos), (pipeline_bus_handler),
1308         (gst_pipeline_change_state):
1309         * tools/gst-launch.c: (check_intr), (event_loop), (main):
1310         Allow elements to post EOS in the state change function.
1311         Fix up -launch, make it exit the poll loop when the
1312         pipeline actually changed state.
1313         Fix up warning parsing in -launch.
1314
1315 2005-06-25  Wim Taymans  <wim@fluendo.com>
1316
1317         * gst/elements/gsttee.c: (gst_tee_chain), (gst_tee_loop),
1318         (gst_tee_sink_activate):
1319         Core takes STREAM_LOCK for us now.
1320
1321 2005-06-25  Wim Taymans  <wim@fluendo.com>
1322
1323         * gst/gstelement.c: (gst_element_get_state_func),
1324         (gst_element_set_state):
1325         * gst/gstelement.h:
1326         * gst/gstmessage.c: (gst_message_parse_error),
1327         (gst_message_parse_warning):
1328         Keep track of current target state while performing a state
1329         change so that subclasses can do something interesting.
1330         Fix parsing of warning/error messages when GError is NULL.
1331
1332 2005-06-24  Thomas Vander Stichele  <thomas at apestaart dot org>
1333
1334         * docs/gst/Makefile.am:
1335         * docs/gst/gstreamer-docs.sgml:
1336         * docs/gst/gstreamer-sections.txt:
1337         * docs/gst/gstreamer.types:
1338         * docs/gst/tmpl/gstbasesink.sgml:
1339         * docs/gst/tmpl/gstbasesrc.sgml:
1340         * docs/gst/tmpl/gstbin.sgml:
1341         * docs/gst/tmpl/gstcompat.sgml:
1342         * docs/gst/tmpl/gstfakesink.sgml:
1343         * docs/gst/tmpl/gstfakesrc.sgml:
1344         * docs/gst/tmpl/gstfilesink.sgml:
1345         * docs/gst/tmpl/gstfilesrc.sgml:
1346         * docs/gst/tmpl/gstindex.sgml:
1347         * docs/manual/appendix-quotes.xml:
1348         * gst/base/gstbasesrc.h:
1349         * gst/elements/gstfakesrc.h:
1350         * gst/gstmessage.h:
1351           start pulling in base classes and elements in our docs
1352
1353 2005-06-24  Stefan Kost  <ensonic@users.sf.net>
1354
1355         * docs/gst/Makefile.am:
1356         * docs/libs/Makefile.am:
1357           fixed make distcheck with gtk-doc 1.3
1358
1359 2005-06-23  Wim Taymans  <wim@fluendo.com>
1360
1361         * gst/gstelement.c: (gst_element_get_state_func),
1362         (gst_element_set_state), (gst_element_change_state):
1363         When the state did not change, also report NO_PREROLL
1364         when it matters.
1365
1366 2005-06-23  Wim Taymans  <wim@fluendo.com>
1367
1368         * gst/gstpad.c: (gst_pad_event_default):
1369         * gst/gstqueue.c: (gst_queue_loop):
1370         No unsafe task pausing please.
1371
1372 2005-06-23  Wim Taymans  <wim@fluendo.com>
1373
1374         * gst/schedulers/threadscheduler.c:
1375         (gst_thread_scheduler_task_start),
1376         (gst_thread_scheduler_task_pause), (gst_thread_scheduler_func):
1377         Ref the task before pushing it on the threadpool. This
1378         makes sure that we have a ref when the threadfunction is
1379         actually called.
1380
1381 2005-06-23  Andy Wingo  <wingo@pobox.com>
1382
1383         * gst/base/gstbasesrc.c (gst_basesrc_get_range): Check if the
1384         offset is greater than the file's size.
1385
1386         * gst/gstobject.h (GST_CLASS_LOCK, GST_CLASS_TRYLOCK) 
1387         (GST_CLASS_UNLOCK, GST_CLASS_GET_LOCK, GstObjectClass)
1388         * gst/gstobject.c (gst_object_class_init): Make the class lock
1389         recursive. Wim won't let me drop deep_notify. Decodebin works
1390         again, whoopdy doo.
1391
1392         * gst/gstghostpad.c (on_int_notify): Catches notify::caps on the
1393         internal pad, and hacks accordingly. Doesn't do it on the target
1394         pad because we change its caps. Probably catches all cases of
1395         interest tho.
1396         (gst_ghost_pad_set_property): Connect to notify::caps as
1397         appropritate.
1398
1399         * tests/network-clock.scm (plot-simulation): Pipe data to the
1400         elite python skript.
1401
1402         * tests/network-clock-utils.scm (define-parameter): New macro,
1403         defines a parameter that can be set via the command line.
1404         (set-parameter!, parse-parameter-arguments): Command line args
1405         parser.
1406
1407         * tests/plot-data: Simple matplotlib-based plotter, takes input on
1408         stdin.
1409
1410 2005-06-23  Jan Schmidt  <thaytan@mad.scientist.com>
1411
1412         * gst/elements/gsttypefindelement.c:
1413         (gst_type_find_element_handle_event):
1414           Don't restart typefinding on a discont.
1415         * gst/gstelement.c: (gst_element_set_state):
1416           Debug spelling fix.
1417         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_send_event):
1418           Allow changing mode of an active pad.
1419           Debug output fixes.
1420         * gst/registries/gstlibxmlregistry.c: (load_feature):
1421           Don't cast a static pad template to a normal pad template.
1422
1423 2005-06-23  Thomas Vander Stichele  <thomas at apestaart dot org>
1424
1425         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
1426         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
1427           remove gst_strtoll completely, since it didn't actually do
1428           anything more than what g_ascii_strtoull already does.
1429           check for range errors when deserializing
1430           do a cast for the unsigned cases; but further fixing needs
1431           a decision on what the interpretation of "(int)" and
1432           deserialization should be for values that fall outside the
1433           type's boundaries (ie, refuse, or interpret as casting)
1434
1435 2005-06-23  Wim Taymans  <wim@fluendo.com>
1436
1437         * check/Makefile.am:
1438         * check/states/sinks.c: (START_TEST), (gst_object_suite), (main):
1439         * docs/design/part-live-source.txt:
1440         * docs/design/part-states.txt:
1441         * gst/base/gstbasesrc.c: (gst_basesrc_init),
1442         (gst_basesrc_set_live), (gst_basesrc_is_live),
1443         (gst_basesrc_get_range), (gst_basesrc_activate),
1444         (gst_basesrc_change_state):
1445         * gst/base/gstbasesrc.h:
1446         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
1447         (gst_fakesrc_set_property), (gst_fakesrc_get_property):
1448         * gst/gstbin.c: (gst_bin_get_state), (gst_bin_change_state):
1449         * gst/gstelement.c: (gst_element_get_state_func),
1450         (gst_element_set_state):
1451         * gst/gstelement.h:
1452         * gst/gsttypes.h:
1453         * tools/gst-launch.c: (event_loop), (main):
1454         Added support for live sources and other elements that
1455         cannot do preroll.
1456         Updated design docs, added live-source design doc.
1457         Implemented live source functionality in basesrc
1458         Fix error condition in _bin_get_state()
1459         Implement live source handling in -launch.
1460         Added check for live sources.
1461         Fixed case in GstBin where elements were changed state
1462         multiple times.
1463
1464
1465 2005-06-23  Andy Wingo  <wingo@pobox.com>
1466
1467         * check/gst/gstpad.c (test_get_allowed_caps, test_refcount): Fix
1468         borken refcounting.
1469
1470         * gst/gstpad.c (gst_pad_set_caps): Remove needless refs,
1471         gst_caps_replace takes care of this for us.
1472
1473         * gst/gstghostpad.c (gst_proxy_pad_do_setcaps): Call the full
1474         gst_pad_set_caps on the target, not just its setcaps() function.
1475
1476         * tests/network-clock.scm: 
1477         * tests/network-clock-utils.scm: A network clock simulator.
1478         Something of an algorithmic testbed before doing something in C.
1479
1480 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
1481
1482         * check/Makefile.am:
1483         * check/gst/capslist.h:
1484           copy over from 0.8, and add two with bitmasks specified with
1485           (int) 0xFF...
1486         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite):
1487           add test to parse everything from capslist.h
1488         * check/gst/gststructure.c: (START_TEST), (gst_value_suite),
1489         (main):
1490           add test for structure deserialization
1491         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
1492           add tests for deserialization of strings to int types
1493         * gst/gststructure.c: (gst_structure_nth_field_name):
1494         * gst/gststructure.h:
1495           add a way to get the name of a field referenced by index
1496         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
1497           instead of checking if the resulting long long lies between
1498           min and max, we check if the long long would fit into
1499           a number of bytes for the final type.
1500           This fixes cases where a string represents 2^32 - 1, which
1501           when cast to int would be the (valid) -1, but is bigger than
1502           G_MAXINT
1503
1504 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
1505
1506         * gst/parse/grammar.y:
1507           add a log line for type deserialization
1508
1509 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
1510
1511         * check/gst/gstvalue.c: (START_TEST):
1512         * gst/gstvalue.c: (gst_value_deserialize):
1513           return long long, not int, so gint64 deserialization actually
1514           works.  Is there any flag that makes the compiler check this ?
1515           Fixes #308559
1516
1517 2005-06-22  Wim Taymans  <wim@fluendo.com>
1518
1519         * gst/gstbuffer.h:
1520         Added convenience macros for setting buffers in GValue.
1521
1522 2005-06-21  Thomas Vander Stichele  <thomas at apestaart dot org>
1523
1524         * check/gst/.cvsignore:
1525         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
1526           add a test deserializing int64, and comment part out because
1527           it fails, yay !
1528
1529 2005-06-21  Thomas Vander Stichele  <thomas at apestaart dot org>
1530
1531         * check/Makefile.am:
1532         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite), (main):
1533         * testsuite/Makefile.am:
1534         * testsuite/caps/Makefile.am:
1535         * testsuite/caps/value_serialize.c:
1536         * testsuite/test_gst_init.c:
1537           move a value_serialize test over
1538
1539 2005-06-20  Wim Taymans  <wim@fluendo.com>
1540
1541         * gst/gstpad.c:
1542         Small doc updates.
1543         
1544         * gst/gstvalue.c: (gst_value_compare_buffer),
1545         (gst_value_serialize_buffer), (gst_value_deserialize_buffer),
1546         (gst_value_compare_flags), (gst_value_serialize_flags),
1547         (gst_value_deserialize_flags), (_gst_value_initialize):
1548         Fix serialisation of buffers, they are not boxed types anymore
1549
1550 2005-06-20  Wim Taymans  <wim@fluendo.com>
1551
1552         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite):
1553         Testcase to show error in buffer-on-caps serialisation.
1554
1555 2005-06-20  Andy Wingo  <wingo@pobox.com>
1556
1557         * docs/random/wingo/porting-plugins-to-0.9: A pitiful document I
1558         will be adding to later.
1559
1560         * gst/gstsystemclock.c (gst_system_clock_init): Unlock the clock
1561         if its socks fill with rocks.
1562         (gst_system_clock_obtain): Set the name on object construction.
1563         Avoid double-checked locking.
1564
1565 2005-06-20  Tim-Philipp Müller  <tim at centricular dot net>
1566
1567         * gst/gsturi.c: (gst_element_make_from_uri):
1568           Fix potential endless loop.
1569
1570 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
1571
1572         * check/Makefile.am:
1573           add gsttag
1574         * check/gst/gsttag.c: (check_tags), (START_TEST), (gst_tag_suite),
1575         (main):
1576           move over from testsuite dir and clean up
1577         * configure.ac:
1578         * gst/gsttag.c:
1579         * testsuite/Makefile.am:
1580         * testsuite/tags/.cvsignore:
1581         * testsuite/tags/Makefile.am:
1582         * testsuite/tags/merge.c:
1583           remove testsuite/tags
1584
1585 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
1586
1587         * docs/gst/gstreamer-sections.txt:
1588         * docs/gst/tmpl/gstenumtypes.sgml:
1589         * win32/gstenumtypes.c:
1590           clean up documentation build a little
1591
1592 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
1593
1594         * check/gstcheck.h:
1595           add macros for checking refcounts on objects and caps
1596         * check/gst/gstpad.c: (START_TEST), (gst_pad_suite):
1597           add some more unit tests
1598         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked),
1599         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_get_allowed_caps):
1600           fix leaked refcounts (I hope :)) so unittest works
1601         * gst/gstpad.h:
1602           whitespace removal
1603
1604 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
1605
1606         * configure.ac: back to HEAD
1607
1608 === release 0.9.1 ===
1609
1610 2005-06-17  Thomas Vander Stichele  <thomas at apestaart dot org>
1611
1612         * NEWS:
1613         * RELEASE:
1614           updated
1615
1616 2005-06-17  Andy Wingo  <wingo@pobox.com>
1617
1618         * gst/base/gstbasesink.c (gst_basesink_chain): Remove bogus
1619         assert; it's always possible that the pad gets deactivated in
1620         between the checks in gstpad.c and the implementation. Rely on
1621         finish_preroll() to return a FLUSHING or similar instead of on the
1622         assert.
1623         
1624         * gst/base/gstbasesink.c (gst_basesink_event): Only wait for the
1625         clock and post an EOS message if we come out of finish_preroll in
1626         the playing state.
1627
1628 2005-06-16  David Schleef  <ds@schleef.org>
1629
1630         * gst/elements/gstcapsfilter.c: (gst_capsfilter_class_init),
1631         (gst_capsfilter_set_property): Allow NULL as possible value
1632         for filter_caps property, indicating GST_CAPS_ANY.
1633
1634 2005-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
1635
1636         * gst/elements/gstfakesrc.c: (gst_fakesrc_create):
1637           fix debug output
1638         * gst/schedulers/Makefile.am:
1639           use libgst prefix
1640         * gstreamer.spec.in:
1641           fix spec for it
1642
1643 2005-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
1644
1645         * gstreamer.spec.in:
1646           clean up
1647
1648 2005-06-08  Andy Wingo  <wingo@pobox.com>
1649
1650         * gst/gstutils.c: RPAD fixes all around.
1651         (gst_element_link_pads): Refcounting fixes.
1652
1653         * tools/gst-inspect.c:
1654         * tools/gst-xmlinspect.c:
1655         * parse/grammar.y:
1656         * gst/base/gsttypefindhelper.c:
1657         * gst/base/gstbasesink.c:
1658         * gst/gstqueue.c: RPAD fixes.
1659
1660         * gst/gstghostpad.h:
1661         * gst/gstghostpad.c: New ghost pad implementation as full proxy
1662         pads. The tricky thing is they provide both source and sink
1663         interfaces, since they proxy the internal pad for the external
1664         pad, and vice versa. Implement with lower-level ProxyPad objects,
1665         with the interior proxy pad as a child of the exterior ghost pad.
1666         Should write a doc on this.
1667         
1668         * gst/gstpad.h: s/RPAD/PAD/, s/RealPad/Pad/.
1669         (gst_pad_set_name, gst_pad_set_parent): Macros removed, use
1670         gst_object API.
1671         
1672         * gst/gstpad.c: Big changes. No more stub base GstPad, now all
1673         pads are real pads. No ghost pads in this file. Not documenting
1674         the myriad s/RPAD/PAD/ and REALIZE fixes.
1675         (gst_pad_class_init): Add properties for "direction" and
1676         "template". Both are construct-only, so they can't change during
1677         the life of the pad. Fixes properly deriving from GstPad.
1678         (gst_pad_custom_new, gst_pad_custom_new_from_template): Gone. For
1679         derived objects, just set properties when creating the objects via
1680         g_object_new.
1681         (gst_pad_get_parent): Implement as a function, return NULL if the
1682         parent is not an element.
1683         (gst_pad_get_real_parent, gst_pad_add_ghost_pad)
1684         (gst_pad_remove_ghost_pad, gst_pad_realize): Removed.
1685         
1686         * gst/gstobject.c (gst_object_class_init): Make name a construct
1687         property. Don't set it in the object init.
1688
1689         * gst/gstelement.c (gst_element_add_pad): Don't allow adding pads
1690         with UNKNOWN direction.
1691         (gst_element_add_ghost_pad): Remove non-orthogonal API. Replace
1692         with gst_element_add_pad (e, gst_ghost_pad_new (name, pad)).
1693         (gst_element_remove_pad): Remove ghost-pad special cases.
1694         (gst_element_pads_activate): Remove rpad cruft.
1695
1696         * gst/gstbin.c (gst_bin_change_state): Use gst_pad_get_parent to
1697         catch the pad's-parent-not-an-element case.
1698
1699         * gst/gst.h: Include gstghostpad.h.
1700
1701         * gst/gst.c (init_post): No more real, ghost pads.
1702
1703         * gst/Makefile.am: Add gstghostpad.[ch].
1704
1705         * check/Makefile.am:
1706         * check/gst/gstbin.c:
1707         * check/gst/gstghostpad.c (test_ghost_pads): Check that linking
1708         into a bin creates ghost pads, and that the refcounts are right.
1709         Partly moved from gstbin.c.
1710
1711 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1712
1713         * check/gst-libs/.cvsignore:
1714         * check/gst/.cvsignore:
1715         * check/pipelines/.cvsignore:
1716           ignore more
1717         * check/pipelines/cleanup.c: (setup_pipeline), (run_pipeline),
1718         (START_TEST), (cleanup_suite), (main):
1719           add some tests related to cleanup after running pipelines
1720
1721 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1722
1723         * check/gst/gstbuffer.c: (START_TEST), (gst_test_suite), (main):
1724           add a testsuite for GstBuffer
1725
1726 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1727
1728         * gst/gstminiobject.h:
1729           add defines for accessing the refcount
1730
1731 2005-06-03  Stefan Kost  <ensonic@users.sf.net>
1732
1733         * Makefile.am: added support for html unit test coverage reports
1734
1735 2005-06-03  Jan Schmidt  <thaytan@mad.scientist.com>
1736
1737         * gst/elements/gstcapsfilter.c: (gst_capsfilter_set_property):
1738           Free existing caps if the capsfilter changes. Add a FIXME about
1739           setting those caps on the pads.
1740
1741         * gst/gstutils.c: (gst_element_get_compatible_pad), (ghost_up):
1742           Before adding a ghost pad to a parent bin, check that there isn't
1743           already one for the element on the bin. Prevents infinite recursion
1744           when using decodebin in parse pipelines. Andy says he'll rewrite the
1745           way this works anyway, so ignore the hack.
1746
1747 2005-06-02  Andy Wingo  <wingo@pobox.com>
1748
1749         * gst/elements/gsttypefindelement.c (do_pull_typefind): Query the
1750         file size, pass it on to the type find helper.
1751
1752         * gst/base/gstbasesrc.c (gst_basesrc_do_seek): Set the
1753         segment_start and segment_end properly according to the seek
1754         method. Segment_end is still a bit flaky because offset can be
1755         negative for CUR and END cases, but it takes -1 as an "unset"
1756         value.
1757
1758 2005-06-02  Wim Taymans  <wim@fluendo.com>
1759
1760         * gst/base/gstbasesink.c: (gst_basesink_pad_buffer_alloc),
1761         (gst_base_sink_buffer_alloc), (gst_basesink_preroll_queue_push),
1762         (gst_basesink_activate):
1763         * gst/base/gstbasesink.h:
1764         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
1765         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_alloc_buffer),
1766         (gst_pad_query), (gst_pad_start_task):
1767         * gst/gstpad.h:
1768         * gst/gstqueue.c: (gst_queue_bufferalloc),
1769         (gst_queue_handle_sink_event), (gst_queue_chain):
1770         Bufferalloc: return GstFlowReturn to more accuratly report
1771         why allocation failed.
1772
1773 2005-06-02  Wim Taymans  <wim@fluendo.com>
1774
1775         * gst/gstpipeline.c: (gst_pipeline_send_event):
1776         Take snapshot of state without blocking.
1777
1778 2005-06-02  Wim Taymans  <wim@fluendo.com>
1779
1780         * docs/design/part-TODO.txt:
1781         * docs/design/part-caps.txt:
1782         * docs/design/part-clocks.txt:
1783         * docs/design/part-negotiation.txt:
1784         * docs/design/part-preroll.txt:
1785         Small doc updates 
1786
1787 2005-05-30  Wim Taymans  <wim@fluendo.com>
1788
1789         * gst/elements/gstidentity.c: (gst_identity_event),
1790         (gst_identity_transform), (gst_identity_get_property):
1791         Protect last_message property as it is accessed from
1792         multiple threads.
1793
1794 2005-05-30  Wim Taymans  <wim@fluendo.com>
1795
1796         * gst/gstelement.c: (gst_element_init),
1797         (gst_element_pads_activate), (gst_element_change_state):
1798         Slicker pad activation code.
1799
1800 2005-05-30  Wim Taymans  <wim@fluendo.com>
1801
1802         * gst/Makefile.am:
1803         * gst/gstelement.h:
1804         * gst/gstelementfactory.h:
1805         * gst/gsttypes.h:
1806         Move elementfactory methods to separate .h file.
1807
1808 2005-05-30  Wim Taymans  <wim@fluendo.com>
1809
1810         * docs/design/part-overview.txt:
1811         * gst/gstsystemclock.h:
1812         Small typo fixes, doc updates.
1813
1814 2005-05-30  Wim Taymans  <wim@fluendo.com>
1815
1816         * gst/gst.c: (gst_init_get_popt_table), (init_post),
1817         (init_popt_callback):
1818         Remove cpu-opt flag.
1819
1820 2005-05-30  Wim Taymans  <wim@fluendo.com>
1821
1822         * gst/gstbuffer.c: (gst_subbuffer_finalize),
1823         (gst_buffer_create_sub), (gst_buffer_is_span_fast):
1824         * gst/gstbuffer.h:
1825         Avoid typechecking in places where not needed.
1826         Added accessor for malloc_data.
1827
1828 2005-05-30  Wim Taymans  <wim@fluendo.com>
1829
1830         * gst/gstpad.c: (gst_real_pad_init), (gst_pad_set_active),
1831         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_accept_caps),
1832         (gst_pad_configure_sink), (gst_pad_configure_src),
1833         (gst_pad_alloc_buffer), (gst_pad_query), (gst_pad_send_event),
1834         (gst_pad_start_task):
1835         Propagate errors from _set_caps() in configure_src/sink
1836         functions instead of returning TRUE.
1837         FLUSH events can travel up and downstream
1838
1839
1840 2005-05-30  Wim Taymans  <wim@fluendo.com>
1841
1842         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_push),
1843         (gst_basesink_activate):
1844         Handle EOS in preroll.
1845
1846 2005-05-30  Wim Taymans  <wim@fluendo.com>
1847
1848         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
1849         (gst_queue_loop), (gst_queue_handle_src_event):
1850         Remove old pieces of code
1851         Flushing the queue in an upstream event is a very bad idea.
1852
1853 2005-05-26  Andy Wingo  <wingo@pobox.com>
1854
1855         * gst/gstminiobject.c (gst_value_mini_object_collect): Use
1856         gst_value_set_mini_object so as to add a ref on the object (which
1857         will be removed when the value is unset).
1858
1859         * gst/elements/gstfakesink.c (gst_fakesink_class_init): Fix signal
1860         arg type in ::handoff.
1861
1862         * gst/gstelement.c (gst_element_change_state): Also deactivate
1863         pads in READY->NULL, just in case the element didn't make it to
1864         PAUSED. Wingo tested, Wim approved.
1865
1866 2005-05-26  Wim Taymans  <wim@fluendo.com>
1867
1868         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
1869         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_alloc_buffer),
1870         (gst_pad_query), (gst_pad_send_event), (gst_pad_start_task):
1871         A flushing pad cannot be used to alloc_buffer from.
1872
1873 2005-05-26  Wim Taymans  <wim@fluendo.com>
1874
1875         * gst/gstbus.c: (gst_bus_init), (gst_bus_dispose), (gst_bus_post),
1876         (gst_bus_pop), (gst_bus_source_prepare), (gst_bus_source_check),
1877         (gst_bus_source_dispatch), (gst_bus_source_finalize),
1878         (gst_bus_create_watch), (gst_bus_add_watch_full):
1879         * gst/gstbus.h:
1880         Implement a real GSource and use g_main_context_wakeup() to
1881         signal new messages instead of the socketpair.
1882
1883 2005-05-25  Wim Taymans  <wim@fluendo.com>
1884
1885         * gst/gstbin.c: (bin_element_is_sink), (has_ancestor),
1886         (bin_element_is_semi_sink), (append_child), (gst_bin_change_state):
1887         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
1888         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_query),
1889         (gst_pad_send_event), (gst_pad_start_task):
1890         * gst/gstqueue.c: (gst_queue_init), (gst_queue_locked_flush),
1891         (gst_queue_handle_sink_event), (gst_queue_chain), (gst_queue_loop),
1892         (gst_queue_sink_activate), (gst_queue_src_activate),
1893         (gst_queue_change_state):
1894         * gst/gstqueue.h:
1895         Fix state changes for non sinks. We now change sinks, then elements
1896         with unconnected srcpads, then the rest.
1897         More efficient queue unlocking in flush and state changes.
1898         Set the pad activate mode even if it does not have an activate
1899         function.
1900
1901 2005-05-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1902
1903         * gst/base/gstbasesrc.c: (gst_basesrc_activate):
1904           Don't go in pull mode for non-seekable sources.
1905         * gst/elements/gsttypefindelement.h:
1906         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
1907         (gst_type_find_element_dispose), (gst_type_find_handle_src_query),
1908         (free_entry), (stop_typefinding),
1909         (gst_type_find_element_handle_event), (find_peek),
1910         (gst_type_find_element_chain), (do_pull_typefind),
1911         (gst_type_find_element_change_state):
1912           Allow typefinding (w/o seeking) in push-mode, simplified version
1913           of what was in 0.8.
1914         * gst/gstutils.c: (gst_buffer_join):
1915         * gst/gstutils.h:
1916           gst_buffer_join() from 0.8.
1917
1918 2005-05-25  Wim Taymans  <wim@fluendo.com>
1919
1920         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
1921         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_query),
1922         (gst_pad_send_event), (gst_pad_start_task):
1923         Disable attempt at mode switching until it is figured out.
1924
1925 2005-05-25  Wim Taymans  <wim@fluendo.com>
1926
1927         * gst/base/gstadapter.c: (gst_adapter_peek), (gst_adapter_flush):
1928         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_push),
1929         (gst_basesink_finish_preroll), (gst_basesink_chain),
1930         (gst_basesink_loop), (gst_basesink_activate),
1931         (gst_basesink_change_state):
1932         * gst/base/gstbasesrc.c: (gst_basesrc_do_seek),
1933         (gst_basesrc_get_range), (gst_basesrc_loop),
1934         (gst_basesrc_activate):
1935         * gst/elements/gsttee.c: (gst_tee_sink_activate):
1936         * gst/gstpad.c: (gst_pad_dispose), (gst_real_pad_class_init),
1937         (gst_real_pad_init), (gst_real_pad_set_property),
1938         (gst_real_pad_get_property), (gst_pad_set_active),
1939         (gst_pad_is_active), (gst_pad_get_query_types), (gst_pad_unlink),
1940         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_get_real_parent),
1941         (gst_real_pad_get_caps_unlocked), (gst_pad_peer_get_caps),
1942         (gst_pad_accept_caps), (gst_pad_get_peer), (gst_pad_realize),
1943         (gst_pad_event_default_dispatch), (gst_pad_event_default),
1944         (gst_pad_dispatcher), (gst_pad_query), (gst_real_pad_dispose),
1945         (gst_pad_save_thyself), (handle_pad_block), (gst_pad_chain),
1946         (gst_pad_push), (gst_pad_get_range), (gst_pad_pull_range),
1947         (gst_pad_send_event), (gst_pad_start_task), (gst_pad_pause_task),
1948         (gst_pad_stop_task):
1949         * gst/gstpad.h:
1950         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
1951         (gst_queue_loop), (gst_queue_src_activate):
1952         * gst/gsttask.c: (gst_task_init), (gst_task_set_lock),
1953         (gst_task_get_state):
1954         * gst/gsttask.h:
1955         * gst/schedulers/threadscheduler.c:
1956         (gst_thread_scheduler_task_start), (gst_thread_scheduler_func):
1957         Implement gst_pad_pause/start/stop_task(), take STREAM lock
1958         in task function.
1959         Remove ACTIVE pad flag, use FLUSHING everywhere
1960         Added _pad_chain(), _pad_get_range() to call chain/getrange 
1961         functions.
1962         Add locks around IS_FLUSHING when reading.
1963         Take STREAM lock in chain(), get_range() functions so plugins
1964         don't need to take it anymore.
1965         
1966
1967
1968 2005-05-25  Wim Taymans  <wim@fluendo.com>
1969
1970         * tools/gst-launch.c: (event_loop):
1971         Unref message after using its contents instead of
1972         before.
1973
1974 2005-05-24  Wim Taymans  <wim@fluendo.com>
1975
1976         * docs/design/draft-ghostpads.txt:
1977         * docs/design/draft-push-pull.txt:
1978         * docs/design/draft-query.txt:
1979         * docs/design/part-overview.txt:
1980         Docs updates, added general overview doc.
1981
1982 2005-05-21  David Schleef  <ds@schleef.org>
1983
1984         * docs/gst/tmpl/old/GstBin.sgml:
1985         * docs/gst/tmpl/old/GstBuffer.sgml:
1986         * docs/gst/tmpl/old/GstCaps.sgml:
1987         * docs/gst/tmpl/old/GstClock.sgml:
1988         * docs/gst/tmpl/old/GstCompat.sgml:
1989         * docs/gst/tmpl/old/GstData.sgml:
1990         * docs/gst/tmpl/old/GstElement.sgml:
1991         * docs/gst/tmpl/old/GstEvent.sgml:
1992         * docs/gst/tmpl/old/GstIndex.sgml:
1993         * docs/gst/tmpl/old/GstStructure.sgml:
1994         * docs/gst/tmpl/old/GstTag.sgml:
1995         * docs/gst/tmpl/old/cothreads.sgml:
1996         * docs/gst/tmpl/old/cothreads_compat.sgml:
1997         * docs/gst/tmpl/old/gettext.sgml:
1998         * docs/gst/tmpl/old/gobject2gtk.sgml:
1999         * docs/gst/tmpl/old/grammar.tab.sgml:
2000         * docs/gst/tmpl/old/gst-i18n-app.sgml:
2001         * docs/gst/tmpl/old/gst-i18n-lib.sgml:
2002         * docs/gst/tmpl/old/gst_private.sgml:
2003         * docs/gst/tmpl/old/gstaggregator.sgml:
2004         * docs/gst/tmpl/old/gstarch.sgml:
2005         * docs/gst/tmpl/old/gstatomic_impl.sgml:
2006         * docs/gst/tmpl/old/gstbufferstore.sgml:
2007         * docs/gst/tmpl/old/gstdata_private.sgml:
2008         * docs/gst/tmpl/old/gstdisksink.sgml:
2009         * docs/gst/tmpl/old/gstdisksrc.sgml:
2010         * docs/gst/tmpl/old/gstelementfactory.sgml:
2011         * docs/gst/tmpl/old/gstextratypes.sgml:
2012         * docs/gst/tmpl/old/gstfakesink.sgml:
2013         * docs/gst/tmpl/old/gstfakesrc.sgml:
2014         * docs/gst/tmpl/old/gstfdsink.sgml:
2015         * docs/gst/tmpl/old/gstfdsrc.sgml:
2016         * docs/gst/tmpl/old/gstfilesink.sgml:
2017         * docs/gst/tmpl/old/gstfilesrc.sgml:
2018         * docs/gst/tmpl/old/gsthttpsrc.sgml:
2019         * docs/gst/tmpl/old/gstidentity.sgml:
2020         * docs/gst/tmpl/old/gstindexfactory.sgml:
2021         * docs/gst/tmpl/old/gstmarshal.sgml:
2022         * docs/gst/tmpl/old/gstmd5sink.sgml:
2023         * docs/gst/tmpl/old/gstmultidisksrc.sgml:
2024         * docs/gst/tmpl/old/gstmultifilesrc.sgml:
2025         * docs/gst/tmpl/old/gstpadtemplate.sgml:
2026         * docs/gst/tmpl/old/gstpipefilter.sgml:
2027         * docs/gst/tmpl/old/gstschedulerfactory.sgml:
2028         * docs/gst/tmpl/old/gstsearchfuncs.sgml:
2029         * docs/gst/tmpl/old/gstshaper.sgml:
2030         * docs/gst/tmpl/old/gstspider.sgml:
2031         * docs/gst/tmpl/old/gstspideridentity.sgml:
2032         * docs/gst/tmpl/old/gststatistics.sgml:
2033         * docs/gst/tmpl/old/gsttee.sgml:
2034         * docs/gst/tmpl/old/gsttimecache.sgml:
2035         * docs/gst/tmpl/old/gsttypefindfactory.sgml:
2036         * docs/gst/tmpl/old/gstxmlregistry.sgml:
2037         * docs/gst/tmpl/old/gthread-cothreads.sgml:
2038         * docs/gst/tmpl/old/types.sgml:
2039           I didn't intend to add these or check them in.
2040
2041 2005-05-19  David Schleef  <ds@schleef.org>
2042
2043         * configure.ac: Use -no-common everywhere.  In a sane world, it
2044           would be the default in libtool, because without it, you can't
2045           build DLLs on Windows.
2046         * docs/gst/gstreamer-docs.sgml: Remove GstCpu, GstData, GstThread
2047         * docs/gst/gstreamer-sections.txt:
2048         * docs/gst/tmpl/gstcpu.sgml:
2049         * docs/gst/tmpl/gstdata.sgml:
2050         * docs/gst/tmpl/gstthread.sgml:
2051
2052 2005-05-19  David Schleef  <ds@schleef.org>
2053
2054         * gst/gstminiobject.c: (gst_value_set_mini_object),
2055         (gst_value_take_mini_object), (gst_value_get_mini_object):
2056         * gst/gstminiobject.h: Add GValue set/get functions.
2057
2058 2005-05-19  Wim Taymans  <wim@fluendo.com>
2059
2060         * gst/gstbuffer.c: (gst_buffer_init), (gst_subbuffer_get_type),
2061         (gst_subbuffer_class_init), (gst_subbuffer_finalize),
2062         (gst_subbuffer_init), (gst_buffer_is_span_fast):
2063         * gst/gstbuffer.h:
2064         * gst/gstbus.c: (gst_bus_post):
2065         * gst/gstelement.c: (gst_element_get_random_pad):
2066         * gst/gstmessage.c: (gst_message_init), (gst_message_finalize):
2067         Make subbufer unref the parent in finalize.
2068         some more debugging info.
2069
2070
2071 2005-05-19  Wim Taymans  <wim@fluendo.com>
2072
2073         * gst/base/gstbasesink.c: (gst_basesink_class_init),
2074         (gst_basesink_init), (gst_basesink_finalize),
2075         (gst_basesink_activate), (gst_basesink_change_state):
2076         Don't free preroll queue too early.
2077
2078 2005-05-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2079
2080         * gst/Makefile.am:
2081         * gst/ROADMAP:
2082           Hi, I'm outdated. Please shoot me.
2083
2084 2005-05-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2085
2086         * gst/gstpipeline.c: (gst_pipeline_send_event):
2087           Do not access variables after they have been deleted.
2088
2089 2005-05-19  Wim Taymans  <wim@fluendo.com>
2090
2091         * tools/gst-inspect.c: (print_plugin_features):
2092         A plugin feature does unfortunatly not use the
2093         object name yet...
2094
2095 2005-05-18  Wim Taymans  <wim@fluendo.com>
2096
2097         * gst/gstbuffer.c: (gst_buffer_is_span_fast), (gst_buffer_span):
2098         Port _span() functions to new subbuffers.
2099
2100 2005-05-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2101
2102         * gst/gstbin.c: (gst_bin_add_func):
2103           Fix clock settery in bins when adding kids after the clock has
2104           been selected.
2105
2106 2005-05-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2107
2108         * gst/elements/gstidentity.c: (gst_identity_class_init):
2109           Workaround until signals support GstMiniObject.
2110
2111 2005-05-18  Jan Schmidt  <thaytan@mad.scientist.com>
2112
2113         * gst/gstbuffer.c:
2114         Oops, fix a typo GST_TYPE_BUFFER -> GST_TYPE_SUBBUFFER.
2115
2116 2005-05-18  Wim Taymans  <wim@fluendo.com>
2117
2118         * gst/base/Makefile.am:
2119         * gst/base/gstadapter.c: (gst_adapter_base_init),
2120         (gst_adapter_class_init), (gst_adapter_init),
2121         (gst_adapter_dispose), (gst_adapter_finalize), (gst_adapter_new),
2122         (gst_adapter_clear), (gst_adapter_push), (gst_adapter_peek),
2123         (gst_adapter_flush), (gst_adapter_available),
2124         (gst_adapter_available_fast):
2125         * gst/base/gstadapter.h:
2126         Ported and added adapter to the base classes.
2127
2128 2005-05-17  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
2129
2130         * gst/gst.c:
2131         * gst/gstmessage.c:
2132           Make sure the class is reffed/unreffed once before threads can be
2133           used.  Fixes #304551.
2134
2135 2005-05-17  Wim Taymans  <wim@fluendo.com>
2136
2137         * gst/base/gstbasesink.c: (gst_basesink_finish_preroll),
2138         (gst_basesink_chain_unlocked), (gst_basesink_activate):
2139         * gst/gstminiobject.c: (gst_mini_object_get_type),
2140         (gst_mini_object_free):
2141         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_query),
2142         (gst_pad_push), (gst_pad_push_event):
2143         * gst/gstqueue.c: (gst_queue_change_state):
2144         Don't queue buffers in basesink when we are flushing.
2145         Unref buffer when flushing in basesink.
2146         Flush queue when going to READY
2147         Unref buffer when _push() returns an error.
2148         Don't free MiniObject instance when refcount is incremented
2149         in _finalize() so that we can recover objects.
2150
2151 2005-05-17  Thomas Vander Stichele  <thomas at apestaart dot org>
2152
2153         * docs/manual/advanced-schedulers.xml:
2154         * docs/manual/appendix-checklist.xml:
2155         * docs/pwg/advanced-clock.xml:
2156         * docs/pwg/advanced-interfaces.xml:
2157         * docs/pwg/advanced-request.xml:
2158         * docs/pwg/advanced-types.xml:
2159         * docs/pwg/intro-preface.xml:
2160         * examples/plugins/example.c: (gst_example_get_type),
2161         (gst_example_class_init), (gst_example_chain),
2162         (gst_example_set_property), (gst_example_get_property),
2163         (gst_example_change_state), (plugin_init):
2164         * examples/plugins/example.h:
2165           small doc fixes
2166
2167 2005-05-17  Wim Taymans  <wim@fluendo.com>
2168
2169         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_set_caps),
2170         (gst_pad_alloc_buffer), (gst_pad_query), (gst_pad_push):
2171         * gst/gstqueue.c: (gst_queue_change_state):
2172         Clear queue when going to READY.
2173         Remove IN_SETCAPS flag too.
2174
2175 2005-05-17  Tim-Philipp Müller  <tim at centricular dot net>
2176
2177         * gst/base/gstbasesrc.c: (gst_basesrc_change_state):
2178           Remove implicit cast from gboolean to GstElementStateReturn;
2179           make sure we still return failure in paused => ready case if
2180           the parent class fails to change state and our own stop 
2181           vfunc succeeds.
2182
2183 2005-05-17  Wim Taymans  <wim@fluendo.com>
2184
2185         * tools/gst-launch.c: (event_loop):
2186         Message was unreffed too soon.
2187
2188 2005-05-16  Andy Wingo  <wingo@pobox.com>
2189
2190         * gst/gstbin.c (sink_iterator_filter): Err... um...
2191
2192         * check/gst/gstbin.c (test_ghost_pads): New test for the
2193         ghosting-if-elements-not-in-same-bin behavior.
2194
2195 2005-05-16  David Schleef  <ds@schleef.org>
2196
2197         * gst/gstminiobject.c: Use g_atomic_int_get() instead of
2198         accessing refcount directly.
2199
2200 2005-05-15  David Schleef  <ds@schleef.org>
2201
2202         * check/Makefile.am: remove GstData checks
2203         * check/gst-libs/gdp.c: (START_TEST): fix for API changes
2204         * gst/Makefile.am: add miniobject, remove data
2205         * gst/gst.h: add miniobject, remove data
2206         * gst/gstdata.c: remove
2207         * gst/gstdata.h: remove
2208         * gst/gstdata_private.h: remove
2209         * gst/gsttypes.h: remove GstEvent and GstMessage
2210         * gst/gstelement.c: (gst_element_post_message): fix for API changes
2211         * gst/gstmarshal.list: change BOXED -> OBJECT
2212
2213         Implement GstMiniObject.
2214         * gst/gstminiobject.c:
2215         * gst/gstminiobject.h:
2216
2217         Modify to be subclasses of GstMiniObject.
2218         * gst/gstbuffer.c: (_gst_buffer_initialize), (gst_buffer_get_type),
2219         (gst_buffer_class_init), (gst_buffer_finalize), (_gst_buffer_copy),
2220         (gst_buffer_init), (gst_buffer_new), (gst_buffer_new_and_alloc),
2221         (gst_subbuffer_get_type), (gst_subbuffer_init),
2222         (gst_buffer_create_sub), (gst_buffer_is_span_fast),
2223         (gst_buffer_span):
2224         * gst/gstbuffer.h:
2225         * gst/gstevent.c: (_gst_event_initialize), (gst_event_get_type),
2226         (gst_event_class_init), (gst_event_init), (gst_event_finalize),
2227         (_gst_event_copy), (gst_event_new):
2228         * gst/gstevent.h:
2229         * gst/gstmessage.c: (_gst_message_initialize),
2230         (gst_message_get_type), (gst_message_class_init),
2231         (gst_message_init), (gst_message_finalize), (_gst_message_copy),
2232         (gst_message_new), (gst_message_new_error),
2233         (gst_message_new_warning), (gst_message_new_tag),
2234         (gst_message_new_state_changed), (gst_message_new_application):
2235         * gst/gstmessage.h:
2236         * gst/gstprobe.c: (gst_probe_perform),
2237         (gst_probe_dispatcher_dispatch):
2238         * gst/gstprobe.h:
2239         * gst/gstquery.c: (_gst_query_initialize), (gst_query_get_type),
2240         (gst_query_class_init), (gst_query_finalize), (gst_query_init),
2241         (_gst_query_copy), (gst_query_new):
2242
2243         Update elements for GstData -> GstMiniObject changes
2244         * gst/gstquery.h:
2245         * gst/gstqueue.c: (gst_queue_finalize), (gst_queue_locked_flush),
2246         (gst_queue_chain), (gst_queue_loop):
2247         * gst/elements/gstbufferstore.c:
2248         (gst_buffer_store_add_buffer_func),
2249         (gst_buffer_store_cleared_func), (gst_buffer_store_get_buffer):
2250         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
2251         (gst_fakesink_render):
2252         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
2253         * gst/elements/gstfilesrc.c: (gst_mmap_buffer_get_type),
2254         (gst_mmap_buffer_class_init), (gst_mmap_buffer_init),
2255         (gst_mmap_buffer_finalize), (gst_filesrc_map_region),
2256         (gst_filesrc_create_read):
2257         * gst/elements/gstidentity.c: (gst_identity_class_init):
2258         * gst/elements/gsttypefindelement.c:
2259         (gst_type_find_element_src_event), (free_entry_buffers),
2260         (gst_type_find_element_handle_event):
2261         * libs/gst/dataprotocol/dataprotocol.c:
2262         (gst_dp_header_from_buffer):
2263         * libs/gst/dataprotocol/dataprotocol.h:
2264         * libs/gst/dataprotocol/dp-private.h:
2265
2266 2005-05-15  David Schleef  <ds@schleef.org>
2267
2268         * gst/elements/gstelements.c: Don't include headers that were
2269         just removed.
2270
2271 2005-05-15  David Schleef  <ds@schleef.org>
2272
2273         * gst/elements/Makefile.am: Remove some elements that don't
2274         need to be in the core (or even exist at all).
2275         * gst/elements/gstaggregator.c:
2276         * gst/elements/gstaggregator.h:
2277         * gst/elements/gstmd5sink.c:
2278         * gst/elements/gstmd5sink.h:
2279         * gst/elements/gstmultifilesrc.c:
2280         * gst/elements/gstmultifilesrc.h:
2281         * gst/elements/gstpipefilter.c:
2282         * gst/elements/gstpipefilter.h:
2283         * gst/elements/gstshaper.c:
2284         * gst/elements/gstshaper.h:
2285         * gst/elements/gststatistics.c:
2286         * gst/elements/gststatistics.h:
2287         * po/POTFILES.in: Remove above files.
2288
2289 2005-05-14  Andy Wingo  <wingo@pobox.com>
2290
2291         * gst/gstbin.c (gst_bin_iterate_sinks): Use sink_iterator_filter
2292         so as to get the refs right.
2293         (sink_iterator_filter): New function, wraps bin_element_is_sink,
2294         unreffing objects that don't pass the filter.
2295
2296         * gst/gstpipeline.c (gst_pipeline_init): Drop ref on bus after
2297         gst_element_set_bus.
2298         (gst_pipeline_dispose): Set the bus on the pipeline to NULL. In
2299         normal cases, this will destroy the bus.
2300
2301         * gst/gstutils.c (prepare_link_maybe_ghosting): Drop ref on root
2302         object.
2303
2304         * gst/gstbin.c (gst_bin_change_state): Fix state changes if a bin
2305         has no sinks.
2306
2307 2005-05-13  Andy Wingo  <wingo@pobox.com>
2308
2309         * gst/gstutils.c (gst_element_link_pads): Instead of calling
2310         gst_pad_link, call pad_link_maybe_ghosting,
2311         (pad_link_maybe_ghosting): Links pads, making sure that the
2312         elements being linked are in the same bin.
2313         (find_common_root, object_has_ancestor, ghost_up, remove_pad):
2314         Helpers for pad_link_maybe_ghosting.
2315
2316 2005-05-13  Tim-Philipp Müller  <tim at centricular dot net>
2317
2318         * configure.ac:
2319           Require GLib >= 2.4.0 (for the g_atomic_* funcs)
2320
2321 2005-05-13  Tim-Philipp Müller  <tim at centricular dot net>
2322
2323         * docs/design/part-element-source.txt:
2324           Mention GstPushSrc
2325
2326 2005-05-12  Wim Taymans  <wim@fluendo.com>
2327
2328         * gst/base/gstbasesink.c: (gst_basesink_init),
2329         (gst_basesink_activate):
2330         * gst/base/gstbasesrc.c: (gst_basesrc_unlock),
2331         (gst_basesrc_is_seekable):
2332         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_remove_func),
2333         (bin_element_is_sink), (gst_bin_change_state):
2334         * gst/gstelement.c: (gst_element_add_pad), (gst_element_query):
2335         * gst/gstelement.h:
2336         Identify sinks by their flag to avoid overly complicated
2337         checks (fow now).
2338         Do state changes even for elements not reachable from the
2339         sinks.
2340         BaseSink is a sink now :)
2341         Some more debugging info in the basesrc.
2342
2343
2344 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2345
2346         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_query):
2347           Implement _query on a bin, similar to _send_event.
2348
2349 2005-05-12  Tim-Philipp Müller  <tim at centricular dot net>
2350
2351         * gst/base/gstbasesrc.c: (gst_basesrc_do_seek):
2352           Discont event offset format should be GST_FORMAT_BYTES,
2353           not GST_FORMAT_TIME.
2354
2355 2005-05-12  Wim Taymans  <wim@fluendo.com>
2356
2357         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_get_state):
2358         Same fix as Ronald's but without the signal. 
2359
2360 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2361
2362         * gst/gstutils.c: (gst_element_query_position):
2363           No, an element is not a pad.
2364
2365 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2366
2367         * gst/gstbin.c: (gst_bin_add_func), (cb_parent_unset),
2368         (gst_bin_get_state):
2369           If a child is removed from a bin while we remove the child from
2370           the bin and while we're retrieving its state, signal this to the
2371           get_state function so we abort the wait (instead of waiting for
2372           a timeout) and can immediately re-iterate over all other elements.
2373
2374 2005-05-12  Wim Taymans  <wim@fluendo.com>
2375
2376         * gst/base/Makefile.am:
2377         * gst/base/gstbasesrc.c: (gst_basesrc_is_seekable),
2378         (gst_basesrc_start):
2379         * gst/base/gstbasesrc.h:
2380         * gst/base/gstpushsrc.c: (gst_pushsrc_get_type),
2381         (gst_pushsrc_base_init), (gst_pushsrc_class_init),
2382         (gst_pushsrc_init), (gst_pushsrc_create):
2383         * gst/base/gstpushsrc.h:
2384         Added is_seekable to BaseSrc
2385         Added simple PushSrc.
2386
2387 2005-05-11  Wim Taymans  <wim@fluendo.com>
2388
2389         * gst/gstelement.c: (gst_element_add_pad), (gst_element_query):
2390         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
2391         (gst_element_link_pads), (gst_element_query_position),
2392         (gst_element_query_convert), (intersect_caps_func),
2393         (gst_pad_query_position), (gst_pad_query_convert):
2394         Fix refcounting in utils function.
2395         No point in trying to activate a pad when it's added, it could
2396         be added from the state change function and then we deadlock, the
2397         element has to decide what to do.
2398
2399 2005-05-10  Andy Wingo  <wingo@pobox.com>
2400
2401         * gst/elements/gstfakesink.c (gst_fakesink_render): Er, emit with
2402         *all* the arguments.
2403
2404         * gst/base/gstbasetransform.c (gst_base_transform_event): Grab the
2405         stream lock if it's a FLUSH_DONE; normal flushes don't get the
2406         lock (according to the docs -- if this is wrong change the docs).
2407
2408         * gst/gstpipeline.c (gst_pipeline_change_state): Set the bus to
2409         flush messages in the NULL state.
2410
2411         * gst/gstbus.c (gst_bus_post): If a bus is flushing, unref the
2412         message immediately and return.
2413         (gst_bus_set_flushing): New function. If a bus is flushing, it
2414         flushes out any queued messages and immediately unrefs new
2415         messages. This is so when an element goes to NULL, all of the
2416         unhandled messages coming from it can be freed, and their
2417         references to the element dropped. In other words: message source
2418         ref considered harmful :P
2419
2420         * gst/gstbin.c (gst_bin_change_state): Unref peer element when
2421         we're finished with it.
2422
2423         * gst/gstmessage.c (gst_message_new_state_changed): 
2424
2425 2005-05-10  Wim Taymans  <wim@fluendo.com>
2426
2427         * gst/gstvalue.c: (gst_value_compare_flags),
2428         (gst_value_serialize_flags), (gst_value_deserialize_flags),
2429         (_gst_value_initialize):
2430         Added flags serialize/deserialize/compare code.
2431
2432 2005-05-09  Andy Wingo  <wingo@pobox.com>
2433
2434         * gst/base/gstbasetransform.c (gst_base_transform_proxy_getcaps):
2435         Intersect the peer's caps with our caps.
2436
2437 2005-05-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2438
2439         * gst/base/gsttypefindhelper.c: (helper_find_peek):
2440         * gst/elements/gsttypefindelement.c: (find_peek):
2441           Handle negative offsets better. Fixes decodebin.
2442
2443 2005-05-09  Wim Taymans  <wim@fluendo.com>
2444
2445         * gst/base/gstbasetransform.c: (gst_base_transform_proxy_getcaps),
2446         (gst_base_transform_event):
2447         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_query):
2448         Implement accept_caps.
2449         Fix silly lock/unlock mismatch in base class.
2450
2451 2005-05-09  Wim Taymans  <wim@fluendo.com>
2452
2453         * docs/design/draft-push-pull.txt:
2454         * gst/base/gstbasesrc.c: (gst_basesrc_init), (gst_basesrc_query):
2455         * gst/elements/gstfilesink.c: (gst_filesink_init),
2456         (gst_filesink_query):
2457         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
2458         (gst_type_find_handle_src_query), (find_element_get_length):
2459         * gst/gstelement.c: (gst_element_seek), (gst_element_query):
2460         * gst/gstelement.h:
2461         * gst/gstmessage.c:
2462         * gst/gstmessage.h:
2463         * gst/gstpad.c: (gst_real_pad_init), (gst_pad_get_query_types),
2464         (gst_real_pad_get_caps_unlocked),
2465         (gst_pad_get_internal_links_default), (gst_pad_get_internal_links),
2466         (gst_pad_event_default_dispatch), (gst_pad_event_default),
2467         (gst_pad_dispatcher), (gst_pad_query), (gst_pad_query_default),
2468         (gst_real_pad_dispose), (gst_real_pad_finalize),
2469         (gst_pad_load_and_link), (gst_pad_save_thyself),
2470         (gst_ghost_pad_save_thyself), (handle_pad_block), (gst_pad_push),
2471         (gst_pad_check_pull_range), (gst_pad_pull_range),
2472         (gst_pad_template_get_type), (gst_pad_template_class_init),
2473         (gst_pad_template_init), (gst_pad_template_dispose),
2474         (name_is_valid), (gst_static_pad_template_get),
2475         (gst_pad_template_new), (gst_static_pad_template_get_caps),
2476         (gst_pad_template_get_caps), (gst_pad_set_element_private),
2477         (gst_pad_get_element_private), (gst_pad_start_task),
2478         (gst_pad_pause_task), (gst_pad_stop_task),
2479         (gst_ghost_pad_get_type), (gst_ghost_pad_class_init),
2480         (gst_ghost_pad_init), (gst_ghost_pad_dispose),
2481         (gst_ghost_pad_set_property), (gst_ghost_pad_get_property),
2482         (gst_ghost_pad_new):
2483         * gst/gstpad.h:
2484         * gst/gstquery.c: (_gst_query_initialize), (gst_query_new),
2485         (gst_query_new_position), (gst_query_set_position),
2486         (gst_query_parse_position), (gst_query_new_convert),
2487         (gst_query_set_convert), (gst_query_parse_convert):
2488         * gst/gstquery.h:
2489         * gst/gstqueryutils.c:
2490         * gst/gstqueryutils.h:
2491         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
2492         (gst_queue_bufferalloc), (gst_queue_handle_sink_event),
2493         (gst_queue_handle_src_query):
2494         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
2495         (gst_element_query_position), (gst_element_query_convert),
2496         (intersect_caps_func), (gst_pad_query_position),
2497         (gst_pad_query_convert):
2498         * gst/gstutils.h:
2499         * tools/gst-inspect.c: (print_pad_info):
2500         * tools/gst-xmlinspect.c: (print_element_info):
2501         Remove old query functions. Ported old code.
2502         Added position/convert helper functions to gstutils.
2503         Reordered gstpad.c code, grouping relevant things.
2504         Remove gst_message_new(), always need to speficy a specific
2505         message.
2506
2507
2508 2005-05-09  Andy Wingo  <wingo@pobox.com>
2509
2510         * gst/gstiterator.h: Add some includes.
2511
2512         * gst/gstqueryutils.h: Include more headers.
2513
2514         * gst/gstpad.h:
2515         * gst/gstpad.c (gst_pad_query_position): New routine, replaces
2516         some uses of gst_pad_query.
2517
2518         * gst/gstqueryutils.c: Build fixes. Make parse functions ignore
2519         NULL out parameters.
2520         (gst_query_new_position): New proc, allocates a new position
2521         query.
2522
2523         * gst/Makefile.am (libgstreamer_@GST_MAJORMINOR@_la_SOURCES): Add
2524         gstqueryutils.c to the build.
2525
2526         * gst/gststructure.c (gst_structure_set_valist): Implement with
2527         the generic G_VALUE_COLLECT.
2528         
2529 2005-05-08  Edward Hervey  <bilboed@bilboed.com>
2530
2531         * gst/Makefile.am: (gst_headers):
2532         Added gstqueryutils.h to the list of headers to install, that was
2533         a 'nachty' move wingo :)
2534
2535 2005-05-06  Andy Wingo  <wingo@pobox.com>
2536
2537         * gst/gstquery.h
2538         * gst/gstquery.c (_gst_query_initialize): Extend GstQuery from
2539         GstData, init a memchunk.
2540         (standard_definitions): Add a few query types, deprecate a few.
2541         (gst_query_get_type): New proc.
2542         (_gst_query_copy, _gst_query_free, gst_query_new): GstData
2543         implementation.
2544         (gst_query_new_application, gst_query_get_structure): New public
2545         procs.
2546
2547         * docs/design/draft-query.txt: Removed LINKS from the query types,
2548         because all the rest can be dispatched to other pads -- seemed
2549         ugly to have a query that couldn't be dispatched. internal_links
2550         is fine as a pad method.
2551
2552         * gst/gstpad.h: Add query2 as a pad method, add the new functions
2553         in gstpad.c, but maintain binary compatibility for the moment.
2554         Will fix before 0.9 is out.
2555
2556         * gst/gstqueryutils.c: 
2557         * gst/gstqueryutils.h: New files, implement 3 methods for each
2558         query type: parse_query, parse_response, and set. Probably need an
2559         allocator as well.
2560
2561         * gst/gst.h: Add gstquery.h and gstqueryutils.h to the list.
2562
2563         * gst/elements/gstfilesink.c (gst_filesink_query2):
2564         * gst/base/gstbasesrc.c (gst_basesrc_query2): Replace old query,
2565         query_types, and formats methods.
2566
2567         * gst/gstpad.c (gst_pad_query2, gst_pad_query2_default)
2568         (gst_pad_set_query2_function): New functions.
2569         (gst_real_pad_init): Set query2_default as the default query2
2570         function. Basically just dispatches to internally linked pads.
2571
2572         Needs review!
2573         
2574         * gst/gstdata_private.h (_GST_DATA_INIT): Set data->refcount to 1
2575         without using the atomic operations. Only one thread can possibly
2576         be accessing the data at this point. Changed so as to avoid
2577         gst_atomic operations.
2578
2579 2005-05-06  Wim Taymans  <wim@fluendo.com>
2580
2581         * gst/gstpad.c: (gst_pad_alloc_buffer), (gst_pad_push):
2582         Also set caps if we use the fallback buffer alloc.
2583
2584 2005-05-06  Tim-Philipp Müller  <tim at centricular dot net>
2585
2586         * docs/gst/Makefile.am:
2587         * docs/gst/gstreamer-docs.sgml:
2588         * docs/gst/gstreamer-sections.txt:
2589         * docs/gst/tmpl/gstatomic.sgml:
2590         * docs/gst/tmpl/gstmemchunk.sgml:
2591         * testsuite/elements/struct_i386.h:
2592         * win32/GStreamer.vcproj:
2593         * win32/Makefile:
2594           Purge GstAtomic stuff from docs and win32 makefiles as well
2595
2596 2005-05-06  Wim Taymans  <wim@fluendo.com>
2597
2598         * gst/base/gstbasetransform.c: (gst_base_transform_proxy_getcaps):
2599         * gst/elements/gstcapsfilter.c: (gst_capsfilter_getcaps):
2600         * gst/gstpad.c: (gst_pad_peer_get_caps):
2601         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
2602         (gst_queue_bufferalloc), (gst_queue_handle_sink_event),
2603         (gst_queue_src_activate), (gst_queue_change_state):
2604         * gst/gstqueue.h:
2605         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
2606         (intersect_caps_func):
2607         Fix gst_pad_peer_get_caps(), make it return NULL if no peer.
2608         Always take QUEUE_LOCK after STREAM_LOCK or we might deadlock.
2609         Some fixes for the peer_get_caps() change.
2610
2611 2005-05-06  Wim Taymans  <wim@fluendo.com>
2612
2613         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
2614         (gst_basesink_handle_buffer), (gst_basesink_chain_unlocked),
2615         (gst_basesink_activate):
2616         Actually do something with error codes returned from the push
2617         functions.
2618
2619 2005-05-06  Wim Taymans  <wim@fluendo.com>
2620
2621         * docs/design/part-element-sink.txt:
2622         * docs/design/part-element-source.txt:
2623         * gst/base/gstbasesink.c: (gst_basesink_class_init),
2624         (gst_basesink_event), (gst_basesink_activate):
2625         * gst/base/gstbasesink.h:
2626         * gst/base/gstbasesrc.c: (gst_basesrc_init), (gst_basesrc_unlock),
2627         (gst_basesrc_activate):
2628         * gst/base/gstbasesrc.h:
2629         * gst/gstelement.c: (gst_element_pads_activate):
2630         Some more documentation.
2631         Fixed scheduling decision in _pads_activate().
2632
2633 2005-05-05  Andy Wingo  <wingo@pobox.com>
2634
2635         * check/pipelines/simple_launch_lines.c (test_2_elements): "Fix"
2636         the test suite.
2637
2638 2005-05-05  Wim Taymans  <wim@fluendo.com>
2639
2640         * gst/base/Makefile.am:
2641         * gst/base/gstbasesink.h:
2642         * gst/base/gstbasesrc.c: (gst_basesrc_init),
2643         (gst_basesrc_set_dataflow_funcs), (gst_basesrc_query):
2644         * gst/base/gstcollectpads.c: (gst_collectpads_get_type),
2645         (gst_collectpads_class_init), (gst_collectpads_init),
2646         (gst_collectpads_finalize), (gst_collectpads_new),
2647         (gst_collectpads_set_function), (gst_collectpads_add_pad),
2648         (find_pad), (gst_collectpads_remove_pad),
2649         (gst_collectpads_is_active), (gst_collectpads_collect),
2650         (gst_collectpads_collect_range), (gst_collectpads_start),
2651         (gst_collectpads_stop), (gst_collectpads_peek),
2652         (gst_collectpads_pop), (gst_collectpads_available),
2653         (gst_collectpads_read), (gst_collectpads_flush),
2654         (gst_collectpads_chain):
2655         * gst/base/gstcollectpads.h:
2656         * gst/elements/Makefile.am:
2657         * gst/elements/gstelements.c:
2658         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
2659         (gst_fakesink_get_times), (gst_fakesink_event),
2660         (gst_fakesink_preroll), (gst_fakesink_render):
2661         * gst/elements/gstfilesink.c: (gst_filesink_class_init),
2662         (gst_filesink_init), (gst_filesink_set_location),
2663         (gst_filesink_open_file), (gst_filesink_close_file),
2664         (gst_filesink_pad_query), (gst_filesink_event),
2665         (gst_filesink_render), (gst_filesink_change_state):
2666         * gst/elements/gstfilesink.h:
2667         Added object to help in making collect pad based elements.
2668         Ported filesink.
2669         Make event function in sink baseclass return gboolean.
2670
2671 2005-05-05  Wim Taymans  <wim@fluendo.com>
2672
2673         * gst/gstbin.c: (gst_bin_send_event), (compare_name),
2674         (gst_bin_get_by_name):
2675         * gst/gstbuffer.h:
2676         * gst/gstclock.c: (gst_clock_entry_new), (gst_clock_class_init),
2677         (gst_clock_finalize):
2678         * gst/gstdata.c: (gst_data_replace):
2679         * gst/gstdata.h:
2680         * gst/gstelement.c: (gst_element_request_pad),
2681         (gst_element_pads_activate):
2682         * gst/gstobject.c: (gst_object_init), (gst_object_ref),
2683         (gst_object_unref):
2684         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
2685         (gst_pad_set_checkgetrange_function),
2686         (gst_pad_link_check_compatible_unlocked), (gst_pad_set_caps),
2687         (gst_pad_check_pull_range), (gst_pad_pull_range),
2688         (gst_static_pad_template_get_caps), (gst_pad_start_task),
2689         (gst_pad_pause_task), (gst_pad_stop_task):
2690         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
2691         (gst_element_request_pad), (gst_pad_proxy_getcaps):
2692         Fix name lookup in GstBin.
2693         Added _data_replace() function and _buffer_replace()
2694         Use finalize method to clean up clock.
2695         Fix refcounting on request pads.
2696         Fix pad schedule mode error.
2697         Some more object refcounting debug info,
2698
2699
2700 2005-05-04  Andy Wingo <wingo@pobox.com>
2701
2702         * check/Makefile.am:
2703         * docs/gst/tmpl/gstatomic.sgml:
2704         * docs/gst/tmpl/gstplugin.sgml:
2705         * gst/base/gstbasesink.c: (gst_basesink_activate):
2706         * gst/base/gstbasesrc.c: (gst_basesrc_class_init),
2707         (gst_basesrc_init), (gst_basesrc_set_dataflow_funcs),
2708         (gst_basesrc_query), (gst_basesrc_set_property),
2709         (gst_basesrc_get_property), (gst_basesrc_check_get_range),
2710         (gst_basesrc_activate):
2711         * gst/base/gstbasesrc.h:
2712         * gst/base/gstbasetransform.c: (gst_base_transform_sink_activate),
2713         (gst_base_transform_src_activate):
2714         * gst/elements/gstelements.c:
2715         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
2716         (gst_fakesrc_set_property), (gst_fakesrc_get_property):
2717         * gst/elements/gsttee.c: (gst_tee_sink_activate):
2718         * gst/elements/gsttypefindelement.c: (find_element_get_length),
2719         (gst_type_find_element_checkgetrange),
2720         (gst_type_find_element_activate):
2721         * gst/gstbin.c: (gst_bin_save_thyself), (gst_bin_restore_thyself):
2722         * gst/gstcaps.c: (gst_caps_do_simplify), (gst_caps_save_thyself),
2723         (gst_caps_load_thyself):
2724         * gst/gstelement.c: (gst_element_pads_activate),
2725         (gst_element_save_thyself), (gst_element_restore_thyself):
2726         * gst/gstpad.c: (gst_pad_load_and_link), (gst_pad_save_thyself),
2727         (gst_ghost_pad_save_thyself), (gst_pad_check_pull_range):
2728         * gst/gstpad.h:
2729         * gst/gstxml.c: (gst_xml_write), (gst_xml_parse_doc),
2730         (gst_xml_parse_file), (gst_xml_parse_memory),
2731         (gst_xml_get_element), (gst_xml_make_element):
2732         * gst/indexers/gstfileindex.c: (gst_file_index_load),
2733         (_file_index_id_save_xml), (gst_file_index_commit):
2734         * gst/registries/gstlibxmlregistry.c: (read_string), (read_uint),
2735         (read_enum), (load_pad_template), (load_feature), (load_plugin),
2736         (load_paths):
2737         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_caps),
2738         (gst_dp_packet_from_event), (gst_dp_caps_from_packet):
2739         * tools/gst-complete.c: (main):
2740         * tools/gst-compprep.c: (main):
2741         * tools/gst-inspect.c: (print_element_properties_info):
2742         * tools/gst-launch.c: (xmllaunch_parse_cmdline):
2743         * tools/gst-xmlinspect.c: (print_element_properties):
2744         GCC 4 fixen.
2745         
2746 2005-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
2747
2748         * gst/gstplugin.c: (gst_plugin_check_module),
2749         (gst_plugin_check_file), (gst_plugin_load_file):
2750             apply patch from #172526 to make register work on MacOSX
2751
2752 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
2753
2754         * docs/gst/tmpl/gstconfig.sgml:
2755         * gst/gstconfig.h.in:
2756           move documentation for some symbols.  Add doc for GST_PTR_FORMAT
2757         * testsuite/debug/printf_extension.c: (main):
2758           Do not use GST_PTR_FORMAT on pointers to types with
2759           sizeof < sizeof(gpointer).  Fixes test on 64-bit
2760         * testsuite/elements/property.h:
2761           use correct printf format
2762
2763 2005-05-02  Wim Taymans  <wim@fluendo.com>
2764
2765         * docs/design/draft-push-pull.txt:
2766         * docs/design/draft-query.txt:
2767         * gst/base/gstbasesrc.c: (gst_basesrc_get_range_unlocked),
2768         (gst_basesrc_start):
2769         Added draft for new query API.
2770         Added draft for better selecting scheduling methods.
2771         Make basesrc ignore length if the subclass does not support
2772         it.
2773
2774 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
2775
2776         * gst/Makefile.am:
2777           possible fixes for automake-1.5 - _LIBADD is reserved
2778
2779 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
2780
2781         * docs/faq/Makefile.am:
2782         * docs/manual/Makefile.am:
2783         * docs/manuals.mak:
2784         * docs/pwg/Makefile.am:
2785         * gst/Makefile.am:
2786           possible fixes for automake-1.5
2787
2788 2005-04-28  Wim Taymans  <wim@fluendo.com>
2789
2790         * gst/base/gstbasesink.c: (gst_basesink_base_init),
2791         (gst_basesink_pad_getcaps), (gst_basesink_init),
2792         (gst_basesink_do_sync):
2793         * gst/gstclock.c: (gst_clock_entry_new):
2794         * gst/gstevent.c: (gst_event_discont_get_value):
2795         * gst/gstpipeline.c: (pipeline_bus_handler),
2796         (gst_pipeline_change_state):
2797         * gst/gstsystemclock.c: (gst_system_clock_id_wait_unlocked):
2798         Better debugging of clocking info.
2799         Allow NULL values when getting discont values.
2800
2801 2005-04-27  Wim Taymans  <wim@fluendo.com>
2802
2803         * check/gst/gstobject.c: (START_TEST), (gst_object_suite):
2804         * check/gst/gstpad.c: (gst_pad_suite):
2805         Increase timeout for checks.
2806
2807 2005-04-27  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
2808
2809         * check/Makefile.am:
2810           fix the broken rule for cleanup.  Apparently this rule is
2811           only needed on FC2, so maybe this warrants further autotool
2812           inspection.
2813
2814 2005-04-26  Wim Taymans  <wim@fluendo.com>
2815
2816         * gst/gsttrashstack.h:
2817         Ooohh. a nasty one! After having a failed pop() from the stack,
2818         it's possible that the stack is empty. In that case, don't
2819         follow the NULL pointer.
2820
2821 2005-04-25  Wim Taymans  <wim@fluendo.com>
2822
2823         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
2824         (gst_pad_set_checkgetrange_function),
2825         (gst_pad_link_check_compatible_unlocked), (gst_pad_link_prepare),
2826         (gst_pad_check_pull_range), (gst_pad_pull_range),
2827         (gst_static_pad_template_get_caps), (gst_pad_start_task),
2828         (gst_pad_pause_task), (gst_pad_stop_task):
2829         * gst/gstplugin.c: (gst_plugin_load):
2830         * gst/gstplugin.h:
2831         Remove gst_library_load as it does more harm than good with
2832         the new g_module flags.
2833         Revert bogus caps template check in pad linking, pad caps
2834         are important when linking not the template, which is more
2835         general than the current caps.
2836
2837 2005-04-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2838
2839         * gst/autoplug/.cvsignore:
2840         * gst/autoplug/Makefile.am:
2841         * gst/autoplug/gstsearchfuncs.c:
2842         * gst/autoplug/gstsearchfuncs.h:
2843         * gst/autoplug/gstspider.c:
2844         * gst/autoplug/gstspider.h:
2845         * gst/autoplug/gstspideridentity.c:
2846         * gst/autoplug/gstspideridentity.h:
2847         * gst/autoplug/spidertest.c:
2848           Die, spider, die.
2849
2850 2005-04-25  Wim Taymans  <wim@fluendo.com>
2851
2852         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
2853         (gst_pad_set_checkgetrange_function), (gst_pad_check_pull_range),
2854         (gst_pad_pull_range), (gst_static_pad_template_get_caps),
2855         (gst_pad_start_task), (gst_pad_pause_task), (gst_pad_stop_task):
2856         * gst/gstpad.h:
2857         Added stubs for unimplemented functions. 
2858
2859 2005-04-24  David Schleef  <ds@schleef.org>
2860
2861         * gst/gstpad.h: Disable some unimplemented functions.  Wim,
2862         please fix.
2863
2864 2005-04-24  David Schleef  <ds@schleef.org>
2865
2866         Convert everything from GstAtomicInt to g_atomic_int_*, and
2867         remove gstatomic.
2868         * gst/Makefile.am:
2869         * gst/gstatomic.c:
2870         * gst/gstatomic.h:
2871         * gst/gstatomic_impl.h:
2872         * gst/gstbuffer.c:
2873         * gst/gstcaps.c:
2874         * gst/gstcaps.h:
2875         * gst/gstclock.c:
2876         * gst/gstclock.h:
2877         * gst/gstdata.c:
2878         * gst/gstdata.h:
2879         * gst/gstdata_private.h:
2880         * gst/gstevent.c:
2881         * gst/gstinfo.c:
2882         * gst/gstinfo.h:
2883         * gst/gstmessage.c:
2884         * gst/gstobject.c:
2885         * gst/gstobject.h:
2886         * gst/gststructure.c:
2887         * gst/gststructure.h:
2888         * gst/gstutils.c: Add gst_atomic_int_set() compaitibility function.
2889         * gst/gstutils.h:
2890
2891 2005-04-24  David Schleef  <ds@schleef.org>
2892
2893         * check/gst/gstpad.c: (START_TEST): Oh yeah, it's always nice to
2894         make the regressions tests work.  Remove some code that is no
2895         longer true.
2896         * gst/gstpad.c: (gst_pad_link_check_templates_compatible_unlocked):
2897         Disable warning for pads without templates.
2898
2899 2005-04-24  David Schleef  <ds@schleef.org>
2900
2901         * gst/gstpad.c: Remove handling of filtered caps.  Fix/merge
2902         functions that handle filtered links.
2903         * gst/gstpad.h: Remove 'appfilter' field and prototypes of
2904         removed functions.
2905         * gst/gstutils.c: Fix/remove utility functions that handle
2906         filtered caps.
2907         * gst/gstutils.h:
2908         * gst/gstvalue.c: Add serialization/deserialization of caps
2909         * gst/parse/grammar.y: Ignore filtered caps when linking.  This
2910         requires fixing so that the filter caps notation creates
2911         a capsfilter element and sets the filter_caps property.  I
2912         think everyone probably wants to keep the shorthand notation.
2913         * docs/gst/tmpl/gstelement.sgml: updates for API changes.
2914         * docs/gst/tmpl/gstpad.sgml:
2915
2916         * gst/elements/gstelements.c: Register capsfilter element.
2917         * gst/Makefile.am: fix spacing
2918         * docs/random/ds/0.9-suggested-changes: random
2919
2920 2005-04-23  David Schleef  <ds@schleef.org>
2921
2922         * gst/elements/Makefile.am:
2923         * gst/elements/gstcapsfilter.c: New element that acts like an
2924         identity, but filters caps.  Will eventually replace filtered
2925         caps in pad linking.
2926         * gst/gstutils.c: (gst_element_create_all_pads): New function
2927         to create all the ALWAYS pads that are registered with an
2928         element class.  This functionality should eventually be
2929         merged in with GstElement initialization.
2930         * gst/gstutils.h:
2931         * testsuite/trigger/README: part of trigger test code that should
2932         have been checked in a long time ago.
2933
2934 2005-04-23  David Schleef  <ds@schleef.org>
2935
2936         * gst/Makefile.am: Remove as-libtool stuff.  It's likely not
2937         needed with new versions of libtool (nobody will confirm this),
2938         and hard to carry around.
2939         * gst/autoplug/Makefile.am:
2940         * gst/base/Makefile.am:
2941         * gst/elements/Makefile.am:
2942         * gst/indexers/Makefile.am:
2943         * gst/schedulers/Makefile.am:
2944         * libs/gst/bytestream/Makefile.am:
2945         * libs/gst/control/Makefile.am:
2946         * libs/gst/dataprotocol/Makefile.am:
2947         * libs/gst/getbits/Makefile.am:
2948
2949 2005-04-21  Wim Taymans  <wim@fluendo.com>
2950
2951         * docs/design/draft-push-pull.txt:
2952         * docs/design/part-MT-refcounting.txt:
2953         * docs/design/part-TODO.txt:
2954         * docs/design/part-caps.txt:
2955         * docs/design/part-events.txt:
2956         * docs/design/part-gstbus.txt:
2957         * docs/design/part-gstpipeline.txt:
2958         * docs/design/part-messages.txt:
2959         * docs/design/part-push-pull.txt:
2960         * docs/design/part-query.txt:
2961         Some more docs.
2962
2963 2005-04-21  Wim Taymans  <wim@fluendo.com>
2964
2965         * gst/gstmessage.c: (_gst_message_copy), (_gst_message_free),
2966         (gst_message_new), (gst_message_new_error),
2967         (gst_message_new_warning), (gst_message_new_tag),
2968         (gst_message_new_state_changed), (gst_message_new_application),
2969         (gst_message_get_structure):
2970         * gst/gstmessage.h:
2971         * gst/gststructure.c: (gst_structure_set_parent_refcount),
2972         (gst_structure_copy_conditional):
2973         Use parent refcount in GstMessage to ensure GstStructure
2974         consistency.
2975         Cleaned up headers a bit.
2976         
2977
2978 2005-04-20  Wim Taymans  <wim@fluendo.com>
2979
2980         * gst/base/gstbasesink.c: (gst_basesink_base_init),
2981         (gst_basesink_pad_getcaps), (gst_basesink_init),
2982         (gst_basesink_chain_unlocked):
2983         * gst/base/gsttypefindhelper.c: (helper_find_suggest),
2984         (gst_type_find_helper):
2985         * gst/elements/gsttypefindelement.c:
2986         (gst_type_find_element_have_type), (gst_type_find_element_init),
2987         (stop_typefinding), (gst_type_find_element_handle_event),
2988         (find_suggest), (gst_type_find_element_chain),
2989         (gst_type_find_element_checkgetrange),
2990         (gst_type_find_element_getrange), (do_typefind),
2991         (gst_type_find_element_activate):
2992         * gst/gstbuffer.c: (_gst_buffer_sub_free),
2993         (gst_buffer_default_free), (gst_buffer_default_copy),
2994         (gst_buffer_set_caps):
2995         * gst/gstcaps.c: (gst_caps_ref), (gst_caps_unref),
2996         (gst_caps_replace):
2997         * gst/gstmessage.c: (gst_message_new),
2998         (gst_message_new_state_changed):
2999         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3000         (gst_pad_set_checkgetrange_function),
3001         (gst_pad_link_prepare_filtered), (gst_pad_relink_filtered),
3002         (gst_pad_set_caps), (gst_pad_check_pull_range),
3003         (gst_pad_pull_range), (gst_static_pad_template_get_caps):
3004         * gst/gstpad.h:
3005         * gst/gsttypefind.c: (gst_type_find_register):
3006         Make gst_caps_replace() work like other _replace() functions.
3007         Use _caps_replace() where possible.
3008         Make sure _message_new() initialises its field.
3009         Add gst_static_pad_template_get_caps()
3010
3011
3012 2005-04-18  Andy Wingo  <wingo@pobox.com>
3013
3014         * gst/gstelement.c (gst_element_pads_activate): Check pull_range
3015         on the peer, not the pad. I think that was a typo. Pass an extra
3016         arg to see if random access is possible. Activate the pads as
3017         PULL_RANGE if possible.
3018
3019         * gst/elements/gstfakesrc.c: s/ARG_/PROP_/.
3020
3021         * gst/base/gstbasesrc.c (gst_basesrc_set_property) 
3022         (gst_basesrc_get_property): BLOCKSIZE is a ULONG. Rename ARG_...
3023         to PROP_....
3024
3025 2005-04-14  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3026
3027         * docs/faq/using.xml:
3028           Add note on gstreamer-properties (#154996).
3029
3030 2005-04-13  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3031
3032         * docs/random/bbb/optional-properties:
3033           Some analysis on optional properties.
3034
3035 2005-04-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3036
3037         * docs/gst/tmpl/gstelementfactory.sgml:
3038         * gst/gstelement.h:
3039         * gst/gstelementfactory.c: (gst_element_factory_init),
3040         (gst_element_factory_cleanup), (gst_element_register),
3041         (__gst_element_factory_add_static_pad_template),
3042         (gst_element_factory_get_static_pad_templates),
3043         (gst_element_factory_can_src_caps),
3044         (gst_element_factory_can_sink_caps):
3045         * gst/registries/Makefile.am:
3046         * gst/registries/gstlibxmlregistry.c: (gst_xml_registry_get_type),
3047         (gst_xml_registry_class_init), (gst_xml_registry_init),
3048         (gst_xml_registry_new), (gst_xml_registry_set_property),
3049         (gst_xml_registry_get_property), (get_time), (make_dir),
3050         (gst_xml_registry_get_perms_func),
3051         (plugin_times_older_than_recurse), (plugin_times_older_than),
3052         (gst_xml_registry_open_func), (gst_xml_registry_load_func),
3053         (gst_xml_registry_save_func), (gst_xml_registry_close_func),
3054         (add_to_char_array), (read_string), (read_uint), (read_enum),
3055         (load_pad_template), (load_feature), (load_plugin), (load_paths),
3056         (gst_xml_registry_load), (gst_xml_registry_load_plugin),
3057         (gst_xml_registry_save_caps), (gst_xml_registry_save_pad_template),
3058         (gst_xml_registry_save_feature), (gst_xml_registry_save_plugin),
3059         (gst_xml_registry_save), (gst_xml_registry_rebuild_recurse),
3060         (gst_xml_registry_rebuild):
3061         * gst/registries/gstlibxmlregistry.h:
3062         * tools/gst-compprep.c: (main):
3063         * tools/gst-inspect.c: (print_pad_templates_info):
3064         * tools/gst-xmlinspect.c: (print_element_info):
3065           Use libxml2 for registry parsing, use staticpadtemplates in
3066           elementfactories. Makes gst_init() +/- 10x faster.
3067
3068 2005-04-12  Wim Taymans  <wim@fluendo.com>
3069
3070         * gst/base/Makefile.am:
3071         * gst/base/gstbasesink.c: (gst_basesink_base_init),
3072         (gst_basesink_pad_getcaps), (gst_basesink_init),
3073         (gst_basesink_event), (gst_basesink_change_state):
3074         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
3075         (gst_basesrc_init), (gst_basesrc_query),
3076         (gst_basesrc_get_event_mask), (gst_basesrc_do_seek),
3077         (gst_basesrc_event_handler), (gst_basesrc_get_range_unlocked),
3078         (gst_basesrc_check_get_range), (gst_basesrc_loop),
3079         (gst_basesrc_unlock), (gst_basesrc_get_size), (gst_basesrc_start),
3080         (gst_basesrc_stop), (gst_basesrc_activate),
3081         (gst_basesrc_change_state):
3082         * gst/base/gsttypefindhelper.c: (helper_find_peek),
3083         (helper_find_suggest), (gst_type_find_helper):
3084         * gst/base/gsttypefindhelper.h:
3085         * gst/elements/Makefile.am:
3086         * gst/elements/gstelements.c:
3087         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
3088         (gst_fakesink_get_times), (gst_fakesink_event),
3089         (gst_fakesink_preroll), (gst_fakesink_render):
3090         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
3091         (gst_fakesrc_init), (gst_fakesrc_event_handler),
3092         (gst_fakesrc_get_property), (gst_fakesrc_create),
3093         (gst_fakesrc_start), (gst_fakesrc_stop):
3094         * gst/elements/gstfakesrc.h:
3095         * gst/elements/gstfilesrc.c: (gst_filesrc_class_init),
3096         (gst_filesrc_free_parent_mmap), (gst_filesrc_map_region),
3097         (gst_filesrc_map_small_region), (gst_filesrc_create_mmap),
3098         (gst_filesrc_create_read), (gst_filesrc_create),
3099         (gst_filesrc_is_seekable), (gst_filesrc_get_size),
3100         (gst_filesrc_start):
3101         * gst/elements/gsttypefindelement.c:
3102         (gst_type_find_element_have_type), (gst_type_find_element_init),
3103         (start_typefinding), (stop_typefinding), (push_buffer_store),
3104         (gst_type_find_element_handle_event),
3105         (gst_type_find_element_chain),
3106         (gst_type_find_element_checkgetrange),
3107         (gst_type_find_element_getrange), (do_typefind),
3108         (gst_type_find_element_activate),
3109         (gst_type_find_element_change_state):
3110         * gst/elements/gsttypefindelement.h:
3111         * gst/gstpipeline.c: (pipeline_bus_handler):
3112         Added typefind helper.
3113         Small preroll fix in the base sink.
3114         Disable typefind code in basesrc.
3115         Crude port of typefindelement.
3116         Fakesrc cleanups.
3117
3118
3119 2005-04-11  Wim Taymans  <wim@fluendo.com>
3120
3121         * check/gst/gstbus.c: (gstbus_suite):
3122         * check/gst/gstdata.c: (thread_ref), (gst_data_suite):
3123         * check/gstcheck.h:
3124           Fix up the timeout so that the test does not fail.
3125
3126 2005-04-06  Wim Taymans  <wim@fluendo.com>
3127
3128         * gst/base/README:
3129         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
3130         (gst_basesrc_init), (gst_basesrc_get_formats), (gst_basesrc_query),
3131         (gst_basesrc_get_event_mask), (gst_basesrc_do_seek),
3132         (gst_basesrc_event_handler), (gst_basesrc_get_range_unlocked),
3133         (gst_basesrc_check_get_range), (gst_basesrc_loop),
3134         (gst_basesrc_unlock), (gst_basesrc_get_size), (gst_basesrc_start),
3135         (gst_basesrc_stop), (gst_basesrc_activate),
3136         (gst_basesrc_change_state), (basesrc_find_peek),
3137         (basesrc_find_suggest), (gst_basesrc_type_find):
3138         * gst/base/gstbasesrc.h:
3139         * gst/elements/gstfilesrc.c: (gst_filesrc_base_init),
3140         (gst_filesrc_class_init), (gst_filesrc_init),
3141         (gst_filesrc_finalize), (gst_filesrc_set_location),
3142         (gst_filesrc_set_property), (gst_filesrc_get_property),
3143         (gst_filesrc_free_parent_mmap), (gst_filesrc_map_region),
3144         (gst_filesrc_map_small_region), (gst_filesrc_create_mmap),
3145         (gst_filesrc_create_read), (gst_filesrc_create),
3146         (gst_filesrc_get_size), (gst_filesrc_start), (gst_filesrc_stop):
3147         * gst/elements/gstfilesrc.h:
3148         * gst/gstelement.c: (gst_element_get_state_func),
3149         (gst_element_lost_state), (gst_element_pads_activate):
3150         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3151         (gst_pad_set_checkgetrange_function), (gst_pad_check_pull_range),
3152         (gst_pad_pull_range):
3153         * gst/gstpad.h:
3154         More work on the generic source base class, implement seeking,
3155         query.
3156         Make filesrc extend the base source class.
3157         Added gst_pad_set_checkgetrange_function to GstPad.
3158
3159 2005-04-06  Andy Wingo  <wingo@pobox.com>
3160
3161         * pkgconfig/gstreamer-base.pc.in:
3162         * pkgconfig/gstreamer-base-uninstalled.pc.in: New files.
3163
3164         * pkgconfig/Makefile.am:
3165         * configure.ac (AC_OUTPUT): Add gstreamer-base pkgconfig files.
3166
3167 2005-04-04  Wim Taymans  <wim@fluendo.com>
3168
3169         * gst/base/Makefile.am:
3170         * gst/base/README:
3171         * gst/base/gstbasesink.c: (gst_basesink_base_init),
3172         (gst_basesink_pad_getcaps), (gst_basesink_pad_setcaps),
3173         (gst_basesink_pad_buffer_alloc), (gst_basesink_init),
3174         (gst_basesink_do_sync), (gst_basesink_chain_unlocked):
3175         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
3176         (gst_basesrc_base_init), (gst_basesrc_class_init),
3177         (gst_basesrc_init), (gst_basesrc_get_formats),
3178         (gst_basesrc_get_query_types), (gst_basesrc_query),
3179         (gst_basesrc_get_event_mask), (gst_basesrc_event_handler),
3180         (gst_basesrc_set_property), (gst_basesrc_get_property),
3181         (gst_basesrc_get_range_unlocked), (gst_basesrc_get_range),
3182         (gst_basesrc_loop), (gst_basesrc_activate),
3183         (gst_basesrc_change_state):
3184         * gst/base/gstbasesrc.h:
3185         * gst/elements/gstfakesrc.c: (gst_fakesrc_base_init),
3186         (gst_fakesrc_class_init), (gst_fakesrc_init),
3187         (gst_fakesrc_event_handler), (gst_fakesrc_set_property),
3188         (gst_fakesrc_get_property), (gst_fakesrc_create):
3189         * gst/elements/gstfakesrc.h:
3190         * gst/elements/gstfilesrc.c: (gst_filesrc_getrange),
3191         (gst_filesrc_open_file), (gst_filesrc_loop),
3192         (gst_filesrc_activate), (filesrc_find_peek),
3193         (gst_filesrc_type_find):
3194         Made base source class, make fakesrc extend it.
3195         Add comments to basesink class.
3196         Some filesrc cleanup.
3197
3198 2005-03-31  David Schleef  <ds@schleef.org>
3199
3200         * gst/gstplugin.c: (gst_plugin_check_file), (gst_plugin_load_file):
3201         Switch to using G_MODULE_BIND_LOCAL, which means plugins are now
3202         expected to link against libgstreamer.
3203         * gst/base/Makefile.am: link against libgstreamer
3204         * gst/elements/Makefile.am: same
3205
3206 2005-03-31  Andy Wingo  <wingo@pobox.com>
3207
3208         * tests/instantiate/Makefile.am:
3209         * tests/instantiate/caps.c: Add test to test speed of caps copy
3210         and free.
3211
3212         * tests/memchunk/gmemchunktest.c (main): Use alloc only on the
3213         GMemChunk to be fair.
3214
3215         * gst/gsttrashstack.h: Remove warning about using the fallback
3216         trash stack implementation, it's still faster than malloc.
3217
3218 2005-03-30  Andy Wingo  <wingo@pobox.com>
3219
3220         * tests/complexity.c: Add a copyright.
3221
3222 2005-03-31  Wim Taymans  <wim@fluendo.com>
3223
3224         * gst/base/gstbasetransform.c: (gst_base_transform_base_init),
3225         (gst_base_transform_class_init), (gst_base_transform_init),
3226         (gst_base_transform_setcaps), (gst_base_transform_handle_buffer),
3227         (gst_base_transform_get_property),
3228         (gst_base_transform_sink_activate),
3229         (gst_base_transform_src_activate),
3230         (gst_base_transform_change_state):
3231         * gst/base/gstbasetransform.h:
3232         * gst/elements/gstidentity.c: (gst_identity_class_init),
3233         (gst_identity_event), (gst_identity_check_perfect),
3234         (gst_identity_transform), (gst_identity_start),
3235         (gst_identity_stop):
3236         Added start/stop methods to transform base class so subclasses 
3237         don't need to deal with state changes even.
3238
3239 2005-03-31  Wim Taymans  <wim@fluendo.com>
3240
3241         * gst/gstevent.c: (gst_event_new_discontinuous_valist),
3242         (gst_event_new_discontinuous), (gst_event_discont_get_value):
3243         * gst/gstevent.h:
3244         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3245         (gst_pad_pull_range):
3246         Added rate to the discont event to prepare for variable speed
3247         and reverse playback.
3248
3249 2005-03-29  David Schleef  <ds@schleef.org>
3250
3251         * configure.ac:
3252         * testsuite/trigger/Makefile.am:
3253         * testsuite/trigger/trigger.c: A little example program to show
3254         how trigger-based elements can work.
3255
3256 2005-03-29  Wim Taymans  <wim@fluendo.com>
3257
3258         * gst/base/Makefile.am:
3259         * gst/base/README:
3260         * gst/base/gstbasesink.c: (gst_basesink_get_type),
3261         (gst_basesink_base_init), (gst_basesink_class_init),
3262         (gst_basesink_pad_getcaps), (gst_basesink_init),
3263         (gst_basesink_activate), (gst_basesink_change_state):
3264         * gst/base/gstbasesink.h:
3265         * gst/base/gstbasetransform.c: (gst_base_transform_get_type),
3266         (gst_base_transform_base_init), (gst_base_transform_finalize),
3267         (gst_base_transform_class_init), (gst_base_transform_init),
3268         (gst_base_transform_proxy_getcaps), (gst_base_transform_setcaps),
3269         (gst_base_transform_event), (gst_base_transform_getrange),
3270         (gst_base_transform_chain), (gst_base_transform_handle_buffer),
3271         (gst_base_transform_set_property),
3272         (gst_base_transform_get_property),
3273         (gst_base_transform_sink_activate),
3274         (gst_base_transform_src_activate),
3275         (gst_base_transform_change_state):
3276         * gst/base/gstbasetransform.h:
3277         * gst/elements/gstidentity.c: (gst_identity_finalize),
3278         (gst_identity_class_init), (gst_identity_init),
3279         (gst_identity_event), (gst_identity_check_perfect),
3280         (gst_identity_transform), (gst_identity_set_property),
3281         (gst_identity_get_property), (gst_identity_change_state):
3282         * gst/elements/gstidentity.h:
3283         * gst/gstelement.c: (gst_element_get_state_func),
3284         (gst_element_lost_state), (gst_element_pads_activate):
3285         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3286         (gst_pad_check_pull_range), (gst_pad_pull_range):
3287         * gst/gstpad.h:
3288         Simplify pad activation.
3289         Added function to check if pull_range can be performed.
3290         Error out when pulling inactive or flushing pads.
3291         Removed const from refcounted types as it does not make sense.
3292         Simplify pad templates in basesink
3293         Added base class for simple 1-to-1 transforms.
3294         Make identity subclass the base transform.
3295
3296 2005-03-29  Andy Wingo  <wingo@pobox.com>
3297
3298         * docs/libs/gstreamer-libs-overrides.txt: 
3299         * docs/gst/gstreamer-overrides.txt: Add these files to CVS. Now I
3300         really don't understand what's going on, but like whatever. I want
3301         green buildbot!
3302
3303         * docs/gst/Makefile.am:
3304         * docs/libs/Makefile.am: Dist the overrides files.
3305
3306         * check/Makefile.am (clean-local): Remove .libs directories.
3307
3308         * gst/elements/Makefile.am (EXTRA_DIST): Add all the attic
3309         elements to EXTRA_DIST, so po/ files are happy.
3310
3311         * po/POTFILES.in: Er, remove it here.
3312
3313         * po/POTFILES: Remove gstspider.c.
3314
3315         * configure.ac (AC_OUTPUT): Add missing testsuite makefiles.
3316
3317         * docs/libs/gstreamer-libs-docs.sgml: 
3318         * docs/libs/gstreamer-libs-sections.txt: Remove the section on
3319         bytestream.
3320
3321         * tests/complexity.c (main): Set the length of the preroll queue
3322         on the sinks to prevent a lockup.
3323
3324         * libs/gst/dataprotocol/Makefile.am: 
3325         * libs/gst/dataprotocol/dataprotocol-test.c: Remove test, it's
3326         the same as the one in check/gst-libs/gdp.c.
3327
3328         * po/, docs/gst/: Commit automatic changes to docs and po files.
3329
3330         * gst/elements/Makefile.am (libgstelements_la_LDFLAGS): Link to
3331         the versioned libgstbase.
3332
3333         * check/Makefile.am: Depend on an unversioned gst-register, seems
3334         to make autoconf happier.
3335
3336         * gst/base/Makefile.am: Make libgstbase a versioned lib.
3337
3338 2005-03-28  Wim Taymans  <wim@fluendo.com>
3339
3340         * configure.ac:
3341         * docs/design/part-gstelement.txt:
3342         * docs/design/part-negotiation.txt:
3343         * docs/design/part-preroll.txt:
3344         * docs/design/part-scheduling.txt:
3345         * docs/design/part-states.txt:
3346         * gst/Makefile.am:
3347         * gst/base/Makefile.am:
3348         * gst/base/README:
3349         * gst/base/gstbasesink.c: (gst_basesink_get_template),
3350         (gst_basesink_base_init), (gst_basesink_class_init),
3351         (gst_basesink_pad_getcaps), (gst_basesink_pad_setcaps),
3352         (gst_basesink_pad_buffer_alloc), (gst_basesink_init),
3353         (gst_basesink_set_pad_functions),
3354         (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock),
3355         (gst_basesink_set_property), (gst_basesink_get_property),
3356         (gst_base_sink_get_template), (gst_base_sink_get_caps),
3357         (gst_base_sink_set_caps), (gst_base_sink_buffer_alloc),
3358         (gst_basesink_preroll_queue_push),
3359         (gst_basesink_preroll_queue_empty),
3360         (gst_basesink_preroll_queue_flush), (gst_basesink_finish_preroll),
3361         (gst_basesink_event), (gst_basesink_get_times),
3362         (gst_basesink_do_sync), (gst_basesink_handle_buffer),
3363         (gst_basesink_chain_unlocked), (gst_basesink_chain),
3364         (gst_basesink_loop), (gst_basesink_activate),
3365         (gst_basesink_change_state):
3366         * gst/base/gstbasesink.h:
3367         * gst/elements/Makefile.am:
3368         * gst/elements/gstfakesink.c: (gst_fakesink_base_init),
3369         (gst_fakesink_class_init), (gst_fakesink_init),
3370         (gst_fakesink_set_property), (gst_fakesink_get_property),
3371         (gst_fakesink_get_times), (gst_fakesink_event),
3372         (gst_fakesink_preroll), (gst_fakesink_render),
3373         (gst_fakesink_change_state):
3374         * gst/elements/gstfakesink.h:
3375         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_manager),
3376         (gst_bin_get_state), (gst_bin_change_state), (gst_bin_send_event):
3377         * gst/gstelement.c: (gst_element_add_pad),
3378         (gst_element_get_state_func), (gst_element_abort_state),
3379         (gst_element_commit_state), (gst_element_lost_state),
3380         (gst_element_set_state), (gst_element_pads_activate):
3381         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_event_default):
3382         * gst/gstpipeline.c: (gst_pipeline_send_event),
3383         (gst_pipeline_change_state):
3384         Added state change code.
3385         Added/updated docs.
3386         Added sink base class, make fakesink extend the base class.
3387         Small cleanups in GstPipeline.
3388
3389 2005-03-26  David Schleef  <ds@schleef.org>
3390
3391         * gst/Makefile.am: remove gstcpu.[ch].  The gst_cpu functionality
3392         is broken and should be implemented in a different library.
3393         * gst/gst.c: (init_post): don't call _gst_cpu_initialize()
3394         * gst/gst.h: remove gstcpu.h
3395         * gst/gstcpu.c: remove
3396         * gst/gstcpu.h: remove
3397         * gst/Makefile.am.future: Remove this file.  It's ancient.
3398
3399 2005-03-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3400
3401         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_manager),
3402         (gst_bin_send_event):
3403           Add default event/set_manager handlers. The set_manager handler
3404           takes care that the manager is distributed over kids that were
3405           already in the bin before the manager was set. The event handler
3406           is a utility virtual function that sends the event over all sinks,
3407           so that gst_element_send_event (bin, event); has the expected
3408           behaviour.
3409         * gst/gstpad.c: (gst_pad_event_default):
3410           Re-install default event handling for discontinuities, so that
3411           seeking works without requiring hacks in applications or extra
3412           code in sinks.
3413         * gst/gstpipeline.c: (gst_pipeline_class_init),
3414         (gst_pipeline_send_event):
3415           Half hack, half utility: set a pipeline to PAUSED for seek events,
3416           since that is the only way we can guarantee a/v sync. Means that
3417           you can do gst_element_seek (pipeline, method, pos); on a pipeline
3418           and it "just works".
3419
3420 2005-03-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3421
3422         * gst/gstpipeline.c: (gst_pipeline_use_clock):
3423           Lock/unlock mismatch.
3424
3425 2005-03-25  Thomas Vander Stichele  <thomas at apestaart dot org>
3426
3427         * docs/faq/gst-uninstalled:
3428           add gst-plugins-base
3429         * docs/gst/Makefile.am:
3430           don't error out until docs are fixed
3431         * docs/gst/gstreamer.types:
3432           remove thread
3433
3434 2005-03-22  Wim Taymans  <wim@fluendo.com>
3435
3436         * check/Makefile.am:
3437         * check/gst/gstmessage.c: (START_TEST), (gst_data_suite), (main):
3438         * gst/gststructure.c: (gst_structure_set_valist),
3439         (gst_structure_copy_conditional):
3440         Activated more tests.
3441         Added message test.
3442         Added G_TYPE_POINTER to GstStructure.
3443         
3444
3445 2005-03-22  Wim Taymans  <wim@fluendo.com>
3446
3447         * docs/design/part-TODO.txt:
3448         * docs/design/part-events.txt:
3449         * docs/design/part-gstbin.txt:
3450         * docs/design/part-gstbus.txt:
3451         * docs/design/part-gstpipeline.txt:
3452         * docs/design/part-messages.txt:
3453         * gst/gstbus.c:
3454         * gst/gstmessage.c:
3455         Docs updates
3456
3457 2005-03-21  Wim Taymans  <wim@fluendo.com>
3458
3459         * gst/gstbus.c: (gst_bus_post):
3460         Fix copy-and-paste error.
3461
3462 2005-03-21  Wim Taymans  <wim@fluendo.com>
3463
3464         * check/Makefile.am:
3465         * gst/Makefile.am:
3466         * gst/elements/Makefile.am:
3467         * gst/elements/gstelements.c:
3468         * gst/elements/gstfakesink.c: (gst_fakesink_init),
3469         (gst_fakesink_event), (gst_fakesink_chain):
3470         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
3471         (gst_fakesrc_init), (gst_fakesrc_get_event_mask),
3472         (gst_fakesrc_event_handler), (gst_fakesrc_set_pad_functions),
3473         (gst_fakesrc_set_all_pad_functions), (gst_fakesrc_request_new_pad),
3474         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
3475         (gst_fakesrc_get_range_unlocked), (gst_fakesrc_get_range),
3476         (gst_fakesrc_loop), (gst_fakesrc_activate),
3477         (gst_fakesrc_change_state):
3478         * gst/elements/gstfakesrc.h:
3479         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
3480         (gst_filesrc_get_read), (gst_filesrc_getrange), (gst_filesrc_get),
3481         (gst_filesrc_open_file), (gst_filesrc_loop),
3482         (gst_filesrc_activate), (gst_filesrc_change_state),
3483         (filesrc_find_peek), (filesrc_find_suggest),
3484         (gst_filesrc_type_find):
3485         * gst/elements/gstidentity.c: (gst_identity_finalize),
3486         (gst_identity_class_init), (gst_identity_init),
3487         (gst_identity_proxy_getcaps), (identity_queue_push),
3488         (identity_queue_pop), (identity_queue_flush), (gst_identity_event),
3489         (gst_identity_getrange), (gst_identity_chain),
3490         (gst_identity_sink_loop), (gst_identity_src_loop),
3491         (gst_identity_handle_buffer), (gst_identity_set_dataflow_funcs),
3492         (gst_identity_set_property), (gst_identity_get_property),
3493         (gst_identity_change_state):
3494         * gst/elements/gstidentity.h:
3495         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_init),
3496         (gst_tee_update_pad_functions), (gst_tee_request_new_pad),
3497         (gst_tee_set_property), (gst_tee_get_property), (gst_tee_do_push),
3498         (gst_tee_handle_buffer), (gst_tee_chain), (gst_tee_loop),
3499         (gst_tee_sink_activate):
3500         * gst/elements/gsttee.h:
3501         * gst/gst.c: (gst_register_core_elements), (init_post):
3502         * gst/gst.h:
3503         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_bus),
3504         (gst_bin_set_scheduler), (gst_bin_add_func), (gst_bin_add),
3505         (gst_bin_remove_func), (gst_bin_remove), (gst_bin_get_state),
3506         (gst_bin_change_state):
3507         * gst/gstbin.h:
3508         * gst/gstbus.c: (gst_bus_get_type), (gst_bus_class_init),
3509         (gst_bus_init), (gst_bus_dispose), (gst_bus_set_property),
3510         (gst_bus_get_property), (gst_bus_new), (gst_bus_post),
3511         (gst_bus_have_pending), (gst_bus_pop), (gst_bus_peek),
3512         (gst_bus_set_sync_handler), (gst_bus_create_watch),
3513         (bus_watch_callback), (bus_watch_destroy),
3514         (gst_bus_add_watch_full), (gst_bus_add_watch), (poll_handler),
3515         (poll_timeout), (gst_bus_poll):
3516         * gst/gstbus.h:
3517         * gst/gstcaps.h:
3518         * gst/gstdata.h:
3519         * gst/gstelement.c: (gst_element_class_init), (gst_element_init),
3520         (gst_element_post_message), (gst_element_message_full),
3521         (gst_element_get_state_func), (gst_element_get_state),
3522         (gst_element_abort_state), (gst_element_commit_state),
3523         (gst_element_lost_state), (gst_element_set_state),
3524         (gst_element_pads_activate), (gst_element_change_state),
3525         (gst_element_dispose), (gst_element_set_manager_func),
3526         (gst_element_set_bus_func), (gst_element_set_scheduler_func),
3527         (gst_element_set_manager), (gst_element_get_manager),
3528         (gst_element_set_bus), (gst_element_get_bus),
3529         (gst_element_set_scheduler), (gst_element_get_scheduler):
3530         * gst/gstelement.h:
3531         * gst/gstevent.c: (gst_event_new_segment_seek),
3532         (gst_event_new_flush):
3533         * gst/gstevent.h:
3534         * gst/gstmessage.c: (_gst_message_initialize), (_gst_message_copy),
3535         (_gst_message_free), (gst_message_get_type), (gst_message_new),
3536         (gst_message_new_eos), (gst_message_new_error),
3537         (gst_message_new_warning), (gst_message_new_tag),
3538         (gst_message_new_state_changed), (gst_message_new_application),
3539         (gst_message_get_structure), (gst_message_parse_tag),
3540         (gst_message_parse_state_changed), (gst_message_parse_error),
3541         (gst_message_parse_warning):
3542         * gst/gstmessage.h:
3543         * gst/gstpad.c: (gst_real_pad_class_init), (gst_real_pad_init),
3544         (gst_real_pad_set_property), (gst_pad_set_active),
3545         (gst_pad_is_active), (gst_pad_set_blocked_async),
3546         (gst_pad_set_blocked), (gst_pad_is_blocked),
3547         (gst_pad_set_activate_function), (gst_pad_set_loop_function),
3548         (gst_pad_set_getrange_function), (gst_pad_set_acceptcaps_function),
3549         (gst_pad_set_fixatecaps_function), (gst_pad_set_setcaps_function),
3550         (gst_pad_unlink), (gst_pad_link_prepare_filtered),
3551         (gst_pad_link_filtered), (gst_pad_relink_filtered),
3552         (gst_real_pad_get_caps_unlocked), (gst_pad_get_caps),
3553         (gst_pad_peer_get_caps), (gst_pad_fixate_caps),
3554         (gst_pad_accept_caps), (gst_pad_peer_accept_caps),
3555         (gst_pad_set_caps), (gst_pad_configure_sink),
3556         (gst_pad_configure_src), (gst_pad_get_negotiated_caps),
3557         (gst_pad_get_filter_caps), (gst_pad_alloc_buffer),
3558         (gst_real_pad_dispose), (gst_real_pad_finalize),
3559         (handle_pad_block), (gst_pad_push), (gst_pad_pull_range),
3560         (gst_pad_event_default_dispatch), (gst_pad_event_default),
3561         (gst_pad_push_event), (gst_pad_send_event), (gst_pad_get_formats):
3562         * gst/gstpad.h:
3563         * gst/gstpipeline.c: (gst_pipeline_init), (is_eos),
3564         (pipeline_bus_handler), (gst_pipeline_change_state),
3565         (gst_pipeline_get_scheduler), (gst_pipeline_get_bus):
3566         * gst/gstpipeline.h:
3567         * gst/gstprobe.h:
3568         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_init),
3569         (gst_queue_finalize), (gst_queue_getcaps), (gst_queue_link_sink),
3570         (gst_queue_link_src), (gst_queue_bufferalloc),
3571         (gst_queue_locked_flush), (gst_queue_handle_sink_event),
3572         (gst_queue_is_empty), (gst_queue_is_filled), (gst_queue_chain),
3573         (gst_queue_loop), (gst_queue_handle_src_event),
3574         (gst_queue_handle_src_query), (gst_queue_src_activate),
3575         (gst_queue_change_state):
3576         * gst/gstqueue.h:
3577         * gst/gstscheduler.c: (gst_scheduler_init),
3578         (gst_scheduler_dispose), (gst_scheduler_create_task),
3579         (gst_scheduler_factory_create):
3580         * gst/gstscheduler.h:
3581         * gst/gststructure.c: (gst_structure_get_type),
3582         (gst_structure_copy_conditional):
3583         * gst/gststructure.h:
3584         * gst/gsttaginterface.h:
3585         * gst/gsttask.c: (gst_task_get_type), (gst_task_class_init),
3586         (gst_task_init), (gst_task_dispose), (gst_task_create),
3587         (gst_task_get_state), (gst_task_start), (gst_task_stop),
3588         (gst_task_pause):
3589         * gst/gsttask.h:
3590         * gst/gstthread.c:
3591         * gst/gstthread.h:
3592         * gst/gsttypes.h:
3593         * gst/schedulers/Makefile.am:
3594         * gst/schedulers/cothreads_compat.h:
3595         * gst/schedulers/entryscheduler.c:
3596         * gst/schedulers/faircothreads.c:
3597         * gst/schedulers/faircothreads.h:
3598         * gst/schedulers/fairscheduler.c:
3599         * gst/schedulers/gstbasicscheduler.c:
3600         * gst/schedulers/gstoptimalscheduler.c:
3601         * gst/schedulers/gthread-cothreads.h:
3602         * gst/schedulers/threadscheduler.c:
3603         (gst_thread_scheduler_task_get_type),
3604         (gst_thread_scheduler_task_class_init),
3605         (gst_thread_scheduler_task_init),
3606         (gst_thread_scheduler_task_start),
3607         (gst_thread_scheduler_task_stop),
3608         (gst_thread_scheduler_task_pause), (gst_thread_scheduler_get_type),
3609         (gst_thread_scheduler_class_init), (gst_thread_scheduler_func),
3610         (gst_thread_scheduler_init), (gst_thread_scheduler_create_task),
3611         (gst_thread_scheduler_setup), (gst_thread_scheduler_reset),
3612         (plugin_init):
3613         * libs/gst/Makefile.am:
3614         * libs/gst/bytestream/bytestream.c: (gst_bytestream_get_next_buf):
3615         * libs/gst/bytestream/filepad.c: (gst_file_pad_init),
3616         (gst_file_pad_parent_set):
3617         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_event),
3618         (gst_dp_event_from_packet):
3619         * tests/complexity.c: (main):
3620         * tests/mass_elements.c: (main):
3621         * testsuite/states/locked.c: (message_received), (main):
3622         * testsuite/states/parent.c: (main):
3623         * tools/gst-inspect.c: (print_element_flag_info),
3624         (print_implementation_info), (print_pad_info):
3625         * tools/gst-launch.c: (check_intr), (play_handler), (event_loop),
3626         (main):
3627         * tools/gst-md5sum.c: (event_loop), (main):
3628         * tools/gst-typefind.c: (main):
3629         * tools/gst-xmlinspect.c: (print_element_info):
3630         Next big merge.
3631         Added GstBus for mainloop integration.
3632         Added GstMessage for sending notifications on the bus.
3633         Added GstTask as an abstraction for pipeline entry points.
3634         Removed GstThread.
3635         Removed Schedulers.
3636         Simplified GstQueue for multithreaded core.
3637         Made _link threadsafe, removed old capsnego.
3638         Added STREAM_LOCK and PREROLL_LOCK in GstPad.
3639         Added pad blocking functions.
3640         Reworked scheduling functions in GstPad to prepare for
3641         scheduling updates soon.
3642         Moved events out of data stream.
3643         Simplified GstEvent types.
3644         Added return values to push/pull.
3645         Removed clocking from GstElement.
3646         Added prototypes for state change function for next merge.
3647         Removed iterate from bins and state change management.
3648         Fixed some elements, disabled others for now.
3649         Fixed -inspect and -launch.
3650         Added check for GstBus.
3651
3652 2005-03-10  Wim Taymans  <wim@fluendo.com>
3653
3654         * docs/design/part-MT-refcounting.txt:
3655         * docs/design/part-clocks.txt:
3656         * docs/design/part-gstelement.txt:
3657         * docs/design/part-gstobject.txt:
3658         * docs/design/part-standards.txt:
3659         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
3660         (gst_bin_remove_func), (gst_bin_remove):
3661         * gst/gstbin.h:
3662         * gst/gstbuffer.c:
3663         * gst/gstcaps.h:
3664         * testsuite/clock/clock1.c: (main):
3665         * testsuite/clock/clock2.c: (gst_clock_debug), (element_wait),
3666         (main):
3667         * testsuite/dlopen/loadgst.c: (do_test):
3668         * testsuite/refcounting/bin.c: (add_remove_test1),
3669         (add_remove_test2), (main):
3670         * testsuite/refcounting/element.c: (main):
3671         * testsuite/refcounting/element_pad.c: (main):
3672         * testsuite/refcounting/pad.c: (main):
3673         * tools/gst-launch.c: (sigint_handler_sighandler):
3674         * tools/gst-typefind.c: (main):
3675         Doc updates.
3676         Added doc about clock.
3677         removed gst_bin_iterate_recurse_up(), marked methods
3678         for removal.
3679         Fix more testsuites.
3680
3681 2005-03-09  Wim Taymans  <wim@fluendo.com>
3682
3683         * gst/gstpad.c: (gst_pad_get_direction),
3684         (_gst_pad_default_fixate_foreach), (gst_pad_collectv),
3685         (gst_pad_collect_valist):
3686         * testsuite/bins/interface.c: (main):
3687         * testsuite/caps/audioscale.c: (test_caps):
3688         * testsuite/caps/caps.c: (test1), (test2), (test3):
3689         * testsuite/caps/deserialize.c: (main):
3690         * testsuite/caps/enumcaps.c: (main):
3691         * testsuite/caps/filtercaps.c: (main):
3692         * testsuite/caps/intersect2.c: (main):
3693         * testsuite/caps/random.c: (main):
3694         * testsuite/caps/renegotiate.c: (my_fixate), (main):
3695         * testsuite/caps/sets.c: (check_caps):
3696         * testsuite/caps/simplify.c: (check_caps), (main):
3697         * testsuite/caps/subtract.c: (check_caps):
3698         Fix _pad_get_direction wrt ghostpads.
3699         Fix caps testsuite.
3700
3701 2005-03-09  Wim Taymans  <wim@fluendo.com>
3702
3703         * check/Makefile.am:
3704         * check/gst/gstbin.c: (START_TEST), (gst_bin_suite), (main):
3705         * check/gst/gstsystemclock.c: (START_TEST), (gst_clock_debug),
3706         (ok_callback), (error_callback), (gst_systemclock_suite), (main):
3707         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_index_func),
3708         (gst_bin_set_clock_func), (gst_bin_get_clock_func),
3709         (gst_bin_add_func), (gst_bin_add), (gst_bin_remove_func),
3710         (gst_bin_remove), (gst_bin_iterate_recurse_up),
3711         (bin_element_is_sink), (gst_bin_iterate_sinks),
3712         (gst_bin_iterate_all_by_interface):
3713         * gst/gstbin.h:
3714         * gst/gstelement.c: (gst_element_init), (gst_element_error_full),
3715         (gst_element_change_state), (gst_element_dispose),
3716         (gst_element_finalize), (gst_element_set_loop_function):
3717         * gst/gstelement.h:
3718         * gst/gstiterator.c: (find_custom_fold_func):
3719         * gst/gstpad.c: (_gst_pad_default_fixate_foreach),
3720         (gst_pad_collectv), (gst_pad_collect_valist),
3721         (gst_pad_template_new):
3722         * gst/gstpipeline.c: (gst_pipeline_class_init),
3723         (gst_pipeline_dispose), (gst_pipeline_set_property),
3724         (gst_pipeline_get_property), (gst_pipeline_get_clock_func),
3725         (gst_pipeline_get_clock), (gst_pipeline_use_clock),
3726         (gst_pipeline_set_clock), (gst_pipeline_auto_clock):
3727         * gst/gstutils.h:
3728         * gst/schedulers/entryscheduler.c:
3729         * gst/schedulers/gstbasicscheduler.c:
3730         (gst_basic_scheduler_cothreaded_chain),
3731         (gst_basic_scheduler_chain_add_element):
3732         * testsuite/bins/interface.c: (main):
3733         Added GstBin test.
3734         Added GstSystemClock test.
3735         Implemented clock distribution code in GstBin.
3736         Implemented iterate sinks method for future use.
3737         Rearranged gstelement.h
3738         Fix GstIterator comparison bug.
3739         Moved some code to GstPipeline, mostly clocking related.
3740
3741 2005-03-09  Wim Taymans  <wim@fluendo.com>
3742
3743         * configure.ac:
3744         * gst/gst_private.h:
3745         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
3746         (gst_bin_remove_func), (gst_bin_remove),
3747         (gst_bin_get_by_name_recurse_up):
3748         * gst/gstclock.c: (gst_clock_id_ref), (gst_clock_id_unref),
3749         (gst_clock_id_compare_func), (gst_clock_id_wait),
3750         (gst_clock_id_wait_async), (gst_clock_init),
3751         (gst_clock_adjust_unlocked), (gst_clock_get_time):
3752         * gst/gstelement.h:
3753         * gst/gstinfo.c: (_gst_debug_init):
3754         * gst/gstobject.h:
3755         * gst/gstpad.c: (_gst_pad_default_fixate_foreach),
3756         (gst_pad_collectv), (gst_pad_collect_valist), (gst_pad_query):
3757         * gst/gstpad.h:
3758         Bump version number, we're now 0.9.0
3759         Add future debugging category.
3760         Fix NULL _unref() in _get_by_name_recurse_up
3761         Rearrange gstpad.h.
3762         Update some docs.
3763
3764 2005-03-08  Wim Taymans  <wim@fluendo.com>
3765
3766         * gst/elements/gstaggregator.c: (gst_aggregator_class_init):
3767         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
3768         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
3769         * gst/elements/gstfdsink.c: (gst_fdsink_class_init):
3770         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init):
3771         * gst/elements/gstfilesink.c: (gst_filesink_class_init):
3772         * gst/elements/gstfilesrc.c: (gst_filesrc_class_init):
3773         * gst/elements/gstidentity.c: (gst_identity_class_init):
3774         * gst/elements/gstmd5sink.c: (gst_md5sink_class_init):
3775         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
3776         * gst/elements/gstshaper.c: (gst_shaper_class_init):
3777         * gst/elements/gststatistics.c: (gst_statistics_class_init):
3778         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_getcaps),
3779         (gst_tee_link):
3780         * gst/gstelement.c: (gst_element_class_init),
3781         (gst_element_base_class_init), (gst_element_init),
3782         (gst_element_get_random_pad), (gst_element_wait_state_change),
3783         (gst_element_change_state), (gst_element_dispose),
3784         (gst_element_finalize), (gst_element_set_loop_function):
3785         * gst/gstelement.h:
3786         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_link_src):
3787         * gst/gstthread.c: (gst_thread_class_init),
3788         (gst_thread_release_children_locks), (gst_thread_change_state):
3789         * gst/schedulers/gstbasicscheduler.c:
3790         (gst_basic_scheduler_loopfunc_wrapper),
3791         (gst_basic_scheduler_chain_wrapper),
3792         (gst_basic_scheduler_src_wrapper),
3793         (gst_basic_scheduler_remove_element):
3794         * gst/schedulers/gstoptimalscheduler.c: (schedule_group):
3795         Remove threadsafe properties. Fix elements because GObject
3796         complains when installing a property before declaring a
3797         set/get_property handler.
3798         Rearrange gstelement.h file, use STATE macros for state locks.
3799         Free mutexes in the finalize method instead of dispose.
3800
3801 2005-03-08  Wim Taymans  <wim@fluendo.com>
3802
3803         * check/gst/gstobject.c: (START_TEST), (gst_object_suite):
3804         * gst/gstthread.c: (gst_thread_release_children_locks):
3805         Added parentage check.
3806         Fix build og GstThread again.
3807
3808 2005-03-08  Wim Taymans  <wim@fluendo.com>
3809
3810         * docs/design/part-MT-refcounting.txt:
3811         * docs/design/part-conventions.txt:
3812         * docs/design/part-gstobject.txt:
3813         * docs/design/part-relations.txt:
3814         * docs/design/part-standards.txt:
3815         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
3816         (gst_bin_remove_func), (gst_bin_remove), (gst_bin_iterate_recurse),
3817         (gst_bin_get_by_name), (gst_bin_get_by_interface),
3818         (gst_bin_iterate_all_by_interface):
3819         * gst/gstbuffer.h:
3820         * gst/gstclock.h:
3821         * gst/gstelement.c: (gst_element_class_init),
3822         (gst_element_change_state), (gst_element_set_loop_function):
3823         * gst/gstelement.h:
3824         * gst/gstiterator.c:
3825         * gst/gstobject.c: (gst_object_class_init), (gst_object_ref),
3826         (gst_object_unref), (gst_object_sink), (gst_object_dispose),
3827         (gst_object_dispatch_properties_changed), (gst_object_set_name),
3828         (gst_object_set_parent), (gst_object_unparent),
3829         (gst_object_check_uniqueness):
3830         * gst/gstobject.h:
3831         Docs updates, clean up some headers.
3832
3833 2005-03-07  Wim Taymans  <wim@fluendo.com>
3834
3835         * check/.cvsignore:
3836         * check/Makefile.am:
3837         * check/gst-libs/.cvsignore:
3838         * check/gst-libs/gdp.c: (START_TEST), (gst_object_suite), (main):
3839         * check/gst/.cvsignore:
3840         * check/gst/gstbus.c: (pound_bus_with_messages), (pull_messages),
3841         (START_TEST), (gstbus_suite), (main):
3842         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite), (main):
3843         * check/gst/gstdata.c: (START_TEST), (thread_ref), (thread_unref),
3844         (gst_data_suite), (main):
3845         * check/gst/gstiterator.c: (make_list_of_ints), (START_TEST),
3846         (add_fold_func), (gstiterator_suite), (main):
3847         * check/gst/gstobject.c: (gst_fake_object_get_type), (START_TEST),
3848         (thread_name_object), (thread_name_object_default),
3849         (gst_object_name_compare), (gst_object_suite), (main):
3850         * check/gst/gstpad.c: (START_TEST), (thread_link_unlink),
3851         (gst_pad_suite), (main):
3852         * check/gstcheck.c: (gst_check_log_message_func),
3853         (gst_check_log_critical_func), (gst_check_init):
3854         * check/gstcheck.h:
3855         * check/pipelines/simple_launch_lines.c: (setup_pipeline),
3856         (run_pipeline), (START_TEST), (simple_launch_lines_suite), (main):
3857         Added checks.
3858
3859 2005-03-07  Wim Taymans  <wim@fluendo.com>
3860
3861         * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new),
3862         (gst_list_iterator_next), (gst_list_iterator_resync),
3863         (gst_list_iterator_free), (gst_iterator_new_list),
3864         (gst_iterator_pop), (gst_iterator_next), (gst_iterator_resync),
3865         (gst_iterator_free), (gst_iterator_push), (filter_next),
3866         (filter_resync), (filter_uninit), (filter_free),
3867         (gst_iterator_filter), (gst_iterator_fold), (foreach_fold_func),
3868         (gst_iterator_foreach), (find_custom_fold_func),
3869         (gst_iterator_find_custom):
3870         * gst/gstiterator.h:
3871         Added missing files.
3872
3873 2005-03-07  Wim Taymans  <wim@fluendo.com>
3874
3875         * Makefile.am:
3876         * configure.ac:
3877         * docs/design/part-MT-refcounting.txt:
3878         * docs/design/part-conventions.txt:
3879         * docs/design/part-gstobject.txt:
3880         * docs/design/part-relations.txt:
3881         * examples/mixer/mixer.c: (main):
3882         * examples/thread/thread.c: (eos), (main):
3883         * gst/Makefile.am:
3884         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_caps_intersect):
3885         * gst/autoplug/gstspider.c: (gst_spider_identity_plug),
3886         (gst_spider_plug_from_srcpad):
3887         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_getcaps),
3888         (gst_spider_identity_change_state),
3889         (gst_spider_identity_sink_loop_type_finding):
3890         * gst/elements/gstfakesrc.c: (gst_fakesrc_loop):
3891         * gst/elements/gstidentity.c: (gst_identity_init):
3892         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_getcaps),
3893         (gst_tee_link), (gst_tee_request_new_pad), (gst_tee_chain):
3894         * gst/elements/gsttypefindelement.c: (free_entry):
3895         * gst/gst.c:
3896         * gst/gst.h:
3897         * gst/gstbin.c: (gst_bin_init), (gst_bin_get_clock_func),
3898         (gst_bin_set_clock_func), (gst_bin_auto_clock),
3899         (gst_bin_set_index), (gst_bin_set_element_sched),
3900         (gst_bin_unset_element_sched), (gst_bin_add_func), (gst_bin_add),
3901         (gst_bin_remove_func), (gst_bin_remove), (iterate_child),
3902         (gst_bin_iterate_elements), (iterate_child_recurse),
3903         (gst_bin_iterate_recurse), (gst_bin_dispose), (compare_name),
3904         (gst_bin_get_by_name), (gst_bin_get_by_name_recurse_up),
3905         (compare_interface), (gst_bin_get_by_interface),
3906         (gst_bin_iterate_all_by_interface), (gst_bin_iterate_func):
3907         * gst/gstbin.h:
3908         * gst/gstbuffer.c: (gst_buffer_get_type), (_gst_buffer_sub_free),
3909         (gst_buffer_default_free), (gst_buffer_default_copy),
3910         (gst_buffer_new), (gst_buffer_get_caps), (gst_buffer_set_caps),
3911         (gst_buffer_create_sub):
3912         * gst/gstbuffer.h:
3913         * gst/gstcaps.c: (gst_caps_get_type), (gst_caps_new_empty),
3914         (_gst_caps_free), (gst_caps_make_writable), (gst_caps_ref),
3915         (gst_caps_unref), (gst_static_caps_get),
3916         (gst_caps_remove_and_get_structure), (gst_caps_append),
3917         (gst_caps_append_structure), (gst_caps_remove_structure),
3918         (gst_caps_copy_nth), (gst_caps_set_simple),
3919         (gst_caps_set_simple_valist), (gst_caps_is_fixed_foreach),
3920         (gst_structure_is_equal_foreach), (gst_caps_is_subset),
3921         (gst_caps_structure_intersect_field), (gst_caps_intersect),
3922         (gst_caps_structure_subtract_field), (gst_caps_subtract),
3923         (gst_caps_normalize_foreach), (gst_caps_compare_structures),
3924         (gst_caps_structure_figure_out_union),
3925         (gst_caps_switch_structures), (gst_caps_do_simplify),
3926         (gst_caps_replace), (gst_caps_from_string),
3927         (gst_caps_copy_conditional):
3928         * gst/gstcaps.h:
3929         * gst/gstclock.c: (gst_clock_entry_new), (gst_clock_id_ref),
3930         (_gst_clock_id_free), (gst_clock_id_unref),
3931         (gst_clock_id_compare_func), (gst_clock_id_wait),
3932         (gst_clock_id_wait_async), (gst_clock_class_init),
3933         (gst_clock_init), (gst_clock_dispose), (gst_clock_adjust_unlocked),
3934         (gst_clock_get_time), (gst_clock_set_time_adjust),
3935         (gst_clock_set_property), (gst_clock_get_property):
3936         * gst/gstclock.h:
3937         * gst/gstcompat.h:
3938         * gst/gstcpu.c: (_gst_cpu_initialize_i386), (gst_cpu_get_flags):
3939         * gst/gstdata.c: (gst_data_is_writable), (gst_data_copy_on_write):
3940         * gst/gstdata.h:
3941         * gst/gstelement.c: (gst_element_class_init), (gst_element_init),
3942         (gst_element_requires_clock), (gst_element_provides_clock),
3943         (gst_element_set_clock), (gst_element_clock_wait),
3944         (gst_element_wait), (gst_element_set_time_delay),
3945         (gst_element_is_indexable), (gst_element_add_pad),
3946         (gst_element_add_ghost_pad), (gst_element_remove_pad),
3947         (pad_compare_name), (gst_element_get_static_pad),
3948         (gst_element_request_pad), (gst_element_get_request_pad),
3949         (gst_element_get_pad), (iterate_pad), (gst_element_iterate_pads),
3950         (gst_element_class_get_pad_template_list),
3951         (gst_element_class_get_pad_template), (gst_element_error_func),
3952         (gst_element_get_random_pad), (gst_element_get_event_masks),
3953         (gst_element_send_event), (gst_element_seek),
3954         (gst_element_get_query_types), (gst_element_query),
3955         (gst_element_get_formats), (gst_element_convert),
3956         (gst_element_is_locked_state), (gst_element_set_locked_state),
3957         (gst_element_sync_state_with_parent), (gst_element_change_state),
3958         (gst_element_finalize), (gst_element_yield),
3959         (gst_element_interrupt), (gst_element_set_scheduler),
3960         (gst_element_get_scheduler), (gst_element_set_loop_function):
3961         * gst/gstelement.h:
3962         * gst/gstevent.h:
3963         * gst/gstformat.c: (_gst_format_initialize), (gst_format_register),
3964         (gst_format_get_by_nick), (gst_format_get_details),
3965         (gst_format_iterate_definitions):
3966         * gst/gstformat.h:
3967         * gst/gstindex.c: (gst_index_gtype_resolver):
3968         * gst/gstinfo.c:
3969         * gst/gstinfo.h:
3970         * gst/gstmemchunk.c: (gst_mem_chunk_alloc), (gst_mem_chunk_alloc0),
3971         (gst_mem_chunk_free):
3972         * gst/gstobject.c: (gst_object_class_init), (gst_object_init),
3973         (gst_object_ref), (gst_object_unref), (gst_object_sink),
3974         (gst_object_replace), (gst_object_dispose), (gst_object_finalize),
3975         (gst_object_dispatch_properties_changed),
3976         (gst_object_set_name_default), (gst_object_set_name),
3977         (gst_object_get_name), (gst_object_set_name_prefix),
3978         (gst_object_get_name_prefix), (gst_object_set_parent),
3979         (gst_object_get_parent), (gst_object_unparent),
3980         (gst_object_check_uniqueness), (gst_object_save_thyself),
3981         (gst_object_restore_thyself), (gst_object_real_restore_thyself),
3982         (gst_object_set_property), (gst_object_get_property),
3983         (gst_object_get_path_string):
3984         * gst/gstobject.h:
3985         * gst/gstpad.c: (gst_pad_dispose), (gst_real_pad_class_init),
3986         (gst_real_pad_init), (gst_real_pad_get_property),
3987         (gst_pad_custom_new), (gst_pad_get_direction),
3988         (gst_pad_set_active), (gst_pad_is_active),
3989         (gst_pad_set_event_function), (gst_pad_is_linked),
3990         (gst_pad_link_free), (gst_pad_link_intersect),
3991         (gst_pad_link_fixate), (gst_pad_set_caps),
3992         (gst_pad_try_set_caps_nonfixed), (gst_pad_set_pad_template),
3993         (gst_pad_get_real_parent), (gst_pad_add_ghost_pad),
3994         (gst_pad_remove_ghost_pad), (_gst_pad_default_fixate_foreach),
3995         (gst_pad_link_unnegotiate), (gst_pad_proxy_fixate),
3996         (gst_pad_get_caps), (gst_pad_peer_get_caps),
3997         (gst_pad_get_pad_template_caps), (gst_pad_get_peer),
3998         (gst_pad_realize), (gst_pad_get_allowed_caps),
3999         (gst_real_pad_dispose), (gst_real_pad_finalize),
4000         (gst_pad_collectv), (gst_pad_collect_valist),
4001         (gst_pad_template_dispose), (gst_pad_template_new),
4002         (gst_pad_get_internal_links):
4003         * gst/gstpad.h:
4004         * gst/gstpipeline.c: (gst_pipeline_dispose),
4005         (gst_pipeline_change_state):
4006         * gst/gstpipeline.h:
4007         * gst/gstplugin.c:
4008         * gst/gstpluginfeature.c: (gst_plugin_feature_get_name),
4009         (gst_plugin_feature_set_rank), (gst_plugin_feature_get_rank):
4010         * gst/gstpluginfeature.h:
4011         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
4012         * gst/gstquery.c: (_gst_query_type_initialize),
4013         (gst_query_type_register), (gst_query_type_get_by_nick),
4014         (gst_query_type_get_details), (gst_query_type_iterate_definitions):
4015         * gst/gstquery.h:
4016         * gst/gstqueue.c: (gst_queue_link_sink), (gst_queue_link_src):
4017         * gst/gstscheduler.c: (gst_scheduler_add_element),
4018         (gst_scheduler_factory_create):
4019         * gst/gststructure.c: (gst_structure_set_parent_refcount),
4020         (gst_structure_free), (gst_structure_set_name),
4021         (gst_structure_id_set_value), (gst_structure_set_value),
4022         (gst_structure_set_valist), (gst_structure_remove_field),
4023         (gst_structure_remove_fields),
4024         (gst_structure_remove_fields_valist),
4025         (gst_structure_remove_all_fields), (gst_structure_foreach),
4026         (gst_structure_map_in_place),
4027         (gst_caps_structure_fixate_field_nearest_int),
4028         (gst_caps_structure_fixate_field_nearest_double):
4029         * gst/gststructure.h:
4030         * gst/gstsystemclock.c: (gst_system_clock_class_init),
4031         (gst_system_clock_init), (gst_system_clock_dispose),
4032         (gst_system_clock_async_thread),
4033         (gst_system_clock_id_wait_unlocked), (gst_system_clock_id_wait),
4034         (gst_system_clock_id_wait_async), (gst_system_clock_id_unschedule):
4035         * gst/gstsystemclock.h:
4036         * gst/gsttag.c: (gst_tag_list_add_value_internal),
4037         (gst_tag_list_copy_foreach), (structure_foreach_wrapper):
4038         * gst/gsttaginterface.c:
4039         * gst/gstthread.c: (gst_thread_dispose),
4040         (gst_thread_release_children_locks), (gst_thread_change_state),
4041         (gst_thread_main_loop):
4042         * gst/gsttrashstack.h:
4043         * gst/gsttypefind.c: (gst_type_find_factory_dispose):
4044         * gst/gsttypes.h:
4045         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
4046         (gst_element_request_pad), (gst_element_get_pad_from_template),
4047         (gst_element_request_compatible_pad),
4048         (gst_element_get_compatible_pad_filtered),
4049         (gst_element_get_compatible_pad), (gst_element_state_get_name),
4050         (gst_element_link_pads_filtered), (gst_element_link_filtered),
4051         (gst_element_link_many), (gst_element_link),
4052         (gst_element_link_pads), (gst_element_unlink_pads),
4053         (gst_element_unlink_many), (gst_element_unlink),
4054         (gst_pad_can_link_filtered), (gst_pad_can_link),
4055         (gst_pad_use_fixed_caps), (gst_pad_get_fixed_caps_func),
4056         (gst_object_default_error), (gst_bin_add_many),
4057         (gst_bin_remove_many), (gst_element_populate_std_props),
4058         (gst_element_class_install_std_props), (gst_buffer_merge),
4059         (gst_buffer_stamp), (intersect_caps_func), (gst_pad_proxy_getcaps),
4060         (link_fold_func), (gst_pad_proxy_setcaps):
4061         * gst/gstutils.h:
4062         * gst/gstvalue.c: (gst_value_deserialize_string):
4063         * gst/parse/grammar.y:
4064         * gst/schedulers/gstbasicscheduler.c:
4065         (gst_basic_scheduler_cothreaded_chain),
4066         (gst_basic_scheduler_chain_recursive_add),
4067         (gst_basic_scheduler_pad_link):
4068         * gst/schedulers/gstoptimalscheduler.c:
4069         (get_group_schedule_function),
4070         (gst_opt_scheduler_state_transition),
4071         (gst_opt_scheduler_add_element), (element_get_reachables_func):
4072         * libs/gst/bytestream/bytestream.c:
4073         * libs/gst/dataprotocol/dataprotocol.c:
4074         (gst_dp_header_from_buffer):
4075         * po/nb.po:
4076         * po/ru.po:
4077         * tests/threadstate/threadstate2.c: (eos):
4078         * tools/gst-compprep.c: (main):
4079         * tools/gst-inspect.c: (print_field), (print_element_flag_info),
4080         (print_pad_info), (print_children_info):
4081         * tools/gst-launch.c: (idle_func), (main):
4082         * tools/gst-md5sum.c: (idle_func), (main):
4083         * tools/gst-xmlinspect.c: (print_element_info):
4084         First THREADED backport attempt, focusing on adding locks and
4085         making sure the API is threadsafe. Needs more work. More docs
4086         follow this week.
4087
4088 2005-02-24  Andy Wingo  <wingo@pobox.com>
4089
4090         * tests/bench-complexity.scm:
4091         * tests/complexity.gnuplot: New files, good for running complexity
4092         benchmarks.
4093
4094         * tests/Makefile.am:
4095         * tests/complexity.c: New test, sets up N elements, at each level
4096         teeing into M streams per element. Eeeenteresting.
4097
4098         * tests/mass_elements.gnuplot: gnuplot file for the mass_elements
4099         benchmark. Run as gnuplot mass_elements.gnuplot > foo.ps, after
4100         running bench-mass_elements.scm.
4101
4102         * tests/bench-mass_elements.scm: New script, runs mass_elements
4103         for various numbers of identities, outputting the results to a
4104         file. Requires guile 1.6. Just for testing.
4105
4106 2005-02-23  Thomas Vander Stichele  <thomas at apestaart dot org>
4107
4108         * gst/schedulers/fairscheduler.c:
4109           compile with debug disabled
4110
4111 2005-02-22  Thomas Vander Stichele  <thomas at apestaart dot org>
4112
4113         * configure.ac:
4114           hunting season on 0.9 is now OPEN
4115
4116 2005-02-22  Stefan Kost  <ensonic@users.sf.net>
4117
4118         * docs/libs/tmpl/gstcontrol.sgml:
4119         * docs/libs/tmpl/gstdparam.sgml:
4120         * docs/libs/tmpl/gstdplinint.sgml:
4121         * docs/libs/tmpl/gstdpman.sgml:
4122         * docs/libs/tmpl/gstdpsmooth.sgml:
4123         * docs/libs/tmpl/gstunitconvert.sgml:
4124           more docs for the state of dparams
4125
4126 2005-02-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4127
4128         * gst/gstelementfactory.c: (gst_element_factory_create):
4129         * gst/gstobject.c: (gst_object_init),
4130         (gst_object_set_name_default), (gst_object_set_name):
4131           name objects by default, not in gst_element_factory_create. Allows
4132           using elements created with g_object_new. (fixes #167283)
4133
4134 2005-02-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4135
4136         * gst/gstinfo.c: (_gst_debug_init), (gst_debug_log_default):
4137           make the time that debugging functions print relative to when
4138           gst_init was called
4139
4140 2005-02-18  Tim-Philipp Müller  <tim at centricular dot net>
4141
4142         * gst/gsttaginterface.c:
4143           Fix inline docs: tag setter vararg functions are NULL-terminated,
4144           GST_TAG_INVALID doesn't exist any more.
4145
4146 2005-02-18  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
4147
4148         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_dump_byte_array):
4149         Allocate the 1 byte more memory that was forgotten!!!!!
4150         fixes memory corruption on 64bit platforms
4151
4152 2005-02-15  Stefan Kost  <ensonic@users.sf.net>
4153
4154         * docs/pwg/building-pads.xml:
4155         * docs/pwg/intro-basics.xml:
4156           fixed a few typos, relabeled introductionary list of types
4157         * docs/random/ensonic/dparams.txt:
4158           more notes abut dparam changes
4159         * libs/gst/control/dparam.c: (gst_dparam_attach):
4160         * libs/gst/control/dparammanager.c:
4161         * libs/gst/control/dparammanager.h:
4162           - many comments and notes on dparam implementation
4163           - new dparams are were not initialized to the default value
4164             from param spec
4165
4166 2005-02-14  Thomas Vander Stichele  <thomas at apestaart dot org>
4167
4168         submitted by: Peter Astakhov
4169
4170         * po/LINGUAS:
4171         * po/ru.po:
4172           adding Russian translation
4173
4174 2005-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
4175
4176         * configure.ac:
4177         * docs/gst/Makefile.am:
4178         * docs/libs/Makefile.am:
4179           make sure popt is added to gtk-doc flags.  Fixes #147782.
4180
4181 2005-02-09  Tim-Philipp Müller  <tim at centricular dot net>
4182
4183         * docs/faq/using.xml:
4184           Fix typo in FAQ (artssink => artsdsink)
4185
4186 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4187
4188         * tools/gst-launch.1.in:
4189           Fix typo (#166699).
4190
4191 2005-02-08  Tim-Philipp Müller  <tim at centricular dot net>
4192
4193         * docs/faq/using.xml:
4194           Add -v argument to fakesrc/fakesink gst-launch line,
4195           so that the promised output will actually show up.
4196
4197 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4198
4199         * gst/gstthread.c: (gst_thread_change_state):
4200           Implement state-change error handling (#166073).
4201
4202 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4203
4204         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
4205           Release interrupt after handling (#166250).
4206
4207 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
4208
4209         * configure.ac:
4210           back to HEAD
4211
4212 === release 0.8.9 ===
4213
4214 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
4215
4216         * NEWS:
4217         * RELEASE:
4218         * configure.ac:
4219           releasing 0.8.9, "Like Eating Glass"
4220
4221 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
4222
4223         submitted by: Clytie Siddall
4224
4225         * po/vi.po: Added Vietnamese translation
4226
4227 2005-02-07  Thomas Vander Stichele  <thomas at apestaart dot org>
4228
4229         patch by: Tim Philipp-Müller
4230
4231         * configure.ac:
4232         * gst/gstpad.c:
4233           unref data when probe function returns FALSE.  Fixes #166362
4234
4235 2005-02-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4236
4237         * gst/gst.c: (gst_init_get_popt_table):
4238           Fix typo (#166269).
4239
4240 2005-02-04  Andy Wingo  <wingo@pobox.com>
4241
4242         * gst/gstelement.c (gst_element_get_compatible_pad_template): Fix
4243         the debugging on whether the caps are compatible.
4244
4245 2005-02-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4246
4247         * docs/manual/basics-elements.xml:
4248           Fix two typos.
4249
4250 2005-02-02  Wim Taymans  <wim@fluendo.com>
4251
4252         * gst/schedulers/gstoptimalscheduler.c: (remove_decoupled),
4253         (schedule_chain), (get_invalid_call), (chain_invalid_call),
4254         (loop_group_schedule_function), (gst_opt_scheduler_iterate):
4255         Remove some FIXMEs after analysing and commenting why they
4256         are not issues.
4257
4258 2005-02-02  Wim Taymans  <wim@fluendo.com>
4259
4260         * gst/schedulers/gstoptimalscheduler.c:
4261         (gst_opt_scheduler_class_init), (gst_opt_scheduler_init),
4262         (gst_opt_scheduler_finalize), (remove_decoupled), (schedule_chain),
4263         (get_invalid_call), (chain_invalid_call),
4264         (get_group_schedule_function), (loop_group_schedule_function),
4265         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
4266         (gst_opt_scheduler_state_transition),
4267         (gst_opt_scheduler_add_element),
4268         (gst_opt_scheduler_remove_element), (gst_opt_scheduler_interrupt),
4269         (gst_opt_scheduler_error), (gst_opt_scheduler_pad_link),
4270         (gst_opt_scheduler_pad_unlink), (gst_opt_scheduler_iterate),
4271         (gst_opt_scheduler_show):
4272         Added lock to protect scheduler data structures.
4273
4274 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4275
4276         * testsuite/threads/threadi.c: (cb_data):
4277           Fix buglet in test.
4278
4279 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4280
4281         * testsuite/threads/Makefile.am:
4282         * testsuite/threads/threadi.c: (cb_data), (cb_play), (main):
4283           On Wim's request, split the test in three separately-compiled
4284           tests that each test a very specific bug. Two of them still fail,
4285           will create bugs for those. threadi.c indicates why they fail.
4286
4287 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4288
4289         * gst/schedulers/gstoptimalscheduler.c:
4290         (get_group_schedule_function):
4291           Try to work with the threading mess that queue_link is.
4292
4293 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4294
4295         * gst/gstbin.c: (gst_bin_remove_func):
4296           Explicitely make an element release locks in a group when being
4297           remove from a bin.
4298         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
4299           If there's no scheduler, always return immediately (similar to
4300           gst_element_interrupt).
4301
4302 2005-01-31  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4303
4304         * gst/gstbin.c: (gst_bin_child_state_change_func):
4305           Remove a piece of code that could never be reached.
4306         * docs/gst/gstreamer-sections.txt:
4307         * gst/gstpad.c: (gst_pad_push), (gst_pad_pull),
4308         (gst_pad_call_get_function):
4309         * gst/gstpad.h:
4310         * testsuite/pad/Makefile.am:
4311           Fix #150546, enable tests.
4312
4313 2005-01-31  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4314
4315         * docs/pwg/advanced-types.xml:
4316           Fix description for buffer-frames=0.
4317         * docs/gst/tmpl/gstbin.sgml:
4318         * gst/gstbin.c: (gst_bin_child_state_change_func),
4319         (gst_bin_change_state), (gst_bin_change_state_norecurse):
4320         * gst/gstbin.h:
4321         * testsuite/threads/Makefile.am:
4322         * testsuite/threads/threadi.c: (cb_timeout), (cb_quit), (cb_eos),
4323         (cb_state), (cb_play), (main):
4324           Fix non-recursive state changes to *really* change the state
4325           of the object, and not just call parent_class->state_change.
4326           Fix a lot of lockups caused by this. Fixes #132775. Add test
4327           for the problem. Also enable test to show #142588 (fixed).
4328         * gst/gstthread.c: (gst_thread_change_state),
4329         (gst_thread_child_state_change):
4330           Don't exit the thread if we go to NULL and are inside thread
4331           context. Instead, return control to the main thread context
4332           and exit from there.
4333         * gst/gstelement.c: (gst_element_disable_threadsafe_properties):
4334           Don't unset virtual functions, since those may still be used.
4335           That's not necessarily correct, but suffices for now.
4336         * configure.ac:
4337         * testsuite/Makefile.am:
4338         * testsuite/pad/Makefile.am:
4339         * testsuite/pad/chainnopull.c: (gst_test_sink_class_init),
4340         (gst_test_sink_base_init), (gst_test_sink_chain),
4341         (gst_test_sink_init), (main):
4342         * testsuite/pad/getnopush.c: (gst_test_src_class_init),
4343         (gst_test_src_base_init), (gst_test_src_get), (gst_test_src_init),
4344         (main):
4345         * testsuite/pad/link.c: (gst_test_element_class_init),
4346         (gst_test_element_base_init), (gst_test_src_get),
4347         (gst_test_src_loop), (gst_test_src_init), (gst_test_filter_chain),
4348         (gst_test_filter_loop), (gst_test_filter_init),
4349         (gst_test_sink_chain), (gst_test_sink_loop), (gst_test_sink_init),
4350         (cb_error), (main):
4351           Add tests to show #150546. Pass, but should fail (currently
4352           disabled from the testsuite).
4353         * gst/gstscheduler.c: (gst_scheduler_dispose):
4354           Dereference child schedulers on dispose (#94464).
4355         * testsuite/bytestream/filepadsink.c: (gst_fp_sink_init):
4356           Fix typo.
4357         * testsuite/threads/thread.c: (main):
4358           Add more debug.
4359
4360 2005-01-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4361
4362         * gst/gstpad.c: (gst_pad_push):
4363           Oops, revert previous commit, broke testsuite...
4364
4365 2005-01-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4366
4367         * gst/gstpad.c: (gst_pad_push):
4368           Add check that the pad on which the push is performed is not a
4369           get-based pad (#150546).
4370
4371 2005-01-28  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4372
4373         * gst/elements/gsttypefindelement.c:
4374         (gst_type_find_element_handle_event):
4375           Fix buffer pushing if stream EOSes during typefinding.
4376
4377 2005-01-28  Edward Hervey  <bilboed@bilboed.com>
4378
4379         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4380
4381         * gst/gstvalue.c: (gst_string_wrap):
4382           Allow NULL-strings as argument (#165365).
4383
4384 2005-01-27  Stephane Wirtel  <stephane.wirtel@belgacom.net>
4385
4386         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4387
4388         * gst/schedulers/faircothreads.c:
4389         (gst_fair_scheduler_cothread_queue_show):
4390           Fix build without debug enabled.
4391
4392 2005-01-26  Stefan Kost  <ensonic@users.sf.net>
4393
4394         * docs/gst/gstreamer-sections.txt:
4395         * docs/libs/gstreamer-libs-docs.sgml:
4396         * docs/libs/gstreamer-libs-sections.txt:
4397         * docs/libs/tmpl/gstcontrol.sgml:
4398         * docs/libs/tmpl/gstdparam.sgml:
4399         * docs/libs/tmpl/gstdplinint.sgml:
4400         * docs/libs/tmpl/gstdpman.sgml:
4401         * docs/libs/tmpl/gstdpsmooth.sgml:
4402         * docs/libs/tmpl/gstputbits.sgml:
4403         * docs/libs/tmpl/gstunitconvert.sgml:
4404         * libs/gst/control/dparam.c:
4405         * libs/gst/control/dparam.h:
4406         * libs/gst/control/dparammanager.c:
4407         (gst_dpman_add_required_dparam_callback),
4408         (gst_dpman_add_required_dparam_direct),
4409         (gst_dpman_add_required_dparam_array),
4410         (gst_dpman_remove_required_dparam), (gst_dpman_attach_dparam),
4411         (gst_dpman_get_dparam), (gst_dpman_get_dparam_type),
4412         (gst_dpman_get_manager)
4413           restructured DParam docs
4414
4415 2005-01-25  Tim-Philipp Müller  <tim at centricular dot net>
4416
4417         * gst-element-check.m4:
4418           Only check for gst-inspect if we haven't already
4419           found it in previous element check runs
4420
4421 2005-01-25  Stefan Kost  <ensonic@users.sf.net>
4422
4423         * docs/gst/Makefile.am:
4424         * docs/libs/Makefile.am:
4425           fixed install rules to treat style.css as optional
4426
4427 2005-01-24  Stefan Kost  <ensonic@users.sf.net>
4428
4429         * docs/gst/Makefile.am:
4430         * docs/libs/Makefile.am:
4431           install style.css along with docs
4432         * docs/gst/tmpl/gstbin.sgml:
4433         * docs/gst/tmpl/gstclock.sgml:
4434         * docs/gst/tmpl/gstdata.sgml:
4435         * docs/gst/tmpl/gstelement.sgml:
4436         * gst/gstbin.h:
4437         * gst/gstelement.c: (gst_element_class_init):
4438         * gst/gstelement.h:
4439           fixing incomplete docs
4440
4441 2005-01-24  Tim-Philipp Müller  <tim at centricular dot net>
4442
4443         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
4444           Don't unref seek event twice when fflush() fails
4445           
4446 2005-01-22  David Schleef  <ds@schleef.org>
4447
4448         * configure.ac: Add --disable-valgrind. (partial fix for #164890)
4449
4450 2005-01-21  Stefan Kost  <ensonic@users.sf.net>
4451
4452         * docs/gst/Makefile.am:
4453         * docs/libs/Makefile.am:
4454           added params for deprecation guards
4455         * gst/gst.c:
4456         * gst/gst.h:
4457         * gst/gsterror.c: (_gst_resource_errors_init),
4458         (_gst_stream_errors_init):
4459         * gst/gsterror.h:
4460           documented some more enums
4461
4462 2005-01-19  Jan Schmidt  <thaytan@mad.scientist.com>
4463         * gst/autoplug/gstspideridentity.c:
4464         Cosmetic fix - spider_find_peek should be static
4465         * gst/parse/parse.l:
4466         Applying fix for #164261
4467
4468 2005-01-18  Stefan Kost  <ensonic@users.sf.net>
4469
4470         * docs/gst/gstreamer-sections.txt:
4471         * docs/gst/tmpl/gstplugin.sgml:
4472         * docs/libs/gstreamer-libs-sections.txt:
4473         * docs/libs/tmpl/gstcontrol.sgml:
4474         * gst/gstbuffer.h:
4475         * gst/gsttag.h:
4476         * gst/gstvalue.c:
4477           added docs for the TAG defines
4478
4479 2005-01-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4480
4481         * gst/schedulers/gstoptimalscheduler.c: (schedule_group):
4482           Only unref entry if there is an entry.
4483
4484 2005-01-17  Wim Taymans  <wim@fluendo.com>
4485
4486         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
4487         (remove_from_group), (schedule_group), (normalize_group),
4488         (gst_opt_scheduler_iterate):
4489         Also ref/unref decoupled elements before iterating the
4490         group since they are not added to the list of elements.
4491
4492 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4493
4494         * docs/manual/highlevel-components.xml:
4495           Add subtitle/streamselection as new features to playbin.
4496
4497 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4498
4499         * docs/manual/manual.xml:
4500           Re-enable dataaccess docs (oops).
4501
4502 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4503
4504         * docs/pwg/advanced-types.xml:
4505         * docs/random/mimetypes:
4506           Add documentation on libsndfile types (#163309), by Steve Baker
4507           <steve@stevebaker.org>.
4508         * gst/gstelement.c: (gst_element_release_request_pad):
4509           If an element has no explicit function, just remove the pad.
4510
4511 2005-01-17  Luca Ognibene  <luogni@tin.it>
4512
4513         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4514
4515         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load):
4516           Fix memleak (#163801).
4517
4518 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4519
4520         * gst/elements/gsttee.c: (gst_tee_getcaps), (gst_tee_link):
4521           I think this is actually more correct...
4522
4523 2005-01-16  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4524
4525         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
4526           Another workaround for memory access while destroyed in callback.
4527           Please, someone with refcount knowledge, have a look at this.
4528
4529 2005-01-15  Thomas Vander Stichele  <thomas at apestaart dot org>
4530
4531         * docs/faq/faq.xml:
4532         * docs/faq/legal.xml:
4533           move the legal Q&A here
4534
4535 2005-01-14  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4536
4537         * gst/elements/gsttee.c: (gst_tee_getcaps), (gst_tee_link),
4538         (gst_tee_request_new_pad):
4539           Fix negotiation.
4540
4541 2005-01-14  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
4542
4543         * docs/random/omega/caps2:
4544         * testsuite/caps/caps_strings:
4545           replace framerate aproximations by their real value
4546           (24000/1001, 30000/1001, 60000/1001)
4547           Partially fixes bug #164049
4548
4549 2005-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
4550
4551         * docs/gst/Makefile.am:
4552           don't fail on the stupid GstPoptOption
4553
4554 2005-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
4555
4556         * gst/gstpad.h:
4557         * gst/gstprobe.c:
4558           allow probes to work on ghost pads by realizing the pad
4559           probe debugging
4560
4561 2005-01-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4562
4563         * docs/gst/gstreamer-sections.txt:
4564         * docs/gst/tmpl/gstpad.sgml:
4565         * gst/gstpad.c: (gst_pad_set_active_recursive):
4566         * gst/gstpad.h:
4567           Add gst_pad_set_active_recursive().
4568
4569 2005-01-10  Thomas Vander Stichele  <thomas at apestaart dot org>
4570
4571         * docs/random/release:
4572           updates
4573         * gst/gst_private.h:
4574         * gst/gstinfo.c:
4575         * gst/gstobject.c:
4576           move deep_notify logging to a new category
4577         * gst/gstprobe.c:
4578         * gst/gstprobe.h:
4579           add stuff so bindings can wrap probes
4580
4581 2005-01-09  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
4582
4583         * gst/gstplugin.c: (gst_plugin_load):
4584           Fix plugin loading if plugin/lib was already loaded. Fixes
4585           #163383
4586
4587 2005-01-09  Sebastien Cote  <sc5@hermes.usherb.ca>
4588
4589         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4590
4591         * gst/gstpluginfeature.c: (gst_plugin_feature_ensure_loaded):
4592           Protect plugin loading by a mutex so it's threadsafe. Fixes
4593           #163234.
4594
4595 2005-01-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4596
4597         * gst/gstevent.c: (_gst_event_copy):
4598           Reference source object when copying events, since it'll be
4599           dereferenced on event dereferencing as well.
4600
4601 2005-01-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4602
4603         * docs/gst/gstreamer-sections.txt:
4604         * docs/gst/tmpl/gstevent.sgml:
4605         * gst/gstevent.c: (gst_event_new_filler_stamped),
4606         (gst_event_filler_get_duration):
4607         * gst/gstevent.h:
4608           Add two new functions for filler events (which are used to
4609           synchronize streams if one of them is not having any data
4610           for a while) without interrupting the actual data-stream.
4611           Basically a no-op.
4612         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
4613         (gst_queue_link_sink), (gst_queue_link_src),
4614         (gst_queue_change_state):
4615           Allow for renegotiation while filled. Required for stream
4616           switching while playing.
4617
4618 2005-01-08  Benjamin Otte  <otte@gnome.org>
4619
4620         * gst/gstelement.c: (gst_element_link_many):
4621           fix up g_return_if_fail's
4622         * po/LINGUAS:
4623         * po/de.po:
4624           add German translation, that was somehow not included
4625
4626 2005-01-08  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
4627
4628         * docs/random/mimetypes:
4629           add 2 more 4CC code for DV (HDTV and SDTV-LongPlay profiles)
4630           do not add them to riff-lib as they are not common
4631
4632 2005-01-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4633
4634         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
4635           Check for existence of probe after performing the probe before
4636           re-accessing it to prevent segfaults caused by removal of the
4637           probe in the callback.
4638
4639 2005-01-05  David Schleef  <ds@schleef.org>
4640
4641         * testsuite/registry/Makefile.am:
4642         * testsuite/registry/gst-print-formats.c:
4643         (print_pad_templates_info), (print_element_list),
4644         (print_typefind_list), (list_sort_func), (get_typefind_mime_list),
4645         (g_list_uniqify), (get_pad_templates_info),
4646         (get_element_mime_list), (print_mime_list), (main): A little
4647         program that looks through the registry to find elements of
4648         a given type.  Not particularly interesting as a test, except
4649         that there's no other test covering the same area.
4650
4651 2005-01-05  David Schleef  <ds@schleef.org>
4652
4653         * tools/gst-launch.c: (idle_func), (fault_handler_sighandler),
4654         (fault_handler_sigaction), (fault_spin),
4655         (sigint_handler_sighandler), (play_handler), (main): Fix deadlocks
4656         in signal.h-type signal handlers by not calling forbidden functions,
4657         including gst_element_set_state().
4658
4659 2005-01-05  David Schleef  <ds@schleef.org>
4660
4661         * gst/gstvalue.h: Mark _gst_reserved[] as private
4662
4663 2005-01-05  David Schleef  <ds@schleef.org>
4664
4665         * gst/gstvalue.c: Fix doc build problem.
4666
4667 2005-01-05  David Schleef  <ds@schleef.org>
4668
4669         * gst/gstvalue.c: Add some documentation
4670
4671 2005-01-05  Stefan Kost  <ensonic@users.sf.net>
4672
4673         * docs/README:
4674           another shell oneliner for empty return value docs
4675         * gst/gstcaps.c:
4676         * gst/gstvalue.c:
4677         * libs/gst/control/dparam.c:
4678           more doc fixes (parameters and return values)
4679
4680 2005-01-05  Vincent Torri  <torri@iecn.u-nancy.fr>
4681
4682         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4683
4684         * gst/gstregistry.h:
4685         * gst/registries/gstxmlregistry.c:
4686           Fix macro's for Mingw (fixes #162276).
4687
4688 2005-01-04  Stefan Kost  <ensonic@users.sf.net>
4689
4690         * docs/README:
4691           quick shell oneliner to find undocumented members
4692         * docs/gst/tmpl/gstplugin.sgml:
4693         * docs/gst/tmpl/gstscheduler.sgml:
4694         * docs/gst/tmpl/gstthread.sgml:
4695           more enumtypes cleanup
4696         * gst/gsterror.h:
4697           activated documentation comments, now someone needs to document
4698           the enums :(
4699
4700 2005-01-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4701
4702         * docs/manual/manual.xml:
4703           Add dataaccess part (doh!).
4704
4705 2005-01-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4706
4707         * docs/manual/advanced-autoplugging.xml:
4708           Fix typo (intiate -> initiate).
4709
4710 2005-01-02  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4711
4712         * docs/random/bbb/streamselection:
4713           Add some notes on how to handle multi-subtitle/-audio streams.
4714
4715 2004-12-30  Stefan Kost  <ensonic@users.sf.net>
4716
4717         * docs/gst/gstreamer-docs.sgml:
4718         * docs/gst/gstreamer-sections.txt:
4719         * docs/gst/tmpl/gstenumtypes.sgml:
4720         * docs/gst/tmpl/gsterror.sgml:
4721         * docs/gst/tmpl/gstevent.sgml:
4722         * docs/gst/tmpl/gstpad.sgml:
4723         * docs/gst/tmpl/gstpadtemplate.sgml:
4724         * docs/gst/tmpl/gstthread.sgml:
4725           removed gstenumtypes section from docs and put all the enums into
4726           their sections
4727
4728 2004-12-27  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
4729
4730         * gst/gstplugin.c:
4731           document gst_library_load a bit more (riff special case + return
4732           value if already loaded)
4733         * testsuite/bytestream/filepadsink.c:
4734           plugin name is 'gstbytestream', not 'bytestream'
4735
4736 2004-12-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4737
4738         * docs/random/bbb/subtitles:
4739           Add some first mind rumblings on proper subtitle support.
4740
4741 2004-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
4742
4743         * po/ca.po:
4744         * po/sv.po:
4745           updated translations
4746
4747 2004-12-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4748
4749         * docs/manual/advanced-dataaccess.xml:
4750           Add section on how to use fakesrc/fakesink/identity in your
4751           application, plus section on how to embed plugins. Also mention
4752           probes.
4753         * docs/manual/appendix-checklist.xml:
4754         * docs/manual/appendix-debugging.xml:
4755         * docs/manual/appendix-gnome.xml:
4756         * docs/manual/appendix-integration.xml:
4757           Debug -> checklist, GNOME -> integration, add sections on Linux,
4758           KDE integration and add other things useful for application
4759           development.
4760         * docs/manual/manual.xml:
4761           Remove some fixmes, update some file pointers.
4762         * docs/pwg/appendix-checklist.xml:
4763           Fix typo.
4764         * docs/pwg/building-boiler.xml:
4765           Remove ugly header and add commented fixme.
4766         * docs/pwg/pwg.xml:
4767           Add fixme.
4768         * examples/manual/Makefile.am:
4769           Add example for added docs.
4770
4771 2004-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
4772
4773         * configure.ac:
4774           back to HEAD
4775
4776 === release 0.8.8 ===
4777
4778 2004-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
4779
4780         * NEWS:
4781         * RELEASE:
4782         * configure.ac:
4783           Releasing 0.8.8, "I'll Take Care Of You"
4784
4785 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
4786
4787         * configure.ac:
4788           second prerelease
4789
4790 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
4791
4792         patch by: Wim Taymans
4793
4794         * gst/gstbin.c:
4795           Fix for #159852 - make iterate emission threadsafe
4796
4797 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
4798
4799         * docs/faq/cvs.xml:
4800           notes about new fdo account request
4801
4802 2004-12-20  Stefan Kost  <ensonic@users.sf.net>
4803
4804         * docs/gst/gstreamer-docs.sgml:
4805         * docs/gst/tmpl/gstenumtypes.sgml:
4806         * docs/gst/tmpl/gstplugin.sgml:
4807         * docs/libs/gstreamer-libs-docs.sgml:
4808           Added missing short docs. Added ids for navigation.
4809
4810 2004-12-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4811
4812         * docs/manual/advanced-autoplugging.xml:
4813         * docs/manual/advanced-schedulers.xml:
4814         * docs/manual/advanced-threads.xml:
4815           Rewrites. Remove cothreads, go a bit into opt specifically,
4816           document threads and their gotchas, and do some technical stuff
4817           on autoplugging plus add some working examples. Fixes #157395.
4818         * examples/manual/Makefile.am:
4819           Add typefind/autoplugger example (one that actually works).
4820           Remove queue example since it's a duplicate of the thread one.
4821
4822 2004-12-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4823
4824         * gst/gstvalue.c: (gst_value_deserialize_string):
4825           use deprecated g_value_set_string_take_ownership to keep compatible
4826           with glib 2.2
4827
4828 2004-12-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4829
4830         * gst/gstvalue.c: (gst_value_deserialize_string):
4831           revert last patch, only dom a g_utf8_validate now before accepting
4832           the string - caps parsing strips " from strings so we can't rely on
4833           them
4834         * testsuite/caps/value_serialize.c: (test_string_deserialization):
4835           disable a test that tested the above and comment it
4836
4837 2004-12-16  Steve Lhomme <steve.lhomme@free.fr>
4838
4839         Patch reviewed by David Schleef  <ds@schleef.org>
4840
4841         * win32/gstenumtypes.c: Update from gst/gstenumtypes.c (See
4842         bug #153882)
4843         * win32/gstenumtypes.h: same
4844
4845 2004-12-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4846
4847         * gst/gstpad.c: (gst_pad_query):
4848           Do query on realized pad, similar to how convert/send_event handle
4849           this. Also makes sense, since this pad belongs to the function to
4850           which this query will be sent. Fixes #158163.
4851
4852 2004-12-16  Christian Fredrik Kalager Schaller  <uraeus@gnome.org>
4853
4854         * docs/manual/appendix-programs.xml: fix pipeline to actually work
4855
4856 2004-12-16  Christian Fredrik Kalager Schaller  <christian@fluendo.com>
4857
4858         * docs/faq/general.xml: fix pipeline to actually work
4859
4860 2004-12-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4861
4862         * gst/gstvalue.c: (gst_value_deserialize_string):
4863           check that a simple string that gets deserialized does not contain
4864           invalid characters
4865         * testsuite/caps/value_serialize.c: (test_string_deserialization):
4866           remove a test that tested a wring behaviour
4867
4868 2004-12-16  Matt Kraai  <kraai@alumni.cmu.edu>
4869
4870         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4871
4872         * docs/manual/intro-motivation.xml:
4873           Fix typos.
4874
4875 2004-12-16  Edward Hervey  <bilboed@bilboed.com>
4876
4877         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4878
4879         * docs/gst/tmpl/gstprobe.sgml:
4880           Fix documentation of probe callback - it is supposed to return
4881           FALSE, not TRUE, to remove data from the stream (#159087).
4882
4883 2004-12-16  Daniel Gazard  <dany42@free.fr>
4884
4885         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4886
4887         * gst/gstelementfactory.c: (gst_element_factory_create):
4888           Fix compile failure if compiling without libxml2 support (#149936).
4889
4890 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4891
4892         * docs/manual/advanced-autoplugging.xml:
4893         * docs/manual/highlevel-components.xml:
4894           Move spider from autoplugging to components. Autoplugging is for
4895           internals, not for solutions. ;-).
4896
4897 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4898
4899         * docs/random/ds/0.9-suggested-changes:
4900           Make note on device/location/uri property names.
4901
4902 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4903
4904         * docs/manual/advanced-autoplugging.xml:
4905         * docs/manual/advanced-clocks.xml:
4906         * docs/manual/advanced-interfaces.xml:
4907         * docs/manual/advanced-metadata.xml:
4908         * docs/manual/advanced-position.xml:
4909         * docs/manual/advanced-schedulers.xml:
4910         * docs/manual/advanced-threads.xml:
4911         * docs/manual/appendix-gnome.xml:
4912         * docs/manual/appendix-programs.xml:
4913         * docs/manual/appendix-quotes.xml:
4914         * docs/manual/autoplugging.xml:
4915         * docs/manual/basics-bins.xml:
4916         * docs/manual/basics-data.xml:
4917         * docs/manual/basics-elements.xml:
4918         * docs/manual/basics-helloworld.xml:
4919         * docs/manual/basics-init.xml:
4920         * docs/manual/basics-pads.xml:
4921         * docs/manual/basics-plugins.xml:
4922         * docs/manual/bins-api.xml:
4923         * docs/manual/bins.xml:
4924         * docs/manual/buffers-api.xml:
4925         * docs/manual/buffers.xml:
4926         * docs/manual/clocks.xml:
4927         * docs/manual/components.xml:
4928         * docs/manual/cothreads.xml:
4929         * docs/manual/debugging.xml:
4930         * docs/manual/dparams-app.xml:
4931         * docs/manual/dynamic.xml:
4932         * docs/manual/elements-api.xml:
4933         * docs/manual/elements.xml:
4934         * docs/manual/factories.xml:
4935         * docs/manual/gnome.xml:
4936         * docs/manual/goals.xml:
4937         * docs/manual/helloworld.xml:
4938         * docs/manual/helloworld2.xml:
4939         * docs/manual/highlevel-components.xml:
4940         * docs/manual/highlevel-xml.xml:
4941         * docs/manual/init-api.xml:
4942         * docs/manual/intro-basics.xml:
4943         * docs/manual/intro-motivation.xml:
4944         * docs/manual/intro-preface.xml:
4945         * docs/manual/intro.xml:
4946         * docs/manual/links-api.xml:
4947         * docs/manual/links.xml:
4948         * docs/manual/manual.xml:
4949         * docs/manual/motivation.xml:
4950         * docs/manual/pads-api.xml:
4951         * docs/manual/pads.xml:
4952         * docs/manual/plugins-api.xml:
4953         * docs/manual/plugins.xml:
4954         * docs/manual/programs.xml:
4955         * docs/manual/queues.xml:
4956         * docs/manual/quotes.xml:
4957         * docs/manual/schedulers.xml:
4958         * docs/manual/states-api.xml:
4959         * docs/manual/states.xml:
4960         * docs/manual/threads.xml:
4961         * docs/manual/typedetection.xml:
4962         * docs/manual/win32.xml:
4963         * docs/manual/xml.xml:
4964           Try 2. This time, include a short preface as a "general
4965           introduction", also add code blocks around all code samples
4966           so they get compiled. We still need a way to tell readers
4967           the filename of the code sample. In some cases, don't show
4968           all code in the documentation, but do include it in the generated
4969           code. This allows for focussing on specific bits in the docs,
4970           while still having a full test application available.
4971         * examples/manual/Makefile.am:
4972           Fix up examples for new ADM. Add several of the new examples that
4973           were either added or were missing from the build system.
4974         * examples/manual/extract.pl:
4975           Allow nameless blocks.
4976
4977 2004-12-15  Thomas Vander Stichele  <thomas at apestaart dot org>
4978
4979         * docs/manual/elements-api.xml:
4980         * docs/manual/helloworld.xml:
4981         * examples/manual/extract.pl:
4982           fix last example.  Add example of adding code blocks that are not
4983           shown in docbook output.
4984
4985 2004-12-15  Thomas Vander Stichele  <thomas at apestaart dot org>
4986
4987         * docs/manual/dynamic.xml:
4988         * docs/manual/elements-api.xml:
4989         * docs/manual/gnome.xml:
4990         * docs/manual/helloworld2.xml:
4991         * docs/manual/init-api.xml:
4992         * docs/manual/queues.xml:
4993         * docs/manual/threads.xml:
4994         * docs/manual/xml.xml:
4995         * examples/manual/extract.pl:
4996           Make it possible to extract example code from separate blocks.
4997           Should make Ronald happy.
4998
4999 2004-12-15  Wim Taymans  <wim@fluendo.com>
5000
5001         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5002         (remove_from_group), (group_elements_set_visited),
5003         (normalize_group), (gst_opt_scheduler_iterate):
5004         Fix bug where a flag was not updated on a decoupled entry point 
5005         because we were just checking the group element list and decoupled
5006         elements are not in that list..
5007
5008 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5009
5010         * docs/manual/advanced-autoplugging.xml:
5011         * docs/manual/advanced-clocks.xml:
5012         * docs/manual/advanced-dparams.xml:
5013         * docs/manual/advanced-interfaces.xml:
5014         * docs/manual/advanced-metadata.xml:
5015         * docs/manual/advanced-position.xml:
5016         * docs/manual/advanced-schedulers.xml:
5017         * docs/manual/advanced-threads.xml:
5018         * docs/manual/appendix-debugging.xml:
5019         * docs/manual/appendix-gnome.xml:
5020         * docs/manual/appendix-programs.xml:
5021         * docs/manual/appendix-quotes.xml:
5022         * docs/manual/appendix-win32.xml:
5023         * docs/manual/autoplugging.xml:
5024         * docs/manual/basics-bins.xml:
5025         * docs/manual/basics-data.xml:
5026         * docs/manual/basics-elements.xml:
5027         * docs/manual/basics-helloworld.xml:
5028         * docs/manual/basics-init.xml:
5029         * docs/manual/basics-pads.xml:
5030         * docs/manual/basics-plugins.xml:
5031         * docs/manual/bins-api.xml:
5032         * docs/manual/bins.xml:
5033         * docs/manual/buffers-api.xml:
5034         * docs/manual/buffers.xml:
5035         * docs/manual/clocks.xml:
5036         * docs/manual/components.xml:
5037         * docs/manual/cothreads.xml:
5038         * docs/manual/debugging.xml:
5039         * docs/manual/dparams-app.xml:
5040         * docs/manual/dynamic.xml:
5041         * docs/manual/elements-api.xml:
5042         * docs/manual/elements.xml:
5043         * docs/manual/factories.xml:
5044         * docs/manual/gnome.xml:
5045         * docs/manual/goals.xml:
5046         * docs/manual/helloworld.xml:
5047         * docs/manual/helloworld2.xml:
5048         * docs/manual/highlevel-components.xml:
5049         * docs/manual/highlevel-xml.xml:
5050         * docs/manual/init-api.xml:
5051         * docs/manual/intro-motivation.xml:
5052         * docs/manual/intro-preface.xml:
5053         * docs/manual/intro.xml:
5054         * docs/manual/links-api.xml:
5055         * docs/manual/links.xml:
5056         * docs/manual/manual.xml:
5057         * docs/manual/motivation.xml:
5058         * docs/manual/pads-api.xml:
5059         * docs/manual/pads.xml:
5060         * docs/manual/plugins-api.xml:
5061         * docs/manual/plugins.xml:
5062         * docs/manual/programs.xml:
5063         * docs/manual/queues.xml:
5064         * docs/manual/quotes.xml:
5065         * docs/manual/schedulers.xml:
5066         * docs/manual/states-api.xml:
5067         * docs/manual/states.xml:
5068         * docs/manual/threads.xml:
5069         * docs/manual/typedetection.xml:
5070         * docs/manual/win32.xml:
5071         * docs/manual/xml.xml:
5072           First try at rewriting the ADM. Needs lotsamore work, but some
5073           parts might already be somewhat useful.
5074         * docs/pwg/advanced-interfaces.xml:
5075           Remove properties interface, it never actually existed (except for
5076           on my HD...).
5077
5078 2004-12-13  David Schleef  <ds@schleef.org>
5079
5080         * gst/gstpad.c: (gst_pad_set_explicit_caps): Allow caps to
5081         be NULL (bug #160220).
5082
5083 2004-12-13  David Schleef  <ds@schleef.org>
5084
5085         * configure.ac: remove all mmx stuff, because it's not used.
5086         * docs/random/ds/0.9-suggested-changes: additional notes
5087         * include/Makefile.am: we don't use these anymore
5088         * include/mmx.h: remove
5089         * include/sse.h: remove
5090
5091 2004-12-13  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
5092
5093         * docs/random/mimetypes:
5094           Add FOURCC code for h264 codec (VSSH)
5095           Add alternate FOURCC codes for h263 related codecs
5096
5097 2004-12-10  Stefan Kost  <ensonic@users.sf.net>
5098
5099         * docs/manual/programs.xml:
5100           Added more gst-launch examples.
5101
5102 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5103
5104         * gst/gstqueue.c: (gst_queue_handle_src_query):
5105           Check for availability again.
5106
5107 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5108
5109         * gst/gstcaps.c: (gst_caps_compare_structures):
5110           Simple caps go first. This has the nice side-effect of fixing an
5111           obscure warning.
5112
5113 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5114
5115         * gst/gstversion.h.in:
5116           Protect header.
5117
5118 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5119
5120         * gst/schedulers/gstoptimalscheduler.c:
5121         (gst_opt_scheduler_schedule_run_queue), (schedule_chain),
5122         (gst_opt_scheduler_get_wrapper):
5123           When we're recursing into a chain run, only run the directly
5124           related group, not all queued ones. This will fix a possible
5125           deadlock in chains with more than two groups.
5126
5127 2004-12-08  Thomas Vander Stichele  <thomas at apestaart dot org>
5128
5129         * autogen.sh:
5130           remove patch if autopoint fails
5131
5132 2004-12-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5133
5134         * docs/gst/gstreamer-sections.txt:
5135           Document Thomas' addition, fix build, make Luis the sheriff happy.
5136
5137 2004-12-07  Thomas Vander Stichele  <thomas at apestaart dot org>
5138
5139         * gst/gstplugin.c:
5140         * gst/gstplugin.h:
5141           add accessor for version field
5142
5143 2004-12-06  Thomas Vander Stichele  <thomas at apestaart dot org>
5144
5145         submitted by: Luca Ferretti <elle.uca@infinito.it>
5146
5147         * po/LINGUAS:
5148         * po/it.po:
5149           New tranlation added: Italian
5150
5151 2004-12-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5152
5153         * gst/gstpad.c: (gst_pad_is_negotiated),
5154         (gst_pad_get_negotiated_caps):
5155           GST_RPAD_* will only operate on a RealPad (it casts the pointer,
5156           it doesn't actually check the contents), so be sure to hand it
5157           a RealPad else we'll crash.
5158
5159 2004-12-03  Wim Taymans  <wim@fluendo.com>
5160
5161         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
5162         (gst_queue_link), (gst_queue_handle_src_query):
5163         Reverted to 1.110 until this makes the testsuite and various
5164         apps work.
5165
5166 2004-12-01  Christian Fredrik Kalager Schaller <christian@fluendo.com>
5167
5168         * docs/upload.mak: fix included CVS conflict strings
5169
5170 2004-12-01  William Jon McCann  <mccann@jhu.edu>
5171
5172         Reviewed by: Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5173
5174         * gst/gstelement.c: (gst_element_error_full):
5175           Use g_error_new_literal because error text may have
5176           percentage signs in it. Fixes #160019.
5177
5178 2004-12-01  Benjamin Otte  <otte@gnome.org>
5179
5180         * gst/elements/gstbufferstore.c:
5181         (gst_buffer_store_add_buffer_func):
5182           don't try to make subbuffers bigger than they can be. (fixes
5183           #159970)
5184
5185 2004-11-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5186
5187         * docs/gst/gstreamer-sections.txt:
5188         * docs/gst/tmpl/gstvalue.sgml:
5189           Add new function to docs to fix build.
5190
5191 2004-11-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5192
5193         * gst/gstcaps.c: (gst_caps_is_fixed_foreach):
5194         * gst/gstpad.c: (_gst_pad_default_fixate_value),
5195         (_gst_pad_default_fixate_foreach):
5196         * gst/gstvalue.c: (gst_type_is_fixed), (gst_value_is_fixed):
5197         * gst/gstvalue.h:
5198           Deprecate _type_is_fixed, use _value_is_fixed instead, since
5199           in some cases (arrays), the fixedness depends on the content.
5200         * gst/gstqueue.c: (gst_queue_handle_src_query):
5201           Check for availability before doing something.
5202
5203 2004-11-29  Wim Taymans  <wim@fluendo.com>
5204
5205         * testsuite/threads/Makefile.am:
5206         * testsuite/threads/signals.c: (gst_test_get_type),
5207         (gst_test_class_init), (gst_test_init), (gst_test_dispose),
5208         (gst_test_set_property), (gst_test_get_property),
5209         (gst_test_do_signal1), (signal2_handler), (gst_test_do_signal2),
5210         (gst_test_do_prop), (run_thread), (main):
5211         Added a bunch of testcases that show threadsafety bugs in glib.
5212
5213 2004-11-29  Stefan Kost  <ensonic@users.sf.net>
5214
5215         * docs/manual/programs.xml:
5216           Added a first batch of gst-launch examples, as provided by Ronald
5217           and others from the devel-mlist
5218
5219 2004-11-28  Benjamin Otte  <otte@gnome.org>
5220
5221         * gst/gstelement.c: (gst_element_negotiate_pads):
5222           simplify
5223         * gst/gstvalue.c: (gst_string_wrap), (gst_string_unwrap),
5224         (gst_value_serialize_string), (gst_value_deserialize_string):
5225           add unwrapping of previously wrapped strings. Fix bug in wrapping
5226           while at it.
5227         * testsuite/caps/value_serialize.c: (test1),
5228         (test_string_serialization), (test_string_deserialization), (main):
5229           add tests for string (de)serialization
5230
5231 2004-11-26  Wim Taymans  <wim@fluendo.com>
5232
5233         * testsuite/threads/159566.c: (object_deep_notify), (main):
5234         * testsuite/threads/Makefile.am:
5235         Added testsuite to show bug #159566
5236
5237 2004-11-25  Wim Taymans  <wim@fluendo.com>
5238
5239         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_change_state),
5240         (gst_thread_child_state_change), (gst_thread_main_loop):
5241         Ref the thread object in the GThread mainloop. Break out of the
5242         thread mainloop if it holds the last ref. This properly exits
5243         the threads when disposing the thread from its own context. It
5244         also avoids possible deadlocks in the dispose function.
5245
5246 2004-11-24  Martin Soto  <martinsoto@users.sourceforge.net>
5247
5248         * gst/gstqueue.c (gst_queue_link_sink): Grab the lock only when
5249         it is necessary to wait.
5250
5251 2004-11-24  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5252
5253         * docs/pwg/building-boiler.xml:
5254           Make description somewhat clearer.
5255
5256 2004-11-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5257
5258         * docs/upload.mak:
5259           Apparently docs changed location on FDO's server.
5260
5261 2004-11-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5262
5263         * docs/pwg/appendix-checklist.xml:
5264           Add some random notes on things to check when writing an element.
5265           This list can be extended as people see fit.
5266
5267 2004-11-23  Martin Soto  <martinsoto@users.sourceforge.net>
5268
5269         * gst/gstqueue.c (gst_queue_init, gst_queue_link_sink)
5270         (gst_queue_link_src): Allow for renegotiating the caps of the sink
5271         pad. The queue will now wait until it is empty and forward the new
5272         caps to the source.
5273         * gst/gstbin.c (gst_bin_set_element_sched)
5274         (gst_bin_unset_element_sched): Make sure that all elements and
5275         links are registered and unregistered with the scheduler exactly
5276         once. This elaborates on a fix by Benjamin Otte, but
5277         guarantees that decoupled elements are also registered.
5278
5279 2004-11-11  Thomas Vander Stichele  <thomas at apestaart dot org>
5280
5281         * docs/manual/quotes.xml:
5282           add a quote
5283         * configure.ac:
5284         * gst/gst.c:
5285         * gst/gstinfo.c:
5286           add LIBDIR and move init message higher up so it's at the start
5287
5288 2004-11-08  Christian Fredrik Kalager Schaller  <christian@fluendo.com>
5289
5290         * gst/schedulers/Makefile.am: fix disted build fair by including .h file
5291         * gstreamer.spec.in: add fair
5292
5293 2004-11-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5294
5295         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
5296         * gst/elements/gstidentity.c: (gst_identity_class_init):
5297           Use G_SIGNAL_TYPE_STATIC_SCOPE, patch by Christophe Fergeau
5298           <teuf@gnome.org> (#157263).
5299         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
5300         (gst_type_find_handle_src_query):
5301           Subtract size of internally stored data from position queries.
5302
5303 2004-11-07  Martin Soto  <martinsoto@users.sourceforge.net>
5304
5305         * gst/schedulers/fairscheduler.c:
5306         * gst/schedulers/faircothreads.c:
5307         * gst/schedulers/faircothreads.h:
5308         New cothread based scheduler: Fair scheduler.
5309         * gst/schedulers/gthread-cothreads.h: 
5310         Add the standard #if around the whole file.
5311         Defining symbol GTHREAD_COTHREADS_NO_DEFINITIONS will now prevent
5312         compilation of the functions defined in this file. This is
5313         necessary to be able to use this file as a normal header.
5314         * gst/schedulers/Makefile.am: Add compiling support for fair
5315         scheduler.
5316         * docs/gst/Makefile.am (IGNORE_HFILES): Exclude internal fair
5317         scheduler cothreads layer from documentation generation.
5318
5319 2004-11-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5320
5321         * gst/autoplug/gstspideridentity.c:
5322         (gst_spider_identity_sink_loop_type_finding):
5323           Don't crash if that function is not implemented.
5324
5325 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5326
5327         * docs/pwg/advanced-types.xml:
5328           Another typo.
5329
5330 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5331
5332         * docs/pwg/intro-preface.xml:
5333           Hm, ok, so the brackets weren't really useful...
5334         * docs/pwg/other-ntoone.xml:
5335           Fix embarassing typo.
5336
5337 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5338
5339         * docs/pwg/intro-preface.xml:
5340           Rewrite preface.
5341
5342 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5343
5344         * docs/pwg/advanced-scheduling.xml:
5345         * docs/pwg/advanced-tagging.xml:
5346         * docs/pwg/advanced-types.xml:
5347         * docs/pwg/building-boiler.xml:
5348         * docs/pwg/building-chainfn.xml:
5349         * docs/pwg/building-signals.xml:
5350         * docs/pwg/building-state.xml:
5351         * docs/pwg/building-testapp.xml:
5352         * docs/pwg/intro-basics.xml:
5353         * docs/pwg/other-manager.xml:
5354         * docs/pwg/other-source.xml:
5355           Typo fixes.
5356         * docs/pwg/other-manager.xml:
5357           Add some first content. No example code yet.
5358         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
5359           Remove double newlines.
5360
5361 2004-11-04  Wim Taymans  <wim@fluendo.com>
5362
5363         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5364         (remove_from_group), (normalize_group), (group_migrate_connected),
5365         (gst_opt_scheduler_iterate):
5366         * testsuite/schedulers/.cvsignore:
5367         * testsuite/schedulers/Makefile.am:
5368         * testsuite/schedulers/queue_link.c: (main):
5369         Added testcase for scheduler segfault.
5370         Fix scheduler segfault when removing a decoupled
5371         entry point as the last element from a group.
5372
5373 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
5374
5375         * gst/gstmarshal.list: add missing marshaller, fixes build
5376
5377 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
5378
5379         * docs/random/signal: added notes about using BOXED for GstBuffer
5380         signal marshallers, not POINTER
5381
5382 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
5383
5384         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
5385         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init): more
5386         POINTER=>BOXED changes to marshal GstBuffers
5387
5388 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
5389
5390         * gst/elements/gstidentity.c: (gst_identity_class_init): GstBuffer is 
5391         a boxed type, marshal the signal with VOID__BOXED, not VOID__POINTER
5392
5393 2004-11-03  Stefan Kost  <ensonic@users.sf.net>
5394
5395         * docs/gst/gstreamer-sections.txt:
5396         * docs/gst/tmpl/gstcaps.sgml:
5397         * docs/gst/tmpl/gsterror.sgml:
5398         * docs/gst/tmpl/gstinfo.sgml:
5399         * docs/gst/tmpl/gstmacros.sgml:
5400         * docs/gst/tmpl/gstutils.sgml:
5401         * docs/random/ensonic/interfaces.txt:
5402         * gst/gstinfo.h:
5403           added some more docs, removed two obsolete defines
5404
5405 2004-11-02  Kjartan Maraas <as at gnome.org>
5406
5407         reviewed by: Wim Taymans, Ronald Bultje.
5408
5409         * gst/cothreads.c: (cothread_create):
5410         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_remove_func),
5411         (gst_bin_child_state_change_func):
5412         * gst/gstbuffer.c: (gst_buffer_span):
5413         * gst/gstelement.c: (gst_element_get_index),
5414         (gst_element_get_event_masks), (gst_element_get_query_types),
5415         (gst_element_get_formats):
5416         * gst/gsterror.c: (_gst_core_errors_init),
5417         (_gst_library_errors_init), (_gst_resource_errors_init),
5418         (_gst_stream_errors_init):
5419         * gst/gstobject.c: (gst_object_default_deep_notify):
5420         * gst/gstpad.c: (gst_pad_get_event_masks),
5421         (gst_pad_get_internal_links_default):
5422         * gst/gstplugin.c: (gst_plugin_register_func),
5423         (gst_plugin_get_module):
5424         * gst/gststructure.c: (gst_structure_get_string),
5425         (gst_structure_get_abbrs), (gst_structure_from_abbr),
5426         (gst_structure_to_abbr):
5427         * gst/gstutils.c: (gst_print_element_args):
5428         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5429         (setup_group_scheduler), (gst_opt_scheduler_iterate):
5430         Aplied part of patch #157127: Cleanup of issues reported by 
5431         sparse.
5432         Also do not try to use cothreads when there is no cothread
5433         context yet.
5434
5435 2004-11-02  Sebastien Cote <sc5 at hermes.usherb.ca>
5436
5437         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5438         (gst_opt_scheduler_iterate):
5439         Applied patch #154061. Running a pipeline in which an element 
5440         calls GST_ELEMENT_ERROR in the chain function, the opt 
5441         scheduler doesn't unref the chain so it never gets freed.
5442
5443 2004-11-02  Wim Taymans  <wim@fluendo.com>
5444
5445         * gst/gststructure.c: (gst_structure_get_abbrs),
5446         (gst_structure_from_abbr), (gst_structure_to_abbr):
5447         Remove that ugly if-then thing in the code that converts
5448         between strings and types.
5449
5450 2004-11-02  Wim Taymans  <wim@fluendo.com>
5451
5452         * gst/gstscheduler.c: (gst_scheduler_add_element),
5453         (gst_scheduler_remove_element), (gst_scheduler_state_transition):
5454         Aplied clock distribution patch, this should fix bug
5455         #148787.
5456
5457 2004-10-27  Thomas Vander Stichele  <thomas at apestaart dot org>
5458
5459         Submitted by: Kjartan Maraas <kmaraas@broadpark.no>
5460
5461         * po/LINGUAS:
5462         * po/nb.po:
5463           Added Norwegian Bokmaal translation
5464
5465 2004-10-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5466
5467         * tools/gst-inspect.c: (print_signal_info):
5468           print signal arguments as pointers if they are
5469
5470 2004-10-22  Stefan Kost  <ensonic@users.sf.net>
5471
5472         * docs/pwg/building-boiler.xml:
5473           exchanged GTK_ macros with G_TYPE macros (as pointed out by mathrick)
5474
5475 2004-10-19  Wim Taymans  <wim at fluendo dot com>
5476
5477         * gst/parse/parse.l:
5478         * testsuite/parse/parse1.c: (main):
5479         Since parse can do 'element name=a:b' make 'a:b.' work as
5480         well. 
5481         Added testcase to verify fix.
5482
5483 2004-10-19  Wim Taymans  <wim at fluendo dot com>
5484
5485         * tools/gst-inspect.c: (print_pad_info), (print_plugin_features):
5486         Use the realpad when printing the direction.
5487         Add extra \n when printing extensions of typefind factories.
5488
5489 2004-10-13  David Schleef  <ds@schleef.org>
5490
5491         * examples/manual/Makefile.am: $< isn't portable in Makefile
5492         rules.
5493
5494 2004-10-13  Stefan Kost  <ensonic@users.sf.net>
5495
5496         * docs/gst/tmpl/gstobject.sgml:
5497         * docs/gst/tmpl/gstplugin.sgml:
5498         * docs/gst/tmpl/gstpluginfeature.sgml:
5499         * docs/gst/tmpl/gstregistry.sgml:
5500         * docs/gst/tmpl/gstversion.sgml:
5501         * gst/gstbin.c:
5502           more api documentation
5503         * gst/gstplugin.c: (gst_plugin_register_func),
5504         (gst_plugin_check_file), (gst_plugin_load_file):
5505           better error signaling and logging
5506
5507 2004-10-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5508
5509         * gst/gstqueue.c: (gst_queue_init), (gst_queue_handle_src_query):
5510           Subtract current queue contents from position queries.
5511
5512 2004-10-11  Johan Dahlin  <johan@gnome.org>
5513
5514         * gst/gsturi.c (gst_uri_get_location): unescape string
5515         (gst_uri_construct): escape string.
5516
5517 2004-10-11  Benjamin Otte  <otte@gnome.org>
5518
5519         * gst/gstpad.c: (gst_pad_renegotiate), (gst_pad_try_set_caps),
5520         (gst_pad_try_set_caps_nonfixed):
5521           allow renegotiation of unconnected pads (as inside spider). Simply
5522           return OK if unconnected - mimic try_set_caps there.
5523
5524 2004-10-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5525
5526         * gst/gstbin.c: (gst_bin_sync_children_state):
5527           Add missing break.
5528
5529 2004-10-09  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5530
5531         * gst/elements/gstfakesrc.c: (gst_fakesrc_get):
5532         Set element to EOS before sending EOS event
5533
5534 2004-10-08  Wim Taymans  <wim at fluendo dot com>
5535
5536         * gst/elements/gsttypefindelement.c:
5537         (gst_type_find_element_handle_event):
5538         Handle EOS events when doing the transition from
5539         typefind to data passing. This should fix the
5540         infinite loops in short files.
5541
5542 2004-10-07  Wim Taymans  <wim at fluendo dot com>
5543
5544         * gst/gstthread.c: (gst_thread_change_state),
5545         (gst_thread_child_state_change):
5546         Make sure no iteration happens while performing
5547         the state change as it could mess up the internal
5548         consistency of the thread state.
5549
5550 2004-10-07  Wim Taymans  <wim at fluendo dot com>
5551
5552         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_sync),
5553         (gst_thread_change_state), (gst_thread_child_state_change):
5554         Do not try to grab the iterate lock in the state change method
5555         when we are in the same thread as the iterate or else we
5556         could deadlock. Some other cleanups.
5557
5558 2004-10-06  Thomas Vander Stichele  <thomas at apestaart dot org>
5559
5560         * configure.ac:
5561           bump nano to cvs
5562
5563 === release 0.8.7 ===
5564
5565 2004-10-06  Thomas Vander Stichele  <thomas at apestaart dot org>
5566
5567         * configure.ac:
5568         * NEWS:
5569         * RELEASE:
5570         * configure.ac:
5571           releasing 0.8.7, "A Cruise"
5572
5573 2004-10-06  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
5574
5575         * docs/random/mimetypes:
5576         Add an entry for Sony ATRAC3 audio format with mime-type
5577         used by rmdemux et riff-read
5578
5579 2004-10-06  Wim Taymans  <wim at fluendo dot com>
5580
5581         * gst/elements/gsttypefindelement.c: (stop_typefinding):
5582         Push the buffer store instead of clearing it in case that
5583         the stream is not seekable.
5584
5585 2004-10-06  Wim Taymans  <wim at fluendo dot com>
5586
5587         * gst/gstthread.c: (gst_thread_init), (gst_thread_change_state),
5588         (gst_thread_main_loop):
5589         Lock the iteration and the state change so that automatic
5590         negotiation and fixation does not happen at the same time
5591         as the in stream negotiation.
5592
5593 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
5594
5595         * configure.ac:
5596           bump nano to cvs
5597
5598 === release 0.8.6 ===
5599
5600 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
5601
5602         * configure.ac:
5603         * NEWS:
5604         * RELEASE:
5605         * configure.ac:
5606           releasing 0.8.6, "Narc"
5607
5608 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
5609
5610         * configure.ac:
5611           prerel bump
5612
5613 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
5614
5615         patch by: Steve Lhomme
5616
5617         * gst/elements/gstfakesrc.c:
5618         * gst/elements/gstidentity.c:
5619         * gst/gstthread.c:
5620           Fix for #153881
5621
5622 2004-10-01  Wim Taymans  <wim at fluendo dot com>
5623
5624         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_crc):
5625         Fix threadsafety of the crc checking function.
5626
5627 2004-09-26  Thomas Vander Stichele  <thomas at apestaart dot org>
5628
5629         patch by: Ronald Bultje
5630
5631         * gst/elements/gsttypefindelement.c: (stop_typefinding),
5632         (gst_type_find_element_handle_event),
5633         (gst_type_find_element_chain):
5634         * gst/elements/gsttypefindelement.h:
5635          #153657.
5636          Filter out discont event from seekable sources when typefind
5637          asks them to seek.  Fixes typefind with demuxers for
5638          avi, asf and matroska.
5639
5640 2004-09-26  Thomas Vander Stichele  <thomas at apestaart dot org>
5641
5642         * docs/gst/gstreamer-sections.txt:
5643         * gst/gstcaps.c:
5644         * gst/gstcaps.h:
5645         * gst/gstpad.c:
5646           Revert preferred caps: (#147789)
5647
5648 2004-09-19  Steve Lhomme  <steve.lhomme@free.fr>
5649
5650         * win32/dirent.c:
5651           fix a memory leak
5652
5653 2004-09-10  Thomas Vander Stichele  <thomas at apestaart dot org>
5654
5655         * configure.ac:
5656           bump for prerelease
5657
5658 2004-09-09  Thomas Vander Stichele  <thomas at apestaart dot org>
5659
5660         * docs/Makefile.am:
5661         * docs/manual/elements-api.xml:
5662           restructure so that common stuff is shown first
5663         * docs/manual/init-api.xml:
5664           convert to examples
5665         * docs/manual/manual.xml:
5666         * docs/manuals.mak:
5667         * docs/url.entities:
5668           link to API on the website, possibly override later in build
5669         * examples/manual/.cvsignore:
5670           ignore more
5671         * examples/manual/Makefile.am:
5672           add more examples
5673         * examples/manual/extract.pl:
5674           error out on failure
5675
5676 2004-09-08  Thomas Vander Stichele  <thomas at apestaart dot org>
5677
5678         * docs/gst/tmpl/gstthread.sgml:
5679         * docs/manual/init-api.xml:
5680         * examples/manual/Makefile.am:
5681           convert two code bits to examples
5682
5683 2004-09-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5684
5685         * gst/gstelement.c: (gst_element_change_state):
5686           Well, actually, I was about to remove this insane assert when
5687           I noticed Wim already did that. A warning is nice so we can
5688           fix actual ugs (using --g-fatal-warnings and backtraces), so
5689           I added that instead.
5690
5691 2004-09-06  Wim Taymans  <wim@fluendo.com>
5692
5693         * gst/gstelement.c: (gst_element_threadsafe_properties_pre_run),
5694         (gst_element_threadsafe_properties_post_run),
5695         (gst_element_set_state), (gst_element_change_state):
5696         Added extra refcounting around various places. 
5697
5698 2004-09-06  Wim Taymans  <wim@fluendo.com>
5699
5700         * gst/gstpad.c: (gst_pad_link_call_link_functions):
5701         Fix debug info.
5702
5703 2004-09-06  Wim Taymans  <wim@fluendo.com>
5704
5705         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5706         (remove_from_group):
5707         Some more debug info.
5708
5709 2004-09-03  Wim Taymans  <wim@fluendo.com>
5710
5711         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
5712         (gst_fakesrc_init), (gst_fakesrc_set_clock),
5713         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
5714         (gst_fakesrc_get), (gst_fakesrc_change_state):
5715         * gst/elements/gstfakesrc.h:
5716         * gst/elements/gstidentity.c: (gst_identity_class_init),
5717         (gst_identity_init), (gst_identity_chain),
5718         (gst_identity_set_property), (gst_identity_get_property),
5719         (gst_identity_change_state):
5720         * gst/elements/gstidentity.h:
5721         Added datarate properties to limit the datarate.
5722
5723 2004-08-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5724
5725         * gst/autoplug/gstspider.c: (plugin_init):
5726           don't set a rank. We don't want to autoplug by inserting spiders.
5727
5728 2004-08-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5729
5730         * gst/autoplug/gstspider.c: (gst_spider_class_init),
5731         (gst_spider_identity_plug):
5732           add a template for spider's sink
5733         * gst/gst.c: (gst_register_core_elements):
5734           queue's rank should be NULL, we don't want spider to add it.
5735
5736 2004-08-18  David Schleef  <ds@schleef.org>
5737
5738         * docs/gst/Makefile.am: Remove --ignore-fail-on-non-empty (#150331)
5739         * docs/libs/Makefile.am: same
5740         * docs/gst/tmpl/gstxml.sgml: Remove GstXMLNs
5741         * docs/random/ds/0.9-planning: random additions
5742         * docs/random/ds/0.9-suggested-changes: same
5743         * gst/gstxml.h: remove vestigal GstXMLNs definition
5744
5745         Preferred caps: (#147789)
5746         * docs/gst/gstreamer-sections.txt: Add symbols
5747         * docs/gst/tmpl/gstcaps.sgml: Add symbols
5748         * gst/gstcaps.c: (gst_caps_copy), (gst_caps_free),
5749         (gst_caps_append), (gst_caps_copy_1), (gst_caps_intersect),
5750         (gst_caps_union), (gst_caps_save_thyself), (gst_caps_load_thyself),
5751         (gst_caps_get_preferred), (gst_caps_set_preferred),
5752         (gst_caps_get_structure_by_id), (gst_caps_prefer_foreach),
5753         (gst_caps_use_preferred): Handle caps preferences
5754         * gst/gstcaps.h: Add caps preferences
5755         * gst/gstpad.c: (gst_pad_link_get_preferred),
5756         (gst_pad_link_fixate), (gst_pad_link_call_link_functions),
5757         (gst_pad_renegotiate), (gst_pad_guess_preferred),
5758         (gst_pad_get_caps), (gst_pad_push):  Use caps preferences for
5759         negotiation.
5760
5761 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5762
5763         * gst/autoplug/gstspideridentity.c:
5764         (gst_spider_identity_request_new_pad):
5765         * gst/elements/gstaggregator.c: (gst_aggregator_base_init),
5766         (gst_aggregator_init):
5767         * gst/elements/gstfakesink.c: (gst_fakesink_base_init),
5768         (gst_fakesink_init):
5769         * gst/elements/gstfakesrc.c: (gst_fakesrc_base_init),
5770         (gst_fakesrc_init):
5771         * gst/elements/gstfdsink.c: (gst_fdsink_base_init),
5772         (gst_fdsink_init):
5773         * gst/elements/gstfdsrc.c: (gst_fdsrc_base_init), (gst_fdsrc_init):
5774         * gst/elements/gstfilesink.c: (gst_filesink_base_init),
5775         (gst_filesink_init):
5776         * gst/elements/gstfilesrc.c: (gst_filesrc_base_init),
5777         (gst_filesrc_init):
5778         * gst/elements/gstidentity.c: (gst_identity_base_init),
5779         (gst_identity_init):
5780         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_base_init),
5781         (gst_multifilesrc_init):
5782         * gst/elements/gstpipefilter.c: (gst_pipefilter_base_init),
5783         (gst_pipefilter_init):
5784         * gst/elements/gststatistics.c: (gst_statistics_base_init),
5785         (gst_statistics_init):
5786         * gst/elements/gsttee.c: (gst_tee_base_init), (gst_tee_init):
5787         * gst/gstqueue.c: (gst_queue_base_init), (gst_queue_init):
5788           s/gst_pad_new/&_from_template/
5789           register pad templates in the base_init function
5790           add static pad template definitions
5791
5792 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5793
5794         * testsuite/bytestream/gstbstest.c: (gst_bstest_init):
5795         * testsuite/dynparams/dparamstest.c: (gst_dptest_init):
5796         * testsuite/refcounting/pad.c: (main):
5797         * testsuite/refcounting/thread.c: (create_thread_ghostpads):
5798           s/gst_pad_new/&_from_template/
5799           prepare deprecation of gst_pad_new
5800
5801 2004-08-17  Thomas Vander Stichele  <thomas at apestaart dot org>
5802
5803         patch by: Luca Ognibene <skaboy81@virgilio.it>
5804
5805         * gst/gstcaps.c:
5806         * gst/gstelement.c:
5807         * gst/gstpad.c:
5808         * gst/gstxml.c:
5809           fix memleaks.  Fixes #150001
5810
5811 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5812
5813         * docs/random/ds/0.9-suggested-changes:
5814           add notes - mostly about pad templates
5815
5816 2004-08-16  Steve Lhomme  <steve.lhomme@free.fr>
5817
5818         * win32/GStreamer.vcproj:
5819           temporary locale files are .gmo not .mo
5820
5821 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
5822
5823         * configure.ac: bump nano to cvs
5824
5825 === release 0.8.5 ===
5826
5827 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
5828
5829         * configure.ac:
5830           releasing 0.8.5, "Stuttgart"
5831         * NEWS:
5832         * RELEASE:
5833         * configure.ac:
5834         * docs/random/release:
5835           updates for release
5836
5837 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
5838
5839         patch by: Wim Taymans (wim@fluendo.com)
5840
5841         * gst/gstbuffer.c:
5842         * gst/gstindex.h:
5843         * libs/gst/dataprotocol/dataprotocol.c:
5844           copy KEY_UNIT and DELTA_UNIT flags correctly.  Fixes #150242
5845
5846 2004-08-13  Thomas Vander Stichele  <thomas at apestaart dot org>
5847
5848         * Makefile.am:
5849         * win32/MANIFEST:
5850           add win32 dir to the build.  Fixes #149981.
5851
5852 2004-08-13  Thomas Vander Stichele  <thomas at apestaart dot org>
5853
5854         * configure.ac:
5855           bump libtool versioning
5856         * gst/gststructure.c:
5857           mark function as static
5858         * po/af.po:
5859         * po/az.po:
5860         * po/ca.po:
5861         * po/cs.po:
5862         * po/en_GB.po:
5863         * po/fr.po:
5864         * po/nl.po:
5865         * po/sq.po:
5866         * po/sr.po:
5867         * po/sv.po:
5868         * po/tr.po:
5869         * po/uk.po:
5870           translations update
5871         * win32/README.txt:
5872           trademark protection
5873
5874 2004-08-12  Thomas Vander Stichele  <thomas at apestaart dot org>
5875
5876         * configure.ac:
5877           fix GST_ORIGIN
5878           set GST_PACKAGE to source, and distinguish between release and other
5879         * tools/gst-inspect.c:
5880           print out plugin an element factory is part of so we see this info
5881
5882 2004-08-12  Thomas Vander Stichele  <thomas at apestaart dot org>
5883
5884         * docs/gst/gstreamer-sections.txt:
5885         * docs/gst/tmpl/gstbuffer.sgml:
5886         * docs/gst/tmpl/gstschedulerfactory.sgml:
5887           reorder docs a little, make GstBuffer's more sensible.
5888         * gst/gstbuffer.h:
5889           API: added GST_BUFFER_FLAG_DELTA_UNIT
5890         * gst/gstscheduler.c:
5891           comment API addition
5892
5893 2004-08-12  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5894
5895         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
5896           work with non-regular files that can be mmapped (like /dev/zero)
5897         * gst/elements/gsttypefindelement.c: (gst_type_find_element_chain):
5898           get rid of typefinds that require a seek when we can't seek instead
5899           of trying them over and over again
5900         * tools/gst-launch.c: (idle_func), (error_cb), (main):
5901           return non-zero failure value when the pipeline was interrupted or
5902           an error occurred
5903
5904 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
5905
5906         * win32/config.h:
5907         * win32/GStreamer.vcproj:
5908           compile and install the locales
5909
5910 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
5911
5912         * gst/gstvalue.c:
5913           fix a possible memory leak under Windows
5914
5915 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
5916
5917         * win32/GStreamer.vcproj:
5918           fix a memory leak that occured under Windows
5919         * win32/gstreamer.def:
5920           add gst_scheduler_register
5921
5922 2004-08-11  Benjamin Otte  <otte@gnome.org>
5923
5924         * docs/gst/gstreamer-sections.txt:
5925         * gst/gstscheduler.c: (gst_scheduler_register):
5926         * gst/gstscheduler.h:
5927           API:
5928           add gst_scheduler_register shortcut similar to gst_element_register
5929         * gst/schedulers/entryscheduler.c: (plugin_init):
5930         * gst/schedulers/gstbasicscheduler.c: (plugin_init):
5931         * gst/schedulers/gstoptimalscheduler.c: (plugin_init):
5932           use it
5933
5934 2004-08-10  Steve Lhomme  <steve.lhomme@free.fr>
5935
5936         * gst/gstvalue.h:
5937           fix a memory leak that occured under Windows
5938
5939 2004-08-10  Colin Walters  <walters@redhat.com>
5940
5941         * gst/registries/gstxmlregistry.c (gst_xml_registry_open_func):
5942         Don't use O_EXCL to open temporary registry.  It will prevent
5943         registry creation if a temporary one already exists, which
5944         is unnecessary.
5945
5946 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
5947
5948         * docs/gst/gstreamer-sections.txt:
5949         * docs/gst/tmpl/gstvalue.sgml:
5950           remove some valuable stuff from the documentation due to the use of GST_EXPORT
5951
5952 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
5953
5954         * win32/gstbytestream.vcproj:
5955         * win32/gstelements.vcproj:
5956         * win32/gstgetbits.vcproj:
5957         * win32/gst-inspect.vcproj:
5958         * win32/gst-launch.vcproj:
5959         * win32/gstoptimalscheduler.vcproj:
5960         * win32/GStreamer.vcproj:
5961         * win32/gst-register.vcproj:
5962         * win32/gstspider.vcproj:
5963           update the include and lib dirs to fit standard libraries as
5964           described in the Win32 manual
5965
5966 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
5967
5968         * win32/config.h:
5969         * win32/gstversion.h:
5970           enable NLS again, push the version number for the coming 0.8.5 release
5971
5972 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
5973
5974         * gst/gstvalue.h:
5975           export gst_type_XXX for windows DLLs
5976
5977 2004-08-09  Thomas Vander Stichele  <thomas at apestaart dot org>
5978
5979         * docs/faq/gst-uninstalled:
5980           fix PKG_CONFIG_PATH and PYTHONPATH
5981         * gst/schedulers/Makefile.am:
5982           cleanup
5983         * libs/gst/bytestream/bytestream.c:
5984           remove newline
5985         * po/LINGUAS:
5986         * po/sq.po:
5987           adding Albanian translation (Laurent Dhima)
5988         * po/cs.po:
5989           updated
5990
5991 2004-08-05  Thomas Vander Stichele  <thomas at apestaart dot org>
5992
5993         * po/ca.po:
5994         * po/sv.po:
5995           updated translations
5996
5997 2004-08-04  Benjamin Otte  <otte@gnome.org>
5998
5999         * tests/mass_elements.c: (main):
6000           allow specifying src and sink element explicitly, so I can test
6001           videotestsrc instead of fakesrc
6002
6003 2004-08-04  Benjamin Otte  <otte@gnome.org>
6004
6005         * gst/gststructure.c: (gst_structure_id_empty_new_with_size),
6006         (gst_structure_id_empty_new), (gst_structure_empty_new),
6007         (gst_structure_copy):
6008           add gst_structure_id_empty_new_with_size to allow preallocating
6009           value array sizes. Use this in gst_structure_copy to get rid of
6010           reallocs.
6011           don't do quark=>string=>quark when copying structures
6012
6013 2004-08-03  Steve Lhomme  <steve.lhomme@free.fr>
6014
6015         * docs/manual/win32.xml:
6016         * win32/README.txt:
6017           update documentation with the clean version of dependencies
6018
6019 2004-08-03  Benjamin Otte  <otte@gnome.org>
6020
6021         * gst/schedulers/entryscheduler.c:
6022         (gst_entry_scheduler_remove_element):
6023           fix for GST_DISABLE_DEBUG
6024         * tools/gst-launch.c: (print_tag):
6025           fixes for G_DISABLE_ASSERT
6026
6027 2004-08-03  Benjamin Otte  <otte@gnome.org>
6028
6029         * gst/gst.c: (gst_register_core_elements):
6030           fix for G_DISABLE_ASSERT
6031         * gst/gstinfo.c: (__gst_in_valgrind):
6032           add for GST_DISABLE_DEBUG
6033
6034 2004-08-03  Benjamin Otte  <otte@gnome.org>
6035
6036         * gst/parse/parse.l:
6037           fix for G_DISABLE_ASSERT
6038
6039 2004-08-03  Wim Taymans  <wim@fluendo.com>
6040
6041         * gst/gstbin.c: (gst_bin_get_type),
6042         (gst_bin_child_state_change_func):
6043         * gst/gstthread.c: (gst_thread_change_state):
6044         Backported some debug logging from a reverted patch
6045         Don't try to destroy the thread twice. Added some more
6046         debugging in GstThread. Unlock and signal even if we
6047         are in the thread context.
6048
6049 2004-08-03  Thomas Vander Stichele  <thomas at apestaart dot org>
6050
6051         * po/uk.po:
6052           updated translation
6053
6054 2004-07-30  David Schleef  <ds@schleef.org>
6055
6056         * gst/gstatomic_impl.h: Enable atomic code for x86_64
6057
6058 2004-07-29  David Schleef  <ds@schleef.org>
6059
6060         * libs/gst/dataprotocol/dataprotocol-test.c: (conversion_test):
6061         Use GST_READ_GUINTxx_BE(), since it accesses unaligned memory.
6062
6063 2004-07-29  Thomas Vander Stichele  <thomas at apestaart dot org>
6064
6065         * gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
6066         (gst_bin_add_func), (gst_bin_remove_func),
6067         (gst_bin_child_state_change), (gst_bin_child_state_change_func),
6068         (set_kid_state_func), (gst_bin_change_state), (gst_bin_set_state),
6069         (gst_bin_change_state_norecurse), (gst_bin_dispose),
6070         (gst_bin_sync_children_state):
6071         * gst/gstbin.h:
6072         * gst/gstthread.c: (gst_thread_class_init), (gst_thread_release),
6073         (gst_thread_change_state):
6074         * testsuite/states/Makefile.am:
6075           revert state change patches as agreed so we can rework them
6076           gradually
6077
6078 2004-07-29  Benjamin Otte  <otte@gnome.org>
6079
6080         * libs/gst/control/Makefile.am:
6081           link to libgstreamer (fixes Debian bug 262019, see
6082           http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=262019 )
6083
6084 2004-07-29  Wim Taymans  <wim@fluendo.com>
6085
6086         * testsuite/caps/fraction-convert.c: (check_from_double_convert),
6087         (check_from_fraction_convert), (transform_test), (main):
6088         Make the test less pedantic about float roundoff errors.
6089
6090 2004-07-29  Benjamin Otte  <otte@gnome.org>
6091
6092         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file),
6093         (gst_filesrc_srcpad_event):
6094           make seek events to before start/after end of file not fail, but
6095           seek to start/end instead
6096         * testsuite/caps/fraction-convert.c: (check_from_double_convert):
6097           add more output
6098
6099 2004-07-29  Benjamin Otte  <otte@gnome.org>
6100
6101         * gst/gstpad.c: (gst_pad_set_explicit_caps):
6102           check that caps are fixed
6103         * gst/gstpad.c: (gst_pad_template_new):
6104           don't try to simplify caps, costs too much time on gst_init
6105         * gst/gstplugin.c: (gst_plugin_add_feature):
6106           G_ERROR if features are added twice
6107         * gst/gsttypefind.c: (gst_type_find_register):
6108         * gst/gstelementfactory.c: (gst_element_register):
6109           don't add features twice
6110         * docs/random/ds/0.9-suggested-changes:
6111           add note about possible gst_init optimization
6112
6113 2004-07-28  David Schleef  <ds@schleef.org>
6114
6115         * testsuite/elements/Makefile.am:
6116         * testsuite/elements/struct_i386.h:
6117         * testsuite/elements/struct_size.c: (main):  A little test
6118         to keep distcheck from working if someone changes a structure
6119         size accidentally.
6120
6121 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
6122
6123         * docs/libs/Makefile.am:
6124         * docs/libs/gstreamer-libs-docs.sgml:
6125         * docs/libs/gstreamer-libs-sections.txt:
6126         * docs/libs/tmpl/gstbytestream.sgml:
6127         * docs/libs/tmpl/gstcontrol.sgml:
6128         * docs/libs/tmpl/gstdataprotocol.sgml:
6129         * docs/libs/tmpl/gstgetbits.sgml:
6130         * libs/gst/bytestream/Makefile.am:
6131         * libs/gst/bytestream/bytestream.c:
6132         * libs/gst/bytestream/bytestream.h:
6133         * libs/gst/control/Makefile.am:
6134         * libs/gst/dataprotocol/Makefile.am:
6135         * libs/gst/getbits/Makefile.am:
6136         * libs/gst/getbits/getbits.h:
6137           various doc and style fixes, adding bytestream to libs docs.
6138
6139 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
6140
6141         * docs/gst/gstreamer-docs.sgml:
6142         * docs/libs/Makefile.am:
6143         * docs/libs/gstreamer-libs-docs.sgml:
6144         * docs/libs/gstreamer-libs-sections.txt:
6145         * libs/gst/control/dparam.c:
6146           more doc fixes.  gst-libs docs now build the same way as gst.
6147
6148 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
6149
6150         * configure.ac:
6151         * testsuite/Makefile.am:
6152         * testsuite/bins/Makefile.am:
6153         * testsuite/caps/Makefile.am:
6154         * testsuite/cleanup/Makefile.am:
6155         * testsuite/clock/Makefile.am:
6156         * testsuite/debug/Makefile.am:
6157         * testsuite/dlopen/Makefile.am:
6158         * testsuite/dynparams/Makefile.am:
6159         * testsuite/elements/.cvsignore:
6160         * testsuite/elements/Makefile.am:
6161         * testsuite/enumcaps/Makefile.am:
6162         * testsuite/enumcaps/enumcaps.c:
6163         * testsuite/ghostpads/Makefile.am:
6164         * testsuite/indexers/Makefile.am:
6165         * testsuite/negotiation/Makefile.am:
6166         * testsuite/parse/Makefile.am:
6167         * testsuite/plugin/Makefile.am:
6168         * testsuite/refcounting/Makefile.am:
6169         * testsuite/schedulers/.cvsignore:
6170         * testsuite/states/Makefile.am:
6171         * testsuite/tags/Makefile.am:
6172         * testsuite/threads/Makefile.am:
6173           fold enumcaps into caps dir
6174           clean up Makefile.am's for testsuite
6175
6176 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
6177
6178         * docs/gst/Makefile.am:
6179         * docs/libs/Makefile.am:
6180           clean up docs build.  Fixes needless rebuilding of template files.
6181
6182 2004-07-28  Wim Taymans  <wim@fluendo.com>
6183
6184         * gst/gstbin.c: (set_kid_state_func), (gst_bin_set_state):
6185         * gst/gstthread.c: (gst_thread_release), (gst_thread_set_state):
6186         Make sure that a bin state change tries to keep the children
6187         in sync. 
6188         Added debug logging to the thread.
6189
6190 2004-07-27  Steve Lhomme  <steve.lhomme@free.fr>
6191
6192         * win32/GStreamer.vcproj:
6193         * win32/gstreamer.def:
6194           more exports for the plugins
6195
6196 2004-07-27  Steve Lhomme  <steve.lhomme@free.fr>
6197
6198         * win32/gstgetbits.vcproj:
6199         * win32/gstgetbits.def:
6200         * win32/msvc71.sln:
6201           add support for the getbits plugin
6202
6203 2004-07-27  Wim Taymans  <wim@fluendo.com>
6204
6205         * gst/gstvalue.c: (gst_value_transform_double_fraction),
6206         (gst_value_transform_fraction_double), (_gst_value_initialize):
6207         * testsuite/caps/Makefile.am:
6208         * testsuite/caps/fraction-convert.c: (check_from_double_convert),
6209         (check_from_fraction_convert), (transform_test), (main):
6210         Added transform functions between double and fraction.
6211         Added testcase to verify transforms
6212
6213 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
6214
6215         * win32/GStreamer.vcproj:
6216           rename GStreamer-0.8.lib to libgstreamer.lib
6217
6218 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
6219
6220         * win32/gstelements.vcproj:
6221         * win32/gstoptimalscheduler.vcproj:
6222           fixes for the Release build
6223
6224 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
6225
6226         * win32/config.h:
6227           update the version number
6228
6229 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
6230
6231         * win32/GStreamer.vcproj:
6232           add gstinterface to the build
6233
6234 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
6235
6236         * win32/gstreamer.def:
6237           add many definitions needed by plugins,
6238           GST_CAT_DEFAULT only available in the Debug build ?
6239
6240 2004-07-26  Thomas Vander Stichele  <thomas at apestaart dot org>
6241
6242         * gst/gstelement.c: (gst_element_set_eos_recursive):
6243           various whitespace fixes.
6244           doc fix, fixes #148497
6245
6246 2004-07-25  Benjamin Otte  <otte@gnome.org>
6247
6248         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link):
6249           don't delay links on the sink elements, it causes unnegotiated
6250           links.
6251         * gst/elements/gsttypefindelement.c:
6252         (gst_type_find_element_base_init):
6253           add our padtemplates, we indeed do have some.
6254         * gst/elements/gsttypefindelement.c:
6255         (gst_type_find_element_handle_event),
6256         (gst_type_find_element_chain):
6257           don't push data when typefinding failed.
6258         * gst/gstpad.c: (gst_pad_link_fixate):
6259           check that no fixate function returns empty caps.
6260         * gst/gstpad.c: (gst_pad_push):
6261           check that the link is negotiated before data gets pushed.
6262         * tools/gst-register.c: (main):
6263           don't assert (fixes #148283)
6264
6265 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
6266
6267         * docs/gst/gstreamer-sections.txt:
6268         * docs/gst/tmpl/gstconfig.sgml:
6269           add GST_PLUGIN_EXPORT definition
6270
6271 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
6272
6273         * gst/gstplugin.h:
6274         * gst/gstconfig.h.in:
6275         * win32/gstconfig.h:
6276         * win32/gstelements.def:
6277         * win32/gstelements.vcproj:
6278         * win32/gstoptimalscheduler.def:
6279         * win32/gstoptimalscheduler.vcproj:
6280         * win32/gstspider.def:
6281         * win32/gstspider.vcproj:
6282           remove unused .def files and export symbols using GST_PLUGIN_DEFINE
6283
6284 2004-07-25  Thomas Vander Stichele  <thomas at apestaart dot org>
6285
6286         * docs/gst/gstreamer-sections.txt:
6287           remove GST_CAT_DEFAULT because the type has changed
6288
6289 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
6290
6291         * win32/gstbytestream.vcproj:
6292         * win32/gstelements.vcproj:
6293         * win32/gst-inspect.vcproj:
6294         * win32/gst-launch.vcproj:
6295         * win32/gstoptimalscheduler.vcproj:
6296         * win32/GStreamer.vcproj:
6297         * win32/gst-register.vcproj:
6298         * win32/gstspider.vcproj:
6299         * win32/msvc71.sln:
6300           Copy the files where needed after building, The testsuite will be
6301           built separately
6302
6303 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
6304
6305         * win32/config.h:
6306         * win32/README.txt:
6307         * docs/manual/win32.xml:
6308         Fixed the plugin and GStreamer location
6309
6310 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6311
6312         * win32/gstreamer.def:
6313         More exports for the plugins
6314
6315 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6316
6317         * gst/gstinfo.h:
6318         Marc was right, we need to export literally GST_CAT_DEFAULT
6319
6320 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6321
6322         * win32/config.h:
6323         NLS crashes in gettext, disabled until this is solved
6324
6325 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6326
6327         * win32/gst-inspect.vcproj:
6328         * win32/gst-launch.vcproj:
6329         Should use NLS when available
6330
6331 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6332
6333         * gst/registries/gstxmlregistry.c:
6334         removing the file doesn't seem to be a good idea on Linux
6335
6336 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6337
6338         * gst/registries/gstxmlregistry.c:
6339         Remove the registry before renaming the tempfile (needed for Windows)
6340
6341 2004-07-23  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6342
6343         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init),
6344         (gst_multifilesrc_init), (gst_multifilesrc_set_property),
6345         (gst_multifilesrc_get_property), (gst_multifilesrc_get):
6346         * gst/elements/gstmultifilesrc.h:
6347         Added newmedia property so it generates newmedia events between each
6348         file when property is set, as well as fixed eos handling
6349
6350 2004-07-22  David Schleef  <ds@schleef.org>
6351
6352         * gst/gststructure.c: (gst_structure_id_empty_new),
6353         (gst_structure_empty_new):  Set type field correctly.
6354         * gst/gststructure.h: Check type field correctly.
6355         * testsuite/caps/Makefile.am:
6356         * testsuite/caps/structure.c: (test1), (main): Add a very small
6357         test for structures.
6358
6359 2004-07-22  David Schleef  <ds@schleef.org>
6360
6361         * docs/random/ds/0.9-suggested-changes: more comments
6362         * tools/gst-launch.c: (idle_func): Fix hard-to-translate string.
6363
6364 2004-07-22  Benjamin Otte  <otte@gnome.org>
6365
6366         * gst/gstelementfactory.c: (gst_element_register):
6367           set the factory in the class struct, so gst_element_get_factory
6368           actually works
6369         * gst/parse/grammar.y:
6370           set element to playing when it gets unlocked as we can't rely on the
6371           bin state - all elements in the bin state might still be locked in
6372           NULL)
6373
6374 2004-07-22  Benjamin Otte  <otte@gnome.org>
6375
6376         * gst/gstelement.c: (gst_element_set_state_func):
6377           make this a static function
6378
6379 2004-07-22  Wim Taymans  <wim@fluendo.com>
6380
6381         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
6382         (gst_opt_scheduler_pad_link):
6383         fix 147894-2 and the group_link problem.
6384
6385 2004-07-22  Wim Taymans  <wim@fluendo.com>
6386
6387         * testsuite/schedulers/147894-2.c: (queue_empty), (queue_filled),
6388         (handoff_identity), (main):
6389         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
6390         (handoff_identity), (main):
6391         * testsuite/schedulers/Makefile.am:
6392         * testsuite/schedulers/group_link.c: (main):
6393         Show bug in scheduler when linking chain and loop based element 
6394         where the chain based element was not yet in a group.
6395
6396 2004-07-21  Benjamin Otte  <otte@gnome.org>
6397
6398         * gst/.cvsignore:
6399         * gst/autoplug/.cvsignore:
6400         * gst/elements/.cvsignore:
6401         * gst/indexers/.cvsignore:
6402         * libs/gst/bytestream/.cvsignore:
6403         * libs/gst/control/.cvsignore:
6404         * libs/gst/getbits/.cvsignore:
6405         * testsuite/states/.cvsignore:
6406         * testsuite/threads/.cvsignore:
6407           keep this up to date, since I seem to be the only one who cares
6408           about not missing files on commits (editor's note: no you don't,
6409           but feel free to change them at the time you add stuff instead
6410           of later on)
6411
6412 2004-07-21  Benjamin Otte  <otte@gnome.org>
6413
6414         * gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
6415         (gst_bin_fix_state), (gst_bin_add_func), (gst_bin_remove_func),
6416         (gst_bin_child_state_change_func), (set_kid_state_func),
6417         (gst_bin_set_state), (gst_bin_change_state_norecurse):
6418           make state changes work correctly and reentrant (so removing
6419           elements from bins during state changes of bins doesn't cause
6420           segfaults or even wrong states)
6421           add debugging category and debugging output to print children states
6422         * gst/gstbin.c: (gst_bin_dispose): 
6423           add some assertion checks
6424         * gst/gstbin.h:
6425         * gst/gstbin.c: (gst_bin_sync_children_state):
6426           deprecate this function - it just does gst_bin_set_state (bin,
6427           GST_STATE (bin)) 
6428         * testsuite/threads/queue.c: (main):
6429           don't use gst_bin_sync_children_state anymore
6430         * testsuite/states/Makefile.am:
6431         * testsuite/states/bin.c:
6432           test that the state changes of bins work as expected
6433         * gst/gstthread.c: (gst_thread_class_init), (gst_thread_set_state):
6434           some adjustments to change states correctly, too
6435         * gst/gstthread.c: (gst_thread_change_state):
6436           don't enable/disable "threadsafe" properties, they're unused and
6437           cause random segfaults
6438         * testsuite/threads/Makefile.am:
6439           the queue check randomly passes now, ignore it
6440
6441 2004-07-21  Benjamin Otte  <otte@gnome.org>
6442
6443         * gst/gstpad.c:
6444           check if data is NULL before outputting debug info. (fixes #145100)
6445
6446 2004-07-21  Benjamin Otte  <otte@gnome.org>
6447
6448         * gst/schedulers/entryscheduler.c:
6449         (gst_entry_scheduler_loop_wrapper),
6450         (gst_entry_scheduler_chain_wrapper),
6451         (gst_entry_scheduler_get_wrapper):
6452           reset the state when the cothread starts, so we don't get assertion
6453           failures on restarting of cothreads
6454
6455 2004-07-20  Benjamin Otte  <otte@gnome.org>
6456
6457         * gst/gstelement.c: (gst_element_link_pads_filtered):
6458           use correct sinkpad, if only sinkpad is specified, but not srcpad
6459           (fixes #147889)
6460         * gst/gstelement.c: (gst_element_set_state_func),
6461         (gst_element_change_state): ref/unref the element, signal handlers
6462         could get rid of the element otherwise
6463
6464 2004-07-20  Ronald Bultje  <rbultje@ronald.bitfreak.net>
6465
6466         * docs/random/ds/0.9-suggested-changes:
6467           Make note about renaming fixed-list to array.
6468         * gst/gstvalue.c: (gst_value_intersect_fixed_list),
6469         (_gst_value_initialize):
6470           Add array intersections.
6471         * testsuite/caps/intersect2.c: (main):
6472           Add test for array intersections.
6473
6474 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6475
6476         * configure.ac: back to cvs
6477
6478 === release 0.8.4 ===
6479
6480 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6481
6482         * configure.ac:
6483           releasing 0.8.4, "Paella"
6484           bump libtool versioning
6485
6486 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6487
6488         * po/LINGUAS:
6489         * po/ca.po:
6490           adding Catalan translation (Jordi Mallach)
6491
6492 2004-07-20  Wim Taymans  <wim@fluendo.com>
6493
6494         * testsuite/schedulers/147894-2.c: (queue_empty), (queue_filled),
6495         (handoff_identity), (main):
6496         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
6497         (handoff_identity), (main):
6498         * testsuite/schedulers/Makefile.am:
6499         Added failing testcase for variant of #147894
6500
6501 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6502
6503         patch by: David Moore
6504
6505         * gst/schedulers/gstoptimalscheduler.c: (group_has_element),
6506         (schedule_group), (gst_opt_scheduler_schedule_run_queue),
6507         (group_migrate_connected):
6508         * testsuite/schedulers/Makefile.am:
6509           fix for #142813 (Deadlock in optimal scheduler)
6510
6511 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6512
6513         patch by: Wim Taymans
6514
6515         * gst/schedulers/gstoptimalscheduler.c: (group_has_element),
6516         (gst_opt_scheduler_schedule_run_queue),
6517         (gst_opt_scheduler_get_wrapper), (get_group),
6518         (group_migrate_connected):
6519         * testsuite/schedulers/Makefile.am:
6520           fix for #147819 (Add some checks in the opt scheduler)
6521
6522 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6523
6524         patch by: Benjamin Otte
6525
6526         * gst/gstelementfactory.c: (__gst_element_details_set):
6527           fix for #147929: running gst-register in non-utf8 locale can cause
6528           invalid registry
6529
6530 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6531
6532         patch by: Wim Taymans
6533
6534         * gst/schedulers/gstoptimalscheduler.c: (group_num_elements),
6535         (group_has_element), (element_get_reachables_func),
6536         (group_migrate_connected):
6537           fix for #147894 (opt scheduler decoupled elements mismanagement)
6538         * testsuite/schedulers/Makefile.am:
6539           testsuite app now passes
6540
6541 2004-07-19  Wim Taymans  <wim@fluendo.com>
6542
6543         * testsuite/schedulers/147819.c: (handoff_identity1),
6544         (handoff_identity2), (main):
6545         * testsuite/schedulers/Makefile.am:
6546         Added testcase for bug 147819
6547
6548 2004-07-19  Wim Taymans  <wim@fluendo.com>
6549
6550         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
6551         (handoff_identity), (main):
6552         * testsuite/schedulers/Makefile.am:
6553         Added testcase for bug 147894
6554
6555 2004-07-16  Wim Taymans  <wim@fluendo.com>
6556
6557         * testsuite/schedulers/142183-2.c: (handoff_identity), (main):
6558         * testsuite/schedulers/142183.c: (handoff_identity), (main):
6559         * testsuite/schedulers/Makefile.am:
6560         Added testsuite for bug 142183 in its two incarnations. Refcount
6561         is not increased for scheduled elements and threadsafe properties
6562         mutexes are not properly unlocked.
6563
6564 2004-07-16  Wim Taymans  <wim@fluendo.com>
6565
6566         * gst/schedulers/gstoptimalscheduler.c: (gst_opt_scheduler_init),
6567         (create_chain), (destroy_chain), (create_group), (destroy_group),
6568         (add_to_group), (merge_groups), (group_elements), (group_inc_link),
6569         (group_dec_link), (gst_opt_scheduler_pad_link),
6570         (group_inc_links_for_element), (group_migrate_connected):
6571         Call group_inc_link with the proper src->sink ordering -- 
6572         break this, and we break sort_chain. patch from wingo for bug
6573         147713.
6574         Partially revert patch 1.89. When adding a loop based element to 
6575         the scheduler, the links to other groups are automatically followed
6576         and incremented. This should not happen because the bin will call
6577         pad_link explicitly for those connection, resulting in them counted 
6578         twice. Results in assertion failure on pipeline cleanup.
6579
6580 2004-07-16  Wim Taymans  <wim@fluendo.com>
6581
6582         * testsuite/schedulers/143777-2.c: (main):
6583         * testsuite/schedulers/147713.c: (handoff_src), (handoff_sink),
6584         (main):
6585         * testsuite/schedulers/Makefile.am:
6586         Added cleanup code to testcase 143777-2.
6587         Added testcase to show bug 147713, does not really show the
6588         deadlock as I can't figure out how to trigger it, but it does
6589         demonstrate bad ordering in the scheduler.
6590
6591 2004-07-16  Thomas Vander Stichele  <thomas at apestaart dot org>
6592
6593         * gst/gstvalue.c: (gst_value_deserialize_fraction):
6594           change strndup to g_strndup.  Fixes #147707
6595
6596 2004-07-16  Thomas Vander Stichele  <thomas at apestaart dot org>
6597
6598         * po/af.po:
6599         * po/az.po:
6600         * po/cs.po:
6601         * po/en_GB.po:
6602         * po/fr.po:
6603         * po/nl.po:
6604         * po/sr.po:
6605         * po/sv.po:
6606         * po/tr.po:
6607         * po/uk.po:
6608           updated translations
6609
6610 2004-07-16  Benjamin Otte  <otte@gnome.org>
6611
6612         * gst/gstvalue.c: (gst_greatest_common_divisor):
6613           use ints and return ints, fractions only use ints, too, so this
6614           avoids accidently casting multiplications to unsigned
6615         (gst_value_lcopy_fraction): it's ints, not uint32
6616         (gst_value_set_fraction): disallow minint, multiplying and negation
6617           are broken with it
6618         (gst_value_fraction_multiply): fix to make large numbers work and get
6619         rid of the assumption that the multiplication of two ints fits an
6620         int64 - dunno if that's true for all systems
6621         * testsuite/caps/Makefile.am:
6622         * testsuite/caps/fraction-multiply-and-zero.c:
6623         (check_multiplication), (check_equal), (zero_test), (main):
6624           add tests for all the stuff above
6625         * testsuite/caps/value_compare.c: (test1):
6626           fix comment
6627         * tests/.cvsignore:
6628         * testsuite/caps/.cvsignore:
6629         * testsuite/debug/.cvsignore:
6630         * testsuite/dlopen/.cvsignore:
6631         * testsuite/states/.cvsignore:
6632           get up to date
6633
6634 2004-07-16  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6635
6636         * docs/manual/bins-api.xml:
6637         * docs/manual/factories.xml:
6638         * docs/manual/helloworld.xml:
6639         * docs/manual/links-api.xml: 
6640           fixes for out of date info, incorrect info and grammar
6641
6642 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6643
6644         * docs/manual/pads.xml:
6645         * docs/manual/pads-api.xml: grammar fix
6646
6647 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6648
6649         * docs/manual/pads-api.xml: typo + grammar fix
6650
6651 2004-07-15  Thomas Vander Stichele  <thomas at apestaart dot org>
6652
6653         * docs/gst/gstreamer-sections.txt:
6654           add new symbols
6655         * docs/gst/tmpl/gstelement.sgml:
6656         * docs/gst/tmpl/gstpad.sgml:
6657         * docs/gst/tmpl/gsttypes.sgml:
6658         * docs/gst/tmpl/gstvalue.sgml:
6659           update docs
6660         * gst/gststructure.c: (gst_structure_set_valist),
6661         (gst_structure_from_abbr), (gst_structure_to_abbr):
6662         * gst/gstvalue.c: (gst_value_compare_double), (gst_type_is_fixed),
6663         (gst_greatest_common_divisor), (gst_value_init_fraction),
6664         (gst_value_copy_fraction), (gst_value_collect_fraction),
6665         (gst_value_lcopy_fraction), (gst_value_set_fraction),
6666         (gst_value_get_fraction_numerator),
6667         (gst_value_get_fraction_denominator),
6668         (gst_value_fraction_multiply), (gst_value_serialize_fraction),
6669         (gst_value_deserialize_fraction),
6670         (gst_value_transform_fraction_string),
6671         (gst_value_transform_string_fraction),
6672         (gst_value_compare_fraction), (_gst_value_initialize):
6673         * gst/gstvalue.h:
6674           adding GstFraction GValue type, get/set, and multiply
6675         * testsuite/caps/Makefile.am:
6676         * testsuite/caps/fraction.c: (test), (main):
6677         * testsuite/caps/string-conversions.c: (main):
6678         * testsuite/caps/value_compare.c: (test1), (main):
6679           add regression tests for GstFraction
6680
6681 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6682         
6683         * docs/manual/init-api.xml: Grammar fix
6684
6685 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6686
6687         * docs/manual/states.xml: Fix inconsistent information
6688
6689 2004-07-15  Thomas Vander Stichele  <thomas at apestaart dot org>
6690
6691         * gst/gstelement.c: (gst_element_set_state):
6692         * gst/gstpad.c: (gst_pad_try_set_caps):
6693         * gst/gststructure.c:
6694         * gst/gstthread.c: (gst_thread_child_state_change):
6695         * gst/gstvalue.c: (gst_value_compare_double):
6696         * gst/gstvalue.h:
6697         * testsuite/parse/parse1.c: (main):
6698           debugging additions and style cleanups
6699
6700 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6701
6702         * docs/manual/states.xml: Grammar fix
6703
6704 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6705
6706         * docs/manual/pads.xml: Grammar fix
6707
6708 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6709
6710         * docs/manual/elements.xml: Fixed image reference
6711
6712 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6713
6714         * docs/manual/goals.xml: Grammar fix
6715
6716 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6717
6718         * docs/manual/motivation.xml:
6719         Bonobo is no longer "emerging" and added sentence regarding tcp plugins
6720
6721 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6722
6723         * docs/manual/motivation.xml: Fix spelling
6724
6725 2004-07-15  Benjamin Otte  <otte@gnome.org>
6726
6727         * gst/gstelement.h: 
6728           Don't GST_ERROR_OBJECT empty strings - Solaris doesn't like NULL
6729           strings.
6730         * gst/gstelement.c (gst_element_class_init):
6731           GError's are boxed, not objects
6732         * gst/gstmarshal.list:
6733           update list for the fixed error signal
6734
6735 2004-07-14  Andy Wingo  <wingo@pobox.com>
6736
6737         * gst/gsttag.c: Add a tag merge func for pointers. The header was
6738         there all along, but the function wasn't. (guile-gstreamer's build
6739         system uses the address of the function -- I wasn't actually
6740         trying to use this.)
6741
6742 2004-07-14  Andy Wingo  <wingo@pobox.com>
6743
6744         * gst/gstpad.c (gst_pad_try_set_caps): Naive link functions (such
6745         as gst_pad_proxy_pad_link) just link to every other pad when they
6746         are called. In the case where the graph has cycles, this will mean
6747         that a call to try_set_caps will recurse. Allow this recursion
6748         and return OK, while we wait for the first try_set_caps to give a
6749         proper return value.
6750         (gst_pad_link_call_link_functions): Since this function is the
6751         only one to set the NEGOTIATING flag on a pad, if the flag is set
6752         it means that the link functions have indirectly recursed. If this
6753         happens, error out to avoid infinite recursion and an eventual
6754         SEGV.
6755         (gst_real_pad_class_init): Remove a crufty GtkObject comment.
6756         (gst_pad_proxy_getcaps): Intersect the result with the template
6757         caps to ensure that the return value is valid.
6758
6759 2004-07-14  Andy Wingo  <wingo@pobox.com>
6760
6761         * gst/gstdata.c (gst_data_is_writable): s/>=/>/. If there is only
6762         one refcount, the calling function is the owner of the buffer.
6763
6764 2004-07-14  Wim Taymans  <wim@fluendo.com>
6765
6766         * gst/schedulers/gstoptimalscheduler.c: (group_dec_link),
6767         (gst_opt_scheduler_pad_link), (group_migrate_connected):
6768         Fix stupid warning when an element is to be migrated but
6769         is already migrated.
6770
6771 2004-07-14  Wim Taymans  <wim@fluendo.com>
6772
6773         * gst/schedulers/gstoptimalscheduler.c: (group_dec_link),
6774         (gst_opt_scheduler_pad_link), (group_migrate_connected):
6775         Make sure that a single non-loop-based element does not 
6776         end up in a group. This fixes the testsuite again.
6777
6778 2004-07-14  Wim Taymans  <wim@fluendo.com>
6779
6780         * gst/schedulers/gstoptimalscheduler.c: (create_group),
6781         (add_to_group), (merge_groups), (schedule_group),
6782         (gst_opt_scheduler_get_wrapper), (group_elements),
6783         (group_dec_link), (gst_opt_scheduler_pad_link),
6784         (group_migrate_connected), (gst_opt_scheduler_pad_unlink),
6785         (gst_opt_scheduler_iterate):
6786         move isolated groups to a new chain.
6787         Emit a warning instead of segfaulting in some error cases.
6788         Fix a bug where the link count between groups was not calculated 
6789         correctly. Fixes #144510.
6790
6791 2004-07-13  Steve Lhomme  <steve.lhomme@free.fr>
6792         * gst/elements/gstfilesrc.c:
6793           Binary files support under Windows now OK
6794       
6795 2004-07-13  Benjamin Otte  <otte@gnome.org>
6796
6797           compatibility fixes for Solaris 8/gcc 2.95
6798         * configure.ac:
6799           include libintl libs in LDFLAGS
6800         * gstvalue.c (gst_value_deserialize_buffer):
6801           cast isxdigit stuff to int to silence compiler warning
6802
6803 2004-07-12  Benjamin Otte  <otte@gnome.org>
6804
6805         * gst/gsttypes.h:
6806           get rid of GST_O_READONLY, GST_FILE_MODE_READ and
6807           GST_FILE_MODE_WRITE, I don't want them in the exported headers. It
6808           just causes support madness
6809         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
6810           make it work without this
6811         * gst/indexers/gstfileindex.c: (_file_index_id_save_entries),
6812         (gst_file_index_commit):
6813           glib IO channels don't want binary mode
6814         * testsuite/bytestream/filepadsink.c: (main):
6815         * testsuite/bytestream/test1.c: (read_param_file):
6816           use "rb" instead of GST_FILE_MODE_READ, it works on POSIX systems
6817
6818 2004-07-12  Benjamin Otte  <otte@gnome.org>
6819
6820         * gst/gstelement.c: (gst_element_class_init),
6821         (gst_element_set_state), (gst_element_set_state_func):
6822           virutalize gst_element_set_state, use set_state member in class
6823           struct that was already added in 0.7 for this.
6824         * gst/gstbin.c: (gst_bin_foreach), (set_kid_state_func), 
6825         (gst_bin_change_state):
6826           make gst_bin_foreach works similar to other foreach functions, plug
6827           memleaks in it. Make functions using it work with the new approach.
6828           Document gst_bin_foreach, so it can be exported if we want to
6829         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_state):
6830           use virtualized set_state to make set_state on bins set the state of
6831           all its children.
6832
6833 2004-07-12  Benjamin Otte  <otte@gnome.org>
6834
6835         * configure.ac:
6836           require valgrind >= 2.1 (fixes Gentoo bug 53967, see
6837           http://bugs.gentoo.org/show_bug.cgi?id=53967)
6838         * gst/gstpad.c: (gst_pad_alloc_buffer):
6839           allow buffer_alloc functions to return NULL and allocate a normal
6840           buffer in that case
6841
6842 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
6843         * gst/elements/gstfilesink.c:
6844         * gst/elements/gstfilesrc.c:
6845         * gst/indexers/gstfileindex.c:
6846         * gst/gsttypes.h:
6847         * testsuite/bytestream/filepadsink.c:
6848         * testsuite/bytestream/test1.c:
6849           Handle binary files under Windows
6850
6851 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
6852         * docs/manual/win32.xml:
6853         * win32/config.h:
6854         * win32/gst-register.vcproj:
6855         * win32/gstreamer.def:
6856           Update to another gettext public build
6857
6858 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
6859         * gst/gstplugin.c:
6860           Fix an impossible C syntax
6861         * win32/config.h:
6862           Disable i18n under Windows for the moment
6863         * win32/gst-register.vcproj:
6864           Use this configuration
6865
6866 2004-07-12  Jan Schmidt  <thaytan@mad.scientis.com>
6867         * docs/manual/quotes.xml:
6868           Keep the quotes file alive
6869         * docs/random/ds/0.9-suggested-changes:
6870           Add the suggestion of including a 'rowstride' as part of video
6871           format caps
6872
6873 2004-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
6874
6875         * gst/gstelement.c: (gst_element_set_state),
6876         (gst_element_change_state):
6877           d'oh.  Set PENDING state correctly before forcing bin to change.
6878         * gst/gststructure.c: (gst_structure_value_get_generic_type),
6879         (gst_structure_parse_fixed_list):
6880         * gst/schedulers/gstoptimalscheduler.c:
6881         (gst_opt_scheduler_state_transition):
6882         * testsuite/states/parent.c: (main):
6883           remove comment now that it's fixed.
6884
6885 2004-07-11  Benjamin Otte  <otte@gnome.org>
6886
6887         * gst/gstclock.h:
6888           GST_SECOND shouldn't cause a conversion to unsigned.
6889         * testsuite/clock/.cvsignore:
6890         * testsuite/clock/Makefile.am:
6891         * testsuite/clock/signedness.c: (main):
6892           make sure it never will again
6893
6894 2004-07-11  Andy Wingo  <wingo@pobox.com>
6895
6896         * gst/gstbin.c (gst_bin_add_func): If we're adding an element
6897         whose state is higher than the bin state, raise the bin state to
6898         ensure that bin state := highest child state.
6899         
6900 2004-07-11  Andy Wingo  <wingo@pobox.com>
6901
6902         * gst/gstbin.c (gst_bin_foreach): New static function. Calls a
6903         procedure on the children of a bin. Assumes that the procedure can
6904         change the set of children.
6905         (set_kid_state_func): New static function.
6906         (gst_bin_change_state): Use gst_bin_foreach to call
6907         set_kid_state_func. Fixes a bug: if a child had a state-change
6908         handler that removes it from the bin, there would be a segfault.
6909         Hopefully it should also work in the case where the state-change
6910         handler on one child adds or removes other children. In any case,
6911         fixes should go to gst_bin_foreach.
6912
6913 2004-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
6914
6915         * gst/gstelement.c: (gst_element_set_state):
6916           compatibility fix for latest plugins release.  Change loop back
6917           to while {}
6918
6919 2004-07-09  Wim Taymans  <wim@fluendo.com>
6920
6921         * gst/gstbin.c: (gst_bin_remove), (gst_bin_dispose):
6922         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_catch),
6923         (gst_thread_main_loop):
6924         Since remove is virtual in GstBin we must not assume the 
6925         elements GList to have anothing useful.
6926         Add some more logging to GstThread and be a bit more paranoid
6927         when resetting the scheduler.
6928         Set the state of the bin to NULL before removing the children.
6929
6930 2004-07-09  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6931
6932         * testsuite/threads/Makefile.am:
6933         * testsuite/threads/threadg.c:
6934           added test to check if problem when removing all elements from a
6935           GstThread before setting GstThread state to NULL
6936
6937 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6938
6939         * docs/gst/tmpl/gstelement.sgml:
6940         * docs/gst/tmpl/gsttypes.sgml:
6941         * gst/gstbin.c: (gst_bin_change_state):
6942         * gst/gstelement.c: (gst_element_set_state),
6943         (gst_element_change_state):
6944           rework so that for bins we try to set the state on all children
6945           as well even if the bin is in the correct state already.
6946           change while to do so at least one iteration is done.
6947           For regular elements, we fall back to the previous behaviour for
6948           now since we first need a new plugins release.
6949         * testsuite/states/parent.c: (main):
6950           test for this case
6951           Fixes #123774
6952
6953 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6954
6955         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_finalize),
6956         (gst_queue_chain), (gst_queue_get), (gst_queue_handle_src_event),
6957         (gst_queue_release_locks), (gst_queue_change_state),
6958         (gst_queue_set_property):
6959           add proper lock debugging.  Change dispose to finalize, since
6960           we're freeing mutexes and other stuff which should happen only once.
6961
6962 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6963
6964         * docs/gst/tmpl/gstelement.sgml:
6965         * docs/gst/tmpl/gstplugin.sgml:
6966         * docs/gst/tmpl/gsttypes.sgml:
6967         * docs/pwg/building-state.xml:
6968         * gst/elements/gstfakesrc.c: (gst_fakesrc_change_state):
6969         * gst/gstelement.c: (gst_element_change_state):
6970         * gst/gstthread.c: (gst_thread_change_state):
6971           catch wrong state changes in element base class.
6972
6973 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6974
6975         * gst/gstinfo.h:
6976           clean up layout a little.
6977
6978 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6979
6980         * configure.ac:
6981         * testsuite/Makefile.am:
6982         * testsuite/states/Makefile.am:
6983         * testsuite/states/parent.c: (main):
6984           re-enable states testsuite dir.  Add test for state changes and
6985           parent behaviour
6986
6987 2004-07-09  Wim Taymans  <wim@fluendo.com>
6988
6989         * gst/schedulers/gstoptimalscheduler.c:
6990         (gst_opt_scheduler_pad_link), (group_elements_set_visited),
6991         (element_get_reachables_func), (element_get_reachables),
6992         (debug_element), (rechain_group), (group_migrate_connected),
6993         (gst_opt_scheduler_pad_unlink):
6994         Do not try to migrate decoupled elements to a new group since
6995         they are not added to groups.
6996
6997 2004-07-08  Benjamin Otte  <otte@gnome.org>
6998
6999         * gst/gstelement.c: (gst_element_error_func):
7000           make reentrant (= allow removing elements in error handler)
7001
7002 2004-07-08  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7003
7004         * gst/gstpad.c: (gst_pad_event_default_dispatch),
7005         (gst_pad_send_event), (gst_pad_call_chain_function):
7006           events sent to elements below PAUSED cannot be handled, so
7007           don't try to
7008
7009 2004-07-08  Wim Taymans  <wim@fluendo.com>
7010
7011         * gst/schedulers/gstoptimalscheduler.c:
7012         (chain_recursively_migrate_group), (create_group),
7013         (schedule_group), (gst_opt_scheduler_pad_link),
7014         (group_elements_set_visited), (element_get_reachables_func),
7015         (element_get_reachables), (group_can_reach_group), (debug_element),
7016         (rechain_group), (group_migrate_connected),
7017         (gst_opt_scheduler_pad_unlink):
7018         * testsuite/schedulers/Makefile.am:
7019         Implemented group splitting and rechaining.
7020         Fixes 143777 and 143777-2 in the testsuite.
7021
7022 2004-07-08  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7023
7024         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_chain):
7025           extra debugging
7026         * gst/gstevent.h:
7027         * gst/gstinfo.c: (gst_debug_log_default):
7028           print time nicely.  add thread pointer until someone figures out
7029           a completely portable way of getting at thread id's.
7030         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_try),
7031         (_invent_event), (gst_pad_pull), (gst_pad_event_default_dispatch),
7032         (gst_pad_call_chain_function):
7033           extra debugging
7034         * gst/schedulers/gstoptimalscheduler.c:
7035         (get_group_schedule_function), (loop_group_schedule_function),
7036         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
7037         (pad_clear_queued), (gst_opt_scheduler_iterate):
7038           rename BUFPEN and friends to DATAPEN since that's what they are.
7039
7040 2004-07-07  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7041
7042         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_chain):
7043         * gst/gstbuffer.h:
7044         * gst/gstpad.c:
7045           cleanups and debugging
7046
7047 2004-07-07  Ronald Bultje  <rbultje@ronald.bitfreak.net>
7048
7049         * configure.ac:
7050         * gst/gstvalue.c: (gst_value_compare_enum),
7051         (gst_value_serialize_enum), (gst_value_deserialize_enum),
7052         (gst_value_can_compare), (gst_value_compare):
7053         * testsuite/Makefile.am:
7054         * testsuite/enumcaps/Makefile.am:
7055         * testsuite/enumcaps/enumcaps.c:
7056           Fix enum serialization, deserialization, comparison in caps, add
7057           a test to ensure that this continues working in the future.
7058
7059 2004-07-06  David Schleef  <ds@schleef.org>
7060
7061         * gst/gstcaps.c: (gst_caps_save_thyself), (gst_caps_load_thyself):
7062         Fix memleak.
7063
7064 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7065
7066         * gst/gstplugin.c: (gst_plugin_check_file), (gst_plugin_load_file):
7067         * gst/gstplugin.h:
7068         * gst/registries/gstxmlregistry.c:
7069         (plugin_times_older_than_recurse), (plugin_times_older_than),
7070         (gst_xml_registry_parse_padtemplate):
7071           only rebuild registry when actual plugins have a newer time than
7072           the registry.  Fixes #145520
7073
7074 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7075
7076         * docs/manual/manual.xml:
7077         * docs/manual/win32.xml:
7078           add chapter on win32 building.  fixes #142422
7079
7080 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7081
7082         patch by: Sebastien Cote <sc5 at hermes.usherb.ca>
7083
7084         * gst/autoplug/gstspider.c: (gst_spider_init),
7085         (gst_spider_dispose):
7086           fix spider memleaks.  fixes #137863
7087
7088 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7089
7090         patch by: Joe Marcus Clarke <marcus at freebsd dot org>
7091
7092         * gst/schedulers/gstoptimalscheduler.c:
7093         (gst_opt_scheduler_pad_unlink):
7094           fix SIGBUS error, fixes #145338
7095
7096 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7097
7098         * gst/gstobject.c: (gst_object_replace):
7099         * gst/gstscheduler.c: (gst_scheduler_get_clock):
7100         * gst/gstsystemclock.c: (gst_system_clock_obtain):
7101           clean up clock lifecycle.  Fixes #109831
7102
7103 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7104
7105         * po/LINGUAS:
7106         * po/cs.po:
7107           added Czech translation (Miloslav Trmac)
7108
7109 2004-07-04  David Schleef  <ds@schleef.org>
7110
7111         * tools/Makefile.am:
7112         * tools/gst-xmlinspect.1.in:  Add man page. (bug #140219)
7113
7114 2004-07-04  David Schleef  <ds@schleef.org>
7115
7116         * common/m4/gst-doc.m4: Check for docbook2html 0.6.10 (bug #139909)
7117
7118 2004-07-04  Thomas Vander Stichele  <thomas at apestaart dot org>
7119
7120         * gst/gstbin.c: (gst_bin_restore_thyself):
7121           chain to parent restore so the bins get restored correctly
7122           in the editor
7123
7124 2004-07-03  David Schleef  <ds@schleef.org>
7125
7126         * gst/gstcaps.c: (gst_caps_save_thyself), (gst_caps_load_thyself):
7127         Actually do something in these functions, like before the big
7128         caps change.  (bug #145137)
7129
7130 2004-07-03  Thomas Vander Stichele  <thomas at apestaart dot org>
7131
7132         * gst/gstelement.c: (gst_element_get_compatible_pad_template),
7133         (gst_element_get_compatible_pad_filtered):
7134         * gst/gstthread.c: (gst_thread_main_loop):
7135           more debugging
7136
7137 2004-07-02  David Schleef  <ds@schleef.org>
7138
7139         * gst/gstinfo.h: wrap #pragmas in #ifdefs for the correct compiler
7140         * gst/gstobject.h:
7141         * gst/gstparse.h:
7142         * gst/gsttrace.h:
7143         * gst/gstxml.h:
7144
7145 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
7146
7147         * gst/gstpad.c: (gst_pad_check_schedulers),
7148         (gst_pad_can_link_filtered), (gst_pad_link_filtered),
7149         (gst_pad_link_prepare):
7150           revert until testsuite is fixed
7151
7152 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
7153
7154         * testsuite/Makefile.am:
7155         * testsuite/caps/filtercaps.c: (main):
7156         * testsuite/clock/clock1.c: (main):
7157         * testsuite/dynparams/dparamstest.c: (gst_dptest_chain), (main):
7158           fix some more tests
7159
7160 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
7161
7162         * testsuite/cleanup/cleanup1.c: (create_pipeline):
7163         * testsuite/cleanup/cleanup2.c: (create_pipeline):
7164         * testsuite/cleanup/cleanup4.c: (main):
7165           fix testsuite
7166
7167 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
7168
7169         * libs/gst/control/control.c:
7170         * libs/gst/control/dparam.c:
7171         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_get_type):
7172         * libs/gst/control/dparammanager.c:
7173         * libs/gst/control/dparammanager.h:
7174         * testsuite/dynparams/Makefile.am:
7175         * testsuite/dynparams/dparamstest.c: (gst_dptest_base_init),
7176         (gst_dptest_change_state), (gst_dptest_chain), (main):
7177           fix testcase for dparams
7178           add debugging category
7179
7180 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
7181
7182         * testsuite/Rules:
7183           change path
7184
7185 2004-07-02  Benjamin Otte  <otte@gnome.org>
7186
7187         * tests/.cvsignore:
7188         * tests/Makefile.am:
7189         * tests/mass_elements.c: (gst_get_current_time), (main):
7190           add simple benchmark to test various speeds of fakesrc ! identity !
7191           identity ! ... ! fakesink.
7192           Usage: mass_elements [num_identities] [num_buffers]
7193           If not specified they default to 1000.
7194
7195 2004-07-02  Benjamin Otte  <otte@gnome.org>
7196
7197         * gst/gstpad.c: (gst_pad_check_schedulers),
7198         (gst_pad_can_link_filtered), (gst_pad_link_filtered),
7199         (gst_pad_link_prepare):
7200           check that pads that get linked belong to the same manager. The old
7201           code allowed linking elements before putting them into bins, so it
7202           worked to link them and then put them in different threads, which
7203           lead to weird behaviour.
7204           Since this effectively disallows linking elements before putting
7205           them in a bin, some applications might not work after this and error
7206           out. If these applications are too critical, we might need to revert
7207           that patch. Please test this before the next release...
7208
7209 2004-06-28  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7210
7211         * gst/gstpad.c: (gst_pad_get_caps):
7212           throw an error if the getcaps function does not return a subset of
7213           the template caps.
7214         * libs/gst/bytestream/filepad.c: (gst_file_pad_chain):
7215           make disconts without position info an error in debugging
7216         * tests/spidey_bench.c: (handoff), (main):
7217           don't count first try when averaging
7218
7219 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
7220
7221         * gst/gstplugin.c: (gst_plugin_load_file):
7222           figure out problem with dynamic test
7223
7224 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
7225
7226         * docs/gst/Makefile.am:
7227           fix docs build
7228
7229 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
7230
7231         * po/POTFILES.in:
7232         * po/af.po:
7233         * po/az.po:
7234         * po/en_GB.po:
7235         * po/fr.po:
7236         * po/nl.po:
7237         * po/sr.po:
7238         * po/sv.po:
7239         * po/tr.po:
7240         * po/uk.po:
7241         * tools/gst-register.c: (plugin_added_func), (main):
7242           i18n-ize -register, fix plural
7243
7244 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
7245
7246         * gst/elements/gstidentity.c: (gst_identity_class_init),
7247         (gst_identity_init), (gst_identity_chain),
7248         (gst_identity_set_property), (gst_identity_get_property):
7249         * gst/elements/gstidentity.h:
7250           check for perfect stream
7251
7252 2004-06-25  Thomas Vander Stichele  <thomas at apestaart dot org>
7253
7254         * gst/elements/gstidentity.c: (gst_identity_chain):
7255           print offset_end
7256
7257 2004-06-25  Thomas Vander Stichele  <thomas at apestaart dot org>
7258
7259         * docs/gst/Makefile.am:
7260         * docs/gst/gstreamer-docs.sgml:
7261           doc fixes
7262
7263 2004-06-24  David Schleef  <ds@schleef.org>
7264
7265         * autogen.sh:  Remove call to env, since the buildbot isn't
7266         broken anymore.
7267
7268 2004-06-24  Wim Taymans  <wim@fluendo.com>
7269
7270         * gst/elements/Makefile.am:
7271         * gst/elements/gstelements.c:
7272         * gst/elements/gstmultifdsink.c: (gst_multifdsink_base_init),
7273         (gst_multifdsink_class_init), (gst_multifdsink_init),
7274         (gst_multifdsink_add), (gst_multifdsink_remove),
7275         (gst_multifdsink_clear), (gst_multifdsink_chain),
7276         (gst_multifdsink_set_property), (gst_multifdsink_get_property):
7277         * gst/elements/gstmultifdsink.h:
7278         Added an element that writes to multiple filedescriptors at once.
7279
7280 2004-06-24  Benjamin Otte  <otte@gnome.org>
7281
7282         * gst/parse/grammar.y:
7283           don't try to link elements before they have been added to bins
7284
7285 2004-06-24  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7286
7287         * libs/gst/bytestream/filepad.c: (gst_file_pad_available),
7288         (gst_file_pad_get_length):
7289         * libs/gst/bytestream/filepad.h:
7290           add 2 new functions
7291
7292 2004-06-22  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7293
7294         * docs/gst/gstreamer-sections.txt:
7295         remove from docs, the define that Benjamin removed from gstelement.h
7296
7297 2004-06-22  Benjamin Otte  <otte@gnome.org>
7298
7299         * gst/gstelement.h:
7300           remove define that referenced a nonexisting GstElement struct member
7301
7302 2004-06-20  Benjamin Otte  <otte@gnome.org>
7303
7304         * gst/gstdata.c: (gst_data_is_writable):
7305           whoops, return values were wrong, so writable data was marked as
7306           non-writable and vice versa. (fixes #143953, spotted by Francis
7307           Labonte)
7308           Shows how rarely we need to copy data ;)
7309
7310 2004-06-20  Benjamin Otte  <otte@gnome.org>
7311
7312         * testsuite/schedulers/.cvsignore:
7313         * testsuite/schedulers/Makefile.am:
7314         * testsuite/schedulers/143777-2.c: (main):
7315           add test for opt breakage in bug #143777
7316
7317 2004-06-20  Benjamin Otte  <otte@gnome.org>
7318
7319         * gst/gstpad.c: (gst_pad_call_chain_function):
7320           check for if we were unlinked while inside the chainfunction (fixes
7321           entrygthread having issues with #143777)
7322         * testsuite/schedulers/143777.c: (main):
7323         * testsuite/schedulers/Makefile.am:
7324           add a test for that fix
7325
7326 2004-06-20  Benjamin Otte  <otte@gnome.org>
7327
7328         * gst/gstvalue.c: (gst_value_set_int_range):
7329           test that start is smaller then end
7330         * libs/gst/bytestream/Makefile.am:
7331         * libs/gst/bytestream/filepad.c: 
7332         * libs/gst/bytestream/filepad.h:
7333           add GstFilePad - a pad that behaves like a FILE*
7334         * testsuite/bytestream/.cvsignore:
7335         * testsuite/bytestream/Makefile.am:
7336         * testsuite/bytestream/filepadsink.c: 
7337           test for the GstFilePad
7338
7339 2004-06-18  Thomas Vander Stichele  <thomas at apestaart dot org>
7340
7341         * gst/elements/gstidentity.c: (gst_identity_class_init),
7342         (gst_identity_init), (gst_identity_set_clock),
7343         (gst_identity_chain), (gst_identity_set_property),
7344         (gst_identity_get_property):
7345         * gst/elements/gstidentity.h:
7346         * gst/gstclock.c: (gst_clock_id_wait):
7347           add a "sync" property to sync to the clock
7348
7349 2004-06-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7350
7351         * gst/gstelementfactory.c: (gst_element_factory_create):
7352           make the freakin "elementfactory bla has no type" message more
7353           useful. So we actually can do something when someone shows up
7354           complaining about it.
7355
7356 2004-06-15  Johan Dahlin  <johan@gnome.org>
7357
7358         * tools/gst-inspect.c (main): Fallback to plugin if no element is
7359         found. This matches the old behavior better. Thanks to Thomas for
7360         pointing out.
7361
7362 2004-06-14  David Schleef  <ds@schleef.org>
7363
7364         * gst/gstcpu.c: (gst_cpuid_i386): Fix problem when using
7365         -fomit-frame-pointer.  Appears to generate correct code in
7366         other cases as well.
7367
7368 2004-06-14  Johan Dahlin  <johan@gnome.org>
7369
7370         * tools/gst-inspect.c (main): Add two new command line options: -a
7371         to print all elements and -n to print the name on each line. Also
7372         fix some error reporting.
7373         (main): Simplify, remove -n and always print names if -a is specified
7374
7375 2004-06-13  Steve Lhomme  <steve.lhomme@free.fr>
7376
7377         * win32/gstconfig.h:
7378         * win32/GSTreamer.vcproj:
7379         * win32/Makefile:
7380         * gst/gstconfig.h.in:
7381         * gst/gst.h:
7382         * gst/gstbin.h:
7383         * gst/gstelement.h:
7384         * gst/gstevent.h:
7385         * gst/gstobject.h:
7386         * gst/gstpad.h:
7387         * docs/gst/gstreamer-sections.txt:
7388         * docs/gst/tmpl/gstconfig.sgml:
7389           rename GSTREAMER_EXPORT(S) to GST_EXPORT(S)
7390
7391 2004-06-13  Jan Schmidt  <thaytan@mad.scientist.com>
7392         * docs/gst/gstreamer-sections.txt:
7393         * docs/gst/tmpl/gstconfig.sgml:
7394         Add the GSTREAMER_EXPORT macro to the docs
7395
7396 2004-06-13  Jan Schmidt  <thaytan@mad.scientist.com>
7397
7398         * tools/gst-compprep.c: (handle_xmlerror), (main):
7399         Add a check for the version that introduced SetStructuredError to fix
7400         the build on FC1
7401
7402 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7403
7404         * win32/msvc71.sln:
7405         * win32/testsuite/:
7406           prepare to compile the testsuite with MSVC
7407
7408 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7409
7410         * docs/manual/win32.xml:
7411           attempt to transform the Win32 README into an XML doc
7412
7413 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7414
7415         * gst/gst.c:
7416         * gst/gstbin.*:
7417         * gst/config.h.in:
7418         * gst/gstelement.*:
7419         * gst/gstevent.h:
7420         * gst/gstobject.*:
7421         * gst/gstpad.h:
7422         * tools/gst-register.c:
7423         * win32/gstreamer.def:
7424           extern symbols are now exported for the Windows DLL
7425
7426 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7427
7428         * gst/gstinfo.h:
7429           fix a problem to enable/disable DEBUG under MSVC
7430
7431 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7432
7433         * win32/:
7434           enable more debug code in DEBUG build
7435
7436 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7437
7438         * win32/config.h:
7439         * gst/gst-i18n-app.h:
7440           enable NLS under Windows
7441
7442 2004-06-12  Jan Schmidt  <thaytan@mad.scientist.com>
7443         * tools/gst-compprep.c: (handle_xmlerror), (main):
7444           Make an error that baffled me a bit clearer
7445
7446 2004-06-12  Thomas Vander Stichele  <thomas at apestaart dot org>
7447
7448         * gst/gstqueue.c:
7449           don't use g_queue_get_length () because it's 2.4, use ->length
7450
7451 2004-06-11  Steve Lhomme  <steve.lhomme@free.fr>
7452
7453         reviewed by Benjamin Otte  <in7y118@public.uni-hamburg.de>
7454
7455         * tools/gst-inspect.c: (print_signal_info):
7456           don't free random data twice. (fixes #144185)
7457
7458 2004-06-11  Thomas Vander Stichele  <thomas at apestaart dot org>
7459
7460         * gst/gstqueue.c:
7461         * gst/gstqueue.h:
7462           fix removing from the wrong queue on event timeout
7463           fix disposing of the event queue by casting correctly
7464           add mutexes for handling the event queue
7465           someone was sleeping when fixing queue last time around :)
7466
7467 2004-06-10  Johan Dahlin  <johan@gnome.org>
7468
7469         * gst/gst.c (gst_init_check_with_popt_table): Do not fail on
7470         errors, like gtk. It makes it more useful in bindings.  Fixes #141692.
7471
7472 2004-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
7473
7474         * docs/random/gdp:
7475         * libs/gst/dataprotocol/dataprotocol-test.c: (buffer_test):
7476         * libs/gst/dataprotocol/dataprotocol.c:
7477         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
7478         (gst_dp_buffer_from_header):
7479         * libs/gst/dataprotocol/dataprotocol.h:
7480         * libs/gst/dataprotocol/dp-private.h:
7481           rev version to 0.1, add buffer flags and copy them
7482
7483 2004-06-09  Johan Dahlin  <johan@gnome.org>
7484
7485         * gst/gstbuffer.c (gst_buffer_default_copy): Don't forget to merge
7486         the flags from the buffer we're copying.
7487
7488 2004-06-09  Wim Taymans  <wim@fluendo.com>
7489
7490         * gst/elements/gstfakesink.c: (gst_fakesink_chain):
7491         * gst/elements/gstidentity.c: (gst_identity_init),
7492         (gst_identity_chain):
7493         Print more buffer info in fakesink.
7494         Make identity output similar to fakesink.
7495
7496 2004-06-07  Daniel Gazard  <dany42@free.fr>
7497
7498         reviewed by Benjamin Otte  <otte@gnome.org>
7499
7500         * configure.ac:
7501           fix cross compiling not working. (fixes #143741)
7502
7503 2004-06-07  Benjamin Otte  <otte@gnome.org>
7504
7505         * gst/gstelement.c: (gst_element_set_time_delay):
7506           add failure check
7507         * gst/gstinfo.h:
7508           put brackets around macro arguments of GST_TIME_ARGS, add note to
7509           move it to correct header in 0.9
7510
7511 2004-06-07  Benjamin Otte  <otte@gnome.org>
7512
7513         * gst/indexers/gstfileindex.c: (gst_file_index_get_writer_id),
7514         (gst_file_index_load), (_file_index_id_save_entries),
7515         (gst_file_index_commit), (gst_file_index_add_association),
7516         (gst_file_index_add_entry), (gst_file_index_get_assoc_entry),
7517         (gst_file_index_plugin_init):
7518           make debugging use a default category
7519
7520 2004-06-06  David Moore  <dcm@acm.org>
7521
7522         reviewed by Benjamin Otte  <otte@gnome.org>
7523
7524         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init),
7525         (gst_fdsrc_change_state):
7526           reset offset counter when going READY => PAUSED. (fixes #142903)
7527
7528 2004-06-06  ed@catmur.co.uk
7529
7530         reviewed by Benjamin Otte  <otte@gnome.org>
7531
7532         * gst/registries/gstxmlregistry.c:
7533         (gst_xml_registry_rebuild_recurse):
7534           don't rely on g_dir_open to figure out if a file is a directory, use
7535           explicit G_TEST_IS_DIR. Reiserfs4 allows opening files as
7536           directories. (fixes #142850)
7537
7538 2004-06-06  Benjamin Otte  <otte@gnome.org>
7539
7540         * gst/gstqueue.c: (gst_queue_dispose), (gst_queue_change_state):
7541           fix memory leaks (fixes #142795). Initial patch by Sebastien Cote
7542         * libs/gst/bytestream/adapter.c:
7543         * libs/gst/bytestream/adapter.h:
7544           fix copyright in header and typo in debugging category name
7545
7546 2004-06-05  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7547
7548         * configure.ac:
7549           bump nano to cvs
7550
7551 === release 0.8.3 ===
7552
7553 2004-06-05  Thomas Vander Stichele  <thomas at apestaart dot org>
7554
7555         * configure.ac:
7556           update libtool versioning
7557           do a new release
7558         * docs/gst/tmpl/gstelement.sgml:
7559         * docs/gst/tmpl/gsttypes.sgml:
7560         * gst/gstinfo.c: (_gst_debug_init):
7561           put back GST_CAT_DATAFLOW to fix API breakage
7562
7563 2004-06-04  David Schleef  <ds@schleef.org>
7564
7565         * autogen.sh: Add a temporary 'env' to test buildbot problems.
7566
7567 2004-06-04  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7568
7569         * configure.ac:
7570           bump nano to cvs
7571
7572 === release 0.8.2 ===
7573
7574 2004-06-03  Thomas Vander Stichele  <thomas at apestaart dot org>
7575
7576         * gst/gst.c: (parse_debug_list), (gst_init_check_with_popt_table):
7577           check GST_DEBUG environment variable which is parsed the same way
7578           as --gst-debug=
7579
7580 2004-05-28  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
7581
7582         * gst/elements    : gstaggregator.c gstfakesink.c gstfakesrc.c
7583                             gstmd5sink.c gstshaper.c gsttee.c
7584                             gsttypefindelement.c
7585         * gst/schedulers  : gstbasicscheduler.c gstoptimalscheduler.c
7586
7587           - removing trailing commas at end of enums
7588             it is correct C99 code but C90 compilers would complain
7589             (AIX, Forte, ...)
7590             ('should' fix #143290, at least partially)
7591
7592 2004-05-27  Wim Taymans  <wim@fluendo.com>
7593
7594         * gst/schedulers/gstoptimalscheduler.c: (remove_from_chain),
7595         (chain_group_set_enabled), (create_group), (add_to_group),
7596         (merge_groups), (setup_group_scheduler), (group_elements),
7597         (gst_opt_scheduler_iterate), (gst_opt_scheduler_show):
7598         Don't try to follow the pad connections with other groups
7599         when a loop based element is added to the scheduler because
7600         the bin will inform the scheduler about the pad links a little
7601         later.
7602
7603 2004-05-27  Wim Taymans  <wim@fluendo.com>
7604
7605         * gst/schedulers/gstoptimalscheduler.c: (add_to_chain),
7606         (remove_from_chain), (chain_group_set_enabled),
7607         (setup_group_scheduler), (group_element_set_enabled),
7608         (gst_opt_scheduler_state_transition), (gst_opt_scheduler_iterate),
7609         (gst_opt_scheduler_show):
7610         Elements without a group can do a state change as well, just wait
7611         with the setup of the scheduling function when it is added to a
7612         chain.
7613
7614 2004-05-27  Wim Taymans  <wim@fluendo.com>
7615
7616         * gst/schedulers/gstoptimalscheduler.c: (add_to_chain),
7617         (remove_from_chain), (chain_group_set_enabled), (add_to_group),
7618         (merge_groups), (setup_group_scheduler),
7619         (group_inc_links_for_element), (gst_opt_scheduler_iterate),
7620         (gst_opt_scheduler_show):
7621         Fixes to maintain internal consistency of the scheduler data
7622         structures. 
7623          - adding an enabled group to a chain should increment the
7624            number of enabled elements in that chain.
7625          - removing an enabled group from a chain could disable the
7626            chain.
7627          - removing a disabled group from a chain could enable the
7628            chain.
7629          - add g_assert when internal inconsistency is detected.
7630          - adding an element to a group could increase the number of
7631            links this group has with other groups.
7632          - merging two groups also merges the chains.
7633          - also show group links in the _show method.
7634            
7635
7636 2004-05-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7637
7638         * gst/gstcaps.c: (gst_caps_structure_simplify):
7639           don't print error messages when there is no error
7640         * gst/gstvalue.c: (gst_value_compare_int_range):
7641           compare the second value, too
7642         * testsuite/caps/Makefile.am:
7643         * testsuite/caps/random.c: (assert_on_error), (main):
7644           add tests to make sure the two things above are checked for
7645
7646 2004-05-24  Thomas Vander Stichele  <thomas at apestaart dot org>
7647
7648         * configure.ac:
7649         * libs/gst/dataprotocol/Makefile.am:
7650         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_caps):
7651         * libs/gst/dataprotocol/dataprotocol.h:
7652           wrap header in GST_ENABLE_NEW.  make code use it
7653
7654 2004-05-23  Johan Dahlin  <johan@gnome.org>
7655
7656         * tools/gst-inspect.c (main): Cleanup most parts of it, don't be
7657         so verbose and print GstElement signal names all the time.
7658
7659 2004-05-22  David Schleef  <ds@schleef.org>
7660
7661         * gst/registries/gstxmlregistry.c:
7662         (gst_xml_registry_parse_padtemplate): Fix warning on OS X.
7663         (bug #142957)
7664
7665 2004-05-22  Thomas Vander Stichele  <thomas at apestaart dot org>
7666
7667         * configure.ac:
7668           scrub cflags for glib2 so gcc doesn't complain when glib is in
7669           /usr/local
7670
7671 2004-05-21  Johan Dahlin  <johan@gnome.org>
7672
7673         * gst/gstcpu.c (gst_cpuid_i386): Protect some gcc asm stuff with
7674         __GNUC__, patch from Brian Cameron, fixes bug #142804
7675
7676 2004-05-20  David Schleef  <ds@schleef.org>
7677
7678         * gst/gstindex.c: (gst_index_compare_func): Fix overflows in
7679         comparison code.  (bug #142819)
7680
7681 2004-05-20  Wim Taymans  <wim@fluendo.com>
7682
7683         * gst/gstbuffer.c: (gst_buffer_default_copy):
7684         * gst/gstbuffer.h:
7685         Added Comment to a flag.
7686         copy relevant flags in _buffer_copy.
7687
7688 2004-05-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7689
7690         reviewed by: Wim Taymans <wim at fluendo dot com>
7691
7692         * gst/gstbuffer.h:
7693           add GST_BUFFER_IN_CAPS buffer flag
7694         * gst/gststructure.c: (gst_structure_value_get_generic_type),
7695         (gst_structure_parse_any_list), (gst_structure_parse_list),
7696         (gst_structure_parse_fixed_list), (gst_structure_parse_value):
7697         * gst/gstvalue.c: (gst_value_serialize_any_list),
7698         (gst_value_transform_any_list_string),
7699         (gst_value_list_prepend_value), (gst_value_list_append_value),
7700         (gst_value_list_get_size), (gst_value_list_get_value),
7701         (gst_value_transform_list_string),
7702         (gst_value_transform_fixed_list_string),
7703         (gst_value_serialize_list), (gst_value_serialize_fixed_list),
7704         (gst_value_deserialize_fixed_list), (gst_type_is_fixed),
7705         (_gst_value_initialize):
7706         * gst/gstvalue.h:
7707           add a GST_TYPE_FIXED_LIST which is fixed by definition and uses
7708           < , > as a format.
7709         * testsuite/caps/string-conversions.c: (main):
7710           add regression tests for < >
7711
7712 2004-05-20  Johan Dahlin  <johan@gnome.org>
7713
7714         * docs/gst/Makefile.am (all-local): Re-add
7715
7716 2004-05-20  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7717
7718         * docs/gst/Makefile.am:
7719         * docs/gst/gstreamer-docs.sgml:
7720         * docs/libs/Makefile.am:
7721         * docs/libs/gstreamer-libs-docs.sgml:
7722           fix distcheck issues
7723
7724 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
7725
7726         * libs/gst/dataprotocol/Makefile.am:
7727           add to autotest
7728
7729 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
7730
7731         * libs/gst/dataprotocol/Makefile.am:
7732         * libs/gst/dataprotocol/dataprotocol.c:
7733         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
7734         (gst_dp_packet_from_event), (gst_dp_event_from_packet):
7735         * libs/gst/dataprotocol/dp-private.h:
7736           use GST macros to read/write fixed length ints
7737           add some more asserts
7738
7739 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
7740
7741         * docs/libs/gstreamer-libs-docs.sgml:
7742         * docs/libs/gstreamer-libs-sections.txt:
7743           remove idct and putbits
7744         * configure.ac:
7745         * docs/libs/tmpl/gstdataprotocol.sgml:
7746         * libs/gst/Makefile.am:
7747         * libs/gst/dataprotocol/Makefile.am:
7748         * libs/gst/dataprotocol/dataprotocol-test.c: (conversion_test),
7749         (buffer_test), (caps_test), (event_test), (main):
7750         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_crc),
7751         (gst_dp_dump_byte_array), (gst_dp_init),
7752         (gst_dp_header_payload_length), (gst_dp_header_payload_type),
7753         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
7754         (gst_dp_packet_from_event), (gst_dp_buffer_from_header),
7755         (gst_dp_caps_from_packet), (gst_dp_event_from_packet),
7756         (gst_dp_validate_header), (gst_dp_validate_payload),
7757         (gst_dp_validate_packet), (plugin_init):
7758         * libs/gst/dataprotocol/dataprotocol.h:
7759         * libs/gst/dataprotocol/dp-private.h:
7760           add dataprotocol
7761
7762 2004-05-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7763
7764         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
7765           fix int variable deserialization and add a helper so we can actually
7766           debug this.
7767
7768 2004-05-18  David Schleef  <ds@schleef.org>
7769
7770         * testsuite/debug/commandline.c: (main): Call ./commandline, not
7771           argv[0].  Calling yourself is probably not the best way to
7772           construct a test like this, btw.
7773
7774 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7775
7776         * gst/gstbin.c: (gst_bin_iterate_func), (gst_bin_iterate):
7777           don't claim to be more intelligent than a scheduler when the
7778           scheduler claims the pipeline is stopped
7779         * gst/schedulers/entryscheduler.c: (safe_cothread_switch),
7780         (safe_cothread_destroy),
7781         (gst_entry_scheduler_remove_all_cothreads),
7782         (gst_entry_scheduler_reset), (_remove_cothread),
7783         (gst_entry_scheduler_state_transition):
7784           hold off cothread destruction if we're not in main cothread
7785         * configure.ac:
7786         * testsuite/Makefile.am:
7787           add new test dir
7788         * testsuite/schedulers/.cvsignore:
7789         * testsuite/schedulers/Makefile.am:
7790           add tests
7791         * testsuite/schedulers/relink.c: (cb_handoff), (main):
7792           check relinking and adding/removing elements from a running pipeline
7793         * testsuite/schedulers/unlink.c: (cb_handoff), (main):
7794           check unlinking in a running pipeline
7795         * testsuite/schedulers/unref.c: (cb_handoff), (main):
7796           check unreffing a running pipeline
7797         * testsuite/schedulers/useless_iteration.c: (main):
7798           check iterating a pipeline that contains running threads works
7799
7800 2004-05-18  David Schleef  <ds@schleef.org>
7801
7802         * docs/gst/Makefile.am: Add all-local target for when HAVE_GTK_DOC
7803           is false.
7804
7805 2004-05-18  Wim Taymans  <wim@fluendo.com>
7806
7807         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
7808         (setup_group_scheduler), (gst_opt_scheduler_pad_link):
7809         Fixed an error introduced with patch for 1.63. When setting
7810         a get based element as the entry point in a group, make sure
7811         to mark the group as GET based.
7812
7813 2004-05-18  Wim Taymans  <wim@fluendo.com>
7814
7815         * gst/schedulers/gstoptimalscheduler.c: (create_group),
7816         (setup_group_scheduler), (loop_group_schedule_function),
7817         (gst_opt_scheduler_pad_link):
7818         Added some more debug info and fixed a bug where the group
7819         type was set to LOOP but it was in fact unknown.
7820
7821 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7822
7823         * gst/schedulers/entryscheduler.c: (gst_entry_scheduler_reset):
7824           make resetting scheduler work twice in a row
7825
7826 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7827
7828         * gst/gstvalue.c: (gst_strtoll), (CREATE_SERIALIZATION),
7829         (CREATE_USERIALIZATION), (_gst_value_initialize),
7830         (gst_value_compare_float), (gst_value_serialize_float),
7831         (gst_value_deserialize_float), (gst_value_compare_enum),
7832         (gst_value_serialize_enum), (gst_value_deserialize_enum):
7833           add serialization and comparison functions for long, int64, enum and
7834           float values
7835         * gst/gstvalue.c: (gst_value_serialize), (gst_value_deserialize):
7836           use best serialization function in type hierarchy instead of only a
7837           matching one. This is required for enums to work.
7838         * gst/parse/grammar.y:
7839           use gst_caps_deserialize
7840         * testsuite/parse/Makefile.am:
7841           parse1 now works
7842         * testsuite/parse/parse1.c: (main):
7843           remove aggregator check, aggregator is broken, this test works now
7844           but fails because of bug #138012
7845         * testsuite/parse/parse2.c: (main):
7846           s/xvideosink/xvimagesink - this test looks a lot like we should
7847           disable it
7848
7849 2004-05-13  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7850
7851         * gst/gstelement.c: (gst_element_class_init):
7852           whoops, store the signal id correctly
7853         * gst/schedulers/gstbasicscheduler.c:
7854         (gst_basic_scheduler_chain_wrapper):
7855           detect infinfinfinfinfinf^Cinite loops in chain wrapper when the
7856           chain function isn't linked
7857
7858 2004-05-13  Jan Schmidt  <thaytan@mad.scientist.com>
7859         * configure.ac:
7860         Add $GST_PKG_CFLAGS back into GST_INT_CFLAGS so I have large file
7861         support until we decide where the flags should be used
7862         * gst/elements/gstfilesrc.c: (gst_filesrc_srcpad_query):
7863         Use GST_FORMAT_BYTES when GST_FORMAT_DEFAULT is passed
7864         * gst/gstpad.c: (gst_pad_link_call_link_functions):
7865         Output refused caps in the debug info
7866
7867 2004-05-13  Thomas Vander Stichele  <thomas at apestaart dot org>
7868
7869         * gst/elements/gstidentity.c: (gst_identity_chain):
7870           add duration debug
7871         * gst/gstinfo.c: (gst_debug_log_default):
7872           add timestamp
7873
7874 2004-05-13  Benjamin Otte  <otte@gnome.org>
7875
7876         * gst/gstpipeline.c: (gst_pipeline_dispose),
7877         (gst_pipeline_change_state):
7878           call gst_scheduler_reset on dispose (fixes #141416)
7879
7880 2004-05-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7881
7882         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
7883           compute mapsize correctly
7884         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
7885           use correct datatypes when calling a varargs function
7886         * gst/elements/gsttypefindelement.c: (stop_typefinding):
7887           push a DISCONT event as first thing
7888         * gst/gst_private.h:
7889         * gst/gstinfo.c: (_gst_debug_init):
7890           remove GST_DATAFLOW debugging category
7891         * gst/gstbin.c: (gst_bin_iterate):
7892           use GST_SCHEDULING category
7893         * gst/gstpad.c: (gst_pad_get_type), (_invent_event),
7894         (gst_pad_push), (gst_pad_pull), (gst_pad_call_chain_function),
7895         (gst_pad_call_get_function):
7896           add GST_DATAFLOW to easily track flow of buffers or events.
7897         * gst/gstqueue.c: (gst_queue_get_type),
7898         (gst_queue_handle_pending_events), (gst_queue_chain),
7899         (gst_queue_get), (gst_queue_handle_src_event):
7900           use own static debugging category GST_DATAFLOW for dataflow,
7901           use DEBUG category for showing which path events go, use LOG
7902           category for buffers.
7903
7904 2004-05-10  David Schleef  <ds@schleef.org>
7905
7906         * docs/gst/gstreamer-sections.txt: Add gst_element_no_more_pads.
7907
7908 2004-05-10  David Schleef  <ds@schleef.org>
7909
7910         * docs/gst/Makefile.am: Dear gtk-doc, please print out the unused
7911         symbols, because otherwise we don't know what they are.  Thanks,
7912         the GStreamer team.
7913         * gst/registries/gstxmlregistry.c: (make_dir): Remove a spurious ;
7914
7915 2004-05-10  David Schleef  <ds@schleef.org>
7916
7917         (from Steve Lhomme)
7918         * win32/Makefile: When using make clean the MS Visual Studio makefiles
7919         are deleted.  Fix.
7920         * win32/Makefile.inspect:
7921         * win32/Makefile.launch:
7922         * win32/Makefile.register:
7923
7924 2004-05-10  David Schleef  <ds@schleef.org>
7925
7926         * gst/gstinfo.h: Add missing inline function.
7927         * gst/gsttrace.c: add include
7928         * gst/parse/grammar.y: remove unused code
7929         * gst/registries/gstxmlregistry.c: (make_dir): make mkdir call
7930         more portable.
7931         * tools/gst-register.c: wrap unistd.h
7932         
7933         More additions/fixes from Steve for the MSVC build.
7934         * win32/GStreamer.vcproj:
7935         * win32/Makefile:
7936         * win32/Makefile.inspect:
7937         * win32/Makefile.launch:
7938         * win32/Makefile.register:
7939         * win32/README.txt:
7940         * win32/gst-inspect.vcproj:
7941         * win32/gst-launch.vcproj:
7942         * win32/gst-register.vcproj:
7943         * win32/gstbytestream.def:
7944         * win32/gstbytestream.vcproj:
7945         * win32/gstconfig.h:
7946         * win32/gstelements.def:
7947         * win32/gstelements.vcproj:
7948         * win32/gstenumtypes.c:
7949         * win32/gstenumtypes.h:
7950         * win32/gstoptimalscheduler.def:
7951         * win32/gstoptimalscheduler.vcproj:
7952         * win32/gstreamer.def:
7953         * win32/gstspider.def:
7954         * win32/gstspider.vcproj:
7955         * win32/gstversion.h:
7956         * win32/msvc71.sln:
7957
7958 2004-05-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7959
7960         * gst/gstelement.c: (gst_element_class_init),
7961         (gst_element_no_more_pads):
7962         * gst/gstelement.h:
7963           add gst_element_no_more_pads and the "no-more-pads" signal
7964
7965 2004-05-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7966
7967         * gst/gstregistry.c: (gst_registry_add_plugin):
7968           refuse to add plugins when a plugin with same name is already
7969           registered. Fixes a bunch of "How to remove plugins?" issues.
7970           May lead to other problems though, let's test
7971
7972 2004-05-10  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
7973
7974         * testsuite/caps/caps_strings : audio/ac3 => audio/x-ac3
7975         * docs/manual/pads-api.xml : audio/wav => audio/x-wav
7976         * docs/random/uraeus/gstreamer_and_midi.txt : audio/wav => audio/x-wav
7977
7978 2004-05-09  Thomas Vander Stichele  <thomas at apestaart dot org>
7979
7980         * tests/Makefile.am: fix am16 issue
7981
7982 2004-05-09  Benjamin Otte  <otte@gnome.org>
7983
7984         * libs/gst/bytestream/Makefile.am:
7985           we should indeed add .c files to makefiles or they won't be built
7986           (d'oh)
7987
7988 2004-05-08  Benjamin Otte  <otte@gnome.org>
7989
7990         * gst/gstpad.c: (gst_pad_proxy_fixate):
7991           really reduce the set of caps
7992
7993 2004-05-08  Benjamin Otte  <otte@gnome.org>
7994
7995         * tests/Makefile.am:
7996         * tests/spidey_bench.c: (handoff), (main):
7997           add benchmark to test how long spider needs to create a pipeline
7998
7999 2004-05-08  Benjamin Otte  <otte@gnome.org>
8000
8001         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_unnegotiate):
8002           mark links as unengaged when unnegotiating instead of deactivating.
8003           This way pads aren't marked as unengaged when going PLAYING=>PAUSED
8004
8005 2004-05-08  Benjamin Otte  <otte@gnome.org>
8006
8007         * docs/manual/helloworld.xml:
8008           s/audiosink/osssink (patch by Patrick Guimond)
8009
8010 2004-05-07  David Schleef  <ds@schleef.org>
8011
8012         * configure.ac: Make sure GST_INT_CFLAGS is not clobbered,
8013         since it contains important stuff.
8014
8015 2004-05-07  David Schleef  <ds@schleef.org>
8016
8017         * testsuite/caps/caps.c: (test3), (main): A check for appending
8018         ANY caps.
8019
8020 2004-05-07  David Schleef  <ds@schleef.org>
8021
8022         * common/m4/as-compiler-flag.m4: Properly quote arguments,
8023         which may contain commas.  Fixes detection of -Wa,-mregnames
8024
8025 2004-05-06  David Schleef  <ds@schleef.org>
8026
8027         Changes to handle compilers that don't have variadic macro
8028         support.  In particular, glib headers define some inlines
8029         that need G_LOG_DOMAIN defined.  Additional fixes for MSVC
8030         builds.
8031         * gst/Makefile.am:
8032         * gst/cothreads.c:
8033         * gst/elements/gstfdsink.c:
8034         * gst/elements/gstfdsrc.c:
8035         * gst/elements/gstfilesink.c:
8036         * gst/elements/gstfilesrc.c:
8037         * gst/gst_private.h:
8038         * gst/gstatomic.c:
8039         * gst/gstcaps.c: (gst_caps_append):
8040         * gst/gstcpu.c: (gst_cpuid_i386):
8041         * gst/gstelement.c:
8042         * gst/gsterror.c:
8043         * gst/gstfilter.c:
8044         * gst/gstinfo.h:
8045         * gst/gstprobe.c:
8046         * gst/gstquery.c:
8047         * gst/gstregistry.c:
8048         * gst/gststructure.c:
8049         * gst/gsttaginterface.c:
8050         * gst/gsttrace.c: (gst_trace_new):
8051         * gst/gsttrashstack.c:
8052         * gst/gsturi.c:
8053         * gst/gstvalue.c:
8054         * gst/parse/grammar.y:
8055         * gst/parse/parse.l:
8056         * tools/gst-inspect.c: (main):
8057         * tools/gst-launch.c: (main):
8058         * tools/gst-xmlinspect.c: (PUT_STRING):
8059
8060 2004-05-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8061
8062         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
8063         (gst_filesrc_change_state), (gst_filesrc_srcpad_event):
8064         * gst/elements/gstfilesrc.h:
8065           send NEW_MEDIA events correctly
8066         * gst/elements/gsttypefindelement.c: (start_typefinding),
8067         (gst_type_find_element_handle_event):
8068           restart typefinding when we get a NEW_MEDIA event
8069         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_change_state),
8070         (gst_bin_dispose):
8071           don't die when someone removes elements in callbacks
8072         * gst/gstelement.c: (gst_element_change_state):
8073           improve debugging
8074         * gst/gstpad.c: (gst_pad_pull), (gst_pad_call_chain_function):
8075           we need a NEW_MEDIA event to engage a link
8076         * gst/gsttrace.c: (gst_trace_new), (gst_alloc_trace_set_flags_all):
8077           don't g_print debugging stuff
8078         * testsuite/caps/simplify.c: (check_caps):
8079
8080 2004-05-04  Benjamin Otte  <otte@gnome.org>
8081
8082         * gst/parse/grammar.y:
8083           use GST_ERROR instead of g_warning, and always throw a GST_ERROR 
8084
8085 2004-05-04  Benjamin Otte  <otte@gnome.org>
8086
8087         * testsuite/caps/renegotiate.c: (main):
8088           improve output in error case
8089
8090 2004-05-04  Benjamin Otte  <otte@gnome.org>
8091
8092         * gst/parse/grammar.y:
8093           fix assert to not trigger when there's no error argument
8094         * gst/parse/parse.l:
8095           fix definition of caps to allow more than two structures
8096         * testsuite/caps/Makefile.am:
8097         * testsuite/caps/renegotiate.c: (main):
8098           it's sinesrc and works in that case
8099
8100 2004-05-04  Wim Taymans  <wim@fluendo.com>
8101
8102         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
8103         (group_dec_link), (gst_opt_scheduler_pad_unlink):
8104         when removing an element from a group, we always need to
8105         decrement the link count that this group had with other 
8106         groups through the element.
8107         added an extra assert to catch inconsistencies when decrementing
8108         the link count.
8109
8110 2004-05-04  Thomas Vander Stichele  <thomas at apestaart dot org>
8111
8112         * configure.ac:
8113         * docs/gst/Makefile.am:
8114         * docs/gst/gstreamer-sections.txt:
8115         * docs/gst/tmpl/gstcompat.sgml:
8116         * examples/appreader/Makefile.am:
8117         * examples/cutter/Makefile.am:
8118         * examples/events/Makefile.am:
8119         * examples/helloworld/Makefile.am:
8120         * examples/helloworld2/Makefile.am:
8121         * examples/launch/Makefile.am:
8122         * examples/manual/Makefile.am:
8123         * examples/mixer/Makefile.am:
8124         * examples/pingpong/Makefile.am:
8125         * examples/plugins/Makefile.am:
8126         * examples/queue/Makefile.am:
8127         * examples/queue2/Makefile.am:
8128         * examples/queue3/Makefile.am:
8129         * examples/queue4/Makefile.am:
8130         * examples/retag/Makefile.am:
8131         * examples/thread/Makefile.am:
8132         * examples/typefind/Makefile.am:
8133         * examples/xml/Makefile.am:
8134         * gst/Makefile.am:
8135         * gst/autoplug/Makefile.am:
8136         * gst/elements/Makefile.am:
8137         * gst/gstcompat.h:
8138         * gst/indexers/Makefile.am:
8139         * gst/parse/Makefile.am:
8140         * gst/registries/Makefile.am:
8141         * gst/schedulers/Makefile.am:
8142         * libs/gst/bytestream/Makefile.am:
8143         * libs/gst/control/Makefile.am:
8144         * libs/gst/getbits/Makefile.am:
8145         * po/af.po:
8146         * po/az.po:
8147         * po/en_GB.po:
8148         * po/fr.po:
8149         * po/nl.po:
8150         * po/sr.po:
8151         * po/sv.po:
8152         * po/tr.po:
8153         * po/uk.po:
8154         * tests/Makefile.am:
8155         * tests/bufspeed/Makefile.am:
8156         * tests/instantiate/Makefile.am:
8157         * tests/memchunk/Makefile.am:
8158         * tests/muxing/Makefile.am:
8159         * tests/negotiation/Makefile.am:
8160         * tests/probes/Makefile.am:
8161         * tests/sched/Makefile.am:
8162         * tests/seeking/Makefile.am:
8163         * tests/threadstate/Makefile.am:
8164         * testsuite/caps/Makefile.am:
8165         * testsuite/cleanup/Makefile.am:
8166         * testsuite/dlopen/Makefile.am:
8167         * testsuite/dynparams/Makefile.am:
8168         * testsuite/plugin/Makefile.am:
8169         * testsuite/states/Makefile.am:
8170         * tools/Makefile.am:
8171           reorganize compile/link flags to be consistent
8172           put gst_info in gstcompat.h and actually use GST_DISABLE_DEPRECATED
8173
8174 2004-05-04  David Schleef  <ds@schleef.org>
8175
8176         The "once more, with feeling" check-in.
8177         * testsuite/caps/Makefile.am: dist caps_strings
8178         * testsuite/caps/renegotiate.c: (main): This test triggers a
8179           segfault in the core.  Marking as failing.
8180
8181 2004-05-03  David Schleef  <ds@schleef.org>
8182
8183         * testsuite/caps/deserialize.c: (main): Fix problems noticed
8184           by the build bots.
8185         * testsuite/caps/renegotiate.c: (main): Same.
8186
8187 2004-05-03  David Schleef  <ds@schleef.org>
8188
8189         * testsuite/caps/renegotiate.c: (my_fixate), (main): Another test.
8190
8191 2004-05-03  David Schleef  <ds@schleef.org>
8192
8193         * testsuite/caps/deserialize.c: (main): Use the srcdir environment
8194           variable to find our source file.
8195
8196 2004-05-03  David Schleef  <ds@schleef.org>
8197
8198         * configure.ac:  Link plugins with libgstreamer and dependent
8199           libraries
8200         * testsuite/caps/Makefile.am:
8201         * testsuite/caps/caps_strings:
8202         * testsuite/caps/deserialize.c: (main): Add a little test to slog
8203           through a file of caps strings and test each one
8204
8205 2004-05-04  Benjamin Otte  <otte@gnome.org>
8206
8207         * libs/gst/bytestream/Makefile.am:
8208         * libs/gst/bytestream/adapter.c: 
8209         * libs/gst/bytestream/adapter.h:
8210           add GstAdapter, similar to bytestream, but doesn't require ugly event
8211           handling or uglier loopbased elements
8212
8213 2004-05-03  David Schleef  <ds@schleef.org>
8214
8215         * testsuite/caps/Makefile.am: Fix spelling of Ηρατοσθενες
8216         * testsuite/caps/erathostenes.c:
8217         * testsuite/caps/eratosthenes.c: (eratosthenes), (main):
8218
8219 2004-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
8220
8221         * docs/pwg/pwg.xml:
8222           remove hardcoded stylesheet path (duh)
8223         * docs/random/release:
8224         * docs/gst/gstreamer-sections.txt:
8225         * gst/Makefile.am:
8226         * gst/gst.h:
8227         * gst/gst_private.h:
8228         * gst/gstcaps.c:
8229         * gst/gstevent.c:
8230         * gst/gstformat.c:
8231         * gst/gstinfo.c:
8232         * gst/gstinfo.h:
8233         * gst/gstinterface.c:
8234         * gst/gstmemchunk.c:
8235         * gst/gstprobe.c:
8236         * gst/gstquery.c:
8237         * gst/gstregistry.c:
8238         * gst/gstregistrypool.c:
8239         * gst/gststructure.c:
8240         * gst/gsttaginterface.c:
8241         * gst/gstthread.c:
8242         * gst/gsttrace.c:
8243         * gst/gsttypefind.c: (gst_type_find_factory_get_type):
8244         * gst/gsturi.c:
8245         * gst/gstvalue.c:
8246           deprecate gst_info; remove gstlog.h
8247    
8248
8249 2004-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
8250
8251         * Makefile.am:
8252         * po/en_GB.po:
8253         * po/sv.po:
8254         * po/uk.po:
8255           updated translations
8256
8257 2004-05-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8258
8259         * gst/gstbin.c: (gst_bin_dispose):
8260           better debugging
8261
8262 2004-05-03  Johan Dahlin  <johan@gnome.org>
8263
8264         * gst/schedulers/gstoptimalscheduler.c
8265         (gst_opt_scheduler_pad_unlink): Check if element is non-NULL and
8266         really is a GstElement. Avoids critical when running gst-launch -v
8267         and a oggdemux/decoding pipeline.
8268
8269 2004-05-02  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8270
8271         * docs/gst/tmpl/gstpipeline.sgml :
8272         * docs/manual/elements-api.xml :
8273                 doc fix by Patrick Guimond (Protector) from devel ML
8274                 reviewed by ronald
8275
8276 2004-05-02  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8277
8278         * docs/gst/Makefile.am :
8279         * docs/libs/Makefile.am :
8280                 apply a patch from Arwed v. Merkatz so that gtk-doc
8281                 generated docs install (same for .devhelp file)
8282                 (fixes part 1 of #138836)
8283
8284 2004-04-30  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8285
8286         * docs/faq/dependencies.xml: typo
8287         * docs/faq/getting.xml :
8288             - fix download URL for new gstreamer site
8289             - hide sf.net download page as latest version aren't there
8290             - fix apt URLs
8291             - fill "get via CVS" paragraph (link to dev page on the site)
8292         * docs/faq/general.xml:
8293             hide status tables as they no more exists
8294             change case on plugins license file to reflect reality
8295         * docs/faq/troubleshooting.xml:
8296             remove the wiki question/answer as there is no more wiki
8297
8298 2004-04-30  Thomas Vander Stichele  <thomas at apestaart dot org>
8299
8300         * gst/gsterror.h:
8301           include the headers needed for declarations used in this header
8302
8303 2004-04-30  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8304
8305         * docs/random/uraeus/gstreamer_and_midi.txt :
8306           add .kar (midi + karaoke/lyrics 'track') doc to midi doc.
8307           (fixes #132288)
8308
8309 2004-04-30  Sebastien Cote  <sc5@hermes.usherb.ca>
8310
8311         reviewed by Benjamin Otte  <otte@gnome.org>
8312
8313         * gst/schedulers/gthread-cothreads.h:
8314           free allocated data for main cothread, too when destroying context
8315           (fixes #141417)
8316
8317 2004-04-29  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8318
8319         * docs/manual/goals.xml : remove duplicated paragraph at end 
8320         of doc page (fixes #141448)
8321
8322 2004-04-29  David Schleef  <ds@schleef.org>
8323
8324         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
8325         Patch from Sebastien Cote to fix leakage of events. (bug #141414)
8326
8327 2004-04-29  Thomas Vander Stichele  <thomas at apestaart dot org>
8328
8329         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
8330           fix property
8331         * gst/gstcaps.c:
8332           fix doc string
8333         * po/POTFILES.in:
8334           rename typefind source file
8335
8336 2004-04-28  David Schleef  <ds@schleef.org>
8337
8338         Several new files from Steve Lhomme's MSVC patch (bug #141317):
8339         * win32/GStreamer.vcproj:
8340         * win32/Makefile:
8341         * win32/config.h:
8342         * win32/dirent.c: (_topendir), (_treaddir), (_tclosedir),
8343         (_trewinddir), (_ttelldir), (_tseekdir):
8344         * win32/dirent.h:
8345         * win32/gst-inspect.vcproj:
8346         * win32/gst-launch.vcproj:
8347         * win32/gst-register.vcproj:
8348         * win32/gstbytestream.vcproj:
8349         * win32/gstelements.vcproj:
8350         * win32/gstoptimalscheduler.vcproj:
8351         * win32/gstspider.vcproj:
8352         * win32/gtchar.h:
8353         * win32/mman.c: (mmap), (mprotect), (msync), (munmap):
8354         * win32/mman.h:
8355         * win32/mman.inl:
8356         * win32/msvc71.sln:
8357
8358 2004-04-29  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8359
8360         * gst/gst.c: (init_post):
8361         * gst/gstinfo.c:
8362           remove useless _gst_progname stuff
8363         * tools/gst-inspect.c: (print_field), (print_caps):
8364           improve caps output
8365
8366 2004-04-28  David Schleef  <ds@schleef.org>
8367
8368         Disable parsing of a lot of files that aren't part of the
8369         exported API.  Move corresponding template files to old/,
8370         waiting for removal when they don't contain anything
8371         interesting.
8372         * docs/gst/Makefile.am:
8373         * docs/gst/gstreamer-sections.txt:
8374         * docs/gst/tmpl/cothreads.sgml:
8375         * docs/gst/tmpl/cothreads_compat.sgml:
8376         * docs/gst/tmpl/gettext.sgml:
8377         * docs/gst/tmpl/gobject2gtk.sgml:
8378         * docs/gst/tmpl/grammar.tab.sgml:
8379         * docs/gst/tmpl/gst-i18n-app.sgml:
8380         * docs/gst/tmpl/gst-i18n-lib.sgml:
8381         * docs/gst/tmpl/gst_private.sgml:
8382         * docs/gst/tmpl/gstaggregator.sgml:
8383         * docs/gst/tmpl/gstarch.sgml:
8384         * docs/gst/tmpl/gstatomic_impl.sgml:
8385         * docs/gst/tmpl/gstbufferstore.sgml:
8386         * docs/gst/tmpl/gstdata_private.sgml:
8387         * docs/gst/tmpl/gstdisksink.sgml:
8388         * docs/gst/tmpl/gstdisksrc.sgml:
8389         * docs/gst/tmpl/gstelementfactory.sgml:
8390         * docs/gst/tmpl/gstextratypes.sgml:
8391         * docs/gst/tmpl/gstfakesink.sgml:
8392         * docs/gst/tmpl/gstfakesrc.sgml:
8393         * docs/gst/tmpl/gstfdsink.sgml:
8394         * docs/gst/tmpl/gstfdsrc.sgml:
8395         * docs/gst/tmpl/gstfilesink.sgml:
8396         * docs/gst/tmpl/gstfilesrc.sgml:
8397         * docs/gst/tmpl/gsthttpsrc.sgml:
8398         * docs/gst/tmpl/gstidentity.sgml:
8399         * docs/gst/tmpl/gstindexfactory.sgml:
8400         * docs/gst/tmpl/gstmarshal.sgml:
8401         * docs/gst/tmpl/gstmd5sink.sgml:
8402         * docs/gst/tmpl/gstmultidisksrc.sgml:
8403         * docs/gst/tmpl/gstmultifilesrc.sgml:
8404         * docs/gst/tmpl/gstpadtemplate.sgml:
8405         * docs/gst/tmpl/gstpipefilter.sgml:
8406         * docs/gst/tmpl/gstschedulerfactory.sgml:
8407         * docs/gst/tmpl/gstsearchfuncs.sgml:
8408         * docs/gst/tmpl/gstshaper.sgml:
8409         * docs/gst/tmpl/gstspider.sgml:
8410         * docs/gst/tmpl/gstspideridentity.sgml:
8411         * docs/gst/tmpl/gststatistics.sgml:
8412         * docs/gst/tmpl/gsttee.sgml:
8413         * docs/gst/tmpl/gsttimecache.sgml:
8414         * docs/gst/tmpl/gsttypefind.sgml:
8415         * docs/gst/tmpl/gsttypefindfactory.sgml:
8416         * docs/gst/tmpl/gstxmlregistry.sgml:
8417         * docs/gst/tmpl/gthread-cothreads.sgml:
8418         * docs/gst/tmpl/old/cothreads.sgml:
8419         * docs/gst/tmpl/old/cothreads_compat.sgml:
8420         * docs/gst/tmpl/old/gettext.sgml:
8421         * docs/gst/tmpl/old/gobject2gtk.sgml:
8422         * docs/gst/tmpl/old/grammar.tab.sgml:
8423         * docs/gst/tmpl/old/gst-i18n-app.sgml:
8424         * docs/gst/tmpl/old/gst-i18n-lib.sgml:
8425         * docs/gst/tmpl/old/gst_private.sgml:
8426         * docs/gst/tmpl/old/gstaggregator.sgml:
8427         * docs/gst/tmpl/old/gstarch.sgml:
8428         * docs/gst/tmpl/old/gstatomic_impl.sgml:
8429         * docs/gst/tmpl/old/gstbufferstore.sgml:
8430         * docs/gst/tmpl/old/gstdata_private.sgml:
8431         * docs/gst/tmpl/old/gstdisksink.sgml:
8432         * docs/gst/tmpl/old/gstdisksrc.sgml:
8433         * docs/gst/tmpl/old/gstelementfactory.sgml:
8434         * docs/gst/tmpl/old/gstextratypes.sgml:
8435         * docs/gst/tmpl/old/gstfakesink.sgml:
8436         * docs/gst/tmpl/old/gstfakesrc.sgml:
8437         * docs/gst/tmpl/old/gstfdsink.sgml:
8438         * docs/gst/tmpl/old/gstfdsrc.sgml:
8439         * docs/gst/tmpl/old/gstfilesink.sgml:
8440         * docs/gst/tmpl/old/gstfilesrc.sgml:
8441         * docs/gst/tmpl/old/gsthttpsrc.sgml:
8442         * docs/gst/tmpl/old/gstidentity.sgml:
8443         * docs/gst/tmpl/old/gstindexfactory.sgml:
8444         * docs/gst/tmpl/old/gstmarshal.sgml:
8445         * docs/gst/tmpl/old/gstmd5sink.sgml:
8446         * docs/gst/tmpl/old/gstmultidisksrc.sgml:
8447         * docs/gst/tmpl/old/gstmultifilesrc.sgml:
8448         * docs/gst/tmpl/old/gstpadtemplate.sgml:
8449         * docs/gst/tmpl/old/gstpipefilter.sgml:
8450         * docs/gst/tmpl/old/gstschedulerfactory.sgml:
8451         * docs/gst/tmpl/old/gstsearchfuncs.sgml:
8452         * docs/gst/tmpl/old/gstshaper.sgml:
8453         * docs/gst/tmpl/old/gstspider.sgml:
8454         * docs/gst/tmpl/old/gstspideridentity.sgml:
8455         * docs/gst/tmpl/old/gststatistics.sgml:
8456         * docs/gst/tmpl/old/gsttee.sgml:
8457         * docs/gst/tmpl/old/gsttimecache.sgml:
8458         * docs/gst/tmpl/old/gsttypefindfactory.sgml:
8459         * docs/gst/tmpl/old/gstxmlregistry.sgml:
8460         * docs/gst/tmpl/old/gthread-cothreads.sgml:
8461         * docs/gst/tmpl/old/types.sgml:
8462         * docs/gst/tmpl/types.sgml:
8463
8464         Rename gsttypefind.[ch] back to gsttypefindelement.[ch], since
8465         gtkdoc-scan doesn't like files with the same name in different
8466         directories.
8467         * gst/elements/Makefile.am:
8468         * gst/elements/gstelements.c:
8469         * gst/elements/gsttypefind.c: 
8470         * gst/elements/gsttypefind.h:
8471         * gst/elements/gsttypefindelement.c:
8472         * gst/elements/gsttypefindelement.h:
8473
8474 2004-04-28  David Schleef  <ds@schleef.org>
8475
8476         A bunch of portability fixes, derived from Steve Lhomme's MSVC
8477         patch (bug #141317):
8478         * gst/gst-i18n-lib.h: Allow disabling gettext.
8479         * gst/gstatomic_impl.h: disable warning when it's dumb.
8480         * gst/gstclock.c: fix include
8481         * gst/gstcompat.h: fix variadic macro
8482         * gst/gstinfo.c: fix include
8483         * gst/gstmacros.h: add defines for inlines on MSVC
8484         * gst/gstplugin.c: fix includes
8485         * gst/gstregistry.c: fix includes
8486         * gst/gstregistry.h: use S_IREAD, etc., if S_IRUSR isn't defined
8487         * gst/gstsystemclock.c: fix include
8488         * gst/gsttrace.c: (gst_trace_new), (gst_trace_text_flush): use
8489         S_IREAD if S_IRUSR isn't defined.  fix use of non-portable functions
8490         * gst/registries/gstxmlregistry.c:
8491         (gst_xml_registry_parse_element_factory): fix use of non-portable
8492         functions
8493         * libs/gst/control/dparam.h: Remove trailing comma in enum definition
8494         * libs/gst/control/dparammanager.h: same
8495
8496 2004-04-28  David Schleef  <ds@schleef.org>
8497
8498         Move a bunch of unused files to old/ with names that are
8499         not case-insensitive-unique.  These files still contain some
8500         useful information that needs to be merged into gstbin.sgml,
8501         etc., so they shouldn't be deleted yet.
8502         * docs/gst/tmpl/GstBin.sgml:
8503         * docs/gst/tmpl/GstBuffer.sgml:
8504         * docs/gst/tmpl/GstCaps.sgml:
8505         * docs/gst/tmpl/GstClock.sgml:
8506         * docs/gst/tmpl/GstCompat.sgml:
8507         * docs/gst/tmpl/GstData.sgml:
8508         * docs/gst/tmpl/GstElement.sgml:
8509         * docs/gst/tmpl/GstEvent.sgml:
8510         * docs/gst/tmpl/GstIndex.sgml:
8511         * docs/gst/tmpl/GstStructure.sgml:
8512         * docs/gst/tmpl/GstTag.sgml:
8513         * docs/gst/tmpl/old/GstBin.sgml:
8514         * docs/gst/tmpl/old/GstBuffer.sgml:
8515         * docs/gst/tmpl/old/GstCaps.sgml:
8516         * docs/gst/tmpl/old/GstClock.sgml:
8517         * docs/gst/tmpl/old/GstCompat.sgml:
8518         * docs/gst/tmpl/old/GstData.sgml:
8519         * docs/gst/tmpl/old/GstElement.sgml:
8520         * docs/gst/tmpl/old/GstEvent.sgml:
8521         * docs/gst/tmpl/old/GstIndex.sgml:
8522         * docs/gst/tmpl/old/GstStructure.sgml:
8523         * docs/gst/tmpl/old/GstTag.sgml:
8524
8525 2004-04-28  David Schleef  <ds@schleef.org>
8526
8527         * gst/gstcaps.c: (gst_caps_copy), (gst_caps_free),
8528         (gst_caps_append), (gst_caps_append_structure),
8529         (gst_caps_get_size), (gst_caps_get_structure), (gst_caps_copy_1),
8530         (gst_caps_set_simple), (gst_caps_set_simple_valist),
8531         (gst_caps_is_any), (gst_caps_is_empty), (gst_caps_is_chained),
8532         (gst_caps_is_fixed), (gst_caps_is_always_compatible),
8533         (gst_caps_intersect), (gst_caps_normalize),
8534         (gst_caps_transform_to_string):  Patch from Tim-Philipp Müller
8535         to fix GST_CAPS() and GST_IS_CAPS(). (bug #141304)
8536         * gst/gstcaps.h: use GST_IS_CAPS().
8537
8538 2004-04-26  David Schleef  <ds@schleef.org>
8539
8540         * gst/gstcpu.c: (gst_cpuid_i386): Don't clobber ebx in inline
8541         assembly.  gcc doesn't handle it correctly. (bug #141083)
8542         * gst/gsttrashstack.h: same
8543
8544 2004-04-25  Benjamin Otte  <otte@gnome.org>
8545
8546         * gst/gstelement.c: (gst_element_change_state):
8547           fix assertion to do an int comparison
8548
8549 2004-04-25  Benjamin Otte  <otte@gnome.org>
8550
8551         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
8552           better debugging output on error
8553
8554 2004-04-25  Benjamin Otte  <otte@gnome.org>
8555
8556         * gst/gstcaps.c: (gst_caps_subtract):
8557           fix memleak
8558
8559 2004-04-23  Benjamin Otte  <otte@gnome.org>
8560
8561         * gst/gstvalue.c: (gst_value_compare_buffer),
8562         (_gst_value_initialize):
8563           add comparison function for buffers
8564
8565 2004-04-22  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8566
8567         * docs/pwg/pwg.xml:
8568           Just found out that this so-called "ima-wav" format is really
8569           just "dvi adpcm" (according to the MS WAV documentation). So
8570           renaming it. We didn't use it yet anyway.
8571
8572 2004-04-23  Benjamin Otte  <otte@gnome.org>
8573
8574         * gst/gstcaps.c: (gst_caps_is_always_compatible):
8575           call gst_caps_is_subset
8576
8577 2004-04-23  Benjamin Otte  <otte@gnome.org>
8578
8579         * gst/gstcaps.c: (gst_caps_subtract), (gst_caps_is_equal), 
8580         (gst_caps_is_subset):
8581           add documentation
8582
8583 2004-04-23  Benjamin Otte  <otte@gnome.org>
8584           
8585         * gst/gstcaps.c: (gst_caps_structure_subtract_field),
8586         (gst_caps_structure_subtract), (gst_caps_subtract),
8587         (gst_caps_structure_figure_out_union),
8588         (gst_caps_structure_simplify), (gst_caps_do_simplify):
8589           fix simplifying and subtracting not working correctly with optional
8590           properties
8591           solve assorted problems that make it now simplify ebven more
8592         * docs/gst/tmpl/gstcaps.sgml:
8593         * gst/gstcaps.h:
8594           make gst_caps_do_simplify return a bool to indicate if it simplified
8595         * testsuite/caps/simplify.c: (main):
8596           add more checks. The tests is quite a bit useless right now because
8597           the core is heavily simplifying itself.
8598         * testsuite/caps/caps.h:
8599           fix caps to contain all optional properties
8600
8601 2004-04-22  Benjamin Otte  <otte@gnome.org>
8602
8603         * docs/gst/tmpl/gstcaps.sgml:
8604         * docs/gst/tmpl/gstfilesrc.sgml:
8605         * docs/gst/tmpl/gststructure.sgml:
8606         * docs/gst/tmpl/gstvalue.sgml:
8607           update for recent API changes
8608         * gst/gstcaps.c: (gst_caps_do_simplify):
8609           fix to stop trying with a freed structure
8610         * gst/gstpad.c: (gst_pad_link_fixate):
8611           simplify caps
8612         * gst/gstpad.c: (gst_pad_template_get_caps_by_name):
8613           remove C++ comment
8614         * gst/gstpad.h:
8615           deprecate gst_pad_template_get_caps_by_name, it doesn't work anyway
8616         * gst/gststructure.c: (gst_structure_value_get_generic_type),
8617         (gst_structure_to_string):
8618           keep the correct type when using lists of ranges
8619         * gst/gstvalue.c: (gst_value_list_prepend_value),
8620         (gst_value_list_append_value):
8621           copy the value before adding to the list (d'oh)
8622         * gst/gstvalue.c: (gst_value_subtract_int_range_int),
8623         (gst_value_subtract_int_range_int_range):
8624           handle overflows correctly
8625         * gst/gstvalue.c: (gst_value_subtract_from_list):
8626           fix memleak
8627         * testsuite/caps/caps.h:
8628           add a caps that caused segfaults
8629
8630 2004-04-22  Benjamin Otte  <otte@gnome.org>
8631
8632         * testsuite/refcounting/pad.c: (main):
8633           fix test
8634
8635 2004-04-22  Benjamin Otte  <otte@gnome.org>
8636
8637         * gst/gstcaps.c: (gst_caps_subtract):
8638           allow subtracting ANY and EMPTY from ANY caps
8639
8640 2004-04-22  Benjamin Otte  <otte@gnome.org>
8641
8642         * gst/gstcaps.c: (gst_caps_append), (gst_caps_intersect),
8643         (gst_caps_union):
8644           only simplify in functions that create new caps. Simplifying in
8645           gst_caps_append breaks tests.
8646
8647 2004-04-22  Benjamin Otte  <otte@gnome.org>
8648
8649         * gst/gstcaps.c: (gst_caps_structure_simplify):
8650           unset GValue after use
8651         * gst/gstcaps.c: (gst_caps_append), 
8652         * gst/gstpad.c: (gst_pad_link_fixate), (gst_pad_template_new):
8653           use gst_caps_simplify (reduces registry size by 30%)
8654         * gst/gstpad.c: (gst_pad_template_new):
8655           don't allow NULL caps
8656
8657 2004-04-22  Benjamin Otte  <otte@gnome.org>
8658
8659         * docs/gst/gstreamer-sections.txt:
8660           add gst_caps_do_simplify
8661         * gst/gstcaps.c:
8662           add documentation for gst_caps_do_simplify
8663         * gst/gstvalue.h:
8664           fix typo in gst_value_register_subtract_func declaration for gst-doc
8665
8666 2004-04-22  Benjamin Otte  <otte@gnome.org>
8667
8668         * gst/gstcaps.c: (gst_caps_from_string_inplace):
8669           fix bug when converting from empty string.
8670         * gst/gstcaps.c: (gst_caps_new_any), (gst_caps_new_simple),
8671         (gst_caps_new_full_valist), (gst_caps_copy), (gst_caps_copy_1):
8672           use gst_caps_new_empty to allocate a new caps. Only that function
8673           allocates memory for caps now.
8674         * gst/gstcaps.c: (gst_caps_remove_and_get_structure),
8675         (gst_caps_remove_structure):
8676           add ability to remove one structure (but not to header yet)
8677         * gst/gstcaps.c: (gst_caps_compare_structures),
8678         (gst_caps_simplify), (gst_caps_structure_figure_out_union),
8679         (gst_caps_structure_simplify), (gst_caps_do_simplify),
8680         * gst/gstcaps.h:
8681           add gst_caps_do_simplify that tries to simplify a caps in place.
8682           Deprecate old gst_caps_simplify function.
8683         * testsuite/caps/caps.h:
8684           add caps.h containing a common set of caps to test against.
8685         * testsuite/caps/sets.c: (check_caps), (main):
8686           use it.
8687         * testsuite/caps/.cvsignore:
8688         * testsuite/caps/Makefile.am:
8689         * testsuite/caps/simplify.c: (check_caps), (main):
8690           add test to check correctness and efficency of caps simplification.
8691
8692 2004-04-22  Sebastien Cote <sc5@hermes.usherb.ca>
8693
8694         reviewed by Benjamin Otte  <otte@gnome.org>
8695
8696         * gst/gstparse.c: (_gst_parse_escape):
8697           Free the GString used in _gst_parse_escape()
8698
8699 2004-04-21  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8700
8701         * gst/gstpad.c: (gst_pad_link_negotiate):
8702           refuse to link if the link is not possible
8703         * configure.ac:
8704         * testsuite/Makefile.am:
8705         * testsuite/negotiation/.cvsignore:
8706         * testsuite/negotiation/Makefile.am:
8707         * testsuite/negotiation/pad_link.c: (main):
8708           add test that checks the above behaviour
8709
8710 2004-04-21  Thomas Vander Stichele  <thomas at apestaart dot org>
8711
8712         * docs/gst/gstreamer-sections.txt:
8713           add newly added API
8714
8715 2004-04-21  Thomas Vander Stichele  <thomas at apestaart dot org>
8716
8717         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
8718         (gst_filesrc_get_mmap), (gst_filesrc_get_read), (gst_filesrc_get),
8719         (gst_filesrc_open_file), (gst_filesrc_close_file),
8720         (gst_filesrc_srcpad_query), (gst_filesrc_srcpad_event):
8721         * gst/elements/gstfilesrc.h:
8722           add support for non-regular files (#140734)
8723
8724 2004-04-21  Benjamin Otte  <otte@gnome.org>
8725
8726         * gst/gstpad.c: (gst_pad_link_fixate):
8727           add sophisticated error checking code to see if fixation functions
8728           did their fixation right
8729
8730 2004-04-21  Benjamin Otte  <otte@gnome.org>
8731
8732         * gst/gstcaps.c: (gst_caps_append), (gst_caps_union):
8733           check for ANY caps before appending/unioning
8734         * gst/gstcaps.c: (gst_caps_is_subset),
8735         (gst_caps_is_equal), (gst_caps_structure_subtract_field),
8736         (gst_caps_structure_subtract), (gst_caps_subtract):
8737         * gst/gstcaps.h:
8738           add gst_caps_is_equal, gst_caps_is_subset and gst_caps_subtract to
8739           the API. deprecate gst_caps_is_equal_fixed
8740         * gst/gstpad.c: (gst_pad_try_set_caps):
8741         * gst/gstqueue.c: (gst_queue_link):
8742           s/gst_caps_is_equal_fixed/gst_caps_is_equal/
8743         * gst/gststructure.c: (gst_structure_get_name_id):
8744         * gst/gststructure.h:
8745           add function gst_structure_get_name_id
8746         * gst/gstvalue.c: (gst_value_subtract_int_int_range),
8747         (gst_value_create_new_range), (gst_value_subtract_int_range_int),
8748         (gst_value_subtract_int_range_int_range),
8749         (gst_value_subtract_double_double_range),
8750         (gst_value_subtract_double_range_double),
8751         (gst_value_subtract_double_range_double_range),
8752         (gst_value_subtract_from_list), (gst_value_subtract_list),
8753         (gst_value_can_intersect), (gst_value_subtract),
8754         (gst_value_can_subtract), (gst_value_register_subtract_func),
8755         (_gst_value_initialize):
8756         * gst/gstvalue.h:
8757           add support for subtracting values from each other. Note that
8758           subtracting means subtracting as in set theory. Required for caps
8759           stuff above.
8760         * testsuite/caps/.cvsignore:
8761         * testsuite/caps/Makefile.am:
8762         * testsuite/caps/erathostenes.c: (erathostenes), (main):
8763         * testsuite/caps/sets.c: (check_caps), (main):
8764         * testsuite/caps/subtract.c: (check_caps), (main):
8765           add tests for subtraction and equality code.
8766
8767 2004-04-20  David Schleef  <ds@schleef.org>
8768
8769         * gst/autoplug/Makefile.am:  Fix some little buglets in last checkin.
8770         * gst/indexers/Makefile.am:
8771         * gst/schedulers/Makefile.am:
8772         * libs/gst/bytestream/Makefile.am:
8773         * libs/gst/control/Makefile.am:
8774         * libs/gst/getbits/Makefile.am:
8775
8776 2004-04-20  David Schleef  <ds@schleef.org>
8777
8778         * common/as-libtool.mak: Fine-tune DLL building.
8779         * configure.ac: Link plugins against libgstreamer.  Define plugindir
8780         (like gst-plugins)
8781         * examples/plugins/Makefile.am: remove plugindir
8782         * gst/autoplug/Makefile.am: DLL building fixes
8783         * gst/elements/Makefile.am: DLL building fixes.  Disable pipefilter on
8784         Windows.
8785         * gst/elements/gstelements.c: Conditionally disable pipefilter.
8786         * gst/indexers/Makefile.am: DLL building fixes
8787         * gst/schedulers/Makefile.am: DLL building fixes.
8788         * libs/gst/bytestream/Makefile.am: DLL building fixes.
8789         * libs/gst/control/Makefile.am: same
8790         * libs/gst/getbits/Makefile.am: same
8791         * testsuite/Makefile.am: New dlopen directory
8792         * testsuite/dlopen/Makefile.am: Tests to check if libgstreamer works
8793         when dlopened.
8794         * testsuite/dlopen/dlopen_gst.c: (main): same
8795         * testsuite/dlopen/loadgst.c: (do_test): same
8796
8797 2004-04-20  David Schleef  <ds@schleef.org>
8798
8799         * gst/parse/grammar.y:  Apply patch from Sebastien Cote
8800         <sc5@hermes.usherb.ca> to fix a memleak. (bug #140594)
8801
8802 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
8803
8804         * gst/gstelement.c: (gst_element_wait),
8805         (gst_element_set_time_delay), (gst_element_change_state):
8806           Use GST_TIME_*
8807
8808 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8809
8810         * gst/autoplug/gstspider.c: (gst_spider_link_sometimes),
8811         (gst_spider_identity_plug):
8812           improve debugging messages
8813         * gst/gstbin.c: (gst_bin_remove_func):
8814           make sure the state_change function is only called with simple state
8815           transitions
8816
8817 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
8818
8819         * gst/elements/gstfakesink.c: (gst_fakesink_state_error_get_type),
8820         (gst_fakesink_set_property), (gst_fakesink_chain):
8821         * gst/elements/gstfakesrc.c: (gst_fakesrc_set_property):
8822         * gst/elements/gstfdsrc.c: (gst_fdsrc_set_property):
8823         * gst/elements/gstfilesrc.c: (gst_filesrc_set_property):
8824         * gst/elements/gstidentity.c: (gst_identity_chain),
8825         (gst_identity_set_property):
8826         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_set_property):
8827         * gst/elements/gstpipefilter.c: (gst_pipefilter_set_property):
8828           add warnings to _set_property for unknown arguments
8829           use GST_TIME_FORMAT/GST_TIME_ARGS for timestamp printing
8830
8831 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
8832
8833         * Makefile.am:
8834         * docs/manuals.mak:
8835           add .po file download snippet
8836           fix a bug in the doc makefile
8837
8838 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
8839
8840         * Makefile.am:
8841         * po/LINGUAS:
8842         * po/en_GB.po:
8843           Added en_GB translation (Gareth Owen)
8844
8845 2004-04-20  Johan Dahlin  <johan@gnome.org>
8846
8847         * gst/gstpad.c (_invent_event): Clean up
8848
8849 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8850
8851         * testsuite/caps/filtercaps.c: (main):
8852           fix test to test things correctly (caps are complicated)
8853
8854 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8855
8856         * testsuite/caps/Makefile.am:
8857         * testsuite/caps/filtercaps.c: (main):
8858           add test (that doesn't work right now, but should)
8859
8860 2004-04-19  David Schleef  <ds@schleef.org>
8861
8862         * configure.ac: Add test for allowing unaligned access.  Add define
8863         to put in gstconfig.h.
8864         * docs/gst/gstreamer-sections.txt: New symbols
8865         * docs/gst/tmpl/gstcompat.sgml: Check in changes made by gtkdoc
8866         * docs/gst/tmpl/gstfilesrc.sgml:
8867         * docs/gst/tmpl/gstparse.sgml:
8868         * docs/gst/tmpl/gsttypes.sgml:
8869         * docs/gst/tmpl/gstutils.sgml:
8870         * docs/gst/tmpl/gstvalue.sgml:
8871         * gst/gstconfig.h.in: Add GST_HAVE_UNALIGNED_ACCESS
8872         * gst/gstutils.h: Add macros for unaligned memory access.  Useful
8873         on most !i386/!powerpc architectures.  From Daniel Gazard
8874         <daniel.gazard@free.fr>.  (bug #140156)
8875         * po/af.po: Check in changes made by gettext.
8876         * po/az.po:
8877         * po/fr.po:
8878         * po/nl.po:
8879         * po/sr.po:
8880         * po/sv.po:
8881
8882 2004-04-20  Benjamin Otte  <otte@gnome.org>
8883
8884         * gst/schedulers/entryscheduler.c: 
8885         (gst_entry_scheduler_yield):
8886           refuse to yield when decoupled elements insist on doing that.
8887           At least it's better than crashing
8888
8889 2004-04-19  David Schleef  <ds@schleef.org>
8890
8891         * docs/libs/Makefile.am: Change sinclude to include
8892         * docs/gst/Makefile.am: same
8893         * pkgconfig/Makefile.am:  Remove GNU-ism from makefile target
8894
8895 2004-04-19  Thomas Vander Stichele  <thomas at apestaart dot org>
8896
8897         * po/LINGUAS:
8898         * po/uk.po:
8899           Added Ukrainian translation (Maxim V. Dziumanenko)
8900
8901 2004-04-19  Johan Dahlin  <johan@gnome.org>
8902
8903         * gst/parse/grammar.y (__gst_parse_chain_free): Don't do null
8904         checking here, do it before calling the function.
8905         Clean up, use for loops instead of while loops while iterating
8906         over lists.
8907
8908         * gst/autoplug/gstspider.c (gst_spider_request_new_pad): Fix typo
8909         in debug message.
8910         (gst_spider_create_and_plug): Improve debug message.
8911         General: Replace while loops which iterates over GLists with for
8912         loops. Which are much cleaner, improves readability, especially
8913         for gst_spider_identity_plug
8914
8915         * gst/gstpad.c (_invent_event): Fix parameters to warning macros,
8916         fixes bug 140477
8917
8918 2004-04-18  Thomas Vander Stichele  <thomas at apestaart dot org>
8919
8920         * po/LINGUAS:
8921         * po/tr.po:
8922           Added Turkish translation (Baris Cicek)
8923
8924 2004-04-18  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8925
8926         * docs/faq/troubleshooting.xml:
8927           Mention gst-register in the FAQ (fixes 139045).
8928
8929 2004-04-17  Thomas Vander Stichele  <thomas at apestaart dot org>
8930
8931         * docs/gst/gstreamer-sections.txt:
8932
8933 2004-04-17  Benjamin Otte  <otte@gnome.org>
8934
8935         * gst/gstelement.c: (gst_element_dispose):
8936           simplify
8937         * gst/gstpad.c: (gst_pad_call_chain_function):
8938           don't create loads of events due to bad macro usage
8939
8940 2004-04-16  David Schleef  <ds@schleef.org>
8941
8942         * gst/gstcaps.c: (gst_caps_is_fixed_foreach):
8943         * gst/gstpad.c: (_gst_pad_default_fixate_foreach):
8944         * gst/gstvalue.c: (gst_value_serialize_buffer),
8945         (gst_value_deserialize_buffer), (gst_type_is_fixed),
8946         (_gst_value_initialize): Create a new function gst_type_is_fixed()
8947         to indicate types that are fixed wrt caps or not.  Switching to
8948         this function fixes (bug #140298).
8949         * gst/gstvalue.h:
8950
8951 2004-04-16  David Schleef  <ds@schleef.org>
8952
8953         * common/m4/gst-arch.m4:  Implmenent a whitelist and blacklist
8954         for GST_UNALIGNED_ACESS, since we essentially know which archs
8955         are ok.
8956
8957 2004-04-17  Benjamin Otte  <otte@gnome.org>
8958
8959         * docs/gst/Makefile.am:
8960           ignore gst/parse directory when building docs (fixes #140205)
8961
8962 2004-04-16  Thomas Vander Stichele  <thomas at apestaart dot org>
8963
8964         * testsuite/refcounting/mem.c: (vmsize):
8965           do error checking
8966
8967 2004-04-16  Johan Dahlin  <johan@gnome.org>
8968
8969         * docs/gst/gstreamer-sections.txt: Add gst_pad_call_chain_function
8970         and gst_pad_call_get_function.
8971
8972 2004-04-15  David Schleef  <ds@schleef.org>
8973
8974         * common/m4/gst-arch.m4: Add GST_UNALIGNED_ACCESS() macro that
8975         checks if we can access unaligned memory.
8976         * configure.ac: Use it.
8977
8978 2004-04-16  Benjamin Otte  <otte@gnome.org>
8979
8980         * gst/elements/gstfilesrc.c: (gst_filesrc_init), (gst_filesrc_get),
8981         (gst_filesrc_change_state), (gst_filesrc_srcpad_event):
8982         * gst/elements/gstfilesrc.h:
8983           s/seek_happened/need_discont/ and require discont before sending any
8984           data
8985
8986 2004-04-15  David Schleef  <ds@schleef.org>
8987
8988         * gst/gstvalue.c: (gst_value_serialize_buffer),
8989         (gst_value_deserialize_buffer), (_gst_value_initialize):
8990         Register these types as fundamental types. (bug #140015)
8991
8992 2004-04-16  Benjamin Otte  <otte@gnome.org>
8993
8994         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_new),
8995         (gst_pad_link_free), (gst_pad_link_try), (_invent_event),
8996         (gst_pad_pull):
8997           implement enforcing discont events before buffers are passed. This
8998           allows state changes of only some elements and later correctly going
8999           on where they left off (or in short: you can now set audio sinks to
9000           NULL to release the device when the pipeline is paused)
9001         * gst/gstpad.c: (gst_pad_call_chain_function),
9002         (gst_pad_call_get_function):
9003         * gst/gstpad.h:
9004           add gst_pad_call_chain_function and gst_pad_call_get_function for
9005           scheduler interaction. They are required because of the changes
9006           above.
9007         * gst/schedulers/entryscheduler.c: (get_buffer),
9008         (gst_entry_scheduler_chain_wrapper),
9009         (gst_entry_scheduler_get_wrapper),
9010         (gst_entry_scheduler_state_transition),
9011         (gst_entry_scheduler_pad_link):
9012         * gst/schedulers/gstbasicscheduler.c:
9013         (gst_basic_scheduler_chain_wrapper),
9014         (gst_basic_scheduler_src_wrapper),
9015         (gst_basic_scheduler_chainhandler_proxy),
9016         (gst_basic_scheduler_gethandler_proxy),
9017         (gst_basic_scheduler_cothreaded_chain),
9018         (gst_basic_scheduler_chain_elements):
9019         * gst/schedulers/gstoptimalscheduler.c:
9020         (get_group_schedule_function), (pad_clear_queued),
9021         (gst_opt_scheduler_pad_link):
9022           use the new functions instead of calling get/chain-functions
9023           directly.
9024
9025 2004-04-15  David Schleef  <ds@schleef.org>
9026
9027         * docs/gst/gstreamer-sections.txt: Remove deprecated symbols.
9028         * docs/gst/tmpl/gstinfo.sgml: same
9029         * docs/gst/tmpl/gstutils.sgml: Remove a bunch of bogus crap that
9030         gtk-doc put here.
9031         * gst/gstutils.h: Remove the \ that was confusing gtk-doc.
9032         * examples/queue/queue.c: (main):  We iterate pipelines, not
9033         bins.  (bug #139996)
9034
9035 2004-04-15  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9036
9037         * docs/pwg/advanced-types.xml:
9038           Add MS RLE support. Also document Qt RLE although I have no sample
9039           files for that yet. And document an extra property for ADPCM.
9040
9041 2004-04-15  David Schleef  <ds@schleef.org>
9042
9043         * gst/gstplugin.c: (_gst_plugin_fault_handler_restore),
9044         (_gst_plugin_fault_handler_setup):  Disable more stuff on
9045         Windows.
9046
9047 2004-04-15  David Schleef  <ds@schleef.org>
9048
9049         * gst/gstinfo.c: (_gst_debug_init): Change some internal
9050         symbol names to not conflict with new gstinfo.h symbols.
9051         * gst/gstinfo.h: Add inline functions for all those crazy
9052         compilers that don't know how to handle variadic macros (MSVC).
9053
9054 2004-04-15  Thomas Vander Stichele  <thomas at apestaart dot org>
9055
9056         * configure.ac: bump nano to 1
9057
9058 === release 0.8.1 ===
9059
9060 2004-04-15  Thomas Vander Stichele  <thomas at apestaart dot org>
9061
9062         * NEWS:
9063         * RELEASE:
9064         * configure.ac:
9065           releasing 0.8.1, "Snow Brigade"
9066
9067 2004-04-14  David Schleef  <ds@schleef.org>
9068
9069         * testsuite/Makefile.am: define tests_ignore
9070         * testsuite/Rules: Added new tests_ignore, which get compiled,
9071         but not run (generally because they're inconsistent or have
9072         heisenbugs).  Now we can ensure all the .c files compile in
9073         testsuite/.
9074         * testsuite/bins/Makefile.am: define tests_ignore
9075         * testsuite/bytestream/Makefile.am:
9076         * testsuite/caps/Makefile.am:
9077         * testsuite/clock/Makefile.am:
9078         * testsuite/debug/Makefile.am:
9079         * testsuite/debug/global.c: (gst_debug_log_one),
9080         (gst_debug_log_two): Fix compilation problem.
9081         * testsuite/dynparams/Makefile.am:
9082         * testsuite/elements/Makefile.am:
9083         * testsuite/ghostpads/Makefile.am:
9084         * testsuite/indexers/Makefile.am:
9085         * testsuite/parse/Makefile.am:
9086         * testsuite/plugin/Makefile.am:
9087         * testsuite/refcounting/Makefile.am:
9088         * testsuite/refcounting/element_pad.c: (main): Don't return leak
9089         results, because it's not calculated correctly.
9090         * testsuite/refcounting/pad.c: (main): same
9091         * testsuite/states/Makefile.am:
9092         * testsuite/tags/Makefile.am:
9093         * testsuite/threads/Makefile.am:
9094
9095 2004-04-14  David Schleef  <ds@schleef.org>
9096
9097         * gst/gstcpu.c: (gst_cpuid_i386): Add workaround for gcc-3.2
9098         generating bad code around the cpu detection asm code.
9099
9100 2004-04-14  Thomas Vander Stichele  <thomas at apestaart dot org>
9101
9102         * tools/gst-inspect.c: (print_element_info):
9103           print numeric version of rank as well, since we added some - 1
9104           rank values to elements
9105
9106 2004-04-13  David Schleef  <ds@schleef.org>
9107
9108         * configure.ac:  Disable various code when compiling for MinGW.
9109         * gst/elements/Makefile.am:
9110         * gst/elements/gstelements.c:
9111         * gst/elements/gstfdsrc.c: (gst_fdsrc_get):
9112         * gst/elements/gstfilesrc.c: (gst_filesrc_init), (gst_filesrc_get):
9113         * gst/registries/gstxmlregistry.c: (make_dir):
9114
9115 2004-04-13  David Schleef  <ds@schleef.org>
9116
9117         * gst/Makefile.am:
9118         * gst/gstcpu.c: (gst_cpuid_i386): Convert asm source into inline
9119         assembly.
9120         * gst/gstcpuid_i386.s: remove
9121
9122 2004-04-13  David Schleef  <ds@schleef.org>
9123
9124         * docs/gst/tmpl/gstaggregator.sgml: Random checkin because gtk-doc
9125         seems to think it needs to be done.
9126         * docs/gst/tmpl/gstfakesink.sgml:
9127         * docs/gst/tmpl/gstfakesrc.sgml:
9128         * docs/gst/tmpl/gstfdsink.sgml:
9129         * docs/gst/tmpl/gstfdsrc.sgml:
9130         * docs/gst/tmpl/gstfilesink.sgml:
9131         * docs/gst/tmpl/gstfilesrc.sgml:
9132         * docs/gst/tmpl/gstidentity.sgml:
9133         * docs/gst/tmpl/gstmd5sink.sgml:
9134         * docs/gst/tmpl/gstmultifilesrc.sgml:
9135         * docs/gst/tmpl/gstpipefilter.sgml:
9136         * docs/gst/tmpl/gstshaper.sgml:
9137         * docs/gst/tmpl/gstspider.sgml:
9138         * docs/gst/tmpl/gstspideridentity.sgml:
9139         * docs/gst/tmpl/gststatistics.sgml:
9140         * docs/gst/tmpl/gsttee.sgml:
9141         * docs/gst/tmpl/gsttypefind.sgml:
9142         * docs/gst/tmpl/gstutils.sgml:
9143
9144 2004-04-13  David Schleef  <ds@schleef.org>
9145
9146         * configure.ac: Changes to remove POSIXisms (mmap in this case)
9147         and to build DLLs on Windows.
9148         * gst/Makefile.am:
9149         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
9150         (gst_filesrc_open_file):
9151         * gst/schedulers/Makefile.am:
9152
9153 2004-04-13  David Schleef  <ds@schleef.org>
9154
9155         * gst/gstcaps.c: (gst_caps_structure_fixate_field_nearest_int),
9156         (gst_caps_structure_fixate_field_nearest_double):  Fix bug in
9157         fixating lists.
9158
9159 2004-04-12  David Schleef  <ds@schleef.org>
9160
9161         * gst/gstbuffer.c: (_gst_buffer_initialize), (gst_buffer_get_type),
9162         (gst_buffer_free_chunk): Added gst_buffer_get_type() and changed
9163         to using it.
9164         * gst/gstbuffer.h: Changed GST_BUFFER_TYPE to gst_buffer_get_type()
9165         * gst/gstcaps.c: (gst_caps_is_fixed_foreach): Buffer is a fixed type
9166         * gst/gstpad.c: (_gst_pad_default_fixate_foreach): same
9167         * gst/gststructure.c: (gst_structure_set_valist),
9168         (gst_structure_from_abbr), (gst_structure_to_abbr): Add vararg
9169         support for buffers.
9170         * gst/gsttag.c: (gst_tag_register): Constify a prototype that was
9171         intended to be const.
9172         * gst/gsttag.h: same
9173         * gst/gstvalue.c: (gst_value_serialize_buffer),
9174         (gst_value_deserialize_buffer), (_gst_value_initialize):  Add code
9175         to (de)serialize buffers.
9176         * testsuite/caps/Makefile.am:  Add a bit of buffer testing
9177         * testsuite/caps/string-conversions.c: (main):
9178         * testsuite/caps/value_serialize.c: add new test
9179
9180 2004-04-11  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9181
9182         * docs/pwg/advanced-types.xml:
9183           Document MS video 1 (video/x-msvideocodec) mimetype/format.
9184
9185 2004-04-11  Benjamin Otte  <otte@gnome.org>
9186
9187         * gst/schedulers/gstbasicscheduler.c: (plugin_init):
9188           rename categories to basic_*
9189         * gst/schedulers/gstbasicscheduler.c: 
9190         (gst_basic_scheduler_chain_wrapper),
9191         (gst_basic_scheduler_chainhandler_proxy),
9192         (gst_basic_scheduler_gethandler_proxy),
9193         (gst_basic_scheduler_eventhandler_proxy):
9194           debugging category fixes - put common stuff in log category
9195         * gst/schedulers/gstbasicscheduler.c: 
9196         (gst_basic_scheduler_chain_elements):
9197           dirty fix: call gst_basic_scheduler_cothreaded_chain when already
9198           active and linking two active chains
9199
9200 2004-04-10  Benjamin Otte  <otte@gnome.org>
9201
9202         * docs/pwg/intro-preface.xml:
9203           fix dead links and remove reference to Wiki
9204
9205 2004-04-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9206
9207         * gst/schedulers/gstbasicscheduler.c:
9208           make sure we can switch back to the main function if we're still in
9209           the main function (supposed to fix #139617)
9210         * gst/schedulers/gthread-cothreads.h:
9211           don't throw an error when switching to the same cothread
9212
9213 2004-04-09  Benjamin Otte  <otte@gnome.org>
9214
9215         * gst/gstbin.c: (gst_bin_get_type):
9216         * gst/gstclock.c: (gst_clock_get_type):
9217         * gst/gstindex.c: (gst_index_get_type):
9218         * gst/gstobject.c: (gst_object_get_type),
9219         (gst_signal_object_get_type):
9220         * gst/gstpad.c: (gst_pad_get_type), (gst_real_pad_get_type),
9221         (gst_pad_template_get_type), (gst_ghost_pad_get_type):
9222         * gst/gstpluginfeature.c: (gst_plugin_feature_get_type):
9223         * gst/gstqueue.c: (gst_queue_get_type):
9224         * gst/gstregistry.c: (gst_registry_get_type):
9225         * gst/gstsystemclock.c: (gst_system_clock_get_type):
9226         * gst/gstthread.c: (gst_thread_get_type):
9227           don't use memchunks for these objects, use malloc instead
9228
9229 2004-04-08  Thomas Vander Stichele  <thomas at apestaart dot org>
9230
9231         * docs/gst/.cvsignore:
9232         * docs/gst/Makefile.am:
9233         * docs/gst/gstreamer-sections.txt:
9234         * docs/gst/tmpl/gstaggregator.sgml:
9235         * docs/gst/tmpl/gstbuffer.sgml:
9236         * docs/gst/tmpl/gstclock.sgml:
9237         * docs/gst/tmpl/gstelement.sgml:
9238         * docs/gst/tmpl/gstfakesink.sgml:
9239         * docs/gst/tmpl/gstfakesrc.sgml:
9240         * docs/gst/tmpl/gstfdsink.sgml:
9241         * docs/gst/tmpl/gstfdsrc.sgml:
9242         * docs/gst/tmpl/gstfilesink.sgml:
9243         * docs/gst/tmpl/gstfilesrc.sgml:
9244         * docs/gst/tmpl/gstidentity.sgml:
9245         * docs/gst/tmpl/gstindex.sgml:
9246         * docs/gst/tmpl/gstinfo.sgml:
9247         * docs/gst/tmpl/gstmd5sink.sgml:
9248         * docs/gst/tmpl/gstmultifilesrc.sgml:
9249         * docs/gst/tmpl/gstpad.sgml:
9250         * docs/gst/tmpl/gstpipefilter.sgml:
9251         * docs/gst/tmpl/gstpipeline.sgml:
9252         * docs/gst/tmpl/gstpluginfeature.sgml:
9253         * docs/gst/tmpl/gstqueue.sgml:
9254         * docs/gst/tmpl/gstregistry.sgml:
9255         * docs/gst/tmpl/gstscheduler.sgml:
9256         * docs/gst/tmpl/gstshaper.sgml:
9257         * docs/gst/tmpl/gstspider.sgml:
9258         * docs/gst/tmpl/gstspideridentity.sgml:
9259         * docs/gst/tmpl/gststatistics.sgml:
9260         * docs/gst/tmpl/gstsystemclock.sgml:
9261         * docs/gst/tmpl/gsttee.sgml:
9262         * docs/gst/tmpl/gstthread.sgml:
9263         * docs/gst/tmpl/gsttypefind.sgml:
9264         * docs/gst/tmpl/gstutils.sgml:
9265           further doc build fixes
9266
9267 2004-04-07  Thomas Vander Stichele  <thomas at apestaart dot org>
9268
9269         * docs/gst/Makefile.am:
9270           make docs exit on scanning problems
9271           fix nonsrcdir build issues
9272         * docs/gst/gstreamer-sections.txt:
9273           adding stuff from -unused
9274         * gst/gstqueue.h:
9275           create GstQueueSize
9276         * gst/schedulers/cothreads_compat.h:
9277           fix cothread warnings
9278
9279 2004-04-07  Thomas Vander Stichele  <thomas at apestaart dot org>
9280
9281         * docs/gst/gstreamer-sections.txt:
9282           remove defines deprecated by Benjamin
9283
9284 2004-04-07  Benjamin Otte  <otte@gnome.org>
9285
9286         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
9287           when the buffer is complete, don't check if other buffers are needed
9288         * gst/elements/gstfilesrc.c: (gst_filesrc_srcpad_event):
9289           check that the offset is >0 so we don't try to read before the
9290           beginning of the file
9291         * gst/gstpad.c: (gst_pad_set_pad_template):
9292           sink the template, so we don't end up with 130k pad templates
9293
9294 2004-04-06  Benjamin Otte  <otte@gnome.org>
9295
9296         * gst/autoplug/gstspider.c: (gst_spider_link_add):
9297           don't ref the element, adding already reffed it. And we didn't unref
9298           it later anyway... (huge memleak when you used many spider elements)
9299         * gst/gstelement.c: (gst_element_base_class_finalize):
9300         * gst/gstelementfactory.c: (gst_element_factory_cleanup),
9301         (gst_element_register):
9302         * gst/gsturi.c: (gst_element_make_from_uri):
9303           use gst_object_(un)ref instead of g_object(un)ref
9304
9305 2004-04-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9306
9307         * gst/gstbuffer.h:
9308           remove macro that wouldn't work anymore because struct member has
9309           been removed.
9310         * gst/schedulers/entryscheduler.c: (schedule_forward):
9311           fix segfault for unconnected pads
9312         
9313 2004-04-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9314
9315         reviewed by David Schleef <ds@schleef.org>
9316
9317         * gst/gstinfo.h:
9318           *_FORMAT modifiers should require putting a % in front of them for
9319           consistency reasons.
9320
9321 2004-04-05  Colin Walters  <walters@redhat.com>
9322
9323         * configure.ac (VALGRIND_CFLAGS, VALGRIND_LIBS): Remove spurious
9324         space.
9325
9326 2004-04-05  Benjamin Otte  <otte@gnome.org>
9327
9328         * configure.ac:
9329         * gst/Makefile.am:
9330         * gst/gst_private.h:
9331         * gst/gstinfo.c: (__gst_in_valgrind), (_gst_debug_init):
9332           add support for detecting if GStreamer runs inside valgrind.
9333           requires valgrind (d'oh) and --enable-debug for correct cdetection.
9334           print a big message in valgrind that GStreamer has detected it's
9335           running inside and might now use different code.
9336         * gst/gstmemchunk.c: (populate), (free_area),
9337         (gst_mem_chunk_destroy), (gst_mem_chunk_alloc),
9338         (gst_mem_chunk_free):
9339           flag memchunks for valgrind, so it can detect leaking of chunks.
9340           This allows detecting leaks of GstBuffer and GstEvent correctly
9341           inside valgrind.
9342
9343 2004-04-05  David Schleef  <ds@schleef.org>
9344
9345         * gst/gsttrace.h:  Fix #ifdef nesting (bug #139109) Patch from
9346           jensgr@gmx.net (Jens Granseuer)
9347
9348 2004-04-05  David Schleef  <ds@schleef.org>
9349
9350         * gst/gstbuffer.c: (_gst_buffer_sub_free),
9351         (gst_buffer_default_free), (gst_buffer_default_copy),
9352         (gst_buffer_alloc_chunk), (gst_buffer_free_chunk),
9353         (gst_buffer_new), (gst_buffer_create_sub):  Allocate GstBuffer
9354         structures in one place.
9355
9356 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
9357
9358         * gst/gstinfo.h: adding Ronald's timestamp debugging defines
9359           (GST_TIME_FORMAT, GST_TIME_ARGS)
9360
9361 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
9362
9363         * testsuite/elements/Makefile.am:
9364           disable test until it stops breaking make distcheck
9365
9366 2004-04-05  Johan Dahlin  <johan@gnome.org>
9367
9368         * po/sv.po: Updated translation
9369
9370 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
9371
9372         * gst/gstplugin.c: (gst_plugin_load_file):
9373           fix segfault for when original plugin was loaded statically
9374
9375 2004-04-05  Benjamin Otte  <otte@gnome.org>
9376
9377         * testsuite/debug/category.c: (main):
9378         * testsuite/debug/commandline.c: (main):
9379         * testsuite/debug/output.c: (main):
9380           fix tests to work again with debugging enabled
9381
9382 2004-04-05  Benjamin Otte  <otte@gnome.org>
9383
9384         * gst/schedulers/gstbasicscheduler.c:
9385         (gst_basic_scheduler_pad_link):
9386           fix to work with recent scheduling changes
9387
9388 2004-04-05  Benjamin Otte  <otte@gnome.org>
9389
9390         * gst/schedulers/entryscheduler.c: (some functions, dunno which,
9391         prepareChangeLog doesn't work when cvs indents):
9392           don't throw an error when no element can be scheduled, there's too
9393           many weird reasons why it doesn't work. Return STOPPED instead.
9394           decoupled elemts' schedulability doesn't depend on bufpens.
9395
9396 2004-04-04  Benjamin Otte  <otte@gnome.org>
9397
9398         * gst/schedulers/gstbasicscheduler.c:
9399         (gst_basic_scheduler_pad_select):
9400           fix uninitialized variable warnings
9401
9402 2004-04-04  Benjamin Otte  <otte@gnome.org>
9403
9404         * gst/gstpad.c: (gst_pad_collect_valist):
9405           fix uninitialized variable warning
9406         * gst/schedulers/entryscheduler.c: (schedule_forward):
9407           fix shadowed variable
9408
9409 2004-04-04  Benjamin Otte  <otte@gnome.org>
9410
9411         * gst/gstpad.c: (gst_pad_collect_array), (gst_pad_collectv),
9412         (gst_pad_collect), (gst_pad_collect_valist), (gst_pad_selectv),
9413         (gst_pad_select):
9414         * gst/gstpad.h:
9415         * gst/gstscheduler.c: (gst_scheduler_pad_select),
9416         (gst_scheduler_lock_element), (gst_scheduler_unlock_element):
9417         * gst/gstscheduler.h:
9418           implement gst_pad_collect as replacement for gst_pad_select.
9419           deprecate gst_pad_select and gst_scheduler_(un)lock_element
9420           add new flag GST_SCHEDULER_FLAG_NEW_API for API that implements the
9421           new pad_select, lock and unlock calls.
9422         * gst/cothreads.c: (cothread_destroy), (cothread_switch):
9423         * gst/cothreads.h:
9424         * gst/schedulers/cothreads_compat.h:
9425         * gst/schedulers/gthread-cothreads.h:
9426           remove unused cothread_lock and cothread_unlock calls
9427         * gst/schedulers/entryscheduler.c:
9428         (gst_entry_scheduler_class_init), (gst_entry_scheduler_init),
9429         (_can_schedule_loop), (gst_entry_scheduler_get_handler),
9430         (gst_entry_scheduler_pad_select):
9431           update to new API
9432         * gst/schedulers/gstbasicscheduler.c:
9433         (gst_basic_scheduler_class_init), (gst_basic_scheduler_init),
9434         (gst_basic_scheduler_pad_select):
9435           remove useless lock and unlock calls, update pad_select to new API
9436           (untested)
9437         * gst/schedulers/gstoptimalscheduler.c:
9438         (gst_opt_scheduler_class_init):
9439           remove useless select, lock and unlock function calls
9440         * gst/elements/gstaggregator.c: (gst_aggregator_loop):
9441           use gst_pad_collect instead of gst_pad_select
9442
9443 2004-04-04  Benjamin Otte  <otte@gnome.org>
9444
9445         * gst/schedulers/entryscheduler.c: (_can_schedule_get),
9446         (can_schedule_pad), (can_schedule), (schedule), (schedule_forward),
9447         (schedule_next_element), (print_entry):
9448           add can_schedule_pad to handle element states.
9449           add schedule_forward to select the correct entry to schedule next
9450
9451 2004-04-03  Benjamin Otte  <otte@gnome.org>
9452
9453         * gst/schedulers/entryscheduler.c: 
9454           remove unused variable, fix error inside Rb, fix compile warning in
9455           unreachable code
9456
9457 2004-04-03  Benjamin Otte  <otte@gnome.org>
9458
9459         * gst/schedulers/entryscheduler.c:
9460           completely revamp the inner workings, so it's a lot easier to
9461           understand and extend
9462
9463 2004-04-03  Andy Wingo  <wingo@pobox.com>
9464
9465         * gst/schedulers/gstoptimalscheduler.c (GstOptSchedulerGroupLink):
9466         Rename ->group1 and ->group2 to ->src and ->sink, respectively.
9467         This allows better introspection of pipeline topology.
9468         (add_to_chain): Don't do trickery to put loop elements first;
9469         rather, queue a chain sort by marking the chain as dirty.
9470         (remove_from_chain): Mark the chain dirty.
9471         (sort_chain): New function. Sorts the group list so that terminal
9472         sinks are first. This means elements on the sink side will be
9473         preferentially sscheduled before elements on the src side of the
9474         pipeline.
9475         (chain_recursively_migrate_group): Use OTHER_GROUP_LINK.
9476         (schedule_chain): If the chain is marked DIRTY, call sort_chain.
9477         (gst_opt_scheduler_pad_link, gst_opt_scheduler_pad_unlink)
9478         (group_inc_link): Change argument and variable names to match the
9479         new link structure member names (src and sink).
9480         (group_dec_link): Add some description
9481
9482 2004-04-03  Benjamin Otte  <otte@gnome.org>
9483
9484         * gst/autoplug/gstspider.c: (gst_spider_identity_plug):
9485         * gst/gstinfo.h:
9486         * testsuite/debug/category.c: (main):
9487         * testsuite/debug/commandline.c: (main):
9488         * testsuite/debug/output.c: (main):
9489         * testsuite/debug/printf_extension.c: (main):
9490           fix to successfully build and test with --disable-gst-debug
9491           configure switch (fixes #138705)
9492
9493 2004-04-03  Benjamin Otte  <otte@gnome.org>
9494
9495         * docs/pwg/building-boiler.xml:
9496           add cvs login line and s/anonymous/anoncvs/
9497
9498 2004-04-03  Tim-Phillip Müller  <t.i.m@zen.co.uk>
9499
9500         reviewed by Benjamin Otte  <otte@gnome.org>
9501
9502         * gst/gststructure.c: (gst_structure_free):
9503           memleak fix: free fields array (partial fix for #134839)
9504
9505 2004-04-01  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9506
9507         * docs/random/ds/0.9-suggested-changes:
9508           Add a note to change handoff use in fakesrc to be usable in
9509           a more generic way (fakesrc should be renamed to appsrc or so).
9510         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
9511           Change signal type to scope, so we can fill the buffer in the
9512           handoff handler (that's the whole use of this signal...).
9513
9514 2004-04-01  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9515
9516         * docs/pwg/other-ntoone.xml:
9517           Document muxers and n-to-1 elements.
9518
9519 2004-04-01  Martin Soto  <martinsoto@users.sourceforge.net>
9520
9521         * gst/registries/gstxmlregistry.c
9522         (gst_xml_registry_rebuild_recurse): Fix the algorithm to
9523         determine if a file is a G_MODULE. The old one discards paths
9524         containing "so" somewhere in the middle. My home directory is
9525         called "soto". Go figure...
9526
9527 2004-03-31  David Schleef  <ds@schleef.org>
9528
9529         * gst/gstbuffer.c: (gst_buffer_join):  Add function gst_buffer_join()
9530         to eventually deprecate gst_buffer_merge().  (bug: #136408)
9531         * gst/gstbuffer.h:
9532
9533 2004-03-31  David Schleef  <ds@schleef.org>
9534
9535         * gst/gstvalue.c: (gst_value_union_int_int_range),
9536         (gst_value_union_int_range_int_range), (gst_value_can_union),
9537         (gst_value_union), (_gst_value_initialize):  Add some union
9538         implementations.  We didn't have any previously.
9539         * testsuite/caps/Makefile.am:
9540         * testsuite/caps/audioscale.c: (gst_audioscale_expand_value),
9541         (gst_audioscale_getcaps), (test_caps), (main): A little test
9542         that is the same as the caps manipulation in audioscale.
9543
9544 2004-03-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9545
9546         * docs/faq/general.xml:
9547           add entry about "does gst support format X?"
9548
9549 2004-03-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9550
9551         * gst/gstthread.c:
9552           fix docs
9553         * gst/gstutils.h:
9554           fix GST_BOILERPLATE_FULL to not throw casting errors on C++
9555
9556 2004-03-30  Benjamin Otte  <otte@gnome.org>
9557
9558         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
9559           set the offset of the buffer to the requested offset
9560         * gst/elements/gsttypefind.c: (stop_typefinding):
9561           revert patch 1.18 (which I unfortunately don't know the reason for).
9562           This is needed to allow downstream elements to seek. Otherwise
9563           typefind might overwrite a previous seek by downstream elements.
9564           This lead to errors with id3tag and typefind on some mp3s.
9565         * gst/schedulers/entryscheduler.c: (COTHREADS_TYPE),
9566         (gst_entry_scheduler_iterate):
9567           be more verbose when debugging
9568
9569 2004-03-30  Thomas Vander Stichele  <thomas at apestaart dot org>
9570
9571         * gst/gstcaps.c: (gst_caps_from_string_inplace):
9572           make sure we don't get NULL strings
9573
9574 2004-03-30  Thomas Vander Stichele  <thomas at apestaart dot org>
9575
9576         * gst/gstcaps.c:
9577         * gst/gstelement.c:
9578         * gst/gstelementfactory.c: (gst_element_factory_get_type):
9579         * gst/gstindex.c: (gst_index_resolver_get_type),
9580         (gst_index_get_type), (gst_index_factory_get_type):
9581         * gst/gstinfo.c:
9582         * gst/gstpad.c:
9583         * gst/gstplugin.c:
9584         * gst/gsturi.c: (gst_uri_handler_get_type):
9585         * gst/gstvalue.c:
9586           first batch of documentation fixes
9587
9588 2004-03-29  David Schleef  <ds@schleef.org>
9589
9590         * docs/gst/Makefile.am:  Disable a bunch of headers from being scanned
9591         * docs/gst/gstreamer-docs.sgml:  More hacking
9592         * docs/gst/gstreamer-sections.txt:
9593         * docs/gst/tmpl/cothreads_compat.sgml:
9594         * docs/gst/tmpl/gstcaps.sgml:
9595         * docs/gst/tmpl/gstclock.sgml:
9596         * docs/gst/tmpl/gstelement.sgml:
9597         * docs/gst/tmpl/gstevent.sgml:
9598         * docs/gst/tmpl/gstpad.sgml:
9599         * docs/gst/tmpl/gstutils.sgml:
9600         * docs/gst/tmpl/gstxml.sgml:
9601         * docs/gst/tmpl/gthread-cothreads.sgml:
9602         * docs/random/ds/0.9-suggested-changes:
9603         * gst/elements/gstfakesink.h: doc fixes
9604         * gst/elements/gstfakesrc.h: doc fixes
9605         * gst/gstcaps.c: doc fixes
9606         * gst/gstcaps.h: doc fixes
9607         * gst/gstelement.c: doc fixes
9608         * gst/gstelement.h: doc fixes
9609         * gst/gstindex.c: doc fixes
9610         * gst/gstinfo.c: doc fixes
9611         * gst/gstpad.c: doc fixes
9612         * gst/gstpad.h: doc fixes
9613         * gst/gstplugin.c: doc fixes
9614         * gst/gsttypefind.h: doc fixes
9615         * gst/gsturi.c: doc fixes
9616         * gst/gstvalue.c: doc fixes
9617
9618 2004-03-29  Colin Walters  <walters@redhat.com>
9619
9620         * gst/registries/gstxmlregistry.c (get_time)
9621         (plugin_times_older_than_recurse):
9622         Use the result of stat to determine whether a path is a file,
9623         so we don't attempt to opendir() files.
9624
9625 2004-03-29  Benjamin Otte  <otte@gnome.org>
9626
9627         * gst/gstpad.c: (gst_pad_set_explicit_caps):
9628           print caps in debugging output when setting caps failed
9629         * gst/schedulers/entryscheduler.c: (COTHREADS_TYPE),
9630         (schedule_next_element), (get_buffer), (run_chainhandler),
9631         (element_may_start), (gst_entry_scheduler_chain_handler),
9632         (gst_entry_scheduler_get_handler),
9633         (gst_entry_scheduler_state_transition),
9634         (gst_entry_scheduler_pad_link):
9635           make this scheduler a testcase for mandatory
9636           discont-before-first-buffer which is needed if we want to allow apps
9637           to release the sound device.
9638           add SCHED_ASSERT macro to print scheduler state before an assertion
9639           triggers.
9640
9641 2004-03-29  Benjamin Otte  <otte@gnome.org>
9642
9643         * COPYING:
9644           replace by LGPL (former COPYING.LIB). The core is completely
9645           licensed LGPL.
9646         * COPYING.LIB:
9647           remove
9648
9649 2004-03-29  Thomas Vander Stichele  <thomas at apestaart dot org>
9650
9651         * po/af.po:
9652         * po/sv.po:
9653           updated Afrikaans and Swedish
9654
9655 2004-03-29  Thomas Vander Stichele  <thomas at apestaart dot org>
9656
9657         * po/LINGUAS:
9658         * po/az.po:
9659           adding Azerbaijani (Mətin Əmirov)
9660
9661 2004-03-28  Martin Soto  <martinsoto@users.sourceforge.net>
9662
9663         * gst/gstelement.h: 
9664         * gst/gstelement.c (gst_element_set_time_delay): New function for
9665         setting element time taking into account a hardware buffering
9666         delay.
9667         (gst_element_set_time): Now just an invocation of
9668         gst_element_set_time_delay.
9669         * gst/gstclock.h: 
9670         * gst/gstclock.c (gst_clock_get_event_time_delay): New function
9671         allowing to set event times in the future.
9672         (gst_clock_get_event_time): Now just an invocation of
9673         gst_clock_get_event_time_delay.
9674
9675 2004-03-28  Benjamin Otte  <otte@gnome.org>
9676
9677         * gst/gstbin.c: (gst_bin_set_element_sched),
9678         (gst_bin_unset_element_sched):
9679           don't add decoupled elements to schedulers - otherwise it's
9680           impossible to control if a link to a decoupled element was already
9681           removed from a scheduler or not.
9682         * gst/schedulers/cothreads_compat.h:
9683         * gst/schedulers/gthread-cothreads.h:
9684           add COTHREADS_TYPE macro. Make do_cothread_set_func a macro so there
9685           is no "unused" warning.
9686         * gst/schedulers/Makefile.am:
9687         * gst/schedulers/entryscheduler.c:
9688           add new scheduler, based on ideas from talking to David and Martin.
9689           It's supposed to be small and correct. Currently it's also slow (but
9690           it's not noticable)
9691         * examples/retag/retag.c: (main):
9692         * testsuite/bytestream/test1.c: (main):
9693           fix missing NULLs at end of variadic functions
9694         * testsuite/elements/.cvsignore:
9695           update
9696
9697 2004-03-28  Jan Schmidt  <thaytan@mad.scientist.com>
9698
9699         * gst/gstevent.h:
9700         Added GST_EVENT_ANY for GstEvents that pass a GstStructure
9701
9702 2004-03-25  David Schleef  <ds@schleef.org>
9703
9704         * docs/gst/gstreamer-sections.txt:  More doc hacking.
9705         * docs/gst/tmpl/gstaggregator.sgml:
9706         * docs/gst/tmpl/gstautoplugfactory.sgml:
9707         * docs/gst/tmpl/gstbin.sgml:
9708         * docs/gst/tmpl/gstbuffer.sgml:
9709         * docs/gst/tmpl/gstbufferstore.sgml:
9710         * docs/gst/tmpl/gstfakesink.sgml:
9711         * docs/gst/tmpl/gstfakesrc.sgml:
9712         * docs/gst/tmpl/gstmd5sink.sgml:
9713         * docs/gst/tmpl/gstreamer-unused.sgml:
9714         * docs/gst/tmpl/gstsearchfuncs.sgml:
9715         * docs/gst/tmpl/gstshaper.sgml:
9716         * docs/gst/tmpl/gstspider.sgml:
9717         * docs/gst/tmpl/gsttee.sgml:
9718         * docs/gst/tmpl/gstutils.sgml:
9719         * docs/gst/tmpl/gstvalue.sgml:
9720         * docs/gst/tmpl/gstxml.sgml:
9721         * gst/Makefile.am:  Remove gstthreaddummy.c.  It never worked,
9722         and we don't support it.
9723         * gst/gst.c: (gst_init_get_popt_table), (init_pre), (init_post),
9724         (gst_use_threads), (gst_has_threads): same
9725         * gst/gstthreaddummy.c: same
9726         * gst/autoplug/gstspider.c: Make gst_spider_details static.
9727         * gst/autoplug/gstspider.h: same
9728         * gst/elements/gstaggregator.h: Remove bogus function from header
9729         * gst/elements/gstfakesink.h: same
9730         * gst/elements/gstfakesrc.h: same
9731         * gst/elements/gstmd5sink.h: same
9732         * gst/elements/gstshaper.h: same
9733         * gst/elements/gsttee.h: same
9734         * gst/gstbin.c: doc fixes
9735         * gst/gstbin.h: Remove unused definition.
9736         * gst/gstbuffer.c: doc fixes
9737         * gst/gstcaps.c: (gst_caps_is_always_compatible): doc fixes
9738         * gst/gstfilter.c: doc fixes
9739         * gst/gsttag.c: doc fixes
9740         * gst/gstvalue.c: doc fixes
9741
9742 2004-03-25  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9743
9744         * docs/pwg/advanced-types.xml:
9745           Document typefinding.
9746         * docs/pwg/other-oneton.xml:
9747           Document one-to-n elements, demuxers and parsers.
9748
9749 2004-03-25  Tim-Philipp Müller <t.i.m@zen.co.uk>
9750
9751         reviewed by: David Schleef  <ds@schleef.org>
9752
9753         * configure.ac: Check bison version (bug #127838)
9754
9755 2004-03-25  David Schleef  <ds@schleef.org>
9756
9757         * docs/gst/gstreamer-docs.sgml: More fine tuning.
9758         * docs/gst/gstreamer-sections.txt:
9759         * docs/gst/tmpl/gstautoplug.sgml:
9760         * docs/gst/tmpl/gststaticautoplug.sgml:
9761         * docs/gst/tmpl/gststaticautoplugrender.sgml:
9762         * docs/gst/tmpl/gstutils.sgml:
9763         * docs/gst/tmpl/gstxml.sgml:
9764
9765 2004-03-24  David Schleef  <ds@schleef.org>
9766
9767         * docs/gst/gstreamer-docs.sgml:  I got tired of the reference
9768         manual being such complete crap, that I decided to do major
9769         hacking of it.  This checkin replaces any fine tuning that
9770         may have been done previously, with the benefit of actually
9771         being complete for much of the API that was changed since
9772         0.6.  Further fine tuning will occur shortly.  (bug #134721)
9773         * docs/gst/gstreamer-sections.txt:
9774         * docs/gst/tmpl/GstBin.sgml:
9775         * docs/gst/tmpl/GstBuffer.sgml:
9776         * docs/gst/tmpl/GstCaps.sgml:
9777         * docs/gst/tmpl/GstClock.sgml:
9778         * docs/gst/tmpl/GstCompat.sgml:
9779         * docs/gst/tmpl/GstData.sgml:
9780         * docs/gst/tmpl/GstElement.sgml:
9781         * docs/gst/tmpl/GstEvent.sgml:
9782         * docs/gst/tmpl/GstIndex.sgml:
9783         * docs/gst/tmpl/GstStructure.sgml:
9784         * docs/gst/tmpl/GstTag.sgml:
9785         * docs/gst/tmpl/cothreads.sgml:
9786         * docs/gst/tmpl/cothreads_compat.sgml:
9787         * docs/gst/tmpl/gettext.sgml:
9788         * docs/gst/tmpl/grammar.tab.sgml:
9789         * docs/gst/tmpl/gst-i18n-app.sgml:
9790         * docs/gst/tmpl/gst-i18n-lib.sgml:
9791         * docs/gst/tmpl/gst.sgml:
9792         * docs/gst/tmpl/gst_private.sgml:
9793         * docs/gst/tmpl/gstaggregator.sgml:
9794         * docs/gst/tmpl/gstarch.sgml:
9795         * docs/gst/tmpl/gstatomic.sgml:
9796         * docs/gst/tmpl/gstatomic_impl.sgml:
9797         * docs/gst/tmpl/gstbin.sgml:
9798         * docs/gst/tmpl/gstbuffer.sgml:
9799         * docs/gst/tmpl/gstbufferstore.sgml:
9800         * docs/gst/tmpl/gstcaps.sgml:
9801         * docs/gst/tmpl/gstclock.sgml:
9802         * docs/gst/tmpl/gstcompat.sgml:
9803         * docs/gst/tmpl/gstconfig.sgml:
9804         * docs/gst/tmpl/gstcpu.sgml:
9805         * docs/gst/tmpl/gstdata.sgml:
9806         * docs/gst/tmpl/gstdata_private.sgml:
9807         * docs/gst/tmpl/gstelement.sgml:
9808         * docs/gst/tmpl/gstenumtypes.sgml:
9809         * docs/gst/tmpl/gsterror.sgml:
9810         * docs/gst/tmpl/gstevent.sgml:
9811         * docs/gst/tmpl/gstfakesink.sgml:
9812         * docs/gst/tmpl/gstfakesrc.sgml:
9813         * docs/gst/tmpl/gstfilesink.sgml:
9814         * docs/gst/tmpl/gstfilter.sgml:
9815         * docs/gst/tmpl/gstindex.sgml:
9816         * docs/gst/tmpl/gstinfo.sgml:
9817         * docs/gst/tmpl/gstinterface.sgml:
9818         * docs/gst/tmpl/gstlog.sgml:
9819         * docs/gst/tmpl/gstmacros.sgml:
9820         * docs/gst/tmpl/gstmarshal.sgml:
9821         * docs/gst/tmpl/gstmd5sink.sgml:
9822         * docs/gst/tmpl/gstmultifilesrc.sgml:
9823         * docs/gst/tmpl/gstobject.sgml:
9824         * docs/gst/tmpl/gstpad.sgml:
9825         * docs/gst/tmpl/gstparse.sgml:
9826         * docs/gst/tmpl/gstpipeline.sgml:
9827         * docs/gst/tmpl/gstplugin.sgml:
9828         * docs/gst/tmpl/gstpluginfeature.sgml:
9829         * docs/gst/tmpl/gstqueue.sgml:
9830         * docs/gst/tmpl/gstreamer-unused.sgml:
9831         * docs/gst/tmpl/gstregistry.sgml:
9832         * docs/gst/tmpl/gstregistrypool.sgml:
9833         * docs/gst/tmpl/gstscheduler.sgml:
9834         * docs/gst/tmpl/gstsearchfuncs.sgml:
9835         * docs/gst/tmpl/gstshaper.sgml:
9836         * docs/gst/tmpl/gstspider.sgml:
9837         * docs/gst/tmpl/gstspideridentity.sgml:
9838         * docs/gst/tmpl/gststructure.sgml:
9839         * docs/gst/tmpl/gstsystemclock.sgml:
9840         * docs/gst/tmpl/gsttag.sgml:
9841         * docs/gst/tmpl/gsttaginterface.sgml:
9842         * docs/gst/tmpl/gsttee.sgml:
9843         * docs/gst/tmpl/gstthread.sgml:
9844         * docs/gst/tmpl/gsttrace.sgml:
9845         * docs/gst/tmpl/gsttrashstack.sgml:
9846         * docs/gst/tmpl/gsttypefind.sgml:
9847         * docs/gst/tmpl/gsttypes.sgml:
9848         * docs/gst/tmpl/gsturi.sgml:
9849         * docs/gst/tmpl/gsturitype.sgml:
9850         * docs/gst/tmpl/gstutils.sgml:
9851         * docs/gst/tmpl/gstvalue.sgml:
9852         * docs/gst/tmpl/gstversion.sgml:
9853         * docs/gst/tmpl/gstxml.sgml:
9854         * docs/gst/tmpl/gstxmlregistry.sgml:
9855         * docs/gst/tmpl/gthread-cothreads.sgml:
9856         * docs/gst/tmpl/types.sgml:
9857
9858 2004-03-24  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9859
9860         * docs/pwg/other-sink.xml:
9861         * docs/pwg/other-source.xml:
9862           Documentation on how to write source and sink elements. Other
9863           stuff in chapter 4 (1-to-n/demuxer, n-to-1/muxer, n-to-n,
9864           manager, autoplugger) are all still pending.
9865
9866 2004-03-25  Benjamin Otte  <otte@gnome.org>
9867
9868         * testsuite/elements/Makefile.am:
9869         * testsuite/elements/gst-compprep-check:
9870           add check to make sure gst-compprep works
9871         * testsuite/elements/gst-inspect-check.in:
9872           improve initialization output
9873         * testsuite/Makefile.am:
9874         * testsuite/gst-inspect-check:
9875           remove old file
9876
9877 2004-03-24  David Schleef  <ds@schleef.org>
9878
9879         * testsuite/elements/Makefile.am:
9880         * testsuite/elements/gst-inspect-check.in: Add gst-inspect-check
9881         to the testsuite.
9882
9883 2004-03-24  Benjamin Otte  <otte@gnome.org>
9884
9885         * libs/gst/control/dparam.c: (gst_dparam_attach),
9886         (gst_dparam_detach):
9887         * libs/gst/control/dparammanager.c: (gst_dpman_init):
9888           fix lvalue casts for real
9889
9890 2004-03-24  Benjamin Otte  <otte@gnome.org>
9891
9892         * gst/schedulers/gstbasicscheduler.c:
9893         (gst_basic_scheduler_src_wrapper):
9894         * gst/schedulers/gstoptimalscheduler.c:
9895         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
9896         (pad_clear_queued), (gst_opt_scheduler_add_element),
9897         (gst_opt_scheduler_remove_element):
9898           fix GStreamer to not have issues with lvalue casts anymore (fixes
9899           #136841)
9900
9901 2004-03-24  Benjamin Otte  <otte@gnome.org>
9902
9903         * gst/gstelement.c:
9904           add documentation about a gobject quirk where the object hasn't the
9905           correct class pointer set on initialization
9906         * gst/schedulers/gstbasicscheduler.c:
9907         (gst_basic_scheduler_src_wrapper):
9908           make sure to not run into an infinite loop
9909
9910 2004-03-22  Benjamin Otte  <otte@gnome.org>
9911
9912         * gst/gstutils.c: (gst_util_dump_mem):
9913         * gst/gstutils.h:
9914           first argument of gst_util_dump_mem should be const
9915
9916 2004-03-22  Johan Dahlin  <johan@gnome.org>
9917
9918         * gst/gstvalue.h: Clean up a little bit.
9919
9920 2004-03-21  Tim-Philipp Müller <t.i.m@zen.co.uk>
9921
9922         reviewed by Benjamin Otte  <otte@gnome.org>
9923
9924         * gst/autoplug/gstspider.c: (gst_spider_dispose):
9925         * gst/elements/gstaggregator.c: (gst_aggregator_finalize),
9926         (gst_aggregator_class_init), (gst_aggregator_init):
9927         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
9928         (gst_filesrc_dispose), (gst_filesrc_set_location):
9929         * gst/elements/gstidentity.c: (gst_identity_finalize),
9930         (gst_identity_class_init), (gst_identity_chain):
9931         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_open_file):
9932         * gst/elements/gststatistics.c: (gst_statistics_finalize),
9933         (gst_statistics_class_init):
9934         * gst/elements/gsttee.c: (gst_tee_finalize), (gst_tee_class_init),
9935         (gst_tee_get_property):
9936           clean up used memory in this elements correctly on teardown (closes
9937           #137279)
9938
9939 2004-03-20  Colin Walters  <walters@redhat.com>
9940
9941         * gst/registries/gstxmlregistry.c:
9942         (gst_xml_registry_open_func, gst_xml_registry_close_func): Make
9943         registry saving atomic.
9944
9945 2004-03-20  Colin Walters  <walters@redhat.com>
9946
9947         * gst/registries/gstxmlregistry.c (gst_xml_registry_get_perms_func):
9948         Just use
9949         access() instead of actually creating and deleting files.
9950
9951 2004-03-18  David Schleef  <ds@schleef.org>
9952
9953         * configure.ac:  Remove HAVE_ATOMIC_H test, since it's unused.
9954         (bug #137625)
9955
9956 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
9957
9958         * po/sv.po: updated translation (Christian Rose)
9959
9960 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
9961
9962         * gst/elements/gstfilesink.c: (gst_filesink_get_formats),
9963         (gst_filesink_get_query_types), (_do_init),
9964         (gst_filesink_handle_event), (gst_filesink_uri_get_protocols):
9965           return FALSE silently
9966         * po/af.po: updated translation (Petri Jooste)
9967
9968 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
9969
9970         * Makefile.am:
9971         * configure.ac:
9972           dist common properly
9973         * po/af.po:
9974         * po/fr.po:
9975         * po/nl.po:
9976         * po/sr.po:
9977         * po/sv.po:
9978           refreshing translations
9979
9980 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
9981
9982         * po/LINGUAS:
9983         * po/sv.po:
9984         * po/af.po:
9985           adding Swedish (Christian Rose) and Afrikaans (Petri Jooste)
9986
9987 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
9988
9989         * Makefile.am: use common/release.mak
9990
9991 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
9992
9993         * docs/faq/gst-uninstalled:
9994           adding gst-monkeysaudio to the list of possible plugin dirs
9995
9996 2004-03-16  David Schleef  <ds@schleef.org>
9997
9998         * gst/gst.c: (gst_get_popt_options), (gst_init_get_popt_table),
9999         (gst_init_check_with_popt_table):  Fix some gettext strings to
10000         make them easier to translate.  Required making the strings
10001         non-const.
10002
10003 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10004
10005         * configure.ac: bump nano to 1
10006
10007 === release 0.8.0 ===
10008
10009 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10010
10011         * configure.ac: release 0.8.0, "Executive Slacks"
10012
10013 2004-03-16  Johan Dahlin  <johan@gnome.org>
10014
10015         * gst/schedulers/gstoptimalscheduler.c
10016         (gst_opt_scheduler_pad_unlink): Remove double ;,
10017         spotted by Scott Wheeler
10018
10019 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10020
10021         * configure.ac: bump libtool version
10022
10023 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10024
10025         * gst/gstcaps.h:
10026         * gst/gststructure.h:
10027           add reserved padding
10028
10029 2004-03-15  Benjamin Otte  <otte@gnome.org>
10030
10031         * gst/elements/gstfdsrc.c: (gst_fdsrc_get):
10032           set the first parameter for select call correctly.
10033           (fixes #137230)
10034
10035 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10036
10037         * *.c,*.h: don't mix tabs and spaces
10038
10039 2004-03-15  Johan Dahlin  <johan@gnome.org>
10040
10041         * gst/schedulers/gstoptimalscheduler.c
10042         (gst_opt_scheduler_pad_unlink): Fix bug that causes totem to
10043         crash on MPEG playback. My boolean arithmetic is a bit rusty.
10044
10045         * tools/Makefile.am (EXTRA_DIST): Add gst-indent
10046         
10047 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10048
10049         * testsuite/Rules:
10050           fix gst-register rules
10051
10052 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10053
10054         * testsuite/Rules:
10055           use versioned gst-register
10056
10057 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10058
10059         * docs/libs/gstreamer-libs-sections.txt:
10060           remove </SUBSECTION>
10061         * gst/gstplugin.c:
10062         * gst/gstregistry.c: (gst_registry_add_plugin):
10063         * gst/registries/gstxmlregistry.c: (gst_xml_registry_get_type),
10064         (gst_xml_registry_open_func), (gst_xml_registry_close_func):
10065           add debugging and fix some comment blocks
10066
10067 2004-03-15  Johan Dahlin  <johan@gnome.org>
10068
10069         * *.h: Revert indent changes.
10070         
10071 2004-03-14  Thomas Vander Stichele  <thomas at apestaart dot org>
10072
10073         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load_plugin):
10074           g_error_free the g_error
10075         * tools/gst-feedback-m.m:
10076           check for other versions of gstreamer
10077         * tools/gst-indent:
10078           use sh, not bash
10079
10080 2004-03-14  Thomas Vander Stichele  <thomas at apestaart dot org>
10081
10082         * tools/gst-register.c: do not spill paths when registries are not
10083           writable, until we fix the "user running gst-register" case.
10084
10085 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
10086
10087         * *.c, *.h: commit of gst-indent run on core
10088
10089 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
10090
10091         * tools/gst-indent:
10092         * tools/Makefile.am:
10093           add our indentation style as a script
10094
10095 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
10096
10097         * po/sr.po:
10098         * po/LINGUAS:
10099           added Serbian translation
10100
10101 2004-03-13  Benjamin Otte  <otte@gnome.org>
10102
10103         * gst/gstelement.c:
10104           add documentation note about gst_element_found_tags_for_pad not
10105           being usable in getfunctions. (see #137042)
10106
10107 2004-03-12  David Schleef  <ds@schleef.org>
10108
10109         * gst/gstcaps.h: jdahlin, what are you smoking?  We can't just
10110         change API right now!  Readd gst_caps_is_simple() macro.
10111         * gst/gstelement.c: (gst_element_base_class_finalize): Fix
10112         uninitialized variable.  I'd bet this caused crashes.
10113         * gst/gstinfo.c: (gst_debug_print_object):  Fix 64-bit cleanliness.
10114
10115 2004-03-12  Johan Dahlin  <johan@gnome.org>
10116
10117         * gst/gstcaps.h (GST_CAPS_IS_SIMPLE): Capitalize macro
10118         * gst/gstcaps.h: Clean up
10119
10120         * gst/gst.c (init_post): call gst_caps_get_type() instead of
10121         _gst_caps_initalize()
10122
10123         * gst/gstcaps.c: Style fixes, stay closer to glib and friends
10124         (_gst_caps_initialize): Remove, in favor for gst_caps_get_type()
10125
10126         * gst/gststructure.c (gst_structure_get_type): Ditto
10127
10128         * gst/gststructure.h: Ditto
10129         
10130 2004-03-11  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10131
10132         * gst/gstqueue.c: (gst_queue_init):
10133           Reset default max. values in queues. Reason is simply to avoid
10134           braindead use. If you want wider values, use the properties. The
10135           default is supposed to always work. Wider values would make this
10136           beast a memory hog by default (250 full-PAL RGB32 video frames?
10137           That's 440 MB! No thank you).
10138
10139 2004-03-10  David Schleef  <ds@schleef.org>
10140
10141         * tools/gst-run.c: (main):  Fix crash when no relevant tools
10142         were found.  (bug #136793)
10143
10144 2004-03-10  Johan Dahlin  <johan@gnome.org>
10145
10146         * gst/schedulers/gstoptimalscheduler.c
10147         (gst_opt_scheduler_pad_unlink): Implement unlink for elements with
10148         links to elements within the same group, so we can finally remove
10149         that annoying warning. Refactor the code a little bit
10150         (group_dec_links_for_element): Split out
10151
10152 2004-03-09  David Schleef  <ds@schleef.org>
10153
10154         * docs/manual/dparams-app.xml:  Fix to handle double dparams.
10155         (bug #134863)
10156
10157 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
10158
10159         * configure.ac: first bug fix due to major/minor bump
10160
10161 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
10162
10163         * configure.ac: bump nano to 1
10164
10165 === release 0.7.6 ===
10166
10167 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
10168
10169         * NEWS:
10170         * RELEASE:
10171         * configure.ac:
10172           releasing 0.7.6, "Almost"
10173         * po/fr.po:
10174         * po/nl.po:
10175         * tools/Makefile.am:
10176         * tools/gst-feedback-m.m:
10177           unversioned source
10178
10179 2004-03-09  Johan Dahlin  <johan@gnome.org>
10180
10181         Reviewed by: Thomas Vander Stichele
10182
10183         * gst/gstelement.c (gst_element_class_init): register second
10184         parameter as GST_TYPE_G_ERROR instead of G_TYPE_POINTER, so
10185         language bindings can (de)marshall correctly.
10186
10187         * gst/gsterror.h: Add GST_TYPE_G_ERROR and cleanup a little bit
10188
10189         * gst/gsterror.c (gst_g_error_get_type): New function
10190
10191         * gst/gstmarshal.list: Remove VOID:OBJECT,POINTER,STRING, replace
10192         with VOID:OBJECT,OBJECT,STRING 
10193
10194 2004-03-10  Jan Schmidt  <thaytan@mad.scientist.com>
10195
10196         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load):
10197         Free a leaked g_timer on early returns.
10198
10199 2004-03-08  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10200
10201         * docs/pwg/advanced-types.xml:
10202           Add cinepak description.
10203
10204 2004-03-07  David Schleef  <ds@schleef.org>
10205
10206         * docs/random/mimetypes:  Added cinepak description
10207
10208 2004-03-07  Andy Wingo  <wingo@pobox.com>
10209
10210         * gst/gstbin.c (gst_bin_remove): Debugging fixes.
10211
10212         * gst/schedulers/gstoptimalscheduler.c (destroy_group): Assert
10213         there are no links to other groups when a group is destroyed.
10214         (gst_opt_scheduler_pad_unlink): If the unlink means an element is
10215         removed from a group, make sure the link count to elements linked
10216         to other pads is appropriately decremented. This really fixes
10217         #135672.
10218
10219         The 1.60->1.61 patch has been reapplied in light of this fix.
10220
10221         * gst/gstelement.c (gst_element_dispose): Really protect against
10222         multiple invocations this time.
10223
10224 2004-03-06  Thomas Vander Stichele  <thomas at apestaart dot org>
10225
10226         * docs/gst/gstreamer-sections.txt:
10227         * docs/gst/tmpl/gsttag.sgml:
10228           remove some deprecated functions, document some existing ones
10229         * gst/gsttag.c: (gst_tag_get_flag):
10230         * gst/gsttag.h:
10231           add accessor function
10232
10233 2004-03-06  Thomas Vander Stichele  <thomas at apestaart dot org>
10234
10235         * docs/gst/gstreamer-sections.txt:
10236         * docs/gst/tmpl/gsttag.sgml:
10237         * docs/gst/tmpl/gstxml.sgml:
10238         * gst/gsttag.c: (gst_tag_get_flag):
10239         * gst/gsttag.h:
10240
10241 2004-03-06  Christophe Fergeau  <teuf@gnome.org>
10242
10243         * gst/autoplug/gstspider.c: (gst_spider_identity_plug): fixed caps
10244         leak
10245
10246 2004-03-05  David Schleef  <ds@schleef.org>
10247
10248         * REQUIREMENTS: Add bison and flex.
10249         * configure.ac: Fix comment about bison.
10250         * docs/random/ds/0.9-suggested-changes: yer ma
10251         * tools/gst-inspect.c: (print_element_info):  Fix warning.
10252
10253 2004-03-05  Benjamin Otte  <otte@gnome.org>
10254
10255         * gst/gstelement.c: (gst_element_error_full):
10256           revert recent recursive state changing commit - messing with other
10257           elements' states is evil and should be done by apps only.
10258
10259 2004-03-05  Benjamin Otte  <otte@gnome.org>
10260
10261         * gst/gstelement.c: (gst_element_get_compatible_pad_template):
10262           check for empty intersection instead of NULL caps
10263         (gst_element_get_compatible_pad_filtered):
10264           remove old workaround that is only a bug nowadays
10265
10266 2004-03-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10267
10268         * gst/gstelement.c: (gst_element_error_full):
10269           make elements try to recursively change state to PAUSED on all
10270           parents after an error to suppress ensuing warnings
10271         * gst/parse/grammar.y:
10272           make it check if it was able to sync the state, and throw an error
10273           if not, so stuff like
10274           oggdemux ! vorbisdec ! osssink gets caught
10275
10276 2004-03-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10277
10278         * configure.ac: use ${libdir} for PLUGINS_DIR since on 64bit
10279           it contains lib64; use AS_AC_EXPAND to handle it properly
10280
10281 2004-03-05  David Schleef  <ds@schleef.org>
10282
10283         * gst/gstcpuid_i386.s:  Remove unused code
10284         * libs/gst/getbits/getbits.c: (gst_getbits_init),
10285         (gst_getbits_newbuf): Remove MMX code
10286         * libs/gst/getbits/getbits.h: Remove MMX code
10287
10288 2004-03-04  David I. Lehn  <dlehn@users.sourceforge.net>
10289
10290         * debian/.cvsignore:
10291         * debian/README.Debian:
10292         * debian/changelog:
10293         * debian/control:
10294         * debian/control.in:
10295         * debian/copyright:
10296         * debian/gstreamer-core-libs-dev.files:
10297         * debian/gstreamer-core-libs.files:
10298         * debian/gstreamer-core.files:
10299         * debian/gstreamer-core.postinst:
10300         * debian/gstreamer-core.postrm:
10301         * debian/gstreamer-doc.files:
10302         * debian/gstreamer-doc.links:
10303         * debian/gstreamer-doc.lintian:
10304         * debian/gstreamer-runtime.files:
10305         * debian/gstreamer-runtime.manpages:
10306         * debian/gstreamer-runtime.postinst:
10307         * debian/gstreamer-runtime.postrm:
10308         * debian/gstreamer-tools.files:
10309         * debian/gstreamer-tools.manpages:
10310         * debian/libgstreamer-dev.files:
10311         * debian/libgstreamer0.4.1.files:
10312         * debian/libgstreamerVERSION.files:
10313         * debian/rules:
10314         Debian package info not maintained here.
10315
10316 2004-03-04  Thomas Vander Stichele  <thomas at apestaart dot org>
10317
10318         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
10319         * gst/gstbin.c: (gst_bin_class_init):
10320         * gst/gstelement.c: (gst_element_class_init):
10321         * gst/gstindex.c: (gst_index_class_init):
10322         * gst/gstobject.c: (gst_object_class_init),
10323         (gst_signal_object_class_init):
10324         * gst/gstpad.c: (gst_pad_template_class_init):
10325         * gst/gstregistry.c: (gst_registry_class_init):
10326         * gst/gsturi.c: (gst_uri_handler_base_init):
10327         * gst/gstxml.c: (gst_xml_class_init):
10328         * libs/gst/control/dparam.c: (gst_dparam_class_init):
10329         * libs/gst/control/dparammanager.c: (gst_dpman_class_init):
10330           make all signal names use dashes instead of underscore
10331
10332 2004-03-03  Thomas Vander Stichele  <thomas at apestaart dot org>
10333
10334         * configure.ac: AC_SUBST GLIB_ONLY CFLAGS and LIBS
10335
10336 2004-03-03  Benjamin Otte  <otte@gnome.org>
10337
10338         * gst/schedulers/gstoptimalscheduler.c:
10339           revert last commit by Andy Wingo. It causes segfaults on unreffing
10340           in Rhythmbox. (see bug #135672)
10341
10342 2004-03-02  Christophe Fergeau  <teuf@gnome.org>
10343
10344         * po/fr.po: fix typo
10345
10346 2004-03-02  Christophe Fergeau  <teuf@gnome.org>
10347
10348         * tools/gst-inspect.c: (main): 
10349         * tools/gst-launch.c: (main): add calls to bind_textdomain_codeset
10350
10351 2004-03-02  Thomas Vander Stichele  <thomas at apestaart dot org>
10352
10353         * configure.ac:
10354           get GLIB_ONLY and POPT flags for the nonversioned binaries
10355         * tools/Makefile.am:
10356           use them
10357
10358 2004-03-02  Thomas Vander Stichele  <thomas at apestaart dot org>
10359
10360         * gst/gst.c: (init_post):
10361           change so that GST_REGISTRY now is where the global registry gets
10362           saved, since that is where plugins now get attached to first, and
10363           spilled over to the user registry.  Note that in the case of using
10364           GST_REGISTRY env var, we don't want to affect any real registries
10365           beyond the one given by this var, and thus we don't set a user
10366           registry to spill to.  So make sure GST_REGISTRY is writable.
10367
10368 2004-03-01  David Schleef  <ds@schleef.org>
10369
10370         * AUTHORS:  Added some names.  Add yourself if you're missing.
10371
10372 2004-03-01  David Schleef  <ds@schleef.org>
10373
10374         * MAINTAINERS: Add
10375
10376 2004-03-01  Thomas Vander Stichele  <thomas at apestaart dot org>
10377
10378         * configure.ac:
10379           remove whitespace
10380         * docs/gst/tmpl/gstbuffer.sgml:
10381         * docs/gst/tmpl/gstdata.sgml:
10382         * docs/gst/tmpl/gstreamer-unused.sgml:
10383         * docs/gst/tmpl/gstxml.sgml:
10384           doc update
10385         * docs/manuals.mak:
10386           add a FIXME
10387         * docs/pwg/intro-preface.xml:
10388         * docs/pwg/pwg.xml:
10389           remove GNOME
10390         * gst/gst.c: (init_post):
10391           try GST_PLUGIN_PATH paths for the _global_registry first
10392         * gst/gstelement.h:
10393           add the error message as well, otherwise (null) debug info doesn't
10394           make much sense
10395         * tools/gst-register.c: (main):
10396           spill paths to next registry if this registry is not writable
10397         * po/fr.po:
10398         * po/nl.po:
10399           translation updates
10400
10401 2004-03-01  Johan Dahlin  <johan@gnome.org>
10402
10403         * gst/gstbuffer.c (_gst_buffer_initialize): 
10404         * gst/gstdata.c (gst_data_get_type): 
10405         * gst/gstevent.c (_gst_event_initialize): Use gst_data_copy,
10406         instead of ref, since some applications that uses GBoxed
10407         routines depends on a function that actually returns a copy.
10408
10409 2004-02-27  Benjamin Otte  <otte@gnome.org>
10410
10411         * gst/gstbuffer.h:
10412           remove gst_buffer_free, use gst_data_unref
10413         * gst/gstdata.c: (gst_data_get_type):
10414           use refcounting in GstData GBoxed registration
10415         * gst/gstdata.h:
10416           remove gst_data_free, use gst_data_unref
10417
10418 2004-02-27  Johan Dahlin  <johan@gnome.org>
10419
10420         * gst/gstdata.c (gst_data_get_type): New function, register
10421         GstData as a GBoxed type.
10422
10423         * gst/gstdata.h (GST_TYPE_DATA): New macro
10424
10425 2004-02-27  Thomas Vander Stichele  <thomas at apestaart dot org>
10426
10427         * Makefile.am:
10428         * gstreamer.spec.in:
10429           put back RELEASE
10430         * gst/Makefile.am:
10431           clean up non-disting of built files
10432         * testsuite/debug/commandline.c:
10433           test fix for option rename
10434
10435 2004-02-26  David Schleef  <ds@schleef.org>
10436
10437         * configure.ac:  We don't really need glib-2.3.  Also remove
10438         some unneeded checks for library functions.
10439         * gst/Makefile.am:  Instead, we need to not dist files created
10440         by glib-genmarshal.
10441
10442 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10443
10444         * configure.ac:
10445           bump glib required version to 2.3.0 for g_value_takes_boxed
10446
10447  2004-02-25  Christian Fredrik Kalager Schaller <uraeus@gnome.org>
10448
10449         * common/m4/gst-docs.m4
10450         change flavour text from enable to disable as enable is our default
10451         closes bug Bug 135304
10452
10453 === release 0.7.5 ===
10454  
10455  2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10456  
10457         * NEWS:
10458           instate NEWS file
10459         * Makefile.am:
10460         * gstreamer.spec.in:
10461         * RELEASE:
10462           put back release
10463         * configure.ac:
10464         * docs/random/release:
10465           more updates
10466
10467 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10468
10469         * gst/gsttag.c: (_gst_tag_initialize):
10470         * po/fr.po:
10471         * po/nl.po:
10472           remove hyphen from codec tags
10473
10474 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10475
10476         * gst/parse/Makefile.am:
10477           fix dependency so that a make from a clean build works the first
10478           time
10479
10480 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10481
10482         * docs/random/release:
10483           update release strategy
10484         * po/fr.po:
10485           auto-update po file
10486         * po/nl.po:
10487           update dutch translation
10488
10489 2004-02-25  Thomas Vander Stichele  <thomas at apestaart dot org>
10490
10491         * docs/manual/debugging.xml:
10492         fix manual for new debugging system
10493
10494 2004-02-25  Andy Wingo  <wingo@pobox.com>
10495
10496         * gst/gstpad.c (gst_pad_link_prepare): Re-add
10497         gst_pad_link_prepare. Please email the list with specific reasons
10498         for reverting.
10499
10500 2004-02-24  Andy Wingo  <wingo@pobox.com>
10501
10502         * gst/gstelement.c (gst_element_dispose): Protect against multiple
10503         invocations.
10504
10505         * gst/schedulers/gstoptimalscheduler.c:
10506         I added a mess of prototypes at the top of the file by way of
10507         documentation. Some of the operations on chains and groups were
10508         re-organized.
10509
10510         (create_group): Added a type argument so if the group is enabled,
10511         the setup_group_scheduler knows what to do.
10512         (group_elements): Added a type argument here, too, to be passed on
10513         to create_group.
10514         (group_element_set_enabled): If an unlinked PLAYING element is
10515         added to a bin, we have to create a new group to hold the element,
10516         and this function will be called before the group is added to the
10517         chain. Thus we have a valid case for group->chain==NULL. Instead
10518         of calling chain_group_set_enabled, just set the flag on the group
10519         (the chain's status will be set when the group is added to it).
10520         (gst_opt_scheduler_state_transition, chain_group_set_enabled):
10521         Setup the group scheduler when the group is enabled, not
10522         specifically when an element goes PAUSED->PLAYING. This means
10523         PLAYING elements can be added, linked, and scheduled into a
10524         PLAYING pipeline, as was intended.
10525         (add_to_group): Don't ref the group twice. I don't know when this
10526         double-ref got in here. Removing it has the potential to cause
10527         segfaults if other parts of the scheduler are buggy. If you find
10528         that the scheduler is segfaulting for you, put in an extra ref
10529         here and see if that hacks over the underlying issue. Of course,
10530         then find out what code is unreffing a group it doesn't own...
10531         (create_group): Make the extra refcount floating, and remove it
10532         after adding the element. This means that...
10533         (unref_group): Destroy when the refcount reaches 0, not 1, like
10534         every other refcounted object in the known universe.
10535         (remove_from_group): When a group becomes empty, set it to be not
10536         active, and remove it from its chain. Don't unref it again,
10537         there's no floating reference any more.
10538         (destroy_group): We have to remove the group from the chain in
10539         remove_from_group (rather than here) to break refcounting cycles
10540         (the chain always has a ref on the group). So assert that
10541         group->chain==NULL.
10542         (ref_group_by_count): Removed, it was commented out anyway.
10543         (merge_chains): Use the remove_from_chain and add_to_chain
10544         primitives to do the reparenting, instead of rolling our own
10545         implementation.
10546         (add_to_chain): The first non-disabled group in the chain's group
10547         list will be the entry point for the chain. Because buffers can
10548         accumulate in loop elements' peer bufpens, we preferentially
10549         schedule loop groups before get groups to avoid unnecessary
10550         execution of get-based groups when the bufpens are already full.
10551         (gst_opt_scheduler_schedule_run_queue): Debug fixes.
10552         (get_group_schedule_function): Ditto.
10553         (loop_group_schedule_function): Ditto.
10554         (gst_opt_scheduler_loop_wrapper): Ditto.
10555         (gst_opt_scheduler_iterate): Ditto.
10556
10557         I understand the opt scheduler now, yippee!
10558
10559         * gst/gstpad.c: All throughout, added FIXMEs to look at for 0.9.
10560         (gst_pad_get_name, gst_pad_set_chain_function) 
10561         (gst_pad_set_get_function, gst_pad_set_event_function) 
10562         (gst_pad_set_event_mask_function, gst_pad_get_event_masks) 
10563         (gst_pad_get_event_masks_default, gst_pad_set_convert_function) 
10564         (gst_pad_set_query_function, gst_pad_get_query_types) 
10565         (gst_pad_get_query_types_default) 
10566         (gst_pad_set_internal_link_function) 
10567         (gst_pad_set_formats_function, gst_pad_set_link_function) 
10568         (gst_pad_set_fixate_function, gst_pad_set_getcaps_function) 
10569         (gst_pad_set_bufferalloc_function, gst_pad_unlink) 
10570         (gst_pad_renegotiate, gst_pad_set_parent, gst_pad_get_parent) 
10571         (gst_pad_add_ghost_pad, gst_pad_proxy_getcaps) 
10572         (gst_pad_proxy_pad_link, gst_pad_proxy_fixate) 
10573         (gst_pad_get_pad_template_caps, gst_pad_check_compatibility) 
10574         (gst_pad_get_peer, gst_pad_get_allowed_caps) 
10575         (gst_pad_alloc_buffer, gst_pad_push, gst_pad_pull) 
10576         (gst_pad_selectv, gst_pad_select, gst_pad_template_get_caps) 
10577         (gst_pad_event_default_dispatch, gst_pad_event_default) 
10578         (gst_pad_dispatcher, gst_pad_send_event, gst_pad_convert_default) 
10579         (gst_pad_convert, gst_pad_query_default, gst_pad_query) 
10580         (gst_pad_get_formats_default, gst_pad_get_formats): Better
10581         argument checks, and some doc fixes.
10582
10583         (gst_pad_custom_new_from_template): Um, does anyone
10584         use these functions? Actually make a custom pad instead of a
10585         normal one.
10586         (gst_pad_try_set_caps): Transpose some checks.
10587         (gst_pad_try_set_caps_nonfixed): Same, and use a macro to check if
10588         the pad is in negotiation.
10589         (gst_pad_try_relink_filtered): Use pad_link_prepare.
10590         
10591         * gst/gstelement.c: Remove prototypes also defined in gstclock.h.
10592
10593         * gst/gstelement.h: 
10594         * gst/gstclock.h: Un-deprecate the old clocking API, as discussed
10595         on the list.
10596
10597 2004-02-24  Thomas Vander Stichele  <thomas at apestaart dot org>
10598
10599         * gst/gstbin.c: (gst_bin_add):
10600           add error for not being able to add elements
10601
10602 2004-02-22  Julien MOUTTE <julien@moutte.net>
10603
10604         * gst/gsttag.c: (_gst_tag_initialize): Registering 2 new tags,
10605         audio-codec and video-codec.
10606
10607 2004-02-22  Benjamin Otte  <otte@gnome.org>
10608
10609         reported by: Padraig O'Briain <padraig.obriain@sun.com>
10610
10611         * autogen.sh:
10612           replace test -e with test -x for mkinstalldirs to be more portable.
10613           (fixes #134816)
10614
10615 2004-02-22  Benjamin Otte  <otte@gnome.org>
10616
10617         * gst/gstpad.c:
10618           revert last patch from Andy, it makes gst_pad_can_link_filtered much
10619           too noisy
10620         * gst/gsttag.c: (_gst_tag_initialize):
10621         * gst/gsttag.h:
10622           add GST_TAG_ALBUM_VOLUME_{COUNT,NUMBER}
10623         * libs/gst/control/dparam.c: (gst_dparam_attach):
10624         * libs/gst/control/dparammanager.c: (gst_dpman_attach_dparam):
10625           check that types for attached dparams match
10626
10627 2004-02-22  Thomas Vander Stichele  <thomas at apestaart dot org>
10628
10629         * gst/elements/gstfilesink.c: (gst_filesink_open_file):
10630         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
10631         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_open_file):
10632           fix errors
10633
10634 2004-02-20  Andy Wingo  <wingo@pobox.com>
10635
10636         * gst/gstbin.c:
10637         * gst/gstbuffer.c:
10638         * gst/gstplugin.c:
10639         * gst/registries/gstxmlregistry.c: 
10640         * gst/schedulers/gstoptimalscheduler.c: Debugging tweaks.
10641
10642         * gst/gstelement.c (gst_element_set_scheduler): Debugging fixes.
10643         (gst_element_add_pad): DEBUG->INFO, some fixes.
10644         (gst_element_get_compatible_pad_template): Just see if the
10645         templates' caps intersect, not if one is a strict subset of the
10646         other. This conforms more to what gst_pad_link_intersect() does.
10647         (gst_element_class_add_pad_template): Don't memcpy the pad
10648         template, just ref it.
10649         (gst_element_get_compatible_pad_filtered): Clean up debug messages
10650
10651         * gst/gstpad.c (gst_pad_can_link_filtered): Debug a true result.
10652         (gst_pad_link_filtered): Debug changes.
10653         (gst_pad_link_prepare): New function, consolidated from
10654         can_link_filtered and link_filtered.
10655
10656         * gst/parse/grammar.y (gst_parse_perform_link): Made INFO output
10657         look more like that of the functions in gstelement.c
10658
10659         * gst/gstinfo.c (gst_debug_print_object): Put a space before the
10660         object, and return the empty string if object is NULL.
10661
10662         * gst/parse/parse.l: Remove trailing newlines when calling PRINT.
10663         * gst/parse/grammar.y (YYFPRINTF): Log bison debugging info via
10664         LOG, not DEBUG. We still get flex info on debug.
10665
10666         * gst/registries/gstxmlregistry.c (gst_xml_registry_load): Make
10667         debug string more verbose.
10668         (plugin_times_older_than): DEBUG->LOG.
10669
10670 2004-02-20  Julien MOUTTE <julien@moutte.net>
10671
10672         * gst/gsttag.h: Adding video-codec and audio-codec for demuxers which
10673         will emit found_tag for each stream they demux with the codec.
10674
10675 2004-02-20  Benjamin Otte  <otte@gnome.org>
10676
10677         * gst/gstevent.c: (_gst_event_copy), (_gst_event_free):
10678           copy navigation event correctly. Check freeing tag lists. 
10679         * gst/gstthread.c: (gst_thread_change_state):
10680           don't abort() on state changing mess - it might happen because of
10681           bugs.
10682         * gst/gstvalue.c: (gst_value_set_caps), (gst_value_get_caps):
10683           use boxed functions
10684         * gst/gstvalue.h:
10685           fix GST_VALUE_HOLDS_CAPS
10686
10687 2004-02-19  David Schleef  <ds@schleef.org>
10688
10689         * gst/gstinfo.h:  Copy G_STRFUNC implementation from glib-2.4
10690         and use it for GST_FUNCTION.  (bug #134750)
10691
10692 2004-02-19  Thomas Vander Stichele  <thomas at apestaart dot org>
10693
10694         * po/fr.po:
10695         * po/nl.po:
10696           updating translations
10697
10698 2004-02-19  Thomas Vander Stichele  <thomas at apestaart dot org>
10699
10700         * tools/gst-run.c: (get_candidates), (main): some fixes from jdahlin
10701
10702 2004-02-18  kost@imn.htwk-leipzig.de
10703
10704         reviewed by: David Schleef  <ds@schleef.org>
10705
10706         * docs/libs/gstreamer-libs-sections.txt:  Add missing sections
10707         for libgstcontrol.
10708
10709 2004-02-18  David Schleef  <ds@schleef.org>
10710
10711         * libs/gst/control/dparam.c: (gst_dparam_class_init):
10712         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_class_init),
10713         (gst_dpsmooth_new): Additional fixes to get double dparams working.
10714         * tools/gst-inspect.c: (print_element_info): Support dumping of
10715         double dparam information.
10716
10717 2004-02-17  David Schleef  <ds@schleef.org>
10718
10719         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
10720         Use G_TYPE_STRING in signal prototype instead of G_TYPE_POINTER.
10721         * gst/elements/gsttypefind.c: (gst_type_find_element_class_init):
10722         Use GST_TYPE_CAPS in signal prototype.
10723         * gst/gstcaps.c: (_gst_caps_initialize), (gst_caps_copy_conditional):
10724         Convert GST_TYPE_CAPS to boxed.
10725         * gst/gstelement.c: (gst_element_class_init):
10726         Use GST_TYPE_TAG_LIST in signal prototype.
10727         * gst/gstindex.c: (gst_index_class_init):
10728         * gst/gstindex.h:
10729         Add GST_TYPE_INDEX_ENTRY type.
10730         * gst/gstmarshal.list:
10731         Add necessary marshal types.
10732         * gst/gstpad.c: (gst_real_pad_class_init),
10733         (_gst_real_pad_fixate_accumulator), (gst_pad_link_fixate),
10734         (gst_pad_recover_caps_error):
10735         Use GST_TYPE_CAPS in signal prototypes.  Fix some debugging strings.
10736         * gst/gststructure.c: (_gst_structure_initialize),
10737         (gst_structure_copy), (_gst_structure_copy_conditional):
10738         * gst/gststructure.h:
10739         Convert GST_TYPE_STRUCTURE to boxed.
10740         * gst/gsttag.c: (gst_tag_list_get_type):
10741         * gst/gsttag.h:
10742         Add GST_TYPE_TAG_LIST type.
10743
10744 2004-02-17  Julien MOUTTE  <julien@moutte.net>
10745
10746         * gst/gstpad.c: (gst_pad_try_set_caps): Reverting my change according
10747         to what we agreed with david.
10748         * gst/gstpad.h: adding GST_PAD_IS_NEGOTIATING macro.
10749
10750 2004-02-17  Thomas Vander Stichele  <thomas at apestaart dot org>
10751
10752         * po/nl.po: update translation
10753
10754 2004-02-17  Thomas Vander Stichele  <thomas at apestaart dot org>
10755
10756         * gst/autoplug/gstspider.c: (gst_spider_identity_plug):
10757           throw an error if spider is trying to play a mime type there is
10758           no decoder for
10759         * po/POTFILES.in:
10760           add gst/autoplug/gstspider.c for translation
10761
10762 2004-02-17  Julien MOUTTE  <julien@moutte.net>
10763
10764         * gst/gstpad.c: (gst_pad_try_set_caps): We are nice people. Return 
10765         silently when the pad is negotiating.
10766
10767 2004-02-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10768
10769         * docs/faq/Makefile.am:
10770           add script to run gstreamer uninstalled 
10771         * docs/faq/faq.xml:
10772         * docs/faq/developing.xml:
10773         * docs/faq/gst-uninstalled:
10774           extract script to run gstreamer uninstalled
10775         * docs/manuals.mak:
10776           add EXTRA_SOURCES variable for Makefile.am's to set to
10777           use additional SOURCE files for the doc build
10778
10779 2004-02-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10780
10781         * gst/gstatomic_impl.h: Fedora 2 test package patch for S390
10782
10783 2004-02-15  Julien MOUTTE  <julien@moutte.net>
10784
10785         * gst/gstbin.c: (gst_bin_change_state), (gst_bin_iterate): Fix a big
10786         bug that was breaking pipelines like sinesrc ! { queue ! osssink } when
10787         an error was thrown by osssink. Basically a state change failure for
10788         an element in a different scheduling group was considered as
10789         successful, which means that caps nego was going on and weird stuff
10790         happened. Like I wrote in the comment there, if someone wants to
10791         revert that please drop me a mail explaining why because I really see
10792         no point in keeping that broken behaviour there.
10793         * gst/gstqueue.c: (gst_queue_get): Add a safety check as the queue CAN
10794         be empty, we then return NULL which will trigger a nice error when 
10795         pulling from the pad.
10796
10797 2004-02-13  David Schleef  <ds@schleef.org>
10798
10799         * libs/gst/control/dparam.c: (gst_dparam_class_init),
10800         (gst_dparam_get_property), (gst_dparam_set_property),
10801         (gst_dparam_do_update_default):
10802         * libs/gst/control/dparam.h:
10803         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_class_init),
10804         (gst_dpsmooth_new), (gst_dpsmooth_set_property),
10805         (gst_dpsmooth_get_property), (gst_dpsmooth_value_changed_double),
10806         (gst_dpsmooth_do_update_double):
10807         * libs/gst/control/dparam_smooth.h:
10808         * libs/gst/control/dparammanager.c:
10809         (gst_dpman_inline_direct_update):
10810         Add support for double dparams.
10811
10812 2004-02-13  David Schleef  <ds@schleef.org>
10813
10814         * gst/elements/gstfdsrc.c: (gst_fdsrc_get): Use GST_TIME_TO_TIMEVAL()
10815         * gst/gstclock.h: Avoid using 64-bit % operator (slow!)
10816
10817 2004-02-13  Mattias Wadman  <mattias@sudac.org>
10818
10819         reviewed by: David Schleef  <ds@schleef.org>
10820
10821         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init),
10822         (gst_fdsrc_init), (gst_fdsrc_set_property),
10823         (gst_fdsrc_get_property), (gst_fdsrc_get):
10824         * gst/elements/gstfdsrc.h:  Adds timeout property to fdsrc,
10825         and sends an EOS event if file descriptor reading times out.
10826
10827 2004-02-13  Thomas Vander Stichele  <thomas at apestaart dot org>
10828
10829         * configure.ac:
10830           add calls to AM_CONDITIONAL for subsystems for automake 1.6.x
10831
10832 2004-02-13  Thomas Vander Stichele  <thomas at apestaart dot org>
10833
10834         * configure.ac: pass required libxml version as argument
10835         (bug reported by Christophe Fergeau)
10836
10837 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10838   
10839         * docs/gst/gstreamer-docs.sgml:
10840         * docs/gst/tmpl/gstxml.sgml:
10841         * docs/libs/gstreamer-libs-docs.sgml:
10842           version API docs
10843
10844 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10845
10846         * gst/gstinfo.c:
10847         * gst/gstregistrypool.c: (gst_registry_pool_plugin_filter),
10848         (gst_registry_pool_feature_filter):
10849         * gst/gstthread.c: (gst_thread_class_init):
10850         * gst/gstvalue.c:
10851           add includes exposed by building without libxml
10852         * gst/indexers/Makefile.am:
10853           do not build fileindex when LOADSAVE disabled; we should have
10854           a better libxml check later since fileindex depends on xml, not
10855           LOADSAVE or REGISTRY
10856         * libs/gst/control/Makefile.am:
10857           link with m
10858         * tools/Makefile.am:
10859           fix wrong source code for gst-xmlinspect
10860
10861 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10862
10863         * configure.ac:
10864           fix gcov help output
10865           move calls to and use new GST_CHECK_DISABLE_SUBSYSTEM
10866         * docs/random/release:
10867           some updated releasing notes
10868         * gstreamer.spec.in:
10869           more updates
10870
10871 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10872
10873         * docs/faq/faq.xml:
10874         * docs/manual/manual.xml:
10875         * docs/pwg/pwg.xml:
10876         * docs/pwg/titlepage.xml:
10877           put version in documentation
10878
10879 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10880
10881         * tools/Makefile.am: fix man page installation
10882
10883 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10884
10885         * configure.ac:
10886           don't check for libxml when load/save and registry disabled (#105844)
10887         * gstreamer.spec.in:
10888           sync with fedora candidate spec
10889
10890 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10891
10892         * po/fr.po:
10893         * po/nl.po:
10894           replace multidisksrc with multifilesrc
10895
10896 2004-02-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10897
10898         * po/POTFILES.in:
10899           update to multidisksrc => multifilesrc file renaming (#134145)
10900
10901 2004-02-11  David Schleef  <ds@schleef.org>
10902
10903         * docs/gst/tmpl/gstcaps.sgml:  Fix stuff that mentions GstProps
10904         * docs/gst/tmpl/gstpadtemplate.sgml: same
10905         * docs/gst/tmpl/gstreamer-unused.sgml: Remove GstProps
10906         * gst/gstobject.c: (gst_object_set_name_default): Do the memleak
10907         fixing dance.
10908         * gst/gstutils.c: Remove disabled code that uses GstProps.
10909         * gst/registries/gstxmlregistry.h: same
10910         * docs/random/ds/0.9-suggested-changes: random notes
10911
10912 2004-02-11  kost@imn.htwk-leipzig.de
10913
10914         reviewed by: David Schleef  <ds@schleef.org>
10915
10916         * gst/gstclock.c: (gst_clock_entry_new): fixes structure
10917         initialisation of clock (bug #134128)
10918
10919 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
10920
10921         * configure.ac:
10922         * gst/elements/Makefile.am:
10923         * gst/elements/gstelements.c:
10924         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_base_init),
10925         (gst_multifilesrc_class_init), (gst_multifilesrc_init),
10926         (gst_multifilesrc_set_property), (gst_multifilesrc_get_property),
10927         (gst_multifilesrc_get), (gst_multifilesrc_open_file),
10928         (gst_multifilesrc_close_file), (gst_multifilesrc_change_state):
10929         * gst/elements/gstmultifilesrc.h:
10930           rename multidisksrc to multifilesrc (part of #122200)
10931
10932 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
10933
10934         * docs/manuals.mak:
10935           fix automake complaints
10936         * gst-element-check.m4:
10937           fix unquotedness
10938
10939 2004-02-11  David Schleef  <ds@schleef.org>
10940
10941         * docs/gst/Makefile.am: Call gst_init() in built gstreamer-scan.
10942         * gst/gstatomic_impl.h: Disable sparc implementation.
10943
10944 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
10945
10946         * gst-element-check.m4:
10947           fix underquoted macros as reported by automake 1.8.x (#133800)
10948         * configure.ac:
10949           require gettext 0.11.5 so ulonglong.m4 gets checked out and copied
10950           by autopoint (fixes #132996)
10951
10952 2004-02-10  Andy Wingo  <wingo@pobox.com>
10953
10954         * gst/gstpad.c (gst_pad_custom_new): Add a FIXME, this is a hacky
10955         way to do inheritance.
10956         (gst_pad_get_event_masks, gst_pad_get_event_masks_default) 
10957         (gst_pad_get_query_types, gst_pad_get_query_types_default):
10958         Routine docs.
10959         (gst_pad_set_link_function, gst_pad_set_fixate_function) 
10960         (gst_pad_set_getcaps_function): Doc from Dave's negotation random
10961         doc.
10962         (gst_pad_unlink, gst_pad_is_linked): Docs.
10963         (gst_pad_renegotiate): A brief description of capsnego.
10964         (gst_pad_try_set_caps): Document.
10965         (gst_pad_try_set_caps_nonfixed): Document.
10966         (gst_pad_can_link_filtered, gst_pad_link_filtered): Doc fixes.
10967         (gst_pad_set_parent): Deprecated (although not out of the API).
10968         (gst_pad_get_parent): Deprecated, although many plugins use this.
10969         (gst_pad_add_ghost_pad, gst_pad_remove_ghost_pad): Doc that these
10970         are private and will go away in 0.9.
10971         (gst_pad_perform_negotiate): Doc.
10972         (gst_pad_link_unnegotiate): I think this is meant to be static.
10973         (gst_pad_get_negotiated_caps, gst_pad_get_pad_template_caps) 
10974         (gst_pad_template_get_caps_by_name, gst_pad_check_compatibility) 
10975         (gst_pad_get_peer): Doc updates.
10976         (gst_pad_caps_change_notify): Doc.
10977         (gst_pad_alloc_buffer, gst_pad_push, gst_static_pad_template_get) 
10978         (gst_ghost_pad_new): Doc fixes.
10979
10980         * gst/gstobject.c (gst_object_get_parent, gst_object_unparent) 
10981         (gst_object_check_uniqueness): 
10982
10983         * gst/gstelement.c (gst_element_add_pad) 
10984         (gst_element_add_ghost_pad, gst_element_remove_pad) 
10985         (gst_element_remove_ghost_pad, gst_element_get_pad) 
10986         (gst_element_get_static_pad, gst_element_get_pad_list) 
10987         (gst_element_class_get_pad_template_list) 
10988         (gst_element_class_get_pad_template): Work on the docs.
10989         (gst_element_get_pad_template_list): Uses the class method.
10990         (gst_element_get_compatible_pad_template): Docs, and consolidate
10991         some test conditions. 
10992         (gst_element_get_pad_from_template): New static function.
10993         (gst_element_request_compatible_pad): Docs, and work with
10994         non-request compatible templates. 
10995         (gst_element_get_compatible_pad_filtered): Docs and remove
10996         redundant checks.
10997         (gst_element_get_compatible_pad, gst_element_link_pads_filtered) 
10998         (gst_element_link_filtered, gst_element_link_many) 
10999         (gst_element_link, gst_element_link_pads) 
11000         (gst_element_unlink_many): Docs.
11001
11002 2004-02-05  Andy Wingo  <wingo@pobox.com>
11003
11004         * gst/gstpad.c (_gst_real_pad_fixate_accumulator):
11005         s/pointer/boxed/.
11006
11007         * gst/gstmarshal.list (VOID:BOXED, BOXED:BOXED): New marshallers.
11008
11009         * gst/gstpad.c (gst_real_pad_class_init): Use a BOXED:BOXED
11010         marshaller for ::fixate, and VOID:BOXED for ::caps-nego-failed,
11011         with the type=GST_TYPE_CAPS. This allows language bindings to know
11012         what kind of data they're dealing with.
11013
11014         * gst/gstcaps.c (_gst_caps_value_init): GBoxed values initialize
11015         to NULL when g_value_init is called. GstCaps, which rolls its own
11016         type implementation, now does the same instead of allocating empty
11017         caps.
11018         (_gst_caps_initialize, _gst_caps_collect_value,
11019         _gst_caps_lcopy_value): Provide collect_value and lcopy_value type
11020         table methods. This allows G_VALUE_COLLECT to work.
11021
11022 2004-02-05  Andy Wingo  <wingo@pobox.com>
11023
11024         * configure.ac:
11025         * testsuite/Makefile.am (SUBDIRS): 
11026         * testsuite/ghostpads/Makefile.am: 
11027         * testsuite/ghostpads/ghostpads.c: A new test for ghost pads.
11028
11029         * gst/gstpad.c (gst_pad_add_ghost_pad, gst_pad_remove_ghost_pad):
11030         These two routines are the only ones that set
11031         GST_GPAD_REALPAD(gpad), the ghost pad list, and the ghost pad's
11032         pad template. They should be made static, depending on ABI needs.
11033         (gst_real_pad_dispose): Handle the case of ghost pads without a
11034         parent. Assert after dealing with ghost pads that the ghost pad
11035         list is empty.
11036         (gst_ghost_pad_class_init): New property added, ::real-pad. Can be
11037         set after creation.
11038         (gst_ghost_pad_dispose): Set ::real-pad to NULL.
11039         (gst_ghost_pad_set_property, gst_ghost_pad_get_property): New
11040         functions. set_property will call add_ghost_pad/remove_ghost_pad
11041         as appropriate.
11042         (gst_ghost_pad_new): All the work is offloaded to g_object_new.
11043
11044         * gst/gstelement.c (gst_element_add_pad): Handle ghost pads as well.
11045         (gst_element_add_ghost_pad): Remove code duplicated from _add_pad.
11046         (gst_element_remove_pad): Handle ghost pads as well.
11047         (gst_element_remove_ghost_pad): Deprecated (could be removed,
11048         depending on API-stability needs).
11049
11050 2004-02-05  Andy Wingo  <wingo@pobox.com>
11051
11052         * gst/gstbin.[ch]: (gst_bin_get_by_interface): GTypes are scalars,
11053         of course they're const
11054
11055 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
11056
11057         * tools/Makefile.am:
11058         * tools/gst-feedback:
11059         * tools/gst-feedback-0.7:
11060           make gst-feedback versioned too for consistency
11061
11062 2004-02-11  David Schleef  <ds@schleef.org>
11063
11064         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
11065         (gst_pad_try_set_caps): Fix format strings for GST_PTR_FORMAT.
11066
11067 2004-02-10  Julien MOUTTE <julien@moutte.net>
11068
11069         * gst/gstevent.c: (_gst_event_free): Sometimes a tag event arrives but
11070         the structure does not contain a valid tag list. Adding a safety check
11071         to remove a noisy warning in that case.
11072
11073 2004-02-10  Thomas Vander Stichele  <thomas at apestaart dot org>
11074
11075         * gst/gst.c: fix name to be in line with others
11076
11077 2004-02-09  Julien MOUTTE <julien@moutte.net>
11078
11079         * libs/gst/bytestream/bytestream.c: (gst_bytestream_peek): We should
11080         not shout that loud when len is 0. Just return 0 silently.
11081
11082 2004-02-09  Julien MOUTTE  <julien@moutte.net>
11083
11084         * gst/gstdata.c: (gst_data_ref): Adding a categorized debug on data_ref
11085         because data_unref has one and I prefer the debug to be symetric.
11086         * gst/gstqueue.c: (gst_queue_locked_flush): Fix a huge memleak. Buffers
11087         were refed when added to the queue and unrefed only once when the queue
11088         was flushed. Now the flush handler unref the buffers two times : first
11089         unref for the ref added when pushing in the queue's tail and second
11090         unref to destroy the flushed buffer.
11091
11092 2004-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
11093
11094         * docs/pwg/building-boiler.xml: fix cvs checkout documentation
11095
11096 2004-02-06  David Schleef  <ds@schleef.org>
11097
11098         * docs/random/ds/0.9-suggested-changes: Random ramblings
11099         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap): Cast size_t
11100         to int before printing.
11101         * gst/parse/grammar.y: Fix gcc-2.95 style variadic macros.
11102         * gst/parse/parse.l: same.  See bug #129600
11103
11104 2004-02-06  David Schleef  <ds@schleef.org>
11105
11106         * gst/gstindex.c: (gst_index_add_format), (gst_index_add_id),
11107         (gst_index_add_entry), (gst_index_add_associationv),
11108         (gst_index_add_association): Add gst_index_add_associationv()
11109         and clean up gst_index_add_association(). #127133
11110
11111 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11112
11113         * autogen.sh: check out common with right tag if CVS/Tag exists
11114
11115 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11116
11117         * testsuite/ghostpads/ghostpads.c: (main):
11118           fix testsuite from segfaulting
11119
11120 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11121
11122         * Makefile.am: add release target
11123         * configure.ac: bump nano to 1
11124         * docs/random/release:
11125
11126 2004-02-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11127
11128         * gst/gstcaps.h:
11129         * gst/gstelement.c: (gst_element_base_class_init),
11130         (gst_element_class_set_details), (gst_element_clear_pad_caps):
11131         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
11132         (gst_pad_try_set_caps), (gst_pad_can_link_filtered),
11133         (gst_real_pad_dispose):
11134         * gst/gststructure.c: (gst_structure_free),
11135         (gst_structure_from_string):
11136           put reverted patch back in
11137         * gst/gstelement.c: (gst_element_remove_pad):
11138           free explicit caps if they're set
11139         * gst/gstpad.c: (_gst_pad_default_fixate_func):
11140           copy the structure when fixating
11141
11142 2004-02-05  David Schleef  <ds@schleef.org>
11143
11144         * gst/gstmarshal.list:
11145         * gst/gstpad.c: (gst_real_pad_class_init),
11146         (_gst_real_pad_fixate_accumulator):
11147         Revert POINTER->BOXED change in signal marshaller.
11148
11149 === release 0.7.4 ===
11150                                                                                 
11151 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11152                                                                                 
11153         * NEWS: GStreamer 0.7.4 "Wooden Eels" released
11154         * configure.ac: changed for release
11155
11156 2004-02-05  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
11157
11158         * gstreamer.spec.in:
11159           bump required version of gtk-doc
11160
11161 2004-02-05  Thomas Vander Stichele  <thomas at apestaart dot org>
11162
11163         * gst/gstcaps.h:
11164         * gst/gstelement.c: (gst_element_base_class_init),
11165         (gst_element_class_set_details), (gst_element_clear_pad_caps):
11166         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
11167         (gst_pad_try_set_caps), (gst_pad_can_link_filtered),
11168         (gst_real_pad_dispose):
11169         * gst/gststructure.c: (gst_structure_free),
11170         (gst_structure_from_string):
11171           revert patch that breaks applications, reapply after release
11172           to get this fixed properly
11173
11174 2004-02-05  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11175
11176         * gst/gsttag.c: (_gst_tag_initialize):
11177         * gst/gsttag.h:
11178           remove duplicated field GST_TAG_APPLICATION. It's GST_TAG_ENCODER
11179
11180 2004-02-04  David Schleef  <ds@schleef.org>
11181
11182         Fix some memleaks:
11183         * gst/autoplug/gstspider.c: (gst_spider_request_new_pad),
11184         (gst_spider_plug_from_srcpad):
11185         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link):
11186
11187 2004-02-04  David Schleef  <ds@schleef.org>
11188
11189         * gst/gstelement.c: (gst_element_clear_pad_caps): Make sure we have
11190         a GstRealPad before accessing its structure members.
11191
11192 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11193
11194         * gst/gstclock.c: (gst_clock_init), (gst_clock_set_speed),
11195         (gst_clock_get_speed):
11196         * gst/gstclock.h:
11197           reset padding, remove unused fields
11198
11199 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11200
11201         * gst/autoplug/gstspideridentity.c:
11202         (gst_spider_identity_sink_loop_type_finding):
11203           use get_allowed_caps, not get_caps (fixes #132519)
11204         * gst/elements/gsttypefind.c: (stop_typefinding):
11205           use correct order when sending buffers and seeking
11206
11207 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
11208
11209         * configure.ac:
11210         * gst/gstelement.h:
11211         * gst/gstpad.h:
11212         * gst/gstqueue.h:
11213           upgrade libtool CURRENT, reset padding
11214
11215 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
11216
11217         * configure.ac:
11218           bump to prerelease
11219           put back AM_PROG_LIBTOOL to make libtoolize stop complaining
11220
11221 2004-02-04  David Schleef  <ds@schleef.org>
11222
11223         * docs/random/ds/0.9-suggested-changes: random notes
11224         * gst/elements/gstfakesrc.c: (gst_fakesrc_get_formats),
11225         (gst_fakesrc_get_query_types), (gst_fakesrc_get_event_mask):
11226         Replace GST_PAD_EVENT_MASK_FUNCTION() (et al.) with its
11227         expansion.
11228         * gst/elements/gstfilesink.c: (gst_filesink_get_formats),
11229         (gst_filesink_get_query_types): same
11230         * gst/elements/gstfilesrc.c: (gst_filesrc_get_event_mask),
11231         (gst_filesrc_get_query_types), (gst_filesrc_get_formats): same
11232         * gst/gstcaps.h: deprecate GST_DEBUG_CAPS(), and fix the macro
11233         to use new GST_PTR_FORMAT.
11234         * gst/gstelement.h: deprecate function factory macros
11235         GST_ELEMENT_QUERY_TYPE_FUNCTION(), GST_ELEMENT_EVENT_MASK_FUNCTION().
11236         These are our last variadic macros that can't be replaced with
11237         inlines.  Celebrate!  Also fix a typo in an #ifdef that was
11238         attempting to deprecate gst_element_clock_wait().
11239         * gst/gstevent.h: same
11240         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
11241         (gst_pad_try_set_caps): replace GST_DEBUG_CAPS() with GST_DEBUG()
11242         * gst/gstpad.h: deprecate function factory macros similar to above.
11243
11244 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
11245
11246         * configure.ac:
11247         * tools/Makefile.am:
11248         * tools/gst-run.c: (popt_callback), (hash_print_key),
11249         (find_highest_version), (unmangle_libtool), (get_dir_of_binary),
11250         (get_candidates), (main):
11251           add new source file to generate non-versioned wrapper binaries
11252           for our tools.
11253
11254 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11255
11256         * gst/gstevent.c: (_gst_event_free):
11257           actually break; inside the switch statement
11258         * gst/parse/grammar.y:
11259           fix memleak where GValues weren't unset
11260
11261 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11262
11263         * gst/gststructure.c: (gst_structure_from_string):
11264           fix huge memleak
11265         * gst/elements/gsttypefind.c: (gst_type_find_element_have_type),
11266         (new_entry), (gst_type_find_element_chain):
11267         * gst/gstelement.c: (gst_element_base_class_init),
11268         (gst_element_class_set_details):
11269         * gst/gstpad.c: (gst_pad_can_link_filtered):
11270           fix smaller memleaks
11271         * gst/gstpad.c: (gst_real_pad_dispose):
11272           check that explicit caps are gone
11273         * gst/gststructure.c: (gst_structure_free):
11274           actually free the structure
11275         * gst/gstelement.c: (gst_element_clear_pad_caps):
11276           unset explicit caps
11277
11278 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
11279
11280         * tools/Makefile.am:
11281           use AM_CFLAGS since all the CFLAGS are the same
11282           use AM_LDFAGS
11283
11284 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
11285
11286         * docs/manual/gnome.xml:
11287           expand example a little
11288         * gst/gst.c: (gst_init_with_popt_table),
11289         (gst_init_check_with_popt_table), (init_pre), (init_popt_callback):
11290           make sure popt option displays are done with right textdomain
11291           use GstPoptOption type
11292         * gst/gst.h:
11293           create GstPoptOption type
11294
11295 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
11296
11297         * gst/gsterror.c: (_gst_stream_errors_init):
11298         * gst/gsterror.h:
11299           adding error type for no codec
11300         * po/POTFILES.in:
11301           add gst-inspect
11302         * po/nl.po:
11303           update dutch translation
11304         * tools/gst-inspect.c: (print_element_list), (main):
11305           do proper internationalization
11306         * tools/gst-launch.c: (idle_func):
11307           remove commented out function call
11308
11309 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
11310
11311         * docs/README:
11312           add some error fixing notes
11313         * docs/gst/gstreamer-sections.txt:
11314           remove double entries
11315         * docs/gst/tmpl/gstbin.sgml:
11316         * docs/gst/tmpl/gstclock.sgml:
11317           remove override
11318         * docs/gst/tmpl/gstelement.sgml:
11319         * docs/gst/tmpl/gstindex.sgml:
11320         * docs/gst/tmpl/gstobject.sgml:
11321         * docs/gst/tmpl/gstpadtemplate.sgml:
11322         * docs/gst/tmpl/gstreamer-unused.sgml:
11323         * docs/gst/tmpl/gsttag.sgml:
11324         * docs/gst/tmpl/gstthread.sgml:
11325         * docs/gst/tmpl/gstxml.sgml:
11326         * gst/gsttag.h:
11327           sync header prototypes with c decls
11328         * gst/gsttaginterface.c:
11329           fix doc headers
11330
11331 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11332
11333         * gst/parse/Makefile.am:
11334         * gst/gstobject.h:
11335           get rid of gstmarshal.h dependency. It's not needed.
11336         * gst/gst.h:
11337         * gst/elements/gstfakesink.c:
11338         * gst/elements/gstfakesrc.c:
11339         * gst/elements/gstidentity.c:
11340         * gst/gstbin.c:
11341         * gst/gstelement.c:
11342         * gst/gstindex.c:
11343         * gst/gstobject.c:
11344         * gst/gstpad.c:
11345         * gst/gstthread.c:
11346         * gst/gstxml.c:
11347         * libs/gst/control/dparam.c:
11348         * libs/gst/control/dparammanager.c:
11349           include gstmarshal.h.
11350         Fixes #132045
11351
11352 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11353
11354         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
11355         (gst_filesrc_dispose), (gst_filesrc_free_parent_mmap),
11356         (gst_filesrc_map_region), (gst_filesrc_get_mmap):
11357         * gst/elements/gstfilesrc.h:
11358           don't ref the filesrc when creating mmaped buffers. Don't keep a
11359           list of not-yet-destroyed buffers.
11360         * gst/gstbuffer.h:
11361           Deprecated BST_BUFFER_FREE_FUNC and GST_BUFFER_COPY_FUNC
11362
11363 2004-02-02  Thomas Vander Stichele  <thomas at apestaart dot org>
11364
11365         * gst/gst.c: (init_pre):
11366           remove textdomain
11367
11368 2004-02-02  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11369
11370         * docs/pwg/advanced-events.xml:
11371         * docs/pwg/advanced-scheduling.xml:
11372         * docs/pwg/intro-basics.xml:
11373         * docs/pwg/other-manager.xml:
11374         * docs/pwg/other-nton.xml:
11375         * docs/pwg/other-ntoone.xml:
11376         * docs/pwg/other-oneton.xml:
11377         * docs/pwg/pwg.xml:
11378           All sort of documentation... Forgot what. Point is that I want this
11379           in before I leave. The 'other-*' will be the last section and will
11380           explain issues specific to these type of elements.
11381
11382 2004-02-02  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11383
11384         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
11385         (gst_filesrc_get_read):
11386           set all the values on buffers that we can
11387
11388 2004-02-02  David Schleef  <ds@schleef.org>
11389
11390         Change usage of isblah() to g_ascii_isblah() to be more locale
11391         independent.  (#133076)
11392         * gst/gsturi.c: (gst_uri_protocol_check_internal):
11393         * gst/gstutils.c:
11394         * gst/parse/parse.l:
11395
11396 2004-02-02  Jon Trowbridge  <trow@gnu.org>
11397
11398         reviewed by: David Schleef  <ds@schleef.org>
11399
11400         Fix memory leaks:
11401         * gst/gstcaps.c: (gst_caps_to_string):
11402         * gst/registries/gstxmlregistry.c:
11403         (gst_xml_registry_add_path_list_func),
11404         (gst_xml_registry_parse_padtemplate):
11405
11406 2004-02-02  Thomas Vander Stichele  <thomas at apestaart dot org>
11407
11408         * gst/gstelement.c: (gst_element_default_error):
11409           suffix error messages with period
11410
11411 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
11412
11413         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
11414         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
11415         * gst/gsterror.c: (gst_error_get_message):
11416           Suffix with dots
11417         * po/fr.po:
11418         * po/nl.po:
11419           Update translation files
11420
11421 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
11422
11423         * gst/autoplug/gstspideridentity.c:
11424         (gst_spider_identity_sink_loop_type_finding):
11425         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
11426         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
11427         (gst_filesink_close_file), (gst_filesink_handle_event),
11428         (gst_filesink_chain):
11429         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
11430         (gst_filesrc_get_read), (gst_filesrc_open_file):
11431         * gst/elements/gstidentity.c: (gst_identity_chain):
11432         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
11433         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
11434         (gst_pipefilter_chain), (gst_pipefilter_open_file):
11435         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
11436         * gst/gsterror.c: (_gst_core_errors_init),
11437         (_gst_library_errors_init), (_gst_resource_errors_init),
11438         (_gst_stream_errors_init), (gst_error_get_message):
11439         * gst/gstpad.c: (gst_pad_set_explicit_caps),
11440         (gst_pad_recover_caps_error), (gst_pad_pull):
11441         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
11442         * gst/schedulers/gstbasicscheduler.c:
11443         (gst_basic_scheduler_chainhandler_proxy),
11444         (gst_basic_scheduler_gethandler_proxy),
11445         (gst_basic_scheduler_cothreaded_chain):
11446           Suffix error messages with period.
11447           Use (NULL) instead of NULL
11448
11449 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
11450
11451         * docs/gst/tmpl/gstelement.sgml:
11452         * docs/gst/tmpl/gstxml.sgml:
11453         * gst/gstelement.c: (gst_element_error_full):
11454           add element path to error
11455
11456 2004-01-31  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11457
11458         * docs/random/mimetypes:
11459           update raw int/float info
11460         * gst/gsttag.c: (_gst_tag_initialize):
11461         * gst/gsttag.h:
11462           add GST_TAG_ENCODER
11463
11464 2004-01-30  David Schleef  <ds@schleef.org>
11465
11466         * gst/cothreads.c: Add another fallback if MAP_ANONYMOUS is
11467           missing (#132991)
11468
11469 2004-01-30  Laurent Vivier <Laurent.Vivier@bull.net>
11470
11471         reviewed by Benjamin Otte 
11472           parts of the patch submitted in bug #113913
11473
11474         * configure.ac:
11475           use AC_C_INLINE. Use = instead of == with test
11476         * examples/plugins/example.c:
11477         * gst/autoplug/gstspideridentity.c:
11478         * gst/elements/gstfdsrc.c:
11479         * gst/elements/gstfilesrc.c:
11480         * gst/elements/gstidentity.c:
11481         * gst/elements/gstmultidisksrc.c:
11482         * gst/elements/gststatistics.c:
11483         * gst/gstelement.c:
11484         * gst/gstobject.c:
11485         * gst/gstpad.c:
11486         * gst/gstpipeline.c:
11487         * gst/gstthread.c:
11488           don't end enums with a comma
11489         * gst/gstindex.c: (gst_index_compare_func):
11490           do explicit casting to gint
11491         * gst/gsttrace.c: (gst_trace_text_flush):
11492           #define strsize as a macro
11493
11494 2004-01-30  Thomas Vander Stichele  <thomas at apestaart dot org>
11495
11496         * docs/README:
11497         * docs/gst/gstreamer-docs.sgml:
11498         * docs/gst/gstreamer-sections.txt:
11499         * docs/gst/tmpl/gstelement.sgml:
11500         * docs/gst/tmpl/gsterror.sgml:
11501         * docs/gst/tmpl/gstinterface.sgml:
11502         * docs/gst/tmpl/gstreamer-unused.sgml:
11503         * docs/gst/tmpl/gststructure.sgml:
11504         * docs/gst/tmpl/gsttag.sgml:
11505         * docs/gst/tmpl/gsttaginterface.sgml:
11506         * docs/gst/tmpl/gstvalue.sgml:
11507         make sure all API ends up in the built docs
11508         * gst/gstinterface.c:
11509         * gst/gststructure.c: (gst_structure_id_set_value),
11510         (gst_structure_set_value), (gst_structure_id_get_value):
11511         * gst/gststructure.h:
11512         * gst/gstvalue.h:
11513         sync .h with .c declarations
11514
11515 2004-01-30  Julien Moutte  <julien@moutte.net>
11516
11517         * libs/gst/bytestream/bytestream.c: Reverting my event handling patch.
11518         Ronald will fix riffread.
11519
11520 2004-01-30  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11521
11522         * docs/pwg/advanced-interfaces.xml:
11523           Added tuner interface docs.
11524
11525 2004-01-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11526
11527         * docs/random/mimetypes:
11528           correct Theora information
11529         * gst/gstelement.h:
11530           make GST_ELEMENT_ERROR do a GST_ERROR_OBJECT
11531
11532 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
11533
11534         * gst/gstelement.c: (gst_element_error_full):
11535         * gst/gstelement.h:
11536           GST_ELEMENT_ERROR in enum -> _IN_ERROR
11537
11538 2004-01-29  Julien MOUTTE  <julien@moutte.net>
11539
11540         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
11541         (gst_filesrc_uri_handler_init): Fixing seeking by making FLUSH happen
11542         again and even before DISCONT.
11543         * gst/gstpad.c: (gst_pad_event_default): Remove a unused switch case.
11544         * libs/gst/bytestream/bytestream.c: (gst_bytestream_get_next_buf): Fix
11545         bytestream so that it's not stopping to fill the bytestream if events
11546         different than EOS or DISCONT are received. Instead it process them so
11547         that they go downstream.
11548
11549 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
11550
11551         * docs/gst/tmpl/gstelement.sgml:
11552         * docs/gst/tmpl/gstreamer-unused.sgml:
11553         * docs/gst/tmpl/gstxml.sgml:
11554         * gst/autoplug/gstspideridentity.c:
11555         (gst_spider_identity_sink_loop_type_finding):
11556         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
11557         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
11558         (gst_filesink_close_file), (gst_filesink_handle_event),
11559         (gst_filesink_chain):
11560         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
11561         (gst_filesrc_get_read), (gst_filesrc_open_file):
11562         * gst/elements/gstidentity.c: (gst_identity_chain):
11563         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
11564         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
11565         (gst_pipefilter_chain), (gst_pipefilter_open_file):
11566         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
11567         * gst/gstelement.h:
11568         * gst/gstpad.c: (gst_pad_set_explicit_caps),
11569         (gst_pad_recover_caps_error), (gst_pad_pull):
11570         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
11571         * gst/schedulers/gstbasicscheduler.c:
11572         (gst_basic_scheduler_chainhandler_proxy),
11573         (gst_basic_scheduler_gethandler_proxy),
11574         (gst_basic_scheduler_cothreaded_chain):
11575           gst_element_error -> GST_ELEMENT_ERROR
11576
11577 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
11578
11579         * docs/Makefile.am:
11580         * docs/gst/tmpl/gstelement.sgml:
11581         * docs/gst/tmpl/gstxml.sgml:
11582         * docs/manuals.mak:
11583         * docs/pwg/advanced-request.xml:
11584         * docs/pwg/advanced-scheduling.xml:
11585         * docs/pwg/advanced-tagging.xml:
11586           fix non-validating docbook using CDATA
11587           make sure make check-local gets run first to check if it validates
11588
11589 2004-01-29  Julien MOUTTE <julien@moutte.net>
11590
11591         * docs/pwg/advanced-events.xml: Adding documentation on advanced event
11592         handling (up and downstream).
11593         * docs/pwg/advanced-interfaces.xml: Make it coherent with the
11594         my_filter thing.
11595
11596 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11597
11598         * docs/pwg/advanced-tagging.xml:
11599           Add docs about tag writing.
11600
11601 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11602
11603         * docs/pwg/advanced-tagging.xml:
11604           Add a part about tag reading and application signalling... Tag
11605           writing still needs to be documented.
11606         * gst/elements/gstfilesrc.c: (gst_filesrc_set_location):
11607           We can set file locations in READY, too.
11608
11609 2004-01-29  Julien MOUTTE <julien@moutte.net>
11610
11611         * docs/random/ds/element-checklist: Adding some notes about src
11612         events.
11613
11614 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11615
11616         * docs/random/mimetypes:
11617           Update docs to point to correct elements for various mimetypes, and
11618           some more errors pointed out by Stéphane LOEUILLET (aka LeRoutier)
11619           <stephane.loeuillet@tiscali.fr>.
11620
11621 2004-01-28  David Schleef  <ds@schleef.org>
11622
11623         * docs/pwg/intro-basics.xml: rewrite bufferpool stuff.
11624
11625 2004-01-29  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11626
11627         * docs/random/mimetypes:
11628           update docs for audio/x-raw-float. Add "buffer-frames=0 means
11629           undefined"
11630         * gst/elements/gstfilesrc.c: (gst_filesrc_set_location):
11631           make it only work in NULL.
11632         * gst/gstcaps.c:
11633           don't posion NULL caps
11634         * gst/gstelement.c: (gst_element_set_time):
11635           add debugging statement
11636         * gst/gstelement.c: (gst_element_emit_found_tag),
11637         (gst_element_found_tag_func), (gst_element_found_tags):
11638         * gst/gstelement.h:
11639           These functions take const taglists
11640         * gst/gstpad.c: (gst_pad_proxy_getcaps):
11641           fix memleak
11642         * gst/gstpad.c: (gst_pad_event_default):
11643           make more effort on handling discont and clocks, g_warn if everything
11644           fails
11645         * gst/gststructure.c: (gst_structure_remove_fields),
11646         (gst_structure_remove_fields_valist):
11647         * gst/gststructure.h:
11648           add gst_structure_remove_fields(_valist)
11649         * gst/gsttag.c:
11650           fix doc glitch
11651
11652 2004-01-28  David Schleef  <ds@schleef.org>
11653
11654         * docs/random/ds/element-checklist: Notes about gst_caps_to_string()
11655         * gst/registries/gstxmlregistry.c: (gst_xml_registry_save_caps):
11656         Fix memory leakage of gst_caps_to_string().
11657
11658         Use GST_PTR_FORMAT instead of gst_caps_to_string():
11659         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_sp):
11660         * gst/autoplug/gstspideridentity.c: (spider_find_suggest),
11661         (gst_spider_identity_sink_loop_type_finding):
11662         * gst/elements/gsttypefind.c: (gst_type_find_element_have_type),
11663         (find_suggest):
11664         * gst/gstpad.c: (gst_pad_try_relink_filtered),
11665         (gst_pad_set_explicit_caps):
11666         * gst/parse/grammar.y:
11667
11668 2004-01-28  David Schleef  <ds@schleef.org>
11669
11670         * configure.ac: Add detection for HAVE_PRINTF_EXTENSION and
11671         GST_PRINTF_EXTENSION_FORMAT_DEFINE.
11672         * docs/random/ds/0.9-suggested-changes: Notes from Company.
11673         * gst/gstcaps.c: (gst_caps_to_string): Add comment.
11674         * gst/gstconfig.h.in: Add define for GST_PTR_FORMAT
11675         * gst/gstinfo.c: (_gst_debug_init), (gst_debug_print_object),
11676         (gst_debug_log_default), (_gst_info_printf_extension),
11677         (_gst_info_printf_extension_arginfo):  Add printf extension.
11678         * gst/gstinfo.h: remove G_GNUC_PRINTF, because it doesn't work with %P
11679         * gst/gststructure.c: (gst_structure_to_string),
11680         (_gst_structure_parse_value): Use gst_value_deserialize() and
11681         remove old code.
11682         * gst/gstvalue.c: (gst_value_deserialize_fourcc),
11683         (gst_value_deserialize_boolean), (gst_strtoi),
11684         (gst_value_deserialize_int), (gst_value_deserialize_double),
11685         (gst_value_deserialize_string), (gst_value_deserialize): Implement
11686         a bunch of deserialize functions and gst_value_deserialize.
11687         * gst/gstvalue.h: er, _de_serialize, not unserialize
11688         * testsuite/caps/string-conversions.c: (main): We don't currently
11689         handle (float) in caps, so convert these to (double).
11690         * testsuite/debug/Makefile.am: Add new test for the printf extension
11691         * testsuite/debug/printf_extension.c: (main): same
11692
11693 2004-01-28  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11694
11695         * docs/random/company/time:
11696           Add some docs about clocking and time
11697
11698 2004-01-28  Julien MOUTTE <julien@moutte.net>
11699
11700         * docs/pwg/advanced-interfaces.xml: Adding XOverlay documentation.
11701
11702 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11703
11704         * docs/pwg/advanced-clock.xml:
11705         * docs/pwg/advanced-dparams.xml:
11706         * docs/pwg/advanced-events.xml:
11707         * docs/pwg/advanced-interfaces.xml:
11708         * docs/pwg/advanced-midi.xml:
11709         * docs/pwg/advanced-request.xml:
11710         * docs/pwg/advanced-scheduling.xml:
11711         * docs/pwg/advanced-tagging.xml:
11712         * docs/pwg/advanced-types.xml:
11713         * docs/pwg/appendix-checklist.xml:
11714         * docs/pwg/building-boiler.xml:
11715         * docs/pwg/building-chainfn.xml:
11716         * docs/pwg/building-filterfactory.xml:
11717         * docs/pwg/building-pads.xml:
11718         * docs/pwg/building-props.xml:
11719         * docs/pwg/building-signals.xml:
11720         * docs/pwg/building-state.xml:
11721         * docs/pwg/building-testapp.xml:
11722         * docs/pwg/intro-basics.xml:
11723         * docs/pwg/intro-preface.xml:
11724         * docs/pwg/other-autoplugger.xml:
11725         * docs/pwg/other-sink.xml:
11726         * docs/pwg/other-source.xml:
11727         * docs/pwg/titlepage.xml:
11728           fix up id's
11729
11730 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11731
11732         * docs/95NonPath:
11733         * docs/HACKING:
11734         * docs/README:
11735         * docs/building-the-docs-on-debian:
11736           collect relevant bits of doc info
11737
11738 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11739
11740         * docs/pwg/advanced_tagging.xml:
11741           Half-assed commit so Thomas can re-arrange document IDs here to be
11742           consistent, too.
11743
11744 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11745
11746         * docs/manual/autoplugging.xml:
11747         * docs/manual/bins-api.xml:
11748         * docs/manual/bins.xml:
11749         * docs/manual/buffers-api.xml:
11750         * docs/manual/buffers.xml:
11751         * docs/manual/clocks.xml:
11752         * docs/manual/components.xml:
11753         * docs/manual/cothreads.xml:
11754         * docs/manual/debugging.xml:
11755         * docs/manual/dparams-app.xml:
11756         * docs/manual/dynamic.xml:
11757         * docs/manual/elements-api.xml:
11758         * docs/manual/elements.xml:
11759         * docs/manual/factories.xml:
11760         * docs/manual/gnome.xml:
11761         * docs/manual/goals.xml:
11762         * docs/manual/helloworld.xml:
11763         * docs/manual/helloworld2.xml:
11764         * docs/manual/init-api.xml:
11765         * docs/manual/intro.xml:
11766         * docs/manual/links-api.xml:
11767         * docs/manual/links.xml:
11768         * docs/manual/manual.xml:
11769         * docs/manual/motivation.xml:
11770         * docs/manual/pads-api.xml:
11771         * docs/manual/pads.xml:
11772         * docs/manual/plugins-api.xml:
11773         * docs/manual/plugins.xml:
11774         * docs/manual/programs.xml:
11775         * docs/manual/queues.xml:
11776         * docs/manual/quotes.xml:
11777         * docs/manual/schedulers.xml:
11778         * docs/manual/states-api.xml:
11779         * docs/manual/states.xml:
11780         * docs/manual/threads.xml:
11781         * docs/manual/typedetection.xml:
11782         * docs/manual/xml.xml:
11783           use chapter, part, section or misc as id starts for all bits
11784
11785 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11786
11787         * docs/gst/gstreamer-sections.txt:
11788           Fix up TITLE of the sections
11789
11790 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11791
11792         * docs/pwg/advanced_interfaces.xml:
11793           Add documentation on propertyprobing.
11794         * docs/pwg/advanced_events.xml:
11795         * docs/pwg/advanced_tagging.xml:
11796         * docs/pwg/building_boiler.xml:
11797         * docs/pwg/building_filterfactory.xml:
11798         * docs/pwg/pwg.xml:
11799           Move filterfactory and tagging into their own chapter, add a chapter
11800           on events. all these are empty placeholders that will be filled in
11801           some day.
11802
11803 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11804
11805         * docs/pwg/advanced_interfaces.xml:
11806           Docs for mixer interface. Also a check for website uploading.
11807
11808 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11809
11810         * docs/HACKING:
11811         * docs/Makefile.am:
11812         * docs/faq/Makefile.am:
11813         * docs/gst/Makefile.am:
11814         * docs/gst/tmpl/gstelement.sgml:
11815         * docs/gst/tmpl/gstplugin.sgml:
11816         * docs/gst/tmpl/gstreamer-unused.sgml:
11817         * docs/libs/Makefile.am:
11818         * docs/manual/Makefile.am:
11819         * docs/manuals.mak:
11820         * docs/pwg/Makefile.am:
11821         * docs/upload.mak:
11822           Separate out upload target and make it similar for
11823           both docbook and gtk-doc docs
11824
11825 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11826
11827         * docs/manuals.mak:
11828           Fix upload target to work with freedesktop
11829
11830 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11831
11832         * docs/pwg/advanced_types.xml:
11833           Add notes on creating your own types.
11834         * docs/pwg/building_boiler.xml:
11835         * docs/pwg/building_pads.xml:
11836         * docs/pwg/building_state.xml:
11837           Add some stuff about how to retrieve values from structures, how
11838           that relates to types and change layout slightly again to be almost
11839           perfect.
11840
11841 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11842
11843         * docs/pwg/advanced_dparams.xml:
11844         * docs/pwg/advanced_scheduling.xml:
11845           Change index layout slightly.
11846
11847 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11848
11849         * docs/pwg/advanced_clock.xml:
11850         * docs/pwg/advanced_interfaces.xml:
11851         * docs/pwg/advanced_midi.xml:
11852           General placeholders for now.
11853         * docs/pwg/advanced_request.xml:
11854           Explanation about sometimes and request pads.
11855         * docs/pwg/advanced_scheduling.xml:
11856           Concept of bytestream, loopfunctions and schedulers.
11857         * docs/pwg/building_boiler.xml:
11858           Add something about plugin-init.
11859
11860 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11861
11862         * docs/pwg/building_pads.xml:
11863           Fix broken docbook
11864
11865 2004-01-27  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11866
11867         * docs/pwg/advanced_interfaces.xml:
11868         * docs/pwg/pwg.xml:
11869           Add as a placeholder for future filling-in.
11870         * docs/pwg/basics_autoplugging.xml:
11871         * docs/pwg/basics_buffers.xml:
11872         * docs/pwg/basics_elements.xml:
11873         * docs/pwg/basics_events.xml:
11874         * docs/pwg/basics_plugins.xml:
11875         * docs/pwg/basics_types.xml:
11876           Remove, because unused (this is all in intro_basics.xml).
11877         * docs/pwg/building_signals.xml:
11878           Short intro to signals + reference to GObject docs - we really
11879           shouldn't go into these sort of things to deply because we don't
11880           use them that extensively anyway.
11881         * docs/pwg/building_state.xml:
11882           Explanation of states. Benjamin, please check.
11883         * docs/pwg/building_testapp.xml:
11884           Put everything in one page - putting only a few lines of content
11885           per page doesn't really make sense.
11886
11887           Time to get into the advanced topics. ;).
11888
11889 2004-01-27  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11890
11891         * docs/pwg/advanced_types.xml:
11892           Finish documenting the current state of mimetypes.
11893         * docs/pwg/building_boiler.xml:
11894         * docs/pwg/building_chainfn.xml:
11895         * docs/pwg/building_pads.xml:
11896         * docs/pwg/building_props.xml:
11897         * docs/pwg/building_testapp.xml:
11898           Start documenting the "how to build a simple audio filter" part
11899           of the PWG. Most stuff is ready by now. Stuff remaining: signals,
11900           states and (maybe?) a short introduction to capsnego in the chapter
11901           on pads (building_pads.xml). Capsnego should probably be explained
11902           fully in advanced_capsnego.xml or so.
11903
11904 2004-01-26  David Schleef  <ds@schleef.org>
11905
11906         * gst/gstpad.c: (gst_pad_try_set_caps_nonfixed):
11907         * gst/gstpad.h: Add new function to allow element to (somewhat)
11908         specify non-fixed caps on a pad.
11909         * gst/gstqueue.c: (gst_queue_chain): Remove noisy g_object_notify()
11910         that I added a few weeks ago.
11911
11912 2004-01-26  David Schleef  <ds@schleef.org>
11913
11914         * gst/gstpad.c: (gst_pad_try_set_caps): Revert last change
11915           making try_set_caps() work with non-fixed caps.
11916
11917 2004-01-26  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11918
11919         * docs/pwg/advanced_types.xml:
11920         * docs/pwg/intro_basics.xml:
11921         * docs/pwg/intro_preface.xml:
11922         * docs/pwg/pwg.xml:
11923         * docs/pwg/titlepage.xml:
11924           First try to resurrect the PWG. I'm halfway integrating the mimetypes
11925           in here (docs/random/mimetypes), and will from there on work on both
11926           updating outdated parts and adding missing parts.
11927           That doesn't mean I'll fix it completely, but I'll try at least. ;).
11928
11929 2004-01-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11930
11931         * gst/gsterror.h: reinstate GST_LIBRARY_ERROR_ENCODE until
11932           policy is set
11933
11934 2004-01-26  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11935
11936         * gst/gstelement.h:
11937           remove gst_element_factory_get_version. It doesn't exist anymore.
11938         * gst/gstplugin.c:
11939         * gst/gstplugin.h:
11940           remove gst_plugin_set_name and change gst_plugin_get_longname to
11941           gst_plugin_get_description to match code.
11942         * gst/gsterror.h:
11943           remove GST_LIBRARY_ERROR_ENCODE. It's GST_STREAM_ERROR_ENCODE.
11944         * gst/gstpad.c: (gst_pad_try_set_caps):
11945           make it work with nonfixed caps.
11946           Note that even in the nonfixed case the link function of the pad
11947           that tries to set caps isn't called.
11948
11949 2004-01-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11950
11951         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
11952           fix bug where buffer was not assembled correctly
11953         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_init):
11954           silence by default
11955         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
11956           only seek if there's no more buffers that could work without seeking
11957
11958 2004-01-23  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11959
11960         * gst/gsttag.c: (_gst_tag_initialize):
11961         * gst/gsttag.h:
11962           Add application tag (for encoding/muxing app).
11963
11964 2004-01-23  Thomas Vander Stichele  <thomas at apestaart dot org>
11965
11966         * autogen.sh:
11967           make autopoint force, and libtoolize not copy
11968         * common/m4/as-docbook.m4:
11969           added docbook xml catalog setup check
11970         * common/m4/gst-doc.m4:
11971           use docbook check
11972
11973 2004-01-22  Thomas Vander Stichele  <thomas at apestaart dot org>
11974
11975         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_register):
11976         * gst/gsttag.h:
11977           add GstTagFlag
11978
11979 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
11980
11981         * docs/gst/gstreamer-sections.txt:
11982         * docs/gst/tmpl/gst.sgml:
11983         * docs/gst/tmpl/gstbuffer.sgml:
11984         * docs/gst/tmpl/gstclock.sgml:
11985         * docs/gst/tmpl/gstelement.sgml:
11986         * docs/gst/tmpl/gstreamer-unused.sgml:
11987         * docs/gst/tmpl/gstxml.sgml:
11988           sync latest API changes to docs
11989
11990 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
11991
11992         * gst/gstpluginfeature.c:
11993           fix doc snippet
11994         * tools/gst-inspect.c: (print_element_list):
11995           fix output of typefind
11996           add GPL header
11997         * tools/gst-launch.c:
11998           add GPL header
11999
12000 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12001
12002         * gst/elements/Makefile.am:
12003         * gst/elements/gstelements.c:
12004         * gst/elements/gsttypefindelement.c:
12005         * gst/elements/gsttypefindelement.h:
12006         * po/POTFILES.in:
12007         * po/fr.po:
12008         * po/nl.po:
12009           renamed gsttypefindelement to gsttypefind, conserving CVS history
12010
12011 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12012
12013         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_list_add_valist):
12014         * gst/gsttag.h:
12015           add some tags used in ogg as well
12016           fix _ in replaygain tags
12017
12018 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12019
12020         * gst/gsterror.h:
12021           fix wrong GST_LIBRARY_ERROR_ENCODE addition
12022
12023 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12024
12025         * gst/gstelement.c: (gst_element_error_full):
12026         * gst/gstelement.h:
12027           change _extended to _full
12028
12029 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12030
12031         reviewed by: <delete if not using a buddy>
12032
12033         * docs/gst/tmpl/gst.sgml:
12034         * docs/gst/tmpl/gstbuffer.sgml:
12035         * docs/gst/tmpl/gstclock.sgml:
12036         * docs/gst/tmpl/gstelement.sgml:
12037         * docs/gst/tmpl/gstreamer-unused.sgml:
12038         * docs/gst/tmpl/gstxml.sgml:
12039         * gst/gstelement.c: (gst_element_error_full):
12040         * gst/gstelement.h:
12041
12042 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12043
12044         * gst/gstelement.h: fix _gst_element_error_printf prototype
12045
12046 2004-01-20  David Schleef  <ds@schleef.org>
12047
12048         * gst/gststructure.c: (gst_structure_to_string):
12049         Convert function to use gst_value_serialize().
12050         * gst/gstvalue.c: (gst_value_serialize_list),
12051         (gst_value_serialize_fourcc), (gst_value_serialize_int_range),
12052         (gst_value_serialize_double_range), (gst_value_serialize_boolean),
12053         (gst_value_serialize_int), (gst_value_serialize_double),
12054         (gst_string_wrap), (gst_value_serialize_string),
12055         (gst_value_serialize), (gst_value_deserialize):
12056         * gst/gstvalue.h:
12057         Add implementations for serialize.
12058
12059 2004-01-20  Julien MOUTTE  <julien@moutte.net>
12060
12061         * gst/gsterror.h: xvidenc.c needs GST_LIBRARY_ERROR_ENCODE. Dunno if
12062         we want to keep that one in the future or change xvidenc.c to use 
12063         another error.
12064
12065 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12066
12067         * gst/gstelement.c: (_gst_element_error_printf):
12068         * gst/gstelement.h:
12069           privatise function
12070
12071 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12072
12073         * docs/random/error:
12074           doc explaining error system
12075         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
12076           cleanup
12077
12078 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12079
12080         * gst/gst-i18n-app.h:
12081         * gst/gst-i18n-lib.h:
12082           remove inclusion of config.h
12083         * po/POTFILES.in:
12084         * po/nl.po:
12085           add gst/gstelement.c
12086
12087 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12088
12089         * po/nl.po: updated Dutch translation
12090
12091 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12092
12093         * gst/gsterror.c: (_gst_core_errors_init),
12094         (_gst_library_errors_init), (_gst_resource_errors_init),
12095         (_gst_stream_errors_init):
12096         remove ending punctuation dots
12097
12098 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12099
12100         * gst/elements/gstfilesink.c: (gst_filesink_open_file):
12101         * gst/elements/gstfilesrc.c: (gst_filesrc_get_read):
12102         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
12103         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
12104         (gst_pipefilter_chain), (gst_pipefilter_open_file):
12105         use GST_ERROR_SYSTEM
12106
12107 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12108
12109         * gst/gstelement.c: (gst_element_error_printf),
12110         (gst_element_error_extended):
12111         * gst/gstelement.h:
12112           add a helper printf function so we can have NULL values passed.
12113
12114 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12115
12116         * gst/gstelement.h:
12117           add G_STMT macros to gst_element_error, which isn't strictly
12118           necessary but people tell me to anyway.
12119
12120 2004-01-18  Thomas Vander Stichele  <thomas at apestaart dot org>
12121
12122         * gst/Makefile.am:
12123         * gst/autoplug/gstspideridentity.c:
12124         (gst_spider_identity_sink_loop_type_finding):
12125         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
12126         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
12127         (gst_filesink_close_file), (gst_filesink_handle_event),
12128         (gst_filesink_chain):
12129         * gst/elements/gstfilesrc.c: (gst_filesrc_set_property),
12130         (gst_filesrc_map_region), (gst_filesrc_get_read),
12131         (gst_filesrc_open_file):
12132         * gst/elements/gstidentity.c: (gst_identity_chain):
12133         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
12134         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
12135         (gst_pipefilter_chain), (gst_pipefilter_open_file):
12136         * gst/elements/gsttypefindelement.c: (gst_type_find_element_chain):
12137         * gst/gst.h:
12138         * gst/gst_private.h:
12139         * gst/gstelement.c: (gst_element_class_init),
12140         (gst_element_default_error), (gst_element_error_func),
12141         (gst_element_error_extended):
12142         * gst/gstelement.h:
12143         * gst/gsterror.c: (_gst_core_errors_init),
12144         (_gst_library_errors_init), (_gst_resource_errors_init),
12145         (_gst_stream_errors_init), (gst_error_get_message):
12146         * gst/gsterror.h:
12147         * gst/gstinfo.c: (_gst_debug_init):
12148         * gst/gstmarshal.list:
12149         * gst/gstpad.c: (gst_pad_set_explicit_caps),
12150         (gst_pad_recover_caps_error), (gst_pad_pull):
12151         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
12152         * gst/schedulers/gstbasicscheduler.c:
12153         (gst_basic_scheduler_chainhandler_proxy),
12154         (gst_basic_scheduler_gethandler_proxy),
12155         (gst_basic_scheduler_cothreaded_chain):
12156         * po/POTFILES.in:
12157         * po/fr.po:
12158         * po/nl.po:
12159           change error signal
12160           add error categories
12161
12162 2004-01-18  Jeremy Simon  <jesimon@libertysurf.fr>
12163
12164         * gst/gsttag.c: (_gst_tag_initialize):
12165         * gst/gsttag.h:
12166         Add replaygain tag
12167
12168 2004-01-18  Colin Walters  <walters@verbum.org>
12169
12170         * examples/retag/retag.c: Call gst_init before processing
12171         program args.  Add g_assert to _link_many call.
12172
12173 2004-01-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12174
12175         * gst/gstpad.c: (gst_pad_alloc_buffer):
12176           Return a newly allocated buffer when the pad has no peer.
12177
12178 2004-01-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12179
12180         * gst/gstclock.c: (gst_clock_get_time):
12181           make it compile with gcc 2.95 again.
12182           Patch by Scott Wheeler
12183
12184 2004-01-15  David Schleef  <ds@schleef.org>
12185
12186         * gst/gstcaps.h:
12187         Added gst_caps_is_simple() macro.
12188         * testsuite/caps/caps.c: (test1):
12189         * testsuite/caps/intersect2.c: (main):
12190         * testsuite/caps/intersection.c: (main):
12191         Fixes to make 'make check' work again after removing
12192         gst_caps_is_chained().
12193
12194 2004-01-15  Leif Johnson <leif@ambient.2y.net>
12195
12196         * docs/random/uraeus/gstreamer_and_midi.txt: Rather large edits
12197         and additions to the MIDI document.
12198
12199 2004-01-15  David Schleef  <ds@schleef.org>
12200
12201         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered),
12202         (gst_element_link_pads_filtered): Use GST_PAD_ macros instead
12203         of GST_RPAD_, since we don't know if it's a real or ghost pad.
12204
12205 2004-01-15  David Schleef  <ds@schleef.org>
12206
12207         * gst/gstqueue.c:
12208         * gst/gstqueue.h:
12209         Fix the spelling of "treshold" and make min_threshold actually
12210         affect the queue.
12211
12212 2004-01-15  David Schleef  <ds@schleef.org>
12213
12214         * gst/gstcaps.c:
12215         Add lots of documentation.
12216         * gst/gstcaps.h:
12217         Deprecate a few functions.
12218         * gst/gstpad.c:
12219         Removed use of deprecated functions.
12220
12221 2004-01-15  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12222
12223         * gst/gstpad.c: (gst_pad_is_linked):
12224         * gst/gstpad.h:
12225           implement gst_pad_is_linked
12226         * gst/gstelement.h:
12227           reserve space for initiate_state_change
12228
12229 2004-01-15  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12230
12231         * gst/autoplug/gstspideridentity.c:
12232         (gst_spider_identity_sink_loop_type_finding):
12233           break infinite loop by just returning instead of looping
12234         * gst/gstclock.c: (gst_clock_class_init), (gst_clock_set_property):
12235           set event time difference correctly. Set it to 1 second instead
12236           of 100ms to be more tolerant
12237         * gst/gstelement.c: (gst_element_set_time):
12238           add debugging output
12239
12240 2004-01-14  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12241
12242         * gst/gstqueue.c: (gst_queue_getcaps), (gst_queue_link):
12243           query if buffers are inside the pool, ignore events
12244
12245 2004-01-13  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12246
12247         * gst/gstclock.c: (gst_clock_class_init), (gst_clock_init),
12248         (gst_clock_set_speed), (gst_clock_set_active),
12249         (gst_clock_is_active), (gst_clock_reset),
12250         (gst_clock_handle_discont):
12251         * gst/gstclock.h:
12252           deprecate old interface and disable functions that aren't in use
12253           anymore.
12254         * gst/gstelement.h:
12255         * gst/gstelement.c: (gst_element_get_time), (gst_element_wait),
12256         (gst_element_set_time), (gst_element_adjust_time):
12257           add concept of "element time" and functions to get/set this time.
12258         * gst/gstelement.c: (gst_element_change_state):
12259           update element time correctly.
12260         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered):
12261           This is a debug message, not a g_critical.
12262         * gst/gstpad.c: (gst_pad_event_default):
12263           handle discontinuous events right with element time.
12264         * gst/gstscheduler.c: (gst_scheduler_state_transition):
12265           update to clocking fixes.
12266           set clocks on elements in READY=>PAUSED. The old behaviour caused
12267           a wrong element time on the first element that started playing.
12268         * gst/schedulers/gstbasicscheduler.c:
12269         (gst_basic_scheduler_class_init):
12270         * gst/schedulers/gstoptimalscheduler.c:
12271         (gst_opt_scheduler_class_init):
12272           remove code that just implements the default behaviour.
12273         * gst/elements/gstfakesink.c: (gst_fakesink_chain):
12274           update to use new clocking functions
12275         * testsuite/clock/clock1.c: (gst_clock_debug), (main):
12276         * testsuite/clock/clock2.c: (gst_clock_debug), (main):
12277           update to test new element time.
12278         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_getcaps):
12279           use _get_allowed_caps instead of _get_caps. This catches filtered
12280           caps correctly.
12281         * testsuite/debug/commandline.c:
12282           update for new GST_DEBUG syntax.
12283         * testsuite/threads/Makefile.am:
12284           disable a test that only works sometimes.
12285
12286 2004-01-13  Julien MOUTTE <julien@moutte.net>
12287
12288         * po/LINGUAS: Adding fr.
12289         * po/fr.po: Adding french translation.
12290
12291 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12292
12293         * gst/parse/grammar.y:
12294         * po/POTFILES.in:
12295         * po/nl.po:
12296         * tools/gst-launch.c: (xmllaunch_parse_cmdline), (main):
12297           translate parsing error messages
12298
12299 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12300
12301         * po/POTFILES.in: adding gst-launch
12302         * po/nl.po: updated translation, all 99 strings translated
12303         * tools/gst-launch.c: (idle_func), (xmllaunch_parse_cmdline),
12304         (found_tag), (sigint_handler_sighandler), (play_handler), (main):
12305           fix strings for translation
12306
12307 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12308
12309         * gst/gst.c:
12310           - capitalize beginnings of popt options
12311           - fix strings for translation
12312           - change gst-debug format from =N1=V1:N2=V2 to =N1:V1,N2:V2
12313
12314 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12315
12316         * po/README: add some notes on how to update translations
12317
12318 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12319
12320         * ABOUT-NLS: removed, is autogenerated from autopoint
12321         * autogen.sh: add autopoint stuff
12322         * configure.ac: fix up gettext stuff
12323         * gst/Makefile.am: add i18n headers to noinst_HEADERS
12324         * gst/elements/gsttypefindelement.c: add header include
12325         * gst/gettext.h: add header, copy from system-installed header
12326         * gst/gst-i18n-app.h: to be included by each app having translations
12327         * gst/gst-i18n-lib.h: to be included by each lib having translations
12328         * gst/gst.c: (init_pre): fix up gettext calls
12329         * gst/gst_private.h: remove i18n stuff, moving to separate headers
12330         * po/LINGUAS: the new way to specify translations present
12331         * po/Makefile.in.in: removed from cvs, autogenerated from autopoint
12332         * po/Makevars: the variables filled in for GStreamer
12333         * po/POTFILES.in: added new files with translations
12334         * po/de.po: has new strings
12335         * po/nl.po: readded, has new strings
12336
12337 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12338
12339         * gst/gsttag.c: fix some strings marked for translation
12340
12341 2004-01-13  Iain <iain@prettypeople.org>
12342
12343         * gst/schedulers/gstoptimalscheduler.c (add_to_group): Reference the
12344         group when we add an element to it, cos we unref it when we remove one
12345
12346 2004-01-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12347
12348         * testsuite/debug/commandline.c: (debug_not_reached):
12349         * testsuite/debug/output.c: (check_message):
12350           fix testsuite
12351
12352 2004-01-12  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12353
12354         * examples/cutter/.cvsignore:
12355         * examples/helloworld/.cvsignore:
12356         * examples/launch/.cvsignore:
12357         * examples/manual/.cvsignore:
12358         * examples/mixer/.cvsignore:
12359         * examples/pingpong/.cvsignore:
12360         * examples/plugins/.cvsignore:
12361         * examples/queue/.cvsignore:
12362         * examples/queue2/.cvsignore:
12363         * examples/queue3/.cvsignore:
12364         * examples/queue4/.cvsignore:
12365         * examples/retag/.cvsignore:
12366         * examples/thread/.cvsignore:
12367         * examples/typefind/.cvsignore:
12368         * examples/xml/.cvsignore:
12369         * gst/.cvsignore:
12370         * gst/autoplug/.cvsignore:
12371         * gst/elements/.cvsignore:
12372         * gst/indexers/.cvsignore:
12373         * gst/parse/.cvsignore:
12374         * gst/registries/.cvsignore:
12375         * gst/schedulers/.cvsignore:
12376         * libs/gst/bytestream/.cvsignore:
12377         * libs/gst/control/.cvsignore:
12378         * libs/gst/getbits/.cvsignore:
12379         * tests/.cvsignore:
12380         * tests/bufspeed/.cvsignore:
12381         * tests/instantiate/.cvsignore:
12382         * tests/memchunk/.cvsignore:
12383         * tests/muxing/.cvsignore:
12384         * tests/sched/.cvsignore:
12385         * tests/seeking/.cvsignore:
12386         * tests/threadstate/.cvsignore:
12387         * testsuite/.cvsignore:
12388         * testsuite/caps/.cvsignore:
12389         * testsuite/cleanup/.cvsignore:
12390         * testsuite/dynparams/.cvsignore:
12391         * testsuite/plugin/.cvsignore:
12392         * tools/.cvsignore:
12393           update - this is huge, because it includes *.bb, *.bbg and *.da files
12394           which are generated for gcov.
12395
12396 2004-01-11  David Schleef  <ds@schleef.org>
12397
12398         * gst/gststructure.c: (gst_strtoi), (gst_value_from_string): Add
12399         a function to parse integers in ways that strto[u]l() does not.
12400
12401 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12402
12403         * tools/gst-inspect.c: (print_caps):
12404           improve output of caps a bit
12405
12406 2004-01-11  David Schleef  <ds@schleef.org>
12407
12408         * gst/gstbuffer.c: (gst_buffer_create_sub): Subbuffers should
12409         inherit correct flags (READONLY and DONTKEEP).
12410
12411 2004-01-11  David Schleef  <ds@schleef.org>
12412
12413         * gst/elements/gstfilesrc.c: (gst_filesrc_free_parent_mmap),
12414         (gst_filesrc_map_region):
12415         * gst/gstbuffer.c: (_gst_buffer_initialize),
12416         (_gst_buffer_sub_free), (gst_buffer_default_copy),
12417         (gst_buffer_new), (gst_buffer_create_sub),
12418         (gst_buffer_is_span_fast), (gst_buffer_span):
12419         * gst/gstbuffer.h:
12420         Change GstBuffer private structure element names. (all files)
12421         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
12422         (gst_queue_link):
12423         * gst/gstqueue.h:
12424         Implement getcaps/pad_link functions that handle the case where
12425         there are data in the queue.
12426
12427 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12428
12429         * gst/elements/gstbufferstore.c:
12430           initialize debugging structure correctly
12431         * gst/elements/gsttee.c: (gst_tee_set_property):
12432           g_object_notify when property was changed
12433         * gst/elements/gsttypefindelement.c:
12434         (gst_type_find_element_change_state):
12435           clear caps correctly
12436
12437 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12438
12439         * gst/gstqueue.c: (gst_queue_init):
12440           Use better defaults for when a queue should block. This
12441           gets rid of jerky playback for quite a few files.
12442           It takes more memory.
12443
12444 2004-01-10  Thomas Vander Stichele  <thomas at apestaart dot org>
12445
12446         (gst_xml_registry_parse_padtemplate):
12447           make critical message slightly more useful
12448
12449 2004-01-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12450
12451         * gst/gstinfo.c: (gst_debug_log), (gst_debug_log_valist),
12452         (gst_debug_message_get), (gst_debug_log_default):
12453         * gst/gstinfo.h:
12454           Change gst_debug_log(_valist) to take a const format string.
12455           Change prototype of log function and functions using those to 
12456           take a GstDebugMessage instead of a string that requires using
12457           gst_debug_message_get.
12458
12459 2004-01-08  David Schleef  <ds@schleef.org>
12460
12461         * Makefile.am:
12462         * configure.ac:
12463         Add option --enable-gcov to build GStreamer with -fprofile-arcs
12464         and -ftest-coverage, which allows gcov to show information about
12465         testsuite coverage.
12466
12467 2004-01-08  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12468
12469         * gst/gstutils.h:
12470           Add GST_BOILERPLATE(_FULL), GST_PARENT_CALL and
12471           GST_PARENT_CALL_WITH_DEFAULT
12472         * gst/elements/gstaggregator.c: 
12473         * gst/elements/gstbufferstore.c: 
12474         * gst/elements/gstfakesink.c: 
12475         * gst/elements/gstfakesrc.c: 
12476         * gst/elements/gstfdsink.c: 
12477         * gst/elements/gstfdsrc.c: 
12478         * gst/elements/gstfilesink.c: 
12479         * gst/elements/gstfilesrc.c: 
12480         * gst/elements/gstidentity.c: 
12481         * gst/elements/gstmd5sink.c: 
12482         * gst/elements/gstmultidisksrc.c:
12483         * gst/elements/gstpipefilter.c: 
12484         * gst/elements/gstshaper.c:
12485         * gst/elements/gststatistics.c:
12486         * gst/elements/gsttee.c:
12487         * gst/elements/gsttypefindelement.c:
12488           use them.
12489
12490 2004-01-07  Thomas Vander Stichele  <thomas at apestaart dot org>
12491
12492         * docs/gst/gstreamer-docs.sgml: remove props
12493         * docs/gst/gstreamer-sections.txt: remove props
12494         * docs/gst/tmpl/gst.sgml:
12495         * docs/gst/tmpl/gstbin.sgml:
12496         * docs/gst/tmpl/gstbuffer.sgml:
12497         * docs/gst/tmpl/gstcaps.sgml:
12498         * docs/gst/tmpl/gstclock.sgml:
12499         * docs/gst/tmpl/gstelement.sgml:
12500         * docs/gst/tmpl/gstindex.sgml:
12501         * docs/gst/tmpl/gstobject.sgml:
12502         * docs/gst/tmpl/gstpad.sgml:
12503         * docs/gst/tmpl/gstpadtemplate.sgml:
12504         * docs/gst/tmpl/gstreamer-unused.sgml:
12505         * docs/gst/tmpl/gstthread.sgml:
12506         * docs/gst/tmpl/gstxml.sgml:
12507           sync with code reorganization
12508
12509 2004-01-07  Jan Schmidt  <thaytan@mad.scientist.com>
12510
12511         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered):
12512         Make the 'Could not find compatible pad' message more informative.
12513
12514 2004-01-07  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12515                                                                                 
12516         * gst/elements/gstfilesink.c: (gst_filesink_set_location):
12517           Fix for if we pass NULL as property to location.
12518         * gst/elements/gstpipefilter.c: (gst_pipefilter_init),
12519         (gst_pipefilter_handle_event), (gst_pipefilter_chain):
12520           Fix for instantiate-test (see below).
12521         * gst/gststructure.c: (_gst_structure_parse_value):
12522           Fix compile error on gcc-2.96.
12523         * configure.ac:
12524         * tests/Makefile.am:
12525         * tests/instantiate/Makefile.am:
12526         * tests/instantiate/create.c: (create_all_elements), (main):
12527           Add a test that instantiates all elements. This makes it easy to
12528           track dead code for old API/design (like setting event functions
12529           on sink pads and so on).
12530
12531 2004-01-06  Jan Schmidt  <thaytan@mad.scientist.com>
12532
12533         * gst/gstcaps.c: (gst_caps_append_structure):
12534           Move the poisoning to allow a NULL structure
12535         * gst/gstevent.c: (_gst_event_free):
12536           When freeing a navigation event, free the structure
12537           also
12538
12539 2004-01-04  David Schleef  <ds@schleef.org>
12540
12541         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_request_new_pad):
12542         Remove usage of gst_pad_proxy_fixate.
12543         * gst/gstcaps.c: (gst_caps_append), (gst_caps_append_structure),
12544         (gst_caps_split_one), (gst_caps_replace):
12545         Add poisoning code.
12546         * gst/gstmarshal.list:
12547         Add pointer__pointer for fixate signal
12548         * gst/gstpad.c: (gst_real_pad_class_init),
12549         (_gst_real_pad_fixate_accumulator), (gst_pad_link_fixate),
12550         (_gst_pad_default_fixate_func), (gst_pad_proxy_fixate),
12551         (gst_pad_set_explicit_caps), (gst_pad_template_new):
12552         Add poisoning code. Add fixate signal on RealPad. Change
12553         set_explicit_caps() to take const GstCaps, like try_set_caps().
12554         * gst/gstpad.h:
12555         * testsuite/caps/Makefile.am:
12556         * testsuite/caps/app_fixate.c: Add a test for the fixate signal
12557
12558 2004-01-03  David Schleef  <ds@schleef.org>
12559
12560         * gst/elements/gsttypefindelement.c:
12561         (gst_type_find_element_have_type), (gst_type_find_element_init):
12562         Use gst_pad_use_explicit_caps for src pad.
12563         * gst/gstpad.c: (gst_pad_try_set_caps):  Check that link exists
12564         before using it.
12565
12566 2004-01-03  David Schleef  <ds@schleef.org>
12567
12568         * gst/gstelement.c: (gst_element_link_pads_filtered),
12569         (gst_element_negotiate_pads): Fix to allow DELAYED to indicate
12570         that linking was successful.
12571         * gst/gstpad.c: (gst_pad_link_free),
12572         (gst_pad_link_call_link_functions), (gst_pad_link_negotiate),
12573         (gst_pad_link_try), (gst_pad_link_unnegotiate),
12574         (gst_pad_unnegotiate), (gst_pad_set_explicit_caps): Pass
12575         GstPadLinkReturn correctly between functions, and don't fail
12576         when DELAYED is used (DELAYED is very important).  Better
12577         cleanup on unlinking and unnegotiation.  Should fix some spider
12578         bugs.
12579
12580 2004-01-02  David Schleef  <ds@schleef.org>
12581
12582         * gst/gstelement.c: (gst_element_class_init),
12583         (gst_element_base_class_init): ->padtemplates should be cleared
12584         in base_init, since we need to have a fresh list for every
12585         class.  (Alternately, we chould copy the list and share the
12586         actual pad templates (not the list), but that would require
12587         changing every plugin to move pad template registration from
12588         base_init to class_init.)
12589
12590 2004-01-03  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12591
12592         * gst/gstelement.c: (gst_element_class_add_pad_template):
12593           Refuse registering a pad template if another pad template
12594           with the same name already exists (#114715).
12595
12596 2004-01-02  David Schleef  <ds@schleef.org>
12597
12598         * gst/gstcaps.c: (_gst_structure_is_equal_foreach),
12599         (gst_caps_is_equal_fixed): Add new function.
12600         * gst/gstcaps.h: ditto.
12601         * gst/gstpad.c: (gst_real_pad_class_init),
12602         (gst_pad_link_call_link_functions), (gst_pad_try_set_caps),
12603         (gst_pad_set_explicit_caps), (gst_pad_get_caps):  In try_set_caps,
12604         check new caps against existing caps -- if they're the same, return
12605         OK without renegotiating.  caps-nego-failed signal fixed so that
12606         the marshaller isn't VOID__OBJECT.  Also changed to G_TYPE_POINTER
12607         to save an extra caps copy.  Don't complete negotiation if a pad
12608         link function returns DELAYED.
12609
12610 2004-01-02  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12611
12612         * gst/gstpad.c: (gst_pad_try_relink_filtered):
12613           Fix wrong g_return_if_fail
12614
12615 2004-01-03  Jan Schmidt  <thaytan@mad.scientist.com>
12616
12617         * gst/gstbin.c: (gst_bin_class_init):
12618         Change the marshalling of element_added/element_removed
12619         to use gst_marshal_VOID__OBJECT, since gst_marshal_VOID__POINTER 
12620         complains that GST_TYPE_ELEMENT is not G_TYPE_POINTER
12621
12622 2004-01-01  David Schleef  <ds@schleef.org>
12623
12624         * gst/gstpad.c: (gst_pad_set_explicit_caps),
12625         (gst_pad_explicit_getcaps), (gst_pad_explicit_link),
12626         (gst_pad_use_explicit_caps):
12627         * gst/gstpad.h:
12628         Add new functions.  gst_pad_use_explicit_caps() sets up a pad
12629         to use an internal getcaps and link fuction so that negotiation
12630         always results in the explicitly set caps.
12631         gst_pad_set_explicit_caps() sets the explicit caps.  These functions
12632         are particularly useful for decoders.
12633
12634 2003-12-31  David Schleef  <ds@schleef.org>
12635
12636         * gst/elements/gstidentity.c: (gst_identity_class_init),
12637         (gst_identity_init), (gst_identity_chain),
12638         (gst_identity_set_property), (gst_identity_get_property):
12639         * gst/elements/gstidentity.h:
12640         * gst/gstqueue.c: (gst_queue_init):
12641           Negotiation fixes.
12642
12643 2003-12-31  David Schleef  <ds@schleef.org>
12644
12645         * gst/gstcaps.c: (gst_caps_intersect),
12646         (_gst_caps_normalize_foreach), (gst_caps_normalize):
12647           Implement gst_caps_normalize().
12648         * testsuite/caps/normalisation.c: (main):
12649           Add an additional test
12650
12651 2003-12-31  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12652
12653         * gst/gstqueue.c: (gst_queue_init):
12654           use gst_pad_proxy_getcaps()
12655
12656 2003-12-31  David Schleef  <ds@schleef.org>
12657
12658         * gst/elements/gstshaper.c: (gst_shaper_link):
12659         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_request_new_pad):
12660         * gst/gstqueue.c: (gst_queue_link):
12661           Negotiation fixes.
12662
12663 2003-12-31  David Schleef  <ds@schleef.org>
12664
12665         * gst/gstpad.c: (gst_pad_proxy_pad_link), (gst_pad_proxy_fixate):
12666         * gst/gstpad.h: Add functions that are useful as default pad
12667         link and fixate functions for elements.
12668
12669 2003-12-30  David Schleef  <ds@schleef.org>
12670
12671         * gst/gstpad.c: (gst_pad_link_try):
12672           Fix segfault when attempting to return to old caps
12673
12674 2003-12-29  David Schleef  <ds@schleef.org>
12675
12676         * gst/gstcaps.c: (gst_caps_normalize), (simplify_foreach),
12677         (gst_caps_structure_simplify), (gst_caps_simplify):
12678         * gst/gstcaps.h:
12679           Add simplify function
12680         * gst/gstpad.c: (gst_pad_link_try), (gst_pad_try_set_caps),
12681         (gst_pad_perform_negotiate), (gst_pad_is_negotiated):
12682         * gst/gstpad.h:
12683           Copy over srcnotify, sinknotify when calling old pad_link
12684           functions.  Add new is_negotiated() function.
12685         * gst/gststructure.c: (gst_structure_copy):
12686           Fix an incredibly stupid bug that should have been noticed
12687           weeks ago.  _copy() returned the argument, not the new copy.
12688
12689 2003-12-27  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12690
12691         * gst/gstcaps.c: (gst_caps_append):
12692           add sanity checks
12693         * gst/gstcaps.h: (gst_caps_debug):
12694           remove, it doesn't exist anymore.
12695         * gst/gstelement.c: (gst_element_threadsafe_properties_pre_run),
12696         (gst_element_threadsafe_properties_post_run):
12697           make debugging messages not clutter up THREAD debug category
12698         (gst_element_negotiate_pads), (gst_element_clear_pad_caps),
12699         (gst_element_change_state):
12700           update to new caps API
12701         * gst/gstinterface.c: (gst_implements_interface_cast):
12702           don't put vital code in g_return_if_fail
12703         * gst/gstpad.c: (gst_pad_link_try), (gst_pad_try_set_caps), 
12704         (gst_pad_link_filtered):
12705           add pst_pad_try_link and use it.
12706         (gst_pad_perform_negotiate), (gst_pad_renegotiate):
12707           implement correctly, deprecate first one.
12708         (gst_pad_link_unnegotiate), (gst_pad_unnegotiate):
12709           add and implement.
12710         (gst_pad_try_relink_filtered), (gst_pad_relink_filtered):
12711           implement.
12712         (gst_pad_get_negotiated_caps):
12713           add and implement. Make GST_PAD_CAPS call this function.
12714         (gst_pad_get_caps):
12715           remove unneeded check..
12716         (gst_pad_recover_caps_error):
12717           disable, always return FALSE.
12718         (gst_real_pad_dispose):
12719           don't free caps and appfilter anymore, they're unused.
12720         * gst/gstpad.h:
12721           Reflect changes mentioned above.
12722         * gst/gstsystemclock.c: (gst_system_clock_wait):
12723           Make 'clock is way behind' a debugging message.
12724         * gst/gstthread.c: (gst_thread_change_state):
12725           Fix debugging message
12726
12727 2003-12-25  Thomas Vander Stichele  <thomas at apestaart dot org>
12728
12729         * gst/gstinfo.h:
12730           fix GST_DEBUG_CATEGORY_INIT gtk-doc description
12731         * docs/gst/tmpl/gstreamer-unused.sgml:
12732           removed all traces of cvs conflicts
12733
12734 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
12735
12736         * configure.ac:
12737         * gst/schedulers/cothreads_compat.h:
12738         * libs/Makefile.am:
12739           remove last instances of wingo cothread usage
12740
12741 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
12742
12743         * gst/gstplugin.c:
12744         * gst/gstversion.h.in:
12745         * gst/parse/grammar.y:
12746           change comment block from /** to /* when not gtk-doc comments
12747
12748 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
12749
12750         * gst/gst.c: whitespace and doc style fixes
12751
12752 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
12753
12754         * gst/gstformat.h: remove trailing whitespace from enum for gtk-doc
12755
12756 2003-12-24  Colin Walters  <walters@verbum.org>
12757
12758         * gst/elements/gsttypefindelement.c:
12759           gst/elements/gsttypefindelement.h: Make GstCaps parameter const.
12760           Copy caps parameter. Use _POINTER to marshal caps instead of _BOXED.
12761           Don't double-free caps.
12762
12763 2003-12-23  David Schleef  <ds@schleef.org>
12764
12765         * gst/gstelement.c, gst/gstpad.c, gst/parse/grammar.y,
12766           gst/gstcaps.c, gst/autoplug/gstspideridentity.c:
12767           Many little fixes and additions of debug statements to
12768           get rhythmbox working.
12769
12770 2003-12-23  Colin Walters  <walters@verbum.org>
12771
12772         * gst/autoplug/gstspideridentity.c (gst_spider_identity_sink_loop_type_finding):
12773         Use GST_PAD_LINK_SUCCESSFUL.
12774
12775 2003-12-23  David Schleef  <ds@schleef.org>
12776
12777         * gst/elements/gstaggregator.c:
12778         * gst/elements/gsttee.c:
12779           Use gst_pad_proxy_getcaps().
12780         * gst/gstpad.c:
12781         * gst/gstpad.h:
12782           Add gst_pad_proxy_getcaps(), which filter elements can use
12783           as a generic getcaps implementation.
12784           Fix gst_pad_get_allowed_caps().  It just wasn't doing what
12785           was advertised.
12786
12787 2003-12-23  David Schleef  <ds@schleef.org>
12788
12789         * gst/gstpad.c:
12790           Rearrange/rewrite much of the pad negotiation code, since it
12791           resembled pasta.  This actually changes the way some
12792           negotiation works, since the previous code was inconsistent
12793           depending on how it was invoked.  Add (internal) structure
12794           GstPadLink, which is used to hold some information (more in
12795           the future) about the link between two pads.  Fixes a number
12796           of bugs, including random lossage of filter caps when the
12797           initial negotiation is delayed.  A few functions are still
12798           unimplemented.
12799         * gst/gstpad.h:
12800           Add GST_PAD_LINK_{SUCESSFUL|FAILED}() macros.  Please use
12801           these when testing GstPadLinkReturn values instead of comparing
12802           directly.
12803
12804 2003-12-23  David Schleef  <ds@schleef.org>
12805
12806         * gst/gstvalue.c: 
12807         * gst/gstvalue.h:
12808           Rearrange lots of code.  Change registration of compare function
12809           into registration of compare/serialize/deserialize functions.
12810           Doesn't include implementation of gst_value_[de]serialize(),
12811           but that should be easy.
12812
12813 2003-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
12814
12815         * docs/gst/gstreamer-sections.txt:
12816         * docs/gst/tmpl/gstprops.sgml: removed
12817         * docs/gst/tmpl/gstreamer-bufferpool.sgml: removed
12818           David removed props and caps code, so let's remove their docs as well.
12819           Removed all no longer existing symbols from gstreamer-sections.txt
12820           
12821 2003-12-22  Colin Walters  <walters@verbum.org>
12822
12823         * gst/gsttaginterface.c, gst/gsttaginterface.h,
12824           gst/gsttag.c, gst/gsttag.h:  Add interface to setting GValues
12825           of tags directly.
12826
12827 2003-12-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12828
12829         * gst/elements/gstelements.c:
12830           Set ranks of elements to NONE, so the autoplugger doesn't use them.
12831         * gst/elements/gstshaper.c: (gst_shaper_getcaps):
12832           Fix proxying to new CAPS stuff. Don't call get_allowed_caps but
12833           gst_caps (peer).
12834
12835 2003-12-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12836
12837         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_caps_intersect):
12838         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link),
12839         (gst_spider_identity_getcaps), (gst_spider_identity_change_state),
12840         (gst_spider_identity_sink_loop_type_finding):
12841         * gst/autoplug/gstspideridentity.h:
12842           Fix autoplugging in spider element, so it works with new caps.
12843           This was mainly caused by identifying empty caps incorrectly.
12844
12845 2003-12-22  David Schleef  <ds@schleef.org>
12846
12847         * gststructure.c, gstvalue.c, gstvalue.h: Add
12848           gst_value_init_and_copy() and use it, to avoid silly mistakes in
12849           using g_value_copy()
12850
12851 2003-12-21  David Schleef  <ds@schleef.org>
12852
12853         * many, many files: Merge CAPS branch.  This includes:
12854           - implemention of GstValue and several GstValue types
12855           - implemention of GstStructure
12856           - entire rewrite of GstCaps
12857           - removal of GstProps
12858           - many changes to GstPad to compensate for new caps paradigm
12859           - removal of GstBufferpool
12860         * gst/Makefile.am, gst/gst.h, gst/gstpad.h, gst/gsttypefind.h,
12861         gstvalue.h, gst/gstcaps[2]*.[ch]:
12862           - rename gstcaps2.[ch] to gstcaps.[ch]
12863
12864 2003-12-21  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12865
12866         * gst/gstqueue.c: (gst_queue_handle_pending_events),
12867         (gst_queue_chain), (gst_queue_handle_src_event):
12868           implement timeout for sending events. Workaround for if the
12869           pipeline on this queue is not passing any data.
12870
12871 2003-12-21  Ronald Bultje <rbultje@ronald.bitfreak.net>
12872                                                                                 
12873         * ChangeLog: moved to gstreamer/docs/random/old/ChangeLog.gstreamer
12874         * moved CVS to freedesktop.org
12875