Release 0.10.23
[platform/upstream/gstreamer.git] / NEWS
1 This is GStreamer 0.10.23 "Alaboo Alaboo"
2
3 Changes since 0.10.22:
4       * Support files > 4GB on Windows
5       * Controller interpolation fixes
6       * Add timer support to GstPoll and use it for clocking
7       * Attempt to typefind contents from the file extension if all else fails
8       * GStreamer revision control switched to Git
9       * Many other bug fixes and improvements
10
11 Bugs fixed since 0.10.22:
12      
13       * 579177 : GstInfo: maintain ABI compatibility
14       * 163577 : [RFC] Interlaced/progressive media support in GStreamer.
15       * 574160 : collectpads does not reliably eos when last pad is removed
16       * 575598 : hierarchical pipelines accumulate segment-done wrongly
17       * 575922 : disabling subsystems cause API break
18       * 576842 : loading a broken registry file can crash
19       * 555978 : [ladspa] no elements exposed/found on Cygwin
20       * 565607 : Broken macros in gsturi.h and gstinterface.h
21       * 566936 : [ghostpads] unlink function wrongly called on target
22       * 567692 : gstinfo.h header not compatible with C++
23       * 567725 : [qtdemux] stopping at a time sometimes shows a different ...
24       * 568289 : gst_pad_template_new() leaks caps it's supposed to take o...
25       * 568438 : gst_poll_wait calling read() on control socket
26       * 568481 : GStreamer linking failures.
27       * 568632 : __MSVCRT_VERSION__ not defined with mingw, causing " stora...
28       * 568678 : filesrc doesn't logs offsets
29       * 570910 : Removing the target of a ghostpad does not re-target the ...
30       * 571227 : Add home page tag
31       * 571559 : [API] add GST_PARAM_MUTABLE_PLAYING etc. to indicate vali...
32       * 572480 : unref and copy functions should not be macros
33       * 573623 : [API] Array binary search utility function
34       * 574024 : [GstAdapter] gst_adapter_push should not accept empty buf...
35       * 574211 : gst_poll_*_control always returns FALSE on Windows
36       * 574213 : [gstcheck] fix for libcheck > 0.9.6
37       * 574241 : gst_tag_list_add and gst_tag_list_add_values behave incon...
38       * 574484 : [patch] Make caps in DOT debug graphs more readable
39       * 574623 : [dot_file_with_ts] ':' not a valid character for a filename
40       * 574805 : [capsfilter] Doesn't reset the internal suggestion with A...
41       * 575695 : build fails on OpenSolaris due to incorrect header file i...
42       * 575814 : flag for EOS on gst-launch when exiting with ctrl-c
43       * 576381 : [basesink] QoS: emergency rendering not always done
44       * 576563 : pidgin crashes on exit in gst_plugin_ext_dep_free()
45       * 576582 : A patch to enable the use of 'name' in Enum parameters
46       * 577887 : Missing GST_DISABLE_GST_DEBUG in gstregistrybinary.c
47       * 577891 : add alloc-pad property on tee
48       * 578114 : API: add two new log levels: FIXME and MEMDUMP
49       * 578201 : _gst_plugin_fault_handler_is_setup undefined under HAVE_W...
50       * 579127 : gst-launch: disable CLOCK_LOST message handling
51       * 580121 : race condition in GStreamer state changes causes problems...
52       * 361155 : Add monotonic clock
53       * 517231 : threadsafe/colored windows logging
54       * 572591 : Another batch of " differs in signedness " warnings
55       * 573823 : pad block callback if it is re-blocked while the previous...
56       * 574163 : Fix gst_pad_activate_pull deactivation with unlinked element
57       * 575682 : Add gst_pad_is_compatible()
58       * 575988 : On Windows filesink can't write files longer than 2-4 GiB...
59
60 API additions since 0.10.22:
61     
62       * New FIXME and MEMDUMP debug levels
63       * gst_tag_list_get_buffer() and gst_tag_list_get_buffer_index()
64       * New tags: GST_TAG_SUBTITLE_CODEC, GST_TAG_HOMEPAGE
65       * gst_util_array_binary_search()
66       * gst_message_new_request_state(), gst_message_parse_request_state(), GST_MESSAGE_REQUEST_STATE
67       * GstPoll::gst_poll_new_timer()
68       * GstPoll::gst_poll_write_control()
69       * GstPoll::gst_poll_read_control()
70
71 Changes since 0.10.21:
72
73       * GstController improvements
74       * Extensions to the latency setting behaviours
75       * Ability for plugins to register dependencies to trigger re-scanning
76       * Optimisations in some common operations on caps and values and elsewhere
77       * Add sequence numbers to events so dependent events can be associated with
78         the event that caused them
79       * New macros for reading and writing float values
80       * Many improvements in the basesink base class
81       * Support non-default main contexts for GstBus watches
82       * Improvements in pull-mode scheduling of sinks
83       * Fixes for alignment issues on sparc
84       * Ghost pad fixes
85       * New bit-reader assistance API
86       * Many other bug fixes and improvements
87       
88 Bugs fixed since 0.10.21:
89
90       * 567002 : --gst-disable-registry-update also skips registry creation
91       * 350477 : [Registry] Provide a way for plugins to delegate the 'cha...
92       * 510354 : post GST_MESSAGE_STRUCTURE_CHANGE when linking and unlink...
93       * 526044 : Crash if there is more than one watcher for a GstBus
94       * 539108 : gst_ghost_pad_new() does more than call g_object_new()
95       * 544003 : [parse] Links to wrong pad if no padtemplate name is given
96       * 544293 : rtspsrc / gstpoll regression
97       * 545714 : GST_READ_UINT_* and GST_WRITE_UINT_* are not always safe ...
98       * 548786 : [win32] search for plugins based on location of DLL
99       * 551676 : Small Memleak fix in gst_pad_link_check_compatible_unlocked
100       * 552778 : add free_func in gstbuffer instances
101       * 553554 : [base] Add a generic bit reader
102       * 553874 : query_position broken during seek
103       * 555196 : Move floating point endian conversion macros into core
104       * 555307 : Need to push latency event into the pipeline
105       * 555631 : Banshee crashes; gstreamer GST_CAPS GST_IS_CAPS warnings
106       * 556091 : libtool-2.2 and old gettext don't mix
107       * 556900 : a copy & paste bug in helloworld example
108       * 557154 : Allow totem to run without write-access to home directory
109       * 557300 : libgstnet needs to link against $(WIN32_LIBS)
110       * 557438 : Gstreamer crashes when Banshee supposed to change track
111       * 557649 : GstBaseTransform can cause ivalid memory references
112       * 559250 : segments need identifiers.
113       * 560301 : Add --plugin to gst-inspect
114       * 560360 : Excessive statting when reading binary cache
115       * 560399 : Unnecessary CRC checksum for binary registry cache
116       * 560442 : GNOME Goal: Remove deprecated GLib symbols
117       * 561501 : g_type_class_ref without unref
118       * 562170 : GstBus watch doesn't work with non-default main context
119       * 562949 : [API] Add an URI query type for querying the source/sink URI
120       * 564863 : Caps are not propagated from a ghostpad's target to the g...
121       * 567225 : volatile gonce_data in BOILERPLATE not initialized to 0
122       * 566393 : [deadlock] Setting index on a pipeline
123
124 API added since 0.10.21:
125
126       * Add bit reader and byte reader classes.
127       * gst_message_new_structure_change()
128       * gst_message_parse_structure_change()
129       * GST_BUFFER_FREE_FUNC()
130       * Add GST_READ_UINT24_(LE|BE) and GST_WRITE_UINT24_(LE|BE).
131       * GstBaseSrc::gst_base_src_set_blocksize()
132       * GstBaseSrc::gst_base_src_get_blocksize()
133       * GstBaseSink::gst_base_sink_set_blocksize()
134       * GstBaseSink::gst_base_sink_get_blocksize()
135       * GstBaseSink::blocksize
136       * GstBaseSink::gst_base_sink_do_preroll()
137       * Add gst_byte_reader_get_data and gst_byte_reader_peek_data 
138       * Move float endianness conversion macros from libgstfloatcast to core
139       * gst_util_seqnum_next, gst_util_seqnum_compare
140       * gst_event_get_seqnum, gst_event_set_seqnum
141       * gst_message_get_seqnum, gst_message_set_seqnum
142       * GstSeekFlags::GST_SEEK_FLAG_SKIP 
143       * gst_bin_recalculate_latency()
144       * GstBin::do-latency
145       * gst_tag_setter_reset_tags()
146       * gst_query_new_uri, gst_query_set_uri, gst_query_parse_uri
147       * add gst_plugin_add_dependency()
148       * add gst_plugin_add_dependency_simple()
149
150
151 Changes since 0.10.20:
152
153       * Basetransform rework
154       * Basesink synchronisation extensions
155       * New documentation
156       * Many bug fixes, enhancements and optimisations
157
158 Bugs fixed since 0.10.20:
159
160       * 481169 : [tag] add support for geo tags (gps location etc.)
161       * 520694 : adding GST_TAG_KEYWORDS
162       * 538201 : deleting the control point at ts=0 does not lower the con...
163       * 544855 : fakesrc and fakesink should call super::event()
164       * 339795 : [GstBaseTransform] Reverse negotiation issues in passthro...
165       * 348114 : [PPC64?] [gcc-4.1.2?] GST_BUFFER_IN_CAPS flag should have...
166       * 361718 : [basetransform] needs API to force renegotiation
167       * 533856 : gst_buffer_join() documentation is unclear
168       * 536978 : GTKDOC_CFLAGS should include CFLAGS
169       * 537804 : [multiqueue] wrongly reporting that the queue is full.
170       * 537812 : [check] add api to setup a pad by name
171       * 538568 : Add GST_TAG_ATTACHMENT
172       * 539772 : gst_pad_template_new() does more than call g_object_new()
173       * 542175 : gst-inspect --gst-plugins-path fails with multiple direct...
174       * 543444 : gst_base_sink_get_position can return 0 unexpectedly
175       * 543853 : Bison version check failure on OSX 10.4 Tiger
176       * 544174 : [basesrc] allow dynamic value of the seekable value.
177       * 544776 : [win32] binary registry may fail if glib is using a diffe...
178       * 545352 : gsturi is too restrictive
179       * 545603 : gst-inspect: don't print uri handler when compiled withou...
180       * 545605 : gstelementfactory: don't use uri handler code without uri...
181       * 545607 : gst: include gstconfig when using macros defined therein
182       * 545853 : [basetransform] rewrite
183       * 546328 : fractions with G_MAXINT cause failure for fixation
184       * 546822 : gstreamer doesn't tell gettext to output its translations...
185       * 547277 : filesrc detect if a file is seekable using SEEK_SET and n...
186       * 547728 : [basetransform] fail on buffer_alloc 
187       * 548394 : basesink should ignore EOS during flushing
188       * 548652 : [Inconsistency] GST_TAG_LOCATION is used for different me...
189       * 549504 : Thread-safe version of gst_pad_get_internal_links()
190       * 551952 : Need 'check' package when compile
191       * 551978 : Memleak in gst_element_sync_state_with_paren
192       * 547835 : tee release_request_pad while buffer_alloc racyness
193       * 538628 : Patch: added a timeout property to fdsrc used in gst_poll...
194       * 546883 : [basetransform] ximagesink fails when resizing video window
195       * 551509 : gst_base_transform_prepare_output_buffer: assertion faile...
196
197 API added since 0.10.20:
198
199       * Add GST_TAG_ATTACHMENT for generic file attachments to streams.
200       * Add gst_base_sink_set_render_delay()
201       * Add gst_base_sink_get_render_delay()
202       * Add gst_check_setup_src_pad_by_name
203       * Add gst_check_setup_sink_pad_by_name
204       * Add gst_check_teardown_pad_by_name
205       * Add GstBaseTransform::gst_base_transform_suggest()
206       * GstBaseTransform::gst_base_transform_reconfigure()
207       * GstPad::gst_pad_set_iterate_internal_links_function()
208       * GstPad::GstPadIterIntLinkFunction
209       * GstPad::gst_pad_iterate_internal_links()
210       * GstPad::gst_pad_iterate_internal_links_default()
211
212 API deprecated since 0.10.20:
213
214       * gst_pad_get_internal_links()
215       * gst_pad_set_internal_link_function()
216       * gst_pad_get_internal_links_default()
217
218 Changes since 0.10.19:
219
220       * Add the Presets interface
221       * Use the binary registry by default
222       * Deprecate gst_element_get_pad and don't use it anywhere any more.
223       * Reverse playback fixes
224       * API to get missing element messages from parse_launch parsing.
225       * Fixes in latency calculations
226       * BaseTransform negotiation fixes
227       * New Buffering query and messages
228       * Fix multiqueue deadlocks when changing limits
229       * Remove pre-generated parser hacks and require newer flex/bison
230       * Use GSlice in more places
231       * Use static strings in property declarations everywhere to save memory
232         allocations
233       * Fix unaligned memory accesses with the binary registry and add CRC
234         checks
235       * Lots of other bug fixes
236
237 Bugs fixed since 0.10.19:
238
239       * 535069 : basesrc no longer support non-flushing seeks on itself
240       * 522882 : Add a configure option to enable/disable OPTION_PARSING i...
241       * 396779 : Preset interface for elements
242       * 359653 : GStreamer Binary Registry patch
243       * 401456 : [API] Rename gst_bin_find_unconnected_pad to gst_bin_find...
244       * 446763 : [identity] leaks events in single segment mode
245       * 459862 : typefinding coud be more efficient
246       * 461253 : Crash when gst_base_transform_prepare_output_buffer is se...
247       * 489269 : valgrind option parameter invalid for valgrind 2.2 
248       * 508070 : gstreamer crashes whilst trying to read .so files in .deb...
249       * 512577 : GstTagMergeMode doc has slightly incorrect explanation
250       * 512578 : gst_tag_setter_merge_tags can mess up with KEEP_ALL merge...
251       * 514507 : gst-xmlinspect outputs text instead of xml for plugins
252       * 518022 : [libgstnet] MSVC 6.0 compile error due to socklen_t
253       * 518932 : Expose gst_segment_copy() to facilitate wrapping of GstSe...
254       * 520468 : Add a Env to enable/disable scan_and_update_registry for ...
255       * 522326 : use of 'char*' instead of 'const char*' in gst_caps_set_s...
256       * 523798 : [API] Some GstMiniObject enhancements
257       * 523806 : Should use G_PARAM_STATIC_(NAME|NICK|BLURB) when possible
258       * 523978 : Documentation fixes. 
259       * 523985 : [PATCH] [identity] meta-writes buffers without meta-writa...
260       * 524659 : Add specific error code for encrypted streams (e.g. WMA/A...
261       * 525532 : [fakesink/fakesrc/identity] Uses GObject marshallers for ...
262       * 526042 : [identity] check-imperfect-timestamp doesn't handle new s...
263       * 526236 : mingw32 gstpoll compilation fix
264       * 526247 : Actually build dlls when cross-compiling with mingw32
265       * 526705 : GstIndexResolver uses nickname field as description field
266       * 526768 : Basetransform bufferalloc passing through too easily
267       * 526814 : [API] add gst_pad_add_{data,event,buffer}_probe_full() wi...
268       * 527967 : gst_gerror_get_type is not thread safe
269       * 528187 : Get missing elements from gst_parse_launch()
270       * 528868 : URI schemes/protocols should be handled case insensitive
271       * 529148 : Make gstqueue give the right min latency
272       * 530317 : GType registration error - race condition when parallel c...
273       * 530637 : queue leak on capacity change
274       * 531538 : Race between gst_bus_set_flushing and async bus watches
275       * 533490 : gst_message_new_warning() should take const gchar*
276       * 533635 : gst_event_new_tag() documentation should say it takes own...
277       * 533740 : [API] add gst_typefind_suggest_simple()
278       * 533865 : gst_element_get_pad() should really be deprecated
279       * 534258 : basesink not accumulated time in some cases.
280       * 535218 : gst_base_src_send_event will block if basesrc is blocking...
281       * 536723 : Misspelled word in error string
282       * 536744 : Must link to libdl if dladdr() is used
283       * 536780 : gcc 4.3.0 compile warnings
284       * 536857 : DATADIR definition conflicts with windows headers
285       * 525961 : Build fails on darwin
286       * 535285 : Correct reference to GST_URI_UNKNOWN in gst_element_facto...
287
288 API added since 0.10.19:
289
290       * Add GST_IS_PARAM_SPEC_MINI_OBJECT, GST_PARAM_SPEC_MINI_OBJECT
291         GST_TYPE_PARAM_MINI_OBJECT and gst_value_dup_mini_object
292       * typefind::force-caps
293       * gst_message_set_buffering_stats()
294       * gst_message_parse_buffering_stats()
295       * GST_QUERY_BUFFERING
296       * GstBufferingMode
297       * gst_query_new_buffering()
298       * gst_query_set_buffering_percent()
299       * gst_query_parse_buffering_percent()
300       * gst_query_set_buffering_stats()
301       * gst_query_parse_buffering_stats()
302       * gst_query_set_buffering_range()
303       * gst_query_parse_buffering_range()
304       * GST_STREAM_ERROR_DECRYPT
305       * GST_STREAM_ERROR_DECRYPT_NOKEY
306       * gst_segment_copy()
307       * gst_pad_add_data_probe_full()
308       * gst_pad_add_buffer_probe_full()
309       * gst_pad_add_event_probe_full()
310       * GstEvent::gst_event_has_name()
311       * GstFakeSrc:format
312       * gst_type_find_suggest_simple()
313       * GstBaseSink::gst_base_sink_wait_clock()
314       * gst_parse_launch_full()
315       * gst_parse_launchv_full()
316       * gst_parse_bin_from_description_full()
317       * gst_parse_context_new()
318       * gst_parse_context_free()
319       * gst_parse_context_get_missing_elements()
320       * gst_bin_find_unlinked_pad()
321       * GstPreset interface
322
323 API deprecated since 0.10.19:
324
325       * gst_element_get_pad -
326         use gst_element_get_static_pad or gst_element_get_request_pad
327       * gst_atomic_int_set() - g_atomic_int_set from GLib
328       * gst_bin_find_unconnected_pad()
329
330 Changes since 0.10.18:
331
332       * Fix a regression in raw fd handling
333
334 Bugs fixed since 0.10.18:
335      
336       * 524041 : gstfdsrc broken in 0.10.18
337
338 Changes since 0.10.17:
339         
340       * New GstPoll abstraction simplifies operations on multiple fd's/sockets
341       * Various bug fixes and corrections
342       
343 Bugs fixed since 0.10.17:
344       
345       * 516187 : adding gst_collect_pads_read_buffer () collectpads
346       * 516395 : gst_buffer_create_sub does not copy flags
347       * 520756 : different registry backend configurations cause build errors
348       * 498222 : configure improvements
349       * 499127 : [multiqueue] has no documentation
350       * 505417 : Add GstPoll to core
351       * 509559 : [gstinfo]_gst_debug_init() memory leak
352       * 510194 : segmentation fault when trying to link elements.
353       * 511783 : [API] [check] add gst_check_element_push_buffer_list() etc.
354       * 513964 : [GstPad] gst_pad_get_caps don't return a copy of the caps
355       * 515469 : patch to add gst_index_set_resolver_full
356       * 519584 : gst_element_implements_interface() segfaults with 'filesr...
357       * 519698 : g_free/xmlFree mismatches in gstregistryxml
358       * 520152 : Core uses non-portable size_t and ssize_t
359       * 520671 : GstPoll needs to be ported to Windows
360       * 520808 : GstPoll's API could need some changes for Windows
361       * 520877 : registrybinary.c doesn't build cleanly on Windows/MSVC
362       * 521740 : libgstreamer.def exports not up to date
363       * 522741 : regression: gst_index_entry_free() frees string it does n...
364
365 Changes since 0.10.16:
366
367       * Fix compilation on environments that have POSIX timers but not
368         monotonic clocks
369
370 Bugs fixed since 0.10.16:
371       
372       * 512715 : gst/gstutils.c and HAVE_MONOTONIC_CLOCK
373
374 Changes since 0.10.15:
375
376       * Monotonic/Posix clock support
377       * Dumping of dot-file graph descriptions for debugging
378       * Clean-up of exported symbols
379       * Many bug-fixes and enhancements
380
381 Bugs fixed since 0.10.15:
382
383       * 497859 : --disable-gst-debug option fails compilation
384       * 339279 : [gst.URIHandler] interfaces with class-global virtual met...
385       * 498694 : Patches to avoid g_signal_emit(SIGNAL_HANDOFF) on identit...
386       * 498746 : basesink is forwarding downstream events
387       * 498767 : Hangs after end of tracks since 0.10.15
388       * 498924 : deprecate GST_PLUGIN_DEFINE_STATIC because it's not portable
389       * 499007 : [gst-plot-timeline] more options
390       * 499140 : Add check to ensure .def files are kept up-to-date
391       * 500143 : Some small improvements (limiting realloc and CPU usage )
392       * 500150 : [filesink] add property to enable buffering via setvbuf()
393       * 501560 : gst_(caps|structure)_from_string() crash if structure nam...
394       * 503131 : g_intern_string SUSE 10.2
395       * 503231 : Change to GST_BUFFER_FLAG_GAP meaning can break with base...
396       * 503417 : Build failure due uninitialized variable in function 'gst...
397       * 503590 : gstreamer-0.10.15 fails tests on ppc64
398       * 503675 : broken registry files written to disk
399       * 504499 : Messages from check no longer contain the test case name
400       * 505799 : iSight camera does not work in gstreamer
401       * 506643 : crash in fixate_value/gst_value_init_and_copy on empty li...
402       * 507957 : clean-up incomplete function declarations
403       * 508175 : GST_TIMEVAL_TO_TIME() and GST_TIMESPEC_TO_TIME() need to ...
404       * 510187 : gst_plugin_register_static() API review and GST_PLUGIN_DE...
405       * 510747 : Use $(MAKE) instead of make to fix the build if GNU make ...
406       * 511750 : Configure of prereleases 15.2-15.4 fail in OpenEmbedded M...
407
408 API additions since 0.10.15:
409
410 * GstIdentity::signal-handoffs
411 * gst_util_get_timestamp()
412 * gst_base_transform_set_gap_aware()
413 * GstFileSink::buffer-mode
414 * GstFileSink::buffer-size
415 * gst_plugin_register_static()
416
417 API deprecated since 0.10.15:
418
419 * GST_PLUGIN_DEFINE_STATIC()
420
421 Changes since 0.10.14:
422
423       * Changes for asynchronous sink management
424       * New ts-offset property on basesink for adjusting clock synchronisation
425       * New GstController LFO feature
426       * Fixes and improvements in latency measurement for live pipelines
427       * Additional documentation and docs fixes
428       * Faster typefinding
429       * More tag types added
430       * Improvements in various core elements and parent classes
431       * New unit tests
432       * Allow dumping pipelines as dot graphs
433       * GstStructures now support nesting
434       * URIHandler interface can now be implemented in bindings
435       * Many other bug-fixes and improvements
436
437 Bugs fixed since 0.10.14:
438
439       * 496722 : DSP/DSW files in win32/vs6 directory are in unix format
440       * 476514 : [queue] Doesn't forward EOS event in all cases
441       * 456573 : allow dumping pipelines as dot graphs
442       * 475723 : cleanup static caps correctly
443       * 480341 : Memory leak at fakesink (regression in cvs)
444       * 349410 : Problems with type handling
445       * 414539 : [API] Support more GST_TAG*_SORTNAME and remove MusicBrai...
446       * 459717 : [Controller] Add GstLFOControlSource that provides values...
447       * 459809 : [API] add GST_TAG_COMPOSER
448       * 461598 : Commit Hungarian translations from TP
449       * 461599 : Some files missing from POTFILES.in
450       * 464366 : program including gst/gstbuffer.h does not compile with -...
451       * 466595 : gst_index_add_association generates corrupted entries
452       * 469402 : File uri handling on windows broken
453       * 473846 : Deadlock if sink is unable to send first buffer
454       * 474371 : Can't build libsgtcontroller with VS6
455       * 474823 : tee unit test failure
456       * 478347 : GST_STATIC_PAD_TEMPLATE macro causes warnings with g++-4.2
457       * 478401 : gstbasesrc.c ref count bug
458       * 479784 : GST_PLUGIN_DEFINE() doesn't accept BSD and MIT/X11 licences
459       * 485343 : Implement a wait_eos function in basesink
460       * 487969 : allow nested GstStructures
461       * 492077 : Build issues on Windows/MSVC
462       * 493134 : Wrong GstObject signals registration
463       * 493983 : Build issues on Windows
464       * 494343 : pre-release vs6 patch
465       * 480858 : gstqueue code cleaning
466       * 486758 : queue element fails to re-negotiate caps upstream when si...
467       * 488201 : gst_segment_set_newsegment does not accumulate correctly
468       * 492729 : PAUSED- > PLAYING returns ASYNC when triggered from bus han...
469       * 494245 : [basesink] doesn't sync correctly if segment is in BYTES ...
470
471 API added since 0.10.14:
472
473       * gst_base_sink_get_last_buffer()
474       * GstBaseSink::last-buffer
475       * GstURIHandlerInterface::get_type_full
476       * GstURIHandlerInterface::get_protocols_full
477       * New tag: GST_TAG_ARTIST_SORTNAME
478       * New tag: GST_TAG_ALBUM_SORTNAME
479       * New tag: GST_TAG_TITLE_SORTNAME
480       * New tag: GST_TAG_COMPOSER
481       * gst_value_set_structure()
482       * gst_value_get_structure()
483       * GST_VALUE_HOLDS_STRUCTURE macro
484       * gst_bus_pop_filtered()
485       * gst_bus_timed_pop_filtered()
486       * gst_base_sink_wait_eos()
487       * gst_pad_peer_query()
488       * GstBaseSrc::do-timestamp
489       * gst_base_src_set_do_timestamp()
490       * gst_base_src_get_do_timestamp()
491       * GstBaseSink::ts-offset property
492       * gst_base_sink_set_ts_offset()
493       * gst_base_sink_get_ts_offset()
494       * GstBaseSink::async property
495       * gst_base_sink_set_async_enabled()
496       * gst_base_sink_is_async_enabled()
497       * gst_structure_get_uint()
498       * GstLFOControlSource and functions
499
500 Changes since 0.10.13:
501
502       * State change handling improvements
503       * New improved GstController API
504       * Multi-queue fixes and enhancements
505       * Fewer dynamic library relocations
506       * Various other fixes and improvements
507       * Parallel installability with 0.8.x series
508       * Threadsafe design and API
509
510 Bugs fixed since 0.10.13:
511
512       * 457322 : registry is read twice on startup
513       * 406632 : pkgconfigify the check for Check in configure.ac
514       * 423700 : [multiqueue] leaks memory when flushing
515       * 437457 : saving relocations for GstElementDetails
516       * 444648 : [API] add GstParamSpecFraction
517       * 444820 : build error with grammar.tab.c
518       * 448794 : state changes are racy with decodebin after rewrite for 0...
519       * 449197 : [capsfilter] Should set src pad caps on buffer
520       * 449226 : Incomplete ghostpads in xml session save
521       * 449493 : minor quoting fix in gst-feature.m4 macro
522       * 450711 : [GstController] Improve extensibility by providing a GstC...
523       * 451939 : [API] add GST_TAG_LICENSE_URI and GST_TAG_COPYRIGHT_URI
524       * 459501 : gst_registry_lookup_feature_locked is slow
525       * 462558 : Regression in async state change handling
526       * 462752 : make gst_element_class_set_details_simple args const
527       * 430682 : multiqueue doesn't output data on unlinked pads properly
528       * 462085 : registry feature hash can access invalid memory
529       * 357959 : buffer_alloc is not proxied through tee
530       * 374639 : GstTee doesn't handle pad list resyncs properly
531       * 449414 : [capsfilter] Copy of passed GstCaps taken instead of refe...
532       * 453732 : [PATCH] multiqueue returns wrong internally linked pads
533
534 API added since 0.10.13:
535
536       * Add GstParamSpecFraction, so elements can have fraction
537         properties without lots of painful string parsing (#444648).
538       * Add fail_unless_equals_float() and assert_equals_float()
539       * Add gst_type_register_static_full
540       * Add gst_element_class_set_details_simple
541       * Refactor GstController into the core controller which can take
542         a GstControlSource for providing actual values for timestamps.
543       * add GST_TAG_LICENSE_URI and GST_TAG_COPYRIGHT_URI (#451939)
544       * gst_element_factory_has_interface()
545
546 Changes since 0.10.12:
547
548       * Latency handling infrastructure for live playback scenarios
549       * State change handling changes
550       * GstController property handling improved
551       * Various bug fixes and improvements
552       * Parallel installability with 0.8.x series
553       * Threadsafe design and API
554
555 Bugs fixed since 0.10.12: 
556
557       * 440682 : gst/gstsystemclock unit test occasionally fails
558       * 342564 : Configure options causing compilation to fail
559       * 378255 : Swedish translation updated
560       * 392804 : [API] add GST_CORE_ERROR_DISABLED
561       * 412648 : [filesink] reports wrong (byte) position after seeking
562       * 413123 : No XML dependency patch
563       * 415394 : [identity] post message for imperfect streams if check-pe...
564       * 417992 : Quickly playing/pausing messes up synchronization
565       * 420106 : [basetransform] race on shutdown: setcaps func called aft...
566       * 420206 : Collectpads causes a segv. when stopping after a pad remove
567       * 421480 : Make it possible to build without libxml2 with --disable-...
568       * 421543 : [GstPad] Doesn't check if pad accepts caps after caps change
569       * 422295 : GstController crashes with quadratic and cubic interpolat...
570       * 425400 : Multiqueue leaks memory when releasing sink pads
571       * 431150 : compilation fails with flex 2.5.4
572       * 431940 : [API] add gst_buffer_try_new_and_alloc()
573       * 432876 : current time level in queue
574       * 434926 : Multilib conflicts with gst-launch-0.10 man page
575       * 435880 : [GstBin] Property to allow bins to handle child async cha...
576       * 437563 : URIs with upper-case protocol don't play
577       * 440463 : gstbin unit test sometimes hangs waiting for ASYNC_DONE m...
578       * 441159 : Regression in state change handling
579       * 349180 : gst_parse_launch is not reentrant (or recursively callable)
580       * 414986 : Don't start the async thread for the system clock until n...
581       * 393099 : GstBuffer copy vfunc broken?
582       * 419851 : pad-added and pad-removed signals parameter type incorrect
583       * 420133 : gst_element_sync_state_with_parent should look at pending...
584       * 421177 : Possible deadlock if pad eventfunc is not specified
585
586 API additions since 0.10.12:
587
588       * gst_element_change_state()
589       * GST_STATE_TARGET
590       * GST_BASE_TRANSFORM_LOCK/UNLOCK
591       * GstClock::gst_clock_unadjust_unlocked()
592       * fakesink::num-buffers property
593       * GST_CORE_ERROR_DISABLED
594       * basesrc::prepare_seek_segment vmethod
595       * gst_buffer_try_new_and_alloc()
596       * gst_buffer_copy_metadata()
597       * GstBufferCopyFlags enum
598       * GST_BUFFER_COPY_ALL flag
599       * gst_uri_protocol_is_supported()
600       * gst_base_src_query_latency()
601       * GstQueue::pushing
602       * gst_controller_suggest_next_sync()
603       * gst_object_suggest_next_sync()
604       * basesrc::unlock_stop
605       * basesink::unlock_stop
606       * GstBin::async-handling property
607       * gst_message_new_async_start()
608       * gst_message_parse_async_start()
609       * gst_message_new_async_done()
610       * GST_MESSAGE_ASYNC_START
611       * GST_MESSAGE_ASYNC_DONE
612
613 Changes since 0.10.11:
614
615       * Add a warning if GLib threading support is not properly initialised
616       * Add support for binary registry serialisation
617       * Preliminary support for pull-mode scheduling of entire chains
618       * Add support for HPPA 
619       * Collectpads fixes
620       * Lots of bug fixes
621
622 Bugs fixed since 0.10.11:
623      
624       * 378931 : Bison version check doesn't work on Solaris 9
625       * 399875 : [multiqueue] dynamic growth not implemented.
626       * 339326 : pads not set to FLUSHING when created
627       * 380129 : gst_plugin_feature_load doesn't consistently ref a return...
628       * 381301 : [patch] Make GstBus watch work with any GMainContext
629       * 383382 : Removing pads from collectpads not threadsafe
630       * 383506 : Disallow CLOCK_TIME_NONE as periodic clock id interval
631       * 387073 : gst-launch videotestsrc ! ffmpegcolorspace ! ximagesink d...
632       * 387866 : [docs] Small fix for GstCollectPads docs
633       * 391278 : g_thread_init() called too late, possibly causing memory ...
634       * 391296 : [API] add gst_update_registry() to rescan registry at run...
635       * 391777 : GStreamer does not reset SEGV trap handler
636       * 391909 : Fix compilation with MinGW
637       * 399094 : gst_pad_start_task: small doc typo
638       * 401381 : GstRegistry signals documentation is missing
639       * 401781 : [API] add GST_ROUND_DOWN_* macros
640       * 402393 : [API][GstCollectPads] Allow elements to specify destroy n...
641       * 405284 : Changing state of pipeline can lock up with preroll queue...
642       * 400656 : [PATCH] filesrc seekability detection fix (NFS and 2GB+ f...
643       * 403172 : [filesrc] doesn't handle localhost file locations
644       * 404569 : [filesrc] Unexpected end of file
645       * 161922 : script to provide plugin installation info
646       * 391915 : adapter test doesn't compile with mingw
647       * 395554 : gst_tag_setter_merge_tags works at most once
648       * 403597 : [API] Add ReplayGain reference level tag
649       * 405288 : Configure checks use pkg-config directly
650       * 381492 : [SystemClock] ClockID wait_async notification broken
651       * 382592 : Multiple wait()ers break periodic clock ids
652       * 385084 : endless ghost pad pull/push activate recursion until crash
653       * 388201 : [API] add gst_adapter_copy()
654
655 API additions since 0.10.11:
656
657       * gst_update_registry()
658       * gst_adapter_copy()
659       * GST_ROUND_DOWN_* macros
660       * GstCollectDataDestroyNotify
661       * gst_query_new_latency()
662       * gst_query_set_latency()
663       * gst_query_parse_latency()
664       * gst_message_new_lost_preroll()
665       * gst_message_parse_lost_preroll()
666       * gst_message_new_prerolled()
667       * gst_message_new_latency()
668       * gst_event_new_latency()
669       * gst_event_parse_latency()
670       * GST_TAG_REFERENCE_LEVEL
671       * gst_base_sink_query_latency()
672       * gst_base_sink_get_latency()
673       * gst_bus_timed_pop()
674       * gst_message_new_info()
675       * gst_message_parse_info()
676
677 Bugs fixed since 0.10.10:
678
679       * 363095 : [BaseTransform] Outputs empty buffers
680       * 353301 : aborts in _get_element_by_uri(), probably due to buggy el...
681       * 344639 : Separate threadsafe queuing functionnality in a separate ...
682       * 347785 : [multiqueue] New multiple input-output queue
683       * 352827 : re-negotiation issues with dynamic pipelines and level or...
684       * 357180 : [libs] gst_controller_new* functions don't increase refco...
685       * 318031 : gstreamer should use gmodule-no-export in its .pc file
686       * 340878 : Registry doesn't discard removed plugin features
687       * 345496 : No GstPadDirection in files created by GstXml
688       * 356910 : Basesrc gst_base_src_activate_push not calling base_src_s...
689       * 357593 : Generated gst-element-check.m4 installed from $(srcdir)
690       * 358436 : #include is missing in gstghostpad.c and gstquery.c
691       * 358999 : [PATCH] [GstPad] Flushing on blocked pads not handled cor...
692       * 359850 : Compiling issues on sparc with Forte
693       * 360151 : Fixes compiling with forte: disable warning as error for ...
694       * 360173 : Fixes compiling with forte: warning clean up (part 1)
695       * 360467 : [API] add gst_tag_list_is_empty ()
696       * 360860 : Fixes compiling with forte: warning clean up (part 2)
697       * 361675 : Allow applications to use libxml2 and GStreamer even if  ...
698       * 361720 : grammar project: error generating gstmarshal.c and gstmar...
699       * 361730 : wrong source file list in VC8 project
700       * 361732 : " win32\common\libgstreamer.def " lacks 'gst_caps_merge' entry
701       * 361769 : Deadlock in gstpad.c 
702       * 364388 : size variable is not always initialized in gst_base_src_s...
703       * 366321 : GST_SEGMENT_FORMAT not defined on windows
704       * 370865 : [basesrc] update segment duration in gst_base_src_update_...
705       * 371493 : Incomplete change of printf conversion specifiers in gstr...
706       * 374475 : [PATCH] minor doc typo
707       * 377332 : [PATCH] Warning with check > = 0.9.4
708       * 357617 : [libs] gst_controller_set_from_list can return without un...
709       * 358737 : _gst_event_copy sets the wrong parent_refcount on the chi...
710       * 366212 : Fix some misspellings in gstreamer core
711       * 369366 : MacOSX printf fixes for CVS
712       * 371894 : tests/examples/typefind is broken  
713       * 355499 : ensure_current_registry_forking()  fails if zombie alread...
714       * 352345 : Small race condition in the queue element
715       * 357432 : [libs] GstController needs to keep controlled objects alive
716       * 358613 : sink- > file is never reset for filesink elements, even tho...
717       * 366286 : [PATCH] fix compilation on Windows
718       * 366572 : Bad declaration in headerfile
719       * 367677 : [fdsrc] skips the first byte
720       * 369942 : [PATCH] unblocking blocked pad does not release all block...
721
722 API added since 0.10.10:
723
724       * gst_element_state_change_return_get_name
725       * gst_tag_list_is_empty
726       * gst_pad_is_blocking()
727       * GST_PAD_IS_BLOCKING() macro
728       * GST_PAD_BLOCKING GstPadFlag
729       * gst_base_src_wait_playing
730       * gst_base_sink_wait_preroll
731       * gst_message_new_buffering
732       * gst_message_parse_buffering
733
734 Bugs fixed since 0.10.9:
735      
736       * 349180 : gst_parse_launch is not reentrant (or recursively callable)
737       * 348455 : [filesrc] should not use mmap() by default, since it migh...
738       * 340674 : marry gst-debugs & plot-timeline.py
739       * 350449 : [GstBaseTransform] buffer_alloc should alway try downstream
740       * 352580 : implement proper caps merging
741       * 345444 : Linking to an audioconvert (pad-added callback) multiple ...
742       * 347293 : GstValueList comparison is flawed
743       * 347311 : element_unlink leaks its iterator wich will leak the src ...
744       * 348179 : gst_parse_lauch is not reentrant
745       * 348354 : failure in bison version detection breaks build
746       * 350419 : API: GST_SEGMENT_FORMAT printf extension for GstSegments
747       * 350879 : [init] Mark gstreamer as being initialized during registr...
748       * 350935 : API: add GST_TAG_EXTENDED_COMMENT
749       * 353976 : asssertion about element sanity in gst_registry_xml_write...
750       * 350432 : micro-optimising quarks
751       * 341029 : Ghostpads internal and target should be linked from the b...
752       * 345295 : [PATCH] gstreamer/libs/gst/net for Windows
753       * 347756 : Allow --disable-trace without --disable-parse
754       * 347794 : Do not reset SIGSEGV handler when --gst-disable-segtrap i...
755       * 348918 : application should decide whether or not to use fork() to...
756       * 349943 : [QOS] documentation/code mismatch
757       * 351768 : Unwanted concurent buffer modifications
758       * 352958 : pad_alloc_buffer and stream lock
759       * 353121 : gst_query_new_segment should initialize all structure fields
760       * 353122 : gst_element_get_bus refs the bus unconditionally
761       * 347385 : [ghostpad] gst_ghost_pad_new_from_template() method
762       * 348677 : Upgrade to 0.10.9 breaks existing applications (failed se...
763
764 API added since 0.10.9:
765      
766       * gst_segtrap_is_enabled
767       * gst_segtrap_set_enabled
768       * gst_registry_fork_is_enabled
769       * gst_registry_fork_set_enabled
770       * gst_ghost_pad_new_from_template
771       * gst_ghost_pad_new_no_target_from_template
772       * gst_caps_merge
773       * GST_TAG_EXTENDED_COMMENT
774       * GstClockCLass:wait_jitter
775       * GST_SEGMENT_FORMAT
776       * gst_structure_id_set
777       * gst_structure_id_set_valist
778
779 Changes since 0.10.8:
780
781       * The testsuite can now generate coverage information
782       * Better support for non-linear editing
783       * Removed Glib 2.6 compatibility
784       * Performance improvements on cpus that support branch hints
785       * Bug fixes
786
787 Bugs fixed since 0.10.8:
788
789       * 346730 : some warnings about enums and macros
790       * 341029 : Ghostpads internal and target should be linked from the b...
791       * 346192 : [PATCH] Pad blocking on events
792       * 347384 : [ghostpad] padtemplates shouldn't be set automatically
793       * 344115 : [patch] make more internal data const
794       * 324176 : gst-element-check-0.x.m4 should use versioned gst-inspect
795       * 330379 : Bogus commits to basesink, basetransform, collectpads
796       * 341667 : restore_from_xml breaks pad links again after creating them
797       * 344642 : tools/gst-inspect.c does not compile if --disable-nls is ...
798       * 344748 : Fails with non-writable registry
799       * 344849 : GstController doesn't handle float properties correct
800       * 345086 : [gst-feedback] calls un-versioned tools
801       * 346097 : SIGSEGV when using --gst-plugin-load
802       * 347337 : GDP does not correctly deserialize events without a struc...
803       * 347408 : basesrc causes regressions in pull with 0 bytes
804       * 345720 : Bad performance playing files off CD
805       * 331727 : make probes and Ghostpads more elegant
806       * 343196 : basetransform not handles ro/rw buffer flagging for trans...
807       * 346663 : Segmentation error with fakesrc, fakesink and a filter
808
809 Changes since 0.10.7:
810     
811       * Important fix for registry update causing applets not to load
812
813 Bugs fixed since 0.10.7:
814     
815       * 344474 : Gnome Mixer Applet doesn't want to load
816
817 Changes since 0.10.6:
818     
819       * Registry cache updating is now done in a fork, so no plugins are left
820         opened
821       * New version of data protocol now serializes events
822       * queue fixes
823       * win32 fixes
824
825 Bugs fixed since 0.10.6:
826     
827       * 338335 : [patch] memleak in gst-utils.c (leak pads from iterator)
828       * 343598 : undefined symbol in coreindexers when using --disable-loa...
829       * 336929 : GstCollectPads does not clear/reset segment info after fl...
830       * 337100 : [fakesink] add " preroll-handoff " signal
831       * 339918 : GstTagSetter merge-mode description unclear, and implemen...
832       * 340501 : [filesrc] give primary rank
833       * 341662 : gst-launch print_tags() fix
834       * 342238 : API: gst_element_seek_simple
835       * 342321 : GST_QUERY_POSITION fails if GstBaseSrc in get_range mode
836       * 342777 : rebuilding the registry leaves all plugins in memory
837       * 342820 : gstnetclientclock.c(453): servaddr used before set
838       * 343057 : gst-launch-0.10 segfaults when passed gst-plugin-path and...
839       * 343341 : [API] add GST_TAG_PREVIEW_IMAGE
840       * 343827 : leak in gst_index_gtype_resolver
841       * 343929 : Use of // in public header
842       * 343988 : data protocol needs extending to handle events better
843       * 341479 : Too many plugins loaded even for up-to-date registry
844       * 343334 : GstCollectPads testsuite and fixes
845       * 343538 : GstCollectPads doesn't reset EOS fields when stopped
846
847 API added since 0.10.6:
848
849       * gst_element_seek_simple()
850       * GST_FLOW_CUSTOM_SUCCESS
851       * GST_FLOW_CUSTOM_ERROR
852       * GST_FLOW_IS_SUCCESS
853       * gst_collect_pads_set_flushing()
854       * GST_TAG_PREVIEW_IMAGE
855       * gst_dp_crc()
856       * GstDPPacketizer
857       * GstDPVersion
858       * GstFakeSink::preroll-handoff
859       * GstFakeSink::use-mmap
860
861 Changes since 0.10.5:
862
863       * Fixes for the collectpads helper
864       * Support for proper time recording on server-trickmode streams
865         via the applied_rate parameter of the NewSegment event
866       * Many bug fixes
867
868 Bugs fixed since 0.10.5:
869
870       * 339808 : [patch] mem-leak of bin in gstbin.c
871       * 338339 : [patch] registry cache is always written
872       * 339843 : [patch] fdsink should not handle short writes and non fat...
873       * 340016 : does not build on opensolaris, must always include config...
874       * 340079 : gst-launch wrapper fails with 'No version of tool gst-lau...
875       * 340174 : locking problem in gstbasesink
876       * 340460 : gst-launch no longer supports --version
877       * 340508 : remove glib pre 2.8 hacks and compat stuff
878       * 340604 : gst_mini_object_ref () docs make no mention of writeability
879       * 340608 : leaking caps in padtemplate
880       * 340697 : gstsystemclock hangs when outputting to stdout via fdsink 
881       * 340721 : API: add GST_TAG_IMAGE
882       * 340772 : [qtdemux] bails out on Meet The Robinsons trailer
883       * 341556 : gst-launch: print image tags in a human readable form
884       * 339821 : [patch] serializing a GValue with a NULL buffer crashes
885
886 API added since 0.10.5:
887
888       * gst_adapter_take_buffer()
889       * GST_TAG_IMAGE tag added.
890       * gst_event_new_new_segment_full()
891       * gst_event_parse_new_segment_full()
892       * GstSegment::applied_rate field
893       * gst_segment_set_newsegment_full()
894
895 Changes since 0.10.4:
896
897       * QoS in BaseTransform
898       * gcc 4.1 fixes
899       * BaseTransform reworked
900       * Bus reworked; signal API added
901
902 Bugs fixed since 0.10.4:
903     
904       * 131079 : [PATCH] [api] loading a class leaves elementfactory blank
905       * 317048 : gstreamer Cygwin build fixes
906       * 325599 : Build fails with GCC 4.1
907       * 327315 : GStreamer CVS head files to build with GCC 4.1
908       * 331248 : [basesink] filesink spews warnings when used with flacenc
909       * 332151 : xml registry loader should use mmap() where possible
910       * 332390 : [GstQueue/GstPad] queue pauses immediately when linked, p...
911       * 332986 : Something wrong in caps checking...
912       * 334109 : pkg-config files must link with the same check library th...
913       * 334303 : Stale libgnomeui check in configure
914       * 334434 : Missing functions in def files for dlls
915       * 335195 : GST_BOILERPLATE_FULL etc isn' optimised
916       * 335480 : start with debugging disabled
917       * 335513 : totem goes (and stays) out of sync when running bittorrent
918       * 336336 : [queue] Queue might block in EOS
919       * 336945 : [filesink] throws error when writing 0 bytes
920       * 337103 : small cleanup in gstplugin.c
921       * 337386 : Pipeline bus is not initially flushing
922       * 338711 : Internal data flow error with latest updates for FC5 with...
923       * 326311 : basesink does not call the PAUSED- > PLAYING change_state f...
924       * 326998 : GstBaseSrc's send_event handler ignores seek requests aft...
925
926 API added since 0.10.4:
927
928       * gst_controller_unset_all()
929       * gst_pad_query_peer_position()
930       * gst_pad_query_peer_duration()
931       * gst_pad_query_peer_convert()
932       * GstBaseSink::async_play()
933       * GstBaseSrc::qos
934       * gst_base_sink_set_qos_enabled()
935       * gst_base_sink_is_qos_enabled()
936       * gst_base_transform_update_qos()
937       * gst_base_transform_set_qos_enabled()
938       * gst_base_transform_is_qos_enabled()
939       * gst_pipeline_get_delay()
940       * gst_pipeline_set_delay()
941
942 Changes since 0.10.3:
943     
944       * Parallel installability with 0.8.x series
945       * Threadsafe design and API
946       * 33% of library size removed by parse change
947       * (Experimental) QoS features (use max-lateness on BaseSink subclasses to enable)
948
949 Bugs fixed since 0.10.3:
950     
951       * 323542 : GStreamer 0.10 hangs at EOS for all songs
952       * 320340 : triggering a gst_task_join from the streaming task can de...
953       * 322628 : document thread-unsafety of gst_value_foo() + gst_value_r...
954       * 324186 : Smarter (deterministic!) typefind decisions
955       * 324398 : varargs/valist functions aren't bindable
956       * 328873 : only one gst_bin_recalc_state allowed at a time
957       * 330899 : CVS directory in make dist tarball
958       * 330906 : API: add GST_QUERY_TYPE_NAME and GST_MESSAGE_TYPE_NAME
959       * 330996 : basesrc emits EOS unconditionally when going to READY
960       * 331255 : Shrinking gst_parse_launch bloat
961       * 331898 : Basetranform is not reusable
962       * 332045 : API: GstPipeline needs API to disable  flushing of its bu...
963       * 332277 : [filesrc] seek does not correct read position in non-mmap...
964       * 332611 : [basesrc] needs way to prevent expensive start/stop in ch...
965       * 332723 : New API: gst_type_find_helper_for_buffer
966       * 333042 : New API: gst_type_find_helper_get_range
967       * 333266 : Registry file writing rewrite
968       * 333272 : tests should set G_SLICE=always-malloc now
969       * 333417 : GST_BOILERPLATE_WITH_INTERFACE can't be used in C++ code
970       * 333669 : Add pad accessor defines for GstBaseTransform
971       * 333779 : New API: add gst_uri_has_protocol
972       * 324818 : gst_registry_get_default doesn't sink newly created registry
973       * 330125 : _pad_send_event does not check flushing correctly
974       * 330684 : Add ability to emit sync-message without messing with the...
975  
976 API added since 0.10.3:
977     
978       * gst_pipeline_set_auto_flush_bus()
979       * gst_pipeline_get_auto_flush_bus()
980       * gst_uri_has_protocol()
981       * gst_pipeline_set_max_lateness()
982       * gst_pipeline_get_max_lateness()
983       * gst_pipeline_get_sync()
984       * gst_pipeline_do_sync()
985       * GST_BASE_TRANSFORM_SRC_PAD()
986       * GST_BASE_TRANSFORM_SINK_PAD()
987       * GstBaseSrc::check_get_range()
988       * GstBaseSink::max-lateness
989       * gst_type_find_helper_get_range()
990       * gst_type_find_helper_for_buffer()
991       * GST_MESSAGE_TYPE_NAME()
992       * GST_QUERY_TYPE_NAME()
993       * gst_bus_enable_sync_message_emission()
994       * gst_bus_disable_sync_message_emission()
995
996 Changes since 0.10.2:
997
998       * Documentation updates
999       * Bug fixes
1000       * Base class improvements
1001       * Extra utility API
1002       * More elements ported from 0.8
1003       * Fixes for win32 build.
1004
1005 Changes since 0.10.1:
1006     
1007       * documentation updates
1008       * bug fixes
1009
1010 Bugs fixed since 0.10.1:
1011     
1012       * 325429 : GST_BOILERPLATE_FULL can't be used when compiling with -W...
1013       * 316086 : MinGW compilation: fileindexer depends on mmap
1014
1015 Changes since 0.10.0:
1016     
1017       * element factory leak fixes
1018       * tests cleanup
1019       * BaseSrc seeking in other format than BYTES
1020       * collectpad fixes
1021
1022 Bugs fixed since 0.10.0:
1023     
1024       * 322441 : getcontext() in common/m4/gst-mcsc.m4 uses incorrect stac...
1025       * 323041 : [BASESRC] basesrc does not handle a seek to non-bytes for...
1026       * 323870 : [tools] gst-feedback needs updating for 0.9/0.10
1027       * 323882 : gst-launch manpage needs updates
1028       * 323905 : use return val of g_list_append
1029
1030 API added since 0.10.0:
1031      
1032       * GST_TYPE_STATIC_CAPS
1033       * GST_TYPE_STATIC_PAD_TEMPLATE
1034       * GstNetTimeProvider::active
1035       * gst_base_src_set_format
1036
1037 Changes from the 0.8 series to 0.10 series:
1038
1039       * Refcounting and API revised for thread safety, see rules in
1040         docs/design/part-MT-refcounting.txt
1041
1042       * Scheduling is now done by the elements, they start/stop
1043         processing threads themselves. This removes the need for 
1044         a separate scheduler.
1045
1046       * State changes now happen from sink to source. This makes sure
1047         that downstream elements are ready to process data when upstream
1048         starts producing.
1049
1050       * EOS/ERROR/... does not change the state of elements anymore. This
1051         means that when the application sets the state on an element, it
1052         remains in this state.
1053
1054       * GMainLoop integration. Information on the state of the pipeline
1055         is now received in the mainloop via the GstBus.
1056
1057       * Events move separate from the datastream, this allows for both
1058         in and out of sync delivery of events.
1059
1060       * Generic _pull() replaced by _pull_region() so that random access
1061         can be made faster.
1062
1063       * data passing happens from PAUSED, called the preroll phase. In this
1064         state no data is rendered but it is queued in the sinks.
1065
1066       * negotiation simplified. Caps are now attached to buffers and travel
1067         along with the datastream. 
1068
1069       * GstBuffer is now subclassable.
1070
1071       * Ghostpads now look and feel like real pads.
1072
1073       * New Seeking/flushing policy.
1074
1075       * Addition of base classes and helper functions in the core to abstract
1076         away the harder parts of plugin development.
1077
1078 Changes since 0.9.7:
1079
1080       * added Traditional Chinese translation
1081
1082 Bugs fixed since 0.9.7:
1083     
1084       * 322874 : [PAD] pad_alloc_buffer should not call set_caps
1085       * 323222 : GStreamer 0.9.7 still checks in dirs containing 0.9
1086       * 323250 : [collectpads] debug category should be called 'collectpad...
1087
1088 Changes since 0.9.6:
1089     
1090       * bumped major/minor to 0.10
1091       * API cleanup
1092       * PluginFeature and TypeFind leak fixes
1093       * cleaned up source tree
1094       * added plugin documentation for core elements
1095       * fixes for stripped core
1096
1097 Bugs fixed since 0.9.6:
1098     
1099       * 320529 : [API] gst_event_new_segment mentions " stream_time " as an ...
1100       * 321917 : quicktime with two video tracks and extra foo, makes tote...
1101       * 322257 : Fix gstnet library name
1102       * 322427 : gst-compprep aborts with 'double free or corruption'
1103       * 322429 : Filesink seeking problem
1104       * 322626 : Strings in gst-launch.c adn gstdebug.c are horrid
1105       * 322708 : gst_plugin_load_file leaks a reference to a GstPlugin
1106       * 322751 : gst_ghost_pad_get_target borks on pads without target
1107       * 322842 : GStreamer-CRITICAL in GstBaseSink and GstBaseTransform
1108
1109 Changes since 0.9.5:
1110     
1111       * API changes and clean-up
1112       * Extensive documentation updates
1113       * remove GLib 2.4 compatibility
1114       * added clock selection
1115       * added network clocking
1116       * added fd:// URI handler
1117       * added more fraction functionality
1118
1119 Bugs fixed since 0.9.5:
1120     
1121       * 143472 : [api] gst_tag_list_foreach() takes a non-const GstTagList*
1122       * 156633 : [API] don't use same API for arrays as for normal lists
1123       * 164168 : circular pipeline fails to negotiate
1124       * 165650 : [API] gst_value_deserialize doesn't work correctly for NU...
1125       * 168438 : [API] GstIndexFilter doesn't receive user_data
1126       * 168494 : [API] gst_index_add_object() does nothing
1127       * 305291 : Obnoxious bug-filing request
1128       * 311489 : Possible gstghostpad locking problems
1129       * 319178 : [API] finish filler events and support them in GstCollect...
1130       * 319388 : 0.9 API changes tracker
1131       * 319389 : state change updates obsolete some functions
1132       * 319392 : GstEventType is not bindings-friendly
1133       * 319395 : Macro name/visibility API bugs
1134       * 319940 : Use GLIB macros for GCC extensions
1135       * 320060 : add a CORE error category for missing ELEMENTS/PLUGINS
1136       * 320097 : GST_BUFFER_FLAG_ORIGINAL should die
1137       * 320113 : [API] duration message changes
1138       * 320299 : gst_pad_send_event should take stream lock for serialized...
1139       * 320324 : [API] GST_FOURCC_FORMAT should drop leading '%'
1140       * 320423 : [API] padding for GstCollectData
1141       * 320766 : [API] collect pads API changes
1142       * 321061 : GstURI not used
1143       * 321235 : [API] GST_PAD_IS_USABLE should be removed
1144       * 321386 : [SEGFAULT] basetransform when doing reverse caps negotiation
1145       * 321452 : GstPad's " template " property is b0rked
1146       * 321528 : capsfilter: assertion `caps != NULL' failed
1147       * 321595 : GstBin doesn't clean the message queue when changing stat...
1148       * 321638 : Don't use // style comments in headers
1149       * 321648 : Wrong type check in gst_message_parse_clock_lost
1150       * 321710 : GstClock resolution functions should take a GstClockTime
1151       * 321712 : GstClock adjust function changes
1152       * 321875 : gst_plugin_check_file disappeared
1153       * 321950 : gst_registry_scan_paths lacks implementation
1154       * 321962 : [easyfix] gst_value_is_fixed uses gst_value_list_* on GST...
1155       * 322027 : [API] Rename gst_caps_structure_fixate_* to gst_structure...
1156       * 322034 : Elements should be updated not to take the stream lock in...
1157       * 322069 : Names of GstTagSetter methods should be more descriptive
1158       * 322134 : API master/slave clocks
1159       * 322139 : our elements are confused about GEnumValue and which is t...
1160   
1161 Changes since 0.9.4:
1162     
1163       * gst_bus_poll and signal watch now see the same messages
1164       * clock sync in BaseSrc class
1165       * API documentation updates
1166       * Bus reworked; signal API added
1167
1168 Bugs fixed since 0.9.4:
1169     
1170       * 317341 : after linking ghost pads, one target pad does not have a ...
1171       * 320774 : basesrc commit broke typefinding
1172
1173 Changes since 0.9.3:
1174
1175       * state lock redefined
1176       * Extensive documentation updates
1177       * BaseTransform reworked
1178       * Bus reworked; signal API added
1179
1180 Bugs fixed since 0.9.3:
1181
1182       * 111146 : new GstThread fails on pipeline with errors
1183       * 169772 : [PATCH] GOption command-line parsing
1184       * 170777 : use GST_TYPE_DATE for GST_TAG_DATE
1185       * 315050 : [API] consider using GstClockTime instead of GTimeVal in ...
1186       * 315126 : filesrc + forced caps should be possible
1187       * 315383 : gst-launch shouldn't run broken pipelines
1188       * 317041 : GstObject flags should be made real flags
1189       * 318447 : gst_bin_iterate_sorted: Invalid call to gst_iterator_new
1190
1191 Changes since 0.9.2:
1192
1193       * gst-register has been removed
1194       * Extensive documentation updates
1195       * BaseTransform reworked
1196       * Bus reworked; signal API added
1197
1198 Bugs fixed since 0.9.2:
1199
1200       * 102980 : support incremental gst-register/compprep updates
1201       * 313897 : [0.9] registry rewrite
1202       * 314710 : gst_buffer_create_sub doesn't copy the GST_BUFFER_FLAGS
1203       * 315895 : gst_pad_query_convert src_val check
1204       * 316155 : MinGW compilation: glib-mkenums root path subtitution pro...
1205       * 316157 : MinGW compilation: Plugin exports
1206
1207 This is GStreamer 0.9.2, "South".
1208
1209 Bugs fixed since 0.9.1:
1210
1211       * 121015 : [api] gst_clock_entry_new() seems broken
1212       * 134227 : [api] gst_clock_id_wait_async, wrong return code for defa...
1213       * 142209 : [build] Large file support broken
1214       * 154785 : Clock does not run if audio stream lacks data for a short...
1215       * 305256 : [API] Change gst_element_seek to not mix enum/flags types
1216       * 309253 : GST_DEBUG_FUNCPTR macro does illegal casting from functio...
1217       * 311004 : ghostpad bugginess
1218       * 311009 : valgrind shows undesired messages
1219       * 311848 : Renegotiation broken
1220       * 314708 : filesrc doesn't set GST_BUFFER_FLAG_READONLY on mmaped bu...