gst/base/gstbasesink.c: Refcounting fixes.
[platform/upstream/gstreamer.git] / ChangeLog
1 2005-07-18  Wim Taymans  <wim@fluendo.com>
2
3         * gst/base/gstbasesink.c: (gst_base_sink_pad_getcaps),
4         (gst_base_sink_pad_setcaps), (gst_base_sink_pad_buffer_alloc),
5         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_object),
6         (gst_base_sink_event), (gst_base_sink_do_sync),
7         (gst_base_sink_chain), (gst_base_sink_loop),
8         (gst_base_sink_deactivate), (gst_base_sink_activate_push),
9         (gst_base_sink_activate_pull), (gst_base_sink_change_state):
10         Refcounting fixes.
11         Fix logic for returning ASYNC when not prerolled.
12
13 2005-07-18  Wim Taymans  <wim@fluendo.com>
14
15         * gst/gstqueue.c: (gst_queue_handle_sink_event):
16         Fix nasty refcount bug.
17
18 2005-07-16 Philippe Khalaf <burger@speedy.org>
19         * gst/elements/gstfdsrc.c:
20         * gst/elements/gstfdsrc.h:
21         * gst/elements/gstelements.c:
22         * gst/elements/Makefile.am:
23         Ported fdsrc to 0.9.
24
25 2005-07-16  Wim Taymans  <wim@fluendo.com>
26
27         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
28         (gst_base_sink_do_sync):
29         Fix compile error.
30
31 2005-07-16  Wim Taymans  <wim@fluendo.com>
32
33         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
34         (gst_base_sink_event), (gst_base_sink_get_times),
35         (gst_base_sink_do_sync), (gst_base_sink_change_state):
36         * gst/base/gstbasesink.h:
37         Store and use discont values when syncing buffers as described
38         in design docs.
39         
40         * gst/base/gstbasesrc.c: (gst_base_src_send_discont),
41         (gst_base_src_do_seek), (gst_base_src_loop), (gst_base_src_start),
42         (gst_base_src_activate_push):
43         Push discont event when starting.
44
45         * gst/elements/gstidentity.c: (gst_identity_transform):
46         Small cleanups.
47
48         * gst/gstbin.c: (gst_bin_change_state):
49         Small cleanups in base_time  distribution.
50
51         * gst/gstelement.c: (gst_element_set_base_time),
52         (gst_element_get_base_time), (gst_element_change_state):
53         * gst/gstelement.h:
54         Added methods for the base_time of the element.
55         Some MT fixes.
56
57         * gst/gstpipeline.c: (gst_pipeline_send_event),
58         (gst_pipeline_change_state), (gst_pipeline_set_new_stream_time),
59         (gst_pipeline_get_last_stream_time):
60         * gst/gstpipeline.h:
61         MT fixes.
62         Handle seeking as described in design doc, remove stream_time
63         hack.
64         Cleanups clock and stream_time selection code. Added accessors
65         for the stream_time.
66         
67
68 2005-07-16  Andy Wingo  <wingo@pobox.com>
69
70         * gst/gsterror.c (_gst_core_errors_init): Use the magic word..
71
72 2005-07-16  Wim Taymans  <wim@fluendo.com>
73
74         * check/gst/gstbin.c: (GST_START_TEST):
75         Make elements silent as the deep_notify refs the
76         parent, which might make the test fail.
77
78         * gst/gstghostpad.c: (gst_ghost_pad_do_activate_push):
79         Don't hold the lock for too long.
80
81 2005-07-16  Tim-Philipp Müller  <tim at centricular dot net>
82
83         * gst/base/gstbasesrc.c: (gst_base_src_default_negotiate):
84           Don't unref the caps we passed to gst_caps_make_writable() after
85           passing them. gst_caps_make_writable() will do that for us.
86
87 2005-07-15  Andy Wingo  <wingo@pobox.com>
88
89         * gst/gstcaps.h (gst_caps_is_simple): Removed deprecated macro
90         (#157311).
91
92         * gst/elements/gstidentity.c (marshal_VOID__MINIOBJECT): Write our
93         own marshalling function for the handoff signal. Properly type the
94         buffer as a buffer. Fixes some warnings. Should do a more general
95         solution.
96         (gst_identity_class_init): Plug into the right marshaller.
97
98 2005-07-15  Wim Taymans  <wim@fluendo.com>
99
100         * docs/design/part-TODO.txt:
101         * docs/design/part-clocks.txt:
102         * docs/design/part-element-sink.txt:
103         * docs/design/part-events.txt:
104         * docs/design/part-gstpipeline.txt:
105         Updated docs, mostly DISCONT related.
106
107 2005-07-15  Tim-Philipp Müller  <tim at centricular dot net>
108
109         * docs/pwg/building-pads.xml:
110           s/GST_PAD_LINK_REFUSED/FALSE/ in gst_my_filter_setcaps()
111
112 2005-07-15  Andy Wingo  <wingo@pobox.com>
113
114         * tools/gst-typefind.c: Update, add copyright block.
115
116         * gst/base/gstbasesrc.c (gst_base_src_default_negotiate):
117         Normalize and truncate caps before fixation.
118
119         * gst/gstcaps.h:
120         * gst/gstcaps.c (gst_caps_truncate): New function, destructively
121         discards all but the first structure from its argument.
122
123 2005-07-15  Wim Taymans  <wim@fluendo.com>
124
125         * gst/base/gstbasetransform.c: (gst_base_transform_init),
126         (gst_base_transform_transform_caps), (gst_base_transform_getcaps),
127         (gst_base_transform_configure_caps), (gst_base_transform_setcaps),
128         (gst_base_transform_get_size), (gst_base_transform_buffer_alloc),
129         (gst_base_transform_handle_buffer), (gst_base_transform_getrange),
130         (gst_base_transform_chain), (gst_base_transform_change_state),
131         (gst_base_transform_set_passthrough),
132         (gst_base_transform_is_passthrough):
133         * gst/base/gstbasetransform.h:
134         Make passthrough work using the bufferpools.
135         Changed API a bit, subclasses have to write into a buffer
136         provided by the base class.
137         More debug info in nego functions.
138         
139         * gst/elements/gstidentity.c: (gst_identity_init),
140         (gst_identity_transform):
141         Port to new base class.
142
143 2005-07-15  Wim Taymans  <wim@fluendo.com>
144
145         * gst/gstmessage.c: (gst_message_new_state_changed):
146         * tools/gst-launch.c: (event_loop), (main):
147         Totally dump messages in -launch with the -m option.
148         Fix message name for State messages,
149
150 2005-07-14  Wim Taymans  <wim@fluendo.com>
151
152         * gst/base/gstbasesrc.c: (gst_base_src_loop):
153         Post error messages on errors.
154
155 2005-07-14  Wim Taymans  <wim@fluendo.com>
156
157         * gst/gstcaps.c: (gst_caps_do_simplify):
158         Remove debug info.
159
160         * gst/gsterror.h:
161         Define error for stream stopped.
162
163         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
164         (gst_proxy_pad_do_chain), (gst_proxy_pad_do_getrange):
165         Do proper return values.
166
167         * gst/gstpad.c: (gst_pad_get_caps_unlocked), (gst_pad_accept_caps),
168         (gst_pad_set_caps), (gst_pad_chain), (gst_pad_push),
169         (gst_pad_get_range):
170         Better return values.
171
172         * gst/gstpad.h:
173         Reorganise return values, add macro to check for fatal errors.
174
175         * gst/gstqueue.c: (gst_queue_chain):
176         Return proper GstFlowReturn values,
177
178 2005-07-14  Thomas Vander Stichele  <thomas at apestaart dot org>
179
180         * docs/gst/gstreamer-sections.txt:
181         * docs/gst/gstreamer.types:
182         * docs/gst/tmpl/gst.sgml:
183         * docs/gst/tmpl/gstbasesink.sgml:
184         * docs/gst/tmpl/gstbasesrc.sgml:
185         * docs/gst/tmpl/gstbasetransform.sgml:
186         * docs/gst/tmpl/gstbin.sgml:
187         * docs/gst/tmpl/gstbuffer.sgml:
188         * docs/gst/tmpl/gstcaps.sgml:
189         * docs/gst/tmpl/gstclock.sgml:
190         * docs/gst/tmpl/gstcompat.sgml:
191         * docs/gst/tmpl/gstconfig.sgml:
192         * docs/gst/tmpl/gstelement.sgml:
193         * docs/gst/tmpl/gstelementdetails.sgml:
194         * docs/gst/tmpl/gstelementfactory.sgml:
195         * docs/gst/tmpl/gstenumtypes.sgml:
196         * docs/gst/tmpl/gsterror.sgml:
197         * docs/gst/tmpl/gstevent.sgml:
198         * docs/gst/tmpl/gstfakesink.sgml:
199         * docs/gst/tmpl/gstfakesrc.sgml:
200         * docs/gst/tmpl/gstfilesink.sgml:
201         * docs/gst/tmpl/gstfilesrc.sgml:
202         * docs/gst/tmpl/gstfilter.sgml:
203         * docs/gst/tmpl/gstformat.sgml:
204         * docs/gst/tmpl/gstghostpad.sgml:
205         * docs/gst/tmpl/gstimplementsinterface.sgml:
206         * docs/gst/tmpl/gstindex.sgml:
207         * docs/gst/tmpl/gstindexfactory.sgml:
208         * docs/gst/tmpl/gstinfo.sgml:
209         * docs/gst/tmpl/gstiterator.sgml:
210         * docs/gst/tmpl/gstmacros.sgml:
211         * docs/gst/tmpl/gstmemchunk.sgml:
212         * docs/gst/tmpl/gstminiobject.sgml:
213         * docs/gst/tmpl/gstobject.sgml:
214         * docs/gst/tmpl/gstpad.sgml:
215         * docs/gst/tmpl/gstpadtemplate.sgml:
216         * docs/gst/tmpl/gstparse.sgml:
217         * docs/gst/tmpl/gstpipeline.sgml:
218         * docs/gst/tmpl/gstplugin.sgml:
219         * docs/gst/tmpl/gstpluginfeature.sgml:
220         * docs/gst/tmpl/gstquery.sgml:
221         * docs/gst/tmpl/gstqueue.sgml:
222         * docs/gst/tmpl/gstregistry.sgml:
223         * docs/gst/tmpl/gstregistrypool.sgml:
224         * docs/gst/tmpl/gstscheduler.sgml:
225         * docs/gst/tmpl/gstschedulerfactory.sgml:
226         * docs/gst/tmpl/gststructure.sgml:
227         * docs/gst/tmpl/gstsystemclock.sgml:
228         * docs/gst/tmpl/gsttaglist.sgml:
229         * docs/gst/tmpl/gsttagsetter.sgml:
230         * docs/gst/tmpl/gsttrace.sgml:
231         * docs/gst/tmpl/gsttrashstack.sgml:
232         * docs/gst/tmpl/gsttypefind.sgml:
233         * docs/gst/tmpl/gsttypefindfactory.sgml:
234         * docs/gst/tmpl/gsttypes.sgml:
235         * docs/gst/tmpl/gsturihandler.sgml:
236         * docs/gst/tmpl/gsturitype.sgml:
237         * docs/gst/tmpl/gstutils.sgml:
238         * docs/gst/tmpl/gstvalue.sgml:
239         * docs/gst/tmpl/gstversion.sgml:
240         * docs/gst/tmpl/gstxml.sgml:
241         * docs/libs/tmpl/gstcontrol.sgml:
242         * docs/libs/tmpl/gstdataprotocol.sgml:
243         * docs/libs/tmpl/gstdparam.sgml:
244         * docs/libs/tmpl/gstdplinint.sgml:
245         * docs/libs/tmpl/gstdpman.sgml:
246         * docs/libs/tmpl/gstdpsmooth.sgml:
247         * docs/libs/tmpl/gstgetbits.sgml:
248         * docs/libs/tmpl/gstunitconvert.sgml:
249         * gst/base/gstpushsrc.c: (gst_push_src_get_type),
250         (gst_push_src_base_init), (gst_push_src_class_init),
251         (gst_push_src_init), (gst_push_src_create):
252         * gst/base/gstpushsrc.h:
253         * gst/elements/gstelements.c:
254         * gst/elements/gstfakesink.c: (gst_fake_sink_state_error_get_type),
255         (gst_fake_sink_base_init), (gst_fake_sink_class_init),
256         (gst_fake_sink_init), (gst_fake_sink_set_property),
257         (gst_fake_sink_get_property), (gst_fake_sink_get_times),
258         (gst_fake_sink_event), (gst_fake_sink_preroll),
259         (gst_fake_sink_render), (gst_fake_sink_change_state):
260         * gst/elements/gstfakesink.h:
261         * gst/elements/gstfakesrc.c: (gst_fake_src_data_get_type),
262         (gst_fake_src_sizetype_get_type), (gst_fake_src_filltype_get_type),
263         (gst_fake_src_base_init), (gst_fake_src_class_init),
264         (gst_fake_src_init), (gst_fake_src_event_handler),
265         (gst_fake_src_alloc_parent), (gst_fake_src_set_property),
266         (gst_fake_src_get_property), (gst_fake_src_prepare_buffer),
267         (gst_fake_src_alloc_buffer), (gst_fake_src_get_size),
268         (gst_fake_src_create_buffer), (gst_fake_src_create),
269         (gst_fake_src_start), (gst_fake_src_stop):
270         * gst/elements/gstfakesrc.h:
271         * gst/elements/gstfilesink.c: (_do_init),
272         (gst_file_sink_base_init), (gst_file_sink_class_init),
273         (gst_file_sink_init), (gst_file_sink_dispose),
274         (gst_file_sink_set_location), (gst_file_sink_set_property),
275         (gst_file_sink_get_property), (gst_file_sink_open_file),
276         (gst_file_sink_close_file), (gst_file_sink_query),
277         (gst_file_sink_event), (gst_file_sink_render),
278         (gst_file_sink_change_state), (gst_file_sink_uri_get_type),
279         (gst_file_sink_uri_get_protocols), (gst_file_sink_uri_get_uri),
280         (gst_file_sink_uri_set_uri), (gst_file_sink_uri_handler_init):
281         * gst/elements/gstfilesink.h:
282         * gst/elements/gstfilesrc.c: (_do_init), (gst_file_src_base_init),
283         (gst_file_src_class_init), (gst_file_src_init),
284         (gst_file_src_finalize), (gst_file_src_set_location),
285         (gst_file_src_set_property), (gst_file_src_get_property),
286         (gst_file_src_map_region), (gst_file_src_map_small_region),
287         (gst_file_src_create_mmap), (gst_file_src_create_read),
288         (gst_file_src_create), (gst_file_src_is_seekable),
289         (gst_file_src_get_size), (gst_file_src_start), (gst_file_src_stop),
290         (gst_file_src_uri_get_type), (gst_file_src_uri_get_protocols),
291         (gst_file_src_uri_get_uri), (gst_file_src_uri_set_uri),
292         (gst_file_src_uri_handler_init):
293         * gst/elements/gstfilesrc.h:
294           more autistic cleanliness in functions/names/defines
295
296 2005-07-13  Andy Wingo  <wingo@pobox.com>
297
298         * gst/base/gstbasesrc.c (gst_base_src_start): Post an error if the
299         source couldn't negotiate.
300
301         * gst/parse/grammar.y: Revert 1.54->1.55, so we now do filtered
302         connections again.
303
304         * gst/gstutils.h:
305         * gst/gstutils.c (gst_element_link_pads_filtered): New old
306         function. I am channeling Hades. Put your boots on suckers!!!
307
308 2005-07-13  Thomas Vander Stichele  <thomas at apestaart dot org>
309
310         * testsuite/caps/Makefile.am:
311         * testsuite/caps/value_compare.c:
312         * testsuite/caps/value_intersect.c:
313         * check/gst/gstvalue.c: (GST_START_TEST), (gst_value_suite):
314           move two testsuite apps over to the check dir
315
316 2005-07-12  Wim Taymans  <wim@fluendo.com>
317
318         * gst/base/gstbasetransform.c: (gst_base_transform_setcaps):
319         Added more debug info in the negotiate process.
320
321         * gst/gstmessage.h:
322         Prepare for segment playback.
323
324         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_set_caps):
325         Better debugging.
326
327         * gst/gstutils.c:
328         Some more docs.
329
330         * tools/gst-launch.c: (main):
331         NULL pipeline on errors.
332
333 2005-07-12  Andy Wingo  <wingo@pobox.com>
334
335         * gst/gstbuffer.c (_gst_buffer_copy): Copy the buffer whether or
336         not it comes from a malloc region. Make sure our copy gets freed.
337
338 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
339
340         * check/gst/gstelement.c: (GST_START_TEST), (gst_element_suite):
341         * check/gst/gstmessage.c: (GST_START_TEST):
342         * check/gst/gststructure.c: (GST_START_TEST),
343         (gst_structure_suite), (main):
344           more testing
345         * gst/gstelement.c: (gst_element_message_full):
346           clean up GError and debug string now that they get copied
347         * gst/gstmessage.c: (gst_message_new_error),
348         (gst_message_new_warning), (gst_message_parse_error),
349         (gst_message_parse_warning):
350           use GST_TYPE_G_ERROR for structure_new, and take copies of
351           arguments, so that we don't mess up refcounting
352
353 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
354
355         * check/Makefile.am:
356           add per-test valgrind targets
357         * check/gst-libs/gdp.c: (GST_START_TEST),
358         (gst_data_protocol_suite), (main):
359           clean up
360
361 2005-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
362
363         * check/Makefile.am:
364           instate more valgrindable tests
365         * check/elements/gstfakesrc.c: (chain_func), (event_func),
366         (GST_START_TEST), (fakesrc_suite):
367         * check/gst/gstpad.c: (GST_START_TEST):
368         * check/gst/gststructure.c: (GST_START_TEST):
369           fix test leaks
370         * docs/gst/tmpl/gstminiobject.sgml:
371         * gst/gstpad.c: (gst_pad_finalize):
372           fix the static mutex leak
373
374 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
375
376         * check/Makefile.am:
377           add two more tests for valgrinding
378         * check/gst/gstvalue.c: (GST_START_TEST):
379           test refcount of deserialized buffer, found a leak
380         * docs/gst/gstreamer-docs.sgml:
381         * docs/gst/gstreamer-sections.txt:
382         * docs/gst/gstreamer.types:
383         * docs/gst/tmpl/gstminiobject.sgml:
384           add miniobject to docs
385         * gst/gstminiobject.c:
386           add some docs
387         * gst/gstvalue.c: (gst_value_deserialize_buffer),
388         (gst_string_unwrap):
389           fix a hard-to-find invalid write for one of the tests
390           fix a leak for deserialized buffers
391
392 2005-07-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
393
394         * docs/pwg/advanced-events.xml:
395         * docs/pwg/advanced-request.xml:
396         * docs/pwg/advanced-scheduling.xml:
397         * docs/pwg/appendix-porting.xml:
398         * docs/pwg/building-boiler.xml:
399         * docs/pwg/intro-preface.xml:
400         * docs/pwg/other-ntoone.xml:
401           Rewrite scheduling-chapter for scheduling model in 0.9. Add lots
402           of example code and explanation for pad activation, loop() and
403           getrange() functions and a bit more. Remove old comments pointing
404           to loop-functions.
405         * examples/pwg/Makefile.am:
406           Add loop/getrange examples.
407
408 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
409
410         * configure.ac:
411           check for valgrind binary + some fixes
412         * check/gst.supp:
413           valgrind suppressions for the tests
414         * check/Makefile.am:
415           add a valgrind: target that valgrinds the unit tests
416         * check/gst/gst.c: (GST_START_TEST), (gst_suite):
417         * check/gst/gstbin.c: (pop_messages), (GST_START_TEST):
418         * check/gst/gstbuffer.c: (GST_START_TEST), (gst_test_suite):
419         * check/gst/gstghostpad.c:
420           added some cleanup
421         * check/gst/gstdata.c:
422           removed
423         * check/gst/gstminiobject.c: (GST_START_TEST), (thread_ref),
424         (thread_unref), (gst_mini_object_suite), (main):
425           added
426         * gst/gst.c: (gst_deinit):
427         * gst/gst.h:
428           add a method to clean up.
429         * gst/gstsystemclock.c: (gst_system_clock_dispose),
430         (gst_system_clock_obtain):
431           allow for disposing the system clock.
432         * tools/gst-launch.c: (main):
433           deinit
434
435 2005-07-11  Thomas Vander Stichele  <thomas at apestaart dot org>
436
437         * docs/gst/tmpl/gstbasesrc.sgml:
438         * docs/gst/tmpl/gstfakesrc.sgml:
439         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
440         (gst_base_src_init), (gst_base_src_set_property),
441         (gst_base_src_get_property), (gst_base_src_get_range),
442         (gst_base_src_start):
443         * gst/base/gstbasesrc.h:
444           add num-buffers property
445         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
446         (gst_fakesrc_init), (gst_fakesrc_set_property),
447         (gst_fakesrc_get_property), (gst_fakesrc_create),
448         (gst_fakesrc_start):
449           remove num-buffers property
450
451 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
452
453         * docs/gst/gstreamer-sections.txt:
454         * docs/gst/tmpl/gstbasesink.sgml:
455         * docs/gst/tmpl/gstbasesrc.sgml:
456         * gst/base/gstbasesink.c: (gst_base_sink_pad_getcaps),
457         (gst_base_sink_pad_setcaps), (gst_base_sink_pad_buffer_alloc),
458         (gst_base_sink_finalize), (gst_base_sink_set_clock),
459         (gst_base_sink_set_property), (gst_base_sink_get_property),
460         (gst_base_sink_handle_object), (gst_base_sink_event),
461         (gst_base_sink_do_sync), (gst_base_sink_handle_event),
462         (gst_base_sink_handle_buffer), (gst_base_sink_chain),
463         (gst_base_sink_loop), (gst_base_sink_deactivate),
464         (gst_base_sink_activate_push), (gst_base_sink_activate_pull),
465         (gst_base_sink_change_state):
466         * gst/base/gstbasesink.h:
467         * gst/base/gstbasesrc.h:
468         * gst/elements/gstfakesink.c: (gst_fakesink_get_times):
469         * gst/elements/gstfilesink.c: (gst_filesink_class_init),
470         (gst_filesink_init):
471           more macro splitting
472
473 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
474
475         * gst/gstelement.c: (gst_element_get_bus):
476           add debug
477         * tools/gst-launch.c: (check_intr), (event_loop):
478           fix bus leaks
479
480 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
481
482         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked):
483           fix a caps leak
484
485 2005-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
486
487         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
488         (gst_base_src_finalize):
489           add finalize method and clean up properly
490         * gst/gstpipeline.c: (gst_pipeline_dispose):
491           add debug
492
493 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
494
495         * check/gst/gstbin.c: (pop_messages), (GST_START_TEST),
496         (gst_bin_suite):
497           add more things to check
498         * gst/gstbin.c: (gst_bin_change_state), (bin_bus_handler):
499         * gst/gstelement.c:
500           more debug
501
502 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
503
504         * check/elements/gstfakesrc.c: (chain_func), (event_func),
505         (GST_START_TEST), (fakesrc_suite):
506         * check/gst-libs/gdp.c: (GST_START_TEST):
507         * check/gst/gst.c: (GST_START_TEST):
508         * check/gst/gstbin.c: (GST_START_TEST), (gst_bin_suite):
509         * check/gst/gstbuffer.c: (GST_START_TEST), (gst_test_suite):
510         * check/gst/gstbus.c: (GST_START_TEST):
511         * check/gst/gstcaps.c: (GST_START_TEST):
512         * check/gst/gstdata.c: (GST_START_TEST):
513         * check/gst/gstelement.c: (GST_START_TEST):
514         * check/gst/gstghostpad.c: (GST_START_TEST):
515         * check/gst/gstiterator.c: (GST_START_TEST):
516         * check/gst/gstmessage.c: (GST_START_TEST):
517         * check/gst/gstobject.c: (GST_START_TEST):
518         * check/gst/gstpad.c: (GST_START_TEST):
519         * check/gst/gststructure.c: (GST_START_TEST):
520         * check/gst/gstsystemclock.c: (GST_START_TEST),
521         (gst_systemclock_suite):
522         * check/gst/gsttag.c: (GST_START_TEST), (gst_tag_suite):
523         * check/gst/gstvalue.c: (GST_START_TEST):
524         * check/pipelines/cleanup.c: (GST_START_TEST):
525         * check/pipelines/simple_launch_lines.c: (GST_START_TEST):
526         * check/states/sinks.c: (GST_START_TEST):
527         * check/gstcheck.c: (gst_check_init):
528         * check/gstcheck.h:
529           add debugging category
530           use GST_START_TEST now, so we add a debug line
531
532 2005-07-09  Thomas Vander Stichele  <thomas at apestaart dot org>
533
534         * check/gst/gstbin.c: (START_TEST), (gst_bin_suite):
535           add test for state change message on a bin
536         * check/gst/gstelement.c: (START_TEST), (gst_element_suite):
537           add another test
538         * gst/gstbin.c: (gst_bin_init):
539         * gst/gstbus.c: (gst_bus_init), (gst_bus_post):
540         * gst/gstelement.c: (gst_element_post_message),
541         (gst_element_set_state):
542         * gst/gstelementfactory.c: (gst_element_factory_create):
543         * gst/gstmessage.c: (gst_message_new):
544         * gst/gstscheduler.c:
545           various debugging additions and cleanups
546
547 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
548
549         * check/Makefile.am:
550         * check/gst/gstelement.c: (START_TEST), (gst_element_suite),
551         (main):
552           adding tests for elements
553         * gst/gstelement.c: (gst_element_dispose):
554
555 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
556
557         * gst/registries/gstlibxmlregistry.c: (load_feature):
558           plug more leaks.  A simple gst_init() now is leakfree, yay.
559
560 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
561
562         * gst/registries/gstlibxmlregistry.c: (read_string), (load_paths),
563         (gst_xml_registry_load):
564           plug another memleak
565
566 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
567
568         * configure.ac:
569           use GST_SET_ERROR_CFLAGS
570         * docs/faq/cvs.xml:
571           change to ERROR_CFLAGS
572
573 2005-07-08  Thomas Vander Stichele  <thomas at apestaart dot org>
574
575         * configure.ac:
576           make GST_ERROR_CFLAGS overridable and re-enable Werror
577         * docs/faq/cvs.xml:
578           add a note about error CFLAGS
579         * docs/gst/tmpl/gstfakesrc.sgml:
580         * gst/elements/gstfakesrc.c:
581           comment out some unused code
582         * gst/gst.c: (split_and_iterate):
583         * gst/registries/gstlibxmlregistry.c: (load_pad_template),
584         (load_feature):
585           plug some memleaks
586
587 2005-07-07  Thomas Vander Stichele  <thomas at apestaart dot org>
588
589         * common/Makefile.am:
590         * common/gtk-doc.mak:
591         * docs/gst/Makefile.am:
592           factor out gtk-doc.mak
593
594 2005-07-07  Wim Taymans  <wim@fluendo.com>
595
596         * gst/schedulers/threadscheduler.c: (gst_thread_scheduler_func),
597         (gst_thread_scheduler_dispose):
598         Unlock the STREAM_LOCK completely.
599
600 2005-07-07  Thomas Vander Stichele  <thomas at apestaart dot org>
601
602         * check/Makefile.am:
603         * check/elements/.cvsignore:
604         * check/elements/gstfakesrc.c: (chain_func), (event_func),
605         (START_TEST), (fakesrc_suite), (main):
606         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
607         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
608         (gst_fakesrc_create), (gst_fakesrc_start):
609         * gst/elements/gstfakesrc.h:
610           adding a first element test
611
612 2005-07-07  Andy Wingo  <wingo@pobox.com>
613
614         * gst/gstbus.c (gst_bus_have_pending): Remove intensely irritating
615         debug message.
616
617 2005-07-07  Wim Taymans  <wim@fluendo.com>
618
619         * gst/gstquery.c:
620         * gst/gstquery.h:
621         Remove old types
622
623 2005-07-07  Wim Taymans  <wim@fluendo.com>
624
625         * gst/base/gstbasesrc.c: (gst_base_src_get_range),
626         (gst_base_src_default_negotiate), (gst_base_src_negotiate):
627         Allow subclasses to implement their own negotiation.
628
629 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
630
631         * docs/design/part-gstbin.txt:
632         * docs/design/part-gstpipeline.txt:
633           Update design notes to reflect the movement of
634           responsibility for bus handling from GstPipeline to
635           GstBin
636
637 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
638
639         * configure.ac:
640           Remove unnecessary queue2/3/4 examples.
641
642 2005-07-07  Jan Schmidt  <thaytan@mad.scientist.com>
643
644         * examples/Makefile.am:
645         * examples/helloworld/helloworld.c: (event_loop), (main):
646         * examples/queue/queue.c: (event_loop), (main):
647         * examples/queue2/queue2.c: (main):
648           Update a couple of the examples to work again.
649
650         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
651         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_event):
652          Spelling corrections and extra debug.
653         
654         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_init), (is_eos),
655         (gst_bin_add_func), (bin_element_is_sink), (gst_bin_get_state),
656         (gst_bin_change_state), (gst_bin_dispose), (bin_bus_handler):
657         * gst/gstbin.h:
658         * gst/gstpipeline.c: (gst_pipeline_init), (gst_pipeline_dispose),
659         (gst_pipeline_change_state):
660         * gst/gstpipeline.h:
661           Move the bus handler for children to the GstBin, and create a
662           separate bus for receiving messages from children to the one the
663           bus sends 'upwards' on.
664
665 2005-07-06  Wim Taymans  <wim@fluendo.com>
666
667         * gst/base/README:
668         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
669         (gst_base_sink_handle_object), (gst_base_sink_loop),
670         (gst_base_sink_change_state):
671         * gst/base/gstbasesink.h:
672         * gst/base/gstbasesrc.c: (gst_base_src_class_init),
673         (gst_base_src_init), (gst_base_src_setcaps),
674         (gst_base_src_getcaps), (gst_base_src_loop),
675         (gst_base_src_default_negotiate), (gst_base_src_negotiate),
676         (gst_base_src_start), (gst_base_src_change_state):
677         * gst/base/gstbasesrc.h:
678         Make basesrc negotiate.
679         Handle the case where preroll fails in basesink.
680         Update README.
681
682 2005-07-06  Wim Taymans  <wim@fluendo.com>
683
684         * gst/gstpad.c: (gst_pad_fixate_caps), (gst_pad_accept_caps):
685         Implement the fixate function.
686         Clean up acceptcaps.
687
688 2005-07-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
689
690         * docs/pwg/building-filterfactory.xml:
691         * docs/pwg/pwg.xml:
692           Remove never-written filter-factory chapter; I'll add the various
693           base classes to part 4 ("other element types") later on.
694
695 2005-07-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
696
697         * docs/pwg/advanced-negotiation.xml:
698         * docs/pwg/building-boiler.xml:
699         * docs/pwg/building-pads.xml:
700         * docs/pwg/pwg.xml:
701         * examples/pwg/Makefile.am:
702           Add a chapter on caps negotiation, simplify the original code
703           samples a bit w.r.t. caps negotiation, add link to the advanced
704           section. Add a bunch of examples showing different use cases of
705           different types of caps negotiation. Upstream renegotiation isn't
706           fully documented yet since nobody knows how that works.
707
708 2005-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
709
710         * check/gst/gstpad.c:
711         * check/gstcheck.c:
712         * gst/gstpad.c: (gst_pad_get_internal_links_default):
713           if pad has no parent, return NULL as list of internal links
714
715 2005-07-05  Andy Wingo  <wingo@pobox.com>
716
717         * gst/elements/gstfilesrc.c:
718         * gst/elements/gstfakesrc.c: 
719         * gst/base/gstpushsrc.c:
720         * gst/base/gstbasesrc.h: 
721         * gst/base/gstbasesrc.c: s/BASESRC/BASE_SRC/g.
722         
723 2005-07-05  Stefan Kost  <ensonic@users.sf.net>
724
725         * Makefile.am:
726           better report generation target (lcov needs a patch)
727
728 2005-07-05  Andy Wingo  <wingo@pobox.com>
729
730         * gst/elements, testsuite: Null if we got it...
731
732 2005-07-05  Wim Taymans  <wim@fluendo.com>
733
734         * configure.ac:
735         * libs/gst/dataprotocol/Makefile.am:
736         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_validate_packet):
737         * libs/gst/dataprotocol/dataprotocol.h:
738         * pkgconfig/Makefile.am:
739         * pkgconfig/gstreamer-dataprotocol-uninstalled.pc.in:
740         * pkgconfig/gstreamer-dataprotocol.pc.in:
741         Ported dataprotol to 0.9. 
742         Added pkgconfig files.
743
744 2005-07-05  Andy Wingo  <wingo@pobox.com>
745
746         * gst/base/gstbasetransform.c (gst_base_transform_setcaps):
747         Default to returning TRUE for the case when tranform_caps returns
748         a fixed caps, like for identity or volume.
749
750         * check/gst/gstbus.c (pound_bus_with_messages): 
751         * check/gst/gstmessage.c (START_TEST): 
752         * check/pipelines/simple_launch_lines.c (got_handoff): Application
753         message API change.
754
755         * gst/base/gstbasetransform.c (gst_base_transform_setcaps): More
756         logic weaks here: always run transform_caps, trying passthrough
757         operation only if the original caps intersects with the transform.
758
759         * gst/gstpad.c (gst_pad_link_check_compatible_unlocked): Debug
760         source and sink caps.
761
762         * gst/base/gstbasetransform.c (gst_base_transform_getcaps):
763         Intersect the peer caps with the pad template before going into
764         transform_caps.
765         (gst_base_transform_transform_caps): More debugging.
766
767         * gst/gstmessage.h (gst_message_new_application): Take a GstObject
768         src argument.
769
770 2005-07-04  Edward Hervey  <edward@fluendo.com>
771
772         * gst/gstutils.c:
773         * gst/gstutils.h:
774         (gst_pad_add_*_probe): now returns the signal id for better wrapping
775         in bindings.
776
777 2005-07-04  Andy Wingo  <wingo@pobox.com>
778
779         * check/gst/gstpad.c: Only set explicit caps on pads.
780
781 2005-07-01  Andy Wingo  <wingo@pobox.com>
782
783         * tests/network-clock.scm: Commentary update.
784
785         * gst/elements/gstidentity.c (PROP_DUPLICATE): Gone daddy gone.
786         Didn't really make sense, not implementable with basetransform,
787         etc.
788         (gst_identity_transform): Unref inbuf via make_writable. Feeble
789         attempt at implementing the sync property, needs an unlock method.
790
791         * gst/base/gstbasetransform.c (gst_base_transform_transform_caps):
792         New func, by default returns the same caps (the identity
793         transformation).
794         (gst_base_transform_getcaps): Uses transform_caps to return
795         something sensible.
796         (gst_base_transform_setcaps): Complicated logic to get caps on
797         both pads, even if they are different, and to call set_caps once
798         for every time both pads get their caps set.
799         (gst_base_transform_handle_buffer): Give the ref to the transform
800         function. Allows in-place modification of the buffer.
801
802         * gst/base/gstbasetransform.h (transform_caps): New class method.
803         Given caps on one side, what can I do on the other.
804         (set_caps): Take two caps, one for each side of the element.
805
806         * gst/gstpad.h:
807         * gst/gstpad.c (gst_pad_fixate_caps): Change prototype to modify
808         caps in place. This is safe because we can check the mutability of
809         the caps, and a good idea because fixate functions are just called
810         as a matter of last resort. (Not actually implemented.)
811         (gst_pad_set_caps): If the caps we're setting is actually the same
812         as the existing pad caps, just update the pointer without calling
813         setcaps. Assert that caps is either NULL or fixed, as per the
814         docs.
815
816         * gst/gstghostpad.c: Update for fixate changes.
817
818 2005-07-02  Andy Wingo  <wingo@pobox.com>
819
820         * gst/gstcaps.c:
821         * gst/gstcaps.h (gst_static_caps_get): Not const return, having
822         two refcounts makes it immutable, which is enough. Doc more.
823
824 2005-07-02  Jan Schmidt  <thaytan@mad.scientist.com>
825
826         * gst/gstpad.c: (gst_pad_emit_have_data_signal):
827           Put the mini_object into GValue as a mini_object,
828           not a gpointer, since that's how we declared
829           the signal.
830
831 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
832
833         * examples/pwg/Makefile.am:
834           Fix buildbot again.
835
836 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
837
838         * docs/pwg/building-testapp.xml:
839           Add extra check.
840         * examples/pwg/Makefile.am:
841           Fix buildbot.
842
843 2005-07-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
844
845         * configure.ac:
846         * examples/Makefile.am:
847         * examples/pwg/Makefile.am:
848         * examples/pwg/extract.pl:
849           Enable building the PWG examples.
850         * docs/pwg/advanced-interfaces.xml:
851           Add URI interface stub.
852         * docs/pwg/advanced-types.xml:
853         * docs/pwg/other-autoplugger.xml:
854         * docs/pwg/appendix-porting.xml:
855         * docs/pwg/pwg.xml:
856           Add porting guide (mostly stubs), remove autoplugging (see ADM).
857         * docs/pwg/building-boiler.xml:
858         * docs/pwg/building-chainfn.xml:
859         * docs/pwg/building-pads.xml:
860         * docs/pwg/building-props.xml:
861         * docs/pwg/building-state.xml:
862         * docs/pwg/building-testapp.xml:
863           Update the building-*.xml parts for 0.9 changes. All examples
864           code blocks compile in examples/pwg/*.
865
866 2005-06-30  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
867
868         * docs/manual/advanced-autoplugging.xml:
869         * docs/manual/appendix-checklist.xml:
870         * docs/manual/appendix-integration.xml:
871         * docs/manual/highlevel-components.xml:
872           Fix playbin/decodebin examples, update docs a bit, mention bus
873           instead of signals in various places, mention kmplayer and
874           kaffeine since they have a working GStreamer backend in the KDE
875           section.
876
877 2005-06-30  Wim Taymans  <wim@fluendo.com>
878
879         * CHANGES-0.9:
880         * docs/design/draft-ghostpads.txt:
881         * docs/design/draft-push-pull.txt:
882         * docs/design/draft-query.txt:
883         * docs/design/part-TODO.txt:
884         * docs/design/part-query.txt:
885         Added CHANGES-0.9 doc, updated status of other docs.
886         
887         * gst/gstquery.h:
888         Remove "hmm" macro
889
890 2005-06-30  Wim Taymans  <wim@fluendo.com>
891
892         * gst/base/gstbasesink.c: (gst_base_sink_preroll_queue_empty),
893         (gst_base_sink_preroll_queue_flush), (gst_base_sink_handle_object),
894         (gst_base_sink_change_state):
895         * gst/base/gstbasesink.h:
896         Some tweaks, only EOS and a buffer complete a preroll.
897
898 2005-06-30  Andy Wingo  <wingo@pobox.com>
899
900         * gst/gstghostpad.c (gst_ghost_pad_do_activate_push): Proxy
901         activate_push down to the internal pad as well.
902
903 2005-06-30  Torsten Schoenfeld  <kaffeetisch@gmx.de>
904
905         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
906
907         * gst/gsttaginterface.c:
908           Some documentation fixes (#307394 and #307397).
909
910 2005-06-30  Antoine Tremblay  <hexa00@gmail.com>
911
912         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
913
914         * gst/gstvalue.c: (gst_value_intersect_list):
915           Fix memleak (#309125).
916
917 2005-06-30  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
918
919         * docs/manual/advanced-dataaccess.xml:
920           Fix fakesrc example to compile; doesn't work, bug somewhere...?
921         * docs/manual/basics-pads.xml:
922           Add reference for filtered caps to above chapter.
923
924 2005-06-30  Wim Taymans  <wim@fluendo.com>
925
926         * gst/gstbin.c: (clear_queue), (remove_all_from_queue),
927         (gst_bin_change_state):
928         Probes are gone.
929         Lame attempt at making the state change function a bit
930         more readable.
931
932 2005-06-30  Wim Taymans  <wim@fluendo.com>
933
934         * docs/design/part-clocks.txt:
935         * docs/design/part-element-sink.txt:
936         * docs/design/part-events.txt:
937         * docs/design/part-preroll.txt:
938         * docs/design/part-states.txt:
939         Some more tweeks and additions to the docs.
940
941 2005-06-30  Wim Taymans  <wim@fluendo.com>
942
943         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
944         (default_have_data), (gst_pad_class_init), (gst_pad_init),
945         (gst_pad_emit_have_data_signal), (gst_pad_chain), (gst_pad_push),
946         (gst_pad_check_pull_range), (gst_pad_get_range),
947         (gst_pad_pull_range), (gst_pad_push_event), (gst_pad_send_event):
948         * gst/gstpad.h:
949         * gst/gstutils.c: (gst_atomic_int_set), (gst_pad_add_data_probe),
950         (gst_pad_add_event_probe), (gst_pad_add_buffer_probe),
951         (gst_pad_remove_data_probe), (gst_pad_remove_event_probe),
952         (gst_pad_remove_buffer_probe):
953         Removed atomic operations, use existing LOCK.
954         Move exception handling out of main code path.
955
956 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
957
958         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
959         (silly_return_true_function), (gst_pad_class_init),
960         (gst_pad_emit_have_data_signal), (gst_pad_chain), (gst_pad_push),
961         (gst_pad_get_range), (gst_pad_pull_range), (gst_pad_push_event),
962         (gst_pad_send_event):
963           Fix accumulator, add default value by using _emitv() instead
964           of _emit() for signal emission.
965
966 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
967
968         * docs/manual/advanced-dataaccess.xml:
969         * examples/manual/Makefile.am:
970           Add probe example.
971         * gst/gstpad.c: (_gst_do_pass_data_accumulator):
972           Make work (??).
973
974 2005-06-29  Tim-Philipp Müller  <tim at centricular dot net>
975
976         * gst/elements/gstfilesink.c: (gst_filesink_render):
977           Simplify code so that we don't have to handle short
978           writes and return GST_FLOW_ERROR if an error occured.
979
980 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
981
982         * docs/gst/gstreamer-docs.sgml:
983           Remove probes more.
984
985 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
986
987         * docs/gst/gstreamer-sections.txt:
988         * docs/gst/tmpl/gstpad.sgml:
989         * docs/gst/tmpl/gstprobe.sgml:
990         * gst/Makefile.am:
991         * gst/gstpad.c: (_gst_do_pass_data_accumulator),
992         (gst_pad_class_init), (gst_pad_init), (gst_pad_chain),
993         (gst_pad_push), (gst_pad_get_range), (gst_pad_pull_range),
994         (gst_pad_push_event), (gst_pad_send_event):
995         * gst/gstpad.h:
996         * gst/gstutils.c: (gst_pad_add_data_probe),
997         (gst_pad_add_event_probe), (gst_pad_add_buffer_probe),
998         (gst_pad_remove_data_probe), (gst_pad_remove_event_probe),
999         (gst_pad_remove_buffer_probe):
1000         * gst/gstutils.h:
1001           Remove old probes, add new g-signal-based probes and some utility
1002           functions.
1003
1004 2005-06-29  Edward Hervey  <edward@fluendo.com>
1005
1006         * gst/gstelementfactory.c:
1007         * gst/gstutils.h:
1008         * gst/gstutils.c:
1009         Moved gst_element_factory_can_[sink|src]_caps() to gstutils and added
1010         the definition to the header file.
1011
1012 2005-06-29  Andy Wingo  <wingo@pobox.com>
1013
1014         * docs/gst/Makefile.am (scan-build.stamp): Totally only check
1015         plugins from the source directory.
1016
1017 2005-06-29  Wim Taymans  <wim@fluendo.com>
1018
1019         * docs/gst/tmpl/gstbuffer.sgml:
1020         * docs/gst/tmpl/gstclock.sgml:
1021         Some fixings for blantently wrong text.
1022
1023 2005-06-29  Thomas Vander Stichele  <thomas at apestaart dot org>
1024
1025         * check/Makefile.am:
1026         * gst/gst.c: (add_path_func), (init_pre):
1027         * gst/gstregistry.c: (gst_registry_add_path):
1028           add A GST_PLUGIN_PATH_ONLY env var; if it is set, it will
1029           only scan the GST_PLUGIN_PATH locations, and not add
1030           system locations
1031
1032 2005-06-29  Thomas Vander Stichele  <thomas at apestaart dot org>
1033
1034         * docs/gst/gstreamer-sections.txt:
1035         * docs/gst/tmpl/gstbasesrc.sgml:
1036         * gst/gstelement.c:
1037         * gst/gstelement.h:
1038         * gst/gstevent.c:
1039         * gst/gstutils.c:
1040           doc fixes
1041
1042 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1043
1044         * docs/manual/advanced-autoplugging.xml:
1045           Fix autoplugging example.
1046
1047 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1048
1049         * docs/manual/advanced-autoplugging.xml:
1050         * docs/manual/mime-world.fig:
1051           Try to get autoplugging working, fix type detection. Fix text
1052           in hello-world image.
1053
1054 2005-06-29  Wim Taymans  <wim@fluendo.com>
1055
1056         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
1057         (gst_base_sink_change_state):
1058         Small debug line.
1059
1060         * gst/gstclock.h:
1061         map SIGNAL and BROADCAST to the right function.
1062
1063         * gst/gstobject.h:
1064         Remove redundant braces.
1065
1066         * gst/gstpad.c: (gst_pad_set_caps):
1067         Don't call setcaps function when reseting caps to NULL.
1068
1069         * gst/gstsystemclock.c: (gst_system_clock_dispose),
1070         (gst_system_clock_async_thread), (gst_system_clock_id_wait_async),
1071         (gst_system_clock_id_unschedule):
1072         Use BROADCAST as this is what we do.
1073
1074 2005-06-29  Wim Taymans  <wim@fluendo.com>
1075
1076         * gst/base/gstbasesink.c: (gst_base_sink_handle_object):
1077         We are actually prerolling before commiting the state
1078         change. 
1079
1080 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1081
1082         * docs/manual/advanced-clocks.xml:
1083         * docs/manual/advanced-interfaces.xml:
1084         * docs/manual/advanced-metadata.xml:
1085         * docs/manual/advanced-position.xml:
1086         * docs/manual/advanced-schedulers.xml:
1087         * docs/manual/advanced-threads.xml:
1088         * docs/manual/appendix-porting.xml:
1089         * docs/manual/basics-bins.xml:
1090         * docs/manual/basics-bus.xml:
1091         * docs/manual/basics-elements.xml:
1092         * docs/manual/basics-helloworld.xml:
1093         * docs/manual/basics-pads.xml:
1094         * docs/manual/highlevel-components.xml:
1095         * docs/manual/manual.xml:
1096         * docs/manual/thread.fig:
1097           Update (until threads/scheduling) Application Development Manual;
1098           remove GstThread, add GstBus, add simple porting checklist, add
1099           documentation for tag writing, clocks, make all examples until this
1100           part compile and run.
1101         * examples/manual/Makefile.am:
1102           Update from changes to Application Development Manual; add bus
1103           example, remove thread example.
1104
1105 2005-06-28  Wim Taymans  <wim@fluendo.com>
1106
1107         * gst/gstbus.c: (gst_bus_post), (gst_bus_have_pending),
1108         (gst_bus_set_flushing), (gst_bus_pop), (gst_bus_peek),
1109         (gst_bus_source_dispatch):
1110         Add debugging messages.
1111         Make internal methods static.
1112         Handle the case where the bus is flushed in the handler.
1113         
1114         * gst/gstelement.c: (gst_element_get_bus):
1115         Fix refcount in _get_bus();
1116
1117         * gst/gstpipeline.c: (gst_pipeline_change_state),
1118         (gst_pipeline_get_clock_func):
1119         Clock refcounting fixes.
1120         Handle the case where preroll timed out more gracefully.
1121         
1122         * gst/gstsystemclock.c: (gst_system_clock_dispose):
1123         Clean up the internal thread in dispose. This is needed
1124         for subclasses that actually get disposed.
1125         
1126         * gst/schedulers/threadscheduler.c:
1127         (gst_thread_scheduler_class_init), (gst_thread_scheduler_func),
1128         (gst_thread_scheduler_dispose):
1129         Free thread pool in dispose.
1130
1131 2005-06-28  Andy Wingo  <wingo@pobox.com>
1132
1133         * tests/network-clock-utils.scm (debug, print-event): New utils.
1134
1135         * tests/network-clock.scm (*debug*, *with-graph*): New parameters.
1136         (*packet-loss*): Unified loss probability.
1137         (network-time): Report out-of-band events.
1138
1139         * tests/plot-data: Add support for out-of-band events. Hack it
1140         into this script instead of passing it down the pipe; should fix
1141         this later.
1142
1143 2005-06-28  Wim Taymans  <wim@fluendo.com>
1144
1145         * docs/gst/gstreamer.types:
1146         * docs/gst/tmpl/gstbasesrc.sgml:
1147         * docs/gst/tmpl/gstpad.sgml:
1148         Docs fixes.
1149
1150 2005-06-28  Wim Taymans  <wim@fluendo.com>
1151
1152         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
1153         (gst_proxy_pad_do_checkgetrange), (gst_proxy_pad_do_acceptcaps),
1154         (gst_proxy_pad_do_fixatecaps):
1155         Correctly proxy the check_pull_range function.
1156
1157 2005-06-28  Andy Wingo  <wingo@pobox.com>
1158
1159         * tests/network-clock.scm: Removed need for slib.
1160         
1161 2005-06-28  Wim Taymans  <wim@fluendo.com>
1162
1163         * gst/base/gstbasesink.c: (gst_basesink_set_pad_functions),
1164         (gst_basesink_preroll_queue_flush):
1165         * gst/base/gstbasesrc.c: (gst_basesrc_set_dataflow_funcs):
1166         * gst/elements/gsttee.c: (gst_tee_update_pad_functions):
1167         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
1168         (gst_proxy_pad_do_acceptcaps), (gst_proxy_pad_do_fixatecaps),
1169         (gst_proxy_pad_set_property):
1170         * gst/gstpad.c:
1171         * gst/gstpad.h:
1172         * gst/gstqueue.c: (gst_queue_init):
1173         The deprecated pad loop function is removed now.
1174
1175 2005-06-28  Andy Wingo  <wingo@pobox.com>
1176
1177         * tests/network-clock.scm (*timeout*, *send-loss*, *recv-loss*):
1178         New parameters, simulate network packet loss.
1179
1180         * tests/network-clock-utils.scm: Initialize the RNG.
1181
1182 2005-06-28  Wim Taymans  <wim@fluendo.com>
1183
1184         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_flush),
1185         (gst_basesink_event), (gst_basesink_deactivate):
1186         Flushing the preroll queue always needs to unlock the waiters.
1187
1188 2005-06-28  Edward Hervey  <edward@fluendo.com>
1189
1190         * gst/gstpipeline.c: (gst_pipeline_send_event): 
1191         Wheen a seek was successful on a pipeline, set the stream_time to the
1192         seek offset in order to have a synchronized stream_time.
1193
1194 2005-06-28  Wim Taymans  <wim@fluendo.com>
1195
1196         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
1197         (gst_proxy_pad_do_getrange), (gst_proxy_pad_do_checkgetrange),
1198         (gst_proxy_pad_do_getcaps), (gst_proxy_pad_do_acceptcaps),
1199         (gst_proxy_pad_do_fixatecaps):
1200         Call wrapper function instead of just calling the function
1201         pointers. This takes care of any locking and whatmore.
1202
1203 2005-06-28  Wim Taymans  <wim@fluendo.com>
1204
1205         * gst/gstpad.c: (gst_pad_alloc_buffer), (gst_pad_push),
1206         (gst_pad_pull_range):
1207         * gst/gstpad.h:
1208         CONNECTED -> LINKED.
1209
1210 2005-06-28  Andy Wingo  <wingo@pobox.com>
1211
1212         * *.c: Don't cast to GST_OBJECT when reffing or unreffing. Large
1213         source-munging commit!!!
1214
1215         * gst/gstobject.c (gst_object_unref, gst_object_ref) 
1216         (gst_object_sink): Take gpointer arguments, not GstObject --
1217         avoids casts. Like GLib.
1218
1219         * gst/gstghostpad.c (gst_proxy_pad_do_activate): Don't proxy
1220         activate.
1221
1222 2005-06-27  Andy Wingo  <wingo@pobox.com>
1223
1224         * gst/base/gsttypefindhelper.c (gst_type_find_helper): Unref any
1225         remaining buffer.
1226
1227         * gst/gsttrace.c (gst_alloc_trace_list_sorted): New helper,
1228         returns a sorted copy of the trace list.
1229         (gst_alloc_trace_print_live): New API, only prints traces with
1230         live objects. Sort the list.
1231         (gst_alloc_trace_print_all): Sort the list.
1232         (gst_alloc_trace_print): Align columns.
1233
1234         * gst/elements/gstttypefindelement.c:
1235         * gst/elements/gsttee.c:
1236         * gst/base/gstbasesrc.c:
1237         * gst/base/gstbasesink.c:
1238         * gst/base/gstbasetransform.c:
1239         * gst/gstqueue.c: Adapt for pad activation changes.
1240
1241         * gst/gstpipeline.c (gst_pipeline_init): Unref after parenting
1242         sched.
1243         (gst_pipeline_dispose): Drop ref on sched.
1244
1245         * gst/gstpad.c (gst_pad_init): Set the default activate func.
1246         (gst_pad_activate_default): Push mode by default.
1247         (pre_activate_switch, post_activate_switch): New stubs, things to
1248         do before and after switching activation modes on pads.
1249         (gst_pad_set_active): Take a boolean and not a mode, dispatch to
1250         the pad's activate function to choose which mode to activate.
1251         Shortcut on deactivation and call the right function directly.
1252         (gst_pad_activate_pull): New API, (de)activates a pad in pull
1253         mode.
1254         (gst_pad_activate_push): New API, same for push mode.
1255         (gst_pad_set_activate_function) 
1256         (gst_pad_set_activatepull_function) 
1257         (gst_pad_set_activatepush_function): Setters for new API.
1258
1259         * gst/gstminiobject.c (gst_mini_object_new, gst_mini_object_free):
1260         Trace all miniobjects.
1261         (gst_mini_object_make_writable): Unref the arg if we copy, like
1262         gst_caps_make_writable.
1263
1264         * gst/gstmessage.c (_gst_message_initialize): No trace init.
1265
1266         * gst/gstghostpad.c (gst_proxy_pad_do_activate) 
1267         (gst_proxy_pad_do_activatepull, gst_proxy_pad_do_activatepush):
1268         Adapt for new pad API.
1269
1270         * gst/gstevent.c (_gst_event_initialize): Don't initialize trace.
1271
1272         * gst/gstelement.h:
1273         * gst/gstelement.c (gst_element_iterate_src_pads) 
1274         (gst_element_iterate_sink_pads): New API functions.
1275         
1276         * gst/gstelement.c (iterator_fold_with_resync): New utility,
1277         should fold into gstiterator.c in some form.
1278         (gst_element_pads_activate): Simplified via use of fold and
1279         delegation of decisions to gstpad->activate.
1280
1281         * gst/gstbus.c (gst_bus_source_finalize): Set the bus to NULL,
1282         help in debugging.
1283
1284         * gst/gstbuffer.c (_gst_buffer_initialize): Ref the buffer type
1285         class once in init, like gstmessage. Didn't run into this issue
1286         but it seems correct. Don't initialize a trace, gstminiobject does
1287         that.
1288
1289         * check/pipelines/simple_launch_lines.c (test_stop_from_app): New
1290         test, runs fakesrc ! fakesink, stopping on ::handoff via a message
1291         to the bus.
1292         (assert_live_count): New util function, uses alloc traces to check
1293         cleanup.
1294
1295         * check/gst/gstghostpad.c (test_ghost_pads): More refcount checks.
1296         To be modified when unlink drops the internal pad.
1297
1298 2005-06-27  Wim Taymans  <wim@fluendo.com>
1299
1300         * gst/gstbin.c: (gst_bin_get_state), (gst_bin_iterate_state_order),
1301         (gst_bin_change_state):
1302         Cleanup the get_state() function a little, make sure it
1303         iterates the same set of elements.
1304         Added stub iterate_state_order().
1305
1306 2005-06-27  Thomas Vander Stichele  <thomas at apestaart dot org>
1307
1308         * docs/gst/gstreamer-docs.sgml:
1309         * docs/gst/gstreamer-sections.txt:
1310         * docs/gst/gstreamer.types:
1311         * docs/gst/tmpl/gstbasesink.sgml:
1312         * docs/gst/tmpl/gstbasesrc.sgml:
1313         * docs/gst/tmpl/gstbasetransform.sgml:
1314         * docs/gst/tmpl/gstelement.sgml:
1315         * docs/gst/tmpl/gstiterator.sgml:
1316         * gst/base/gstbasesrc.c:
1317         * gst/base/gstbasesrc.h:
1318         * gst/base/gstbasetransform.h:
1319         * gst/gstelement.c:
1320         * gst/gstiterator.h:
1321           adding basetransform and iterator docs
1322
1323 2005-06-27  Andy Wingo  <wingo@pobox.com>
1324
1325         * docs/design/part-activation.txt: Notes on how activation should
1326         work -- not quite implemented yet.
1327
1328 2005-06-25  Wim Taymans  <wim@fluendo.com>
1329
1330         * gst/gstghostpad.c: (gst_proxy_pad_do_chain):
1331         At least get the chain function correct, needs more
1332         fixing.
1333
1334 2005-06-25  Wim Taymans  <wim@fluendo.com>
1335
1336         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
1337         (gst_basesink_handle_object), (gst_basesink_event),
1338         (gst_basesink_do_sync), (gst_basesink_handle_event),
1339         (gst_basesink_change_state):
1340         * gst/gsttask.h:
1341         Right, two problems here: ghostpads don't take locks and
1342         glib _rec_mutex_lock_full() with depth==0 still locks.
1343         Catch illegal locking and g_warn them.
1344
1345 2005-06-25  Wim Taymans  <wim@fluendo.com>
1346
1347         * check/states/sinks.c: (START_TEST), (gst_object_suite):
1348         Have to check for completion now...
1349
1350 2005-06-25  Wim Taymans  <wim@fluendo.com>
1351
1352         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
1353         (gst_basesink_handle_object), (gst_basesink_event),
1354         (gst_basesink_do_sync), (gst_basesink_handle_event),
1355         (gst_basesink_change_state):
1356         * gst/gstpad.h:
1357         Unlock STREAM_LOCK whatever the recursion was.
1358
1359 2005-06-25  Wim Taymans  <wim@fluendo.com>
1360
1361         * gst/base/gstbasesink.c: (gst_basesink_set_property),
1362         (gst_basesink_preroll_queue_empty),
1363         (gst_basesink_preroll_queue_flush), (gst_basesink_handle_object),
1364         (gst_basesink_event), (gst_basesink_do_sync),
1365         (gst_basesink_handle_event), (gst_basesink_handle_buffer),
1366         (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate),
1367         (gst_basesink_change_state):
1368         Reworked the base sink, handle event and buffer serialisation
1369         correctly and removed possible deadlock.
1370         Handle EOS correctly.
1371
1372 2005-06-25  Wim Taymans  <wim@fluendo.com>
1373
1374         * gst/gstpipeline.c: (is_eos), (pipeline_bus_handler),
1375         (gst_pipeline_change_state):
1376         * tools/gst-launch.c: (check_intr), (event_loop), (main):
1377         Allow elements to post EOS in the state change function.
1378         Fix up -launch, make it exit the poll loop when the
1379         pipeline actually changed state.
1380         Fix up warning parsing in -launch.
1381
1382 2005-06-25  Wim Taymans  <wim@fluendo.com>
1383
1384         * gst/elements/gsttee.c: (gst_tee_chain), (gst_tee_loop),
1385         (gst_tee_sink_activate):
1386         Core takes STREAM_LOCK for us now.
1387
1388 2005-06-25  Wim Taymans  <wim@fluendo.com>
1389
1390         * gst/gstelement.c: (gst_element_get_state_func),
1391         (gst_element_set_state):
1392         * gst/gstelement.h:
1393         * gst/gstmessage.c: (gst_message_parse_error),
1394         (gst_message_parse_warning):
1395         Keep track of current target state while performing a state
1396         change so that subclasses can do something interesting.
1397         Fix parsing of warning/error messages when GError is NULL.
1398
1399 2005-06-24  Thomas Vander Stichele  <thomas at apestaart dot org>
1400
1401         * docs/gst/Makefile.am:
1402         * docs/gst/gstreamer-docs.sgml:
1403         * docs/gst/gstreamer-sections.txt:
1404         * docs/gst/gstreamer.types:
1405         * docs/gst/tmpl/gstbasesink.sgml:
1406         * docs/gst/tmpl/gstbasesrc.sgml:
1407         * docs/gst/tmpl/gstbin.sgml:
1408         * docs/gst/tmpl/gstcompat.sgml:
1409         * docs/gst/tmpl/gstfakesink.sgml:
1410         * docs/gst/tmpl/gstfakesrc.sgml:
1411         * docs/gst/tmpl/gstfilesink.sgml:
1412         * docs/gst/tmpl/gstfilesrc.sgml:
1413         * docs/gst/tmpl/gstindex.sgml:
1414         * docs/manual/appendix-quotes.xml:
1415         * gst/base/gstbasesrc.h:
1416         * gst/elements/gstfakesrc.h:
1417         * gst/gstmessage.h:
1418           start pulling in base classes and elements in our docs
1419
1420 2005-06-24  Stefan Kost  <ensonic@users.sf.net>
1421
1422         * docs/gst/Makefile.am:
1423         * docs/libs/Makefile.am:
1424           fixed make distcheck with gtk-doc 1.3
1425
1426 2005-06-23  Wim Taymans  <wim@fluendo.com>
1427
1428         * gst/gstelement.c: (gst_element_get_state_func),
1429         (gst_element_set_state), (gst_element_change_state):
1430         When the state did not change, also report NO_PREROLL
1431         when it matters.
1432
1433 2005-06-23  Wim Taymans  <wim@fluendo.com>
1434
1435         * gst/gstpad.c: (gst_pad_event_default):
1436         * gst/gstqueue.c: (gst_queue_loop):
1437         No unsafe task pausing please.
1438
1439 2005-06-23  Wim Taymans  <wim@fluendo.com>
1440
1441         * gst/schedulers/threadscheduler.c:
1442         (gst_thread_scheduler_task_start),
1443         (gst_thread_scheduler_task_pause), (gst_thread_scheduler_func):
1444         Ref the task before pushing it on the threadpool. This
1445         makes sure that we have a ref when the threadfunction is
1446         actually called.
1447
1448 2005-06-23  Andy Wingo  <wingo@pobox.com>
1449
1450         * gst/base/gstbasesrc.c (gst_basesrc_get_range): Check if the
1451         offset is greater than the file's size.
1452
1453         * gst/gstobject.h (GST_CLASS_LOCK, GST_CLASS_TRYLOCK) 
1454         (GST_CLASS_UNLOCK, GST_CLASS_GET_LOCK, GstObjectClass)
1455         * gst/gstobject.c (gst_object_class_init): Make the class lock
1456         recursive. Wim won't let me drop deep_notify. Decodebin works
1457         again, whoopdy doo.
1458
1459         * gst/gstghostpad.c (on_int_notify): Catches notify::caps on the
1460         internal pad, and hacks accordingly. Doesn't do it on the target
1461         pad because we change its caps. Probably catches all cases of
1462         interest tho.
1463         (gst_ghost_pad_set_property): Connect to notify::caps as
1464         appropritate.
1465
1466         * tests/network-clock.scm (plot-simulation): Pipe data to the
1467         elite python skript.
1468
1469         * tests/network-clock-utils.scm (define-parameter): New macro,
1470         defines a parameter that can be set via the command line.
1471         (set-parameter!, parse-parameter-arguments): Command line args
1472         parser.
1473
1474         * tests/plot-data: Simple matplotlib-based plotter, takes input on
1475         stdin.
1476
1477 2005-06-23  Jan Schmidt  <thaytan@mad.scientist.com>
1478
1479         * gst/elements/gsttypefindelement.c:
1480         (gst_type_find_element_handle_event):
1481           Don't restart typefinding on a discont.
1482         * gst/gstelement.c: (gst_element_set_state):
1483           Debug spelling fix.
1484         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_send_event):
1485           Allow changing mode of an active pad.
1486           Debug output fixes.
1487         * gst/registries/gstlibxmlregistry.c: (load_feature):
1488           Don't cast a static pad template to a normal pad template.
1489
1490 2005-06-23  Thomas Vander Stichele  <thomas at apestaart dot org>
1491
1492         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
1493         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
1494           remove gst_strtoll completely, since it didn't actually do
1495           anything more than what g_ascii_strtoull already does.
1496           check for range errors when deserializing
1497           do a cast for the unsigned cases; but further fixing needs
1498           a decision on what the interpretation of "(int)" and
1499           deserialization should be for values that fall outside the
1500           type's boundaries (ie, refuse, or interpret as casting)
1501
1502 2005-06-23  Wim Taymans  <wim@fluendo.com>
1503
1504         * check/Makefile.am:
1505         * check/states/sinks.c: (START_TEST), (gst_object_suite), (main):
1506         * docs/design/part-live-source.txt:
1507         * docs/design/part-states.txt:
1508         * gst/base/gstbasesrc.c: (gst_basesrc_init),
1509         (gst_basesrc_set_live), (gst_basesrc_is_live),
1510         (gst_basesrc_get_range), (gst_basesrc_activate),
1511         (gst_basesrc_change_state):
1512         * gst/base/gstbasesrc.h:
1513         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
1514         (gst_fakesrc_set_property), (gst_fakesrc_get_property):
1515         * gst/gstbin.c: (gst_bin_get_state), (gst_bin_change_state):
1516         * gst/gstelement.c: (gst_element_get_state_func),
1517         (gst_element_set_state):
1518         * gst/gstelement.h:
1519         * gst/gsttypes.h:
1520         * tools/gst-launch.c: (event_loop), (main):
1521         Added support for live sources and other elements that
1522         cannot do preroll.
1523         Updated design docs, added live-source design doc.
1524         Implemented live source functionality in basesrc
1525         Fix error condition in _bin_get_state()
1526         Implement live source handling in -launch.
1527         Added check for live sources.
1528         Fixed case in GstBin where elements were changed state
1529         multiple times.
1530
1531
1532 2005-06-23  Andy Wingo  <wingo@pobox.com>
1533
1534         * check/gst/gstpad.c (test_get_allowed_caps, test_refcount): Fix
1535         borken refcounting.
1536
1537         * gst/gstpad.c (gst_pad_set_caps): Remove needless refs,
1538         gst_caps_replace takes care of this for us.
1539
1540         * gst/gstghostpad.c (gst_proxy_pad_do_setcaps): Call the full
1541         gst_pad_set_caps on the target, not just its setcaps() function.
1542
1543         * tests/network-clock.scm: 
1544         * tests/network-clock-utils.scm: A network clock simulator.
1545         Something of an algorithmic testbed before doing something in C.
1546
1547 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
1548
1549         * check/Makefile.am:
1550         * check/gst/capslist.h:
1551           copy over from 0.8, and add two with bitmasks specified with
1552           (int) 0xFF...
1553         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite):
1554           add test to parse everything from capslist.h
1555         * check/gst/gststructure.c: (START_TEST), (gst_value_suite),
1556         (main):
1557           add test for structure deserialization
1558         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
1559           add tests for deserialization of strings to int types
1560         * gst/gststructure.c: (gst_structure_nth_field_name):
1561         * gst/gststructure.h:
1562           add a way to get the name of a field referenced by index
1563         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
1564           instead of checking if the resulting long long lies between
1565           min and max, we check if the long long would fit into
1566           a number of bytes for the final type.
1567           This fixes cases where a string represents 2^32 - 1, which
1568           when cast to int would be the (valid) -1, but is bigger than
1569           G_MAXINT
1570
1571 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
1572
1573         * gst/parse/grammar.y:
1574           add a log line for type deserialization
1575
1576 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
1577
1578         * check/gst/gstvalue.c: (START_TEST):
1579         * gst/gstvalue.c: (gst_value_deserialize):
1580           return long long, not int, so gint64 deserialization actually
1581           works.  Is there any flag that makes the compiler check this ?
1582           Fixes #308559
1583
1584 2005-06-22  Wim Taymans  <wim@fluendo.com>
1585
1586         * gst/gstbuffer.h:
1587         Added convenience macros for setting buffers in GValue.
1588
1589 2005-06-21  Thomas Vander Stichele  <thomas at apestaart dot org>
1590
1591         * check/gst/.cvsignore:
1592         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
1593           add a test deserializing int64, and comment part out because
1594           it fails, yay !
1595
1596 2005-06-21  Thomas Vander Stichele  <thomas at apestaart dot org>
1597
1598         * check/Makefile.am:
1599         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite), (main):
1600         * testsuite/Makefile.am:
1601         * testsuite/caps/Makefile.am:
1602         * testsuite/caps/value_serialize.c:
1603         * testsuite/test_gst_init.c:
1604           move a value_serialize test over
1605
1606 2005-06-20  Wim Taymans  <wim@fluendo.com>
1607
1608         * gst/gstpad.c:
1609         Small doc updates.
1610         
1611         * gst/gstvalue.c: (gst_value_compare_buffer),
1612         (gst_value_serialize_buffer), (gst_value_deserialize_buffer),
1613         (gst_value_compare_flags), (gst_value_serialize_flags),
1614         (gst_value_deserialize_flags), (_gst_value_initialize):
1615         Fix serialisation of buffers, they are not boxed types anymore
1616
1617 2005-06-20  Wim Taymans  <wim@fluendo.com>
1618
1619         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite):
1620         Testcase to show error in buffer-on-caps serialisation.
1621
1622 2005-06-20  Andy Wingo  <wingo@pobox.com>
1623
1624         * docs/random/wingo/porting-plugins-to-0.9: A pitiful document I
1625         will be adding to later.
1626
1627         * gst/gstsystemclock.c (gst_system_clock_init): Unlock the clock
1628         if its socks fill with rocks.
1629         (gst_system_clock_obtain): Set the name on object construction.
1630         Avoid double-checked locking.
1631
1632 2005-06-20  Tim-Philipp Müller  <tim at centricular dot net>
1633
1634         * gst/gsturi.c: (gst_element_make_from_uri):
1635           Fix potential endless loop.
1636
1637 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
1638
1639         * check/Makefile.am:
1640           add gsttag
1641         * check/gst/gsttag.c: (check_tags), (START_TEST), (gst_tag_suite),
1642         (main):
1643           move over from testsuite dir and clean up
1644         * configure.ac:
1645         * gst/gsttag.c:
1646         * testsuite/Makefile.am:
1647         * testsuite/tags/.cvsignore:
1648         * testsuite/tags/Makefile.am:
1649         * testsuite/tags/merge.c:
1650           remove testsuite/tags
1651
1652 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
1653
1654         * docs/gst/gstreamer-sections.txt:
1655         * docs/gst/tmpl/gstenumtypes.sgml:
1656         * win32/gstenumtypes.c:
1657           clean up documentation build a little
1658
1659 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
1660
1661         * check/gstcheck.h:
1662           add macros for checking refcounts on objects and caps
1663         * check/gst/gstpad.c: (START_TEST), (gst_pad_suite):
1664           add some more unit tests
1665         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked),
1666         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_get_allowed_caps):
1667           fix leaked refcounts (I hope :)) so unittest works
1668         * gst/gstpad.h:
1669           whitespace removal
1670
1671 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
1672
1673         * configure.ac: back to HEAD
1674
1675 === release 0.9.1 ===
1676
1677 2005-06-17  Thomas Vander Stichele  <thomas at apestaart dot org>
1678
1679         * NEWS:
1680         * RELEASE:
1681           updated
1682
1683 2005-06-17  Andy Wingo  <wingo@pobox.com>
1684
1685         * gst/base/gstbasesink.c (gst_basesink_chain): Remove bogus
1686         assert; it's always possible that the pad gets deactivated in
1687         between the checks in gstpad.c and the implementation. Rely on
1688         finish_preroll() to return a FLUSHING or similar instead of on the
1689         assert.
1690         
1691         * gst/base/gstbasesink.c (gst_basesink_event): Only wait for the
1692         clock and post an EOS message if we come out of finish_preroll in
1693         the playing state.
1694
1695 2005-06-16  David Schleef  <ds@schleef.org>
1696
1697         * gst/elements/gstcapsfilter.c: (gst_capsfilter_class_init),
1698         (gst_capsfilter_set_property): Allow NULL as possible value
1699         for filter_caps property, indicating GST_CAPS_ANY.
1700
1701 2005-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
1702
1703         * gst/elements/gstfakesrc.c: (gst_fakesrc_create):
1704           fix debug output
1705         * gst/schedulers/Makefile.am:
1706           use libgst prefix
1707         * gstreamer.spec.in:
1708           fix spec for it
1709
1710 2005-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
1711
1712         * gstreamer.spec.in:
1713           clean up
1714
1715 2005-06-08  Andy Wingo  <wingo@pobox.com>
1716
1717         * gst/gstutils.c: RPAD fixes all around.
1718         (gst_element_link_pads): Refcounting fixes.
1719
1720         * tools/gst-inspect.c:
1721         * tools/gst-xmlinspect.c:
1722         * parse/grammar.y:
1723         * gst/base/gsttypefindhelper.c:
1724         * gst/base/gstbasesink.c:
1725         * gst/gstqueue.c: RPAD fixes.
1726
1727         * gst/gstghostpad.h:
1728         * gst/gstghostpad.c: New ghost pad implementation as full proxy
1729         pads. The tricky thing is they provide both source and sink
1730         interfaces, since they proxy the internal pad for the external
1731         pad, and vice versa. Implement with lower-level ProxyPad objects,
1732         with the interior proxy pad as a child of the exterior ghost pad.
1733         Should write a doc on this.
1734         
1735         * gst/gstpad.h: s/RPAD/PAD/, s/RealPad/Pad/.
1736         (gst_pad_set_name, gst_pad_set_parent): Macros removed, use
1737         gst_object API.
1738         
1739         * gst/gstpad.c: Big changes. No more stub base GstPad, now all
1740         pads are real pads. No ghost pads in this file. Not documenting
1741         the myriad s/RPAD/PAD/ and REALIZE fixes.
1742         (gst_pad_class_init): Add properties for "direction" and
1743         "template". Both are construct-only, so they can't change during
1744         the life of the pad. Fixes properly deriving from GstPad.
1745         (gst_pad_custom_new, gst_pad_custom_new_from_template): Gone. For
1746         derived objects, just set properties when creating the objects via
1747         g_object_new.
1748         (gst_pad_get_parent): Implement as a function, return NULL if the
1749         parent is not an element.
1750         (gst_pad_get_real_parent, gst_pad_add_ghost_pad)
1751         (gst_pad_remove_ghost_pad, gst_pad_realize): Removed.
1752         
1753         * gst/gstobject.c (gst_object_class_init): Make name a construct
1754         property. Don't set it in the object init.
1755
1756         * gst/gstelement.c (gst_element_add_pad): Don't allow adding pads
1757         with UNKNOWN direction.
1758         (gst_element_add_ghost_pad): Remove non-orthogonal API. Replace
1759         with gst_element_add_pad (e, gst_ghost_pad_new (name, pad)).
1760         (gst_element_remove_pad): Remove ghost-pad special cases.
1761         (gst_element_pads_activate): Remove rpad cruft.
1762
1763         * gst/gstbin.c (gst_bin_change_state): Use gst_pad_get_parent to
1764         catch the pad's-parent-not-an-element case.
1765
1766         * gst/gst.h: Include gstghostpad.h.
1767
1768         * gst/gst.c (init_post): No more real, ghost pads.
1769
1770         * gst/Makefile.am: Add gstghostpad.[ch].
1771
1772         * check/Makefile.am:
1773         * check/gst/gstbin.c:
1774         * check/gst/gstghostpad.c (test_ghost_pads): Check that linking
1775         into a bin creates ghost pads, and that the refcounts are right.
1776         Partly moved from gstbin.c.
1777
1778 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1779
1780         * check/gst-libs/.cvsignore:
1781         * check/gst/.cvsignore:
1782         * check/pipelines/.cvsignore:
1783           ignore more
1784         * check/pipelines/cleanup.c: (setup_pipeline), (run_pipeline),
1785         (START_TEST), (cleanup_suite), (main):
1786           add some tests related to cleanup after running pipelines
1787
1788 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1789
1790         * check/gst/gstbuffer.c: (START_TEST), (gst_test_suite), (main):
1791           add a testsuite for GstBuffer
1792
1793 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
1794
1795         * gst/gstminiobject.h:
1796           add defines for accessing the refcount
1797
1798 2005-06-03  Stefan Kost  <ensonic@users.sf.net>
1799
1800         * Makefile.am: added support for html unit test coverage reports
1801
1802 2005-06-03  Jan Schmidt  <thaytan@mad.scientist.com>
1803
1804         * gst/elements/gstcapsfilter.c: (gst_capsfilter_set_property):
1805           Free existing caps if the capsfilter changes. Add a FIXME about
1806           setting those caps on the pads.
1807
1808         * gst/gstutils.c: (gst_element_get_compatible_pad), (ghost_up):
1809           Before adding a ghost pad to a parent bin, check that there isn't
1810           already one for the element on the bin. Prevents infinite recursion
1811           when using decodebin in parse pipelines. Andy says he'll rewrite the
1812           way this works anyway, so ignore the hack.
1813
1814 2005-06-02  Andy Wingo  <wingo@pobox.com>
1815
1816         * gst/elements/gsttypefindelement.c (do_pull_typefind): Query the
1817         file size, pass it on to the type find helper.
1818
1819         * gst/base/gstbasesrc.c (gst_basesrc_do_seek): Set the
1820         segment_start and segment_end properly according to the seek
1821         method. Segment_end is still a bit flaky because offset can be
1822         negative for CUR and END cases, but it takes -1 as an "unset"
1823         value.
1824
1825 2005-06-02  Wim Taymans  <wim@fluendo.com>
1826
1827         * gst/base/gstbasesink.c: (gst_basesink_pad_buffer_alloc),
1828         (gst_base_sink_buffer_alloc), (gst_basesink_preroll_queue_push),
1829         (gst_basesink_activate):
1830         * gst/base/gstbasesink.h:
1831         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
1832         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_alloc_buffer),
1833         (gst_pad_query), (gst_pad_start_task):
1834         * gst/gstpad.h:
1835         * gst/gstqueue.c: (gst_queue_bufferalloc),
1836         (gst_queue_handle_sink_event), (gst_queue_chain):
1837         Bufferalloc: return GstFlowReturn to more accuratly report
1838         why allocation failed.
1839
1840 2005-06-02  Wim Taymans  <wim@fluendo.com>
1841
1842         * gst/gstpipeline.c: (gst_pipeline_send_event):
1843         Take snapshot of state without blocking.
1844
1845 2005-06-02  Wim Taymans  <wim@fluendo.com>
1846
1847         * docs/design/part-TODO.txt:
1848         * docs/design/part-caps.txt:
1849         * docs/design/part-clocks.txt:
1850         * docs/design/part-negotiation.txt:
1851         * docs/design/part-preroll.txt:
1852         Small doc updates 
1853
1854 2005-05-30  Wim Taymans  <wim@fluendo.com>
1855
1856         * gst/elements/gstidentity.c: (gst_identity_event),
1857         (gst_identity_transform), (gst_identity_get_property):
1858         Protect last_message property as it is accessed from
1859         multiple threads.
1860
1861 2005-05-30  Wim Taymans  <wim@fluendo.com>
1862
1863         * gst/gstelement.c: (gst_element_init),
1864         (gst_element_pads_activate), (gst_element_change_state):
1865         Slicker pad activation code.
1866
1867 2005-05-30  Wim Taymans  <wim@fluendo.com>
1868
1869         * gst/Makefile.am:
1870         * gst/gstelement.h:
1871         * gst/gstelementfactory.h:
1872         * gst/gsttypes.h:
1873         Move elementfactory methods to separate .h file.
1874
1875 2005-05-30  Wim Taymans  <wim@fluendo.com>
1876
1877         * docs/design/part-overview.txt:
1878         * gst/gstsystemclock.h:
1879         Small typo fixes, doc updates.
1880
1881 2005-05-30  Wim Taymans  <wim@fluendo.com>
1882
1883         * gst/gst.c: (gst_init_get_popt_table), (init_post),
1884         (init_popt_callback):
1885         Remove cpu-opt flag.
1886
1887 2005-05-30  Wim Taymans  <wim@fluendo.com>
1888
1889         * gst/gstbuffer.c: (gst_subbuffer_finalize),
1890         (gst_buffer_create_sub), (gst_buffer_is_span_fast):
1891         * gst/gstbuffer.h:
1892         Avoid typechecking in places where not needed.
1893         Added accessor for malloc_data.
1894
1895 2005-05-30  Wim Taymans  <wim@fluendo.com>
1896
1897         * gst/gstpad.c: (gst_real_pad_init), (gst_pad_set_active),
1898         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_accept_caps),
1899         (gst_pad_configure_sink), (gst_pad_configure_src),
1900         (gst_pad_alloc_buffer), (gst_pad_query), (gst_pad_send_event),
1901         (gst_pad_start_task):
1902         Propagate errors from _set_caps() in configure_src/sink
1903         functions instead of returning TRUE.
1904         FLUSH events can travel up and downstream
1905
1906
1907 2005-05-30  Wim Taymans  <wim@fluendo.com>
1908
1909         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_push),
1910         (gst_basesink_activate):
1911         Handle EOS in preroll.
1912
1913 2005-05-30  Wim Taymans  <wim@fluendo.com>
1914
1915         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
1916         (gst_queue_loop), (gst_queue_handle_src_event):
1917         Remove old pieces of code
1918         Flushing the queue in an upstream event is a very bad idea.
1919
1920 2005-05-26  Andy Wingo  <wingo@pobox.com>
1921
1922         * gst/gstminiobject.c (gst_value_mini_object_collect): Use
1923         gst_value_set_mini_object so as to add a ref on the object (which
1924         will be removed when the value is unset).
1925
1926         * gst/elements/gstfakesink.c (gst_fakesink_class_init): Fix signal
1927         arg type in ::handoff.
1928
1929         * gst/gstelement.c (gst_element_change_state): Also deactivate
1930         pads in READY->NULL, just in case the element didn't make it to
1931         PAUSED. Wingo tested, Wim approved.
1932
1933 2005-05-26  Wim Taymans  <wim@fluendo.com>
1934
1935         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
1936         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_alloc_buffer),
1937         (gst_pad_query), (gst_pad_send_event), (gst_pad_start_task):
1938         A flushing pad cannot be used to alloc_buffer from.
1939
1940 2005-05-26  Wim Taymans  <wim@fluendo.com>
1941
1942         * gst/gstbus.c: (gst_bus_init), (gst_bus_dispose), (gst_bus_post),
1943         (gst_bus_pop), (gst_bus_source_prepare), (gst_bus_source_check),
1944         (gst_bus_source_dispatch), (gst_bus_source_finalize),
1945         (gst_bus_create_watch), (gst_bus_add_watch_full):
1946         * gst/gstbus.h:
1947         Implement a real GSource and use g_main_context_wakeup() to
1948         signal new messages instead of the socketpair.
1949
1950 2005-05-25  Wim Taymans  <wim@fluendo.com>
1951
1952         * gst/gstbin.c: (bin_element_is_sink), (has_ancestor),
1953         (bin_element_is_semi_sink), (append_child), (gst_bin_change_state):
1954         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
1955         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_query),
1956         (gst_pad_send_event), (gst_pad_start_task):
1957         * gst/gstqueue.c: (gst_queue_init), (gst_queue_locked_flush),
1958         (gst_queue_handle_sink_event), (gst_queue_chain), (gst_queue_loop),
1959         (gst_queue_sink_activate), (gst_queue_src_activate),
1960         (gst_queue_change_state):
1961         * gst/gstqueue.h:
1962         Fix state changes for non sinks. We now change sinks, then elements
1963         with unconnected srcpads, then the rest.
1964         More efficient queue unlocking in flush and state changes.
1965         Set the pad activate mode even if it does not have an activate
1966         function.
1967
1968 2005-05-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1969
1970         * gst/base/gstbasesrc.c: (gst_basesrc_activate):
1971           Don't go in pull mode for non-seekable sources.
1972         * gst/elements/gsttypefindelement.h:
1973         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
1974         (gst_type_find_element_dispose), (gst_type_find_handle_src_query),
1975         (free_entry), (stop_typefinding),
1976         (gst_type_find_element_handle_event), (find_peek),
1977         (gst_type_find_element_chain), (do_pull_typefind),
1978         (gst_type_find_element_change_state):
1979           Allow typefinding (w/o seeking) in push-mode, simplified version
1980           of what was in 0.8.
1981         * gst/gstutils.c: (gst_buffer_join):
1982         * gst/gstutils.h:
1983           gst_buffer_join() from 0.8.
1984
1985 2005-05-25  Wim Taymans  <wim@fluendo.com>
1986
1987         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
1988         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_query),
1989         (gst_pad_send_event), (gst_pad_start_task):
1990         Disable attempt at mode switching until it is figured out.
1991
1992 2005-05-25  Wim Taymans  <wim@fluendo.com>
1993
1994         * gst/base/gstadapter.c: (gst_adapter_peek), (gst_adapter_flush):
1995         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_push),
1996         (gst_basesink_finish_preroll), (gst_basesink_chain),
1997         (gst_basesink_loop), (gst_basesink_activate),
1998         (gst_basesink_change_state):
1999         * gst/base/gstbasesrc.c: (gst_basesrc_do_seek),
2000         (gst_basesrc_get_range), (gst_basesrc_loop),
2001         (gst_basesrc_activate):
2002         * gst/elements/gsttee.c: (gst_tee_sink_activate):
2003         * gst/gstpad.c: (gst_pad_dispose), (gst_real_pad_class_init),
2004         (gst_real_pad_init), (gst_real_pad_set_property),
2005         (gst_real_pad_get_property), (gst_pad_set_active),
2006         (gst_pad_is_active), (gst_pad_get_query_types), (gst_pad_unlink),
2007         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_get_real_parent),
2008         (gst_real_pad_get_caps_unlocked), (gst_pad_peer_get_caps),
2009         (gst_pad_accept_caps), (gst_pad_get_peer), (gst_pad_realize),
2010         (gst_pad_event_default_dispatch), (gst_pad_event_default),
2011         (gst_pad_dispatcher), (gst_pad_query), (gst_real_pad_dispose),
2012         (gst_pad_save_thyself), (handle_pad_block), (gst_pad_chain),
2013         (gst_pad_push), (gst_pad_get_range), (gst_pad_pull_range),
2014         (gst_pad_send_event), (gst_pad_start_task), (gst_pad_pause_task),
2015         (gst_pad_stop_task):
2016         * gst/gstpad.h:
2017         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
2018         (gst_queue_loop), (gst_queue_src_activate):
2019         * gst/gsttask.c: (gst_task_init), (gst_task_set_lock),
2020         (gst_task_get_state):
2021         * gst/gsttask.h:
2022         * gst/schedulers/threadscheduler.c:
2023         (gst_thread_scheduler_task_start), (gst_thread_scheduler_func):
2024         Implement gst_pad_pause/start/stop_task(), take STREAM lock
2025         in task function.
2026         Remove ACTIVE pad flag, use FLUSHING everywhere
2027         Added _pad_chain(), _pad_get_range() to call chain/getrange 
2028         functions.
2029         Add locks around IS_FLUSHING when reading.
2030         Take STREAM lock in chain(), get_range() functions so plugins
2031         don't need to take it anymore.
2032         
2033
2034
2035 2005-05-25  Wim Taymans  <wim@fluendo.com>
2036
2037         * tools/gst-launch.c: (event_loop):
2038         Unref message after using its contents instead of
2039         before.
2040
2041 2005-05-24  Wim Taymans  <wim@fluendo.com>
2042
2043         * docs/design/draft-ghostpads.txt:
2044         * docs/design/draft-push-pull.txt:
2045         * docs/design/draft-query.txt:
2046         * docs/design/part-overview.txt:
2047         Docs updates, added general overview doc.
2048
2049 2005-05-21  David Schleef  <ds@schleef.org>
2050
2051         * docs/gst/tmpl/old/GstBin.sgml:
2052         * docs/gst/tmpl/old/GstBuffer.sgml:
2053         * docs/gst/tmpl/old/GstCaps.sgml:
2054         * docs/gst/tmpl/old/GstClock.sgml:
2055         * docs/gst/tmpl/old/GstCompat.sgml:
2056         * docs/gst/tmpl/old/GstData.sgml:
2057         * docs/gst/tmpl/old/GstElement.sgml:
2058         * docs/gst/tmpl/old/GstEvent.sgml:
2059         * docs/gst/tmpl/old/GstIndex.sgml:
2060         * docs/gst/tmpl/old/GstStructure.sgml:
2061         * docs/gst/tmpl/old/GstTag.sgml:
2062         * docs/gst/tmpl/old/cothreads.sgml:
2063         * docs/gst/tmpl/old/cothreads_compat.sgml:
2064         * docs/gst/tmpl/old/gettext.sgml:
2065         * docs/gst/tmpl/old/gobject2gtk.sgml:
2066         * docs/gst/tmpl/old/grammar.tab.sgml:
2067         * docs/gst/tmpl/old/gst-i18n-app.sgml:
2068         * docs/gst/tmpl/old/gst-i18n-lib.sgml:
2069         * docs/gst/tmpl/old/gst_private.sgml:
2070         * docs/gst/tmpl/old/gstaggregator.sgml:
2071         * docs/gst/tmpl/old/gstarch.sgml:
2072         * docs/gst/tmpl/old/gstatomic_impl.sgml:
2073         * docs/gst/tmpl/old/gstbufferstore.sgml:
2074         * docs/gst/tmpl/old/gstdata_private.sgml:
2075         * docs/gst/tmpl/old/gstdisksink.sgml:
2076         * docs/gst/tmpl/old/gstdisksrc.sgml:
2077         * docs/gst/tmpl/old/gstelementfactory.sgml:
2078         * docs/gst/tmpl/old/gstextratypes.sgml:
2079         * docs/gst/tmpl/old/gstfakesink.sgml:
2080         * docs/gst/tmpl/old/gstfakesrc.sgml:
2081         * docs/gst/tmpl/old/gstfdsink.sgml:
2082         * docs/gst/tmpl/old/gstfdsrc.sgml:
2083         * docs/gst/tmpl/old/gstfilesink.sgml:
2084         * docs/gst/tmpl/old/gstfilesrc.sgml:
2085         * docs/gst/tmpl/old/gsthttpsrc.sgml:
2086         * docs/gst/tmpl/old/gstidentity.sgml:
2087         * docs/gst/tmpl/old/gstindexfactory.sgml:
2088         * docs/gst/tmpl/old/gstmarshal.sgml:
2089         * docs/gst/tmpl/old/gstmd5sink.sgml:
2090         * docs/gst/tmpl/old/gstmultidisksrc.sgml:
2091         * docs/gst/tmpl/old/gstmultifilesrc.sgml:
2092         * docs/gst/tmpl/old/gstpadtemplate.sgml:
2093         * docs/gst/tmpl/old/gstpipefilter.sgml:
2094         * docs/gst/tmpl/old/gstschedulerfactory.sgml:
2095         * docs/gst/tmpl/old/gstsearchfuncs.sgml:
2096         * docs/gst/tmpl/old/gstshaper.sgml:
2097         * docs/gst/tmpl/old/gstspider.sgml:
2098         * docs/gst/tmpl/old/gstspideridentity.sgml:
2099         * docs/gst/tmpl/old/gststatistics.sgml:
2100         * docs/gst/tmpl/old/gsttee.sgml:
2101         * docs/gst/tmpl/old/gsttimecache.sgml:
2102         * docs/gst/tmpl/old/gsttypefindfactory.sgml:
2103         * docs/gst/tmpl/old/gstxmlregistry.sgml:
2104         * docs/gst/tmpl/old/gthread-cothreads.sgml:
2105         * docs/gst/tmpl/old/types.sgml:
2106           I didn't intend to add these or check them in.
2107
2108 2005-05-19  David Schleef  <ds@schleef.org>
2109
2110         * configure.ac: Use -no-common everywhere.  In a sane world, it
2111           would be the default in libtool, because without it, you can't
2112           build DLLs on Windows.
2113         * docs/gst/gstreamer-docs.sgml: Remove GstCpu, GstData, GstThread
2114         * docs/gst/gstreamer-sections.txt:
2115         * docs/gst/tmpl/gstcpu.sgml:
2116         * docs/gst/tmpl/gstdata.sgml:
2117         * docs/gst/tmpl/gstthread.sgml:
2118
2119 2005-05-19  David Schleef  <ds@schleef.org>
2120
2121         * gst/gstminiobject.c: (gst_value_set_mini_object),
2122         (gst_value_take_mini_object), (gst_value_get_mini_object):
2123         * gst/gstminiobject.h: Add GValue set/get functions.
2124
2125 2005-05-19  Wim Taymans  <wim@fluendo.com>
2126
2127         * gst/gstbuffer.c: (gst_buffer_init), (gst_subbuffer_get_type),
2128         (gst_subbuffer_class_init), (gst_subbuffer_finalize),
2129         (gst_subbuffer_init), (gst_buffer_is_span_fast):
2130         * gst/gstbuffer.h:
2131         * gst/gstbus.c: (gst_bus_post):
2132         * gst/gstelement.c: (gst_element_get_random_pad):
2133         * gst/gstmessage.c: (gst_message_init), (gst_message_finalize):
2134         Make subbufer unref the parent in finalize.
2135         some more debugging info.
2136
2137
2138 2005-05-19  Wim Taymans  <wim@fluendo.com>
2139
2140         * gst/base/gstbasesink.c: (gst_basesink_class_init),
2141         (gst_basesink_init), (gst_basesink_finalize),
2142         (gst_basesink_activate), (gst_basesink_change_state):
2143         Don't free preroll queue too early.
2144
2145 2005-05-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2146
2147         * gst/Makefile.am:
2148         * gst/ROADMAP:
2149           Hi, I'm outdated. Please shoot me.
2150
2151 2005-05-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2152
2153         * gst/gstpipeline.c: (gst_pipeline_send_event):
2154           Do not access variables after they have been deleted.
2155
2156 2005-05-19  Wim Taymans  <wim@fluendo.com>
2157
2158         * tools/gst-inspect.c: (print_plugin_features):
2159         A plugin feature does unfortunatly not use the
2160         object name yet...
2161
2162 2005-05-18  Wim Taymans  <wim@fluendo.com>
2163
2164         * gst/gstbuffer.c: (gst_buffer_is_span_fast), (gst_buffer_span):
2165         Port _span() functions to new subbuffers.
2166
2167 2005-05-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2168
2169         * gst/gstbin.c: (gst_bin_add_func):
2170           Fix clock settery in bins when adding kids after the clock has
2171           been selected.
2172
2173 2005-05-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2174
2175         * gst/elements/gstidentity.c: (gst_identity_class_init):
2176           Workaround until signals support GstMiniObject.
2177
2178 2005-05-18  Jan Schmidt  <thaytan@mad.scientist.com>
2179
2180         * gst/gstbuffer.c:
2181         Oops, fix a typo GST_TYPE_BUFFER -> GST_TYPE_SUBBUFFER.
2182
2183 2005-05-18  Wim Taymans  <wim@fluendo.com>
2184
2185         * gst/base/Makefile.am:
2186         * gst/base/gstadapter.c: (gst_adapter_base_init),
2187         (gst_adapter_class_init), (gst_adapter_init),
2188         (gst_adapter_dispose), (gst_adapter_finalize), (gst_adapter_new),
2189         (gst_adapter_clear), (gst_adapter_push), (gst_adapter_peek),
2190         (gst_adapter_flush), (gst_adapter_available),
2191         (gst_adapter_available_fast):
2192         * gst/base/gstadapter.h:
2193         Ported and added adapter to the base classes.
2194
2195 2005-05-17  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
2196
2197         * gst/gst.c:
2198         * gst/gstmessage.c:
2199           Make sure the class is reffed/unreffed once before threads can be
2200           used.  Fixes #304551.
2201
2202 2005-05-17  Wim Taymans  <wim@fluendo.com>
2203
2204         * gst/base/gstbasesink.c: (gst_basesink_finish_preroll),
2205         (gst_basesink_chain_unlocked), (gst_basesink_activate):
2206         * gst/gstminiobject.c: (gst_mini_object_get_type),
2207         (gst_mini_object_free):
2208         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_query),
2209         (gst_pad_push), (gst_pad_push_event):
2210         * gst/gstqueue.c: (gst_queue_change_state):
2211         Don't queue buffers in basesink when we are flushing.
2212         Unref buffer when flushing in basesink.
2213         Flush queue when going to READY
2214         Unref buffer when _push() returns an error.
2215         Don't free MiniObject instance when refcount is incremented
2216         in _finalize() so that we can recover objects.
2217
2218 2005-05-17  Thomas Vander Stichele  <thomas at apestaart dot org>
2219
2220         * docs/manual/advanced-schedulers.xml:
2221         * docs/manual/appendix-checklist.xml:
2222         * docs/pwg/advanced-clock.xml:
2223         * docs/pwg/advanced-interfaces.xml:
2224         * docs/pwg/advanced-request.xml:
2225         * docs/pwg/advanced-types.xml:
2226         * docs/pwg/intro-preface.xml:
2227         * examples/plugins/example.c: (gst_example_get_type),
2228         (gst_example_class_init), (gst_example_chain),
2229         (gst_example_set_property), (gst_example_get_property),
2230         (gst_example_change_state), (plugin_init):
2231         * examples/plugins/example.h:
2232           small doc fixes
2233
2234 2005-05-17  Wim Taymans  <wim@fluendo.com>
2235
2236         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_set_caps),
2237         (gst_pad_alloc_buffer), (gst_pad_query), (gst_pad_push):
2238         * gst/gstqueue.c: (gst_queue_change_state):
2239         Clear queue when going to READY.
2240         Remove IN_SETCAPS flag too.
2241
2242 2005-05-17  Tim-Philipp Müller  <tim at centricular dot net>
2243
2244         * gst/base/gstbasesrc.c: (gst_basesrc_change_state):
2245           Remove implicit cast from gboolean to GstElementStateReturn;
2246           make sure we still return failure in paused => ready case if
2247           the parent class fails to change state and our own stop 
2248           vfunc succeeds.
2249
2250 2005-05-17  Wim Taymans  <wim@fluendo.com>
2251
2252         * tools/gst-launch.c: (event_loop):
2253         Message was unreffed too soon.
2254
2255 2005-05-16  Andy Wingo  <wingo@pobox.com>
2256
2257         * gst/gstbin.c (sink_iterator_filter): Err... um...
2258
2259         * check/gst/gstbin.c (test_ghost_pads): New test for the
2260         ghosting-if-elements-not-in-same-bin behavior.
2261
2262 2005-05-16  David Schleef  <ds@schleef.org>
2263
2264         * gst/gstminiobject.c: Use g_atomic_int_get() instead of
2265         accessing refcount directly.
2266
2267 2005-05-15  David Schleef  <ds@schleef.org>
2268
2269         * check/Makefile.am: remove GstData checks
2270         * check/gst-libs/gdp.c: (START_TEST): fix for API changes
2271         * gst/Makefile.am: add miniobject, remove data
2272         * gst/gst.h: add miniobject, remove data
2273         * gst/gstdata.c: remove
2274         * gst/gstdata.h: remove
2275         * gst/gstdata_private.h: remove
2276         * gst/gsttypes.h: remove GstEvent and GstMessage
2277         * gst/gstelement.c: (gst_element_post_message): fix for API changes
2278         * gst/gstmarshal.list: change BOXED -> OBJECT
2279
2280         Implement GstMiniObject.
2281         * gst/gstminiobject.c:
2282         * gst/gstminiobject.h:
2283
2284         Modify to be subclasses of GstMiniObject.
2285         * gst/gstbuffer.c: (_gst_buffer_initialize), (gst_buffer_get_type),
2286         (gst_buffer_class_init), (gst_buffer_finalize), (_gst_buffer_copy),
2287         (gst_buffer_init), (gst_buffer_new), (gst_buffer_new_and_alloc),
2288         (gst_subbuffer_get_type), (gst_subbuffer_init),
2289         (gst_buffer_create_sub), (gst_buffer_is_span_fast),
2290         (gst_buffer_span):
2291         * gst/gstbuffer.h:
2292         * gst/gstevent.c: (_gst_event_initialize), (gst_event_get_type),
2293         (gst_event_class_init), (gst_event_init), (gst_event_finalize),
2294         (_gst_event_copy), (gst_event_new):
2295         * gst/gstevent.h:
2296         * gst/gstmessage.c: (_gst_message_initialize),
2297         (gst_message_get_type), (gst_message_class_init),
2298         (gst_message_init), (gst_message_finalize), (_gst_message_copy),
2299         (gst_message_new), (gst_message_new_error),
2300         (gst_message_new_warning), (gst_message_new_tag),
2301         (gst_message_new_state_changed), (gst_message_new_application):
2302         * gst/gstmessage.h:
2303         * gst/gstprobe.c: (gst_probe_perform),
2304         (gst_probe_dispatcher_dispatch):
2305         * gst/gstprobe.h:
2306         * gst/gstquery.c: (_gst_query_initialize), (gst_query_get_type),
2307         (gst_query_class_init), (gst_query_finalize), (gst_query_init),
2308         (_gst_query_copy), (gst_query_new):
2309
2310         Update elements for GstData -> GstMiniObject changes
2311         * gst/gstquery.h:
2312         * gst/gstqueue.c: (gst_queue_finalize), (gst_queue_locked_flush),
2313         (gst_queue_chain), (gst_queue_loop):
2314         * gst/elements/gstbufferstore.c:
2315         (gst_buffer_store_add_buffer_func),
2316         (gst_buffer_store_cleared_func), (gst_buffer_store_get_buffer):
2317         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
2318         (gst_fakesink_render):
2319         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
2320         * gst/elements/gstfilesrc.c: (gst_mmap_buffer_get_type),
2321         (gst_mmap_buffer_class_init), (gst_mmap_buffer_init),
2322         (gst_mmap_buffer_finalize), (gst_filesrc_map_region),
2323         (gst_filesrc_create_read):
2324         * gst/elements/gstidentity.c: (gst_identity_class_init):
2325         * gst/elements/gsttypefindelement.c:
2326         (gst_type_find_element_src_event), (free_entry_buffers),
2327         (gst_type_find_element_handle_event):
2328         * libs/gst/dataprotocol/dataprotocol.c:
2329         (gst_dp_header_from_buffer):
2330         * libs/gst/dataprotocol/dataprotocol.h:
2331         * libs/gst/dataprotocol/dp-private.h:
2332
2333 2005-05-15  David Schleef  <ds@schleef.org>
2334
2335         * gst/elements/gstelements.c: Don't include headers that were
2336         just removed.
2337
2338 2005-05-15  David Schleef  <ds@schleef.org>
2339
2340         * gst/elements/Makefile.am: Remove some elements that don't
2341         need to be in the core (or even exist at all).
2342         * gst/elements/gstaggregator.c:
2343         * gst/elements/gstaggregator.h:
2344         * gst/elements/gstmd5sink.c:
2345         * gst/elements/gstmd5sink.h:
2346         * gst/elements/gstmultifilesrc.c:
2347         * gst/elements/gstmultifilesrc.h:
2348         * gst/elements/gstpipefilter.c:
2349         * gst/elements/gstpipefilter.h:
2350         * gst/elements/gstshaper.c:
2351         * gst/elements/gstshaper.h:
2352         * gst/elements/gststatistics.c:
2353         * gst/elements/gststatistics.h:
2354         * po/POTFILES.in: Remove above files.
2355
2356 2005-05-14  Andy Wingo  <wingo@pobox.com>
2357
2358         * gst/gstbin.c (gst_bin_iterate_sinks): Use sink_iterator_filter
2359         so as to get the refs right.
2360         (sink_iterator_filter): New function, wraps bin_element_is_sink,
2361         unreffing objects that don't pass the filter.
2362
2363         * gst/gstpipeline.c (gst_pipeline_init): Drop ref on bus after
2364         gst_element_set_bus.
2365         (gst_pipeline_dispose): Set the bus on the pipeline to NULL. In
2366         normal cases, this will destroy the bus.
2367
2368         * gst/gstutils.c (prepare_link_maybe_ghosting): Drop ref on root
2369         object.
2370
2371         * gst/gstbin.c (gst_bin_change_state): Fix state changes if a bin
2372         has no sinks.
2373
2374 2005-05-13  Andy Wingo  <wingo@pobox.com>
2375
2376         * gst/gstutils.c (gst_element_link_pads): Instead of calling
2377         gst_pad_link, call pad_link_maybe_ghosting,
2378         (pad_link_maybe_ghosting): Links pads, making sure that the
2379         elements being linked are in the same bin.
2380         (find_common_root, object_has_ancestor, ghost_up, remove_pad):
2381         Helpers for pad_link_maybe_ghosting.
2382
2383 2005-05-13  Tim-Philipp Müller  <tim at centricular dot net>
2384
2385         * configure.ac:
2386           Require GLib >= 2.4.0 (for the g_atomic_* funcs)
2387
2388 2005-05-13  Tim-Philipp Müller  <tim at centricular dot net>
2389
2390         * docs/design/part-element-source.txt:
2391           Mention GstPushSrc
2392
2393 2005-05-12  Wim Taymans  <wim@fluendo.com>
2394
2395         * gst/base/gstbasesink.c: (gst_basesink_init),
2396         (gst_basesink_activate):
2397         * gst/base/gstbasesrc.c: (gst_basesrc_unlock),
2398         (gst_basesrc_is_seekable):
2399         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_remove_func),
2400         (bin_element_is_sink), (gst_bin_change_state):
2401         * gst/gstelement.c: (gst_element_add_pad), (gst_element_query):
2402         * gst/gstelement.h:
2403         Identify sinks by their flag to avoid overly complicated
2404         checks (fow now).
2405         Do state changes even for elements not reachable from the
2406         sinks.
2407         BaseSink is a sink now :)
2408         Some more debugging info in the basesrc.
2409
2410
2411 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2412
2413         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_query):
2414           Implement _query on a bin, similar to _send_event.
2415
2416 2005-05-12  Tim-Philipp Müller  <tim at centricular dot net>
2417
2418         * gst/base/gstbasesrc.c: (gst_basesrc_do_seek):
2419           Discont event offset format should be GST_FORMAT_BYTES,
2420           not GST_FORMAT_TIME.
2421
2422 2005-05-12  Wim Taymans  <wim@fluendo.com>
2423
2424         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_get_state):
2425         Same fix as Ronald's but without the signal. 
2426
2427 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2428
2429         * gst/gstutils.c: (gst_element_query_position):
2430           No, an element is not a pad.
2431
2432 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2433
2434         * gst/gstbin.c: (gst_bin_add_func), (cb_parent_unset),
2435         (gst_bin_get_state):
2436           If a child is removed from a bin while we remove the child from
2437           the bin and while we're retrieving its state, signal this to the
2438           get_state function so we abort the wait (instead of waiting for
2439           a timeout) and can immediately re-iterate over all other elements.
2440
2441 2005-05-12  Wim Taymans  <wim@fluendo.com>
2442
2443         * gst/base/Makefile.am:
2444         * gst/base/gstbasesrc.c: (gst_basesrc_is_seekable),
2445         (gst_basesrc_start):
2446         * gst/base/gstbasesrc.h:
2447         * gst/base/gstpushsrc.c: (gst_pushsrc_get_type),
2448         (gst_pushsrc_base_init), (gst_pushsrc_class_init),
2449         (gst_pushsrc_init), (gst_pushsrc_create):
2450         * gst/base/gstpushsrc.h:
2451         Added is_seekable to BaseSrc
2452         Added simple PushSrc.
2453
2454 2005-05-11  Wim Taymans  <wim@fluendo.com>
2455
2456         * gst/gstelement.c: (gst_element_add_pad), (gst_element_query):
2457         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
2458         (gst_element_link_pads), (gst_element_query_position),
2459         (gst_element_query_convert), (intersect_caps_func),
2460         (gst_pad_query_position), (gst_pad_query_convert):
2461         Fix refcounting in utils function.
2462         No point in trying to activate a pad when it's added, it could
2463         be added from the state change function and then we deadlock, the
2464         element has to decide what to do.
2465
2466 2005-05-10  Andy Wingo  <wingo@pobox.com>
2467
2468         * gst/elements/gstfakesink.c (gst_fakesink_render): Er, emit with
2469         *all* the arguments.
2470
2471         * gst/base/gstbasetransform.c (gst_base_transform_event): Grab the
2472         stream lock if it's a FLUSH_DONE; normal flushes don't get the
2473         lock (according to the docs -- if this is wrong change the docs).
2474
2475         * gst/gstpipeline.c (gst_pipeline_change_state): Set the bus to
2476         flush messages in the NULL state.
2477
2478         * gst/gstbus.c (gst_bus_post): If a bus is flushing, unref the
2479         message immediately and return.
2480         (gst_bus_set_flushing): New function. If a bus is flushing, it
2481         flushes out any queued messages and immediately unrefs new
2482         messages. This is so when an element goes to NULL, all of the
2483         unhandled messages coming from it can be freed, and their
2484         references to the element dropped. In other words: message source
2485         ref considered harmful :P
2486
2487         * gst/gstbin.c (gst_bin_change_state): Unref peer element when
2488         we're finished with it.
2489
2490         * gst/gstmessage.c (gst_message_new_state_changed): 
2491
2492 2005-05-10  Wim Taymans  <wim@fluendo.com>
2493
2494         * gst/gstvalue.c: (gst_value_compare_flags),
2495         (gst_value_serialize_flags), (gst_value_deserialize_flags),
2496         (_gst_value_initialize):
2497         Added flags serialize/deserialize/compare code.
2498
2499 2005-05-09  Andy Wingo  <wingo@pobox.com>
2500
2501         * gst/base/gstbasetransform.c (gst_base_transform_proxy_getcaps):
2502         Intersect the peer's caps with our caps.
2503
2504 2005-05-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2505
2506         * gst/base/gsttypefindhelper.c: (helper_find_peek):
2507         * gst/elements/gsttypefindelement.c: (find_peek):
2508           Handle negative offsets better. Fixes decodebin.
2509
2510 2005-05-09  Wim Taymans  <wim@fluendo.com>
2511
2512         * gst/base/gstbasetransform.c: (gst_base_transform_proxy_getcaps),
2513         (gst_base_transform_event):
2514         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_query):
2515         Implement accept_caps.
2516         Fix silly lock/unlock mismatch in base class.
2517
2518 2005-05-09  Wim Taymans  <wim@fluendo.com>
2519
2520         * docs/design/draft-push-pull.txt:
2521         * gst/base/gstbasesrc.c: (gst_basesrc_init), (gst_basesrc_query):
2522         * gst/elements/gstfilesink.c: (gst_filesink_init),
2523         (gst_filesink_query):
2524         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
2525         (gst_type_find_handle_src_query), (find_element_get_length):
2526         * gst/gstelement.c: (gst_element_seek), (gst_element_query):
2527         * gst/gstelement.h:
2528         * gst/gstmessage.c:
2529         * gst/gstmessage.h:
2530         * gst/gstpad.c: (gst_real_pad_init), (gst_pad_get_query_types),
2531         (gst_real_pad_get_caps_unlocked),
2532         (gst_pad_get_internal_links_default), (gst_pad_get_internal_links),
2533         (gst_pad_event_default_dispatch), (gst_pad_event_default),
2534         (gst_pad_dispatcher), (gst_pad_query), (gst_pad_query_default),
2535         (gst_real_pad_dispose), (gst_real_pad_finalize),
2536         (gst_pad_load_and_link), (gst_pad_save_thyself),
2537         (gst_ghost_pad_save_thyself), (handle_pad_block), (gst_pad_push),
2538         (gst_pad_check_pull_range), (gst_pad_pull_range),
2539         (gst_pad_template_get_type), (gst_pad_template_class_init),
2540         (gst_pad_template_init), (gst_pad_template_dispose),
2541         (name_is_valid), (gst_static_pad_template_get),
2542         (gst_pad_template_new), (gst_static_pad_template_get_caps),
2543         (gst_pad_template_get_caps), (gst_pad_set_element_private),
2544         (gst_pad_get_element_private), (gst_pad_start_task),
2545         (gst_pad_pause_task), (gst_pad_stop_task),
2546         (gst_ghost_pad_get_type), (gst_ghost_pad_class_init),
2547         (gst_ghost_pad_init), (gst_ghost_pad_dispose),
2548         (gst_ghost_pad_set_property), (gst_ghost_pad_get_property),
2549         (gst_ghost_pad_new):
2550         * gst/gstpad.h:
2551         * gst/gstquery.c: (_gst_query_initialize), (gst_query_new),
2552         (gst_query_new_position), (gst_query_set_position),
2553         (gst_query_parse_position), (gst_query_new_convert),
2554         (gst_query_set_convert), (gst_query_parse_convert):
2555         * gst/gstquery.h:
2556         * gst/gstqueryutils.c:
2557         * gst/gstqueryutils.h:
2558         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
2559         (gst_queue_bufferalloc), (gst_queue_handle_sink_event),
2560         (gst_queue_handle_src_query):
2561         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
2562         (gst_element_query_position), (gst_element_query_convert),
2563         (intersect_caps_func), (gst_pad_query_position),
2564         (gst_pad_query_convert):
2565         * gst/gstutils.h:
2566         * tools/gst-inspect.c: (print_pad_info):
2567         * tools/gst-xmlinspect.c: (print_element_info):
2568         Remove old query functions. Ported old code.
2569         Added position/convert helper functions to gstutils.
2570         Reordered gstpad.c code, grouping relevant things.
2571         Remove gst_message_new(), always need to speficy a specific
2572         message.
2573
2574
2575 2005-05-09  Andy Wingo  <wingo@pobox.com>
2576
2577         * gst/gstiterator.h: Add some includes.
2578
2579         * gst/gstqueryutils.h: Include more headers.
2580
2581         * gst/gstpad.h:
2582         * gst/gstpad.c (gst_pad_query_position): New routine, replaces
2583         some uses of gst_pad_query.
2584
2585         * gst/gstqueryutils.c: Build fixes. Make parse functions ignore
2586         NULL out parameters.
2587         (gst_query_new_position): New proc, allocates a new position
2588         query.
2589
2590         * gst/Makefile.am (libgstreamer_@GST_MAJORMINOR@_la_SOURCES): Add
2591         gstqueryutils.c to the build.
2592
2593         * gst/gststructure.c (gst_structure_set_valist): Implement with
2594         the generic G_VALUE_COLLECT.
2595         
2596 2005-05-08  Edward Hervey  <bilboed@bilboed.com>
2597
2598         * gst/Makefile.am: (gst_headers):
2599         Added gstqueryutils.h to the list of headers to install, that was
2600         a 'nachty' move wingo :)
2601
2602 2005-05-06  Andy Wingo  <wingo@pobox.com>
2603
2604         * gst/gstquery.h
2605         * gst/gstquery.c (_gst_query_initialize): Extend GstQuery from
2606         GstData, init a memchunk.
2607         (standard_definitions): Add a few query types, deprecate a few.
2608         (gst_query_get_type): New proc.
2609         (_gst_query_copy, _gst_query_free, gst_query_new): GstData
2610         implementation.
2611         (gst_query_new_application, gst_query_get_structure): New public
2612         procs.
2613
2614         * docs/design/draft-query.txt: Removed LINKS from the query types,
2615         because all the rest can be dispatched to other pads -- seemed
2616         ugly to have a query that couldn't be dispatched. internal_links
2617         is fine as a pad method.
2618
2619         * gst/gstpad.h: Add query2 as a pad method, add the new functions
2620         in gstpad.c, but maintain binary compatibility for the moment.
2621         Will fix before 0.9 is out.
2622
2623         * gst/gstqueryutils.c: 
2624         * gst/gstqueryutils.h: New files, implement 3 methods for each
2625         query type: parse_query, parse_response, and set. Probably need an
2626         allocator as well.
2627
2628         * gst/gst.h: Add gstquery.h and gstqueryutils.h to the list.
2629
2630         * gst/elements/gstfilesink.c (gst_filesink_query2):
2631         * gst/base/gstbasesrc.c (gst_basesrc_query2): Replace old query,
2632         query_types, and formats methods.
2633
2634         * gst/gstpad.c (gst_pad_query2, gst_pad_query2_default)
2635         (gst_pad_set_query2_function): New functions.
2636         (gst_real_pad_init): Set query2_default as the default query2
2637         function. Basically just dispatches to internally linked pads.
2638
2639         Needs review!
2640         
2641         * gst/gstdata_private.h (_GST_DATA_INIT): Set data->refcount to 1
2642         without using the atomic operations. Only one thread can possibly
2643         be accessing the data at this point. Changed so as to avoid
2644         gst_atomic operations.
2645
2646 2005-05-06  Wim Taymans  <wim@fluendo.com>
2647
2648         * gst/gstpad.c: (gst_pad_alloc_buffer), (gst_pad_push):
2649         Also set caps if we use the fallback buffer alloc.
2650
2651 2005-05-06  Tim-Philipp Müller  <tim at centricular dot net>
2652
2653         * docs/gst/Makefile.am:
2654         * docs/gst/gstreamer-docs.sgml:
2655         * docs/gst/gstreamer-sections.txt:
2656         * docs/gst/tmpl/gstatomic.sgml:
2657         * docs/gst/tmpl/gstmemchunk.sgml:
2658         * testsuite/elements/struct_i386.h:
2659         * win32/GStreamer.vcproj:
2660         * win32/Makefile:
2661           Purge GstAtomic stuff from docs and win32 makefiles as well
2662
2663 2005-05-06  Wim Taymans  <wim@fluendo.com>
2664
2665         * gst/base/gstbasetransform.c: (gst_base_transform_proxy_getcaps):
2666         * gst/elements/gstcapsfilter.c: (gst_capsfilter_getcaps):
2667         * gst/gstpad.c: (gst_pad_peer_get_caps):
2668         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
2669         (gst_queue_bufferalloc), (gst_queue_handle_sink_event),
2670         (gst_queue_src_activate), (gst_queue_change_state):
2671         * gst/gstqueue.h:
2672         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
2673         (intersect_caps_func):
2674         Fix gst_pad_peer_get_caps(), make it return NULL if no peer.
2675         Always take QUEUE_LOCK after STREAM_LOCK or we might deadlock.
2676         Some fixes for the peer_get_caps() change.
2677
2678 2005-05-06  Wim Taymans  <wim@fluendo.com>
2679
2680         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
2681         (gst_basesink_handle_buffer), (gst_basesink_chain_unlocked),
2682         (gst_basesink_activate):
2683         Actually do something with error codes returned from the push
2684         functions.
2685
2686 2005-05-06  Wim Taymans  <wim@fluendo.com>
2687
2688         * docs/design/part-element-sink.txt:
2689         * docs/design/part-element-source.txt:
2690         * gst/base/gstbasesink.c: (gst_basesink_class_init),
2691         (gst_basesink_event), (gst_basesink_activate):
2692         * gst/base/gstbasesink.h:
2693         * gst/base/gstbasesrc.c: (gst_basesrc_init), (gst_basesrc_unlock),
2694         (gst_basesrc_activate):
2695         * gst/base/gstbasesrc.h:
2696         * gst/gstelement.c: (gst_element_pads_activate):
2697         Some more documentation.
2698         Fixed scheduling decision in _pads_activate().
2699
2700 2005-05-05  Andy Wingo  <wingo@pobox.com>
2701
2702         * check/pipelines/simple_launch_lines.c (test_2_elements): "Fix"
2703         the test suite.
2704
2705 2005-05-05  Wim Taymans  <wim@fluendo.com>
2706
2707         * gst/base/Makefile.am:
2708         * gst/base/gstbasesink.h:
2709         * gst/base/gstbasesrc.c: (gst_basesrc_init),
2710         (gst_basesrc_set_dataflow_funcs), (gst_basesrc_query):
2711         * gst/base/gstcollectpads.c: (gst_collectpads_get_type),
2712         (gst_collectpads_class_init), (gst_collectpads_init),
2713         (gst_collectpads_finalize), (gst_collectpads_new),
2714         (gst_collectpads_set_function), (gst_collectpads_add_pad),
2715         (find_pad), (gst_collectpads_remove_pad),
2716         (gst_collectpads_is_active), (gst_collectpads_collect),
2717         (gst_collectpads_collect_range), (gst_collectpads_start),
2718         (gst_collectpads_stop), (gst_collectpads_peek),
2719         (gst_collectpads_pop), (gst_collectpads_available),
2720         (gst_collectpads_read), (gst_collectpads_flush),
2721         (gst_collectpads_chain):
2722         * gst/base/gstcollectpads.h:
2723         * gst/elements/Makefile.am:
2724         * gst/elements/gstelements.c:
2725         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
2726         (gst_fakesink_get_times), (gst_fakesink_event),
2727         (gst_fakesink_preroll), (gst_fakesink_render):
2728         * gst/elements/gstfilesink.c: (gst_filesink_class_init),
2729         (gst_filesink_init), (gst_filesink_set_location),
2730         (gst_filesink_open_file), (gst_filesink_close_file),
2731         (gst_filesink_pad_query), (gst_filesink_event),
2732         (gst_filesink_render), (gst_filesink_change_state):
2733         * gst/elements/gstfilesink.h:
2734         Added object to help in making collect pad based elements.
2735         Ported filesink.
2736         Make event function in sink baseclass return gboolean.
2737
2738 2005-05-05  Wim Taymans  <wim@fluendo.com>
2739
2740         * gst/gstbin.c: (gst_bin_send_event), (compare_name),
2741         (gst_bin_get_by_name):
2742         * gst/gstbuffer.h:
2743         * gst/gstclock.c: (gst_clock_entry_new), (gst_clock_class_init),
2744         (gst_clock_finalize):
2745         * gst/gstdata.c: (gst_data_replace):
2746         * gst/gstdata.h:
2747         * gst/gstelement.c: (gst_element_request_pad),
2748         (gst_element_pads_activate):
2749         * gst/gstobject.c: (gst_object_init), (gst_object_ref),
2750         (gst_object_unref):
2751         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
2752         (gst_pad_set_checkgetrange_function),
2753         (gst_pad_link_check_compatible_unlocked), (gst_pad_set_caps),
2754         (gst_pad_check_pull_range), (gst_pad_pull_range),
2755         (gst_static_pad_template_get_caps), (gst_pad_start_task),
2756         (gst_pad_pause_task), (gst_pad_stop_task):
2757         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
2758         (gst_element_request_pad), (gst_pad_proxy_getcaps):
2759         Fix name lookup in GstBin.
2760         Added _data_replace() function and _buffer_replace()
2761         Use finalize method to clean up clock.
2762         Fix refcounting on request pads.
2763         Fix pad schedule mode error.
2764         Some more object refcounting debug info,
2765
2766
2767 2005-05-04  Andy Wingo <wingo@pobox.com>
2768
2769         * check/Makefile.am:
2770         * docs/gst/tmpl/gstatomic.sgml:
2771         * docs/gst/tmpl/gstplugin.sgml:
2772         * gst/base/gstbasesink.c: (gst_basesink_activate):
2773         * gst/base/gstbasesrc.c: (gst_basesrc_class_init),
2774         (gst_basesrc_init), (gst_basesrc_set_dataflow_funcs),
2775         (gst_basesrc_query), (gst_basesrc_set_property),
2776         (gst_basesrc_get_property), (gst_basesrc_check_get_range),
2777         (gst_basesrc_activate):
2778         * gst/base/gstbasesrc.h:
2779         * gst/base/gstbasetransform.c: (gst_base_transform_sink_activate),
2780         (gst_base_transform_src_activate):
2781         * gst/elements/gstelements.c:
2782         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
2783         (gst_fakesrc_set_property), (gst_fakesrc_get_property):
2784         * gst/elements/gsttee.c: (gst_tee_sink_activate):
2785         * gst/elements/gsttypefindelement.c: (find_element_get_length),
2786         (gst_type_find_element_checkgetrange),
2787         (gst_type_find_element_activate):
2788         * gst/gstbin.c: (gst_bin_save_thyself), (gst_bin_restore_thyself):
2789         * gst/gstcaps.c: (gst_caps_do_simplify), (gst_caps_save_thyself),
2790         (gst_caps_load_thyself):
2791         * gst/gstelement.c: (gst_element_pads_activate),
2792         (gst_element_save_thyself), (gst_element_restore_thyself):
2793         * gst/gstpad.c: (gst_pad_load_and_link), (gst_pad_save_thyself),
2794         (gst_ghost_pad_save_thyself), (gst_pad_check_pull_range):
2795         * gst/gstpad.h:
2796         * gst/gstxml.c: (gst_xml_write), (gst_xml_parse_doc),
2797         (gst_xml_parse_file), (gst_xml_parse_memory),
2798         (gst_xml_get_element), (gst_xml_make_element):
2799         * gst/indexers/gstfileindex.c: (gst_file_index_load),
2800         (_file_index_id_save_xml), (gst_file_index_commit):
2801         * gst/registries/gstlibxmlregistry.c: (read_string), (read_uint),
2802         (read_enum), (load_pad_template), (load_feature), (load_plugin),
2803         (load_paths):
2804         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_caps),
2805         (gst_dp_packet_from_event), (gst_dp_caps_from_packet):
2806         * tools/gst-complete.c: (main):
2807         * tools/gst-compprep.c: (main):
2808         * tools/gst-inspect.c: (print_element_properties_info):
2809         * tools/gst-launch.c: (xmllaunch_parse_cmdline):
2810         * tools/gst-xmlinspect.c: (print_element_properties):
2811         GCC 4 fixen.
2812         
2813 2005-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
2814
2815         * gst/gstplugin.c: (gst_plugin_check_module),
2816         (gst_plugin_check_file), (gst_plugin_load_file):
2817             apply patch from #172526 to make register work on MacOSX
2818
2819 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
2820
2821         * docs/gst/tmpl/gstconfig.sgml:
2822         * gst/gstconfig.h.in:
2823           move documentation for some symbols.  Add doc for GST_PTR_FORMAT
2824         * testsuite/debug/printf_extension.c: (main):
2825           Do not use GST_PTR_FORMAT on pointers to types with
2826           sizeof < sizeof(gpointer).  Fixes test on 64-bit
2827         * testsuite/elements/property.h:
2828           use correct printf format
2829
2830 2005-05-02  Wim Taymans  <wim@fluendo.com>
2831
2832         * docs/design/draft-push-pull.txt:
2833         * docs/design/draft-query.txt:
2834         * gst/base/gstbasesrc.c: (gst_basesrc_get_range_unlocked),
2835         (gst_basesrc_start):
2836         Added draft for new query API.
2837         Added draft for better selecting scheduling methods.
2838         Make basesrc ignore length if the subclass does not support
2839         it.
2840
2841 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
2842
2843         * gst/Makefile.am:
2844           possible fixes for automake-1.5 - _LIBADD is reserved
2845
2846 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
2847
2848         * docs/faq/Makefile.am:
2849         * docs/manual/Makefile.am:
2850         * docs/manuals.mak:
2851         * docs/pwg/Makefile.am:
2852         * gst/Makefile.am:
2853           possible fixes for automake-1.5
2854
2855 2005-04-28  Wim Taymans  <wim@fluendo.com>
2856
2857         * gst/base/gstbasesink.c: (gst_basesink_base_init),
2858         (gst_basesink_pad_getcaps), (gst_basesink_init),
2859         (gst_basesink_do_sync):
2860         * gst/gstclock.c: (gst_clock_entry_new):
2861         * gst/gstevent.c: (gst_event_discont_get_value):
2862         * gst/gstpipeline.c: (pipeline_bus_handler),
2863         (gst_pipeline_change_state):
2864         * gst/gstsystemclock.c: (gst_system_clock_id_wait_unlocked):
2865         Better debugging of clocking info.
2866         Allow NULL values when getting discont values.
2867
2868 2005-04-27  Wim Taymans  <wim@fluendo.com>
2869
2870         * check/gst/gstobject.c: (START_TEST), (gst_object_suite):
2871         * check/gst/gstpad.c: (gst_pad_suite):
2872         Increase timeout for checks.
2873
2874 2005-04-27  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
2875
2876         * check/Makefile.am:
2877           fix the broken rule for cleanup.  Apparently this rule is
2878           only needed on FC2, so maybe this warrants further autotool
2879           inspection.
2880
2881 2005-04-26  Wim Taymans  <wim@fluendo.com>
2882
2883         * gst/gsttrashstack.h:
2884         Ooohh. a nasty one! After having a failed pop() from the stack,
2885         it's possible that the stack is empty. In that case, don't
2886         follow the NULL pointer.
2887
2888 2005-04-25  Wim Taymans  <wim@fluendo.com>
2889
2890         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
2891         (gst_pad_set_checkgetrange_function),
2892         (gst_pad_link_check_compatible_unlocked), (gst_pad_link_prepare),
2893         (gst_pad_check_pull_range), (gst_pad_pull_range),
2894         (gst_static_pad_template_get_caps), (gst_pad_start_task),
2895         (gst_pad_pause_task), (gst_pad_stop_task):
2896         * gst/gstplugin.c: (gst_plugin_load):
2897         * gst/gstplugin.h:
2898         Remove gst_library_load as it does more harm than good with
2899         the new g_module flags.
2900         Revert bogus caps template check in pad linking, pad caps
2901         are important when linking not the template, which is more
2902         general than the current caps.
2903
2904 2005-04-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2905
2906         * gst/autoplug/.cvsignore:
2907         * gst/autoplug/Makefile.am:
2908         * gst/autoplug/gstsearchfuncs.c:
2909         * gst/autoplug/gstsearchfuncs.h:
2910         * gst/autoplug/gstspider.c:
2911         * gst/autoplug/gstspider.h:
2912         * gst/autoplug/gstspideridentity.c:
2913         * gst/autoplug/gstspideridentity.h:
2914         * gst/autoplug/spidertest.c:
2915           Die, spider, die.
2916
2917 2005-04-25  Wim Taymans  <wim@fluendo.com>
2918
2919         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
2920         (gst_pad_set_checkgetrange_function), (gst_pad_check_pull_range),
2921         (gst_pad_pull_range), (gst_static_pad_template_get_caps),
2922         (gst_pad_start_task), (gst_pad_pause_task), (gst_pad_stop_task):
2923         * gst/gstpad.h:
2924         Added stubs for unimplemented functions. 
2925
2926 2005-04-24  David Schleef  <ds@schleef.org>
2927
2928         * gst/gstpad.h: Disable some unimplemented functions.  Wim,
2929         please fix.
2930
2931 2005-04-24  David Schleef  <ds@schleef.org>
2932
2933         Convert everything from GstAtomicInt to g_atomic_int_*, and
2934         remove gstatomic.
2935         * gst/Makefile.am:
2936         * gst/gstatomic.c:
2937         * gst/gstatomic.h:
2938         * gst/gstatomic_impl.h:
2939         * gst/gstbuffer.c:
2940         * gst/gstcaps.c:
2941         * gst/gstcaps.h:
2942         * gst/gstclock.c:
2943         * gst/gstclock.h:
2944         * gst/gstdata.c:
2945         * gst/gstdata.h:
2946         * gst/gstdata_private.h:
2947         * gst/gstevent.c:
2948         * gst/gstinfo.c:
2949         * gst/gstinfo.h:
2950         * gst/gstmessage.c:
2951         * gst/gstobject.c:
2952         * gst/gstobject.h:
2953         * gst/gststructure.c:
2954         * gst/gststructure.h:
2955         * gst/gstutils.c: Add gst_atomic_int_set() compaitibility function.
2956         * gst/gstutils.h:
2957
2958 2005-04-24  David Schleef  <ds@schleef.org>
2959
2960         * check/gst/gstpad.c: (START_TEST): Oh yeah, it's always nice to
2961         make the regressions tests work.  Remove some code that is no
2962         longer true.
2963         * gst/gstpad.c: (gst_pad_link_check_templates_compatible_unlocked):
2964         Disable warning for pads without templates.
2965
2966 2005-04-24  David Schleef  <ds@schleef.org>
2967
2968         * gst/gstpad.c: Remove handling of filtered caps.  Fix/merge
2969         functions that handle filtered links.
2970         * gst/gstpad.h: Remove 'appfilter' field and prototypes of
2971         removed functions.
2972         * gst/gstutils.c: Fix/remove utility functions that handle
2973         filtered caps.
2974         * gst/gstutils.h:
2975         * gst/gstvalue.c: Add serialization/deserialization of caps
2976         * gst/parse/grammar.y: Ignore filtered caps when linking.  This
2977         requires fixing so that the filter caps notation creates
2978         a capsfilter element and sets the filter_caps property.  I
2979         think everyone probably wants to keep the shorthand notation.
2980         * docs/gst/tmpl/gstelement.sgml: updates for API changes.
2981         * docs/gst/tmpl/gstpad.sgml:
2982
2983         * gst/elements/gstelements.c: Register capsfilter element.
2984         * gst/Makefile.am: fix spacing
2985         * docs/random/ds/0.9-suggested-changes: random
2986
2987 2005-04-23  David Schleef  <ds@schleef.org>
2988
2989         * gst/elements/Makefile.am:
2990         * gst/elements/gstcapsfilter.c: New element that acts like an
2991         identity, but filters caps.  Will eventually replace filtered
2992         caps in pad linking.
2993         * gst/gstutils.c: (gst_element_create_all_pads): New function
2994         to create all the ALWAYS pads that are registered with an
2995         element class.  This functionality should eventually be
2996         merged in with GstElement initialization.
2997         * gst/gstutils.h:
2998         * testsuite/trigger/README: part of trigger test code that should
2999         have been checked in a long time ago.
3000
3001 2005-04-23  David Schleef  <ds@schleef.org>
3002
3003         * gst/Makefile.am: Remove as-libtool stuff.  It's likely not
3004         needed with new versions of libtool (nobody will confirm this),
3005         and hard to carry around.
3006         * gst/autoplug/Makefile.am:
3007         * gst/base/Makefile.am:
3008         * gst/elements/Makefile.am:
3009         * gst/indexers/Makefile.am:
3010         * gst/schedulers/Makefile.am:
3011         * libs/gst/bytestream/Makefile.am:
3012         * libs/gst/control/Makefile.am:
3013         * libs/gst/dataprotocol/Makefile.am:
3014         * libs/gst/getbits/Makefile.am:
3015
3016 2005-04-21  Wim Taymans  <wim@fluendo.com>
3017
3018         * docs/design/draft-push-pull.txt:
3019         * docs/design/part-MT-refcounting.txt:
3020         * docs/design/part-TODO.txt:
3021         * docs/design/part-caps.txt:
3022         * docs/design/part-events.txt:
3023         * docs/design/part-gstbus.txt:
3024         * docs/design/part-gstpipeline.txt:
3025         * docs/design/part-messages.txt:
3026         * docs/design/part-push-pull.txt:
3027         * docs/design/part-query.txt:
3028         Some more docs.
3029
3030 2005-04-21  Wim Taymans  <wim@fluendo.com>
3031
3032         * gst/gstmessage.c: (_gst_message_copy), (_gst_message_free),
3033         (gst_message_new), (gst_message_new_error),
3034         (gst_message_new_warning), (gst_message_new_tag),
3035         (gst_message_new_state_changed), (gst_message_new_application),
3036         (gst_message_get_structure):
3037         * gst/gstmessage.h:
3038         * gst/gststructure.c: (gst_structure_set_parent_refcount),
3039         (gst_structure_copy_conditional):
3040         Use parent refcount in GstMessage to ensure GstStructure
3041         consistency.
3042         Cleaned up headers a bit.
3043         
3044
3045 2005-04-20  Wim Taymans  <wim@fluendo.com>
3046
3047         * gst/base/gstbasesink.c: (gst_basesink_base_init),
3048         (gst_basesink_pad_getcaps), (gst_basesink_init),
3049         (gst_basesink_chain_unlocked):
3050         * gst/base/gsttypefindhelper.c: (helper_find_suggest),
3051         (gst_type_find_helper):
3052         * gst/elements/gsttypefindelement.c:
3053         (gst_type_find_element_have_type), (gst_type_find_element_init),
3054         (stop_typefinding), (gst_type_find_element_handle_event),
3055         (find_suggest), (gst_type_find_element_chain),
3056         (gst_type_find_element_checkgetrange),
3057         (gst_type_find_element_getrange), (do_typefind),
3058         (gst_type_find_element_activate):
3059         * gst/gstbuffer.c: (_gst_buffer_sub_free),
3060         (gst_buffer_default_free), (gst_buffer_default_copy),
3061         (gst_buffer_set_caps):
3062         * gst/gstcaps.c: (gst_caps_ref), (gst_caps_unref),
3063         (gst_caps_replace):
3064         * gst/gstmessage.c: (gst_message_new),
3065         (gst_message_new_state_changed):
3066         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3067         (gst_pad_set_checkgetrange_function),
3068         (gst_pad_link_prepare_filtered), (gst_pad_relink_filtered),
3069         (gst_pad_set_caps), (gst_pad_check_pull_range),
3070         (gst_pad_pull_range), (gst_static_pad_template_get_caps):
3071         * gst/gstpad.h:
3072         * gst/gsttypefind.c: (gst_type_find_register):
3073         Make gst_caps_replace() work like other _replace() functions.
3074         Use _caps_replace() where possible.
3075         Make sure _message_new() initialises its field.
3076         Add gst_static_pad_template_get_caps()
3077
3078
3079 2005-04-18  Andy Wingo  <wingo@pobox.com>
3080
3081         * gst/gstelement.c (gst_element_pads_activate): Check pull_range
3082         on the peer, not the pad. I think that was a typo. Pass an extra
3083         arg to see if random access is possible. Activate the pads as
3084         PULL_RANGE if possible.
3085
3086         * gst/elements/gstfakesrc.c: s/ARG_/PROP_/.
3087
3088         * gst/base/gstbasesrc.c (gst_basesrc_set_property) 
3089         (gst_basesrc_get_property): BLOCKSIZE is a ULONG. Rename ARG_...
3090         to PROP_....
3091
3092 2005-04-14  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3093
3094         * docs/faq/using.xml:
3095           Add note on gstreamer-properties (#154996).
3096
3097 2005-04-13  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3098
3099         * docs/random/bbb/optional-properties:
3100           Some analysis on optional properties.
3101
3102 2005-04-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3103
3104         * docs/gst/tmpl/gstelementfactory.sgml:
3105         * gst/gstelement.h:
3106         * gst/gstelementfactory.c: (gst_element_factory_init),
3107         (gst_element_factory_cleanup), (gst_element_register),
3108         (__gst_element_factory_add_static_pad_template),
3109         (gst_element_factory_get_static_pad_templates),
3110         (gst_element_factory_can_src_caps),
3111         (gst_element_factory_can_sink_caps):
3112         * gst/registries/Makefile.am:
3113         * gst/registries/gstlibxmlregistry.c: (gst_xml_registry_get_type),
3114         (gst_xml_registry_class_init), (gst_xml_registry_init),
3115         (gst_xml_registry_new), (gst_xml_registry_set_property),
3116         (gst_xml_registry_get_property), (get_time), (make_dir),
3117         (gst_xml_registry_get_perms_func),
3118         (plugin_times_older_than_recurse), (plugin_times_older_than),
3119         (gst_xml_registry_open_func), (gst_xml_registry_load_func),
3120         (gst_xml_registry_save_func), (gst_xml_registry_close_func),
3121         (add_to_char_array), (read_string), (read_uint), (read_enum),
3122         (load_pad_template), (load_feature), (load_plugin), (load_paths),
3123         (gst_xml_registry_load), (gst_xml_registry_load_plugin),
3124         (gst_xml_registry_save_caps), (gst_xml_registry_save_pad_template),
3125         (gst_xml_registry_save_feature), (gst_xml_registry_save_plugin),
3126         (gst_xml_registry_save), (gst_xml_registry_rebuild_recurse),
3127         (gst_xml_registry_rebuild):
3128         * gst/registries/gstlibxmlregistry.h:
3129         * tools/gst-compprep.c: (main):
3130         * tools/gst-inspect.c: (print_pad_templates_info):
3131         * tools/gst-xmlinspect.c: (print_element_info):
3132           Use libxml2 for registry parsing, use staticpadtemplates in
3133           elementfactories. Makes gst_init() +/- 10x faster.
3134
3135 2005-04-12  Wim Taymans  <wim@fluendo.com>
3136
3137         * gst/base/Makefile.am:
3138         * gst/base/gstbasesink.c: (gst_basesink_base_init),
3139         (gst_basesink_pad_getcaps), (gst_basesink_init),
3140         (gst_basesink_event), (gst_basesink_change_state):
3141         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
3142         (gst_basesrc_init), (gst_basesrc_query),
3143         (gst_basesrc_get_event_mask), (gst_basesrc_do_seek),
3144         (gst_basesrc_event_handler), (gst_basesrc_get_range_unlocked),
3145         (gst_basesrc_check_get_range), (gst_basesrc_loop),
3146         (gst_basesrc_unlock), (gst_basesrc_get_size), (gst_basesrc_start),
3147         (gst_basesrc_stop), (gst_basesrc_activate),
3148         (gst_basesrc_change_state):
3149         * gst/base/gsttypefindhelper.c: (helper_find_peek),
3150         (helper_find_suggest), (gst_type_find_helper):
3151         * gst/base/gsttypefindhelper.h:
3152         * gst/elements/Makefile.am:
3153         * gst/elements/gstelements.c:
3154         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
3155         (gst_fakesink_get_times), (gst_fakesink_event),
3156         (gst_fakesink_preroll), (gst_fakesink_render):
3157         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
3158         (gst_fakesrc_init), (gst_fakesrc_event_handler),
3159         (gst_fakesrc_get_property), (gst_fakesrc_create),
3160         (gst_fakesrc_start), (gst_fakesrc_stop):
3161         * gst/elements/gstfakesrc.h:
3162         * gst/elements/gstfilesrc.c: (gst_filesrc_class_init),
3163         (gst_filesrc_free_parent_mmap), (gst_filesrc_map_region),
3164         (gst_filesrc_map_small_region), (gst_filesrc_create_mmap),
3165         (gst_filesrc_create_read), (gst_filesrc_create),
3166         (gst_filesrc_is_seekable), (gst_filesrc_get_size),
3167         (gst_filesrc_start):
3168         * gst/elements/gsttypefindelement.c:
3169         (gst_type_find_element_have_type), (gst_type_find_element_init),
3170         (start_typefinding), (stop_typefinding), (push_buffer_store),
3171         (gst_type_find_element_handle_event),
3172         (gst_type_find_element_chain),
3173         (gst_type_find_element_checkgetrange),
3174         (gst_type_find_element_getrange), (do_typefind),
3175         (gst_type_find_element_activate),
3176         (gst_type_find_element_change_state):
3177         * gst/elements/gsttypefindelement.h:
3178         * gst/gstpipeline.c: (pipeline_bus_handler):
3179         Added typefind helper.
3180         Small preroll fix in the base sink.
3181         Disable typefind code in basesrc.
3182         Crude port of typefindelement.
3183         Fakesrc cleanups.
3184
3185
3186 2005-04-11  Wim Taymans  <wim@fluendo.com>
3187
3188         * check/gst/gstbus.c: (gstbus_suite):
3189         * check/gst/gstdata.c: (thread_ref), (gst_data_suite):
3190         * check/gstcheck.h:
3191           Fix up the timeout so that the test does not fail.
3192
3193 2005-04-06  Wim Taymans  <wim@fluendo.com>
3194
3195         * gst/base/README:
3196         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
3197         (gst_basesrc_init), (gst_basesrc_get_formats), (gst_basesrc_query),
3198         (gst_basesrc_get_event_mask), (gst_basesrc_do_seek),
3199         (gst_basesrc_event_handler), (gst_basesrc_get_range_unlocked),
3200         (gst_basesrc_check_get_range), (gst_basesrc_loop),
3201         (gst_basesrc_unlock), (gst_basesrc_get_size), (gst_basesrc_start),
3202         (gst_basesrc_stop), (gst_basesrc_activate),
3203         (gst_basesrc_change_state), (basesrc_find_peek),
3204         (basesrc_find_suggest), (gst_basesrc_type_find):
3205         * gst/base/gstbasesrc.h:
3206         * gst/elements/gstfilesrc.c: (gst_filesrc_base_init),
3207         (gst_filesrc_class_init), (gst_filesrc_init),
3208         (gst_filesrc_finalize), (gst_filesrc_set_location),
3209         (gst_filesrc_set_property), (gst_filesrc_get_property),
3210         (gst_filesrc_free_parent_mmap), (gst_filesrc_map_region),
3211         (gst_filesrc_map_small_region), (gst_filesrc_create_mmap),
3212         (gst_filesrc_create_read), (gst_filesrc_create),
3213         (gst_filesrc_get_size), (gst_filesrc_start), (gst_filesrc_stop):
3214         * gst/elements/gstfilesrc.h:
3215         * gst/gstelement.c: (gst_element_get_state_func),
3216         (gst_element_lost_state), (gst_element_pads_activate):
3217         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3218         (gst_pad_set_checkgetrange_function), (gst_pad_check_pull_range),
3219         (gst_pad_pull_range):
3220         * gst/gstpad.h:
3221         More work on the generic source base class, implement seeking,
3222         query.
3223         Make filesrc extend the base source class.
3224         Added gst_pad_set_checkgetrange_function to GstPad.
3225
3226 2005-04-06  Andy Wingo  <wingo@pobox.com>
3227
3228         * pkgconfig/gstreamer-base.pc.in:
3229         * pkgconfig/gstreamer-base-uninstalled.pc.in: New files.
3230
3231         * pkgconfig/Makefile.am:
3232         * configure.ac (AC_OUTPUT): Add gstreamer-base pkgconfig files.
3233
3234 2005-04-04  Wim Taymans  <wim@fluendo.com>
3235
3236         * gst/base/Makefile.am:
3237         * gst/base/README:
3238         * gst/base/gstbasesink.c: (gst_basesink_base_init),
3239         (gst_basesink_pad_getcaps), (gst_basesink_pad_setcaps),
3240         (gst_basesink_pad_buffer_alloc), (gst_basesink_init),
3241         (gst_basesink_do_sync), (gst_basesink_chain_unlocked):
3242         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
3243         (gst_basesrc_base_init), (gst_basesrc_class_init),
3244         (gst_basesrc_init), (gst_basesrc_get_formats),
3245         (gst_basesrc_get_query_types), (gst_basesrc_query),
3246         (gst_basesrc_get_event_mask), (gst_basesrc_event_handler),
3247         (gst_basesrc_set_property), (gst_basesrc_get_property),
3248         (gst_basesrc_get_range_unlocked), (gst_basesrc_get_range),
3249         (gst_basesrc_loop), (gst_basesrc_activate),
3250         (gst_basesrc_change_state):
3251         * gst/base/gstbasesrc.h:
3252         * gst/elements/gstfakesrc.c: (gst_fakesrc_base_init),
3253         (gst_fakesrc_class_init), (gst_fakesrc_init),
3254         (gst_fakesrc_event_handler), (gst_fakesrc_set_property),
3255         (gst_fakesrc_get_property), (gst_fakesrc_create):
3256         * gst/elements/gstfakesrc.h:
3257         * gst/elements/gstfilesrc.c: (gst_filesrc_getrange),
3258         (gst_filesrc_open_file), (gst_filesrc_loop),
3259         (gst_filesrc_activate), (filesrc_find_peek),
3260         (gst_filesrc_type_find):
3261         Made base source class, make fakesrc extend it.
3262         Add comments to basesink class.
3263         Some filesrc cleanup.
3264
3265 2005-03-31  David Schleef  <ds@schleef.org>
3266
3267         * gst/gstplugin.c: (gst_plugin_check_file), (gst_plugin_load_file):
3268         Switch to using G_MODULE_BIND_LOCAL, which means plugins are now
3269         expected to link against libgstreamer.
3270         * gst/base/Makefile.am: link against libgstreamer
3271         * gst/elements/Makefile.am: same
3272
3273 2005-03-31  Andy Wingo  <wingo@pobox.com>
3274
3275         * tests/instantiate/Makefile.am:
3276         * tests/instantiate/caps.c: Add test to test speed of caps copy
3277         and free.
3278
3279         * tests/memchunk/gmemchunktest.c (main): Use alloc only on the
3280         GMemChunk to be fair.
3281
3282         * gst/gsttrashstack.h: Remove warning about using the fallback
3283         trash stack implementation, it's still faster than malloc.
3284
3285 2005-03-30  Andy Wingo  <wingo@pobox.com>
3286
3287         * tests/complexity.c: Add a copyright.
3288
3289 2005-03-31  Wim Taymans  <wim@fluendo.com>
3290
3291         * gst/base/gstbasetransform.c: (gst_base_transform_base_init),
3292         (gst_base_transform_class_init), (gst_base_transform_init),
3293         (gst_base_transform_setcaps), (gst_base_transform_handle_buffer),
3294         (gst_base_transform_get_property),
3295         (gst_base_transform_sink_activate),
3296         (gst_base_transform_src_activate),
3297         (gst_base_transform_change_state):
3298         * gst/base/gstbasetransform.h:
3299         * gst/elements/gstidentity.c: (gst_identity_class_init),
3300         (gst_identity_event), (gst_identity_check_perfect),
3301         (gst_identity_transform), (gst_identity_start),
3302         (gst_identity_stop):
3303         Added start/stop methods to transform base class so subclasses 
3304         don't need to deal with state changes even.
3305
3306 2005-03-31  Wim Taymans  <wim@fluendo.com>
3307
3308         * gst/gstevent.c: (gst_event_new_discontinuous_valist),
3309         (gst_event_new_discontinuous), (gst_event_discont_get_value):
3310         * gst/gstevent.h:
3311         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3312         (gst_pad_pull_range):
3313         Added rate to the discont event to prepare for variable speed
3314         and reverse playback.
3315
3316 2005-03-29  David Schleef  <ds@schleef.org>
3317
3318         * configure.ac:
3319         * testsuite/trigger/Makefile.am:
3320         * testsuite/trigger/trigger.c: A little example program to show
3321         how trigger-based elements can work.
3322
3323 2005-03-29  Wim Taymans  <wim@fluendo.com>
3324
3325         * gst/base/Makefile.am:
3326         * gst/base/README:
3327         * gst/base/gstbasesink.c: (gst_basesink_get_type),
3328         (gst_basesink_base_init), (gst_basesink_class_init),
3329         (gst_basesink_pad_getcaps), (gst_basesink_init),
3330         (gst_basesink_activate), (gst_basesink_change_state):
3331         * gst/base/gstbasesink.h:
3332         * gst/base/gstbasetransform.c: (gst_base_transform_get_type),
3333         (gst_base_transform_base_init), (gst_base_transform_finalize),
3334         (gst_base_transform_class_init), (gst_base_transform_init),
3335         (gst_base_transform_proxy_getcaps), (gst_base_transform_setcaps),
3336         (gst_base_transform_event), (gst_base_transform_getrange),
3337         (gst_base_transform_chain), (gst_base_transform_handle_buffer),
3338         (gst_base_transform_set_property),
3339         (gst_base_transform_get_property),
3340         (gst_base_transform_sink_activate),
3341         (gst_base_transform_src_activate),
3342         (gst_base_transform_change_state):
3343         * gst/base/gstbasetransform.h:
3344         * gst/elements/gstidentity.c: (gst_identity_finalize),
3345         (gst_identity_class_init), (gst_identity_init),
3346         (gst_identity_event), (gst_identity_check_perfect),
3347         (gst_identity_transform), (gst_identity_set_property),
3348         (gst_identity_get_property), (gst_identity_change_state):
3349         * gst/elements/gstidentity.h:
3350         * gst/gstelement.c: (gst_element_get_state_func),
3351         (gst_element_lost_state), (gst_element_pads_activate):
3352         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
3353         (gst_pad_check_pull_range), (gst_pad_pull_range):
3354         * gst/gstpad.h:
3355         Simplify pad activation.
3356         Added function to check if pull_range can be performed.
3357         Error out when pulling inactive or flushing pads.
3358         Removed const from refcounted types as it does not make sense.
3359         Simplify pad templates in basesink
3360         Added base class for simple 1-to-1 transforms.
3361         Make identity subclass the base transform.
3362
3363 2005-03-29  Andy Wingo  <wingo@pobox.com>
3364
3365         * docs/libs/gstreamer-libs-overrides.txt: 
3366         * docs/gst/gstreamer-overrides.txt: Add these files to CVS. Now I
3367         really don't understand what's going on, but like whatever. I want
3368         green buildbot!
3369
3370         * docs/gst/Makefile.am:
3371         * docs/libs/Makefile.am: Dist the overrides files.
3372
3373         * check/Makefile.am (clean-local): Remove .libs directories.
3374
3375         * gst/elements/Makefile.am (EXTRA_DIST): Add all the attic
3376         elements to EXTRA_DIST, so po/ files are happy.
3377
3378         * po/POTFILES.in: Er, remove it here.
3379
3380         * po/POTFILES: Remove gstspider.c.
3381
3382         * configure.ac (AC_OUTPUT): Add missing testsuite makefiles.
3383
3384         * docs/libs/gstreamer-libs-docs.sgml: 
3385         * docs/libs/gstreamer-libs-sections.txt: Remove the section on
3386         bytestream.
3387
3388         * tests/complexity.c (main): Set the length of the preroll queue
3389         on the sinks to prevent a lockup.
3390
3391         * libs/gst/dataprotocol/Makefile.am: 
3392         * libs/gst/dataprotocol/dataprotocol-test.c: Remove test, it's
3393         the same as the one in check/gst-libs/gdp.c.
3394
3395         * po/, docs/gst/: Commit automatic changes to docs and po files.
3396
3397         * gst/elements/Makefile.am (libgstelements_la_LDFLAGS): Link to
3398         the versioned libgstbase.
3399
3400         * check/Makefile.am: Depend on an unversioned gst-register, seems
3401         to make autoconf happier.
3402
3403         * gst/base/Makefile.am: Make libgstbase a versioned lib.
3404
3405 2005-03-28  Wim Taymans  <wim@fluendo.com>
3406
3407         * configure.ac:
3408         * docs/design/part-gstelement.txt:
3409         * docs/design/part-negotiation.txt:
3410         * docs/design/part-preroll.txt:
3411         * docs/design/part-scheduling.txt:
3412         * docs/design/part-states.txt:
3413         * gst/Makefile.am:
3414         * gst/base/Makefile.am:
3415         * gst/base/README:
3416         * gst/base/gstbasesink.c: (gst_basesink_get_template),
3417         (gst_basesink_base_init), (gst_basesink_class_init),
3418         (gst_basesink_pad_getcaps), (gst_basesink_pad_setcaps),
3419         (gst_basesink_pad_buffer_alloc), (gst_basesink_init),
3420         (gst_basesink_set_pad_functions),
3421         (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock),
3422         (gst_basesink_set_property), (gst_basesink_get_property),
3423         (gst_base_sink_get_template), (gst_base_sink_get_caps),
3424         (gst_base_sink_set_caps), (gst_base_sink_buffer_alloc),
3425         (gst_basesink_preroll_queue_push),
3426         (gst_basesink_preroll_queue_empty),
3427         (gst_basesink_preroll_queue_flush), (gst_basesink_finish_preroll),
3428         (gst_basesink_event), (gst_basesink_get_times),
3429         (gst_basesink_do_sync), (gst_basesink_handle_buffer),
3430         (gst_basesink_chain_unlocked), (gst_basesink_chain),
3431         (gst_basesink_loop), (gst_basesink_activate),
3432         (gst_basesink_change_state):
3433         * gst/base/gstbasesink.h:
3434         * gst/elements/Makefile.am:
3435         * gst/elements/gstfakesink.c: (gst_fakesink_base_init),
3436         (gst_fakesink_class_init), (gst_fakesink_init),
3437         (gst_fakesink_set_property), (gst_fakesink_get_property),
3438         (gst_fakesink_get_times), (gst_fakesink_event),
3439         (gst_fakesink_preroll), (gst_fakesink_render),
3440         (gst_fakesink_change_state):
3441         * gst/elements/gstfakesink.h:
3442         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_manager),
3443         (gst_bin_get_state), (gst_bin_change_state), (gst_bin_send_event):
3444         * gst/gstelement.c: (gst_element_add_pad),
3445         (gst_element_get_state_func), (gst_element_abort_state),
3446         (gst_element_commit_state), (gst_element_lost_state),
3447         (gst_element_set_state), (gst_element_pads_activate):
3448         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_event_default):
3449         * gst/gstpipeline.c: (gst_pipeline_send_event),
3450         (gst_pipeline_change_state):
3451         Added state change code.
3452         Added/updated docs.
3453         Added sink base class, make fakesink extend the base class.
3454         Small cleanups in GstPipeline.
3455
3456 2005-03-26  David Schleef  <ds@schleef.org>
3457
3458         * gst/Makefile.am: remove gstcpu.[ch].  The gst_cpu functionality
3459         is broken and should be implemented in a different library.
3460         * gst/gst.c: (init_post): don't call _gst_cpu_initialize()
3461         * gst/gst.h: remove gstcpu.h
3462         * gst/gstcpu.c: remove
3463         * gst/gstcpu.h: remove
3464         * gst/Makefile.am.future: Remove this file.  It's ancient.
3465
3466 2005-03-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3467
3468         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_manager),
3469         (gst_bin_send_event):
3470           Add default event/set_manager handlers. The set_manager handler
3471           takes care that the manager is distributed over kids that were
3472           already in the bin before the manager was set. The event handler
3473           is a utility virtual function that sends the event over all sinks,
3474           so that gst_element_send_event (bin, event); has the expected
3475           behaviour.
3476         * gst/gstpad.c: (gst_pad_event_default):
3477           Re-install default event handling for discontinuities, so that
3478           seeking works without requiring hacks in applications or extra
3479           code in sinks.
3480         * gst/gstpipeline.c: (gst_pipeline_class_init),
3481         (gst_pipeline_send_event):
3482           Half hack, half utility: set a pipeline to PAUSED for seek events,
3483           since that is the only way we can guarantee a/v sync. Means that
3484           you can do gst_element_seek (pipeline, method, pos); on a pipeline
3485           and it "just works".
3486
3487 2005-03-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3488
3489         * gst/gstpipeline.c: (gst_pipeline_use_clock):
3490           Lock/unlock mismatch.
3491
3492 2005-03-25  Thomas Vander Stichele  <thomas at apestaart dot org>
3493
3494         * docs/faq/gst-uninstalled:
3495           add gst-plugins-base
3496         * docs/gst/Makefile.am:
3497           don't error out until docs are fixed
3498         * docs/gst/gstreamer.types:
3499           remove thread
3500
3501 2005-03-22  Wim Taymans  <wim@fluendo.com>
3502
3503         * check/Makefile.am:
3504         * check/gst/gstmessage.c: (START_TEST), (gst_data_suite), (main):
3505         * gst/gststructure.c: (gst_structure_set_valist),
3506         (gst_structure_copy_conditional):
3507         Activated more tests.
3508         Added message test.
3509         Added G_TYPE_POINTER to GstStructure.
3510         
3511
3512 2005-03-22  Wim Taymans  <wim@fluendo.com>
3513
3514         * docs/design/part-TODO.txt:
3515         * docs/design/part-events.txt:
3516         * docs/design/part-gstbin.txt:
3517         * docs/design/part-gstbus.txt:
3518         * docs/design/part-gstpipeline.txt:
3519         * docs/design/part-messages.txt:
3520         * gst/gstbus.c:
3521         * gst/gstmessage.c:
3522         Docs updates
3523
3524 2005-03-21  Wim Taymans  <wim@fluendo.com>
3525
3526         * gst/gstbus.c: (gst_bus_post):
3527         Fix copy-and-paste error.
3528
3529 2005-03-21  Wim Taymans  <wim@fluendo.com>
3530
3531         * check/Makefile.am:
3532         * gst/Makefile.am:
3533         * gst/elements/Makefile.am:
3534         * gst/elements/gstelements.c:
3535         * gst/elements/gstfakesink.c: (gst_fakesink_init),
3536         (gst_fakesink_event), (gst_fakesink_chain):
3537         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
3538         (gst_fakesrc_init), (gst_fakesrc_get_event_mask),
3539         (gst_fakesrc_event_handler), (gst_fakesrc_set_pad_functions),
3540         (gst_fakesrc_set_all_pad_functions), (gst_fakesrc_request_new_pad),
3541         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
3542         (gst_fakesrc_get_range_unlocked), (gst_fakesrc_get_range),
3543         (gst_fakesrc_loop), (gst_fakesrc_activate),
3544         (gst_fakesrc_change_state):
3545         * gst/elements/gstfakesrc.h:
3546         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
3547         (gst_filesrc_get_read), (gst_filesrc_getrange), (gst_filesrc_get),
3548         (gst_filesrc_open_file), (gst_filesrc_loop),
3549         (gst_filesrc_activate), (gst_filesrc_change_state),
3550         (filesrc_find_peek), (filesrc_find_suggest),
3551         (gst_filesrc_type_find):
3552         * gst/elements/gstidentity.c: (gst_identity_finalize),
3553         (gst_identity_class_init), (gst_identity_init),
3554         (gst_identity_proxy_getcaps), (identity_queue_push),
3555         (identity_queue_pop), (identity_queue_flush), (gst_identity_event),
3556         (gst_identity_getrange), (gst_identity_chain),
3557         (gst_identity_sink_loop), (gst_identity_src_loop),
3558         (gst_identity_handle_buffer), (gst_identity_set_dataflow_funcs),
3559         (gst_identity_set_property), (gst_identity_get_property),
3560         (gst_identity_change_state):
3561         * gst/elements/gstidentity.h:
3562         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_init),
3563         (gst_tee_update_pad_functions), (gst_tee_request_new_pad),
3564         (gst_tee_set_property), (gst_tee_get_property), (gst_tee_do_push),
3565         (gst_tee_handle_buffer), (gst_tee_chain), (gst_tee_loop),
3566         (gst_tee_sink_activate):
3567         * gst/elements/gsttee.h:
3568         * gst/gst.c: (gst_register_core_elements), (init_post):
3569         * gst/gst.h:
3570         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_bus),
3571         (gst_bin_set_scheduler), (gst_bin_add_func), (gst_bin_add),
3572         (gst_bin_remove_func), (gst_bin_remove), (gst_bin_get_state),
3573         (gst_bin_change_state):
3574         * gst/gstbin.h:
3575         * gst/gstbus.c: (gst_bus_get_type), (gst_bus_class_init),
3576         (gst_bus_init), (gst_bus_dispose), (gst_bus_set_property),
3577         (gst_bus_get_property), (gst_bus_new), (gst_bus_post),
3578         (gst_bus_have_pending), (gst_bus_pop), (gst_bus_peek),
3579         (gst_bus_set_sync_handler), (gst_bus_create_watch),
3580         (bus_watch_callback), (bus_watch_destroy),
3581         (gst_bus_add_watch_full), (gst_bus_add_watch), (poll_handler),
3582         (poll_timeout), (gst_bus_poll):
3583         * gst/gstbus.h:
3584         * gst/gstcaps.h:
3585         * gst/gstdata.h:
3586         * gst/gstelement.c: (gst_element_class_init), (gst_element_init),
3587         (gst_element_post_message), (gst_element_message_full),
3588         (gst_element_get_state_func), (gst_element_get_state),
3589         (gst_element_abort_state), (gst_element_commit_state),
3590         (gst_element_lost_state), (gst_element_set_state),
3591         (gst_element_pads_activate), (gst_element_change_state),
3592         (gst_element_dispose), (gst_element_set_manager_func),
3593         (gst_element_set_bus_func), (gst_element_set_scheduler_func),
3594         (gst_element_set_manager), (gst_element_get_manager),
3595         (gst_element_set_bus), (gst_element_get_bus),
3596         (gst_element_set_scheduler), (gst_element_get_scheduler):
3597         * gst/gstelement.h:
3598         * gst/gstevent.c: (gst_event_new_segment_seek),
3599         (gst_event_new_flush):
3600         * gst/gstevent.h:
3601         * gst/gstmessage.c: (_gst_message_initialize), (_gst_message_copy),
3602         (_gst_message_free), (gst_message_get_type), (gst_message_new),
3603         (gst_message_new_eos), (gst_message_new_error),
3604         (gst_message_new_warning), (gst_message_new_tag),
3605         (gst_message_new_state_changed), (gst_message_new_application),
3606         (gst_message_get_structure), (gst_message_parse_tag),
3607         (gst_message_parse_state_changed), (gst_message_parse_error),
3608         (gst_message_parse_warning):
3609         * gst/gstmessage.h:
3610         * gst/gstpad.c: (gst_real_pad_class_init), (gst_real_pad_init),
3611         (gst_real_pad_set_property), (gst_pad_set_active),
3612         (gst_pad_is_active), (gst_pad_set_blocked_async),
3613         (gst_pad_set_blocked), (gst_pad_is_blocked),
3614         (gst_pad_set_activate_function), (gst_pad_set_loop_function),
3615         (gst_pad_set_getrange_function), (gst_pad_set_acceptcaps_function),
3616         (gst_pad_set_fixatecaps_function), (gst_pad_set_setcaps_function),
3617         (gst_pad_unlink), (gst_pad_link_prepare_filtered),
3618         (gst_pad_link_filtered), (gst_pad_relink_filtered),
3619         (gst_real_pad_get_caps_unlocked), (gst_pad_get_caps),
3620         (gst_pad_peer_get_caps), (gst_pad_fixate_caps),
3621         (gst_pad_accept_caps), (gst_pad_peer_accept_caps),
3622         (gst_pad_set_caps), (gst_pad_configure_sink),
3623         (gst_pad_configure_src), (gst_pad_get_negotiated_caps),
3624         (gst_pad_get_filter_caps), (gst_pad_alloc_buffer),
3625         (gst_real_pad_dispose), (gst_real_pad_finalize),
3626         (handle_pad_block), (gst_pad_push), (gst_pad_pull_range),
3627         (gst_pad_event_default_dispatch), (gst_pad_event_default),
3628         (gst_pad_push_event), (gst_pad_send_event), (gst_pad_get_formats):
3629         * gst/gstpad.h:
3630         * gst/gstpipeline.c: (gst_pipeline_init), (is_eos),
3631         (pipeline_bus_handler), (gst_pipeline_change_state),
3632         (gst_pipeline_get_scheduler), (gst_pipeline_get_bus):
3633         * gst/gstpipeline.h:
3634         * gst/gstprobe.h:
3635         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_init),
3636         (gst_queue_finalize), (gst_queue_getcaps), (gst_queue_link_sink),
3637         (gst_queue_link_src), (gst_queue_bufferalloc),
3638         (gst_queue_locked_flush), (gst_queue_handle_sink_event),
3639         (gst_queue_is_empty), (gst_queue_is_filled), (gst_queue_chain),
3640         (gst_queue_loop), (gst_queue_handle_src_event),
3641         (gst_queue_handle_src_query), (gst_queue_src_activate),
3642         (gst_queue_change_state):
3643         * gst/gstqueue.h:
3644         * gst/gstscheduler.c: (gst_scheduler_init),
3645         (gst_scheduler_dispose), (gst_scheduler_create_task),
3646         (gst_scheduler_factory_create):
3647         * gst/gstscheduler.h:
3648         * gst/gststructure.c: (gst_structure_get_type),
3649         (gst_structure_copy_conditional):
3650         * gst/gststructure.h:
3651         * gst/gsttaginterface.h:
3652         * gst/gsttask.c: (gst_task_get_type), (gst_task_class_init),
3653         (gst_task_init), (gst_task_dispose), (gst_task_create),
3654         (gst_task_get_state), (gst_task_start), (gst_task_stop),
3655         (gst_task_pause):
3656         * gst/gsttask.h:
3657         * gst/gstthread.c:
3658         * gst/gstthread.h:
3659         * gst/gsttypes.h:
3660         * gst/schedulers/Makefile.am:
3661         * gst/schedulers/cothreads_compat.h:
3662         * gst/schedulers/entryscheduler.c:
3663         * gst/schedulers/faircothreads.c:
3664         * gst/schedulers/faircothreads.h:
3665         * gst/schedulers/fairscheduler.c:
3666         * gst/schedulers/gstbasicscheduler.c:
3667         * gst/schedulers/gstoptimalscheduler.c:
3668         * gst/schedulers/gthread-cothreads.h:
3669         * gst/schedulers/threadscheduler.c:
3670         (gst_thread_scheduler_task_get_type),
3671         (gst_thread_scheduler_task_class_init),
3672         (gst_thread_scheduler_task_init),
3673         (gst_thread_scheduler_task_start),
3674         (gst_thread_scheduler_task_stop),
3675         (gst_thread_scheduler_task_pause), (gst_thread_scheduler_get_type),
3676         (gst_thread_scheduler_class_init), (gst_thread_scheduler_func),
3677         (gst_thread_scheduler_init), (gst_thread_scheduler_create_task),
3678         (gst_thread_scheduler_setup), (gst_thread_scheduler_reset),
3679         (plugin_init):
3680         * libs/gst/Makefile.am:
3681         * libs/gst/bytestream/bytestream.c: (gst_bytestream_get_next_buf):
3682         * libs/gst/bytestream/filepad.c: (gst_file_pad_init),
3683         (gst_file_pad_parent_set):
3684         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_event),
3685         (gst_dp_event_from_packet):
3686         * tests/complexity.c: (main):
3687         * tests/mass_elements.c: (main):
3688         * testsuite/states/locked.c: (message_received), (main):
3689         * testsuite/states/parent.c: (main):
3690         * tools/gst-inspect.c: (print_element_flag_info),
3691         (print_implementation_info), (print_pad_info):
3692         * tools/gst-launch.c: (check_intr), (play_handler), (event_loop),
3693         (main):
3694         * tools/gst-md5sum.c: (event_loop), (main):
3695         * tools/gst-typefind.c: (main):
3696         * tools/gst-xmlinspect.c: (print_element_info):
3697         Next big merge.
3698         Added GstBus for mainloop integration.
3699         Added GstMessage for sending notifications on the bus.
3700         Added GstTask as an abstraction for pipeline entry points.
3701         Removed GstThread.
3702         Removed Schedulers.
3703         Simplified GstQueue for multithreaded core.
3704         Made _link threadsafe, removed old capsnego.
3705         Added STREAM_LOCK and PREROLL_LOCK in GstPad.
3706         Added pad blocking functions.
3707         Reworked scheduling functions in GstPad to prepare for
3708         scheduling updates soon.
3709         Moved events out of data stream.
3710         Simplified GstEvent types.
3711         Added return values to push/pull.
3712         Removed clocking from GstElement.
3713         Added prototypes for state change function for next merge.
3714         Removed iterate from bins and state change management.
3715         Fixed some elements, disabled others for now.
3716         Fixed -inspect and -launch.
3717         Added check for GstBus.
3718
3719 2005-03-10  Wim Taymans  <wim@fluendo.com>
3720
3721         * docs/design/part-MT-refcounting.txt:
3722         * docs/design/part-clocks.txt:
3723         * docs/design/part-gstelement.txt:
3724         * docs/design/part-gstobject.txt:
3725         * docs/design/part-standards.txt:
3726         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
3727         (gst_bin_remove_func), (gst_bin_remove):
3728         * gst/gstbin.h:
3729         * gst/gstbuffer.c:
3730         * gst/gstcaps.h:
3731         * testsuite/clock/clock1.c: (main):
3732         * testsuite/clock/clock2.c: (gst_clock_debug), (element_wait),
3733         (main):
3734         * testsuite/dlopen/loadgst.c: (do_test):
3735         * testsuite/refcounting/bin.c: (add_remove_test1),
3736         (add_remove_test2), (main):
3737         * testsuite/refcounting/element.c: (main):
3738         * testsuite/refcounting/element_pad.c: (main):
3739         * testsuite/refcounting/pad.c: (main):
3740         * tools/gst-launch.c: (sigint_handler_sighandler):
3741         * tools/gst-typefind.c: (main):
3742         Doc updates.
3743         Added doc about clock.
3744         removed gst_bin_iterate_recurse_up(), marked methods
3745         for removal.
3746         Fix more testsuites.
3747
3748 2005-03-09  Wim Taymans  <wim@fluendo.com>
3749
3750         * gst/gstpad.c: (gst_pad_get_direction),
3751         (_gst_pad_default_fixate_foreach), (gst_pad_collectv),
3752         (gst_pad_collect_valist):
3753         * testsuite/bins/interface.c: (main):
3754         * testsuite/caps/audioscale.c: (test_caps):
3755         * testsuite/caps/caps.c: (test1), (test2), (test3):
3756         * testsuite/caps/deserialize.c: (main):
3757         * testsuite/caps/enumcaps.c: (main):
3758         * testsuite/caps/filtercaps.c: (main):
3759         * testsuite/caps/intersect2.c: (main):
3760         * testsuite/caps/random.c: (main):
3761         * testsuite/caps/renegotiate.c: (my_fixate), (main):
3762         * testsuite/caps/sets.c: (check_caps):
3763         * testsuite/caps/simplify.c: (check_caps), (main):
3764         * testsuite/caps/subtract.c: (check_caps):
3765         Fix _pad_get_direction wrt ghostpads.
3766         Fix caps testsuite.
3767
3768 2005-03-09  Wim Taymans  <wim@fluendo.com>
3769
3770         * check/Makefile.am:
3771         * check/gst/gstbin.c: (START_TEST), (gst_bin_suite), (main):
3772         * check/gst/gstsystemclock.c: (START_TEST), (gst_clock_debug),
3773         (ok_callback), (error_callback), (gst_systemclock_suite), (main):
3774         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_index_func),
3775         (gst_bin_set_clock_func), (gst_bin_get_clock_func),
3776         (gst_bin_add_func), (gst_bin_add), (gst_bin_remove_func),
3777         (gst_bin_remove), (gst_bin_iterate_recurse_up),
3778         (bin_element_is_sink), (gst_bin_iterate_sinks),
3779         (gst_bin_iterate_all_by_interface):
3780         * gst/gstbin.h:
3781         * gst/gstelement.c: (gst_element_init), (gst_element_error_full),
3782         (gst_element_change_state), (gst_element_dispose),
3783         (gst_element_finalize), (gst_element_set_loop_function):
3784         * gst/gstelement.h:
3785         * gst/gstiterator.c: (find_custom_fold_func):
3786         * gst/gstpad.c: (_gst_pad_default_fixate_foreach),
3787         (gst_pad_collectv), (gst_pad_collect_valist),
3788         (gst_pad_template_new):
3789         * gst/gstpipeline.c: (gst_pipeline_class_init),
3790         (gst_pipeline_dispose), (gst_pipeline_set_property),
3791         (gst_pipeline_get_property), (gst_pipeline_get_clock_func),
3792         (gst_pipeline_get_clock), (gst_pipeline_use_clock),
3793         (gst_pipeline_set_clock), (gst_pipeline_auto_clock):
3794         * gst/gstutils.h:
3795         * gst/schedulers/entryscheduler.c:
3796         * gst/schedulers/gstbasicscheduler.c:
3797         (gst_basic_scheduler_cothreaded_chain),
3798         (gst_basic_scheduler_chain_add_element):
3799         * testsuite/bins/interface.c: (main):
3800         Added GstBin test.
3801         Added GstSystemClock test.
3802         Implemented clock distribution code in GstBin.
3803         Implemented iterate sinks method for future use.
3804         Rearranged gstelement.h
3805         Fix GstIterator comparison bug.
3806         Moved some code to GstPipeline, mostly clocking related.
3807
3808 2005-03-09  Wim Taymans  <wim@fluendo.com>
3809
3810         * configure.ac:
3811         * gst/gst_private.h:
3812         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
3813         (gst_bin_remove_func), (gst_bin_remove),
3814         (gst_bin_get_by_name_recurse_up):
3815         * gst/gstclock.c: (gst_clock_id_ref), (gst_clock_id_unref),
3816         (gst_clock_id_compare_func), (gst_clock_id_wait),
3817         (gst_clock_id_wait_async), (gst_clock_init),
3818         (gst_clock_adjust_unlocked), (gst_clock_get_time):
3819         * gst/gstelement.h:
3820         * gst/gstinfo.c: (_gst_debug_init):
3821         * gst/gstobject.h:
3822         * gst/gstpad.c: (_gst_pad_default_fixate_foreach),
3823         (gst_pad_collectv), (gst_pad_collect_valist), (gst_pad_query):
3824         * gst/gstpad.h:
3825         Bump version number, we're now 0.9.0
3826         Add future debugging category.
3827         Fix NULL _unref() in _get_by_name_recurse_up
3828         Rearrange gstpad.h.
3829         Update some docs.
3830
3831 2005-03-08  Wim Taymans  <wim@fluendo.com>
3832
3833         * gst/elements/gstaggregator.c: (gst_aggregator_class_init):
3834         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
3835         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
3836         * gst/elements/gstfdsink.c: (gst_fdsink_class_init):
3837         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init):
3838         * gst/elements/gstfilesink.c: (gst_filesink_class_init):
3839         * gst/elements/gstfilesrc.c: (gst_filesrc_class_init):
3840         * gst/elements/gstidentity.c: (gst_identity_class_init):
3841         * gst/elements/gstmd5sink.c: (gst_md5sink_class_init):
3842         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
3843         * gst/elements/gstshaper.c: (gst_shaper_class_init):
3844         * gst/elements/gststatistics.c: (gst_statistics_class_init):
3845         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_getcaps),
3846         (gst_tee_link):
3847         * gst/gstelement.c: (gst_element_class_init),
3848         (gst_element_base_class_init), (gst_element_init),
3849         (gst_element_get_random_pad), (gst_element_wait_state_change),
3850         (gst_element_change_state), (gst_element_dispose),
3851         (gst_element_finalize), (gst_element_set_loop_function):
3852         * gst/gstelement.h:
3853         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_link_src):
3854         * gst/gstthread.c: (gst_thread_class_init),
3855         (gst_thread_release_children_locks), (gst_thread_change_state):
3856         * gst/schedulers/gstbasicscheduler.c:
3857         (gst_basic_scheduler_loopfunc_wrapper),
3858         (gst_basic_scheduler_chain_wrapper),
3859         (gst_basic_scheduler_src_wrapper),
3860         (gst_basic_scheduler_remove_element):
3861         * gst/schedulers/gstoptimalscheduler.c: (schedule_group):
3862         Remove threadsafe properties. Fix elements because GObject
3863         complains when installing a property before declaring a
3864         set/get_property handler.
3865         Rearrange gstelement.h file, use STATE macros for state locks.
3866         Free mutexes in the finalize method instead of dispose.
3867
3868 2005-03-08  Wim Taymans  <wim@fluendo.com>
3869
3870         * check/gst/gstobject.c: (START_TEST), (gst_object_suite):
3871         * gst/gstthread.c: (gst_thread_release_children_locks):
3872         Added parentage check.
3873         Fix build og GstThread again.
3874
3875 2005-03-08  Wim Taymans  <wim@fluendo.com>
3876
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         * docs/design/part-standards.txt:
3882         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
3883         (gst_bin_remove_func), (gst_bin_remove), (gst_bin_iterate_recurse),
3884         (gst_bin_get_by_name), (gst_bin_get_by_interface),
3885         (gst_bin_iterate_all_by_interface):
3886         * gst/gstbuffer.h:
3887         * gst/gstclock.h:
3888         * gst/gstelement.c: (gst_element_class_init),
3889         (gst_element_change_state), (gst_element_set_loop_function):
3890         * gst/gstelement.h:
3891         * gst/gstiterator.c:
3892         * gst/gstobject.c: (gst_object_class_init), (gst_object_ref),
3893         (gst_object_unref), (gst_object_sink), (gst_object_dispose),
3894         (gst_object_dispatch_properties_changed), (gst_object_set_name),
3895         (gst_object_set_parent), (gst_object_unparent),
3896         (gst_object_check_uniqueness):
3897         * gst/gstobject.h:
3898         Docs updates, clean up some headers.
3899
3900 2005-03-07  Wim Taymans  <wim@fluendo.com>
3901
3902         * check/.cvsignore:
3903         * check/Makefile.am:
3904         * check/gst-libs/.cvsignore:
3905         * check/gst-libs/gdp.c: (START_TEST), (gst_object_suite), (main):
3906         * check/gst/.cvsignore:
3907         * check/gst/gstbus.c: (pound_bus_with_messages), (pull_messages),
3908         (START_TEST), (gstbus_suite), (main):
3909         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite), (main):
3910         * check/gst/gstdata.c: (START_TEST), (thread_ref), (thread_unref),
3911         (gst_data_suite), (main):
3912         * check/gst/gstiterator.c: (make_list_of_ints), (START_TEST),
3913         (add_fold_func), (gstiterator_suite), (main):
3914         * check/gst/gstobject.c: (gst_fake_object_get_type), (START_TEST),
3915         (thread_name_object), (thread_name_object_default),
3916         (gst_object_name_compare), (gst_object_suite), (main):
3917         * check/gst/gstpad.c: (START_TEST), (thread_link_unlink),
3918         (gst_pad_suite), (main):
3919         * check/gstcheck.c: (gst_check_log_message_func),
3920         (gst_check_log_critical_func), (gst_check_init):
3921         * check/gstcheck.h:
3922         * check/pipelines/simple_launch_lines.c: (setup_pipeline),
3923         (run_pipeline), (START_TEST), (simple_launch_lines_suite), (main):
3924         Added checks.
3925
3926 2005-03-07  Wim Taymans  <wim@fluendo.com>
3927
3928         * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new),
3929         (gst_list_iterator_next), (gst_list_iterator_resync),
3930         (gst_list_iterator_free), (gst_iterator_new_list),
3931         (gst_iterator_pop), (gst_iterator_next), (gst_iterator_resync),
3932         (gst_iterator_free), (gst_iterator_push), (filter_next),
3933         (filter_resync), (filter_uninit), (filter_free),
3934         (gst_iterator_filter), (gst_iterator_fold), (foreach_fold_func),
3935         (gst_iterator_foreach), (find_custom_fold_func),
3936         (gst_iterator_find_custom):
3937         * gst/gstiterator.h:
3938         Added missing files.
3939
3940 2005-03-07  Wim Taymans  <wim@fluendo.com>
3941
3942         * Makefile.am:
3943         * configure.ac:
3944         * docs/design/part-MT-refcounting.txt:
3945         * docs/design/part-conventions.txt:
3946         * docs/design/part-gstobject.txt:
3947         * docs/design/part-relations.txt:
3948         * examples/mixer/mixer.c: (main):
3949         * examples/thread/thread.c: (eos), (main):
3950         * gst/Makefile.am:
3951         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_caps_intersect):
3952         * gst/autoplug/gstspider.c: (gst_spider_identity_plug),
3953         (gst_spider_plug_from_srcpad):
3954         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_getcaps),
3955         (gst_spider_identity_change_state),
3956         (gst_spider_identity_sink_loop_type_finding):
3957         * gst/elements/gstfakesrc.c: (gst_fakesrc_loop):
3958         * gst/elements/gstidentity.c: (gst_identity_init):
3959         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_getcaps),
3960         (gst_tee_link), (gst_tee_request_new_pad), (gst_tee_chain):
3961         * gst/elements/gsttypefindelement.c: (free_entry):
3962         * gst/gst.c:
3963         * gst/gst.h:
3964         * gst/gstbin.c: (gst_bin_init), (gst_bin_get_clock_func),
3965         (gst_bin_set_clock_func), (gst_bin_auto_clock),
3966         (gst_bin_set_index), (gst_bin_set_element_sched),
3967         (gst_bin_unset_element_sched), (gst_bin_add_func), (gst_bin_add),
3968         (gst_bin_remove_func), (gst_bin_remove), (iterate_child),
3969         (gst_bin_iterate_elements), (iterate_child_recurse),
3970         (gst_bin_iterate_recurse), (gst_bin_dispose), (compare_name),
3971         (gst_bin_get_by_name), (gst_bin_get_by_name_recurse_up),
3972         (compare_interface), (gst_bin_get_by_interface),
3973         (gst_bin_iterate_all_by_interface), (gst_bin_iterate_func):
3974         * gst/gstbin.h:
3975         * gst/gstbuffer.c: (gst_buffer_get_type), (_gst_buffer_sub_free),
3976         (gst_buffer_default_free), (gst_buffer_default_copy),
3977         (gst_buffer_new), (gst_buffer_get_caps), (gst_buffer_set_caps),
3978         (gst_buffer_create_sub):
3979         * gst/gstbuffer.h:
3980         * gst/gstcaps.c: (gst_caps_get_type), (gst_caps_new_empty),
3981         (_gst_caps_free), (gst_caps_make_writable), (gst_caps_ref),
3982         (gst_caps_unref), (gst_static_caps_get),
3983         (gst_caps_remove_and_get_structure), (gst_caps_append),
3984         (gst_caps_append_structure), (gst_caps_remove_structure),
3985         (gst_caps_copy_nth), (gst_caps_set_simple),
3986         (gst_caps_set_simple_valist), (gst_caps_is_fixed_foreach),
3987         (gst_structure_is_equal_foreach), (gst_caps_is_subset),
3988         (gst_caps_structure_intersect_field), (gst_caps_intersect),
3989         (gst_caps_structure_subtract_field), (gst_caps_subtract),
3990         (gst_caps_normalize_foreach), (gst_caps_compare_structures),
3991         (gst_caps_structure_figure_out_union),
3992         (gst_caps_switch_structures), (gst_caps_do_simplify),
3993         (gst_caps_replace), (gst_caps_from_string),
3994         (gst_caps_copy_conditional):
3995         * gst/gstcaps.h:
3996         * gst/gstclock.c: (gst_clock_entry_new), (gst_clock_id_ref),
3997         (_gst_clock_id_free), (gst_clock_id_unref),
3998         (gst_clock_id_compare_func), (gst_clock_id_wait),
3999         (gst_clock_id_wait_async), (gst_clock_class_init),
4000         (gst_clock_init), (gst_clock_dispose), (gst_clock_adjust_unlocked),
4001         (gst_clock_get_time), (gst_clock_set_time_adjust),
4002         (gst_clock_set_property), (gst_clock_get_property):
4003         * gst/gstclock.h:
4004         * gst/gstcompat.h:
4005         * gst/gstcpu.c: (_gst_cpu_initialize_i386), (gst_cpu_get_flags):
4006         * gst/gstdata.c: (gst_data_is_writable), (gst_data_copy_on_write):
4007         * gst/gstdata.h:
4008         * gst/gstelement.c: (gst_element_class_init), (gst_element_init),
4009         (gst_element_requires_clock), (gst_element_provides_clock),
4010         (gst_element_set_clock), (gst_element_clock_wait),
4011         (gst_element_wait), (gst_element_set_time_delay),
4012         (gst_element_is_indexable), (gst_element_add_pad),
4013         (gst_element_add_ghost_pad), (gst_element_remove_pad),
4014         (pad_compare_name), (gst_element_get_static_pad),
4015         (gst_element_request_pad), (gst_element_get_request_pad),
4016         (gst_element_get_pad), (iterate_pad), (gst_element_iterate_pads),
4017         (gst_element_class_get_pad_template_list),
4018         (gst_element_class_get_pad_template), (gst_element_error_func),
4019         (gst_element_get_random_pad), (gst_element_get_event_masks),
4020         (gst_element_send_event), (gst_element_seek),
4021         (gst_element_get_query_types), (gst_element_query),
4022         (gst_element_get_formats), (gst_element_convert),
4023         (gst_element_is_locked_state), (gst_element_set_locked_state),
4024         (gst_element_sync_state_with_parent), (gst_element_change_state),
4025         (gst_element_finalize), (gst_element_yield),
4026         (gst_element_interrupt), (gst_element_set_scheduler),
4027         (gst_element_get_scheduler), (gst_element_set_loop_function):
4028         * gst/gstelement.h:
4029         * gst/gstevent.h:
4030         * gst/gstformat.c: (_gst_format_initialize), (gst_format_register),
4031         (gst_format_get_by_nick), (gst_format_get_details),
4032         (gst_format_iterate_definitions):
4033         * gst/gstformat.h:
4034         * gst/gstindex.c: (gst_index_gtype_resolver):
4035         * gst/gstinfo.c:
4036         * gst/gstinfo.h:
4037         * gst/gstmemchunk.c: (gst_mem_chunk_alloc), (gst_mem_chunk_alloc0),
4038         (gst_mem_chunk_free):
4039         * gst/gstobject.c: (gst_object_class_init), (gst_object_init),
4040         (gst_object_ref), (gst_object_unref), (gst_object_sink),
4041         (gst_object_replace), (gst_object_dispose), (gst_object_finalize),
4042         (gst_object_dispatch_properties_changed),
4043         (gst_object_set_name_default), (gst_object_set_name),
4044         (gst_object_get_name), (gst_object_set_name_prefix),
4045         (gst_object_get_name_prefix), (gst_object_set_parent),
4046         (gst_object_get_parent), (gst_object_unparent),
4047         (gst_object_check_uniqueness), (gst_object_save_thyself),
4048         (gst_object_restore_thyself), (gst_object_real_restore_thyself),
4049         (gst_object_set_property), (gst_object_get_property),
4050         (gst_object_get_path_string):
4051         * gst/gstobject.h:
4052         * gst/gstpad.c: (gst_pad_dispose), (gst_real_pad_class_init),
4053         (gst_real_pad_init), (gst_real_pad_get_property),
4054         (gst_pad_custom_new), (gst_pad_get_direction),
4055         (gst_pad_set_active), (gst_pad_is_active),
4056         (gst_pad_set_event_function), (gst_pad_is_linked),
4057         (gst_pad_link_free), (gst_pad_link_intersect),
4058         (gst_pad_link_fixate), (gst_pad_set_caps),
4059         (gst_pad_try_set_caps_nonfixed), (gst_pad_set_pad_template),
4060         (gst_pad_get_real_parent), (gst_pad_add_ghost_pad),
4061         (gst_pad_remove_ghost_pad), (_gst_pad_default_fixate_foreach),
4062         (gst_pad_link_unnegotiate), (gst_pad_proxy_fixate),
4063         (gst_pad_get_caps), (gst_pad_peer_get_caps),
4064         (gst_pad_get_pad_template_caps), (gst_pad_get_peer),
4065         (gst_pad_realize), (gst_pad_get_allowed_caps),
4066         (gst_real_pad_dispose), (gst_real_pad_finalize),
4067         (gst_pad_collectv), (gst_pad_collect_valist),
4068         (gst_pad_template_dispose), (gst_pad_template_new),
4069         (gst_pad_get_internal_links):
4070         * gst/gstpad.h:
4071         * gst/gstpipeline.c: (gst_pipeline_dispose),
4072         (gst_pipeline_change_state):
4073         * gst/gstpipeline.h:
4074         * gst/gstplugin.c:
4075         * gst/gstpluginfeature.c: (gst_plugin_feature_get_name),
4076         (gst_plugin_feature_set_rank), (gst_plugin_feature_get_rank):
4077         * gst/gstpluginfeature.h:
4078         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
4079         * gst/gstquery.c: (_gst_query_type_initialize),
4080         (gst_query_type_register), (gst_query_type_get_by_nick),
4081         (gst_query_type_get_details), (gst_query_type_iterate_definitions):
4082         * gst/gstquery.h:
4083         * gst/gstqueue.c: (gst_queue_link_sink), (gst_queue_link_src):
4084         * gst/gstscheduler.c: (gst_scheduler_add_element),
4085         (gst_scheduler_factory_create):
4086         * gst/gststructure.c: (gst_structure_set_parent_refcount),
4087         (gst_structure_free), (gst_structure_set_name),
4088         (gst_structure_id_set_value), (gst_structure_set_value),
4089         (gst_structure_set_valist), (gst_structure_remove_field),
4090         (gst_structure_remove_fields),
4091         (gst_structure_remove_fields_valist),
4092         (gst_structure_remove_all_fields), (gst_structure_foreach),
4093         (gst_structure_map_in_place),
4094         (gst_caps_structure_fixate_field_nearest_int),
4095         (gst_caps_structure_fixate_field_nearest_double):
4096         * gst/gststructure.h:
4097         * gst/gstsystemclock.c: (gst_system_clock_class_init),
4098         (gst_system_clock_init), (gst_system_clock_dispose),
4099         (gst_system_clock_async_thread),
4100         (gst_system_clock_id_wait_unlocked), (gst_system_clock_id_wait),
4101         (gst_system_clock_id_wait_async), (gst_system_clock_id_unschedule):
4102         * gst/gstsystemclock.h:
4103         * gst/gsttag.c: (gst_tag_list_add_value_internal),
4104         (gst_tag_list_copy_foreach), (structure_foreach_wrapper):
4105         * gst/gsttaginterface.c:
4106         * gst/gstthread.c: (gst_thread_dispose),
4107         (gst_thread_release_children_locks), (gst_thread_change_state),
4108         (gst_thread_main_loop):
4109         * gst/gsttrashstack.h:
4110         * gst/gsttypefind.c: (gst_type_find_factory_dispose):
4111         * gst/gsttypes.h:
4112         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
4113         (gst_element_request_pad), (gst_element_get_pad_from_template),
4114         (gst_element_request_compatible_pad),
4115         (gst_element_get_compatible_pad_filtered),
4116         (gst_element_get_compatible_pad), (gst_element_state_get_name),
4117         (gst_element_link_pads_filtered), (gst_element_link_filtered),
4118         (gst_element_link_many), (gst_element_link),
4119         (gst_element_link_pads), (gst_element_unlink_pads),
4120         (gst_element_unlink_many), (gst_element_unlink),
4121         (gst_pad_can_link_filtered), (gst_pad_can_link),
4122         (gst_pad_use_fixed_caps), (gst_pad_get_fixed_caps_func),
4123         (gst_object_default_error), (gst_bin_add_many),
4124         (gst_bin_remove_many), (gst_element_populate_std_props),
4125         (gst_element_class_install_std_props), (gst_buffer_merge),
4126         (gst_buffer_stamp), (intersect_caps_func), (gst_pad_proxy_getcaps),
4127         (link_fold_func), (gst_pad_proxy_setcaps):
4128         * gst/gstutils.h:
4129         * gst/gstvalue.c: (gst_value_deserialize_string):
4130         * gst/parse/grammar.y:
4131         * gst/schedulers/gstbasicscheduler.c:
4132         (gst_basic_scheduler_cothreaded_chain),
4133         (gst_basic_scheduler_chain_recursive_add),
4134         (gst_basic_scheduler_pad_link):
4135         * gst/schedulers/gstoptimalscheduler.c:
4136         (get_group_schedule_function),
4137         (gst_opt_scheduler_state_transition),
4138         (gst_opt_scheduler_add_element), (element_get_reachables_func):
4139         * libs/gst/bytestream/bytestream.c:
4140         * libs/gst/dataprotocol/dataprotocol.c:
4141         (gst_dp_header_from_buffer):
4142         * po/nb.po:
4143         * po/ru.po:
4144         * tests/threadstate/threadstate2.c: (eos):
4145         * tools/gst-compprep.c: (main):
4146         * tools/gst-inspect.c: (print_field), (print_element_flag_info),
4147         (print_pad_info), (print_children_info):
4148         * tools/gst-launch.c: (idle_func), (main):
4149         * tools/gst-md5sum.c: (idle_func), (main):
4150         * tools/gst-xmlinspect.c: (print_element_info):
4151         First THREADED backport attempt, focusing on adding locks and
4152         making sure the API is threadsafe. Needs more work. More docs
4153         follow this week.
4154
4155 2005-02-24  Andy Wingo  <wingo@pobox.com>
4156
4157         * tests/bench-complexity.scm:
4158         * tests/complexity.gnuplot: New files, good for running complexity
4159         benchmarks.
4160
4161         * tests/Makefile.am:
4162         * tests/complexity.c: New test, sets up N elements, at each level
4163         teeing into M streams per element. Eeeenteresting.
4164
4165         * tests/mass_elements.gnuplot: gnuplot file for the mass_elements
4166         benchmark. Run as gnuplot mass_elements.gnuplot > foo.ps, after
4167         running bench-mass_elements.scm.
4168
4169         * tests/bench-mass_elements.scm: New script, runs mass_elements
4170         for various numbers of identities, outputting the results to a
4171         file. Requires guile 1.6. Just for testing.
4172
4173 2005-02-23  Thomas Vander Stichele  <thomas at apestaart dot org>
4174
4175         * gst/schedulers/fairscheduler.c:
4176           compile with debug disabled
4177
4178 2005-02-22  Thomas Vander Stichele  <thomas at apestaart dot org>
4179
4180         * configure.ac:
4181           hunting season on 0.9 is now OPEN
4182
4183 2005-02-22  Stefan Kost  <ensonic@users.sf.net>
4184
4185         * docs/libs/tmpl/gstcontrol.sgml:
4186         * docs/libs/tmpl/gstdparam.sgml:
4187         * docs/libs/tmpl/gstdplinint.sgml:
4188         * docs/libs/tmpl/gstdpman.sgml:
4189         * docs/libs/tmpl/gstdpsmooth.sgml:
4190         * docs/libs/tmpl/gstunitconvert.sgml:
4191           more docs for the state of dparams
4192
4193 2005-02-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4194
4195         * gst/gstelementfactory.c: (gst_element_factory_create):
4196         * gst/gstobject.c: (gst_object_init),
4197         (gst_object_set_name_default), (gst_object_set_name):
4198           name objects by default, not in gst_element_factory_create. Allows
4199           using elements created with g_object_new. (fixes #167283)
4200
4201 2005-02-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4202
4203         * gst/gstinfo.c: (_gst_debug_init), (gst_debug_log_default):
4204           make the time that debugging functions print relative to when
4205           gst_init was called
4206
4207 2005-02-18  Tim-Philipp Müller  <tim at centricular dot net>
4208
4209         * gst/gsttaginterface.c:
4210           Fix inline docs: tag setter vararg functions are NULL-terminated,
4211           GST_TAG_INVALID doesn't exist any more.
4212
4213 2005-02-18  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
4214
4215         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_dump_byte_array):
4216         Allocate the 1 byte more memory that was forgotten!!!!!
4217         fixes memory corruption on 64bit platforms
4218
4219 2005-02-15  Stefan Kost  <ensonic@users.sf.net>
4220
4221         * docs/pwg/building-pads.xml:
4222         * docs/pwg/intro-basics.xml:
4223           fixed a few typos, relabeled introductionary list of types
4224         * docs/random/ensonic/dparams.txt:
4225           more notes abut dparam changes
4226         * libs/gst/control/dparam.c: (gst_dparam_attach):
4227         * libs/gst/control/dparammanager.c:
4228         * libs/gst/control/dparammanager.h:
4229           - many comments and notes on dparam implementation
4230           - new dparams are were not initialized to the default value
4231             from param spec
4232
4233 2005-02-14  Thomas Vander Stichele  <thomas at apestaart dot org>
4234
4235         submitted by: Peter Astakhov
4236
4237         * po/LINGUAS:
4238         * po/ru.po:
4239           adding Russian translation
4240
4241 2005-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
4242
4243         * configure.ac:
4244         * docs/gst/Makefile.am:
4245         * docs/libs/Makefile.am:
4246           make sure popt is added to gtk-doc flags.  Fixes #147782.
4247
4248 2005-02-09  Tim-Philipp Müller  <tim at centricular dot net>
4249
4250         * docs/faq/using.xml:
4251           Fix typo in FAQ (artssink => artsdsink)
4252
4253 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4254
4255         * tools/gst-launch.1.in:
4256           Fix typo (#166699).
4257
4258 2005-02-08  Tim-Philipp Müller  <tim at centricular dot net>
4259
4260         * docs/faq/using.xml:
4261           Add -v argument to fakesrc/fakesink gst-launch line,
4262           so that the promised output will actually show up.
4263
4264 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4265
4266         * gst/gstthread.c: (gst_thread_change_state):
4267           Implement state-change error handling (#166073).
4268
4269 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4270
4271         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
4272           Release interrupt after handling (#166250).
4273
4274 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
4275
4276         * configure.ac:
4277           back to HEAD
4278
4279 === release 0.8.9 ===
4280
4281 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
4282
4283         * NEWS:
4284         * RELEASE:
4285         * configure.ac:
4286           releasing 0.8.9, "Like Eating Glass"
4287
4288 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
4289
4290         submitted by: Clytie Siddall
4291
4292         * po/vi.po: Added Vietnamese translation
4293
4294 2005-02-07  Thomas Vander Stichele  <thomas at apestaart dot org>
4295
4296         patch by: Tim Philipp-Müller
4297
4298         * configure.ac:
4299         * gst/gstpad.c:
4300           unref data when probe function returns FALSE.  Fixes #166362
4301
4302 2005-02-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4303
4304         * gst/gst.c: (gst_init_get_popt_table):
4305           Fix typo (#166269).
4306
4307 2005-02-04  Andy Wingo  <wingo@pobox.com>
4308
4309         * gst/gstelement.c (gst_element_get_compatible_pad_template): Fix
4310         the debugging on whether the caps are compatible.
4311
4312 2005-02-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4313
4314         * docs/manual/basics-elements.xml:
4315           Fix two typos.
4316
4317 2005-02-02  Wim Taymans  <wim@fluendo.com>
4318
4319         * gst/schedulers/gstoptimalscheduler.c: (remove_decoupled),
4320         (schedule_chain), (get_invalid_call), (chain_invalid_call),
4321         (loop_group_schedule_function), (gst_opt_scheduler_iterate):
4322         Remove some FIXMEs after analysing and commenting why they
4323         are not issues.
4324
4325 2005-02-02  Wim Taymans  <wim@fluendo.com>
4326
4327         * gst/schedulers/gstoptimalscheduler.c:
4328         (gst_opt_scheduler_class_init), (gst_opt_scheduler_init),
4329         (gst_opt_scheduler_finalize), (remove_decoupled), (schedule_chain),
4330         (get_invalid_call), (chain_invalid_call),
4331         (get_group_schedule_function), (loop_group_schedule_function),
4332         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
4333         (gst_opt_scheduler_state_transition),
4334         (gst_opt_scheduler_add_element),
4335         (gst_opt_scheduler_remove_element), (gst_opt_scheduler_interrupt),
4336         (gst_opt_scheduler_error), (gst_opt_scheduler_pad_link),
4337         (gst_opt_scheduler_pad_unlink), (gst_opt_scheduler_iterate),
4338         (gst_opt_scheduler_show):
4339         Added lock to protect scheduler data structures.
4340
4341 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4342
4343         * testsuite/threads/threadi.c: (cb_data):
4344           Fix buglet in test.
4345
4346 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4347
4348         * testsuite/threads/Makefile.am:
4349         * testsuite/threads/threadi.c: (cb_data), (cb_play), (main):
4350           On Wim's request, split the test in three separately-compiled
4351           tests that each test a very specific bug. Two of them still fail,
4352           will create bugs for those. threadi.c indicates why they fail.
4353
4354 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4355
4356         * gst/schedulers/gstoptimalscheduler.c:
4357         (get_group_schedule_function):
4358           Try to work with the threading mess that queue_link is.
4359
4360 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4361
4362         * gst/gstbin.c: (gst_bin_remove_func):
4363           Explicitely make an element release locks in a group when being
4364           remove from a bin.
4365         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
4366           If there's no scheduler, always return immediately (similar to
4367           gst_element_interrupt).
4368
4369 2005-01-31  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4370
4371         * gst/gstbin.c: (gst_bin_child_state_change_func):
4372           Remove a piece of code that could never be reached.
4373         * docs/gst/gstreamer-sections.txt:
4374         * gst/gstpad.c: (gst_pad_push), (gst_pad_pull),
4375         (gst_pad_call_get_function):
4376         * gst/gstpad.h:
4377         * testsuite/pad/Makefile.am:
4378           Fix #150546, enable tests.
4379
4380 2005-01-31  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4381
4382         * docs/pwg/advanced-types.xml:
4383           Fix description for buffer-frames=0.
4384         * docs/gst/tmpl/gstbin.sgml:
4385         * gst/gstbin.c: (gst_bin_child_state_change_func),
4386         (gst_bin_change_state), (gst_bin_change_state_norecurse):
4387         * gst/gstbin.h:
4388         * testsuite/threads/Makefile.am:
4389         * testsuite/threads/threadi.c: (cb_timeout), (cb_quit), (cb_eos),
4390         (cb_state), (cb_play), (main):
4391           Fix non-recursive state changes to *really* change the state
4392           of the object, and not just call parent_class->state_change.
4393           Fix a lot of lockups caused by this. Fixes #132775. Add test
4394           for the problem. Also enable test to show #142588 (fixed).
4395         * gst/gstthread.c: (gst_thread_change_state),
4396         (gst_thread_child_state_change):
4397           Don't exit the thread if we go to NULL and are inside thread
4398           context. Instead, return control to the main thread context
4399           and exit from there.
4400         * gst/gstelement.c: (gst_element_disable_threadsafe_properties):
4401           Don't unset virtual functions, since those may still be used.
4402           That's not necessarily correct, but suffices for now.
4403         * configure.ac:
4404         * testsuite/Makefile.am:
4405         * testsuite/pad/Makefile.am:
4406         * testsuite/pad/chainnopull.c: (gst_test_sink_class_init),
4407         (gst_test_sink_base_init), (gst_test_sink_chain),
4408         (gst_test_sink_init), (main):
4409         * testsuite/pad/getnopush.c: (gst_test_src_class_init),
4410         (gst_test_src_base_init), (gst_test_src_get), (gst_test_src_init),
4411         (main):
4412         * testsuite/pad/link.c: (gst_test_element_class_init),
4413         (gst_test_element_base_init), (gst_test_src_get),
4414         (gst_test_src_loop), (gst_test_src_init), (gst_test_filter_chain),
4415         (gst_test_filter_loop), (gst_test_filter_init),
4416         (gst_test_sink_chain), (gst_test_sink_loop), (gst_test_sink_init),
4417         (cb_error), (main):
4418           Add tests to show #150546. Pass, but should fail (currently
4419           disabled from the testsuite).
4420         * gst/gstscheduler.c: (gst_scheduler_dispose):
4421           Dereference child schedulers on dispose (#94464).
4422         * testsuite/bytestream/filepadsink.c: (gst_fp_sink_init):
4423           Fix typo.
4424         * testsuite/threads/thread.c: (main):
4425           Add more debug.
4426
4427 2005-01-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4428
4429         * gst/gstpad.c: (gst_pad_push):
4430           Oops, revert previous commit, broke testsuite...
4431
4432 2005-01-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4433
4434         * gst/gstpad.c: (gst_pad_push):
4435           Add check that the pad on which the push is performed is not a
4436           get-based pad (#150546).
4437
4438 2005-01-28  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4439
4440         * gst/elements/gsttypefindelement.c:
4441         (gst_type_find_element_handle_event):
4442           Fix buffer pushing if stream EOSes during typefinding.
4443
4444 2005-01-28  Edward Hervey  <bilboed@bilboed.com>
4445
4446         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4447
4448         * gst/gstvalue.c: (gst_string_wrap):
4449           Allow NULL-strings as argument (#165365).
4450
4451 2005-01-27  Stephane Wirtel  <stephane.wirtel@belgacom.net>
4452
4453         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4454
4455         * gst/schedulers/faircothreads.c:
4456         (gst_fair_scheduler_cothread_queue_show):
4457           Fix build without debug enabled.
4458
4459 2005-01-26  Stefan Kost  <ensonic@users.sf.net>
4460
4461         * docs/gst/gstreamer-sections.txt:
4462         * docs/libs/gstreamer-libs-docs.sgml:
4463         * docs/libs/gstreamer-libs-sections.txt:
4464         * docs/libs/tmpl/gstcontrol.sgml:
4465         * docs/libs/tmpl/gstdparam.sgml:
4466         * docs/libs/tmpl/gstdplinint.sgml:
4467         * docs/libs/tmpl/gstdpman.sgml:
4468         * docs/libs/tmpl/gstdpsmooth.sgml:
4469         * docs/libs/tmpl/gstputbits.sgml:
4470         * docs/libs/tmpl/gstunitconvert.sgml:
4471         * libs/gst/control/dparam.c:
4472         * libs/gst/control/dparam.h:
4473         * libs/gst/control/dparammanager.c:
4474         (gst_dpman_add_required_dparam_callback),
4475         (gst_dpman_add_required_dparam_direct),
4476         (gst_dpman_add_required_dparam_array),
4477         (gst_dpman_remove_required_dparam), (gst_dpman_attach_dparam),
4478         (gst_dpman_get_dparam), (gst_dpman_get_dparam_type),
4479         (gst_dpman_get_manager)
4480           restructured DParam docs
4481
4482 2005-01-25  Tim-Philipp Müller  <tim at centricular dot net>
4483
4484         * gst-element-check.m4:
4485           Only check for gst-inspect if we haven't already
4486           found it in previous element check runs
4487
4488 2005-01-25  Stefan Kost  <ensonic@users.sf.net>
4489
4490         * docs/gst/Makefile.am:
4491         * docs/libs/Makefile.am:
4492           fixed install rules to treat style.css as optional
4493
4494 2005-01-24  Stefan Kost  <ensonic@users.sf.net>
4495
4496         * docs/gst/Makefile.am:
4497         * docs/libs/Makefile.am:
4498           install style.css along with docs
4499         * docs/gst/tmpl/gstbin.sgml:
4500         * docs/gst/tmpl/gstclock.sgml:
4501         * docs/gst/tmpl/gstdata.sgml:
4502         * docs/gst/tmpl/gstelement.sgml:
4503         * gst/gstbin.h:
4504         * gst/gstelement.c: (gst_element_class_init):
4505         * gst/gstelement.h:
4506           fixing incomplete docs
4507
4508 2005-01-24  Tim-Philipp Müller  <tim at centricular dot net>
4509
4510         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
4511           Don't unref seek event twice when fflush() fails
4512           
4513 2005-01-22  David Schleef  <ds@schleef.org>
4514
4515         * configure.ac: Add --disable-valgrind. (partial fix for #164890)
4516
4517 2005-01-21  Stefan Kost  <ensonic@users.sf.net>
4518
4519         * docs/gst/Makefile.am:
4520         * docs/libs/Makefile.am:
4521           added params for deprecation guards
4522         * gst/gst.c:
4523         * gst/gst.h:
4524         * gst/gsterror.c: (_gst_resource_errors_init),
4525         (_gst_stream_errors_init):
4526         * gst/gsterror.h:
4527           documented some more enums
4528
4529 2005-01-19  Jan Schmidt  <thaytan@mad.scientist.com>
4530         * gst/autoplug/gstspideridentity.c:
4531         Cosmetic fix - spider_find_peek should be static
4532         * gst/parse/parse.l:
4533         Applying fix for #164261
4534
4535 2005-01-18  Stefan Kost  <ensonic@users.sf.net>
4536
4537         * docs/gst/gstreamer-sections.txt:
4538         * docs/gst/tmpl/gstplugin.sgml:
4539         * docs/libs/gstreamer-libs-sections.txt:
4540         * docs/libs/tmpl/gstcontrol.sgml:
4541         * gst/gstbuffer.h:
4542         * gst/gsttag.h:
4543         * gst/gstvalue.c:
4544           added docs for the TAG defines
4545
4546 2005-01-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4547
4548         * gst/schedulers/gstoptimalscheduler.c: (schedule_group):
4549           Only unref entry if there is an entry.
4550
4551 2005-01-17  Wim Taymans  <wim@fluendo.com>
4552
4553         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
4554         (remove_from_group), (schedule_group), (normalize_group),
4555         (gst_opt_scheduler_iterate):
4556         Also ref/unref decoupled elements before iterating the
4557         group since they are not added to the list of elements.
4558
4559 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4560
4561         * docs/manual/highlevel-components.xml:
4562           Add subtitle/streamselection as new features to playbin.
4563
4564 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4565
4566         * docs/manual/manual.xml:
4567           Re-enable dataaccess docs (oops).
4568
4569 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4570
4571         * docs/pwg/advanced-types.xml:
4572         * docs/random/mimetypes:
4573           Add documentation on libsndfile types (#163309), by Steve Baker
4574           <steve@stevebaker.org>.
4575         * gst/gstelement.c: (gst_element_release_request_pad):
4576           If an element has no explicit function, just remove the pad.
4577
4578 2005-01-17  Luca Ognibene  <luogni@tin.it>
4579
4580         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4581
4582         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load):
4583           Fix memleak (#163801).
4584
4585 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4586
4587         * gst/elements/gsttee.c: (gst_tee_getcaps), (gst_tee_link):
4588           I think this is actually more correct...
4589
4590 2005-01-16  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4591
4592         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
4593           Another workaround for memory access while destroyed in callback.
4594           Please, someone with refcount knowledge, have a look at this.
4595
4596 2005-01-15  Thomas Vander Stichele  <thomas at apestaart dot org>
4597
4598         * docs/faq/faq.xml:
4599         * docs/faq/legal.xml:
4600           move the legal Q&A here
4601
4602 2005-01-14  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4603
4604         * gst/elements/gsttee.c: (gst_tee_getcaps), (gst_tee_link),
4605         (gst_tee_request_new_pad):
4606           Fix negotiation.
4607
4608 2005-01-14  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
4609
4610         * docs/random/omega/caps2:
4611         * testsuite/caps/caps_strings:
4612           replace framerate aproximations by their real value
4613           (24000/1001, 30000/1001, 60000/1001)
4614           Partially fixes bug #164049
4615
4616 2005-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
4617
4618         * docs/gst/Makefile.am:
4619           don't fail on the stupid GstPoptOption
4620
4621 2005-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
4622
4623         * gst/gstpad.h:
4624         * gst/gstprobe.c:
4625           allow probes to work on ghost pads by realizing the pad
4626           probe debugging
4627
4628 2005-01-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4629
4630         * docs/gst/gstreamer-sections.txt:
4631         * docs/gst/tmpl/gstpad.sgml:
4632         * gst/gstpad.c: (gst_pad_set_active_recursive):
4633         * gst/gstpad.h:
4634           Add gst_pad_set_active_recursive().
4635
4636 2005-01-10  Thomas Vander Stichele  <thomas at apestaart dot org>
4637
4638         * docs/random/release:
4639           updates
4640         * gst/gst_private.h:
4641         * gst/gstinfo.c:
4642         * gst/gstobject.c:
4643           move deep_notify logging to a new category
4644         * gst/gstprobe.c:
4645         * gst/gstprobe.h:
4646           add stuff so bindings can wrap probes
4647
4648 2005-01-09  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
4649
4650         * gst/gstplugin.c: (gst_plugin_load):
4651           Fix plugin loading if plugin/lib was already loaded. Fixes
4652           #163383
4653
4654 2005-01-09  Sebastien Cote  <sc5@hermes.usherb.ca>
4655
4656         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4657
4658         * gst/gstpluginfeature.c: (gst_plugin_feature_ensure_loaded):
4659           Protect plugin loading by a mutex so it's threadsafe. Fixes
4660           #163234.
4661
4662 2005-01-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4663
4664         * gst/gstevent.c: (_gst_event_copy):
4665           Reference source object when copying events, since it'll be
4666           dereferenced on event dereferencing as well.
4667
4668 2005-01-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4669
4670         * docs/gst/gstreamer-sections.txt:
4671         * docs/gst/tmpl/gstevent.sgml:
4672         * gst/gstevent.c: (gst_event_new_filler_stamped),
4673         (gst_event_filler_get_duration):
4674         * gst/gstevent.h:
4675           Add two new functions for filler events (which are used to
4676           synchronize streams if one of them is not having any data
4677           for a while) without interrupting the actual data-stream.
4678           Basically a no-op.
4679         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
4680         (gst_queue_link_sink), (gst_queue_link_src),
4681         (gst_queue_change_state):
4682           Allow for renegotiation while filled. Required for stream
4683           switching while playing.
4684
4685 2005-01-08  Benjamin Otte  <otte@gnome.org>
4686
4687         * gst/gstelement.c: (gst_element_link_many):
4688           fix up g_return_if_fail's
4689         * po/LINGUAS:
4690         * po/de.po:
4691           add German translation, that was somehow not included
4692
4693 2005-01-08  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
4694
4695         * docs/random/mimetypes:
4696           add 2 more 4CC code for DV (HDTV and SDTV-LongPlay profiles)
4697           do not add them to riff-lib as they are not common
4698
4699 2005-01-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4700
4701         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
4702           Check for existence of probe after performing the probe before
4703           re-accessing it to prevent segfaults caused by removal of the
4704           probe in the callback.
4705
4706 2005-01-05  David Schleef  <ds@schleef.org>
4707
4708         * testsuite/registry/Makefile.am:
4709         * testsuite/registry/gst-print-formats.c:
4710         (print_pad_templates_info), (print_element_list),
4711         (print_typefind_list), (list_sort_func), (get_typefind_mime_list),
4712         (g_list_uniqify), (get_pad_templates_info),
4713         (get_element_mime_list), (print_mime_list), (main): A little
4714         program that looks through the registry to find elements of
4715         a given type.  Not particularly interesting as a test, except
4716         that there's no other test covering the same area.
4717
4718 2005-01-05  David Schleef  <ds@schleef.org>
4719
4720         * tools/gst-launch.c: (idle_func), (fault_handler_sighandler),
4721         (fault_handler_sigaction), (fault_spin),
4722         (sigint_handler_sighandler), (play_handler), (main): Fix deadlocks
4723         in signal.h-type signal handlers by not calling forbidden functions,
4724         including gst_element_set_state().
4725
4726 2005-01-05  David Schleef  <ds@schleef.org>
4727
4728         * gst/gstvalue.h: Mark _gst_reserved[] as private
4729
4730 2005-01-05  David Schleef  <ds@schleef.org>
4731
4732         * gst/gstvalue.c: Fix doc build problem.
4733
4734 2005-01-05  David Schleef  <ds@schleef.org>
4735
4736         * gst/gstvalue.c: Add some documentation
4737
4738 2005-01-05  Stefan Kost  <ensonic@users.sf.net>
4739
4740         * docs/README:
4741           another shell oneliner for empty return value docs
4742         * gst/gstcaps.c:
4743         * gst/gstvalue.c:
4744         * libs/gst/control/dparam.c:
4745           more doc fixes (parameters and return values)
4746
4747 2005-01-05  Vincent Torri  <torri@iecn.u-nancy.fr>
4748
4749         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4750
4751         * gst/gstregistry.h:
4752         * gst/registries/gstxmlregistry.c:
4753           Fix macro's for Mingw (fixes #162276).
4754
4755 2005-01-04  Stefan Kost  <ensonic@users.sf.net>
4756
4757         * docs/README:
4758           quick shell oneliner to find undocumented members
4759         * docs/gst/tmpl/gstplugin.sgml:
4760         * docs/gst/tmpl/gstscheduler.sgml:
4761         * docs/gst/tmpl/gstthread.sgml:
4762           more enumtypes cleanup
4763         * gst/gsterror.h:
4764           activated documentation comments, now someone needs to document
4765           the enums :(
4766
4767 2005-01-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4768
4769         * docs/manual/manual.xml:
4770           Add dataaccess part (doh!).
4771
4772 2005-01-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4773
4774         * docs/manual/advanced-autoplugging.xml:
4775           Fix typo (intiate -> initiate).
4776
4777 2005-01-02  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4778
4779         * docs/random/bbb/streamselection:
4780           Add some notes on how to handle multi-subtitle/-audio streams.
4781
4782 2004-12-30  Stefan Kost  <ensonic@users.sf.net>
4783
4784         * docs/gst/gstreamer-docs.sgml:
4785         * docs/gst/gstreamer-sections.txt:
4786         * docs/gst/tmpl/gstenumtypes.sgml:
4787         * docs/gst/tmpl/gsterror.sgml:
4788         * docs/gst/tmpl/gstevent.sgml:
4789         * docs/gst/tmpl/gstpad.sgml:
4790         * docs/gst/tmpl/gstpadtemplate.sgml:
4791         * docs/gst/tmpl/gstthread.sgml:
4792           removed gstenumtypes section from docs and put all the enums into
4793           their sections
4794
4795 2004-12-27  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
4796
4797         * gst/gstplugin.c:
4798           document gst_library_load a bit more (riff special case + return
4799           value if already loaded)
4800         * testsuite/bytestream/filepadsink.c:
4801           plugin name is 'gstbytestream', not 'bytestream'
4802
4803 2004-12-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4804
4805         * docs/random/bbb/subtitles:
4806           Add some first mind rumblings on proper subtitle support.
4807
4808 2004-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
4809
4810         * po/ca.po:
4811         * po/sv.po:
4812           updated translations
4813
4814 2004-12-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4815
4816         * docs/manual/advanced-dataaccess.xml:
4817           Add section on how to use fakesrc/fakesink/identity in your
4818           application, plus section on how to embed plugins. Also mention
4819           probes.
4820         * docs/manual/appendix-checklist.xml:
4821         * docs/manual/appendix-debugging.xml:
4822         * docs/manual/appendix-gnome.xml:
4823         * docs/manual/appendix-integration.xml:
4824           Debug -> checklist, GNOME -> integration, add sections on Linux,
4825           KDE integration and add other things useful for application
4826           development.
4827         * docs/manual/manual.xml:
4828           Remove some fixmes, update some file pointers.
4829         * docs/pwg/appendix-checklist.xml:
4830           Fix typo.
4831         * docs/pwg/building-boiler.xml:
4832           Remove ugly header and add commented fixme.
4833         * docs/pwg/pwg.xml:
4834           Add fixme.
4835         * examples/manual/Makefile.am:
4836           Add example for added docs.
4837
4838 2004-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
4839
4840         * configure.ac:
4841           back to HEAD
4842
4843 === release 0.8.8 ===
4844
4845 2004-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
4846
4847         * NEWS:
4848         * RELEASE:
4849         * configure.ac:
4850           Releasing 0.8.8, "I'll Take Care Of You"
4851
4852 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
4853
4854         * configure.ac:
4855           second prerelease
4856
4857 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
4858
4859         patch by: Wim Taymans
4860
4861         * gst/gstbin.c:
4862           Fix for #159852 - make iterate emission threadsafe
4863
4864 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
4865
4866         * docs/faq/cvs.xml:
4867           notes about new fdo account request
4868
4869 2004-12-20  Stefan Kost  <ensonic@users.sf.net>
4870
4871         * docs/gst/gstreamer-docs.sgml:
4872         * docs/gst/tmpl/gstenumtypes.sgml:
4873         * docs/gst/tmpl/gstplugin.sgml:
4874         * docs/libs/gstreamer-libs-docs.sgml:
4875           Added missing short docs. Added ids for navigation.
4876
4877 2004-12-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4878
4879         * docs/manual/advanced-autoplugging.xml:
4880         * docs/manual/advanced-schedulers.xml:
4881         * docs/manual/advanced-threads.xml:
4882           Rewrites. Remove cothreads, go a bit into opt specifically,
4883           document threads and their gotchas, and do some technical stuff
4884           on autoplugging plus add some working examples. Fixes #157395.
4885         * examples/manual/Makefile.am:
4886           Add typefind/autoplugger example (one that actually works).
4887           Remove queue example since it's a duplicate of the thread one.
4888
4889 2004-12-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4890
4891         * gst/gstvalue.c: (gst_value_deserialize_string):
4892           use deprecated g_value_set_string_take_ownership to keep compatible
4893           with glib 2.2
4894
4895 2004-12-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4896
4897         * gst/gstvalue.c: (gst_value_deserialize_string):
4898           revert last patch, only dom a g_utf8_validate now before accepting
4899           the string - caps parsing strips " from strings so we can't rely on
4900           them
4901         * testsuite/caps/value_serialize.c: (test_string_deserialization):
4902           disable a test that tested the above and comment it
4903
4904 2004-12-16  Steve Lhomme <steve.lhomme@free.fr>
4905
4906         Patch reviewed by David Schleef  <ds@schleef.org>
4907
4908         * win32/gstenumtypes.c: Update from gst/gstenumtypes.c (See
4909         bug #153882)
4910         * win32/gstenumtypes.h: same
4911
4912 2004-12-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4913
4914         * gst/gstpad.c: (gst_pad_query):
4915           Do query on realized pad, similar to how convert/send_event handle
4916           this. Also makes sense, since this pad belongs to the function to
4917           which this query will be sent. Fixes #158163.
4918
4919 2004-12-16  Christian Fredrik Kalager Schaller  <uraeus@gnome.org>
4920
4921         * docs/manual/appendix-programs.xml: fix pipeline to actually work
4922
4923 2004-12-16  Christian Fredrik Kalager Schaller  <christian@fluendo.com>
4924
4925         * docs/faq/general.xml: fix pipeline to actually work
4926
4927 2004-12-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4928
4929         * gst/gstvalue.c: (gst_value_deserialize_string):
4930           check that a simple string that gets deserialized does not contain
4931           invalid characters
4932         * testsuite/caps/value_serialize.c: (test_string_deserialization):
4933           remove a test that tested a wring behaviour
4934
4935 2004-12-16  Matt Kraai  <kraai@alumni.cmu.edu>
4936
4937         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4938
4939         * docs/manual/intro-motivation.xml:
4940           Fix typos.
4941
4942 2004-12-16  Edward Hervey  <bilboed@bilboed.com>
4943
4944         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4945
4946         * docs/gst/tmpl/gstprobe.sgml:
4947           Fix documentation of probe callback - it is supposed to return
4948           FALSE, not TRUE, to remove data from the stream (#159087).
4949
4950 2004-12-16  Daniel Gazard  <dany42@free.fr>
4951
4952         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4953
4954         * gst/gstelementfactory.c: (gst_element_factory_create):
4955           Fix compile failure if compiling without libxml2 support (#149936).
4956
4957 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4958
4959         * docs/manual/advanced-autoplugging.xml:
4960         * docs/manual/highlevel-components.xml:
4961           Move spider from autoplugging to components. Autoplugging is for
4962           internals, not for solutions. ;-).
4963
4964 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4965
4966         * docs/random/ds/0.9-suggested-changes:
4967           Make note on device/location/uri property names.
4968
4969 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4970
4971         * docs/manual/advanced-autoplugging.xml:
4972         * docs/manual/advanced-clocks.xml:
4973         * docs/manual/advanced-interfaces.xml:
4974         * docs/manual/advanced-metadata.xml:
4975         * docs/manual/advanced-position.xml:
4976         * docs/manual/advanced-schedulers.xml:
4977         * docs/manual/advanced-threads.xml:
4978         * docs/manual/appendix-gnome.xml:
4979         * docs/manual/appendix-programs.xml:
4980         * docs/manual/appendix-quotes.xml:
4981         * docs/manual/autoplugging.xml:
4982         * docs/manual/basics-bins.xml:
4983         * docs/manual/basics-data.xml:
4984         * docs/manual/basics-elements.xml:
4985         * docs/manual/basics-helloworld.xml:
4986         * docs/manual/basics-init.xml:
4987         * docs/manual/basics-pads.xml:
4988         * docs/manual/basics-plugins.xml:
4989         * docs/manual/bins-api.xml:
4990         * docs/manual/bins.xml:
4991         * docs/manual/buffers-api.xml:
4992         * docs/manual/buffers.xml:
4993         * docs/manual/clocks.xml:
4994         * docs/manual/components.xml:
4995         * docs/manual/cothreads.xml:
4996         * docs/manual/debugging.xml:
4997         * docs/manual/dparams-app.xml:
4998         * docs/manual/dynamic.xml:
4999         * docs/manual/elements-api.xml:
5000         * docs/manual/elements.xml:
5001         * docs/manual/factories.xml:
5002         * docs/manual/gnome.xml:
5003         * docs/manual/goals.xml:
5004         * docs/manual/helloworld.xml:
5005         * docs/manual/helloworld2.xml:
5006         * docs/manual/highlevel-components.xml:
5007         * docs/manual/highlevel-xml.xml:
5008         * docs/manual/init-api.xml:
5009         * docs/manual/intro-basics.xml:
5010         * docs/manual/intro-motivation.xml:
5011         * docs/manual/intro-preface.xml:
5012         * docs/manual/intro.xml:
5013         * docs/manual/links-api.xml:
5014         * docs/manual/links.xml:
5015         * docs/manual/manual.xml:
5016         * docs/manual/motivation.xml:
5017         * docs/manual/pads-api.xml:
5018         * docs/manual/pads.xml:
5019         * docs/manual/plugins-api.xml:
5020         * docs/manual/plugins.xml:
5021         * docs/manual/programs.xml:
5022         * docs/manual/queues.xml:
5023         * docs/manual/quotes.xml:
5024         * docs/manual/schedulers.xml:
5025         * docs/manual/states-api.xml:
5026         * docs/manual/states.xml:
5027         * docs/manual/threads.xml:
5028         * docs/manual/typedetection.xml:
5029         * docs/manual/win32.xml:
5030         * docs/manual/xml.xml:
5031           Try 2. This time, include a short preface as a "general
5032           introduction", also add code blocks around all code samples
5033           so they get compiled. We still need a way to tell readers
5034           the filename of the code sample. In some cases, don't show
5035           all code in the documentation, but do include it in the generated
5036           code. This allows for focussing on specific bits in the docs,
5037           while still having a full test application available.
5038         * examples/manual/Makefile.am:
5039           Fix up examples for new ADM. Add several of the new examples that
5040           were either added or were missing from the build system.
5041         * examples/manual/extract.pl:
5042           Allow nameless blocks.
5043
5044 2004-12-15  Thomas Vander Stichele  <thomas at apestaart dot org>
5045
5046         * docs/manual/elements-api.xml:
5047         * docs/manual/helloworld.xml:
5048         * examples/manual/extract.pl:
5049           fix last example.  Add example of adding code blocks that are not
5050           shown in docbook output.
5051
5052 2004-12-15  Thomas Vander Stichele  <thomas at apestaart dot org>
5053
5054         * docs/manual/dynamic.xml:
5055         * docs/manual/elements-api.xml:
5056         * docs/manual/gnome.xml:
5057         * docs/manual/helloworld2.xml:
5058         * docs/manual/init-api.xml:
5059         * docs/manual/queues.xml:
5060         * docs/manual/threads.xml:
5061         * docs/manual/xml.xml:
5062         * examples/manual/extract.pl:
5063           Make it possible to extract example code from separate blocks.
5064           Should make Ronald happy.
5065
5066 2004-12-15  Wim Taymans  <wim@fluendo.com>
5067
5068         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5069         (remove_from_group), (group_elements_set_visited),
5070         (normalize_group), (gst_opt_scheduler_iterate):
5071         Fix bug where a flag was not updated on a decoupled entry point 
5072         because we were just checking the group element list and decoupled
5073         elements are not in that list..
5074
5075 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5076
5077         * docs/manual/advanced-autoplugging.xml:
5078         * docs/manual/advanced-clocks.xml:
5079         * docs/manual/advanced-dparams.xml:
5080         * docs/manual/advanced-interfaces.xml:
5081         * docs/manual/advanced-metadata.xml:
5082         * docs/manual/advanced-position.xml:
5083         * docs/manual/advanced-schedulers.xml:
5084         * docs/manual/advanced-threads.xml:
5085         * docs/manual/appendix-debugging.xml:
5086         * docs/manual/appendix-gnome.xml:
5087         * docs/manual/appendix-programs.xml:
5088         * docs/manual/appendix-quotes.xml:
5089         * docs/manual/appendix-win32.xml:
5090         * docs/manual/autoplugging.xml:
5091         * docs/manual/basics-bins.xml:
5092         * docs/manual/basics-data.xml:
5093         * docs/manual/basics-elements.xml:
5094         * docs/manual/basics-helloworld.xml:
5095         * docs/manual/basics-init.xml:
5096         * docs/manual/basics-pads.xml:
5097         * docs/manual/basics-plugins.xml:
5098         * docs/manual/bins-api.xml:
5099         * docs/manual/bins.xml:
5100         * docs/manual/buffers-api.xml:
5101         * docs/manual/buffers.xml:
5102         * docs/manual/clocks.xml:
5103         * docs/manual/components.xml:
5104         * docs/manual/cothreads.xml:
5105         * docs/manual/debugging.xml:
5106         * docs/manual/dparams-app.xml:
5107         * docs/manual/dynamic.xml:
5108         * docs/manual/elements-api.xml:
5109         * docs/manual/elements.xml:
5110         * docs/manual/factories.xml:
5111         * docs/manual/gnome.xml:
5112         * docs/manual/goals.xml:
5113         * docs/manual/helloworld.xml:
5114         * docs/manual/helloworld2.xml:
5115         * docs/manual/highlevel-components.xml:
5116         * docs/manual/highlevel-xml.xml:
5117         * docs/manual/init-api.xml:
5118         * docs/manual/intro-motivation.xml:
5119         * docs/manual/intro-preface.xml:
5120         * docs/manual/intro.xml:
5121         * docs/manual/links-api.xml:
5122         * docs/manual/links.xml:
5123         * docs/manual/manual.xml:
5124         * docs/manual/motivation.xml:
5125         * docs/manual/pads-api.xml:
5126         * docs/manual/pads.xml:
5127         * docs/manual/plugins-api.xml:
5128         * docs/manual/plugins.xml:
5129         * docs/manual/programs.xml:
5130         * docs/manual/queues.xml:
5131         * docs/manual/quotes.xml:
5132         * docs/manual/schedulers.xml:
5133         * docs/manual/states-api.xml:
5134         * docs/manual/states.xml:
5135         * docs/manual/threads.xml:
5136         * docs/manual/typedetection.xml:
5137         * docs/manual/win32.xml:
5138         * docs/manual/xml.xml:
5139           First try at rewriting the ADM. Needs lotsamore work, but some
5140           parts might already be somewhat useful.
5141         * docs/pwg/advanced-interfaces.xml:
5142           Remove properties interface, it never actually existed (except for
5143           on my HD...).
5144
5145 2004-12-13  David Schleef  <ds@schleef.org>
5146
5147         * gst/gstpad.c: (gst_pad_set_explicit_caps): Allow caps to
5148         be NULL (bug #160220).
5149
5150 2004-12-13  David Schleef  <ds@schleef.org>
5151
5152         * configure.ac: remove all mmx stuff, because it's not used.
5153         * docs/random/ds/0.9-suggested-changes: additional notes
5154         * include/Makefile.am: we don't use these anymore
5155         * include/mmx.h: remove
5156         * include/sse.h: remove
5157
5158 2004-12-13  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
5159
5160         * docs/random/mimetypes:
5161           Add FOURCC code for h264 codec (VSSH)
5162           Add alternate FOURCC codes for h263 related codecs
5163
5164 2004-12-10  Stefan Kost  <ensonic@users.sf.net>
5165
5166         * docs/manual/programs.xml:
5167           Added more gst-launch examples.
5168
5169 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5170
5171         * gst/gstqueue.c: (gst_queue_handle_src_query):
5172           Check for availability again.
5173
5174 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5175
5176         * gst/gstcaps.c: (gst_caps_compare_structures):
5177           Simple caps go first. This has the nice side-effect of fixing an
5178           obscure warning.
5179
5180 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5181
5182         * gst/gstversion.h.in:
5183           Protect header.
5184
5185 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5186
5187         * gst/schedulers/gstoptimalscheduler.c:
5188         (gst_opt_scheduler_schedule_run_queue), (schedule_chain),
5189         (gst_opt_scheduler_get_wrapper):
5190           When we're recursing into a chain run, only run the directly
5191           related group, not all queued ones. This will fix a possible
5192           deadlock in chains with more than two groups.
5193
5194 2004-12-08  Thomas Vander Stichele  <thomas at apestaart dot org>
5195
5196         * autogen.sh:
5197           remove patch if autopoint fails
5198
5199 2004-12-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5200
5201         * docs/gst/gstreamer-sections.txt:
5202           Document Thomas' addition, fix build, make Luis the sheriff happy.
5203
5204 2004-12-07  Thomas Vander Stichele  <thomas at apestaart dot org>
5205
5206         * gst/gstplugin.c:
5207         * gst/gstplugin.h:
5208           add accessor for version field
5209
5210 2004-12-06  Thomas Vander Stichele  <thomas at apestaart dot org>
5211
5212         submitted by: Luca Ferretti <elle.uca@infinito.it>
5213
5214         * po/LINGUAS:
5215         * po/it.po:
5216           New tranlation added: Italian
5217
5218 2004-12-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5219
5220         * gst/gstpad.c: (gst_pad_is_negotiated),
5221         (gst_pad_get_negotiated_caps):
5222           GST_RPAD_* will only operate on a RealPad (it casts the pointer,
5223           it doesn't actually check the contents), so be sure to hand it
5224           a RealPad else we'll crash.
5225
5226 2004-12-03  Wim Taymans  <wim@fluendo.com>
5227
5228         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
5229         (gst_queue_link), (gst_queue_handle_src_query):
5230         Reverted to 1.110 until this makes the testsuite and various
5231         apps work.
5232
5233 2004-12-01  Christian Fredrik Kalager Schaller <christian@fluendo.com>
5234
5235         * docs/upload.mak: fix included CVS conflict strings
5236
5237 2004-12-01  William Jon McCann  <mccann@jhu.edu>
5238
5239         Reviewed by: Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5240
5241         * gst/gstelement.c: (gst_element_error_full):
5242           Use g_error_new_literal because error text may have
5243           percentage signs in it. Fixes #160019.
5244
5245 2004-12-01  Benjamin Otte  <otte@gnome.org>
5246
5247         * gst/elements/gstbufferstore.c:
5248         (gst_buffer_store_add_buffer_func):
5249           don't try to make subbuffers bigger than they can be. (fixes
5250           #159970)
5251
5252 2004-11-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5253
5254         * docs/gst/gstreamer-sections.txt:
5255         * docs/gst/tmpl/gstvalue.sgml:
5256           Add new function to docs to fix build.
5257
5258 2004-11-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5259
5260         * gst/gstcaps.c: (gst_caps_is_fixed_foreach):
5261         * gst/gstpad.c: (_gst_pad_default_fixate_value),
5262         (_gst_pad_default_fixate_foreach):
5263         * gst/gstvalue.c: (gst_type_is_fixed), (gst_value_is_fixed):
5264         * gst/gstvalue.h:
5265           Deprecate _type_is_fixed, use _value_is_fixed instead, since
5266           in some cases (arrays), the fixedness depends on the content.
5267         * gst/gstqueue.c: (gst_queue_handle_src_query):
5268           Check for availability before doing something.
5269
5270 2004-11-29  Wim Taymans  <wim@fluendo.com>
5271
5272         * testsuite/threads/Makefile.am:
5273         * testsuite/threads/signals.c: (gst_test_get_type),
5274         (gst_test_class_init), (gst_test_init), (gst_test_dispose),
5275         (gst_test_set_property), (gst_test_get_property),
5276         (gst_test_do_signal1), (signal2_handler), (gst_test_do_signal2),
5277         (gst_test_do_prop), (run_thread), (main):
5278         Added a bunch of testcases that show threadsafety bugs in glib.
5279
5280 2004-11-29  Stefan Kost  <ensonic@users.sf.net>
5281
5282         * docs/manual/programs.xml:
5283           Added a first batch of gst-launch examples, as provided by Ronald
5284           and others from the devel-mlist
5285
5286 2004-11-28  Benjamin Otte  <otte@gnome.org>
5287
5288         * gst/gstelement.c: (gst_element_negotiate_pads):
5289           simplify
5290         * gst/gstvalue.c: (gst_string_wrap), (gst_string_unwrap),
5291         (gst_value_serialize_string), (gst_value_deserialize_string):
5292           add unwrapping of previously wrapped strings. Fix bug in wrapping
5293           while at it.
5294         * testsuite/caps/value_serialize.c: (test1),
5295         (test_string_serialization), (test_string_deserialization), (main):
5296           add tests for string (de)serialization
5297
5298 2004-11-26  Wim Taymans  <wim@fluendo.com>
5299
5300         * testsuite/threads/159566.c: (object_deep_notify), (main):
5301         * testsuite/threads/Makefile.am:
5302         Added testsuite to show bug #159566
5303
5304 2004-11-25  Wim Taymans  <wim@fluendo.com>
5305
5306         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_change_state),
5307         (gst_thread_child_state_change), (gst_thread_main_loop):
5308         Ref the thread object in the GThread mainloop. Break out of the
5309         thread mainloop if it holds the last ref. This properly exits
5310         the threads when disposing the thread from its own context. It
5311         also avoids possible deadlocks in the dispose function.
5312
5313 2004-11-24  Martin Soto  <martinsoto@users.sourceforge.net>
5314
5315         * gst/gstqueue.c (gst_queue_link_sink): Grab the lock only when
5316         it is necessary to wait.
5317
5318 2004-11-24  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5319
5320         * docs/pwg/building-boiler.xml:
5321           Make description somewhat clearer.
5322
5323 2004-11-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5324
5325         * docs/upload.mak:
5326           Apparently docs changed location on FDO's server.
5327
5328 2004-11-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5329
5330         * docs/pwg/appendix-checklist.xml:
5331           Add some random notes on things to check when writing an element.
5332           This list can be extended as people see fit.
5333
5334 2004-11-23  Martin Soto  <martinsoto@users.sourceforge.net>
5335
5336         * gst/gstqueue.c (gst_queue_init, gst_queue_link_sink)
5337         (gst_queue_link_src): Allow for renegotiating the caps of the sink
5338         pad. The queue will now wait until it is empty and forward the new
5339         caps to the source.
5340         * gst/gstbin.c (gst_bin_set_element_sched)
5341         (gst_bin_unset_element_sched): Make sure that all elements and
5342         links are registered and unregistered with the scheduler exactly
5343         once. This elaborates on a fix by Benjamin Otte, but
5344         guarantees that decoupled elements are also registered.
5345
5346 2004-11-11  Thomas Vander Stichele  <thomas at apestaart dot org>
5347
5348         * docs/manual/quotes.xml:
5349           add a quote
5350         * configure.ac:
5351         * gst/gst.c:
5352         * gst/gstinfo.c:
5353           add LIBDIR and move init message higher up so it's at the start
5354
5355 2004-11-08  Christian Fredrik Kalager Schaller  <christian@fluendo.com>
5356
5357         * gst/schedulers/Makefile.am: fix disted build fair by including .h file
5358         * gstreamer.spec.in: add fair
5359
5360 2004-11-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5361
5362         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
5363         * gst/elements/gstidentity.c: (gst_identity_class_init):
5364           Use G_SIGNAL_TYPE_STATIC_SCOPE, patch by Christophe Fergeau
5365           <teuf@gnome.org> (#157263).
5366         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
5367         (gst_type_find_handle_src_query):
5368           Subtract size of internally stored data from position queries.
5369
5370 2004-11-07  Martin Soto  <martinsoto@users.sourceforge.net>
5371
5372         * gst/schedulers/fairscheduler.c:
5373         * gst/schedulers/faircothreads.c:
5374         * gst/schedulers/faircothreads.h:
5375         New cothread based scheduler: Fair scheduler.
5376         * gst/schedulers/gthread-cothreads.h: 
5377         Add the standard #if around the whole file.
5378         Defining symbol GTHREAD_COTHREADS_NO_DEFINITIONS will now prevent
5379         compilation of the functions defined in this file. This is
5380         necessary to be able to use this file as a normal header.
5381         * gst/schedulers/Makefile.am: Add compiling support for fair
5382         scheduler.
5383         * docs/gst/Makefile.am (IGNORE_HFILES): Exclude internal fair
5384         scheduler cothreads layer from documentation generation.
5385
5386 2004-11-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5387
5388         * gst/autoplug/gstspideridentity.c:
5389         (gst_spider_identity_sink_loop_type_finding):
5390           Don't crash if that function is not implemented.
5391
5392 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5393
5394         * docs/pwg/advanced-types.xml:
5395           Another typo.
5396
5397 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5398
5399         * docs/pwg/intro-preface.xml:
5400           Hm, ok, so the brackets weren't really useful...
5401         * docs/pwg/other-ntoone.xml:
5402           Fix embarassing typo.
5403
5404 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5405
5406         * docs/pwg/intro-preface.xml:
5407           Rewrite preface.
5408
5409 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5410
5411         * docs/pwg/advanced-scheduling.xml:
5412         * docs/pwg/advanced-tagging.xml:
5413         * docs/pwg/advanced-types.xml:
5414         * docs/pwg/building-boiler.xml:
5415         * docs/pwg/building-chainfn.xml:
5416         * docs/pwg/building-signals.xml:
5417         * docs/pwg/building-state.xml:
5418         * docs/pwg/building-testapp.xml:
5419         * docs/pwg/intro-basics.xml:
5420         * docs/pwg/other-manager.xml:
5421         * docs/pwg/other-source.xml:
5422           Typo fixes.
5423         * docs/pwg/other-manager.xml:
5424           Add some first content. No example code yet.
5425         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
5426           Remove double newlines.
5427
5428 2004-11-04  Wim Taymans  <wim@fluendo.com>
5429
5430         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5431         (remove_from_group), (normalize_group), (group_migrate_connected),
5432         (gst_opt_scheduler_iterate):
5433         * testsuite/schedulers/.cvsignore:
5434         * testsuite/schedulers/Makefile.am:
5435         * testsuite/schedulers/queue_link.c: (main):
5436         Added testcase for scheduler segfault.
5437         Fix scheduler segfault when removing a decoupled
5438         entry point as the last element from a group.
5439
5440 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
5441
5442         * gst/gstmarshal.list: add missing marshaller, fixes build
5443
5444 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
5445
5446         * docs/random/signal: added notes about using BOXED for GstBuffer
5447         signal marshallers, not POINTER
5448
5449 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
5450
5451         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
5452         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init): more
5453         POINTER=>BOXED changes to marshal GstBuffers
5454
5455 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
5456
5457         * gst/elements/gstidentity.c: (gst_identity_class_init): GstBuffer is 
5458         a boxed type, marshal the signal with VOID__BOXED, not VOID__POINTER
5459
5460 2004-11-03  Stefan Kost  <ensonic@users.sf.net>
5461
5462         * docs/gst/gstreamer-sections.txt:
5463         * docs/gst/tmpl/gstcaps.sgml:
5464         * docs/gst/tmpl/gsterror.sgml:
5465         * docs/gst/tmpl/gstinfo.sgml:
5466         * docs/gst/tmpl/gstmacros.sgml:
5467         * docs/gst/tmpl/gstutils.sgml:
5468         * docs/random/ensonic/interfaces.txt:
5469         * gst/gstinfo.h:
5470           added some more docs, removed two obsolete defines
5471
5472 2004-11-02  Kjartan Maraas <as at gnome.org>
5473
5474         reviewed by: Wim Taymans, Ronald Bultje.
5475
5476         * gst/cothreads.c: (cothread_create):
5477         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_remove_func),
5478         (gst_bin_child_state_change_func):
5479         * gst/gstbuffer.c: (gst_buffer_span):
5480         * gst/gstelement.c: (gst_element_get_index),
5481         (gst_element_get_event_masks), (gst_element_get_query_types),
5482         (gst_element_get_formats):
5483         * gst/gsterror.c: (_gst_core_errors_init),
5484         (_gst_library_errors_init), (_gst_resource_errors_init),
5485         (_gst_stream_errors_init):
5486         * gst/gstobject.c: (gst_object_default_deep_notify):
5487         * gst/gstpad.c: (gst_pad_get_event_masks),
5488         (gst_pad_get_internal_links_default):
5489         * gst/gstplugin.c: (gst_plugin_register_func),
5490         (gst_plugin_get_module):
5491         * gst/gststructure.c: (gst_structure_get_string),
5492         (gst_structure_get_abbrs), (gst_structure_from_abbr),
5493         (gst_structure_to_abbr):
5494         * gst/gstutils.c: (gst_print_element_args):
5495         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5496         (setup_group_scheduler), (gst_opt_scheduler_iterate):
5497         Aplied part of patch #157127: Cleanup of issues reported by 
5498         sparse.
5499         Also do not try to use cothreads when there is no cothread
5500         context yet.
5501
5502 2004-11-02  Sebastien Cote <sc5 at hermes.usherb.ca>
5503
5504         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5505         (gst_opt_scheduler_iterate):
5506         Applied patch #154061. Running a pipeline in which an element 
5507         calls GST_ELEMENT_ERROR in the chain function, the opt 
5508         scheduler doesn't unref the chain so it never gets freed.
5509
5510 2004-11-02  Wim Taymans  <wim@fluendo.com>
5511
5512         * gst/gststructure.c: (gst_structure_get_abbrs),
5513         (gst_structure_from_abbr), (gst_structure_to_abbr):
5514         Remove that ugly if-then thing in the code that converts
5515         between strings and types.
5516
5517 2004-11-02  Wim Taymans  <wim@fluendo.com>
5518
5519         * gst/gstscheduler.c: (gst_scheduler_add_element),
5520         (gst_scheduler_remove_element), (gst_scheduler_state_transition):
5521         Aplied clock distribution patch, this should fix bug
5522         #148787.
5523
5524 2004-10-27  Thomas Vander Stichele  <thomas at apestaart dot org>
5525
5526         Submitted by: Kjartan Maraas <kmaraas@broadpark.no>
5527
5528         * po/LINGUAS:
5529         * po/nb.po:
5530           Added Norwegian Bokmaal translation
5531
5532 2004-10-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5533
5534         * tools/gst-inspect.c: (print_signal_info):
5535           print signal arguments as pointers if they are
5536
5537 2004-10-22  Stefan Kost  <ensonic@users.sf.net>
5538
5539         * docs/pwg/building-boiler.xml:
5540           exchanged GTK_ macros with G_TYPE macros (as pointed out by mathrick)
5541
5542 2004-10-19  Wim Taymans  <wim at fluendo dot com>
5543
5544         * gst/parse/parse.l:
5545         * testsuite/parse/parse1.c: (main):
5546         Since parse can do 'element name=a:b' make 'a:b.' work as
5547         well. 
5548         Added testcase to verify fix.
5549
5550 2004-10-19  Wim Taymans  <wim at fluendo dot com>
5551
5552         * tools/gst-inspect.c: (print_pad_info), (print_plugin_features):
5553         Use the realpad when printing the direction.
5554         Add extra \n when printing extensions of typefind factories.
5555
5556 2004-10-13  David Schleef  <ds@schleef.org>
5557
5558         * examples/manual/Makefile.am: $< isn't portable in Makefile
5559         rules.
5560
5561 2004-10-13  Stefan Kost  <ensonic@users.sf.net>
5562
5563         * docs/gst/tmpl/gstobject.sgml:
5564         * docs/gst/tmpl/gstplugin.sgml:
5565         * docs/gst/tmpl/gstpluginfeature.sgml:
5566         * docs/gst/tmpl/gstregistry.sgml:
5567         * docs/gst/tmpl/gstversion.sgml:
5568         * gst/gstbin.c:
5569           more api documentation
5570         * gst/gstplugin.c: (gst_plugin_register_func),
5571         (gst_plugin_check_file), (gst_plugin_load_file):
5572           better error signaling and logging
5573
5574 2004-10-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5575
5576         * gst/gstqueue.c: (gst_queue_init), (gst_queue_handle_src_query):
5577           Subtract current queue contents from position queries.
5578
5579 2004-10-11  Johan Dahlin  <johan@gnome.org>
5580
5581         * gst/gsturi.c (gst_uri_get_location): unescape string
5582         (gst_uri_construct): escape string.
5583
5584 2004-10-11  Benjamin Otte  <otte@gnome.org>
5585
5586         * gst/gstpad.c: (gst_pad_renegotiate), (gst_pad_try_set_caps),
5587         (gst_pad_try_set_caps_nonfixed):
5588           allow renegotiation of unconnected pads (as inside spider). Simply
5589           return OK if unconnected - mimic try_set_caps there.
5590
5591 2004-10-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5592
5593         * gst/gstbin.c: (gst_bin_sync_children_state):
5594           Add missing break.
5595
5596 2004-10-09  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5597
5598         * gst/elements/gstfakesrc.c: (gst_fakesrc_get):
5599         Set element to EOS before sending EOS event
5600
5601 2004-10-08  Wim Taymans  <wim at fluendo dot com>
5602
5603         * gst/elements/gsttypefindelement.c:
5604         (gst_type_find_element_handle_event):
5605         Handle EOS events when doing the transition from
5606         typefind to data passing. This should fix the
5607         infinite loops in short files.
5608
5609 2004-10-07  Wim Taymans  <wim at fluendo dot com>
5610
5611         * gst/gstthread.c: (gst_thread_change_state),
5612         (gst_thread_child_state_change):
5613         Make sure no iteration happens while performing
5614         the state change as it could mess up the internal
5615         consistency of the thread state.
5616
5617 2004-10-07  Wim Taymans  <wim at fluendo dot com>
5618
5619         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_sync),
5620         (gst_thread_change_state), (gst_thread_child_state_change):
5621         Do not try to grab the iterate lock in the state change method
5622         when we are in the same thread as the iterate or else we
5623         could deadlock. Some other cleanups.
5624
5625 2004-10-06  Thomas Vander Stichele  <thomas at apestaart dot org>
5626
5627         * configure.ac:
5628           bump nano to cvs
5629
5630 === release 0.8.7 ===
5631
5632 2004-10-06  Thomas Vander Stichele  <thomas at apestaart dot org>
5633
5634         * configure.ac:
5635         * NEWS:
5636         * RELEASE:
5637         * configure.ac:
5638           releasing 0.8.7, "A Cruise"
5639
5640 2004-10-06  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
5641
5642         * docs/random/mimetypes:
5643         Add an entry for Sony ATRAC3 audio format with mime-type
5644         used by rmdemux et riff-read
5645
5646 2004-10-06  Wim Taymans  <wim at fluendo dot com>
5647
5648         * gst/elements/gsttypefindelement.c: (stop_typefinding):
5649         Push the buffer store instead of clearing it in case that
5650         the stream is not seekable.
5651
5652 2004-10-06  Wim Taymans  <wim at fluendo dot com>
5653
5654         * gst/gstthread.c: (gst_thread_init), (gst_thread_change_state),
5655         (gst_thread_main_loop):
5656         Lock the iteration and the state change so that automatic
5657         negotiation and fixation does not happen at the same time
5658         as the in stream negotiation.
5659
5660 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
5661
5662         * configure.ac:
5663           bump nano to cvs
5664
5665 === release 0.8.6 ===
5666
5667 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
5668
5669         * configure.ac:
5670         * NEWS:
5671         * RELEASE:
5672         * configure.ac:
5673           releasing 0.8.6, "Narc"
5674
5675 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
5676
5677         * configure.ac:
5678           prerel bump
5679
5680 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
5681
5682         patch by: Steve Lhomme
5683
5684         * gst/elements/gstfakesrc.c:
5685         * gst/elements/gstidentity.c:
5686         * gst/gstthread.c:
5687           Fix for #153881
5688
5689 2004-10-01  Wim Taymans  <wim at fluendo dot com>
5690
5691         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_crc):
5692         Fix threadsafety of the crc checking function.
5693
5694 2004-09-26  Thomas Vander Stichele  <thomas at apestaart dot org>
5695
5696         patch by: Ronald Bultje
5697
5698         * gst/elements/gsttypefindelement.c: (stop_typefinding),
5699         (gst_type_find_element_handle_event),
5700         (gst_type_find_element_chain):
5701         * gst/elements/gsttypefindelement.h:
5702          #153657.
5703          Filter out discont event from seekable sources when typefind
5704          asks them to seek.  Fixes typefind with demuxers for
5705          avi, asf and matroska.
5706
5707 2004-09-26  Thomas Vander Stichele  <thomas at apestaart dot org>
5708
5709         * docs/gst/gstreamer-sections.txt:
5710         * gst/gstcaps.c:
5711         * gst/gstcaps.h:
5712         * gst/gstpad.c:
5713           Revert preferred caps: (#147789)
5714
5715 2004-09-19  Steve Lhomme  <steve.lhomme@free.fr>
5716
5717         * win32/dirent.c:
5718           fix a memory leak
5719
5720 2004-09-10  Thomas Vander Stichele  <thomas at apestaart dot org>
5721
5722         * configure.ac:
5723           bump for prerelease
5724
5725 2004-09-09  Thomas Vander Stichele  <thomas at apestaart dot org>
5726
5727         * docs/Makefile.am:
5728         * docs/manual/elements-api.xml:
5729           restructure so that common stuff is shown first
5730         * docs/manual/init-api.xml:
5731           convert to examples
5732         * docs/manual/manual.xml:
5733         * docs/manuals.mak:
5734         * docs/url.entities:
5735           link to API on the website, possibly override later in build
5736         * examples/manual/.cvsignore:
5737           ignore more
5738         * examples/manual/Makefile.am:
5739           add more examples
5740         * examples/manual/extract.pl:
5741           error out on failure
5742
5743 2004-09-08  Thomas Vander Stichele  <thomas at apestaart dot org>
5744
5745         * docs/gst/tmpl/gstthread.sgml:
5746         * docs/manual/init-api.xml:
5747         * examples/manual/Makefile.am:
5748           convert two code bits to examples
5749
5750 2004-09-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
5751
5752         * gst/gstelement.c: (gst_element_change_state):
5753           Well, actually, I was about to remove this insane assert when
5754           I noticed Wim already did that. A warning is nice so we can
5755           fix actual ugs (using --g-fatal-warnings and backtraces), so
5756           I added that instead.
5757
5758 2004-09-06  Wim Taymans  <wim@fluendo.com>
5759
5760         * gst/gstelement.c: (gst_element_threadsafe_properties_pre_run),
5761         (gst_element_threadsafe_properties_post_run),
5762         (gst_element_set_state), (gst_element_change_state):
5763         Added extra refcounting around various places. 
5764
5765 2004-09-06  Wim Taymans  <wim@fluendo.com>
5766
5767         * gst/gstpad.c: (gst_pad_link_call_link_functions):
5768         Fix debug info.
5769
5770 2004-09-06  Wim Taymans  <wim@fluendo.com>
5771
5772         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
5773         (remove_from_group):
5774         Some more debug info.
5775
5776 2004-09-03  Wim Taymans  <wim@fluendo.com>
5777
5778         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
5779         (gst_fakesrc_init), (gst_fakesrc_set_clock),
5780         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
5781         (gst_fakesrc_get), (gst_fakesrc_change_state):
5782         * gst/elements/gstfakesrc.h:
5783         * gst/elements/gstidentity.c: (gst_identity_class_init),
5784         (gst_identity_init), (gst_identity_chain),
5785         (gst_identity_set_property), (gst_identity_get_property),
5786         (gst_identity_change_state):
5787         * gst/elements/gstidentity.h:
5788         Added datarate properties to limit the datarate.
5789
5790 2004-08-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5791
5792         * gst/autoplug/gstspider.c: (plugin_init):
5793           don't set a rank. We don't want to autoplug by inserting spiders.
5794
5795 2004-08-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5796
5797         * gst/autoplug/gstspider.c: (gst_spider_class_init),
5798         (gst_spider_identity_plug):
5799           add a template for spider's sink
5800         * gst/gst.c: (gst_register_core_elements):
5801           queue's rank should be NULL, we don't want spider to add it.
5802
5803 2004-08-18  David Schleef  <ds@schleef.org>
5804
5805         * docs/gst/Makefile.am: Remove --ignore-fail-on-non-empty (#150331)
5806         * docs/libs/Makefile.am: same
5807         * docs/gst/tmpl/gstxml.sgml: Remove GstXMLNs
5808         * docs/random/ds/0.9-planning: random additions
5809         * docs/random/ds/0.9-suggested-changes: same
5810         * gst/gstxml.h: remove vestigal GstXMLNs definition
5811
5812         Preferred caps: (#147789)
5813         * docs/gst/gstreamer-sections.txt: Add symbols
5814         * docs/gst/tmpl/gstcaps.sgml: Add symbols
5815         * gst/gstcaps.c: (gst_caps_copy), (gst_caps_free),
5816         (gst_caps_append), (gst_caps_copy_1), (gst_caps_intersect),
5817         (gst_caps_union), (gst_caps_save_thyself), (gst_caps_load_thyself),
5818         (gst_caps_get_preferred), (gst_caps_set_preferred),
5819         (gst_caps_get_structure_by_id), (gst_caps_prefer_foreach),
5820         (gst_caps_use_preferred): Handle caps preferences
5821         * gst/gstcaps.h: Add caps preferences
5822         * gst/gstpad.c: (gst_pad_link_get_preferred),
5823         (gst_pad_link_fixate), (gst_pad_link_call_link_functions),
5824         (gst_pad_renegotiate), (gst_pad_guess_preferred),
5825         (gst_pad_get_caps), (gst_pad_push):  Use caps preferences for
5826         negotiation.
5827
5828 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5829
5830         * gst/autoplug/gstspideridentity.c:
5831         (gst_spider_identity_request_new_pad):
5832         * gst/elements/gstaggregator.c: (gst_aggregator_base_init),
5833         (gst_aggregator_init):
5834         * gst/elements/gstfakesink.c: (gst_fakesink_base_init),
5835         (gst_fakesink_init):
5836         * gst/elements/gstfakesrc.c: (gst_fakesrc_base_init),
5837         (gst_fakesrc_init):
5838         * gst/elements/gstfdsink.c: (gst_fdsink_base_init),
5839         (gst_fdsink_init):
5840         * gst/elements/gstfdsrc.c: (gst_fdsrc_base_init), (gst_fdsrc_init):
5841         * gst/elements/gstfilesink.c: (gst_filesink_base_init),
5842         (gst_filesink_init):
5843         * gst/elements/gstfilesrc.c: (gst_filesrc_base_init),
5844         (gst_filesrc_init):
5845         * gst/elements/gstidentity.c: (gst_identity_base_init),
5846         (gst_identity_init):
5847         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_base_init),
5848         (gst_multifilesrc_init):
5849         * gst/elements/gstpipefilter.c: (gst_pipefilter_base_init),
5850         (gst_pipefilter_init):
5851         * gst/elements/gststatistics.c: (gst_statistics_base_init),
5852         (gst_statistics_init):
5853         * gst/elements/gsttee.c: (gst_tee_base_init), (gst_tee_init):
5854         * gst/gstqueue.c: (gst_queue_base_init), (gst_queue_init):
5855           s/gst_pad_new/&_from_template/
5856           register pad templates in the base_init function
5857           add static pad template definitions
5858
5859 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5860
5861         * testsuite/bytestream/gstbstest.c: (gst_bstest_init):
5862         * testsuite/dynparams/dparamstest.c: (gst_dptest_init):
5863         * testsuite/refcounting/pad.c: (main):
5864         * testsuite/refcounting/thread.c: (create_thread_ghostpads):
5865           s/gst_pad_new/&_from_template/
5866           prepare deprecation of gst_pad_new
5867
5868 2004-08-17  Thomas Vander Stichele  <thomas at apestaart dot org>
5869
5870         patch by: Luca Ognibene <skaboy81@virgilio.it>
5871
5872         * gst/gstcaps.c:
5873         * gst/gstelement.c:
5874         * gst/gstpad.c:
5875         * gst/gstxml.c:
5876           fix memleaks.  Fixes #150001
5877
5878 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5879
5880         * docs/random/ds/0.9-suggested-changes:
5881           add notes - mostly about pad templates
5882
5883 2004-08-16  Steve Lhomme  <steve.lhomme@free.fr>
5884
5885         * win32/GStreamer.vcproj:
5886           temporary locale files are .gmo not .mo
5887
5888 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
5889
5890         * configure.ac: bump nano to cvs
5891
5892 === release 0.8.5 ===
5893
5894 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
5895
5896         * configure.ac:
5897           releasing 0.8.5, "Stuttgart"
5898         * NEWS:
5899         * RELEASE:
5900         * configure.ac:
5901         * docs/random/release:
5902           updates for release
5903
5904 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
5905
5906         patch by: Wim Taymans (wim@fluendo.com)
5907
5908         * gst/gstbuffer.c:
5909         * gst/gstindex.h:
5910         * libs/gst/dataprotocol/dataprotocol.c:
5911           copy KEY_UNIT and DELTA_UNIT flags correctly.  Fixes #150242
5912
5913 2004-08-13  Thomas Vander Stichele  <thomas at apestaart dot org>
5914
5915         * Makefile.am:
5916         * win32/MANIFEST:
5917           add win32 dir to the build.  Fixes #149981.
5918
5919 2004-08-13  Thomas Vander Stichele  <thomas at apestaart dot org>
5920
5921         * configure.ac:
5922           bump libtool versioning
5923         * gst/gststructure.c:
5924           mark function as static
5925         * po/af.po:
5926         * po/az.po:
5927         * po/ca.po:
5928         * po/cs.po:
5929         * po/en_GB.po:
5930         * po/fr.po:
5931         * po/nl.po:
5932         * po/sq.po:
5933         * po/sr.po:
5934         * po/sv.po:
5935         * po/tr.po:
5936         * po/uk.po:
5937           translations update
5938         * win32/README.txt:
5939           trademark protection
5940
5941 2004-08-12  Thomas Vander Stichele  <thomas at apestaart dot org>
5942
5943         * configure.ac:
5944           fix GST_ORIGIN
5945           set GST_PACKAGE to source, and distinguish between release and other
5946         * tools/gst-inspect.c:
5947           print out plugin an element factory is part of so we see this info
5948
5949 2004-08-12  Thomas Vander Stichele  <thomas at apestaart dot org>
5950
5951         * docs/gst/gstreamer-sections.txt:
5952         * docs/gst/tmpl/gstbuffer.sgml:
5953         * docs/gst/tmpl/gstschedulerfactory.sgml:
5954           reorder docs a little, make GstBuffer's more sensible.
5955         * gst/gstbuffer.h:
5956           API: added GST_BUFFER_FLAG_DELTA_UNIT
5957         * gst/gstscheduler.c:
5958           comment API addition
5959
5960 2004-08-12  Benjamin Otte  <in7y118@public.uni-hamburg.de>
5961
5962         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
5963           work with non-regular files that can be mmapped (like /dev/zero)
5964         * gst/elements/gsttypefindelement.c: (gst_type_find_element_chain):
5965           get rid of typefinds that require a seek when we can't seek instead
5966           of trying them over and over again
5967         * tools/gst-launch.c: (idle_func), (error_cb), (main):
5968           return non-zero failure value when the pipeline was interrupted or
5969           an error occurred
5970
5971 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
5972
5973         * win32/config.h:
5974         * win32/GStreamer.vcproj:
5975           compile and install the locales
5976
5977 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
5978
5979         * gst/gstvalue.c:
5980           fix a possible memory leak under Windows
5981
5982 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
5983
5984         * win32/GStreamer.vcproj:
5985           fix a memory leak that occured under Windows
5986         * win32/gstreamer.def:
5987           add gst_scheduler_register
5988
5989 2004-08-11  Benjamin Otte  <otte@gnome.org>
5990
5991         * docs/gst/gstreamer-sections.txt:
5992         * gst/gstscheduler.c: (gst_scheduler_register):
5993         * gst/gstscheduler.h:
5994           API:
5995           add gst_scheduler_register shortcut similar to gst_element_register
5996         * gst/schedulers/entryscheduler.c: (plugin_init):
5997         * gst/schedulers/gstbasicscheduler.c: (plugin_init):
5998         * gst/schedulers/gstoptimalscheduler.c: (plugin_init):
5999           use it
6000
6001 2004-08-10  Steve Lhomme  <steve.lhomme@free.fr>
6002
6003         * gst/gstvalue.h:
6004           fix a memory leak that occured under Windows
6005
6006 2004-08-10  Colin Walters  <walters@redhat.com>
6007
6008         * gst/registries/gstxmlregistry.c (gst_xml_registry_open_func):
6009         Don't use O_EXCL to open temporary registry.  It will prevent
6010         registry creation if a temporary one already exists, which
6011         is unnecessary.
6012
6013 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
6014
6015         * docs/gst/gstreamer-sections.txt:
6016         * docs/gst/tmpl/gstvalue.sgml:
6017           remove some valuable stuff from the documentation due to the use of GST_EXPORT
6018
6019 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
6020
6021         * win32/gstbytestream.vcproj:
6022         * win32/gstelements.vcproj:
6023         * win32/gstgetbits.vcproj:
6024         * win32/gst-inspect.vcproj:
6025         * win32/gst-launch.vcproj:
6026         * win32/gstoptimalscheduler.vcproj:
6027         * win32/GStreamer.vcproj:
6028         * win32/gst-register.vcproj:
6029         * win32/gstspider.vcproj:
6030           update the include and lib dirs to fit standard libraries as
6031           described in the Win32 manual
6032
6033 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
6034
6035         * win32/config.h:
6036         * win32/gstversion.h:
6037           enable NLS again, push the version number for the coming 0.8.5 release
6038
6039 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
6040
6041         * gst/gstvalue.h:
6042           export gst_type_XXX for windows DLLs
6043
6044 2004-08-09  Thomas Vander Stichele  <thomas at apestaart dot org>
6045
6046         * docs/faq/gst-uninstalled:
6047           fix PKG_CONFIG_PATH and PYTHONPATH
6048         * gst/schedulers/Makefile.am:
6049           cleanup
6050         * libs/gst/bytestream/bytestream.c:
6051           remove newline
6052         * po/LINGUAS:
6053         * po/sq.po:
6054           adding Albanian translation (Laurent Dhima)
6055         * po/cs.po:
6056           updated
6057
6058 2004-08-05  Thomas Vander Stichele  <thomas at apestaart dot org>
6059
6060         * po/ca.po:
6061         * po/sv.po:
6062           updated translations
6063
6064 2004-08-04  Benjamin Otte  <otte@gnome.org>
6065
6066         * tests/mass_elements.c: (main):
6067           allow specifying src and sink element explicitly, so I can test
6068           videotestsrc instead of fakesrc
6069
6070 2004-08-04  Benjamin Otte  <otte@gnome.org>
6071
6072         * gst/gststructure.c: (gst_structure_id_empty_new_with_size),
6073         (gst_structure_id_empty_new), (gst_structure_empty_new),
6074         (gst_structure_copy):
6075           add gst_structure_id_empty_new_with_size to allow preallocating
6076           value array sizes. Use this in gst_structure_copy to get rid of
6077           reallocs.
6078           don't do quark=>string=>quark when copying structures
6079
6080 2004-08-03  Steve Lhomme  <steve.lhomme@free.fr>
6081
6082         * docs/manual/win32.xml:
6083         * win32/README.txt:
6084           update documentation with the clean version of dependencies
6085
6086 2004-08-03  Benjamin Otte  <otte@gnome.org>
6087
6088         * gst/schedulers/entryscheduler.c:
6089         (gst_entry_scheduler_remove_element):
6090           fix for GST_DISABLE_DEBUG
6091         * tools/gst-launch.c: (print_tag):
6092           fixes for G_DISABLE_ASSERT
6093
6094 2004-08-03  Benjamin Otte  <otte@gnome.org>
6095
6096         * gst/gst.c: (gst_register_core_elements):
6097           fix for G_DISABLE_ASSERT
6098         * gst/gstinfo.c: (__gst_in_valgrind):
6099           add for GST_DISABLE_DEBUG
6100
6101 2004-08-03  Benjamin Otte  <otte@gnome.org>
6102
6103         * gst/parse/parse.l:
6104           fix for G_DISABLE_ASSERT
6105
6106 2004-08-03  Wim Taymans  <wim@fluendo.com>
6107
6108         * gst/gstbin.c: (gst_bin_get_type),
6109         (gst_bin_child_state_change_func):
6110         * gst/gstthread.c: (gst_thread_change_state):
6111         Backported some debug logging from a reverted patch
6112         Don't try to destroy the thread twice. Added some more
6113         debugging in GstThread. Unlock and signal even if we
6114         are in the thread context.
6115
6116 2004-08-03  Thomas Vander Stichele  <thomas at apestaart dot org>
6117
6118         * po/uk.po:
6119           updated translation
6120
6121 2004-07-30  David Schleef  <ds@schleef.org>
6122
6123         * gst/gstatomic_impl.h: Enable atomic code for x86_64
6124
6125 2004-07-29  David Schleef  <ds@schleef.org>
6126
6127         * libs/gst/dataprotocol/dataprotocol-test.c: (conversion_test):
6128         Use GST_READ_GUINTxx_BE(), since it accesses unaligned memory.
6129
6130 2004-07-29  Thomas Vander Stichele  <thomas at apestaart dot org>
6131
6132         * gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
6133         (gst_bin_add_func), (gst_bin_remove_func),
6134         (gst_bin_child_state_change), (gst_bin_child_state_change_func),
6135         (set_kid_state_func), (gst_bin_change_state), (gst_bin_set_state),
6136         (gst_bin_change_state_norecurse), (gst_bin_dispose),
6137         (gst_bin_sync_children_state):
6138         * gst/gstbin.h:
6139         * gst/gstthread.c: (gst_thread_class_init), (gst_thread_release),
6140         (gst_thread_change_state):
6141         * testsuite/states/Makefile.am:
6142           revert state change patches as agreed so we can rework them
6143           gradually
6144
6145 2004-07-29  Benjamin Otte  <otte@gnome.org>
6146
6147         * libs/gst/control/Makefile.am:
6148           link to libgstreamer (fixes Debian bug 262019, see
6149           http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=262019 )
6150
6151 2004-07-29  Wim Taymans  <wim@fluendo.com>
6152
6153         * testsuite/caps/fraction-convert.c: (check_from_double_convert),
6154         (check_from_fraction_convert), (transform_test), (main):
6155         Make the test less pedantic about float roundoff errors.
6156
6157 2004-07-29  Benjamin Otte  <otte@gnome.org>
6158
6159         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file),
6160         (gst_filesrc_srcpad_event):
6161           make seek events to before start/after end of file not fail, but
6162           seek to start/end instead
6163         * testsuite/caps/fraction-convert.c: (check_from_double_convert):
6164           add more output
6165
6166 2004-07-29  Benjamin Otte  <otte@gnome.org>
6167
6168         * gst/gstpad.c: (gst_pad_set_explicit_caps):
6169           check that caps are fixed
6170         * gst/gstpad.c: (gst_pad_template_new):
6171           don't try to simplify caps, costs too much time on gst_init
6172         * gst/gstplugin.c: (gst_plugin_add_feature):
6173           G_ERROR if features are added twice
6174         * gst/gsttypefind.c: (gst_type_find_register):
6175         * gst/gstelementfactory.c: (gst_element_register):
6176           don't add features twice
6177         * docs/random/ds/0.9-suggested-changes:
6178           add note about possible gst_init optimization
6179
6180 2004-07-28  David Schleef  <ds@schleef.org>
6181
6182         * testsuite/elements/Makefile.am:
6183         * testsuite/elements/struct_i386.h:
6184         * testsuite/elements/struct_size.c: (main):  A little test
6185         to keep distcheck from working if someone changes a structure
6186         size accidentally.
6187
6188 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
6189
6190         * docs/libs/Makefile.am:
6191         * docs/libs/gstreamer-libs-docs.sgml:
6192         * docs/libs/gstreamer-libs-sections.txt:
6193         * docs/libs/tmpl/gstbytestream.sgml:
6194         * docs/libs/tmpl/gstcontrol.sgml:
6195         * docs/libs/tmpl/gstdataprotocol.sgml:
6196         * docs/libs/tmpl/gstgetbits.sgml:
6197         * libs/gst/bytestream/Makefile.am:
6198         * libs/gst/bytestream/bytestream.c:
6199         * libs/gst/bytestream/bytestream.h:
6200         * libs/gst/control/Makefile.am:
6201         * libs/gst/dataprotocol/Makefile.am:
6202         * libs/gst/getbits/Makefile.am:
6203         * libs/gst/getbits/getbits.h:
6204           various doc and style fixes, adding bytestream to libs docs.
6205
6206 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
6207
6208         * docs/gst/gstreamer-docs.sgml:
6209         * docs/libs/Makefile.am:
6210         * docs/libs/gstreamer-libs-docs.sgml:
6211         * docs/libs/gstreamer-libs-sections.txt:
6212         * libs/gst/control/dparam.c:
6213           more doc fixes.  gst-libs docs now build the same way as gst.
6214
6215 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
6216
6217         * configure.ac:
6218         * testsuite/Makefile.am:
6219         * testsuite/bins/Makefile.am:
6220         * testsuite/caps/Makefile.am:
6221         * testsuite/cleanup/Makefile.am:
6222         * testsuite/clock/Makefile.am:
6223         * testsuite/debug/Makefile.am:
6224         * testsuite/dlopen/Makefile.am:
6225         * testsuite/dynparams/Makefile.am:
6226         * testsuite/elements/.cvsignore:
6227         * testsuite/elements/Makefile.am:
6228         * testsuite/enumcaps/Makefile.am:
6229         * testsuite/enumcaps/enumcaps.c:
6230         * testsuite/ghostpads/Makefile.am:
6231         * testsuite/indexers/Makefile.am:
6232         * testsuite/negotiation/Makefile.am:
6233         * testsuite/parse/Makefile.am:
6234         * testsuite/plugin/Makefile.am:
6235         * testsuite/refcounting/Makefile.am:
6236         * testsuite/schedulers/.cvsignore:
6237         * testsuite/states/Makefile.am:
6238         * testsuite/tags/Makefile.am:
6239         * testsuite/threads/Makefile.am:
6240           fold enumcaps into caps dir
6241           clean up Makefile.am's for testsuite
6242
6243 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
6244
6245         * docs/gst/Makefile.am:
6246         * docs/libs/Makefile.am:
6247           clean up docs build.  Fixes needless rebuilding of template files.
6248
6249 2004-07-28  Wim Taymans  <wim@fluendo.com>
6250
6251         * gst/gstbin.c: (set_kid_state_func), (gst_bin_set_state):
6252         * gst/gstthread.c: (gst_thread_release), (gst_thread_set_state):
6253         Make sure that a bin state change tries to keep the children
6254         in sync. 
6255         Added debug logging to the thread.
6256
6257 2004-07-27  Steve Lhomme  <steve.lhomme@free.fr>
6258
6259         * win32/GStreamer.vcproj:
6260         * win32/gstreamer.def:
6261           more exports for the plugins
6262
6263 2004-07-27  Steve Lhomme  <steve.lhomme@free.fr>
6264
6265         * win32/gstgetbits.vcproj:
6266         * win32/gstgetbits.def:
6267         * win32/msvc71.sln:
6268           add support for the getbits plugin
6269
6270 2004-07-27  Wim Taymans  <wim@fluendo.com>
6271
6272         * gst/gstvalue.c: (gst_value_transform_double_fraction),
6273         (gst_value_transform_fraction_double), (_gst_value_initialize):
6274         * testsuite/caps/Makefile.am:
6275         * testsuite/caps/fraction-convert.c: (check_from_double_convert),
6276         (check_from_fraction_convert), (transform_test), (main):
6277         Added transform functions between double and fraction.
6278         Added testcase to verify transforms
6279
6280 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
6281
6282         * win32/GStreamer.vcproj:
6283           rename GStreamer-0.8.lib to libgstreamer.lib
6284
6285 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
6286
6287         * win32/gstelements.vcproj:
6288         * win32/gstoptimalscheduler.vcproj:
6289           fixes for the Release build
6290
6291 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
6292
6293         * win32/config.h:
6294           update the version number
6295
6296 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
6297
6298         * win32/GStreamer.vcproj:
6299           add gstinterface to the build
6300
6301 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
6302
6303         * win32/gstreamer.def:
6304           add many definitions needed by plugins,
6305           GST_CAT_DEFAULT only available in the Debug build ?
6306
6307 2004-07-26  Thomas Vander Stichele  <thomas at apestaart dot org>
6308
6309         * gst/gstelement.c: (gst_element_set_eos_recursive):
6310           various whitespace fixes.
6311           doc fix, fixes #148497
6312
6313 2004-07-25  Benjamin Otte  <otte@gnome.org>
6314
6315         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link):
6316           don't delay links on the sink elements, it causes unnegotiated
6317           links.
6318         * gst/elements/gsttypefindelement.c:
6319         (gst_type_find_element_base_init):
6320           add our padtemplates, we indeed do have some.
6321         * gst/elements/gsttypefindelement.c:
6322         (gst_type_find_element_handle_event),
6323         (gst_type_find_element_chain):
6324           don't push data when typefinding failed.
6325         * gst/gstpad.c: (gst_pad_link_fixate):
6326           check that no fixate function returns empty caps.
6327         * gst/gstpad.c: (gst_pad_push):
6328           check that the link is negotiated before data gets pushed.
6329         * tools/gst-register.c: (main):
6330           don't assert (fixes #148283)
6331
6332 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
6333
6334         * docs/gst/gstreamer-sections.txt:
6335         * docs/gst/tmpl/gstconfig.sgml:
6336           add GST_PLUGIN_EXPORT definition
6337
6338 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
6339
6340         * gst/gstplugin.h:
6341         * gst/gstconfig.h.in:
6342         * win32/gstconfig.h:
6343         * win32/gstelements.def:
6344         * win32/gstelements.vcproj:
6345         * win32/gstoptimalscheduler.def:
6346         * win32/gstoptimalscheduler.vcproj:
6347         * win32/gstspider.def:
6348         * win32/gstspider.vcproj:
6349           remove unused .def files and export symbols using GST_PLUGIN_DEFINE
6350
6351 2004-07-25  Thomas Vander Stichele  <thomas at apestaart dot org>
6352
6353         * docs/gst/gstreamer-sections.txt:
6354           remove GST_CAT_DEFAULT because the type has changed
6355
6356 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
6357
6358         * win32/gstbytestream.vcproj:
6359         * win32/gstelements.vcproj:
6360         * win32/gst-inspect.vcproj:
6361         * win32/gst-launch.vcproj:
6362         * win32/gstoptimalscheduler.vcproj:
6363         * win32/GStreamer.vcproj:
6364         * win32/gst-register.vcproj:
6365         * win32/gstspider.vcproj:
6366         * win32/msvc71.sln:
6367           Copy the files where needed after building, The testsuite will be
6368           built separately
6369
6370 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
6371
6372         * win32/config.h:
6373         * win32/README.txt:
6374         * docs/manual/win32.xml:
6375         Fixed the plugin and GStreamer location
6376
6377 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6378
6379         * win32/gstreamer.def:
6380         More exports for the plugins
6381
6382 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6383
6384         * gst/gstinfo.h:
6385         Marc was right, we need to export literally GST_CAT_DEFAULT
6386
6387 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6388
6389         * win32/config.h:
6390         NLS crashes in gettext, disabled until this is solved
6391
6392 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6393
6394         * win32/gst-inspect.vcproj:
6395         * win32/gst-launch.vcproj:
6396         Should use NLS when available
6397
6398 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6399
6400         * gst/registries/gstxmlregistry.c:
6401         removing the file doesn't seem to be a good idea on Linux
6402
6403 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
6404
6405         * gst/registries/gstxmlregistry.c:
6406         Remove the registry before renaming the tempfile (needed for Windows)
6407
6408 2004-07-23  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6409
6410         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init),
6411         (gst_multifilesrc_init), (gst_multifilesrc_set_property),
6412         (gst_multifilesrc_get_property), (gst_multifilesrc_get):
6413         * gst/elements/gstmultifilesrc.h:
6414         Added newmedia property so it generates newmedia events between each
6415         file when property is set, as well as fixed eos handling
6416
6417 2004-07-22  David Schleef  <ds@schleef.org>
6418
6419         * gst/gststructure.c: (gst_structure_id_empty_new),
6420         (gst_structure_empty_new):  Set type field correctly.
6421         * gst/gststructure.h: Check type field correctly.
6422         * testsuite/caps/Makefile.am:
6423         * testsuite/caps/structure.c: (test1), (main): Add a very small
6424         test for structures.
6425
6426 2004-07-22  David Schleef  <ds@schleef.org>
6427
6428         * docs/random/ds/0.9-suggested-changes: more comments
6429         * tools/gst-launch.c: (idle_func): Fix hard-to-translate string.
6430
6431 2004-07-22  Benjamin Otte  <otte@gnome.org>
6432
6433         * gst/gstelementfactory.c: (gst_element_register):
6434           set the factory in the class struct, so gst_element_get_factory
6435           actually works
6436         * gst/parse/grammar.y:
6437           set element to playing when it gets unlocked as we can't rely on the
6438           bin state - all elements in the bin state might still be locked in
6439           NULL)
6440
6441 2004-07-22  Benjamin Otte  <otte@gnome.org>
6442
6443         * gst/gstelement.c: (gst_element_set_state_func):
6444           make this a static function
6445
6446 2004-07-22  Wim Taymans  <wim@fluendo.com>
6447
6448         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
6449         (gst_opt_scheduler_pad_link):
6450         fix 147894-2 and the group_link problem.
6451
6452 2004-07-22  Wim Taymans  <wim@fluendo.com>
6453
6454         * testsuite/schedulers/147894-2.c: (queue_empty), (queue_filled),
6455         (handoff_identity), (main):
6456         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
6457         (handoff_identity), (main):
6458         * testsuite/schedulers/Makefile.am:
6459         * testsuite/schedulers/group_link.c: (main):
6460         Show bug in scheduler when linking chain and loop based element 
6461         where the chain based element was not yet in a group.
6462
6463 2004-07-21  Benjamin Otte  <otte@gnome.org>
6464
6465         * gst/.cvsignore:
6466         * gst/autoplug/.cvsignore:
6467         * gst/elements/.cvsignore:
6468         * gst/indexers/.cvsignore:
6469         * libs/gst/bytestream/.cvsignore:
6470         * libs/gst/control/.cvsignore:
6471         * libs/gst/getbits/.cvsignore:
6472         * testsuite/states/.cvsignore:
6473         * testsuite/threads/.cvsignore:
6474           keep this up to date, since I seem to be the only one who cares
6475           about not missing files on commits (editor's note: no you don't,
6476           but feel free to change them at the time you add stuff instead
6477           of later on)
6478
6479 2004-07-21  Benjamin Otte  <otte@gnome.org>
6480
6481         * gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
6482         (gst_bin_fix_state), (gst_bin_add_func), (gst_bin_remove_func),
6483         (gst_bin_child_state_change_func), (set_kid_state_func),
6484         (gst_bin_set_state), (gst_bin_change_state_norecurse):
6485           make state changes work correctly and reentrant (so removing
6486           elements from bins during state changes of bins doesn't cause
6487           segfaults or even wrong states)
6488           add debugging category and debugging output to print children states
6489         * gst/gstbin.c: (gst_bin_dispose): 
6490           add some assertion checks
6491         * gst/gstbin.h:
6492         * gst/gstbin.c: (gst_bin_sync_children_state):
6493           deprecate this function - it just does gst_bin_set_state (bin,
6494           GST_STATE (bin)) 
6495         * testsuite/threads/queue.c: (main):
6496           don't use gst_bin_sync_children_state anymore
6497         * testsuite/states/Makefile.am:
6498         * testsuite/states/bin.c:
6499           test that the state changes of bins work as expected
6500         * gst/gstthread.c: (gst_thread_class_init), (gst_thread_set_state):
6501           some adjustments to change states correctly, too
6502         * gst/gstthread.c: (gst_thread_change_state):
6503           don't enable/disable "threadsafe" properties, they're unused and
6504           cause random segfaults
6505         * testsuite/threads/Makefile.am:
6506           the queue check randomly passes now, ignore it
6507
6508 2004-07-21  Benjamin Otte  <otte@gnome.org>
6509
6510         * gst/gstpad.c:
6511           check if data is NULL before outputting debug info. (fixes #145100)
6512
6513 2004-07-21  Benjamin Otte  <otte@gnome.org>
6514
6515         * gst/schedulers/entryscheduler.c:
6516         (gst_entry_scheduler_loop_wrapper),
6517         (gst_entry_scheduler_chain_wrapper),
6518         (gst_entry_scheduler_get_wrapper):
6519           reset the state when the cothread starts, so we don't get assertion
6520           failures on restarting of cothreads
6521
6522 2004-07-20  Benjamin Otte  <otte@gnome.org>
6523
6524         * gst/gstelement.c: (gst_element_link_pads_filtered):
6525           use correct sinkpad, if only sinkpad is specified, but not srcpad
6526           (fixes #147889)
6527         * gst/gstelement.c: (gst_element_set_state_func),
6528         (gst_element_change_state): ref/unref the element, signal handlers
6529         could get rid of the element otherwise
6530
6531 2004-07-20  Ronald Bultje  <rbultje@ronald.bitfreak.net>
6532
6533         * docs/random/ds/0.9-suggested-changes:
6534           Make note about renaming fixed-list to array.
6535         * gst/gstvalue.c: (gst_value_intersect_fixed_list),
6536         (_gst_value_initialize):
6537           Add array intersections.
6538         * testsuite/caps/intersect2.c: (main):
6539           Add test for array intersections.
6540
6541 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6542
6543         * configure.ac: back to cvs
6544
6545 === release 0.8.4 ===
6546
6547 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6548
6549         * configure.ac:
6550           releasing 0.8.4, "Paella"
6551           bump libtool versioning
6552
6553 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6554
6555         * po/LINGUAS:
6556         * po/ca.po:
6557           adding Catalan translation (Jordi Mallach)
6558
6559 2004-07-20  Wim Taymans  <wim@fluendo.com>
6560
6561         * testsuite/schedulers/147894-2.c: (queue_empty), (queue_filled),
6562         (handoff_identity), (main):
6563         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
6564         (handoff_identity), (main):
6565         * testsuite/schedulers/Makefile.am:
6566         Added failing testcase for variant of #147894
6567
6568 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6569
6570         patch by: David Moore
6571
6572         * gst/schedulers/gstoptimalscheduler.c: (group_has_element),
6573         (schedule_group), (gst_opt_scheduler_schedule_run_queue),
6574         (group_migrate_connected):
6575         * testsuite/schedulers/Makefile.am:
6576           fix for #142813 (Deadlock in optimal scheduler)
6577
6578 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6579
6580         patch by: Wim Taymans
6581
6582         * gst/schedulers/gstoptimalscheduler.c: (group_has_element),
6583         (gst_opt_scheduler_schedule_run_queue),
6584         (gst_opt_scheduler_get_wrapper), (get_group),
6585         (group_migrate_connected):
6586         * testsuite/schedulers/Makefile.am:
6587           fix for #147819 (Add some checks in the opt scheduler)
6588
6589 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6590
6591         patch by: Benjamin Otte
6592
6593         * gst/gstelementfactory.c: (__gst_element_details_set):
6594           fix for #147929: running gst-register in non-utf8 locale can cause
6595           invalid registry
6596
6597 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6598
6599         patch by: Wim Taymans
6600
6601         * gst/schedulers/gstoptimalscheduler.c: (group_num_elements),
6602         (group_has_element), (element_get_reachables_func),
6603         (group_migrate_connected):
6604           fix for #147894 (opt scheduler decoupled elements mismanagement)
6605         * testsuite/schedulers/Makefile.am:
6606           testsuite app now passes
6607
6608 2004-07-19  Wim Taymans  <wim@fluendo.com>
6609
6610         * testsuite/schedulers/147819.c: (handoff_identity1),
6611         (handoff_identity2), (main):
6612         * testsuite/schedulers/Makefile.am:
6613         Added testcase for bug 147819
6614
6615 2004-07-19  Wim Taymans  <wim@fluendo.com>
6616
6617         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
6618         (handoff_identity), (main):
6619         * testsuite/schedulers/Makefile.am:
6620         Added testcase for bug 147894
6621
6622 2004-07-16  Wim Taymans  <wim@fluendo.com>
6623
6624         * testsuite/schedulers/142183-2.c: (handoff_identity), (main):
6625         * testsuite/schedulers/142183.c: (handoff_identity), (main):
6626         * testsuite/schedulers/Makefile.am:
6627         Added testsuite for bug 142183 in its two incarnations. Refcount
6628         is not increased for scheduled elements and threadsafe properties
6629         mutexes are not properly unlocked.
6630
6631 2004-07-16  Wim Taymans  <wim@fluendo.com>
6632
6633         * gst/schedulers/gstoptimalscheduler.c: (gst_opt_scheduler_init),
6634         (create_chain), (destroy_chain), (create_group), (destroy_group),
6635         (add_to_group), (merge_groups), (group_elements), (group_inc_link),
6636         (group_dec_link), (gst_opt_scheduler_pad_link),
6637         (group_inc_links_for_element), (group_migrate_connected):
6638         Call group_inc_link with the proper src->sink ordering -- 
6639         break this, and we break sort_chain. patch from wingo for bug
6640         147713.
6641         Partially revert patch 1.89. When adding a loop based element to 
6642         the scheduler, the links to other groups are automatically followed
6643         and incremented. This should not happen because the bin will call
6644         pad_link explicitly for those connection, resulting in them counted 
6645         twice. Results in assertion failure on pipeline cleanup.
6646
6647 2004-07-16  Wim Taymans  <wim@fluendo.com>
6648
6649         * testsuite/schedulers/143777-2.c: (main):
6650         * testsuite/schedulers/147713.c: (handoff_src), (handoff_sink),
6651         (main):
6652         * testsuite/schedulers/Makefile.am:
6653         Added cleanup code to testcase 143777-2.
6654         Added testcase to show bug 147713, does not really show the
6655         deadlock as I can't figure out how to trigger it, but it does
6656         demonstrate bad ordering in the scheduler.
6657
6658 2004-07-16  Thomas Vander Stichele  <thomas at apestaart dot org>
6659
6660         * gst/gstvalue.c: (gst_value_deserialize_fraction):
6661           change strndup to g_strndup.  Fixes #147707
6662
6663 2004-07-16  Thomas Vander Stichele  <thomas at apestaart dot org>
6664
6665         * po/af.po:
6666         * po/az.po:
6667         * po/cs.po:
6668         * po/en_GB.po:
6669         * po/fr.po:
6670         * po/nl.po:
6671         * po/sr.po:
6672         * po/sv.po:
6673         * po/tr.po:
6674         * po/uk.po:
6675           updated translations
6676
6677 2004-07-16  Benjamin Otte  <otte@gnome.org>
6678
6679         * gst/gstvalue.c: (gst_greatest_common_divisor):
6680           use ints and return ints, fractions only use ints, too, so this
6681           avoids accidently casting multiplications to unsigned
6682         (gst_value_lcopy_fraction): it's ints, not uint32
6683         (gst_value_set_fraction): disallow minint, multiplying and negation
6684           are broken with it
6685         (gst_value_fraction_multiply): fix to make large numbers work and get
6686         rid of the assumption that the multiplication of two ints fits an
6687         int64 - dunno if that's true for all systems
6688         * testsuite/caps/Makefile.am:
6689         * testsuite/caps/fraction-multiply-and-zero.c:
6690         (check_multiplication), (check_equal), (zero_test), (main):
6691           add tests for all the stuff above
6692         * testsuite/caps/value_compare.c: (test1):
6693           fix comment
6694         * tests/.cvsignore:
6695         * testsuite/caps/.cvsignore:
6696         * testsuite/debug/.cvsignore:
6697         * testsuite/dlopen/.cvsignore:
6698         * testsuite/states/.cvsignore:
6699           get up to date
6700
6701 2004-07-16  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6702
6703         * docs/manual/bins-api.xml:
6704         * docs/manual/factories.xml:
6705         * docs/manual/helloworld.xml:
6706         * docs/manual/links-api.xml: 
6707           fixes for out of date info, incorrect info and grammar
6708
6709 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6710
6711         * docs/manual/pads.xml:
6712         * docs/manual/pads-api.xml: grammar fix
6713
6714 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6715
6716         * docs/manual/pads-api.xml: typo + grammar fix
6717
6718 2004-07-15  Thomas Vander Stichele  <thomas at apestaart dot org>
6719
6720         * docs/gst/gstreamer-sections.txt:
6721           add new symbols
6722         * docs/gst/tmpl/gstelement.sgml:
6723         * docs/gst/tmpl/gstpad.sgml:
6724         * docs/gst/tmpl/gsttypes.sgml:
6725         * docs/gst/tmpl/gstvalue.sgml:
6726           update docs
6727         * gst/gststructure.c: (gst_structure_set_valist),
6728         (gst_structure_from_abbr), (gst_structure_to_abbr):
6729         * gst/gstvalue.c: (gst_value_compare_double), (gst_type_is_fixed),
6730         (gst_greatest_common_divisor), (gst_value_init_fraction),
6731         (gst_value_copy_fraction), (gst_value_collect_fraction),
6732         (gst_value_lcopy_fraction), (gst_value_set_fraction),
6733         (gst_value_get_fraction_numerator),
6734         (gst_value_get_fraction_denominator),
6735         (gst_value_fraction_multiply), (gst_value_serialize_fraction),
6736         (gst_value_deserialize_fraction),
6737         (gst_value_transform_fraction_string),
6738         (gst_value_transform_string_fraction),
6739         (gst_value_compare_fraction), (_gst_value_initialize):
6740         * gst/gstvalue.h:
6741           adding GstFraction GValue type, get/set, and multiply
6742         * testsuite/caps/Makefile.am:
6743         * testsuite/caps/fraction.c: (test), (main):
6744         * testsuite/caps/string-conversions.c: (main):
6745         * testsuite/caps/value_compare.c: (test1), (main):
6746           add regression tests for GstFraction
6747
6748 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6749         
6750         * docs/manual/init-api.xml: Grammar fix
6751
6752 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6753
6754         * docs/manual/states.xml: Fix inconsistent information
6755
6756 2004-07-15  Thomas Vander Stichele  <thomas at apestaart dot org>
6757
6758         * gst/gstelement.c: (gst_element_set_state):
6759         * gst/gstpad.c: (gst_pad_try_set_caps):
6760         * gst/gststructure.c:
6761         * gst/gstthread.c: (gst_thread_child_state_change):
6762         * gst/gstvalue.c: (gst_value_compare_double):
6763         * gst/gstvalue.h:
6764         * testsuite/parse/parse1.c: (main):
6765           debugging additions and style cleanups
6766
6767 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6768
6769         * docs/manual/states.xml: Grammar fix
6770
6771 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6772
6773         * docs/manual/pads.xml: Grammar fix
6774
6775 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6776
6777         * docs/manual/elements.xml: Fixed image reference
6778
6779 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6780
6781         * docs/manual/goals.xml: Grammar fix
6782
6783 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6784
6785         * docs/manual/motivation.xml:
6786         Bonobo is no longer "emerging" and added sentence regarding tcp plugins
6787
6788 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6789
6790         * docs/manual/motivation.xml: Fix spelling
6791
6792 2004-07-15  Benjamin Otte  <otte@gnome.org>
6793
6794         * gst/gstelement.h: 
6795           Don't GST_ERROR_OBJECT empty strings - Solaris doesn't like NULL
6796           strings.
6797         * gst/gstelement.c (gst_element_class_init):
6798           GError's are boxed, not objects
6799         * gst/gstmarshal.list:
6800           update list for the fixed error signal
6801
6802 2004-07-14  Andy Wingo  <wingo@pobox.com>
6803
6804         * gst/gsttag.c: Add a tag merge func for pointers. The header was
6805         there all along, but the function wasn't. (guile-gstreamer's build
6806         system uses the address of the function -- I wasn't actually
6807         trying to use this.)
6808
6809 2004-07-14  Andy Wingo  <wingo@pobox.com>
6810
6811         * gst/gstpad.c (gst_pad_try_set_caps): Naive link functions (such
6812         as gst_pad_proxy_pad_link) just link to every other pad when they
6813         are called. In the case where the graph has cycles, this will mean
6814         that a call to try_set_caps will recurse. Allow this recursion
6815         and return OK, while we wait for the first try_set_caps to give a
6816         proper return value.
6817         (gst_pad_link_call_link_functions): Since this function is the
6818         only one to set the NEGOTIATING flag on a pad, if the flag is set
6819         it means that the link functions have indirectly recursed. If this
6820         happens, error out to avoid infinite recursion and an eventual
6821         SEGV.
6822         (gst_real_pad_class_init): Remove a crufty GtkObject comment.
6823         (gst_pad_proxy_getcaps): Intersect the result with the template
6824         caps to ensure that the return value is valid.
6825
6826 2004-07-14  Andy Wingo  <wingo@pobox.com>
6827
6828         * gst/gstdata.c (gst_data_is_writable): s/>=/>/. If there is only
6829         one refcount, the calling function is the owner of the buffer.
6830
6831 2004-07-14  Wim Taymans  <wim@fluendo.com>
6832
6833         * gst/schedulers/gstoptimalscheduler.c: (group_dec_link),
6834         (gst_opt_scheduler_pad_link), (group_migrate_connected):
6835         Fix stupid warning when an element is to be migrated but
6836         is already migrated.
6837
6838 2004-07-14  Wim Taymans  <wim@fluendo.com>
6839
6840         * gst/schedulers/gstoptimalscheduler.c: (group_dec_link),
6841         (gst_opt_scheduler_pad_link), (group_migrate_connected):
6842         Make sure that a single non-loop-based element does not 
6843         end up in a group. This fixes the testsuite again.
6844
6845 2004-07-14  Wim Taymans  <wim@fluendo.com>
6846
6847         * gst/schedulers/gstoptimalscheduler.c: (create_group),
6848         (add_to_group), (merge_groups), (schedule_group),
6849         (gst_opt_scheduler_get_wrapper), (group_elements),
6850         (group_dec_link), (gst_opt_scheduler_pad_link),
6851         (group_migrate_connected), (gst_opt_scheduler_pad_unlink),
6852         (gst_opt_scheduler_iterate):
6853         move isolated groups to a new chain.
6854         Emit a warning instead of segfaulting in some error cases.
6855         Fix a bug where the link count between groups was not calculated 
6856         correctly. Fixes #144510.
6857
6858 2004-07-13  Steve Lhomme  <steve.lhomme@free.fr>
6859         * gst/elements/gstfilesrc.c:
6860           Binary files support under Windows now OK
6861       
6862 2004-07-13  Benjamin Otte  <otte@gnome.org>
6863
6864           compatibility fixes for Solaris 8/gcc 2.95
6865         * configure.ac:
6866           include libintl libs in LDFLAGS
6867         * gstvalue.c (gst_value_deserialize_buffer):
6868           cast isxdigit stuff to int to silence compiler warning
6869
6870 2004-07-12  Benjamin Otte  <otte@gnome.org>
6871
6872         * gst/gsttypes.h:
6873           get rid of GST_O_READONLY, GST_FILE_MODE_READ and
6874           GST_FILE_MODE_WRITE, I don't want them in the exported headers. It
6875           just causes support madness
6876         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
6877           make it work without this
6878         * gst/indexers/gstfileindex.c: (_file_index_id_save_entries),
6879         (gst_file_index_commit):
6880           glib IO channels don't want binary mode
6881         * testsuite/bytestream/filepadsink.c: (main):
6882         * testsuite/bytestream/test1.c: (read_param_file):
6883           use "rb" instead of GST_FILE_MODE_READ, it works on POSIX systems
6884
6885 2004-07-12  Benjamin Otte  <otte@gnome.org>
6886
6887         * gst/gstelement.c: (gst_element_class_init),
6888         (gst_element_set_state), (gst_element_set_state_func):
6889           virutalize gst_element_set_state, use set_state member in class
6890           struct that was already added in 0.7 for this.
6891         * gst/gstbin.c: (gst_bin_foreach), (set_kid_state_func), 
6892         (gst_bin_change_state):
6893           make gst_bin_foreach works similar to other foreach functions, plug
6894           memleaks in it. Make functions using it work with the new approach.
6895           Document gst_bin_foreach, so it can be exported if we want to
6896         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_state):
6897           use virtualized set_state to make set_state on bins set the state of
6898           all its children.
6899
6900 2004-07-12  Benjamin Otte  <otte@gnome.org>
6901
6902         * configure.ac:
6903           require valgrind >= 2.1 (fixes Gentoo bug 53967, see
6904           http://bugs.gentoo.org/show_bug.cgi?id=53967)
6905         * gst/gstpad.c: (gst_pad_alloc_buffer):
6906           allow buffer_alloc functions to return NULL and allocate a normal
6907           buffer in that case
6908
6909 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
6910         * gst/elements/gstfilesink.c:
6911         * gst/elements/gstfilesrc.c:
6912         * gst/indexers/gstfileindex.c:
6913         * gst/gsttypes.h:
6914         * testsuite/bytestream/filepadsink.c:
6915         * testsuite/bytestream/test1.c:
6916           Handle binary files under Windows
6917
6918 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
6919         * docs/manual/win32.xml:
6920         * win32/config.h:
6921         * win32/gst-register.vcproj:
6922         * win32/gstreamer.def:
6923           Update to another gettext public build
6924
6925 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
6926         * gst/gstplugin.c:
6927           Fix an impossible C syntax
6928         * win32/config.h:
6929           Disable i18n under Windows for the moment
6930         * win32/gst-register.vcproj:
6931           Use this configuration
6932
6933 2004-07-12  Jan Schmidt  <thaytan@mad.scientis.com>
6934         * docs/manual/quotes.xml:
6935           Keep the quotes file alive
6936         * docs/random/ds/0.9-suggested-changes:
6937           Add the suggestion of including a 'rowstride' as part of video
6938           format caps
6939
6940 2004-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
6941
6942         * gst/gstelement.c: (gst_element_set_state),
6943         (gst_element_change_state):
6944           d'oh.  Set PENDING state correctly before forcing bin to change.
6945         * gst/gststructure.c: (gst_structure_value_get_generic_type),
6946         (gst_structure_parse_fixed_list):
6947         * gst/schedulers/gstoptimalscheduler.c:
6948         (gst_opt_scheduler_state_transition):
6949         * testsuite/states/parent.c: (main):
6950           remove comment now that it's fixed.
6951
6952 2004-07-11  Benjamin Otte  <otte@gnome.org>
6953
6954         * gst/gstclock.h:
6955           GST_SECOND shouldn't cause a conversion to unsigned.
6956         * testsuite/clock/.cvsignore:
6957         * testsuite/clock/Makefile.am:
6958         * testsuite/clock/signedness.c: (main):
6959           make sure it never will again
6960
6961 2004-07-11  Andy Wingo  <wingo@pobox.com>
6962
6963         * gst/gstbin.c (gst_bin_add_func): If we're adding an element
6964         whose state is higher than the bin state, raise the bin state to
6965         ensure that bin state := highest child state.
6966         
6967 2004-07-11  Andy Wingo  <wingo@pobox.com>
6968
6969         * gst/gstbin.c (gst_bin_foreach): New static function. Calls a
6970         procedure on the children of a bin. Assumes that the procedure can
6971         change the set of children.
6972         (set_kid_state_func): New static function.
6973         (gst_bin_change_state): Use gst_bin_foreach to call
6974         set_kid_state_func. Fixes a bug: if a child had a state-change
6975         handler that removes it from the bin, there would be a segfault.
6976         Hopefully it should also work in the case where the state-change
6977         handler on one child adds or removes other children. In any case,
6978         fixes should go to gst_bin_foreach.
6979
6980 2004-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
6981
6982         * gst/gstelement.c: (gst_element_set_state):
6983           compatibility fix for latest plugins release.  Change loop back
6984           to while {}
6985
6986 2004-07-09  Wim Taymans  <wim@fluendo.com>
6987
6988         * gst/gstbin.c: (gst_bin_remove), (gst_bin_dispose):
6989         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_catch),
6990         (gst_thread_main_loop):
6991         Since remove is virtual in GstBin we must not assume the 
6992         elements GList to have anothing useful.
6993         Add some more logging to GstThread and be a bit more paranoid
6994         when resetting the scheduler.
6995         Set the state of the bin to NULL before removing the children.
6996
6997 2004-07-09  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6998
6999         * testsuite/threads/Makefile.am:
7000         * testsuite/threads/threadg.c:
7001           added test to check if problem when removing all elements from a
7002           GstThread before setting GstThread state to NULL
7003
7004 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7005
7006         * docs/gst/tmpl/gstelement.sgml:
7007         * docs/gst/tmpl/gsttypes.sgml:
7008         * gst/gstbin.c: (gst_bin_change_state):
7009         * gst/gstelement.c: (gst_element_set_state),
7010         (gst_element_change_state):
7011           rework so that for bins we try to set the state on all children
7012           as well even if the bin is in the correct state already.
7013           change while to do so at least one iteration is done.
7014           For regular elements, we fall back to the previous behaviour for
7015           now since we first need a new plugins release.
7016         * testsuite/states/parent.c: (main):
7017           test for this case
7018           Fixes #123774
7019
7020 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7021
7022         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_finalize),
7023         (gst_queue_chain), (gst_queue_get), (gst_queue_handle_src_event),
7024         (gst_queue_release_locks), (gst_queue_change_state),
7025         (gst_queue_set_property):
7026           add proper lock debugging.  Change dispose to finalize, since
7027           we're freeing mutexes and other stuff which should happen only once.
7028
7029 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7030
7031         * docs/gst/tmpl/gstelement.sgml:
7032         * docs/gst/tmpl/gstplugin.sgml:
7033         * docs/gst/tmpl/gsttypes.sgml:
7034         * docs/pwg/building-state.xml:
7035         * gst/elements/gstfakesrc.c: (gst_fakesrc_change_state):
7036         * gst/gstelement.c: (gst_element_change_state):
7037         * gst/gstthread.c: (gst_thread_change_state):
7038           catch wrong state changes in element base class.
7039
7040 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7041
7042         * gst/gstinfo.h:
7043           clean up layout a little.
7044
7045 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7046
7047         * configure.ac:
7048         * testsuite/Makefile.am:
7049         * testsuite/states/Makefile.am:
7050         * testsuite/states/parent.c: (main):
7051           re-enable states testsuite dir.  Add test for state changes and
7052           parent behaviour
7053
7054 2004-07-09  Wim Taymans  <wim@fluendo.com>
7055
7056         * gst/schedulers/gstoptimalscheduler.c:
7057         (gst_opt_scheduler_pad_link), (group_elements_set_visited),
7058         (element_get_reachables_func), (element_get_reachables),
7059         (debug_element), (rechain_group), (group_migrate_connected),
7060         (gst_opt_scheduler_pad_unlink):
7061         Do not try to migrate decoupled elements to a new group since
7062         they are not added to groups.
7063
7064 2004-07-08  Benjamin Otte  <otte@gnome.org>
7065
7066         * gst/gstelement.c: (gst_element_error_func):
7067           make reentrant (= allow removing elements in error handler)
7068
7069 2004-07-08  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7070
7071         * gst/gstpad.c: (gst_pad_event_default_dispatch),
7072         (gst_pad_send_event), (gst_pad_call_chain_function):
7073           events sent to elements below PAUSED cannot be handled, so
7074           don't try to
7075
7076 2004-07-08  Wim Taymans  <wim@fluendo.com>
7077
7078         * gst/schedulers/gstoptimalscheduler.c:
7079         (chain_recursively_migrate_group), (create_group),
7080         (schedule_group), (gst_opt_scheduler_pad_link),
7081         (group_elements_set_visited), (element_get_reachables_func),
7082         (element_get_reachables), (group_can_reach_group), (debug_element),
7083         (rechain_group), (group_migrate_connected),
7084         (gst_opt_scheduler_pad_unlink):
7085         * testsuite/schedulers/Makefile.am:
7086         Implemented group splitting and rechaining.
7087         Fixes 143777 and 143777-2 in the testsuite.
7088
7089 2004-07-08  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7090
7091         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_chain):
7092           extra debugging
7093         * gst/gstevent.h:
7094         * gst/gstinfo.c: (gst_debug_log_default):
7095           print time nicely.  add thread pointer until someone figures out
7096           a completely portable way of getting at thread id's.
7097         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_try),
7098         (_invent_event), (gst_pad_pull), (gst_pad_event_default_dispatch),
7099         (gst_pad_call_chain_function):
7100           extra debugging
7101         * gst/schedulers/gstoptimalscheduler.c:
7102         (get_group_schedule_function), (loop_group_schedule_function),
7103         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
7104         (pad_clear_queued), (gst_opt_scheduler_iterate):
7105           rename BUFPEN and friends to DATAPEN since that's what they are.
7106
7107 2004-07-07  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7108
7109         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_chain):
7110         * gst/gstbuffer.h:
7111         * gst/gstpad.c:
7112           cleanups and debugging
7113
7114 2004-07-07  Ronald Bultje  <rbultje@ronald.bitfreak.net>
7115
7116         * configure.ac:
7117         * gst/gstvalue.c: (gst_value_compare_enum),
7118         (gst_value_serialize_enum), (gst_value_deserialize_enum),
7119         (gst_value_can_compare), (gst_value_compare):
7120         * testsuite/Makefile.am:
7121         * testsuite/enumcaps/Makefile.am:
7122         * testsuite/enumcaps/enumcaps.c:
7123           Fix enum serialization, deserialization, comparison in caps, add
7124           a test to ensure that this continues working in the future.
7125
7126 2004-07-06  David Schleef  <ds@schleef.org>
7127
7128         * gst/gstcaps.c: (gst_caps_save_thyself), (gst_caps_load_thyself):
7129         Fix memleak.
7130
7131 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7132
7133         * gst/gstplugin.c: (gst_plugin_check_file), (gst_plugin_load_file):
7134         * gst/gstplugin.h:
7135         * gst/registries/gstxmlregistry.c:
7136         (plugin_times_older_than_recurse), (plugin_times_older_than),
7137         (gst_xml_registry_parse_padtemplate):
7138           only rebuild registry when actual plugins have a newer time than
7139           the registry.  Fixes #145520
7140
7141 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7142
7143         * docs/manual/manual.xml:
7144         * docs/manual/win32.xml:
7145           add chapter on win32 building.  fixes #142422
7146
7147 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7148
7149         patch by: Sebastien Cote <sc5 at hermes.usherb.ca>
7150
7151         * gst/autoplug/gstspider.c: (gst_spider_init),
7152         (gst_spider_dispose):
7153           fix spider memleaks.  fixes #137863
7154
7155 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7156
7157         patch by: Joe Marcus Clarke <marcus at freebsd dot org>
7158
7159         * gst/schedulers/gstoptimalscheduler.c:
7160         (gst_opt_scheduler_pad_unlink):
7161           fix SIGBUS error, fixes #145338
7162
7163 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7164
7165         * gst/gstobject.c: (gst_object_replace):
7166         * gst/gstscheduler.c: (gst_scheduler_get_clock):
7167         * gst/gstsystemclock.c: (gst_system_clock_obtain):
7168           clean up clock lifecycle.  Fixes #109831
7169
7170 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
7171
7172         * po/LINGUAS:
7173         * po/cs.po:
7174           added Czech translation (Miloslav Trmac)
7175
7176 2004-07-04  David Schleef  <ds@schleef.org>
7177
7178         * tools/Makefile.am:
7179         * tools/gst-xmlinspect.1.in:  Add man page. (bug #140219)
7180
7181 2004-07-04  David Schleef  <ds@schleef.org>
7182
7183         * common/m4/gst-doc.m4: Check for docbook2html 0.6.10 (bug #139909)
7184
7185 2004-07-04  Thomas Vander Stichele  <thomas at apestaart dot org>
7186
7187         * gst/gstbin.c: (gst_bin_restore_thyself):
7188           chain to parent restore so the bins get restored correctly
7189           in the editor
7190
7191 2004-07-03  David Schleef  <ds@schleef.org>
7192
7193         * gst/gstcaps.c: (gst_caps_save_thyself), (gst_caps_load_thyself):
7194         Actually do something in these functions, like before the big
7195         caps change.  (bug #145137)
7196
7197 2004-07-03  Thomas Vander Stichele  <thomas at apestaart dot org>
7198
7199         * gst/gstelement.c: (gst_element_get_compatible_pad_template),
7200         (gst_element_get_compatible_pad_filtered):
7201         * gst/gstthread.c: (gst_thread_main_loop):
7202           more debugging
7203
7204 2004-07-02  David Schleef  <ds@schleef.org>
7205
7206         * gst/gstinfo.h: wrap #pragmas in #ifdefs for the correct compiler
7207         * gst/gstobject.h:
7208         * gst/gstparse.h:
7209         * gst/gsttrace.h:
7210         * gst/gstxml.h:
7211
7212 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
7213
7214         * gst/gstpad.c: (gst_pad_check_schedulers),
7215         (gst_pad_can_link_filtered), (gst_pad_link_filtered),
7216         (gst_pad_link_prepare):
7217           revert until testsuite is fixed
7218
7219 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
7220
7221         * testsuite/Makefile.am:
7222         * testsuite/caps/filtercaps.c: (main):
7223         * testsuite/clock/clock1.c: (main):
7224         * testsuite/dynparams/dparamstest.c: (gst_dptest_chain), (main):
7225           fix some more tests
7226
7227 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
7228
7229         * testsuite/cleanup/cleanup1.c: (create_pipeline):
7230         * testsuite/cleanup/cleanup2.c: (create_pipeline):
7231         * testsuite/cleanup/cleanup4.c: (main):
7232           fix testsuite
7233
7234 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
7235
7236         * libs/gst/control/control.c:
7237         * libs/gst/control/dparam.c:
7238         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_get_type):
7239         * libs/gst/control/dparammanager.c:
7240         * libs/gst/control/dparammanager.h:
7241         * testsuite/dynparams/Makefile.am:
7242         * testsuite/dynparams/dparamstest.c: (gst_dptest_base_init),
7243         (gst_dptest_change_state), (gst_dptest_chain), (main):
7244           fix testcase for dparams
7245           add debugging category
7246
7247 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
7248
7249         * testsuite/Rules:
7250           change path
7251
7252 2004-07-02  Benjamin Otte  <otte@gnome.org>
7253
7254         * tests/.cvsignore:
7255         * tests/Makefile.am:
7256         * tests/mass_elements.c: (gst_get_current_time), (main):
7257           add simple benchmark to test various speeds of fakesrc ! identity !
7258           identity ! ... ! fakesink.
7259           Usage: mass_elements [num_identities] [num_buffers]
7260           If not specified they default to 1000.
7261
7262 2004-07-02  Benjamin Otte  <otte@gnome.org>
7263
7264         * gst/gstpad.c: (gst_pad_check_schedulers),
7265         (gst_pad_can_link_filtered), (gst_pad_link_filtered),
7266         (gst_pad_link_prepare):
7267           check that pads that get linked belong to the same manager. The old
7268           code allowed linking elements before putting them into bins, so it
7269           worked to link them and then put them in different threads, which
7270           lead to weird behaviour.
7271           Since this effectively disallows linking elements before putting
7272           them in a bin, some applications might not work after this and error
7273           out. If these applications are too critical, we might need to revert
7274           that patch. Please test this before the next release...
7275
7276 2004-06-28  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7277
7278         * gst/gstpad.c: (gst_pad_get_caps):
7279           throw an error if the getcaps function does not return a subset of
7280           the template caps.
7281         * libs/gst/bytestream/filepad.c: (gst_file_pad_chain):
7282           make disconts without position info an error in debugging
7283         * tests/spidey_bench.c: (handoff), (main):
7284           don't count first try when averaging
7285
7286 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
7287
7288         * gst/gstplugin.c: (gst_plugin_load_file):
7289           figure out problem with dynamic test
7290
7291 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
7292
7293         * docs/gst/Makefile.am:
7294           fix docs build
7295
7296 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
7297
7298         * po/POTFILES.in:
7299         * po/af.po:
7300         * po/az.po:
7301         * po/en_GB.po:
7302         * po/fr.po:
7303         * po/nl.po:
7304         * po/sr.po:
7305         * po/sv.po:
7306         * po/tr.po:
7307         * po/uk.po:
7308         * tools/gst-register.c: (plugin_added_func), (main):
7309           i18n-ize -register, fix plural
7310
7311 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
7312
7313         * gst/elements/gstidentity.c: (gst_identity_class_init),
7314         (gst_identity_init), (gst_identity_chain),
7315         (gst_identity_set_property), (gst_identity_get_property):
7316         * gst/elements/gstidentity.h:
7317           check for perfect stream
7318
7319 2004-06-25  Thomas Vander Stichele  <thomas at apestaart dot org>
7320
7321         * gst/elements/gstidentity.c: (gst_identity_chain):
7322           print offset_end
7323
7324 2004-06-25  Thomas Vander Stichele  <thomas at apestaart dot org>
7325
7326         * docs/gst/Makefile.am:
7327         * docs/gst/gstreamer-docs.sgml:
7328           doc fixes
7329
7330 2004-06-24  David Schleef  <ds@schleef.org>
7331
7332         * autogen.sh:  Remove call to env, since the buildbot isn't
7333         broken anymore.
7334
7335 2004-06-24  Wim Taymans  <wim@fluendo.com>
7336
7337         * gst/elements/Makefile.am:
7338         * gst/elements/gstelements.c:
7339         * gst/elements/gstmultifdsink.c: (gst_multifdsink_base_init),
7340         (gst_multifdsink_class_init), (gst_multifdsink_init),
7341         (gst_multifdsink_add), (gst_multifdsink_remove),
7342         (gst_multifdsink_clear), (gst_multifdsink_chain),
7343         (gst_multifdsink_set_property), (gst_multifdsink_get_property):
7344         * gst/elements/gstmultifdsink.h:
7345         Added an element that writes to multiple filedescriptors at once.
7346
7347 2004-06-24  Benjamin Otte  <otte@gnome.org>
7348
7349         * gst/parse/grammar.y:
7350           don't try to link elements before they have been added to bins
7351
7352 2004-06-24  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7353
7354         * libs/gst/bytestream/filepad.c: (gst_file_pad_available),
7355         (gst_file_pad_get_length):
7356         * libs/gst/bytestream/filepad.h:
7357           add 2 new functions
7358
7359 2004-06-22  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
7360
7361         * docs/gst/gstreamer-sections.txt:
7362         remove from docs, the define that Benjamin removed from gstelement.h
7363
7364 2004-06-22  Benjamin Otte  <otte@gnome.org>
7365
7366         * gst/gstelement.h:
7367           remove define that referenced a nonexisting GstElement struct member
7368
7369 2004-06-20  Benjamin Otte  <otte@gnome.org>
7370
7371         * gst/gstdata.c: (gst_data_is_writable):
7372           whoops, return values were wrong, so writable data was marked as
7373           non-writable and vice versa. (fixes #143953, spotted by Francis
7374           Labonte)
7375           Shows how rarely we need to copy data ;)
7376
7377 2004-06-20  Benjamin Otte  <otte@gnome.org>
7378
7379         * testsuite/schedulers/.cvsignore:
7380         * testsuite/schedulers/Makefile.am:
7381         * testsuite/schedulers/143777-2.c: (main):
7382           add test for opt breakage in bug #143777
7383
7384 2004-06-20  Benjamin Otte  <otte@gnome.org>
7385
7386         * gst/gstpad.c: (gst_pad_call_chain_function):
7387           check for if we were unlinked while inside the chainfunction (fixes
7388           entrygthread having issues with #143777)
7389         * testsuite/schedulers/143777.c: (main):
7390         * testsuite/schedulers/Makefile.am:
7391           add a test for that fix
7392
7393 2004-06-20  Benjamin Otte  <otte@gnome.org>
7394
7395         * gst/gstvalue.c: (gst_value_set_int_range):
7396           test that start is smaller then end
7397         * libs/gst/bytestream/Makefile.am:
7398         * libs/gst/bytestream/filepad.c: 
7399         * libs/gst/bytestream/filepad.h:
7400           add GstFilePad - a pad that behaves like a FILE*
7401         * testsuite/bytestream/.cvsignore:
7402         * testsuite/bytestream/Makefile.am:
7403         * testsuite/bytestream/filepadsink.c: 
7404           test for the GstFilePad
7405
7406 2004-06-18  Thomas Vander Stichele  <thomas at apestaart dot org>
7407
7408         * gst/elements/gstidentity.c: (gst_identity_class_init),
7409         (gst_identity_init), (gst_identity_set_clock),
7410         (gst_identity_chain), (gst_identity_set_property),
7411         (gst_identity_get_property):
7412         * gst/elements/gstidentity.h:
7413         * gst/gstclock.c: (gst_clock_id_wait):
7414           add a "sync" property to sync to the clock
7415
7416 2004-06-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7417
7418         * gst/gstelementfactory.c: (gst_element_factory_create):
7419           make the freakin "elementfactory bla has no type" message more
7420           useful. So we actually can do something when someone shows up
7421           complaining about it.
7422
7423 2004-06-15  Johan Dahlin  <johan@gnome.org>
7424
7425         * tools/gst-inspect.c (main): Fallback to plugin if no element is
7426         found. This matches the old behavior better. Thanks to Thomas for
7427         pointing out.
7428
7429 2004-06-14  David Schleef  <ds@schleef.org>
7430
7431         * gst/gstcpu.c: (gst_cpuid_i386): Fix problem when using
7432         -fomit-frame-pointer.  Appears to generate correct code in
7433         other cases as well.
7434
7435 2004-06-14  Johan Dahlin  <johan@gnome.org>
7436
7437         * tools/gst-inspect.c (main): Add two new command line options: -a
7438         to print all elements and -n to print the name on each line. Also
7439         fix some error reporting.
7440         (main): Simplify, remove -n and always print names if -a is specified
7441
7442 2004-06-13  Steve Lhomme  <steve.lhomme@free.fr>
7443
7444         * win32/gstconfig.h:
7445         * win32/GSTreamer.vcproj:
7446         * win32/Makefile:
7447         * gst/gstconfig.h.in:
7448         * gst/gst.h:
7449         * gst/gstbin.h:
7450         * gst/gstelement.h:
7451         * gst/gstevent.h:
7452         * gst/gstobject.h:
7453         * gst/gstpad.h:
7454         * docs/gst/gstreamer-sections.txt:
7455         * docs/gst/tmpl/gstconfig.sgml:
7456           rename GSTREAMER_EXPORT(S) to GST_EXPORT(S)
7457
7458 2004-06-13  Jan Schmidt  <thaytan@mad.scientist.com>
7459         * docs/gst/gstreamer-sections.txt:
7460         * docs/gst/tmpl/gstconfig.sgml:
7461         Add the GSTREAMER_EXPORT macro to the docs
7462
7463 2004-06-13  Jan Schmidt  <thaytan@mad.scientist.com>
7464
7465         * tools/gst-compprep.c: (handle_xmlerror), (main):
7466         Add a check for the version that introduced SetStructuredError to fix
7467         the build on FC1
7468
7469 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7470
7471         * win32/msvc71.sln:
7472         * win32/testsuite/:
7473           prepare to compile the testsuite with MSVC
7474
7475 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7476
7477         * docs/manual/win32.xml:
7478           attempt to transform the Win32 README into an XML doc
7479
7480 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7481
7482         * gst/gst.c:
7483         * gst/gstbin.*:
7484         * gst/config.h.in:
7485         * gst/gstelement.*:
7486         * gst/gstevent.h:
7487         * gst/gstobject.*:
7488         * gst/gstpad.h:
7489         * tools/gst-register.c:
7490         * win32/gstreamer.def:
7491           extern symbols are now exported for the Windows DLL
7492
7493 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7494
7495         * gst/gstinfo.h:
7496           fix a problem to enable/disable DEBUG under MSVC
7497
7498 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7499
7500         * win32/:
7501           enable more debug code in DEBUG build
7502
7503 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
7504
7505         * win32/config.h:
7506         * gst/gst-i18n-app.h:
7507           enable NLS under Windows
7508
7509 2004-06-12  Jan Schmidt  <thaytan@mad.scientist.com>
7510         * tools/gst-compprep.c: (handle_xmlerror), (main):
7511           Make an error that baffled me a bit clearer
7512
7513 2004-06-12  Thomas Vander Stichele  <thomas at apestaart dot org>
7514
7515         * gst/gstqueue.c:
7516           don't use g_queue_get_length () because it's 2.4, use ->length
7517
7518 2004-06-11  Steve Lhomme  <steve.lhomme@free.fr>
7519
7520         reviewed by Benjamin Otte  <in7y118@public.uni-hamburg.de>
7521
7522         * tools/gst-inspect.c: (print_signal_info):
7523           don't free random data twice. (fixes #144185)
7524
7525 2004-06-11  Thomas Vander Stichele  <thomas at apestaart dot org>
7526
7527         * gst/gstqueue.c:
7528         * gst/gstqueue.h:
7529           fix removing from the wrong queue on event timeout
7530           fix disposing of the event queue by casting correctly
7531           add mutexes for handling the event queue
7532           someone was sleeping when fixing queue last time around :)
7533
7534 2004-06-10  Johan Dahlin  <johan@gnome.org>
7535
7536         * gst/gst.c (gst_init_check_with_popt_table): Do not fail on
7537         errors, like gtk. It makes it more useful in bindings.  Fixes #141692.
7538
7539 2004-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
7540
7541         * docs/random/gdp:
7542         * libs/gst/dataprotocol/dataprotocol-test.c: (buffer_test):
7543         * libs/gst/dataprotocol/dataprotocol.c:
7544         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
7545         (gst_dp_buffer_from_header):
7546         * libs/gst/dataprotocol/dataprotocol.h:
7547         * libs/gst/dataprotocol/dp-private.h:
7548           rev version to 0.1, add buffer flags and copy them
7549
7550 2004-06-09  Johan Dahlin  <johan@gnome.org>
7551
7552         * gst/gstbuffer.c (gst_buffer_default_copy): Don't forget to merge
7553         the flags from the buffer we're copying.
7554
7555 2004-06-09  Wim Taymans  <wim@fluendo.com>
7556
7557         * gst/elements/gstfakesink.c: (gst_fakesink_chain):
7558         * gst/elements/gstidentity.c: (gst_identity_init),
7559         (gst_identity_chain):
7560         Print more buffer info in fakesink.
7561         Make identity output similar to fakesink.
7562
7563 2004-06-07  Daniel Gazard  <dany42@free.fr>
7564
7565         reviewed by Benjamin Otte  <otte@gnome.org>
7566
7567         * configure.ac:
7568           fix cross compiling not working. (fixes #143741)
7569
7570 2004-06-07  Benjamin Otte  <otte@gnome.org>
7571
7572         * gst/gstelement.c: (gst_element_set_time_delay):
7573           add failure check
7574         * gst/gstinfo.h:
7575           put brackets around macro arguments of GST_TIME_ARGS, add note to
7576           move it to correct header in 0.9
7577
7578 2004-06-07  Benjamin Otte  <otte@gnome.org>
7579
7580         * gst/indexers/gstfileindex.c: (gst_file_index_get_writer_id),
7581         (gst_file_index_load), (_file_index_id_save_entries),
7582         (gst_file_index_commit), (gst_file_index_add_association),
7583         (gst_file_index_add_entry), (gst_file_index_get_assoc_entry),
7584         (gst_file_index_plugin_init):
7585           make debugging use a default category
7586
7587 2004-06-06  David Moore  <dcm@acm.org>
7588
7589         reviewed by Benjamin Otte  <otte@gnome.org>
7590
7591         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init),
7592         (gst_fdsrc_change_state):
7593           reset offset counter when going READY => PAUSED. (fixes #142903)
7594
7595 2004-06-06  ed@catmur.co.uk
7596
7597         reviewed by Benjamin Otte  <otte@gnome.org>
7598
7599         * gst/registries/gstxmlregistry.c:
7600         (gst_xml_registry_rebuild_recurse):
7601           don't rely on g_dir_open to figure out if a file is a directory, use
7602           explicit G_TEST_IS_DIR. Reiserfs4 allows opening files as
7603           directories. (fixes #142850)
7604
7605 2004-06-06  Benjamin Otte  <otte@gnome.org>
7606
7607         * gst/gstqueue.c: (gst_queue_dispose), (gst_queue_change_state):
7608           fix memory leaks (fixes #142795). Initial patch by Sebastien Cote
7609         * libs/gst/bytestream/adapter.c:
7610         * libs/gst/bytestream/adapter.h:
7611           fix copyright in header and typo in debugging category name
7612
7613 2004-06-05  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7614
7615         * configure.ac:
7616           bump nano to cvs
7617
7618 === release 0.8.3 ===
7619
7620 2004-06-05  Thomas Vander Stichele  <thomas at apestaart dot org>
7621
7622         * configure.ac:
7623           update libtool versioning
7624           do a new release
7625         * docs/gst/tmpl/gstelement.sgml:
7626         * docs/gst/tmpl/gsttypes.sgml:
7627         * gst/gstinfo.c: (_gst_debug_init):
7628           put back GST_CAT_DATAFLOW to fix API breakage
7629
7630 2004-06-04  David Schleef  <ds@schleef.org>
7631
7632         * autogen.sh: Add a temporary 'env' to test buildbot problems.
7633
7634 2004-06-04  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7635
7636         * configure.ac:
7637           bump nano to cvs
7638
7639 === release 0.8.2 ===
7640
7641 2004-06-03  Thomas Vander Stichele  <thomas at apestaart dot org>
7642
7643         * gst/gst.c: (parse_debug_list), (gst_init_check_with_popt_table):
7644           check GST_DEBUG environment variable which is parsed the same way
7645           as --gst-debug=
7646
7647 2004-05-28  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
7648
7649         * gst/elements    : gstaggregator.c gstfakesink.c gstfakesrc.c
7650                             gstmd5sink.c gstshaper.c gsttee.c
7651                             gsttypefindelement.c
7652         * gst/schedulers  : gstbasicscheduler.c gstoptimalscheduler.c
7653
7654           - removing trailing commas at end of enums
7655             it is correct C99 code but C90 compilers would complain
7656             (AIX, Forte, ...)
7657             ('should' fix #143290, at least partially)
7658
7659 2004-05-27  Wim Taymans  <wim@fluendo.com>
7660
7661         * gst/schedulers/gstoptimalscheduler.c: (remove_from_chain),
7662         (chain_group_set_enabled), (create_group), (add_to_group),
7663         (merge_groups), (setup_group_scheduler), (group_elements),
7664         (gst_opt_scheduler_iterate), (gst_opt_scheduler_show):
7665         Don't try to follow the pad connections with other groups
7666         when a loop based element is added to the scheduler because
7667         the bin will inform the scheduler about the pad links a little
7668         later.
7669
7670 2004-05-27  Wim Taymans  <wim@fluendo.com>
7671
7672         * gst/schedulers/gstoptimalscheduler.c: (add_to_chain),
7673         (remove_from_chain), (chain_group_set_enabled),
7674         (setup_group_scheduler), (group_element_set_enabled),
7675         (gst_opt_scheduler_state_transition), (gst_opt_scheduler_iterate),
7676         (gst_opt_scheduler_show):
7677         Elements without a group can do a state change as well, just wait
7678         with the setup of the scheduling function when it is added to a
7679         chain.
7680
7681 2004-05-27  Wim Taymans  <wim@fluendo.com>
7682
7683         * gst/schedulers/gstoptimalscheduler.c: (add_to_chain),
7684         (remove_from_chain), (chain_group_set_enabled), (add_to_group),
7685         (merge_groups), (setup_group_scheduler),
7686         (group_inc_links_for_element), (gst_opt_scheduler_iterate),
7687         (gst_opt_scheduler_show):
7688         Fixes to maintain internal consistency of the scheduler data
7689         structures. 
7690          - adding an enabled group to a chain should increment the
7691            number of enabled elements in that chain.
7692          - removing an enabled group from a chain could disable the
7693            chain.
7694          - removing a disabled group from a chain could enable the
7695            chain.
7696          - add g_assert when internal inconsistency is detected.
7697          - adding an element to a group could increase the number of
7698            links this group has with other groups.
7699          - merging two groups also merges the chains.
7700          - also show group links in the _show method.
7701            
7702
7703 2004-05-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7704
7705         * gst/gstcaps.c: (gst_caps_structure_simplify):
7706           don't print error messages when there is no error
7707         * gst/gstvalue.c: (gst_value_compare_int_range):
7708           compare the second value, too
7709         * testsuite/caps/Makefile.am:
7710         * testsuite/caps/random.c: (assert_on_error), (main):
7711           add tests to make sure the two things above are checked for
7712
7713 2004-05-24  Thomas Vander Stichele  <thomas at apestaart dot org>
7714
7715         * configure.ac:
7716         * libs/gst/dataprotocol/Makefile.am:
7717         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_caps):
7718         * libs/gst/dataprotocol/dataprotocol.h:
7719           wrap header in GST_ENABLE_NEW.  make code use it
7720
7721 2004-05-23  Johan Dahlin  <johan@gnome.org>
7722
7723         * tools/gst-inspect.c (main): Cleanup most parts of it, don't be
7724         so verbose and print GstElement signal names all the time.
7725
7726 2004-05-22  David Schleef  <ds@schleef.org>
7727
7728         * gst/registries/gstxmlregistry.c:
7729         (gst_xml_registry_parse_padtemplate): Fix warning on OS X.
7730         (bug #142957)
7731
7732 2004-05-22  Thomas Vander Stichele  <thomas at apestaart dot org>
7733
7734         * configure.ac:
7735           scrub cflags for glib2 so gcc doesn't complain when glib is in
7736           /usr/local
7737
7738 2004-05-21  Johan Dahlin  <johan@gnome.org>
7739
7740         * gst/gstcpu.c (gst_cpuid_i386): Protect some gcc asm stuff with
7741         __GNUC__, patch from Brian Cameron, fixes bug #142804
7742
7743 2004-05-20  David Schleef  <ds@schleef.org>
7744
7745         * gst/gstindex.c: (gst_index_compare_func): Fix overflows in
7746         comparison code.  (bug #142819)
7747
7748 2004-05-20  Wim Taymans  <wim@fluendo.com>
7749
7750         * gst/gstbuffer.c: (gst_buffer_default_copy):
7751         * gst/gstbuffer.h:
7752         Added Comment to a flag.
7753         copy relevant flags in _buffer_copy.
7754
7755 2004-05-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7756
7757         reviewed by: Wim Taymans <wim at fluendo dot com>
7758
7759         * gst/gstbuffer.h:
7760           add GST_BUFFER_IN_CAPS buffer flag
7761         * gst/gststructure.c: (gst_structure_value_get_generic_type),
7762         (gst_structure_parse_any_list), (gst_structure_parse_list),
7763         (gst_structure_parse_fixed_list), (gst_structure_parse_value):
7764         * gst/gstvalue.c: (gst_value_serialize_any_list),
7765         (gst_value_transform_any_list_string),
7766         (gst_value_list_prepend_value), (gst_value_list_append_value),
7767         (gst_value_list_get_size), (gst_value_list_get_value),
7768         (gst_value_transform_list_string),
7769         (gst_value_transform_fixed_list_string),
7770         (gst_value_serialize_list), (gst_value_serialize_fixed_list),
7771         (gst_value_deserialize_fixed_list), (gst_type_is_fixed),
7772         (_gst_value_initialize):
7773         * gst/gstvalue.h:
7774           add a GST_TYPE_FIXED_LIST which is fixed by definition and uses
7775           < , > as a format.
7776         * testsuite/caps/string-conversions.c: (main):
7777           add regression tests for < >
7778
7779 2004-05-20  Johan Dahlin  <johan@gnome.org>
7780
7781         * docs/gst/Makefile.am (all-local): Re-add
7782
7783 2004-05-20  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
7784
7785         * docs/gst/Makefile.am:
7786         * docs/gst/gstreamer-docs.sgml:
7787         * docs/libs/Makefile.am:
7788         * docs/libs/gstreamer-libs-docs.sgml:
7789           fix distcheck issues
7790
7791 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
7792
7793         * libs/gst/dataprotocol/Makefile.am:
7794           add to autotest
7795
7796 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
7797
7798         * libs/gst/dataprotocol/Makefile.am:
7799         * libs/gst/dataprotocol/dataprotocol.c:
7800         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
7801         (gst_dp_packet_from_event), (gst_dp_event_from_packet):
7802         * libs/gst/dataprotocol/dp-private.h:
7803           use GST macros to read/write fixed length ints
7804           add some more asserts
7805
7806 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
7807
7808         * docs/libs/gstreamer-libs-docs.sgml:
7809         * docs/libs/gstreamer-libs-sections.txt:
7810           remove idct and putbits
7811         * configure.ac:
7812         * docs/libs/tmpl/gstdataprotocol.sgml:
7813         * libs/gst/Makefile.am:
7814         * libs/gst/dataprotocol/Makefile.am:
7815         * libs/gst/dataprotocol/dataprotocol-test.c: (conversion_test),
7816         (buffer_test), (caps_test), (event_test), (main):
7817         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_crc),
7818         (gst_dp_dump_byte_array), (gst_dp_init),
7819         (gst_dp_header_payload_length), (gst_dp_header_payload_type),
7820         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
7821         (gst_dp_packet_from_event), (gst_dp_buffer_from_header),
7822         (gst_dp_caps_from_packet), (gst_dp_event_from_packet),
7823         (gst_dp_validate_header), (gst_dp_validate_payload),
7824         (gst_dp_validate_packet), (plugin_init):
7825         * libs/gst/dataprotocol/dataprotocol.h:
7826         * libs/gst/dataprotocol/dp-private.h:
7827           add dataprotocol
7828
7829 2004-05-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7830
7831         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
7832           fix int variable deserialization and add a helper so we can actually
7833           debug this.
7834
7835 2004-05-18  David Schleef  <ds@schleef.org>
7836
7837         * testsuite/debug/commandline.c: (main): Call ./commandline, not
7838           argv[0].  Calling yourself is probably not the best way to
7839           construct a test like this, btw.
7840
7841 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7842
7843         * gst/gstbin.c: (gst_bin_iterate_func), (gst_bin_iterate):
7844           don't claim to be more intelligent than a scheduler when the
7845           scheduler claims the pipeline is stopped
7846         * gst/schedulers/entryscheduler.c: (safe_cothread_switch),
7847         (safe_cothread_destroy),
7848         (gst_entry_scheduler_remove_all_cothreads),
7849         (gst_entry_scheduler_reset), (_remove_cothread),
7850         (gst_entry_scheduler_state_transition):
7851           hold off cothread destruction if we're not in main cothread
7852         * configure.ac:
7853         * testsuite/Makefile.am:
7854           add new test dir
7855         * testsuite/schedulers/.cvsignore:
7856         * testsuite/schedulers/Makefile.am:
7857           add tests
7858         * testsuite/schedulers/relink.c: (cb_handoff), (main):
7859           check relinking and adding/removing elements from a running pipeline
7860         * testsuite/schedulers/unlink.c: (cb_handoff), (main):
7861           check unlinking in a running pipeline
7862         * testsuite/schedulers/unref.c: (cb_handoff), (main):
7863           check unreffing a running pipeline
7864         * testsuite/schedulers/useless_iteration.c: (main):
7865           check iterating a pipeline that contains running threads works
7866
7867 2004-05-18  David Schleef  <ds@schleef.org>
7868
7869         * docs/gst/Makefile.am: Add all-local target for when HAVE_GTK_DOC
7870           is false.
7871
7872 2004-05-18  Wim Taymans  <wim@fluendo.com>
7873
7874         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
7875         (setup_group_scheduler), (gst_opt_scheduler_pad_link):
7876         Fixed an error introduced with patch for 1.63. When setting
7877         a get based element as the entry point in a group, make sure
7878         to mark the group as GET based.
7879
7880 2004-05-18  Wim Taymans  <wim@fluendo.com>
7881
7882         * gst/schedulers/gstoptimalscheduler.c: (create_group),
7883         (setup_group_scheduler), (loop_group_schedule_function),
7884         (gst_opt_scheduler_pad_link):
7885         Added some more debug info and fixed a bug where the group
7886         type was set to LOOP but it was in fact unknown.
7887
7888 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7889
7890         * gst/schedulers/entryscheduler.c: (gst_entry_scheduler_reset):
7891           make resetting scheduler work twice in a row
7892
7893 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7894
7895         * gst/gstvalue.c: (gst_strtoll), (CREATE_SERIALIZATION),
7896         (CREATE_USERIALIZATION), (_gst_value_initialize),
7897         (gst_value_compare_float), (gst_value_serialize_float),
7898         (gst_value_deserialize_float), (gst_value_compare_enum),
7899         (gst_value_serialize_enum), (gst_value_deserialize_enum):
7900           add serialization and comparison functions for long, int64, enum and
7901           float values
7902         * gst/gstvalue.c: (gst_value_serialize), (gst_value_deserialize):
7903           use best serialization function in type hierarchy instead of only a
7904           matching one. This is required for enums to work.
7905         * gst/parse/grammar.y:
7906           use gst_caps_deserialize
7907         * testsuite/parse/Makefile.am:
7908           parse1 now works
7909         * testsuite/parse/parse1.c: (main):
7910           remove aggregator check, aggregator is broken, this test works now
7911           but fails because of bug #138012
7912         * testsuite/parse/parse2.c: (main):
7913           s/xvideosink/xvimagesink - this test looks a lot like we should
7914           disable it
7915
7916 2004-05-13  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7917
7918         * gst/gstelement.c: (gst_element_class_init):
7919           whoops, store the signal id correctly
7920         * gst/schedulers/gstbasicscheduler.c:
7921         (gst_basic_scheduler_chain_wrapper):
7922           detect infinfinfinfinfinf^Cinite loops in chain wrapper when the
7923           chain function isn't linked
7924
7925 2004-05-13  Jan Schmidt  <thaytan@mad.scientist.com>
7926         * configure.ac:
7927         Add $GST_PKG_CFLAGS back into GST_INT_CFLAGS so I have large file
7928         support until we decide where the flags should be used
7929         * gst/elements/gstfilesrc.c: (gst_filesrc_srcpad_query):
7930         Use GST_FORMAT_BYTES when GST_FORMAT_DEFAULT is passed
7931         * gst/gstpad.c: (gst_pad_link_call_link_functions):
7932         Output refused caps in the debug info
7933
7934 2004-05-13  Thomas Vander Stichele  <thomas at apestaart dot org>
7935
7936         * gst/elements/gstidentity.c: (gst_identity_chain):
7937           add duration debug
7938         * gst/gstinfo.c: (gst_debug_log_default):
7939           add timestamp
7940
7941 2004-05-13  Benjamin Otte  <otte@gnome.org>
7942
7943         * gst/gstpipeline.c: (gst_pipeline_dispose),
7944         (gst_pipeline_change_state):
7945           call gst_scheduler_reset on dispose (fixes #141416)
7946
7947 2004-05-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7948
7949         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
7950           compute mapsize correctly
7951         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
7952           use correct datatypes when calling a varargs function
7953         * gst/elements/gsttypefindelement.c: (stop_typefinding):
7954           push a DISCONT event as first thing
7955         * gst/gst_private.h:
7956         * gst/gstinfo.c: (_gst_debug_init):
7957           remove GST_DATAFLOW debugging category
7958         * gst/gstbin.c: (gst_bin_iterate):
7959           use GST_SCHEDULING category
7960         * gst/gstpad.c: (gst_pad_get_type), (_invent_event),
7961         (gst_pad_push), (gst_pad_pull), (gst_pad_call_chain_function),
7962         (gst_pad_call_get_function):
7963           add GST_DATAFLOW to easily track flow of buffers or events.
7964         * gst/gstqueue.c: (gst_queue_get_type),
7965         (gst_queue_handle_pending_events), (gst_queue_chain),
7966         (gst_queue_get), (gst_queue_handle_src_event):
7967           use own static debugging category GST_DATAFLOW for dataflow,
7968           use DEBUG category for showing which path events go, use LOG
7969           category for buffers.
7970
7971 2004-05-10  David Schleef  <ds@schleef.org>
7972
7973         * docs/gst/gstreamer-sections.txt: Add gst_element_no_more_pads.
7974
7975 2004-05-10  David Schleef  <ds@schleef.org>
7976
7977         * docs/gst/Makefile.am: Dear gtk-doc, please print out the unused
7978         symbols, because otherwise we don't know what they are.  Thanks,
7979         the GStreamer team.
7980         * gst/registries/gstxmlregistry.c: (make_dir): Remove a spurious ;
7981
7982 2004-05-10  David Schleef  <ds@schleef.org>
7983
7984         (from Steve Lhomme)
7985         * win32/Makefile: When using make clean the MS Visual Studio makefiles
7986         are deleted.  Fix.
7987         * win32/Makefile.inspect:
7988         * win32/Makefile.launch:
7989         * win32/Makefile.register:
7990
7991 2004-05-10  David Schleef  <ds@schleef.org>
7992
7993         * gst/gstinfo.h: Add missing inline function.
7994         * gst/gsttrace.c: add include
7995         * gst/parse/grammar.y: remove unused code
7996         * gst/registries/gstxmlregistry.c: (make_dir): make mkdir call
7997         more portable.
7998         * tools/gst-register.c: wrap unistd.h
7999         
8000         More additions/fixes from Steve for the MSVC build.
8001         * win32/GStreamer.vcproj:
8002         * win32/Makefile:
8003         * win32/Makefile.inspect:
8004         * win32/Makefile.launch:
8005         * win32/Makefile.register:
8006         * win32/README.txt:
8007         * win32/gst-inspect.vcproj:
8008         * win32/gst-launch.vcproj:
8009         * win32/gst-register.vcproj:
8010         * win32/gstbytestream.def:
8011         * win32/gstbytestream.vcproj:
8012         * win32/gstconfig.h:
8013         * win32/gstelements.def:
8014         * win32/gstelements.vcproj:
8015         * win32/gstenumtypes.c:
8016         * win32/gstenumtypes.h:
8017         * win32/gstoptimalscheduler.def:
8018         * win32/gstoptimalscheduler.vcproj:
8019         * win32/gstreamer.def:
8020         * win32/gstspider.def:
8021         * win32/gstspider.vcproj:
8022         * win32/gstversion.h:
8023         * win32/msvc71.sln:
8024
8025 2004-05-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8026
8027         * gst/gstelement.c: (gst_element_class_init),
8028         (gst_element_no_more_pads):
8029         * gst/gstelement.h:
8030           add gst_element_no_more_pads and the "no-more-pads" signal
8031
8032 2004-05-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8033
8034         * gst/gstregistry.c: (gst_registry_add_plugin):
8035           refuse to add plugins when a plugin with same name is already
8036           registered. Fixes a bunch of "How to remove plugins?" issues.
8037           May lead to other problems though, let's test
8038
8039 2004-05-10  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8040
8041         * testsuite/caps/caps_strings : audio/ac3 => audio/x-ac3
8042         * docs/manual/pads-api.xml : audio/wav => audio/x-wav
8043         * docs/random/uraeus/gstreamer_and_midi.txt : audio/wav => audio/x-wav
8044
8045 2004-05-09  Thomas Vander Stichele  <thomas at apestaart dot org>
8046
8047         * tests/Makefile.am: fix am16 issue
8048
8049 2004-05-09  Benjamin Otte  <otte@gnome.org>
8050
8051         * libs/gst/bytestream/Makefile.am:
8052           we should indeed add .c files to makefiles or they won't be built
8053           (d'oh)
8054
8055 2004-05-08  Benjamin Otte  <otte@gnome.org>
8056
8057         * gst/gstpad.c: (gst_pad_proxy_fixate):
8058           really reduce the set of caps
8059
8060 2004-05-08  Benjamin Otte  <otte@gnome.org>
8061
8062         * tests/Makefile.am:
8063         * tests/spidey_bench.c: (handoff), (main):
8064           add benchmark to test how long spider needs to create a pipeline
8065
8066 2004-05-08  Benjamin Otte  <otte@gnome.org>
8067
8068         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_unnegotiate):
8069           mark links as unengaged when unnegotiating instead of deactivating.
8070           This way pads aren't marked as unengaged when going PLAYING=>PAUSED
8071
8072 2004-05-08  Benjamin Otte  <otte@gnome.org>
8073
8074         * docs/manual/helloworld.xml:
8075           s/audiosink/osssink (patch by Patrick Guimond)
8076
8077 2004-05-07  David Schleef  <ds@schleef.org>
8078
8079         * configure.ac: Make sure GST_INT_CFLAGS is not clobbered,
8080         since it contains important stuff.
8081
8082 2004-05-07  David Schleef  <ds@schleef.org>
8083
8084         * testsuite/caps/caps.c: (test3), (main): A check for appending
8085         ANY caps.
8086
8087 2004-05-07  David Schleef  <ds@schleef.org>
8088
8089         * common/m4/as-compiler-flag.m4: Properly quote arguments,
8090         which may contain commas.  Fixes detection of -Wa,-mregnames
8091
8092 2004-05-06  David Schleef  <ds@schleef.org>
8093
8094         Changes to handle compilers that don't have variadic macro
8095         support.  In particular, glib headers define some inlines
8096         that need G_LOG_DOMAIN defined.  Additional fixes for MSVC
8097         builds.
8098         * gst/Makefile.am:
8099         * gst/cothreads.c:
8100         * gst/elements/gstfdsink.c:
8101         * gst/elements/gstfdsrc.c:
8102         * gst/elements/gstfilesink.c:
8103         * gst/elements/gstfilesrc.c:
8104         * gst/gst_private.h:
8105         * gst/gstatomic.c:
8106         * gst/gstcaps.c: (gst_caps_append):
8107         * gst/gstcpu.c: (gst_cpuid_i386):
8108         * gst/gstelement.c:
8109         * gst/gsterror.c:
8110         * gst/gstfilter.c:
8111         * gst/gstinfo.h:
8112         * gst/gstprobe.c:
8113         * gst/gstquery.c:
8114         * gst/gstregistry.c:
8115         * gst/gststructure.c:
8116         * gst/gsttaginterface.c:
8117         * gst/gsttrace.c: (gst_trace_new):
8118         * gst/gsttrashstack.c:
8119         * gst/gsturi.c:
8120         * gst/gstvalue.c:
8121         * gst/parse/grammar.y:
8122         * gst/parse/parse.l:
8123         * tools/gst-inspect.c: (main):
8124         * tools/gst-launch.c: (main):
8125         * tools/gst-xmlinspect.c: (PUT_STRING):
8126
8127 2004-05-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8128
8129         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
8130         (gst_filesrc_change_state), (gst_filesrc_srcpad_event):
8131         * gst/elements/gstfilesrc.h:
8132           send NEW_MEDIA events correctly
8133         * gst/elements/gsttypefindelement.c: (start_typefinding),
8134         (gst_type_find_element_handle_event):
8135           restart typefinding when we get a NEW_MEDIA event
8136         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_change_state),
8137         (gst_bin_dispose):
8138           don't die when someone removes elements in callbacks
8139         * gst/gstelement.c: (gst_element_change_state):
8140           improve debugging
8141         * gst/gstpad.c: (gst_pad_pull), (gst_pad_call_chain_function):
8142           we need a NEW_MEDIA event to engage a link
8143         * gst/gsttrace.c: (gst_trace_new), (gst_alloc_trace_set_flags_all):
8144           don't g_print debugging stuff
8145         * testsuite/caps/simplify.c: (check_caps):
8146
8147 2004-05-04  Benjamin Otte  <otte@gnome.org>
8148
8149         * gst/parse/grammar.y:
8150           use GST_ERROR instead of g_warning, and always throw a GST_ERROR 
8151
8152 2004-05-04  Benjamin Otte  <otte@gnome.org>
8153
8154         * testsuite/caps/renegotiate.c: (main):
8155           improve output in error case
8156
8157 2004-05-04  Benjamin Otte  <otte@gnome.org>
8158
8159         * gst/parse/grammar.y:
8160           fix assert to not trigger when there's no error argument
8161         * gst/parse/parse.l:
8162           fix definition of caps to allow more than two structures
8163         * testsuite/caps/Makefile.am:
8164         * testsuite/caps/renegotiate.c: (main):
8165           it's sinesrc and works in that case
8166
8167 2004-05-04  Wim Taymans  <wim@fluendo.com>
8168
8169         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
8170         (group_dec_link), (gst_opt_scheduler_pad_unlink):
8171         when removing an element from a group, we always need to
8172         decrement the link count that this group had with other 
8173         groups through the element.
8174         added an extra assert to catch inconsistencies when decrementing
8175         the link count.
8176
8177 2004-05-04  Thomas Vander Stichele  <thomas at apestaart dot org>
8178
8179         * configure.ac:
8180         * docs/gst/Makefile.am:
8181         * docs/gst/gstreamer-sections.txt:
8182         * docs/gst/tmpl/gstcompat.sgml:
8183         * examples/appreader/Makefile.am:
8184         * examples/cutter/Makefile.am:
8185         * examples/events/Makefile.am:
8186         * examples/helloworld/Makefile.am:
8187         * examples/helloworld2/Makefile.am:
8188         * examples/launch/Makefile.am:
8189         * examples/manual/Makefile.am:
8190         * examples/mixer/Makefile.am:
8191         * examples/pingpong/Makefile.am:
8192         * examples/plugins/Makefile.am:
8193         * examples/queue/Makefile.am:
8194         * examples/queue2/Makefile.am:
8195         * examples/queue3/Makefile.am:
8196         * examples/queue4/Makefile.am:
8197         * examples/retag/Makefile.am:
8198         * examples/thread/Makefile.am:
8199         * examples/typefind/Makefile.am:
8200         * examples/xml/Makefile.am:
8201         * gst/Makefile.am:
8202         * gst/autoplug/Makefile.am:
8203         * gst/elements/Makefile.am:
8204         * gst/gstcompat.h:
8205         * gst/indexers/Makefile.am:
8206         * gst/parse/Makefile.am:
8207         * gst/registries/Makefile.am:
8208         * gst/schedulers/Makefile.am:
8209         * libs/gst/bytestream/Makefile.am:
8210         * libs/gst/control/Makefile.am:
8211         * libs/gst/getbits/Makefile.am:
8212         * po/af.po:
8213         * po/az.po:
8214         * po/en_GB.po:
8215         * po/fr.po:
8216         * po/nl.po:
8217         * po/sr.po:
8218         * po/sv.po:
8219         * po/tr.po:
8220         * po/uk.po:
8221         * tests/Makefile.am:
8222         * tests/bufspeed/Makefile.am:
8223         * tests/instantiate/Makefile.am:
8224         * tests/memchunk/Makefile.am:
8225         * tests/muxing/Makefile.am:
8226         * tests/negotiation/Makefile.am:
8227         * tests/probes/Makefile.am:
8228         * tests/sched/Makefile.am:
8229         * tests/seeking/Makefile.am:
8230         * tests/threadstate/Makefile.am:
8231         * testsuite/caps/Makefile.am:
8232         * testsuite/cleanup/Makefile.am:
8233         * testsuite/dlopen/Makefile.am:
8234         * testsuite/dynparams/Makefile.am:
8235         * testsuite/plugin/Makefile.am:
8236         * testsuite/states/Makefile.am:
8237         * tools/Makefile.am:
8238           reorganize compile/link flags to be consistent
8239           put gst_info in gstcompat.h and actually use GST_DISABLE_DEPRECATED
8240
8241 2004-05-04  David Schleef  <ds@schleef.org>
8242
8243         The "once more, with feeling" check-in.
8244         * testsuite/caps/Makefile.am: dist caps_strings
8245         * testsuite/caps/renegotiate.c: (main): This test triggers a
8246           segfault in the core.  Marking as failing.
8247
8248 2004-05-03  David Schleef  <ds@schleef.org>
8249
8250         * testsuite/caps/deserialize.c: (main): Fix problems noticed
8251           by the build bots.
8252         * testsuite/caps/renegotiate.c: (main): Same.
8253
8254 2004-05-03  David Schleef  <ds@schleef.org>
8255
8256         * testsuite/caps/renegotiate.c: (my_fixate), (main): Another test.
8257
8258 2004-05-03  David Schleef  <ds@schleef.org>
8259
8260         * testsuite/caps/deserialize.c: (main): Use the srcdir environment
8261           variable to find our source file.
8262
8263 2004-05-03  David Schleef  <ds@schleef.org>
8264
8265         * configure.ac:  Link plugins with libgstreamer and dependent
8266           libraries
8267         * testsuite/caps/Makefile.am:
8268         * testsuite/caps/caps_strings:
8269         * testsuite/caps/deserialize.c: (main): Add a little test to slog
8270           through a file of caps strings and test each one
8271
8272 2004-05-04  Benjamin Otte  <otte@gnome.org>
8273
8274         * libs/gst/bytestream/Makefile.am:
8275         * libs/gst/bytestream/adapter.c: 
8276         * libs/gst/bytestream/adapter.h:
8277           add GstAdapter, similar to bytestream, but doesn't require ugly event
8278           handling or uglier loopbased elements
8279
8280 2004-05-03  David Schleef  <ds@schleef.org>
8281
8282         * testsuite/caps/Makefile.am: Fix spelling of Ηρατοσθενες
8283         * testsuite/caps/erathostenes.c:
8284         * testsuite/caps/eratosthenes.c: (eratosthenes), (main):
8285
8286 2004-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
8287
8288         * docs/pwg/pwg.xml:
8289           remove hardcoded stylesheet path (duh)
8290         * docs/random/release:
8291         * docs/gst/gstreamer-sections.txt:
8292         * gst/Makefile.am:
8293         * gst/gst.h:
8294         * gst/gst_private.h:
8295         * gst/gstcaps.c:
8296         * gst/gstevent.c:
8297         * gst/gstformat.c:
8298         * gst/gstinfo.c:
8299         * gst/gstinfo.h:
8300         * gst/gstinterface.c:
8301         * gst/gstmemchunk.c:
8302         * gst/gstprobe.c:
8303         * gst/gstquery.c:
8304         * gst/gstregistry.c:
8305         * gst/gstregistrypool.c:
8306         * gst/gststructure.c:
8307         * gst/gsttaginterface.c:
8308         * gst/gstthread.c:
8309         * gst/gsttrace.c:
8310         * gst/gsttypefind.c: (gst_type_find_factory_get_type):
8311         * gst/gsturi.c:
8312         * gst/gstvalue.c:
8313           deprecate gst_info; remove gstlog.h
8314    
8315
8316 2004-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
8317
8318         * Makefile.am:
8319         * po/en_GB.po:
8320         * po/sv.po:
8321         * po/uk.po:
8322           updated translations
8323
8324 2004-05-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8325
8326         * gst/gstbin.c: (gst_bin_dispose):
8327           better debugging
8328
8329 2004-05-03  Johan Dahlin  <johan@gnome.org>
8330
8331         * gst/schedulers/gstoptimalscheduler.c
8332         (gst_opt_scheduler_pad_unlink): Check if element is non-NULL and
8333         really is a GstElement. Avoids critical when running gst-launch -v
8334         and a oggdemux/decoding pipeline.
8335
8336 2004-05-02  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8337
8338         * docs/gst/tmpl/gstpipeline.sgml :
8339         * docs/manual/elements-api.xml :
8340                 doc fix by Patrick Guimond (Protector) from devel ML
8341                 reviewed by ronald
8342
8343 2004-05-02  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8344
8345         * docs/gst/Makefile.am :
8346         * docs/libs/Makefile.am :
8347                 apply a patch from Arwed v. Merkatz so that gtk-doc
8348                 generated docs install (same for .devhelp file)
8349                 (fixes part 1 of #138836)
8350
8351 2004-04-30  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8352
8353         * docs/faq/dependencies.xml: typo
8354         * docs/faq/getting.xml :
8355             - fix download URL for new gstreamer site
8356             - hide sf.net download page as latest version aren't there
8357             - fix apt URLs
8358             - fill "get via CVS" paragraph (link to dev page on the site)
8359         * docs/faq/general.xml:
8360             hide status tables as they no more exists
8361             change case on plugins license file to reflect reality
8362         * docs/faq/troubleshooting.xml:
8363             remove the wiki question/answer as there is no more wiki
8364
8365 2004-04-30  Thomas Vander Stichele  <thomas at apestaart dot org>
8366
8367         * gst/gsterror.h:
8368           include the headers needed for declarations used in this header
8369
8370 2004-04-30  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8371
8372         * docs/random/uraeus/gstreamer_and_midi.txt :
8373           add .kar (midi + karaoke/lyrics 'track') doc to midi doc.
8374           (fixes #132288)
8375
8376 2004-04-30  Sebastien Cote  <sc5@hermes.usherb.ca>
8377
8378         reviewed by Benjamin Otte  <otte@gnome.org>
8379
8380         * gst/schedulers/gthread-cothreads.h:
8381           free allocated data for main cothread, too when destroying context
8382           (fixes #141417)
8383
8384 2004-04-29  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
8385
8386         * docs/manual/goals.xml : remove duplicated paragraph at end 
8387         of doc page (fixes #141448)
8388
8389 2004-04-29  David Schleef  <ds@schleef.org>
8390
8391         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
8392         Patch from Sebastien Cote to fix leakage of events. (bug #141414)
8393
8394 2004-04-29  Thomas Vander Stichele  <thomas at apestaart dot org>
8395
8396         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
8397           fix property
8398         * gst/gstcaps.c:
8399           fix doc string
8400         * po/POTFILES.in:
8401           rename typefind source file
8402
8403 2004-04-28  David Schleef  <ds@schleef.org>
8404
8405         Several new files from Steve Lhomme's MSVC patch (bug #141317):
8406         * win32/GStreamer.vcproj:
8407         * win32/Makefile:
8408         * win32/config.h:
8409         * win32/dirent.c: (_topendir), (_treaddir), (_tclosedir),
8410         (_trewinddir), (_ttelldir), (_tseekdir):
8411         * win32/dirent.h:
8412         * win32/gst-inspect.vcproj:
8413         * win32/gst-launch.vcproj:
8414         * win32/gst-register.vcproj:
8415         * win32/gstbytestream.vcproj:
8416         * win32/gstelements.vcproj:
8417         * win32/gstoptimalscheduler.vcproj:
8418         * win32/gstspider.vcproj:
8419         * win32/gtchar.h:
8420         * win32/mman.c: (mmap), (mprotect), (msync), (munmap):
8421         * win32/mman.h:
8422         * win32/mman.inl:
8423         * win32/msvc71.sln:
8424
8425 2004-04-29  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8426
8427         * gst/gst.c: (init_post):
8428         * gst/gstinfo.c:
8429           remove useless _gst_progname stuff
8430         * tools/gst-inspect.c: (print_field), (print_caps):
8431           improve caps output
8432
8433 2004-04-28  David Schleef  <ds@schleef.org>
8434
8435         Disable parsing of a lot of files that aren't part of the
8436         exported API.  Move corresponding template files to old/,
8437         waiting for removal when they don't contain anything
8438         interesting.
8439         * docs/gst/Makefile.am:
8440         * docs/gst/gstreamer-sections.txt:
8441         * docs/gst/tmpl/cothreads.sgml:
8442         * docs/gst/tmpl/cothreads_compat.sgml:
8443         * docs/gst/tmpl/gettext.sgml:
8444         * docs/gst/tmpl/gobject2gtk.sgml:
8445         * docs/gst/tmpl/grammar.tab.sgml:
8446         * docs/gst/tmpl/gst-i18n-app.sgml:
8447         * docs/gst/tmpl/gst-i18n-lib.sgml:
8448         * docs/gst/tmpl/gst_private.sgml:
8449         * docs/gst/tmpl/gstaggregator.sgml:
8450         * docs/gst/tmpl/gstarch.sgml:
8451         * docs/gst/tmpl/gstatomic_impl.sgml:
8452         * docs/gst/tmpl/gstbufferstore.sgml:
8453         * docs/gst/tmpl/gstdata_private.sgml:
8454         * docs/gst/tmpl/gstdisksink.sgml:
8455         * docs/gst/tmpl/gstdisksrc.sgml:
8456         * docs/gst/tmpl/gstelementfactory.sgml:
8457         * docs/gst/tmpl/gstextratypes.sgml:
8458         * docs/gst/tmpl/gstfakesink.sgml:
8459         * docs/gst/tmpl/gstfakesrc.sgml:
8460         * docs/gst/tmpl/gstfdsink.sgml:
8461         * docs/gst/tmpl/gstfdsrc.sgml:
8462         * docs/gst/tmpl/gstfilesink.sgml:
8463         * docs/gst/tmpl/gstfilesrc.sgml:
8464         * docs/gst/tmpl/gsthttpsrc.sgml:
8465         * docs/gst/tmpl/gstidentity.sgml:
8466         * docs/gst/tmpl/gstindexfactory.sgml:
8467         * docs/gst/tmpl/gstmarshal.sgml:
8468         * docs/gst/tmpl/gstmd5sink.sgml:
8469         * docs/gst/tmpl/gstmultidisksrc.sgml:
8470         * docs/gst/tmpl/gstmultifilesrc.sgml:
8471         * docs/gst/tmpl/gstpadtemplate.sgml:
8472         * docs/gst/tmpl/gstpipefilter.sgml:
8473         * docs/gst/tmpl/gstschedulerfactory.sgml:
8474         * docs/gst/tmpl/gstsearchfuncs.sgml:
8475         * docs/gst/tmpl/gstshaper.sgml:
8476         * docs/gst/tmpl/gstspider.sgml:
8477         * docs/gst/tmpl/gstspideridentity.sgml:
8478         * docs/gst/tmpl/gststatistics.sgml:
8479         * docs/gst/tmpl/gsttee.sgml:
8480         * docs/gst/tmpl/gsttimecache.sgml:
8481         * docs/gst/tmpl/gsttypefind.sgml:
8482         * docs/gst/tmpl/gsttypefindfactory.sgml:
8483         * docs/gst/tmpl/gstxmlregistry.sgml:
8484         * docs/gst/tmpl/gthread-cothreads.sgml:
8485         * docs/gst/tmpl/old/cothreads.sgml:
8486         * docs/gst/tmpl/old/cothreads_compat.sgml:
8487         * docs/gst/tmpl/old/gettext.sgml:
8488         * docs/gst/tmpl/old/gobject2gtk.sgml:
8489         * docs/gst/tmpl/old/grammar.tab.sgml:
8490         * docs/gst/tmpl/old/gst-i18n-app.sgml:
8491         * docs/gst/tmpl/old/gst-i18n-lib.sgml:
8492         * docs/gst/tmpl/old/gst_private.sgml:
8493         * docs/gst/tmpl/old/gstaggregator.sgml:
8494         * docs/gst/tmpl/old/gstarch.sgml:
8495         * docs/gst/tmpl/old/gstatomic_impl.sgml:
8496         * docs/gst/tmpl/old/gstbufferstore.sgml:
8497         * docs/gst/tmpl/old/gstdata_private.sgml:
8498         * docs/gst/tmpl/old/gstdisksink.sgml:
8499         * docs/gst/tmpl/old/gstdisksrc.sgml:
8500         * docs/gst/tmpl/old/gstelementfactory.sgml:
8501         * docs/gst/tmpl/old/gstextratypes.sgml:
8502         * docs/gst/tmpl/old/gstfakesink.sgml:
8503         * docs/gst/tmpl/old/gstfakesrc.sgml:
8504         * docs/gst/tmpl/old/gstfdsink.sgml:
8505         * docs/gst/tmpl/old/gstfdsrc.sgml:
8506         * docs/gst/tmpl/old/gstfilesink.sgml:
8507         * docs/gst/tmpl/old/gstfilesrc.sgml:
8508         * docs/gst/tmpl/old/gsthttpsrc.sgml:
8509         * docs/gst/tmpl/old/gstidentity.sgml:
8510         * docs/gst/tmpl/old/gstindexfactory.sgml:
8511         * docs/gst/tmpl/old/gstmarshal.sgml:
8512         * docs/gst/tmpl/old/gstmd5sink.sgml:
8513         * docs/gst/tmpl/old/gstmultidisksrc.sgml:
8514         * docs/gst/tmpl/old/gstmultifilesrc.sgml:
8515         * docs/gst/tmpl/old/gstpadtemplate.sgml:
8516         * docs/gst/tmpl/old/gstpipefilter.sgml:
8517         * docs/gst/tmpl/old/gstschedulerfactory.sgml:
8518         * docs/gst/tmpl/old/gstsearchfuncs.sgml:
8519         * docs/gst/tmpl/old/gstshaper.sgml:
8520         * docs/gst/tmpl/old/gstspider.sgml:
8521         * docs/gst/tmpl/old/gstspideridentity.sgml:
8522         * docs/gst/tmpl/old/gststatistics.sgml:
8523         * docs/gst/tmpl/old/gsttee.sgml:
8524         * docs/gst/tmpl/old/gsttimecache.sgml:
8525         * docs/gst/tmpl/old/gsttypefindfactory.sgml:
8526         * docs/gst/tmpl/old/gstxmlregistry.sgml:
8527         * docs/gst/tmpl/old/gthread-cothreads.sgml:
8528         * docs/gst/tmpl/old/types.sgml:
8529         * docs/gst/tmpl/types.sgml:
8530
8531         Rename gsttypefind.[ch] back to gsttypefindelement.[ch], since
8532         gtkdoc-scan doesn't like files with the same name in different
8533         directories.
8534         * gst/elements/Makefile.am:
8535         * gst/elements/gstelements.c:
8536         * gst/elements/gsttypefind.c: 
8537         * gst/elements/gsttypefind.h:
8538         * gst/elements/gsttypefindelement.c:
8539         * gst/elements/gsttypefindelement.h:
8540
8541 2004-04-28  David Schleef  <ds@schleef.org>
8542
8543         A bunch of portability fixes, derived from Steve Lhomme's MSVC
8544         patch (bug #141317):
8545         * gst/gst-i18n-lib.h: Allow disabling gettext.
8546         * gst/gstatomic_impl.h: disable warning when it's dumb.
8547         * gst/gstclock.c: fix include
8548         * gst/gstcompat.h: fix variadic macro
8549         * gst/gstinfo.c: fix include
8550         * gst/gstmacros.h: add defines for inlines on MSVC
8551         * gst/gstplugin.c: fix includes
8552         * gst/gstregistry.c: fix includes
8553         * gst/gstregistry.h: use S_IREAD, etc., if S_IRUSR isn't defined
8554         * gst/gstsystemclock.c: fix include
8555         * gst/gsttrace.c: (gst_trace_new), (gst_trace_text_flush): use
8556         S_IREAD if S_IRUSR isn't defined.  fix use of non-portable functions
8557         * gst/registries/gstxmlregistry.c:
8558         (gst_xml_registry_parse_element_factory): fix use of non-portable
8559         functions
8560         * libs/gst/control/dparam.h: Remove trailing comma in enum definition
8561         * libs/gst/control/dparammanager.h: same
8562
8563 2004-04-28  David Schleef  <ds@schleef.org>
8564
8565         Move a bunch of unused files to old/ with names that are
8566         not case-insensitive-unique.  These files still contain some
8567         useful information that needs to be merged into gstbin.sgml,
8568         etc., so they shouldn't be deleted yet.
8569         * docs/gst/tmpl/GstBin.sgml:
8570         * docs/gst/tmpl/GstBuffer.sgml:
8571         * docs/gst/tmpl/GstCaps.sgml:
8572         * docs/gst/tmpl/GstClock.sgml:
8573         * docs/gst/tmpl/GstCompat.sgml:
8574         * docs/gst/tmpl/GstData.sgml:
8575         * docs/gst/tmpl/GstElement.sgml:
8576         * docs/gst/tmpl/GstEvent.sgml:
8577         * docs/gst/tmpl/GstIndex.sgml:
8578         * docs/gst/tmpl/GstStructure.sgml:
8579         * docs/gst/tmpl/GstTag.sgml:
8580         * docs/gst/tmpl/old/GstBin.sgml:
8581         * docs/gst/tmpl/old/GstBuffer.sgml:
8582         * docs/gst/tmpl/old/GstCaps.sgml:
8583         * docs/gst/tmpl/old/GstClock.sgml:
8584         * docs/gst/tmpl/old/GstCompat.sgml:
8585         * docs/gst/tmpl/old/GstData.sgml:
8586         * docs/gst/tmpl/old/GstElement.sgml:
8587         * docs/gst/tmpl/old/GstEvent.sgml:
8588         * docs/gst/tmpl/old/GstIndex.sgml:
8589         * docs/gst/tmpl/old/GstStructure.sgml:
8590         * docs/gst/tmpl/old/GstTag.sgml:
8591
8592 2004-04-28  David Schleef  <ds@schleef.org>
8593
8594         * gst/gstcaps.c: (gst_caps_copy), (gst_caps_free),
8595         (gst_caps_append), (gst_caps_append_structure),
8596         (gst_caps_get_size), (gst_caps_get_structure), (gst_caps_copy_1),
8597         (gst_caps_set_simple), (gst_caps_set_simple_valist),
8598         (gst_caps_is_any), (gst_caps_is_empty), (gst_caps_is_chained),
8599         (gst_caps_is_fixed), (gst_caps_is_always_compatible),
8600         (gst_caps_intersect), (gst_caps_normalize),
8601         (gst_caps_transform_to_string):  Patch from Tim-Philipp Müller
8602         to fix GST_CAPS() and GST_IS_CAPS(). (bug #141304)
8603         * gst/gstcaps.h: use GST_IS_CAPS().
8604
8605 2004-04-26  David Schleef  <ds@schleef.org>
8606
8607         * gst/gstcpu.c: (gst_cpuid_i386): Don't clobber ebx in inline
8608         assembly.  gcc doesn't handle it correctly. (bug #141083)
8609         * gst/gsttrashstack.h: same
8610
8611 2004-04-25  Benjamin Otte  <otte@gnome.org>
8612
8613         * gst/gstelement.c: (gst_element_change_state):
8614           fix assertion to do an int comparison
8615
8616 2004-04-25  Benjamin Otte  <otte@gnome.org>
8617
8618         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
8619           better debugging output on error
8620
8621 2004-04-25  Benjamin Otte  <otte@gnome.org>
8622
8623         * gst/gstcaps.c: (gst_caps_subtract):
8624           fix memleak
8625
8626 2004-04-23  Benjamin Otte  <otte@gnome.org>
8627
8628         * gst/gstvalue.c: (gst_value_compare_buffer),
8629         (_gst_value_initialize):
8630           add comparison function for buffers
8631
8632 2004-04-22  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8633
8634         * docs/pwg/pwg.xml:
8635           Just found out that this so-called "ima-wav" format is really
8636           just "dvi adpcm" (according to the MS WAV documentation). So
8637           renaming it. We didn't use it yet anyway.
8638
8639 2004-04-23  Benjamin Otte  <otte@gnome.org>
8640
8641         * gst/gstcaps.c: (gst_caps_is_always_compatible):
8642           call gst_caps_is_subset
8643
8644 2004-04-23  Benjamin Otte  <otte@gnome.org>
8645
8646         * gst/gstcaps.c: (gst_caps_subtract), (gst_caps_is_equal), 
8647         (gst_caps_is_subset):
8648           add documentation
8649
8650 2004-04-23  Benjamin Otte  <otte@gnome.org>
8651           
8652         * gst/gstcaps.c: (gst_caps_structure_subtract_field),
8653         (gst_caps_structure_subtract), (gst_caps_subtract),
8654         (gst_caps_structure_figure_out_union),
8655         (gst_caps_structure_simplify), (gst_caps_do_simplify):
8656           fix simplifying and subtracting not working correctly with optional
8657           properties
8658           solve assorted problems that make it now simplify ebven more
8659         * docs/gst/tmpl/gstcaps.sgml:
8660         * gst/gstcaps.h:
8661           make gst_caps_do_simplify return a bool to indicate if it simplified
8662         * testsuite/caps/simplify.c: (main):
8663           add more checks. The tests is quite a bit useless right now because
8664           the core is heavily simplifying itself.
8665         * testsuite/caps/caps.h:
8666           fix caps to contain all optional properties
8667
8668 2004-04-22  Benjamin Otte  <otte@gnome.org>
8669
8670         * docs/gst/tmpl/gstcaps.sgml:
8671         * docs/gst/tmpl/gstfilesrc.sgml:
8672         * docs/gst/tmpl/gststructure.sgml:
8673         * docs/gst/tmpl/gstvalue.sgml:
8674           update for recent API changes
8675         * gst/gstcaps.c: (gst_caps_do_simplify):
8676           fix to stop trying with a freed structure
8677         * gst/gstpad.c: (gst_pad_link_fixate):
8678           simplify caps
8679         * gst/gstpad.c: (gst_pad_template_get_caps_by_name):
8680           remove C++ comment
8681         * gst/gstpad.h:
8682           deprecate gst_pad_template_get_caps_by_name, it doesn't work anyway
8683         * gst/gststructure.c: (gst_structure_value_get_generic_type),
8684         (gst_structure_to_string):
8685           keep the correct type when using lists of ranges
8686         * gst/gstvalue.c: (gst_value_list_prepend_value),
8687         (gst_value_list_append_value):
8688           copy the value before adding to the list (d'oh)
8689         * gst/gstvalue.c: (gst_value_subtract_int_range_int),
8690         (gst_value_subtract_int_range_int_range):
8691           handle overflows correctly
8692         * gst/gstvalue.c: (gst_value_subtract_from_list):
8693           fix memleak
8694         * testsuite/caps/caps.h:
8695           add a caps that caused segfaults
8696
8697 2004-04-22  Benjamin Otte  <otte@gnome.org>
8698
8699         * testsuite/refcounting/pad.c: (main):
8700           fix test
8701
8702 2004-04-22  Benjamin Otte  <otte@gnome.org>
8703
8704         * gst/gstcaps.c: (gst_caps_subtract):
8705           allow subtracting ANY and EMPTY from ANY caps
8706
8707 2004-04-22  Benjamin Otte  <otte@gnome.org>
8708
8709         * gst/gstcaps.c: (gst_caps_append), (gst_caps_intersect),
8710         (gst_caps_union):
8711           only simplify in functions that create new caps. Simplifying in
8712           gst_caps_append breaks tests.
8713
8714 2004-04-22  Benjamin Otte  <otte@gnome.org>
8715
8716         * gst/gstcaps.c: (gst_caps_structure_simplify):
8717           unset GValue after use
8718         * gst/gstcaps.c: (gst_caps_append), 
8719         * gst/gstpad.c: (gst_pad_link_fixate), (gst_pad_template_new):
8720           use gst_caps_simplify (reduces registry size by 30%)
8721         * gst/gstpad.c: (gst_pad_template_new):
8722           don't allow NULL caps
8723
8724 2004-04-22  Benjamin Otte  <otte@gnome.org>
8725
8726         * docs/gst/gstreamer-sections.txt:
8727           add gst_caps_do_simplify
8728         * gst/gstcaps.c:
8729           add documentation for gst_caps_do_simplify
8730         * gst/gstvalue.h:
8731           fix typo in gst_value_register_subtract_func declaration for gst-doc
8732
8733 2004-04-22  Benjamin Otte  <otte@gnome.org>
8734
8735         * gst/gstcaps.c: (gst_caps_from_string_inplace):
8736           fix bug when converting from empty string.
8737         * gst/gstcaps.c: (gst_caps_new_any), (gst_caps_new_simple),
8738         (gst_caps_new_full_valist), (gst_caps_copy), (gst_caps_copy_1):
8739           use gst_caps_new_empty to allocate a new caps. Only that function
8740           allocates memory for caps now.
8741         * gst/gstcaps.c: (gst_caps_remove_and_get_structure),
8742         (gst_caps_remove_structure):
8743           add ability to remove one structure (but not to header yet)
8744         * gst/gstcaps.c: (gst_caps_compare_structures),
8745         (gst_caps_simplify), (gst_caps_structure_figure_out_union),
8746         (gst_caps_structure_simplify), (gst_caps_do_simplify),
8747         * gst/gstcaps.h:
8748           add gst_caps_do_simplify that tries to simplify a caps in place.
8749           Deprecate old gst_caps_simplify function.
8750         * testsuite/caps/caps.h:
8751           add caps.h containing a common set of caps to test against.
8752         * testsuite/caps/sets.c: (check_caps), (main):
8753           use it.
8754         * testsuite/caps/.cvsignore:
8755         * testsuite/caps/Makefile.am:
8756         * testsuite/caps/simplify.c: (check_caps), (main):
8757           add test to check correctness and efficency of caps simplification.
8758
8759 2004-04-22  Sebastien Cote <sc5@hermes.usherb.ca>
8760
8761         reviewed by Benjamin Otte  <otte@gnome.org>
8762
8763         * gst/gstparse.c: (_gst_parse_escape):
8764           Free the GString used in _gst_parse_escape()
8765
8766 2004-04-21  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8767
8768         * gst/gstpad.c: (gst_pad_link_negotiate):
8769           refuse to link if the link is not possible
8770         * configure.ac:
8771         * testsuite/Makefile.am:
8772         * testsuite/negotiation/.cvsignore:
8773         * testsuite/negotiation/Makefile.am:
8774         * testsuite/negotiation/pad_link.c: (main):
8775           add test that checks the above behaviour
8776
8777 2004-04-21  Thomas Vander Stichele  <thomas at apestaart dot org>
8778
8779         * docs/gst/gstreamer-sections.txt:
8780           add newly added API
8781
8782 2004-04-21  Thomas Vander Stichele  <thomas at apestaart dot org>
8783
8784         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
8785         (gst_filesrc_get_mmap), (gst_filesrc_get_read), (gst_filesrc_get),
8786         (gst_filesrc_open_file), (gst_filesrc_close_file),
8787         (gst_filesrc_srcpad_query), (gst_filesrc_srcpad_event):
8788         * gst/elements/gstfilesrc.h:
8789           add support for non-regular files (#140734)
8790
8791 2004-04-21  Benjamin Otte  <otte@gnome.org>
8792
8793         * gst/gstpad.c: (gst_pad_link_fixate):
8794           add sophisticated error checking code to see if fixation functions
8795           did their fixation right
8796
8797 2004-04-21  Benjamin Otte  <otte@gnome.org>
8798
8799         * gst/gstcaps.c: (gst_caps_append), (gst_caps_union):
8800           check for ANY caps before appending/unioning
8801         * gst/gstcaps.c: (gst_caps_is_subset),
8802         (gst_caps_is_equal), (gst_caps_structure_subtract_field),
8803         (gst_caps_structure_subtract), (gst_caps_subtract):
8804         * gst/gstcaps.h:
8805           add gst_caps_is_equal, gst_caps_is_subset and gst_caps_subtract to
8806           the API. deprecate gst_caps_is_equal_fixed
8807         * gst/gstpad.c: (gst_pad_try_set_caps):
8808         * gst/gstqueue.c: (gst_queue_link):
8809           s/gst_caps_is_equal_fixed/gst_caps_is_equal/
8810         * gst/gststructure.c: (gst_structure_get_name_id):
8811         * gst/gststructure.h:
8812           add function gst_structure_get_name_id
8813         * gst/gstvalue.c: (gst_value_subtract_int_int_range),
8814         (gst_value_create_new_range), (gst_value_subtract_int_range_int),
8815         (gst_value_subtract_int_range_int_range),
8816         (gst_value_subtract_double_double_range),
8817         (gst_value_subtract_double_range_double),
8818         (gst_value_subtract_double_range_double_range),
8819         (gst_value_subtract_from_list), (gst_value_subtract_list),
8820         (gst_value_can_intersect), (gst_value_subtract),
8821         (gst_value_can_subtract), (gst_value_register_subtract_func),
8822         (_gst_value_initialize):
8823         * gst/gstvalue.h:
8824           add support for subtracting values from each other. Note that
8825           subtracting means subtracting as in set theory. Required for caps
8826           stuff above.
8827         * testsuite/caps/.cvsignore:
8828         * testsuite/caps/Makefile.am:
8829         * testsuite/caps/erathostenes.c: (erathostenes), (main):
8830         * testsuite/caps/sets.c: (check_caps), (main):
8831         * testsuite/caps/subtract.c: (check_caps), (main):
8832           add tests for subtraction and equality code.
8833
8834 2004-04-20  David Schleef  <ds@schleef.org>
8835
8836         * gst/autoplug/Makefile.am:  Fix some little buglets in last checkin.
8837         * gst/indexers/Makefile.am:
8838         * gst/schedulers/Makefile.am:
8839         * libs/gst/bytestream/Makefile.am:
8840         * libs/gst/control/Makefile.am:
8841         * libs/gst/getbits/Makefile.am:
8842
8843 2004-04-20  David Schleef  <ds@schleef.org>
8844
8845         * common/as-libtool.mak: Fine-tune DLL building.
8846         * configure.ac: Link plugins against libgstreamer.  Define plugindir
8847         (like gst-plugins)
8848         * examples/plugins/Makefile.am: remove plugindir
8849         * gst/autoplug/Makefile.am: DLL building fixes
8850         * gst/elements/Makefile.am: DLL building fixes.  Disable pipefilter on
8851         Windows.
8852         * gst/elements/gstelements.c: Conditionally disable pipefilter.
8853         * gst/indexers/Makefile.am: DLL building fixes
8854         * gst/schedulers/Makefile.am: DLL building fixes.
8855         * libs/gst/bytestream/Makefile.am: DLL building fixes.
8856         * libs/gst/control/Makefile.am: same
8857         * libs/gst/getbits/Makefile.am: same
8858         * testsuite/Makefile.am: New dlopen directory
8859         * testsuite/dlopen/Makefile.am: Tests to check if libgstreamer works
8860         when dlopened.
8861         * testsuite/dlopen/dlopen_gst.c: (main): same
8862         * testsuite/dlopen/loadgst.c: (do_test): same
8863
8864 2004-04-20  David Schleef  <ds@schleef.org>
8865
8866         * gst/parse/grammar.y:  Apply patch from Sebastien Cote
8867         <sc5@hermes.usherb.ca> to fix a memleak. (bug #140594)
8868
8869 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
8870
8871         * gst/gstelement.c: (gst_element_wait),
8872         (gst_element_set_time_delay), (gst_element_change_state):
8873           Use GST_TIME_*
8874
8875 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8876
8877         * gst/autoplug/gstspider.c: (gst_spider_link_sometimes),
8878         (gst_spider_identity_plug):
8879           improve debugging messages
8880         * gst/gstbin.c: (gst_bin_remove_func):
8881           make sure the state_change function is only called with simple state
8882           transitions
8883
8884 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
8885
8886         * gst/elements/gstfakesink.c: (gst_fakesink_state_error_get_type),
8887         (gst_fakesink_set_property), (gst_fakesink_chain):
8888         * gst/elements/gstfakesrc.c: (gst_fakesrc_set_property):
8889         * gst/elements/gstfdsrc.c: (gst_fdsrc_set_property):
8890         * gst/elements/gstfilesrc.c: (gst_filesrc_set_property):
8891         * gst/elements/gstidentity.c: (gst_identity_chain),
8892         (gst_identity_set_property):
8893         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_set_property):
8894         * gst/elements/gstpipefilter.c: (gst_pipefilter_set_property):
8895           add warnings to _set_property for unknown arguments
8896           use GST_TIME_FORMAT/GST_TIME_ARGS for timestamp printing
8897
8898 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
8899
8900         * Makefile.am:
8901         * docs/manuals.mak:
8902           add .po file download snippet
8903           fix a bug in the doc makefile
8904
8905 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
8906
8907         * Makefile.am:
8908         * po/LINGUAS:
8909         * po/en_GB.po:
8910           Added en_GB translation (Gareth Owen)
8911
8912 2004-04-20  Johan Dahlin  <johan@gnome.org>
8913
8914         * gst/gstpad.c (_invent_event): Clean up
8915
8916 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8917
8918         * testsuite/caps/filtercaps.c: (main):
8919           fix test to test things correctly (caps are complicated)
8920
8921 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8922
8923         * testsuite/caps/Makefile.am:
8924         * testsuite/caps/filtercaps.c: (main):
8925           add test (that doesn't work right now, but should)
8926
8927 2004-04-19  David Schleef  <ds@schleef.org>
8928
8929         * configure.ac: Add test for allowing unaligned access.  Add define
8930         to put in gstconfig.h.
8931         * docs/gst/gstreamer-sections.txt: New symbols
8932         * docs/gst/tmpl/gstcompat.sgml: Check in changes made by gtkdoc
8933         * docs/gst/tmpl/gstfilesrc.sgml:
8934         * docs/gst/tmpl/gstparse.sgml:
8935         * docs/gst/tmpl/gsttypes.sgml:
8936         * docs/gst/tmpl/gstutils.sgml:
8937         * docs/gst/tmpl/gstvalue.sgml:
8938         * gst/gstconfig.h.in: Add GST_HAVE_UNALIGNED_ACCESS
8939         * gst/gstutils.h: Add macros for unaligned memory access.  Useful
8940         on most !i386/!powerpc architectures.  From Daniel Gazard
8941         <daniel.gazard@free.fr>.  (bug #140156)
8942         * po/af.po: Check in changes made by gettext.
8943         * po/az.po:
8944         * po/fr.po:
8945         * po/nl.po:
8946         * po/sr.po:
8947         * po/sv.po:
8948
8949 2004-04-20  Benjamin Otte  <otte@gnome.org>
8950
8951         * gst/schedulers/entryscheduler.c: 
8952         (gst_entry_scheduler_yield):
8953           refuse to yield when decoupled elements insist on doing that.
8954           At least it's better than crashing
8955
8956 2004-04-19  David Schleef  <ds@schleef.org>
8957
8958         * docs/libs/Makefile.am: Change sinclude to include
8959         * docs/gst/Makefile.am: same
8960         * pkgconfig/Makefile.am:  Remove GNU-ism from makefile target
8961
8962 2004-04-19  Thomas Vander Stichele  <thomas at apestaart dot org>
8963
8964         * po/LINGUAS:
8965         * po/uk.po:
8966           Added Ukrainian translation (Maxim V. Dziumanenko)
8967
8968 2004-04-19  Johan Dahlin  <johan@gnome.org>
8969
8970         * gst/parse/grammar.y (__gst_parse_chain_free): Don't do null
8971         checking here, do it before calling the function.
8972         Clean up, use for loops instead of while loops while iterating
8973         over lists.
8974
8975         * gst/autoplug/gstspider.c (gst_spider_request_new_pad): Fix typo
8976         in debug message.
8977         (gst_spider_create_and_plug): Improve debug message.
8978         General: Replace while loops which iterates over GLists with for
8979         loops. Which are much cleaner, improves readability, especially
8980         for gst_spider_identity_plug
8981
8982         * gst/gstpad.c (_invent_event): Fix parameters to warning macros,
8983         fixes bug 140477
8984
8985 2004-04-18  Thomas Vander Stichele  <thomas at apestaart dot org>
8986
8987         * po/LINGUAS:
8988         * po/tr.po:
8989           Added Turkish translation (Baris Cicek)
8990
8991 2004-04-18  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8992
8993         * docs/faq/troubleshooting.xml:
8994           Mention gst-register in the FAQ (fixes 139045).
8995
8996 2004-04-17  Thomas Vander Stichele  <thomas at apestaart dot org>
8997
8998         * docs/gst/gstreamer-sections.txt:
8999
9000 2004-04-17  Benjamin Otte  <otte@gnome.org>
9001
9002         * gst/gstelement.c: (gst_element_dispose):
9003           simplify
9004         * gst/gstpad.c: (gst_pad_call_chain_function):
9005           don't create loads of events due to bad macro usage
9006
9007 2004-04-16  David Schleef  <ds@schleef.org>
9008
9009         * gst/gstcaps.c: (gst_caps_is_fixed_foreach):
9010         * gst/gstpad.c: (_gst_pad_default_fixate_foreach):
9011         * gst/gstvalue.c: (gst_value_serialize_buffer),
9012         (gst_value_deserialize_buffer), (gst_type_is_fixed),
9013         (_gst_value_initialize): Create a new function gst_type_is_fixed()
9014         to indicate types that are fixed wrt caps or not.  Switching to
9015         this function fixes (bug #140298).
9016         * gst/gstvalue.h:
9017
9018 2004-04-16  David Schleef  <ds@schleef.org>
9019
9020         * common/m4/gst-arch.m4:  Implmenent a whitelist and blacklist
9021         for GST_UNALIGNED_ACESS, since we essentially know which archs
9022         are ok.
9023
9024 2004-04-17  Benjamin Otte  <otte@gnome.org>
9025
9026         * docs/gst/Makefile.am:
9027           ignore gst/parse directory when building docs (fixes #140205)
9028
9029 2004-04-16  Thomas Vander Stichele  <thomas at apestaart dot org>
9030
9031         * testsuite/refcounting/mem.c: (vmsize):
9032           do error checking
9033
9034 2004-04-16  Johan Dahlin  <johan@gnome.org>
9035
9036         * docs/gst/gstreamer-sections.txt: Add gst_pad_call_chain_function
9037         and gst_pad_call_get_function.
9038
9039 2004-04-15  David Schleef  <ds@schleef.org>
9040
9041         * common/m4/gst-arch.m4: Add GST_UNALIGNED_ACCESS() macro that
9042         checks if we can access unaligned memory.
9043         * configure.ac: Use it.
9044
9045 2004-04-16  Benjamin Otte  <otte@gnome.org>
9046
9047         * gst/elements/gstfilesrc.c: (gst_filesrc_init), (gst_filesrc_get),
9048         (gst_filesrc_change_state), (gst_filesrc_srcpad_event):
9049         * gst/elements/gstfilesrc.h:
9050           s/seek_happened/need_discont/ and require discont before sending any
9051           data
9052
9053 2004-04-15  David Schleef  <ds@schleef.org>
9054
9055         * gst/gstvalue.c: (gst_value_serialize_buffer),
9056         (gst_value_deserialize_buffer), (_gst_value_initialize):
9057         Register these types as fundamental types. (bug #140015)
9058
9059 2004-04-16  Benjamin Otte  <otte@gnome.org>
9060
9061         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_new),
9062         (gst_pad_link_free), (gst_pad_link_try), (_invent_event),
9063         (gst_pad_pull):
9064           implement enforcing discont events before buffers are passed. This
9065           allows state changes of only some elements and later correctly going
9066           on where they left off (or in short: you can now set audio sinks to
9067           NULL to release the device when the pipeline is paused)
9068         * gst/gstpad.c: (gst_pad_call_chain_function),
9069         (gst_pad_call_get_function):
9070         * gst/gstpad.h:
9071           add gst_pad_call_chain_function and gst_pad_call_get_function for
9072           scheduler interaction. They are required because of the changes
9073           above.
9074         * gst/schedulers/entryscheduler.c: (get_buffer),
9075         (gst_entry_scheduler_chain_wrapper),
9076         (gst_entry_scheduler_get_wrapper),
9077         (gst_entry_scheduler_state_transition),
9078         (gst_entry_scheduler_pad_link):
9079         * gst/schedulers/gstbasicscheduler.c:
9080         (gst_basic_scheduler_chain_wrapper),
9081         (gst_basic_scheduler_src_wrapper),
9082         (gst_basic_scheduler_chainhandler_proxy),
9083         (gst_basic_scheduler_gethandler_proxy),
9084         (gst_basic_scheduler_cothreaded_chain),
9085         (gst_basic_scheduler_chain_elements):
9086         * gst/schedulers/gstoptimalscheduler.c:
9087         (get_group_schedule_function), (pad_clear_queued),
9088         (gst_opt_scheduler_pad_link):
9089           use the new functions instead of calling get/chain-functions
9090           directly.
9091
9092 2004-04-15  David Schleef  <ds@schleef.org>
9093
9094         * docs/gst/gstreamer-sections.txt: Remove deprecated symbols.
9095         * docs/gst/tmpl/gstinfo.sgml: same
9096         * docs/gst/tmpl/gstutils.sgml: Remove a bunch of bogus crap that
9097         gtk-doc put here.
9098         * gst/gstutils.h: Remove the \ that was confusing gtk-doc.
9099         * examples/queue/queue.c: (main):  We iterate pipelines, not
9100         bins.  (bug #139996)
9101
9102 2004-04-15  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9103
9104         * docs/pwg/advanced-types.xml:
9105           Add MS RLE support. Also document Qt RLE although I have no sample
9106           files for that yet. And document an extra property for ADPCM.
9107
9108 2004-04-15  David Schleef  <ds@schleef.org>
9109
9110         * gst/gstplugin.c: (_gst_plugin_fault_handler_restore),
9111         (_gst_plugin_fault_handler_setup):  Disable more stuff on
9112         Windows.
9113
9114 2004-04-15  David Schleef  <ds@schleef.org>
9115
9116         * gst/gstinfo.c: (_gst_debug_init): Change some internal
9117         symbol names to not conflict with new gstinfo.h symbols.
9118         * gst/gstinfo.h: Add inline functions for all those crazy
9119         compilers that don't know how to handle variadic macros (MSVC).
9120
9121 2004-04-15  Thomas Vander Stichele  <thomas at apestaart dot org>
9122
9123         * configure.ac: bump nano to 1
9124
9125 === release 0.8.1 ===
9126
9127 2004-04-15  Thomas Vander Stichele  <thomas at apestaart dot org>
9128
9129         * NEWS:
9130         * RELEASE:
9131         * configure.ac:
9132           releasing 0.8.1, "Snow Brigade"
9133
9134 2004-04-14  David Schleef  <ds@schleef.org>
9135
9136         * testsuite/Makefile.am: define tests_ignore
9137         * testsuite/Rules: Added new tests_ignore, which get compiled,
9138         but not run (generally because they're inconsistent or have
9139         heisenbugs).  Now we can ensure all the .c files compile in
9140         testsuite/.
9141         * testsuite/bins/Makefile.am: define tests_ignore
9142         * testsuite/bytestream/Makefile.am:
9143         * testsuite/caps/Makefile.am:
9144         * testsuite/clock/Makefile.am:
9145         * testsuite/debug/Makefile.am:
9146         * testsuite/debug/global.c: (gst_debug_log_one),
9147         (gst_debug_log_two): Fix compilation problem.
9148         * testsuite/dynparams/Makefile.am:
9149         * testsuite/elements/Makefile.am:
9150         * testsuite/ghostpads/Makefile.am:
9151         * testsuite/indexers/Makefile.am:
9152         * testsuite/parse/Makefile.am:
9153         * testsuite/plugin/Makefile.am:
9154         * testsuite/refcounting/Makefile.am:
9155         * testsuite/refcounting/element_pad.c: (main): Don't return leak
9156         results, because it's not calculated correctly.
9157         * testsuite/refcounting/pad.c: (main): same
9158         * testsuite/states/Makefile.am:
9159         * testsuite/tags/Makefile.am:
9160         * testsuite/threads/Makefile.am:
9161
9162 2004-04-14  David Schleef  <ds@schleef.org>
9163
9164         * gst/gstcpu.c: (gst_cpuid_i386): Add workaround for gcc-3.2
9165         generating bad code around the cpu detection asm code.
9166
9167 2004-04-14  Thomas Vander Stichele  <thomas at apestaart dot org>
9168
9169         * tools/gst-inspect.c: (print_element_info):
9170           print numeric version of rank as well, since we added some - 1
9171           rank values to elements
9172
9173 2004-04-13  David Schleef  <ds@schleef.org>
9174
9175         * configure.ac:  Disable various code when compiling for MinGW.
9176         * gst/elements/Makefile.am:
9177         * gst/elements/gstelements.c:
9178         * gst/elements/gstfdsrc.c: (gst_fdsrc_get):
9179         * gst/elements/gstfilesrc.c: (gst_filesrc_init), (gst_filesrc_get):
9180         * gst/registries/gstxmlregistry.c: (make_dir):
9181
9182 2004-04-13  David Schleef  <ds@schleef.org>
9183
9184         * gst/Makefile.am:
9185         * gst/gstcpu.c: (gst_cpuid_i386): Convert asm source into inline
9186         assembly.
9187         * gst/gstcpuid_i386.s: remove
9188
9189 2004-04-13  David Schleef  <ds@schleef.org>
9190
9191         * docs/gst/tmpl/gstaggregator.sgml: Random checkin because gtk-doc
9192         seems to think it needs to be done.
9193         * docs/gst/tmpl/gstfakesink.sgml:
9194         * docs/gst/tmpl/gstfakesrc.sgml:
9195         * docs/gst/tmpl/gstfdsink.sgml:
9196         * docs/gst/tmpl/gstfdsrc.sgml:
9197         * docs/gst/tmpl/gstfilesink.sgml:
9198         * docs/gst/tmpl/gstfilesrc.sgml:
9199         * docs/gst/tmpl/gstidentity.sgml:
9200         * docs/gst/tmpl/gstmd5sink.sgml:
9201         * docs/gst/tmpl/gstmultifilesrc.sgml:
9202         * docs/gst/tmpl/gstpipefilter.sgml:
9203         * docs/gst/tmpl/gstshaper.sgml:
9204         * docs/gst/tmpl/gstspider.sgml:
9205         * docs/gst/tmpl/gstspideridentity.sgml:
9206         * docs/gst/tmpl/gststatistics.sgml:
9207         * docs/gst/tmpl/gsttee.sgml:
9208         * docs/gst/tmpl/gsttypefind.sgml:
9209         * docs/gst/tmpl/gstutils.sgml:
9210
9211 2004-04-13  David Schleef  <ds@schleef.org>
9212
9213         * configure.ac: Changes to remove POSIXisms (mmap in this case)
9214         and to build DLLs on Windows.
9215         * gst/Makefile.am:
9216         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
9217         (gst_filesrc_open_file):
9218         * gst/schedulers/Makefile.am:
9219
9220 2004-04-13  David Schleef  <ds@schleef.org>
9221
9222         * gst/gstcaps.c: (gst_caps_structure_fixate_field_nearest_int),
9223         (gst_caps_structure_fixate_field_nearest_double):  Fix bug in
9224         fixating lists.
9225
9226 2004-04-12  David Schleef  <ds@schleef.org>
9227
9228         * gst/gstbuffer.c: (_gst_buffer_initialize), (gst_buffer_get_type),
9229         (gst_buffer_free_chunk): Added gst_buffer_get_type() and changed
9230         to using it.
9231         * gst/gstbuffer.h: Changed GST_BUFFER_TYPE to gst_buffer_get_type()
9232         * gst/gstcaps.c: (gst_caps_is_fixed_foreach): Buffer is a fixed type
9233         * gst/gstpad.c: (_gst_pad_default_fixate_foreach): same
9234         * gst/gststructure.c: (gst_structure_set_valist),
9235         (gst_structure_from_abbr), (gst_structure_to_abbr): Add vararg
9236         support for buffers.
9237         * gst/gsttag.c: (gst_tag_register): Constify a prototype that was
9238         intended to be const.
9239         * gst/gsttag.h: same
9240         * gst/gstvalue.c: (gst_value_serialize_buffer),
9241         (gst_value_deserialize_buffer), (_gst_value_initialize):  Add code
9242         to (de)serialize buffers.
9243         * testsuite/caps/Makefile.am:  Add a bit of buffer testing
9244         * testsuite/caps/string-conversions.c: (main):
9245         * testsuite/caps/value_serialize.c: add new test
9246
9247 2004-04-11  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9248
9249         * docs/pwg/advanced-types.xml:
9250           Document MS video 1 (video/x-msvideocodec) mimetype/format.
9251
9252 2004-04-11  Benjamin Otte  <otte@gnome.org>
9253
9254         * gst/schedulers/gstbasicscheduler.c: (plugin_init):
9255           rename categories to basic_*
9256         * gst/schedulers/gstbasicscheduler.c: 
9257         (gst_basic_scheduler_chain_wrapper),
9258         (gst_basic_scheduler_chainhandler_proxy),
9259         (gst_basic_scheduler_gethandler_proxy),
9260         (gst_basic_scheduler_eventhandler_proxy):
9261           debugging category fixes - put common stuff in log category
9262         * gst/schedulers/gstbasicscheduler.c: 
9263         (gst_basic_scheduler_chain_elements):
9264           dirty fix: call gst_basic_scheduler_cothreaded_chain when already
9265           active and linking two active chains
9266
9267 2004-04-10  Benjamin Otte  <otte@gnome.org>
9268
9269         * docs/pwg/intro-preface.xml:
9270           fix dead links and remove reference to Wiki
9271
9272 2004-04-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9273
9274         * gst/schedulers/gstbasicscheduler.c:
9275           make sure we can switch back to the main function if we're still in
9276           the main function (supposed to fix #139617)
9277         * gst/schedulers/gthread-cothreads.h:
9278           don't throw an error when switching to the same cothread
9279
9280 2004-04-09  Benjamin Otte  <otte@gnome.org>
9281
9282         * gst/gstbin.c: (gst_bin_get_type):
9283         * gst/gstclock.c: (gst_clock_get_type):
9284         * gst/gstindex.c: (gst_index_get_type):
9285         * gst/gstobject.c: (gst_object_get_type),
9286         (gst_signal_object_get_type):
9287         * gst/gstpad.c: (gst_pad_get_type), (gst_real_pad_get_type),
9288         (gst_pad_template_get_type), (gst_ghost_pad_get_type):
9289         * gst/gstpluginfeature.c: (gst_plugin_feature_get_type):
9290         * gst/gstqueue.c: (gst_queue_get_type):
9291         * gst/gstregistry.c: (gst_registry_get_type):
9292         * gst/gstsystemclock.c: (gst_system_clock_get_type):
9293         * gst/gstthread.c: (gst_thread_get_type):
9294           don't use memchunks for these objects, use malloc instead
9295
9296 2004-04-08  Thomas Vander Stichele  <thomas at apestaart dot org>
9297
9298         * docs/gst/.cvsignore:
9299         * docs/gst/Makefile.am:
9300         * docs/gst/gstreamer-sections.txt:
9301         * docs/gst/tmpl/gstaggregator.sgml:
9302         * docs/gst/tmpl/gstbuffer.sgml:
9303         * docs/gst/tmpl/gstclock.sgml:
9304         * docs/gst/tmpl/gstelement.sgml:
9305         * docs/gst/tmpl/gstfakesink.sgml:
9306         * docs/gst/tmpl/gstfakesrc.sgml:
9307         * docs/gst/tmpl/gstfdsink.sgml:
9308         * docs/gst/tmpl/gstfdsrc.sgml:
9309         * docs/gst/tmpl/gstfilesink.sgml:
9310         * docs/gst/tmpl/gstfilesrc.sgml:
9311         * docs/gst/tmpl/gstidentity.sgml:
9312         * docs/gst/tmpl/gstindex.sgml:
9313         * docs/gst/tmpl/gstinfo.sgml:
9314         * docs/gst/tmpl/gstmd5sink.sgml:
9315         * docs/gst/tmpl/gstmultifilesrc.sgml:
9316         * docs/gst/tmpl/gstpad.sgml:
9317         * docs/gst/tmpl/gstpipefilter.sgml:
9318         * docs/gst/tmpl/gstpipeline.sgml:
9319         * docs/gst/tmpl/gstpluginfeature.sgml:
9320         * docs/gst/tmpl/gstqueue.sgml:
9321         * docs/gst/tmpl/gstregistry.sgml:
9322         * docs/gst/tmpl/gstscheduler.sgml:
9323         * docs/gst/tmpl/gstshaper.sgml:
9324         * docs/gst/tmpl/gstspider.sgml:
9325         * docs/gst/tmpl/gstspideridentity.sgml:
9326         * docs/gst/tmpl/gststatistics.sgml:
9327         * docs/gst/tmpl/gstsystemclock.sgml:
9328         * docs/gst/tmpl/gsttee.sgml:
9329         * docs/gst/tmpl/gstthread.sgml:
9330         * docs/gst/tmpl/gsttypefind.sgml:
9331         * docs/gst/tmpl/gstutils.sgml:
9332           further doc build fixes
9333
9334 2004-04-07  Thomas Vander Stichele  <thomas at apestaart dot org>
9335
9336         * docs/gst/Makefile.am:
9337           make docs exit on scanning problems
9338           fix nonsrcdir build issues
9339         * docs/gst/gstreamer-sections.txt:
9340           adding stuff from -unused
9341         * gst/gstqueue.h:
9342           create GstQueueSize
9343         * gst/schedulers/cothreads_compat.h:
9344           fix cothread warnings
9345
9346 2004-04-07  Thomas Vander Stichele  <thomas at apestaart dot org>
9347
9348         * docs/gst/gstreamer-sections.txt:
9349           remove defines deprecated by Benjamin
9350
9351 2004-04-07  Benjamin Otte  <otte@gnome.org>
9352
9353         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
9354           when the buffer is complete, don't check if other buffers are needed
9355         * gst/elements/gstfilesrc.c: (gst_filesrc_srcpad_event):
9356           check that the offset is >0 so we don't try to read before the
9357           beginning of the file
9358         * gst/gstpad.c: (gst_pad_set_pad_template):
9359           sink the template, so we don't end up with 130k pad templates
9360
9361 2004-04-06  Benjamin Otte  <otte@gnome.org>
9362
9363         * gst/autoplug/gstspider.c: (gst_spider_link_add):
9364           don't ref the element, adding already reffed it. And we didn't unref
9365           it later anyway... (huge memleak when you used many spider elements)
9366         * gst/gstelement.c: (gst_element_base_class_finalize):
9367         * gst/gstelementfactory.c: (gst_element_factory_cleanup),
9368         (gst_element_register):
9369         * gst/gsturi.c: (gst_element_make_from_uri):
9370           use gst_object_(un)ref instead of g_object(un)ref
9371
9372 2004-04-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9373
9374         * gst/gstbuffer.h:
9375           remove macro that wouldn't work anymore because struct member has
9376           been removed.
9377         * gst/schedulers/entryscheduler.c: (schedule_forward):
9378           fix segfault for unconnected pads
9379         
9380 2004-04-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9381
9382         reviewed by David Schleef <ds@schleef.org>
9383
9384         * gst/gstinfo.h:
9385           *_FORMAT modifiers should require putting a % in front of them for
9386           consistency reasons.
9387
9388 2004-04-05  Colin Walters  <walters@redhat.com>
9389
9390         * configure.ac (VALGRIND_CFLAGS, VALGRIND_LIBS): Remove spurious
9391         space.
9392
9393 2004-04-05  Benjamin Otte  <otte@gnome.org>
9394
9395         * configure.ac:
9396         * gst/Makefile.am:
9397         * gst/gst_private.h:
9398         * gst/gstinfo.c: (__gst_in_valgrind), (_gst_debug_init):
9399           add support for detecting if GStreamer runs inside valgrind.
9400           requires valgrind (d'oh) and --enable-debug for correct cdetection.
9401           print a big message in valgrind that GStreamer has detected it's
9402           running inside and might now use different code.
9403         * gst/gstmemchunk.c: (populate), (free_area),
9404         (gst_mem_chunk_destroy), (gst_mem_chunk_alloc),
9405         (gst_mem_chunk_free):
9406           flag memchunks for valgrind, so it can detect leaking of chunks.
9407           This allows detecting leaks of GstBuffer and GstEvent correctly
9408           inside valgrind.
9409
9410 2004-04-05  David Schleef  <ds@schleef.org>
9411
9412         * gst/gsttrace.h:  Fix #ifdef nesting (bug #139109) Patch from
9413           jensgr@gmx.net (Jens Granseuer)
9414
9415 2004-04-05  David Schleef  <ds@schleef.org>
9416
9417         * gst/gstbuffer.c: (_gst_buffer_sub_free),
9418         (gst_buffer_default_free), (gst_buffer_default_copy),
9419         (gst_buffer_alloc_chunk), (gst_buffer_free_chunk),
9420         (gst_buffer_new), (gst_buffer_create_sub):  Allocate GstBuffer
9421         structures in one place.
9422
9423 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
9424
9425         * gst/gstinfo.h: adding Ronald's timestamp debugging defines
9426           (GST_TIME_FORMAT, GST_TIME_ARGS)
9427
9428 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
9429
9430         * testsuite/elements/Makefile.am:
9431           disable test until it stops breaking make distcheck
9432
9433 2004-04-05  Johan Dahlin  <johan@gnome.org>
9434
9435         * po/sv.po: Updated translation
9436
9437 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
9438
9439         * gst/gstplugin.c: (gst_plugin_load_file):
9440           fix segfault for when original plugin was loaded statically
9441
9442 2004-04-05  Benjamin Otte  <otte@gnome.org>
9443
9444         * testsuite/debug/category.c: (main):
9445         * testsuite/debug/commandline.c: (main):
9446         * testsuite/debug/output.c: (main):
9447           fix tests to work again with debugging enabled
9448
9449 2004-04-05  Benjamin Otte  <otte@gnome.org>
9450
9451         * gst/schedulers/gstbasicscheduler.c:
9452         (gst_basic_scheduler_pad_link):
9453           fix to work with recent scheduling changes
9454
9455 2004-04-05  Benjamin Otte  <otte@gnome.org>
9456
9457         * gst/schedulers/entryscheduler.c: (some functions, dunno which,
9458         prepareChangeLog doesn't work when cvs indents):
9459           don't throw an error when no element can be scheduled, there's too
9460           many weird reasons why it doesn't work. Return STOPPED instead.
9461           decoupled elemts' schedulability doesn't depend on bufpens.
9462
9463 2004-04-04  Benjamin Otte  <otte@gnome.org>
9464
9465         * gst/schedulers/gstbasicscheduler.c:
9466         (gst_basic_scheduler_pad_select):
9467           fix uninitialized variable warnings
9468
9469 2004-04-04  Benjamin Otte  <otte@gnome.org>
9470
9471         * gst/gstpad.c: (gst_pad_collect_valist):
9472           fix uninitialized variable warning
9473         * gst/schedulers/entryscheduler.c: (schedule_forward):
9474           fix shadowed variable
9475
9476 2004-04-04  Benjamin Otte  <otte@gnome.org>
9477
9478         * gst/gstpad.c: (gst_pad_collect_array), (gst_pad_collectv),
9479         (gst_pad_collect), (gst_pad_collect_valist), (gst_pad_selectv),
9480         (gst_pad_select):
9481         * gst/gstpad.h:
9482         * gst/gstscheduler.c: (gst_scheduler_pad_select),
9483         (gst_scheduler_lock_element), (gst_scheduler_unlock_element):
9484         * gst/gstscheduler.h:
9485           implement gst_pad_collect as replacement for gst_pad_select.
9486           deprecate gst_pad_select and gst_scheduler_(un)lock_element
9487           add new flag GST_SCHEDULER_FLAG_NEW_API for API that implements the
9488           new pad_select, lock and unlock calls.
9489         * gst/cothreads.c: (cothread_destroy), (cothread_switch):
9490         * gst/cothreads.h:
9491         * gst/schedulers/cothreads_compat.h:
9492         * gst/schedulers/gthread-cothreads.h:
9493           remove unused cothread_lock and cothread_unlock calls
9494         * gst/schedulers/entryscheduler.c:
9495         (gst_entry_scheduler_class_init), (gst_entry_scheduler_init),
9496         (_can_schedule_loop), (gst_entry_scheduler_get_handler),
9497         (gst_entry_scheduler_pad_select):
9498           update to new API
9499         * gst/schedulers/gstbasicscheduler.c:
9500         (gst_basic_scheduler_class_init), (gst_basic_scheduler_init),
9501         (gst_basic_scheduler_pad_select):
9502           remove useless lock and unlock calls, update pad_select to new API
9503           (untested)
9504         * gst/schedulers/gstoptimalscheduler.c:
9505         (gst_opt_scheduler_class_init):
9506           remove useless select, lock and unlock function calls
9507         * gst/elements/gstaggregator.c: (gst_aggregator_loop):
9508           use gst_pad_collect instead of gst_pad_select
9509
9510 2004-04-04  Benjamin Otte  <otte@gnome.org>
9511
9512         * gst/schedulers/entryscheduler.c: (_can_schedule_get),
9513         (can_schedule_pad), (can_schedule), (schedule), (schedule_forward),
9514         (schedule_next_element), (print_entry):
9515           add can_schedule_pad to handle element states.
9516           add schedule_forward to select the correct entry to schedule next
9517
9518 2004-04-03  Benjamin Otte  <otte@gnome.org>
9519
9520         * gst/schedulers/entryscheduler.c: 
9521           remove unused variable, fix error inside Rb, fix compile warning in
9522           unreachable code
9523
9524 2004-04-03  Benjamin Otte  <otte@gnome.org>
9525
9526         * gst/schedulers/entryscheduler.c:
9527           completely revamp the inner workings, so it's a lot easier to
9528           understand and extend
9529
9530 2004-04-03  Andy Wingo  <wingo@pobox.com>
9531
9532         * gst/schedulers/gstoptimalscheduler.c (GstOptSchedulerGroupLink):
9533         Rename ->group1 and ->group2 to ->src and ->sink, respectively.
9534         This allows better introspection of pipeline topology.
9535         (add_to_chain): Don't do trickery to put loop elements first;
9536         rather, queue a chain sort by marking the chain as dirty.
9537         (remove_from_chain): Mark the chain dirty.
9538         (sort_chain): New function. Sorts the group list so that terminal
9539         sinks are first. This means elements on the sink side will be
9540         preferentially sscheduled before elements on the src side of the
9541         pipeline.
9542         (chain_recursively_migrate_group): Use OTHER_GROUP_LINK.
9543         (schedule_chain): If the chain is marked DIRTY, call sort_chain.
9544         (gst_opt_scheduler_pad_link, gst_opt_scheduler_pad_unlink)
9545         (group_inc_link): Change argument and variable names to match the
9546         new link structure member names (src and sink).
9547         (group_dec_link): Add some description
9548
9549 2004-04-03  Benjamin Otte  <otte@gnome.org>
9550
9551         * gst/autoplug/gstspider.c: (gst_spider_identity_plug):
9552         * gst/gstinfo.h:
9553         * testsuite/debug/category.c: (main):
9554         * testsuite/debug/commandline.c: (main):
9555         * testsuite/debug/output.c: (main):
9556         * testsuite/debug/printf_extension.c: (main):
9557           fix to successfully build and test with --disable-gst-debug
9558           configure switch (fixes #138705)
9559
9560 2004-04-03  Benjamin Otte  <otte@gnome.org>
9561
9562         * docs/pwg/building-boiler.xml:
9563           add cvs login line and s/anonymous/anoncvs/
9564
9565 2004-04-03  Tim-Phillip Müller  <t.i.m@zen.co.uk>
9566
9567         reviewed by Benjamin Otte  <otte@gnome.org>
9568
9569         * gst/gststructure.c: (gst_structure_free):
9570           memleak fix: free fields array (partial fix for #134839)
9571
9572 2004-04-01  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9573
9574         * docs/random/ds/0.9-suggested-changes:
9575           Add a note to change handoff use in fakesrc to be usable in
9576           a more generic way (fakesrc should be renamed to appsrc or so).
9577         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
9578           Change signal type to scope, so we can fill the buffer in the
9579           handoff handler (that's the whole use of this signal...).
9580
9581 2004-04-01  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9582
9583         * docs/pwg/other-ntoone.xml:
9584           Document muxers and n-to-1 elements.
9585
9586 2004-04-01  Martin Soto  <martinsoto@users.sourceforge.net>
9587
9588         * gst/registries/gstxmlregistry.c
9589         (gst_xml_registry_rebuild_recurse): Fix the algorithm to
9590         determine if a file is a G_MODULE. The old one discards paths
9591         containing "so" somewhere in the middle. My home directory is
9592         called "soto". Go figure...
9593
9594 2004-03-31  David Schleef  <ds@schleef.org>
9595
9596         * gst/gstbuffer.c: (gst_buffer_join):  Add function gst_buffer_join()
9597         to eventually deprecate gst_buffer_merge().  (bug: #136408)
9598         * gst/gstbuffer.h:
9599
9600 2004-03-31  David Schleef  <ds@schleef.org>
9601
9602         * gst/gstvalue.c: (gst_value_union_int_int_range),
9603         (gst_value_union_int_range_int_range), (gst_value_can_union),
9604         (gst_value_union), (_gst_value_initialize):  Add some union
9605         implementations.  We didn't have any previously.
9606         * testsuite/caps/Makefile.am:
9607         * testsuite/caps/audioscale.c: (gst_audioscale_expand_value),
9608         (gst_audioscale_getcaps), (test_caps), (main): A little test
9609         that is the same as the caps manipulation in audioscale.
9610
9611 2004-03-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9612
9613         * docs/faq/general.xml:
9614           add entry about "does gst support format X?"
9615
9616 2004-03-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9617
9618         * gst/gstthread.c:
9619           fix docs
9620         * gst/gstutils.h:
9621           fix GST_BOILERPLATE_FULL to not throw casting errors on C++
9622
9623 2004-03-30  Benjamin Otte  <otte@gnome.org>
9624
9625         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
9626           set the offset of the buffer to the requested offset
9627         * gst/elements/gsttypefind.c: (stop_typefinding):
9628           revert patch 1.18 (which I unfortunately don't know the reason for).
9629           This is needed to allow downstream elements to seek. Otherwise
9630           typefind might overwrite a previous seek by downstream elements.
9631           This lead to errors with id3tag and typefind on some mp3s.
9632         * gst/schedulers/entryscheduler.c: (COTHREADS_TYPE),
9633         (gst_entry_scheduler_iterate):
9634           be more verbose when debugging
9635
9636 2004-03-30  Thomas Vander Stichele  <thomas at apestaart dot org>
9637
9638         * gst/gstcaps.c: (gst_caps_from_string_inplace):
9639           make sure we don't get NULL strings
9640
9641 2004-03-30  Thomas Vander Stichele  <thomas at apestaart dot org>
9642
9643         * gst/gstcaps.c:
9644         * gst/gstelement.c:
9645         * gst/gstelementfactory.c: (gst_element_factory_get_type):
9646         * gst/gstindex.c: (gst_index_resolver_get_type),
9647         (gst_index_get_type), (gst_index_factory_get_type):
9648         * gst/gstinfo.c:
9649         * gst/gstpad.c:
9650         * gst/gstplugin.c:
9651         * gst/gsturi.c: (gst_uri_handler_get_type):
9652         * gst/gstvalue.c:
9653           first batch of documentation fixes
9654
9655 2004-03-29  David Schleef  <ds@schleef.org>
9656
9657         * docs/gst/Makefile.am:  Disable a bunch of headers from being scanned
9658         * docs/gst/gstreamer-docs.sgml:  More hacking
9659         * docs/gst/gstreamer-sections.txt:
9660         * docs/gst/tmpl/cothreads_compat.sgml:
9661         * docs/gst/tmpl/gstcaps.sgml:
9662         * docs/gst/tmpl/gstclock.sgml:
9663         * docs/gst/tmpl/gstelement.sgml:
9664         * docs/gst/tmpl/gstevent.sgml:
9665         * docs/gst/tmpl/gstpad.sgml:
9666         * docs/gst/tmpl/gstutils.sgml:
9667         * docs/gst/tmpl/gstxml.sgml:
9668         * docs/gst/tmpl/gthread-cothreads.sgml:
9669         * docs/random/ds/0.9-suggested-changes:
9670         * gst/elements/gstfakesink.h: doc fixes
9671         * gst/elements/gstfakesrc.h: doc fixes
9672         * gst/gstcaps.c: doc fixes
9673         * gst/gstcaps.h: doc fixes
9674         * gst/gstelement.c: doc fixes
9675         * gst/gstelement.h: doc fixes
9676         * gst/gstindex.c: doc fixes
9677         * gst/gstinfo.c: doc fixes
9678         * gst/gstpad.c: doc fixes
9679         * gst/gstpad.h: doc fixes
9680         * gst/gstplugin.c: doc fixes
9681         * gst/gsttypefind.h: doc fixes
9682         * gst/gsturi.c: doc fixes
9683         * gst/gstvalue.c: doc fixes
9684
9685 2004-03-29  Colin Walters  <walters@redhat.com>
9686
9687         * gst/registries/gstxmlregistry.c (get_time)
9688         (plugin_times_older_than_recurse):
9689         Use the result of stat to determine whether a path is a file,
9690         so we don't attempt to opendir() files.
9691
9692 2004-03-29  Benjamin Otte  <otte@gnome.org>
9693
9694         * gst/gstpad.c: (gst_pad_set_explicit_caps):
9695           print caps in debugging output when setting caps failed
9696         * gst/schedulers/entryscheduler.c: (COTHREADS_TYPE),
9697         (schedule_next_element), (get_buffer), (run_chainhandler),
9698         (element_may_start), (gst_entry_scheduler_chain_handler),
9699         (gst_entry_scheduler_get_handler),
9700         (gst_entry_scheduler_state_transition),
9701         (gst_entry_scheduler_pad_link):
9702           make this scheduler a testcase for mandatory
9703           discont-before-first-buffer which is needed if we want to allow apps
9704           to release the sound device.
9705           add SCHED_ASSERT macro to print scheduler state before an assertion
9706           triggers.
9707
9708 2004-03-29  Benjamin Otte  <otte@gnome.org>
9709
9710         * COPYING:
9711           replace by LGPL (former COPYING.LIB). The core is completely
9712           licensed LGPL.
9713         * COPYING.LIB:
9714           remove
9715
9716 2004-03-29  Thomas Vander Stichele  <thomas at apestaart dot org>
9717
9718         * po/af.po:
9719         * po/sv.po:
9720           updated Afrikaans and Swedish
9721
9722 2004-03-29  Thomas Vander Stichele  <thomas at apestaart dot org>
9723
9724         * po/LINGUAS:
9725         * po/az.po:
9726           adding Azerbaijani (Mətin Əmirov)
9727
9728 2004-03-28  Martin Soto  <martinsoto@users.sourceforge.net>
9729
9730         * gst/gstelement.h: 
9731         * gst/gstelement.c (gst_element_set_time_delay): New function for
9732         setting element time taking into account a hardware buffering
9733         delay.
9734         (gst_element_set_time): Now just an invocation of
9735         gst_element_set_time_delay.
9736         * gst/gstclock.h: 
9737         * gst/gstclock.c (gst_clock_get_event_time_delay): New function
9738         allowing to set event times in the future.
9739         (gst_clock_get_event_time): Now just an invocation of
9740         gst_clock_get_event_time_delay.
9741
9742 2004-03-28  Benjamin Otte  <otte@gnome.org>
9743
9744         * gst/gstbin.c: (gst_bin_set_element_sched),
9745         (gst_bin_unset_element_sched):
9746           don't add decoupled elements to schedulers - otherwise it's
9747           impossible to control if a link to a decoupled element was already
9748           removed from a scheduler or not.
9749         * gst/schedulers/cothreads_compat.h:
9750         * gst/schedulers/gthread-cothreads.h:
9751           add COTHREADS_TYPE macro. Make do_cothread_set_func a macro so there
9752           is no "unused" warning.
9753         * gst/schedulers/Makefile.am:
9754         * gst/schedulers/entryscheduler.c:
9755           add new scheduler, based on ideas from talking to David and Martin.
9756           It's supposed to be small and correct. Currently it's also slow (but
9757           it's not noticable)
9758         * examples/retag/retag.c: (main):
9759         * testsuite/bytestream/test1.c: (main):
9760           fix missing NULLs at end of variadic functions
9761         * testsuite/elements/.cvsignore:
9762           update
9763
9764 2004-03-28  Jan Schmidt  <thaytan@mad.scientist.com>
9765
9766         * gst/gstevent.h:
9767         Added GST_EVENT_ANY for GstEvents that pass a GstStructure
9768
9769 2004-03-25  David Schleef  <ds@schleef.org>
9770
9771         * docs/gst/gstreamer-sections.txt:  More doc hacking.
9772         * docs/gst/tmpl/gstaggregator.sgml:
9773         * docs/gst/tmpl/gstautoplugfactory.sgml:
9774         * docs/gst/tmpl/gstbin.sgml:
9775         * docs/gst/tmpl/gstbuffer.sgml:
9776         * docs/gst/tmpl/gstbufferstore.sgml:
9777         * docs/gst/tmpl/gstfakesink.sgml:
9778         * docs/gst/tmpl/gstfakesrc.sgml:
9779         * docs/gst/tmpl/gstmd5sink.sgml:
9780         * docs/gst/tmpl/gstreamer-unused.sgml:
9781         * docs/gst/tmpl/gstsearchfuncs.sgml:
9782         * docs/gst/tmpl/gstshaper.sgml:
9783         * docs/gst/tmpl/gstspider.sgml:
9784         * docs/gst/tmpl/gsttee.sgml:
9785         * docs/gst/tmpl/gstutils.sgml:
9786         * docs/gst/tmpl/gstvalue.sgml:
9787         * docs/gst/tmpl/gstxml.sgml:
9788         * gst/Makefile.am:  Remove gstthreaddummy.c.  It never worked,
9789         and we don't support it.
9790         * gst/gst.c: (gst_init_get_popt_table), (init_pre), (init_post),
9791         (gst_use_threads), (gst_has_threads): same
9792         * gst/gstthreaddummy.c: same
9793         * gst/autoplug/gstspider.c: Make gst_spider_details static.
9794         * gst/autoplug/gstspider.h: same
9795         * gst/elements/gstaggregator.h: Remove bogus function from header
9796         * gst/elements/gstfakesink.h: same
9797         * gst/elements/gstfakesrc.h: same
9798         * gst/elements/gstmd5sink.h: same
9799         * gst/elements/gstshaper.h: same
9800         * gst/elements/gsttee.h: same
9801         * gst/gstbin.c: doc fixes
9802         * gst/gstbin.h: Remove unused definition.
9803         * gst/gstbuffer.c: doc fixes
9804         * gst/gstcaps.c: (gst_caps_is_always_compatible): doc fixes
9805         * gst/gstfilter.c: doc fixes
9806         * gst/gsttag.c: doc fixes
9807         * gst/gstvalue.c: doc fixes
9808
9809 2004-03-25  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9810
9811         * docs/pwg/advanced-types.xml:
9812           Document typefinding.
9813         * docs/pwg/other-oneton.xml:
9814           Document one-to-n elements, demuxers and parsers.
9815
9816 2004-03-25  Tim-Philipp Müller <t.i.m@zen.co.uk>
9817
9818         reviewed by: David Schleef  <ds@schleef.org>
9819
9820         * configure.ac: Check bison version (bug #127838)
9821
9822 2004-03-25  David Schleef  <ds@schleef.org>
9823
9824         * docs/gst/gstreamer-docs.sgml: More fine tuning.
9825         * docs/gst/gstreamer-sections.txt:
9826         * docs/gst/tmpl/gstautoplug.sgml:
9827         * docs/gst/tmpl/gststaticautoplug.sgml:
9828         * docs/gst/tmpl/gststaticautoplugrender.sgml:
9829         * docs/gst/tmpl/gstutils.sgml:
9830         * docs/gst/tmpl/gstxml.sgml:
9831
9832 2004-03-24  David Schleef  <ds@schleef.org>
9833
9834         * docs/gst/gstreamer-docs.sgml:  I got tired of the reference
9835         manual being such complete crap, that I decided to do major
9836         hacking of it.  This checkin replaces any fine tuning that
9837         may have been done previously, with the benefit of actually
9838         being complete for much of the API that was changed since
9839         0.6.  Further fine tuning will occur shortly.  (bug #134721)
9840         * docs/gst/gstreamer-sections.txt:
9841         * docs/gst/tmpl/GstBin.sgml:
9842         * docs/gst/tmpl/GstBuffer.sgml:
9843         * docs/gst/tmpl/GstCaps.sgml:
9844         * docs/gst/tmpl/GstClock.sgml:
9845         * docs/gst/tmpl/GstCompat.sgml:
9846         * docs/gst/tmpl/GstData.sgml:
9847         * docs/gst/tmpl/GstElement.sgml:
9848         * docs/gst/tmpl/GstEvent.sgml:
9849         * docs/gst/tmpl/GstIndex.sgml:
9850         * docs/gst/tmpl/GstStructure.sgml:
9851         * docs/gst/tmpl/GstTag.sgml:
9852         * docs/gst/tmpl/cothreads.sgml:
9853         * docs/gst/tmpl/cothreads_compat.sgml:
9854         * docs/gst/tmpl/gettext.sgml:
9855         * docs/gst/tmpl/grammar.tab.sgml:
9856         * docs/gst/tmpl/gst-i18n-app.sgml:
9857         * docs/gst/tmpl/gst-i18n-lib.sgml:
9858         * docs/gst/tmpl/gst.sgml:
9859         * docs/gst/tmpl/gst_private.sgml:
9860         * docs/gst/tmpl/gstaggregator.sgml:
9861         * docs/gst/tmpl/gstarch.sgml:
9862         * docs/gst/tmpl/gstatomic.sgml:
9863         * docs/gst/tmpl/gstatomic_impl.sgml:
9864         * docs/gst/tmpl/gstbin.sgml:
9865         * docs/gst/tmpl/gstbuffer.sgml:
9866         * docs/gst/tmpl/gstbufferstore.sgml:
9867         * docs/gst/tmpl/gstcaps.sgml:
9868         * docs/gst/tmpl/gstclock.sgml:
9869         * docs/gst/tmpl/gstcompat.sgml:
9870         * docs/gst/tmpl/gstconfig.sgml:
9871         * docs/gst/tmpl/gstcpu.sgml:
9872         * docs/gst/tmpl/gstdata.sgml:
9873         * docs/gst/tmpl/gstdata_private.sgml:
9874         * docs/gst/tmpl/gstelement.sgml:
9875         * docs/gst/tmpl/gstenumtypes.sgml:
9876         * docs/gst/tmpl/gsterror.sgml:
9877         * docs/gst/tmpl/gstevent.sgml:
9878         * docs/gst/tmpl/gstfakesink.sgml:
9879         * docs/gst/tmpl/gstfakesrc.sgml:
9880         * docs/gst/tmpl/gstfilesink.sgml:
9881         * docs/gst/tmpl/gstfilter.sgml:
9882         * docs/gst/tmpl/gstindex.sgml:
9883         * docs/gst/tmpl/gstinfo.sgml:
9884         * docs/gst/tmpl/gstinterface.sgml:
9885         * docs/gst/tmpl/gstlog.sgml:
9886         * docs/gst/tmpl/gstmacros.sgml:
9887         * docs/gst/tmpl/gstmarshal.sgml:
9888         * docs/gst/tmpl/gstmd5sink.sgml:
9889         * docs/gst/tmpl/gstmultifilesrc.sgml:
9890         * docs/gst/tmpl/gstobject.sgml:
9891         * docs/gst/tmpl/gstpad.sgml:
9892         * docs/gst/tmpl/gstparse.sgml:
9893         * docs/gst/tmpl/gstpipeline.sgml:
9894         * docs/gst/tmpl/gstplugin.sgml:
9895         * docs/gst/tmpl/gstpluginfeature.sgml:
9896         * docs/gst/tmpl/gstqueue.sgml:
9897         * docs/gst/tmpl/gstreamer-unused.sgml:
9898         * docs/gst/tmpl/gstregistry.sgml:
9899         * docs/gst/tmpl/gstregistrypool.sgml:
9900         * docs/gst/tmpl/gstscheduler.sgml:
9901         * docs/gst/tmpl/gstsearchfuncs.sgml:
9902         * docs/gst/tmpl/gstshaper.sgml:
9903         * docs/gst/tmpl/gstspider.sgml:
9904         * docs/gst/tmpl/gstspideridentity.sgml:
9905         * docs/gst/tmpl/gststructure.sgml:
9906         * docs/gst/tmpl/gstsystemclock.sgml:
9907         * docs/gst/tmpl/gsttag.sgml:
9908         * docs/gst/tmpl/gsttaginterface.sgml:
9909         * docs/gst/tmpl/gsttee.sgml:
9910         * docs/gst/tmpl/gstthread.sgml:
9911         * docs/gst/tmpl/gsttrace.sgml:
9912         * docs/gst/tmpl/gsttrashstack.sgml:
9913         * docs/gst/tmpl/gsttypefind.sgml:
9914         * docs/gst/tmpl/gsttypes.sgml:
9915         * docs/gst/tmpl/gsturi.sgml:
9916         * docs/gst/tmpl/gsturitype.sgml:
9917         * docs/gst/tmpl/gstutils.sgml:
9918         * docs/gst/tmpl/gstvalue.sgml:
9919         * docs/gst/tmpl/gstversion.sgml:
9920         * docs/gst/tmpl/gstxml.sgml:
9921         * docs/gst/tmpl/gstxmlregistry.sgml:
9922         * docs/gst/tmpl/gthread-cothreads.sgml:
9923         * docs/gst/tmpl/types.sgml:
9924
9925 2004-03-24  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9926
9927         * docs/pwg/other-sink.xml:
9928         * docs/pwg/other-source.xml:
9929           Documentation on how to write source and sink elements. Other
9930           stuff in chapter 4 (1-to-n/demuxer, n-to-1/muxer, n-to-n,
9931           manager, autoplugger) are all still pending.
9932
9933 2004-03-25  Benjamin Otte  <otte@gnome.org>
9934
9935         * testsuite/elements/Makefile.am:
9936         * testsuite/elements/gst-compprep-check:
9937           add check to make sure gst-compprep works
9938         * testsuite/elements/gst-inspect-check.in:
9939           improve initialization output
9940         * testsuite/Makefile.am:
9941         * testsuite/gst-inspect-check:
9942           remove old file
9943
9944 2004-03-24  David Schleef  <ds@schleef.org>
9945
9946         * testsuite/elements/Makefile.am:
9947         * testsuite/elements/gst-inspect-check.in: Add gst-inspect-check
9948         to the testsuite.
9949
9950 2004-03-24  Benjamin Otte  <otte@gnome.org>
9951
9952         * libs/gst/control/dparam.c: (gst_dparam_attach),
9953         (gst_dparam_detach):
9954         * libs/gst/control/dparammanager.c: (gst_dpman_init):
9955           fix lvalue casts for real
9956
9957 2004-03-24  Benjamin Otte  <otte@gnome.org>
9958
9959         * gst/schedulers/gstbasicscheduler.c:
9960         (gst_basic_scheduler_src_wrapper):
9961         * gst/schedulers/gstoptimalscheduler.c:
9962         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
9963         (pad_clear_queued), (gst_opt_scheduler_add_element),
9964         (gst_opt_scheduler_remove_element):
9965           fix GStreamer to not have issues with lvalue casts anymore (fixes
9966           #136841)
9967
9968 2004-03-24  Benjamin Otte  <otte@gnome.org>
9969
9970         * gst/gstelement.c:
9971           add documentation about a gobject quirk where the object hasn't the
9972           correct class pointer set on initialization
9973         * gst/schedulers/gstbasicscheduler.c:
9974         (gst_basic_scheduler_src_wrapper):
9975           make sure to not run into an infinite loop
9976
9977 2004-03-22  Benjamin Otte  <otte@gnome.org>
9978
9979         * gst/gstutils.c: (gst_util_dump_mem):
9980         * gst/gstutils.h:
9981           first argument of gst_util_dump_mem should be const
9982
9983 2004-03-22  Johan Dahlin  <johan@gnome.org>
9984
9985         * gst/gstvalue.h: Clean up a little bit.
9986
9987 2004-03-21  Tim-Philipp Müller <t.i.m@zen.co.uk>
9988
9989         reviewed by Benjamin Otte  <otte@gnome.org>
9990
9991         * gst/autoplug/gstspider.c: (gst_spider_dispose):
9992         * gst/elements/gstaggregator.c: (gst_aggregator_finalize),
9993         (gst_aggregator_class_init), (gst_aggregator_init):
9994         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
9995         (gst_filesrc_dispose), (gst_filesrc_set_location):
9996         * gst/elements/gstidentity.c: (gst_identity_finalize),
9997         (gst_identity_class_init), (gst_identity_chain):
9998         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_open_file):
9999         * gst/elements/gststatistics.c: (gst_statistics_finalize),
10000         (gst_statistics_class_init):
10001         * gst/elements/gsttee.c: (gst_tee_finalize), (gst_tee_class_init),
10002         (gst_tee_get_property):
10003           clean up used memory in this elements correctly on teardown (closes
10004           #137279)
10005
10006 2004-03-20  Colin Walters  <walters@redhat.com>
10007
10008         * gst/registries/gstxmlregistry.c:
10009         (gst_xml_registry_open_func, gst_xml_registry_close_func): Make
10010         registry saving atomic.
10011
10012 2004-03-20  Colin Walters  <walters@redhat.com>
10013
10014         * gst/registries/gstxmlregistry.c (gst_xml_registry_get_perms_func):
10015         Just use
10016         access() instead of actually creating and deleting files.
10017
10018 2004-03-18  David Schleef  <ds@schleef.org>
10019
10020         * configure.ac:  Remove HAVE_ATOMIC_H test, since it's unused.
10021         (bug #137625)
10022
10023 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
10024
10025         * po/sv.po: updated translation (Christian Rose)
10026
10027 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
10028
10029         * gst/elements/gstfilesink.c: (gst_filesink_get_formats),
10030         (gst_filesink_get_query_types), (_do_init),
10031         (gst_filesink_handle_event), (gst_filesink_uri_get_protocols):
10032           return FALSE silently
10033         * po/af.po: updated translation (Petri Jooste)
10034
10035 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
10036
10037         * Makefile.am:
10038         * configure.ac:
10039           dist common properly
10040         * po/af.po:
10041         * po/fr.po:
10042         * po/nl.po:
10043         * po/sr.po:
10044         * po/sv.po:
10045           refreshing translations
10046
10047 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
10048
10049         * po/LINGUAS:
10050         * po/sv.po:
10051         * po/af.po:
10052           adding Swedish (Christian Rose) and Afrikaans (Petri Jooste)
10053
10054 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
10055
10056         * Makefile.am: use common/release.mak
10057
10058 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
10059
10060         * docs/faq/gst-uninstalled:
10061           adding gst-monkeysaudio to the list of possible plugin dirs
10062
10063 2004-03-16  David Schleef  <ds@schleef.org>
10064
10065         * gst/gst.c: (gst_get_popt_options), (gst_init_get_popt_table),
10066         (gst_init_check_with_popt_table):  Fix some gettext strings to
10067         make them easier to translate.  Required making the strings
10068         non-const.
10069
10070 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10071
10072         * configure.ac: bump nano to 1
10073
10074 === release 0.8.0 ===
10075
10076 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10077
10078         * configure.ac: release 0.8.0, "Executive Slacks"
10079
10080 2004-03-16  Johan Dahlin  <johan@gnome.org>
10081
10082         * gst/schedulers/gstoptimalscheduler.c
10083         (gst_opt_scheduler_pad_unlink): Remove double ;,
10084         spotted by Scott Wheeler
10085
10086 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10087
10088         * configure.ac: bump libtool version
10089
10090 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10091
10092         * gst/gstcaps.h:
10093         * gst/gststructure.h:
10094           add reserved padding
10095
10096 2004-03-15  Benjamin Otte  <otte@gnome.org>
10097
10098         * gst/elements/gstfdsrc.c: (gst_fdsrc_get):
10099           set the first parameter for select call correctly.
10100           (fixes #137230)
10101
10102 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10103
10104         * *.c,*.h: don't mix tabs and spaces
10105
10106 2004-03-15  Johan Dahlin  <johan@gnome.org>
10107
10108         * gst/schedulers/gstoptimalscheduler.c
10109         (gst_opt_scheduler_pad_unlink): Fix bug that causes totem to
10110         crash on MPEG playback. My boolean arithmetic is a bit rusty.
10111
10112         * tools/Makefile.am (EXTRA_DIST): Add gst-indent
10113         
10114 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10115
10116         * testsuite/Rules:
10117           fix gst-register rules
10118
10119 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10120
10121         * testsuite/Rules:
10122           use versioned gst-register
10123
10124 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
10125
10126         * docs/libs/gstreamer-libs-sections.txt:
10127           remove </SUBSECTION>
10128         * gst/gstplugin.c:
10129         * gst/gstregistry.c: (gst_registry_add_plugin):
10130         * gst/registries/gstxmlregistry.c: (gst_xml_registry_get_type),
10131         (gst_xml_registry_open_func), (gst_xml_registry_close_func):
10132           add debugging and fix some comment blocks
10133
10134 2004-03-15  Johan Dahlin  <johan@gnome.org>
10135
10136         * *.h: Revert indent changes.
10137         
10138 2004-03-14  Thomas Vander Stichele  <thomas at apestaart dot org>
10139
10140         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load_plugin):
10141           g_error_free the g_error
10142         * tools/gst-feedback-m.m:
10143           check for other versions of gstreamer
10144         * tools/gst-indent:
10145           use sh, not bash
10146
10147 2004-03-14  Thomas Vander Stichele  <thomas at apestaart dot org>
10148
10149         * tools/gst-register.c: do not spill paths when registries are not
10150           writable, until we fix the "user running gst-register" case.
10151
10152 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
10153
10154         * *.c, *.h: commit of gst-indent run on core
10155
10156 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
10157
10158         * tools/gst-indent:
10159         * tools/Makefile.am:
10160           add our indentation style as a script
10161
10162 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
10163
10164         * po/sr.po:
10165         * po/LINGUAS:
10166           added Serbian translation
10167
10168 2004-03-13  Benjamin Otte  <otte@gnome.org>
10169
10170         * gst/gstelement.c:
10171           add documentation note about gst_element_found_tags_for_pad not
10172           being usable in getfunctions. (see #137042)
10173
10174 2004-03-12  David Schleef  <ds@schleef.org>
10175
10176         * gst/gstcaps.h: jdahlin, what are you smoking?  We can't just
10177         change API right now!  Readd gst_caps_is_simple() macro.
10178         * gst/gstelement.c: (gst_element_base_class_finalize): Fix
10179         uninitialized variable.  I'd bet this caused crashes.
10180         * gst/gstinfo.c: (gst_debug_print_object):  Fix 64-bit cleanliness.
10181
10182 2004-03-12  Johan Dahlin  <johan@gnome.org>
10183
10184         * gst/gstcaps.h (GST_CAPS_IS_SIMPLE): Capitalize macro
10185         * gst/gstcaps.h: Clean up
10186
10187         * gst/gst.c (init_post): call gst_caps_get_type() instead of
10188         _gst_caps_initalize()
10189
10190         * gst/gstcaps.c: Style fixes, stay closer to glib and friends
10191         (_gst_caps_initialize): Remove, in favor for gst_caps_get_type()
10192
10193         * gst/gststructure.c (gst_structure_get_type): Ditto
10194
10195         * gst/gststructure.h: Ditto
10196         
10197 2004-03-11  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10198
10199         * gst/gstqueue.c: (gst_queue_init):
10200           Reset default max. values in queues. Reason is simply to avoid
10201           braindead use. If you want wider values, use the properties. The
10202           default is supposed to always work. Wider values would make this
10203           beast a memory hog by default (250 full-PAL RGB32 video frames?
10204           That's 440 MB! No thank you).
10205
10206 2004-03-10  David Schleef  <ds@schleef.org>
10207
10208         * tools/gst-run.c: (main):  Fix crash when no relevant tools
10209         were found.  (bug #136793)
10210
10211 2004-03-10  Johan Dahlin  <johan@gnome.org>
10212
10213         * gst/schedulers/gstoptimalscheduler.c
10214         (gst_opt_scheduler_pad_unlink): Implement unlink for elements with
10215         links to elements within the same group, so we can finally remove
10216         that annoying warning. Refactor the code a little bit
10217         (group_dec_links_for_element): Split out
10218
10219 2004-03-09  David Schleef  <ds@schleef.org>
10220
10221         * docs/manual/dparams-app.xml:  Fix to handle double dparams.
10222         (bug #134863)
10223
10224 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
10225
10226         * configure.ac: first bug fix due to major/minor bump
10227
10228 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
10229
10230         * configure.ac: bump nano to 1
10231
10232 === release 0.7.6 ===
10233
10234 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
10235
10236         * NEWS:
10237         * RELEASE:
10238         * configure.ac:
10239           releasing 0.7.6, "Almost"
10240         * po/fr.po:
10241         * po/nl.po:
10242         * tools/Makefile.am:
10243         * tools/gst-feedback-m.m:
10244           unversioned source
10245
10246 2004-03-09  Johan Dahlin  <johan@gnome.org>
10247
10248         Reviewed by: Thomas Vander Stichele
10249
10250         * gst/gstelement.c (gst_element_class_init): register second
10251         parameter as GST_TYPE_G_ERROR instead of G_TYPE_POINTER, so
10252         language bindings can (de)marshall correctly.
10253
10254         * gst/gsterror.h: Add GST_TYPE_G_ERROR and cleanup a little bit
10255
10256         * gst/gsterror.c (gst_g_error_get_type): New function
10257
10258         * gst/gstmarshal.list: Remove VOID:OBJECT,POINTER,STRING, replace
10259         with VOID:OBJECT,OBJECT,STRING 
10260
10261 2004-03-10  Jan Schmidt  <thaytan@mad.scientist.com>
10262
10263         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load):
10264         Free a leaked g_timer on early returns.
10265
10266 2004-03-08  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10267
10268         * docs/pwg/advanced-types.xml:
10269           Add cinepak description.
10270
10271 2004-03-07  David Schleef  <ds@schleef.org>
10272
10273         * docs/random/mimetypes:  Added cinepak description
10274
10275 2004-03-07  Andy Wingo  <wingo@pobox.com>
10276
10277         * gst/gstbin.c (gst_bin_remove): Debugging fixes.
10278
10279         * gst/schedulers/gstoptimalscheduler.c (destroy_group): Assert
10280         there are no links to other groups when a group is destroyed.
10281         (gst_opt_scheduler_pad_unlink): If the unlink means an element is
10282         removed from a group, make sure the link count to elements linked
10283         to other pads is appropriately decremented. This really fixes
10284         #135672.
10285
10286         The 1.60->1.61 patch has been reapplied in light of this fix.
10287
10288         * gst/gstelement.c (gst_element_dispose): Really protect against
10289         multiple invocations this time.
10290
10291 2004-03-06  Thomas Vander Stichele  <thomas at apestaart dot org>
10292
10293         * docs/gst/gstreamer-sections.txt:
10294         * docs/gst/tmpl/gsttag.sgml:
10295           remove some deprecated functions, document some existing ones
10296         * gst/gsttag.c: (gst_tag_get_flag):
10297         * gst/gsttag.h:
10298           add accessor function
10299
10300 2004-03-06  Thomas Vander Stichele  <thomas at apestaart dot org>
10301
10302         * docs/gst/gstreamer-sections.txt:
10303         * docs/gst/tmpl/gsttag.sgml:
10304         * docs/gst/tmpl/gstxml.sgml:
10305         * gst/gsttag.c: (gst_tag_get_flag):
10306         * gst/gsttag.h:
10307
10308 2004-03-06  Christophe Fergeau  <teuf@gnome.org>
10309
10310         * gst/autoplug/gstspider.c: (gst_spider_identity_plug): fixed caps
10311         leak
10312
10313 2004-03-05  David Schleef  <ds@schleef.org>
10314
10315         * REQUIREMENTS: Add bison and flex.
10316         * configure.ac: Fix comment about bison.
10317         * docs/random/ds/0.9-suggested-changes: yer ma
10318         * tools/gst-inspect.c: (print_element_info):  Fix warning.
10319
10320 2004-03-05  Benjamin Otte  <otte@gnome.org>
10321
10322         * gst/gstelement.c: (gst_element_error_full):
10323           revert recent recursive state changing commit - messing with other
10324           elements' states is evil and should be done by apps only.
10325
10326 2004-03-05  Benjamin Otte  <otte@gnome.org>
10327
10328         * gst/gstelement.c: (gst_element_get_compatible_pad_template):
10329           check for empty intersection instead of NULL caps
10330         (gst_element_get_compatible_pad_filtered):
10331           remove old workaround that is only a bug nowadays
10332
10333 2004-03-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10334
10335         * gst/gstelement.c: (gst_element_error_full):
10336           make elements try to recursively change state to PAUSED on all
10337           parents after an error to suppress ensuing warnings
10338         * gst/parse/grammar.y:
10339           make it check if it was able to sync the state, and throw an error
10340           if not, so stuff like
10341           oggdemux ! vorbisdec ! osssink gets caught
10342
10343 2004-03-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10344
10345         * configure.ac: use ${libdir} for PLUGINS_DIR since on 64bit
10346           it contains lib64; use AS_AC_EXPAND to handle it properly
10347
10348 2004-03-05  David Schleef  <ds@schleef.org>
10349
10350         * gst/gstcpuid_i386.s:  Remove unused code
10351         * libs/gst/getbits/getbits.c: (gst_getbits_init),
10352         (gst_getbits_newbuf): Remove MMX code
10353         * libs/gst/getbits/getbits.h: Remove MMX code
10354
10355 2004-03-04  David I. Lehn  <dlehn@users.sourceforge.net>
10356
10357         * debian/.cvsignore:
10358         * debian/README.Debian:
10359         * debian/changelog:
10360         * debian/control:
10361         * debian/control.in:
10362         * debian/copyright:
10363         * debian/gstreamer-core-libs-dev.files:
10364         * debian/gstreamer-core-libs.files:
10365         * debian/gstreamer-core.files:
10366         * debian/gstreamer-core.postinst:
10367         * debian/gstreamer-core.postrm:
10368         * debian/gstreamer-doc.files:
10369         * debian/gstreamer-doc.links:
10370         * debian/gstreamer-doc.lintian:
10371         * debian/gstreamer-runtime.files:
10372         * debian/gstreamer-runtime.manpages:
10373         * debian/gstreamer-runtime.postinst:
10374         * debian/gstreamer-runtime.postrm:
10375         * debian/gstreamer-tools.files:
10376         * debian/gstreamer-tools.manpages:
10377         * debian/libgstreamer-dev.files:
10378         * debian/libgstreamer0.4.1.files:
10379         * debian/libgstreamerVERSION.files:
10380         * debian/rules:
10381         Debian package info not maintained here.
10382
10383 2004-03-04  Thomas Vander Stichele  <thomas at apestaart dot org>
10384
10385         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
10386         * gst/gstbin.c: (gst_bin_class_init):
10387         * gst/gstelement.c: (gst_element_class_init):
10388         * gst/gstindex.c: (gst_index_class_init):
10389         * gst/gstobject.c: (gst_object_class_init),
10390         (gst_signal_object_class_init):
10391         * gst/gstpad.c: (gst_pad_template_class_init):
10392         * gst/gstregistry.c: (gst_registry_class_init):
10393         * gst/gsturi.c: (gst_uri_handler_base_init):
10394         * gst/gstxml.c: (gst_xml_class_init):
10395         * libs/gst/control/dparam.c: (gst_dparam_class_init):
10396         * libs/gst/control/dparammanager.c: (gst_dpman_class_init):
10397           make all signal names use dashes instead of underscore
10398
10399 2004-03-03  Thomas Vander Stichele  <thomas at apestaart dot org>
10400
10401         * configure.ac: AC_SUBST GLIB_ONLY CFLAGS and LIBS
10402
10403 2004-03-03  Benjamin Otte  <otte@gnome.org>
10404
10405         * gst/schedulers/gstoptimalscheduler.c:
10406           revert last commit by Andy Wingo. It causes segfaults on unreffing
10407           in Rhythmbox. (see bug #135672)
10408
10409 2004-03-02  Christophe Fergeau  <teuf@gnome.org>
10410
10411         * po/fr.po: fix typo
10412
10413 2004-03-02  Christophe Fergeau  <teuf@gnome.org>
10414
10415         * tools/gst-inspect.c: (main): 
10416         * tools/gst-launch.c: (main): add calls to bind_textdomain_codeset
10417
10418 2004-03-02  Thomas Vander Stichele  <thomas at apestaart dot org>
10419
10420         * configure.ac:
10421           get GLIB_ONLY and POPT flags for the nonversioned binaries
10422         * tools/Makefile.am:
10423           use them
10424
10425 2004-03-02  Thomas Vander Stichele  <thomas at apestaart dot org>
10426
10427         * gst/gst.c: (init_post):
10428           change so that GST_REGISTRY now is where the global registry gets
10429           saved, since that is where plugins now get attached to first, and
10430           spilled over to the user registry.  Note that in the case of using
10431           GST_REGISTRY env var, we don't want to affect any real registries
10432           beyond the one given by this var, and thus we don't set a user
10433           registry to spill to.  So make sure GST_REGISTRY is writable.
10434
10435 2004-03-01  David Schleef  <ds@schleef.org>
10436
10437         * AUTHORS:  Added some names.  Add yourself if you're missing.
10438
10439 2004-03-01  David Schleef  <ds@schleef.org>
10440
10441         * MAINTAINERS: Add
10442
10443 2004-03-01  Thomas Vander Stichele  <thomas at apestaart dot org>
10444
10445         * configure.ac:
10446           remove whitespace
10447         * docs/gst/tmpl/gstbuffer.sgml:
10448         * docs/gst/tmpl/gstdata.sgml:
10449         * docs/gst/tmpl/gstreamer-unused.sgml:
10450         * docs/gst/tmpl/gstxml.sgml:
10451           doc update
10452         * docs/manuals.mak:
10453           add a FIXME
10454         * docs/pwg/intro-preface.xml:
10455         * docs/pwg/pwg.xml:
10456           remove GNOME
10457         * gst/gst.c: (init_post):
10458           try GST_PLUGIN_PATH paths for the _global_registry first
10459         * gst/gstelement.h:
10460           add the error message as well, otherwise (null) debug info doesn't
10461           make much sense
10462         * tools/gst-register.c: (main):
10463           spill paths to next registry if this registry is not writable
10464         * po/fr.po:
10465         * po/nl.po:
10466           translation updates
10467
10468 2004-03-01  Johan Dahlin  <johan@gnome.org>
10469
10470         * gst/gstbuffer.c (_gst_buffer_initialize): 
10471         * gst/gstdata.c (gst_data_get_type): 
10472         * gst/gstevent.c (_gst_event_initialize): Use gst_data_copy,
10473         instead of ref, since some applications that uses GBoxed
10474         routines depends on a function that actually returns a copy.
10475
10476 2004-02-27  Benjamin Otte  <otte@gnome.org>
10477
10478         * gst/gstbuffer.h:
10479           remove gst_buffer_free, use gst_data_unref
10480         * gst/gstdata.c: (gst_data_get_type):
10481           use refcounting in GstData GBoxed registration
10482         * gst/gstdata.h:
10483           remove gst_data_free, use gst_data_unref
10484
10485 2004-02-27  Johan Dahlin  <johan@gnome.org>
10486
10487         * gst/gstdata.c (gst_data_get_type): New function, register
10488         GstData as a GBoxed type.
10489
10490         * gst/gstdata.h (GST_TYPE_DATA): New macro
10491
10492 2004-02-27  Thomas Vander Stichele  <thomas at apestaart dot org>
10493
10494         * Makefile.am:
10495         * gstreamer.spec.in:
10496           put back RELEASE
10497         * gst/Makefile.am:
10498           clean up non-disting of built files
10499         * testsuite/debug/commandline.c:
10500           test fix for option rename
10501
10502 2004-02-26  David Schleef  <ds@schleef.org>
10503
10504         * configure.ac:  We don't really need glib-2.3.  Also remove
10505         some unneeded checks for library functions.
10506         * gst/Makefile.am:  Instead, we need to not dist files created
10507         by glib-genmarshal.
10508
10509 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10510
10511         * configure.ac:
10512           bump glib required version to 2.3.0 for g_value_takes_boxed
10513
10514  2004-02-25  Christian Fredrik Kalager Schaller <uraeus@gnome.org>
10515
10516         * common/m4/gst-docs.m4
10517         change flavour text from enable to disable as enable is our default
10518         closes bug Bug 135304
10519
10520 === release 0.7.5 ===
10521  
10522  2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10523  
10524         * NEWS:
10525           instate NEWS file
10526         * Makefile.am:
10527         * gstreamer.spec.in:
10528         * RELEASE:
10529           put back release
10530         * configure.ac:
10531         * docs/random/release:
10532           more updates
10533
10534 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10535
10536         * gst/gsttag.c: (_gst_tag_initialize):
10537         * po/fr.po:
10538         * po/nl.po:
10539           remove hyphen from codec tags
10540
10541 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10542
10543         * gst/parse/Makefile.am:
10544           fix dependency so that a make from a clean build works the first
10545           time
10546
10547 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10548
10549         * docs/random/release:
10550           update release strategy
10551         * po/fr.po:
10552           auto-update po file
10553         * po/nl.po:
10554           update dutch translation
10555
10556 2004-02-25  Thomas Vander Stichele  <thomas at apestaart dot org>
10557
10558         * docs/manual/debugging.xml:
10559         fix manual for new debugging system
10560
10561 2004-02-25  Andy Wingo  <wingo@pobox.com>
10562
10563         * gst/gstpad.c (gst_pad_link_prepare): Re-add
10564         gst_pad_link_prepare. Please email the list with specific reasons
10565         for reverting.
10566
10567 2004-02-24  Andy Wingo  <wingo@pobox.com>
10568
10569         * gst/gstelement.c (gst_element_dispose): Protect against multiple
10570         invocations.
10571
10572         * gst/schedulers/gstoptimalscheduler.c:
10573         I added a mess of prototypes at the top of the file by way of
10574         documentation. Some of the operations on chains and groups were
10575         re-organized.
10576
10577         (create_group): Added a type argument so if the group is enabled,
10578         the setup_group_scheduler knows what to do.
10579         (group_elements): Added a type argument here, too, to be passed on
10580         to create_group.
10581         (group_element_set_enabled): If an unlinked PLAYING element is
10582         added to a bin, we have to create a new group to hold the element,
10583         and this function will be called before the group is added to the
10584         chain. Thus we have a valid case for group->chain==NULL. Instead
10585         of calling chain_group_set_enabled, just set the flag on the group
10586         (the chain's status will be set when the group is added to it).
10587         (gst_opt_scheduler_state_transition, chain_group_set_enabled):
10588         Setup the group scheduler when the group is enabled, not
10589         specifically when an element goes PAUSED->PLAYING. This means
10590         PLAYING elements can be added, linked, and scheduled into a
10591         PLAYING pipeline, as was intended.
10592         (add_to_group): Don't ref the group twice. I don't know when this
10593         double-ref got in here. Removing it has the potential to cause
10594         segfaults if other parts of the scheduler are buggy. If you find
10595         that the scheduler is segfaulting for you, put in an extra ref
10596         here and see if that hacks over the underlying issue. Of course,
10597         then find out what code is unreffing a group it doesn't own...
10598         (create_group): Make the extra refcount floating, and remove it
10599         after adding the element. This means that...
10600         (unref_group): Destroy when the refcount reaches 0, not 1, like
10601         every other refcounted object in the known universe.
10602         (remove_from_group): When a group becomes empty, set it to be not
10603         active, and remove it from its chain. Don't unref it again,
10604         there's no floating reference any more.
10605         (destroy_group): We have to remove the group from the chain in
10606         remove_from_group (rather than here) to break refcounting cycles
10607         (the chain always has a ref on the group). So assert that
10608         group->chain==NULL.
10609         (ref_group_by_count): Removed, it was commented out anyway.
10610         (merge_chains): Use the remove_from_chain and add_to_chain
10611         primitives to do the reparenting, instead of rolling our own
10612         implementation.
10613         (add_to_chain): The first non-disabled group in the chain's group
10614         list will be the entry point for the chain. Because buffers can
10615         accumulate in loop elements' peer bufpens, we preferentially
10616         schedule loop groups before get groups to avoid unnecessary
10617         execution of get-based groups when the bufpens are already full.
10618         (gst_opt_scheduler_schedule_run_queue): Debug fixes.
10619         (get_group_schedule_function): Ditto.
10620         (loop_group_schedule_function): Ditto.
10621         (gst_opt_scheduler_loop_wrapper): Ditto.
10622         (gst_opt_scheduler_iterate): Ditto.
10623
10624         I understand the opt scheduler now, yippee!
10625
10626         * gst/gstpad.c: All throughout, added FIXMEs to look at for 0.9.
10627         (gst_pad_get_name, gst_pad_set_chain_function) 
10628         (gst_pad_set_get_function, gst_pad_set_event_function) 
10629         (gst_pad_set_event_mask_function, gst_pad_get_event_masks) 
10630         (gst_pad_get_event_masks_default, gst_pad_set_convert_function) 
10631         (gst_pad_set_query_function, gst_pad_get_query_types) 
10632         (gst_pad_get_query_types_default) 
10633         (gst_pad_set_internal_link_function) 
10634         (gst_pad_set_formats_function, gst_pad_set_link_function) 
10635         (gst_pad_set_fixate_function, gst_pad_set_getcaps_function) 
10636         (gst_pad_set_bufferalloc_function, gst_pad_unlink) 
10637         (gst_pad_renegotiate, gst_pad_set_parent, gst_pad_get_parent) 
10638         (gst_pad_add_ghost_pad, gst_pad_proxy_getcaps) 
10639         (gst_pad_proxy_pad_link, gst_pad_proxy_fixate) 
10640         (gst_pad_get_pad_template_caps, gst_pad_check_compatibility) 
10641         (gst_pad_get_peer, gst_pad_get_allowed_caps) 
10642         (gst_pad_alloc_buffer, gst_pad_push, gst_pad_pull) 
10643         (gst_pad_selectv, gst_pad_select, gst_pad_template_get_caps) 
10644         (gst_pad_event_default_dispatch, gst_pad_event_default) 
10645         (gst_pad_dispatcher, gst_pad_send_event, gst_pad_convert_default) 
10646         (gst_pad_convert, gst_pad_query_default, gst_pad_query) 
10647         (gst_pad_get_formats_default, gst_pad_get_formats): Better
10648         argument checks, and some doc fixes.
10649
10650         (gst_pad_custom_new_from_template): Um, does anyone
10651         use these functions? Actually make a custom pad instead of a
10652         normal one.
10653         (gst_pad_try_set_caps): Transpose some checks.
10654         (gst_pad_try_set_caps_nonfixed): Same, and use a macro to check if
10655         the pad is in negotiation.
10656         (gst_pad_try_relink_filtered): Use pad_link_prepare.
10657         
10658         * gst/gstelement.c: Remove prototypes also defined in gstclock.h.
10659
10660         * gst/gstelement.h: 
10661         * gst/gstclock.h: Un-deprecate the old clocking API, as discussed
10662         on the list.
10663
10664 2004-02-24  Thomas Vander Stichele  <thomas at apestaart dot org>
10665
10666         * gst/gstbin.c: (gst_bin_add):
10667           add error for not being able to add elements
10668
10669 2004-02-22  Julien MOUTTE <julien@moutte.net>
10670
10671         * gst/gsttag.c: (_gst_tag_initialize): Registering 2 new tags,
10672         audio-codec and video-codec.
10673
10674 2004-02-22  Benjamin Otte  <otte@gnome.org>
10675
10676         reported by: Padraig O'Briain <padraig.obriain@sun.com>
10677
10678         * autogen.sh:
10679           replace test -e with test -x for mkinstalldirs to be more portable.
10680           (fixes #134816)
10681
10682 2004-02-22  Benjamin Otte  <otte@gnome.org>
10683
10684         * gst/gstpad.c:
10685           revert last patch from Andy, it makes gst_pad_can_link_filtered much
10686           too noisy
10687         * gst/gsttag.c: (_gst_tag_initialize):
10688         * gst/gsttag.h:
10689           add GST_TAG_ALBUM_VOLUME_{COUNT,NUMBER}
10690         * libs/gst/control/dparam.c: (gst_dparam_attach):
10691         * libs/gst/control/dparammanager.c: (gst_dpman_attach_dparam):
10692           check that types for attached dparams match
10693
10694 2004-02-22  Thomas Vander Stichele  <thomas at apestaart dot org>
10695
10696         * gst/elements/gstfilesink.c: (gst_filesink_open_file):
10697         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
10698         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_open_file):
10699           fix errors
10700
10701 2004-02-20  Andy Wingo  <wingo@pobox.com>
10702
10703         * gst/gstbin.c:
10704         * gst/gstbuffer.c:
10705         * gst/gstplugin.c:
10706         * gst/registries/gstxmlregistry.c: 
10707         * gst/schedulers/gstoptimalscheduler.c: Debugging tweaks.
10708
10709         * gst/gstelement.c (gst_element_set_scheduler): Debugging fixes.
10710         (gst_element_add_pad): DEBUG->INFO, some fixes.
10711         (gst_element_get_compatible_pad_template): Just see if the
10712         templates' caps intersect, not if one is a strict subset of the
10713         other. This conforms more to what gst_pad_link_intersect() does.
10714         (gst_element_class_add_pad_template): Don't memcpy the pad
10715         template, just ref it.
10716         (gst_element_get_compatible_pad_filtered): Clean up debug messages
10717
10718         * gst/gstpad.c (gst_pad_can_link_filtered): Debug a true result.
10719         (gst_pad_link_filtered): Debug changes.
10720         (gst_pad_link_prepare): New function, consolidated from
10721         can_link_filtered and link_filtered.
10722
10723         * gst/parse/grammar.y (gst_parse_perform_link): Made INFO output
10724         look more like that of the functions in gstelement.c
10725
10726         * gst/gstinfo.c (gst_debug_print_object): Put a space before the
10727         object, and return the empty string if object is NULL.
10728
10729         * gst/parse/parse.l: Remove trailing newlines when calling PRINT.
10730         * gst/parse/grammar.y (YYFPRINTF): Log bison debugging info via
10731         LOG, not DEBUG. We still get flex info on debug.
10732
10733         * gst/registries/gstxmlregistry.c (gst_xml_registry_load): Make
10734         debug string more verbose.
10735         (plugin_times_older_than): DEBUG->LOG.
10736
10737 2004-02-20  Julien MOUTTE <julien@moutte.net>
10738
10739         * gst/gsttag.h: Adding video-codec and audio-codec for demuxers which
10740         will emit found_tag for each stream they demux with the codec.
10741
10742 2004-02-20  Benjamin Otte  <otte@gnome.org>
10743
10744         * gst/gstevent.c: (_gst_event_copy), (_gst_event_free):
10745           copy navigation event correctly. Check freeing tag lists. 
10746         * gst/gstthread.c: (gst_thread_change_state):
10747           don't abort() on state changing mess - it might happen because of
10748           bugs.
10749         * gst/gstvalue.c: (gst_value_set_caps), (gst_value_get_caps):
10750           use boxed functions
10751         * gst/gstvalue.h:
10752           fix GST_VALUE_HOLDS_CAPS
10753
10754 2004-02-19  David Schleef  <ds@schleef.org>
10755
10756         * gst/gstinfo.h:  Copy G_STRFUNC implementation from glib-2.4
10757         and use it for GST_FUNCTION.  (bug #134750)
10758
10759 2004-02-19  Thomas Vander Stichele  <thomas at apestaart dot org>
10760
10761         * po/fr.po:
10762         * po/nl.po:
10763           updating translations
10764
10765 2004-02-19  Thomas Vander Stichele  <thomas at apestaart dot org>
10766
10767         * tools/gst-run.c: (get_candidates), (main): some fixes from jdahlin
10768
10769 2004-02-18  kost@imn.htwk-leipzig.de
10770
10771         reviewed by: David Schleef  <ds@schleef.org>
10772
10773         * docs/libs/gstreamer-libs-sections.txt:  Add missing sections
10774         for libgstcontrol.
10775
10776 2004-02-18  David Schleef  <ds@schleef.org>
10777
10778         * libs/gst/control/dparam.c: (gst_dparam_class_init):
10779         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_class_init),
10780         (gst_dpsmooth_new): Additional fixes to get double dparams working.
10781         * tools/gst-inspect.c: (print_element_info): Support dumping of
10782         double dparam information.
10783
10784 2004-02-17  David Schleef  <ds@schleef.org>
10785
10786         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
10787         Use G_TYPE_STRING in signal prototype instead of G_TYPE_POINTER.
10788         * gst/elements/gsttypefind.c: (gst_type_find_element_class_init):
10789         Use GST_TYPE_CAPS in signal prototype.
10790         * gst/gstcaps.c: (_gst_caps_initialize), (gst_caps_copy_conditional):
10791         Convert GST_TYPE_CAPS to boxed.
10792         * gst/gstelement.c: (gst_element_class_init):
10793         Use GST_TYPE_TAG_LIST in signal prototype.
10794         * gst/gstindex.c: (gst_index_class_init):
10795         * gst/gstindex.h:
10796         Add GST_TYPE_INDEX_ENTRY type.
10797         * gst/gstmarshal.list:
10798         Add necessary marshal types.
10799         * gst/gstpad.c: (gst_real_pad_class_init),
10800         (_gst_real_pad_fixate_accumulator), (gst_pad_link_fixate),
10801         (gst_pad_recover_caps_error):
10802         Use GST_TYPE_CAPS in signal prototypes.  Fix some debugging strings.
10803         * gst/gststructure.c: (_gst_structure_initialize),
10804         (gst_structure_copy), (_gst_structure_copy_conditional):
10805         * gst/gststructure.h:
10806         Convert GST_TYPE_STRUCTURE to boxed.
10807         * gst/gsttag.c: (gst_tag_list_get_type):
10808         * gst/gsttag.h:
10809         Add GST_TYPE_TAG_LIST type.
10810
10811 2004-02-17  Julien MOUTTE  <julien@moutte.net>
10812
10813         * gst/gstpad.c: (gst_pad_try_set_caps): Reverting my change according
10814         to what we agreed with david.
10815         * gst/gstpad.h: adding GST_PAD_IS_NEGOTIATING macro.
10816
10817 2004-02-17  Thomas Vander Stichele  <thomas at apestaart dot org>
10818
10819         * po/nl.po: update translation
10820
10821 2004-02-17  Thomas Vander Stichele  <thomas at apestaart dot org>
10822
10823         * gst/autoplug/gstspider.c: (gst_spider_identity_plug):
10824           throw an error if spider is trying to play a mime type there is
10825           no decoder for
10826         * po/POTFILES.in:
10827           add gst/autoplug/gstspider.c for translation
10828
10829 2004-02-17  Julien MOUTTE  <julien@moutte.net>
10830
10831         * gst/gstpad.c: (gst_pad_try_set_caps): We are nice people. Return 
10832         silently when the pad is negotiating.
10833
10834 2004-02-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10835
10836         * docs/faq/Makefile.am:
10837           add script to run gstreamer uninstalled 
10838         * docs/faq/faq.xml:
10839         * docs/faq/developing.xml:
10840         * docs/faq/gst-uninstalled:
10841           extract script to run gstreamer uninstalled
10842         * docs/manuals.mak:
10843           add EXTRA_SOURCES variable for Makefile.am's to set to
10844           use additional SOURCE files for the doc build
10845
10846 2004-02-16  Thomas Vander Stichele  <thomas at apestaart dot org>
10847
10848         * gst/gstatomic_impl.h: Fedora 2 test package patch for S390
10849
10850 2004-02-15  Julien MOUTTE  <julien@moutte.net>
10851
10852         * gst/gstbin.c: (gst_bin_change_state), (gst_bin_iterate): Fix a big
10853         bug that was breaking pipelines like sinesrc ! { queue ! osssink } when
10854         an error was thrown by osssink. Basically a state change failure for
10855         an element in a different scheduling group was considered as
10856         successful, which means that caps nego was going on and weird stuff
10857         happened. Like I wrote in the comment there, if someone wants to
10858         revert that please drop me a mail explaining why because I really see
10859         no point in keeping that broken behaviour there.
10860         * gst/gstqueue.c: (gst_queue_get): Add a safety check as the queue CAN
10861         be empty, we then return NULL which will trigger a nice error when 
10862         pulling from the pad.
10863
10864 2004-02-13  David Schleef  <ds@schleef.org>
10865
10866         * libs/gst/control/dparam.c: (gst_dparam_class_init),
10867         (gst_dparam_get_property), (gst_dparam_set_property),
10868         (gst_dparam_do_update_default):
10869         * libs/gst/control/dparam.h:
10870         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_class_init),
10871         (gst_dpsmooth_new), (gst_dpsmooth_set_property),
10872         (gst_dpsmooth_get_property), (gst_dpsmooth_value_changed_double),
10873         (gst_dpsmooth_do_update_double):
10874         * libs/gst/control/dparam_smooth.h:
10875         * libs/gst/control/dparammanager.c:
10876         (gst_dpman_inline_direct_update):
10877         Add support for double dparams.
10878
10879 2004-02-13  David Schleef  <ds@schleef.org>
10880
10881         * gst/elements/gstfdsrc.c: (gst_fdsrc_get): Use GST_TIME_TO_TIMEVAL()
10882         * gst/gstclock.h: Avoid using 64-bit % operator (slow!)
10883
10884 2004-02-13  Mattias Wadman  <mattias@sudac.org>
10885
10886         reviewed by: David Schleef  <ds@schleef.org>
10887
10888         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init),
10889         (gst_fdsrc_init), (gst_fdsrc_set_property),
10890         (gst_fdsrc_get_property), (gst_fdsrc_get):
10891         * gst/elements/gstfdsrc.h:  Adds timeout property to fdsrc,
10892         and sends an EOS event if file descriptor reading times out.
10893
10894 2004-02-13  Thomas Vander Stichele  <thomas at apestaart dot org>
10895
10896         * configure.ac:
10897           add calls to AM_CONDITIONAL for subsystems for automake 1.6.x
10898
10899 2004-02-13  Thomas Vander Stichele  <thomas at apestaart dot org>
10900
10901         * configure.ac: pass required libxml version as argument
10902         (bug reported by Christophe Fergeau)
10903
10904 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10905   
10906         * docs/gst/gstreamer-docs.sgml:
10907         * docs/gst/tmpl/gstxml.sgml:
10908         * docs/libs/gstreamer-libs-docs.sgml:
10909           version API docs
10910
10911 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10912
10913         * gst/gstinfo.c:
10914         * gst/gstregistrypool.c: (gst_registry_pool_plugin_filter),
10915         (gst_registry_pool_feature_filter):
10916         * gst/gstthread.c: (gst_thread_class_init):
10917         * gst/gstvalue.c:
10918           add includes exposed by building without libxml
10919         * gst/indexers/Makefile.am:
10920           do not build fileindex when LOADSAVE disabled; we should have
10921           a better libxml check later since fileindex depends on xml, not
10922           LOADSAVE or REGISTRY
10923         * libs/gst/control/Makefile.am:
10924           link with m
10925         * tools/Makefile.am:
10926           fix wrong source code for gst-xmlinspect
10927
10928 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10929
10930         * configure.ac:
10931           fix gcov help output
10932           move calls to and use new GST_CHECK_DISABLE_SUBSYSTEM
10933         * docs/random/release:
10934           some updated releasing notes
10935         * gstreamer.spec.in:
10936           more updates
10937
10938 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10939
10940         * docs/faq/faq.xml:
10941         * docs/manual/manual.xml:
10942         * docs/pwg/pwg.xml:
10943         * docs/pwg/titlepage.xml:
10944           put version in documentation
10945
10946 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10947
10948         * tools/Makefile.am: fix man page installation
10949
10950 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10951
10952         * configure.ac:
10953           don't check for libxml when load/save and registry disabled (#105844)
10954         * gstreamer.spec.in:
10955           sync with fedora candidate spec
10956
10957 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
10958
10959         * po/fr.po:
10960         * po/nl.po:
10961           replace multidisksrc with multifilesrc
10962
10963 2004-02-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10964
10965         * po/POTFILES.in:
10966           update to multidisksrc => multifilesrc file renaming (#134145)
10967
10968 2004-02-11  David Schleef  <ds@schleef.org>
10969
10970         * docs/gst/tmpl/gstcaps.sgml:  Fix stuff that mentions GstProps
10971         * docs/gst/tmpl/gstpadtemplate.sgml: same
10972         * docs/gst/tmpl/gstreamer-unused.sgml: Remove GstProps
10973         * gst/gstobject.c: (gst_object_set_name_default): Do the memleak
10974         fixing dance.
10975         * gst/gstutils.c: Remove disabled code that uses GstProps.
10976         * gst/registries/gstxmlregistry.h: same
10977         * docs/random/ds/0.9-suggested-changes: random notes
10978
10979 2004-02-11  kost@imn.htwk-leipzig.de
10980
10981         reviewed by: David Schleef  <ds@schleef.org>
10982
10983         * gst/gstclock.c: (gst_clock_entry_new): fixes structure
10984         initialisation of clock (bug #134128)
10985
10986 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
10987
10988         * configure.ac:
10989         * gst/elements/Makefile.am:
10990         * gst/elements/gstelements.c:
10991         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_base_init),
10992         (gst_multifilesrc_class_init), (gst_multifilesrc_init),
10993         (gst_multifilesrc_set_property), (gst_multifilesrc_get_property),
10994         (gst_multifilesrc_get), (gst_multifilesrc_open_file),
10995         (gst_multifilesrc_close_file), (gst_multifilesrc_change_state):
10996         * gst/elements/gstmultifilesrc.h:
10997           rename multidisksrc to multifilesrc (part of #122200)
10998
10999 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
11000
11001         * docs/manuals.mak:
11002           fix automake complaints
11003         * gst-element-check.m4:
11004           fix unquotedness
11005
11006 2004-02-11  David Schleef  <ds@schleef.org>
11007
11008         * docs/gst/Makefile.am: Call gst_init() in built gstreamer-scan.
11009         * gst/gstatomic_impl.h: Disable sparc implementation.
11010
11011 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
11012
11013         * gst-element-check.m4:
11014           fix underquoted macros as reported by automake 1.8.x (#133800)
11015         * configure.ac:
11016           require gettext 0.11.5 so ulonglong.m4 gets checked out and copied
11017           by autopoint (fixes #132996)
11018
11019 2004-02-10  Andy Wingo  <wingo@pobox.com>
11020
11021         * gst/gstpad.c (gst_pad_custom_new): Add a FIXME, this is a hacky
11022         way to do inheritance.
11023         (gst_pad_get_event_masks, gst_pad_get_event_masks_default) 
11024         (gst_pad_get_query_types, gst_pad_get_query_types_default):
11025         Routine docs.
11026         (gst_pad_set_link_function, gst_pad_set_fixate_function) 
11027         (gst_pad_set_getcaps_function): Doc from Dave's negotation random
11028         doc.
11029         (gst_pad_unlink, gst_pad_is_linked): Docs.
11030         (gst_pad_renegotiate): A brief description of capsnego.
11031         (gst_pad_try_set_caps): Document.
11032         (gst_pad_try_set_caps_nonfixed): Document.
11033         (gst_pad_can_link_filtered, gst_pad_link_filtered): Doc fixes.
11034         (gst_pad_set_parent): Deprecated (although not out of the API).
11035         (gst_pad_get_parent): Deprecated, although many plugins use this.
11036         (gst_pad_add_ghost_pad, gst_pad_remove_ghost_pad): Doc that these
11037         are private and will go away in 0.9.
11038         (gst_pad_perform_negotiate): Doc.
11039         (gst_pad_link_unnegotiate): I think this is meant to be static.
11040         (gst_pad_get_negotiated_caps, gst_pad_get_pad_template_caps) 
11041         (gst_pad_template_get_caps_by_name, gst_pad_check_compatibility) 
11042         (gst_pad_get_peer): Doc updates.
11043         (gst_pad_caps_change_notify): Doc.
11044         (gst_pad_alloc_buffer, gst_pad_push, gst_static_pad_template_get) 
11045         (gst_ghost_pad_new): Doc fixes.
11046
11047         * gst/gstobject.c (gst_object_get_parent, gst_object_unparent) 
11048         (gst_object_check_uniqueness): 
11049
11050         * gst/gstelement.c (gst_element_add_pad) 
11051         (gst_element_add_ghost_pad, gst_element_remove_pad) 
11052         (gst_element_remove_ghost_pad, gst_element_get_pad) 
11053         (gst_element_get_static_pad, gst_element_get_pad_list) 
11054         (gst_element_class_get_pad_template_list) 
11055         (gst_element_class_get_pad_template): Work on the docs.
11056         (gst_element_get_pad_template_list): Uses the class method.
11057         (gst_element_get_compatible_pad_template): Docs, and consolidate
11058         some test conditions. 
11059         (gst_element_get_pad_from_template): New static function.
11060         (gst_element_request_compatible_pad): Docs, and work with
11061         non-request compatible templates. 
11062         (gst_element_get_compatible_pad_filtered): Docs and remove
11063         redundant checks.
11064         (gst_element_get_compatible_pad, gst_element_link_pads_filtered) 
11065         (gst_element_link_filtered, gst_element_link_many) 
11066         (gst_element_link, gst_element_link_pads) 
11067         (gst_element_unlink_many): Docs.
11068
11069 2004-02-05  Andy Wingo  <wingo@pobox.com>
11070
11071         * gst/gstpad.c (_gst_real_pad_fixate_accumulator):
11072         s/pointer/boxed/.
11073
11074         * gst/gstmarshal.list (VOID:BOXED, BOXED:BOXED): New marshallers.
11075
11076         * gst/gstpad.c (gst_real_pad_class_init): Use a BOXED:BOXED
11077         marshaller for ::fixate, and VOID:BOXED for ::caps-nego-failed,
11078         with the type=GST_TYPE_CAPS. This allows language bindings to know
11079         what kind of data they're dealing with.
11080
11081         * gst/gstcaps.c (_gst_caps_value_init): GBoxed values initialize
11082         to NULL when g_value_init is called. GstCaps, which rolls its own
11083         type implementation, now does the same instead of allocating empty
11084         caps.
11085         (_gst_caps_initialize, _gst_caps_collect_value,
11086         _gst_caps_lcopy_value): Provide collect_value and lcopy_value type
11087         table methods. This allows G_VALUE_COLLECT to work.
11088
11089 2004-02-05  Andy Wingo  <wingo@pobox.com>
11090
11091         * configure.ac:
11092         * testsuite/Makefile.am (SUBDIRS): 
11093         * testsuite/ghostpads/Makefile.am: 
11094         * testsuite/ghostpads/ghostpads.c: A new test for ghost pads.
11095
11096         * gst/gstpad.c (gst_pad_add_ghost_pad, gst_pad_remove_ghost_pad):
11097         These two routines are the only ones that set
11098         GST_GPAD_REALPAD(gpad), the ghost pad list, and the ghost pad's
11099         pad template. They should be made static, depending on ABI needs.
11100         (gst_real_pad_dispose): Handle the case of ghost pads without a
11101         parent. Assert after dealing with ghost pads that the ghost pad
11102         list is empty.
11103         (gst_ghost_pad_class_init): New property added, ::real-pad. Can be
11104         set after creation.
11105         (gst_ghost_pad_dispose): Set ::real-pad to NULL.
11106         (gst_ghost_pad_set_property, gst_ghost_pad_get_property): New
11107         functions. set_property will call add_ghost_pad/remove_ghost_pad
11108         as appropriate.
11109         (gst_ghost_pad_new): All the work is offloaded to g_object_new.
11110
11111         * gst/gstelement.c (gst_element_add_pad): Handle ghost pads as well.
11112         (gst_element_add_ghost_pad): Remove code duplicated from _add_pad.
11113         (gst_element_remove_pad): Handle ghost pads as well.
11114         (gst_element_remove_ghost_pad): Deprecated (could be removed,
11115         depending on API-stability needs).
11116
11117 2004-02-05  Andy Wingo  <wingo@pobox.com>
11118
11119         * gst/gstbin.[ch]: (gst_bin_get_by_interface): GTypes are scalars,
11120         of course they're const
11121
11122 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
11123
11124         * tools/Makefile.am:
11125         * tools/gst-feedback:
11126         * tools/gst-feedback-0.7:
11127           make gst-feedback versioned too for consistency
11128
11129 2004-02-11  David Schleef  <ds@schleef.org>
11130
11131         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
11132         (gst_pad_try_set_caps): Fix format strings for GST_PTR_FORMAT.
11133
11134 2004-02-10  Julien MOUTTE <julien@moutte.net>
11135
11136         * gst/gstevent.c: (_gst_event_free): Sometimes a tag event arrives but
11137         the structure does not contain a valid tag list. Adding a safety check
11138         to remove a noisy warning in that case.
11139
11140 2004-02-10  Thomas Vander Stichele  <thomas at apestaart dot org>
11141
11142         * gst/gst.c: fix name to be in line with others
11143
11144 2004-02-09  Julien MOUTTE <julien@moutte.net>
11145
11146         * libs/gst/bytestream/bytestream.c: (gst_bytestream_peek): We should
11147         not shout that loud when len is 0. Just return 0 silently.
11148
11149 2004-02-09  Julien MOUTTE  <julien@moutte.net>
11150
11151         * gst/gstdata.c: (gst_data_ref): Adding a categorized debug on data_ref
11152         because data_unref has one and I prefer the debug to be symetric.
11153         * gst/gstqueue.c: (gst_queue_locked_flush): Fix a huge memleak. Buffers
11154         were refed when added to the queue and unrefed only once when the queue
11155         was flushed. Now the flush handler unref the buffers two times : first
11156         unref for the ref added when pushing in the queue's tail and second
11157         unref to destroy the flushed buffer.
11158
11159 2004-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
11160
11161         * docs/pwg/building-boiler.xml: fix cvs checkout documentation
11162
11163 2004-02-06  David Schleef  <ds@schleef.org>
11164
11165         * docs/random/ds/0.9-suggested-changes: Random ramblings
11166         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap): Cast size_t
11167         to int before printing.
11168         * gst/parse/grammar.y: Fix gcc-2.95 style variadic macros.
11169         * gst/parse/parse.l: same.  See bug #129600
11170
11171 2004-02-06  David Schleef  <ds@schleef.org>
11172
11173         * gst/gstindex.c: (gst_index_add_format), (gst_index_add_id),
11174         (gst_index_add_entry), (gst_index_add_associationv),
11175         (gst_index_add_association): Add gst_index_add_associationv()
11176         and clean up gst_index_add_association(). #127133
11177
11178 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11179
11180         * autogen.sh: check out common with right tag if CVS/Tag exists
11181
11182 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11183
11184         * testsuite/ghostpads/ghostpads.c: (main):
11185           fix testsuite from segfaulting
11186
11187 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11188
11189         * Makefile.am: add release target
11190         * configure.ac: bump nano to 1
11191         * docs/random/release:
11192
11193 2004-02-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11194
11195         * gst/gstcaps.h:
11196         * gst/gstelement.c: (gst_element_base_class_init),
11197         (gst_element_class_set_details), (gst_element_clear_pad_caps):
11198         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
11199         (gst_pad_try_set_caps), (gst_pad_can_link_filtered),
11200         (gst_real_pad_dispose):
11201         * gst/gststructure.c: (gst_structure_free),
11202         (gst_structure_from_string):
11203           put reverted patch back in
11204         * gst/gstelement.c: (gst_element_remove_pad):
11205           free explicit caps if they're set
11206         * gst/gstpad.c: (_gst_pad_default_fixate_func):
11207           copy the structure when fixating
11208
11209 2004-02-05  David Schleef  <ds@schleef.org>
11210
11211         * gst/gstmarshal.list:
11212         * gst/gstpad.c: (gst_real_pad_class_init),
11213         (_gst_real_pad_fixate_accumulator):
11214         Revert POINTER->BOXED change in signal marshaller.
11215
11216 === release 0.7.4 ===
11217                                                                                 
11218 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
11219                                                                                 
11220         * NEWS: GStreamer 0.7.4 "Wooden Eels" released
11221         * configure.ac: changed for release
11222
11223 2004-02-05  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
11224
11225         * gstreamer.spec.in:
11226           bump required version of gtk-doc
11227
11228 2004-02-05  Thomas Vander Stichele  <thomas at apestaart dot org>
11229
11230         * gst/gstcaps.h:
11231         * gst/gstelement.c: (gst_element_base_class_init),
11232         (gst_element_class_set_details), (gst_element_clear_pad_caps):
11233         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
11234         (gst_pad_try_set_caps), (gst_pad_can_link_filtered),
11235         (gst_real_pad_dispose):
11236         * gst/gststructure.c: (gst_structure_free),
11237         (gst_structure_from_string):
11238           revert patch that breaks applications, reapply after release
11239           to get this fixed properly
11240
11241 2004-02-05  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11242
11243         * gst/gsttag.c: (_gst_tag_initialize):
11244         * gst/gsttag.h:
11245           remove duplicated field GST_TAG_APPLICATION. It's GST_TAG_ENCODER
11246
11247 2004-02-04  David Schleef  <ds@schleef.org>
11248
11249         Fix some memleaks:
11250         * gst/autoplug/gstspider.c: (gst_spider_request_new_pad),
11251         (gst_spider_plug_from_srcpad):
11252         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link):
11253
11254 2004-02-04  David Schleef  <ds@schleef.org>
11255
11256         * gst/gstelement.c: (gst_element_clear_pad_caps): Make sure we have
11257         a GstRealPad before accessing its structure members.
11258
11259 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11260
11261         * gst/gstclock.c: (gst_clock_init), (gst_clock_set_speed),
11262         (gst_clock_get_speed):
11263         * gst/gstclock.h:
11264           reset padding, remove unused fields
11265
11266 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11267
11268         * gst/autoplug/gstspideridentity.c:
11269         (gst_spider_identity_sink_loop_type_finding):
11270           use get_allowed_caps, not get_caps (fixes #132519)
11271         * gst/elements/gsttypefind.c: (stop_typefinding):
11272           use correct order when sending buffers and seeking
11273
11274 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
11275
11276         * configure.ac:
11277         * gst/gstelement.h:
11278         * gst/gstpad.h:
11279         * gst/gstqueue.h:
11280           upgrade libtool CURRENT, reset padding
11281
11282 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
11283
11284         * configure.ac:
11285           bump to prerelease
11286           put back AM_PROG_LIBTOOL to make libtoolize stop complaining
11287
11288 2004-02-04  David Schleef  <ds@schleef.org>
11289
11290         * docs/random/ds/0.9-suggested-changes: random notes
11291         * gst/elements/gstfakesrc.c: (gst_fakesrc_get_formats),
11292         (gst_fakesrc_get_query_types), (gst_fakesrc_get_event_mask):
11293         Replace GST_PAD_EVENT_MASK_FUNCTION() (et al.) with its
11294         expansion.
11295         * gst/elements/gstfilesink.c: (gst_filesink_get_formats),
11296         (gst_filesink_get_query_types): same
11297         * gst/elements/gstfilesrc.c: (gst_filesrc_get_event_mask),
11298         (gst_filesrc_get_query_types), (gst_filesrc_get_formats): same
11299         * gst/gstcaps.h: deprecate GST_DEBUG_CAPS(), and fix the macro
11300         to use new GST_PTR_FORMAT.
11301         * gst/gstelement.h: deprecate function factory macros
11302         GST_ELEMENT_QUERY_TYPE_FUNCTION(), GST_ELEMENT_EVENT_MASK_FUNCTION().
11303         These are our last variadic macros that can't be replaced with
11304         inlines.  Celebrate!  Also fix a typo in an #ifdef that was
11305         attempting to deprecate gst_element_clock_wait().
11306         * gst/gstevent.h: same
11307         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
11308         (gst_pad_try_set_caps): replace GST_DEBUG_CAPS() with GST_DEBUG()
11309         * gst/gstpad.h: deprecate function factory macros similar to above.
11310
11311 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
11312
11313         * configure.ac:
11314         * tools/Makefile.am:
11315         * tools/gst-run.c: (popt_callback), (hash_print_key),
11316         (find_highest_version), (unmangle_libtool), (get_dir_of_binary),
11317         (get_candidates), (main):
11318           add new source file to generate non-versioned wrapper binaries
11319           for our tools.
11320
11321 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11322
11323         * gst/gstevent.c: (_gst_event_free):
11324           actually break; inside the switch statement
11325         * gst/parse/grammar.y:
11326           fix memleak where GValues weren't unset
11327
11328 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11329
11330         * gst/gststructure.c: (gst_structure_from_string):
11331           fix huge memleak
11332         * gst/elements/gsttypefind.c: (gst_type_find_element_have_type),
11333         (new_entry), (gst_type_find_element_chain):
11334         * gst/gstelement.c: (gst_element_base_class_init),
11335         (gst_element_class_set_details):
11336         * gst/gstpad.c: (gst_pad_can_link_filtered):
11337           fix smaller memleaks
11338         * gst/gstpad.c: (gst_real_pad_dispose):
11339           check that explicit caps are gone
11340         * gst/gststructure.c: (gst_structure_free):
11341           actually free the structure
11342         * gst/gstelement.c: (gst_element_clear_pad_caps):
11343           unset explicit caps
11344
11345 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
11346
11347         * tools/Makefile.am:
11348           use AM_CFLAGS since all the CFLAGS are the same
11349           use AM_LDFAGS
11350
11351 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
11352
11353         * docs/manual/gnome.xml:
11354           expand example a little
11355         * gst/gst.c: (gst_init_with_popt_table),
11356         (gst_init_check_with_popt_table), (init_pre), (init_popt_callback):
11357           make sure popt option displays are done with right textdomain
11358           use GstPoptOption type
11359         * gst/gst.h:
11360           create GstPoptOption type
11361
11362 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
11363
11364         * gst/gsterror.c: (_gst_stream_errors_init):
11365         * gst/gsterror.h:
11366           adding error type for no codec
11367         * po/POTFILES.in:
11368           add gst-inspect
11369         * po/nl.po:
11370           update dutch translation
11371         * tools/gst-inspect.c: (print_element_list), (main):
11372           do proper internationalization
11373         * tools/gst-launch.c: (idle_func):
11374           remove commented out function call
11375
11376 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
11377
11378         * docs/README:
11379           add some error fixing notes
11380         * docs/gst/gstreamer-sections.txt:
11381           remove double entries
11382         * docs/gst/tmpl/gstbin.sgml:
11383         * docs/gst/tmpl/gstclock.sgml:
11384           remove override
11385         * docs/gst/tmpl/gstelement.sgml:
11386         * docs/gst/tmpl/gstindex.sgml:
11387         * docs/gst/tmpl/gstobject.sgml:
11388         * docs/gst/tmpl/gstpadtemplate.sgml:
11389         * docs/gst/tmpl/gstreamer-unused.sgml:
11390         * docs/gst/tmpl/gsttag.sgml:
11391         * docs/gst/tmpl/gstthread.sgml:
11392         * docs/gst/tmpl/gstxml.sgml:
11393         * gst/gsttag.h:
11394           sync header prototypes with c decls
11395         * gst/gsttaginterface.c:
11396           fix doc headers
11397
11398 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11399
11400         * gst/parse/Makefile.am:
11401         * gst/gstobject.h:
11402           get rid of gstmarshal.h dependency. It's not needed.
11403         * gst/gst.h:
11404         * gst/elements/gstfakesink.c:
11405         * gst/elements/gstfakesrc.c:
11406         * gst/elements/gstidentity.c:
11407         * gst/gstbin.c:
11408         * gst/gstelement.c:
11409         * gst/gstindex.c:
11410         * gst/gstobject.c:
11411         * gst/gstpad.c:
11412         * gst/gstthread.c:
11413         * gst/gstxml.c:
11414         * libs/gst/control/dparam.c:
11415         * libs/gst/control/dparammanager.c:
11416           include gstmarshal.h.
11417         Fixes #132045
11418
11419 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11420
11421         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
11422         (gst_filesrc_dispose), (gst_filesrc_free_parent_mmap),
11423         (gst_filesrc_map_region), (gst_filesrc_get_mmap):
11424         * gst/elements/gstfilesrc.h:
11425           don't ref the filesrc when creating mmaped buffers. Don't keep a
11426           list of not-yet-destroyed buffers.
11427         * gst/gstbuffer.h:
11428           Deprecated BST_BUFFER_FREE_FUNC and GST_BUFFER_COPY_FUNC
11429
11430 2004-02-02  Thomas Vander Stichele  <thomas at apestaart dot org>
11431
11432         * gst/gst.c: (init_pre):
11433           remove textdomain
11434
11435 2004-02-02  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11436
11437         * docs/pwg/advanced-events.xml:
11438         * docs/pwg/advanced-scheduling.xml:
11439         * docs/pwg/intro-basics.xml:
11440         * docs/pwg/other-manager.xml:
11441         * docs/pwg/other-nton.xml:
11442         * docs/pwg/other-ntoone.xml:
11443         * docs/pwg/other-oneton.xml:
11444         * docs/pwg/pwg.xml:
11445           All sort of documentation... Forgot what. Point is that I want this
11446           in before I leave. The 'other-*' will be the last section and will
11447           explain issues specific to these type of elements.
11448
11449 2004-02-02  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11450
11451         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
11452         (gst_filesrc_get_read):
11453           set all the values on buffers that we can
11454
11455 2004-02-02  David Schleef  <ds@schleef.org>
11456
11457         Change usage of isblah() to g_ascii_isblah() to be more locale
11458         independent.  (#133076)
11459         * gst/gsturi.c: (gst_uri_protocol_check_internal):
11460         * gst/gstutils.c:
11461         * gst/parse/parse.l:
11462
11463 2004-02-02  Jon Trowbridge  <trow@gnu.org>
11464
11465         reviewed by: David Schleef  <ds@schleef.org>
11466
11467         Fix memory leaks:
11468         * gst/gstcaps.c: (gst_caps_to_string):
11469         * gst/registries/gstxmlregistry.c:
11470         (gst_xml_registry_add_path_list_func),
11471         (gst_xml_registry_parse_padtemplate):
11472
11473 2004-02-02  Thomas Vander Stichele  <thomas at apestaart dot org>
11474
11475         * gst/gstelement.c: (gst_element_default_error):
11476           suffix error messages with period
11477
11478 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
11479
11480         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
11481         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
11482         * gst/gsterror.c: (gst_error_get_message):
11483           Suffix with dots
11484         * po/fr.po:
11485         * po/nl.po:
11486           Update translation files
11487
11488 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
11489
11490         * gst/autoplug/gstspideridentity.c:
11491         (gst_spider_identity_sink_loop_type_finding):
11492         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
11493         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
11494         (gst_filesink_close_file), (gst_filesink_handle_event),
11495         (gst_filesink_chain):
11496         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
11497         (gst_filesrc_get_read), (gst_filesrc_open_file):
11498         * gst/elements/gstidentity.c: (gst_identity_chain):
11499         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
11500         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
11501         (gst_pipefilter_chain), (gst_pipefilter_open_file):
11502         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
11503         * gst/gsterror.c: (_gst_core_errors_init),
11504         (_gst_library_errors_init), (_gst_resource_errors_init),
11505         (_gst_stream_errors_init), (gst_error_get_message):
11506         * gst/gstpad.c: (gst_pad_set_explicit_caps),
11507         (gst_pad_recover_caps_error), (gst_pad_pull):
11508         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
11509         * gst/schedulers/gstbasicscheduler.c:
11510         (gst_basic_scheduler_chainhandler_proxy),
11511         (gst_basic_scheduler_gethandler_proxy),
11512         (gst_basic_scheduler_cothreaded_chain):
11513           Suffix error messages with period.
11514           Use (NULL) instead of NULL
11515
11516 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
11517
11518         * docs/gst/tmpl/gstelement.sgml:
11519         * docs/gst/tmpl/gstxml.sgml:
11520         * gst/gstelement.c: (gst_element_error_full):
11521           add element path to error
11522
11523 2004-01-31  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11524
11525         * docs/random/mimetypes:
11526           update raw int/float info
11527         * gst/gsttag.c: (_gst_tag_initialize):
11528         * gst/gsttag.h:
11529           add GST_TAG_ENCODER
11530
11531 2004-01-30  David Schleef  <ds@schleef.org>
11532
11533         * gst/cothreads.c: Add another fallback if MAP_ANONYMOUS is
11534           missing (#132991)
11535
11536 2004-01-30  Laurent Vivier <Laurent.Vivier@bull.net>
11537
11538         reviewed by Benjamin Otte 
11539           parts of the patch submitted in bug #113913
11540
11541         * configure.ac:
11542           use AC_C_INLINE. Use = instead of == with test
11543         * examples/plugins/example.c:
11544         * gst/autoplug/gstspideridentity.c:
11545         * gst/elements/gstfdsrc.c:
11546         * gst/elements/gstfilesrc.c:
11547         * gst/elements/gstidentity.c:
11548         * gst/elements/gstmultidisksrc.c:
11549         * gst/elements/gststatistics.c:
11550         * gst/gstelement.c:
11551         * gst/gstobject.c:
11552         * gst/gstpad.c:
11553         * gst/gstpipeline.c:
11554         * gst/gstthread.c:
11555           don't end enums with a comma
11556         * gst/gstindex.c: (gst_index_compare_func):
11557           do explicit casting to gint
11558         * gst/gsttrace.c: (gst_trace_text_flush):
11559           #define strsize as a macro
11560
11561 2004-01-30  Thomas Vander Stichele  <thomas at apestaart dot org>
11562
11563         * docs/README:
11564         * docs/gst/gstreamer-docs.sgml:
11565         * docs/gst/gstreamer-sections.txt:
11566         * docs/gst/tmpl/gstelement.sgml:
11567         * docs/gst/tmpl/gsterror.sgml:
11568         * docs/gst/tmpl/gstinterface.sgml:
11569         * docs/gst/tmpl/gstreamer-unused.sgml:
11570         * docs/gst/tmpl/gststructure.sgml:
11571         * docs/gst/tmpl/gsttag.sgml:
11572         * docs/gst/tmpl/gsttaginterface.sgml:
11573         * docs/gst/tmpl/gstvalue.sgml:
11574         make sure all API ends up in the built docs
11575         * gst/gstinterface.c:
11576         * gst/gststructure.c: (gst_structure_id_set_value),
11577         (gst_structure_set_value), (gst_structure_id_get_value):
11578         * gst/gststructure.h:
11579         * gst/gstvalue.h:
11580         sync .h with .c declarations
11581
11582 2004-01-30  Julien Moutte  <julien@moutte.net>
11583
11584         * libs/gst/bytestream/bytestream.c: Reverting my event handling patch.
11585         Ronald will fix riffread.
11586
11587 2004-01-30  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11588
11589         * docs/pwg/advanced-interfaces.xml:
11590           Added tuner interface docs.
11591
11592 2004-01-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11593
11594         * docs/random/mimetypes:
11595           correct Theora information
11596         * gst/gstelement.h:
11597           make GST_ELEMENT_ERROR do a GST_ERROR_OBJECT
11598
11599 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
11600
11601         * gst/gstelement.c: (gst_element_error_full):
11602         * gst/gstelement.h:
11603           GST_ELEMENT_ERROR in enum -> _IN_ERROR
11604
11605 2004-01-29  Julien MOUTTE  <julien@moutte.net>
11606
11607         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
11608         (gst_filesrc_uri_handler_init): Fixing seeking by making FLUSH happen
11609         again and even before DISCONT.
11610         * gst/gstpad.c: (gst_pad_event_default): Remove a unused switch case.
11611         * libs/gst/bytestream/bytestream.c: (gst_bytestream_get_next_buf): Fix
11612         bytestream so that it's not stopping to fill the bytestream if events
11613         different than EOS or DISCONT are received. Instead it process them so
11614         that they go downstream.
11615
11616 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
11617
11618         * docs/gst/tmpl/gstelement.sgml:
11619         * docs/gst/tmpl/gstreamer-unused.sgml:
11620         * docs/gst/tmpl/gstxml.sgml:
11621         * gst/autoplug/gstspideridentity.c:
11622         (gst_spider_identity_sink_loop_type_finding):
11623         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
11624         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
11625         (gst_filesink_close_file), (gst_filesink_handle_event),
11626         (gst_filesink_chain):
11627         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
11628         (gst_filesrc_get_read), (gst_filesrc_open_file):
11629         * gst/elements/gstidentity.c: (gst_identity_chain):
11630         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
11631         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
11632         (gst_pipefilter_chain), (gst_pipefilter_open_file):
11633         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
11634         * gst/gstelement.h:
11635         * gst/gstpad.c: (gst_pad_set_explicit_caps),
11636         (gst_pad_recover_caps_error), (gst_pad_pull):
11637         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
11638         * gst/schedulers/gstbasicscheduler.c:
11639         (gst_basic_scheduler_chainhandler_proxy),
11640         (gst_basic_scheduler_gethandler_proxy),
11641         (gst_basic_scheduler_cothreaded_chain):
11642           gst_element_error -> GST_ELEMENT_ERROR
11643
11644 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
11645
11646         * docs/Makefile.am:
11647         * docs/gst/tmpl/gstelement.sgml:
11648         * docs/gst/tmpl/gstxml.sgml:
11649         * docs/manuals.mak:
11650         * docs/pwg/advanced-request.xml:
11651         * docs/pwg/advanced-scheduling.xml:
11652         * docs/pwg/advanced-tagging.xml:
11653           fix non-validating docbook using CDATA
11654           make sure make check-local gets run first to check if it validates
11655
11656 2004-01-29  Julien MOUTTE <julien@moutte.net>
11657
11658         * docs/pwg/advanced-events.xml: Adding documentation on advanced event
11659         handling (up and downstream).
11660         * docs/pwg/advanced-interfaces.xml: Make it coherent with the
11661         my_filter thing.
11662
11663 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11664
11665         * docs/pwg/advanced-tagging.xml:
11666           Add docs about tag writing.
11667
11668 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11669
11670         * docs/pwg/advanced-tagging.xml:
11671           Add a part about tag reading and application signalling... Tag
11672           writing still needs to be documented.
11673         * gst/elements/gstfilesrc.c: (gst_filesrc_set_location):
11674           We can set file locations in READY, too.
11675
11676 2004-01-29  Julien MOUTTE <julien@moutte.net>
11677
11678         * docs/random/ds/element-checklist: Adding some notes about src
11679         events.
11680
11681 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11682
11683         * docs/random/mimetypes:
11684           Update docs to point to correct elements for various mimetypes, and
11685           some more errors pointed out by Stéphane LOEUILLET (aka LeRoutier)
11686           <stephane.loeuillet@tiscali.fr>.
11687
11688 2004-01-28  David Schleef  <ds@schleef.org>
11689
11690         * docs/pwg/intro-basics.xml: rewrite bufferpool stuff.
11691
11692 2004-01-29  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11693
11694         * docs/random/mimetypes:
11695           update docs for audio/x-raw-float. Add "buffer-frames=0 means
11696           undefined"
11697         * gst/elements/gstfilesrc.c: (gst_filesrc_set_location):
11698           make it only work in NULL.
11699         * gst/gstcaps.c:
11700           don't posion NULL caps
11701         * gst/gstelement.c: (gst_element_set_time):
11702           add debugging statement
11703         * gst/gstelement.c: (gst_element_emit_found_tag),
11704         (gst_element_found_tag_func), (gst_element_found_tags):
11705         * gst/gstelement.h:
11706           These functions take const taglists
11707         * gst/gstpad.c: (gst_pad_proxy_getcaps):
11708           fix memleak
11709         * gst/gstpad.c: (gst_pad_event_default):
11710           make more effort on handling discont and clocks, g_warn if everything
11711           fails
11712         * gst/gststructure.c: (gst_structure_remove_fields),
11713         (gst_structure_remove_fields_valist):
11714         * gst/gststructure.h:
11715           add gst_structure_remove_fields(_valist)
11716         * gst/gsttag.c:
11717           fix doc glitch
11718
11719 2004-01-28  David Schleef  <ds@schleef.org>
11720
11721         * docs/random/ds/element-checklist: Notes about gst_caps_to_string()
11722         * gst/registries/gstxmlregistry.c: (gst_xml_registry_save_caps):
11723         Fix memory leakage of gst_caps_to_string().
11724
11725         Use GST_PTR_FORMAT instead of gst_caps_to_string():
11726         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_sp):
11727         * gst/autoplug/gstspideridentity.c: (spider_find_suggest),
11728         (gst_spider_identity_sink_loop_type_finding):
11729         * gst/elements/gsttypefind.c: (gst_type_find_element_have_type),
11730         (find_suggest):
11731         * gst/gstpad.c: (gst_pad_try_relink_filtered),
11732         (gst_pad_set_explicit_caps):
11733         * gst/parse/grammar.y:
11734
11735 2004-01-28  David Schleef  <ds@schleef.org>
11736
11737         * configure.ac: Add detection for HAVE_PRINTF_EXTENSION and
11738         GST_PRINTF_EXTENSION_FORMAT_DEFINE.
11739         * docs/random/ds/0.9-suggested-changes: Notes from Company.
11740         * gst/gstcaps.c: (gst_caps_to_string): Add comment.
11741         * gst/gstconfig.h.in: Add define for GST_PTR_FORMAT
11742         * gst/gstinfo.c: (_gst_debug_init), (gst_debug_print_object),
11743         (gst_debug_log_default), (_gst_info_printf_extension),
11744         (_gst_info_printf_extension_arginfo):  Add printf extension.
11745         * gst/gstinfo.h: remove G_GNUC_PRINTF, because it doesn't work with %P
11746         * gst/gststructure.c: (gst_structure_to_string),
11747         (_gst_structure_parse_value): Use gst_value_deserialize() and
11748         remove old code.
11749         * gst/gstvalue.c: (gst_value_deserialize_fourcc),
11750         (gst_value_deserialize_boolean), (gst_strtoi),
11751         (gst_value_deserialize_int), (gst_value_deserialize_double),
11752         (gst_value_deserialize_string), (gst_value_deserialize): Implement
11753         a bunch of deserialize functions and gst_value_deserialize.
11754         * gst/gstvalue.h: er, _de_serialize, not unserialize
11755         * testsuite/caps/string-conversions.c: (main): We don't currently
11756         handle (float) in caps, so convert these to (double).
11757         * testsuite/debug/Makefile.am: Add new test for the printf extension
11758         * testsuite/debug/printf_extension.c: (main): same
11759
11760 2004-01-28  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11761
11762         * docs/random/company/time:
11763           Add some docs about clocking and time
11764
11765 2004-01-28  Julien MOUTTE <julien@moutte.net>
11766
11767         * docs/pwg/advanced-interfaces.xml: Adding XOverlay documentation.
11768
11769 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11770
11771         * docs/pwg/advanced-clock.xml:
11772         * docs/pwg/advanced-dparams.xml:
11773         * docs/pwg/advanced-events.xml:
11774         * docs/pwg/advanced-interfaces.xml:
11775         * docs/pwg/advanced-midi.xml:
11776         * docs/pwg/advanced-request.xml:
11777         * docs/pwg/advanced-scheduling.xml:
11778         * docs/pwg/advanced-tagging.xml:
11779         * docs/pwg/advanced-types.xml:
11780         * docs/pwg/appendix-checklist.xml:
11781         * docs/pwg/building-boiler.xml:
11782         * docs/pwg/building-chainfn.xml:
11783         * docs/pwg/building-filterfactory.xml:
11784         * docs/pwg/building-pads.xml:
11785         * docs/pwg/building-props.xml:
11786         * docs/pwg/building-signals.xml:
11787         * docs/pwg/building-state.xml:
11788         * docs/pwg/building-testapp.xml:
11789         * docs/pwg/intro-basics.xml:
11790         * docs/pwg/intro-preface.xml:
11791         * docs/pwg/other-autoplugger.xml:
11792         * docs/pwg/other-sink.xml:
11793         * docs/pwg/other-source.xml:
11794         * docs/pwg/titlepage.xml:
11795           fix up id's
11796
11797 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11798
11799         * docs/95NonPath:
11800         * docs/HACKING:
11801         * docs/README:
11802         * docs/building-the-docs-on-debian:
11803           collect relevant bits of doc info
11804
11805 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11806
11807         * docs/pwg/advanced_tagging.xml:
11808           Half-assed commit so Thomas can re-arrange document IDs here to be
11809           consistent, too.
11810
11811 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11812
11813         * docs/manual/autoplugging.xml:
11814         * docs/manual/bins-api.xml:
11815         * docs/manual/bins.xml:
11816         * docs/manual/buffers-api.xml:
11817         * docs/manual/buffers.xml:
11818         * docs/manual/clocks.xml:
11819         * docs/manual/components.xml:
11820         * docs/manual/cothreads.xml:
11821         * docs/manual/debugging.xml:
11822         * docs/manual/dparams-app.xml:
11823         * docs/manual/dynamic.xml:
11824         * docs/manual/elements-api.xml:
11825         * docs/manual/elements.xml:
11826         * docs/manual/factories.xml:
11827         * docs/manual/gnome.xml:
11828         * docs/manual/goals.xml:
11829         * docs/manual/helloworld.xml:
11830         * docs/manual/helloworld2.xml:
11831         * docs/manual/init-api.xml:
11832         * docs/manual/intro.xml:
11833         * docs/manual/links-api.xml:
11834         * docs/manual/links.xml:
11835         * docs/manual/manual.xml:
11836         * docs/manual/motivation.xml:
11837         * docs/manual/pads-api.xml:
11838         * docs/manual/pads.xml:
11839         * docs/manual/plugins-api.xml:
11840         * docs/manual/plugins.xml:
11841         * docs/manual/programs.xml:
11842         * docs/manual/queues.xml:
11843         * docs/manual/quotes.xml:
11844         * docs/manual/schedulers.xml:
11845         * docs/manual/states-api.xml:
11846         * docs/manual/states.xml:
11847         * docs/manual/threads.xml:
11848         * docs/manual/typedetection.xml:
11849         * docs/manual/xml.xml:
11850           use chapter, part, section or misc as id starts for all bits
11851
11852 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11853
11854         * docs/gst/gstreamer-sections.txt:
11855           Fix up TITLE of the sections
11856
11857 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11858
11859         * docs/pwg/advanced_interfaces.xml:
11860           Add documentation on propertyprobing.
11861         * docs/pwg/advanced_events.xml:
11862         * docs/pwg/advanced_tagging.xml:
11863         * docs/pwg/building_boiler.xml:
11864         * docs/pwg/building_filterfactory.xml:
11865         * docs/pwg/pwg.xml:
11866           Move filterfactory and tagging into their own chapter, add a chapter
11867           on events. all these are empty placeholders that will be filled in
11868           some day.
11869
11870 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11871
11872         * docs/pwg/advanced_interfaces.xml:
11873           Docs for mixer interface. Also a check for website uploading.
11874
11875 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11876
11877         * docs/HACKING:
11878         * docs/Makefile.am:
11879         * docs/faq/Makefile.am:
11880         * docs/gst/Makefile.am:
11881         * docs/gst/tmpl/gstelement.sgml:
11882         * docs/gst/tmpl/gstplugin.sgml:
11883         * docs/gst/tmpl/gstreamer-unused.sgml:
11884         * docs/libs/Makefile.am:
11885         * docs/manual/Makefile.am:
11886         * docs/manuals.mak:
11887         * docs/pwg/Makefile.am:
11888         * docs/upload.mak:
11889           Separate out upload target and make it similar for
11890           both docbook and gtk-doc docs
11891
11892 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11893
11894         * docs/manuals.mak:
11895           Fix upload target to work with freedesktop
11896
11897 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11898
11899         * docs/pwg/advanced_types.xml:
11900           Add notes on creating your own types.
11901         * docs/pwg/building_boiler.xml:
11902         * docs/pwg/building_pads.xml:
11903         * docs/pwg/building_state.xml:
11904           Add some stuff about how to retrieve values from structures, how
11905           that relates to types and change layout slightly again to be almost
11906           perfect.
11907
11908 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11909
11910         * docs/pwg/advanced_dparams.xml:
11911         * docs/pwg/advanced_scheduling.xml:
11912           Change index layout slightly.
11913
11914 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11915
11916         * docs/pwg/advanced_clock.xml:
11917         * docs/pwg/advanced_interfaces.xml:
11918         * docs/pwg/advanced_midi.xml:
11919           General placeholders for now.
11920         * docs/pwg/advanced_request.xml:
11921           Explanation about sometimes and request pads.
11922         * docs/pwg/advanced_scheduling.xml:
11923           Concept of bytestream, loopfunctions and schedulers.
11924         * docs/pwg/building_boiler.xml:
11925           Add something about plugin-init.
11926
11927 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
11928
11929         * docs/pwg/building_pads.xml:
11930           Fix broken docbook
11931
11932 2004-01-27  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11933
11934         * docs/pwg/advanced_interfaces.xml:
11935         * docs/pwg/pwg.xml:
11936           Add as a placeholder for future filling-in.
11937         * docs/pwg/basics_autoplugging.xml:
11938         * docs/pwg/basics_buffers.xml:
11939         * docs/pwg/basics_elements.xml:
11940         * docs/pwg/basics_events.xml:
11941         * docs/pwg/basics_plugins.xml:
11942         * docs/pwg/basics_types.xml:
11943           Remove, because unused (this is all in intro_basics.xml).
11944         * docs/pwg/building_signals.xml:
11945           Short intro to signals + reference to GObject docs - we really
11946           shouldn't go into these sort of things to deply because we don't
11947           use them that extensively anyway.
11948         * docs/pwg/building_state.xml:
11949           Explanation of states. Benjamin, please check.
11950         * docs/pwg/building_testapp.xml:
11951           Put everything in one page - putting only a few lines of content
11952           per page doesn't really make sense.
11953
11954           Time to get into the advanced topics. ;).
11955
11956 2004-01-27  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11957
11958         * docs/pwg/advanced_types.xml:
11959           Finish documenting the current state of mimetypes.
11960         * docs/pwg/building_boiler.xml:
11961         * docs/pwg/building_chainfn.xml:
11962         * docs/pwg/building_pads.xml:
11963         * docs/pwg/building_props.xml:
11964         * docs/pwg/building_testapp.xml:
11965           Start documenting the "how to build a simple audio filter" part
11966           of the PWG. Most stuff is ready by now. Stuff remaining: signals,
11967           states and (maybe?) a short introduction to capsnego in the chapter
11968           on pads (building_pads.xml). Capsnego should probably be explained
11969           fully in advanced_capsnego.xml or so.
11970
11971 2004-01-26  David Schleef  <ds@schleef.org>
11972
11973         * gst/gstpad.c: (gst_pad_try_set_caps_nonfixed):
11974         * gst/gstpad.h: Add new function to allow element to (somewhat)
11975         specify non-fixed caps on a pad.
11976         * gst/gstqueue.c: (gst_queue_chain): Remove noisy g_object_notify()
11977         that I added a few weeks ago.
11978
11979 2004-01-26  David Schleef  <ds@schleef.org>
11980
11981         * gst/gstpad.c: (gst_pad_try_set_caps): Revert last change
11982           making try_set_caps() work with non-fixed caps.
11983
11984 2004-01-26  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11985
11986         * docs/pwg/advanced_types.xml:
11987         * docs/pwg/intro_basics.xml:
11988         * docs/pwg/intro_preface.xml:
11989         * docs/pwg/pwg.xml:
11990         * docs/pwg/titlepage.xml:
11991           First try to resurrect the PWG. I'm halfway integrating the mimetypes
11992           in here (docs/random/mimetypes), and will from there on work on both
11993           updating outdated parts and adding missing parts.
11994           That doesn't mean I'll fix it completely, but I'll try at least. ;).
11995
11996 2004-01-26  Thomas Vander Stichele  <thomas at apestaart dot org>
11997
11998         * gst/gsterror.h: reinstate GST_LIBRARY_ERROR_ENCODE until
11999           policy is set
12000
12001 2004-01-26  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12002
12003         * gst/gstelement.h:
12004           remove gst_element_factory_get_version. It doesn't exist anymore.
12005         * gst/gstplugin.c:
12006         * gst/gstplugin.h:
12007           remove gst_plugin_set_name and change gst_plugin_get_longname to
12008           gst_plugin_get_description to match code.
12009         * gst/gsterror.h:
12010           remove GST_LIBRARY_ERROR_ENCODE. It's GST_STREAM_ERROR_ENCODE.
12011         * gst/gstpad.c: (gst_pad_try_set_caps):
12012           make it work with nonfixed caps.
12013           Note that even in the nonfixed case the link function of the pad
12014           that tries to set caps isn't called.
12015
12016 2004-01-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12017
12018         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
12019           fix bug where buffer was not assembled correctly
12020         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_init):
12021           silence by default
12022         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
12023           only seek if there's no more buffers that could work without seeking
12024
12025 2004-01-23  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12026
12027         * gst/gsttag.c: (_gst_tag_initialize):
12028         * gst/gsttag.h:
12029           Add application tag (for encoding/muxing app).
12030
12031 2004-01-23  Thomas Vander Stichele  <thomas at apestaart dot org>
12032
12033         * autogen.sh:
12034           make autopoint force, and libtoolize not copy
12035         * common/m4/as-docbook.m4:
12036           added docbook xml catalog setup check
12037         * common/m4/gst-doc.m4:
12038           use docbook check
12039
12040 2004-01-22  Thomas Vander Stichele  <thomas at apestaart dot org>
12041
12042         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_register):
12043         * gst/gsttag.h:
12044           add GstTagFlag
12045
12046 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12047
12048         * docs/gst/gstreamer-sections.txt:
12049         * docs/gst/tmpl/gst.sgml:
12050         * docs/gst/tmpl/gstbuffer.sgml:
12051         * docs/gst/tmpl/gstclock.sgml:
12052         * docs/gst/tmpl/gstelement.sgml:
12053         * docs/gst/tmpl/gstreamer-unused.sgml:
12054         * docs/gst/tmpl/gstxml.sgml:
12055           sync latest API changes to docs
12056
12057 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12058
12059         * gst/gstpluginfeature.c:
12060           fix doc snippet
12061         * tools/gst-inspect.c: (print_element_list):
12062           fix output of typefind
12063           add GPL header
12064         * tools/gst-launch.c:
12065           add GPL header
12066
12067 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12068
12069         * gst/elements/Makefile.am:
12070         * gst/elements/gstelements.c:
12071         * gst/elements/gsttypefindelement.c:
12072         * gst/elements/gsttypefindelement.h:
12073         * po/POTFILES.in:
12074         * po/fr.po:
12075         * po/nl.po:
12076           renamed gsttypefindelement to gsttypefind, conserving CVS history
12077
12078 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12079
12080         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_list_add_valist):
12081         * gst/gsttag.h:
12082           add some tags used in ogg as well
12083           fix _ in replaygain tags
12084
12085 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12086
12087         * gst/gsterror.h:
12088           fix wrong GST_LIBRARY_ERROR_ENCODE addition
12089
12090 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12091
12092         * gst/gstelement.c: (gst_element_error_full):
12093         * gst/gstelement.h:
12094           change _extended to _full
12095
12096 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12097
12098         reviewed by: <delete if not using a buddy>
12099
12100         * docs/gst/tmpl/gst.sgml:
12101         * docs/gst/tmpl/gstbuffer.sgml:
12102         * docs/gst/tmpl/gstclock.sgml:
12103         * docs/gst/tmpl/gstelement.sgml:
12104         * docs/gst/tmpl/gstreamer-unused.sgml:
12105         * docs/gst/tmpl/gstxml.sgml:
12106         * gst/gstelement.c: (gst_element_error_full):
12107         * gst/gstelement.h:
12108
12109 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
12110
12111         * gst/gstelement.h: fix _gst_element_error_printf prototype
12112
12113 2004-01-20  David Schleef  <ds@schleef.org>
12114
12115         * gst/gststructure.c: (gst_structure_to_string):
12116         Convert function to use gst_value_serialize().
12117         * gst/gstvalue.c: (gst_value_serialize_list),
12118         (gst_value_serialize_fourcc), (gst_value_serialize_int_range),
12119         (gst_value_serialize_double_range), (gst_value_serialize_boolean),
12120         (gst_value_serialize_int), (gst_value_serialize_double),
12121         (gst_string_wrap), (gst_value_serialize_string),
12122         (gst_value_serialize), (gst_value_deserialize):
12123         * gst/gstvalue.h:
12124         Add implementations for serialize.
12125
12126 2004-01-20  Julien MOUTTE  <julien@moutte.net>
12127
12128         * gst/gsterror.h: xvidenc.c needs GST_LIBRARY_ERROR_ENCODE. Dunno if
12129         we want to keep that one in the future or change xvidenc.c to use 
12130         another error.
12131
12132 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12133
12134         * gst/gstelement.c: (_gst_element_error_printf):
12135         * gst/gstelement.h:
12136           privatise function
12137
12138 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12139
12140         * docs/random/error:
12141           doc explaining error system
12142         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
12143           cleanup
12144
12145 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12146
12147         * gst/gst-i18n-app.h:
12148         * gst/gst-i18n-lib.h:
12149           remove inclusion of config.h
12150         * po/POTFILES.in:
12151         * po/nl.po:
12152           add gst/gstelement.c
12153
12154 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12155
12156         * po/nl.po: updated Dutch translation
12157
12158 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12159
12160         * gst/gsterror.c: (_gst_core_errors_init),
12161         (_gst_library_errors_init), (_gst_resource_errors_init),
12162         (_gst_stream_errors_init):
12163         remove ending punctuation dots
12164
12165 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12166
12167         * gst/elements/gstfilesink.c: (gst_filesink_open_file):
12168         * gst/elements/gstfilesrc.c: (gst_filesrc_get_read):
12169         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
12170         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
12171         (gst_pipefilter_chain), (gst_pipefilter_open_file):
12172         use GST_ERROR_SYSTEM
12173
12174 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12175
12176         * gst/gstelement.c: (gst_element_error_printf),
12177         (gst_element_error_extended):
12178         * gst/gstelement.h:
12179           add a helper printf function so we can have NULL values passed.
12180
12181 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
12182
12183         * gst/gstelement.h:
12184           add G_STMT macros to gst_element_error, which isn't strictly
12185           necessary but people tell me to anyway.
12186
12187 2004-01-18  Thomas Vander Stichele  <thomas at apestaart dot org>
12188
12189         * gst/Makefile.am:
12190         * gst/autoplug/gstspideridentity.c:
12191         (gst_spider_identity_sink_loop_type_finding):
12192         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
12193         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
12194         (gst_filesink_close_file), (gst_filesink_handle_event),
12195         (gst_filesink_chain):
12196         * gst/elements/gstfilesrc.c: (gst_filesrc_set_property),
12197         (gst_filesrc_map_region), (gst_filesrc_get_read),
12198         (gst_filesrc_open_file):
12199         * gst/elements/gstidentity.c: (gst_identity_chain):
12200         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
12201         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
12202         (gst_pipefilter_chain), (gst_pipefilter_open_file):
12203         * gst/elements/gsttypefindelement.c: (gst_type_find_element_chain):
12204         * gst/gst.h:
12205         * gst/gst_private.h:
12206         * gst/gstelement.c: (gst_element_class_init),
12207         (gst_element_default_error), (gst_element_error_func),
12208         (gst_element_error_extended):
12209         * gst/gstelement.h:
12210         * gst/gsterror.c: (_gst_core_errors_init),
12211         (_gst_library_errors_init), (_gst_resource_errors_init),
12212         (_gst_stream_errors_init), (gst_error_get_message):
12213         * gst/gsterror.h:
12214         * gst/gstinfo.c: (_gst_debug_init):
12215         * gst/gstmarshal.list:
12216         * gst/gstpad.c: (gst_pad_set_explicit_caps),
12217         (gst_pad_recover_caps_error), (gst_pad_pull):
12218         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
12219         * gst/schedulers/gstbasicscheduler.c:
12220         (gst_basic_scheduler_chainhandler_proxy),
12221         (gst_basic_scheduler_gethandler_proxy),
12222         (gst_basic_scheduler_cothreaded_chain):
12223         * po/POTFILES.in:
12224         * po/fr.po:
12225         * po/nl.po:
12226           change error signal
12227           add error categories
12228
12229 2004-01-18  Jeremy Simon  <jesimon@libertysurf.fr>
12230
12231         * gst/gsttag.c: (_gst_tag_initialize):
12232         * gst/gsttag.h:
12233         Add replaygain tag
12234
12235 2004-01-18  Colin Walters  <walters@verbum.org>
12236
12237         * examples/retag/retag.c: Call gst_init before processing
12238         program args.  Add g_assert to _link_many call.
12239
12240 2004-01-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12241
12242         * gst/gstpad.c: (gst_pad_alloc_buffer):
12243           Return a newly allocated buffer when the pad has no peer.
12244
12245 2004-01-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12246
12247         * gst/gstclock.c: (gst_clock_get_time):
12248           make it compile with gcc 2.95 again.
12249           Patch by Scott Wheeler
12250
12251 2004-01-15  David Schleef  <ds@schleef.org>
12252
12253         * gst/gstcaps.h:
12254         Added gst_caps_is_simple() macro.
12255         * testsuite/caps/caps.c: (test1):
12256         * testsuite/caps/intersect2.c: (main):
12257         * testsuite/caps/intersection.c: (main):
12258         Fixes to make 'make check' work again after removing
12259         gst_caps_is_chained().
12260
12261 2004-01-15  Leif Johnson <leif@ambient.2y.net>
12262
12263         * docs/random/uraeus/gstreamer_and_midi.txt: Rather large edits
12264         and additions to the MIDI document.
12265
12266 2004-01-15  David Schleef  <ds@schleef.org>
12267
12268         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered),
12269         (gst_element_link_pads_filtered): Use GST_PAD_ macros instead
12270         of GST_RPAD_, since we don't know if it's a real or ghost pad.
12271
12272 2004-01-15  David Schleef  <ds@schleef.org>
12273
12274         * gst/gstqueue.c:
12275         * gst/gstqueue.h:
12276         Fix the spelling of "treshold" and make min_threshold actually
12277         affect the queue.
12278
12279 2004-01-15  David Schleef  <ds@schleef.org>
12280
12281         * gst/gstcaps.c:
12282         Add lots of documentation.
12283         * gst/gstcaps.h:
12284         Deprecate a few functions.
12285         * gst/gstpad.c:
12286         Removed use of deprecated functions.
12287
12288 2004-01-15  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12289
12290         * gst/gstpad.c: (gst_pad_is_linked):
12291         * gst/gstpad.h:
12292           implement gst_pad_is_linked
12293         * gst/gstelement.h:
12294           reserve space for initiate_state_change
12295
12296 2004-01-15  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12297
12298         * gst/autoplug/gstspideridentity.c:
12299         (gst_spider_identity_sink_loop_type_finding):
12300           break infinite loop by just returning instead of looping
12301         * gst/gstclock.c: (gst_clock_class_init), (gst_clock_set_property):
12302           set event time difference correctly. Set it to 1 second instead
12303           of 100ms to be more tolerant
12304         * gst/gstelement.c: (gst_element_set_time):
12305           add debugging output
12306
12307 2004-01-14  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12308
12309         * gst/gstqueue.c: (gst_queue_getcaps), (gst_queue_link):
12310           query if buffers are inside the pool, ignore events
12311
12312 2004-01-13  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12313
12314         * gst/gstclock.c: (gst_clock_class_init), (gst_clock_init),
12315         (gst_clock_set_speed), (gst_clock_set_active),
12316         (gst_clock_is_active), (gst_clock_reset),
12317         (gst_clock_handle_discont):
12318         * gst/gstclock.h:
12319           deprecate old interface and disable functions that aren't in use
12320           anymore.
12321         * gst/gstelement.h:
12322         * gst/gstelement.c: (gst_element_get_time), (gst_element_wait),
12323         (gst_element_set_time), (gst_element_adjust_time):
12324           add concept of "element time" and functions to get/set this time.
12325         * gst/gstelement.c: (gst_element_change_state):
12326           update element time correctly.
12327         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered):
12328           This is a debug message, not a g_critical.
12329         * gst/gstpad.c: (gst_pad_event_default):
12330           handle discontinuous events right with element time.
12331         * gst/gstscheduler.c: (gst_scheduler_state_transition):
12332           update to clocking fixes.
12333           set clocks on elements in READY=>PAUSED. The old behaviour caused
12334           a wrong element time on the first element that started playing.
12335         * gst/schedulers/gstbasicscheduler.c:
12336         (gst_basic_scheduler_class_init):
12337         * gst/schedulers/gstoptimalscheduler.c:
12338         (gst_opt_scheduler_class_init):
12339           remove code that just implements the default behaviour.
12340         * gst/elements/gstfakesink.c: (gst_fakesink_chain):
12341           update to use new clocking functions
12342         * testsuite/clock/clock1.c: (gst_clock_debug), (main):
12343         * testsuite/clock/clock2.c: (gst_clock_debug), (main):
12344           update to test new element time.
12345         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_getcaps):
12346           use _get_allowed_caps instead of _get_caps. This catches filtered
12347           caps correctly.
12348         * testsuite/debug/commandline.c:
12349           update for new GST_DEBUG syntax.
12350         * testsuite/threads/Makefile.am:
12351           disable a test that only works sometimes.
12352
12353 2004-01-13  Julien MOUTTE <julien@moutte.net>
12354
12355         * po/LINGUAS: Adding fr.
12356         * po/fr.po: Adding french translation.
12357
12358 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12359
12360         * gst/parse/grammar.y:
12361         * po/POTFILES.in:
12362         * po/nl.po:
12363         * tools/gst-launch.c: (xmllaunch_parse_cmdline), (main):
12364           translate parsing error messages
12365
12366 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12367
12368         * po/POTFILES.in: adding gst-launch
12369         * po/nl.po: updated translation, all 99 strings translated
12370         * tools/gst-launch.c: (idle_func), (xmllaunch_parse_cmdline),
12371         (found_tag), (sigint_handler_sighandler), (play_handler), (main):
12372           fix strings for translation
12373
12374 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12375
12376         * gst/gst.c:
12377           - capitalize beginnings of popt options
12378           - fix strings for translation
12379           - change gst-debug format from =N1=V1:N2=V2 to =N1:V1,N2:V2
12380
12381 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12382
12383         * po/README: add some notes on how to update translations
12384
12385 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12386
12387         * ABOUT-NLS: removed, is autogenerated from autopoint
12388         * autogen.sh: add autopoint stuff
12389         * configure.ac: fix up gettext stuff
12390         * gst/Makefile.am: add i18n headers to noinst_HEADERS
12391         * gst/elements/gsttypefindelement.c: add header include
12392         * gst/gettext.h: add header, copy from system-installed header
12393         * gst/gst-i18n-app.h: to be included by each app having translations
12394         * gst/gst-i18n-lib.h: to be included by each lib having translations
12395         * gst/gst.c: (init_pre): fix up gettext calls
12396         * gst/gst_private.h: remove i18n stuff, moving to separate headers
12397         * po/LINGUAS: the new way to specify translations present
12398         * po/Makefile.in.in: removed from cvs, autogenerated from autopoint
12399         * po/Makevars: the variables filled in for GStreamer
12400         * po/POTFILES.in: added new files with translations
12401         * po/de.po: has new strings
12402         * po/nl.po: readded, has new strings
12403
12404 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
12405
12406         * gst/gsttag.c: fix some strings marked for translation
12407
12408 2004-01-13  Iain <iain@prettypeople.org>
12409
12410         * gst/schedulers/gstoptimalscheduler.c (add_to_group): Reference the
12411         group when we add an element to it, cos we unref it when we remove one
12412
12413 2004-01-12  Thomas Vander Stichele  <thomas at apestaart dot org>
12414
12415         * testsuite/debug/commandline.c: (debug_not_reached):
12416         * testsuite/debug/output.c: (check_message):
12417           fix testsuite
12418
12419 2004-01-12  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12420
12421         * examples/cutter/.cvsignore:
12422         * examples/helloworld/.cvsignore:
12423         * examples/launch/.cvsignore:
12424         * examples/manual/.cvsignore:
12425         * examples/mixer/.cvsignore:
12426         * examples/pingpong/.cvsignore:
12427         * examples/plugins/.cvsignore:
12428         * examples/queue/.cvsignore:
12429         * examples/queue2/.cvsignore:
12430         * examples/queue3/.cvsignore:
12431         * examples/queue4/.cvsignore:
12432         * examples/retag/.cvsignore:
12433         * examples/thread/.cvsignore:
12434         * examples/typefind/.cvsignore:
12435         * examples/xml/.cvsignore:
12436         * gst/.cvsignore:
12437         * gst/autoplug/.cvsignore:
12438         * gst/elements/.cvsignore:
12439         * gst/indexers/.cvsignore:
12440         * gst/parse/.cvsignore:
12441         * gst/registries/.cvsignore:
12442         * gst/schedulers/.cvsignore:
12443         * libs/gst/bytestream/.cvsignore:
12444         * libs/gst/control/.cvsignore:
12445         * libs/gst/getbits/.cvsignore:
12446         * tests/.cvsignore:
12447         * tests/bufspeed/.cvsignore:
12448         * tests/instantiate/.cvsignore:
12449         * tests/memchunk/.cvsignore:
12450         * tests/muxing/.cvsignore:
12451         * tests/sched/.cvsignore:
12452         * tests/seeking/.cvsignore:
12453         * tests/threadstate/.cvsignore:
12454         * testsuite/.cvsignore:
12455         * testsuite/caps/.cvsignore:
12456         * testsuite/cleanup/.cvsignore:
12457         * testsuite/dynparams/.cvsignore:
12458         * testsuite/plugin/.cvsignore:
12459         * tools/.cvsignore:
12460           update - this is huge, because it includes *.bb, *.bbg and *.da files
12461           which are generated for gcov.
12462
12463 2004-01-11  David Schleef  <ds@schleef.org>
12464
12465         * gst/gststructure.c: (gst_strtoi), (gst_value_from_string): Add
12466         a function to parse integers in ways that strto[u]l() does not.
12467
12468 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12469
12470         * tools/gst-inspect.c: (print_caps):
12471           improve output of caps a bit
12472
12473 2004-01-11  David Schleef  <ds@schleef.org>
12474
12475         * gst/gstbuffer.c: (gst_buffer_create_sub): Subbuffers should
12476         inherit correct flags (READONLY and DONTKEEP).
12477
12478 2004-01-11  David Schleef  <ds@schleef.org>
12479
12480         * gst/elements/gstfilesrc.c: (gst_filesrc_free_parent_mmap),
12481         (gst_filesrc_map_region):
12482         * gst/gstbuffer.c: (_gst_buffer_initialize),
12483         (_gst_buffer_sub_free), (gst_buffer_default_copy),
12484         (gst_buffer_new), (gst_buffer_create_sub),
12485         (gst_buffer_is_span_fast), (gst_buffer_span):
12486         * gst/gstbuffer.h:
12487         Change GstBuffer private structure element names. (all files)
12488         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
12489         (gst_queue_link):
12490         * gst/gstqueue.h:
12491         Implement getcaps/pad_link functions that handle the case where
12492         there are data in the queue.
12493
12494 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12495
12496         * gst/elements/gstbufferstore.c:
12497           initialize debugging structure correctly
12498         * gst/elements/gsttee.c: (gst_tee_set_property):
12499           g_object_notify when property was changed
12500         * gst/elements/gsttypefindelement.c:
12501         (gst_type_find_element_change_state):
12502           clear caps correctly
12503
12504 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12505
12506         * gst/gstqueue.c: (gst_queue_init):
12507           Use better defaults for when a queue should block. This
12508           gets rid of jerky playback for quite a few files.
12509           It takes more memory.
12510
12511 2004-01-10  Thomas Vander Stichele  <thomas at apestaart dot org>
12512
12513         (gst_xml_registry_parse_padtemplate):
12514           make critical message slightly more useful
12515
12516 2004-01-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12517
12518         * gst/gstinfo.c: (gst_debug_log), (gst_debug_log_valist),
12519         (gst_debug_message_get), (gst_debug_log_default):
12520         * gst/gstinfo.h:
12521           Change gst_debug_log(_valist) to take a const format string.
12522           Change prototype of log function and functions using those to 
12523           take a GstDebugMessage instead of a string that requires using
12524           gst_debug_message_get.
12525
12526 2004-01-08  David Schleef  <ds@schleef.org>
12527
12528         * Makefile.am:
12529         * configure.ac:
12530         Add option --enable-gcov to build GStreamer with -fprofile-arcs
12531         and -ftest-coverage, which allows gcov to show information about
12532         testsuite coverage.
12533
12534 2004-01-08  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12535
12536         * gst/gstutils.h:
12537           Add GST_BOILERPLATE(_FULL), GST_PARENT_CALL and
12538           GST_PARENT_CALL_WITH_DEFAULT
12539         * gst/elements/gstaggregator.c: 
12540         * gst/elements/gstbufferstore.c: 
12541         * gst/elements/gstfakesink.c: 
12542         * gst/elements/gstfakesrc.c: 
12543         * gst/elements/gstfdsink.c: 
12544         * gst/elements/gstfdsrc.c: 
12545         * gst/elements/gstfilesink.c: 
12546         * gst/elements/gstfilesrc.c: 
12547         * gst/elements/gstidentity.c: 
12548         * gst/elements/gstmd5sink.c: 
12549         * gst/elements/gstmultidisksrc.c:
12550         * gst/elements/gstpipefilter.c: 
12551         * gst/elements/gstshaper.c:
12552         * gst/elements/gststatistics.c:
12553         * gst/elements/gsttee.c:
12554         * gst/elements/gsttypefindelement.c:
12555           use them.
12556
12557 2004-01-07  Thomas Vander Stichele  <thomas at apestaart dot org>
12558
12559         * docs/gst/gstreamer-docs.sgml: remove props
12560         * docs/gst/gstreamer-sections.txt: remove props
12561         * docs/gst/tmpl/gst.sgml:
12562         * docs/gst/tmpl/gstbin.sgml:
12563         * docs/gst/tmpl/gstbuffer.sgml:
12564         * docs/gst/tmpl/gstcaps.sgml:
12565         * docs/gst/tmpl/gstclock.sgml:
12566         * docs/gst/tmpl/gstelement.sgml:
12567         * docs/gst/tmpl/gstindex.sgml:
12568         * docs/gst/tmpl/gstobject.sgml:
12569         * docs/gst/tmpl/gstpad.sgml:
12570         * docs/gst/tmpl/gstpadtemplate.sgml:
12571         * docs/gst/tmpl/gstreamer-unused.sgml:
12572         * docs/gst/tmpl/gstthread.sgml:
12573         * docs/gst/tmpl/gstxml.sgml:
12574           sync with code reorganization
12575
12576 2004-01-07  Jan Schmidt  <thaytan@mad.scientist.com>
12577
12578         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered):
12579         Make the 'Could not find compatible pad' message more informative.
12580
12581 2004-01-07  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12582                                                                                 
12583         * gst/elements/gstfilesink.c: (gst_filesink_set_location):
12584           Fix for if we pass NULL as property to location.
12585         * gst/elements/gstpipefilter.c: (gst_pipefilter_init),
12586         (gst_pipefilter_handle_event), (gst_pipefilter_chain):
12587           Fix for instantiate-test (see below).
12588         * gst/gststructure.c: (_gst_structure_parse_value):
12589           Fix compile error on gcc-2.96.
12590         * configure.ac:
12591         * tests/Makefile.am:
12592         * tests/instantiate/Makefile.am:
12593         * tests/instantiate/create.c: (create_all_elements), (main):
12594           Add a test that instantiates all elements. This makes it easy to
12595           track dead code for old API/design (like setting event functions
12596           on sink pads and so on).
12597
12598 2004-01-06  Jan Schmidt  <thaytan@mad.scientist.com>
12599
12600         * gst/gstcaps.c: (gst_caps_append_structure):
12601           Move the poisoning to allow a NULL structure
12602         * gst/gstevent.c: (_gst_event_free):
12603           When freeing a navigation event, free the structure
12604           also
12605
12606 2004-01-04  David Schleef  <ds@schleef.org>
12607
12608         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_request_new_pad):
12609         Remove usage of gst_pad_proxy_fixate.
12610         * gst/gstcaps.c: (gst_caps_append), (gst_caps_append_structure),
12611         (gst_caps_split_one), (gst_caps_replace):
12612         Add poisoning code.
12613         * gst/gstmarshal.list:
12614         Add pointer__pointer for fixate signal
12615         * gst/gstpad.c: (gst_real_pad_class_init),
12616         (_gst_real_pad_fixate_accumulator), (gst_pad_link_fixate),
12617         (_gst_pad_default_fixate_func), (gst_pad_proxy_fixate),
12618         (gst_pad_set_explicit_caps), (gst_pad_template_new):
12619         Add poisoning code. Add fixate signal on RealPad. Change
12620         set_explicit_caps() to take const GstCaps, like try_set_caps().
12621         * gst/gstpad.h:
12622         * testsuite/caps/Makefile.am:
12623         * testsuite/caps/app_fixate.c: Add a test for the fixate signal
12624
12625 2004-01-03  David Schleef  <ds@schleef.org>
12626
12627         * gst/elements/gsttypefindelement.c:
12628         (gst_type_find_element_have_type), (gst_type_find_element_init):
12629         Use gst_pad_use_explicit_caps for src pad.
12630         * gst/gstpad.c: (gst_pad_try_set_caps):  Check that link exists
12631         before using it.
12632
12633 2004-01-03  David Schleef  <ds@schleef.org>
12634
12635         * gst/gstelement.c: (gst_element_link_pads_filtered),
12636         (gst_element_negotiate_pads): Fix to allow DELAYED to indicate
12637         that linking was successful.
12638         * gst/gstpad.c: (gst_pad_link_free),
12639         (gst_pad_link_call_link_functions), (gst_pad_link_negotiate),
12640         (gst_pad_link_try), (gst_pad_link_unnegotiate),
12641         (gst_pad_unnegotiate), (gst_pad_set_explicit_caps): Pass
12642         GstPadLinkReturn correctly between functions, and don't fail
12643         when DELAYED is used (DELAYED is very important).  Better
12644         cleanup on unlinking and unnegotiation.  Should fix some spider
12645         bugs.
12646
12647 2004-01-02  David Schleef  <ds@schleef.org>
12648
12649         * gst/gstelement.c: (gst_element_class_init),
12650         (gst_element_base_class_init): ->padtemplates should be cleared
12651         in base_init, since we need to have a fresh list for every
12652         class.  (Alternately, we chould copy the list and share the
12653         actual pad templates (not the list), but that would require
12654         changing every plugin to move pad template registration from
12655         base_init to class_init.)
12656
12657 2004-01-03  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12658
12659         * gst/gstelement.c: (gst_element_class_add_pad_template):
12660           Refuse registering a pad template if another pad template
12661           with the same name already exists (#114715).
12662
12663 2004-01-02  David Schleef  <ds@schleef.org>
12664
12665         * gst/gstcaps.c: (_gst_structure_is_equal_foreach),
12666         (gst_caps_is_equal_fixed): Add new function.
12667         * gst/gstcaps.h: ditto.
12668         * gst/gstpad.c: (gst_real_pad_class_init),
12669         (gst_pad_link_call_link_functions), (gst_pad_try_set_caps),
12670         (gst_pad_set_explicit_caps), (gst_pad_get_caps):  In try_set_caps,
12671         check new caps against existing caps -- if they're the same, return
12672         OK without renegotiating.  caps-nego-failed signal fixed so that
12673         the marshaller isn't VOID__OBJECT.  Also changed to G_TYPE_POINTER
12674         to save an extra caps copy.  Don't complete negotiation if a pad
12675         link function returns DELAYED.
12676
12677 2004-01-02  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12678
12679         * gst/gstpad.c: (gst_pad_try_relink_filtered):
12680           Fix wrong g_return_if_fail
12681
12682 2004-01-03  Jan Schmidt  <thaytan@mad.scientist.com>
12683
12684         * gst/gstbin.c: (gst_bin_class_init):
12685         Change the marshalling of element_added/element_removed
12686         to use gst_marshal_VOID__OBJECT, since gst_marshal_VOID__POINTER 
12687         complains that GST_TYPE_ELEMENT is not G_TYPE_POINTER
12688
12689 2004-01-01  David Schleef  <ds@schleef.org>
12690
12691         * gst/gstpad.c: (gst_pad_set_explicit_caps),
12692         (gst_pad_explicit_getcaps), (gst_pad_explicit_link),
12693         (gst_pad_use_explicit_caps):
12694         * gst/gstpad.h:
12695         Add new functions.  gst_pad_use_explicit_caps() sets up a pad
12696         to use an internal getcaps and link fuction so that negotiation
12697         always results in the explicitly set caps.
12698         gst_pad_set_explicit_caps() sets the explicit caps.  These functions
12699         are particularly useful for decoders.
12700
12701 2003-12-31  David Schleef  <ds@schleef.org>
12702
12703         * gst/elements/gstidentity.c: (gst_identity_class_init),
12704         (gst_identity_init), (gst_identity_chain),
12705         (gst_identity_set_property), (gst_identity_get_property):
12706         * gst/elements/gstidentity.h:
12707         * gst/gstqueue.c: (gst_queue_init):
12708           Negotiation fixes.
12709
12710 2003-12-31  David Schleef  <ds@schleef.org>
12711
12712         * gst/gstcaps.c: (gst_caps_intersect),
12713         (_gst_caps_normalize_foreach), (gst_caps_normalize):
12714           Implement gst_caps_normalize().
12715         * testsuite/caps/normalisation.c: (main):
12716           Add an additional test
12717
12718 2003-12-31  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12719
12720         * gst/gstqueue.c: (gst_queue_init):
12721           use gst_pad_proxy_getcaps()
12722
12723 2003-12-31  David Schleef  <ds@schleef.org>
12724
12725         * gst/elements/gstshaper.c: (gst_shaper_link):
12726         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_request_new_pad):
12727         * gst/gstqueue.c: (gst_queue_link):
12728           Negotiation fixes.
12729
12730 2003-12-31  David Schleef  <ds@schleef.org>
12731
12732         * gst/gstpad.c: (gst_pad_proxy_pad_link), (gst_pad_proxy_fixate):
12733         * gst/gstpad.h: Add functions that are useful as default pad
12734         link and fixate functions for elements.
12735
12736 2003-12-30  David Schleef  <ds@schleef.org>
12737
12738         * gst/gstpad.c: (gst_pad_link_try):
12739           Fix segfault when attempting to return to old caps
12740
12741 2003-12-29  David Schleef  <ds@schleef.org>
12742
12743         * gst/gstcaps.c: (gst_caps_normalize), (simplify_foreach),
12744         (gst_caps_structure_simplify), (gst_caps_simplify):
12745         * gst/gstcaps.h:
12746           Add simplify function
12747         * gst/gstpad.c: (gst_pad_link_try), (gst_pad_try_set_caps),
12748         (gst_pad_perform_negotiate), (gst_pad_is_negotiated):
12749         * gst/gstpad.h:
12750           Copy over srcnotify, sinknotify when calling old pad_link
12751           functions.  Add new is_negotiated() function.
12752         * gst/gststructure.c: (gst_structure_copy):
12753           Fix an incredibly stupid bug that should have been noticed
12754           weeks ago.  _copy() returned the argument, not the new copy.
12755
12756 2003-12-27  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12757
12758         * gst/gstcaps.c: (gst_caps_append):
12759           add sanity checks
12760         * gst/gstcaps.h: (gst_caps_debug):
12761           remove, it doesn't exist anymore.
12762         * gst/gstelement.c: (gst_element_threadsafe_properties_pre_run),
12763         (gst_element_threadsafe_properties_post_run):
12764           make debugging messages not clutter up THREAD debug category
12765         (gst_element_negotiate_pads), (gst_element_clear_pad_caps),
12766         (gst_element_change_state):
12767           update to new caps API
12768         * gst/gstinterface.c: (gst_implements_interface_cast):
12769           don't put vital code in g_return_if_fail
12770         * gst/gstpad.c: (gst_pad_link_try), (gst_pad_try_set_caps), 
12771         (gst_pad_link_filtered):
12772           add pst_pad_try_link and use it.
12773         (gst_pad_perform_negotiate), (gst_pad_renegotiate):
12774           implement correctly, deprecate first one.
12775         (gst_pad_link_unnegotiate), (gst_pad_unnegotiate):
12776           add and implement.
12777         (gst_pad_try_relink_filtered), (gst_pad_relink_filtered):
12778           implement.
12779         (gst_pad_get_negotiated_caps):
12780           add and implement. Make GST_PAD_CAPS call this function.
12781         (gst_pad_get_caps):
12782           remove unneeded check..
12783         (gst_pad_recover_caps_error):
12784           disable, always return FALSE.
12785         (gst_real_pad_dispose):
12786           don't free caps and appfilter anymore, they're unused.
12787         * gst/gstpad.h:
12788           Reflect changes mentioned above.
12789         * gst/gstsystemclock.c: (gst_system_clock_wait):
12790           Make 'clock is way behind' a debugging message.
12791         * gst/gstthread.c: (gst_thread_change_state):
12792           Fix debugging message
12793
12794 2003-12-25  Thomas Vander Stichele  <thomas at apestaart dot org>
12795
12796         * gst/gstinfo.h:
12797           fix GST_DEBUG_CATEGORY_INIT gtk-doc description
12798         * docs/gst/tmpl/gstreamer-unused.sgml:
12799           removed all traces of cvs conflicts
12800
12801 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
12802
12803         * configure.ac:
12804         * gst/schedulers/cothreads_compat.h:
12805         * libs/Makefile.am:
12806           remove last instances of wingo cothread usage
12807
12808 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
12809
12810         * gst/gstplugin.c:
12811         * gst/gstversion.h.in:
12812         * gst/parse/grammar.y:
12813           change comment block from /** to /* when not gtk-doc comments
12814
12815 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
12816
12817         * gst/gst.c: whitespace and doc style fixes
12818
12819 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
12820
12821         * gst/gstformat.h: remove trailing whitespace from enum for gtk-doc
12822
12823 2003-12-24  Colin Walters  <walters@verbum.org>
12824
12825         * gst/elements/gsttypefindelement.c:
12826           gst/elements/gsttypefindelement.h: Make GstCaps parameter const.
12827           Copy caps parameter. Use _POINTER to marshal caps instead of _BOXED.
12828           Don't double-free caps.
12829
12830 2003-12-23  David Schleef  <ds@schleef.org>
12831
12832         * gst/gstelement.c, gst/gstpad.c, gst/parse/grammar.y,
12833           gst/gstcaps.c, gst/autoplug/gstspideridentity.c:
12834           Many little fixes and additions of debug statements to
12835           get rhythmbox working.
12836
12837 2003-12-23  Colin Walters  <walters@verbum.org>
12838
12839         * gst/autoplug/gstspideridentity.c (gst_spider_identity_sink_loop_type_finding):
12840         Use GST_PAD_LINK_SUCCESSFUL.
12841
12842 2003-12-23  David Schleef  <ds@schleef.org>
12843
12844         * gst/elements/gstaggregator.c:
12845         * gst/elements/gsttee.c:
12846           Use gst_pad_proxy_getcaps().
12847         * gst/gstpad.c:
12848         * gst/gstpad.h:
12849           Add gst_pad_proxy_getcaps(), which filter elements can use
12850           as a generic getcaps implementation.
12851           Fix gst_pad_get_allowed_caps().  It just wasn't doing what
12852           was advertised.
12853
12854 2003-12-23  David Schleef  <ds@schleef.org>
12855
12856         * gst/gstpad.c:
12857           Rearrange/rewrite much of the pad negotiation code, since it
12858           resembled pasta.  This actually changes the way some
12859           negotiation works, since the previous code was inconsistent
12860           depending on how it was invoked.  Add (internal) structure
12861           GstPadLink, which is used to hold some information (more in
12862           the future) about the link between two pads.  Fixes a number
12863           of bugs, including random lossage of filter caps when the
12864           initial negotiation is delayed.  A few functions are still
12865           unimplemented.
12866         * gst/gstpad.h:
12867           Add GST_PAD_LINK_{SUCESSFUL|FAILED}() macros.  Please use
12868           these when testing GstPadLinkReturn values instead of comparing
12869           directly.
12870
12871 2003-12-23  David Schleef  <ds@schleef.org>
12872
12873         * gst/gstvalue.c: 
12874         * gst/gstvalue.h:
12875           Rearrange lots of code.  Change registration of compare function
12876           into registration of compare/serialize/deserialize functions.
12877           Doesn't include implementation of gst_value_[de]serialize(),
12878           but that should be easy.
12879
12880 2003-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
12881
12882         * docs/gst/gstreamer-sections.txt:
12883         * docs/gst/tmpl/gstprops.sgml: removed
12884         * docs/gst/tmpl/gstreamer-bufferpool.sgml: removed
12885           David removed props and caps code, so let's remove their docs as well.
12886           Removed all no longer existing symbols from gstreamer-sections.txt
12887           
12888 2003-12-22  Colin Walters  <walters@verbum.org>
12889
12890         * gst/gsttaginterface.c, gst/gsttaginterface.h,
12891           gst/gsttag.c, gst/gsttag.h:  Add interface to setting GValues
12892           of tags directly.
12893
12894 2003-12-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12895
12896         * gst/elements/gstelements.c:
12897           Set ranks of elements to NONE, so the autoplugger doesn't use them.
12898         * gst/elements/gstshaper.c: (gst_shaper_getcaps):
12899           Fix proxying to new CAPS stuff. Don't call get_allowed_caps but
12900           gst_caps (peer).
12901
12902 2003-12-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
12903
12904         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_caps_intersect):
12905         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link),
12906         (gst_spider_identity_getcaps), (gst_spider_identity_change_state),
12907         (gst_spider_identity_sink_loop_type_finding):
12908         * gst/autoplug/gstspideridentity.h:
12909           Fix autoplugging in spider element, so it works with new caps.
12910           This was mainly caused by identifying empty caps incorrectly.
12911
12912 2003-12-22  David Schleef  <ds@schleef.org>
12913
12914         * gststructure.c, gstvalue.c, gstvalue.h: Add
12915           gst_value_init_and_copy() and use it, to avoid silly mistakes in
12916           using g_value_copy()
12917
12918 2003-12-21  David Schleef  <ds@schleef.org>
12919
12920         * many, many files: Merge CAPS branch.  This includes:
12921           - implemention of GstValue and several GstValue types
12922           - implemention of GstStructure
12923           - entire rewrite of GstCaps
12924           - removal of GstProps
12925           - many changes to GstPad to compensate for new caps paradigm
12926           - removal of GstBufferpool
12927         * gst/Makefile.am, gst/gst.h, gst/gstpad.h, gst/gsttypefind.h,
12928         gstvalue.h, gst/gstcaps[2]*.[ch]:
12929           - rename gstcaps2.[ch] to gstcaps.[ch]
12930
12931 2003-12-21  Ronald Bultje  <rbultje@ronald.bitfreak.net>
12932
12933         * gst/gstqueue.c: (gst_queue_handle_pending_events),
12934         (gst_queue_chain), (gst_queue_handle_src_event):
12935           implement timeout for sending events. Workaround for if the
12936           pipeline on this queue is not passing any data.
12937
12938 2003-12-21  Ronald Bultje <rbultje@ronald.bitfreak.net>
12939                                                                                 
12940         * ChangeLog: moved to gstreamer/docs/random/old/ChangeLog.gstreamer
12941         * moved CVS to freedesktop.org
12942