add A GST_PLUGIN_PATH_ONLY env var; if it is set, it will only scan the GST_PLUGIN_PA...
[platform/upstream/gstreamer.git] / ChangeLog
1 2005-06-29  Thomas Vander Stichele  <thomas at apestaart dot org>
2
3         * check/Makefile.am:
4         * gst/gst.c: (add_path_func), (init_pre):
5         * gst/gstregistry.c: (gst_registry_add_path):
6           add A GST_PLUGIN_PATH_ONLY env var; if it is set, it will
7           only scan the GST_PLUGIN_PATH locations, and not add
8           system locations
9
10 2005-06-29  Thomas Vander Stichele  <thomas at apestaart dot org>
11
12         * docs/gst/gstreamer-sections.txt:
13         * docs/gst/tmpl/gstbasesrc.sgml:
14         * gst/gstelement.c:
15         * gst/gstelement.h:
16         * gst/gstevent.c:
17         * gst/gstutils.c:
18           doc fixes
19
20 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
21
22         * docs/manual/advanced-autoplugging.xml:
23           Fix autoplugging example.
24
25 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
26
27         * docs/manual/advanced-autoplugging.xml:
28         * docs/manual/mime-world.fig:
29           Try to get autoplugging working, fix type detection. Fix text
30           in hello-world image.
31
32 2005-06-29  Wim Taymans  <wim@fluendo.com>
33
34         * gst/base/gstbasesink.c: (gst_base_sink_handle_object),
35         (gst_base_sink_change_state):
36         Small debug line.
37
38         * gst/gstclock.h:
39         map SIGNAL and BROADCAST to the right function.
40
41         * gst/gstobject.h:
42         Remove redundant braces.
43
44         * gst/gstpad.c: (gst_pad_set_caps):
45         Don't call setcaps function when reseting caps to NULL.
46
47         * gst/gstsystemclock.c: (gst_system_clock_dispose),
48         (gst_system_clock_async_thread), (gst_system_clock_id_wait_async),
49         (gst_system_clock_id_unschedule):
50         Use BROADCAST as this is what we do.
51
52 2005-06-29  Wim Taymans  <wim@fluendo.com>
53
54         * gst/base/gstbasesink.c: (gst_base_sink_handle_object):
55         We are actually prerolling before commiting the state
56         change. 
57
58 2005-06-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
59
60         * docs/manual/advanced-clocks.xml:
61         * docs/manual/advanced-interfaces.xml:
62         * docs/manual/advanced-metadata.xml:
63         * docs/manual/advanced-position.xml:
64         * docs/manual/advanced-schedulers.xml:
65         * docs/manual/advanced-threads.xml:
66         * docs/manual/appendix-porting.xml:
67         * docs/manual/basics-bins.xml:
68         * docs/manual/basics-bus.xml:
69         * docs/manual/basics-elements.xml:
70         * docs/manual/basics-helloworld.xml:
71         * docs/manual/basics-pads.xml:
72         * docs/manual/highlevel-components.xml:
73         * docs/manual/manual.xml:
74         * docs/manual/thread.fig:
75           Update (until threads/scheduling) Application Development Manual;
76           remove GstThread, add GstBus, add simple porting checklist, add
77           documentation for tag writing, clocks, make all examples until this
78           part compile and run.
79         * examples/manual/Makefile.am:
80           Update from changes to Application Development Manual; add bus
81           example, remove thread example.
82
83 2005-06-28  Wim Taymans  <wim@fluendo.com>
84
85         * gst/gstbus.c: (gst_bus_post), (gst_bus_have_pending),
86         (gst_bus_set_flushing), (gst_bus_pop), (gst_bus_peek),
87         (gst_bus_source_dispatch):
88         Add debugging messages.
89         Make internal methods static.
90         Handle the case where the bus is flushed in the handler.
91         
92         * gst/gstelement.c: (gst_element_get_bus):
93         Fix refcount in _get_bus();
94
95         * gst/gstpipeline.c: (gst_pipeline_change_state),
96         (gst_pipeline_get_clock_func):
97         Clock refcounting fixes.
98         Handle the case where preroll timed out more gracefully.
99         
100         * gst/gstsystemclock.c: (gst_system_clock_dispose):
101         Clean up the internal thread in dispose. This is needed
102         for subclasses that actually get disposed.
103         
104         * gst/schedulers/threadscheduler.c:
105         (gst_thread_scheduler_class_init), (gst_thread_scheduler_func),
106         (gst_thread_scheduler_dispose):
107         Free thread pool in dispose.
108
109 2005-06-28  Andy Wingo  <wingo@pobox.com>
110
111         * tests/network-clock-utils.scm (debug, print-event): New utils.
112
113         * tests/network-clock.scm (*debug*, *with-graph*): New parameters.
114         (*packet-loss*): Unified loss probability.
115         (network-time): Report out-of-band events.
116
117         * tests/plot-data: Add support for out-of-band events. Hack it
118         into this script instead of passing it down the pipe; should fix
119         this later.
120
121 2005-06-28  Wim Taymans  <wim@fluendo.com>
122
123         * docs/gst/gstreamer.types:
124         * docs/gst/tmpl/gstbasesrc.sgml:
125         * docs/gst/tmpl/gstpad.sgml:
126         Docs fixes.
127
128 2005-06-28  Wim Taymans  <wim@fluendo.com>
129
130         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
131         (gst_proxy_pad_do_checkgetrange), (gst_proxy_pad_do_acceptcaps),
132         (gst_proxy_pad_do_fixatecaps):
133         Correctly proxy the check_pull_range function.
134
135 2005-06-28  Andy Wingo  <wingo@pobox.com>
136
137         * tests/network-clock.scm: Removed need for slib.
138         
139 2005-06-28  Wim Taymans  <wim@fluendo.com>
140
141         * gst/base/gstbasesink.c: (gst_basesink_set_pad_functions),
142         (gst_basesink_preroll_queue_flush):
143         * gst/base/gstbasesrc.c: (gst_basesrc_set_dataflow_funcs):
144         * gst/elements/gsttee.c: (gst_tee_update_pad_functions):
145         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
146         (gst_proxy_pad_do_acceptcaps), (gst_proxy_pad_do_fixatecaps),
147         (gst_proxy_pad_set_property):
148         * gst/gstpad.c:
149         * gst/gstpad.h:
150         * gst/gstqueue.c: (gst_queue_init):
151         The deprecated pad loop function is removed now.
152
153 2005-06-28  Andy Wingo  <wingo@pobox.com>
154
155         * tests/network-clock.scm (*timeout*, *send-loss*, *recv-loss*):
156         New parameters, simulate network packet loss.
157
158         * tests/network-clock-utils.scm: Initialize the RNG.
159
160 2005-06-28  Wim Taymans  <wim@fluendo.com>
161
162         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_flush),
163         (gst_basesink_event), (gst_basesink_deactivate):
164         Flushing the preroll queue always needs to unlock the waiters.
165
166 2005-06-28  Edward Hervey  <edward@fluendo.com>
167
168         * gst/gstpipeline.c: (gst_pipeline_send_event): 
169         Wheen a seek was successful on a pipeline, set the stream_time to the
170         seek offset in order to have a synchronized stream_time.
171
172 2005-06-28  Wim Taymans  <wim@fluendo.com>
173
174         * gst/gstghostpad.c: (gst_proxy_pad_do_bufferalloc),
175         (gst_proxy_pad_do_getrange), (gst_proxy_pad_do_checkgetrange),
176         (gst_proxy_pad_do_getcaps), (gst_proxy_pad_do_acceptcaps),
177         (gst_proxy_pad_do_fixatecaps):
178         Call wrapper function instead of just calling the function
179         pointers. This takes care of any locking and whatmore.
180
181 2005-06-28  Wim Taymans  <wim@fluendo.com>
182
183         * gst/gstpad.c: (gst_pad_alloc_buffer), (gst_pad_push),
184         (gst_pad_pull_range):
185         * gst/gstpad.h:
186         CONNECTED -> LINKED.
187
188 2005-06-28  Andy Wingo  <wingo@pobox.com>
189
190         * *.c: Don't cast to GST_OBJECT when reffing or unreffing. Large
191         source-munging commit!!!
192
193         * gst/gstobject.c (gst_object_unref, gst_object_ref) 
194         (gst_object_sink): Take gpointer arguments, not GstObject --
195         avoids casts. Like GLib.
196
197         * gst/gstghostpad.c (gst_proxy_pad_do_activate): Don't proxy
198         activate.
199
200 2005-06-27  Andy Wingo  <wingo@pobox.com>
201
202         * gst/base/gsttypefindhelper.c (gst_type_find_helper): Unref any
203         remaining buffer.
204
205         * gst/gsttrace.c (gst_alloc_trace_list_sorted): New helper,
206         returns a sorted copy of the trace list.
207         (gst_alloc_trace_print_live): New API, only prints traces with
208         live objects. Sort the list.
209         (gst_alloc_trace_print_all): Sort the list.
210         (gst_alloc_trace_print): Align columns.
211
212         * gst/elements/gstttypefindelement.c:
213         * gst/elements/gsttee.c:
214         * gst/base/gstbasesrc.c:
215         * gst/base/gstbasesink.c:
216         * gst/base/gstbasetransform.c:
217         * gst/gstqueue.c: Adapt for pad activation changes.
218
219         * gst/gstpipeline.c (gst_pipeline_init): Unref after parenting
220         sched.
221         (gst_pipeline_dispose): Drop ref on sched.
222
223         * gst/gstpad.c (gst_pad_init): Set the default activate func.
224         (gst_pad_activate_default): Push mode by default.
225         (pre_activate_switch, post_activate_switch): New stubs, things to
226         do before and after switching activation modes on pads.
227         (gst_pad_set_active): Take a boolean and not a mode, dispatch to
228         the pad's activate function to choose which mode to activate.
229         Shortcut on deactivation and call the right function directly.
230         (gst_pad_activate_pull): New API, (de)activates a pad in pull
231         mode.
232         (gst_pad_activate_push): New API, same for push mode.
233         (gst_pad_set_activate_function) 
234         (gst_pad_set_activatepull_function) 
235         (gst_pad_set_activatepush_function): Setters for new API.
236
237         * gst/gstminiobject.c (gst_mini_object_new, gst_mini_object_free):
238         Trace all miniobjects.
239         (gst_mini_object_make_writable): Unref the arg if we copy, like
240         gst_caps_make_writable.
241
242         * gst/gstmessage.c (_gst_message_initialize): No trace init.
243
244         * gst/gstghostpad.c (gst_proxy_pad_do_activate) 
245         (gst_proxy_pad_do_activatepull, gst_proxy_pad_do_activatepush):
246         Adapt for new pad API.
247
248         * gst/gstevent.c (_gst_event_initialize): Don't initialize trace.
249
250         * gst/gstelement.h:
251         * gst/gstelement.c (gst_element_iterate_src_pads) 
252         (gst_element_iterate_sink_pads): New API functions.
253         
254         * gst/gstelement.c (iterator_fold_with_resync): New utility,
255         should fold into gstiterator.c in some form.
256         (gst_element_pads_activate): Simplified via use of fold and
257         delegation of decisions to gstpad->activate.
258
259         * gst/gstbus.c (gst_bus_source_finalize): Set the bus to NULL,
260         help in debugging.
261
262         * gst/gstbuffer.c (_gst_buffer_initialize): Ref the buffer type
263         class once in init, like gstmessage. Didn't run into this issue
264         but it seems correct. Don't initialize a trace, gstminiobject does
265         that.
266
267         * check/pipelines/simple_launch_lines.c (test_stop_from_app): New
268         test, runs fakesrc ! fakesink, stopping on ::handoff via a message
269         to the bus.
270         (assert_live_count): New util function, uses alloc traces to check
271         cleanup.
272
273         * check/gst/gstghostpad.c (test_ghost_pads): More refcount checks.
274         To be modified when unlink drops the internal pad.
275
276 2005-06-27  Wim Taymans  <wim@fluendo.com>
277
278         * gst/gstbin.c: (gst_bin_get_state), (gst_bin_iterate_state_order),
279         (gst_bin_change_state):
280         Cleanup the get_state() function a little, make sure it
281         iterates the same set of elements.
282         Added stub iterate_state_order().
283
284 2005-06-27  Thomas Vander Stichele  <thomas at apestaart dot org>
285
286         * docs/gst/gstreamer-docs.sgml:
287         * docs/gst/gstreamer-sections.txt:
288         * docs/gst/gstreamer.types:
289         * docs/gst/tmpl/gstbasesink.sgml:
290         * docs/gst/tmpl/gstbasesrc.sgml:
291         * docs/gst/tmpl/gstbasetransform.sgml:
292         * docs/gst/tmpl/gstelement.sgml:
293         * docs/gst/tmpl/gstiterator.sgml:
294         * gst/base/gstbasesrc.c:
295         * gst/base/gstbasesrc.h:
296         * gst/base/gstbasetransform.h:
297         * gst/gstelement.c:
298         * gst/gstiterator.h:
299           adding basetransform and iterator docs
300
301 2005-06-27  Andy Wingo  <wingo@pobox.com>
302
303         * docs/design/part-activation.txt: Notes on how activation should
304         work -- not quite implemented yet.
305
306 2005-06-25  Wim Taymans  <wim@fluendo.com>
307
308         * gst/gstghostpad.c: (gst_proxy_pad_do_chain):
309         At least get the chain function correct, needs more
310         fixing.
311
312 2005-06-25  Wim Taymans  <wim@fluendo.com>
313
314         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
315         (gst_basesink_handle_object), (gst_basesink_event),
316         (gst_basesink_do_sync), (gst_basesink_handle_event),
317         (gst_basesink_change_state):
318         * gst/gsttask.h:
319         Right, two problems here: ghostpads don't take locks and
320         glib _rec_mutex_lock_full() with depth==0 still locks.
321         Catch illegal locking and g_warn them.
322
323 2005-06-25  Wim Taymans  <wim@fluendo.com>
324
325         * check/states/sinks.c: (START_TEST), (gst_object_suite):
326         Have to check for completion now...
327
328 2005-06-25  Wim Taymans  <wim@fluendo.com>
329
330         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
331         (gst_basesink_handle_object), (gst_basesink_event),
332         (gst_basesink_do_sync), (gst_basesink_handle_event),
333         (gst_basesink_change_state):
334         * gst/gstpad.h:
335         Unlock STREAM_LOCK whatever the recursion was.
336
337 2005-06-25  Wim Taymans  <wim@fluendo.com>
338
339         * gst/base/gstbasesink.c: (gst_basesink_set_property),
340         (gst_basesink_preroll_queue_empty),
341         (gst_basesink_preroll_queue_flush), (gst_basesink_handle_object),
342         (gst_basesink_event), (gst_basesink_do_sync),
343         (gst_basesink_handle_event), (gst_basesink_handle_buffer),
344         (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate),
345         (gst_basesink_change_state):
346         Reworked the base sink, handle event and buffer serialisation
347         correctly and removed possible deadlock.
348         Handle EOS correctly.
349
350 2005-06-25  Wim Taymans  <wim@fluendo.com>
351
352         * gst/gstpipeline.c: (is_eos), (pipeline_bus_handler),
353         (gst_pipeline_change_state):
354         * tools/gst-launch.c: (check_intr), (event_loop), (main):
355         Allow elements to post EOS in the state change function.
356         Fix up -launch, make it exit the poll loop when the
357         pipeline actually changed state.
358         Fix up warning parsing in -launch.
359
360 2005-06-25  Wim Taymans  <wim@fluendo.com>
361
362         * gst/elements/gsttee.c: (gst_tee_chain), (gst_tee_loop),
363         (gst_tee_sink_activate):
364         Core takes STREAM_LOCK for us now.
365
366 2005-06-25  Wim Taymans  <wim@fluendo.com>
367
368         * gst/gstelement.c: (gst_element_get_state_func),
369         (gst_element_set_state):
370         * gst/gstelement.h:
371         * gst/gstmessage.c: (gst_message_parse_error),
372         (gst_message_parse_warning):
373         Keep track of current target state while performing a state
374         change so that subclasses can do something interesting.
375         Fix parsing of warning/error messages when GError is NULL.
376
377 2005-06-24  Thomas Vander Stichele  <thomas at apestaart dot org>
378
379         * docs/gst/Makefile.am:
380         * docs/gst/gstreamer-docs.sgml:
381         * docs/gst/gstreamer-sections.txt:
382         * docs/gst/gstreamer.types:
383         * docs/gst/tmpl/gstbasesink.sgml:
384         * docs/gst/tmpl/gstbasesrc.sgml:
385         * docs/gst/tmpl/gstbin.sgml:
386         * docs/gst/tmpl/gstcompat.sgml:
387         * docs/gst/tmpl/gstfakesink.sgml:
388         * docs/gst/tmpl/gstfakesrc.sgml:
389         * docs/gst/tmpl/gstfilesink.sgml:
390         * docs/gst/tmpl/gstfilesrc.sgml:
391         * docs/gst/tmpl/gstindex.sgml:
392         * docs/manual/appendix-quotes.xml:
393         * gst/base/gstbasesrc.h:
394         * gst/elements/gstfakesrc.h:
395         * gst/gstmessage.h:
396           start pulling in base classes and elements in our docs
397
398 2005-06-24  Stefan Kost  <ensonic@users.sf.net>
399
400         * docs/gst/Makefile.am:
401         * docs/libs/Makefile.am:
402           fixed make distcheck with gtk-doc 1.3
403
404 2005-06-23  Wim Taymans  <wim@fluendo.com>
405
406         * gst/gstelement.c: (gst_element_get_state_func),
407         (gst_element_set_state), (gst_element_change_state):
408         When the state did not change, also report NO_PREROLL
409         when it matters.
410
411 2005-06-23  Wim Taymans  <wim@fluendo.com>
412
413         * gst/gstpad.c: (gst_pad_event_default):
414         * gst/gstqueue.c: (gst_queue_loop):
415         No unsafe task pausing please.
416
417 2005-06-23  Wim Taymans  <wim@fluendo.com>
418
419         * gst/schedulers/threadscheduler.c:
420         (gst_thread_scheduler_task_start),
421         (gst_thread_scheduler_task_pause), (gst_thread_scheduler_func):
422         Ref the task before pushing it on the threadpool. This
423         makes sure that we have a ref when the threadfunction is
424         actually called.
425
426 2005-06-23  Andy Wingo  <wingo@pobox.com>
427
428         * gst/base/gstbasesrc.c (gst_basesrc_get_range): Check if the
429         offset is greater than the file's size.
430
431         * gst/gstobject.h (GST_CLASS_LOCK, GST_CLASS_TRYLOCK) 
432         (GST_CLASS_UNLOCK, GST_CLASS_GET_LOCK, GstObjectClass)
433         * gst/gstobject.c (gst_object_class_init): Make the class lock
434         recursive. Wim won't let me drop deep_notify. Decodebin works
435         again, whoopdy doo.
436
437         * gst/gstghostpad.c (on_int_notify): Catches notify::caps on the
438         internal pad, and hacks accordingly. Doesn't do it on the target
439         pad because we change its caps. Probably catches all cases of
440         interest tho.
441         (gst_ghost_pad_set_property): Connect to notify::caps as
442         appropritate.
443
444         * tests/network-clock.scm (plot-simulation): Pipe data to the
445         elite python skript.
446
447         * tests/network-clock-utils.scm (define-parameter): New macro,
448         defines a parameter that can be set via the command line.
449         (set-parameter!, parse-parameter-arguments): Command line args
450         parser.
451
452         * tests/plot-data: Simple matplotlib-based plotter, takes input on
453         stdin.
454
455 2005-06-23  Jan Schmidt  <thaytan@mad.scientist.com>
456
457         * gst/elements/gsttypefindelement.c:
458         (gst_type_find_element_handle_event):
459           Don't restart typefinding on a discont.
460         * gst/gstelement.c: (gst_element_set_state):
461           Debug spelling fix.
462         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_send_event):
463           Allow changing mode of an active pad.
464           Debug output fixes.
465         * gst/registries/gstlibxmlregistry.c: (load_feature):
466           Don't cast a static pad template to a normal pad template.
467
468 2005-06-23  Thomas Vander Stichele  <thomas at apestaart dot org>
469
470         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
471         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
472           remove gst_strtoll completely, since it didn't actually do
473           anything more than what g_ascii_strtoull already does.
474           check for range errors when deserializing
475           do a cast for the unsigned cases; but further fixing needs
476           a decision on what the interpretation of "(int)" and
477           deserialization should be for values that fall outside the
478           type's boundaries (ie, refuse, or interpret as casting)
479
480 2005-06-23  Wim Taymans  <wim@fluendo.com>
481
482         * check/Makefile.am:
483         * check/states/sinks.c: (START_TEST), (gst_object_suite), (main):
484         * docs/design/part-live-source.txt:
485         * docs/design/part-states.txt:
486         * gst/base/gstbasesrc.c: (gst_basesrc_init),
487         (gst_basesrc_set_live), (gst_basesrc_is_live),
488         (gst_basesrc_get_range), (gst_basesrc_activate),
489         (gst_basesrc_change_state):
490         * gst/base/gstbasesrc.h:
491         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
492         (gst_fakesrc_set_property), (gst_fakesrc_get_property):
493         * gst/gstbin.c: (gst_bin_get_state), (gst_bin_change_state):
494         * gst/gstelement.c: (gst_element_get_state_func),
495         (gst_element_set_state):
496         * gst/gstelement.h:
497         * gst/gsttypes.h:
498         * tools/gst-launch.c: (event_loop), (main):
499         Added support for live sources and other elements that
500         cannot do preroll.
501         Updated design docs, added live-source design doc.
502         Implemented live source functionality in basesrc
503         Fix error condition in _bin_get_state()
504         Implement live source handling in -launch.
505         Added check for live sources.
506         Fixed case in GstBin where elements were changed state
507         multiple times.
508
509
510 2005-06-23  Andy Wingo  <wingo@pobox.com>
511
512         * check/gst/gstpad.c (test_get_allowed_caps, test_refcount): Fix
513         borken refcounting.
514
515         * gst/gstpad.c (gst_pad_set_caps): Remove needless refs,
516         gst_caps_replace takes care of this for us.
517
518         * gst/gstghostpad.c (gst_proxy_pad_do_setcaps): Call the full
519         gst_pad_set_caps on the target, not just its setcaps() function.
520
521         * tests/network-clock.scm: 
522         * tests/network-clock-utils.scm: A network clock simulator.
523         Something of an algorithmic testbed before doing something in C.
524
525 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
526
527         * check/Makefile.am:
528         * check/gst/capslist.h:
529           copy over from 0.8, and add two with bitmasks specified with
530           (int) 0xFF...
531         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite):
532           add test to parse everything from capslist.h
533         * check/gst/gststructure.c: (START_TEST), (gst_value_suite),
534         (main):
535           add test for structure deserialization
536         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
537           add tests for deserialization of strings to int types
538         * gst/gststructure.c: (gst_structure_nth_field_name):
539         * gst/gststructure.h:
540           add a way to get the name of a field referenced by index
541         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
542           instead of checking if the resulting long long lies between
543           min and max, we check if the long long would fit into
544           a number of bytes for the final type.
545           This fixes cases where a string represents 2^32 - 1, which
546           when cast to int would be the (valid) -1, but is bigger than
547           G_MAXINT
548
549 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
550
551         * gst/parse/grammar.y:
552           add a log line for type deserialization
553
554 2005-06-22  Thomas Vander Stichele  <thomas at apestaart dot org>
555
556         * check/gst/gstvalue.c: (START_TEST):
557         * gst/gstvalue.c: (gst_value_deserialize):
558           return long long, not int, so gint64 deserialization actually
559           works.  Is there any flag that makes the compiler check this ?
560           Fixes #308559
561
562 2005-06-22  Wim Taymans  <wim@fluendo.com>
563
564         * gst/gstbuffer.h:
565         Added convenience macros for setting buffers in GValue.
566
567 2005-06-21  Thomas Vander Stichele  <thomas at apestaart dot org>
568
569         * check/gst/.cvsignore:
570         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite):
571           add a test deserializing int64, and comment part out because
572           it fails, yay !
573
574 2005-06-21  Thomas Vander Stichele  <thomas at apestaart dot org>
575
576         * check/Makefile.am:
577         * check/gst/gstvalue.c: (START_TEST), (gst_value_suite), (main):
578         * testsuite/Makefile.am:
579         * testsuite/caps/Makefile.am:
580         * testsuite/caps/value_serialize.c:
581         * testsuite/test_gst_init.c:
582           move a value_serialize test over
583
584 2005-06-20  Wim Taymans  <wim@fluendo.com>
585
586         * gst/gstpad.c:
587         Small doc updates.
588         
589         * gst/gstvalue.c: (gst_value_compare_buffer),
590         (gst_value_serialize_buffer), (gst_value_deserialize_buffer),
591         (gst_value_compare_flags), (gst_value_serialize_flags),
592         (gst_value_deserialize_flags), (_gst_value_initialize):
593         Fix serialisation of buffers, they are not boxed types anymore
594
595 2005-06-20  Wim Taymans  <wim@fluendo.com>
596
597         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite):
598         Testcase to show error in buffer-on-caps serialisation.
599
600 2005-06-20  Andy Wingo  <wingo@pobox.com>
601
602         * docs/random/wingo/porting-plugins-to-0.9: A pitiful document I
603         will be adding to later.
604
605         * gst/gstsystemclock.c (gst_system_clock_init): Unlock the clock
606         if its socks fill with rocks.
607         (gst_system_clock_obtain): Set the name on object construction.
608         Avoid double-checked locking.
609
610 2005-06-20  Tim-Philipp Müller  <tim at centricular dot net>
611
612         * gst/gsturi.c: (gst_element_make_from_uri):
613           Fix potential endless loop.
614
615 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
616
617         * check/Makefile.am:
618           add gsttag
619         * check/gst/gsttag.c: (check_tags), (START_TEST), (gst_tag_suite),
620         (main):
621           move over from testsuite dir and clean up
622         * configure.ac:
623         * gst/gsttag.c:
624         * testsuite/Makefile.am:
625         * testsuite/tags/.cvsignore:
626         * testsuite/tags/Makefile.am:
627         * testsuite/tags/merge.c:
628           remove testsuite/tags
629
630 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
631
632         * docs/gst/gstreamer-sections.txt:
633         * docs/gst/tmpl/gstenumtypes.sgml:
634         * win32/gstenumtypes.c:
635           clean up documentation build a little
636
637 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
638
639         * check/gstcheck.h:
640           add macros for checking refcounts on objects and caps
641         * check/gst/gstpad.c: (START_TEST), (gst_pad_suite):
642           add some more unit tests
643         * gst/gstpad.c: (gst_pad_link_check_compatible_unlocked),
644         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_get_allowed_caps):
645           fix leaked refcounts (I hope :)) so unittest works
646         * gst/gstpad.h:
647           whitespace removal
648
649 2005-06-19  Thomas Vander Stichele  <thomas at apestaart dot org>
650
651         * configure.ac: back to HEAD
652
653 === release 0.9.1 ===
654
655 2005-06-17  Thomas Vander Stichele  <thomas at apestaart dot org>
656
657         * NEWS:
658         * RELEASE:
659           updated
660
661 2005-06-17  Andy Wingo  <wingo@pobox.com>
662
663         * gst/base/gstbasesink.c (gst_basesink_chain): Remove bogus
664         assert; it's always possible that the pad gets deactivated in
665         between the checks in gstpad.c and the implementation. Rely on
666         finish_preroll() to return a FLUSHING or similar instead of on the
667         assert.
668         
669         * gst/base/gstbasesink.c (gst_basesink_event): Only wait for the
670         clock and post an EOS message if we come out of finish_preroll in
671         the playing state.
672
673 2005-06-16  David Schleef  <ds@schleef.org>
674
675         * gst/elements/gstcapsfilter.c: (gst_capsfilter_class_init),
676         (gst_capsfilter_set_property): Allow NULL as possible value
677         for filter_caps property, indicating GST_CAPS_ANY.
678
679 2005-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
680
681         * gst/elements/gstfakesrc.c: (gst_fakesrc_create):
682           fix debug output
683         * gst/schedulers/Makefile.am:
684           use libgst prefix
685         * gstreamer.spec.in:
686           fix spec for it
687
688 2005-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
689
690         * gstreamer.spec.in:
691           clean up
692
693 2005-06-08  Andy Wingo  <wingo@pobox.com>
694
695         * gst/gstutils.c: RPAD fixes all around.
696         (gst_element_link_pads): Refcounting fixes.
697
698         * tools/gst-inspect.c:
699         * tools/gst-xmlinspect.c:
700         * parse/grammar.y:
701         * gst/base/gsttypefindhelper.c:
702         * gst/base/gstbasesink.c:
703         * gst/gstqueue.c: RPAD fixes.
704
705         * gst/gstghostpad.h:
706         * gst/gstghostpad.c: New ghost pad implementation as full proxy
707         pads. The tricky thing is they provide both source and sink
708         interfaces, since they proxy the internal pad for the external
709         pad, and vice versa. Implement with lower-level ProxyPad objects,
710         with the interior proxy pad as a child of the exterior ghost pad.
711         Should write a doc on this.
712         
713         * gst/gstpad.h: s/RPAD/PAD/, s/RealPad/Pad/.
714         (gst_pad_set_name, gst_pad_set_parent): Macros removed, use
715         gst_object API.
716         
717         * gst/gstpad.c: Big changes. No more stub base GstPad, now all
718         pads are real pads. No ghost pads in this file. Not documenting
719         the myriad s/RPAD/PAD/ and REALIZE fixes.
720         (gst_pad_class_init): Add properties for "direction" and
721         "template". Both are construct-only, so they can't change during
722         the life of the pad. Fixes properly deriving from GstPad.
723         (gst_pad_custom_new, gst_pad_custom_new_from_template): Gone. For
724         derived objects, just set properties when creating the objects via
725         g_object_new.
726         (gst_pad_get_parent): Implement as a function, return NULL if the
727         parent is not an element.
728         (gst_pad_get_real_parent, gst_pad_add_ghost_pad)
729         (gst_pad_remove_ghost_pad, gst_pad_realize): Removed.
730         
731         * gst/gstobject.c (gst_object_class_init): Make name a construct
732         property. Don't set it in the object init.
733
734         * gst/gstelement.c (gst_element_add_pad): Don't allow adding pads
735         with UNKNOWN direction.
736         (gst_element_add_ghost_pad): Remove non-orthogonal API. Replace
737         with gst_element_add_pad (e, gst_ghost_pad_new (name, pad)).
738         (gst_element_remove_pad): Remove ghost-pad special cases.
739         (gst_element_pads_activate): Remove rpad cruft.
740
741         * gst/gstbin.c (gst_bin_change_state): Use gst_pad_get_parent to
742         catch the pad's-parent-not-an-element case.
743
744         * gst/gst.h: Include gstghostpad.h.
745
746         * gst/gst.c (init_post): No more real, ghost pads.
747
748         * gst/Makefile.am: Add gstghostpad.[ch].
749
750         * check/Makefile.am:
751         * check/gst/gstbin.c:
752         * check/gst/gstghostpad.c (test_ghost_pads): Check that linking
753         into a bin creates ghost pads, and that the refcounts are right.
754         Partly moved from gstbin.c.
755
756 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
757
758         * check/gst-libs/.cvsignore:
759         * check/gst/.cvsignore:
760         * check/pipelines/.cvsignore:
761           ignore more
762         * check/pipelines/cleanup.c: (setup_pipeline), (run_pipeline),
763         (START_TEST), (cleanup_suite), (main):
764           add some tests related to cleanup after running pipelines
765
766 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
767
768         * check/gst/gstbuffer.c: (START_TEST), (gst_test_suite), (main):
769           add a testsuite for GstBuffer
770
771 2005-06-08  Thomas Vander Stichele  <thomas at apestaart dot org>
772
773         * gst/gstminiobject.h:
774           add defines for accessing the refcount
775
776 2005-06-03  Stefan Kost  <ensonic@users.sf.net>
777
778         * Makefile.am: added support for html unit test coverage reports
779
780 2005-06-03  Jan Schmidt  <thaytan@mad.scientist.com>
781
782         * gst/elements/gstcapsfilter.c: (gst_capsfilter_set_property):
783           Free existing caps if the capsfilter changes. Add a FIXME about
784           setting those caps on the pads.
785
786         * gst/gstutils.c: (gst_element_get_compatible_pad), (ghost_up):
787           Before adding a ghost pad to a parent bin, check that there isn't
788           already one for the element on the bin. Prevents infinite recursion
789           when using decodebin in parse pipelines. Andy says he'll rewrite the
790           way this works anyway, so ignore the hack.
791
792 2005-06-02  Andy Wingo  <wingo@pobox.com>
793
794         * gst/elements/gsttypefindelement.c (do_pull_typefind): Query the
795         file size, pass it on to the type find helper.
796
797         * gst/base/gstbasesrc.c (gst_basesrc_do_seek): Set the
798         segment_start and segment_end properly according to the seek
799         method. Segment_end is still a bit flaky because offset can be
800         negative for CUR and END cases, but it takes -1 as an "unset"
801         value.
802
803 2005-06-02  Wim Taymans  <wim@fluendo.com>
804
805         * gst/base/gstbasesink.c: (gst_basesink_pad_buffer_alloc),
806         (gst_base_sink_buffer_alloc), (gst_basesink_preroll_queue_push),
807         (gst_basesink_activate):
808         * gst/base/gstbasesink.h:
809         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
810         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_alloc_buffer),
811         (gst_pad_query), (gst_pad_start_task):
812         * gst/gstpad.h:
813         * gst/gstqueue.c: (gst_queue_bufferalloc),
814         (gst_queue_handle_sink_event), (gst_queue_chain):
815         Bufferalloc: return GstFlowReturn to more accuratly report
816         why allocation failed.
817
818 2005-06-02  Wim Taymans  <wim@fluendo.com>
819
820         * gst/gstpipeline.c: (gst_pipeline_send_event):
821         Take snapshot of state without blocking.
822
823 2005-06-02  Wim Taymans  <wim@fluendo.com>
824
825         * docs/design/part-TODO.txt:
826         * docs/design/part-caps.txt:
827         * docs/design/part-clocks.txt:
828         * docs/design/part-negotiation.txt:
829         * docs/design/part-preroll.txt:
830         Small doc updates 
831
832 2005-05-30  Wim Taymans  <wim@fluendo.com>
833
834         * gst/elements/gstidentity.c: (gst_identity_event),
835         (gst_identity_transform), (gst_identity_get_property):
836         Protect last_message property as it is accessed from
837         multiple threads.
838
839 2005-05-30  Wim Taymans  <wim@fluendo.com>
840
841         * gst/gstelement.c: (gst_element_init),
842         (gst_element_pads_activate), (gst_element_change_state):
843         Slicker pad activation code.
844
845 2005-05-30  Wim Taymans  <wim@fluendo.com>
846
847         * gst/Makefile.am:
848         * gst/gstelement.h:
849         * gst/gstelementfactory.h:
850         * gst/gsttypes.h:
851         Move elementfactory methods to separate .h file.
852
853 2005-05-30  Wim Taymans  <wim@fluendo.com>
854
855         * docs/design/part-overview.txt:
856         * gst/gstsystemclock.h:
857         Small typo fixes, doc updates.
858
859 2005-05-30  Wim Taymans  <wim@fluendo.com>
860
861         * gst/gst.c: (gst_init_get_popt_table), (init_post),
862         (init_popt_callback):
863         Remove cpu-opt flag.
864
865 2005-05-30  Wim Taymans  <wim@fluendo.com>
866
867         * gst/gstbuffer.c: (gst_subbuffer_finalize),
868         (gst_buffer_create_sub), (gst_buffer_is_span_fast):
869         * gst/gstbuffer.h:
870         Avoid typechecking in places where not needed.
871         Added accessor for malloc_data.
872
873 2005-05-30  Wim Taymans  <wim@fluendo.com>
874
875         * gst/gstpad.c: (gst_real_pad_init), (gst_pad_set_active),
876         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_accept_caps),
877         (gst_pad_configure_sink), (gst_pad_configure_src),
878         (gst_pad_alloc_buffer), (gst_pad_query), (gst_pad_send_event),
879         (gst_pad_start_task):
880         Propagate errors from _set_caps() in configure_src/sink
881         functions instead of returning TRUE.
882         FLUSH events can travel up and downstream
883
884
885 2005-05-30  Wim Taymans  <wim@fluendo.com>
886
887         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_push),
888         (gst_basesink_activate):
889         Handle EOS in preroll.
890
891 2005-05-30  Wim Taymans  <wim@fluendo.com>
892
893         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
894         (gst_queue_loop), (gst_queue_handle_src_event):
895         Remove old pieces of code
896         Flushing the queue in an upstream event is a very bad idea.
897
898 2005-05-26  Andy Wingo  <wingo@pobox.com>
899
900         * gst/gstminiobject.c (gst_value_mini_object_collect): Use
901         gst_value_set_mini_object so as to add a ref on the object (which
902         will be removed when the value is unset).
903
904         * gst/elements/gstfakesink.c (gst_fakesink_class_init): Fix signal
905         arg type in ::handoff.
906
907         * gst/gstelement.c (gst_element_change_state): Also deactivate
908         pads in READY->NULL, just in case the element didn't make it to
909         PAUSED. Wingo tested, Wim approved.
910
911 2005-05-26  Wim Taymans  <wim@fluendo.com>
912
913         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
914         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_alloc_buffer),
915         (gst_pad_query), (gst_pad_send_event), (gst_pad_start_task):
916         A flushing pad cannot be used to alloc_buffer from.
917
918 2005-05-26  Wim Taymans  <wim@fluendo.com>
919
920         * gst/gstbus.c: (gst_bus_init), (gst_bus_dispose), (gst_bus_post),
921         (gst_bus_pop), (gst_bus_source_prepare), (gst_bus_source_check),
922         (gst_bus_source_dispatch), (gst_bus_source_finalize),
923         (gst_bus_create_watch), (gst_bus_add_watch_full):
924         * gst/gstbus.h:
925         Implement a real GSource and use g_main_context_wakeup() to
926         signal new messages instead of the socketpair.
927
928 2005-05-25  Wim Taymans  <wim@fluendo.com>
929
930         * gst/gstbin.c: (bin_element_is_sink), (has_ancestor),
931         (bin_element_is_semi_sink), (append_child), (gst_bin_change_state):
932         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
933         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_query),
934         (gst_pad_send_event), (gst_pad_start_task):
935         * gst/gstqueue.c: (gst_queue_init), (gst_queue_locked_flush),
936         (gst_queue_handle_sink_event), (gst_queue_chain), (gst_queue_loop),
937         (gst_queue_sink_activate), (gst_queue_src_activate),
938         (gst_queue_change_state):
939         * gst/gstqueue.h:
940         Fix state changes for non sinks. We now change sinks, then elements
941         with unconnected srcpads, then the rest.
942         More efficient queue unlocking in flush and state changes.
943         Set the pad activate mode even if it does not have an activate
944         function.
945
946 2005-05-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
947
948         * gst/base/gstbasesrc.c: (gst_basesrc_activate):
949           Don't go in pull mode for non-seekable sources.
950         * gst/elements/gsttypefindelement.h:
951         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
952         (gst_type_find_element_dispose), (gst_type_find_handle_src_query),
953         (free_entry), (stop_typefinding),
954         (gst_type_find_element_handle_event), (find_peek),
955         (gst_type_find_element_chain), (do_pull_typefind),
956         (gst_type_find_element_change_state):
957           Allow typefinding (w/o seeking) in push-mode, simplified version
958           of what was in 0.8.
959         * gst/gstutils.c: (gst_buffer_join):
960         * gst/gstutils.h:
961           gst_buffer_join() from 0.8.
962
963 2005-05-25  Wim Taymans  <wim@fluendo.com>
964
965         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_prepare),
966         (gst_pad_link), (gst_pad_accept_caps), (gst_pad_query),
967         (gst_pad_send_event), (gst_pad_start_task):
968         Disable attempt at mode switching until it is figured out.
969
970 2005-05-25  Wim Taymans  <wim@fluendo.com>
971
972         * gst/base/gstadapter.c: (gst_adapter_peek), (gst_adapter_flush):
973         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_push),
974         (gst_basesink_finish_preroll), (gst_basesink_chain),
975         (gst_basesink_loop), (gst_basesink_activate),
976         (gst_basesink_change_state):
977         * gst/base/gstbasesrc.c: (gst_basesrc_do_seek),
978         (gst_basesrc_get_range), (gst_basesrc_loop),
979         (gst_basesrc_activate):
980         * gst/elements/gsttee.c: (gst_tee_sink_activate):
981         * gst/gstpad.c: (gst_pad_dispose), (gst_real_pad_class_init),
982         (gst_real_pad_init), (gst_real_pad_set_property),
983         (gst_real_pad_get_property), (gst_pad_set_active),
984         (gst_pad_is_active), (gst_pad_get_query_types), (gst_pad_unlink),
985         (gst_pad_link_prepare), (gst_pad_link), (gst_pad_get_real_parent),
986         (gst_real_pad_get_caps_unlocked), (gst_pad_peer_get_caps),
987         (gst_pad_accept_caps), (gst_pad_get_peer), (gst_pad_realize),
988         (gst_pad_event_default_dispatch), (gst_pad_event_default),
989         (gst_pad_dispatcher), (gst_pad_query), (gst_real_pad_dispose),
990         (gst_pad_save_thyself), (handle_pad_block), (gst_pad_chain),
991         (gst_pad_push), (gst_pad_get_range), (gst_pad_pull_range),
992         (gst_pad_send_event), (gst_pad_start_task), (gst_pad_pause_task),
993         (gst_pad_stop_task):
994         * gst/gstpad.h:
995         * gst/gstqueue.c: (gst_queue_handle_sink_event), (gst_queue_chain),
996         (gst_queue_loop), (gst_queue_src_activate):
997         * gst/gsttask.c: (gst_task_init), (gst_task_set_lock),
998         (gst_task_get_state):
999         * gst/gsttask.h:
1000         * gst/schedulers/threadscheduler.c:
1001         (gst_thread_scheduler_task_start), (gst_thread_scheduler_func):
1002         Implement gst_pad_pause/start/stop_task(), take STREAM lock
1003         in task function.
1004         Remove ACTIVE pad flag, use FLUSHING everywhere
1005         Added _pad_chain(), _pad_get_range() to call chain/getrange 
1006         functions.
1007         Add locks around IS_FLUSHING when reading.
1008         Take STREAM lock in chain(), get_range() functions so plugins
1009         don't need to take it anymore.
1010         
1011
1012
1013 2005-05-25  Wim Taymans  <wim@fluendo.com>
1014
1015         * tools/gst-launch.c: (event_loop):
1016         Unref message after using its contents instead of
1017         before.
1018
1019 2005-05-24  Wim Taymans  <wim@fluendo.com>
1020
1021         * docs/design/draft-ghostpads.txt:
1022         * docs/design/draft-push-pull.txt:
1023         * docs/design/draft-query.txt:
1024         * docs/design/part-overview.txt:
1025         Docs updates, added general overview doc.
1026
1027 2005-05-21  David Schleef  <ds@schleef.org>
1028
1029         * docs/gst/tmpl/old/GstBin.sgml:
1030         * docs/gst/tmpl/old/GstBuffer.sgml:
1031         * docs/gst/tmpl/old/GstCaps.sgml:
1032         * docs/gst/tmpl/old/GstClock.sgml:
1033         * docs/gst/tmpl/old/GstCompat.sgml:
1034         * docs/gst/tmpl/old/GstData.sgml:
1035         * docs/gst/tmpl/old/GstElement.sgml:
1036         * docs/gst/tmpl/old/GstEvent.sgml:
1037         * docs/gst/tmpl/old/GstIndex.sgml:
1038         * docs/gst/tmpl/old/GstStructure.sgml:
1039         * docs/gst/tmpl/old/GstTag.sgml:
1040         * docs/gst/tmpl/old/cothreads.sgml:
1041         * docs/gst/tmpl/old/cothreads_compat.sgml:
1042         * docs/gst/tmpl/old/gettext.sgml:
1043         * docs/gst/tmpl/old/gobject2gtk.sgml:
1044         * docs/gst/tmpl/old/grammar.tab.sgml:
1045         * docs/gst/tmpl/old/gst-i18n-app.sgml:
1046         * docs/gst/tmpl/old/gst-i18n-lib.sgml:
1047         * docs/gst/tmpl/old/gst_private.sgml:
1048         * docs/gst/tmpl/old/gstaggregator.sgml:
1049         * docs/gst/tmpl/old/gstarch.sgml:
1050         * docs/gst/tmpl/old/gstatomic_impl.sgml:
1051         * docs/gst/tmpl/old/gstbufferstore.sgml:
1052         * docs/gst/tmpl/old/gstdata_private.sgml:
1053         * docs/gst/tmpl/old/gstdisksink.sgml:
1054         * docs/gst/tmpl/old/gstdisksrc.sgml:
1055         * docs/gst/tmpl/old/gstelementfactory.sgml:
1056         * docs/gst/tmpl/old/gstextratypes.sgml:
1057         * docs/gst/tmpl/old/gstfakesink.sgml:
1058         * docs/gst/tmpl/old/gstfakesrc.sgml:
1059         * docs/gst/tmpl/old/gstfdsink.sgml:
1060         * docs/gst/tmpl/old/gstfdsrc.sgml:
1061         * docs/gst/tmpl/old/gstfilesink.sgml:
1062         * docs/gst/tmpl/old/gstfilesrc.sgml:
1063         * docs/gst/tmpl/old/gsthttpsrc.sgml:
1064         * docs/gst/tmpl/old/gstidentity.sgml:
1065         * docs/gst/tmpl/old/gstindexfactory.sgml:
1066         * docs/gst/tmpl/old/gstmarshal.sgml:
1067         * docs/gst/tmpl/old/gstmd5sink.sgml:
1068         * docs/gst/tmpl/old/gstmultidisksrc.sgml:
1069         * docs/gst/tmpl/old/gstmultifilesrc.sgml:
1070         * docs/gst/tmpl/old/gstpadtemplate.sgml:
1071         * docs/gst/tmpl/old/gstpipefilter.sgml:
1072         * docs/gst/tmpl/old/gstschedulerfactory.sgml:
1073         * docs/gst/tmpl/old/gstsearchfuncs.sgml:
1074         * docs/gst/tmpl/old/gstshaper.sgml:
1075         * docs/gst/tmpl/old/gstspider.sgml:
1076         * docs/gst/tmpl/old/gstspideridentity.sgml:
1077         * docs/gst/tmpl/old/gststatistics.sgml:
1078         * docs/gst/tmpl/old/gsttee.sgml:
1079         * docs/gst/tmpl/old/gsttimecache.sgml:
1080         * docs/gst/tmpl/old/gsttypefindfactory.sgml:
1081         * docs/gst/tmpl/old/gstxmlregistry.sgml:
1082         * docs/gst/tmpl/old/gthread-cothreads.sgml:
1083         * docs/gst/tmpl/old/types.sgml:
1084           I didn't intend to add these or check them in.
1085
1086 2005-05-19  David Schleef  <ds@schleef.org>
1087
1088         * configure.ac: Use -no-common everywhere.  In a sane world, it
1089           would be the default in libtool, because without it, you can't
1090           build DLLs on Windows.
1091         * docs/gst/gstreamer-docs.sgml: Remove GstCpu, GstData, GstThread
1092         * docs/gst/gstreamer-sections.txt:
1093         * docs/gst/tmpl/gstcpu.sgml:
1094         * docs/gst/tmpl/gstdata.sgml:
1095         * docs/gst/tmpl/gstthread.sgml:
1096
1097 2005-05-19  David Schleef  <ds@schleef.org>
1098
1099         * gst/gstminiobject.c: (gst_value_set_mini_object),
1100         (gst_value_take_mini_object), (gst_value_get_mini_object):
1101         * gst/gstminiobject.h: Add GValue set/get functions.
1102
1103 2005-05-19  Wim Taymans  <wim@fluendo.com>
1104
1105         * gst/gstbuffer.c: (gst_buffer_init), (gst_subbuffer_get_type),
1106         (gst_subbuffer_class_init), (gst_subbuffer_finalize),
1107         (gst_subbuffer_init), (gst_buffer_is_span_fast):
1108         * gst/gstbuffer.h:
1109         * gst/gstbus.c: (gst_bus_post):
1110         * gst/gstelement.c: (gst_element_get_random_pad):
1111         * gst/gstmessage.c: (gst_message_init), (gst_message_finalize):
1112         Make subbufer unref the parent in finalize.
1113         some more debugging info.
1114
1115
1116 2005-05-19  Wim Taymans  <wim@fluendo.com>
1117
1118         * gst/base/gstbasesink.c: (gst_basesink_class_init),
1119         (gst_basesink_init), (gst_basesink_finalize),
1120         (gst_basesink_activate), (gst_basesink_change_state):
1121         Don't free preroll queue too early.
1122
1123 2005-05-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1124
1125         * gst/Makefile.am:
1126         * gst/ROADMAP:
1127           Hi, I'm outdated. Please shoot me.
1128
1129 2005-05-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1130
1131         * gst/gstpipeline.c: (gst_pipeline_send_event):
1132           Do not access variables after they have been deleted.
1133
1134 2005-05-19  Wim Taymans  <wim@fluendo.com>
1135
1136         * tools/gst-inspect.c: (print_plugin_features):
1137         A plugin feature does unfortunatly not use the
1138         object name yet...
1139
1140 2005-05-18  Wim Taymans  <wim@fluendo.com>
1141
1142         * gst/gstbuffer.c: (gst_buffer_is_span_fast), (gst_buffer_span):
1143         Port _span() functions to new subbuffers.
1144
1145 2005-05-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1146
1147         * gst/gstbin.c: (gst_bin_add_func):
1148           Fix clock settery in bins when adding kids after the clock has
1149           been selected.
1150
1151 2005-05-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1152
1153         * gst/elements/gstidentity.c: (gst_identity_class_init):
1154           Workaround until signals support GstMiniObject.
1155
1156 2005-05-18  Jan Schmidt  <thaytan@mad.scientist.com>
1157
1158         * gst/gstbuffer.c:
1159         Oops, fix a typo GST_TYPE_BUFFER -> GST_TYPE_SUBBUFFER.
1160
1161 2005-05-18  Wim Taymans  <wim@fluendo.com>
1162
1163         * gst/base/Makefile.am:
1164         * gst/base/gstadapter.c: (gst_adapter_base_init),
1165         (gst_adapter_class_init), (gst_adapter_init),
1166         (gst_adapter_dispose), (gst_adapter_finalize), (gst_adapter_new),
1167         (gst_adapter_clear), (gst_adapter_push), (gst_adapter_peek),
1168         (gst_adapter_flush), (gst_adapter_available),
1169         (gst_adapter_available_fast):
1170         * gst/base/gstadapter.h:
1171         Ported and added adapter to the base classes.
1172
1173 2005-05-17  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
1174
1175         * gst/gst.c:
1176         * gst/gstmessage.c:
1177           Make sure the class is reffed/unreffed once before threads can be
1178           used.  Fixes #304551.
1179
1180 2005-05-17  Wim Taymans  <wim@fluendo.com>
1181
1182         * gst/base/gstbasesink.c: (gst_basesink_finish_preroll),
1183         (gst_basesink_chain_unlocked), (gst_basesink_activate):
1184         * gst/gstminiobject.c: (gst_mini_object_get_type),
1185         (gst_mini_object_free):
1186         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_query),
1187         (gst_pad_push), (gst_pad_push_event):
1188         * gst/gstqueue.c: (gst_queue_change_state):
1189         Don't queue buffers in basesink when we are flushing.
1190         Unref buffer when flushing in basesink.
1191         Flush queue when going to READY
1192         Unref buffer when _push() returns an error.
1193         Don't free MiniObject instance when refcount is incremented
1194         in _finalize() so that we can recover objects.
1195
1196 2005-05-17  Thomas Vander Stichele  <thomas at apestaart dot org>
1197
1198         * docs/manual/advanced-schedulers.xml:
1199         * docs/manual/appendix-checklist.xml:
1200         * docs/pwg/advanced-clock.xml:
1201         * docs/pwg/advanced-interfaces.xml:
1202         * docs/pwg/advanced-request.xml:
1203         * docs/pwg/advanced-types.xml:
1204         * docs/pwg/intro-preface.xml:
1205         * examples/plugins/example.c: (gst_example_get_type),
1206         (gst_example_class_init), (gst_example_chain),
1207         (gst_example_set_property), (gst_example_get_property),
1208         (gst_example_change_state), (plugin_init):
1209         * examples/plugins/example.h:
1210           small doc fixes
1211
1212 2005-05-17  Wim Taymans  <wim@fluendo.com>
1213
1214         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_set_caps),
1215         (gst_pad_alloc_buffer), (gst_pad_query), (gst_pad_push):
1216         * gst/gstqueue.c: (gst_queue_change_state):
1217         Clear queue when going to READY.
1218         Remove IN_SETCAPS flag too.
1219
1220 2005-05-17  Tim-Philipp Müller  <tim at centricular dot net>
1221
1222         * gst/base/gstbasesrc.c: (gst_basesrc_change_state):
1223           Remove implicit cast from gboolean to GstElementStateReturn;
1224           make sure we still return failure in paused => ready case if
1225           the parent class fails to change state and our own stop 
1226           vfunc succeeds.
1227
1228 2005-05-17  Wim Taymans  <wim@fluendo.com>
1229
1230         * tools/gst-launch.c: (event_loop):
1231         Message was unreffed too soon.
1232
1233 2005-05-16  Andy Wingo  <wingo@pobox.com>
1234
1235         * gst/gstbin.c (sink_iterator_filter): Err... um...
1236
1237         * check/gst/gstbin.c (test_ghost_pads): New test for the
1238         ghosting-if-elements-not-in-same-bin behavior.
1239
1240 2005-05-16  David Schleef  <ds@schleef.org>
1241
1242         * gst/gstminiobject.c: Use g_atomic_int_get() instead of
1243         accessing refcount directly.
1244
1245 2005-05-15  David Schleef  <ds@schleef.org>
1246
1247         * check/Makefile.am: remove GstData checks
1248         * check/gst-libs/gdp.c: (START_TEST): fix for API changes
1249         * gst/Makefile.am: add miniobject, remove data
1250         * gst/gst.h: add miniobject, remove data
1251         * gst/gstdata.c: remove
1252         * gst/gstdata.h: remove
1253         * gst/gstdata_private.h: remove
1254         * gst/gsttypes.h: remove GstEvent and GstMessage
1255         * gst/gstelement.c: (gst_element_post_message): fix for API changes
1256         * gst/gstmarshal.list: change BOXED -> OBJECT
1257
1258         Implement GstMiniObject.
1259         * gst/gstminiobject.c:
1260         * gst/gstminiobject.h:
1261
1262         Modify to be subclasses of GstMiniObject.
1263         * gst/gstbuffer.c: (_gst_buffer_initialize), (gst_buffer_get_type),
1264         (gst_buffer_class_init), (gst_buffer_finalize), (_gst_buffer_copy),
1265         (gst_buffer_init), (gst_buffer_new), (gst_buffer_new_and_alloc),
1266         (gst_subbuffer_get_type), (gst_subbuffer_init),
1267         (gst_buffer_create_sub), (gst_buffer_is_span_fast),
1268         (gst_buffer_span):
1269         * gst/gstbuffer.h:
1270         * gst/gstevent.c: (_gst_event_initialize), (gst_event_get_type),
1271         (gst_event_class_init), (gst_event_init), (gst_event_finalize),
1272         (_gst_event_copy), (gst_event_new):
1273         * gst/gstevent.h:
1274         * gst/gstmessage.c: (_gst_message_initialize),
1275         (gst_message_get_type), (gst_message_class_init),
1276         (gst_message_init), (gst_message_finalize), (_gst_message_copy),
1277         (gst_message_new), (gst_message_new_error),
1278         (gst_message_new_warning), (gst_message_new_tag),
1279         (gst_message_new_state_changed), (gst_message_new_application):
1280         * gst/gstmessage.h:
1281         * gst/gstprobe.c: (gst_probe_perform),
1282         (gst_probe_dispatcher_dispatch):
1283         * gst/gstprobe.h:
1284         * gst/gstquery.c: (_gst_query_initialize), (gst_query_get_type),
1285         (gst_query_class_init), (gst_query_finalize), (gst_query_init),
1286         (_gst_query_copy), (gst_query_new):
1287
1288         Update elements for GstData -> GstMiniObject changes
1289         * gst/gstquery.h:
1290         * gst/gstqueue.c: (gst_queue_finalize), (gst_queue_locked_flush),
1291         (gst_queue_chain), (gst_queue_loop):
1292         * gst/elements/gstbufferstore.c:
1293         (gst_buffer_store_add_buffer_func),
1294         (gst_buffer_store_cleared_func), (gst_buffer_store_get_buffer):
1295         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
1296         (gst_fakesink_render):
1297         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
1298         * gst/elements/gstfilesrc.c: (gst_mmap_buffer_get_type),
1299         (gst_mmap_buffer_class_init), (gst_mmap_buffer_init),
1300         (gst_mmap_buffer_finalize), (gst_filesrc_map_region),
1301         (gst_filesrc_create_read):
1302         * gst/elements/gstidentity.c: (gst_identity_class_init):
1303         * gst/elements/gsttypefindelement.c:
1304         (gst_type_find_element_src_event), (free_entry_buffers),
1305         (gst_type_find_element_handle_event):
1306         * libs/gst/dataprotocol/dataprotocol.c:
1307         (gst_dp_header_from_buffer):
1308         * libs/gst/dataprotocol/dataprotocol.h:
1309         * libs/gst/dataprotocol/dp-private.h:
1310
1311 2005-05-15  David Schleef  <ds@schleef.org>
1312
1313         * gst/elements/gstelements.c: Don't include headers that were
1314         just removed.
1315
1316 2005-05-15  David Schleef  <ds@schleef.org>
1317
1318         * gst/elements/Makefile.am: Remove some elements that don't
1319         need to be in the core (or even exist at all).
1320         * gst/elements/gstaggregator.c:
1321         * gst/elements/gstaggregator.h:
1322         * gst/elements/gstmd5sink.c:
1323         * gst/elements/gstmd5sink.h:
1324         * gst/elements/gstmultifilesrc.c:
1325         * gst/elements/gstmultifilesrc.h:
1326         * gst/elements/gstpipefilter.c:
1327         * gst/elements/gstpipefilter.h:
1328         * gst/elements/gstshaper.c:
1329         * gst/elements/gstshaper.h:
1330         * gst/elements/gststatistics.c:
1331         * gst/elements/gststatistics.h:
1332         * po/POTFILES.in: Remove above files.
1333
1334 2005-05-14  Andy Wingo  <wingo@pobox.com>
1335
1336         * gst/gstbin.c (gst_bin_iterate_sinks): Use sink_iterator_filter
1337         so as to get the refs right.
1338         (sink_iterator_filter): New function, wraps bin_element_is_sink,
1339         unreffing objects that don't pass the filter.
1340
1341         * gst/gstpipeline.c (gst_pipeline_init): Drop ref on bus after
1342         gst_element_set_bus.
1343         (gst_pipeline_dispose): Set the bus on the pipeline to NULL. In
1344         normal cases, this will destroy the bus.
1345
1346         * gst/gstutils.c (prepare_link_maybe_ghosting): Drop ref on root
1347         object.
1348
1349         * gst/gstbin.c (gst_bin_change_state): Fix state changes if a bin
1350         has no sinks.
1351
1352 2005-05-13  Andy Wingo  <wingo@pobox.com>
1353
1354         * gst/gstutils.c (gst_element_link_pads): Instead of calling
1355         gst_pad_link, call pad_link_maybe_ghosting,
1356         (pad_link_maybe_ghosting): Links pads, making sure that the
1357         elements being linked are in the same bin.
1358         (find_common_root, object_has_ancestor, ghost_up, remove_pad):
1359         Helpers for pad_link_maybe_ghosting.
1360
1361 2005-05-13  Tim-Philipp Müller  <tim at centricular dot net>
1362
1363         * configure.ac:
1364           Require GLib >= 2.4.0 (for the g_atomic_* funcs)
1365
1366 2005-05-13  Tim-Philipp Müller  <tim at centricular dot net>
1367
1368         * docs/design/part-element-source.txt:
1369           Mention GstPushSrc
1370
1371 2005-05-12  Wim Taymans  <wim@fluendo.com>
1372
1373         * gst/base/gstbasesink.c: (gst_basesink_init),
1374         (gst_basesink_activate):
1375         * gst/base/gstbasesrc.c: (gst_basesrc_unlock),
1376         (gst_basesrc_is_seekable):
1377         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_remove_func),
1378         (bin_element_is_sink), (gst_bin_change_state):
1379         * gst/gstelement.c: (gst_element_add_pad), (gst_element_query):
1380         * gst/gstelement.h:
1381         Identify sinks by their flag to avoid overly complicated
1382         checks (fow now).
1383         Do state changes even for elements not reachable from the
1384         sinks.
1385         BaseSink is a sink now :)
1386         Some more debugging info in the basesrc.
1387
1388
1389 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1390
1391         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_query):
1392           Implement _query on a bin, similar to _send_event.
1393
1394 2005-05-12  Tim-Philipp Müller  <tim at centricular dot net>
1395
1396         * gst/base/gstbasesrc.c: (gst_basesrc_do_seek):
1397           Discont event offset format should be GST_FORMAT_BYTES,
1398           not GST_FORMAT_TIME.
1399
1400 2005-05-12  Wim Taymans  <wim@fluendo.com>
1401
1402         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_get_state):
1403         Same fix as Ronald's but without the signal. 
1404
1405 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1406
1407         * gst/gstutils.c: (gst_element_query_position):
1408           No, an element is not a pad.
1409
1410 2005-05-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1411
1412         * gst/gstbin.c: (gst_bin_add_func), (cb_parent_unset),
1413         (gst_bin_get_state):
1414           If a child is removed from a bin while we remove the child from
1415           the bin and while we're retrieving its state, signal this to the
1416           get_state function so we abort the wait (instead of waiting for
1417           a timeout) and can immediately re-iterate over all other elements.
1418
1419 2005-05-12  Wim Taymans  <wim@fluendo.com>
1420
1421         * gst/base/Makefile.am:
1422         * gst/base/gstbasesrc.c: (gst_basesrc_is_seekable),
1423         (gst_basesrc_start):
1424         * gst/base/gstbasesrc.h:
1425         * gst/base/gstpushsrc.c: (gst_pushsrc_get_type),
1426         (gst_pushsrc_base_init), (gst_pushsrc_class_init),
1427         (gst_pushsrc_init), (gst_pushsrc_create):
1428         * gst/base/gstpushsrc.h:
1429         Added is_seekable to BaseSrc
1430         Added simple PushSrc.
1431
1432 2005-05-11  Wim Taymans  <wim@fluendo.com>
1433
1434         * gst/gstelement.c: (gst_element_add_pad), (gst_element_query):
1435         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
1436         (gst_element_link_pads), (gst_element_query_position),
1437         (gst_element_query_convert), (intersect_caps_func),
1438         (gst_pad_query_position), (gst_pad_query_convert):
1439         Fix refcounting in utils function.
1440         No point in trying to activate a pad when it's added, it could
1441         be added from the state change function and then we deadlock, the
1442         element has to decide what to do.
1443
1444 2005-05-10  Andy Wingo  <wingo@pobox.com>
1445
1446         * gst/elements/gstfakesink.c (gst_fakesink_render): Er, emit with
1447         *all* the arguments.
1448
1449         * gst/base/gstbasetransform.c (gst_base_transform_event): Grab the
1450         stream lock if it's a FLUSH_DONE; normal flushes don't get the
1451         lock (according to the docs -- if this is wrong change the docs).
1452
1453         * gst/gstpipeline.c (gst_pipeline_change_state): Set the bus to
1454         flush messages in the NULL state.
1455
1456         * gst/gstbus.c (gst_bus_post): If a bus is flushing, unref the
1457         message immediately and return.
1458         (gst_bus_set_flushing): New function. If a bus is flushing, it
1459         flushes out any queued messages and immediately unrefs new
1460         messages. This is so when an element goes to NULL, all of the
1461         unhandled messages coming from it can be freed, and their
1462         references to the element dropped. In other words: message source
1463         ref considered harmful :P
1464
1465         * gst/gstbin.c (gst_bin_change_state): Unref peer element when
1466         we're finished with it.
1467
1468         * gst/gstmessage.c (gst_message_new_state_changed): 
1469
1470 2005-05-10  Wim Taymans  <wim@fluendo.com>
1471
1472         * gst/gstvalue.c: (gst_value_compare_flags),
1473         (gst_value_serialize_flags), (gst_value_deserialize_flags),
1474         (_gst_value_initialize):
1475         Added flags serialize/deserialize/compare code.
1476
1477 2005-05-09  Andy Wingo  <wingo@pobox.com>
1478
1479         * gst/base/gstbasetransform.c (gst_base_transform_proxy_getcaps):
1480         Intersect the peer's caps with our caps.
1481
1482 2005-05-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1483
1484         * gst/base/gsttypefindhelper.c: (helper_find_peek):
1485         * gst/elements/gsttypefindelement.c: (find_peek):
1486           Handle negative offsets better. Fixes decodebin.
1487
1488 2005-05-09  Wim Taymans  <wim@fluendo.com>
1489
1490         * gst/base/gstbasetransform.c: (gst_base_transform_proxy_getcaps),
1491         (gst_base_transform_event):
1492         * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_query):
1493         Implement accept_caps.
1494         Fix silly lock/unlock mismatch in base class.
1495
1496 2005-05-09  Wim Taymans  <wim@fluendo.com>
1497
1498         * docs/design/draft-push-pull.txt:
1499         * gst/base/gstbasesrc.c: (gst_basesrc_init), (gst_basesrc_query):
1500         * gst/elements/gstfilesink.c: (gst_filesink_init),
1501         (gst_filesink_query):
1502         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
1503         (gst_type_find_handle_src_query), (find_element_get_length):
1504         * gst/gstelement.c: (gst_element_seek), (gst_element_query):
1505         * gst/gstelement.h:
1506         * gst/gstmessage.c:
1507         * gst/gstmessage.h:
1508         * gst/gstpad.c: (gst_real_pad_init), (gst_pad_get_query_types),
1509         (gst_real_pad_get_caps_unlocked),
1510         (gst_pad_get_internal_links_default), (gst_pad_get_internal_links),
1511         (gst_pad_event_default_dispatch), (gst_pad_event_default),
1512         (gst_pad_dispatcher), (gst_pad_query), (gst_pad_query_default),
1513         (gst_real_pad_dispose), (gst_real_pad_finalize),
1514         (gst_pad_load_and_link), (gst_pad_save_thyself),
1515         (gst_ghost_pad_save_thyself), (handle_pad_block), (gst_pad_push),
1516         (gst_pad_check_pull_range), (gst_pad_pull_range),
1517         (gst_pad_template_get_type), (gst_pad_template_class_init),
1518         (gst_pad_template_init), (gst_pad_template_dispose),
1519         (name_is_valid), (gst_static_pad_template_get),
1520         (gst_pad_template_new), (gst_static_pad_template_get_caps),
1521         (gst_pad_template_get_caps), (gst_pad_set_element_private),
1522         (gst_pad_get_element_private), (gst_pad_start_task),
1523         (gst_pad_pause_task), (gst_pad_stop_task),
1524         (gst_ghost_pad_get_type), (gst_ghost_pad_class_init),
1525         (gst_ghost_pad_init), (gst_ghost_pad_dispose),
1526         (gst_ghost_pad_set_property), (gst_ghost_pad_get_property),
1527         (gst_ghost_pad_new):
1528         * gst/gstpad.h:
1529         * gst/gstquery.c: (_gst_query_initialize), (gst_query_new),
1530         (gst_query_new_position), (gst_query_set_position),
1531         (gst_query_parse_position), (gst_query_new_convert),
1532         (gst_query_set_convert), (gst_query_parse_convert):
1533         * gst/gstquery.h:
1534         * gst/gstqueryutils.c:
1535         * gst/gstqueryutils.h:
1536         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
1537         (gst_queue_bufferalloc), (gst_queue_handle_sink_event),
1538         (gst_queue_handle_src_query):
1539         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
1540         (gst_element_query_position), (gst_element_query_convert),
1541         (intersect_caps_func), (gst_pad_query_position),
1542         (gst_pad_query_convert):
1543         * gst/gstutils.h:
1544         * tools/gst-inspect.c: (print_pad_info):
1545         * tools/gst-xmlinspect.c: (print_element_info):
1546         Remove old query functions. Ported old code.
1547         Added position/convert helper functions to gstutils.
1548         Reordered gstpad.c code, grouping relevant things.
1549         Remove gst_message_new(), always need to speficy a specific
1550         message.
1551
1552
1553 2005-05-09  Andy Wingo  <wingo@pobox.com>
1554
1555         * gst/gstiterator.h: Add some includes.
1556
1557         * gst/gstqueryutils.h: Include more headers.
1558
1559         * gst/gstpad.h:
1560         * gst/gstpad.c (gst_pad_query_position): New routine, replaces
1561         some uses of gst_pad_query.
1562
1563         * gst/gstqueryutils.c: Build fixes. Make parse functions ignore
1564         NULL out parameters.
1565         (gst_query_new_position): New proc, allocates a new position
1566         query.
1567
1568         * gst/Makefile.am (libgstreamer_@GST_MAJORMINOR@_la_SOURCES): Add
1569         gstqueryutils.c to the build.
1570
1571         * gst/gststructure.c (gst_structure_set_valist): Implement with
1572         the generic G_VALUE_COLLECT.
1573         
1574 2005-05-08  Edward Hervey  <bilboed@bilboed.com>
1575
1576         * gst/Makefile.am: (gst_headers):
1577         Added gstqueryutils.h to the list of headers to install, that was
1578         a 'nachty' move wingo :)
1579
1580 2005-05-06  Andy Wingo  <wingo@pobox.com>
1581
1582         * gst/gstquery.h
1583         * gst/gstquery.c (_gst_query_initialize): Extend GstQuery from
1584         GstData, init a memchunk.
1585         (standard_definitions): Add a few query types, deprecate a few.
1586         (gst_query_get_type): New proc.
1587         (_gst_query_copy, _gst_query_free, gst_query_new): GstData
1588         implementation.
1589         (gst_query_new_application, gst_query_get_structure): New public
1590         procs.
1591
1592         * docs/design/draft-query.txt: Removed LINKS from the query types,
1593         because all the rest can be dispatched to other pads -- seemed
1594         ugly to have a query that couldn't be dispatched. internal_links
1595         is fine as a pad method.
1596
1597         * gst/gstpad.h: Add query2 as a pad method, add the new functions
1598         in gstpad.c, but maintain binary compatibility for the moment.
1599         Will fix before 0.9 is out.
1600
1601         * gst/gstqueryutils.c: 
1602         * gst/gstqueryutils.h: New files, implement 3 methods for each
1603         query type: parse_query, parse_response, and set. Probably need an
1604         allocator as well.
1605
1606         * gst/gst.h: Add gstquery.h and gstqueryutils.h to the list.
1607
1608         * gst/elements/gstfilesink.c (gst_filesink_query2):
1609         * gst/base/gstbasesrc.c (gst_basesrc_query2): Replace old query,
1610         query_types, and formats methods.
1611
1612         * gst/gstpad.c (gst_pad_query2, gst_pad_query2_default)
1613         (gst_pad_set_query2_function): New functions.
1614         (gst_real_pad_init): Set query2_default as the default query2
1615         function. Basically just dispatches to internally linked pads.
1616
1617         Needs review!
1618         
1619         * gst/gstdata_private.h (_GST_DATA_INIT): Set data->refcount to 1
1620         without using the atomic operations. Only one thread can possibly
1621         be accessing the data at this point. Changed so as to avoid
1622         gst_atomic operations.
1623
1624 2005-05-06  Wim Taymans  <wim@fluendo.com>
1625
1626         * gst/gstpad.c: (gst_pad_alloc_buffer), (gst_pad_push):
1627         Also set caps if we use the fallback buffer alloc.
1628
1629 2005-05-06  Tim-Philipp Müller  <tim at centricular dot net>
1630
1631         * docs/gst/Makefile.am:
1632         * docs/gst/gstreamer-docs.sgml:
1633         * docs/gst/gstreamer-sections.txt:
1634         * docs/gst/tmpl/gstatomic.sgml:
1635         * docs/gst/tmpl/gstmemchunk.sgml:
1636         * testsuite/elements/struct_i386.h:
1637         * win32/GStreamer.vcproj:
1638         * win32/Makefile:
1639           Purge GstAtomic stuff from docs and win32 makefiles as well
1640
1641 2005-05-06  Wim Taymans  <wim@fluendo.com>
1642
1643         * gst/base/gstbasetransform.c: (gst_base_transform_proxy_getcaps):
1644         * gst/elements/gstcapsfilter.c: (gst_capsfilter_getcaps):
1645         * gst/gstpad.c: (gst_pad_peer_get_caps):
1646         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
1647         (gst_queue_bufferalloc), (gst_queue_handle_sink_event),
1648         (gst_queue_src_activate), (gst_queue_change_state):
1649         * gst/gstqueue.h:
1650         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
1651         (intersect_caps_func):
1652         Fix gst_pad_peer_get_caps(), make it return NULL if no peer.
1653         Always take QUEUE_LOCK after STREAM_LOCK or we might deadlock.
1654         Some fixes for the peer_get_caps() change.
1655
1656 2005-05-06  Wim Taymans  <wim@fluendo.com>
1657
1658         * gst/base/gstbasesink.c: (gst_basesink_preroll_queue_empty),
1659         (gst_basesink_handle_buffer), (gst_basesink_chain_unlocked),
1660         (gst_basesink_activate):
1661         Actually do something with error codes returned from the push
1662         functions.
1663
1664 2005-05-06  Wim Taymans  <wim@fluendo.com>
1665
1666         * docs/design/part-element-sink.txt:
1667         * docs/design/part-element-source.txt:
1668         * gst/base/gstbasesink.c: (gst_basesink_class_init),
1669         (gst_basesink_event), (gst_basesink_activate):
1670         * gst/base/gstbasesink.h:
1671         * gst/base/gstbasesrc.c: (gst_basesrc_init), (gst_basesrc_unlock),
1672         (gst_basesrc_activate):
1673         * gst/base/gstbasesrc.h:
1674         * gst/gstelement.c: (gst_element_pads_activate):
1675         Some more documentation.
1676         Fixed scheduling decision in _pads_activate().
1677
1678 2005-05-05  Andy Wingo  <wingo@pobox.com>
1679
1680         * check/pipelines/simple_launch_lines.c (test_2_elements): "Fix"
1681         the test suite.
1682
1683 2005-05-05  Wim Taymans  <wim@fluendo.com>
1684
1685         * gst/base/Makefile.am:
1686         * gst/base/gstbasesink.h:
1687         * gst/base/gstbasesrc.c: (gst_basesrc_init),
1688         (gst_basesrc_set_dataflow_funcs), (gst_basesrc_query):
1689         * gst/base/gstcollectpads.c: (gst_collectpads_get_type),
1690         (gst_collectpads_class_init), (gst_collectpads_init),
1691         (gst_collectpads_finalize), (gst_collectpads_new),
1692         (gst_collectpads_set_function), (gst_collectpads_add_pad),
1693         (find_pad), (gst_collectpads_remove_pad),
1694         (gst_collectpads_is_active), (gst_collectpads_collect),
1695         (gst_collectpads_collect_range), (gst_collectpads_start),
1696         (gst_collectpads_stop), (gst_collectpads_peek),
1697         (gst_collectpads_pop), (gst_collectpads_available),
1698         (gst_collectpads_read), (gst_collectpads_flush),
1699         (gst_collectpads_chain):
1700         * gst/base/gstcollectpads.h:
1701         * gst/elements/Makefile.am:
1702         * gst/elements/gstelements.c:
1703         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
1704         (gst_fakesink_get_times), (gst_fakesink_event),
1705         (gst_fakesink_preroll), (gst_fakesink_render):
1706         * gst/elements/gstfilesink.c: (gst_filesink_class_init),
1707         (gst_filesink_init), (gst_filesink_set_location),
1708         (gst_filesink_open_file), (gst_filesink_close_file),
1709         (gst_filesink_pad_query), (gst_filesink_event),
1710         (gst_filesink_render), (gst_filesink_change_state):
1711         * gst/elements/gstfilesink.h:
1712         Added object to help in making collect pad based elements.
1713         Ported filesink.
1714         Make event function in sink baseclass return gboolean.
1715
1716 2005-05-05  Wim Taymans  <wim@fluendo.com>
1717
1718         * gst/gstbin.c: (gst_bin_send_event), (compare_name),
1719         (gst_bin_get_by_name):
1720         * gst/gstbuffer.h:
1721         * gst/gstclock.c: (gst_clock_entry_new), (gst_clock_class_init),
1722         (gst_clock_finalize):
1723         * gst/gstdata.c: (gst_data_replace):
1724         * gst/gstdata.h:
1725         * gst/gstelement.c: (gst_element_request_pad),
1726         (gst_element_pads_activate):
1727         * gst/gstobject.c: (gst_object_init), (gst_object_ref),
1728         (gst_object_unref):
1729         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
1730         (gst_pad_set_checkgetrange_function),
1731         (gst_pad_link_check_compatible_unlocked), (gst_pad_set_caps),
1732         (gst_pad_check_pull_range), (gst_pad_pull_range),
1733         (gst_static_pad_template_get_caps), (gst_pad_start_task),
1734         (gst_pad_pause_task), (gst_pad_stop_task):
1735         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
1736         (gst_element_request_pad), (gst_pad_proxy_getcaps):
1737         Fix name lookup in GstBin.
1738         Added _data_replace() function and _buffer_replace()
1739         Use finalize method to clean up clock.
1740         Fix refcounting on request pads.
1741         Fix pad schedule mode error.
1742         Some more object refcounting debug info,
1743
1744
1745 2005-05-04  Andy Wingo <wingo@pobox.com>
1746
1747         * check/Makefile.am:
1748         * docs/gst/tmpl/gstatomic.sgml:
1749         * docs/gst/tmpl/gstplugin.sgml:
1750         * gst/base/gstbasesink.c: (gst_basesink_activate):
1751         * gst/base/gstbasesrc.c: (gst_basesrc_class_init),
1752         (gst_basesrc_init), (gst_basesrc_set_dataflow_funcs),
1753         (gst_basesrc_query), (gst_basesrc_set_property),
1754         (gst_basesrc_get_property), (gst_basesrc_check_get_range),
1755         (gst_basesrc_activate):
1756         * gst/base/gstbasesrc.h:
1757         * gst/base/gstbasetransform.c: (gst_base_transform_sink_activate),
1758         (gst_base_transform_src_activate):
1759         * gst/elements/gstelements.c:
1760         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
1761         (gst_fakesrc_set_property), (gst_fakesrc_get_property):
1762         * gst/elements/gsttee.c: (gst_tee_sink_activate):
1763         * gst/elements/gsttypefindelement.c: (find_element_get_length),
1764         (gst_type_find_element_checkgetrange),
1765         (gst_type_find_element_activate):
1766         * gst/gstbin.c: (gst_bin_save_thyself), (gst_bin_restore_thyself):
1767         * gst/gstcaps.c: (gst_caps_do_simplify), (gst_caps_save_thyself),
1768         (gst_caps_load_thyself):
1769         * gst/gstelement.c: (gst_element_pads_activate),
1770         (gst_element_save_thyself), (gst_element_restore_thyself):
1771         * gst/gstpad.c: (gst_pad_load_and_link), (gst_pad_save_thyself),
1772         (gst_ghost_pad_save_thyself), (gst_pad_check_pull_range):
1773         * gst/gstpad.h:
1774         * gst/gstxml.c: (gst_xml_write), (gst_xml_parse_doc),
1775         (gst_xml_parse_file), (gst_xml_parse_memory),
1776         (gst_xml_get_element), (gst_xml_make_element):
1777         * gst/indexers/gstfileindex.c: (gst_file_index_load),
1778         (_file_index_id_save_xml), (gst_file_index_commit):
1779         * gst/registries/gstlibxmlregistry.c: (read_string), (read_uint),
1780         (read_enum), (load_pad_template), (load_feature), (load_plugin),
1781         (load_paths):
1782         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_caps),
1783         (gst_dp_packet_from_event), (gst_dp_caps_from_packet):
1784         * tools/gst-complete.c: (main):
1785         * tools/gst-compprep.c: (main):
1786         * tools/gst-inspect.c: (print_element_properties_info):
1787         * tools/gst-launch.c: (xmllaunch_parse_cmdline):
1788         * tools/gst-xmlinspect.c: (print_element_properties):
1789         GCC 4 fixen.
1790         
1791 2005-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
1792
1793         * gst/gstplugin.c: (gst_plugin_check_module),
1794         (gst_plugin_check_file), (gst_plugin_load_file):
1795             apply patch from #172526 to make register work on MacOSX
1796
1797 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
1798
1799         * docs/gst/tmpl/gstconfig.sgml:
1800         * gst/gstconfig.h.in:
1801           move documentation for some symbols.  Add doc for GST_PTR_FORMAT
1802         * testsuite/debug/printf_extension.c: (main):
1803           Do not use GST_PTR_FORMAT on pointers to types with
1804           sizeof < sizeof(gpointer).  Fixes test on 64-bit
1805         * testsuite/elements/property.h:
1806           use correct printf format
1807
1808 2005-05-02  Wim Taymans  <wim@fluendo.com>
1809
1810         * docs/design/draft-push-pull.txt:
1811         * docs/design/draft-query.txt:
1812         * gst/base/gstbasesrc.c: (gst_basesrc_get_range_unlocked),
1813         (gst_basesrc_start):
1814         Added draft for new query API.
1815         Added draft for better selecting scheduling methods.
1816         Make basesrc ignore length if the subclass does not support
1817         it.
1818
1819 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
1820
1821         * gst/Makefile.am:
1822           possible fixes for automake-1.5 - _LIBADD is reserved
1823
1824 2005-05-02  Thomas Vander Stichele  <thomas at apestaart dot org>
1825
1826         * docs/faq/Makefile.am:
1827         * docs/manual/Makefile.am:
1828         * docs/manuals.mak:
1829         * docs/pwg/Makefile.am:
1830         * gst/Makefile.am:
1831           possible fixes for automake-1.5
1832
1833 2005-04-28  Wim Taymans  <wim@fluendo.com>
1834
1835         * gst/base/gstbasesink.c: (gst_basesink_base_init),
1836         (gst_basesink_pad_getcaps), (gst_basesink_init),
1837         (gst_basesink_do_sync):
1838         * gst/gstclock.c: (gst_clock_entry_new):
1839         * gst/gstevent.c: (gst_event_discont_get_value):
1840         * gst/gstpipeline.c: (pipeline_bus_handler),
1841         (gst_pipeline_change_state):
1842         * gst/gstsystemclock.c: (gst_system_clock_id_wait_unlocked):
1843         Better debugging of clocking info.
1844         Allow NULL values when getting discont values.
1845
1846 2005-04-27  Wim Taymans  <wim@fluendo.com>
1847
1848         * check/gst/gstobject.c: (START_TEST), (gst_object_suite):
1849         * check/gst/gstpad.c: (gst_pad_suite):
1850         Increase timeout for checks.
1851
1852 2005-04-27  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
1853
1854         * check/Makefile.am:
1855           fix the broken rule for cleanup.  Apparently this rule is
1856           only needed on FC2, so maybe this warrants further autotool
1857           inspection.
1858
1859 2005-04-26  Wim Taymans  <wim@fluendo.com>
1860
1861         * gst/gsttrashstack.h:
1862         Ooohh. a nasty one! After having a failed pop() from the stack,
1863         it's possible that the stack is empty. In that case, don't
1864         follow the NULL pointer.
1865
1866 2005-04-25  Wim Taymans  <wim@fluendo.com>
1867
1868         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
1869         (gst_pad_set_checkgetrange_function),
1870         (gst_pad_link_check_compatible_unlocked), (gst_pad_link_prepare),
1871         (gst_pad_check_pull_range), (gst_pad_pull_range),
1872         (gst_static_pad_template_get_caps), (gst_pad_start_task),
1873         (gst_pad_pause_task), (gst_pad_stop_task):
1874         * gst/gstplugin.c: (gst_plugin_load):
1875         * gst/gstplugin.h:
1876         Remove gst_library_load as it does more harm than good with
1877         the new g_module flags.
1878         Revert bogus caps template check in pad linking, pad caps
1879         are important when linking not the template, which is more
1880         general than the current caps.
1881
1882 2005-04-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
1883
1884         * gst/autoplug/.cvsignore:
1885         * gst/autoplug/Makefile.am:
1886         * gst/autoplug/gstsearchfuncs.c:
1887         * gst/autoplug/gstsearchfuncs.h:
1888         * gst/autoplug/gstspider.c:
1889         * gst/autoplug/gstspider.h:
1890         * gst/autoplug/gstspideridentity.c:
1891         * gst/autoplug/gstspideridentity.h:
1892         * gst/autoplug/spidertest.c:
1893           Die, spider, die.
1894
1895 2005-04-25  Wim Taymans  <wim@fluendo.com>
1896
1897         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
1898         (gst_pad_set_checkgetrange_function), (gst_pad_check_pull_range),
1899         (gst_pad_pull_range), (gst_static_pad_template_get_caps),
1900         (gst_pad_start_task), (gst_pad_pause_task), (gst_pad_stop_task):
1901         * gst/gstpad.h:
1902         Added stubs for unimplemented functions. 
1903
1904 2005-04-24  David Schleef  <ds@schleef.org>
1905
1906         * gst/gstpad.h: Disable some unimplemented functions.  Wim,
1907         please fix.
1908
1909 2005-04-24  David Schleef  <ds@schleef.org>
1910
1911         Convert everything from GstAtomicInt to g_atomic_int_*, and
1912         remove gstatomic.
1913         * gst/Makefile.am:
1914         * gst/gstatomic.c:
1915         * gst/gstatomic.h:
1916         * gst/gstatomic_impl.h:
1917         * gst/gstbuffer.c:
1918         * gst/gstcaps.c:
1919         * gst/gstcaps.h:
1920         * gst/gstclock.c:
1921         * gst/gstclock.h:
1922         * gst/gstdata.c:
1923         * gst/gstdata.h:
1924         * gst/gstdata_private.h:
1925         * gst/gstevent.c:
1926         * gst/gstinfo.c:
1927         * gst/gstinfo.h:
1928         * gst/gstmessage.c:
1929         * gst/gstobject.c:
1930         * gst/gstobject.h:
1931         * gst/gststructure.c:
1932         * gst/gststructure.h:
1933         * gst/gstutils.c: Add gst_atomic_int_set() compaitibility function.
1934         * gst/gstutils.h:
1935
1936 2005-04-24  David Schleef  <ds@schleef.org>
1937
1938         * check/gst/gstpad.c: (START_TEST): Oh yeah, it's always nice to
1939         make the regressions tests work.  Remove some code that is no
1940         longer true.
1941         * gst/gstpad.c: (gst_pad_link_check_templates_compatible_unlocked):
1942         Disable warning for pads without templates.
1943
1944 2005-04-24  David Schleef  <ds@schleef.org>
1945
1946         * gst/gstpad.c: Remove handling of filtered caps.  Fix/merge
1947         functions that handle filtered links.
1948         * gst/gstpad.h: Remove 'appfilter' field and prototypes of
1949         removed functions.
1950         * gst/gstutils.c: Fix/remove utility functions that handle
1951         filtered caps.
1952         * gst/gstutils.h:
1953         * gst/gstvalue.c: Add serialization/deserialization of caps
1954         * gst/parse/grammar.y: Ignore filtered caps when linking.  This
1955         requires fixing so that the filter caps notation creates
1956         a capsfilter element and sets the filter_caps property.  I
1957         think everyone probably wants to keep the shorthand notation.
1958         * docs/gst/tmpl/gstelement.sgml: updates for API changes.
1959         * docs/gst/tmpl/gstpad.sgml:
1960
1961         * gst/elements/gstelements.c: Register capsfilter element.
1962         * gst/Makefile.am: fix spacing
1963         * docs/random/ds/0.9-suggested-changes: random
1964
1965 2005-04-23  David Schleef  <ds@schleef.org>
1966
1967         * gst/elements/Makefile.am:
1968         * gst/elements/gstcapsfilter.c: New element that acts like an
1969         identity, but filters caps.  Will eventually replace filtered
1970         caps in pad linking.
1971         * gst/gstutils.c: (gst_element_create_all_pads): New function
1972         to create all the ALWAYS pads that are registered with an
1973         element class.  This functionality should eventually be
1974         merged in with GstElement initialization.
1975         * gst/gstutils.h:
1976         * testsuite/trigger/README: part of trigger test code that should
1977         have been checked in a long time ago.
1978
1979 2005-04-23  David Schleef  <ds@schleef.org>
1980
1981         * gst/Makefile.am: Remove as-libtool stuff.  It's likely not
1982         needed with new versions of libtool (nobody will confirm this),
1983         and hard to carry around.
1984         * gst/autoplug/Makefile.am:
1985         * gst/base/Makefile.am:
1986         * gst/elements/Makefile.am:
1987         * gst/indexers/Makefile.am:
1988         * gst/schedulers/Makefile.am:
1989         * libs/gst/bytestream/Makefile.am:
1990         * libs/gst/control/Makefile.am:
1991         * libs/gst/dataprotocol/Makefile.am:
1992         * libs/gst/getbits/Makefile.am:
1993
1994 2005-04-21  Wim Taymans  <wim@fluendo.com>
1995
1996         * docs/design/draft-push-pull.txt:
1997         * docs/design/part-MT-refcounting.txt:
1998         * docs/design/part-TODO.txt:
1999         * docs/design/part-caps.txt:
2000         * docs/design/part-events.txt:
2001         * docs/design/part-gstbus.txt:
2002         * docs/design/part-gstpipeline.txt:
2003         * docs/design/part-messages.txt:
2004         * docs/design/part-push-pull.txt:
2005         * docs/design/part-query.txt:
2006         Some more docs.
2007
2008 2005-04-21  Wim Taymans  <wim@fluendo.com>
2009
2010         * gst/gstmessage.c: (_gst_message_copy), (_gst_message_free),
2011         (gst_message_new), (gst_message_new_error),
2012         (gst_message_new_warning), (gst_message_new_tag),
2013         (gst_message_new_state_changed), (gst_message_new_application),
2014         (gst_message_get_structure):
2015         * gst/gstmessage.h:
2016         * gst/gststructure.c: (gst_structure_set_parent_refcount),
2017         (gst_structure_copy_conditional):
2018         Use parent refcount in GstMessage to ensure GstStructure
2019         consistency.
2020         Cleaned up headers a bit.
2021         
2022
2023 2005-04-20  Wim Taymans  <wim@fluendo.com>
2024
2025         * gst/base/gstbasesink.c: (gst_basesink_base_init),
2026         (gst_basesink_pad_getcaps), (gst_basesink_init),
2027         (gst_basesink_chain_unlocked):
2028         * gst/base/gsttypefindhelper.c: (helper_find_suggest),
2029         (gst_type_find_helper):
2030         * gst/elements/gsttypefindelement.c:
2031         (gst_type_find_element_have_type), (gst_type_find_element_init),
2032         (stop_typefinding), (gst_type_find_element_handle_event),
2033         (find_suggest), (gst_type_find_element_chain),
2034         (gst_type_find_element_checkgetrange),
2035         (gst_type_find_element_getrange), (do_typefind),
2036         (gst_type_find_element_activate):
2037         * gst/gstbuffer.c: (_gst_buffer_sub_free),
2038         (gst_buffer_default_free), (gst_buffer_default_copy),
2039         (gst_buffer_set_caps):
2040         * gst/gstcaps.c: (gst_caps_ref), (gst_caps_unref),
2041         (gst_caps_replace):
2042         * gst/gstmessage.c: (gst_message_new),
2043         (gst_message_new_state_changed):
2044         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
2045         (gst_pad_set_checkgetrange_function),
2046         (gst_pad_link_prepare_filtered), (gst_pad_relink_filtered),
2047         (gst_pad_set_caps), (gst_pad_check_pull_range),
2048         (gst_pad_pull_range), (gst_static_pad_template_get_caps):
2049         * gst/gstpad.h:
2050         * gst/gsttypefind.c: (gst_type_find_register):
2051         Make gst_caps_replace() work like other _replace() functions.
2052         Use _caps_replace() where possible.
2053         Make sure _message_new() initialises its field.
2054         Add gst_static_pad_template_get_caps()
2055
2056
2057 2005-04-18  Andy Wingo  <wingo@pobox.com>
2058
2059         * gst/gstelement.c (gst_element_pads_activate): Check pull_range
2060         on the peer, not the pad. I think that was a typo. Pass an extra
2061         arg to see if random access is possible. Activate the pads as
2062         PULL_RANGE if possible.
2063
2064         * gst/elements/gstfakesrc.c: s/ARG_/PROP_/.
2065
2066         * gst/base/gstbasesrc.c (gst_basesrc_set_property) 
2067         (gst_basesrc_get_property): BLOCKSIZE is a ULONG. Rename ARG_...
2068         to PROP_....
2069
2070 2005-04-14  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2071
2072         * docs/faq/using.xml:
2073           Add note on gstreamer-properties (#154996).
2074
2075 2005-04-13  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2076
2077         * docs/random/bbb/optional-properties:
2078           Some analysis on optional properties.
2079
2080 2005-04-12  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2081
2082         * docs/gst/tmpl/gstelementfactory.sgml:
2083         * gst/gstelement.h:
2084         * gst/gstelementfactory.c: (gst_element_factory_init),
2085         (gst_element_factory_cleanup), (gst_element_register),
2086         (__gst_element_factory_add_static_pad_template),
2087         (gst_element_factory_get_static_pad_templates),
2088         (gst_element_factory_can_src_caps),
2089         (gst_element_factory_can_sink_caps):
2090         * gst/registries/Makefile.am:
2091         * gst/registries/gstlibxmlregistry.c: (gst_xml_registry_get_type),
2092         (gst_xml_registry_class_init), (gst_xml_registry_init),
2093         (gst_xml_registry_new), (gst_xml_registry_set_property),
2094         (gst_xml_registry_get_property), (get_time), (make_dir),
2095         (gst_xml_registry_get_perms_func),
2096         (plugin_times_older_than_recurse), (plugin_times_older_than),
2097         (gst_xml_registry_open_func), (gst_xml_registry_load_func),
2098         (gst_xml_registry_save_func), (gst_xml_registry_close_func),
2099         (add_to_char_array), (read_string), (read_uint), (read_enum),
2100         (load_pad_template), (load_feature), (load_plugin), (load_paths),
2101         (gst_xml_registry_load), (gst_xml_registry_load_plugin),
2102         (gst_xml_registry_save_caps), (gst_xml_registry_save_pad_template),
2103         (gst_xml_registry_save_feature), (gst_xml_registry_save_plugin),
2104         (gst_xml_registry_save), (gst_xml_registry_rebuild_recurse),
2105         (gst_xml_registry_rebuild):
2106         * gst/registries/gstlibxmlregistry.h:
2107         * tools/gst-compprep.c: (main):
2108         * tools/gst-inspect.c: (print_pad_templates_info):
2109         * tools/gst-xmlinspect.c: (print_element_info):
2110           Use libxml2 for registry parsing, use staticpadtemplates in
2111           elementfactories. Makes gst_init() +/- 10x faster.
2112
2113 2005-04-12  Wim Taymans  <wim@fluendo.com>
2114
2115         * gst/base/Makefile.am:
2116         * gst/base/gstbasesink.c: (gst_basesink_base_init),
2117         (gst_basesink_pad_getcaps), (gst_basesink_init),
2118         (gst_basesink_event), (gst_basesink_change_state):
2119         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
2120         (gst_basesrc_init), (gst_basesrc_query),
2121         (gst_basesrc_get_event_mask), (gst_basesrc_do_seek),
2122         (gst_basesrc_event_handler), (gst_basesrc_get_range_unlocked),
2123         (gst_basesrc_check_get_range), (gst_basesrc_loop),
2124         (gst_basesrc_unlock), (gst_basesrc_get_size), (gst_basesrc_start),
2125         (gst_basesrc_stop), (gst_basesrc_activate),
2126         (gst_basesrc_change_state):
2127         * gst/base/gsttypefindhelper.c: (helper_find_peek),
2128         (helper_find_suggest), (gst_type_find_helper):
2129         * gst/base/gsttypefindhelper.h:
2130         * gst/elements/Makefile.am:
2131         * gst/elements/gstelements.c:
2132         * gst/elements/gstfakesink.c: (gst_fakesink_class_init),
2133         (gst_fakesink_get_times), (gst_fakesink_event),
2134         (gst_fakesink_preroll), (gst_fakesink_render):
2135         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
2136         (gst_fakesrc_init), (gst_fakesrc_event_handler),
2137         (gst_fakesrc_get_property), (gst_fakesrc_create),
2138         (gst_fakesrc_start), (gst_fakesrc_stop):
2139         * gst/elements/gstfakesrc.h:
2140         * gst/elements/gstfilesrc.c: (gst_filesrc_class_init),
2141         (gst_filesrc_free_parent_mmap), (gst_filesrc_map_region),
2142         (gst_filesrc_map_small_region), (gst_filesrc_create_mmap),
2143         (gst_filesrc_create_read), (gst_filesrc_create),
2144         (gst_filesrc_is_seekable), (gst_filesrc_get_size),
2145         (gst_filesrc_start):
2146         * gst/elements/gsttypefindelement.c:
2147         (gst_type_find_element_have_type), (gst_type_find_element_init),
2148         (start_typefinding), (stop_typefinding), (push_buffer_store),
2149         (gst_type_find_element_handle_event),
2150         (gst_type_find_element_chain),
2151         (gst_type_find_element_checkgetrange),
2152         (gst_type_find_element_getrange), (do_typefind),
2153         (gst_type_find_element_activate),
2154         (gst_type_find_element_change_state):
2155         * gst/elements/gsttypefindelement.h:
2156         * gst/gstpipeline.c: (pipeline_bus_handler):
2157         Added typefind helper.
2158         Small preroll fix in the base sink.
2159         Disable typefind code in basesrc.
2160         Crude port of typefindelement.
2161         Fakesrc cleanups.
2162
2163
2164 2005-04-11  Wim Taymans  <wim@fluendo.com>
2165
2166         * check/gst/gstbus.c: (gstbus_suite):
2167         * check/gst/gstdata.c: (thread_ref), (gst_data_suite):
2168         * check/gstcheck.h:
2169           Fix up the timeout so that the test does not fail.
2170
2171 2005-04-06  Wim Taymans  <wim@fluendo.com>
2172
2173         * gst/base/README:
2174         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
2175         (gst_basesrc_init), (gst_basesrc_get_formats), (gst_basesrc_query),
2176         (gst_basesrc_get_event_mask), (gst_basesrc_do_seek),
2177         (gst_basesrc_event_handler), (gst_basesrc_get_range_unlocked),
2178         (gst_basesrc_check_get_range), (gst_basesrc_loop),
2179         (gst_basesrc_unlock), (gst_basesrc_get_size), (gst_basesrc_start),
2180         (gst_basesrc_stop), (gst_basesrc_activate),
2181         (gst_basesrc_change_state), (basesrc_find_peek),
2182         (basesrc_find_suggest), (gst_basesrc_type_find):
2183         * gst/base/gstbasesrc.h:
2184         * gst/elements/gstfilesrc.c: (gst_filesrc_base_init),
2185         (gst_filesrc_class_init), (gst_filesrc_init),
2186         (gst_filesrc_finalize), (gst_filesrc_set_location),
2187         (gst_filesrc_set_property), (gst_filesrc_get_property),
2188         (gst_filesrc_free_parent_mmap), (gst_filesrc_map_region),
2189         (gst_filesrc_map_small_region), (gst_filesrc_create_mmap),
2190         (gst_filesrc_create_read), (gst_filesrc_create),
2191         (gst_filesrc_get_size), (gst_filesrc_start), (gst_filesrc_stop):
2192         * gst/elements/gstfilesrc.h:
2193         * gst/gstelement.c: (gst_element_get_state_func),
2194         (gst_element_lost_state), (gst_element_pads_activate):
2195         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
2196         (gst_pad_set_checkgetrange_function), (gst_pad_check_pull_range),
2197         (gst_pad_pull_range):
2198         * gst/gstpad.h:
2199         More work on the generic source base class, implement seeking,
2200         query.
2201         Make filesrc extend the base source class.
2202         Added gst_pad_set_checkgetrange_function to GstPad.
2203
2204 2005-04-06  Andy Wingo  <wingo@pobox.com>
2205
2206         * pkgconfig/gstreamer-base.pc.in:
2207         * pkgconfig/gstreamer-base-uninstalled.pc.in: New files.
2208
2209         * pkgconfig/Makefile.am:
2210         * configure.ac (AC_OUTPUT): Add gstreamer-base pkgconfig files.
2211
2212 2005-04-04  Wim Taymans  <wim@fluendo.com>
2213
2214         * gst/base/Makefile.am:
2215         * gst/base/README:
2216         * gst/base/gstbasesink.c: (gst_basesink_base_init),
2217         (gst_basesink_pad_getcaps), (gst_basesink_pad_setcaps),
2218         (gst_basesink_pad_buffer_alloc), (gst_basesink_init),
2219         (gst_basesink_do_sync), (gst_basesink_chain_unlocked):
2220         * gst/base/gstbasesrc.c: (gst_basesrc_get_type),
2221         (gst_basesrc_base_init), (gst_basesrc_class_init),
2222         (gst_basesrc_init), (gst_basesrc_get_formats),
2223         (gst_basesrc_get_query_types), (gst_basesrc_query),
2224         (gst_basesrc_get_event_mask), (gst_basesrc_event_handler),
2225         (gst_basesrc_set_property), (gst_basesrc_get_property),
2226         (gst_basesrc_get_range_unlocked), (gst_basesrc_get_range),
2227         (gst_basesrc_loop), (gst_basesrc_activate),
2228         (gst_basesrc_change_state):
2229         * gst/base/gstbasesrc.h:
2230         * gst/elements/gstfakesrc.c: (gst_fakesrc_base_init),
2231         (gst_fakesrc_class_init), (gst_fakesrc_init),
2232         (gst_fakesrc_event_handler), (gst_fakesrc_set_property),
2233         (gst_fakesrc_get_property), (gst_fakesrc_create):
2234         * gst/elements/gstfakesrc.h:
2235         * gst/elements/gstfilesrc.c: (gst_filesrc_getrange),
2236         (gst_filesrc_open_file), (gst_filesrc_loop),
2237         (gst_filesrc_activate), (filesrc_find_peek),
2238         (gst_filesrc_type_find):
2239         Made base source class, make fakesrc extend it.
2240         Add comments to basesink class.
2241         Some filesrc cleanup.
2242
2243 2005-03-31  David Schleef  <ds@schleef.org>
2244
2245         * gst/gstplugin.c: (gst_plugin_check_file), (gst_plugin_load_file):
2246         Switch to using G_MODULE_BIND_LOCAL, which means plugins are now
2247         expected to link against libgstreamer.
2248         * gst/base/Makefile.am: link against libgstreamer
2249         * gst/elements/Makefile.am: same
2250
2251 2005-03-31  Andy Wingo  <wingo@pobox.com>
2252
2253         * tests/instantiate/Makefile.am:
2254         * tests/instantiate/caps.c: Add test to test speed of caps copy
2255         and free.
2256
2257         * tests/memchunk/gmemchunktest.c (main): Use alloc only on the
2258         GMemChunk to be fair.
2259
2260         * gst/gsttrashstack.h: Remove warning about using the fallback
2261         trash stack implementation, it's still faster than malloc.
2262
2263 2005-03-30  Andy Wingo  <wingo@pobox.com>
2264
2265         * tests/complexity.c: Add a copyright.
2266
2267 2005-03-31  Wim Taymans  <wim@fluendo.com>
2268
2269         * gst/base/gstbasetransform.c: (gst_base_transform_base_init),
2270         (gst_base_transform_class_init), (gst_base_transform_init),
2271         (gst_base_transform_setcaps), (gst_base_transform_handle_buffer),
2272         (gst_base_transform_get_property),
2273         (gst_base_transform_sink_activate),
2274         (gst_base_transform_src_activate),
2275         (gst_base_transform_change_state):
2276         * gst/base/gstbasetransform.h:
2277         * gst/elements/gstidentity.c: (gst_identity_class_init),
2278         (gst_identity_event), (gst_identity_check_perfect),
2279         (gst_identity_transform), (gst_identity_start),
2280         (gst_identity_stop):
2281         Added start/stop methods to transform base class so subclasses 
2282         don't need to deal with state changes even.
2283
2284 2005-03-31  Wim Taymans  <wim@fluendo.com>
2285
2286         * gst/gstevent.c: (gst_event_new_discontinuous_valist),
2287         (gst_event_new_discontinuous), (gst_event_discont_get_value):
2288         * gst/gstevent.h:
2289         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
2290         (gst_pad_pull_range):
2291         Added rate to the discont event to prepare for variable speed
2292         and reverse playback.
2293
2294 2005-03-29  David Schleef  <ds@schleef.org>
2295
2296         * configure.ac:
2297         * testsuite/trigger/Makefile.am:
2298         * testsuite/trigger/trigger.c: A little example program to show
2299         how trigger-based elements can work.
2300
2301 2005-03-29  Wim Taymans  <wim@fluendo.com>
2302
2303         * gst/base/Makefile.am:
2304         * gst/base/README:
2305         * gst/base/gstbasesink.c: (gst_basesink_get_type),
2306         (gst_basesink_base_init), (gst_basesink_class_init),
2307         (gst_basesink_pad_getcaps), (gst_basesink_init),
2308         (gst_basesink_activate), (gst_basesink_change_state):
2309         * gst/base/gstbasesink.h:
2310         * gst/base/gstbasetransform.c: (gst_base_transform_get_type),
2311         (gst_base_transform_base_init), (gst_base_transform_finalize),
2312         (gst_base_transform_class_init), (gst_base_transform_init),
2313         (gst_base_transform_proxy_getcaps), (gst_base_transform_setcaps),
2314         (gst_base_transform_event), (gst_base_transform_getrange),
2315         (gst_base_transform_chain), (gst_base_transform_handle_buffer),
2316         (gst_base_transform_set_property),
2317         (gst_base_transform_get_property),
2318         (gst_base_transform_sink_activate),
2319         (gst_base_transform_src_activate),
2320         (gst_base_transform_change_state):
2321         * gst/base/gstbasetransform.h:
2322         * gst/elements/gstidentity.c: (gst_identity_finalize),
2323         (gst_identity_class_init), (gst_identity_init),
2324         (gst_identity_event), (gst_identity_check_perfect),
2325         (gst_identity_transform), (gst_identity_set_property),
2326         (gst_identity_get_property), (gst_identity_change_state):
2327         * gst/elements/gstidentity.h:
2328         * gst/gstelement.c: (gst_element_get_state_func),
2329         (gst_element_lost_state), (gst_element_pads_activate):
2330         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_peer_set_active),
2331         (gst_pad_check_pull_range), (gst_pad_pull_range):
2332         * gst/gstpad.h:
2333         Simplify pad activation.
2334         Added function to check if pull_range can be performed.
2335         Error out when pulling inactive or flushing pads.
2336         Removed const from refcounted types as it does not make sense.
2337         Simplify pad templates in basesink
2338         Added base class for simple 1-to-1 transforms.
2339         Make identity subclass the base transform.
2340
2341 2005-03-29  Andy Wingo  <wingo@pobox.com>
2342
2343         * docs/libs/gstreamer-libs-overrides.txt: 
2344         * docs/gst/gstreamer-overrides.txt: Add these files to CVS. Now I
2345         really don't understand what's going on, but like whatever. I want
2346         green buildbot!
2347
2348         * docs/gst/Makefile.am:
2349         * docs/libs/Makefile.am: Dist the overrides files.
2350
2351         * check/Makefile.am (clean-local): Remove .libs directories.
2352
2353         * gst/elements/Makefile.am (EXTRA_DIST): Add all the attic
2354         elements to EXTRA_DIST, so po/ files are happy.
2355
2356         * po/POTFILES.in: Er, remove it here.
2357
2358         * po/POTFILES: Remove gstspider.c.
2359
2360         * configure.ac (AC_OUTPUT): Add missing testsuite makefiles.
2361
2362         * docs/libs/gstreamer-libs-docs.sgml: 
2363         * docs/libs/gstreamer-libs-sections.txt: Remove the section on
2364         bytestream.
2365
2366         * tests/complexity.c (main): Set the length of the preroll queue
2367         on the sinks to prevent a lockup.
2368
2369         * libs/gst/dataprotocol/Makefile.am: 
2370         * libs/gst/dataprotocol/dataprotocol-test.c: Remove test, it's
2371         the same as the one in check/gst-libs/gdp.c.
2372
2373         * po/, docs/gst/: Commit automatic changes to docs and po files.
2374
2375         * gst/elements/Makefile.am (libgstelements_la_LDFLAGS): Link to
2376         the versioned libgstbase.
2377
2378         * check/Makefile.am: Depend on an unversioned gst-register, seems
2379         to make autoconf happier.
2380
2381         * gst/base/Makefile.am: Make libgstbase a versioned lib.
2382
2383 2005-03-28  Wim Taymans  <wim@fluendo.com>
2384
2385         * configure.ac:
2386         * docs/design/part-gstelement.txt:
2387         * docs/design/part-negotiation.txt:
2388         * docs/design/part-preroll.txt:
2389         * docs/design/part-scheduling.txt:
2390         * docs/design/part-states.txt:
2391         * gst/Makefile.am:
2392         * gst/base/Makefile.am:
2393         * gst/base/README:
2394         * gst/base/gstbasesink.c: (gst_basesink_get_template),
2395         (gst_basesink_base_init), (gst_basesink_class_init),
2396         (gst_basesink_pad_getcaps), (gst_basesink_pad_setcaps),
2397         (gst_basesink_pad_buffer_alloc), (gst_basesink_init),
2398         (gst_basesink_set_pad_functions),
2399         (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock),
2400         (gst_basesink_set_property), (gst_basesink_get_property),
2401         (gst_base_sink_get_template), (gst_base_sink_get_caps),
2402         (gst_base_sink_set_caps), (gst_base_sink_buffer_alloc),
2403         (gst_basesink_preroll_queue_push),
2404         (gst_basesink_preroll_queue_empty),
2405         (gst_basesink_preroll_queue_flush), (gst_basesink_finish_preroll),
2406         (gst_basesink_event), (gst_basesink_get_times),
2407         (gst_basesink_do_sync), (gst_basesink_handle_buffer),
2408         (gst_basesink_chain_unlocked), (gst_basesink_chain),
2409         (gst_basesink_loop), (gst_basesink_activate),
2410         (gst_basesink_change_state):
2411         * gst/base/gstbasesink.h:
2412         * gst/elements/Makefile.am:
2413         * gst/elements/gstfakesink.c: (gst_fakesink_base_init),
2414         (gst_fakesink_class_init), (gst_fakesink_init),
2415         (gst_fakesink_set_property), (gst_fakesink_get_property),
2416         (gst_fakesink_get_times), (gst_fakesink_event),
2417         (gst_fakesink_preroll), (gst_fakesink_render),
2418         (gst_fakesink_change_state):
2419         * gst/elements/gstfakesink.h:
2420         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_manager),
2421         (gst_bin_get_state), (gst_bin_change_state), (gst_bin_send_event):
2422         * gst/gstelement.c: (gst_element_add_pad),
2423         (gst_element_get_state_func), (gst_element_abort_state),
2424         (gst_element_commit_state), (gst_element_lost_state),
2425         (gst_element_set_state), (gst_element_pads_activate):
2426         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_event_default):
2427         * gst/gstpipeline.c: (gst_pipeline_send_event),
2428         (gst_pipeline_change_state):
2429         Added state change code.
2430         Added/updated docs.
2431         Added sink base class, make fakesink extend the base class.
2432         Small cleanups in GstPipeline.
2433
2434 2005-03-26  David Schleef  <ds@schleef.org>
2435
2436         * gst/Makefile.am: remove gstcpu.[ch].  The gst_cpu functionality
2437         is broken and should be implemented in a different library.
2438         * gst/gst.c: (init_post): don't call _gst_cpu_initialize()
2439         * gst/gst.h: remove gstcpu.h
2440         * gst/gstcpu.c: remove
2441         * gst/gstcpu.h: remove
2442         * gst/Makefile.am.future: Remove this file.  It's ancient.
2443
2444 2005-03-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2445
2446         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_manager),
2447         (gst_bin_send_event):
2448           Add default event/set_manager handlers. The set_manager handler
2449           takes care that the manager is distributed over kids that were
2450           already in the bin before the manager was set. The event handler
2451           is a utility virtual function that sends the event over all sinks,
2452           so that gst_element_send_event (bin, event); has the expected
2453           behaviour.
2454         * gst/gstpad.c: (gst_pad_event_default):
2455           Re-install default event handling for discontinuities, so that
2456           seeking works without requiring hacks in applications or extra
2457           code in sinks.
2458         * gst/gstpipeline.c: (gst_pipeline_class_init),
2459         (gst_pipeline_send_event):
2460           Half hack, half utility: set a pipeline to PAUSED for seek events,
2461           since that is the only way we can guarantee a/v sync. Means that
2462           you can do gst_element_seek (pipeline, method, pos); on a pipeline
2463           and it "just works".
2464
2465 2005-03-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
2466
2467         * gst/gstpipeline.c: (gst_pipeline_use_clock):
2468           Lock/unlock mismatch.
2469
2470 2005-03-25  Thomas Vander Stichele  <thomas at apestaart dot org>
2471
2472         * docs/faq/gst-uninstalled:
2473           add gst-plugins-base
2474         * docs/gst/Makefile.am:
2475           don't error out until docs are fixed
2476         * docs/gst/gstreamer.types:
2477           remove thread
2478
2479 2005-03-22  Wim Taymans  <wim@fluendo.com>
2480
2481         * check/Makefile.am:
2482         * check/gst/gstmessage.c: (START_TEST), (gst_data_suite), (main):
2483         * gst/gststructure.c: (gst_structure_set_valist),
2484         (gst_structure_copy_conditional):
2485         Activated more tests.
2486         Added message test.
2487         Added G_TYPE_POINTER to GstStructure.
2488         
2489
2490 2005-03-22  Wim Taymans  <wim@fluendo.com>
2491
2492         * docs/design/part-TODO.txt:
2493         * docs/design/part-events.txt:
2494         * docs/design/part-gstbin.txt:
2495         * docs/design/part-gstbus.txt:
2496         * docs/design/part-gstpipeline.txt:
2497         * docs/design/part-messages.txt:
2498         * gst/gstbus.c:
2499         * gst/gstmessage.c:
2500         Docs updates
2501
2502 2005-03-21  Wim Taymans  <wim@fluendo.com>
2503
2504         * gst/gstbus.c: (gst_bus_post):
2505         Fix copy-and-paste error.
2506
2507 2005-03-21  Wim Taymans  <wim@fluendo.com>
2508
2509         * check/Makefile.am:
2510         * gst/Makefile.am:
2511         * gst/elements/Makefile.am:
2512         * gst/elements/gstelements.c:
2513         * gst/elements/gstfakesink.c: (gst_fakesink_init),
2514         (gst_fakesink_event), (gst_fakesink_chain):
2515         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
2516         (gst_fakesrc_init), (gst_fakesrc_get_event_mask),
2517         (gst_fakesrc_event_handler), (gst_fakesrc_set_pad_functions),
2518         (gst_fakesrc_set_all_pad_functions), (gst_fakesrc_request_new_pad),
2519         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
2520         (gst_fakesrc_get_range_unlocked), (gst_fakesrc_get_range),
2521         (gst_fakesrc_loop), (gst_fakesrc_activate),
2522         (gst_fakesrc_change_state):
2523         * gst/elements/gstfakesrc.h:
2524         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
2525         (gst_filesrc_get_read), (gst_filesrc_getrange), (gst_filesrc_get),
2526         (gst_filesrc_open_file), (gst_filesrc_loop),
2527         (gst_filesrc_activate), (gst_filesrc_change_state),
2528         (filesrc_find_peek), (filesrc_find_suggest),
2529         (gst_filesrc_type_find):
2530         * gst/elements/gstidentity.c: (gst_identity_finalize),
2531         (gst_identity_class_init), (gst_identity_init),
2532         (gst_identity_proxy_getcaps), (identity_queue_push),
2533         (identity_queue_pop), (identity_queue_flush), (gst_identity_event),
2534         (gst_identity_getrange), (gst_identity_chain),
2535         (gst_identity_sink_loop), (gst_identity_src_loop),
2536         (gst_identity_handle_buffer), (gst_identity_set_dataflow_funcs),
2537         (gst_identity_set_property), (gst_identity_get_property),
2538         (gst_identity_change_state):
2539         * gst/elements/gstidentity.h:
2540         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_init),
2541         (gst_tee_update_pad_functions), (gst_tee_request_new_pad),
2542         (gst_tee_set_property), (gst_tee_get_property), (gst_tee_do_push),
2543         (gst_tee_handle_buffer), (gst_tee_chain), (gst_tee_loop),
2544         (gst_tee_sink_activate):
2545         * gst/elements/gsttee.h:
2546         * gst/gst.c: (gst_register_core_elements), (init_post):
2547         * gst/gst.h:
2548         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_bus),
2549         (gst_bin_set_scheduler), (gst_bin_add_func), (gst_bin_add),
2550         (gst_bin_remove_func), (gst_bin_remove), (gst_bin_get_state),
2551         (gst_bin_change_state):
2552         * gst/gstbin.h:
2553         * gst/gstbus.c: (gst_bus_get_type), (gst_bus_class_init),
2554         (gst_bus_init), (gst_bus_dispose), (gst_bus_set_property),
2555         (gst_bus_get_property), (gst_bus_new), (gst_bus_post),
2556         (gst_bus_have_pending), (gst_bus_pop), (gst_bus_peek),
2557         (gst_bus_set_sync_handler), (gst_bus_create_watch),
2558         (bus_watch_callback), (bus_watch_destroy),
2559         (gst_bus_add_watch_full), (gst_bus_add_watch), (poll_handler),
2560         (poll_timeout), (gst_bus_poll):
2561         * gst/gstbus.h:
2562         * gst/gstcaps.h:
2563         * gst/gstdata.h:
2564         * gst/gstelement.c: (gst_element_class_init), (gst_element_init),
2565         (gst_element_post_message), (gst_element_message_full),
2566         (gst_element_get_state_func), (gst_element_get_state),
2567         (gst_element_abort_state), (gst_element_commit_state),
2568         (gst_element_lost_state), (gst_element_set_state),
2569         (gst_element_pads_activate), (gst_element_change_state),
2570         (gst_element_dispose), (gst_element_set_manager_func),
2571         (gst_element_set_bus_func), (gst_element_set_scheduler_func),
2572         (gst_element_set_manager), (gst_element_get_manager),
2573         (gst_element_set_bus), (gst_element_get_bus),
2574         (gst_element_set_scheduler), (gst_element_get_scheduler):
2575         * gst/gstelement.h:
2576         * gst/gstevent.c: (gst_event_new_segment_seek),
2577         (gst_event_new_flush):
2578         * gst/gstevent.h:
2579         * gst/gstmessage.c: (_gst_message_initialize), (_gst_message_copy),
2580         (_gst_message_free), (gst_message_get_type), (gst_message_new),
2581         (gst_message_new_eos), (gst_message_new_error),
2582         (gst_message_new_warning), (gst_message_new_tag),
2583         (gst_message_new_state_changed), (gst_message_new_application),
2584         (gst_message_get_structure), (gst_message_parse_tag),
2585         (gst_message_parse_state_changed), (gst_message_parse_error),
2586         (gst_message_parse_warning):
2587         * gst/gstmessage.h:
2588         * gst/gstpad.c: (gst_real_pad_class_init), (gst_real_pad_init),
2589         (gst_real_pad_set_property), (gst_pad_set_active),
2590         (gst_pad_is_active), (gst_pad_set_blocked_async),
2591         (gst_pad_set_blocked), (gst_pad_is_blocked),
2592         (gst_pad_set_activate_function), (gst_pad_set_loop_function),
2593         (gst_pad_set_getrange_function), (gst_pad_set_acceptcaps_function),
2594         (gst_pad_set_fixatecaps_function), (gst_pad_set_setcaps_function),
2595         (gst_pad_unlink), (gst_pad_link_prepare_filtered),
2596         (gst_pad_link_filtered), (gst_pad_relink_filtered),
2597         (gst_real_pad_get_caps_unlocked), (gst_pad_get_caps),
2598         (gst_pad_peer_get_caps), (gst_pad_fixate_caps),
2599         (gst_pad_accept_caps), (gst_pad_peer_accept_caps),
2600         (gst_pad_set_caps), (gst_pad_configure_sink),
2601         (gst_pad_configure_src), (gst_pad_get_negotiated_caps),
2602         (gst_pad_get_filter_caps), (gst_pad_alloc_buffer),
2603         (gst_real_pad_dispose), (gst_real_pad_finalize),
2604         (handle_pad_block), (gst_pad_push), (gst_pad_pull_range),
2605         (gst_pad_event_default_dispatch), (gst_pad_event_default),
2606         (gst_pad_push_event), (gst_pad_send_event), (gst_pad_get_formats):
2607         * gst/gstpad.h:
2608         * gst/gstpipeline.c: (gst_pipeline_init), (is_eos),
2609         (pipeline_bus_handler), (gst_pipeline_change_state),
2610         (gst_pipeline_get_scheduler), (gst_pipeline_get_bus):
2611         * gst/gstpipeline.h:
2612         * gst/gstprobe.h:
2613         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_init),
2614         (gst_queue_finalize), (gst_queue_getcaps), (gst_queue_link_sink),
2615         (gst_queue_link_src), (gst_queue_bufferalloc),
2616         (gst_queue_locked_flush), (gst_queue_handle_sink_event),
2617         (gst_queue_is_empty), (gst_queue_is_filled), (gst_queue_chain),
2618         (gst_queue_loop), (gst_queue_handle_src_event),
2619         (gst_queue_handle_src_query), (gst_queue_src_activate),
2620         (gst_queue_change_state):
2621         * gst/gstqueue.h:
2622         * gst/gstscheduler.c: (gst_scheduler_init),
2623         (gst_scheduler_dispose), (gst_scheduler_create_task),
2624         (gst_scheduler_factory_create):
2625         * gst/gstscheduler.h:
2626         * gst/gststructure.c: (gst_structure_get_type),
2627         (gst_structure_copy_conditional):
2628         * gst/gststructure.h:
2629         * gst/gsttaginterface.h:
2630         * gst/gsttask.c: (gst_task_get_type), (gst_task_class_init),
2631         (gst_task_init), (gst_task_dispose), (gst_task_create),
2632         (gst_task_get_state), (gst_task_start), (gst_task_stop),
2633         (gst_task_pause):
2634         * gst/gsttask.h:
2635         * gst/gstthread.c:
2636         * gst/gstthread.h:
2637         * gst/gsttypes.h:
2638         * gst/schedulers/Makefile.am:
2639         * gst/schedulers/cothreads_compat.h:
2640         * gst/schedulers/entryscheduler.c:
2641         * gst/schedulers/faircothreads.c:
2642         * gst/schedulers/faircothreads.h:
2643         * gst/schedulers/fairscheduler.c:
2644         * gst/schedulers/gstbasicscheduler.c:
2645         * gst/schedulers/gstoptimalscheduler.c:
2646         * gst/schedulers/gthread-cothreads.h:
2647         * gst/schedulers/threadscheduler.c:
2648         (gst_thread_scheduler_task_get_type),
2649         (gst_thread_scheduler_task_class_init),
2650         (gst_thread_scheduler_task_init),
2651         (gst_thread_scheduler_task_start),
2652         (gst_thread_scheduler_task_stop),
2653         (gst_thread_scheduler_task_pause), (gst_thread_scheduler_get_type),
2654         (gst_thread_scheduler_class_init), (gst_thread_scheduler_func),
2655         (gst_thread_scheduler_init), (gst_thread_scheduler_create_task),
2656         (gst_thread_scheduler_setup), (gst_thread_scheduler_reset),
2657         (plugin_init):
2658         * libs/gst/Makefile.am:
2659         * libs/gst/bytestream/bytestream.c: (gst_bytestream_get_next_buf):
2660         * libs/gst/bytestream/filepad.c: (gst_file_pad_init),
2661         (gst_file_pad_parent_set):
2662         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_event),
2663         (gst_dp_event_from_packet):
2664         * tests/complexity.c: (main):
2665         * tests/mass_elements.c: (main):
2666         * testsuite/states/locked.c: (message_received), (main):
2667         * testsuite/states/parent.c: (main):
2668         * tools/gst-inspect.c: (print_element_flag_info),
2669         (print_implementation_info), (print_pad_info):
2670         * tools/gst-launch.c: (check_intr), (play_handler), (event_loop),
2671         (main):
2672         * tools/gst-md5sum.c: (event_loop), (main):
2673         * tools/gst-typefind.c: (main):
2674         * tools/gst-xmlinspect.c: (print_element_info):
2675         Next big merge.
2676         Added GstBus for mainloop integration.
2677         Added GstMessage for sending notifications on the bus.
2678         Added GstTask as an abstraction for pipeline entry points.
2679         Removed GstThread.
2680         Removed Schedulers.
2681         Simplified GstQueue for multithreaded core.
2682         Made _link threadsafe, removed old capsnego.
2683         Added STREAM_LOCK and PREROLL_LOCK in GstPad.
2684         Added pad blocking functions.
2685         Reworked scheduling functions in GstPad to prepare for
2686         scheduling updates soon.
2687         Moved events out of data stream.
2688         Simplified GstEvent types.
2689         Added return values to push/pull.
2690         Removed clocking from GstElement.
2691         Added prototypes for state change function for next merge.
2692         Removed iterate from bins and state change management.
2693         Fixed some elements, disabled others for now.
2694         Fixed -inspect and -launch.
2695         Added check for GstBus.
2696
2697 2005-03-10  Wim Taymans  <wim@fluendo.com>
2698
2699         * docs/design/part-MT-refcounting.txt:
2700         * docs/design/part-clocks.txt:
2701         * docs/design/part-gstelement.txt:
2702         * docs/design/part-gstobject.txt:
2703         * docs/design/part-standards.txt:
2704         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
2705         (gst_bin_remove_func), (gst_bin_remove):
2706         * gst/gstbin.h:
2707         * gst/gstbuffer.c:
2708         * gst/gstcaps.h:
2709         * testsuite/clock/clock1.c: (main):
2710         * testsuite/clock/clock2.c: (gst_clock_debug), (element_wait),
2711         (main):
2712         * testsuite/dlopen/loadgst.c: (do_test):
2713         * testsuite/refcounting/bin.c: (add_remove_test1),
2714         (add_remove_test2), (main):
2715         * testsuite/refcounting/element.c: (main):
2716         * testsuite/refcounting/element_pad.c: (main):
2717         * testsuite/refcounting/pad.c: (main):
2718         * tools/gst-launch.c: (sigint_handler_sighandler):
2719         * tools/gst-typefind.c: (main):
2720         Doc updates.
2721         Added doc about clock.
2722         removed gst_bin_iterate_recurse_up(), marked methods
2723         for removal.
2724         Fix more testsuites.
2725
2726 2005-03-09  Wim Taymans  <wim@fluendo.com>
2727
2728         * gst/gstpad.c: (gst_pad_get_direction),
2729         (_gst_pad_default_fixate_foreach), (gst_pad_collectv),
2730         (gst_pad_collect_valist):
2731         * testsuite/bins/interface.c: (main):
2732         * testsuite/caps/audioscale.c: (test_caps):
2733         * testsuite/caps/caps.c: (test1), (test2), (test3):
2734         * testsuite/caps/deserialize.c: (main):
2735         * testsuite/caps/enumcaps.c: (main):
2736         * testsuite/caps/filtercaps.c: (main):
2737         * testsuite/caps/intersect2.c: (main):
2738         * testsuite/caps/random.c: (main):
2739         * testsuite/caps/renegotiate.c: (my_fixate), (main):
2740         * testsuite/caps/sets.c: (check_caps):
2741         * testsuite/caps/simplify.c: (check_caps), (main):
2742         * testsuite/caps/subtract.c: (check_caps):
2743         Fix _pad_get_direction wrt ghostpads.
2744         Fix caps testsuite.
2745
2746 2005-03-09  Wim Taymans  <wim@fluendo.com>
2747
2748         * check/Makefile.am:
2749         * check/gst/gstbin.c: (START_TEST), (gst_bin_suite), (main):
2750         * check/gst/gstsystemclock.c: (START_TEST), (gst_clock_debug),
2751         (ok_callback), (error_callback), (gst_systemclock_suite), (main):
2752         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_index_func),
2753         (gst_bin_set_clock_func), (gst_bin_get_clock_func),
2754         (gst_bin_add_func), (gst_bin_add), (gst_bin_remove_func),
2755         (gst_bin_remove), (gst_bin_iterate_recurse_up),
2756         (bin_element_is_sink), (gst_bin_iterate_sinks),
2757         (gst_bin_iterate_all_by_interface):
2758         * gst/gstbin.h:
2759         * gst/gstelement.c: (gst_element_init), (gst_element_error_full),
2760         (gst_element_change_state), (gst_element_dispose),
2761         (gst_element_finalize), (gst_element_set_loop_function):
2762         * gst/gstelement.h:
2763         * gst/gstiterator.c: (find_custom_fold_func):
2764         * gst/gstpad.c: (_gst_pad_default_fixate_foreach),
2765         (gst_pad_collectv), (gst_pad_collect_valist),
2766         (gst_pad_template_new):
2767         * gst/gstpipeline.c: (gst_pipeline_class_init),
2768         (gst_pipeline_dispose), (gst_pipeline_set_property),
2769         (gst_pipeline_get_property), (gst_pipeline_get_clock_func),
2770         (gst_pipeline_get_clock), (gst_pipeline_use_clock),
2771         (gst_pipeline_set_clock), (gst_pipeline_auto_clock):
2772         * gst/gstutils.h:
2773         * gst/schedulers/entryscheduler.c:
2774         * gst/schedulers/gstbasicscheduler.c:
2775         (gst_basic_scheduler_cothreaded_chain),
2776         (gst_basic_scheduler_chain_add_element):
2777         * testsuite/bins/interface.c: (main):
2778         Added GstBin test.
2779         Added GstSystemClock test.
2780         Implemented clock distribution code in GstBin.
2781         Implemented iterate sinks method for future use.
2782         Rearranged gstelement.h
2783         Fix GstIterator comparison bug.
2784         Moved some code to GstPipeline, mostly clocking related.
2785
2786 2005-03-09  Wim Taymans  <wim@fluendo.com>
2787
2788         * configure.ac:
2789         * gst/gst_private.h:
2790         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
2791         (gst_bin_remove_func), (gst_bin_remove),
2792         (gst_bin_get_by_name_recurse_up):
2793         * gst/gstclock.c: (gst_clock_id_ref), (gst_clock_id_unref),
2794         (gst_clock_id_compare_func), (gst_clock_id_wait),
2795         (gst_clock_id_wait_async), (gst_clock_init),
2796         (gst_clock_adjust_unlocked), (gst_clock_get_time):
2797         * gst/gstelement.h:
2798         * gst/gstinfo.c: (_gst_debug_init):
2799         * gst/gstobject.h:
2800         * gst/gstpad.c: (_gst_pad_default_fixate_foreach),
2801         (gst_pad_collectv), (gst_pad_collect_valist), (gst_pad_query):
2802         * gst/gstpad.h:
2803         Bump version number, we're now 0.9.0
2804         Add future debugging category.
2805         Fix NULL _unref() in _get_by_name_recurse_up
2806         Rearrange gstpad.h.
2807         Update some docs.
2808
2809 2005-03-08  Wim Taymans  <wim@fluendo.com>
2810
2811         * gst/elements/gstaggregator.c: (gst_aggregator_class_init):
2812         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
2813         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
2814         * gst/elements/gstfdsink.c: (gst_fdsink_class_init):
2815         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init):
2816         * gst/elements/gstfilesink.c: (gst_filesink_class_init):
2817         * gst/elements/gstfilesrc.c: (gst_filesrc_class_init):
2818         * gst/elements/gstidentity.c: (gst_identity_class_init):
2819         * gst/elements/gstmd5sink.c: (gst_md5sink_class_init):
2820         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
2821         * gst/elements/gstshaper.c: (gst_shaper_class_init):
2822         * gst/elements/gststatistics.c: (gst_statistics_class_init):
2823         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_getcaps),
2824         (gst_tee_link):
2825         * gst/gstelement.c: (gst_element_class_init),
2826         (gst_element_base_class_init), (gst_element_init),
2827         (gst_element_get_random_pad), (gst_element_wait_state_change),
2828         (gst_element_change_state), (gst_element_dispose),
2829         (gst_element_finalize), (gst_element_set_loop_function):
2830         * gst/gstelement.h:
2831         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_link_src):
2832         * gst/gstthread.c: (gst_thread_class_init),
2833         (gst_thread_release_children_locks), (gst_thread_change_state):
2834         * gst/schedulers/gstbasicscheduler.c:
2835         (gst_basic_scheduler_loopfunc_wrapper),
2836         (gst_basic_scheduler_chain_wrapper),
2837         (gst_basic_scheduler_src_wrapper),
2838         (gst_basic_scheduler_remove_element):
2839         * gst/schedulers/gstoptimalscheduler.c: (schedule_group):
2840         Remove threadsafe properties. Fix elements because GObject
2841         complains when installing a property before declaring a
2842         set/get_property handler.
2843         Rearrange gstelement.h file, use STATE macros for state locks.
2844         Free mutexes in the finalize method instead of dispose.
2845
2846 2005-03-08  Wim Taymans  <wim@fluendo.com>
2847
2848         * check/gst/gstobject.c: (START_TEST), (gst_object_suite):
2849         * gst/gstthread.c: (gst_thread_release_children_locks):
2850         Added parentage check.
2851         Fix build og GstThread again.
2852
2853 2005-03-08  Wim Taymans  <wim@fluendo.com>
2854
2855         * docs/design/part-MT-refcounting.txt:
2856         * docs/design/part-conventions.txt:
2857         * docs/design/part-gstobject.txt:
2858         * docs/design/part-relations.txt:
2859         * docs/design/part-standards.txt:
2860         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_add),
2861         (gst_bin_remove_func), (gst_bin_remove), (gst_bin_iterate_recurse),
2862         (gst_bin_get_by_name), (gst_bin_get_by_interface),
2863         (gst_bin_iterate_all_by_interface):
2864         * gst/gstbuffer.h:
2865         * gst/gstclock.h:
2866         * gst/gstelement.c: (gst_element_class_init),
2867         (gst_element_change_state), (gst_element_set_loop_function):
2868         * gst/gstelement.h:
2869         * gst/gstiterator.c:
2870         * gst/gstobject.c: (gst_object_class_init), (gst_object_ref),
2871         (gst_object_unref), (gst_object_sink), (gst_object_dispose),
2872         (gst_object_dispatch_properties_changed), (gst_object_set_name),
2873         (gst_object_set_parent), (gst_object_unparent),
2874         (gst_object_check_uniqueness):
2875         * gst/gstobject.h:
2876         Docs updates, clean up some headers.
2877
2878 2005-03-07  Wim Taymans  <wim@fluendo.com>
2879
2880         * check/.cvsignore:
2881         * check/Makefile.am:
2882         * check/gst-libs/.cvsignore:
2883         * check/gst-libs/gdp.c: (START_TEST), (gst_object_suite), (main):
2884         * check/gst/.cvsignore:
2885         * check/gst/gstbus.c: (pound_bus_with_messages), (pull_messages),
2886         (START_TEST), (gstbus_suite), (main):
2887         * check/gst/gstcaps.c: (START_TEST), (gst_caps_suite), (main):
2888         * check/gst/gstdata.c: (START_TEST), (thread_ref), (thread_unref),
2889         (gst_data_suite), (main):
2890         * check/gst/gstiterator.c: (make_list_of_ints), (START_TEST),
2891         (add_fold_func), (gstiterator_suite), (main):
2892         * check/gst/gstobject.c: (gst_fake_object_get_type), (START_TEST),
2893         (thread_name_object), (thread_name_object_default),
2894         (gst_object_name_compare), (gst_object_suite), (main):
2895         * check/gst/gstpad.c: (START_TEST), (thread_link_unlink),
2896         (gst_pad_suite), (main):
2897         * check/gstcheck.c: (gst_check_log_message_func),
2898         (gst_check_log_critical_func), (gst_check_init):
2899         * check/gstcheck.h:
2900         * check/pipelines/simple_launch_lines.c: (setup_pipeline),
2901         (run_pipeline), (START_TEST), (simple_launch_lines_suite), (main):
2902         Added checks.
2903
2904 2005-03-07  Wim Taymans  <wim@fluendo.com>
2905
2906         * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new),
2907         (gst_list_iterator_next), (gst_list_iterator_resync),
2908         (gst_list_iterator_free), (gst_iterator_new_list),
2909         (gst_iterator_pop), (gst_iterator_next), (gst_iterator_resync),
2910         (gst_iterator_free), (gst_iterator_push), (filter_next),
2911         (filter_resync), (filter_uninit), (filter_free),
2912         (gst_iterator_filter), (gst_iterator_fold), (foreach_fold_func),
2913         (gst_iterator_foreach), (find_custom_fold_func),
2914         (gst_iterator_find_custom):
2915         * gst/gstiterator.h:
2916         Added missing files.
2917
2918 2005-03-07  Wim Taymans  <wim@fluendo.com>
2919
2920         * Makefile.am:
2921         * configure.ac:
2922         * docs/design/part-MT-refcounting.txt:
2923         * docs/design/part-conventions.txt:
2924         * docs/design/part-gstobject.txt:
2925         * docs/design/part-relations.txt:
2926         * examples/mixer/mixer.c: (main):
2927         * examples/thread/thread.c: (eos), (main):
2928         * gst/Makefile.am:
2929         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_caps_intersect):
2930         * gst/autoplug/gstspider.c: (gst_spider_identity_plug),
2931         (gst_spider_plug_from_srcpad):
2932         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_getcaps),
2933         (gst_spider_identity_change_state),
2934         (gst_spider_identity_sink_loop_type_finding):
2935         * gst/elements/gstfakesrc.c: (gst_fakesrc_loop):
2936         * gst/elements/gstidentity.c: (gst_identity_init):
2937         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_getcaps),
2938         (gst_tee_link), (gst_tee_request_new_pad), (gst_tee_chain):
2939         * gst/elements/gsttypefindelement.c: (free_entry):
2940         * gst/gst.c:
2941         * gst/gst.h:
2942         * gst/gstbin.c: (gst_bin_init), (gst_bin_get_clock_func),
2943         (gst_bin_set_clock_func), (gst_bin_auto_clock),
2944         (gst_bin_set_index), (gst_bin_set_element_sched),
2945         (gst_bin_unset_element_sched), (gst_bin_add_func), (gst_bin_add),
2946         (gst_bin_remove_func), (gst_bin_remove), (iterate_child),
2947         (gst_bin_iterate_elements), (iterate_child_recurse),
2948         (gst_bin_iterate_recurse), (gst_bin_dispose), (compare_name),
2949         (gst_bin_get_by_name), (gst_bin_get_by_name_recurse_up),
2950         (compare_interface), (gst_bin_get_by_interface),
2951         (gst_bin_iterate_all_by_interface), (gst_bin_iterate_func):
2952         * gst/gstbin.h:
2953         * gst/gstbuffer.c: (gst_buffer_get_type), (_gst_buffer_sub_free),
2954         (gst_buffer_default_free), (gst_buffer_default_copy),
2955         (gst_buffer_new), (gst_buffer_get_caps), (gst_buffer_set_caps),
2956         (gst_buffer_create_sub):
2957         * gst/gstbuffer.h:
2958         * gst/gstcaps.c: (gst_caps_get_type), (gst_caps_new_empty),
2959         (_gst_caps_free), (gst_caps_make_writable), (gst_caps_ref),
2960         (gst_caps_unref), (gst_static_caps_get),
2961         (gst_caps_remove_and_get_structure), (gst_caps_append),
2962         (gst_caps_append_structure), (gst_caps_remove_structure),
2963         (gst_caps_copy_nth), (gst_caps_set_simple),
2964         (gst_caps_set_simple_valist), (gst_caps_is_fixed_foreach),
2965         (gst_structure_is_equal_foreach), (gst_caps_is_subset),
2966         (gst_caps_structure_intersect_field), (gst_caps_intersect),
2967         (gst_caps_structure_subtract_field), (gst_caps_subtract),
2968         (gst_caps_normalize_foreach), (gst_caps_compare_structures),
2969         (gst_caps_structure_figure_out_union),
2970         (gst_caps_switch_structures), (gst_caps_do_simplify),
2971         (gst_caps_replace), (gst_caps_from_string),
2972         (gst_caps_copy_conditional):
2973         * gst/gstcaps.h:
2974         * gst/gstclock.c: (gst_clock_entry_new), (gst_clock_id_ref),
2975         (_gst_clock_id_free), (gst_clock_id_unref),
2976         (gst_clock_id_compare_func), (gst_clock_id_wait),
2977         (gst_clock_id_wait_async), (gst_clock_class_init),
2978         (gst_clock_init), (gst_clock_dispose), (gst_clock_adjust_unlocked),
2979         (gst_clock_get_time), (gst_clock_set_time_adjust),
2980         (gst_clock_set_property), (gst_clock_get_property):
2981         * gst/gstclock.h:
2982         * gst/gstcompat.h:
2983         * gst/gstcpu.c: (_gst_cpu_initialize_i386), (gst_cpu_get_flags):
2984         * gst/gstdata.c: (gst_data_is_writable), (gst_data_copy_on_write):
2985         * gst/gstdata.h:
2986         * gst/gstelement.c: (gst_element_class_init), (gst_element_init),
2987         (gst_element_requires_clock), (gst_element_provides_clock),
2988         (gst_element_set_clock), (gst_element_clock_wait),
2989         (gst_element_wait), (gst_element_set_time_delay),
2990         (gst_element_is_indexable), (gst_element_add_pad),
2991         (gst_element_add_ghost_pad), (gst_element_remove_pad),
2992         (pad_compare_name), (gst_element_get_static_pad),
2993         (gst_element_request_pad), (gst_element_get_request_pad),
2994         (gst_element_get_pad), (iterate_pad), (gst_element_iterate_pads),
2995         (gst_element_class_get_pad_template_list),
2996         (gst_element_class_get_pad_template), (gst_element_error_func),
2997         (gst_element_get_random_pad), (gst_element_get_event_masks),
2998         (gst_element_send_event), (gst_element_seek),
2999         (gst_element_get_query_types), (gst_element_query),
3000         (gst_element_get_formats), (gst_element_convert),
3001         (gst_element_is_locked_state), (gst_element_set_locked_state),
3002         (gst_element_sync_state_with_parent), (gst_element_change_state),
3003         (gst_element_finalize), (gst_element_yield),
3004         (gst_element_interrupt), (gst_element_set_scheduler),
3005         (gst_element_get_scheduler), (gst_element_set_loop_function):
3006         * gst/gstelement.h:
3007         * gst/gstevent.h:
3008         * gst/gstformat.c: (_gst_format_initialize), (gst_format_register),
3009         (gst_format_get_by_nick), (gst_format_get_details),
3010         (gst_format_iterate_definitions):
3011         * gst/gstformat.h:
3012         * gst/gstindex.c: (gst_index_gtype_resolver):
3013         * gst/gstinfo.c:
3014         * gst/gstinfo.h:
3015         * gst/gstmemchunk.c: (gst_mem_chunk_alloc), (gst_mem_chunk_alloc0),
3016         (gst_mem_chunk_free):
3017         * gst/gstobject.c: (gst_object_class_init), (gst_object_init),
3018         (gst_object_ref), (gst_object_unref), (gst_object_sink),
3019         (gst_object_replace), (gst_object_dispose), (gst_object_finalize),
3020         (gst_object_dispatch_properties_changed),
3021         (gst_object_set_name_default), (gst_object_set_name),
3022         (gst_object_get_name), (gst_object_set_name_prefix),
3023         (gst_object_get_name_prefix), (gst_object_set_parent),
3024         (gst_object_get_parent), (gst_object_unparent),
3025         (gst_object_check_uniqueness), (gst_object_save_thyself),
3026         (gst_object_restore_thyself), (gst_object_real_restore_thyself),
3027         (gst_object_set_property), (gst_object_get_property),
3028         (gst_object_get_path_string):
3029         * gst/gstobject.h:
3030         * gst/gstpad.c: (gst_pad_dispose), (gst_real_pad_class_init),
3031         (gst_real_pad_init), (gst_real_pad_get_property),
3032         (gst_pad_custom_new), (gst_pad_get_direction),
3033         (gst_pad_set_active), (gst_pad_is_active),
3034         (gst_pad_set_event_function), (gst_pad_is_linked),
3035         (gst_pad_link_free), (gst_pad_link_intersect),
3036         (gst_pad_link_fixate), (gst_pad_set_caps),
3037         (gst_pad_try_set_caps_nonfixed), (gst_pad_set_pad_template),
3038         (gst_pad_get_real_parent), (gst_pad_add_ghost_pad),
3039         (gst_pad_remove_ghost_pad), (_gst_pad_default_fixate_foreach),
3040         (gst_pad_link_unnegotiate), (gst_pad_proxy_fixate),
3041         (gst_pad_get_caps), (gst_pad_peer_get_caps),
3042         (gst_pad_get_pad_template_caps), (gst_pad_get_peer),
3043         (gst_pad_realize), (gst_pad_get_allowed_caps),
3044         (gst_real_pad_dispose), (gst_real_pad_finalize),
3045         (gst_pad_collectv), (gst_pad_collect_valist),
3046         (gst_pad_template_dispose), (gst_pad_template_new),
3047         (gst_pad_get_internal_links):
3048         * gst/gstpad.h:
3049         * gst/gstpipeline.c: (gst_pipeline_dispose),
3050         (gst_pipeline_change_state):
3051         * gst/gstpipeline.h:
3052         * gst/gstplugin.c:
3053         * gst/gstpluginfeature.c: (gst_plugin_feature_get_name),
3054         (gst_plugin_feature_set_rank), (gst_plugin_feature_get_rank):
3055         * gst/gstpluginfeature.h:
3056         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
3057         * gst/gstquery.c: (_gst_query_type_initialize),
3058         (gst_query_type_register), (gst_query_type_get_by_nick),
3059         (gst_query_type_get_details), (gst_query_type_iterate_definitions):
3060         * gst/gstquery.h:
3061         * gst/gstqueue.c: (gst_queue_link_sink), (gst_queue_link_src):
3062         * gst/gstscheduler.c: (gst_scheduler_add_element),
3063         (gst_scheduler_factory_create):
3064         * gst/gststructure.c: (gst_structure_set_parent_refcount),
3065         (gst_structure_free), (gst_structure_set_name),
3066         (gst_structure_id_set_value), (gst_structure_set_value),
3067         (gst_structure_set_valist), (gst_structure_remove_field),
3068         (gst_structure_remove_fields),
3069         (gst_structure_remove_fields_valist),
3070         (gst_structure_remove_all_fields), (gst_structure_foreach),
3071         (gst_structure_map_in_place),
3072         (gst_caps_structure_fixate_field_nearest_int),
3073         (gst_caps_structure_fixate_field_nearest_double):
3074         * gst/gststructure.h:
3075         * gst/gstsystemclock.c: (gst_system_clock_class_init),
3076         (gst_system_clock_init), (gst_system_clock_dispose),
3077         (gst_system_clock_async_thread),
3078         (gst_system_clock_id_wait_unlocked), (gst_system_clock_id_wait),
3079         (gst_system_clock_id_wait_async), (gst_system_clock_id_unschedule):
3080         * gst/gstsystemclock.h:
3081         * gst/gsttag.c: (gst_tag_list_add_value_internal),
3082         (gst_tag_list_copy_foreach), (structure_foreach_wrapper):
3083         * gst/gsttaginterface.c:
3084         * gst/gstthread.c: (gst_thread_dispose),
3085         (gst_thread_release_children_locks), (gst_thread_change_state),
3086         (gst_thread_main_loop):
3087         * gst/gsttrashstack.h:
3088         * gst/gsttypefind.c: (gst_type_find_factory_dispose):
3089         * gst/gsttypes.h:
3090         * gst/gstutils.c: (gst_element_get_compatible_pad_template),
3091         (gst_element_request_pad), (gst_element_get_pad_from_template),
3092         (gst_element_request_compatible_pad),
3093         (gst_element_get_compatible_pad_filtered),
3094         (gst_element_get_compatible_pad), (gst_element_state_get_name),
3095         (gst_element_link_pads_filtered), (gst_element_link_filtered),
3096         (gst_element_link_many), (gst_element_link),
3097         (gst_element_link_pads), (gst_element_unlink_pads),
3098         (gst_element_unlink_many), (gst_element_unlink),
3099         (gst_pad_can_link_filtered), (gst_pad_can_link),
3100         (gst_pad_use_fixed_caps), (gst_pad_get_fixed_caps_func),
3101         (gst_object_default_error), (gst_bin_add_many),
3102         (gst_bin_remove_many), (gst_element_populate_std_props),
3103         (gst_element_class_install_std_props), (gst_buffer_merge),
3104         (gst_buffer_stamp), (intersect_caps_func), (gst_pad_proxy_getcaps),
3105         (link_fold_func), (gst_pad_proxy_setcaps):
3106         * gst/gstutils.h:
3107         * gst/gstvalue.c: (gst_value_deserialize_string):
3108         * gst/parse/grammar.y:
3109         * gst/schedulers/gstbasicscheduler.c:
3110         (gst_basic_scheduler_cothreaded_chain),
3111         (gst_basic_scheduler_chain_recursive_add),
3112         (gst_basic_scheduler_pad_link):
3113         * gst/schedulers/gstoptimalscheduler.c:
3114         (get_group_schedule_function),
3115         (gst_opt_scheduler_state_transition),
3116         (gst_opt_scheduler_add_element), (element_get_reachables_func):
3117         * libs/gst/bytestream/bytestream.c:
3118         * libs/gst/dataprotocol/dataprotocol.c:
3119         (gst_dp_header_from_buffer):
3120         * po/nb.po:
3121         * po/ru.po:
3122         * tests/threadstate/threadstate2.c: (eos):
3123         * tools/gst-compprep.c: (main):
3124         * tools/gst-inspect.c: (print_field), (print_element_flag_info),
3125         (print_pad_info), (print_children_info):
3126         * tools/gst-launch.c: (idle_func), (main):
3127         * tools/gst-md5sum.c: (idle_func), (main):
3128         * tools/gst-xmlinspect.c: (print_element_info):
3129         First THREADED backport attempt, focusing on adding locks and
3130         making sure the API is threadsafe. Needs more work. More docs
3131         follow this week.
3132
3133 2005-02-24  Andy Wingo  <wingo@pobox.com>
3134
3135         * tests/bench-complexity.scm:
3136         * tests/complexity.gnuplot: New files, good for running complexity
3137         benchmarks.
3138
3139         * tests/Makefile.am:
3140         * tests/complexity.c: New test, sets up N elements, at each level
3141         teeing into M streams per element. Eeeenteresting.
3142
3143         * tests/mass_elements.gnuplot: gnuplot file for the mass_elements
3144         benchmark. Run as gnuplot mass_elements.gnuplot > foo.ps, after
3145         running bench-mass_elements.scm.
3146
3147         * tests/bench-mass_elements.scm: New script, runs mass_elements
3148         for various numbers of identities, outputting the results to a
3149         file. Requires guile 1.6. Just for testing.
3150
3151 2005-02-23  Thomas Vander Stichele  <thomas at apestaart dot org>
3152
3153         * gst/schedulers/fairscheduler.c:
3154           compile with debug disabled
3155
3156 2005-02-22  Thomas Vander Stichele  <thomas at apestaart dot org>
3157
3158         * configure.ac:
3159           hunting season on 0.9 is now OPEN
3160
3161 2005-02-22  Stefan Kost  <ensonic@users.sf.net>
3162
3163         * docs/libs/tmpl/gstcontrol.sgml:
3164         * docs/libs/tmpl/gstdparam.sgml:
3165         * docs/libs/tmpl/gstdplinint.sgml:
3166         * docs/libs/tmpl/gstdpman.sgml:
3167         * docs/libs/tmpl/gstdpsmooth.sgml:
3168         * docs/libs/tmpl/gstunitconvert.sgml:
3169           more docs for the state of dparams
3170
3171 2005-02-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
3172
3173         * gst/gstelementfactory.c: (gst_element_factory_create):
3174         * gst/gstobject.c: (gst_object_init),
3175         (gst_object_set_name_default), (gst_object_set_name):
3176           name objects by default, not in gst_element_factory_create. Allows
3177           using elements created with g_object_new. (fixes #167283)
3178
3179 2005-02-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
3180
3181         * gst/gstinfo.c: (_gst_debug_init), (gst_debug_log_default):
3182           make the time that debugging functions print relative to when
3183           gst_init was called
3184
3185 2005-02-18  Tim-Philipp Müller  <tim at centricular dot net>
3186
3187         * gst/gsttaginterface.c:
3188           Fix inline docs: tag setter vararg functions are NULL-terminated,
3189           GST_TAG_INVALID doesn't exist any more.
3190
3191 2005-02-18  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
3192
3193         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_dump_byte_array):
3194         Allocate the 1 byte more memory that was forgotten!!!!!
3195         fixes memory corruption on 64bit platforms
3196
3197 2005-02-15  Stefan Kost  <ensonic@users.sf.net>
3198
3199         * docs/pwg/building-pads.xml:
3200         * docs/pwg/intro-basics.xml:
3201           fixed a few typos, relabeled introductionary list of types
3202         * docs/random/ensonic/dparams.txt:
3203           more notes abut dparam changes
3204         * libs/gst/control/dparam.c: (gst_dparam_attach):
3205         * libs/gst/control/dparammanager.c:
3206         * libs/gst/control/dparammanager.h:
3207           - many comments and notes on dparam implementation
3208           - new dparams are were not initialized to the default value
3209             from param spec
3210
3211 2005-02-14  Thomas Vander Stichele  <thomas at apestaart dot org>
3212
3213         submitted by: Peter Astakhov
3214
3215         * po/LINGUAS:
3216         * po/ru.po:
3217           adding Russian translation
3218
3219 2005-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
3220
3221         * configure.ac:
3222         * docs/gst/Makefile.am:
3223         * docs/libs/Makefile.am:
3224           make sure popt is added to gtk-doc flags.  Fixes #147782.
3225
3226 2005-02-09  Tim-Philipp Müller  <tim at centricular dot net>
3227
3228         * docs/faq/using.xml:
3229           Fix typo in FAQ (artssink => artsdsink)
3230
3231 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3232
3233         * tools/gst-launch.1.in:
3234           Fix typo (#166699).
3235
3236 2005-02-08  Tim-Philipp Müller  <tim at centricular dot net>
3237
3238         * docs/faq/using.xml:
3239           Add -v argument to fakesrc/fakesink gst-launch line,
3240           so that the promised output will actually show up.
3241
3242 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3243
3244         * gst/gstthread.c: (gst_thread_change_state):
3245           Implement state-change error handling (#166073).
3246
3247 2005-02-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3248
3249         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
3250           Release interrupt after handling (#166250).
3251
3252 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
3253
3254         * configure.ac:
3255           back to HEAD
3256
3257 === release 0.8.9 ===
3258
3259 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
3260
3261         * NEWS:
3262         * RELEASE:
3263         * configure.ac:
3264           releasing 0.8.9, "Like Eating Glass"
3265
3266 2005-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
3267
3268         submitted by: Clytie Siddall
3269
3270         * po/vi.po: Added Vietnamese translation
3271
3272 2005-02-07  Thomas Vander Stichele  <thomas at apestaart dot org>
3273
3274         patch by: Tim Philipp-Müller
3275
3276         * configure.ac:
3277         * gst/gstpad.c:
3278           unref data when probe function returns FALSE.  Fixes #166362
3279
3280 2005-02-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3281
3282         * gst/gst.c: (gst_init_get_popt_table):
3283           Fix typo (#166269).
3284
3285 2005-02-04  Andy Wingo  <wingo@pobox.com>
3286
3287         * gst/gstelement.c (gst_element_get_compatible_pad_template): Fix
3288         the debugging on whether the caps are compatible.
3289
3290 2005-02-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3291
3292         * docs/manual/basics-elements.xml:
3293           Fix two typos.
3294
3295 2005-02-02  Wim Taymans  <wim@fluendo.com>
3296
3297         * gst/schedulers/gstoptimalscheduler.c: (remove_decoupled),
3298         (schedule_chain), (get_invalid_call), (chain_invalid_call),
3299         (loop_group_schedule_function), (gst_opt_scheduler_iterate):
3300         Remove some FIXMEs after analysing and commenting why they
3301         are not issues.
3302
3303 2005-02-02  Wim Taymans  <wim@fluendo.com>
3304
3305         * gst/schedulers/gstoptimalscheduler.c:
3306         (gst_opt_scheduler_class_init), (gst_opt_scheduler_init),
3307         (gst_opt_scheduler_finalize), (remove_decoupled), (schedule_chain),
3308         (get_invalid_call), (chain_invalid_call),
3309         (get_group_schedule_function), (loop_group_schedule_function),
3310         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
3311         (gst_opt_scheduler_state_transition),
3312         (gst_opt_scheduler_add_element),
3313         (gst_opt_scheduler_remove_element), (gst_opt_scheduler_interrupt),
3314         (gst_opt_scheduler_error), (gst_opt_scheduler_pad_link),
3315         (gst_opt_scheduler_pad_unlink), (gst_opt_scheduler_iterate),
3316         (gst_opt_scheduler_show):
3317         Added lock to protect scheduler data structures.
3318
3319 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3320
3321         * testsuite/threads/threadi.c: (cb_data):
3322           Fix buglet in test.
3323
3324 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3325
3326         * testsuite/threads/Makefile.am:
3327         * testsuite/threads/threadi.c: (cb_data), (cb_play), (main):
3328           On Wim's request, split the test in three separately-compiled
3329           tests that each test a very specific bug. Two of them still fail,
3330           will create bugs for those. threadi.c indicates why they fail.
3331
3332 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3333
3334         * gst/schedulers/gstoptimalscheduler.c:
3335         (get_group_schedule_function):
3336           Try to work with the threading mess that queue_link is.
3337
3338 2005-02-01  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3339
3340         * gst/gstbin.c: (gst_bin_remove_func):
3341           Explicitely make an element release locks in a group when being
3342           remove from a bin.
3343         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
3344           If there's no scheduler, always return immediately (similar to
3345           gst_element_interrupt).
3346
3347 2005-01-31  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3348
3349         * gst/gstbin.c: (gst_bin_child_state_change_func):
3350           Remove a piece of code that could never be reached.
3351         * docs/gst/gstreamer-sections.txt:
3352         * gst/gstpad.c: (gst_pad_push), (gst_pad_pull),
3353         (gst_pad_call_get_function):
3354         * gst/gstpad.h:
3355         * testsuite/pad/Makefile.am:
3356           Fix #150546, enable tests.
3357
3358 2005-01-31  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3359
3360         * docs/pwg/advanced-types.xml:
3361           Fix description for buffer-frames=0.
3362         * docs/gst/tmpl/gstbin.sgml:
3363         * gst/gstbin.c: (gst_bin_child_state_change_func),
3364         (gst_bin_change_state), (gst_bin_change_state_norecurse):
3365         * gst/gstbin.h:
3366         * testsuite/threads/Makefile.am:
3367         * testsuite/threads/threadi.c: (cb_timeout), (cb_quit), (cb_eos),
3368         (cb_state), (cb_play), (main):
3369           Fix non-recursive state changes to *really* change the state
3370           of the object, and not just call parent_class->state_change.
3371           Fix a lot of lockups caused by this. Fixes #132775. Add test
3372           for the problem. Also enable test to show #142588 (fixed).
3373         * gst/gstthread.c: (gst_thread_change_state),
3374         (gst_thread_child_state_change):
3375           Don't exit the thread if we go to NULL and are inside thread
3376           context. Instead, return control to the main thread context
3377           and exit from there.
3378         * gst/gstelement.c: (gst_element_disable_threadsafe_properties):
3379           Don't unset virtual functions, since those may still be used.
3380           That's not necessarily correct, but suffices for now.
3381         * configure.ac:
3382         * testsuite/Makefile.am:
3383         * testsuite/pad/Makefile.am:
3384         * testsuite/pad/chainnopull.c: (gst_test_sink_class_init),
3385         (gst_test_sink_base_init), (gst_test_sink_chain),
3386         (gst_test_sink_init), (main):
3387         * testsuite/pad/getnopush.c: (gst_test_src_class_init),
3388         (gst_test_src_base_init), (gst_test_src_get), (gst_test_src_init),
3389         (main):
3390         * testsuite/pad/link.c: (gst_test_element_class_init),
3391         (gst_test_element_base_init), (gst_test_src_get),
3392         (gst_test_src_loop), (gst_test_src_init), (gst_test_filter_chain),
3393         (gst_test_filter_loop), (gst_test_filter_init),
3394         (gst_test_sink_chain), (gst_test_sink_loop), (gst_test_sink_init),
3395         (cb_error), (main):
3396           Add tests to show #150546. Pass, but should fail (currently
3397           disabled from the testsuite).
3398         * gst/gstscheduler.c: (gst_scheduler_dispose):
3399           Dereference child schedulers on dispose (#94464).
3400         * testsuite/bytestream/filepadsink.c: (gst_fp_sink_init):
3401           Fix typo.
3402         * testsuite/threads/thread.c: (main):
3403           Add more debug.
3404
3405 2005-01-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3406
3407         * gst/gstpad.c: (gst_pad_push):
3408           Oops, revert previous commit, broke testsuite...
3409
3410 2005-01-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3411
3412         * gst/gstpad.c: (gst_pad_push):
3413           Add check that the pad on which the push is performed is not a
3414           get-based pad (#150546).
3415
3416 2005-01-28  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3417
3418         * gst/elements/gsttypefindelement.c:
3419         (gst_type_find_element_handle_event):
3420           Fix buffer pushing if stream EOSes during typefinding.
3421
3422 2005-01-28  Edward Hervey  <bilboed@bilboed.com>
3423
3424         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3425
3426         * gst/gstvalue.c: (gst_string_wrap):
3427           Allow NULL-strings as argument (#165365).
3428
3429 2005-01-27  Stephane Wirtel  <stephane.wirtel@belgacom.net>
3430
3431         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3432
3433         * gst/schedulers/faircothreads.c:
3434         (gst_fair_scheduler_cothread_queue_show):
3435           Fix build without debug enabled.
3436
3437 2005-01-26  Stefan Kost  <ensonic@users.sf.net>
3438
3439         * docs/gst/gstreamer-sections.txt:
3440         * docs/libs/gstreamer-libs-docs.sgml:
3441         * docs/libs/gstreamer-libs-sections.txt:
3442         * docs/libs/tmpl/gstcontrol.sgml:
3443         * docs/libs/tmpl/gstdparam.sgml:
3444         * docs/libs/tmpl/gstdplinint.sgml:
3445         * docs/libs/tmpl/gstdpman.sgml:
3446         * docs/libs/tmpl/gstdpsmooth.sgml:
3447         * docs/libs/tmpl/gstputbits.sgml:
3448         * docs/libs/tmpl/gstunitconvert.sgml:
3449         * libs/gst/control/dparam.c:
3450         * libs/gst/control/dparam.h:
3451         * libs/gst/control/dparammanager.c:
3452         (gst_dpman_add_required_dparam_callback),
3453         (gst_dpman_add_required_dparam_direct),
3454         (gst_dpman_add_required_dparam_array),
3455         (gst_dpman_remove_required_dparam), (gst_dpman_attach_dparam),
3456         (gst_dpman_get_dparam), (gst_dpman_get_dparam_type),
3457         (gst_dpman_get_manager)
3458           restructured DParam docs
3459
3460 2005-01-25  Tim-Philipp Müller  <tim at centricular dot net>
3461
3462         * gst-element-check.m4:
3463           Only check for gst-inspect if we haven't already
3464           found it in previous element check runs
3465
3466 2005-01-25  Stefan Kost  <ensonic@users.sf.net>
3467
3468         * docs/gst/Makefile.am:
3469         * docs/libs/Makefile.am:
3470           fixed install rules to treat style.css as optional
3471
3472 2005-01-24  Stefan Kost  <ensonic@users.sf.net>
3473
3474         * docs/gst/Makefile.am:
3475         * docs/libs/Makefile.am:
3476           install style.css along with docs
3477         * docs/gst/tmpl/gstbin.sgml:
3478         * docs/gst/tmpl/gstclock.sgml:
3479         * docs/gst/tmpl/gstdata.sgml:
3480         * docs/gst/tmpl/gstelement.sgml:
3481         * gst/gstbin.h:
3482         * gst/gstelement.c: (gst_element_class_init):
3483         * gst/gstelement.h:
3484           fixing incomplete docs
3485
3486 2005-01-24  Tim-Philipp Müller  <tim at centricular dot net>
3487
3488         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
3489           Don't unref seek event twice when fflush() fails
3490           
3491 2005-01-22  David Schleef  <ds@schleef.org>
3492
3493         * configure.ac: Add --disable-valgrind. (partial fix for #164890)
3494
3495 2005-01-21  Stefan Kost  <ensonic@users.sf.net>
3496
3497         * docs/gst/Makefile.am:
3498         * docs/libs/Makefile.am:
3499           added params for deprecation guards
3500         * gst/gst.c:
3501         * gst/gst.h:
3502         * gst/gsterror.c: (_gst_resource_errors_init),
3503         (_gst_stream_errors_init):
3504         * gst/gsterror.h:
3505           documented some more enums
3506
3507 2005-01-19  Jan Schmidt  <thaytan@mad.scientist.com>
3508         * gst/autoplug/gstspideridentity.c:
3509         Cosmetic fix - spider_find_peek should be static
3510         * gst/parse/parse.l:
3511         Applying fix for #164261
3512
3513 2005-01-18  Stefan Kost  <ensonic@users.sf.net>
3514
3515         * docs/gst/gstreamer-sections.txt:
3516         * docs/gst/tmpl/gstplugin.sgml:
3517         * docs/libs/gstreamer-libs-sections.txt:
3518         * docs/libs/tmpl/gstcontrol.sgml:
3519         * gst/gstbuffer.h:
3520         * gst/gsttag.h:
3521         * gst/gstvalue.c:
3522           added docs for the TAG defines
3523
3524 2005-01-18  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3525
3526         * gst/schedulers/gstoptimalscheduler.c: (schedule_group):
3527           Only unref entry if there is an entry.
3528
3529 2005-01-17  Wim Taymans  <wim@fluendo.com>
3530
3531         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
3532         (remove_from_group), (schedule_group), (normalize_group),
3533         (gst_opt_scheduler_iterate):
3534         Also ref/unref decoupled elements before iterating the
3535         group since they are not added to the list of elements.
3536
3537 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3538
3539         * docs/manual/highlevel-components.xml:
3540           Add subtitle/streamselection as new features to playbin.
3541
3542 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3543
3544         * docs/manual/manual.xml:
3545           Re-enable dataaccess docs (oops).
3546
3547 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3548
3549         * docs/pwg/advanced-types.xml:
3550         * docs/random/mimetypes:
3551           Add documentation on libsndfile types (#163309), by Steve Baker
3552           <steve@stevebaker.org>.
3553         * gst/gstelement.c: (gst_element_release_request_pad):
3554           If an element has no explicit function, just remove the pad.
3555
3556 2005-01-17  Luca Ognibene  <luogni@tin.it>
3557
3558         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3559
3560         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load):
3561           Fix memleak (#163801).
3562
3563 2005-01-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3564
3565         * gst/elements/gsttee.c: (gst_tee_getcaps), (gst_tee_link):
3566           I think this is actually more correct...
3567
3568 2005-01-16  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3569
3570         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
3571           Another workaround for memory access while destroyed in callback.
3572           Please, someone with refcount knowledge, have a look at this.
3573
3574 2005-01-15  Thomas Vander Stichele  <thomas at apestaart dot org>
3575
3576         * docs/faq/faq.xml:
3577         * docs/faq/legal.xml:
3578           move the legal Q&A here
3579
3580 2005-01-14  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3581
3582         * gst/elements/gsttee.c: (gst_tee_getcaps), (gst_tee_link),
3583         (gst_tee_request_new_pad):
3584           Fix negotiation.
3585
3586 2005-01-14  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
3587
3588         * docs/random/omega/caps2:
3589         * testsuite/caps/caps_strings:
3590           replace framerate aproximations by their real value
3591           (24000/1001, 30000/1001, 60000/1001)
3592           Partially fixes bug #164049
3593
3594 2005-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
3595
3596         * docs/gst/Makefile.am:
3597           don't fail on the stupid GstPoptOption
3598
3599 2005-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
3600
3601         * gst/gstpad.h:
3602         * gst/gstprobe.c:
3603           allow probes to work on ghost pads by realizing the pad
3604           probe debugging
3605
3606 2005-01-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3607
3608         * docs/gst/gstreamer-sections.txt:
3609         * docs/gst/tmpl/gstpad.sgml:
3610         * gst/gstpad.c: (gst_pad_set_active_recursive):
3611         * gst/gstpad.h:
3612           Add gst_pad_set_active_recursive().
3613
3614 2005-01-10  Thomas Vander Stichele  <thomas at apestaart dot org>
3615
3616         * docs/random/release:
3617           updates
3618         * gst/gst_private.h:
3619         * gst/gstinfo.c:
3620         * gst/gstobject.c:
3621           move deep_notify logging to a new category
3622         * gst/gstprobe.c:
3623         * gst/gstprobe.h:
3624           add stuff so bindings can wrap probes
3625
3626 2005-01-09  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
3627
3628         * gst/gstplugin.c: (gst_plugin_load):
3629           Fix plugin loading if plugin/lib was already loaded. Fixes
3630           #163383
3631
3632 2005-01-09  Sebastien Cote  <sc5@hermes.usherb.ca>
3633
3634         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3635
3636         * gst/gstpluginfeature.c: (gst_plugin_feature_ensure_loaded):
3637           Protect plugin loading by a mutex so it's threadsafe. Fixes
3638           #163234.
3639
3640 2005-01-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3641
3642         * gst/gstevent.c: (_gst_event_copy):
3643           Reference source object when copying events, since it'll be
3644           dereferenced on event dereferencing as well.
3645
3646 2005-01-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3647
3648         * docs/gst/gstreamer-sections.txt:
3649         * docs/gst/tmpl/gstevent.sgml:
3650         * gst/gstevent.c: (gst_event_new_filler_stamped),
3651         (gst_event_filler_get_duration):
3652         * gst/gstevent.h:
3653           Add two new functions for filler events (which are used to
3654           synchronize streams if one of them is not having any data
3655           for a while) without interrupting the actual data-stream.
3656           Basically a no-op.
3657         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
3658         (gst_queue_link_sink), (gst_queue_link_src),
3659         (gst_queue_change_state):
3660           Allow for renegotiation while filled. Required for stream
3661           switching while playing.
3662
3663 2005-01-08  Benjamin Otte  <otte@gnome.org>
3664
3665         * gst/gstelement.c: (gst_element_link_many):
3666           fix up g_return_if_fail's
3667         * po/LINGUAS:
3668         * po/de.po:
3669           add German translation, that was somehow not included
3670
3671 2005-01-08  Stephane LOEUILLET  <stephane.loeuillet@tiscali.fr>
3672
3673         * docs/random/mimetypes:
3674           add 2 more 4CC code for DV (HDTV and SDTV-LongPlay profiles)
3675           do not add them to riff-lib as they are not common
3676
3677 2005-01-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3678
3679         * gst/gstprobe.c: (gst_probe_dispatcher_dispatch):
3680           Check for existence of probe after performing the probe before
3681           re-accessing it to prevent segfaults caused by removal of the
3682           probe in the callback.
3683
3684 2005-01-05  David Schleef  <ds@schleef.org>
3685
3686         * testsuite/registry/Makefile.am:
3687         * testsuite/registry/gst-print-formats.c:
3688         (print_pad_templates_info), (print_element_list),
3689         (print_typefind_list), (list_sort_func), (get_typefind_mime_list),
3690         (g_list_uniqify), (get_pad_templates_info),
3691         (get_element_mime_list), (print_mime_list), (main): A little
3692         program that looks through the registry to find elements of
3693         a given type.  Not particularly interesting as a test, except
3694         that there's no other test covering the same area.
3695
3696 2005-01-05  David Schleef  <ds@schleef.org>
3697
3698         * tools/gst-launch.c: (idle_func), (fault_handler_sighandler),
3699         (fault_handler_sigaction), (fault_spin),
3700         (sigint_handler_sighandler), (play_handler), (main): Fix deadlocks
3701         in signal.h-type signal handlers by not calling forbidden functions,
3702         including gst_element_set_state().
3703
3704 2005-01-05  David Schleef  <ds@schleef.org>
3705
3706         * gst/gstvalue.h: Mark _gst_reserved[] as private
3707
3708 2005-01-05  David Schleef  <ds@schleef.org>
3709
3710         * gst/gstvalue.c: Fix doc build problem.
3711
3712 2005-01-05  David Schleef  <ds@schleef.org>
3713
3714         * gst/gstvalue.c: Add some documentation
3715
3716 2005-01-05  Stefan Kost  <ensonic@users.sf.net>
3717
3718         * docs/README:
3719           another shell oneliner for empty return value docs
3720         * gst/gstcaps.c:
3721         * gst/gstvalue.c:
3722         * libs/gst/control/dparam.c:
3723           more doc fixes (parameters and return values)
3724
3725 2005-01-05  Vincent Torri  <torri@iecn.u-nancy.fr>
3726
3727         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3728
3729         * gst/gstregistry.h:
3730         * gst/registries/gstxmlregistry.c:
3731           Fix macro's for Mingw (fixes #162276).
3732
3733 2005-01-04  Stefan Kost  <ensonic@users.sf.net>
3734
3735         * docs/README:
3736           quick shell oneliner to find undocumented members
3737         * docs/gst/tmpl/gstplugin.sgml:
3738         * docs/gst/tmpl/gstscheduler.sgml:
3739         * docs/gst/tmpl/gstthread.sgml:
3740           more enumtypes cleanup
3741         * gst/gsterror.h:
3742           activated documentation comments, now someone needs to document
3743           the enums :(
3744
3745 2005-01-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3746
3747         * docs/manual/manual.xml:
3748           Add dataaccess part (doh!).
3749
3750 2005-01-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3751
3752         * docs/manual/advanced-autoplugging.xml:
3753           Fix typo (intiate -> initiate).
3754
3755 2005-01-02  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3756
3757         * docs/random/bbb/streamselection:
3758           Add some notes on how to handle multi-subtitle/-audio streams.
3759
3760 2004-12-30  Stefan Kost  <ensonic@users.sf.net>
3761
3762         * docs/gst/gstreamer-docs.sgml:
3763         * docs/gst/gstreamer-sections.txt:
3764         * docs/gst/tmpl/gstenumtypes.sgml:
3765         * docs/gst/tmpl/gsterror.sgml:
3766         * docs/gst/tmpl/gstevent.sgml:
3767         * docs/gst/tmpl/gstpad.sgml:
3768         * docs/gst/tmpl/gstpadtemplate.sgml:
3769         * docs/gst/tmpl/gstthread.sgml:
3770           removed gstenumtypes section from docs and put all the enums into
3771           their sections
3772
3773 2004-12-27  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
3774
3775         * gst/gstplugin.c:
3776           document gst_library_load a bit more (riff special case + return
3777           value if already loaded)
3778         * testsuite/bytestream/filepadsink.c:
3779           plugin name is 'gstbytestream', not 'bytestream'
3780
3781 2004-12-25  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3782
3783         * docs/random/bbb/subtitles:
3784           Add some first mind rumblings on proper subtitle support.
3785
3786 2004-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
3787
3788         * po/ca.po:
3789         * po/sv.po:
3790           updated translations
3791
3792 2004-12-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3793
3794         * docs/manual/advanced-dataaccess.xml:
3795           Add section on how to use fakesrc/fakesink/identity in your
3796           application, plus section on how to embed plugins. Also mention
3797           probes.
3798         * docs/manual/appendix-checklist.xml:
3799         * docs/manual/appendix-debugging.xml:
3800         * docs/manual/appendix-gnome.xml:
3801         * docs/manual/appendix-integration.xml:
3802           Debug -> checklist, GNOME -> integration, add sections on Linux,
3803           KDE integration and add other things useful for application
3804           development.
3805         * docs/manual/manual.xml:
3806           Remove some fixmes, update some file pointers.
3807         * docs/pwg/appendix-checklist.xml:
3808           Fix typo.
3809         * docs/pwg/building-boiler.xml:
3810           Remove ugly header and add commented fixme.
3811         * docs/pwg/pwg.xml:
3812           Add fixme.
3813         * examples/manual/Makefile.am:
3814           Add example for added docs.
3815
3816 2004-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
3817
3818         * configure.ac:
3819           back to HEAD
3820
3821 === release 0.8.8 ===
3822
3823 2004-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
3824
3825         * NEWS:
3826         * RELEASE:
3827         * configure.ac:
3828           Releasing 0.8.8, "I'll Take Care Of You"
3829
3830 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
3831
3832         * configure.ac:
3833           second prerelease
3834
3835 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
3836
3837         patch by: Wim Taymans
3838
3839         * gst/gstbin.c:
3840           Fix for #159852 - make iterate emission threadsafe
3841
3842 2004-12-21  Thomas Vander Stichele  <thomas at apestaart dot org>
3843
3844         * docs/faq/cvs.xml:
3845           notes about new fdo account request
3846
3847 2004-12-20  Stefan Kost  <ensonic@users.sf.net>
3848
3849         * docs/gst/gstreamer-docs.sgml:
3850         * docs/gst/tmpl/gstenumtypes.sgml:
3851         * docs/gst/tmpl/gstplugin.sgml:
3852         * docs/libs/gstreamer-libs-docs.sgml:
3853           Added missing short docs. Added ids for navigation.
3854
3855 2004-12-19  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3856
3857         * docs/manual/advanced-autoplugging.xml:
3858         * docs/manual/advanced-schedulers.xml:
3859         * docs/manual/advanced-threads.xml:
3860           Rewrites. Remove cothreads, go a bit into opt specifically,
3861           document threads and their gotchas, and do some technical stuff
3862           on autoplugging plus add some working examples. Fixes #157395.
3863         * examples/manual/Makefile.am:
3864           Add typefind/autoplugger example (one that actually works).
3865           Remove queue example since it's a duplicate of the thread one.
3866
3867 2004-12-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
3868
3869         * gst/gstvalue.c: (gst_value_deserialize_string):
3870           use deprecated g_value_set_string_take_ownership to keep compatible
3871           with glib 2.2
3872
3873 2004-12-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
3874
3875         * gst/gstvalue.c: (gst_value_deserialize_string):
3876           revert last patch, only dom a g_utf8_validate now before accepting
3877           the string - caps parsing strips " from strings so we can't rely on
3878           them
3879         * testsuite/caps/value_serialize.c: (test_string_deserialization):
3880           disable a test that tested the above and comment it
3881
3882 2004-12-16  Steve Lhomme <steve.lhomme@free.fr>
3883
3884         Patch reviewed by David Schleef  <ds@schleef.org>
3885
3886         * win32/gstenumtypes.c: Update from gst/gstenumtypes.c (See
3887         bug #153882)
3888         * win32/gstenumtypes.h: same
3889
3890 2004-12-17  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3891
3892         * gst/gstpad.c: (gst_pad_query):
3893           Do query on realized pad, similar to how convert/send_event handle
3894           this. Also makes sense, since this pad belongs to the function to
3895           which this query will be sent. Fixes #158163.
3896
3897 2004-12-16  Christian Fredrik Kalager Schaller  <uraeus@gnome.org>
3898
3899         * docs/manual/appendix-programs.xml: fix pipeline to actually work
3900
3901 2004-12-16  Christian Fredrik Kalager Schaller  <christian@fluendo.com>
3902
3903         * docs/faq/general.xml: fix pipeline to actually work
3904
3905 2004-12-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
3906
3907         * gst/gstvalue.c: (gst_value_deserialize_string):
3908           check that a simple string that gets deserialized does not contain
3909           invalid characters
3910         * testsuite/caps/value_serialize.c: (test_string_deserialization):
3911           remove a test that tested a wring behaviour
3912
3913 2004-12-16  Matt Kraai  <kraai@alumni.cmu.edu>
3914
3915         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3916
3917         * docs/manual/intro-motivation.xml:
3918           Fix typos.
3919
3920 2004-12-16  Edward Hervey  <bilboed@bilboed.com>
3921
3922         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3923
3924         * docs/gst/tmpl/gstprobe.sgml:
3925           Fix documentation of probe callback - it is supposed to return
3926           FALSE, not TRUE, to remove data from the stream (#159087).
3927
3928 2004-12-16  Daniel Gazard  <dany42@free.fr>
3929
3930         Reviewed by:  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3931
3932         * gst/gstelementfactory.c: (gst_element_factory_create):
3933           Fix compile failure if compiling without libxml2 support (#149936).
3934
3935 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3936
3937         * docs/manual/advanced-autoplugging.xml:
3938         * docs/manual/highlevel-components.xml:
3939           Move spider from autoplugging to components. Autoplugging is for
3940           internals, not for solutions. ;-).
3941
3942 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3943
3944         * docs/random/ds/0.9-suggested-changes:
3945           Make note on device/location/uri property names.
3946
3947 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
3948
3949         * docs/manual/advanced-autoplugging.xml:
3950         * docs/manual/advanced-clocks.xml:
3951         * docs/manual/advanced-interfaces.xml:
3952         * docs/manual/advanced-metadata.xml:
3953         * docs/manual/advanced-position.xml:
3954         * docs/manual/advanced-schedulers.xml:
3955         * docs/manual/advanced-threads.xml:
3956         * docs/manual/appendix-gnome.xml:
3957         * docs/manual/appendix-programs.xml:
3958         * docs/manual/appendix-quotes.xml:
3959         * docs/manual/autoplugging.xml:
3960         * docs/manual/basics-bins.xml:
3961         * docs/manual/basics-data.xml:
3962         * docs/manual/basics-elements.xml:
3963         * docs/manual/basics-helloworld.xml:
3964         * docs/manual/basics-init.xml:
3965         * docs/manual/basics-pads.xml:
3966         * docs/manual/basics-plugins.xml:
3967         * docs/manual/bins-api.xml:
3968         * docs/manual/bins.xml:
3969         * docs/manual/buffers-api.xml:
3970         * docs/manual/buffers.xml:
3971         * docs/manual/clocks.xml:
3972         * docs/manual/components.xml:
3973         * docs/manual/cothreads.xml:
3974         * docs/manual/debugging.xml:
3975         * docs/manual/dparams-app.xml:
3976         * docs/manual/dynamic.xml:
3977         * docs/manual/elements-api.xml:
3978         * docs/manual/elements.xml:
3979         * docs/manual/factories.xml:
3980         * docs/manual/gnome.xml:
3981         * docs/manual/goals.xml:
3982         * docs/manual/helloworld.xml:
3983         * docs/manual/helloworld2.xml:
3984         * docs/manual/highlevel-components.xml:
3985         * docs/manual/highlevel-xml.xml:
3986         * docs/manual/init-api.xml:
3987         * docs/manual/intro-basics.xml:
3988         * docs/manual/intro-motivation.xml:
3989         * docs/manual/intro-preface.xml:
3990         * docs/manual/intro.xml:
3991         * docs/manual/links-api.xml:
3992         * docs/manual/links.xml:
3993         * docs/manual/manual.xml:
3994         * docs/manual/motivation.xml:
3995         * docs/manual/pads-api.xml:
3996         * docs/manual/pads.xml:
3997         * docs/manual/plugins-api.xml:
3998         * docs/manual/plugins.xml:
3999         * docs/manual/programs.xml:
4000         * docs/manual/queues.xml:
4001         * docs/manual/quotes.xml:
4002         * docs/manual/schedulers.xml:
4003         * docs/manual/states-api.xml:
4004         * docs/manual/states.xml:
4005         * docs/manual/threads.xml:
4006         * docs/manual/typedetection.xml:
4007         * docs/manual/win32.xml:
4008         * docs/manual/xml.xml:
4009           Try 2. This time, include a short preface as a "general
4010           introduction", also add code blocks around all code samples
4011           so they get compiled. We still need a way to tell readers
4012           the filename of the code sample. In some cases, don't show
4013           all code in the documentation, but do include it in the generated
4014           code. This allows for focussing on specific bits in the docs,
4015           while still having a full test application available.
4016         * examples/manual/Makefile.am:
4017           Fix up examples for new ADM. Add several of the new examples that
4018           were either added or were missing from the build system.
4019         * examples/manual/extract.pl:
4020           Allow nameless blocks.
4021
4022 2004-12-15  Thomas Vander Stichele  <thomas at apestaart dot org>
4023
4024         * docs/manual/elements-api.xml:
4025         * docs/manual/helloworld.xml:
4026         * examples/manual/extract.pl:
4027           fix last example.  Add example of adding code blocks that are not
4028           shown in docbook output.
4029
4030 2004-12-15  Thomas Vander Stichele  <thomas at apestaart dot org>
4031
4032         * docs/manual/dynamic.xml:
4033         * docs/manual/elements-api.xml:
4034         * docs/manual/gnome.xml:
4035         * docs/manual/helloworld2.xml:
4036         * docs/manual/init-api.xml:
4037         * docs/manual/queues.xml:
4038         * docs/manual/threads.xml:
4039         * docs/manual/xml.xml:
4040         * examples/manual/extract.pl:
4041           Make it possible to extract example code from separate blocks.
4042           Should make Ronald happy.
4043
4044 2004-12-15  Wim Taymans  <wim@fluendo.com>
4045
4046         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
4047         (remove_from_group), (group_elements_set_visited),
4048         (normalize_group), (gst_opt_scheduler_iterate):
4049         Fix bug where a flag was not updated on a decoupled entry point 
4050         because we were just checking the group element list and decoupled
4051         elements are not in that list..
4052
4053 2004-12-15  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4054
4055         * docs/manual/advanced-autoplugging.xml:
4056         * docs/manual/advanced-clocks.xml:
4057         * docs/manual/advanced-dparams.xml:
4058         * docs/manual/advanced-interfaces.xml:
4059         * docs/manual/advanced-metadata.xml:
4060         * docs/manual/advanced-position.xml:
4061         * docs/manual/advanced-schedulers.xml:
4062         * docs/manual/advanced-threads.xml:
4063         * docs/manual/appendix-debugging.xml:
4064         * docs/manual/appendix-gnome.xml:
4065         * docs/manual/appendix-programs.xml:
4066         * docs/manual/appendix-quotes.xml:
4067         * docs/manual/appendix-win32.xml:
4068         * docs/manual/autoplugging.xml:
4069         * docs/manual/basics-bins.xml:
4070         * docs/manual/basics-data.xml:
4071         * docs/manual/basics-elements.xml:
4072         * docs/manual/basics-helloworld.xml:
4073         * docs/manual/basics-init.xml:
4074         * docs/manual/basics-pads.xml:
4075         * docs/manual/basics-plugins.xml:
4076         * docs/manual/bins-api.xml:
4077         * docs/manual/bins.xml:
4078         * docs/manual/buffers-api.xml:
4079         * docs/manual/buffers.xml:
4080         * docs/manual/clocks.xml:
4081         * docs/manual/components.xml:
4082         * docs/manual/cothreads.xml:
4083         * docs/manual/debugging.xml:
4084         * docs/manual/dparams-app.xml:
4085         * docs/manual/dynamic.xml:
4086         * docs/manual/elements-api.xml:
4087         * docs/manual/elements.xml:
4088         * docs/manual/factories.xml:
4089         * docs/manual/gnome.xml:
4090         * docs/manual/goals.xml:
4091         * docs/manual/helloworld.xml:
4092         * docs/manual/helloworld2.xml:
4093         * docs/manual/highlevel-components.xml:
4094         * docs/manual/highlevel-xml.xml:
4095         * docs/manual/init-api.xml:
4096         * docs/manual/intro-motivation.xml:
4097         * docs/manual/intro-preface.xml:
4098         * docs/manual/intro.xml:
4099         * docs/manual/links-api.xml:
4100         * docs/manual/links.xml:
4101         * docs/manual/manual.xml:
4102         * docs/manual/motivation.xml:
4103         * docs/manual/pads-api.xml:
4104         * docs/manual/pads.xml:
4105         * docs/manual/plugins-api.xml:
4106         * docs/manual/plugins.xml:
4107         * docs/manual/programs.xml:
4108         * docs/manual/queues.xml:
4109         * docs/manual/quotes.xml:
4110         * docs/manual/schedulers.xml:
4111         * docs/manual/states-api.xml:
4112         * docs/manual/states.xml:
4113         * docs/manual/threads.xml:
4114         * docs/manual/typedetection.xml:
4115         * docs/manual/win32.xml:
4116         * docs/manual/xml.xml:
4117           First try at rewriting the ADM. Needs lotsamore work, but some
4118           parts might already be somewhat useful.
4119         * docs/pwg/advanced-interfaces.xml:
4120           Remove properties interface, it never actually existed (except for
4121           on my HD...).
4122
4123 2004-12-13  David Schleef  <ds@schleef.org>
4124
4125         * gst/gstpad.c: (gst_pad_set_explicit_caps): Allow caps to
4126         be NULL (bug #160220).
4127
4128 2004-12-13  David Schleef  <ds@schleef.org>
4129
4130         * configure.ac: remove all mmx stuff, because it's not used.
4131         * docs/random/ds/0.9-suggested-changes: additional notes
4132         * include/Makefile.am: we don't use these anymore
4133         * include/mmx.h: remove
4134         * include/sse.h: remove
4135
4136 2004-12-13  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
4137
4138         * docs/random/mimetypes:
4139           Add FOURCC code for h264 codec (VSSH)
4140           Add alternate FOURCC codes for h263 related codecs
4141
4142 2004-12-10  Stefan Kost  <ensonic@users.sf.net>
4143
4144         * docs/manual/programs.xml:
4145           Added more gst-launch examples.
4146
4147 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4148
4149         * gst/gstqueue.c: (gst_queue_handle_src_query):
4150           Check for availability again.
4151
4152 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4153
4154         * gst/gstcaps.c: (gst_caps_compare_structures):
4155           Simple caps go first. This has the nice side-effect of fixing an
4156           obscure warning.
4157
4158 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4159
4160         * gst/gstversion.h.in:
4161           Protect header.
4162
4163 2004-12-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4164
4165         * gst/schedulers/gstoptimalscheduler.c:
4166         (gst_opt_scheduler_schedule_run_queue), (schedule_chain),
4167         (gst_opt_scheduler_get_wrapper):
4168           When we're recursing into a chain run, only run the directly
4169           related group, not all queued ones. This will fix a possible
4170           deadlock in chains with more than two groups.
4171
4172 2004-12-08  Thomas Vander Stichele  <thomas at apestaart dot org>
4173
4174         * autogen.sh:
4175           remove patch if autopoint fails
4176
4177 2004-12-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4178
4179         * docs/gst/gstreamer-sections.txt:
4180           Document Thomas' addition, fix build, make Luis the sheriff happy.
4181
4182 2004-12-07  Thomas Vander Stichele  <thomas at apestaart dot org>
4183
4184         * gst/gstplugin.c:
4185         * gst/gstplugin.h:
4186           add accessor for version field
4187
4188 2004-12-06  Thomas Vander Stichele  <thomas at apestaart dot org>
4189
4190         submitted by: Luca Ferretti <elle.uca@infinito.it>
4191
4192         * po/LINGUAS:
4193         * po/it.po:
4194           New tranlation added: Italian
4195
4196 2004-12-03  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4197
4198         * gst/gstpad.c: (gst_pad_is_negotiated),
4199         (gst_pad_get_negotiated_caps):
4200           GST_RPAD_* will only operate on a RealPad (it casts the pointer,
4201           it doesn't actually check the contents), so be sure to hand it
4202           a RealPad else we'll crash.
4203
4204 2004-12-03  Wim Taymans  <wim@fluendo.com>
4205
4206         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
4207         (gst_queue_link), (gst_queue_handle_src_query):
4208         Reverted to 1.110 until this makes the testsuite and various
4209         apps work.
4210
4211 2004-12-01  Christian Fredrik Kalager Schaller <christian@fluendo.com>
4212
4213         * docs/upload.mak: fix included CVS conflict strings
4214
4215 2004-12-01  William Jon McCann  <mccann@jhu.edu>
4216
4217         Reviewed by: Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4218
4219         * gst/gstelement.c: (gst_element_error_full):
4220           Use g_error_new_literal because error text may have
4221           percentage signs in it. Fixes #160019.
4222
4223 2004-12-01  Benjamin Otte  <otte@gnome.org>
4224
4225         * gst/elements/gstbufferstore.c:
4226         (gst_buffer_store_add_buffer_func):
4227           don't try to make subbuffers bigger than they can be. (fixes
4228           #159970)
4229
4230 2004-11-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4231
4232         * docs/gst/gstreamer-sections.txt:
4233         * docs/gst/tmpl/gstvalue.sgml:
4234           Add new function to docs to fix build.
4235
4236 2004-11-29  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4237
4238         * gst/gstcaps.c: (gst_caps_is_fixed_foreach):
4239         * gst/gstpad.c: (_gst_pad_default_fixate_value),
4240         (_gst_pad_default_fixate_foreach):
4241         * gst/gstvalue.c: (gst_type_is_fixed), (gst_value_is_fixed):
4242         * gst/gstvalue.h:
4243           Deprecate _type_is_fixed, use _value_is_fixed instead, since
4244           in some cases (arrays), the fixedness depends on the content.
4245         * gst/gstqueue.c: (gst_queue_handle_src_query):
4246           Check for availability before doing something.
4247
4248 2004-11-29  Wim Taymans  <wim@fluendo.com>
4249
4250         * testsuite/threads/Makefile.am:
4251         * testsuite/threads/signals.c: (gst_test_get_type),
4252         (gst_test_class_init), (gst_test_init), (gst_test_dispose),
4253         (gst_test_set_property), (gst_test_get_property),
4254         (gst_test_do_signal1), (signal2_handler), (gst_test_do_signal2),
4255         (gst_test_do_prop), (run_thread), (main):
4256         Added a bunch of testcases that show threadsafety bugs in glib.
4257
4258 2004-11-29  Stefan Kost  <ensonic@users.sf.net>
4259
4260         * docs/manual/programs.xml:
4261           Added a first batch of gst-launch examples, as provided by Ronald
4262           and others from the devel-mlist
4263
4264 2004-11-28  Benjamin Otte  <otte@gnome.org>
4265
4266         * gst/gstelement.c: (gst_element_negotiate_pads):
4267           simplify
4268         * gst/gstvalue.c: (gst_string_wrap), (gst_string_unwrap),
4269         (gst_value_serialize_string), (gst_value_deserialize_string):
4270           add unwrapping of previously wrapped strings. Fix bug in wrapping
4271           while at it.
4272         * testsuite/caps/value_serialize.c: (test1),
4273         (test_string_serialization), (test_string_deserialization), (main):
4274           add tests for string (de)serialization
4275
4276 2004-11-26  Wim Taymans  <wim@fluendo.com>
4277
4278         * testsuite/threads/159566.c: (object_deep_notify), (main):
4279         * testsuite/threads/Makefile.am:
4280         Added testsuite to show bug #159566
4281
4282 2004-11-25  Wim Taymans  <wim@fluendo.com>
4283
4284         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_change_state),
4285         (gst_thread_child_state_change), (gst_thread_main_loop):
4286         Ref the thread object in the GThread mainloop. Break out of the
4287         thread mainloop if it holds the last ref. This properly exits
4288         the threads when disposing the thread from its own context. It
4289         also avoids possible deadlocks in the dispose function.
4290
4291 2004-11-24  Martin Soto  <martinsoto@users.sourceforge.net>
4292
4293         * gst/gstqueue.c (gst_queue_link_sink): Grab the lock only when
4294         it is necessary to wait.
4295
4296 2004-11-24  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4297
4298         * docs/pwg/building-boiler.xml:
4299           Make description somewhat clearer.
4300
4301 2004-11-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4302
4303         * docs/upload.mak:
4304           Apparently docs changed location on FDO's server.
4305
4306 2004-11-23  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4307
4308         * docs/pwg/appendix-checklist.xml:
4309           Add some random notes on things to check when writing an element.
4310           This list can be extended as people see fit.
4311
4312 2004-11-23  Martin Soto  <martinsoto@users.sourceforge.net>
4313
4314         * gst/gstqueue.c (gst_queue_init, gst_queue_link_sink)
4315         (gst_queue_link_src): Allow for renegotiating the caps of the sink
4316         pad. The queue will now wait until it is empty and forward the new
4317         caps to the source.
4318         * gst/gstbin.c (gst_bin_set_element_sched)
4319         (gst_bin_unset_element_sched): Make sure that all elements and
4320         links are registered and unregistered with the scheduler exactly
4321         once. This elaborates on a fix by Benjamin Otte, but
4322         guarantees that decoupled elements are also registered.
4323
4324 2004-11-11  Thomas Vander Stichele  <thomas at apestaart dot org>
4325
4326         * docs/manual/quotes.xml:
4327           add a quote
4328         * configure.ac:
4329         * gst/gst.c:
4330         * gst/gstinfo.c:
4331           add LIBDIR and move init message higher up so it's at the start
4332
4333 2004-11-08  Christian Fredrik Kalager Schaller  <christian@fluendo.com>
4334
4335         * gst/schedulers/Makefile.am: fix disted build fair by including .h file
4336         * gstreamer.spec.in: add fair
4337
4338 2004-11-08  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4339
4340         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
4341         * gst/elements/gstidentity.c: (gst_identity_class_init):
4342           Use G_SIGNAL_TYPE_STATIC_SCOPE, patch by Christophe Fergeau
4343           <teuf@gnome.org> (#157263).
4344         * gst/elements/gsttypefindelement.c: (gst_type_find_element_init),
4345         (gst_type_find_handle_src_query):
4346           Subtract size of internally stored data from position queries.
4347
4348 2004-11-07  Martin Soto  <martinsoto@users.sourceforge.net>
4349
4350         * gst/schedulers/fairscheduler.c:
4351         * gst/schedulers/faircothreads.c:
4352         * gst/schedulers/faircothreads.h:
4353         New cothread based scheduler: Fair scheduler.
4354         * gst/schedulers/gthread-cothreads.h: 
4355         Add the standard #if around the whole file.
4356         Defining symbol GTHREAD_COTHREADS_NO_DEFINITIONS will now prevent
4357         compilation of the functions defined in this file. This is
4358         necessary to be able to use this file as a normal header.
4359         * gst/schedulers/Makefile.am: Add compiling support for fair
4360         scheduler.
4361         * docs/gst/Makefile.am (IGNORE_HFILES): Exclude internal fair
4362         scheduler cothreads layer from documentation generation.
4363
4364 2004-11-07  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4365
4366         * gst/autoplug/gstspideridentity.c:
4367         (gst_spider_identity_sink_loop_type_finding):
4368           Don't crash if that function is not implemented.
4369
4370 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4371
4372         * docs/pwg/advanced-types.xml:
4373           Another typo.
4374
4375 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4376
4377         * docs/pwg/intro-preface.xml:
4378           Hm, ok, so the brackets weren't really useful...
4379         * docs/pwg/other-ntoone.xml:
4380           Fix embarassing typo.
4381
4382 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4383
4384         * docs/pwg/intro-preface.xml:
4385           Rewrite preface.
4386
4387 2004-11-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4388
4389         * docs/pwg/advanced-scheduling.xml:
4390         * docs/pwg/advanced-tagging.xml:
4391         * docs/pwg/advanced-types.xml:
4392         * docs/pwg/building-boiler.xml:
4393         * docs/pwg/building-chainfn.xml:
4394         * docs/pwg/building-signals.xml:
4395         * docs/pwg/building-state.xml:
4396         * docs/pwg/building-testapp.xml:
4397         * docs/pwg/intro-basics.xml:
4398         * docs/pwg/other-manager.xml:
4399         * docs/pwg/other-source.xml:
4400           Typo fixes.
4401         * docs/pwg/other-manager.xml:
4402           Add some first content. No example code yet.
4403         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
4404           Remove double newlines.
4405
4406 2004-11-04  Wim Taymans  <wim@fluendo.com>
4407
4408         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
4409         (remove_from_group), (normalize_group), (group_migrate_connected),
4410         (gst_opt_scheduler_iterate):
4411         * testsuite/schedulers/.cvsignore:
4412         * testsuite/schedulers/Makefile.am:
4413         * testsuite/schedulers/queue_link.c: (main):
4414         Added testcase for scheduler segfault.
4415         Fix scheduler segfault when removing a decoupled
4416         entry point as the last element from a group.
4417
4418 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
4419
4420         * gst/gstmarshal.list: add missing marshaller, fixes build
4421
4422 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
4423
4424         * docs/random/signal: added notes about using BOXED for GstBuffer
4425         signal marshallers, not POINTER
4426
4427 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
4428
4429         * gst/elements/gstfakesink.c: (gst_fakesink_class_init):
4430         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init): more
4431         POINTER=>BOXED changes to marshal GstBuffers
4432
4433 2004-11-03  Christophe Fergeau  <teuf@gnome.org>
4434
4435         * gst/elements/gstidentity.c: (gst_identity_class_init): GstBuffer is 
4436         a boxed type, marshal the signal with VOID__BOXED, not VOID__POINTER
4437
4438 2004-11-03  Stefan Kost  <ensonic@users.sf.net>
4439
4440         * docs/gst/gstreamer-sections.txt:
4441         * docs/gst/tmpl/gstcaps.sgml:
4442         * docs/gst/tmpl/gsterror.sgml:
4443         * docs/gst/tmpl/gstinfo.sgml:
4444         * docs/gst/tmpl/gstmacros.sgml:
4445         * docs/gst/tmpl/gstutils.sgml:
4446         * docs/random/ensonic/interfaces.txt:
4447         * gst/gstinfo.h:
4448           added some more docs, removed two obsolete defines
4449
4450 2004-11-02  Kjartan Maraas <as at gnome.org>
4451
4452         reviewed by: Wim Taymans, Ronald Bultje.
4453
4454         * gst/cothreads.c: (cothread_create):
4455         * gst/gstbin.c: (gst_bin_add_func), (gst_bin_remove_func),
4456         (gst_bin_child_state_change_func):
4457         * gst/gstbuffer.c: (gst_buffer_span):
4458         * gst/gstelement.c: (gst_element_get_index),
4459         (gst_element_get_event_masks), (gst_element_get_query_types),
4460         (gst_element_get_formats):
4461         * gst/gsterror.c: (_gst_core_errors_init),
4462         (_gst_library_errors_init), (_gst_resource_errors_init),
4463         (_gst_stream_errors_init):
4464         * gst/gstobject.c: (gst_object_default_deep_notify):
4465         * gst/gstpad.c: (gst_pad_get_event_masks),
4466         (gst_pad_get_internal_links_default):
4467         * gst/gstplugin.c: (gst_plugin_register_func),
4468         (gst_plugin_get_module):
4469         * gst/gststructure.c: (gst_structure_get_string),
4470         (gst_structure_get_abbrs), (gst_structure_from_abbr),
4471         (gst_structure_to_abbr):
4472         * gst/gstutils.c: (gst_print_element_args):
4473         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
4474         (setup_group_scheduler), (gst_opt_scheduler_iterate):
4475         Aplied part of patch #157127: Cleanup of issues reported by 
4476         sparse.
4477         Also do not try to use cothreads when there is no cothread
4478         context yet.
4479
4480 2004-11-02  Sebastien Cote <sc5 at hermes.usherb.ca>
4481
4482         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
4483         (gst_opt_scheduler_iterate):
4484         Applied patch #154061. Running a pipeline in which an element 
4485         calls GST_ELEMENT_ERROR in the chain function, the opt 
4486         scheduler doesn't unref the chain so it never gets freed.
4487
4488 2004-11-02  Wim Taymans  <wim@fluendo.com>
4489
4490         * gst/gststructure.c: (gst_structure_get_abbrs),
4491         (gst_structure_from_abbr), (gst_structure_to_abbr):
4492         Remove that ugly if-then thing in the code that converts
4493         between strings and types.
4494
4495 2004-11-02  Wim Taymans  <wim@fluendo.com>
4496
4497         * gst/gstscheduler.c: (gst_scheduler_add_element),
4498         (gst_scheduler_remove_element), (gst_scheduler_state_transition):
4499         Aplied clock distribution patch, this should fix bug
4500         #148787.
4501
4502 2004-10-27  Thomas Vander Stichele  <thomas at apestaart dot org>
4503
4504         Submitted by: Kjartan Maraas <kmaraas@broadpark.no>
4505
4506         * po/LINGUAS:
4507         * po/nb.po:
4508           Added Norwegian Bokmaal translation
4509
4510 2004-10-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4511
4512         * tools/gst-inspect.c: (print_signal_info):
4513           print signal arguments as pointers if they are
4514
4515 2004-10-22  Stefan Kost  <ensonic@users.sf.net>
4516
4517         * docs/pwg/building-boiler.xml:
4518           exchanged GTK_ macros with G_TYPE macros (as pointed out by mathrick)
4519
4520 2004-10-19  Wim Taymans  <wim at fluendo dot com>
4521
4522         * gst/parse/parse.l:
4523         * testsuite/parse/parse1.c: (main):
4524         Since parse can do 'element name=a:b' make 'a:b.' work as
4525         well. 
4526         Added testcase to verify fix.
4527
4528 2004-10-19  Wim Taymans  <wim at fluendo dot com>
4529
4530         * tools/gst-inspect.c: (print_pad_info), (print_plugin_features):
4531         Use the realpad when printing the direction.
4532         Add extra \n when printing extensions of typefind factories.
4533
4534 2004-10-13  David Schleef  <ds@schleef.org>
4535
4536         * examples/manual/Makefile.am: $< isn't portable in Makefile
4537         rules.
4538
4539 2004-10-13  Stefan Kost  <ensonic@users.sf.net>
4540
4541         * docs/gst/tmpl/gstobject.sgml:
4542         * docs/gst/tmpl/gstplugin.sgml:
4543         * docs/gst/tmpl/gstpluginfeature.sgml:
4544         * docs/gst/tmpl/gstregistry.sgml:
4545         * docs/gst/tmpl/gstversion.sgml:
4546         * gst/gstbin.c:
4547           more api documentation
4548         * gst/gstplugin.c: (gst_plugin_register_func),
4549         (gst_plugin_check_file), (gst_plugin_load_file):
4550           better error signaling and logging
4551
4552 2004-10-11  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4553
4554         * gst/gstqueue.c: (gst_queue_init), (gst_queue_handle_src_query):
4555           Subtract current queue contents from position queries.
4556
4557 2004-10-11  Johan Dahlin  <johan@gnome.org>
4558
4559         * gst/gsturi.c (gst_uri_get_location): unescape string
4560         (gst_uri_construct): escape string.
4561
4562 2004-10-11  Benjamin Otte  <otte@gnome.org>
4563
4564         * gst/gstpad.c: (gst_pad_renegotiate), (gst_pad_try_set_caps),
4565         (gst_pad_try_set_caps_nonfixed):
4566           allow renegotiation of unconnected pads (as inside spider). Simply
4567           return OK if unconnected - mimic try_set_caps there.
4568
4569 2004-10-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4570
4571         * gst/gstbin.c: (gst_bin_sync_children_state):
4572           Add missing break.
4573
4574 2004-10-09  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
4575
4576         * gst/elements/gstfakesrc.c: (gst_fakesrc_get):
4577         Set element to EOS before sending EOS event
4578
4579 2004-10-08  Wim Taymans  <wim at fluendo dot com>
4580
4581         * gst/elements/gsttypefindelement.c:
4582         (gst_type_find_element_handle_event):
4583         Handle EOS events when doing the transition from
4584         typefind to data passing. This should fix the
4585         infinite loops in short files.
4586
4587 2004-10-07  Wim Taymans  <wim at fluendo dot com>
4588
4589         * gst/gstthread.c: (gst_thread_change_state),
4590         (gst_thread_child_state_change):
4591         Make sure no iteration happens while performing
4592         the state change as it could mess up the internal
4593         consistency of the thread state.
4594
4595 2004-10-07  Wim Taymans  <wim at fluendo dot com>
4596
4597         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_sync),
4598         (gst_thread_change_state), (gst_thread_child_state_change):
4599         Do not try to grab the iterate lock in the state change method
4600         when we are in the same thread as the iterate or else we
4601         could deadlock. Some other cleanups.
4602
4603 2004-10-06  Thomas Vander Stichele  <thomas at apestaart dot org>
4604
4605         * configure.ac:
4606           bump nano to cvs
4607
4608 === release 0.8.7 ===
4609
4610 2004-10-06  Thomas Vander Stichele  <thomas at apestaart dot org>
4611
4612         * configure.ac:
4613         * NEWS:
4614         * RELEASE:
4615         * configure.ac:
4616           releasing 0.8.7, "A Cruise"
4617
4618 2004-10-06  Stephane Loeuillet  <stephane.loeuillet@tiscali.fr>
4619
4620         * docs/random/mimetypes:
4621         Add an entry for Sony ATRAC3 audio format with mime-type
4622         used by rmdemux et riff-read
4623
4624 2004-10-06  Wim Taymans  <wim at fluendo dot com>
4625
4626         * gst/elements/gsttypefindelement.c: (stop_typefinding):
4627         Push the buffer store instead of clearing it in case that
4628         the stream is not seekable.
4629
4630 2004-10-06  Wim Taymans  <wim at fluendo dot com>
4631
4632         * gst/gstthread.c: (gst_thread_init), (gst_thread_change_state),
4633         (gst_thread_main_loop):
4634         Lock the iteration and the state change so that automatic
4635         negotiation and fixation does not happen at the same time
4636         as the in stream negotiation.
4637
4638 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
4639
4640         * configure.ac:
4641           bump nano to cvs
4642
4643 === release 0.8.6 ===
4644
4645 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
4646
4647         * configure.ac:
4648         * NEWS:
4649         * RELEASE:
4650         * configure.ac:
4651           releasing 0.8.6, "Narc"
4652
4653 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
4654
4655         * configure.ac:
4656           prerel bump
4657
4658 2004-10-05  Thomas Vander Stichele  <thomas at apestaart dot org>
4659
4660         patch by: Steve Lhomme
4661
4662         * gst/elements/gstfakesrc.c:
4663         * gst/elements/gstidentity.c:
4664         * gst/gstthread.c:
4665           Fix for #153881
4666
4667 2004-10-01  Wim Taymans  <wim at fluendo dot com>
4668
4669         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_crc):
4670         Fix threadsafety of the crc checking function.
4671
4672 2004-09-26  Thomas Vander Stichele  <thomas at apestaart dot org>
4673
4674         patch by: Ronald Bultje
4675
4676         * gst/elements/gsttypefindelement.c: (stop_typefinding),
4677         (gst_type_find_element_handle_event),
4678         (gst_type_find_element_chain):
4679         * gst/elements/gsttypefindelement.h:
4680          #153657.
4681          Filter out discont event from seekable sources when typefind
4682          asks them to seek.  Fixes typefind with demuxers for
4683          avi, asf and matroska.
4684
4685 2004-09-26  Thomas Vander Stichele  <thomas at apestaart dot org>
4686
4687         * docs/gst/gstreamer-sections.txt:
4688         * gst/gstcaps.c:
4689         * gst/gstcaps.h:
4690         * gst/gstpad.c:
4691           Revert preferred caps: (#147789)
4692
4693 2004-09-19  Steve Lhomme  <steve.lhomme@free.fr>
4694
4695         * win32/dirent.c:
4696           fix a memory leak
4697
4698 2004-09-10  Thomas Vander Stichele  <thomas at apestaart dot org>
4699
4700         * configure.ac:
4701           bump for prerelease
4702
4703 2004-09-09  Thomas Vander Stichele  <thomas at apestaart dot org>
4704
4705         * docs/Makefile.am:
4706         * docs/manual/elements-api.xml:
4707           restructure so that common stuff is shown first
4708         * docs/manual/init-api.xml:
4709           convert to examples
4710         * docs/manual/manual.xml:
4711         * docs/manuals.mak:
4712         * docs/url.entities:
4713           link to API on the website, possibly override later in build
4714         * examples/manual/.cvsignore:
4715           ignore more
4716         * examples/manual/Makefile.am:
4717           add more examples
4718         * examples/manual/extract.pl:
4719           error out on failure
4720
4721 2004-09-08  Thomas Vander Stichele  <thomas at apestaart dot org>
4722
4723         * docs/gst/tmpl/gstthread.sgml:
4724         * docs/manual/init-api.xml:
4725         * examples/manual/Makefile.am:
4726           convert two code bits to examples
4727
4728 2004-09-06  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
4729
4730         * gst/gstelement.c: (gst_element_change_state):
4731           Well, actually, I was about to remove this insane assert when
4732           I noticed Wim already did that. A warning is nice so we can
4733           fix actual ugs (using --g-fatal-warnings and backtraces), so
4734           I added that instead.
4735
4736 2004-09-06  Wim Taymans  <wim@fluendo.com>
4737
4738         * gst/gstelement.c: (gst_element_threadsafe_properties_pre_run),
4739         (gst_element_threadsafe_properties_post_run),
4740         (gst_element_set_state), (gst_element_change_state):
4741         Added extra refcounting around various places. 
4742
4743 2004-09-06  Wim Taymans  <wim@fluendo.com>
4744
4745         * gst/gstpad.c: (gst_pad_link_call_link_functions):
4746         Fix debug info.
4747
4748 2004-09-06  Wim Taymans  <wim@fluendo.com>
4749
4750         * gst/schedulers/gstoptimalscheduler.c: (add_to_group),
4751         (remove_from_group):
4752         Some more debug info.
4753
4754 2004-09-03  Wim Taymans  <wim@fluendo.com>
4755
4756         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init),
4757         (gst_fakesrc_init), (gst_fakesrc_set_clock),
4758         (gst_fakesrc_set_property), (gst_fakesrc_get_property),
4759         (gst_fakesrc_get), (gst_fakesrc_change_state):
4760         * gst/elements/gstfakesrc.h:
4761         * gst/elements/gstidentity.c: (gst_identity_class_init),
4762         (gst_identity_init), (gst_identity_chain),
4763         (gst_identity_set_property), (gst_identity_get_property),
4764         (gst_identity_change_state):
4765         * gst/elements/gstidentity.h:
4766         Added datarate properties to limit the datarate.
4767
4768 2004-08-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4769
4770         * gst/autoplug/gstspider.c: (plugin_init):
4771           don't set a rank. We don't want to autoplug by inserting spiders.
4772
4773 2004-08-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4774
4775         * gst/autoplug/gstspider.c: (gst_spider_class_init),
4776         (gst_spider_identity_plug):
4777           add a template for spider's sink
4778         * gst/gst.c: (gst_register_core_elements):
4779           queue's rank should be NULL, we don't want spider to add it.
4780
4781 2004-08-18  David Schleef  <ds@schleef.org>
4782
4783         * docs/gst/Makefile.am: Remove --ignore-fail-on-non-empty (#150331)
4784         * docs/libs/Makefile.am: same
4785         * docs/gst/tmpl/gstxml.sgml: Remove GstXMLNs
4786         * docs/random/ds/0.9-planning: random additions
4787         * docs/random/ds/0.9-suggested-changes: same
4788         * gst/gstxml.h: remove vestigal GstXMLNs definition
4789
4790         Preferred caps: (#147789)
4791         * docs/gst/gstreamer-sections.txt: Add symbols
4792         * docs/gst/tmpl/gstcaps.sgml: Add symbols
4793         * gst/gstcaps.c: (gst_caps_copy), (gst_caps_free),
4794         (gst_caps_append), (gst_caps_copy_1), (gst_caps_intersect),
4795         (gst_caps_union), (gst_caps_save_thyself), (gst_caps_load_thyself),
4796         (gst_caps_get_preferred), (gst_caps_set_preferred),
4797         (gst_caps_get_structure_by_id), (gst_caps_prefer_foreach),
4798         (gst_caps_use_preferred): Handle caps preferences
4799         * gst/gstcaps.h: Add caps preferences
4800         * gst/gstpad.c: (gst_pad_link_get_preferred),
4801         (gst_pad_link_fixate), (gst_pad_link_call_link_functions),
4802         (gst_pad_renegotiate), (gst_pad_guess_preferred),
4803         (gst_pad_get_caps), (gst_pad_push):  Use caps preferences for
4804         negotiation.
4805
4806 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4807
4808         * gst/autoplug/gstspideridentity.c:
4809         (gst_spider_identity_request_new_pad):
4810         * gst/elements/gstaggregator.c: (gst_aggregator_base_init),
4811         (gst_aggregator_init):
4812         * gst/elements/gstfakesink.c: (gst_fakesink_base_init),
4813         (gst_fakesink_init):
4814         * gst/elements/gstfakesrc.c: (gst_fakesrc_base_init),
4815         (gst_fakesrc_init):
4816         * gst/elements/gstfdsink.c: (gst_fdsink_base_init),
4817         (gst_fdsink_init):
4818         * gst/elements/gstfdsrc.c: (gst_fdsrc_base_init), (gst_fdsrc_init):
4819         * gst/elements/gstfilesink.c: (gst_filesink_base_init),
4820         (gst_filesink_init):
4821         * gst/elements/gstfilesrc.c: (gst_filesrc_base_init),
4822         (gst_filesrc_init):
4823         * gst/elements/gstidentity.c: (gst_identity_base_init),
4824         (gst_identity_init):
4825         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_base_init),
4826         (gst_multifilesrc_init):
4827         * gst/elements/gstpipefilter.c: (gst_pipefilter_base_init),
4828         (gst_pipefilter_init):
4829         * gst/elements/gststatistics.c: (gst_statistics_base_init),
4830         (gst_statistics_init):
4831         * gst/elements/gsttee.c: (gst_tee_base_init), (gst_tee_init):
4832         * gst/gstqueue.c: (gst_queue_base_init), (gst_queue_init):
4833           s/gst_pad_new/&_from_template/
4834           register pad templates in the base_init function
4835           add static pad template definitions
4836
4837 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4838
4839         * testsuite/bytestream/gstbstest.c: (gst_bstest_init):
4840         * testsuite/dynparams/dparamstest.c: (gst_dptest_init):
4841         * testsuite/refcounting/pad.c: (main):
4842         * testsuite/refcounting/thread.c: (create_thread_ghostpads):
4843           s/gst_pad_new/&_from_template/
4844           prepare deprecation of gst_pad_new
4845
4846 2004-08-17  Thomas Vander Stichele  <thomas at apestaart dot org>
4847
4848         patch by: Luca Ognibene <skaboy81@virgilio.it>
4849
4850         * gst/gstcaps.c:
4851         * gst/gstelement.c:
4852         * gst/gstpad.c:
4853         * gst/gstxml.c:
4854           fix memleaks.  Fixes #150001
4855
4856 2004-08-17  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4857
4858         * docs/random/ds/0.9-suggested-changes:
4859           add notes - mostly about pad templates
4860
4861 2004-08-16  Steve Lhomme  <steve.lhomme@free.fr>
4862
4863         * win32/GStreamer.vcproj:
4864           temporary locale files are .gmo not .mo
4865
4866 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
4867
4868         * configure.ac: bump nano to cvs
4869
4870 === release 0.8.5 ===
4871
4872 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
4873
4874         * configure.ac:
4875           releasing 0.8.5, "Stuttgart"
4876         * NEWS:
4877         * RELEASE:
4878         * configure.ac:
4879         * docs/random/release:
4880           updates for release
4881
4882 2004-08-16  Thomas Vander Stichele  <thomas at apestaart dot org>
4883
4884         patch by: Wim Taymans (wim@fluendo.com)
4885
4886         * gst/gstbuffer.c:
4887         * gst/gstindex.h:
4888         * libs/gst/dataprotocol/dataprotocol.c:
4889           copy KEY_UNIT and DELTA_UNIT flags correctly.  Fixes #150242
4890
4891 2004-08-13  Thomas Vander Stichele  <thomas at apestaart dot org>
4892
4893         * Makefile.am:
4894         * win32/MANIFEST:
4895           add win32 dir to the build.  Fixes #149981.
4896
4897 2004-08-13  Thomas Vander Stichele  <thomas at apestaart dot org>
4898
4899         * configure.ac:
4900           bump libtool versioning
4901         * gst/gststructure.c:
4902           mark function as static
4903         * po/af.po:
4904         * po/az.po:
4905         * po/ca.po:
4906         * po/cs.po:
4907         * po/en_GB.po:
4908         * po/fr.po:
4909         * po/nl.po:
4910         * po/sq.po:
4911         * po/sr.po:
4912         * po/sv.po:
4913         * po/tr.po:
4914         * po/uk.po:
4915           translations update
4916         * win32/README.txt:
4917           trademark protection
4918
4919 2004-08-12  Thomas Vander Stichele  <thomas at apestaart dot org>
4920
4921         * configure.ac:
4922           fix GST_ORIGIN
4923           set GST_PACKAGE to source, and distinguish between release and other
4924         * tools/gst-inspect.c:
4925           print out plugin an element factory is part of so we see this info
4926
4927 2004-08-12  Thomas Vander Stichele  <thomas at apestaart dot org>
4928
4929         * docs/gst/gstreamer-sections.txt:
4930         * docs/gst/tmpl/gstbuffer.sgml:
4931         * docs/gst/tmpl/gstschedulerfactory.sgml:
4932           reorder docs a little, make GstBuffer's more sensible.
4933         * gst/gstbuffer.h:
4934           API: added GST_BUFFER_FLAG_DELTA_UNIT
4935         * gst/gstscheduler.c:
4936           comment API addition
4937
4938 2004-08-12  Benjamin Otte  <in7y118@public.uni-hamburg.de>
4939
4940         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
4941           work with non-regular files that can be mmapped (like /dev/zero)
4942         * gst/elements/gsttypefindelement.c: (gst_type_find_element_chain):
4943           get rid of typefinds that require a seek when we can't seek instead
4944           of trying them over and over again
4945         * tools/gst-launch.c: (idle_func), (error_cb), (main):
4946           return non-zero failure value when the pipeline was interrupted or
4947           an error occurred
4948
4949 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
4950
4951         * win32/config.h:
4952         * win32/GStreamer.vcproj:
4953           compile and install the locales
4954
4955 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
4956
4957         * gst/gstvalue.c:
4958           fix a possible memory leak under Windows
4959
4960 2004-08-11  Steve Lhomme  <steve.lhomme@free.fr>
4961
4962         * win32/GStreamer.vcproj:
4963           fix a memory leak that occured under Windows
4964         * win32/gstreamer.def:
4965           add gst_scheduler_register
4966
4967 2004-08-11  Benjamin Otte  <otte@gnome.org>
4968
4969         * docs/gst/gstreamer-sections.txt:
4970         * gst/gstscheduler.c: (gst_scheduler_register):
4971         * gst/gstscheduler.h:
4972           API:
4973           add gst_scheduler_register shortcut similar to gst_element_register
4974         * gst/schedulers/entryscheduler.c: (plugin_init):
4975         * gst/schedulers/gstbasicscheduler.c: (plugin_init):
4976         * gst/schedulers/gstoptimalscheduler.c: (plugin_init):
4977           use it
4978
4979 2004-08-10  Steve Lhomme  <steve.lhomme@free.fr>
4980
4981         * gst/gstvalue.h:
4982           fix a memory leak that occured under Windows
4983
4984 2004-08-10  Colin Walters  <walters@redhat.com>
4985
4986         * gst/registries/gstxmlregistry.c (gst_xml_registry_open_func):
4987         Don't use O_EXCL to open temporary registry.  It will prevent
4988         registry creation if a temporary one already exists, which
4989         is unnecessary.
4990
4991 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
4992
4993         * docs/gst/gstreamer-sections.txt:
4994         * docs/gst/tmpl/gstvalue.sgml:
4995           remove some valuable stuff from the documentation due to the use of GST_EXPORT
4996
4997 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
4998
4999         * win32/gstbytestream.vcproj:
5000         * win32/gstelements.vcproj:
5001         * win32/gstgetbits.vcproj:
5002         * win32/gst-inspect.vcproj:
5003         * win32/gst-launch.vcproj:
5004         * win32/gstoptimalscheduler.vcproj:
5005         * win32/GStreamer.vcproj:
5006         * win32/gst-register.vcproj:
5007         * win32/gstspider.vcproj:
5008           update the include and lib dirs to fit standard libraries as
5009           described in the Win32 manual
5010
5011 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
5012
5013         * win32/config.h:
5014         * win32/gstversion.h:
5015           enable NLS again, push the version number for the coming 0.8.5 release
5016
5017 2004-08-09  Steve Lhomme  <steve.lhomme@free.fr>
5018
5019         * gst/gstvalue.h:
5020           export gst_type_XXX for windows DLLs
5021
5022 2004-08-09  Thomas Vander Stichele  <thomas at apestaart dot org>
5023
5024         * docs/faq/gst-uninstalled:
5025           fix PKG_CONFIG_PATH and PYTHONPATH
5026         * gst/schedulers/Makefile.am:
5027           cleanup
5028         * libs/gst/bytestream/bytestream.c:
5029           remove newline
5030         * po/LINGUAS:
5031         * po/sq.po:
5032           adding Albanian translation (Laurent Dhima)
5033         * po/cs.po:
5034           updated
5035
5036 2004-08-05  Thomas Vander Stichele  <thomas at apestaart dot org>
5037
5038         * po/ca.po:
5039         * po/sv.po:
5040           updated translations
5041
5042 2004-08-04  Benjamin Otte  <otte@gnome.org>
5043
5044         * tests/mass_elements.c: (main):
5045           allow specifying src and sink element explicitly, so I can test
5046           videotestsrc instead of fakesrc
5047
5048 2004-08-04  Benjamin Otte  <otte@gnome.org>
5049
5050         * gst/gststructure.c: (gst_structure_id_empty_new_with_size),
5051         (gst_structure_id_empty_new), (gst_structure_empty_new),
5052         (gst_structure_copy):
5053           add gst_structure_id_empty_new_with_size to allow preallocating
5054           value array sizes. Use this in gst_structure_copy to get rid of
5055           reallocs.
5056           don't do quark=>string=>quark when copying structures
5057
5058 2004-08-03  Steve Lhomme  <steve.lhomme@free.fr>
5059
5060         * docs/manual/win32.xml:
5061         * win32/README.txt:
5062           update documentation with the clean version of dependencies
5063
5064 2004-08-03  Benjamin Otte  <otte@gnome.org>
5065
5066         * gst/schedulers/entryscheduler.c:
5067         (gst_entry_scheduler_remove_element):
5068           fix for GST_DISABLE_DEBUG
5069         * tools/gst-launch.c: (print_tag):
5070           fixes for G_DISABLE_ASSERT
5071
5072 2004-08-03  Benjamin Otte  <otte@gnome.org>
5073
5074         * gst/gst.c: (gst_register_core_elements):
5075           fix for G_DISABLE_ASSERT
5076         * gst/gstinfo.c: (__gst_in_valgrind):
5077           add for GST_DISABLE_DEBUG
5078
5079 2004-08-03  Benjamin Otte  <otte@gnome.org>
5080
5081         * gst/parse/parse.l:
5082           fix for G_DISABLE_ASSERT
5083
5084 2004-08-03  Wim Taymans  <wim@fluendo.com>
5085
5086         * gst/gstbin.c: (gst_bin_get_type),
5087         (gst_bin_child_state_change_func):
5088         * gst/gstthread.c: (gst_thread_change_state):
5089         Backported some debug logging from a reverted patch
5090         Don't try to destroy the thread twice. Added some more
5091         debugging in GstThread. Unlock and signal even if we
5092         are in the thread context.
5093
5094 2004-08-03  Thomas Vander Stichele  <thomas at apestaart dot org>
5095
5096         * po/uk.po:
5097           updated translation
5098
5099 2004-07-30  David Schleef  <ds@schleef.org>
5100
5101         * gst/gstatomic_impl.h: Enable atomic code for x86_64
5102
5103 2004-07-29  David Schleef  <ds@schleef.org>
5104
5105         * libs/gst/dataprotocol/dataprotocol-test.c: (conversion_test):
5106         Use GST_READ_GUINTxx_BE(), since it accesses unaligned memory.
5107
5108 2004-07-29  Thomas Vander Stichele  <thomas at apestaart dot org>
5109
5110         * gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
5111         (gst_bin_add_func), (gst_bin_remove_func),
5112         (gst_bin_child_state_change), (gst_bin_child_state_change_func),
5113         (set_kid_state_func), (gst_bin_change_state), (gst_bin_set_state),
5114         (gst_bin_change_state_norecurse), (gst_bin_dispose),
5115         (gst_bin_sync_children_state):
5116         * gst/gstbin.h:
5117         * gst/gstthread.c: (gst_thread_class_init), (gst_thread_release),
5118         (gst_thread_change_state):
5119         * testsuite/states/Makefile.am:
5120           revert state change patches as agreed so we can rework them
5121           gradually
5122
5123 2004-07-29  Benjamin Otte  <otte@gnome.org>
5124
5125         * libs/gst/control/Makefile.am:
5126           link to libgstreamer (fixes Debian bug 262019, see
5127           http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=262019 )
5128
5129 2004-07-29  Wim Taymans  <wim@fluendo.com>
5130
5131         * testsuite/caps/fraction-convert.c: (check_from_double_convert),
5132         (check_from_fraction_convert), (transform_test), (main):
5133         Make the test less pedantic about float roundoff errors.
5134
5135 2004-07-29  Benjamin Otte  <otte@gnome.org>
5136
5137         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file),
5138         (gst_filesrc_srcpad_event):
5139           make seek events to before start/after end of file not fail, but
5140           seek to start/end instead
5141         * testsuite/caps/fraction-convert.c: (check_from_double_convert):
5142           add more output
5143
5144 2004-07-29  Benjamin Otte  <otte@gnome.org>
5145
5146         * gst/gstpad.c: (gst_pad_set_explicit_caps):
5147           check that caps are fixed
5148         * gst/gstpad.c: (gst_pad_template_new):
5149           don't try to simplify caps, costs too much time on gst_init
5150         * gst/gstplugin.c: (gst_plugin_add_feature):
5151           G_ERROR if features are added twice
5152         * gst/gsttypefind.c: (gst_type_find_register):
5153         * gst/gstelementfactory.c: (gst_element_register):
5154           don't add features twice
5155         * docs/random/ds/0.9-suggested-changes:
5156           add note about possible gst_init optimization
5157
5158 2004-07-28  David Schleef  <ds@schleef.org>
5159
5160         * testsuite/elements/Makefile.am:
5161         * testsuite/elements/struct_i386.h:
5162         * testsuite/elements/struct_size.c: (main):  A little test
5163         to keep distcheck from working if someone changes a structure
5164         size accidentally.
5165
5166 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
5167
5168         * docs/libs/Makefile.am:
5169         * docs/libs/gstreamer-libs-docs.sgml:
5170         * docs/libs/gstreamer-libs-sections.txt:
5171         * docs/libs/tmpl/gstbytestream.sgml:
5172         * docs/libs/tmpl/gstcontrol.sgml:
5173         * docs/libs/tmpl/gstdataprotocol.sgml:
5174         * docs/libs/tmpl/gstgetbits.sgml:
5175         * libs/gst/bytestream/Makefile.am:
5176         * libs/gst/bytestream/bytestream.c:
5177         * libs/gst/bytestream/bytestream.h:
5178         * libs/gst/control/Makefile.am:
5179         * libs/gst/dataprotocol/Makefile.am:
5180         * libs/gst/getbits/Makefile.am:
5181         * libs/gst/getbits/getbits.h:
5182           various doc and style fixes, adding bytestream to libs docs.
5183
5184 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
5185
5186         * docs/gst/gstreamer-docs.sgml:
5187         * docs/libs/Makefile.am:
5188         * docs/libs/gstreamer-libs-docs.sgml:
5189         * docs/libs/gstreamer-libs-sections.txt:
5190         * libs/gst/control/dparam.c:
5191           more doc fixes.  gst-libs docs now build the same way as gst.
5192
5193 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
5194
5195         * configure.ac:
5196         * testsuite/Makefile.am:
5197         * testsuite/bins/Makefile.am:
5198         * testsuite/caps/Makefile.am:
5199         * testsuite/cleanup/Makefile.am:
5200         * testsuite/clock/Makefile.am:
5201         * testsuite/debug/Makefile.am:
5202         * testsuite/dlopen/Makefile.am:
5203         * testsuite/dynparams/Makefile.am:
5204         * testsuite/elements/.cvsignore:
5205         * testsuite/elements/Makefile.am:
5206         * testsuite/enumcaps/Makefile.am:
5207         * testsuite/enumcaps/enumcaps.c:
5208         * testsuite/ghostpads/Makefile.am:
5209         * testsuite/indexers/Makefile.am:
5210         * testsuite/negotiation/Makefile.am:
5211         * testsuite/parse/Makefile.am:
5212         * testsuite/plugin/Makefile.am:
5213         * testsuite/refcounting/Makefile.am:
5214         * testsuite/schedulers/.cvsignore:
5215         * testsuite/states/Makefile.am:
5216         * testsuite/tags/Makefile.am:
5217         * testsuite/threads/Makefile.am:
5218           fold enumcaps into caps dir
5219           clean up Makefile.am's for testsuite
5220
5221 2004-07-28  Thomas Vander Stichele  <thomas at apestaart dot org>
5222
5223         * docs/gst/Makefile.am:
5224         * docs/libs/Makefile.am:
5225           clean up docs build.  Fixes needless rebuilding of template files.
5226
5227 2004-07-28  Wim Taymans  <wim@fluendo.com>
5228
5229         * gst/gstbin.c: (set_kid_state_func), (gst_bin_set_state):
5230         * gst/gstthread.c: (gst_thread_release), (gst_thread_set_state):
5231         Make sure that a bin state change tries to keep the children
5232         in sync. 
5233         Added debug logging to the thread.
5234
5235 2004-07-27  Steve Lhomme  <steve.lhomme@free.fr>
5236
5237         * win32/GStreamer.vcproj:
5238         * win32/gstreamer.def:
5239           more exports for the plugins
5240
5241 2004-07-27  Steve Lhomme  <steve.lhomme@free.fr>
5242
5243         * win32/gstgetbits.vcproj:
5244         * win32/gstgetbits.def:
5245         * win32/msvc71.sln:
5246           add support for the getbits plugin
5247
5248 2004-07-27  Wim Taymans  <wim@fluendo.com>
5249
5250         * gst/gstvalue.c: (gst_value_transform_double_fraction),
5251         (gst_value_transform_fraction_double), (_gst_value_initialize):
5252         * testsuite/caps/Makefile.am:
5253         * testsuite/caps/fraction-convert.c: (check_from_double_convert),
5254         (check_from_fraction_convert), (transform_test), (main):
5255         Added transform functions between double and fraction.
5256         Added testcase to verify transforms
5257
5258 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
5259
5260         * win32/GStreamer.vcproj:
5261           rename GStreamer-0.8.lib to libgstreamer.lib
5262
5263 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
5264
5265         * win32/gstelements.vcproj:
5266         * win32/gstoptimalscheduler.vcproj:
5267           fixes for the Release build
5268
5269 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
5270
5271         * win32/config.h:
5272           update the version number
5273
5274 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
5275
5276         * win32/GStreamer.vcproj:
5277           add gstinterface to the build
5278
5279 2004-07-26  Steve Lhomme  <steve.lhomme@free.fr>
5280
5281         * win32/gstreamer.def:
5282           add many definitions needed by plugins,
5283           GST_CAT_DEFAULT only available in the Debug build ?
5284
5285 2004-07-26  Thomas Vander Stichele  <thomas at apestaart dot org>
5286
5287         * gst/gstelement.c: (gst_element_set_eos_recursive):
5288           various whitespace fixes.
5289           doc fix, fixes #148497
5290
5291 2004-07-25  Benjamin Otte  <otte@gnome.org>
5292
5293         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link):
5294           don't delay links on the sink elements, it causes unnegotiated
5295           links.
5296         * gst/elements/gsttypefindelement.c:
5297         (gst_type_find_element_base_init):
5298           add our padtemplates, we indeed do have some.
5299         * gst/elements/gsttypefindelement.c:
5300         (gst_type_find_element_handle_event),
5301         (gst_type_find_element_chain):
5302           don't push data when typefinding failed.
5303         * gst/gstpad.c: (gst_pad_link_fixate):
5304           check that no fixate function returns empty caps.
5305         * gst/gstpad.c: (gst_pad_push):
5306           check that the link is negotiated before data gets pushed.
5307         * tools/gst-register.c: (main):
5308           don't assert (fixes #148283)
5309
5310 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
5311
5312         * docs/gst/gstreamer-sections.txt:
5313         * docs/gst/tmpl/gstconfig.sgml:
5314           add GST_PLUGIN_EXPORT definition
5315
5316 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
5317
5318         * gst/gstplugin.h:
5319         * gst/gstconfig.h.in:
5320         * win32/gstconfig.h:
5321         * win32/gstelements.def:
5322         * win32/gstelements.vcproj:
5323         * win32/gstoptimalscheduler.def:
5324         * win32/gstoptimalscheduler.vcproj:
5325         * win32/gstspider.def:
5326         * win32/gstspider.vcproj:
5327           remove unused .def files and export symbols using GST_PLUGIN_DEFINE
5328
5329 2004-07-25  Thomas Vander Stichele  <thomas at apestaart dot org>
5330
5331         * docs/gst/gstreamer-sections.txt:
5332           remove GST_CAT_DEFAULT because the type has changed
5333
5334 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
5335
5336         * win32/gstbytestream.vcproj:
5337         * win32/gstelements.vcproj:
5338         * win32/gst-inspect.vcproj:
5339         * win32/gst-launch.vcproj:
5340         * win32/gstoptimalscheduler.vcproj:
5341         * win32/GStreamer.vcproj:
5342         * win32/gst-register.vcproj:
5343         * win32/gstspider.vcproj:
5344         * win32/msvc71.sln:
5345           Copy the files where needed after building, The testsuite will be
5346           built separately
5347
5348 2004-07-25  Steve Lhomme  <steve.lhomme@free.fr>
5349
5350         * win32/config.h:
5351         * win32/README.txt:
5352         * docs/manual/win32.xml:
5353         Fixed the plugin and GStreamer location
5354
5355 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
5356
5357         * win32/gstreamer.def:
5358         More exports for the plugins
5359
5360 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
5361
5362         * gst/gstinfo.h:
5363         Marc was right, we need to export literally GST_CAT_DEFAULT
5364
5365 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
5366
5367         * win32/config.h:
5368         NLS crashes in gettext, disabled until this is solved
5369
5370 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
5371
5372         * win32/gst-inspect.vcproj:
5373         * win32/gst-launch.vcproj:
5374         Should use NLS when available
5375
5376 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
5377
5378         * gst/registries/gstxmlregistry.c:
5379         removing the file doesn't seem to be a good idea on Linux
5380
5381 2004-07-24  Steve Lhomme  <steve.lhomme@free.fr>
5382
5383         * gst/registries/gstxmlregistry.c:
5384         Remove the registry before renaming the tempfile (needed for Windows)
5385
5386 2004-07-23  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5387
5388         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init),
5389         (gst_multifilesrc_init), (gst_multifilesrc_set_property),
5390         (gst_multifilesrc_get_property), (gst_multifilesrc_get):
5391         * gst/elements/gstmultifilesrc.h:
5392         Added newmedia property so it generates newmedia events between each
5393         file when property is set, as well as fixed eos handling
5394
5395 2004-07-22  David Schleef  <ds@schleef.org>
5396
5397         * gst/gststructure.c: (gst_structure_id_empty_new),
5398         (gst_structure_empty_new):  Set type field correctly.
5399         * gst/gststructure.h: Check type field correctly.
5400         * testsuite/caps/Makefile.am:
5401         * testsuite/caps/structure.c: (test1), (main): Add a very small
5402         test for structures.
5403
5404 2004-07-22  David Schleef  <ds@schleef.org>
5405
5406         * docs/random/ds/0.9-suggested-changes: more comments
5407         * tools/gst-launch.c: (idle_func): Fix hard-to-translate string.
5408
5409 2004-07-22  Benjamin Otte  <otte@gnome.org>
5410
5411         * gst/gstelementfactory.c: (gst_element_register):
5412           set the factory in the class struct, so gst_element_get_factory
5413           actually works
5414         * gst/parse/grammar.y:
5415           set element to playing when it gets unlocked as we can't rely on the
5416           bin state - all elements in the bin state might still be locked in
5417           NULL)
5418
5419 2004-07-22  Benjamin Otte  <otte@gnome.org>
5420
5421         * gst/gstelement.c: (gst_element_set_state_func):
5422           make this a static function
5423
5424 2004-07-22  Wim Taymans  <wim@fluendo.com>
5425
5426         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
5427         (gst_opt_scheduler_pad_link):
5428         fix 147894-2 and the group_link problem.
5429
5430 2004-07-22  Wim Taymans  <wim@fluendo.com>
5431
5432         * testsuite/schedulers/147894-2.c: (queue_empty), (queue_filled),
5433         (handoff_identity), (main):
5434         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
5435         (handoff_identity), (main):
5436         * testsuite/schedulers/Makefile.am:
5437         * testsuite/schedulers/group_link.c: (main):
5438         Show bug in scheduler when linking chain and loop based element 
5439         where the chain based element was not yet in a group.
5440
5441 2004-07-21  Benjamin Otte  <otte@gnome.org>
5442
5443         * gst/.cvsignore:
5444         * gst/autoplug/.cvsignore:
5445         * gst/elements/.cvsignore:
5446         * gst/indexers/.cvsignore:
5447         * libs/gst/bytestream/.cvsignore:
5448         * libs/gst/control/.cvsignore:
5449         * libs/gst/getbits/.cvsignore:
5450         * testsuite/states/.cvsignore:
5451         * testsuite/threads/.cvsignore:
5452           keep this up to date, since I seem to be the only one who cares
5453           about not missing files on commits (editor's note: no you don't,
5454           but feel free to change them at the time you add stuff instead
5455           of later on)
5456
5457 2004-07-21  Benjamin Otte  <otte@gnome.org>
5458
5459         * gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
5460         (gst_bin_fix_state), (gst_bin_add_func), (gst_bin_remove_func),
5461         (gst_bin_child_state_change_func), (set_kid_state_func),
5462         (gst_bin_set_state), (gst_bin_change_state_norecurse):
5463           make state changes work correctly and reentrant (so removing
5464           elements from bins during state changes of bins doesn't cause
5465           segfaults or even wrong states)
5466           add debugging category and debugging output to print children states
5467         * gst/gstbin.c: (gst_bin_dispose): 
5468           add some assertion checks
5469         * gst/gstbin.h:
5470         * gst/gstbin.c: (gst_bin_sync_children_state):
5471           deprecate this function - it just does gst_bin_set_state (bin,
5472           GST_STATE (bin)) 
5473         * testsuite/threads/queue.c: (main):
5474           don't use gst_bin_sync_children_state anymore
5475         * testsuite/states/Makefile.am:
5476         * testsuite/states/bin.c:
5477           test that the state changes of bins work as expected
5478         * gst/gstthread.c: (gst_thread_class_init), (gst_thread_set_state):
5479           some adjustments to change states correctly, too
5480         * gst/gstthread.c: (gst_thread_change_state):
5481           don't enable/disable "threadsafe" properties, they're unused and
5482           cause random segfaults
5483         * testsuite/threads/Makefile.am:
5484           the queue check randomly passes now, ignore it
5485
5486 2004-07-21  Benjamin Otte  <otte@gnome.org>
5487
5488         * gst/gstpad.c:
5489           check if data is NULL before outputting debug info. (fixes #145100)
5490
5491 2004-07-21  Benjamin Otte  <otte@gnome.org>
5492
5493         * gst/schedulers/entryscheduler.c:
5494         (gst_entry_scheduler_loop_wrapper),
5495         (gst_entry_scheduler_chain_wrapper),
5496         (gst_entry_scheduler_get_wrapper):
5497           reset the state when the cothread starts, so we don't get assertion
5498           failures on restarting of cothreads
5499
5500 2004-07-20  Benjamin Otte  <otte@gnome.org>
5501
5502         * gst/gstelement.c: (gst_element_link_pads_filtered):
5503           use correct sinkpad, if only sinkpad is specified, but not srcpad
5504           (fixes #147889)
5505         * gst/gstelement.c: (gst_element_set_state_func),
5506         (gst_element_change_state): ref/unref the element, signal handlers
5507         could get rid of the element otherwise
5508
5509 2004-07-20  Ronald Bultje  <rbultje@ronald.bitfreak.net>
5510
5511         * docs/random/ds/0.9-suggested-changes:
5512           Make note about renaming fixed-list to array.
5513         * gst/gstvalue.c: (gst_value_intersect_fixed_list),
5514         (_gst_value_initialize):
5515           Add array intersections.
5516         * testsuite/caps/intersect2.c: (main):
5517           Add test for array intersections.
5518
5519 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
5520
5521         * configure.ac: back to cvs
5522
5523 === release 0.8.4 ===
5524
5525 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
5526
5527         * configure.ac:
5528           releasing 0.8.4, "Paella"
5529           bump libtool versioning
5530
5531 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
5532
5533         * po/LINGUAS:
5534         * po/ca.po:
5535           adding Catalan translation (Jordi Mallach)
5536
5537 2004-07-20  Wim Taymans  <wim@fluendo.com>
5538
5539         * testsuite/schedulers/147894-2.c: (queue_empty), (queue_filled),
5540         (handoff_identity), (main):
5541         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
5542         (handoff_identity), (main):
5543         * testsuite/schedulers/Makefile.am:
5544         Added failing testcase for variant of #147894
5545
5546 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
5547
5548         patch by: David Moore
5549
5550         * gst/schedulers/gstoptimalscheduler.c: (group_has_element),
5551         (schedule_group), (gst_opt_scheduler_schedule_run_queue),
5552         (group_migrate_connected):
5553         * testsuite/schedulers/Makefile.am:
5554           fix for #142813 (Deadlock in optimal scheduler)
5555
5556 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
5557
5558         patch by: Wim Taymans
5559
5560         * gst/schedulers/gstoptimalscheduler.c: (group_has_element),
5561         (gst_opt_scheduler_schedule_run_queue),
5562         (gst_opt_scheduler_get_wrapper), (get_group),
5563         (group_migrate_connected):
5564         * testsuite/schedulers/Makefile.am:
5565           fix for #147819 (Add some checks in the opt scheduler)
5566
5567 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
5568
5569         patch by: Benjamin Otte
5570
5571         * gst/gstelementfactory.c: (__gst_element_details_set):
5572           fix for #147929: running gst-register in non-utf8 locale can cause
5573           invalid registry
5574
5575 2004-07-20  Thomas Vander Stichele  <thomas at apestaart dot org>
5576
5577         patch by: Wim Taymans
5578
5579         * gst/schedulers/gstoptimalscheduler.c: (group_num_elements),
5580         (group_has_element), (element_get_reachables_func),
5581         (group_migrate_connected):
5582           fix for #147894 (opt scheduler decoupled elements mismanagement)
5583         * testsuite/schedulers/Makefile.am:
5584           testsuite app now passes
5585
5586 2004-07-19  Wim Taymans  <wim@fluendo.com>
5587
5588         * testsuite/schedulers/147819.c: (handoff_identity1),
5589         (handoff_identity2), (main):
5590         * testsuite/schedulers/Makefile.am:
5591         Added testcase for bug 147819
5592
5593 2004-07-19  Wim Taymans  <wim@fluendo.com>
5594
5595         * testsuite/schedulers/147894.c: (queue_empty), (queue_filled),
5596         (handoff_identity), (main):
5597         * testsuite/schedulers/Makefile.am:
5598         Added testcase for bug 147894
5599
5600 2004-07-16  Wim Taymans  <wim@fluendo.com>
5601
5602         * testsuite/schedulers/142183-2.c: (handoff_identity), (main):
5603         * testsuite/schedulers/142183.c: (handoff_identity), (main):
5604         * testsuite/schedulers/Makefile.am:
5605         Added testsuite for bug 142183 in its two incarnations. Refcount
5606         is not increased for scheduled elements and threadsafe properties
5607         mutexes are not properly unlocked.
5608
5609 2004-07-16  Wim Taymans  <wim@fluendo.com>
5610
5611         * gst/schedulers/gstoptimalscheduler.c: (gst_opt_scheduler_init),
5612         (create_chain), (destroy_chain), (create_group), (destroy_group),
5613         (add_to_group), (merge_groups), (group_elements), (group_inc_link),
5614         (group_dec_link), (gst_opt_scheduler_pad_link),
5615         (group_inc_links_for_element), (group_migrate_connected):
5616         Call group_inc_link with the proper src->sink ordering -- 
5617         break this, and we break sort_chain. patch from wingo for bug
5618         147713.
5619         Partially revert patch 1.89. When adding a loop based element to 
5620         the scheduler, the links to other groups are automatically followed
5621         and incremented. This should not happen because the bin will call
5622         pad_link explicitly for those connection, resulting in them counted 
5623         twice. Results in assertion failure on pipeline cleanup.
5624
5625 2004-07-16  Wim Taymans  <wim@fluendo.com>
5626
5627         * testsuite/schedulers/143777-2.c: (main):
5628         * testsuite/schedulers/147713.c: (handoff_src), (handoff_sink),
5629         (main):
5630         * testsuite/schedulers/Makefile.am:
5631         Added cleanup code to testcase 143777-2.
5632         Added testcase to show bug 147713, does not really show the
5633         deadlock as I can't figure out how to trigger it, but it does
5634         demonstrate bad ordering in the scheduler.
5635
5636 2004-07-16  Thomas Vander Stichele  <thomas at apestaart dot org>
5637
5638         * gst/gstvalue.c: (gst_value_deserialize_fraction):
5639           change strndup to g_strndup.  Fixes #147707
5640
5641 2004-07-16  Thomas Vander Stichele  <thomas at apestaart dot org>
5642
5643         * po/af.po:
5644         * po/az.po:
5645         * po/cs.po:
5646         * po/en_GB.po:
5647         * po/fr.po:
5648         * po/nl.po:
5649         * po/sr.po:
5650         * po/sv.po:
5651         * po/tr.po:
5652         * po/uk.po:
5653           updated translations
5654
5655 2004-07-16  Benjamin Otte  <otte@gnome.org>
5656
5657         * gst/gstvalue.c: (gst_greatest_common_divisor):
5658           use ints and return ints, fractions only use ints, too, so this
5659           avoids accidently casting multiplications to unsigned
5660         (gst_value_lcopy_fraction): it's ints, not uint32
5661         (gst_value_set_fraction): disallow minint, multiplying and negation
5662           are broken with it
5663         (gst_value_fraction_multiply): fix to make large numbers work and get
5664         rid of the assumption that the multiplication of two ints fits an
5665         int64 - dunno if that's true for all systems
5666         * testsuite/caps/Makefile.am:
5667         * testsuite/caps/fraction-multiply-and-zero.c:
5668         (check_multiplication), (check_equal), (zero_test), (main):
5669           add tests for all the stuff above
5670         * testsuite/caps/value_compare.c: (test1):
5671           fix comment
5672         * tests/.cvsignore:
5673         * testsuite/caps/.cvsignore:
5674         * testsuite/debug/.cvsignore:
5675         * testsuite/dlopen/.cvsignore:
5676         * testsuite/states/.cvsignore:
5677           get up to date
5678
5679 2004-07-16  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5680
5681         * docs/manual/bins-api.xml:
5682         * docs/manual/factories.xml:
5683         * docs/manual/helloworld.xml:
5684         * docs/manual/links-api.xml: 
5685           fixes for out of date info, incorrect info and grammar
5686
5687 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5688
5689         * docs/manual/pads.xml:
5690         * docs/manual/pads-api.xml: grammar fix
5691
5692 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5693
5694         * docs/manual/pads-api.xml: typo + grammar fix
5695
5696 2004-07-15  Thomas Vander Stichele  <thomas at apestaart dot org>
5697
5698         * docs/gst/gstreamer-sections.txt:
5699           add new symbols
5700         * docs/gst/tmpl/gstelement.sgml:
5701         * docs/gst/tmpl/gstpad.sgml:
5702         * docs/gst/tmpl/gsttypes.sgml:
5703         * docs/gst/tmpl/gstvalue.sgml:
5704           update docs
5705         * gst/gststructure.c: (gst_structure_set_valist),
5706         (gst_structure_from_abbr), (gst_structure_to_abbr):
5707         * gst/gstvalue.c: (gst_value_compare_double), (gst_type_is_fixed),
5708         (gst_greatest_common_divisor), (gst_value_init_fraction),
5709         (gst_value_copy_fraction), (gst_value_collect_fraction),
5710         (gst_value_lcopy_fraction), (gst_value_set_fraction),
5711         (gst_value_get_fraction_numerator),
5712         (gst_value_get_fraction_denominator),
5713         (gst_value_fraction_multiply), (gst_value_serialize_fraction),
5714         (gst_value_deserialize_fraction),
5715         (gst_value_transform_fraction_string),
5716         (gst_value_transform_string_fraction),
5717         (gst_value_compare_fraction), (_gst_value_initialize):
5718         * gst/gstvalue.h:
5719           adding GstFraction GValue type, get/set, and multiply
5720         * testsuite/caps/Makefile.am:
5721         * testsuite/caps/fraction.c: (test), (main):
5722         * testsuite/caps/string-conversions.c: (main):
5723         * testsuite/caps/value_compare.c: (test1), (main):
5724           add regression tests for GstFraction
5725
5726 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5727         
5728         * docs/manual/init-api.xml: Grammar fix
5729
5730 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5731
5732         * docs/manual/states.xml: Fix inconsistent information
5733
5734 2004-07-15  Thomas Vander Stichele  <thomas at apestaart dot org>
5735
5736         * gst/gstelement.c: (gst_element_set_state):
5737         * gst/gstpad.c: (gst_pad_try_set_caps):
5738         * gst/gststructure.c:
5739         * gst/gstthread.c: (gst_thread_child_state_change):
5740         * gst/gstvalue.c: (gst_value_compare_double):
5741         * gst/gstvalue.h:
5742         * testsuite/parse/parse1.c: (main):
5743           debugging additions and style cleanups
5744
5745 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5746
5747         * docs/manual/states.xml: Grammar fix
5748
5749 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5750
5751         * docs/manual/pads.xml: Grammar fix
5752
5753 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5754
5755         * docs/manual/elements.xml: Fixed image reference
5756
5757 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5758
5759         * docs/manual/goals.xml: Grammar fix
5760
5761 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5762
5763         * docs/manual/motivation.xml:
5764         Bonobo is no longer "emerging" and added sentence regarding tcp plugins
5765
5766 2004-07-15  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5767
5768         * docs/manual/motivation.xml: Fix spelling
5769
5770 2004-07-15  Benjamin Otte  <otte@gnome.org>
5771
5772         * gst/gstelement.h: 
5773           Don't GST_ERROR_OBJECT empty strings - Solaris doesn't like NULL
5774           strings.
5775         * gst/gstelement.c (gst_element_class_init):
5776           GError's are boxed, not objects
5777         * gst/gstmarshal.list:
5778           update list for the fixed error signal
5779
5780 2004-07-14  Andy Wingo  <wingo@pobox.com>
5781
5782         * gst/gsttag.c: Add a tag merge func for pointers. The header was
5783         there all along, but the function wasn't. (guile-gstreamer's build
5784         system uses the address of the function -- I wasn't actually
5785         trying to use this.)
5786
5787 2004-07-14  Andy Wingo  <wingo@pobox.com>
5788
5789         * gst/gstpad.c (gst_pad_try_set_caps): Naive link functions (such
5790         as gst_pad_proxy_pad_link) just link to every other pad when they
5791         are called. In the case where the graph has cycles, this will mean
5792         that a call to try_set_caps will recurse. Allow this recursion
5793         and return OK, while we wait for the first try_set_caps to give a
5794         proper return value.
5795         (gst_pad_link_call_link_functions): Since this function is the
5796         only one to set the NEGOTIATING flag on a pad, if the flag is set
5797         it means that the link functions have indirectly recursed. If this
5798         happens, error out to avoid infinite recursion and an eventual
5799         SEGV.
5800         (gst_real_pad_class_init): Remove a crufty GtkObject comment.
5801         (gst_pad_proxy_getcaps): Intersect the result with the template
5802         caps to ensure that the return value is valid.
5803
5804 2004-07-14  Andy Wingo  <wingo@pobox.com>
5805
5806         * gst/gstdata.c (gst_data_is_writable): s/>=/>/. If there is only
5807         one refcount, the calling function is the owner of the buffer.
5808
5809 2004-07-14  Wim Taymans  <wim@fluendo.com>
5810
5811         * gst/schedulers/gstoptimalscheduler.c: (group_dec_link),
5812         (gst_opt_scheduler_pad_link), (group_migrate_connected):
5813         Fix stupid warning when an element is to be migrated but
5814         is already migrated.
5815
5816 2004-07-14  Wim Taymans  <wim@fluendo.com>
5817
5818         * gst/schedulers/gstoptimalscheduler.c: (group_dec_link),
5819         (gst_opt_scheduler_pad_link), (group_migrate_connected):
5820         Make sure that a single non-loop-based element does not 
5821         end up in a group. This fixes the testsuite again.
5822
5823 2004-07-14  Wim Taymans  <wim@fluendo.com>
5824
5825         * gst/schedulers/gstoptimalscheduler.c: (create_group),
5826         (add_to_group), (merge_groups), (schedule_group),
5827         (gst_opt_scheduler_get_wrapper), (group_elements),
5828         (group_dec_link), (gst_opt_scheduler_pad_link),
5829         (group_migrate_connected), (gst_opt_scheduler_pad_unlink),
5830         (gst_opt_scheduler_iterate):
5831         move isolated groups to a new chain.
5832         Emit a warning instead of segfaulting in some error cases.
5833         Fix a bug where the link count between groups was not calculated 
5834         correctly. Fixes #144510.
5835
5836 2004-07-13  Steve Lhomme  <steve.lhomme@free.fr>
5837         * gst/elements/gstfilesrc.c:
5838           Binary files support under Windows now OK
5839       
5840 2004-07-13  Benjamin Otte  <otte@gnome.org>
5841
5842           compatibility fixes for Solaris 8/gcc 2.95
5843         * configure.ac:
5844           include libintl libs in LDFLAGS
5845         * gstvalue.c (gst_value_deserialize_buffer):
5846           cast isxdigit stuff to int to silence compiler warning
5847
5848 2004-07-12  Benjamin Otte  <otte@gnome.org>
5849
5850         * gst/gsttypes.h:
5851           get rid of GST_O_READONLY, GST_FILE_MODE_READ and
5852           GST_FILE_MODE_WRITE, I don't want them in the exported headers. It
5853           just causes support madness
5854         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
5855           make it work without this
5856         * gst/indexers/gstfileindex.c: (_file_index_id_save_entries),
5857         (gst_file_index_commit):
5858           glib IO channels don't want binary mode
5859         * testsuite/bytestream/filepadsink.c: (main):
5860         * testsuite/bytestream/test1.c: (read_param_file):
5861           use "rb" instead of GST_FILE_MODE_READ, it works on POSIX systems
5862
5863 2004-07-12  Benjamin Otte  <otte@gnome.org>
5864
5865         * gst/gstelement.c: (gst_element_class_init),
5866         (gst_element_set_state), (gst_element_set_state_func):
5867           virutalize gst_element_set_state, use set_state member in class
5868           struct that was already added in 0.7 for this.
5869         * gst/gstbin.c: (gst_bin_foreach), (set_kid_state_func), 
5870         (gst_bin_change_state):
5871           make gst_bin_foreach works similar to other foreach functions, plug
5872           memleaks in it. Make functions using it work with the new approach.
5873           Document gst_bin_foreach, so it can be exported if we want to
5874         * gst/gstbin.c: (gst_bin_class_init), (gst_bin_set_state):
5875           use virtualized set_state to make set_state on bins set the state of
5876           all its children.
5877
5878 2004-07-12  Benjamin Otte  <otte@gnome.org>
5879
5880         * configure.ac:
5881           require valgrind >= 2.1 (fixes Gentoo bug 53967, see
5882           http://bugs.gentoo.org/show_bug.cgi?id=53967)
5883         * gst/gstpad.c: (gst_pad_alloc_buffer):
5884           allow buffer_alloc functions to return NULL and allocate a normal
5885           buffer in that case
5886
5887 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
5888         * gst/elements/gstfilesink.c:
5889         * gst/elements/gstfilesrc.c:
5890         * gst/indexers/gstfileindex.c:
5891         * gst/gsttypes.h:
5892         * testsuite/bytestream/filepadsink.c:
5893         * testsuite/bytestream/test1.c:
5894           Handle binary files under Windows
5895
5896 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
5897         * docs/manual/win32.xml:
5898         * win32/config.h:
5899         * win32/gst-register.vcproj:
5900         * win32/gstreamer.def:
5901           Update to another gettext public build
5902
5903 2004-07-12  Steve Lhomme  <steve.lhomme@free.fr>
5904         * gst/gstplugin.c:
5905           Fix an impossible C syntax
5906         * win32/config.h:
5907           Disable i18n under Windows for the moment
5908         * win32/gst-register.vcproj:
5909           Use this configuration
5910
5911 2004-07-12  Jan Schmidt  <thaytan@mad.scientis.com>
5912         * docs/manual/quotes.xml:
5913           Keep the quotes file alive
5914         * docs/random/ds/0.9-suggested-changes:
5915           Add the suggestion of including a 'rowstride' as part of video
5916           format caps
5917
5918 2004-07-12  Thomas Vander Stichele  <thomas at apestaart dot org>
5919
5920         * gst/gstelement.c: (gst_element_set_state),
5921         (gst_element_change_state):
5922           d'oh.  Set PENDING state correctly before forcing bin to change.
5923         * gst/gststructure.c: (gst_structure_value_get_generic_type),
5924         (gst_structure_parse_fixed_list):
5925         * gst/schedulers/gstoptimalscheduler.c:
5926         (gst_opt_scheduler_state_transition):
5927         * testsuite/states/parent.c: (main):
5928           remove comment now that it's fixed.
5929
5930 2004-07-11  Benjamin Otte  <otte@gnome.org>
5931
5932         * gst/gstclock.h:
5933           GST_SECOND shouldn't cause a conversion to unsigned.
5934         * testsuite/clock/.cvsignore:
5935         * testsuite/clock/Makefile.am:
5936         * testsuite/clock/signedness.c: (main):
5937           make sure it never will again
5938
5939 2004-07-11  Andy Wingo  <wingo@pobox.com>
5940
5941         * gst/gstbin.c (gst_bin_add_func): If we're adding an element
5942         whose state is higher than the bin state, raise the bin state to
5943         ensure that bin state := highest child state.
5944         
5945 2004-07-11  Andy Wingo  <wingo@pobox.com>
5946
5947         * gst/gstbin.c (gst_bin_foreach): New static function. Calls a
5948         procedure on the children of a bin. Assumes that the procedure can
5949         change the set of children.
5950         (set_kid_state_func): New static function.
5951         (gst_bin_change_state): Use gst_bin_foreach to call
5952         set_kid_state_func. Fixes a bug: if a child had a state-change
5953         handler that removes it from the bin, there would be a segfault.
5954         Hopefully it should also work in the case where the state-change
5955         handler on one child adds or removes other children. In any case,
5956         fixes should go to gst_bin_foreach.
5957
5958 2004-07-10  Thomas Vander Stichele  <thomas at apestaart dot org>
5959
5960         * gst/gstelement.c: (gst_element_set_state):
5961           compatibility fix for latest plugins release.  Change loop back
5962           to while {}
5963
5964 2004-07-09  Wim Taymans  <wim@fluendo.com>
5965
5966         * gst/gstbin.c: (gst_bin_remove), (gst_bin_dispose):
5967         * gst/gstthread.c: (gst_thread_dispose), (gst_thread_catch),
5968         (gst_thread_main_loop):
5969         Since remove is virtual in GstBin we must not assume the 
5970         elements GList to have anothing useful.
5971         Add some more logging to GstThread and be a bit more paranoid
5972         when resetting the scheduler.
5973         Set the state of the bin to NULL before removing the children.
5974
5975 2004-07-09  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
5976
5977         * testsuite/threads/Makefile.am:
5978         * testsuite/threads/threadg.c:
5979           added test to check if problem when removing all elements from a
5980           GstThread before setting GstThread state to NULL
5981
5982 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
5983
5984         * docs/gst/tmpl/gstelement.sgml:
5985         * docs/gst/tmpl/gsttypes.sgml:
5986         * gst/gstbin.c: (gst_bin_change_state):
5987         * gst/gstelement.c: (gst_element_set_state),
5988         (gst_element_change_state):
5989           rework so that for bins we try to set the state on all children
5990           as well even if the bin is in the correct state already.
5991           change while to do so at least one iteration is done.
5992           For regular elements, we fall back to the previous behaviour for
5993           now since we first need a new plugins release.
5994         * testsuite/states/parent.c: (main):
5995           test for this case
5996           Fixes #123774
5997
5998 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
5999
6000         * gst/gstqueue.c: (gst_queue_class_init), (gst_queue_finalize),
6001         (gst_queue_chain), (gst_queue_get), (gst_queue_handle_src_event),
6002         (gst_queue_release_locks), (gst_queue_change_state),
6003         (gst_queue_set_property):
6004           add proper lock debugging.  Change dispose to finalize, since
6005           we're freeing mutexes and other stuff which should happen only once.
6006
6007 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6008
6009         * docs/gst/tmpl/gstelement.sgml:
6010         * docs/gst/tmpl/gstplugin.sgml:
6011         * docs/gst/tmpl/gsttypes.sgml:
6012         * docs/pwg/building-state.xml:
6013         * gst/elements/gstfakesrc.c: (gst_fakesrc_change_state):
6014         * gst/gstelement.c: (gst_element_change_state):
6015         * gst/gstthread.c: (gst_thread_change_state):
6016           catch wrong state changes in element base class.
6017
6018 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6019
6020         * gst/gstinfo.h:
6021           clean up layout a little.
6022
6023 2004-07-09  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6024
6025         * configure.ac:
6026         * testsuite/Makefile.am:
6027         * testsuite/states/Makefile.am:
6028         * testsuite/states/parent.c: (main):
6029           re-enable states testsuite dir.  Add test for state changes and
6030           parent behaviour
6031
6032 2004-07-09  Wim Taymans  <wim@fluendo.com>
6033
6034         * gst/schedulers/gstoptimalscheduler.c:
6035         (gst_opt_scheduler_pad_link), (group_elements_set_visited),
6036         (element_get_reachables_func), (element_get_reachables),
6037         (debug_element), (rechain_group), (group_migrate_connected),
6038         (gst_opt_scheduler_pad_unlink):
6039         Do not try to migrate decoupled elements to a new group since
6040         they are not added to groups.
6041
6042 2004-07-08  Benjamin Otte  <otte@gnome.org>
6043
6044         * gst/gstelement.c: (gst_element_error_func):
6045           make reentrant (= allow removing elements in error handler)
6046
6047 2004-07-08  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6048
6049         * gst/gstpad.c: (gst_pad_event_default_dispatch),
6050         (gst_pad_send_event), (gst_pad_call_chain_function):
6051           events sent to elements below PAUSED cannot be handled, so
6052           don't try to
6053
6054 2004-07-08  Wim Taymans  <wim@fluendo.com>
6055
6056         * gst/schedulers/gstoptimalscheduler.c:
6057         (chain_recursively_migrate_group), (create_group),
6058         (schedule_group), (gst_opt_scheduler_pad_link),
6059         (group_elements_set_visited), (element_get_reachables_func),
6060         (element_get_reachables), (group_can_reach_group), (debug_element),
6061         (rechain_group), (group_migrate_connected),
6062         (gst_opt_scheduler_pad_unlink):
6063         * testsuite/schedulers/Makefile.am:
6064         Implemented group splitting and rechaining.
6065         Fixes 143777 and 143777-2 in the testsuite.
6066
6067 2004-07-08  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6068
6069         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_chain):
6070           extra debugging
6071         * gst/gstevent.h:
6072         * gst/gstinfo.c: (gst_debug_log_default):
6073           print time nicely.  add thread pointer until someone figures out
6074           a completely portable way of getting at thread id's.
6075         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_try),
6076         (_invent_event), (gst_pad_pull), (gst_pad_event_default_dispatch),
6077         (gst_pad_call_chain_function):
6078           extra debugging
6079         * gst/schedulers/gstoptimalscheduler.c:
6080         (get_group_schedule_function), (loop_group_schedule_function),
6081         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
6082         (pad_clear_queued), (gst_opt_scheduler_iterate):
6083           rename BUFPEN and friends to DATAPEN since that's what they are.
6084
6085 2004-07-07  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6086
6087         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_chain):
6088         * gst/gstbuffer.h:
6089         * gst/gstpad.c:
6090           cleanups and debugging
6091
6092 2004-07-07  Ronald Bultje  <rbultje@ronald.bitfreak.net>
6093
6094         * configure.ac:
6095         * gst/gstvalue.c: (gst_value_compare_enum),
6096         (gst_value_serialize_enum), (gst_value_deserialize_enum),
6097         (gst_value_can_compare), (gst_value_compare):
6098         * testsuite/Makefile.am:
6099         * testsuite/enumcaps/Makefile.am:
6100         * testsuite/enumcaps/enumcaps.c:
6101           Fix enum serialization, deserialization, comparison in caps, add
6102           a test to ensure that this continues working in the future.
6103
6104 2004-07-06  David Schleef  <ds@schleef.org>
6105
6106         * gst/gstcaps.c: (gst_caps_save_thyself), (gst_caps_load_thyself):
6107         Fix memleak.
6108
6109 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6110
6111         * gst/gstplugin.c: (gst_plugin_check_file), (gst_plugin_load_file):
6112         * gst/gstplugin.h:
6113         * gst/registries/gstxmlregistry.c:
6114         (plugin_times_older_than_recurse), (plugin_times_older_than),
6115         (gst_xml_registry_parse_padtemplate):
6116           only rebuild registry when actual plugins have a newer time than
6117           the registry.  Fixes #145520
6118
6119 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6120
6121         * docs/manual/manual.xml:
6122         * docs/manual/win32.xml:
6123           add chapter on win32 building.  fixes #142422
6124
6125 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6126
6127         patch by: Sebastien Cote <sc5 at hermes.usherb.ca>
6128
6129         * gst/autoplug/gstspider.c: (gst_spider_init),
6130         (gst_spider_dispose):
6131           fix spider memleaks.  fixes #137863
6132
6133 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6134
6135         patch by: Joe Marcus Clarke <marcus at freebsd dot org>
6136
6137         * gst/schedulers/gstoptimalscheduler.c:
6138         (gst_opt_scheduler_pad_unlink):
6139           fix SIGBUS error, fixes #145338
6140
6141 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6142
6143         * gst/gstobject.c: (gst_object_replace):
6144         * gst/gstscheduler.c: (gst_scheduler_get_clock):
6145         * gst/gstsystemclock.c: (gst_system_clock_obtain):
6146           clean up clock lifecycle.  Fixes #109831
6147
6148 2004-07-06  Thomas Vander Stichele  <thomas at apestaart dot org>
6149
6150         * po/LINGUAS:
6151         * po/cs.po:
6152           added Czech translation (Miloslav Trmac)
6153
6154 2004-07-04  David Schleef  <ds@schleef.org>
6155
6156         * tools/Makefile.am:
6157         * tools/gst-xmlinspect.1.in:  Add man page. (bug #140219)
6158
6159 2004-07-04  David Schleef  <ds@schleef.org>
6160
6161         * common/m4/gst-doc.m4: Check for docbook2html 0.6.10 (bug #139909)
6162
6163 2004-07-04  Thomas Vander Stichele  <thomas at apestaart dot org>
6164
6165         * gst/gstbin.c: (gst_bin_restore_thyself):
6166           chain to parent restore so the bins get restored correctly
6167           in the editor
6168
6169 2004-07-03  David Schleef  <ds@schleef.org>
6170
6171         * gst/gstcaps.c: (gst_caps_save_thyself), (gst_caps_load_thyself):
6172         Actually do something in these functions, like before the big
6173         caps change.  (bug #145137)
6174
6175 2004-07-03  Thomas Vander Stichele  <thomas at apestaart dot org>
6176
6177         * gst/gstelement.c: (gst_element_get_compatible_pad_template),
6178         (gst_element_get_compatible_pad_filtered):
6179         * gst/gstthread.c: (gst_thread_main_loop):
6180           more debugging
6181
6182 2004-07-02  David Schleef  <ds@schleef.org>
6183
6184         * gst/gstinfo.h: wrap #pragmas in #ifdefs for the correct compiler
6185         * gst/gstobject.h:
6186         * gst/gstparse.h:
6187         * gst/gsttrace.h:
6188         * gst/gstxml.h:
6189
6190 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
6191
6192         * gst/gstpad.c: (gst_pad_check_schedulers),
6193         (gst_pad_can_link_filtered), (gst_pad_link_filtered),
6194         (gst_pad_link_prepare):
6195           revert until testsuite is fixed
6196
6197 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
6198
6199         * testsuite/Makefile.am:
6200         * testsuite/caps/filtercaps.c: (main):
6201         * testsuite/clock/clock1.c: (main):
6202         * testsuite/dynparams/dparamstest.c: (gst_dptest_chain), (main):
6203           fix some more tests
6204
6205 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
6206
6207         * testsuite/cleanup/cleanup1.c: (create_pipeline):
6208         * testsuite/cleanup/cleanup2.c: (create_pipeline):
6209         * testsuite/cleanup/cleanup4.c: (main):
6210           fix testsuite
6211
6212 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
6213
6214         * libs/gst/control/control.c:
6215         * libs/gst/control/dparam.c:
6216         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_get_type):
6217         * libs/gst/control/dparammanager.c:
6218         * libs/gst/control/dparammanager.h:
6219         * testsuite/dynparams/Makefile.am:
6220         * testsuite/dynparams/dparamstest.c: (gst_dptest_base_init),
6221         (gst_dptest_change_state), (gst_dptest_chain), (main):
6222           fix testcase for dparams
6223           add debugging category
6224
6225 2004-07-02  Thomas Vander Stichele  <thomas at apestaart dot org>
6226
6227         * testsuite/Rules:
6228           change path
6229
6230 2004-07-02  Benjamin Otte  <otte@gnome.org>
6231
6232         * tests/.cvsignore:
6233         * tests/Makefile.am:
6234         * tests/mass_elements.c: (gst_get_current_time), (main):
6235           add simple benchmark to test various speeds of fakesrc ! identity !
6236           identity ! ... ! fakesink.
6237           Usage: mass_elements [num_identities] [num_buffers]
6238           If not specified they default to 1000.
6239
6240 2004-07-02  Benjamin Otte  <otte@gnome.org>
6241
6242         * gst/gstpad.c: (gst_pad_check_schedulers),
6243         (gst_pad_can_link_filtered), (gst_pad_link_filtered),
6244         (gst_pad_link_prepare):
6245           check that pads that get linked belong to the same manager. The old
6246           code allowed linking elements before putting them into bins, so it
6247           worked to link them and then put them in different threads, which
6248           lead to weird behaviour.
6249           Since this effectively disallows linking elements before putting
6250           them in a bin, some applications might not work after this and error
6251           out. If these applications are too critical, we might need to revert
6252           that patch. Please test this before the next release...
6253
6254 2004-06-28  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6255
6256         * gst/gstpad.c: (gst_pad_get_caps):
6257           throw an error if the getcaps function does not return a subset of
6258           the template caps.
6259         * libs/gst/bytestream/filepad.c: (gst_file_pad_chain):
6260           make disconts without position info an error in debugging
6261         * tests/spidey_bench.c: (handoff), (main):
6262           don't count first try when averaging
6263
6264 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
6265
6266         * gst/gstplugin.c: (gst_plugin_load_file):
6267           figure out problem with dynamic test
6268
6269 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
6270
6271         * docs/gst/Makefile.am:
6272           fix docs build
6273
6274 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
6275
6276         * po/POTFILES.in:
6277         * po/af.po:
6278         * po/az.po:
6279         * po/en_GB.po:
6280         * po/fr.po:
6281         * po/nl.po:
6282         * po/sr.po:
6283         * po/sv.po:
6284         * po/tr.po:
6285         * po/uk.po:
6286         * tools/gst-register.c: (plugin_added_func), (main):
6287           i18n-ize -register, fix plural
6288
6289 2004-06-26  Thomas Vander Stichele  <thomas at apestaart dot org>
6290
6291         * gst/elements/gstidentity.c: (gst_identity_class_init),
6292         (gst_identity_init), (gst_identity_chain),
6293         (gst_identity_set_property), (gst_identity_get_property):
6294         * gst/elements/gstidentity.h:
6295           check for perfect stream
6296
6297 2004-06-25  Thomas Vander Stichele  <thomas at apestaart dot org>
6298
6299         * gst/elements/gstidentity.c: (gst_identity_chain):
6300           print offset_end
6301
6302 2004-06-25  Thomas Vander Stichele  <thomas at apestaart dot org>
6303
6304         * docs/gst/Makefile.am:
6305         * docs/gst/gstreamer-docs.sgml:
6306           doc fixes
6307
6308 2004-06-24  David Schleef  <ds@schleef.org>
6309
6310         * autogen.sh:  Remove call to env, since the buildbot isn't
6311         broken anymore.
6312
6313 2004-06-24  Wim Taymans  <wim@fluendo.com>
6314
6315         * gst/elements/Makefile.am:
6316         * gst/elements/gstelements.c:
6317         * gst/elements/gstmultifdsink.c: (gst_multifdsink_base_init),
6318         (gst_multifdsink_class_init), (gst_multifdsink_init),
6319         (gst_multifdsink_add), (gst_multifdsink_remove),
6320         (gst_multifdsink_clear), (gst_multifdsink_chain),
6321         (gst_multifdsink_set_property), (gst_multifdsink_get_property):
6322         * gst/elements/gstmultifdsink.h:
6323         Added an element that writes to multiple filedescriptors at once.
6324
6325 2004-06-24  Benjamin Otte  <otte@gnome.org>
6326
6327         * gst/parse/grammar.y:
6328           don't try to link elements before they have been added to bins
6329
6330 2004-06-24  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6331
6332         * libs/gst/bytestream/filepad.c: (gst_file_pad_available),
6333         (gst_file_pad_get_length):
6334         * libs/gst/bytestream/filepad.h:
6335           add 2 new functions
6336
6337 2004-06-22  Zaheer Abbas Merali  <zaheerabbas at merali dot org>
6338
6339         * docs/gst/gstreamer-sections.txt:
6340         remove from docs, the define that Benjamin removed from gstelement.h
6341
6342 2004-06-22  Benjamin Otte  <otte@gnome.org>
6343
6344         * gst/gstelement.h:
6345           remove define that referenced a nonexisting GstElement struct member
6346
6347 2004-06-20  Benjamin Otte  <otte@gnome.org>
6348
6349         * gst/gstdata.c: (gst_data_is_writable):
6350           whoops, return values were wrong, so writable data was marked as
6351           non-writable and vice versa. (fixes #143953, spotted by Francis
6352           Labonte)
6353           Shows how rarely we need to copy data ;)
6354
6355 2004-06-20  Benjamin Otte  <otte@gnome.org>
6356
6357         * testsuite/schedulers/.cvsignore:
6358         * testsuite/schedulers/Makefile.am:
6359         * testsuite/schedulers/143777-2.c: (main):
6360           add test for opt breakage in bug #143777
6361
6362 2004-06-20  Benjamin Otte  <otte@gnome.org>
6363
6364         * gst/gstpad.c: (gst_pad_call_chain_function):
6365           check for if we were unlinked while inside the chainfunction (fixes
6366           entrygthread having issues with #143777)
6367         * testsuite/schedulers/143777.c: (main):
6368         * testsuite/schedulers/Makefile.am:
6369           add a test for that fix
6370
6371 2004-06-20  Benjamin Otte  <otte@gnome.org>
6372
6373         * gst/gstvalue.c: (gst_value_set_int_range):
6374           test that start is smaller then end
6375         * libs/gst/bytestream/Makefile.am:
6376         * libs/gst/bytestream/filepad.c: 
6377         * libs/gst/bytestream/filepad.h:
6378           add GstFilePad - a pad that behaves like a FILE*
6379         * testsuite/bytestream/.cvsignore:
6380         * testsuite/bytestream/Makefile.am:
6381         * testsuite/bytestream/filepadsink.c: 
6382           test for the GstFilePad
6383
6384 2004-06-18  Thomas Vander Stichele  <thomas at apestaart dot org>
6385
6386         * gst/elements/gstidentity.c: (gst_identity_class_init),
6387         (gst_identity_init), (gst_identity_set_clock),
6388         (gst_identity_chain), (gst_identity_set_property),
6389         (gst_identity_get_property):
6390         * gst/elements/gstidentity.h:
6391         * gst/gstclock.c: (gst_clock_id_wait):
6392           add a "sync" property to sync to the clock
6393
6394 2004-06-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6395
6396         * gst/gstelementfactory.c: (gst_element_factory_create):
6397           make the freakin "elementfactory bla has no type" message more
6398           useful. So we actually can do something when someone shows up
6399           complaining about it.
6400
6401 2004-06-15  Johan Dahlin  <johan@gnome.org>
6402
6403         * tools/gst-inspect.c (main): Fallback to plugin if no element is
6404         found. This matches the old behavior better. Thanks to Thomas for
6405         pointing out.
6406
6407 2004-06-14  David Schleef  <ds@schleef.org>
6408
6409         * gst/gstcpu.c: (gst_cpuid_i386): Fix problem when using
6410         -fomit-frame-pointer.  Appears to generate correct code in
6411         other cases as well.
6412
6413 2004-06-14  Johan Dahlin  <johan@gnome.org>
6414
6415         * tools/gst-inspect.c (main): Add two new command line options: -a
6416         to print all elements and -n to print the name on each line. Also
6417         fix some error reporting.
6418         (main): Simplify, remove -n and always print names if -a is specified
6419
6420 2004-06-13  Steve Lhomme  <steve.lhomme@free.fr>
6421
6422         * win32/gstconfig.h:
6423         * win32/GSTreamer.vcproj:
6424         * win32/Makefile:
6425         * gst/gstconfig.h.in:
6426         * gst/gst.h:
6427         * gst/gstbin.h:
6428         * gst/gstelement.h:
6429         * gst/gstevent.h:
6430         * gst/gstobject.h:
6431         * gst/gstpad.h:
6432         * docs/gst/gstreamer-sections.txt:
6433         * docs/gst/tmpl/gstconfig.sgml:
6434           rename GSTREAMER_EXPORT(S) to GST_EXPORT(S)
6435
6436 2004-06-13  Jan Schmidt  <thaytan@mad.scientist.com>
6437         * docs/gst/gstreamer-sections.txt:
6438         * docs/gst/tmpl/gstconfig.sgml:
6439         Add the GSTREAMER_EXPORT macro to the docs
6440
6441 2004-06-13  Jan Schmidt  <thaytan@mad.scientist.com>
6442
6443         * tools/gst-compprep.c: (handle_xmlerror), (main):
6444         Add a check for the version that introduced SetStructuredError to fix
6445         the build on FC1
6446
6447 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
6448
6449         * win32/msvc71.sln:
6450         * win32/testsuite/:
6451           prepare to compile the testsuite with MSVC
6452
6453 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
6454
6455         * docs/manual/win32.xml:
6456           attempt to transform the Win32 README into an XML doc
6457
6458 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
6459
6460         * gst/gst.c:
6461         * gst/gstbin.*:
6462         * gst/config.h.in:
6463         * gst/gstelement.*:
6464         * gst/gstevent.h:
6465         * gst/gstobject.*:
6466         * gst/gstpad.h:
6467         * tools/gst-register.c:
6468         * win32/gstreamer.def:
6469           extern symbols are now exported for the Windows DLL
6470
6471 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
6472
6473         * gst/gstinfo.h:
6474           fix a problem to enable/disable DEBUG under MSVC
6475
6476 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
6477
6478         * win32/:
6479           enable more debug code in DEBUG build
6480
6481 2004-06-12  Steve Lhomme  <steve.lhomme@free.fr>
6482
6483         * win32/config.h:
6484         * gst/gst-i18n-app.h:
6485           enable NLS under Windows
6486
6487 2004-06-12  Jan Schmidt  <thaytan@mad.scientist.com>
6488         * tools/gst-compprep.c: (handle_xmlerror), (main):
6489           Make an error that baffled me a bit clearer
6490
6491 2004-06-12  Thomas Vander Stichele  <thomas at apestaart dot org>
6492
6493         * gst/gstqueue.c:
6494           don't use g_queue_get_length () because it's 2.4, use ->length
6495
6496 2004-06-11  Steve Lhomme  <steve.lhomme@free.fr>
6497
6498         reviewed by Benjamin Otte  <in7y118@public.uni-hamburg.de>
6499
6500         * tools/gst-inspect.c: (print_signal_info):
6501           don't free random data twice. (fixes #144185)
6502
6503 2004-06-11  Thomas Vander Stichele  <thomas at apestaart dot org>
6504
6505         * gst/gstqueue.c:
6506         * gst/gstqueue.h:
6507           fix removing from the wrong queue on event timeout
6508           fix disposing of the event queue by casting correctly
6509           add mutexes for handling the event queue
6510           someone was sleeping when fixing queue last time around :)
6511
6512 2004-06-10  Johan Dahlin  <johan@gnome.org>
6513
6514         * gst/gst.c (gst_init_check_with_popt_table): Do not fail on
6515         errors, like gtk. It makes it more useful in bindings.  Fixes #141692.
6516
6517 2004-06-09  Thomas Vander Stichele  <thomas at apestaart dot org>
6518
6519         * docs/random/gdp:
6520         * libs/gst/dataprotocol/dataprotocol-test.c: (buffer_test):
6521         * libs/gst/dataprotocol/dataprotocol.c:
6522         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
6523         (gst_dp_buffer_from_header):
6524         * libs/gst/dataprotocol/dataprotocol.h:
6525         * libs/gst/dataprotocol/dp-private.h:
6526           rev version to 0.1, add buffer flags and copy them
6527
6528 2004-06-09  Johan Dahlin  <johan@gnome.org>
6529
6530         * gst/gstbuffer.c (gst_buffer_default_copy): Don't forget to merge
6531         the flags from the buffer we're copying.
6532
6533 2004-06-09  Wim Taymans  <wim@fluendo.com>
6534
6535         * gst/elements/gstfakesink.c: (gst_fakesink_chain):
6536         * gst/elements/gstidentity.c: (gst_identity_init),
6537         (gst_identity_chain):
6538         Print more buffer info in fakesink.
6539         Make identity output similar to fakesink.
6540
6541 2004-06-07  Daniel Gazard  <dany42@free.fr>
6542
6543         reviewed by Benjamin Otte  <otte@gnome.org>
6544
6545         * configure.ac:
6546           fix cross compiling not working. (fixes #143741)
6547
6548 2004-06-07  Benjamin Otte  <otte@gnome.org>
6549
6550         * gst/gstelement.c: (gst_element_set_time_delay):
6551           add failure check
6552         * gst/gstinfo.h:
6553           put brackets around macro arguments of GST_TIME_ARGS, add note to
6554           move it to correct header in 0.9
6555
6556 2004-06-07  Benjamin Otte  <otte@gnome.org>
6557
6558         * gst/indexers/gstfileindex.c: (gst_file_index_get_writer_id),
6559         (gst_file_index_load), (_file_index_id_save_entries),
6560         (gst_file_index_commit), (gst_file_index_add_association),
6561         (gst_file_index_add_entry), (gst_file_index_get_assoc_entry),
6562         (gst_file_index_plugin_init):
6563           make debugging use a default category
6564
6565 2004-06-06  David Moore  <dcm@acm.org>
6566
6567         reviewed by Benjamin Otte  <otte@gnome.org>
6568
6569         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init),
6570         (gst_fdsrc_change_state):
6571           reset offset counter when going READY => PAUSED. (fixes #142903)
6572
6573 2004-06-06  ed@catmur.co.uk
6574
6575         reviewed by Benjamin Otte  <otte@gnome.org>
6576
6577         * gst/registries/gstxmlregistry.c:
6578         (gst_xml_registry_rebuild_recurse):
6579           don't rely on g_dir_open to figure out if a file is a directory, use
6580           explicit G_TEST_IS_DIR. Reiserfs4 allows opening files as
6581           directories. (fixes #142850)
6582
6583 2004-06-06  Benjamin Otte  <otte@gnome.org>
6584
6585         * gst/gstqueue.c: (gst_queue_dispose), (gst_queue_change_state):
6586           fix memory leaks (fixes #142795). Initial patch by Sebastien Cote
6587         * libs/gst/bytestream/adapter.c:
6588         * libs/gst/bytestream/adapter.h:
6589           fix copyright in header and typo in debugging category name
6590
6591 2004-06-05  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6592
6593         * configure.ac:
6594           bump nano to cvs
6595
6596 === release 0.8.3 ===
6597
6598 2004-06-05  Thomas Vander Stichele  <thomas at apestaart dot org>
6599
6600         * configure.ac:
6601           update libtool versioning
6602           do a new release
6603         * docs/gst/tmpl/gstelement.sgml:
6604         * docs/gst/tmpl/gsttypes.sgml:
6605         * gst/gstinfo.c: (_gst_debug_init):
6606           put back GST_CAT_DATAFLOW to fix API breakage
6607
6608 2004-06-04  David Schleef  <ds@schleef.org>
6609
6610         * autogen.sh: Add a temporary 'env' to test buildbot problems.
6611
6612 2004-06-04  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6613
6614         * configure.ac:
6615           bump nano to cvs
6616
6617 === release 0.8.2 ===
6618
6619 2004-06-03  Thomas Vander Stichele  <thomas at apestaart dot org>
6620
6621         * gst/gst.c: (parse_debug_list), (gst_init_check_with_popt_table):
6622           check GST_DEBUG environment variable which is parsed the same way
6623           as --gst-debug=
6624
6625 2004-05-28  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
6626
6627         * gst/elements    : gstaggregator.c gstfakesink.c gstfakesrc.c
6628                             gstmd5sink.c gstshaper.c gsttee.c
6629                             gsttypefindelement.c
6630         * gst/schedulers  : gstbasicscheduler.c gstoptimalscheduler.c
6631
6632           - removing trailing commas at end of enums
6633             it is correct C99 code but C90 compilers would complain
6634             (AIX, Forte, ...)
6635             ('should' fix #143290, at least partially)
6636
6637 2004-05-27  Wim Taymans  <wim@fluendo.com>
6638
6639         * gst/schedulers/gstoptimalscheduler.c: (remove_from_chain),
6640         (chain_group_set_enabled), (create_group), (add_to_group),
6641         (merge_groups), (setup_group_scheduler), (group_elements),
6642         (gst_opt_scheduler_iterate), (gst_opt_scheduler_show):
6643         Don't try to follow the pad connections with other groups
6644         when a loop based element is added to the scheduler because
6645         the bin will inform the scheduler about the pad links a little
6646         later.
6647
6648 2004-05-27  Wim Taymans  <wim@fluendo.com>
6649
6650         * gst/schedulers/gstoptimalscheduler.c: (add_to_chain),
6651         (remove_from_chain), (chain_group_set_enabled),
6652         (setup_group_scheduler), (group_element_set_enabled),
6653         (gst_opt_scheduler_state_transition), (gst_opt_scheduler_iterate),
6654         (gst_opt_scheduler_show):
6655         Elements without a group can do a state change as well, just wait
6656         with the setup of the scheduling function when it is added to a
6657         chain.
6658
6659 2004-05-27  Wim Taymans  <wim@fluendo.com>
6660
6661         * gst/schedulers/gstoptimalscheduler.c: (add_to_chain),
6662         (remove_from_chain), (chain_group_set_enabled), (add_to_group),
6663         (merge_groups), (setup_group_scheduler),
6664         (group_inc_links_for_element), (gst_opt_scheduler_iterate),
6665         (gst_opt_scheduler_show):
6666         Fixes to maintain internal consistency of the scheduler data
6667         structures. 
6668          - adding an enabled group to a chain should increment the
6669            number of enabled elements in that chain.
6670          - removing an enabled group from a chain could disable the
6671            chain.
6672          - removing a disabled group from a chain could enable the
6673            chain.
6674          - add g_assert when internal inconsistency is detected.
6675          - adding an element to a group could increase the number of
6676            links this group has with other groups.
6677          - merging two groups also merges the chains.
6678          - also show group links in the _show method.
6679            
6680
6681 2004-05-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6682
6683         * gst/gstcaps.c: (gst_caps_structure_simplify):
6684           don't print error messages when there is no error
6685         * gst/gstvalue.c: (gst_value_compare_int_range):
6686           compare the second value, too
6687         * testsuite/caps/Makefile.am:
6688         * testsuite/caps/random.c: (assert_on_error), (main):
6689           add tests to make sure the two things above are checked for
6690
6691 2004-05-24  Thomas Vander Stichele  <thomas at apestaart dot org>
6692
6693         * configure.ac:
6694         * libs/gst/dataprotocol/Makefile.am:
6695         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_packet_from_caps):
6696         * libs/gst/dataprotocol/dataprotocol.h:
6697           wrap header in GST_ENABLE_NEW.  make code use it
6698
6699 2004-05-23  Johan Dahlin  <johan@gnome.org>
6700
6701         * tools/gst-inspect.c (main): Cleanup most parts of it, don't be
6702         so verbose and print GstElement signal names all the time.
6703
6704 2004-05-22  David Schleef  <ds@schleef.org>
6705
6706         * gst/registries/gstxmlregistry.c:
6707         (gst_xml_registry_parse_padtemplate): Fix warning on OS X.
6708         (bug #142957)
6709
6710 2004-05-22  Thomas Vander Stichele  <thomas at apestaart dot org>
6711
6712         * configure.ac:
6713           scrub cflags for glib2 so gcc doesn't complain when glib is in
6714           /usr/local
6715
6716 2004-05-21  Johan Dahlin  <johan@gnome.org>
6717
6718         * gst/gstcpu.c (gst_cpuid_i386): Protect some gcc asm stuff with
6719         __GNUC__, patch from Brian Cameron, fixes bug #142804
6720
6721 2004-05-20  David Schleef  <ds@schleef.org>
6722
6723         * gst/gstindex.c: (gst_index_compare_func): Fix overflows in
6724         comparison code.  (bug #142819)
6725
6726 2004-05-20  Wim Taymans  <wim@fluendo.com>
6727
6728         * gst/gstbuffer.c: (gst_buffer_default_copy):
6729         * gst/gstbuffer.h:
6730         Added Comment to a flag.
6731         copy relevant flags in _buffer_copy.
6732
6733 2004-05-20  Thomas Vander Stichele  <thomas at apestaart dot org>
6734
6735         reviewed by: Wim Taymans <wim at fluendo dot com>
6736
6737         * gst/gstbuffer.h:
6738           add GST_BUFFER_IN_CAPS buffer flag
6739         * gst/gststructure.c: (gst_structure_value_get_generic_type),
6740         (gst_structure_parse_any_list), (gst_structure_parse_list),
6741         (gst_structure_parse_fixed_list), (gst_structure_parse_value):
6742         * gst/gstvalue.c: (gst_value_serialize_any_list),
6743         (gst_value_transform_any_list_string),
6744         (gst_value_list_prepend_value), (gst_value_list_append_value),
6745         (gst_value_list_get_size), (gst_value_list_get_value),
6746         (gst_value_transform_list_string),
6747         (gst_value_transform_fixed_list_string),
6748         (gst_value_serialize_list), (gst_value_serialize_fixed_list),
6749         (gst_value_deserialize_fixed_list), (gst_type_is_fixed),
6750         (_gst_value_initialize):
6751         * gst/gstvalue.h:
6752           add a GST_TYPE_FIXED_LIST which is fixed by definition and uses
6753           < , > as a format.
6754         * testsuite/caps/string-conversions.c: (main):
6755           add regression tests for < >
6756
6757 2004-05-20  Johan Dahlin  <johan@gnome.org>
6758
6759         * docs/gst/Makefile.am (all-local): Re-add
6760
6761 2004-05-20  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
6762
6763         * docs/gst/Makefile.am:
6764         * docs/gst/gstreamer-docs.sgml:
6765         * docs/libs/Makefile.am:
6766         * docs/libs/gstreamer-libs-docs.sgml:
6767           fix distcheck issues
6768
6769 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
6770
6771         * libs/gst/dataprotocol/Makefile.am:
6772           add to autotest
6773
6774 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
6775
6776         * libs/gst/dataprotocol/Makefile.am:
6777         * libs/gst/dataprotocol/dataprotocol.c:
6778         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
6779         (gst_dp_packet_from_event), (gst_dp_event_from_packet):
6780         * libs/gst/dataprotocol/dp-private.h:
6781           use GST macros to read/write fixed length ints
6782           add some more asserts
6783
6784 2004-05-19  Thomas Vander Stichele  <thomas at apestaart dot org>
6785
6786         * docs/libs/gstreamer-libs-docs.sgml:
6787         * docs/libs/gstreamer-libs-sections.txt:
6788           remove idct and putbits
6789         * configure.ac:
6790         * docs/libs/tmpl/gstdataprotocol.sgml:
6791         * libs/gst/Makefile.am:
6792         * libs/gst/dataprotocol/Makefile.am:
6793         * libs/gst/dataprotocol/dataprotocol-test.c: (conversion_test),
6794         (buffer_test), (caps_test), (event_test), (main):
6795         * libs/gst/dataprotocol/dataprotocol.c: (gst_dp_crc),
6796         (gst_dp_dump_byte_array), (gst_dp_init),
6797         (gst_dp_header_payload_length), (gst_dp_header_payload_type),
6798         (gst_dp_header_from_buffer), (gst_dp_packet_from_caps),
6799         (gst_dp_packet_from_event), (gst_dp_buffer_from_header),
6800         (gst_dp_caps_from_packet), (gst_dp_event_from_packet),
6801         (gst_dp_validate_header), (gst_dp_validate_payload),
6802         (gst_dp_validate_packet), (plugin_init):
6803         * libs/gst/dataprotocol/dataprotocol.h:
6804         * libs/gst/dataprotocol/dp-private.h:
6805           add dataprotocol
6806
6807 2004-05-19  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6808
6809         * gst/gstvalue.c: (gst_value_deserialize_int_helper):
6810           fix int variable deserialization and add a helper so we can actually
6811           debug this.
6812
6813 2004-05-18  David Schleef  <ds@schleef.org>
6814
6815         * testsuite/debug/commandline.c: (main): Call ./commandline, not
6816           argv[0].  Calling yourself is probably not the best way to
6817           construct a test like this, btw.
6818
6819 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6820
6821         * gst/gstbin.c: (gst_bin_iterate_func), (gst_bin_iterate):
6822           don't claim to be more intelligent than a scheduler when the
6823           scheduler claims the pipeline is stopped
6824         * gst/schedulers/entryscheduler.c: (safe_cothread_switch),
6825         (safe_cothread_destroy),
6826         (gst_entry_scheduler_remove_all_cothreads),
6827         (gst_entry_scheduler_reset), (_remove_cothread),
6828         (gst_entry_scheduler_state_transition):
6829           hold off cothread destruction if we're not in main cothread
6830         * configure.ac:
6831         * testsuite/Makefile.am:
6832           add new test dir
6833         * testsuite/schedulers/.cvsignore:
6834         * testsuite/schedulers/Makefile.am:
6835           add tests
6836         * testsuite/schedulers/relink.c: (cb_handoff), (main):
6837           check relinking and adding/removing elements from a running pipeline
6838         * testsuite/schedulers/unlink.c: (cb_handoff), (main):
6839           check unlinking in a running pipeline
6840         * testsuite/schedulers/unref.c: (cb_handoff), (main):
6841           check unreffing a running pipeline
6842         * testsuite/schedulers/useless_iteration.c: (main):
6843           check iterating a pipeline that contains running threads works
6844
6845 2004-05-18  David Schleef  <ds@schleef.org>
6846
6847         * docs/gst/Makefile.am: Add all-local target for when HAVE_GTK_DOC
6848           is false.
6849
6850 2004-05-18  Wim Taymans  <wim@fluendo.com>
6851
6852         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
6853         (setup_group_scheduler), (gst_opt_scheduler_pad_link):
6854         Fixed an error introduced with patch for 1.63. When setting
6855         a get based element as the entry point in a group, make sure
6856         to mark the group as GET based.
6857
6858 2004-05-18  Wim Taymans  <wim@fluendo.com>
6859
6860         * gst/schedulers/gstoptimalscheduler.c: (create_group),
6861         (setup_group_scheduler), (loop_group_schedule_function),
6862         (gst_opt_scheduler_pad_link):
6863         Added some more debug info and fixed a bug where the group
6864         type was set to LOOP but it was in fact unknown.
6865
6866 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6867
6868         * gst/schedulers/entryscheduler.c: (gst_entry_scheduler_reset):
6869           make resetting scheduler work twice in a row
6870
6871 2004-05-18  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6872
6873         * gst/gstvalue.c: (gst_strtoll), (CREATE_SERIALIZATION),
6874         (CREATE_USERIALIZATION), (_gst_value_initialize),
6875         (gst_value_compare_float), (gst_value_serialize_float),
6876         (gst_value_deserialize_float), (gst_value_compare_enum),
6877         (gst_value_serialize_enum), (gst_value_deserialize_enum):
6878           add serialization and comparison functions for long, int64, enum and
6879           float values
6880         * gst/gstvalue.c: (gst_value_serialize), (gst_value_deserialize):
6881           use best serialization function in type hierarchy instead of only a
6882           matching one. This is required for enums to work.
6883         * gst/parse/grammar.y:
6884           use gst_caps_deserialize
6885         * testsuite/parse/Makefile.am:
6886           parse1 now works
6887         * testsuite/parse/parse1.c: (main):
6888           remove aggregator check, aggregator is broken, this test works now
6889           but fails because of bug #138012
6890         * testsuite/parse/parse2.c: (main):
6891           s/xvideosink/xvimagesink - this test looks a lot like we should
6892           disable it
6893
6894 2004-05-13  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6895
6896         * gst/gstelement.c: (gst_element_class_init):
6897           whoops, store the signal id correctly
6898         * gst/schedulers/gstbasicscheduler.c:
6899         (gst_basic_scheduler_chain_wrapper):
6900           detect infinfinfinfinfinf^Cinite loops in chain wrapper when the
6901           chain function isn't linked
6902
6903 2004-05-13  Jan Schmidt  <thaytan@mad.scientist.com>
6904         * configure.ac:
6905         Add $GST_PKG_CFLAGS back into GST_INT_CFLAGS so I have large file
6906         support until we decide where the flags should be used
6907         * gst/elements/gstfilesrc.c: (gst_filesrc_srcpad_query):
6908         Use GST_FORMAT_BYTES when GST_FORMAT_DEFAULT is passed
6909         * gst/gstpad.c: (gst_pad_link_call_link_functions):
6910         Output refused caps in the debug info
6911
6912 2004-05-13  Thomas Vander Stichele  <thomas at apestaart dot org>
6913
6914         * gst/elements/gstidentity.c: (gst_identity_chain):
6915           add duration debug
6916         * gst/gstinfo.c: (gst_debug_log_default):
6917           add timestamp
6918
6919 2004-05-13  Benjamin Otte  <otte@gnome.org>
6920
6921         * gst/gstpipeline.c: (gst_pipeline_dispose),
6922         (gst_pipeline_change_state):
6923           call gst_scheduler_reset on dispose (fixes #141416)
6924
6925 2004-05-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
6926
6927         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
6928           compute mapsize correctly
6929         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap):
6930           use correct datatypes when calling a varargs function
6931         * gst/elements/gsttypefindelement.c: (stop_typefinding):
6932           push a DISCONT event as first thing
6933         * gst/gst_private.h:
6934         * gst/gstinfo.c: (_gst_debug_init):
6935           remove GST_DATAFLOW debugging category
6936         * gst/gstbin.c: (gst_bin_iterate):
6937           use GST_SCHEDULING category
6938         * gst/gstpad.c: (gst_pad_get_type), (_invent_event),
6939         (gst_pad_push), (gst_pad_pull), (gst_pad_call_chain_function),
6940         (gst_pad_call_get_function):
6941           add GST_DATAFLOW to easily track flow of buffers or events.
6942         * gst/gstqueue.c: (gst_queue_get_type),
6943         (gst_queue_handle_pending_events), (gst_queue_chain),
6944         (gst_queue_get), (gst_queue_handle_src_event):
6945           use own static debugging category GST_DATAFLOW for dataflow,
6946           use DEBUG category for showing which path events go, use LOG
6947           category for buffers.
6948
6949 2004-05-10  David Schleef  <ds@schleef.org>
6950
6951         * docs/gst/gstreamer-sections.txt: Add gst_element_no_more_pads.
6952
6953 2004-05-10  David Schleef  <ds@schleef.org>
6954
6955         * docs/gst/Makefile.am: Dear gtk-doc, please print out the unused
6956         symbols, because otherwise we don't know what they are.  Thanks,
6957         the GStreamer team.
6958         * gst/registries/gstxmlregistry.c: (make_dir): Remove a spurious ;
6959
6960 2004-05-10  David Schleef  <ds@schleef.org>
6961
6962         (from Steve Lhomme)
6963         * win32/Makefile: When using make clean the MS Visual Studio makefiles
6964         are deleted.  Fix.
6965         * win32/Makefile.inspect:
6966         * win32/Makefile.launch:
6967         * win32/Makefile.register:
6968
6969 2004-05-10  David Schleef  <ds@schleef.org>
6970
6971         * gst/gstinfo.h: Add missing inline function.
6972         * gst/gsttrace.c: add include
6973         * gst/parse/grammar.y: remove unused code
6974         * gst/registries/gstxmlregistry.c: (make_dir): make mkdir call
6975         more portable.
6976         * tools/gst-register.c: wrap unistd.h
6977         
6978         More additions/fixes from Steve for the MSVC build.
6979         * win32/GStreamer.vcproj:
6980         * win32/Makefile:
6981         * win32/Makefile.inspect:
6982         * win32/Makefile.launch:
6983         * win32/Makefile.register:
6984         * win32/README.txt:
6985         * win32/gst-inspect.vcproj:
6986         * win32/gst-launch.vcproj:
6987         * win32/gst-register.vcproj:
6988         * win32/gstbytestream.def:
6989         * win32/gstbytestream.vcproj:
6990         * win32/gstconfig.h:
6991         * win32/gstelements.def:
6992         * win32/gstelements.vcproj:
6993         * win32/gstenumtypes.c:
6994         * win32/gstenumtypes.h:
6995         * win32/gstoptimalscheduler.def:
6996         * win32/gstoptimalscheduler.vcproj:
6997         * win32/gstreamer.def:
6998         * win32/gstspider.def:
6999         * win32/gstspider.vcproj:
7000         * win32/gstversion.h:
7001         * win32/msvc71.sln:
7002
7003 2004-05-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7004
7005         * gst/gstelement.c: (gst_element_class_init),
7006         (gst_element_no_more_pads):
7007         * gst/gstelement.h:
7008           add gst_element_no_more_pads and the "no-more-pads" signal
7009
7010 2004-05-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7011
7012         * gst/gstregistry.c: (gst_registry_add_plugin):
7013           refuse to add plugins when a plugin with same name is already
7014           registered. Fixes a bunch of "How to remove plugins?" issues.
7015           May lead to other problems though, let's test
7016
7017 2004-05-10  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
7018
7019         * testsuite/caps/caps_strings : audio/ac3 => audio/x-ac3
7020         * docs/manual/pads-api.xml : audio/wav => audio/x-wav
7021         * docs/random/uraeus/gstreamer_and_midi.txt : audio/wav => audio/x-wav
7022
7023 2004-05-09  Thomas Vander Stichele  <thomas at apestaart dot org>
7024
7025         * tests/Makefile.am: fix am16 issue
7026
7027 2004-05-09  Benjamin Otte  <otte@gnome.org>
7028
7029         * libs/gst/bytestream/Makefile.am:
7030           we should indeed add .c files to makefiles or they won't be built
7031           (d'oh)
7032
7033 2004-05-08  Benjamin Otte  <otte@gnome.org>
7034
7035         * gst/gstpad.c: (gst_pad_proxy_fixate):
7036           really reduce the set of caps
7037
7038 2004-05-08  Benjamin Otte  <otte@gnome.org>
7039
7040         * tests/Makefile.am:
7041         * tests/spidey_bench.c: (handoff), (main):
7042           add benchmark to test how long spider needs to create a pipeline
7043
7044 2004-05-08  Benjamin Otte  <otte@gnome.org>
7045
7046         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_unnegotiate):
7047           mark links as unengaged when unnegotiating instead of deactivating.
7048           This way pads aren't marked as unengaged when going PLAYING=>PAUSED
7049
7050 2004-05-08  Benjamin Otte  <otte@gnome.org>
7051
7052         * docs/manual/helloworld.xml:
7053           s/audiosink/osssink (patch by Patrick Guimond)
7054
7055 2004-05-07  David Schleef  <ds@schleef.org>
7056
7057         * configure.ac: Make sure GST_INT_CFLAGS is not clobbered,
7058         since it contains important stuff.
7059
7060 2004-05-07  David Schleef  <ds@schleef.org>
7061
7062         * testsuite/caps/caps.c: (test3), (main): A check for appending
7063         ANY caps.
7064
7065 2004-05-07  David Schleef  <ds@schleef.org>
7066
7067         * common/m4/as-compiler-flag.m4: Properly quote arguments,
7068         which may contain commas.  Fixes detection of -Wa,-mregnames
7069
7070 2004-05-06  David Schleef  <ds@schleef.org>
7071
7072         Changes to handle compilers that don't have variadic macro
7073         support.  In particular, glib headers define some inlines
7074         that need G_LOG_DOMAIN defined.  Additional fixes for MSVC
7075         builds.
7076         * gst/Makefile.am:
7077         * gst/cothreads.c:
7078         * gst/elements/gstfdsink.c:
7079         * gst/elements/gstfdsrc.c:
7080         * gst/elements/gstfilesink.c:
7081         * gst/elements/gstfilesrc.c:
7082         * gst/gst_private.h:
7083         * gst/gstatomic.c:
7084         * gst/gstcaps.c: (gst_caps_append):
7085         * gst/gstcpu.c: (gst_cpuid_i386):
7086         * gst/gstelement.c:
7087         * gst/gsterror.c:
7088         * gst/gstfilter.c:
7089         * gst/gstinfo.h:
7090         * gst/gstprobe.c:
7091         * gst/gstquery.c:
7092         * gst/gstregistry.c:
7093         * gst/gststructure.c:
7094         * gst/gsttaginterface.c:
7095         * gst/gsttrace.c: (gst_trace_new):
7096         * gst/gsttrashstack.c:
7097         * gst/gsturi.c:
7098         * gst/gstvalue.c:
7099         * gst/parse/grammar.y:
7100         * gst/parse/parse.l:
7101         * tools/gst-inspect.c: (main):
7102         * tools/gst-launch.c: (main):
7103         * tools/gst-xmlinspect.c: (PUT_STRING):
7104
7105 2004-05-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7106
7107         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
7108         (gst_filesrc_change_state), (gst_filesrc_srcpad_event):
7109         * gst/elements/gstfilesrc.h:
7110           send NEW_MEDIA events correctly
7111         * gst/elements/gsttypefindelement.c: (start_typefinding),
7112         (gst_type_find_element_handle_event):
7113           restart typefinding when we get a NEW_MEDIA event
7114         * gst/gstbin.c: (gst_bin_remove_func), (gst_bin_change_state),
7115         (gst_bin_dispose):
7116           don't die when someone removes elements in callbacks
7117         * gst/gstelement.c: (gst_element_change_state):
7118           improve debugging
7119         * gst/gstpad.c: (gst_pad_pull), (gst_pad_call_chain_function):
7120           we need a NEW_MEDIA event to engage a link
7121         * gst/gsttrace.c: (gst_trace_new), (gst_alloc_trace_set_flags_all):
7122           don't g_print debugging stuff
7123         * testsuite/caps/simplify.c: (check_caps):
7124
7125 2004-05-04  Benjamin Otte  <otte@gnome.org>
7126
7127         * gst/parse/grammar.y:
7128           use GST_ERROR instead of g_warning, and always throw a GST_ERROR 
7129
7130 2004-05-04  Benjamin Otte  <otte@gnome.org>
7131
7132         * testsuite/caps/renegotiate.c: (main):
7133           improve output in error case
7134
7135 2004-05-04  Benjamin Otte  <otte@gnome.org>
7136
7137         * gst/parse/grammar.y:
7138           fix assert to not trigger when there's no error argument
7139         * gst/parse/parse.l:
7140           fix definition of caps to allow more than two structures
7141         * testsuite/caps/Makefile.am:
7142         * testsuite/caps/renegotiate.c: (main):
7143           it's sinesrc and works in that case
7144
7145 2004-05-04  Wim Taymans  <wim@fluendo.com>
7146
7147         * gst/schedulers/gstoptimalscheduler.c: (remove_from_group),
7148         (group_dec_link), (gst_opt_scheduler_pad_unlink):
7149         when removing an element from a group, we always need to
7150         decrement the link count that this group had with other 
7151         groups through the element.
7152         added an extra assert to catch inconsistencies when decrementing
7153         the link count.
7154
7155 2004-05-04  Thomas Vander Stichele  <thomas at apestaart dot org>
7156
7157         * configure.ac:
7158         * docs/gst/Makefile.am:
7159         * docs/gst/gstreamer-sections.txt:
7160         * docs/gst/tmpl/gstcompat.sgml:
7161         * examples/appreader/Makefile.am:
7162         * examples/cutter/Makefile.am:
7163         * examples/events/Makefile.am:
7164         * examples/helloworld/Makefile.am:
7165         * examples/helloworld2/Makefile.am:
7166         * examples/launch/Makefile.am:
7167         * examples/manual/Makefile.am:
7168         * examples/mixer/Makefile.am:
7169         * examples/pingpong/Makefile.am:
7170         * examples/plugins/Makefile.am:
7171         * examples/queue/Makefile.am:
7172         * examples/queue2/Makefile.am:
7173         * examples/queue3/Makefile.am:
7174         * examples/queue4/Makefile.am:
7175         * examples/retag/Makefile.am:
7176         * examples/thread/Makefile.am:
7177         * examples/typefind/Makefile.am:
7178         * examples/xml/Makefile.am:
7179         * gst/Makefile.am:
7180         * gst/autoplug/Makefile.am:
7181         * gst/elements/Makefile.am:
7182         * gst/gstcompat.h:
7183         * gst/indexers/Makefile.am:
7184         * gst/parse/Makefile.am:
7185         * gst/registries/Makefile.am:
7186         * gst/schedulers/Makefile.am:
7187         * libs/gst/bytestream/Makefile.am:
7188         * libs/gst/control/Makefile.am:
7189         * libs/gst/getbits/Makefile.am:
7190         * po/af.po:
7191         * po/az.po:
7192         * po/en_GB.po:
7193         * po/fr.po:
7194         * po/nl.po:
7195         * po/sr.po:
7196         * po/sv.po:
7197         * po/tr.po:
7198         * po/uk.po:
7199         * tests/Makefile.am:
7200         * tests/bufspeed/Makefile.am:
7201         * tests/instantiate/Makefile.am:
7202         * tests/memchunk/Makefile.am:
7203         * tests/muxing/Makefile.am:
7204         * tests/negotiation/Makefile.am:
7205         * tests/probes/Makefile.am:
7206         * tests/sched/Makefile.am:
7207         * tests/seeking/Makefile.am:
7208         * tests/threadstate/Makefile.am:
7209         * testsuite/caps/Makefile.am:
7210         * testsuite/cleanup/Makefile.am:
7211         * testsuite/dlopen/Makefile.am:
7212         * testsuite/dynparams/Makefile.am:
7213         * testsuite/plugin/Makefile.am:
7214         * testsuite/states/Makefile.am:
7215         * tools/Makefile.am:
7216           reorganize compile/link flags to be consistent
7217           put gst_info in gstcompat.h and actually use GST_DISABLE_DEPRECATED
7218
7219 2004-05-04  David Schleef  <ds@schleef.org>
7220
7221         The "once more, with feeling" check-in.
7222         * testsuite/caps/Makefile.am: dist caps_strings
7223         * testsuite/caps/renegotiate.c: (main): This test triggers a
7224           segfault in the core.  Marking as failing.
7225
7226 2004-05-03  David Schleef  <ds@schleef.org>
7227
7228         * testsuite/caps/deserialize.c: (main): Fix problems noticed
7229           by the build bots.
7230         * testsuite/caps/renegotiate.c: (main): Same.
7231
7232 2004-05-03  David Schleef  <ds@schleef.org>
7233
7234         * testsuite/caps/renegotiate.c: (my_fixate), (main): Another test.
7235
7236 2004-05-03  David Schleef  <ds@schleef.org>
7237
7238         * testsuite/caps/deserialize.c: (main): Use the srcdir environment
7239           variable to find our source file.
7240
7241 2004-05-03  David Schleef  <ds@schleef.org>
7242
7243         * configure.ac:  Link plugins with libgstreamer and dependent
7244           libraries
7245         * testsuite/caps/Makefile.am:
7246         * testsuite/caps/caps_strings:
7247         * testsuite/caps/deserialize.c: (main): Add a little test to slog
7248           through a file of caps strings and test each one
7249
7250 2004-05-04  Benjamin Otte  <otte@gnome.org>
7251
7252         * libs/gst/bytestream/Makefile.am:
7253         * libs/gst/bytestream/adapter.c: 
7254         * libs/gst/bytestream/adapter.h:
7255           add GstAdapter, similar to bytestream, but doesn't require ugly event
7256           handling or uglier loopbased elements
7257
7258 2004-05-03  David Schleef  <ds@schleef.org>
7259
7260         * testsuite/caps/Makefile.am: Fix spelling of Ηρατοσθενες
7261         * testsuite/caps/erathostenes.c:
7262         * testsuite/caps/eratosthenes.c: (eratosthenes), (main):
7263
7264 2004-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
7265
7266         * docs/pwg/pwg.xml:
7267           remove hardcoded stylesheet path (duh)
7268         * docs/random/release:
7269         * docs/gst/gstreamer-sections.txt:
7270         * gst/Makefile.am:
7271         * gst/gst.h:
7272         * gst/gst_private.h:
7273         * gst/gstcaps.c:
7274         * gst/gstevent.c:
7275         * gst/gstformat.c:
7276         * gst/gstinfo.c:
7277         * gst/gstinfo.h:
7278         * gst/gstinterface.c:
7279         * gst/gstmemchunk.c:
7280         * gst/gstprobe.c:
7281         * gst/gstquery.c:
7282         * gst/gstregistry.c:
7283         * gst/gstregistrypool.c:
7284         * gst/gststructure.c:
7285         * gst/gsttaginterface.c:
7286         * gst/gstthread.c:
7287         * gst/gsttrace.c:
7288         * gst/gsttypefind.c: (gst_type_find_factory_get_type):
7289         * gst/gsturi.c:
7290         * gst/gstvalue.c:
7291           deprecate gst_info; remove gstlog.h
7292    
7293
7294 2004-05-03  Thomas Vander Stichele  <thomas at apestaart dot org>
7295
7296         * Makefile.am:
7297         * po/en_GB.po:
7298         * po/sv.po:
7299         * po/uk.po:
7300           updated translations
7301
7302 2004-05-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7303
7304         * gst/gstbin.c: (gst_bin_dispose):
7305           better debugging
7306
7307 2004-05-03  Johan Dahlin  <johan@gnome.org>
7308
7309         * gst/schedulers/gstoptimalscheduler.c
7310         (gst_opt_scheduler_pad_unlink): Check if element is non-NULL and
7311         really is a GstElement. Avoids critical when running gst-launch -v
7312         and a oggdemux/decoding pipeline.
7313
7314 2004-05-02  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
7315
7316         * docs/gst/tmpl/gstpipeline.sgml :
7317         * docs/manual/elements-api.xml :
7318                 doc fix by Patrick Guimond (Protector) from devel ML
7319                 reviewed by ronald
7320
7321 2004-05-02  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
7322
7323         * docs/gst/Makefile.am :
7324         * docs/libs/Makefile.am :
7325                 apply a patch from Arwed v. Merkatz so that gtk-doc
7326                 generated docs install (same for .devhelp file)
7327                 (fixes part 1 of #138836)
7328
7329 2004-04-30  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
7330
7331         * docs/faq/dependencies.xml: typo
7332         * docs/faq/getting.xml :
7333             - fix download URL for new gstreamer site
7334             - hide sf.net download page as latest version aren't there
7335             - fix apt URLs
7336             - fill "get via CVS" paragraph (link to dev page on the site)
7337         * docs/faq/general.xml:
7338             hide status tables as they no more exists
7339             change case on plugins license file to reflect reality
7340         * docs/faq/troubleshooting.xml:
7341             remove the wiki question/answer as there is no more wiki
7342
7343 2004-04-30  Thomas Vander Stichele  <thomas at apestaart dot org>
7344
7345         * gst/gsterror.h:
7346           include the headers needed for declarations used in this header
7347
7348 2004-04-30  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
7349
7350         * docs/random/uraeus/gstreamer_and_midi.txt :
7351           add .kar (midi + karaoke/lyrics 'track') doc to midi doc.
7352           (fixes #132288)
7353
7354 2004-04-30  Sebastien Cote  <sc5@hermes.usherb.ca>
7355
7356         reviewed by Benjamin Otte  <otte@gnome.org>
7357
7358         * gst/schedulers/gthread-cothreads.h:
7359           free allocated data for main cothread, too when destroying context
7360           (fixes #141417)
7361
7362 2004-04-29  Stephane Loeuillet <stephane.loeuillet@tiscali.fr>
7363
7364         * docs/manual/goals.xml : remove duplicated paragraph at end 
7365         of doc page (fixes #141448)
7366
7367 2004-04-29  David Schleef  <ds@schleef.org>
7368
7369         * gst/elements/gstfilesink.c: (gst_filesink_handle_event):
7370         Patch from Sebastien Cote to fix leakage of events. (bug #141414)
7371
7372 2004-04-29  Thomas Vander Stichele  <thomas at apestaart dot org>
7373
7374         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
7375           fix property
7376         * gst/gstcaps.c:
7377           fix doc string
7378         * po/POTFILES.in:
7379           rename typefind source file
7380
7381 2004-04-28  David Schleef  <ds@schleef.org>
7382
7383         Several new files from Steve Lhomme's MSVC patch (bug #141317):
7384         * win32/GStreamer.vcproj:
7385         * win32/Makefile:
7386         * win32/config.h:
7387         * win32/dirent.c: (_topendir), (_treaddir), (_tclosedir),
7388         (_trewinddir), (_ttelldir), (_tseekdir):
7389         * win32/dirent.h:
7390         * win32/gst-inspect.vcproj:
7391         * win32/gst-launch.vcproj:
7392         * win32/gst-register.vcproj:
7393         * win32/gstbytestream.vcproj:
7394         * win32/gstelements.vcproj:
7395         * win32/gstoptimalscheduler.vcproj:
7396         * win32/gstspider.vcproj:
7397         * win32/gtchar.h:
7398         * win32/mman.c: (mmap), (mprotect), (msync), (munmap):
7399         * win32/mman.h:
7400         * win32/mman.inl:
7401         * win32/msvc71.sln:
7402
7403 2004-04-29  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7404
7405         * gst/gst.c: (init_post):
7406         * gst/gstinfo.c:
7407           remove useless _gst_progname stuff
7408         * tools/gst-inspect.c: (print_field), (print_caps):
7409           improve caps output
7410
7411 2004-04-28  David Schleef  <ds@schleef.org>
7412
7413         Disable parsing of a lot of files that aren't part of the
7414         exported API.  Move corresponding template files to old/,
7415         waiting for removal when they don't contain anything
7416         interesting.
7417         * docs/gst/Makefile.am:
7418         * docs/gst/gstreamer-sections.txt:
7419         * docs/gst/tmpl/cothreads.sgml:
7420         * docs/gst/tmpl/cothreads_compat.sgml:
7421         * docs/gst/tmpl/gettext.sgml:
7422         * docs/gst/tmpl/gobject2gtk.sgml:
7423         * docs/gst/tmpl/grammar.tab.sgml:
7424         * docs/gst/tmpl/gst-i18n-app.sgml:
7425         * docs/gst/tmpl/gst-i18n-lib.sgml:
7426         * docs/gst/tmpl/gst_private.sgml:
7427         * docs/gst/tmpl/gstaggregator.sgml:
7428         * docs/gst/tmpl/gstarch.sgml:
7429         * docs/gst/tmpl/gstatomic_impl.sgml:
7430         * docs/gst/tmpl/gstbufferstore.sgml:
7431         * docs/gst/tmpl/gstdata_private.sgml:
7432         * docs/gst/tmpl/gstdisksink.sgml:
7433         * docs/gst/tmpl/gstdisksrc.sgml:
7434         * docs/gst/tmpl/gstelementfactory.sgml:
7435         * docs/gst/tmpl/gstextratypes.sgml:
7436         * docs/gst/tmpl/gstfakesink.sgml:
7437         * docs/gst/tmpl/gstfakesrc.sgml:
7438         * docs/gst/tmpl/gstfdsink.sgml:
7439         * docs/gst/tmpl/gstfdsrc.sgml:
7440         * docs/gst/tmpl/gstfilesink.sgml:
7441         * docs/gst/tmpl/gstfilesrc.sgml:
7442         * docs/gst/tmpl/gsthttpsrc.sgml:
7443         * docs/gst/tmpl/gstidentity.sgml:
7444         * docs/gst/tmpl/gstindexfactory.sgml:
7445         * docs/gst/tmpl/gstmarshal.sgml:
7446         * docs/gst/tmpl/gstmd5sink.sgml:
7447         * docs/gst/tmpl/gstmultidisksrc.sgml:
7448         * docs/gst/tmpl/gstmultifilesrc.sgml:
7449         * docs/gst/tmpl/gstpadtemplate.sgml:
7450         * docs/gst/tmpl/gstpipefilter.sgml:
7451         * docs/gst/tmpl/gstschedulerfactory.sgml:
7452         * docs/gst/tmpl/gstsearchfuncs.sgml:
7453         * docs/gst/tmpl/gstshaper.sgml:
7454         * docs/gst/tmpl/gstspider.sgml:
7455         * docs/gst/tmpl/gstspideridentity.sgml:
7456         * docs/gst/tmpl/gststatistics.sgml:
7457         * docs/gst/tmpl/gsttee.sgml:
7458         * docs/gst/tmpl/gsttimecache.sgml:
7459         * docs/gst/tmpl/gsttypefind.sgml:
7460         * docs/gst/tmpl/gsttypefindfactory.sgml:
7461         * docs/gst/tmpl/gstxmlregistry.sgml:
7462         * docs/gst/tmpl/gthread-cothreads.sgml:
7463         * docs/gst/tmpl/old/cothreads.sgml:
7464         * docs/gst/tmpl/old/cothreads_compat.sgml:
7465         * docs/gst/tmpl/old/gettext.sgml:
7466         * docs/gst/tmpl/old/gobject2gtk.sgml:
7467         * docs/gst/tmpl/old/grammar.tab.sgml:
7468         * docs/gst/tmpl/old/gst-i18n-app.sgml:
7469         * docs/gst/tmpl/old/gst-i18n-lib.sgml:
7470         * docs/gst/tmpl/old/gst_private.sgml:
7471         * docs/gst/tmpl/old/gstaggregator.sgml:
7472         * docs/gst/tmpl/old/gstarch.sgml:
7473         * docs/gst/tmpl/old/gstatomic_impl.sgml:
7474         * docs/gst/tmpl/old/gstbufferstore.sgml:
7475         * docs/gst/tmpl/old/gstdata_private.sgml:
7476         * docs/gst/tmpl/old/gstdisksink.sgml:
7477         * docs/gst/tmpl/old/gstdisksrc.sgml:
7478         * docs/gst/tmpl/old/gstelementfactory.sgml:
7479         * docs/gst/tmpl/old/gstextratypes.sgml:
7480         * docs/gst/tmpl/old/gstfakesink.sgml:
7481         * docs/gst/tmpl/old/gstfakesrc.sgml:
7482         * docs/gst/tmpl/old/gstfdsink.sgml:
7483         * docs/gst/tmpl/old/gstfdsrc.sgml:
7484         * docs/gst/tmpl/old/gstfilesink.sgml:
7485         * docs/gst/tmpl/old/gstfilesrc.sgml:
7486         * docs/gst/tmpl/old/gsthttpsrc.sgml:
7487         * docs/gst/tmpl/old/gstidentity.sgml:
7488         * docs/gst/tmpl/old/gstindexfactory.sgml:
7489         * docs/gst/tmpl/old/gstmarshal.sgml:
7490         * docs/gst/tmpl/old/gstmd5sink.sgml:
7491         * docs/gst/tmpl/old/gstmultidisksrc.sgml:
7492         * docs/gst/tmpl/old/gstmultifilesrc.sgml:
7493         * docs/gst/tmpl/old/gstpadtemplate.sgml:
7494         * docs/gst/tmpl/old/gstpipefilter.sgml:
7495         * docs/gst/tmpl/old/gstschedulerfactory.sgml:
7496         * docs/gst/tmpl/old/gstsearchfuncs.sgml:
7497         * docs/gst/tmpl/old/gstshaper.sgml:
7498         * docs/gst/tmpl/old/gstspider.sgml:
7499         * docs/gst/tmpl/old/gstspideridentity.sgml:
7500         * docs/gst/tmpl/old/gststatistics.sgml:
7501         * docs/gst/tmpl/old/gsttee.sgml:
7502         * docs/gst/tmpl/old/gsttimecache.sgml:
7503         * docs/gst/tmpl/old/gsttypefindfactory.sgml:
7504         * docs/gst/tmpl/old/gstxmlregistry.sgml:
7505         * docs/gst/tmpl/old/gthread-cothreads.sgml:
7506         * docs/gst/tmpl/old/types.sgml:
7507         * docs/gst/tmpl/types.sgml:
7508
7509         Rename gsttypefind.[ch] back to gsttypefindelement.[ch], since
7510         gtkdoc-scan doesn't like files with the same name in different
7511         directories.
7512         * gst/elements/Makefile.am:
7513         * gst/elements/gstelements.c:
7514         * gst/elements/gsttypefind.c: 
7515         * gst/elements/gsttypefind.h:
7516         * gst/elements/gsttypefindelement.c:
7517         * gst/elements/gsttypefindelement.h:
7518
7519 2004-04-28  David Schleef  <ds@schleef.org>
7520
7521         A bunch of portability fixes, derived from Steve Lhomme's MSVC
7522         patch (bug #141317):
7523         * gst/gst-i18n-lib.h: Allow disabling gettext.
7524         * gst/gstatomic_impl.h: disable warning when it's dumb.
7525         * gst/gstclock.c: fix include
7526         * gst/gstcompat.h: fix variadic macro
7527         * gst/gstinfo.c: fix include
7528         * gst/gstmacros.h: add defines for inlines on MSVC
7529         * gst/gstplugin.c: fix includes
7530         * gst/gstregistry.c: fix includes
7531         * gst/gstregistry.h: use S_IREAD, etc., if S_IRUSR isn't defined
7532         * gst/gstsystemclock.c: fix include
7533         * gst/gsttrace.c: (gst_trace_new), (gst_trace_text_flush): use
7534         S_IREAD if S_IRUSR isn't defined.  fix use of non-portable functions
7535         * gst/registries/gstxmlregistry.c:
7536         (gst_xml_registry_parse_element_factory): fix use of non-portable
7537         functions
7538         * libs/gst/control/dparam.h: Remove trailing comma in enum definition
7539         * libs/gst/control/dparammanager.h: same
7540
7541 2004-04-28  David Schleef  <ds@schleef.org>
7542
7543         Move a bunch of unused files to old/ with names that are
7544         not case-insensitive-unique.  These files still contain some
7545         useful information that needs to be merged into gstbin.sgml,
7546         etc., so they shouldn't be deleted yet.
7547         * docs/gst/tmpl/GstBin.sgml:
7548         * docs/gst/tmpl/GstBuffer.sgml:
7549         * docs/gst/tmpl/GstCaps.sgml:
7550         * docs/gst/tmpl/GstClock.sgml:
7551         * docs/gst/tmpl/GstCompat.sgml:
7552         * docs/gst/tmpl/GstData.sgml:
7553         * docs/gst/tmpl/GstElement.sgml:
7554         * docs/gst/tmpl/GstEvent.sgml:
7555         * docs/gst/tmpl/GstIndex.sgml:
7556         * docs/gst/tmpl/GstStructure.sgml:
7557         * docs/gst/tmpl/GstTag.sgml:
7558         * docs/gst/tmpl/old/GstBin.sgml:
7559         * docs/gst/tmpl/old/GstBuffer.sgml:
7560         * docs/gst/tmpl/old/GstCaps.sgml:
7561         * docs/gst/tmpl/old/GstClock.sgml:
7562         * docs/gst/tmpl/old/GstCompat.sgml:
7563         * docs/gst/tmpl/old/GstData.sgml:
7564         * docs/gst/tmpl/old/GstElement.sgml:
7565         * docs/gst/tmpl/old/GstEvent.sgml:
7566         * docs/gst/tmpl/old/GstIndex.sgml:
7567         * docs/gst/tmpl/old/GstStructure.sgml:
7568         * docs/gst/tmpl/old/GstTag.sgml:
7569
7570 2004-04-28  David Schleef  <ds@schleef.org>
7571
7572         * gst/gstcaps.c: (gst_caps_copy), (gst_caps_free),
7573         (gst_caps_append), (gst_caps_append_structure),
7574         (gst_caps_get_size), (gst_caps_get_structure), (gst_caps_copy_1),
7575         (gst_caps_set_simple), (gst_caps_set_simple_valist),
7576         (gst_caps_is_any), (gst_caps_is_empty), (gst_caps_is_chained),
7577         (gst_caps_is_fixed), (gst_caps_is_always_compatible),
7578         (gst_caps_intersect), (gst_caps_normalize),
7579         (gst_caps_transform_to_string):  Patch from Tim-Philipp Müller
7580         to fix GST_CAPS() and GST_IS_CAPS(). (bug #141304)
7581         * gst/gstcaps.h: use GST_IS_CAPS().
7582
7583 2004-04-26  David Schleef  <ds@schleef.org>
7584
7585         * gst/gstcpu.c: (gst_cpuid_i386): Don't clobber ebx in inline
7586         assembly.  gcc doesn't handle it correctly. (bug #141083)
7587         * gst/gsttrashstack.h: same
7588
7589 2004-04-25  Benjamin Otte  <otte@gnome.org>
7590
7591         * gst/gstelement.c: (gst_element_change_state):
7592           fix assertion to do an int comparison
7593
7594 2004-04-25  Benjamin Otte  <otte@gnome.org>
7595
7596         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
7597           better debugging output on error
7598
7599 2004-04-25  Benjamin Otte  <otte@gnome.org>
7600
7601         * gst/gstcaps.c: (gst_caps_subtract):
7602           fix memleak
7603
7604 2004-04-23  Benjamin Otte  <otte@gnome.org>
7605
7606         * gst/gstvalue.c: (gst_value_compare_buffer),
7607         (_gst_value_initialize):
7608           add comparison function for buffers
7609
7610 2004-04-22  Ronald Bultje  <rbultje@ronald.bitfreak.net>
7611
7612         * docs/pwg/pwg.xml:
7613           Just found out that this so-called "ima-wav" format is really
7614           just "dvi adpcm" (according to the MS WAV documentation). So
7615           renaming it. We didn't use it yet anyway.
7616
7617 2004-04-23  Benjamin Otte  <otte@gnome.org>
7618
7619         * gst/gstcaps.c: (gst_caps_is_always_compatible):
7620           call gst_caps_is_subset
7621
7622 2004-04-23  Benjamin Otte  <otte@gnome.org>
7623
7624         * gst/gstcaps.c: (gst_caps_subtract), (gst_caps_is_equal), 
7625         (gst_caps_is_subset):
7626           add documentation
7627
7628 2004-04-23  Benjamin Otte  <otte@gnome.org>
7629           
7630         * gst/gstcaps.c: (gst_caps_structure_subtract_field),
7631         (gst_caps_structure_subtract), (gst_caps_subtract),
7632         (gst_caps_structure_figure_out_union),
7633         (gst_caps_structure_simplify), (gst_caps_do_simplify):
7634           fix simplifying and subtracting not working correctly with optional
7635           properties
7636           solve assorted problems that make it now simplify ebven more
7637         * docs/gst/tmpl/gstcaps.sgml:
7638         * gst/gstcaps.h:
7639           make gst_caps_do_simplify return a bool to indicate if it simplified
7640         * testsuite/caps/simplify.c: (main):
7641           add more checks. The tests is quite a bit useless right now because
7642           the core is heavily simplifying itself.
7643         * testsuite/caps/caps.h:
7644           fix caps to contain all optional properties
7645
7646 2004-04-22  Benjamin Otte  <otte@gnome.org>
7647
7648         * docs/gst/tmpl/gstcaps.sgml:
7649         * docs/gst/tmpl/gstfilesrc.sgml:
7650         * docs/gst/tmpl/gststructure.sgml:
7651         * docs/gst/tmpl/gstvalue.sgml:
7652           update for recent API changes
7653         * gst/gstcaps.c: (gst_caps_do_simplify):
7654           fix to stop trying with a freed structure
7655         * gst/gstpad.c: (gst_pad_link_fixate):
7656           simplify caps
7657         * gst/gstpad.c: (gst_pad_template_get_caps_by_name):
7658           remove C++ comment
7659         * gst/gstpad.h:
7660           deprecate gst_pad_template_get_caps_by_name, it doesn't work anyway
7661         * gst/gststructure.c: (gst_structure_value_get_generic_type),
7662         (gst_structure_to_string):
7663           keep the correct type when using lists of ranges
7664         * gst/gstvalue.c: (gst_value_list_prepend_value),
7665         (gst_value_list_append_value):
7666           copy the value before adding to the list (d'oh)
7667         * gst/gstvalue.c: (gst_value_subtract_int_range_int),
7668         (gst_value_subtract_int_range_int_range):
7669           handle overflows correctly
7670         * gst/gstvalue.c: (gst_value_subtract_from_list):
7671           fix memleak
7672         * testsuite/caps/caps.h:
7673           add a caps that caused segfaults
7674
7675 2004-04-22  Benjamin Otte  <otte@gnome.org>
7676
7677         * testsuite/refcounting/pad.c: (main):
7678           fix test
7679
7680 2004-04-22  Benjamin Otte  <otte@gnome.org>
7681
7682         * gst/gstcaps.c: (gst_caps_subtract):
7683           allow subtracting ANY and EMPTY from ANY caps
7684
7685 2004-04-22  Benjamin Otte  <otte@gnome.org>
7686
7687         * gst/gstcaps.c: (gst_caps_append), (gst_caps_intersect),
7688         (gst_caps_union):
7689           only simplify in functions that create new caps. Simplifying in
7690           gst_caps_append breaks tests.
7691
7692 2004-04-22  Benjamin Otte  <otte@gnome.org>
7693
7694         * gst/gstcaps.c: (gst_caps_structure_simplify):
7695           unset GValue after use
7696         * gst/gstcaps.c: (gst_caps_append), 
7697         * gst/gstpad.c: (gst_pad_link_fixate), (gst_pad_template_new):
7698           use gst_caps_simplify (reduces registry size by 30%)
7699         * gst/gstpad.c: (gst_pad_template_new):
7700           don't allow NULL caps
7701
7702 2004-04-22  Benjamin Otte  <otte@gnome.org>
7703
7704         * docs/gst/gstreamer-sections.txt:
7705           add gst_caps_do_simplify
7706         * gst/gstcaps.c:
7707           add documentation for gst_caps_do_simplify
7708         * gst/gstvalue.h:
7709           fix typo in gst_value_register_subtract_func declaration for gst-doc
7710
7711 2004-04-22  Benjamin Otte  <otte@gnome.org>
7712
7713         * gst/gstcaps.c: (gst_caps_from_string_inplace):
7714           fix bug when converting from empty string.
7715         * gst/gstcaps.c: (gst_caps_new_any), (gst_caps_new_simple),
7716         (gst_caps_new_full_valist), (gst_caps_copy), (gst_caps_copy_1):
7717           use gst_caps_new_empty to allocate a new caps. Only that function
7718           allocates memory for caps now.
7719         * gst/gstcaps.c: (gst_caps_remove_and_get_structure),
7720         (gst_caps_remove_structure):
7721           add ability to remove one structure (but not to header yet)
7722         * gst/gstcaps.c: (gst_caps_compare_structures),
7723         (gst_caps_simplify), (gst_caps_structure_figure_out_union),
7724         (gst_caps_structure_simplify), (gst_caps_do_simplify),
7725         * gst/gstcaps.h:
7726           add gst_caps_do_simplify that tries to simplify a caps in place.
7727           Deprecate old gst_caps_simplify function.
7728         * testsuite/caps/caps.h:
7729           add caps.h containing a common set of caps to test against.
7730         * testsuite/caps/sets.c: (check_caps), (main):
7731           use it.
7732         * testsuite/caps/.cvsignore:
7733         * testsuite/caps/Makefile.am:
7734         * testsuite/caps/simplify.c: (check_caps), (main):
7735           add test to check correctness and efficency of caps simplification.
7736
7737 2004-04-22  Sebastien Cote <sc5@hermes.usherb.ca>
7738
7739         reviewed by Benjamin Otte  <otte@gnome.org>
7740
7741         * gst/gstparse.c: (_gst_parse_escape):
7742           Free the GString used in _gst_parse_escape()
7743
7744 2004-04-21  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7745
7746         * gst/gstpad.c: (gst_pad_link_negotiate):
7747           refuse to link if the link is not possible
7748         * configure.ac:
7749         * testsuite/Makefile.am:
7750         * testsuite/negotiation/.cvsignore:
7751         * testsuite/negotiation/Makefile.am:
7752         * testsuite/negotiation/pad_link.c: (main):
7753           add test that checks the above behaviour
7754
7755 2004-04-21  Thomas Vander Stichele  <thomas at apestaart dot org>
7756
7757         * docs/gst/gstreamer-sections.txt:
7758           add newly added API
7759
7760 2004-04-21  Thomas Vander Stichele  <thomas at apestaart dot org>
7761
7762         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
7763         (gst_filesrc_get_mmap), (gst_filesrc_get_read), (gst_filesrc_get),
7764         (gst_filesrc_open_file), (gst_filesrc_close_file),
7765         (gst_filesrc_srcpad_query), (gst_filesrc_srcpad_event):
7766         * gst/elements/gstfilesrc.h:
7767           add support for non-regular files (#140734)
7768
7769 2004-04-21  Benjamin Otte  <otte@gnome.org>
7770
7771         * gst/gstpad.c: (gst_pad_link_fixate):
7772           add sophisticated error checking code to see if fixation functions
7773           did their fixation right
7774
7775 2004-04-21  Benjamin Otte  <otte@gnome.org>
7776
7777         * gst/gstcaps.c: (gst_caps_append), (gst_caps_union):
7778           check for ANY caps before appending/unioning
7779         * gst/gstcaps.c: (gst_caps_is_subset),
7780         (gst_caps_is_equal), (gst_caps_structure_subtract_field),
7781         (gst_caps_structure_subtract), (gst_caps_subtract):
7782         * gst/gstcaps.h:
7783           add gst_caps_is_equal, gst_caps_is_subset and gst_caps_subtract to
7784           the API. deprecate gst_caps_is_equal_fixed
7785         * gst/gstpad.c: (gst_pad_try_set_caps):
7786         * gst/gstqueue.c: (gst_queue_link):
7787           s/gst_caps_is_equal_fixed/gst_caps_is_equal/
7788         * gst/gststructure.c: (gst_structure_get_name_id):
7789         * gst/gststructure.h:
7790           add function gst_structure_get_name_id
7791         * gst/gstvalue.c: (gst_value_subtract_int_int_range),
7792         (gst_value_create_new_range), (gst_value_subtract_int_range_int),
7793         (gst_value_subtract_int_range_int_range),
7794         (gst_value_subtract_double_double_range),
7795         (gst_value_subtract_double_range_double),
7796         (gst_value_subtract_double_range_double_range),
7797         (gst_value_subtract_from_list), (gst_value_subtract_list),
7798         (gst_value_can_intersect), (gst_value_subtract),
7799         (gst_value_can_subtract), (gst_value_register_subtract_func),
7800         (_gst_value_initialize):
7801         * gst/gstvalue.h:
7802           add support for subtracting values from each other. Note that
7803           subtracting means subtracting as in set theory. Required for caps
7804           stuff above.
7805         * testsuite/caps/.cvsignore:
7806         * testsuite/caps/Makefile.am:
7807         * testsuite/caps/erathostenes.c: (erathostenes), (main):
7808         * testsuite/caps/sets.c: (check_caps), (main):
7809         * testsuite/caps/subtract.c: (check_caps), (main):
7810           add tests for subtraction and equality code.
7811
7812 2004-04-20  David Schleef  <ds@schleef.org>
7813
7814         * gst/autoplug/Makefile.am:  Fix some little buglets in last checkin.
7815         * gst/indexers/Makefile.am:
7816         * gst/schedulers/Makefile.am:
7817         * libs/gst/bytestream/Makefile.am:
7818         * libs/gst/control/Makefile.am:
7819         * libs/gst/getbits/Makefile.am:
7820
7821 2004-04-20  David Schleef  <ds@schleef.org>
7822
7823         * common/as-libtool.mak: Fine-tune DLL building.
7824         * configure.ac: Link plugins against libgstreamer.  Define plugindir
7825         (like gst-plugins)
7826         * examples/plugins/Makefile.am: remove plugindir
7827         * gst/autoplug/Makefile.am: DLL building fixes
7828         * gst/elements/Makefile.am: DLL building fixes.  Disable pipefilter on
7829         Windows.
7830         * gst/elements/gstelements.c: Conditionally disable pipefilter.
7831         * gst/indexers/Makefile.am: DLL building fixes
7832         * gst/schedulers/Makefile.am: DLL building fixes.
7833         * libs/gst/bytestream/Makefile.am: DLL building fixes.
7834         * libs/gst/control/Makefile.am: same
7835         * libs/gst/getbits/Makefile.am: same
7836         * testsuite/Makefile.am: New dlopen directory
7837         * testsuite/dlopen/Makefile.am: Tests to check if libgstreamer works
7838         when dlopened.
7839         * testsuite/dlopen/dlopen_gst.c: (main): same
7840         * testsuite/dlopen/loadgst.c: (do_test): same
7841
7842 2004-04-20  David Schleef  <ds@schleef.org>
7843
7844         * gst/parse/grammar.y:  Apply patch from Sebastien Cote
7845         <sc5@hermes.usherb.ca> to fix a memleak. (bug #140594)
7846
7847 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7848
7849         * gst/gstelement.c: (gst_element_wait),
7850         (gst_element_set_time_delay), (gst_element_change_state):
7851           Use GST_TIME_*
7852
7853 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7854
7855         * gst/autoplug/gstspider.c: (gst_spider_link_sometimes),
7856         (gst_spider_identity_plug):
7857           improve debugging messages
7858         * gst/gstbin.c: (gst_bin_remove_func):
7859           make sure the state_change function is only called with simple state
7860           transitions
7861
7862 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7863
7864         * gst/elements/gstfakesink.c: (gst_fakesink_state_error_get_type),
7865         (gst_fakesink_set_property), (gst_fakesink_chain):
7866         * gst/elements/gstfakesrc.c: (gst_fakesrc_set_property):
7867         * gst/elements/gstfdsrc.c: (gst_fdsrc_set_property):
7868         * gst/elements/gstfilesrc.c: (gst_filesrc_set_property):
7869         * gst/elements/gstidentity.c: (gst_identity_chain),
7870         (gst_identity_set_property):
7871         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_set_property):
7872         * gst/elements/gstpipefilter.c: (gst_pipefilter_set_property):
7873           add warnings to _set_property for unknown arguments
7874           use GST_TIME_FORMAT/GST_TIME_ARGS for timestamp printing
7875
7876 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7877
7878         * Makefile.am:
7879         * docs/manuals.mak:
7880           add .po file download snippet
7881           fix a bug in the doc makefile
7882
7883 2004-04-20  Thomas Vander Stichele  <thomas at apestaart dot org>
7884
7885         * Makefile.am:
7886         * po/LINGUAS:
7887         * po/en_GB.po:
7888           Added en_GB translation (Gareth Owen)
7889
7890 2004-04-20  Johan Dahlin  <johan@gnome.org>
7891
7892         * gst/gstpad.c (_invent_event): Clean up
7893
7894 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7895
7896         * testsuite/caps/filtercaps.c: (main):
7897           fix test to test things correctly (caps are complicated)
7898
7899 2004-04-20  Benjamin Otte  <in7y118@public.uni-hamburg.de>
7900
7901         * testsuite/caps/Makefile.am:
7902         * testsuite/caps/filtercaps.c: (main):
7903           add test (that doesn't work right now, but should)
7904
7905 2004-04-19  David Schleef  <ds@schleef.org>
7906
7907         * configure.ac: Add test for allowing unaligned access.  Add define
7908         to put in gstconfig.h.
7909         * docs/gst/gstreamer-sections.txt: New symbols
7910         * docs/gst/tmpl/gstcompat.sgml: Check in changes made by gtkdoc
7911         * docs/gst/tmpl/gstfilesrc.sgml:
7912         * docs/gst/tmpl/gstparse.sgml:
7913         * docs/gst/tmpl/gsttypes.sgml:
7914         * docs/gst/tmpl/gstutils.sgml:
7915         * docs/gst/tmpl/gstvalue.sgml:
7916         * gst/gstconfig.h.in: Add GST_HAVE_UNALIGNED_ACCESS
7917         * gst/gstutils.h: Add macros for unaligned memory access.  Useful
7918         on most !i386/!powerpc architectures.  From Daniel Gazard
7919         <daniel.gazard@free.fr>.  (bug #140156)
7920         * po/af.po: Check in changes made by gettext.
7921         * po/az.po:
7922         * po/fr.po:
7923         * po/nl.po:
7924         * po/sr.po:
7925         * po/sv.po:
7926
7927 2004-04-20  Benjamin Otte  <otte@gnome.org>
7928
7929         * gst/schedulers/entryscheduler.c: 
7930         (gst_entry_scheduler_yield):
7931           refuse to yield when decoupled elements insist on doing that.
7932           At least it's better than crashing
7933
7934 2004-04-19  David Schleef  <ds@schleef.org>
7935
7936         * docs/libs/Makefile.am: Change sinclude to include
7937         * docs/gst/Makefile.am: same
7938         * pkgconfig/Makefile.am:  Remove GNU-ism from makefile target
7939
7940 2004-04-19  Thomas Vander Stichele  <thomas at apestaart dot org>
7941
7942         * po/LINGUAS:
7943         * po/uk.po:
7944           Added Ukrainian translation (Maxim V. Dziumanenko)
7945
7946 2004-04-19  Johan Dahlin  <johan@gnome.org>
7947
7948         * gst/parse/grammar.y (__gst_parse_chain_free): Don't do null
7949         checking here, do it before calling the function.
7950         Clean up, use for loops instead of while loops while iterating
7951         over lists.
7952
7953         * gst/autoplug/gstspider.c (gst_spider_request_new_pad): Fix typo
7954         in debug message.
7955         (gst_spider_create_and_plug): Improve debug message.
7956         General: Replace while loops which iterates over GLists with for
7957         loops. Which are much cleaner, improves readability, especially
7958         for gst_spider_identity_plug
7959
7960         * gst/gstpad.c (_invent_event): Fix parameters to warning macros,
7961         fixes bug 140477
7962
7963 2004-04-18  Thomas Vander Stichele  <thomas at apestaart dot org>
7964
7965         * po/LINGUAS:
7966         * po/tr.po:
7967           Added Turkish translation (Baris Cicek)
7968
7969 2004-04-18  Ronald Bultje  <rbultje@ronald.bitfreak.net>
7970
7971         * docs/faq/troubleshooting.xml:
7972           Mention gst-register in the FAQ (fixes 139045).
7973
7974 2004-04-17  Thomas Vander Stichele  <thomas at apestaart dot org>
7975
7976         * docs/gst/gstreamer-sections.txt:
7977
7978 2004-04-17  Benjamin Otte  <otte@gnome.org>
7979
7980         * gst/gstelement.c: (gst_element_dispose):
7981           simplify
7982         * gst/gstpad.c: (gst_pad_call_chain_function):
7983           don't create loads of events due to bad macro usage
7984
7985 2004-04-16  David Schleef  <ds@schleef.org>
7986
7987         * gst/gstcaps.c: (gst_caps_is_fixed_foreach):
7988         * gst/gstpad.c: (_gst_pad_default_fixate_foreach):
7989         * gst/gstvalue.c: (gst_value_serialize_buffer),
7990         (gst_value_deserialize_buffer), (gst_type_is_fixed),
7991         (_gst_value_initialize): Create a new function gst_type_is_fixed()
7992         to indicate types that are fixed wrt caps or not.  Switching to
7993         this function fixes (bug #140298).
7994         * gst/gstvalue.h:
7995
7996 2004-04-16  David Schleef  <ds@schleef.org>
7997
7998         * common/m4/gst-arch.m4:  Implmenent a whitelist and blacklist
7999         for GST_UNALIGNED_ACESS, since we essentially know which archs
8000         are ok.
8001
8002 2004-04-17  Benjamin Otte  <otte@gnome.org>
8003
8004         * docs/gst/Makefile.am:
8005           ignore gst/parse directory when building docs (fixes #140205)
8006
8007 2004-04-16  Thomas Vander Stichele  <thomas at apestaart dot org>
8008
8009         * testsuite/refcounting/mem.c: (vmsize):
8010           do error checking
8011
8012 2004-04-16  Johan Dahlin  <johan@gnome.org>
8013
8014         * docs/gst/gstreamer-sections.txt: Add gst_pad_call_chain_function
8015         and gst_pad_call_get_function.
8016
8017 2004-04-15  David Schleef  <ds@schleef.org>
8018
8019         * common/m4/gst-arch.m4: Add GST_UNALIGNED_ACCESS() macro that
8020         checks if we can access unaligned memory.
8021         * configure.ac: Use it.
8022
8023 2004-04-16  Benjamin Otte  <otte@gnome.org>
8024
8025         * gst/elements/gstfilesrc.c: (gst_filesrc_init), (gst_filesrc_get),
8026         (gst_filesrc_change_state), (gst_filesrc_srcpad_event):
8027         * gst/elements/gstfilesrc.h:
8028           s/seek_happened/need_discont/ and require discont before sending any
8029           data
8030
8031 2004-04-15  David Schleef  <ds@schleef.org>
8032
8033         * gst/gstvalue.c: (gst_value_serialize_buffer),
8034         (gst_value_deserialize_buffer), (_gst_value_initialize):
8035         Register these types as fundamental types. (bug #140015)
8036
8037 2004-04-16  Benjamin Otte  <otte@gnome.org>
8038
8039         * gst/gstpad.c: (gst_pad_set_active), (gst_pad_link_new),
8040         (gst_pad_link_free), (gst_pad_link_try), (_invent_event),
8041         (gst_pad_pull):
8042           implement enforcing discont events before buffers are passed. This
8043           allows state changes of only some elements and later correctly going
8044           on where they left off (or in short: you can now set audio sinks to
8045           NULL to release the device when the pipeline is paused)
8046         * gst/gstpad.c: (gst_pad_call_chain_function),
8047         (gst_pad_call_get_function):
8048         * gst/gstpad.h:
8049           add gst_pad_call_chain_function and gst_pad_call_get_function for
8050           scheduler interaction. They are required because of the changes
8051           above.
8052         * gst/schedulers/entryscheduler.c: (get_buffer),
8053         (gst_entry_scheduler_chain_wrapper),
8054         (gst_entry_scheduler_get_wrapper),
8055         (gst_entry_scheduler_state_transition),
8056         (gst_entry_scheduler_pad_link):
8057         * gst/schedulers/gstbasicscheduler.c:
8058         (gst_basic_scheduler_chain_wrapper),
8059         (gst_basic_scheduler_src_wrapper),
8060         (gst_basic_scheduler_chainhandler_proxy),
8061         (gst_basic_scheduler_gethandler_proxy),
8062         (gst_basic_scheduler_cothreaded_chain),
8063         (gst_basic_scheduler_chain_elements):
8064         * gst/schedulers/gstoptimalscheduler.c:
8065         (get_group_schedule_function), (pad_clear_queued),
8066         (gst_opt_scheduler_pad_link):
8067           use the new functions instead of calling get/chain-functions
8068           directly.
8069
8070 2004-04-15  David Schleef  <ds@schleef.org>
8071
8072         * docs/gst/gstreamer-sections.txt: Remove deprecated symbols.
8073         * docs/gst/tmpl/gstinfo.sgml: same
8074         * docs/gst/tmpl/gstutils.sgml: Remove a bunch of bogus crap that
8075         gtk-doc put here.
8076         * gst/gstutils.h: Remove the \ that was confusing gtk-doc.
8077         * examples/queue/queue.c: (main):  We iterate pipelines, not
8078         bins.  (bug #139996)
8079
8080 2004-04-15  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8081
8082         * docs/pwg/advanced-types.xml:
8083           Add MS RLE support. Also document Qt RLE although I have no sample
8084           files for that yet. And document an extra property for ADPCM.
8085
8086 2004-04-15  David Schleef  <ds@schleef.org>
8087
8088         * gst/gstplugin.c: (_gst_plugin_fault_handler_restore),
8089         (_gst_plugin_fault_handler_setup):  Disable more stuff on
8090         Windows.
8091
8092 2004-04-15  David Schleef  <ds@schleef.org>
8093
8094         * gst/gstinfo.c: (_gst_debug_init): Change some internal
8095         symbol names to not conflict with new gstinfo.h symbols.
8096         * gst/gstinfo.h: Add inline functions for all those crazy
8097         compilers that don't know how to handle variadic macros (MSVC).
8098
8099 2004-04-15  Thomas Vander Stichele  <thomas at apestaart dot org>
8100
8101         * configure.ac: bump nano to 1
8102
8103 === release 0.8.1 ===
8104
8105 2004-04-15  Thomas Vander Stichele  <thomas at apestaart dot org>
8106
8107         * NEWS:
8108         * RELEASE:
8109         * configure.ac:
8110           releasing 0.8.1, "Snow Brigade"
8111
8112 2004-04-14  David Schleef  <ds@schleef.org>
8113
8114         * testsuite/Makefile.am: define tests_ignore
8115         * testsuite/Rules: Added new tests_ignore, which get compiled,
8116         but not run (generally because they're inconsistent or have
8117         heisenbugs).  Now we can ensure all the .c files compile in
8118         testsuite/.
8119         * testsuite/bins/Makefile.am: define tests_ignore
8120         * testsuite/bytestream/Makefile.am:
8121         * testsuite/caps/Makefile.am:
8122         * testsuite/clock/Makefile.am:
8123         * testsuite/debug/Makefile.am:
8124         * testsuite/debug/global.c: (gst_debug_log_one),
8125         (gst_debug_log_two): Fix compilation problem.
8126         * testsuite/dynparams/Makefile.am:
8127         * testsuite/elements/Makefile.am:
8128         * testsuite/ghostpads/Makefile.am:
8129         * testsuite/indexers/Makefile.am:
8130         * testsuite/parse/Makefile.am:
8131         * testsuite/plugin/Makefile.am:
8132         * testsuite/refcounting/Makefile.am:
8133         * testsuite/refcounting/element_pad.c: (main): Don't return leak
8134         results, because it's not calculated correctly.
8135         * testsuite/refcounting/pad.c: (main): same
8136         * testsuite/states/Makefile.am:
8137         * testsuite/tags/Makefile.am:
8138         * testsuite/threads/Makefile.am:
8139
8140 2004-04-14  David Schleef  <ds@schleef.org>
8141
8142         * gst/gstcpu.c: (gst_cpuid_i386): Add workaround for gcc-3.2
8143         generating bad code around the cpu detection asm code.
8144
8145 2004-04-14  Thomas Vander Stichele  <thomas at apestaart dot org>
8146
8147         * tools/gst-inspect.c: (print_element_info):
8148           print numeric version of rank as well, since we added some - 1
8149           rank values to elements
8150
8151 2004-04-13  David Schleef  <ds@schleef.org>
8152
8153         * configure.ac:  Disable various code when compiling for MinGW.
8154         * gst/elements/Makefile.am:
8155         * gst/elements/gstelements.c:
8156         * gst/elements/gstfdsrc.c: (gst_fdsrc_get):
8157         * gst/elements/gstfilesrc.c: (gst_filesrc_init), (gst_filesrc_get):
8158         * gst/registries/gstxmlregistry.c: (make_dir):
8159
8160 2004-04-13  David Schleef  <ds@schleef.org>
8161
8162         * gst/Makefile.am:
8163         * gst/gstcpu.c: (gst_cpuid_i386): Convert asm source into inline
8164         assembly.
8165         * gst/gstcpuid_i386.s: remove
8166
8167 2004-04-13  David Schleef  <ds@schleef.org>
8168
8169         * docs/gst/tmpl/gstaggregator.sgml: Random checkin because gtk-doc
8170         seems to think it needs to be done.
8171         * docs/gst/tmpl/gstfakesink.sgml:
8172         * docs/gst/tmpl/gstfakesrc.sgml:
8173         * docs/gst/tmpl/gstfdsink.sgml:
8174         * docs/gst/tmpl/gstfdsrc.sgml:
8175         * docs/gst/tmpl/gstfilesink.sgml:
8176         * docs/gst/tmpl/gstfilesrc.sgml:
8177         * docs/gst/tmpl/gstidentity.sgml:
8178         * docs/gst/tmpl/gstmd5sink.sgml:
8179         * docs/gst/tmpl/gstmultifilesrc.sgml:
8180         * docs/gst/tmpl/gstpipefilter.sgml:
8181         * docs/gst/tmpl/gstshaper.sgml:
8182         * docs/gst/tmpl/gstspider.sgml:
8183         * docs/gst/tmpl/gstspideridentity.sgml:
8184         * docs/gst/tmpl/gststatistics.sgml:
8185         * docs/gst/tmpl/gsttee.sgml:
8186         * docs/gst/tmpl/gsttypefind.sgml:
8187         * docs/gst/tmpl/gstutils.sgml:
8188
8189 2004-04-13  David Schleef  <ds@schleef.org>
8190
8191         * configure.ac: Changes to remove POSIXisms (mmap in this case)
8192         and to build DLLs on Windows.
8193         * gst/Makefile.am:
8194         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
8195         (gst_filesrc_open_file):
8196         * gst/schedulers/Makefile.am:
8197
8198 2004-04-13  David Schleef  <ds@schleef.org>
8199
8200         * gst/gstcaps.c: (gst_caps_structure_fixate_field_nearest_int),
8201         (gst_caps_structure_fixate_field_nearest_double):  Fix bug in
8202         fixating lists.
8203
8204 2004-04-12  David Schleef  <ds@schleef.org>
8205
8206         * gst/gstbuffer.c: (_gst_buffer_initialize), (gst_buffer_get_type),
8207         (gst_buffer_free_chunk): Added gst_buffer_get_type() and changed
8208         to using it.
8209         * gst/gstbuffer.h: Changed GST_BUFFER_TYPE to gst_buffer_get_type()
8210         * gst/gstcaps.c: (gst_caps_is_fixed_foreach): Buffer is a fixed type
8211         * gst/gstpad.c: (_gst_pad_default_fixate_foreach): same
8212         * gst/gststructure.c: (gst_structure_set_valist),
8213         (gst_structure_from_abbr), (gst_structure_to_abbr): Add vararg
8214         support for buffers.
8215         * gst/gsttag.c: (gst_tag_register): Constify a prototype that was
8216         intended to be const.
8217         * gst/gsttag.h: same
8218         * gst/gstvalue.c: (gst_value_serialize_buffer),
8219         (gst_value_deserialize_buffer), (_gst_value_initialize):  Add code
8220         to (de)serialize buffers.
8221         * testsuite/caps/Makefile.am:  Add a bit of buffer testing
8222         * testsuite/caps/string-conversions.c: (main):
8223         * testsuite/caps/value_serialize.c: add new test
8224
8225 2004-04-11  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8226
8227         * docs/pwg/advanced-types.xml:
8228           Document MS video 1 (video/x-msvideocodec) mimetype/format.
8229
8230 2004-04-11  Benjamin Otte  <otte@gnome.org>
8231
8232         * gst/schedulers/gstbasicscheduler.c: (plugin_init):
8233           rename categories to basic_*
8234         * gst/schedulers/gstbasicscheduler.c: 
8235         (gst_basic_scheduler_chain_wrapper),
8236         (gst_basic_scheduler_chainhandler_proxy),
8237         (gst_basic_scheduler_gethandler_proxy),
8238         (gst_basic_scheduler_eventhandler_proxy):
8239           debugging category fixes - put common stuff in log category
8240         * gst/schedulers/gstbasicscheduler.c: 
8241         (gst_basic_scheduler_chain_elements):
8242           dirty fix: call gst_basic_scheduler_cothreaded_chain when already
8243           active and linking two active chains
8244
8245 2004-04-10  Benjamin Otte  <otte@gnome.org>
8246
8247         * docs/pwg/intro-preface.xml:
8248           fix dead links and remove reference to Wiki
8249
8250 2004-04-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8251
8252         * gst/schedulers/gstbasicscheduler.c:
8253           make sure we can switch back to the main function if we're still in
8254           the main function (supposed to fix #139617)
8255         * gst/schedulers/gthread-cothreads.h:
8256           don't throw an error when switching to the same cothread
8257
8258 2004-04-09  Benjamin Otte  <otte@gnome.org>
8259
8260         * gst/gstbin.c: (gst_bin_get_type):
8261         * gst/gstclock.c: (gst_clock_get_type):
8262         * gst/gstindex.c: (gst_index_get_type):
8263         * gst/gstobject.c: (gst_object_get_type),
8264         (gst_signal_object_get_type):
8265         * gst/gstpad.c: (gst_pad_get_type), (gst_real_pad_get_type),
8266         (gst_pad_template_get_type), (gst_ghost_pad_get_type):
8267         * gst/gstpluginfeature.c: (gst_plugin_feature_get_type):
8268         * gst/gstqueue.c: (gst_queue_get_type):
8269         * gst/gstregistry.c: (gst_registry_get_type):
8270         * gst/gstsystemclock.c: (gst_system_clock_get_type):
8271         * gst/gstthread.c: (gst_thread_get_type):
8272           don't use memchunks for these objects, use malloc instead
8273
8274 2004-04-08  Thomas Vander Stichele  <thomas at apestaart dot org>
8275
8276         * docs/gst/.cvsignore:
8277         * docs/gst/Makefile.am:
8278         * docs/gst/gstreamer-sections.txt:
8279         * docs/gst/tmpl/gstaggregator.sgml:
8280         * docs/gst/tmpl/gstbuffer.sgml:
8281         * docs/gst/tmpl/gstclock.sgml:
8282         * docs/gst/tmpl/gstelement.sgml:
8283         * docs/gst/tmpl/gstfakesink.sgml:
8284         * docs/gst/tmpl/gstfakesrc.sgml:
8285         * docs/gst/tmpl/gstfdsink.sgml:
8286         * docs/gst/tmpl/gstfdsrc.sgml:
8287         * docs/gst/tmpl/gstfilesink.sgml:
8288         * docs/gst/tmpl/gstfilesrc.sgml:
8289         * docs/gst/tmpl/gstidentity.sgml:
8290         * docs/gst/tmpl/gstindex.sgml:
8291         * docs/gst/tmpl/gstinfo.sgml:
8292         * docs/gst/tmpl/gstmd5sink.sgml:
8293         * docs/gst/tmpl/gstmultifilesrc.sgml:
8294         * docs/gst/tmpl/gstpad.sgml:
8295         * docs/gst/tmpl/gstpipefilter.sgml:
8296         * docs/gst/tmpl/gstpipeline.sgml:
8297         * docs/gst/tmpl/gstpluginfeature.sgml:
8298         * docs/gst/tmpl/gstqueue.sgml:
8299         * docs/gst/tmpl/gstregistry.sgml:
8300         * docs/gst/tmpl/gstscheduler.sgml:
8301         * docs/gst/tmpl/gstshaper.sgml:
8302         * docs/gst/tmpl/gstspider.sgml:
8303         * docs/gst/tmpl/gstspideridentity.sgml:
8304         * docs/gst/tmpl/gststatistics.sgml:
8305         * docs/gst/tmpl/gstsystemclock.sgml:
8306         * docs/gst/tmpl/gsttee.sgml:
8307         * docs/gst/tmpl/gstthread.sgml:
8308         * docs/gst/tmpl/gsttypefind.sgml:
8309         * docs/gst/tmpl/gstutils.sgml:
8310           further doc build fixes
8311
8312 2004-04-07  Thomas Vander Stichele  <thomas at apestaart dot org>
8313
8314         * docs/gst/Makefile.am:
8315           make docs exit on scanning problems
8316           fix nonsrcdir build issues
8317         * docs/gst/gstreamer-sections.txt:
8318           adding stuff from -unused
8319         * gst/gstqueue.h:
8320           create GstQueueSize
8321         * gst/schedulers/cothreads_compat.h:
8322           fix cothread warnings
8323
8324 2004-04-07  Thomas Vander Stichele  <thomas at apestaart dot org>
8325
8326         * docs/gst/gstreamer-sections.txt:
8327           remove defines deprecated by Benjamin
8328
8329 2004-04-07  Benjamin Otte  <otte@gnome.org>
8330
8331         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
8332           when the buffer is complete, don't check if other buffers are needed
8333         * gst/elements/gstfilesrc.c: (gst_filesrc_srcpad_event):
8334           check that the offset is >0 so we don't try to read before the
8335           beginning of the file
8336         * gst/gstpad.c: (gst_pad_set_pad_template):
8337           sink the template, so we don't end up with 130k pad templates
8338
8339 2004-04-06  Benjamin Otte  <otte@gnome.org>
8340
8341         * gst/autoplug/gstspider.c: (gst_spider_link_add):
8342           don't ref the element, adding already reffed it. And we didn't unref
8343           it later anyway... (huge memleak when you used many spider elements)
8344         * gst/gstelement.c: (gst_element_base_class_finalize):
8345         * gst/gstelementfactory.c: (gst_element_factory_cleanup),
8346         (gst_element_register):
8347         * gst/gsturi.c: (gst_element_make_from_uri):
8348           use gst_object_(un)ref instead of g_object(un)ref
8349
8350 2004-04-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8351
8352         * gst/gstbuffer.h:
8353           remove macro that wouldn't work anymore because struct member has
8354           been removed.
8355         * gst/schedulers/entryscheduler.c: (schedule_forward):
8356           fix segfault for unconnected pads
8357         
8358 2004-04-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8359
8360         reviewed by David Schleef <ds@schleef.org>
8361
8362         * gst/gstinfo.h:
8363           *_FORMAT modifiers should require putting a % in front of them for
8364           consistency reasons.
8365
8366 2004-04-05  Colin Walters  <walters@redhat.com>
8367
8368         * configure.ac (VALGRIND_CFLAGS, VALGRIND_LIBS): Remove spurious
8369         space.
8370
8371 2004-04-05  Benjamin Otte  <otte@gnome.org>
8372
8373         * configure.ac:
8374         * gst/Makefile.am:
8375         * gst/gst_private.h:
8376         * gst/gstinfo.c: (__gst_in_valgrind), (_gst_debug_init):
8377           add support for detecting if GStreamer runs inside valgrind.
8378           requires valgrind (d'oh) and --enable-debug for correct cdetection.
8379           print a big message in valgrind that GStreamer has detected it's
8380           running inside and might now use different code.
8381         * gst/gstmemchunk.c: (populate), (free_area),
8382         (gst_mem_chunk_destroy), (gst_mem_chunk_alloc),
8383         (gst_mem_chunk_free):
8384           flag memchunks for valgrind, so it can detect leaking of chunks.
8385           This allows detecting leaks of GstBuffer and GstEvent correctly
8386           inside valgrind.
8387
8388 2004-04-05  David Schleef  <ds@schleef.org>
8389
8390         * gst/gsttrace.h:  Fix #ifdef nesting (bug #139109) Patch from
8391           jensgr@gmx.net (Jens Granseuer)
8392
8393 2004-04-05  David Schleef  <ds@schleef.org>
8394
8395         * gst/gstbuffer.c: (_gst_buffer_sub_free),
8396         (gst_buffer_default_free), (gst_buffer_default_copy),
8397         (gst_buffer_alloc_chunk), (gst_buffer_free_chunk),
8398         (gst_buffer_new), (gst_buffer_create_sub):  Allocate GstBuffer
8399         structures in one place.
8400
8401 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
8402
8403         * gst/gstinfo.h: adding Ronald's timestamp debugging defines
8404           (GST_TIME_FORMAT, GST_TIME_ARGS)
8405
8406 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
8407
8408         * testsuite/elements/Makefile.am:
8409           disable test until it stops breaking make distcheck
8410
8411 2004-04-05  Johan Dahlin  <johan@gnome.org>
8412
8413         * po/sv.po: Updated translation
8414
8415 2004-04-05  Thomas Vander Stichele  <thomas at apestaart dot org>
8416
8417         * gst/gstplugin.c: (gst_plugin_load_file):
8418           fix segfault for when original plugin was loaded statically
8419
8420 2004-04-05  Benjamin Otte  <otte@gnome.org>
8421
8422         * testsuite/debug/category.c: (main):
8423         * testsuite/debug/commandline.c: (main):
8424         * testsuite/debug/output.c: (main):
8425           fix tests to work again with debugging enabled
8426
8427 2004-04-05  Benjamin Otte  <otte@gnome.org>
8428
8429         * gst/schedulers/gstbasicscheduler.c:
8430         (gst_basic_scheduler_pad_link):
8431           fix to work with recent scheduling changes
8432
8433 2004-04-05  Benjamin Otte  <otte@gnome.org>
8434
8435         * gst/schedulers/entryscheduler.c: (some functions, dunno which,
8436         prepareChangeLog doesn't work when cvs indents):
8437           don't throw an error when no element can be scheduled, there's too
8438           many weird reasons why it doesn't work. Return STOPPED instead.
8439           decoupled elemts' schedulability doesn't depend on bufpens.
8440
8441 2004-04-04  Benjamin Otte  <otte@gnome.org>
8442
8443         * gst/schedulers/gstbasicscheduler.c:
8444         (gst_basic_scheduler_pad_select):
8445           fix uninitialized variable warnings
8446
8447 2004-04-04  Benjamin Otte  <otte@gnome.org>
8448
8449         * gst/gstpad.c: (gst_pad_collect_valist):
8450           fix uninitialized variable warning
8451         * gst/schedulers/entryscheduler.c: (schedule_forward):
8452           fix shadowed variable
8453
8454 2004-04-04  Benjamin Otte  <otte@gnome.org>
8455
8456         * gst/gstpad.c: (gst_pad_collect_array), (gst_pad_collectv),
8457         (gst_pad_collect), (gst_pad_collect_valist), (gst_pad_selectv),
8458         (gst_pad_select):
8459         * gst/gstpad.h:
8460         * gst/gstscheduler.c: (gst_scheduler_pad_select),
8461         (gst_scheduler_lock_element), (gst_scheduler_unlock_element):
8462         * gst/gstscheduler.h:
8463           implement gst_pad_collect as replacement for gst_pad_select.
8464           deprecate gst_pad_select and gst_scheduler_(un)lock_element
8465           add new flag GST_SCHEDULER_FLAG_NEW_API for API that implements the
8466           new pad_select, lock and unlock calls.
8467         * gst/cothreads.c: (cothread_destroy), (cothread_switch):
8468         * gst/cothreads.h:
8469         * gst/schedulers/cothreads_compat.h:
8470         * gst/schedulers/gthread-cothreads.h:
8471           remove unused cothread_lock and cothread_unlock calls
8472         * gst/schedulers/entryscheduler.c:
8473         (gst_entry_scheduler_class_init), (gst_entry_scheduler_init),
8474         (_can_schedule_loop), (gst_entry_scheduler_get_handler),
8475         (gst_entry_scheduler_pad_select):
8476           update to new API
8477         * gst/schedulers/gstbasicscheduler.c:
8478         (gst_basic_scheduler_class_init), (gst_basic_scheduler_init),
8479         (gst_basic_scheduler_pad_select):
8480           remove useless lock and unlock calls, update pad_select to new API
8481           (untested)
8482         * gst/schedulers/gstoptimalscheduler.c:
8483         (gst_opt_scheduler_class_init):
8484           remove useless select, lock and unlock function calls
8485         * gst/elements/gstaggregator.c: (gst_aggregator_loop):
8486           use gst_pad_collect instead of gst_pad_select
8487
8488 2004-04-04  Benjamin Otte  <otte@gnome.org>
8489
8490         * gst/schedulers/entryscheduler.c: (_can_schedule_get),
8491         (can_schedule_pad), (can_schedule), (schedule), (schedule_forward),
8492         (schedule_next_element), (print_entry):
8493           add can_schedule_pad to handle element states.
8494           add schedule_forward to select the correct entry to schedule next
8495
8496 2004-04-03  Benjamin Otte  <otte@gnome.org>
8497
8498         * gst/schedulers/entryscheduler.c: 
8499           remove unused variable, fix error inside Rb, fix compile warning in
8500           unreachable code
8501
8502 2004-04-03  Benjamin Otte  <otte@gnome.org>
8503
8504         * gst/schedulers/entryscheduler.c:
8505           completely revamp the inner workings, so it's a lot easier to
8506           understand and extend
8507
8508 2004-04-03  Andy Wingo  <wingo@pobox.com>
8509
8510         * gst/schedulers/gstoptimalscheduler.c (GstOptSchedulerGroupLink):
8511         Rename ->group1 and ->group2 to ->src and ->sink, respectively.
8512         This allows better introspection of pipeline topology.
8513         (add_to_chain): Don't do trickery to put loop elements first;
8514         rather, queue a chain sort by marking the chain as dirty.
8515         (remove_from_chain): Mark the chain dirty.
8516         (sort_chain): New function. Sorts the group list so that terminal
8517         sinks are first. This means elements on the sink side will be
8518         preferentially sscheduled before elements on the src side of the
8519         pipeline.
8520         (chain_recursively_migrate_group): Use OTHER_GROUP_LINK.
8521         (schedule_chain): If the chain is marked DIRTY, call sort_chain.
8522         (gst_opt_scheduler_pad_link, gst_opt_scheduler_pad_unlink)
8523         (group_inc_link): Change argument and variable names to match the
8524         new link structure member names (src and sink).
8525         (group_dec_link): Add some description
8526
8527 2004-04-03  Benjamin Otte  <otte@gnome.org>
8528
8529         * gst/autoplug/gstspider.c: (gst_spider_identity_plug):
8530         * gst/gstinfo.h:
8531         * testsuite/debug/category.c: (main):
8532         * testsuite/debug/commandline.c: (main):
8533         * testsuite/debug/output.c: (main):
8534         * testsuite/debug/printf_extension.c: (main):
8535           fix to successfully build and test with --disable-gst-debug
8536           configure switch (fixes #138705)
8537
8538 2004-04-03  Benjamin Otte  <otte@gnome.org>
8539
8540         * docs/pwg/building-boiler.xml:
8541           add cvs login line and s/anonymous/anoncvs/
8542
8543 2004-04-03  Tim-Phillip Müller  <t.i.m@zen.co.uk>
8544
8545         reviewed by Benjamin Otte  <otte@gnome.org>
8546
8547         * gst/gststructure.c: (gst_structure_free):
8548           memleak fix: free fields array (partial fix for #134839)
8549
8550 2004-04-01  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8551
8552         * docs/random/ds/0.9-suggested-changes:
8553           Add a note to change handoff use in fakesrc to be usable in
8554           a more generic way (fakesrc should be renamed to appsrc or so).
8555         * gst/elements/gstfakesrc.c: (gst_fakesrc_class_init):
8556           Change signal type to scope, so we can fill the buffer in the
8557           handoff handler (that's the whole use of this signal...).
8558
8559 2004-04-01  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8560
8561         * docs/pwg/other-ntoone.xml:
8562           Document muxers and n-to-1 elements.
8563
8564 2004-04-01  Martin Soto  <martinsoto@users.sourceforge.net>
8565
8566         * gst/registries/gstxmlregistry.c
8567         (gst_xml_registry_rebuild_recurse): Fix the algorithm to
8568         determine if a file is a G_MODULE. The old one discards paths
8569         containing "so" somewhere in the middle. My home directory is
8570         called "soto". Go figure...
8571
8572 2004-03-31  David Schleef  <ds@schleef.org>
8573
8574         * gst/gstbuffer.c: (gst_buffer_join):  Add function gst_buffer_join()
8575         to eventually deprecate gst_buffer_merge().  (bug: #136408)
8576         * gst/gstbuffer.h:
8577
8578 2004-03-31  David Schleef  <ds@schleef.org>
8579
8580         * gst/gstvalue.c: (gst_value_union_int_int_range),
8581         (gst_value_union_int_range_int_range), (gst_value_can_union),
8582         (gst_value_union), (_gst_value_initialize):  Add some union
8583         implementations.  We didn't have any previously.
8584         * testsuite/caps/Makefile.am:
8585         * testsuite/caps/audioscale.c: (gst_audioscale_expand_value),
8586         (gst_audioscale_getcaps), (test_caps), (main): A little test
8587         that is the same as the caps manipulation in audioscale.
8588
8589 2004-03-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8590
8591         * docs/faq/general.xml:
8592           add entry about "does gst support format X?"
8593
8594 2004-03-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
8595
8596         * gst/gstthread.c:
8597           fix docs
8598         * gst/gstutils.h:
8599           fix GST_BOILERPLATE_FULL to not throw casting errors on C++
8600
8601 2004-03-30  Benjamin Otte  <otte@gnome.org>
8602
8603         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
8604           set the offset of the buffer to the requested offset
8605         * gst/elements/gsttypefind.c: (stop_typefinding):
8606           revert patch 1.18 (which I unfortunately don't know the reason for).
8607           This is needed to allow downstream elements to seek. Otherwise
8608           typefind might overwrite a previous seek by downstream elements.
8609           This lead to errors with id3tag and typefind on some mp3s.
8610         * gst/schedulers/entryscheduler.c: (COTHREADS_TYPE),
8611         (gst_entry_scheduler_iterate):
8612           be more verbose when debugging
8613
8614 2004-03-30  Thomas Vander Stichele  <thomas at apestaart dot org>
8615
8616         * gst/gstcaps.c: (gst_caps_from_string_inplace):
8617           make sure we don't get NULL strings
8618
8619 2004-03-30  Thomas Vander Stichele  <thomas at apestaart dot org>
8620
8621         * gst/gstcaps.c:
8622         * gst/gstelement.c:
8623         * gst/gstelementfactory.c: (gst_element_factory_get_type):
8624         * gst/gstindex.c: (gst_index_resolver_get_type),
8625         (gst_index_get_type), (gst_index_factory_get_type):
8626         * gst/gstinfo.c:
8627         * gst/gstpad.c:
8628         * gst/gstplugin.c:
8629         * gst/gsturi.c: (gst_uri_handler_get_type):
8630         * gst/gstvalue.c:
8631           first batch of documentation fixes
8632
8633 2004-03-29  David Schleef  <ds@schleef.org>
8634
8635         * docs/gst/Makefile.am:  Disable a bunch of headers from being scanned
8636         * docs/gst/gstreamer-docs.sgml:  More hacking
8637         * docs/gst/gstreamer-sections.txt:
8638         * docs/gst/tmpl/cothreads_compat.sgml:
8639         * docs/gst/tmpl/gstcaps.sgml:
8640         * docs/gst/tmpl/gstclock.sgml:
8641         * docs/gst/tmpl/gstelement.sgml:
8642         * docs/gst/tmpl/gstevent.sgml:
8643         * docs/gst/tmpl/gstpad.sgml:
8644         * docs/gst/tmpl/gstutils.sgml:
8645         * docs/gst/tmpl/gstxml.sgml:
8646         * docs/gst/tmpl/gthread-cothreads.sgml:
8647         * docs/random/ds/0.9-suggested-changes:
8648         * gst/elements/gstfakesink.h: doc fixes
8649         * gst/elements/gstfakesrc.h: doc fixes
8650         * gst/gstcaps.c: doc fixes
8651         * gst/gstcaps.h: doc fixes
8652         * gst/gstelement.c: doc fixes
8653         * gst/gstelement.h: doc fixes
8654         * gst/gstindex.c: doc fixes
8655         * gst/gstinfo.c: doc fixes
8656         * gst/gstpad.c: doc fixes
8657         * gst/gstpad.h: doc fixes
8658         * gst/gstplugin.c: doc fixes
8659         * gst/gsttypefind.h: doc fixes
8660         * gst/gsturi.c: doc fixes
8661         * gst/gstvalue.c: doc fixes
8662
8663 2004-03-29  Colin Walters  <walters@redhat.com>
8664
8665         * gst/registries/gstxmlregistry.c (get_time)
8666         (plugin_times_older_than_recurse):
8667         Use the result of stat to determine whether a path is a file,
8668         so we don't attempt to opendir() files.
8669
8670 2004-03-29  Benjamin Otte  <otte@gnome.org>
8671
8672         * gst/gstpad.c: (gst_pad_set_explicit_caps):
8673           print caps in debugging output when setting caps failed
8674         * gst/schedulers/entryscheduler.c: (COTHREADS_TYPE),
8675         (schedule_next_element), (get_buffer), (run_chainhandler),
8676         (element_may_start), (gst_entry_scheduler_chain_handler),
8677         (gst_entry_scheduler_get_handler),
8678         (gst_entry_scheduler_state_transition),
8679         (gst_entry_scheduler_pad_link):
8680           make this scheduler a testcase for mandatory
8681           discont-before-first-buffer which is needed if we want to allow apps
8682           to release the sound device.
8683           add SCHED_ASSERT macro to print scheduler state before an assertion
8684           triggers.
8685
8686 2004-03-29  Benjamin Otte  <otte@gnome.org>
8687
8688         * COPYING:
8689           replace by LGPL (former COPYING.LIB). The core is completely
8690           licensed LGPL.
8691         * COPYING.LIB:
8692           remove
8693
8694 2004-03-29  Thomas Vander Stichele  <thomas at apestaart dot org>
8695
8696         * po/af.po:
8697         * po/sv.po:
8698           updated Afrikaans and Swedish
8699
8700 2004-03-29  Thomas Vander Stichele  <thomas at apestaart dot org>
8701
8702         * po/LINGUAS:
8703         * po/az.po:
8704           adding Azerbaijani (Mətin Əmirov)
8705
8706 2004-03-28  Martin Soto  <martinsoto@users.sourceforge.net>
8707
8708         * gst/gstelement.h: 
8709         * gst/gstelement.c (gst_element_set_time_delay): New function for
8710         setting element time taking into account a hardware buffering
8711         delay.
8712         (gst_element_set_time): Now just an invocation of
8713         gst_element_set_time_delay.
8714         * gst/gstclock.h: 
8715         * gst/gstclock.c (gst_clock_get_event_time_delay): New function
8716         allowing to set event times in the future.
8717         (gst_clock_get_event_time): Now just an invocation of
8718         gst_clock_get_event_time_delay.
8719
8720 2004-03-28  Benjamin Otte  <otte@gnome.org>
8721
8722         * gst/gstbin.c: (gst_bin_set_element_sched),
8723         (gst_bin_unset_element_sched):
8724           don't add decoupled elements to schedulers - otherwise it's
8725           impossible to control if a link to a decoupled element was already
8726           removed from a scheduler or not.
8727         * gst/schedulers/cothreads_compat.h:
8728         * gst/schedulers/gthread-cothreads.h:
8729           add COTHREADS_TYPE macro. Make do_cothread_set_func a macro so there
8730           is no "unused" warning.
8731         * gst/schedulers/Makefile.am:
8732         * gst/schedulers/entryscheduler.c:
8733           add new scheduler, based on ideas from talking to David and Martin.
8734           It's supposed to be small and correct. Currently it's also slow (but
8735           it's not noticable)
8736         * examples/retag/retag.c: (main):
8737         * testsuite/bytestream/test1.c: (main):
8738           fix missing NULLs at end of variadic functions
8739         * testsuite/elements/.cvsignore:
8740           update
8741
8742 2004-03-28  Jan Schmidt  <thaytan@mad.scientist.com>
8743
8744         * gst/gstevent.h:
8745         Added GST_EVENT_ANY for GstEvents that pass a GstStructure
8746
8747 2004-03-25  David Schleef  <ds@schleef.org>
8748
8749         * docs/gst/gstreamer-sections.txt:  More doc hacking.
8750         * docs/gst/tmpl/gstaggregator.sgml:
8751         * docs/gst/tmpl/gstautoplugfactory.sgml:
8752         * docs/gst/tmpl/gstbin.sgml:
8753         * docs/gst/tmpl/gstbuffer.sgml:
8754         * docs/gst/tmpl/gstbufferstore.sgml:
8755         * docs/gst/tmpl/gstfakesink.sgml:
8756         * docs/gst/tmpl/gstfakesrc.sgml:
8757         * docs/gst/tmpl/gstmd5sink.sgml:
8758         * docs/gst/tmpl/gstreamer-unused.sgml:
8759         * docs/gst/tmpl/gstsearchfuncs.sgml:
8760         * docs/gst/tmpl/gstshaper.sgml:
8761         * docs/gst/tmpl/gstspider.sgml:
8762         * docs/gst/tmpl/gsttee.sgml:
8763         * docs/gst/tmpl/gstutils.sgml:
8764         * docs/gst/tmpl/gstvalue.sgml:
8765         * docs/gst/tmpl/gstxml.sgml:
8766         * gst/Makefile.am:  Remove gstthreaddummy.c.  It never worked,
8767         and we don't support it.
8768         * gst/gst.c: (gst_init_get_popt_table), (init_pre), (init_post),
8769         (gst_use_threads), (gst_has_threads): same
8770         * gst/gstthreaddummy.c: same
8771         * gst/autoplug/gstspider.c: Make gst_spider_details static.
8772         * gst/autoplug/gstspider.h: same
8773         * gst/elements/gstaggregator.h: Remove bogus function from header
8774         * gst/elements/gstfakesink.h: same
8775         * gst/elements/gstfakesrc.h: same
8776         * gst/elements/gstmd5sink.h: same
8777         * gst/elements/gstshaper.h: same
8778         * gst/elements/gsttee.h: same
8779         * gst/gstbin.c: doc fixes
8780         * gst/gstbin.h: Remove unused definition.
8781         * gst/gstbuffer.c: doc fixes
8782         * gst/gstcaps.c: (gst_caps_is_always_compatible): doc fixes
8783         * gst/gstfilter.c: doc fixes
8784         * gst/gsttag.c: doc fixes
8785         * gst/gstvalue.c: doc fixes
8786
8787 2004-03-25  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8788
8789         * docs/pwg/advanced-types.xml:
8790           Document typefinding.
8791         * docs/pwg/other-oneton.xml:
8792           Document one-to-n elements, demuxers and parsers.
8793
8794 2004-03-25  Tim-Philipp Müller <t.i.m@zen.co.uk>
8795
8796         reviewed by: David Schleef  <ds@schleef.org>
8797
8798         * configure.ac: Check bison version (bug #127838)
8799
8800 2004-03-25  David Schleef  <ds@schleef.org>
8801
8802         * docs/gst/gstreamer-docs.sgml: More fine tuning.
8803         * docs/gst/gstreamer-sections.txt:
8804         * docs/gst/tmpl/gstautoplug.sgml:
8805         * docs/gst/tmpl/gststaticautoplug.sgml:
8806         * docs/gst/tmpl/gststaticautoplugrender.sgml:
8807         * docs/gst/tmpl/gstutils.sgml:
8808         * docs/gst/tmpl/gstxml.sgml:
8809
8810 2004-03-24  David Schleef  <ds@schleef.org>
8811
8812         * docs/gst/gstreamer-docs.sgml:  I got tired of the reference
8813         manual being such complete crap, that I decided to do major
8814         hacking of it.  This checkin replaces any fine tuning that
8815         may have been done previously, with the benefit of actually
8816         being complete for much of the API that was changed since
8817         0.6.  Further fine tuning will occur shortly.  (bug #134721)
8818         * docs/gst/gstreamer-sections.txt:
8819         * docs/gst/tmpl/GstBin.sgml:
8820         * docs/gst/tmpl/GstBuffer.sgml:
8821         * docs/gst/tmpl/GstCaps.sgml:
8822         * docs/gst/tmpl/GstClock.sgml:
8823         * docs/gst/tmpl/GstCompat.sgml:
8824         * docs/gst/tmpl/GstData.sgml:
8825         * docs/gst/tmpl/GstElement.sgml:
8826         * docs/gst/tmpl/GstEvent.sgml:
8827         * docs/gst/tmpl/GstIndex.sgml:
8828         * docs/gst/tmpl/GstStructure.sgml:
8829         * docs/gst/tmpl/GstTag.sgml:
8830         * docs/gst/tmpl/cothreads.sgml:
8831         * docs/gst/tmpl/cothreads_compat.sgml:
8832         * docs/gst/tmpl/gettext.sgml:
8833         * docs/gst/tmpl/grammar.tab.sgml:
8834         * docs/gst/tmpl/gst-i18n-app.sgml:
8835         * docs/gst/tmpl/gst-i18n-lib.sgml:
8836         * docs/gst/tmpl/gst.sgml:
8837         * docs/gst/tmpl/gst_private.sgml:
8838         * docs/gst/tmpl/gstaggregator.sgml:
8839         * docs/gst/tmpl/gstarch.sgml:
8840         * docs/gst/tmpl/gstatomic.sgml:
8841         * docs/gst/tmpl/gstatomic_impl.sgml:
8842         * docs/gst/tmpl/gstbin.sgml:
8843         * docs/gst/tmpl/gstbuffer.sgml:
8844         * docs/gst/tmpl/gstbufferstore.sgml:
8845         * docs/gst/tmpl/gstcaps.sgml:
8846         * docs/gst/tmpl/gstclock.sgml:
8847         * docs/gst/tmpl/gstcompat.sgml:
8848         * docs/gst/tmpl/gstconfig.sgml:
8849         * docs/gst/tmpl/gstcpu.sgml:
8850         * docs/gst/tmpl/gstdata.sgml:
8851         * docs/gst/tmpl/gstdata_private.sgml:
8852         * docs/gst/tmpl/gstelement.sgml:
8853         * docs/gst/tmpl/gstenumtypes.sgml:
8854         * docs/gst/tmpl/gsterror.sgml:
8855         * docs/gst/tmpl/gstevent.sgml:
8856         * docs/gst/tmpl/gstfakesink.sgml:
8857         * docs/gst/tmpl/gstfakesrc.sgml:
8858         * docs/gst/tmpl/gstfilesink.sgml:
8859         * docs/gst/tmpl/gstfilter.sgml:
8860         * docs/gst/tmpl/gstindex.sgml:
8861         * docs/gst/tmpl/gstinfo.sgml:
8862         * docs/gst/tmpl/gstinterface.sgml:
8863         * docs/gst/tmpl/gstlog.sgml:
8864         * docs/gst/tmpl/gstmacros.sgml:
8865         * docs/gst/tmpl/gstmarshal.sgml:
8866         * docs/gst/tmpl/gstmd5sink.sgml:
8867         * docs/gst/tmpl/gstmultifilesrc.sgml:
8868         * docs/gst/tmpl/gstobject.sgml:
8869         * docs/gst/tmpl/gstpad.sgml:
8870         * docs/gst/tmpl/gstparse.sgml:
8871         * docs/gst/tmpl/gstpipeline.sgml:
8872         * docs/gst/tmpl/gstplugin.sgml:
8873         * docs/gst/tmpl/gstpluginfeature.sgml:
8874         * docs/gst/tmpl/gstqueue.sgml:
8875         * docs/gst/tmpl/gstreamer-unused.sgml:
8876         * docs/gst/tmpl/gstregistry.sgml:
8877         * docs/gst/tmpl/gstregistrypool.sgml:
8878         * docs/gst/tmpl/gstscheduler.sgml:
8879         * docs/gst/tmpl/gstsearchfuncs.sgml:
8880         * docs/gst/tmpl/gstshaper.sgml:
8881         * docs/gst/tmpl/gstspider.sgml:
8882         * docs/gst/tmpl/gstspideridentity.sgml:
8883         * docs/gst/tmpl/gststructure.sgml:
8884         * docs/gst/tmpl/gstsystemclock.sgml:
8885         * docs/gst/tmpl/gsttag.sgml:
8886         * docs/gst/tmpl/gsttaginterface.sgml:
8887         * docs/gst/tmpl/gsttee.sgml:
8888         * docs/gst/tmpl/gstthread.sgml:
8889         * docs/gst/tmpl/gsttrace.sgml:
8890         * docs/gst/tmpl/gsttrashstack.sgml:
8891         * docs/gst/tmpl/gsttypefind.sgml:
8892         * docs/gst/tmpl/gsttypes.sgml:
8893         * docs/gst/tmpl/gsturi.sgml:
8894         * docs/gst/tmpl/gsturitype.sgml:
8895         * docs/gst/tmpl/gstutils.sgml:
8896         * docs/gst/tmpl/gstvalue.sgml:
8897         * docs/gst/tmpl/gstversion.sgml:
8898         * docs/gst/tmpl/gstxml.sgml:
8899         * docs/gst/tmpl/gstxmlregistry.sgml:
8900         * docs/gst/tmpl/gthread-cothreads.sgml:
8901         * docs/gst/tmpl/types.sgml:
8902
8903 2004-03-24  Ronald Bultje  <rbultje@ronald.bitfreak.net>
8904
8905         * docs/pwg/other-sink.xml:
8906         * docs/pwg/other-source.xml:
8907           Documentation on how to write source and sink elements. Other
8908           stuff in chapter 4 (1-to-n/demuxer, n-to-1/muxer, n-to-n,
8909           manager, autoplugger) are all still pending.
8910
8911 2004-03-25  Benjamin Otte  <otte@gnome.org>
8912
8913         * testsuite/elements/Makefile.am:
8914         * testsuite/elements/gst-compprep-check:
8915           add check to make sure gst-compprep works
8916         * testsuite/elements/gst-inspect-check.in:
8917           improve initialization output
8918         * testsuite/Makefile.am:
8919         * testsuite/gst-inspect-check:
8920           remove old file
8921
8922 2004-03-24  David Schleef  <ds@schleef.org>
8923
8924         * testsuite/elements/Makefile.am:
8925         * testsuite/elements/gst-inspect-check.in: Add gst-inspect-check
8926         to the testsuite.
8927
8928 2004-03-24  Benjamin Otte  <otte@gnome.org>
8929
8930         * libs/gst/control/dparam.c: (gst_dparam_attach),
8931         (gst_dparam_detach):
8932         * libs/gst/control/dparammanager.c: (gst_dpman_init):
8933           fix lvalue casts for real
8934
8935 2004-03-24  Benjamin Otte  <otte@gnome.org>
8936
8937         * gst/schedulers/gstbasicscheduler.c:
8938         (gst_basic_scheduler_src_wrapper):
8939         * gst/schedulers/gstoptimalscheduler.c:
8940         (gst_opt_scheduler_loop_wrapper), (gst_opt_scheduler_get_wrapper),
8941         (pad_clear_queued), (gst_opt_scheduler_add_element),
8942         (gst_opt_scheduler_remove_element):
8943           fix GStreamer to not have issues with lvalue casts anymore (fixes
8944           #136841)
8945
8946 2004-03-24  Benjamin Otte  <otte@gnome.org>
8947
8948         * gst/gstelement.c:
8949           add documentation about a gobject quirk where the object hasn't the
8950           correct class pointer set on initialization
8951         * gst/schedulers/gstbasicscheduler.c:
8952         (gst_basic_scheduler_src_wrapper):
8953           make sure to not run into an infinite loop
8954
8955 2004-03-22  Benjamin Otte  <otte@gnome.org>
8956
8957         * gst/gstutils.c: (gst_util_dump_mem):
8958         * gst/gstutils.h:
8959           first argument of gst_util_dump_mem should be const
8960
8961 2004-03-22  Johan Dahlin  <johan@gnome.org>
8962
8963         * gst/gstvalue.h: Clean up a little bit.
8964
8965 2004-03-21  Tim-Philipp Müller <t.i.m@zen.co.uk>
8966
8967         reviewed by Benjamin Otte  <otte@gnome.org>
8968
8969         * gst/autoplug/gstspider.c: (gst_spider_dispose):
8970         * gst/elements/gstaggregator.c: (gst_aggregator_finalize),
8971         (gst_aggregator_class_init), (gst_aggregator_init):
8972         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
8973         (gst_filesrc_dispose), (gst_filesrc_set_location):
8974         * gst/elements/gstidentity.c: (gst_identity_finalize),
8975         (gst_identity_class_init), (gst_identity_chain):
8976         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_open_file):
8977         * gst/elements/gststatistics.c: (gst_statistics_finalize),
8978         (gst_statistics_class_init):
8979         * gst/elements/gsttee.c: (gst_tee_finalize), (gst_tee_class_init),
8980         (gst_tee_get_property):
8981           clean up used memory in this elements correctly on teardown (closes
8982           #137279)
8983
8984 2004-03-20  Colin Walters  <walters@redhat.com>
8985
8986         * gst/registries/gstxmlregistry.c:
8987         (gst_xml_registry_open_func, gst_xml_registry_close_func): Make
8988         registry saving atomic.
8989
8990 2004-03-20  Colin Walters  <walters@redhat.com>
8991
8992         * gst/registries/gstxmlregistry.c (gst_xml_registry_get_perms_func):
8993         Just use
8994         access() instead of actually creating and deleting files.
8995
8996 2004-03-18  David Schleef  <ds@schleef.org>
8997
8998         * configure.ac:  Remove HAVE_ATOMIC_H test, since it's unused.
8999         (bug #137625)
9000
9001 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
9002
9003         * po/sv.po: updated translation (Christian Rose)
9004
9005 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
9006
9007         * gst/elements/gstfilesink.c: (gst_filesink_get_formats),
9008         (gst_filesink_get_query_types), (_do_init),
9009         (gst_filesink_handle_event), (gst_filesink_uri_get_protocols):
9010           return FALSE silently
9011         * po/af.po: updated translation (Petri Jooste)
9012
9013 2004-03-18  Thomas Vander Stichele  <thomas at apestaart dot org>
9014
9015         * Makefile.am:
9016         * configure.ac:
9017           dist common properly
9018         * po/af.po:
9019         * po/fr.po:
9020         * po/nl.po:
9021         * po/sr.po:
9022         * po/sv.po:
9023           refreshing translations
9024
9025 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
9026
9027         * po/LINGUAS:
9028         * po/sv.po:
9029         * po/af.po:
9030           adding Swedish (Christian Rose) and Afrikaans (Petri Jooste)
9031
9032 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
9033
9034         * Makefile.am: use common/release.mak
9035
9036 2004-03-17  Thomas Vander Stichele  <thomas at apestaart dot org>
9037
9038         * docs/faq/gst-uninstalled:
9039           adding gst-monkeysaudio to the list of possible plugin dirs
9040
9041 2004-03-16  David Schleef  <ds@schleef.org>
9042
9043         * gst/gst.c: (gst_get_popt_options), (gst_init_get_popt_table),
9044         (gst_init_check_with_popt_table):  Fix some gettext strings to
9045         make them easier to translate.  Required making the strings
9046         non-const.
9047
9048 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
9049
9050         * configure.ac: bump nano to 1
9051
9052 === release 0.8.0 ===
9053
9054 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
9055
9056         * configure.ac: release 0.8.0, "Executive Slacks"
9057
9058 2004-03-16  Johan Dahlin  <johan@gnome.org>
9059
9060         * gst/schedulers/gstoptimalscheduler.c
9061         (gst_opt_scheduler_pad_unlink): Remove double ;,
9062         spotted by Scott Wheeler
9063
9064 2004-03-16  Thomas Vander Stichele  <thomas at apestaart dot org>
9065
9066         * configure.ac: bump libtool version
9067
9068 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
9069
9070         * gst/gstcaps.h:
9071         * gst/gststructure.h:
9072           add reserved padding
9073
9074 2004-03-15  Benjamin Otte  <otte@gnome.org>
9075
9076         * gst/elements/gstfdsrc.c: (gst_fdsrc_get):
9077           set the first parameter for select call correctly.
9078           (fixes #137230)
9079
9080 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
9081
9082         * *.c,*.h: don't mix tabs and spaces
9083
9084 2004-03-15  Johan Dahlin  <johan@gnome.org>
9085
9086         * gst/schedulers/gstoptimalscheduler.c
9087         (gst_opt_scheduler_pad_unlink): Fix bug that causes totem to
9088         crash on MPEG playback. My boolean arithmetic is a bit rusty.
9089
9090         * tools/Makefile.am (EXTRA_DIST): Add gst-indent
9091         
9092 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
9093
9094         * testsuite/Rules:
9095           fix gst-register rules
9096
9097 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
9098
9099         * testsuite/Rules:
9100           use versioned gst-register
9101
9102 2004-03-15  Thomas Vander Stichele  <thomas at apestaart dot org>
9103
9104         * docs/libs/gstreamer-libs-sections.txt:
9105           remove </SUBSECTION>
9106         * gst/gstplugin.c:
9107         * gst/gstregistry.c: (gst_registry_add_plugin):
9108         * gst/registries/gstxmlregistry.c: (gst_xml_registry_get_type),
9109         (gst_xml_registry_open_func), (gst_xml_registry_close_func):
9110           add debugging and fix some comment blocks
9111
9112 2004-03-15  Johan Dahlin  <johan@gnome.org>
9113
9114         * *.h: Revert indent changes.
9115         
9116 2004-03-14  Thomas Vander Stichele  <thomas at apestaart dot org>
9117
9118         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load_plugin):
9119           g_error_free the g_error
9120         * tools/gst-feedback-m.m:
9121           check for other versions of gstreamer
9122         * tools/gst-indent:
9123           use sh, not bash
9124
9125 2004-03-14  Thomas Vander Stichele  <thomas at apestaart dot org>
9126
9127         * tools/gst-register.c: do not spill paths when registries are not
9128           writable, until we fix the "user running gst-register" case.
9129
9130 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
9131
9132         * *.c, *.h: commit of gst-indent run on core
9133
9134 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
9135
9136         * tools/gst-indent:
9137         * tools/Makefile.am:
9138           add our indentation style as a script
9139
9140 2004-03-13  Thomas Vander Stichele  <thomas at apestaart dot org>
9141
9142         * po/sr.po:
9143         * po/LINGUAS:
9144           added Serbian translation
9145
9146 2004-03-13  Benjamin Otte  <otte@gnome.org>
9147
9148         * gst/gstelement.c:
9149           add documentation note about gst_element_found_tags_for_pad not
9150           being usable in getfunctions. (see #137042)
9151
9152 2004-03-12  David Schleef  <ds@schleef.org>
9153
9154         * gst/gstcaps.h: jdahlin, what are you smoking?  We can't just
9155         change API right now!  Readd gst_caps_is_simple() macro.
9156         * gst/gstelement.c: (gst_element_base_class_finalize): Fix
9157         uninitialized variable.  I'd bet this caused crashes.
9158         * gst/gstinfo.c: (gst_debug_print_object):  Fix 64-bit cleanliness.
9159
9160 2004-03-12  Johan Dahlin  <johan@gnome.org>
9161
9162         * gst/gstcaps.h (GST_CAPS_IS_SIMPLE): Capitalize macro
9163         * gst/gstcaps.h: Clean up
9164
9165         * gst/gst.c (init_post): call gst_caps_get_type() instead of
9166         _gst_caps_initalize()
9167
9168         * gst/gstcaps.c: Style fixes, stay closer to glib and friends
9169         (_gst_caps_initialize): Remove, in favor for gst_caps_get_type()
9170
9171         * gst/gststructure.c (gst_structure_get_type): Ditto
9172
9173         * gst/gststructure.h: Ditto
9174         
9175 2004-03-11  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9176
9177         * gst/gstqueue.c: (gst_queue_init):
9178           Reset default max. values in queues. Reason is simply to avoid
9179           braindead use. If you want wider values, use the properties. The
9180           default is supposed to always work. Wider values would make this
9181           beast a memory hog by default (250 full-PAL RGB32 video frames?
9182           That's 440 MB! No thank you).
9183
9184 2004-03-10  David Schleef  <ds@schleef.org>
9185
9186         * tools/gst-run.c: (main):  Fix crash when no relevant tools
9187         were found.  (bug #136793)
9188
9189 2004-03-10  Johan Dahlin  <johan@gnome.org>
9190
9191         * gst/schedulers/gstoptimalscheduler.c
9192         (gst_opt_scheduler_pad_unlink): Implement unlink for elements with
9193         links to elements within the same group, so we can finally remove
9194         that annoying warning. Refactor the code a little bit
9195         (group_dec_links_for_element): Split out
9196
9197 2004-03-09  David Schleef  <ds@schleef.org>
9198
9199         * docs/manual/dparams-app.xml:  Fix to handle double dparams.
9200         (bug #134863)
9201
9202 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
9203
9204         * configure.ac: first bug fix due to major/minor bump
9205
9206 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
9207
9208         * configure.ac: bump nano to 1
9209
9210 === release 0.7.6 ===
9211
9212 2004-03-09  Thomas Vander Stichele  <thomas at apestaart dot org>
9213
9214         * NEWS:
9215         * RELEASE:
9216         * configure.ac:
9217           releasing 0.7.6, "Almost"
9218         * po/fr.po:
9219         * po/nl.po:
9220         * tools/Makefile.am:
9221         * tools/gst-feedback-m.m:
9222           unversioned source
9223
9224 2004-03-09  Johan Dahlin  <johan@gnome.org>
9225
9226         Reviewed by: Thomas Vander Stichele
9227
9228         * gst/gstelement.c (gst_element_class_init): register second
9229         parameter as GST_TYPE_G_ERROR instead of G_TYPE_POINTER, so
9230         language bindings can (de)marshall correctly.
9231
9232         * gst/gsterror.h: Add GST_TYPE_G_ERROR and cleanup a little bit
9233
9234         * gst/gsterror.c (gst_g_error_get_type): New function
9235
9236         * gst/gstmarshal.list: Remove VOID:OBJECT,POINTER,STRING, replace
9237         with VOID:OBJECT,OBJECT,STRING 
9238
9239 2004-03-10  Jan Schmidt  <thaytan@mad.scientist.com>
9240
9241         * gst/registries/gstxmlregistry.c: (gst_xml_registry_load):
9242         Free a leaked g_timer on early returns.
9243
9244 2004-03-08  Ronald Bultje  <rbultje@ronald.bitfreak.net>
9245
9246         * docs/pwg/advanced-types.xml:
9247           Add cinepak description.
9248
9249 2004-03-07  David Schleef  <ds@schleef.org>
9250
9251         * docs/random/mimetypes:  Added cinepak description
9252
9253 2004-03-07  Andy Wingo  <wingo@pobox.com>
9254
9255         * gst/gstbin.c (gst_bin_remove): Debugging fixes.
9256
9257         * gst/schedulers/gstoptimalscheduler.c (destroy_group): Assert
9258         there are no links to other groups when a group is destroyed.
9259         (gst_opt_scheduler_pad_unlink): If the unlink means an element is
9260         removed from a group, make sure the link count to elements linked
9261         to other pads is appropriately decremented. This really fixes
9262         #135672.
9263
9264         The 1.60->1.61 patch has been reapplied in light of this fix.
9265
9266         * gst/gstelement.c (gst_element_dispose): Really protect against
9267         multiple invocations this time.
9268
9269 2004-03-06  Thomas Vander Stichele  <thomas at apestaart dot org>
9270
9271         * docs/gst/gstreamer-sections.txt:
9272         * docs/gst/tmpl/gsttag.sgml:
9273           remove some deprecated functions, document some existing ones
9274         * gst/gsttag.c: (gst_tag_get_flag):
9275         * gst/gsttag.h:
9276           add accessor function
9277
9278 2004-03-06  Thomas Vander Stichele  <thomas at apestaart dot org>
9279
9280         * docs/gst/gstreamer-sections.txt:
9281         * docs/gst/tmpl/gsttag.sgml:
9282         * docs/gst/tmpl/gstxml.sgml:
9283         * gst/gsttag.c: (gst_tag_get_flag):
9284         * gst/gsttag.h:
9285
9286 2004-03-06  Christophe Fergeau  <teuf@gnome.org>
9287
9288         * gst/autoplug/gstspider.c: (gst_spider_identity_plug): fixed caps
9289         leak
9290
9291 2004-03-05  David Schleef  <ds@schleef.org>
9292
9293         * REQUIREMENTS: Add bison and flex.
9294         * configure.ac: Fix comment about bison.
9295         * docs/random/ds/0.9-suggested-changes: yer ma
9296         * tools/gst-inspect.c: (print_element_info):  Fix warning.
9297
9298 2004-03-05  Benjamin Otte  <otte@gnome.org>
9299
9300         * gst/gstelement.c: (gst_element_error_full):
9301           revert recent recursive state changing commit - messing with other
9302           elements' states is evil and should be done by apps only.
9303
9304 2004-03-05  Benjamin Otte  <otte@gnome.org>
9305
9306         * gst/gstelement.c: (gst_element_get_compatible_pad_template):
9307           check for empty intersection instead of NULL caps
9308         (gst_element_get_compatible_pad_filtered):
9309           remove old workaround that is only a bug nowadays
9310
9311 2004-03-05  Thomas Vander Stichele  <thomas at apestaart dot org>
9312
9313         * gst/gstelement.c: (gst_element_error_full):
9314           make elements try to recursively change state to PAUSED on all
9315           parents after an error to suppress ensuing warnings
9316         * gst/parse/grammar.y:
9317           make it check if it was able to sync the state, and throw an error
9318           if not, so stuff like
9319           oggdemux ! vorbisdec ! osssink gets caught
9320
9321 2004-03-05  Thomas Vander Stichele  <thomas at apestaart dot org>
9322
9323         * configure.ac: use ${libdir} for PLUGINS_DIR since on 64bit
9324           it contains lib64; use AS_AC_EXPAND to handle it properly
9325
9326 2004-03-05  David Schleef  <ds@schleef.org>
9327
9328         * gst/gstcpuid_i386.s:  Remove unused code
9329         * libs/gst/getbits/getbits.c: (gst_getbits_init),
9330         (gst_getbits_newbuf): Remove MMX code
9331         * libs/gst/getbits/getbits.h: Remove MMX code
9332
9333 2004-03-04  David I. Lehn  <dlehn@users.sourceforge.net>
9334
9335         * debian/.cvsignore:
9336         * debian/README.Debian:
9337         * debian/changelog:
9338         * debian/control:
9339         * debian/control.in:
9340         * debian/copyright:
9341         * debian/gstreamer-core-libs-dev.files:
9342         * debian/gstreamer-core-libs.files:
9343         * debian/gstreamer-core.files:
9344         * debian/gstreamer-core.postinst:
9345         * debian/gstreamer-core.postrm:
9346         * debian/gstreamer-doc.files:
9347         * debian/gstreamer-doc.links:
9348         * debian/gstreamer-doc.lintian:
9349         * debian/gstreamer-runtime.files:
9350         * debian/gstreamer-runtime.manpages:
9351         * debian/gstreamer-runtime.postinst:
9352         * debian/gstreamer-runtime.postrm:
9353         * debian/gstreamer-tools.files:
9354         * debian/gstreamer-tools.manpages:
9355         * debian/libgstreamer-dev.files:
9356         * debian/libgstreamer0.4.1.files:
9357         * debian/libgstreamerVERSION.files:
9358         * debian/rules:
9359         Debian package info not maintained here.
9360
9361 2004-03-04  Thomas Vander Stichele  <thomas at apestaart dot org>
9362
9363         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
9364         * gst/gstbin.c: (gst_bin_class_init):
9365         * gst/gstelement.c: (gst_element_class_init):
9366         * gst/gstindex.c: (gst_index_class_init):
9367         * gst/gstobject.c: (gst_object_class_init),
9368         (gst_signal_object_class_init):
9369         * gst/gstpad.c: (gst_pad_template_class_init):
9370         * gst/gstregistry.c: (gst_registry_class_init):
9371         * gst/gsturi.c: (gst_uri_handler_base_init):
9372         * gst/gstxml.c: (gst_xml_class_init):
9373         * libs/gst/control/dparam.c: (gst_dparam_class_init):
9374         * libs/gst/control/dparammanager.c: (gst_dpman_class_init):
9375           make all signal names use dashes instead of underscore
9376
9377 2004-03-03  Thomas Vander Stichele  <thomas at apestaart dot org>
9378
9379         * configure.ac: AC_SUBST GLIB_ONLY CFLAGS and LIBS
9380
9381 2004-03-03  Benjamin Otte  <otte@gnome.org>
9382
9383         * gst/schedulers/gstoptimalscheduler.c:
9384           revert last commit by Andy Wingo. It causes segfaults on unreffing
9385           in Rhythmbox. (see bug #135672)
9386
9387 2004-03-02  Christophe Fergeau  <teuf@gnome.org>
9388
9389         * po/fr.po: fix typo
9390
9391 2004-03-02  Christophe Fergeau  <teuf@gnome.org>
9392
9393         * tools/gst-inspect.c: (main): 
9394         * tools/gst-launch.c: (main): add calls to bind_textdomain_codeset
9395
9396 2004-03-02  Thomas Vander Stichele  <thomas at apestaart dot org>
9397
9398         * configure.ac:
9399           get GLIB_ONLY and POPT flags for the nonversioned binaries
9400         * tools/Makefile.am:
9401           use them
9402
9403 2004-03-02  Thomas Vander Stichele  <thomas at apestaart dot org>
9404
9405         * gst/gst.c: (init_post):
9406           change so that GST_REGISTRY now is where the global registry gets
9407           saved, since that is where plugins now get attached to first, and
9408           spilled over to the user registry.  Note that in the case of using
9409           GST_REGISTRY env var, we don't want to affect any real registries
9410           beyond the one given by this var, and thus we don't set a user
9411           registry to spill to.  So make sure GST_REGISTRY is writable.
9412
9413 2004-03-01  David Schleef  <ds@schleef.org>
9414
9415         * AUTHORS:  Added some names.  Add yourself if you're missing.
9416
9417 2004-03-01  David Schleef  <ds@schleef.org>
9418
9419         * MAINTAINERS: Add
9420
9421 2004-03-01  Thomas Vander Stichele  <thomas at apestaart dot org>
9422
9423         * configure.ac:
9424           remove whitespace
9425         * docs/gst/tmpl/gstbuffer.sgml:
9426         * docs/gst/tmpl/gstdata.sgml:
9427         * docs/gst/tmpl/gstreamer-unused.sgml:
9428         * docs/gst/tmpl/gstxml.sgml:
9429           doc update
9430         * docs/manuals.mak:
9431           add a FIXME
9432         * docs/pwg/intro-preface.xml:
9433         * docs/pwg/pwg.xml:
9434           remove GNOME
9435         * gst/gst.c: (init_post):
9436           try GST_PLUGIN_PATH paths for the _global_registry first
9437         * gst/gstelement.h:
9438           add the error message as well, otherwise (null) debug info doesn't
9439           make much sense
9440         * tools/gst-register.c: (main):
9441           spill paths to next registry if this registry is not writable
9442         * po/fr.po:
9443         * po/nl.po:
9444           translation updates
9445
9446 2004-03-01  Johan Dahlin  <johan@gnome.org>
9447
9448         * gst/gstbuffer.c (_gst_buffer_initialize): 
9449         * gst/gstdata.c (gst_data_get_type): 
9450         * gst/gstevent.c (_gst_event_initialize): Use gst_data_copy,
9451         instead of ref, since some applications that uses GBoxed
9452         routines depends on a function that actually returns a copy.
9453
9454 2004-02-27  Benjamin Otte  <otte@gnome.org>
9455
9456         * gst/gstbuffer.h:
9457           remove gst_buffer_free, use gst_data_unref
9458         * gst/gstdata.c: (gst_data_get_type):
9459           use refcounting in GstData GBoxed registration
9460         * gst/gstdata.h:
9461           remove gst_data_free, use gst_data_unref
9462
9463 2004-02-27  Johan Dahlin  <johan@gnome.org>
9464
9465         * gst/gstdata.c (gst_data_get_type): New function, register
9466         GstData as a GBoxed type.
9467
9468         * gst/gstdata.h (GST_TYPE_DATA): New macro
9469
9470 2004-02-27  Thomas Vander Stichele  <thomas at apestaart dot org>
9471
9472         * Makefile.am:
9473         * gstreamer.spec.in:
9474           put back RELEASE
9475         * gst/Makefile.am:
9476           clean up non-disting of built files
9477         * testsuite/debug/commandline.c:
9478           test fix for option rename
9479
9480 2004-02-26  David Schleef  <ds@schleef.org>
9481
9482         * configure.ac:  We don't really need glib-2.3.  Also remove
9483         some unneeded checks for library functions.
9484         * gst/Makefile.am:  Instead, we need to not dist files created
9485         by glib-genmarshal.
9486
9487 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
9488
9489         * configure.ac:
9490           bump glib required version to 2.3.0 for g_value_takes_boxed
9491
9492  2004-02-25  Christian Fredrik Kalager Schaller <uraeus@gnome.org>
9493
9494         * common/m4/gst-docs.m4
9495         change flavour text from enable to disable as enable is our default
9496         closes bug Bug 135304
9497
9498 === release 0.7.5 ===
9499  
9500  2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
9501  
9502         * NEWS:
9503           instate NEWS file
9504         * Makefile.am:
9505         * gstreamer.spec.in:
9506         * RELEASE:
9507           put back release
9508         * configure.ac:
9509         * docs/random/release:
9510           more updates
9511
9512 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
9513
9514         * gst/gsttag.c: (_gst_tag_initialize):
9515         * po/fr.po:
9516         * po/nl.po:
9517           remove hyphen from codec tags
9518
9519 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
9520
9521         * gst/parse/Makefile.am:
9522           fix dependency so that a make from a clean build works the first
9523           time
9524
9525 2004-02-26  Thomas Vander Stichele  <thomas at apestaart dot org>
9526
9527         * docs/random/release:
9528           update release strategy
9529         * po/fr.po:
9530           auto-update po file
9531         * po/nl.po:
9532           update dutch translation
9533
9534 2004-02-25  Thomas Vander Stichele  <thomas at apestaart dot org>
9535
9536         * docs/manual/debugging.xml:
9537         fix manual for new debugging system
9538
9539 2004-02-25  Andy Wingo  <wingo@pobox.com>
9540
9541         * gst/gstpad.c (gst_pad_link_prepare): Re-add
9542         gst_pad_link_prepare. Please email the list with specific reasons
9543         for reverting.
9544
9545 2004-02-24  Andy Wingo  <wingo@pobox.com>
9546
9547         * gst/gstelement.c (gst_element_dispose): Protect against multiple
9548         invocations.
9549
9550         * gst/schedulers/gstoptimalscheduler.c:
9551         I added a mess of prototypes at the top of the file by way of
9552         documentation. Some of the operations on chains and groups were
9553         re-organized.
9554
9555         (create_group): Added a type argument so if the group is enabled,
9556         the setup_group_scheduler knows what to do.
9557         (group_elements): Added a type argument here, too, to be passed on
9558         to create_group.
9559         (group_element_set_enabled): If an unlinked PLAYING element is
9560         added to a bin, we have to create a new group to hold the element,
9561         and this function will be called before the group is added to the
9562         chain. Thus we have a valid case for group->chain==NULL. Instead
9563         of calling chain_group_set_enabled, just set the flag on the group
9564         (the chain's status will be set when the group is added to it).
9565         (gst_opt_scheduler_state_transition, chain_group_set_enabled):
9566         Setup the group scheduler when the group is enabled, not
9567         specifically when an element goes PAUSED->PLAYING. This means
9568         PLAYING elements can be added, linked, and scheduled into a
9569         PLAYING pipeline, as was intended.
9570         (add_to_group): Don't ref the group twice. I don't know when this
9571         double-ref got in here. Removing it has the potential to cause
9572         segfaults if other parts of the scheduler are buggy. If you find
9573         that the scheduler is segfaulting for you, put in an extra ref
9574         here and see if that hacks over the underlying issue. Of course,
9575         then find out what code is unreffing a group it doesn't own...
9576         (create_group): Make the extra refcount floating, and remove it
9577         after adding the element. This means that...
9578         (unref_group): Destroy when the refcount reaches 0, not 1, like
9579         every other refcounted object in the known universe.
9580         (remove_from_group): When a group becomes empty, set it to be not
9581         active, and remove it from its chain. Don't unref it again,
9582         there's no floating reference any more.
9583         (destroy_group): We have to remove the group from the chain in
9584         remove_from_group (rather than here) to break refcounting cycles
9585         (the chain always has a ref on the group). So assert that
9586         group->chain==NULL.
9587         (ref_group_by_count): Removed, it was commented out anyway.
9588         (merge_chains): Use the remove_from_chain and add_to_chain
9589         primitives to do the reparenting, instead of rolling our own
9590         implementation.
9591         (add_to_chain): The first non-disabled group in the chain's group
9592         list will be the entry point for the chain. Because buffers can
9593         accumulate in loop elements' peer bufpens, we preferentially
9594         schedule loop groups before get groups to avoid unnecessary
9595         execution of get-based groups when the bufpens are already full.
9596         (gst_opt_scheduler_schedule_run_queue): Debug fixes.
9597         (get_group_schedule_function): Ditto.
9598         (loop_group_schedule_function): Ditto.
9599         (gst_opt_scheduler_loop_wrapper): Ditto.
9600         (gst_opt_scheduler_iterate): Ditto.
9601
9602         I understand the opt scheduler now, yippee!
9603
9604         * gst/gstpad.c: All throughout, added FIXMEs to look at for 0.9.
9605         (gst_pad_get_name, gst_pad_set_chain_function) 
9606         (gst_pad_set_get_function, gst_pad_set_event_function) 
9607         (gst_pad_set_event_mask_function, gst_pad_get_event_masks) 
9608         (gst_pad_get_event_masks_default, gst_pad_set_convert_function) 
9609         (gst_pad_set_query_function, gst_pad_get_query_types) 
9610         (gst_pad_get_query_types_default) 
9611         (gst_pad_set_internal_link_function) 
9612         (gst_pad_set_formats_function, gst_pad_set_link_function) 
9613         (gst_pad_set_fixate_function, gst_pad_set_getcaps_function) 
9614         (gst_pad_set_bufferalloc_function, gst_pad_unlink) 
9615         (gst_pad_renegotiate, gst_pad_set_parent, gst_pad_get_parent) 
9616         (gst_pad_add_ghost_pad, gst_pad_proxy_getcaps) 
9617         (gst_pad_proxy_pad_link, gst_pad_proxy_fixate) 
9618         (gst_pad_get_pad_template_caps, gst_pad_check_compatibility) 
9619         (gst_pad_get_peer, gst_pad_get_allowed_caps) 
9620         (gst_pad_alloc_buffer, gst_pad_push, gst_pad_pull) 
9621         (gst_pad_selectv, gst_pad_select, gst_pad_template_get_caps) 
9622         (gst_pad_event_default_dispatch, gst_pad_event_default) 
9623         (gst_pad_dispatcher, gst_pad_send_event, gst_pad_convert_default) 
9624         (gst_pad_convert, gst_pad_query_default, gst_pad_query) 
9625         (gst_pad_get_formats_default, gst_pad_get_formats): Better
9626         argument checks, and some doc fixes.
9627
9628         (gst_pad_custom_new_from_template): Um, does anyone
9629         use these functions? Actually make a custom pad instead of a
9630         normal one.
9631         (gst_pad_try_set_caps): Transpose some checks.
9632         (gst_pad_try_set_caps_nonfixed): Same, and use a macro to check if
9633         the pad is in negotiation.
9634         (gst_pad_try_relink_filtered): Use pad_link_prepare.
9635         
9636         * gst/gstelement.c: Remove prototypes also defined in gstclock.h.
9637
9638         * gst/gstelement.h: 
9639         * gst/gstclock.h: Un-deprecate the old clocking API, as discussed
9640         on the list.
9641
9642 2004-02-24  Thomas Vander Stichele  <thomas at apestaart dot org>
9643
9644         * gst/gstbin.c: (gst_bin_add):
9645           add error for not being able to add elements
9646
9647 2004-02-22  Julien MOUTTE <julien@moutte.net>
9648
9649         * gst/gsttag.c: (_gst_tag_initialize): Registering 2 new tags,
9650         audio-codec and video-codec.
9651
9652 2004-02-22  Benjamin Otte  <otte@gnome.org>
9653
9654         reported by: Padraig O'Briain <padraig.obriain@sun.com>
9655
9656         * autogen.sh:
9657           replace test -e with test -x for mkinstalldirs to be more portable.
9658           (fixes #134816)
9659
9660 2004-02-22  Benjamin Otte  <otte@gnome.org>
9661
9662         * gst/gstpad.c:
9663           revert last patch from Andy, it makes gst_pad_can_link_filtered much
9664           too noisy
9665         * gst/gsttag.c: (_gst_tag_initialize):
9666         * gst/gsttag.h:
9667           add GST_TAG_ALBUM_VOLUME_{COUNT,NUMBER}
9668         * libs/gst/control/dparam.c: (gst_dparam_attach):
9669         * libs/gst/control/dparammanager.c: (gst_dpman_attach_dparam):
9670           check that types for attached dparams match
9671
9672 2004-02-22  Thomas Vander Stichele  <thomas at apestaart dot org>
9673
9674         * gst/elements/gstfilesink.c: (gst_filesink_open_file):
9675         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
9676         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_open_file):
9677           fix errors
9678
9679 2004-02-20  Andy Wingo  <wingo@pobox.com>
9680
9681         * gst/gstbin.c:
9682         * gst/gstbuffer.c:
9683         * gst/gstplugin.c:
9684         * gst/registries/gstxmlregistry.c: 
9685         * gst/schedulers/gstoptimalscheduler.c: Debugging tweaks.
9686
9687         * gst/gstelement.c (gst_element_set_scheduler): Debugging fixes.
9688         (gst_element_add_pad): DEBUG->INFO, some fixes.
9689         (gst_element_get_compatible_pad_template): Just see if the
9690         templates' caps intersect, not if one is a strict subset of the
9691         other. This conforms more to what gst_pad_link_intersect() does.
9692         (gst_element_class_add_pad_template): Don't memcpy the pad
9693         template, just ref it.
9694         (gst_element_get_compatible_pad_filtered): Clean up debug messages
9695
9696         * gst/gstpad.c (gst_pad_can_link_filtered): Debug a true result.
9697         (gst_pad_link_filtered): Debug changes.
9698         (gst_pad_link_prepare): New function, consolidated from
9699         can_link_filtered and link_filtered.
9700
9701         * gst/parse/grammar.y (gst_parse_perform_link): Made INFO output
9702         look more like that of the functions in gstelement.c
9703
9704         * gst/gstinfo.c (gst_debug_print_object): Put a space before the
9705         object, and return the empty string if object is NULL.
9706
9707         * gst/parse/parse.l: Remove trailing newlines when calling PRINT.
9708         * gst/parse/grammar.y (YYFPRINTF): Log bison debugging info via
9709         LOG, not DEBUG. We still get flex info on debug.
9710
9711         * gst/registries/gstxmlregistry.c (gst_xml_registry_load): Make
9712         debug string more verbose.
9713         (plugin_times_older_than): DEBUG->LOG.
9714
9715 2004-02-20  Julien MOUTTE <julien@moutte.net>
9716
9717         * gst/gsttag.h: Adding video-codec and audio-codec for demuxers which
9718         will emit found_tag for each stream they demux with the codec.
9719
9720 2004-02-20  Benjamin Otte  <otte@gnome.org>
9721
9722         * gst/gstevent.c: (_gst_event_copy), (_gst_event_free):
9723           copy navigation event correctly. Check freeing tag lists. 
9724         * gst/gstthread.c: (gst_thread_change_state):
9725           don't abort() on state changing mess - it might happen because of
9726           bugs.
9727         * gst/gstvalue.c: (gst_value_set_caps), (gst_value_get_caps):
9728           use boxed functions
9729         * gst/gstvalue.h:
9730           fix GST_VALUE_HOLDS_CAPS
9731
9732 2004-02-19  David Schleef  <ds@schleef.org>
9733
9734         * gst/gstinfo.h:  Copy G_STRFUNC implementation from glib-2.4
9735         and use it for GST_FUNCTION.  (bug #134750)
9736
9737 2004-02-19  Thomas Vander Stichele  <thomas at apestaart dot org>
9738
9739         * po/fr.po:
9740         * po/nl.po:
9741           updating translations
9742
9743 2004-02-19  Thomas Vander Stichele  <thomas at apestaart dot org>
9744
9745         * tools/gst-run.c: (get_candidates), (main): some fixes from jdahlin
9746
9747 2004-02-18  kost@imn.htwk-leipzig.de
9748
9749         reviewed by: David Schleef  <ds@schleef.org>
9750
9751         * docs/libs/gstreamer-libs-sections.txt:  Add missing sections
9752         for libgstcontrol.
9753
9754 2004-02-18  David Schleef  <ds@schleef.org>
9755
9756         * libs/gst/control/dparam.c: (gst_dparam_class_init):
9757         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_class_init),
9758         (gst_dpsmooth_new): Additional fixes to get double dparams working.
9759         * tools/gst-inspect.c: (print_element_info): Support dumping of
9760         double dparam information.
9761
9762 2004-02-17  David Schleef  <ds@schleef.org>
9763
9764         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_class_init):
9765         Use G_TYPE_STRING in signal prototype instead of G_TYPE_POINTER.
9766         * gst/elements/gsttypefind.c: (gst_type_find_element_class_init):
9767         Use GST_TYPE_CAPS in signal prototype.
9768         * gst/gstcaps.c: (_gst_caps_initialize), (gst_caps_copy_conditional):
9769         Convert GST_TYPE_CAPS to boxed.
9770         * gst/gstelement.c: (gst_element_class_init):
9771         Use GST_TYPE_TAG_LIST in signal prototype.
9772         * gst/gstindex.c: (gst_index_class_init):
9773         * gst/gstindex.h:
9774         Add GST_TYPE_INDEX_ENTRY type.
9775         * gst/gstmarshal.list:
9776         Add necessary marshal types.
9777         * gst/gstpad.c: (gst_real_pad_class_init),
9778         (_gst_real_pad_fixate_accumulator), (gst_pad_link_fixate),
9779         (gst_pad_recover_caps_error):
9780         Use GST_TYPE_CAPS in signal prototypes.  Fix some debugging strings.
9781         * gst/gststructure.c: (_gst_structure_initialize),
9782         (gst_structure_copy), (_gst_structure_copy_conditional):
9783         * gst/gststructure.h:
9784         Convert GST_TYPE_STRUCTURE to boxed.
9785         * gst/gsttag.c: (gst_tag_list_get_type):
9786         * gst/gsttag.h:
9787         Add GST_TYPE_TAG_LIST type.
9788
9789 2004-02-17  Julien MOUTTE  <julien@moutte.net>
9790
9791         * gst/gstpad.c: (gst_pad_try_set_caps): Reverting my change according
9792         to what we agreed with david.
9793         * gst/gstpad.h: adding GST_PAD_IS_NEGOTIATING macro.
9794
9795 2004-02-17  Thomas Vander Stichele  <thomas at apestaart dot org>
9796
9797         * po/nl.po: update translation
9798
9799 2004-02-17  Thomas Vander Stichele  <thomas at apestaart dot org>
9800
9801         * gst/autoplug/gstspider.c: (gst_spider_identity_plug):
9802           throw an error if spider is trying to play a mime type there is
9803           no decoder for
9804         * po/POTFILES.in:
9805           add gst/autoplug/gstspider.c for translation
9806
9807 2004-02-17  Julien MOUTTE  <julien@moutte.net>
9808
9809         * gst/gstpad.c: (gst_pad_try_set_caps): We are nice people. Return 
9810         silently when the pad is negotiating.
9811
9812 2004-02-16  Thomas Vander Stichele  <thomas at apestaart dot org>
9813
9814         * docs/faq/Makefile.am:
9815           add script to run gstreamer uninstalled 
9816         * docs/faq/faq.xml:
9817         * docs/faq/developing.xml:
9818         * docs/faq/gst-uninstalled:
9819           extract script to run gstreamer uninstalled
9820         * docs/manuals.mak:
9821           add EXTRA_SOURCES variable for Makefile.am's to set to
9822           use additional SOURCE files for the doc build
9823
9824 2004-02-16  Thomas Vander Stichele  <thomas at apestaart dot org>
9825
9826         * gst/gstatomic_impl.h: Fedora 2 test package patch for S390
9827
9828 2004-02-15  Julien MOUTTE  <julien@moutte.net>
9829
9830         * gst/gstbin.c: (gst_bin_change_state), (gst_bin_iterate): Fix a big
9831         bug that was breaking pipelines like sinesrc ! { queue ! osssink } when
9832         an error was thrown by osssink. Basically a state change failure for
9833         an element in a different scheduling group was considered as
9834         successful, which means that caps nego was going on and weird stuff
9835         happened. Like I wrote in the comment there, if someone wants to
9836         revert that please drop me a mail explaining why because I really see
9837         no point in keeping that broken behaviour there.
9838         * gst/gstqueue.c: (gst_queue_get): Add a safety check as the queue CAN
9839         be empty, we then return NULL which will trigger a nice error when 
9840         pulling from the pad.
9841
9842 2004-02-13  David Schleef  <ds@schleef.org>
9843
9844         * libs/gst/control/dparam.c: (gst_dparam_class_init),
9845         (gst_dparam_get_property), (gst_dparam_set_property),
9846         (gst_dparam_do_update_default):
9847         * libs/gst/control/dparam.h:
9848         * libs/gst/control/dparam_smooth.c: (gst_dpsmooth_class_init),
9849         (gst_dpsmooth_new), (gst_dpsmooth_set_property),
9850         (gst_dpsmooth_get_property), (gst_dpsmooth_value_changed_double),
9851         (gst_dpsmooth_do_update_double):
9852         * libs/gst/control/dparam_smooth.h:
9853         * libs/gst/control/dparammanager.c:
9854         (gst_dpman_inline_direct_update):
9855         Add support for double dparams.
9856
9857 2004-02-13  David Schleef  <ds@schleef.org>
9858
9859         * gst/elements/gstfdsrc.c: (gst_fdsrc_get): Use GST_TIME_TO_TIMEVAL()
9860         * gst/gstclock.h: Avoid using 64-bit % operator (slow!)
9861
9862 2004-02-13  Mattias Wadman  <mattias@sudac.org>
9863
9864         reviewed by: David Schleef  <ds@schleef.org>
9865
9866         * gst/elements/gstfdsrc.c: (gst_fdsrc_class_init),
9867         (gst_fdsrc_init), (gst_fdsrc_set_property),
9868         (gst_fdsrc_get_property), (gst_fdsrc_get):
9869         * gst/elements/gstfdsrc.h:  Adds timeout property to fdsrc,
9870         and sends an EOS event if file descriptor reading times out.
9871
9872 2004-02-13  Thomas Vander Stichele  <thomas at apestaart dot org>
9873
9874         * configure.ac:
9875           add calls to AM_CONDITIONAL for subsystems for automake 1.6.x
9876
9877 2004-02-13  Thomas Vander Stichele  <thomas at apestaart dot org>
9878
9879         * configure.ac: pass required libxml version as argument
9880         (bug reported by Christophe Fergeau)
9881
9882 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
9883   
9884         * docs/gst/gstreamer-docs.sgml:
9885         * docs/gst/tmpl/gstxml.sgml:
9886         * docs/libs/gstreamer-libs-docs.sgml:
9887           version API docs
9888
9889 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
9890
9891         * gst/gstinfo.c:
9892         * gst/gstregistrypool.c: (gst_registry_pool_plugin_filter),
9893         (gst_registry_pool_feature_filter):
9894         * gst/gstthread.c: (gst_thread_class_init):
9895         * gst/gstvalue.c:
9896           add includes exposed by building without libxml
9897         * gst/indexers/Makefile.am:
9898           do not build fileindex when LOADSAVE disabled; we should have
9899           a better libxml check later since fileindex depends on xml, not
9900           LOADSAVE or REGISTRY
9901         * libs/gst/control/Makefile.am:
9902           link with m
9903         * tools/Makefile.am:
9904           fix wrong source code for gst-xmlinspect
9905
9906 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
9907
9908         * configure.ac:
9909           fix gcov help output
9910           move calls to and use new GST_CHECK_DISABLE_SUBSYSTEM
9911         * docs/random/release:
9912           some updated releasing notes
9913         * gstreamer.spec.in:
9914           more updates
9915
9916 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
9917
9918         * docs/faq/faq.xml:
9919         * docs/manual/manual.xml:
9920         * docs/pwg/pwg.xml:
9921         * docs/pwg/titlepage.xml:
9922           put version in documentation
9923
9924 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
9925
9926         * tools/Makefile.am: fix man page installation
9927
9928 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
9929
9930         * configure.ac:
9931           don't check for libxml when load/save and registry disabled (#105844)
9932         * gstreamer.spec.in:
9933           sync with fedora candidate spec
9934
9935 2004-02-12  Thomas Vander Stichele  <thomas at apestaart dot org>
9936
9937         * po/fr.po:
9938         * po/nl.po:
9939           replace multidisksrc with multifilesrc
9940
9941 2004-02-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
9942
9943         * po/POTFILES.in:
9944           update to multidisksrc => multifilesrc file renaming (#134145)
9945
9946 2004-02-11  David Schleef  <ds@schleef.org>
9947
9948         * docs/gst/tmpl/gstcaps.sgml:  Fix stuff that mentions GstProps
9949         * docs/gst/tmpl/gstpadtemplate.sgml: same
9950         * docs/gst/tmpl/gstreamer-unused.sgml: Remove GstProps
9951         * gst/gstobject.c: (gst_object_set_name_default): Do the memleak
9952         fixing dance.
9953         * gst/gstutils.c: Remove disabled code that uses GstProps.
9954         * gst/registries/gstxmlregistry.h: same
9955         * docs/random/ds/0.9-suggested-changes: random notes
9956
9957 2004-02-11  kost@imn.htwk-leipzig.de
9958
9959         reviewed by: David Schleef  <ds@schleef.org>
9960
9961         * gst/gstclock.c: (gst_clock_entry_new): fixes structure
9962         initialisation of clock (bug #134128)
9963
9964 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
9965
9966         * configure.ac:
9967         * gst/elements/Makefile.am:
9968         * gst/elements/gstelements.c:
9969         * gst/elements/gstmultifilesrc.c: (gst_multifilesrc_base_init),
9970         (gst_multifilesrc_class_init), (gst_multifilesrc_init),
9971         (gst_multifilesrc_set_property), (gst_multifilesrc_get_property),
9972         (gst_multifilesrc_get), (gst_multifilesrc_open_file),
9973         (gst_multifilesrc_close_file), (gst_multifilesrc_change_state):
9974         * gst/elements/gstmultifilesrc.h:
9975           rename multidisksrc to multifilesrc (part of #122200)
9976
9977 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
9978
9979         * docs/manuals.mak:
9980           fix automake complaints
9981         * gst-element-check.m4:
9982           fix unquotedness
9983
9984 2004-02-11  David Schleef  <ds@schleef.org>
9985
9986         * docs/gst/Makefile.am: Call gst_init() in built gstreamer-scan.
9987         * gst/gstatomic_impl.h: Disable sparc implementation.
9988
9989 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
9990
9991         * gst-element-check.m4:
9992           fix underquoted macros as reported by automake 1.8.x (#133800)
9993         * configure.ac:
9994           require gettext 0.11.5 so ulonglong.m4 gets checked out and copied
9995           by autopoint (fixes #132996)
9996
9997 2004-02-10  Andy Wingo  <wingo@pobox.com>
9998
9999         * gst/gstpad.c (gst_pad_custom_new): Add a FIXME, this is a hacky
10000         way to do inheritance.
10001         (gst_pad_get_event_masks, gst_pad_get_event_masks_default) 
10002         (gst_pad_get_query_types, gst_pad_get_query_types_default):
10003         Routine docs.
10004         (gst_pad_set_link_function, gst_pad_set_fixate_function) 
10005         (gst_pad_set_getcaps_function): Doc from Dave's negotation random
10006         doc.
10007         (gst_pad_unlink, gst_pad_is_linked): Docs.
10008         (gst_pad_renegotiate): A brief description of capsnego.
10009         (gst_pad_try_set_caps): Document.
10010         (gst_pad_try_set_caps_nonfixed): Document.
10011         (gst_pad_can_link_filtered, gst_pad_link_filtered): Doc fixes.
10012         (gst_pad_set_parent): Deprecated (although not out of the API).
10013         (gst_pad_get_parent): Deprecated, although many plugins use this.
10014         (gst_pad_add_ghost_pad, gst_pad_remove_ghost_pad): Doc that these
10015         are private and will go away in 0.9.
10016         (gst_pad_perform_negotiate): Doc.
10017         (gst_pad_link_unnegotiate): I think this is meant to be static.
10018         (gst_pad_get_negotiated_caps, gst_pad_get_pad_template_caps) 
10019         (gst_pad_template_get_caps_by_name, gst_pad_check_compatibility) 
10020         (gst_pad_get_peer): Doc updates.
10021         (gst_pad_caps_change_notify): Doc.
10022         (gst_pad_alloc_buffer, gst_pad_push, gst_static_pad_template_get) 
10023         (gst_ghost_pad_new): Doc fixes.
10024
10025         * gst/gstobject.c (gst_object_get_parent, gst_object_unparent) 
10026         (gst_object_check_uniqueness): 
10027
10028         * gst/gstelement.c (gst_element_add_pad) 
10029         (gst_element_add_ghost_pad, gst_element_remove_pad) 
10030         (gst_element_remove_ghost_pad, gst_element_get_pad) 
10031         (gst_element_get_static_pad, gst_element_get_pad_list) 
10032         (gst_element_class_get_pad_template_list) 
10033         (gst_element_class_get_pad_template): Work on the docs.
10034         (gst_element_get_pad_template_list): Uses the class method.
10035         (gst_element_get_compatible_pad_template): Docs, and consolidate
10036         some test conditions. 
10037         (gst_element_get_pad_from_template): New static function.
10038         (gst_element_request_compatible_pad): Docs, and work with
10039         non-request compatible templates. 
10040         (gst_element_get_compatible_pad_filtered): Docs and remove
10041         redundant checks.
10042         (gst_element_get_compatible_pad, gst_element_link_pads_filtered) 
10043         (gst_element_link_filtered, gst_element_link_many) 
10044         (gst_element_link, gst_element_link_pads) 
10045         (gst_element_unlink_many): Docs.
10046
10047 2004-02-05  Andy Wingo  <wingo@pobox.com>
10048
10049         * gst/gstpad.c (_gst_real_pad_fixate_accumulator):
10050         s/pointer/boxed/.
10051
10052         * gst/gstmarshal.list (VOID:BOXED, BOXED:BOXED): New marshallers.
10053
10054         * gst/gstpad.c (gst_real_pad_class_init): Use a BOXED:BOXED
10055         marshaller for ::fixate, and VOID:BOXED for ::caps-nego-failed,
10056         with the type=GST_TYPE_CAPS. This allows language bindings to know
10057         what kind of data they're dealing with.
10058
10059         * gst/gstcaps.c (_gst_caps_value_init): GBoxed values initialize
10060         to NULL when g_value_init is called. GstCaps, which rolls its own
10061         type implementation, now does the same instead of allocating empty
10062         caps.
10063         (_gst_caps_initialize, _gst_caps_collect_value,
10064         _gst_caps_lcopy_value): Provide collect_value and lcopy_value type
10065         table methods. This allows G_VALUE_COLLECT to work.
10066
10067 2004-02-05  Andy Wingo  <wingo@pobox.com>
10068
10069         * configure.ac:
10070         * testsuite/Makefile.am (SUBDIRS): 
10071         * testsuite/ghostpads/Makefile.am: 
10072         * testsuite/ghostpads/ghostpads.c: A new test for ghost pads.
10073
10074         * gst/gstpad.c (gst_pad_add_ghost_pad, gst_pad_remove_ghost_pad):
10075         These two routines are the only ones that set
10076         GST_GPAD_REALPAD(gpad), the ghost pad list, and the ghost pad's
10077         pad template. They should be made static, depending on ABI needs.
10078         (gst_real_pad_dispose): Handle the case of ghost pads without a
10079         parent. Assert after dealing with ghost pads that the ghost pad
10080         list is empty.
10081         (gst_ghost_pad_class_init): New property added, ::real-pad. Can be
10082         set after creation.
10083         (gst_ghost_pad_dispose): Set ::real-pad to NULL.
10084         (gst_ghost_pad_set_property, gst_ghost_pad_get_property): New
10085         functions. set_property will call add_ghost_pad/remove_ghost_pad
10086         as appropriate.
10087         (gst_ghost_pad_new): All the work is offloaded to g_object_new.
10088
10089         * gst/gstelement.c (gst_element_add_pad): Handle ghost pads as well.
10090         (gst_element_add_ghost_pad): Remove code duplicated from _add_pad.
10091         (gst_element_remove_pad): Handle ghost pads as well.
10092         (gst_element_remove_ghost_pad): Deprecated (could be removed,
10093         depending on API-stability needs).
10094
10095 2004-02-05  Andy Wingo  <wingo@pobox.com>
10096
10097         * gst/gstbin.[ch]: (gst_bin_get_by_interface): GTypes are scalars,
10098         of course they're const
10099
10100 2004-02-11  Thomas Vander Stichele  <thomas at apestaart dot org>
10101
10102         * tools/Makefile.am:
10103         * tools/gst-feedback:
10104         * tools/gst-feedback-0.7:
10105           make gst-feedback versioned too for consistency
10106
10107 2004-02-11  David Schleef  <ds@schleef.org>
10108
10109         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
10110         (gst_pad_try_set_caps): Fix format strings for GST_PTR_FORMAT.
10111
10112 2004-02-10  Julien MOUTTE <julien@moutte.net>
10113
10114         * gst/gstevent.c: (_gst_event_free): Sometimes a tag event arrives but
10115         the structure does not contain a valid tag list. Adding a safety check
10116         to remove a noisy warning in that case.
10117
10118 2004-02-10  Thomas Vander Stichele  <thomas at apestaart dot org>
10119
10120         * gst/gst.c: fix name to be in line with others
10121
10122 2004-02-09  Julien MOUTTE <julien@moutte.net>
10123
10124         * libs/gst/bytestream/bytestream.c: (gst_bytestream_peek): We should
10125         not shout that loud when len is 0. Just return 0 silently.
10126
10127 2004-02-09  Julien MOUTTE  <julien@moutte.net>
10128
10129         * gst/gstdata.c: (gst_data_ref): Adding a categorized debug on data_ref
10130         because data_unref has one and I prefer the debug to be symetric.
10131         * gst/gstqueue.c: (gst_queue_locked_flush): Fix a huge memleak. Buffers
10132         were refed when added to the queue and unrefed only once when the queue
10133         was flushed. Now the flush handler unref the buffers two times : first
10134         unref for the ref added when pushing in the queue's tail and second
10135         unref to destroy the flushed buffer.
10136
10137 2004-02-08  Thomas Vander Stichele  <thomas at apestaart dot org>
10138
10139         * docs/pwg/building-boiler.xml: fix cvs checkout documentation
10140
10141 2004-02-06  David Schleef  <ds@schleef.org>
10142
10143         * docs/random/ds/0.9-suggested-changes: Random ramblings
10144         * gst/elements/gstfilesrc.c: (gst_filesrc_get_mmap): Cast size_t
10145         to int before printing.
10146         * gst/parse/grammar.y: Fix gcc-2.95 style variadic macros.
10147         * gst/parse/parse.l: same.  See bug #129600
10148
10149 2004-02-06  David Schleef  <ds@schleef.org>
10150
10151         * gst/gstindex.c: (gst_index_add_format), (gst_index_add_id),
10152         (gst_index_add_entry), (gst_index_add_associationv),
10153         (gst_index_add_association): Add gst_index_add_associationv()
10154         and clean up gst_index_add_association(). #127133
10155
10156 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
10157
10158         * autogen.sh: check out common with right tag if CVS/Tag exists
10159
10160 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
10161
10162         * testsuite/ghostpads/ghostpads.c: (main):
10163           fix testsuite from segfaulting
10164
10165 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
10166
10167         * Makefile.am: add release target
10168         * configure.ac: bump nano to 1
10169         * docs/random/release:
10170
10171 2004-02-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10172
10173         * gst/gstcaps.h:
10174         * gst/gstelement.c: (gst_element_base_class_init),
10175         (gst_element_class_set_details), (gst_element_clear_pad_caps):
10176         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
10177         (gst_pad_try_set_caps), (gst_pad_can_link_filtered),
10178         (gst_real_pad_dispose):
10179         * gst/gststructure.c: (gst_structure_free),
10180         (gst_structure_from_string):
10181           put reverted patch back in
10182         * gst/gstelement.c: (gst_element_remove_pad):
10183           free explicit caps if they're set
10184         * gst/gstpad.c: (_gst_pad_default_fixate_func):
10185           copy the structure when fixating
10186
10187 2004-02-05  David Schleef  <ds@schleef.org>
10188
10189         * gst/gstmarshal.list:
10190         * gst/gstpad.c: (gst_real_pad_class_init),
10191         (_gst_real_pad_fixate_accumulator):
10192         Revert POINTER->BOXED change in signal marshaller.
10193
10194 === release 0.7.4 ===
10195                                                                                 
10196 2004-02-06  Thomas Vander Stichele  <thomas at apestaart dot org>
10197                                                                                 
10198         * NEWS: GStreamer 0.7.4 "Wooden Eels" released
10199         * configure.ac: changed for release
10200
10201 2004-02-05  Thomas Vander Stichele  <thomas (at) apestaart (dot) org>
10202
10203         * gstreamer.spec.in:
10204           bump required version of gtk-doc
10205
10206 2004-02-05  Thomas Vander Stichele  <thomas at apestaart dot org>
10207
10208         * gst/gstcaps.h:
10209         * gst/gstelement.c: (gst_element_base_class_init),
10210         (gst_element_class_set_details), (gst_element_clear_pad_caps):
10211         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
10212         (gst_pad_try_set_caps), (gst_pad_can_link_filtered),
10213         (gst_real_pad_dispose):
10214         * gst/gststructure.c: (gst_structure_free),
10215         (gst_structure_from_string):
10216           revert patch that breaks applications, reapply after release
10217           to get this fixed properly
10218
10219 2004-02-05  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10220
10221         * gst/gsttag.c: (_gst_tag_initialize):
10222         * gst/gsttag.h:
10223           remove duplicated field GST_TAG_APPLICATION. It's GST_TAG_ENCODER
10224
10225 2004-02-04  David Schleef  <ds@schleef.org>
10226
10227         Fix some memleaks:
10228         * gst/autoplug/gstspider.c: (gst_spider_request_new_pad),
10229         (gst_spider_plug_from_srcpad):
10230         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link):
10231
10232 2004-02-04  David Schleef  <ds@schleef.org>
10233
10234         * gst/gstelement.c: (gst_element_clear_pad_caps): Make sure we have
10235         a GstRealPad before accessing its structure members.
10236
10237 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10238
10239         * gst/gstclock.c: (gst_clock_init), (gst_clock_set_speed),
10240         (gst_clock_get_speed):
10241         * gst/gstclock.h:
10242           reset padding, remove unused fields
10243
10244 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10245
10246         * gst/autoplug/gstspideridentity.c:
10247         (gst_spider_identity_sink_loop_type_finding):
10248           use get_allowed_caps, not get_caps (fixes #132519)
10249         * gst/elements/gsttypefind.c: (stop_typefinding):
10250           use correct order when sending buffers and seeking
10251
10252 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
10253
10254         * configure.ac:
10255         * gst/gstelement.h:
10256         * gst/gstpad.h:
10257         * gst/gstqueue.h:
10258           upgrade libtool CURRENT, reset padding
10259
10260 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
10261
10262         * configure.ac:
10263           bump to prerelease
10264           put back AM_PROG_LIBTOOL to make libtoolize stop complaining
10265
10266 2004-02-04  David Schleef  <ds@schleef.org>
10267
10268         * docs/random/ds/0.9-suggested-changes: random notes
10269         * gst/elements/gstfakesrc.c: (gst_fakesrc_get_formats),
10270         (gst_fakesrc_get_query_types), (gst_fakesrc_get_event_mask):
10271         Replace GST_PAD_EVENT_MASK_FUNCTION() (et al.) with its
10272         expansion.
10273         * gst/elements/gstfilesink.c: (gst_filesink_get_formats),
10274         (gst_filesink_get_query_types): same
10275         * gst/elements/gstfilesrc.c: (gst_filesrc_get_event_mask),
10276         (gst_filesrc_get_query_types), (gst_filesrc_get_formats): same
10277         * gst/gstcaps.h: deprecate GST_DEBUG_CAPS(), and fix the macro
10278         to use new GST_PTR_FORMAT.
10279         * gst/gstelement.h: deprecate function factory macros
10280         GST_ELEMENT_QUERY_TYPE_FUNCTION(), GST_ELEMENT_EVENT_MASK_FUNCTION().
10281         These are our last variadic macros that can't be replaced with
10282         inlines.  Celebrate!  Also fix a typo in an #ifdef that was
10283         attempting to deprecate gst_element_clock_wait().
10284         * gst/gstevent.h: same
10285         * gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
10286         (gst_pad_try_set_caps): replace GST_DEBUG_CAPS() with GST_DEBUG()
10287         * gst/gstpad.h: deprecate function factory macros similar to above.
10288
10289 2004-02-04  Thomas Vander Stichele  <thomas at apestaart dot org>
10290
10291         * configure.ac:
10292         * tools/Makefile.am:
10293         * tools/gst-run.c: (popt_callback), (hash_print_key),
10294         (find_highest_version), (unmangle_libtool), (get_dir_of_binary),
10295         (get_candidates), (main):
10296           add new source file to generate non-versioned wrapper binaries
10297           for our tools.
10298
10299 2004-02-04  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10300
10301         * gst/gstevent.c: (_gst_event_free):
10302           actually break; inside the switch statement
10303         * gst/parse/grammar.y:
10304           fix memleak where GValues weren't unset
10305
10306 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10307
10308         * gst/gststructure.c: (gst_structure_from_string):
10309           fix huge memleak
10310         * gst/elements/gsttypefind.c: (gst_type_find_element_have_type),
10311         (new_entry), (gst_type_find_element_chain):
10312         * gst/gstelement.c: (gst_element_base_class_init),
10313         (gst_element_class_set_details):
10314         * gst/gstpad.c: (gst_pad_can_link_filtered):
10315           fix smaller memleaks
10316         * gst/gstpad.c: (gst_real_pad_dispose):
10317           check that explicit caps are gone
10318         * gst/gststructure.c: (gst_structure_free):
10319           actually free the structure
10320         * gst/gstelement.c: (gst_element_clear_pad_caps):
10321           unset explicit caps
10322
10323 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
10324
10325         * tools/Makefile.am:
10326           use AM_CFLAGS since all the CFLAGS are the same
10327           use AM_LDFAGS
10328
10329 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
10330
10331         * docs/manual/gnome.xml:
10332           expand example a little
10333         * gst/gst.c: (gst_init_with_popt_table),
10334         (gst_init_check_with_popt_table), (init_pre), (init_popt_callback):
10335           make sure popt option displays are done with right textdomain
10336           use GstPoptOption type
10337         * gst/gst.h:
10338           create GstPoptOption type
10339
10340 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
10341
10342         * gst/gsterror.c: (_gst_stream_errors_init):
10343         * gst/gsterror.h:
10344           adding error type for no codec
10345         * po/POTFILES.in:
10346           add gst-inspect
10347         * po/nl.po:
10348           update dutch translation
10349         * tools/gst-inspect.c: (print_element_list), (main):
10350           do proper internationalization
10351         * tools/gst-launch.c: (idle_func):
10352           remove commented out function call
10353
10354 2004-02-03  Thomas Vander Stichele  <thomas at apestaart dot org>
10355
10356         * docs/README:
10357           add some error fixing notes
10358         * docs/gst/gstreamer-sections.txt:
10359           remove double entries
10360         * docs/gst/tmpl/gstbin.sgml:
10361         * docs/gst/tmpl/gstclock.sgml:
10362           remove override
10363         * docs/gst/tmpl/gstelement.sgml:
10364         * docs/gst/tmpl/gstindex.sgml:
10365         * docs/gst/tmpl/gstobject.sgml:
10366         * docs/gst/tmpl/gstpadtemplate.sgml:
10367         * docs/gst/tmpl/gstreamer-unused.sgml:
10368         * docs/gst/tmpl/gsttag.sgml:
10369         * docs/gst/tmpl/gstthread.sgml:
10370         * docs/gst/tmpl/gstxml.sgml:
10371         * gst/gsttag.h:
10372           sync header prototypes with c decls
10373         * gst/gsttaginterface.c:
10374           fix doc headers
10375
10376 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10377
10378         * gst/parse/Makefile.am:
10379         * gst/gstobject.h:
10380           get rid of gstmarshal.h dependency. It's not needed.
10381         * gst/gst.h:
10382         * gst/elements/gstfakesink.c:
10383         * gst/elements/gstfakesrc.c:
10384         * gst/elements/gstidentity.c:
10385         * gst/gstbin.c:
10386         * gst/gstelement.c:
10387         * gst/gstindex.c:
10388         * gst/gstobject.c:
10389         * gst/gstpad.c:
10390         * gst/gstthread.c:
10391         * gst/gstxml.c:
10392         * libs/gst/control/dparam.c:
10393         * libs/gst/control/dparammanager.c:
10394           include gstmarshal.h.
10395         Fixes #132045
10396
10397 2004-02-03  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10398
10399         * gst/elements/gstfilesrc.c: (gst_filesrc_init),
10400         (gst_filesrc_dispose), (gst_filesrc_free_parent_mmap),
10401         (gst_filesrc_map_region), (gst_filesrc_get_mmap):
10402         * gst/elements/gstfilesrc.h:
10403           don't ref the filesrc when creating mmaped buffers. Don't keep a
10404           list of not-yet-destroyed buffers.
10405         * gst/gstbuffer.h:
10406           Deprecated BST_BUFFER_FREE_FUNC and GST_BUFFER_COPY_FUNC
10407
10408 2004-02-02  Thomas Vander Stichele  <thomas at apestaart dot org>
10409
10410         * gst/gst.c: (init_pre):
10411           remove textdomain
10412
10413 2004-02-02  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10414
10415         * docs/pwg/advanced-events.xml:
10416         * docs/pwg/advanced-scheduling.xml:
10417         * docs/pwg/intro-basics.xml:
10418         * docs/pwg/other-manager.xml:
10419         * docs/pwg/other-nton.xml:
10420         * docs/pwg/other-ntoone.xml:
10421         * docs/pwg/other-oneton.xml:
10422         * docs/pwg/pwg.xml:
10423           All sort of documentation... Forgot what. Point is that I want this
10424           in before I leave. The 'other-*' will be the last section and will
10425           explain issues specific to these type of elements.
10426
10427 2004-02-02  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10428
10429         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
10430         (gst_filesrc_get_read):
10431           set all the values on buffers that we can
10432
10433 2004-02-02  David Schleef  <ds@schleef.org>
10434
10435         Change usage of isblah() to g_ascii_isblah() to be more locale
10436         independent.  (#133076)
10437         * gst/gsturi.c: (gst_uri_protocol_check_internal):
10438         * gst/gstutils.c:
10439         * gst/parse/parse.l:
10440
10441 2004-02-02  Jon Trowbridge  <trow@gnu.org>
10442
10443         reviewed by: David Schleef  <ds@schleef.org>
10444
10445         Fix memory leaks:
10446         * gst/gstcaps.c: (gst_caps_to_string):
10447         * gst/registries/gstxmlregistry.c:
10448         (gst_xml_registry_add_path_list_func),
10449         (gst_xml_registry_parse_padtemplate):
10450
10451 2004-02-02  Thomas Vander Stichele  <thomas at apestaart dot org>
10452
10453         * gst/gstelement.c: (gst_element_default_error):
10454           suffix error messages with period
10455
10456 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
10457
10458         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
10459         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
10460         * gst/gsterror.c: (gst_error_get_message):
10461           Suffix with dots
10462         * po/fr.po:
10463         * po/nl.po:
10464           Update translation files
10465
10466 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
10467
10468         * gst/autoplug/gstspideridentity.c:
10469         (gst_spider_identity_sink_loop_type_finding):
10470         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
10471         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
10472         (gst_filesink_close_file), (gst_filesink_handle_event),
10473         (gst_filesink_chain):
10474         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
10475         (gst_filesrc_get_read), (gst_filesrc_open_file):
10476         * gst/elements/gstidentity.c: (gst_identity_chain):
10477         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
10478         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
10479         (gst_pipefilter_chain), (gst_pipefilter_open_file):
10480         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
10481         * gst/gsterror.c: (_gst_core_errors_init),
10482         (_gst_library_errors_init), (_gst_resource_errors_init),
10483         (_gst_stream_errors_init), (gst_error_get_message):
10484         * gst/gstpad.c: (gst_pad_set_explicit_caps),
10485         (gst_pad_recover_caps_error), (gst_pad_pull):
10486         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
10487         * gst/schedulers/gstbasicscheduler.c:
10488         (gst_basic_scheduler_chainhandler_proxy),
10489         (gst_basic_scheduler_gethandler_proxy),
10490         (gst_basic_scheduler_cothreaded_chain):
10491           Suffix error messages with period.
10492           Use (NULL) instead of NULL
10493
10494 2004-01-31  Thomas Vander Stichele  <thomas at apestaart dot org>
10495
10496         * docs/gst/tmpl/gstelement.sgml:
10497         * docs/gst/tmpl/gstxml.sgml:
10498         * gst/gstelement.c: (gst_element_error_full):
10499           add element path to error
10500
10501 2004-01-31  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10502
10503         * docs/random/mimetypes:
10504           update raw int/float info
10505         * gst/gsttag.c: (_gst_tag_initialize):
10506         * gst/gsttag.h:
10507           add GST_TAG_ENCODER
10508
10509 2004-01-30  David Schleef  <ds@schleef.org>
10510
10511         * gst/cothreads.c: Add another fallback if MAP_ANONYMOUS is
10512           missing (#132991)
10513
10514 2004-01-30  Laurent Vivier <Laurent.Vivier@bull.net>
10515
10516         reviewed by Benjamin Otte 
10517           parts of the patch submitted in bug #113913
10518
10519         * configure.ac:
10520           use AC_C_INLINE. Use = instead of == with test
10521         * examples/plugins/example.c:
10522         * gst/autoplug/gstspideridentity.c:
10523         * gst/elements/gstfdsrc.c:
10524         * gst/elements/gstfilesrc.c:
10525         * gst/elements/gstidentity.c:
10526         * gst/elements/gstmultidisksrc.c:
10527         * gst/elements/gststatistics.c:
10528         * gst/gstelement.c:
10529         * gst/gstobject.c:
10530         * gst/gstpad.c:
10531         * gst/gstpipeline.c:
10532         * gst/gstthread.c:
10533           don't end enums with a comma
10534         * gst/gstindex.c: (gst_index_compare_func):
10535           do explicit casting to gint
10536         * gst/gsttrace.c: (gst_trace_text_flush):
10537           #define strsize as a macro
10538
10539 2004-01-30  Thomas Vander Stichele  <thomas at apestaart dot org>
10540
10541         * docs/README:
10542         * docs/gst/gstreamer-docs.sgml:
10543         * docs/gst/gstreamer-sections.txt:
10544         * docs/gst/tmpl/gstelement.sgml:
10545         * docs/gst/tmpl/gsterror.sgml:
10546         * docs/gst/tmpl/gstinterface.sgml:
10547         * docs/gst/tmpl/gstreamer-unused.sgml:
10548         * docs/gst/tmpl/gststructure.sgml:
10549         * docs/gst/tmpl/gsttag.sgml:
10550         * docs/gst/tmpl/gsttaginterface.sgml:
10551         * docs/gst/tmpl/gstvalue.sgml:
10552         make sure all API ends up in the built docs
10553         * gst/gstinterface.c:
10554         * gst/gststructure.c: (gst_structure_id_set_value),
10555         (gst_structure_set_value), (gst_structure_id_get_value):
10556         * gst/gststructure.h:
10557         * gst/gstvalue.h:
10558         sync .h with .c declarations
10559
10560 2004-01-30  Julien Moutte  <julien@moutte.net>
10561
10562         * libs/gst/bytestream/bytestream.c: Reverting my event handling patch.
10563         Ronald will fix riffread.
10564
10565 2004-01-30  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10566
10567         * docs/pwg/advanced-interfaces.xml:
10568           Added tuner interface docs.
10569
10570 2004-01-30  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10571
10572         * docs/random/mimetypes:
10573           correct Theora information
10574         * gst/gstelement.h:
10575           make GST_ELEMENT_ERROR do a GST_ERROR_OBJECT
10576
10577 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
10578
10579         * gst/gstelement.c: (gst_element_error_full):
10580         * gst/gstelement.h:
10581           GST_ELEMENT_ERROR in enum -> _IN_ERROR
10582
10583 2004-01-29  Julien MOUTTE  <julien@moutte.net>
10584
10585         * gst/elements/gstfilesrc.c: (gst_filesrc_get),
10586         (gst_filesrc_uri_handler_init): Fixing seeking by making FLUSH happen
10587         again and even before DISCONT.
10588         * gst/gstpad.c: (gst_pad_event_default): Remove a unused switch case.
10589         * libs/gst/bytestream/bytestream.c: (gst_bytestream_get_next_buf): Fix
10590         bytestream so that it's not stopping to fill the bytestream if events
10591         different than EOS or DISCONT are received. Instead it process them so
10592         that they go downstream.
10593
10594 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
10595
10596         * docs/gst/tmpl/gstelement.sgml:
10597         * docs/gst/tmpl/gstreamer-unused.sgml:
10598         * docs/gst/tmpl/gstxml.sgml:
10599         * gst/autoplug/gstspideridentity.c:
10600         (gst_spider_identity_sink_loop_type_finding):
10601         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
10602         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
10603         (gst_filesink_close_file), (gst_filesink_handle_event),
10604         (gst_filesink_chain):
10605         * gst/elements/gstfilesrc.c: (gst_filesrc_map_region),
10606         (gst_filesrc_get_read), (gst_filesrc_open_file):
10607         * gst/elements/gstidentity.c: (gst_identity_chain):
10608         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
10609         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
10610         (gst_pipefilter_chain), (gst_pipefilter_open_file):
10611         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
10612         * gst/gstelement.h:
10613         * gst/gstpad.c: (gst_pad_set_explicit_caps),
10614         (gst_pad_recover_caps_error), (gst_pad_pull):
10615         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
10616         * gst/schedulers/gstbasicscheduler.c:
10617         (gst_basic_scheduler_chainhandler_proxy),
10618         (gst_basic_scheduler_gethandler_proxy),
10619         (gst_basic_scheduler_cothreaded_chain):
10620           gst_element_error -> GST_ELEMENT_ERROR
10621
10622 2004-01-29  Thomas Vander Stichele  <thomas at apestaart dot org>
10623
10624         * docs/Makefile.am:
10625         * docs/gst/tmpl/gstelement.sgml:
10626         * docs/gst/tmpl/gstxml.sgml:
10627         * docs/manuals.mak:
10628         * docs/pwg/advanced-request.xml:
10629         * docs/pwg/advanced-scheduling.xml:
10630         * docs/pwg/advanced-tagging.xml:
10631           fix non-validating docbook using CDATA
10632           make sure make check-local gets run first to check if it validates
10633
10634 2004-01-29  Julien MOUTTE <julien@moutte.net>
10635
10636         * docs/pwg/advanced-events.xml: Adding documentation on advanced event
10637         handling (up and downstream).
10638         * docs/pwg/advanced-interfaces.xml: Make it coherent with the
10639         my_filter thing.
10640
10641 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10642
10643         * docs/pwg/advanced-tagging.xml:
10644           Add docs about tag writing.
10645
10646 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10647
10648         * docs/pwg/advanced-tagging.xml:
10649           Add a part about tag reading and application signalling... Tag
10650           writing still needs to be documented.
10651         * gst/elements/gstfilesrc.c: (gst_filesrc_set_location):
10652           We can set file locations in READY, too.
10653
10654 2004-01-29  Julien MOUTTE <julien@moutte.net>
10655
10656         * docs/random/ds/element-checklist: Adding some notes about src
10657         events.
10658
10659 2004-01-29  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10660
10661         * docs/random/mimetypes:
10662           Update docs to point to correct elements for various mimetypes, and
10663           some more errors pointed out by Stéphane LOEUILLET (aka LeRoutier)
10664           <stephane.loeuillet@tiscali.fr>.
10665
10666 2004-01-28  David Schleef  <ds@schleef.org>
10667
10668         * docs/pwg/intro-basics.xml: rewrite bufferpool stuff.
10669
10670 2004-01-29  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10671
10672         * docs/random/mimetypes:
10673           update docs for audio/x-raw-float. Add "buffer-frames=0 means
10674           undefined"
10675         * gst/elements/gstfilesrc.c: (gst_filesrc_set_location):
10676           make it only work in NULL.
10677         * gst/gstcaps.c:
10678           don't posion NULL caps
10679         * gst/gstelement.c: (gst_element_set_time):
10680           add debugging statement
10681         * gst/gstelement.c: (gst_element_emit_found_tag),
10682         (gst_element_found_tag_func), (gst_element_found_tags):
10683         * gst/gstelement.h:
10684           These functions take const taglists
10685         * gst/gstpad.c: (gst_pad_proxy_getcaps):
10686           fix memleak
10687         * gst/gstpad.c: (gst_pad_event_default):
10688           make more effort on handling discont and clocks, g_warn if everything
10689           fails
10690         * gst/gststructure.c: (gst_structure_remove_fields),
10691         (gst_structure_remove_fields_valist):
10692         * gst/gststructure.h:
10693           add gst_structure_remove_fields(_valist)
10694         * gst/gsttag.c:
10695           fix doc glitch
10696
10697 2004-01-28  David Schleef  <ds@schleef.org>
10698
10699         * docs/random/ds/element-checklist: Notes about gst_caps_to_string()
10700         * gst/registries/gstxmlregistry.c: (gst_xml_registry_save_caps):
10701         Fix memory leakage of gst_caps_to_string().
10702
10703         Use GST_PTR_FORMAT instead of gst_caps_to_string():
10704         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_sp):
10705         * gst/autoplug/gstspideridentity.c: (spider_find_suggest),
10706         (gst_spider_identity_sink_loop_type_finding):
10707         * gst/elements/gsttypefind.c: (gst_type_find_element_have_type),
10708         (find_suggest):
10709         * gst/gstpad.c: (gst_pad_try_relink_filtered),
10710         (gst_pad_set_explicit_caps):
10711         * gst/parse/grammar.y:
10712
10713 2004-01-28  David Schleef  <ds@schleef.org>
10714
10715         * configure.ac: Add detection for HAVE_PRINTF_EXTENSION and
10716         GST_PRINTF_EXTENSION_FORMAT_DEFINE.
10717         * docs/random/ds/0.9-suggested-changes: Notes from Company.
10718         * gst/gstcaps.c: (gst_caps_to_string): Add comment.
10719         * gst/gstconfig.h.in: Add define for GST_PTR_FORMAT
10720         * gst/gstinfo.c: (_gst_debug_init), (gst_debug_print_object),
10721         (gst_debug_log_default), (_gst_info_printf_extension),
10722         (_gst_info_printf_extension_arginfo):  Add printf extension.
10723         * gst/gstinfo.h: remove G_GNUC_PRINTF, because it doesn't work with %P
10724         * gst/gststructure.c: (gst_structure_to_string),
10725         (_gst_structure_parse_value): Use gst_value_deserialize() and
10726         remove old code.
10727         * gst/gstvalue.c: (gst_value_deserialize_fourcc),
10728         (gst_value_deserialize_boolean), (gst_strtoi),
10729         (gst_value_deserialize_int), (gst_value_deserialize_double),
10730         (gst_value_deserialize_string), (gst_value_deserialize): Implement
10731         a bunch of deserialize functions and gst_value_deserialize.
10732         * gst/gstvalue.h: er, _de_serialize, not unserialize
10733         * testsuite/caps/string-conversions.c: (main): We don't currently
10734         handle (float) in caps, so convert these to (double).
10735         * testsuite/debug/Makefile.am: Add new test for the printf extension
10736         * testsuite/debug/printf_extension.c: (main): same
10737
10738 2004-01-28  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10739
10740         * docs/random/company/time:
10741           Add some docs about clocking and time
10742
10743 2004-01-28  Julien MOUTTE <julien@moutte.net>
10744
10745         * docs/pwg/advanced-interfaces.xml: Adding XOverlay documentation.
10746
10747 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
10748
10749         * docs/pwg/advanced-clock.xml:
10750         * docs/pwg/advanced-dparams.xml:
10751         * docs/pwg/advanced-events.xml:
10752         * docs/pwg/advanced-interfaces.xml:
10753         * docs/pwg/advanced-midi.xml:
10754         * docs/pwg/advanced-request.xml:
10755         * docs/pwg/advanced-scheduling.xml:
10756         * docs/pwg/advanced-tagging.xml:
10757         * docs/pwg/advanced-types.xml:
10758         * docs/pwg/appendix-checklist.xml:
10759         * docs/pwg/building-boiler.xml:
10760         * docs/pwg/building-chainfn.xml:
10761         * docs/pwg/building-filterfactory.xml:
10762         * docs/pwg/building-pads.xml:
10763         * docs/pwg/building-props.xml:
10764         * docs/pwg/building-signals.xml:
10765         * docs/pwg/building-state.xml:
10766         * docs/pwg/building-testapp.xml:
10767         * docs/pwg/intro-basics.xml:
10768         * docs/pwg/intro-preface.xml:
10769         * docs/pwg/other-autoplugger.xml:
10770         * docs/pwg/other-sink.xml:
10771         * docs/pwg/other-source.xml:
10772         * docs/pwg/titlepage.xml:
10773           fix up id's
10774
10775 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
10776
10777         * docs/95NonPath:
10778         * docs/HACKING:
10779         * docs/README:
10780         * docs/building-the-docs-on-debian:
10781           collect relevant bits of doc info
10782
10783 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10784
10785         * docs/pwg/advanced_tagging.xml:
10786           Half-assed commit so Thomas can re-arrange document IDs here to be
10787           consistent, too.
10788
10789 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
10790
10791         * docs/manual/autoplugging.xml:
10792         * docs/manual/bins-api.xml:
10793         * docs/manual/bins.xml:
10794         * docs/manual/buffers-api.xml:
10795         * docs/manual/buffers.xml:
10796         * docs/manual/clocks.xml:
10797         * docs/manual/components.xml:
10798         * docs/manual/cothreads.xml:
10799         * docs/manual/debugging.xml:
10800         * docs/manual/dparams-app.xml:
10801         * docs/manual/dynamic.xml:
10802         * docs/manual/elements-api.xml:
10803         * docs/manual/elements.xml:
10804         * docs/manual/factories.xml:
10805         * docs/manual/gnome.xml:
10806         * docs/manual/goals.xml:
10807         * docs/manual/helloworld.xml:
10808         * docs/manual/helloworld2.xml:
10809         * docs/manual/init-api.xml:
10810         * docs/manual/intro.xml:
10811         * docs/manual/links-api.xml:
10812         * docs/manual/links.xml:
10813         * docs/manual/manual.xml:
10814         * docs/manual/motivation.xml:
10815         * docs/manual/pads-api.xml:
10816         * docs/manual/pads.xml:
10817         * docs/manual/plugins-api.xml:
10818         * docs/manual/plugins.xml:
10819         * docs/manual/programs.xml:
10820         * docs/manual/queues.xml:
10821         * docs/manual/quotes.xml:
10822         * docs/manual/schedulers.xml:
10823         * docs/manual/states-api.xml:
10824         * docs/manual/states.xml:
10825         * docs/manual/threads.xml:
10826         * docs/manual/typedetection.xml:
10827         * docs/manual/xml.xml:
10828           use chapter, part, section or misc as id starts for all bits
10829
10830 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
10831
10832         * docs/gst/gstreamer-sections.txt:
10833           Fix up TITLE of the sections
10834
10835 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10836
10837         * docs/pwg/advanced_interfaces.xml:
10838           Add documentation on propertyprobing.
10839         * docs/pwg/advanced_events.xml:
10840         * docs/pwg/advanced_tagging.xml:
10841         * docs/pwg/building_boiler.xml:
10842         * docs/pwg/building_filterfactory.xml:
10843         * docs/pwg/pwg.xml:
10844           Move filterfactory and tagging into their own chapter, add a chapter
10845           on events. all these are empty placeholders that will be filled in
10846           some day.
10847
10848 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10849
10850         * docs/pwg/advanced_interfaces.xml:
10851           Docs for mixer interface. Also a check for website uploading.
10852
10853 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
10854
10855         * docs/HACKING:
10856         * docs/Makefile.am:
10857         * docs/faq/Makefile.am:
10858         * docs/gst/Makefile.am:
10859         * docs/gst/tmpl/gstelement.sgml:
10860         * docs/gst/tmpl/gstplugin.sgml:
10861         * docs/gst/tmpl/gstreamer-unused.sgml:
10862         * docs/libs/Makefile.am:
10863         * docs/manual/Makefile.am:
10864         * docs/manuals.mak:
10865         * docs/pwg/Makefile.am:
10866         * docs/upload.mak:
10867           Separate out upload target and make it similar for
10868           both docbook and gtk-doc docs
10869
10870 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
10871
10872         * docs/manuals.mak:
10873           Fix upload target to work with freedesktop
10874
10875 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10876
10877         * docs/pwg/advanced_types.xml:
10878           Add notes on creating your own types.
10879         * docs/pwg/building_boiler.xml:
10880         * docs/pwg/building_pads.xml:
10881         * docs/pwg/building_state.xml:
10882           Add some stuff about how to retrieve values from structures, how
10883           that relates to types and change layout slightly again to be almost
10884           perfect.
10885
10886 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10887
10888         * docs/pwg/advanced_dparams.xml:
10889         * docs/pwg/advanced_scheduling.xml:
10890           Change index layout slightly.
10891
10892 2004-01-28  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10893
10894         * docs/pwg/advanced_clock.xml:
10895         * docs/pwg/advanced_interfaces.xml:
10896         * docs/pwg/advanced_midi.xml:
10897           General placeholders for now.
10898         * docs/pwg/advanced_request.xml:
10899           Explanation about sometimes and request pads.
10900         * docs/pwg/advanced_scheduling.xml:
10901           Concept of bytestream, loopfunctions and schedulers.
10902         * docs/pwg/building_boiler.xml:
10903           Add something about plugin-init.
10904
10905 2004-01-28  Thomas Vander Stichele  <thomas at apestaart dot org>
10906
10907         * docs/pwg/building_pads.xml:
10908           Fix broken docbook
10909
10910 2004-01-27  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10911
10912         * docs/pwg/advanced_interfaces.xml:
10913         * docs/pwg/pwg.xml:
10914           Add as a placeholder for future filling-in.
10915         * docs/pwg/basics_autoplugging.xml:
10916         * docs/pwg/basics_buffers.xml:
10917         * docs/pwg/basics_elements.xml:
10918         * docs/pwg/basics_events.xml:
10919         * docs/pwg/basics_plugins.xml:
10920         * docs/pwg/basics_types.xml:
10921           Remove, because unused (this is all in intro_basics.xml).
10922         * docs/pwg/building_signals.xml:
10923           Short intro to signals + reference to GObject docs - we really
10924           shouldn't go into these sort of things to deply because we don't
10925           use them that extensively anyway.
10926         * docs/pwg/building_state.xml:
10927           Explanation of states. Benjamin, please check.
10928         * docs/pwg/building_testapp.xml:
10929           Put everything in one page - putting only a few lines of content
10930           per page doesn't really make sense.
10931
10932           Time to get into the advanced topics. ;).
10933
10934 2004-01-27  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10935
10936         * docs/pwg/advanced_types.xml:
10937           Finish documenting the current state of mimetypes.
10938         * docs/pwg/building_boiler.xml:
10939         * docs/pwg/building_chainfn.xml:
10940         * docs/pwg/building_pads.xml:
10941         * docs/pwg/building_props.xml:
10942         * docs/pwg/building_testapp.xml:
10943           Start documenting the "how to build a simple audio filter" part
10944           of the PWG. Most stuff is ready by now. Stuff remaining: signals,
10945           states and (maybe?) a short introduction to capsnego in the chapter
10946           on pads (building_pads.xml). Capsnego should probably be explained
10947           fully in advanced_capsnego.xml or so.
10948
10949 2004-01-26  David Schleef  <ds@schleef.org>
10950
10951         * gst/gstpad.c: (gst_pad_try_set_caps_nonfixed):
10952         * gst/gstpad.h: Add new function to allow element to (somewhat)
10953         specify non-fixed caps on a pad.
10954         * gst/gstqueue.c: (gst_queue_chain): Remove noisy g_object_notify()
10955         that I added a few weeks ago.
10956
10957 2004-01-26  David Schleef  <ds@schleef.org>
10958
10959         * gst/gstpad.c: (gst_pad_try_set_caps): Revert last change
10960           making try_set_caps() work with non-fixed caps.
10961
10962 2004-01-26  Ronald Bultje  <rbultje@ronald.bitfreak.net>
10963
10964         * docs/pwg/advanced_types.xml:
10965         * docs/pwg/intro_basics.xml:
10966         * docs/pwg/intro_preface.xml:
10967         * docs/pwg/pwg.xml:
10968         * docs/pwg/titlepage.xml:
10969           First try to resurrect the PWG. I'm halfway integrating the mimetypes
10970           in here (docs/random/mimetypes), and will from there on work on both
10971           updating outdated parts and adding missing parts.
10972           That doesn't mean I'll fix it completely, but I'll try at least. ;).
10973
10974 2004-01-26  Thomas Vander Stichele  <thomas at apestaart dot org>
10975
10976         * gst/gsterror.h: reinstate GST_LIBRARY_ERROR_ENCODE until
10977           policy is set
10978
10979 2004-01-26  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10980
10981         * gst/gstelement.h:
10982           remove gst_element_factory_get_version. It doesn't exist anymore.
10983         * gst/gstplugin.c:
10984         * gst/gstplugin.h:
10985           remove gst_plugin_set_name and change gst_plugin_get_longname to
10986           gst_plugin_get_description to match code.
10987         * gst/gsterror.h:
10988           remove GST_LIBRARY_ERROR_ENCODE. It's GST_STREAM_ERROR_ENCODE.
10989         * gst/gstpad.c: (gst_pad_try_set_caps):
10990           make it work with nonfixed caps.
10991           Note that even in the nonfixed case the link function of the pad
10992           that tries to set caps isn't called.
10993
10994 2004-01-25  Benjamin Otte  <in7y118@public.uni-hamburg.de>
10995
10996         * gst/elements/gstbufferstore.c: (gst_buffer_store_get_buffer):
10997           fix bug where buffer was not assembled correctly
10998         * gst/elements/gsttee.c: (gst_tee_class_init), (gst_tee_init):
10999           silence by default
11000         * gst/elements/gsttypefind.c: (gst_type_find_element_chain):
11001           only seek if there's no more buffers that could work without seeking
11002
11003 2004-01-23  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11004
11005         * gst/gsttag.c: (_gst_tag_initialize):
11006         * gst/gsttag.h:
11007           Add application tag (for encoding/muxing app).
11008
11009 2004-01-23  Thomas Vander Stichele  <thomas at apestaart dot org>
11010
11011         * autogen.sh:
11012           make autopoint force, and libtoolize not copy
11013         * common/m4/as-docbook.m4:
11014           added docbook xml catalog setup check
11015         * common/m4/gst-doc.m4:
11016           use docbook check
11017
11018 2004-01-22  Thomas Vander Stichele  <thomas at apestaart dot org>
11019
11020         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_register):
11021         * gst/gsttag.h:
11022           add GstTagFlag
11023
11024 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
11025
11026         * docs/gst/gstreamer-sections.txt:
11027         * docs/gst/tmpl/gst.sgml:
11028         * docs/gst/tmpl/gstbuffer.sgml:
11029         * docs/gst/tmpl/gstclock.sgml:
11030         * docs/gst/tmpl/gstelement.sgml:
11031         * docs/gst/tmpl/gstreamer-unused.sgml:
11032         * docs/gst/tmpl/gstxml.sgml:
11033           sync latest API changes to docs
11034
11035 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
11036
11037         * gst/gstpluginfeature.c:
11038           fix doc snippet
11039         * tools/gst-inspect.c: (print_element_list):
11040           fix output of typefind
11041           add GPL header
11042         * tools/gst-launch.c:
11043           add GPL header
11044
11045 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
11046
11047         * gst/elements/Makefile.am:
11048         * gst/elements/gstelements.c:
11049         * gst/elements/gsttypefindelement.c:
11050         * gst/elements/gsttypefindelement.h:
11051         * po/POTFILES.in:
11052         * po/fr.po:
11053         * po/nl.po:
11054           renamed gsttypefindelement to gsttypefind, conserving CVS history
11055
11056 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
11057
11058         * gst/gsttag.c: (_gst_tag_initialize), (gst_tag_list_add_valist):
11059         * gst/gsttag.h:
11060           add some tags used in ogg as well
11061           fix _ in replaygain tags
11062
11063 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
11064
11065         * gst/gsterror.h:
11066           fix wrong GST_LIBRARY_ERROR_ENCODE addition
11067
11068 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
11069
11070         * gst/gstelement.c: (gst_element_error_full):
11071         * gst/gstelement.h:
11072           change _extended to _full
11073
11074 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
11075
11076         reviewed by: <delete if not using a buddy>
11077
11078         * docs/gst/tmpl/gst.sgml:
11079         * docs/gst/tmpl/gstbuffer.sgml:
11080         * docs/gst/tmpl/gstclock.sgml:
11081         * docs/gst/tmpl/gstelement.sgml:
11082         * docs/gst/tmpl/gstreamer-unused.sgml:
11083         * docs/gst/tmpl/gstxml.sgml:
11084         * gst/gstelement.c: (gst_element_error_full):
11085         * gst/gstelement.h:
11086
11087 2004-01-20  Thomas Vander Stichele  <thomas at apestaart dot org>
11088
11089         * gst/gstelement.h: fix _gst_element_error_printf prototype
11090
11091 2004-01-20  David Schleef  <ds@schleef.org>
11092
11093         * gst/gststructure.c: (gst_structure_to_string):
11094         Convert function to use gst_value_serialize().
11095         * gst/gstvalue.c: (gst_value_serialize_list),
11096         (gst_value_serialize_fourcc), (gst_value_serialize_int_range),
11097         (gst_value_serialize_double_range), (gst_value_serialize_boolean),
11098         (gst_value_serialize_int), (gst_value_serialize_double),
11099         (gst_string_wrap), (gst_value_serialize_string),
11100         (gst_value_serialize), (gst_value_deserialize):
11101         * gst/gstvalue.h:
11102         Add implementations for serialize.
11103
11104 2004-01-20  Julien MOUTTE  <julien@moutte.net>
11105
11106         * gst/gsterror.h: xvidenc.c needs GST_LIBRARY_ERROR_ENCODE. Dunno if
11107         we want to keep that one in the future or change xvidenc.c to use 
11108         another error.
11109
11110 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11111
11112         * gst/gstelement.c: (_gst_element_error_printf):
11113         * gst/gstelement.h:
11114           privatise function
11115
11116 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11117
11118         * docs/random/error:
11119           doc explaining error system
11120         * gst/elements/gstfilesrc.c: (gst_filesrc_open_file):
11121           cleanup
11122
11123 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11124
11125         * gst/gst-i18n-app.h:
11126         * gst/gst-i18n-lib.h:
11127           remove inclusion of config.h
11128         * po/POTFILES.in:
11129         * po/nl.po:
11130           add gst/gstelement.c
11131
11132 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11133
11134         * po/nl.po: updated Dutch translation
11135
11136 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11137
11138         * gst/gsterror.c: (_gst_core_errors_init),
11139         (_gst_library_errors_init), (_gst_resource_errors_init),
11140         (_gst_stream_errors_init):
11141         remove ending punctuation dots
11142
11143 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11144
11145         * gst/elements/gstfilesink.c: (gst_filesink_open_file):
11146         * gst/elements/gstfilesrc.c: (gst_filesrc_get_read):
11147         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
11148         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
11149         (gst_pipefilter_chain), (gst_pipefilter_open_file):
11150         use GST_ERROR_SYSTEM
11151
11152 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11153
11154         * gst/gstelement.c: (gst_element_error_printf),
11155         (gst_element_error_extended):
11156         * gst/gstelement.h:
11157           add a helper printf function so we can have NULL values passed.
11158
11159 2004-01-19  Thomas Vander Stichele  <thomas at apestaart dot org>
11160
11161         * gst/gstelement.h:
11162           add G_STMT macros to gst_element_error, which isn't strictly
11163           necessary but people tell me to anyway.
11164
11165 2004-01-18  Thomas Vander Stichele  <thomas at apestaart dot org>
11166
11167         * gst/Makefile.am:
11168         * gst/autoplug/gstspideridentity.c:
11169         (gst_spider_identity_sink_loop_type_finding):
11170         * gst/elements/gstfakesink.c: (gst_fakesink_change_state):
11171         * gst/elements/gstfilesink.c: (gst_filesink_open_file),
11172         (gst_filesink_close_file), (gst_filesink_handle_event),
11173         (gst_filesink_chain):
11174         * gst/elements/gstfilesrc.c: (gst_filesrc_set_property),
11175         (gst_filesrc_map_region), (gst_filesrc_get_read),
11176         (gst_filesrc_open_file):
11177         * gst/elements/gstidentity.c: (gst_identity_chain):
11178         * gst/elements/gstmultidisksrc.c: (gst_multidisksrc_open_file):
11179         * gst/elements/gstpipefilter.c: (gst_pipefilter_get),
11180         (gst_pipefilter_chain), (gst_pipefilter_open_file):
11181         * gst/elements/gsttypefindelement.c: (gst_type_find_element_chain):
11182         * gst/gst.h:
11183         * gst/gst_private.h:
11184         * gst/gstelement.c: (gst_element_class_init),
11185         (gst_element_default_error), (gst_element_error_func),
11186         (gst_element_error_extended):
11187         * gst/gstelement.h:
11188         * gst/gsterror.c: (_gst_core_errors_init),
11189         (_gst_library_errors_init), (_gst_resource_errors_init),
11190         (_gst_stream_errors_init), (gst_error_get_message):
11191         * gst/gsterror.h:
11192         * gst/gstinfo.c: (_gst_debug_init):
11193         * gst/gstmarshal.list:
11194         * gst/gstpad.c: (gst_pad_set_explicit_caps),
11195         (gst_pad_recover_caps_error), (gst_pad_pull):
11196         * gst/gstqueue.c: (gst_queue_chain), (gst_queue_get):
11197         * gst/schedulers/gstbasicscheduler.c:
11198         (gst_basic_scheduler_chainhandler_proxy),
11199         (gst_basic_scheduler_gethandler_proxy),
11200         (gst_basic_scheduler_cothreaded_chain):
11201         * po/POTFILES.in:
11202         * po/fr.po:
11203         * po/nl.po:
11204           change error signal
11205           add error categories
11206
11207 2004-01-18  Jeremy Simon  <jesimon@libertysurf.fr>
11208
11209         * gst/gsttag.c: (_gst_tag_initialize):
11210         * gst/gsttag.h:
11211         Add replaygain tag
11212
11213 2004-01-18  Colin Walters  <walters@verbum.org>
11214
11215         * examples/retag/retag.c: Call gst_init before processing
11216         program args.  Add g_assert to _link_many call.
11217
11218 2004-01-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11219
11220         * gst/gstpad.c: (gst_pad_alloc_buffer):
11221           Return a newly allocated buffer when the pad has no peer.
11222
11223 2004-01-16  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11224
11225         * gst/gstclock.c: (gst_clock_get_time):
11226           make it compile with gcc 2.95 again.
11227           Patch by Scott Wheeler
11228
11229 2004-01-15  David Schleef  <ds@schleef.org>
11230
11231         * gst/gstcaps.h:
11232         Added gst_caps_is_simple() macro.
11233         * testsuite/caps/caps.c: (test1):
11234         * testsuite/caps/intersect2.c: (main):
11235         * testsuite/caps/intersection.c: (main):
11236         Fixes to make 'make check' work again after removing
11237         gst_caps_is_chained().
11238
11239 2004-01-15  Leif Johnson <leif@ambient.2y.net>
11240
11241         * docs/random/uraeus/gstreamer_and_midi.txt: Rather large edits
11242         and additions to the MIDI document.
11243
11244 2004-01-15  David Schleef  <ds@schleef.org>
11245
11246         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered),
11247         (gst_element_link_pads_filtered): Use GST_PAD_ macros instead
11248         of GST_RPAD_, since we don't know if it's a real or ghost pad.
11249
11250 2004-01-15  David Schleef  <ds@schleef.org>
11251
11252         * gst/gstqueue.c:
11253         * gst/gstqueue.h:
11254         Fix the spelling of "treshold" and make min_threshold actually
11255         affect the queue.
11256
11257 2004-01-15  David Schleef  <ds@schleef.org>
11258
11259         * gst/gstcaps.c:
11260         Add lots of documentation.
11261         * gst/gstcaps.h:
11262         Deprecate a few functions.
11263         * gst/gstpad.c:
11264         Removed use of deprecated functions.
11265
11266 2004-01-15  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11267
11268         * gst/gstpad.c: (gst_pad_is_linked):
11269         * gst/gstpad.h:
11270           implement gst_pad_is_linked
11271         * gst/gstelement.h:
11272           reserve space for initiate_state_change
11273
11274 2004-01-15  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11275
11276         * gst/autoplug/gstspideridentity.c:
11277         (gst_spider_identity_sink_loop_type_finding):
11278           break infinite loop by just returning instead of looping
11279         * gst/gstclock.c: (gst_clock_class_init), (gst_clock_set_property):
11280           set event time difference correctly. Set it to 1 second instead
11281           of 100ms to be more tolerant
11282         * gst/gstelement.c: (gst_element_set_time):
11283           add debugging output
11284
11285 2004-01-14  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11286
11287         * gst/gstqueue.c: (gst_queue_getcaps), (gst_queue_link):
11288           query if buffers are inside the pool, ignore events
11289
11290 2004-01-13  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11291
11292         * gst/gstclock.c: (gst_clock_class_init), (gst_clock_init),
11293         (gst_clock_set_speed), (gst_clock_set_active),
11294         (gst_clock_is_active), (gst_clock_reset),
11295         (gst_clock_handle_discont):
11296         * gst/gstclock.h:
11297           deprecate old interface and disable functions that aren't in use
11298           anymore.
11299         * gst/gstelement.h:
11300         * gst/gstelement.c: (gst_element_get_time), (gst_element_wait),
11301         (gst_element_set_time), (gst_element_adjust_time):
11302           add concept of "element time" and functions to get/set this time.
11303         * gst/gstelement.c: (gst_element_change_state):
11304           update element time correctly.
11305         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered):
11306           This is a debug message, not a g_critical.
11307         * gst/gstpad.c: (gst_pad_event_default):
11308           handle discontinuous events right with element time.
11309         * gst/gstscheduler.c: (gst_scheduler_state_transition):
11310           update to clocking fixes.
11311           set clocks on elements in READY=>PAUSED. The old behaviour caused
11312           a wrong element time on the first element that started playing.
11313         * gst/schedulers/gstbasicscheduler.c:
11314         (gst_basic_scheduler_class_init):
11315         * gst/schedulers/gstoptimalscheduler.c:
11316         (gst_opt_scheduler_class_init):
11317           remove code that just implements the default behaviour.
11318         * gst/elements/gstfakesink.c: (gst_fakesink_chain):
11319           update to use new clocking functions
11320         * testsuite/clock/clock1.c: (gst_clock_debug), (main):
11321         * testsuite/clock/clock2.c: (gst_clock_debug), (main):
11322           update to test new element time.
11323         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_getcaps):
11324           use _get_allowed_caps instead of _get_caps. This catches filtered
11325           caps correctly.
11326         * testsuite/debug/commandline.c:
11327           update for new GST_DEBUG syntax.
11328         * testsuite/threads/Makefile.am:
11329           disable a test that only works sometimes.
11330
11331 2004-01-13  Julien MOUTTE <julien@moutte.net>
11332
11333         * po/LINGUAS: Adding fr.
11334         * po/fr.po: Adding french translation.
11335
11336 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11337
11338         * gst/parse/grammar.y:
11339         * po/POTFILES.in:
11340         * po/nl.po:
11341         * tools/gst-launch.c: (xmllaunch_parse_cmdline), (main):
11342           translate parsing error messages
11343
11344 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11345
11346         * po/POTFILES.in: adding gst-launch
11347         * po/nl.po: updated translation, all 99 strings translated
11348         * tools/gst-launch.c: (idle_func), (xmllaunch_parse_cmdline),
11349         (found_tag), (sigint_handler_sighandler), (play_handler), (main):
11350           fix strings for translation
11351
11352 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11353
11354         * gst/gst.c:
11355           - capitalize beginnings of popt options
11356           - fix strings for translation
11357           - change gst-debug format from =N1=V1:N2=V2 to =N1:V1,N2:V2
11358
11359 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11360
11361         * po/README: add some notes on how to update translations
11362
11363 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11364
11365         * ABOUT-NLS: removed, is autogenerated from autopoint
11366         * autogen.sh: add autopoint stuff
11367         * configure.ac: fix up gettext stuff
11368         * gst/Makefile.am: add i18n headers to noinst_HEADERS
11369         * gst/elements/gsttypefindelement.c: add header include
11370         * gst/gettext.h: add header, copy from system-installed header
11371         * gst/gst-i18n-app.h: to be included by each app having translations
11372         * gst/gst-i18n-lib.h: to be included by each lib having translations
11373         * gst/gst.c: (init_pre): fix up gettext calls
11374         * gst/gst_private.h: remove i18n stuff, moving to separate headers
11375         * po/LINGUAS: the new way to specify translations present
11376         * po/Makefile.in.in: removed from cvs, autogenerated from autopoint
11377         * po/Makevars: the variables filled in for GStreamer
11378         * po/POTFILES.in: added new files with translations
11379         * po/de.po: has new strings
11380         * po/nl.po: readded, has new strings
11381
11382 2004-01-13  Thomas Vander Stichele  <thomas at apestaart dot org>
11383
11384         * gst/gsttag.c: fix some strings marked for translation
11385
11386 2004-01-13  Iain <iain@prettypeople.org>
11387
11388         * gst/schedulers/gstoptimalscheduler.c (add_to_group): Reference the
11389         group when we add an element to it, cos we unref it when we remove one
11390
11391 2004-01-12  Thomas Vander Stichele  <thomas at apestaart dot org>
11392
11393         * testsuite/debug/commandline.c: (debug_not_reached):
11394         * testsuite/debug/output.c: (check_message):
11395           fix testsuite
11396
11397 2004-01-12  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11398
11399         * examples/cutter/.cvsignore:
11400         * examples/helloworld/.cvsignore:
11401         * examples/launch/.cvsignore:
11402         * examples/manual/.cvsignore:
11403         * examples/mixer/.cvsignore:
11404         * examples/pingpong/.cvsignore:
11405         * examples/plugins/.cvsignore:
11406         * examples/queue/.cvsignore:
11407         * examples/queue2/.cvsignore:
11408         * examples/queue3/.cvsignore:
11409         * examples/queue4/.cvsignore:
11410         * examples/retag/.cvsignore:
11411         * examples/thread/.cvsignore:
11412         * examples/typefind/.cvsignore:
11413         * examples/xml/.cvsignore:
11414         * gst/.cvsignore:
11415         * gst/autoplug/.cvsignore:
11416         * gst/elements/.cvsignore:
11417         * gst/indexers/.cvsignore:
11418         * gst/parse/.cvsignore:
11419         * gst/registries/.cvsignore:
11420         * gst/schedulers/.cvsignore:
11421         * libs/gst/bytestream/.cvsignore:
11422         * libs/gst/control/.cvsignore:
11423         * libs/gst/getbits/.cvsignore:
11424         * tests/.cvsignore:
11425         * tests/bufspeed/.cvsignore:
11426         * tests/instantiate/.cvsignore:
11427         * tests/memchunk/.cvsignore:
11428         * tests/muxing/.cvsignore:
11429         * tests/sched/.cvsignore:
11430         * tests/seeking/.cvsignore:
11431         * tests/threadstate/.cvsignore:
11432         * testsuite/.cvsignore:
11433         * testsuite/caps/.cvsignore:
11434         * testsuite/cleanup/.cvsignore:
11435         * testsuite/dynparams/.cvsignore:
11436         * testsuite/plugin/.cvsignore:
11437         * tools/.cvsignore:
11438           update - this is huge, because it includes *.bb, *.bbg and *.da files
11439           which are generated for gcov.
11440
11441 2004-01-11  David Schleef  <ds@schleef.org>
11442
11443         * gst/gststructure.c: (gst_strtoi), (gst_value_from_string): Add
11444         a function to parse integers in ways that strto[u]l() does not.
11445
11446 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11447
11448         * tools/gst-inspect.c: (print_caps):
11449           improve output of caps a bit
11450
11451 2004-01-11  David Schleef  <ds@schleef.org>
11452
11453         * gst/gstbuffer.c: (gst_buffer_create_sub): Subbuffers should
11454         inherit correct flags (READONLY and DONTKEEP).
11455
11456 2004-01-11  David Schleef  <ds@schleef.org>
11457
11458         * gst/elements/gstfilesrc.c: (gst_filesrc_free_parent_mmap),
11459         (gst_filesrc_map_region):
11460         * gst/gstbuffer.c: (_gst_buffer_initialize),
11461         (_gst_buffer_sub_free), (gst_buffer_default_copy),
11462         (gst_buffer_new), (gst_buffer_create_sub),
11463         (gst_buffer_is_span_fast), (gst_buffer_span):
11464         * gst/gstbuffer.h:
11465         Change GstBuffer private structure element names. (all files)
11466         * gst/gstqueue.c: (gst_queue_init), (gst_queue_getcaps),
11467         (gst_queue_link):
11468         * gst/gstqueue.h:
11469         Implement getcaps/pad_link functions that handle the case where
11470         there are data in the queue.
11471
11472 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11473
11474         * gst/elements/gstbufferstore.c:
11475           initialize debugging structure correctly
11476         * gst/elements/gsttee.c: (gst_tee_set_property):
11477           g_object_notify when property was changed
11478         * gst/elements/gsttypefindelement.c:
11479         (gst_type_find_element_change_state):
11480           clear caps correctly
11481
11482 2004-01-11  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11483
11484         * gst/gstqueue.c: (gst_queue_init):
11485           Use better defaults for when a queue should block. This
11486           gets rid of jerky playback for quite a few files.
11487           It takes more memory.
11488
11489 2004-01-10  Thomas Vander Stichele  <thomas at apestaart dot org>
11490
11491         (gst_xml_registry_parse_padtemplate):
11492           make critical message slightly more useful
11493
11494 2004-01-10  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11495
11496         * gst/gstinfo.c: (gst_debug_log), (gst_debug_log_valist),
11497         (gst_debug_message_get), (gst_debug_log_default):
11498         * gst/gstinfo.h:
11499           Change gst_debug_log(_valist) to take a const format string.
11500           Change prototype of log function and functions using those to 
11501           take a GstDebugMessage instead of a string that requires using
11502           gst_debug_message_get.
11503
11504 2004-01-08  David Schleef  <ds@schleef.org>
11505
11506         * Makefile.am:
11507         * configure.ac:
11508         Add option --enable-gcov to build GStreamer with -fprofile-arcs
11509         and -ftest-coverage, which allows gcov to show information about
11510         testsuite coverage.
11511
11512 2004-01-08  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11513
11514         * gst/gstutils.h:
11515           Add GST_BOILERPLATE(_FULL), GST_PARENT_CALL and
11516           GST_PARENT_CALL_WITH_DEFAULT
11517         * gst/elements/gstaggregator.c: 
11518         * gst/elements/gstbufferstore.c: 
11519         * gst/elements/gstfakesink.c: 
11520         * gst/elements/gstfakesrc.c: 
11521         * gst/elements/gstfdsink.c: 
11522         * gst/elements/gstfdsrc.c: 
11523         * gst/elements/gstfilesink.c: 
11524         * gst/elements/gstfilesrc.c: 
11525         * gst/elements/gstidentity.c: 
11526         * gst/elements/gstmd5sink.c: 
11527         * gst/elements/gstmultidisksrc.c:
11528         * gst/elements/gstpipefilter.c: 
11529         * gst/elements/gstshaper.c:
11530         * gst/elements/gststatistics.c:
11531         * gst/elements/gsttee.c:
11532         * gst/elements/gsttypefindelement.c:
11533           use them.
11534
11535 2004-01-07  Thomas Vander Stichele  <thomas at apestaart dot org>
11536
11537         * docs/gst/gstreamer-docs.sgml: remove props
11538         * docs/gst/gstreamer-sections.txt: remove props
11539         * docs/gst/tmpl/gst.sgml:
11540         * docs/gst/tmpl/gstbin.sgml:
11541         * docs/gst/tmpl/gstbuffer.sgml:
11542         * docs/gst/tmpl/gstcaps.sgml:
11543         * docs/gst/tmpl/gstclock.sgml:
11544         * docs/gst/tmpl/gstelement.sgml:
11545         * docs/gst/tmpl/gstindex.sgml:
11546         * docs/gst/tmpl/gstobject.sgml:
11547         * docs/gst/tmpl/gstpad.sgml:
11548         * docs/gst/tmpl/gstpadtemplate.sgml:
11549         * docs/gst/tmpl/gstreamer-unused.sgml:
11550         * docs/gst/tmpl/gstthread.sgml:
11551         * docs/gst/tmpl/gstxml.sgml:
11552           sync with code reorganization
11553
11554 2004-01-07  Jan Schmidt  <thaytan@mad.scientist.com>
11555
11556         * gst/gstelement.c: (gst_element_get_compatible_pad_filtered):
11557         Make the 'Could not find compatible pad' message more informative.
11558
11559 2004-01-07  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11560                                                                                 
11561         * gst/elements/gstfilesink.c: (gst_filesink_set_location):
11562           Fix for if we pass NULL as property to location.
11563         * gst/elements/gstpipefilter.c: (gst_pipefilter_init),
11564         (gst_pipefilter_handle_event), (gst_pipefilter_chain):
11565           Fix for instantiate-test (see below).
11566         * gst/gststructure.c: (_gst_structure_parse_value):
11567           Fix compile error on gcc-2.96.
11568         * configure.ac:
11569         * tests/Makefile.am:
11570         * tests/instantiate/Makefile.am:
11571         * tests/instantiate/create.c: (create_all_elements), (main):
11572           Add a test that instantiates all elements. This makes it easy to
11573           track dead code for old API/design (like setting event functions
11574           on sink pads and so on).
11575
11576 2004-01-06  Jan Schmidt  <thaytan@mad.scientist.com>
11577
11578         * gst/gstcaps.c: (gst_caps_append_structure):
11579           Move the poisoning to allow a NULL structure
11580         * gst/gstevent.c: (_gst_event_free):
11581           When freeing a navigation event, free the structure
11582           also
11583
11584 2004-01-04  David Schleef  <ds@schleef.org>
11585
11586         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_request_new_pad):
11587         Remove usage of gst_pad_proxy_fixate.
11588         * gst/gstcaps.c: (gst_caps_append), (gst_caps_append_structure),
11589         (gst_caps_split_one), (gst_caps_replace):
11590         Add poisoning code.
11591         * gst/gstmarshal.list:
11592         Add pointer__pointer for fixate signal
11593         * gst/gstpad.c: (gst_real_pad_class_init),
11594         (_gst_real_pad_fixate_accumulator), (gst_pad_link_fixate),
11595         (_gst_pad_default_fixate_func), (gst_pad_proxy_fixate),
11596         (gst_pad_set_explicit_caps), (gst_pad_template_new):
11597         Add poisoning code. Add fixate signal on RealPad. Change
11598         set_explicit_caps() to take const GstCaps, like try_set_caps().
11599         * gst/gstpad.h:
11600         * testsuite/caps/Makefile.am:
11601         * testsuite/caps/app_fixate.c: Add a test for the fixate signal
11602
11603 2004-01-03  David Schleef  <ds@schleef.org>
11604
11605         * gst/elements/gsttypefindelement.c:
11606         (gst_type_find_element_have_type), (gst_type_find_element_init):
11607         Use gst_pad_use_explicit_caps for src pad.
11608         * gst/gstpad.c: (gst_pad_try_set_caps):  Check that link exists
11609         before using it.
11610
11611 2004-01-03  David Schleef  <ds@schleef.org>
11612
11613         * gst/gstelement.c: (gst_element_link_pads_filtered),
11614         (gst_element_negotiate_pads): Fix to allow DELAYED to indicate
11615         that linking was successful.
11616         * gst/gstpad.c: (gst_pad_link_free),
11617         (gst_pad_link_call_link_functions), (gst_pad_link_negotiate),
11618         (gst_pad_link_try), (gst_pad_link_unnegotiate),
11619         (gst_pad_unnegotiate), (gst_pad_set_explicit_caps): Pass
11620         GstPadLinkReturn correctly between functions, and don't fail
11621         when DELAYED is used (DELAYED is very important).  Better
11622         cleanup on unlinking and unnegotiation.  Should fix some spider
11623         bugs.
11624
11625 2004-01-02  David Schleef  <ds@schleef.org>
11626
11627         * gst/gstelement.c: (gst_element_class_init),
11628         (gst_element_base_class_init): ->padtemplates should be cleared
11629         in base_init, since we need to have a fresh list for every
11630         class.  (Alternately, we chould copy the list and share the
11631         actual pad templates (not the list), but that would require
11632         changing every plugin to move pad template registration from
11633         base_init to class_init.)
11634
11635 2004-01-03  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11636
11637         * gst/gstelement.c: (gst_element_class_add_pad_template):
11638           Refuse registering a pad template if another pad template
11639           with the same name already exists (#114715).
11640
11641 2004-01-02  David Schleef  <ds@schleef.org>
11642
11643         * gst/gstcaps.c: (_gst_structure_is_equal_foreach),
11644         (gst_caps_is_equal_fixed): Add new function.
11645         * gst/gstcaps.h: ditto.
11646         * gst/gstpad.c: (gst_real_pad_class_init),
11647         (gst_pad_link_call_link_functions), (gst_pad_try_set_caps),
11648         (gst_pad_set_explicit_caps), (gst_pad_get_caps):  In try_set_caps,
11649         check new caps against existing caps -- if they're the same, return
11650         OK without renegotiating.  caps-nego-failed signal fixed so that
11651         the marshaller isn't VOID__OBJECT.  Also changed to G_TYPE_POINTER
11652         to save an extra caps copy.  Don't complete negotiation if a pad
11653         link function returns DELAYED.
11654
11655 2004-01-02  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11656
11657         * gst/gstpad.c: (gst_pad_try_relink_filtered):
11658           Fix wrong g_return_if_fail
11659
11660 2004-01-03  Jan Schmidt  <thaytan@mad.scientist.com>
11661
11662         * gst/gstbin.c: (gst_bin_class_init):
11663         Change the marshalling of element_added/element_removed
11664         to use gst_marshal_VOID__OBJECT, since gst_marshal_VOID__POINTER 
11665         complains that GST_TYPE_ELEMENT is not G_TYPE_POINTER
11666
11667 2004-01-01  David Schleef  <ds@schleef.org>
11668
11669         * gst/gstpad.c: (gst_pad_set_explicit_caps),
11670         (gst_pad_explicit_getcaps), (gst_pad_explicit_link),
11671         (gst_pad_use_explicit_caps):
11672         * gst/gstpad.h:
11673         Add new functions.  gst_pad_use_explicit_caps() sets up a pad
11674         to use an internal getcaps and link fuction so that negotiation
11675         always results in the explicitly set caps.
11676         gst_pad_set_explicit_caps() sets the explicit caps.  These functions
11677         are particularly useful for decoders.
11678
11679 2003-12-31  David Schleef  <ds@schleef.org>
11680
11681         * gst/elements/gstidentity.c: (gst_identity_class_init),
11682         (gst_identity_init), (gst_identity_chain),
11683         (gst_identity_set_property), (gst_identity_get_property):
11684         * gst/elements/gstidentity.h:
11685         * gst/gstqueue.c: (gst_queue_init):
11686           Negotiation fixes.
11687
11688 2003-12-31  David Schleef  <ds@schleef.org>
11689
11690         * gst/gstcaps.c: (gst_caps_intersect),
11691         (_gst_caps_normalize_foreach), (gst_caps_normalize):
11692           Implement gst_caps_normalize().
11693         * testsuite/caps/normalisation.c: (main):
11694           Add an additional test
11695
11696 2003-12-31  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11697
11698         * gst/gstqueue.c: (gst_queue_init):
11699           use gst_pad_proxy_getcaps()
11700
11701 2003-12-31  David Schleef  <ds@schleef.org>
11702
11703         * gst/elements/gstshaper.c: (gst_shaper_link):
11704         * gst/elements/gsttee.c: (gst_tee_init), (gst_tee_request_new_pad):
11705         * gst/gstqueue.c: (gst_queue_link):
11706           Negotiation fixes.
11707
11708 2003-12-31  David Schleef  <ds@schleef.org>
11709
11710         * gst/gstpad.c: (gst_pad_proxy_pad_link), (gst_pad_proxy_fixate):
11711         * gst/gstpad.h: Add functions that are useful as default pad
11712         link and fixate functions for elements.
11713
11714 2003-12-30  David Schleef  <ds@schleef.org>
11715
11716         * gst/gstpad.c: (gst_pad_link_try):
11717           Fix segfault when attempting to return to old caps
11718
11719 2003-12-29  David Schleef  <ds@schleef.org>
11720
11721         * gst/gstcaps.c: (gst_caps_normalize), (simplify_foreach),
11722         (gst_caps_structure_simplify), (gst_caps_simplify):
11723         * gst/gstcaps.h:
11724           Add simplify function
11725         * gst/gstpad.c: (gst_pad_link_try), (gst_pad_try_set_caps),
11726         (gst_pad_perform_negotiate), (gst_pad_is_negotiated):
11727         * gst/gstpad.h:
11728           Copy over srcnotify, sinknotify when calling old pad_link
11729           functions.  Add new is_negotiated() function.
11730         * gst/gststructure.c: (gst_structure_copy):
11731           Fix an incredibly stupid bug that should have been noticed
11732           weeks ago.  _copy() returned the argument, not the new copy.
11733
11734 2003-12-27  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11735
11736         * gst/gstcaps.c: (gst_caps_append):
11737           add sanity checks
11738         * gst/gstcaps.h: (gst_caps_debug):
11739           remove, it doesn't exist anymore.
11740         * gst/gstelement.c: (gst_element_threadsafe_properties_pre_run),
11741         (gst_element_threadsafe_properties_post_run):
11742           make debugging messages not clutter up THREAD debug category
11743         (gst_element_negotiate_pads), (gst_element_clear_pad_caps),
11744         (gst_element_change_state):
11745           update to new caps API
11746         * gst/gstinterface.c: (gst_implements_interface_cast):
11747           don't put vital code in g_return_if_fail
11748         * gst/gstpad.c: (gst_pad_link_try), (gst_pad_try_set_caps), 
11749         (gst_pad_link_filtered):
11750           add pst_pad_try_link and use it.
11751         (gst_pad_perform_negotiate), (gst_pad_renegotiate):
11752           implement correctly, deprecate first one.
11753         (gst_pad_link_unnegotiate), (gst_pad_unnegotiate):
11754           add and implement.
11755         (gst_pad_try_relink_filtered), (gst_pad_relink_filtered):
11756           implement.
11757         (gst_pad_get_negotiated_caps):
11758           add and implement. Make GST_PAD_CAPS call this function.
11759         (gst_pad_get_caps):
11760           remove unneeded check..
11761         (gst_pad_recover_caps_error):
11762           disable, always return FALSE.
11763         (gst_real_pad_dispose):
11764           don't free caps and appfilter anymore, they're unused.
11765         * gst/gstpad.h:
11766           Reflect changes mentioned above.
11767         * gst/gstsystemclock.c: (gst_system_clock_wait):
11768           Make 'clock is way behind' a debugging message.
11769         * gst/gstthread.c: (gst_thread_change_state):
11770           Fix debugging message
11771
11772 2003-12-25  Thomas Vander Stichele  <thomas at apestaart dot org>
11773
11774         * gst/gstinfo.h:
11775           fix GST_DEBUG_CATEGORY_INIT gtk-doc description
11776         * docs/gst/tmpl/gstreamer-unused.sgml:
11777           removed all traces of cvs conflicts
11778
11779 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
11780
11781         * configure.ac:
11782         * gst/schedulers/cothreads_compat.h:
11783         * libs/Makefile.am:
11784           remove last instances of wingo cothread usage
11785
11786 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
11787
11788         * gst/gstplugin.c:
11789         * gst/gstversion.h.in:
11790         * gst/parse/grammar.y:
11791           change comment block from /** to /* when not gtk-doc comments
11792
11793 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
11794
11795         * gst/gst.c: whitespace and doc style fixes
11796
11797 2003-12-24  Thomas Vander Stichele  <thomas at apestaart dot org>
11798
11799         * gst/gstformat.h: remove trailing whitespace from enum for gtk-doc
11800
11801 2003-12-24  Colin Walters  <walters@verbum.org>
11802
11803         * gst/elements/gsttypefindelement.c:
11804           gst/elements/gsttypefindelement.h: Make GstCaps parameter const.
11805           Copy caps parameter. Use _POINTER to marshal caps instead of _BOXED.
11806           Don't double-free caps.
11807
11808 2003-12-23  David Schleef  <ds@schleef.org>
11809
11810         * gst/gstelement.c, gst/gstpad.c, gst/parse/grammar.y,
11811           gst/gstcaps.c, gst/autoplug/gstspideridentity.c:
11812           Many little fixes and additions of debug statements to
11813           get rhythmbox working.
11814
11815 2003-12-23  Colin Walters  <walters@verbum.org>
11816
11817         * gst/autoplug/gstspideridentity.c (gst_spider_identity_sink_loop_type_finding):
11818         Use GST_PAD_LINK_SUCCESSFUL.
11819
11820 2003-12-23  David Schleef  <ds@schleef.org>
11821
11822         * gst/elements/gstaggregator.c:
11823         * gst/elements/gsttee.c:
11824           Use gst_pad_proxy_getcaps().
11825         * gst/gstpad.c:
11826         * gst/gstpad.h:
11827           Add gst_pad_proxy_getcaps(), which filter elements can use
11828           as a generic getcaps implementation.
11829           Fix gst_pad_get_allowed_caps().  It just wasn't doing what
11830           was advertised.
11831
11832 2003-12-23  David Schleef  <ds@schleef.org>
11833
11834         * gst/gstpad.c:
11835           Rearrange/rewrite much of the pad negotiation code, since it
11836           resembled pasta.  This actually changes the way some
11837           negotiation works, since the previous code was inconsistent
11838           depending on how it was invoked.  Add (internal) structure
11839           GstPadLink, which is used to hold some information (more in
11840           the future) about the link between two pads.  Fixes a number
11841           of bugs, including random lossage of filter caps when the
11842           initial negotiation is delayed.  A few functions are still
11843           unimplemented.
11844         * gst/gstpad.h:
11845           Add GST_PAD_LINK_{SUCESSFUL|FAILED}() macros.  Please use
11846           these when testing GstPadLinkReturn values instead of comparing
11847           directly.
11848
11849 2003-12-23  David Schleef  <ds@schleef.org>
11850
11851         * gst/gstvalue.c: 
11852         * gst/gstvalue.h:
11853           Rearrange lots of code.  Change registration of compare function
11854           into registration of compare/serialize/deserialize functions.
11855           Doesn't include implementation of gst_value_[de]serialize(),
11856           but that should be easy.
11857
11858 2003-12-23  Thomas Vander Stichele  <thomas at apestaart dot org>
11859
11860         * docs/gst/gstreamer-sections.txt:
11861         * docs/gst/tmpl/gstprops.sgml: removed
11862         * docs/gst/tmpl/gstreamer-bufferpool.sgml: removed
11863           David removed props and caps code, so let's remove their docs as well.
11864           Removed all no longer existing symbols from gstreamer-sections.txt
11865           
11866 2003-12-22  Colin Walters  <walters@verbum.org>
11867
11868         * gst/gsttaginterface.c, gst/gsttaginterface.h,
11869           gst/gsttag.c, gst/gsttag.h:  Add interface to setting GValues
11870           of tags directly.
11871
11872 2003-12-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11873
11874         * gst/elements/gstelements.c:
11875           Set ranks of elements to NONE, so the autoplugger doesn't use them.
11876         * gst/elements/gstshaper.c: (gst_shaper_getcaps):
11877           Fix proxying to new CAPS stuff. Don't call get_allowed_caps but
11878           gst_caps (peer).
11879
11880 2003-12-22  Benjamin Otte  <in7y118@public.uni-hamburg.de>
11881
11882         * gst/autoplug/gstsearchfuncs.c: (gst_autoplug_caps_intersect):
11883         * gst/autoplug/gstspideridentity.c: (gst_spider_identity_link),
11884         (gst_spider_identity_getcaps), (gst_spider_identity_change_state),
11885         (gst_spider_identity_sink_loop_type_finding):
11886         * gst/autoplug/gstspideridentity.h:
11887           Fix autoplugging in spider element, so it works with new caps.
11888           This was mainly caused by identifying empty caps incorrectly.
11889
11890 2003-12-22  David Schleef  <ds@schleef.org>
11891
11892         * gststructure.c, gstvalue.c, gstvalue.h: Add
11893           gst_value_init_and_copy() and use it, to avoid silly mistakes in
11894           using g_value_copy()
11895
11896 2003-12-21  David Schleef  <ds@schleef.org>
11897
11898         * many, many files: Merge CAPS branch.  This includes:
11899           - implemention of GstValue and several GstValue types
11900           - implemention of GstStructure
11901           - entire rewrite of GstCaps
11902           - removal of GstProps
11903           - many changes to GstPad to compensate for new caps paradigm
11904           - removal of GstBufferpool
11905         * gst/Makefile.am, gst/gst.h, gst/gstpad.h, gst/gsttypefind.h,
11906         gstvalue.h, gst/gstcaps[2]*.[ch]:
11907           - rename gstcaps2.[ch] to gstcaps.[ch]
11908
11909 2003-12-21  Ronald Bultje  <rbultje@ronald.bitfreak.net>
11910
11911         * gst/gstqueue.c: (gst_queue_handle_pending_events),
11912         (gst_queue_chain), (gst_queue_handle_src_event):
11913           implement timeout for sending events. Workaround for if the
11914           pipeline on this queue is not passing any data.
11915
11916 2003-12-21  Ronald Bultje <rbultje@ronald.bitfreak.net>
11917                                                                                 
11918         * ChangeLog: moved to gstreamer/docs/random/old/ChangeLog.gstreamer
11919         * moved CVS to freedesktop.org
11920