Tim-Philipp Müller [Tue, 29 Dec 2009 00:40:27 +0000 (00:40 +0000)]
examples: make seek example work with Gtk+ >= 2.18
Gtk+ broke API slightly with the introduction of
client-side windows in Gtk+ 2.18. Fix up seek
example to work with newer Gtk+ versions.
Fixes #601809.
Tim-Philipp Müller [Sat, 26 Dec 2009 23:29:24 +0000 (23:29 +0000)]
tests: fix warning and memory leak in stress-overlay test
Not all messages have structures and we need to unref messages
when returning GST_BUS_DROP in the sync bus handler.
Mark Nauwelaerts [Sat, 26 Dec 2009 17:46:50 +0000 (18:46 +0100)]
audiorate: correctly eat empty and dummy buffers
Wim Taymans [Thu, 24 Dec 2009 18:56:55 +0000 (19:56 +0100)]
adder: be a lot smarter with buffer management
Detect EOS faster.
Try to reuse one of the input buffer as the output buffer. This usually works
and avoids an allocation and a memcpy.
Be smarter with GAP buffers so that they don't get mixed or cleared at all. Also
try to use a GAP buffer as the output buffer when all input buffers are GAP
buffers.
Wim Taymans [Thu, 24 Dec 2009 15:30:23 +0000 (16:30 +0100)]
adder: use collectpads clipping function
Install a clipping function in the collectpads and use the audio clipping helper
function to perform clipping to the segment boundaries.
Fixes #590265
Wim Taymans [Thu, 24 Dec 2009 12:58:52 +0000 (13:58 +0100)]
adder: fix juvenile comment
Wim Taymans [Wed, 23 Dec 2009 20:24:48 +0000 (21:24 +0100)]
decodebin2: fix typo in debug message
Wim Taymans [Wed, 23 Dec 2009 17:18:03 +0000 (18:18 +0100)]
decodebin2: avoid some type checks
Wim Taymans [Wed, 23 Dec 2009 16:08:27 +0000 (17:08 +0100)]
playbin2: avoid leaking selector request pads
Wim Taymans [Wed, 23 Dec 2009 14:46:25 +0000 (15:46 +0100)]
uridecodebin: avoid leaking queue and typefind
Don't leak the queue and typefind elements that we might link after the
source element.
Jonathan Matthew [Wed, 23 Dec 2009 14:43:52 +0000 (15:43 +0100)]
uridecodebin: don't name the queue
There is no reason to name the queue.
Fixes #605219
Wim Taymans [Wed, 23 Dec 2009 14:30:50 +0000 (15:30 +0100)]
defs: update defs with new symbols
Wim Taymans [Tue, 22 Dec 2009 19:15:28 +0000 (20:15 +0100)]
rtcpbuffer: add helper functions for SDES types
Add functions to convert SDES names to their types and back. Will be used later
to set SDES items using a GstStructure.
See #595265
Mark Nauwelaerts [Mon, 21 Dec 2009 18:12:02 +0000 (19:12 +0100)]
Automatic update of common submodule
From 47cb23a to 14cec89
Mark Nauwelaerts [Mon, 21 Dec 2009 17:45:58 +0000 (18:45 +0100)]
audiorate: add Since marker for the new tolerance property
Tim-Philipp Müller [Mon, 21 Dec 2009 07:57:42 +0000 (07:57 +0000)]
docs: use 'Returns: xyz' rather than 'Returns xyz' to make gtk-doc happy
Tim-Philipp Müller [Mon, 21 Dec 2009 07:50:26 +0000 (07:50 +0000)]
tests: don't use deprecated GLib API g_mapped_file_free
Fixes #605100.
David Schleef [Mon, 21 Dec 2009 01:34:46 +0000 (17:34 -0800)]
theoraenc: Add encoder controls for libtheora 1.1
Added drop-frames, cap-overflow, cap-underflow, and rate-buffer.
Tim-Philipp Müller [Sat, 19 Dec 2009 21:40:44 +0000 (21:40 +0000)]
baseaudiosink: increase default drift tolerance to fix glitches with WMA
Increase default drift tolerance to 40ms to avoid glitches with decoders
or formats where there's a lot of timestamp jitter for some reason or
another (in this case: asf/wma), at least until we implement timestamp
smoothing.
Mark Nauwelaerts [Tue, 15 Dec 2009 17:41:38 +0000 (18:41 +0100)]
audiorate: add a tolerance property
It may not be uncommon for the input timestamps to experience some jitter
around the 'perfect time'. As such, instead of regularly adding and dropping
samples, optionally allow for some tolerance in a more relaxed approach.
API: GstAudioRate:tolerance
Mark Nauwelaerts [Tue, 15 Dec 2009 18:50:56 +0000 (19:50 +0100)]
audiorate: add documentation
Mark Nauwelaerts [Tue, 15 Dec 2009 15:52:44 +0000 (16:52 +0100)]
audiorate: use separate header file
Mark Nauwelaerts [Mon, 14 Dec 2009 20:17:57 +0000 (21:17 +0100)]
audiorate: set DISCONT when resyncing (e.g. newsegment)
Mark Nauwelaerts [Mon, 14 Dec 2009 17:47:27 +0000 (18:47 +0100)]
audiorate: also fill up segments if possible
Mark Nauwelaerts [Tue, 15 Dec 2009 18:29:29 +0000 (19:29 +0100)]
audiorate: fix segment handling
Do not compare a media (buffer) time to a (bogus) running time
(or their offset equivalents).
Mark Nauwelaerts [Tue, 15 Dec 2009 18:22:45 +0000 (19:22 +0100)]
audiorate: properly report truncated samples as dropped samples
Tim-Philipp Müller [Sun, 13 Dec 2009 18:43:56 +0000 (18:43 +0000)]
docs: mention that gst_tag_get_language_name() may return NULL
Tim-Philipp Müller [Sun, 13 Dec 2009 18:42:11 +0000 (18:42 +0000)]
checks: some more testing for the new language code functions
Tim-Philipp Müller [Sat, 12 Dec 2009 18:58:39 +0000 (18:58 +0000)]
docs: misc. mixer docs improvements
Tim-Philipp Müller [Sat, 12 Dec 2009 18:16:39 +0000 (18:16 +0000)]
docs: add short descriptions for API reference contents page
Tim-Philipp Müller [Sat, 12 Dec 2009 17:43:26 +0000 (17:43 +0000)]
tag: make internal language names table static
Tim-Philipp Müller [Sat, 12 Dec 2009 17:41:44 +0000 (17:41 +0000)]
tag: don't use GLib 2.22 API
g_mapped_file_unref() was introduced in GLib 2.22, but we depend
only on GLib 2.18, so use g_mapped_file_free() when compiling
against older GLib versions until we bump the GLib dependency.
Tim-Philipp Müller [Fri, 11 Dec 2009 23:59:54 +0000 (23:59 +0000)]
tag: add some utility functions for language codes and tags
Add some utility functions for language tags and ISO-639
codes. These are useful for both GUIs and elements. The
iso-codes package is used for language name translations
if available.
API: gst_tag_get_language_codes()
API: gst_tag_get_language_name()
API: gst_tag_get_language_code()
API: gst_tag_get_language_code_iso_639_1()
API: gst_tag_get_language_code_iso_639_2B()
API: gst_tag_get_language_code_iso_639_2T()
Wim Taymans [Fri, 11 Dec 2009 11:02:15 +0000 (12:02 +0100)]
ogg: ogm video has constant packet duration
David Schleef [Fri, 11 Dec 2009 06:47:53 +0000 (22:47 -0800)]
oggdemux: implement old fLaC mapping
Wim Taymans [Thu, 10 Dec 2009 16:53:01 +0000 (17:53 +0100)]
tcpclientsrc: unset flushing state too
When unlocking, we set the flushing state on the fdset. Implement unlock_stop so
that we can use it to unset the flushing state again.
Fixes #577326
Wim Taymans [Thu, 10 Dec 2009 15:09:09 +0000 (16:09 +0100)]
oggdemux: remove redundant fields
Wim Taymans [Wed, 9 Dec 2009 18:03:16 +0000 (19:03 +0100)]
vorbisdec: adapt to new oggdemux
Remove all granulepos hacks and simply use the timestamps from the new oggdemux
like any other decoder.
Wim Taymans [Wed, 9 Dec 2009 18:04:18 +0000 (19:04 +0100)]
vorbisdec: fix peer query
Wim Taymans [Wed, 9 Dec 2009 16:24:01 +0000 (17:24 +0100)]
theoradec: fix query
Wim Taymans [Wed, 9 Dec 2009 15:55:52 +0000 (16:55 +0100)]
theoradec: small cleanups
Wim Taymans [Wed, 9 Dec 2009 15:38:43 +0000 (16:38 +0100)]
vorbisdec: use gst_pad_peer_query()
Wim Taymans [Wed, 9 Dec 2009 11:10:35 +0000 (12:10 +0100)]
playsink: fix video when subtitles disabled
When we have a source with subtitles but they were disabled with the flags,
still ghostpad the video pad instead of leaving it unlinked.
Sebastian Dröge [Wed, 9 Dec 2009 08:47:30 +0000 (09:47 +0100)]
textoverlay: Only flush downstream on seeks for flushing seeks
Sebastian Dröge [Wed, 9 Dec 2009 08:35:14 +0000 (09:35 +0100)]
textoverlay: Proxy buffer allocation on the video sinkpad to the srcpad
Wim Taymans [Tue, 8 Dec 2009 16:30:39 +0000 (17:30 +0100)]
seek: update slider only 25 times a second
don't update the slider a 100 times a second, it's likely higher than the screen
framerate and just wastes cpu.
Wim Taymans [Tue, 8 Dec 2009 16:23:53 +0000 (17:23 +0100)]
theora: remove granulepos hacks
Remove the granulepos hacking now that oggdemux outputs timestamps like any
other demuxer.
Sebastian Dröge [Tue, 8 Dec 2009 12:40:18 +0000 (13:40 +0100)]
playbin2: Fix stream-changed message list iteration
When iterating the list and removing the current element, first
get the next element and then remove the current one and not
the other way around.
Wim Taymans [Mon, 7 Dec 2009 17:49:43 +0000 (18:49 +0100)]
oggdemux: improve keyframe seeking
Improve keyframe seeking.
Fix reverse playback.
Wim Taymans [Mon, 7 Dec 2009 14:42:05 +0000 (15:42 +0100)]
oggdemux: implement keyframe seeking
Implement keyframe seeking in oggdemux by doing the double seek trick. First
seek to the required position, then read pages for all streams to grab the
granulepos (to know the timing of the keyframe) of each stream, then seek back
to the first keyframe.
Sebastian Dröge [Mon, 7 Dec 2009 08:13:40 +0000 (09:13 +0100)]
playsink: Some minor cleanup
Sebastian Dröge [Sun, 6 Dec 2009 17:05:15 +0000 (18:05 +0100)]
playbin2: Reset stream segments on FLUSH_STOP and don't adjust QoS events for non-time segments
Wim Taymans [Fri, 4 Dec 2009 15:35:09 +0000 (16:35 +0100)]
oggdemux: fix timestamps after seek
After a seek, discard all packets before the packet with the granulepos on it so
that the output buffers contain valid timestamps.
Reorder some code so that we check the timestamps before allocating and pushing
an output buffer.
Do more checks on valid packets in ogm mode.
Wim Taymans [Fri, 4 Dec 2009 14:39:59 +0000 (15:39 +0100)]
oggdemux: add comment
Wim Taymans [Fri, 4 Dec 2009 13:01:11 +0000 (14:01 +0100)]
oggdemux: don't do math with invalid granulepos
When the current granulepos is unknown and set to -1, don't try to add durations
to it.
Wim Taymans [Fri, 4 Dec 2009 12:14:57 +0000 (13:14 +0100)]
oggdemux: guard against wrong granulepos
Clamp the initial granulepos to 0 instead of going negative for some badly muxed
ogg files.
Wim Taymans [Fri, 4 Dec 2009 11:26:47 +0000 (12:26 +0100)]
theoradec: don't fail on bogus granulepos
Do some additional checks on the granulpos timestamp before using it for
calculating the duration because oggdemux generates wrong granulepos now.
Fixes seeking somewhat again.
David Schleef [Fri, 4 Dec 2009 04:05:29 +0000 (20:05 -0800)]
oggdemux: reimplement OGM support
OGM demuxing no longer requires helper elements. It's done internally
in oggdemux. Vorbis comments are still not handled because I don't
have anything to test with.
David Schleef [Fri, 4 Dec 2009 01:02:11 +0000 (17:02 -0800)]
oggdemux: fix for I-frame-only theora
Tim-Philipp Müller [Thu, 3 Dec 2009 01:16:17 +0000 (01:16 +0000)]
ogg: log when ogg mapper doesn't accept the setup header packet
Tim-Philipp Müller [Wed, 2 Dec 2009 02:08:46 +0000 (02:08 +0000)]
ogg: extract width, height and PAR from theora header and add to caps
Tim-Philipp Müller [Thu, 3 Dec 2009 23:43:08 +0000 (23:43 +0000)]
ogg: extract number of channels from FLAC, speex and vorbis headers
Because we can.
Stefan Kost [Thu, 3 Dec 2009 20:14:34 +0000 (22:14 +0200)]
build: fix build with debug logging disabled.
Tim-Philipp Müller [Thu, 3 Dec 2009 21:07:49 +0000 (21:07 +0000)]
ogg: more print fixes
gstoggstream.c:419: error: format ‘%lld’ expects type ‘long long int’, but argument 8 has type ‘gint64’
gstoggdemux.c:2253: error: format ‘%lld’ expects type ‘long long int’, but argument 8 has type ‘GstClockTime’
gstoggdemux.c:2333: error: format ‘%lld’ expects type ‘long long int’, but argument 8 has type ‘GstClockTime’
Thiago Santos [Thu, 3 Dec 2009 19:57:48 +0000 (16:57 -0300)]
ogg: Fixing some printf format strings
Fixes some printf format strings to make it build on mac.
Stefan Kost [Thu, 3 Dec 2009 16:08:49 +0000 (18:08 +0200)]
playbin2: don't iterate the factory lists in non-debug mode
When debugging is disabled, we won't see anything printed anyway.
David Schleef [Thu, 3 Dec 2009 07:55:55 +0000 (23:55 -0800)]
Build fix for MSVC
Stefan Kost [Wed, 2 Dec 2009 21:27:55 +0000 (23:27 +0200)]
build: add missing includes for sprintf and atoi
Thiago Santos [Tue, 1 Dec 2009 19:42:42 +0000 (16:42 -0300)]
subparse: Add support for some tags of qttext
Currently supporting timescale, timestamps, font, size,
textColor, backColor, plain, bold and italic
Fixes #603357
Thiago Santos [Tue, 1 Dec 2009 16:13:24 +0000 (13:13 -0300)]
subparse: add qttext support
Adds basic support for qttext subtitles, still lacks markup tags
to make it prettier, but the plain text already works.
Implemented according to:
http://www.apple.com/quicktime/tutorials/texttracks.html
http://www.apple.com/quicktime/tutorials/textdescriptors.html
Fixes #603357
Thiago Santos [Tue, 1 Dec 2009 16:22:57 +0000 (13:22 -0300)]
subparse: conditionally cleanup sami context
Only cleanup sami context if we are parsing sami subtitles,
otherwise we might have crashes.
Thiago Santos [Tue, 1 Dec 2009 16:19:35 +0000 (13:19 -0300)]
subparse: Add missing caps to sink caps template
Some caps were missing from the sink caps template when
xml was disabled
Tim-Philipp Müller [Tue, 1 Dec 2009 15:06:10 +0000 (15:06 +0000)]
Automatic update of common submodule
From 87bf428 to 47cb23a
Sebastian Dröge [Tue, 1 Dec 2009 13:14:25 +0000 (14:14 +0100)]
Automatic update of common submodule
From da4c75c to 87bf428
Sebastian Dröge [Mon, 30 Nov 2009 09:22:15 +0000 (10:22 +0100)]
subtitleoverlay: Fix some pad refcount issues
Fixes bug #603345.
Edward Hervey [Fri, 27 Nov 2009 17:54:57 +0000 (18:54 +0100)]
Automatic update of common submodule
From 53a2485 to da4c75c
David Schleef [Thu, 26 Nov 2009 01:04:41 +0000 (17:04 -0800)]
oggdemux: handle theora streams with 0 keyoffset
David Schleef [Thu, 26 Nov 2009 00:53:26 +0000 (16:53 -0800)]
oggdemux: Handle unknown streams
Sebastian Dröge [Thu, 26 Nov 2009 13:30:33 +0000 (14:30 +0100)]
Revert "textoverlay: First draw outline text and then the real text"
This reverts commit
60aa09d28c1f9fd29b56876d7ac6c0366d6cef4d.
First drawing the real text and then the outline produces ugly
text in lower resolutions. The outline line width needs to be somehow
changed relative to the resolution. Fixes bug #602924.
Sebastian Dröge [Thu, 26 Nov 2009 09:30:25 +0000 (10:30 +0100)]
audiofilter: Use G_DEFINE_ABSTRACT_TYPE_WITH_CODE
...and fix code style a bit.
Sebastian Dröge [Thu, 26 Nov 2009 09:31:00 +0000 (10:31 +0100)]
audiofilter: Add _CAST variants of the cast macros
Wim Taymans [Wed, 25 Nov 2009 16:26:16 +0000 (10:26 -0600)]
audiosink: add adjustement when slaving
Our calibration against the pipeline clock is done with the adjusted
ringbuffer time, so take the adjustement into account. Fixes some audio dropouts
when reusing audio sinks after switching clocks and slaving methods in a
pipeline.
Sebastian Dröge [Wed, 25 Nov 2009 15:17:13 +0000 (16:17 +0100)]
ffmpegcolorspace: Prefer transforming alpha formats to alpha formats and the other way around
Fixes bug #602834 and #350748.
David Schleef [Wed, 25 Nov 2009 08:46:55 +0000 (00:46 -0800)]
oggdemux: Reset last_granule during seeking
Fix case where we would reconstruct the wrong granulepos for
outgoing streams immediately after a seek.
David Schleef [Wed, 25 Nov 2009 06:08:09 +0000 (22:08 -0800)]
oggdemux: Fix timestamp generation for theora
Timestamp generation was broken by the last commit for formats
with a non-zero granule shift. Also keep track of the last keyframe
so that we can regenerate granulepos for theora.
David Schleef [Wed, 25 Nov 2009 05:22:03 +0000 (21:22 -0800)]
oggdemux: Fix vorbis parsing
Add a granule to granulepos conversion function. Fix the duration
function for vorbis. Handle timestamps on header packets differently
and be more careful about calculating OFFSET and OFFSET_END. After
this change, timestamps for vorbis don't exactly match up with the
timestamps that vorbisparse outputs, but it's unclear if vorbisparse
is actually correct and it would add a lot more code to make oggdemux
match vorbisparse. Fixes #602790.
Sebastian Dröge [Thu, 19 Nov 2009 18:28:12 +0000 (19:28 +0100)]
playbin2: Transform QoS events to be meaningful for upstream elements
This is necessary because the sinks don't notice the group switches
and the decoders/demuxers have a different running time than the
sinks.
Fixes bug #537050.
David Schleef [Sat, 21 Nov 2009 21:05:34 +0000 (22:05 +0100)]
ogg: Fix generation of timestamps and durations
After changing some internal functions, I forgot to update
the code that puts the values on the buffers.
David Schleef [Sat, 29 Aug 2009 17:51:48 +0000 (10:51 -0700)]
ogg: Add ogg stream parsing
Adds code that parses headers of various formats encapsulated in
Ogg in order to calculate timestamps and durations of each buffer.
Removes the creation of helper decoder elements to do this calculation
via conversion queries.
Fixes: #344013, #568014.
David Schleef [Fri, 4 Sep 2009 07:11:38 +0000 (00:11 -0700)]
oggmux: don't overwrite object properties
Stefan Kost [Sat, 21 Nov 2009 15:54:49 +0000 (17:54 +0200)]
debug: also cast packet.packetno to gint64 in debug log
We do this already for granulepos to handle ogg_int64_t mismatches.
Stefan Kost [Sat, 21 Nov 2009 15:47:26 +0000 (17:47 +0200)]
debug: fix format string that was missing a var
Stefan Kost [Fri, 9 Oct 2009 21:32:04 +0000 (00:32 +0300)]
adder: make events succeed, if they succed on atleast one pad
Thiago Santos [Thu, 19 Nov 2009 17:51:33 +0000 (14:51 -0300)]
decodebin2: error when all streams have no buffers
In some cases (all buffers dropped by a parser) a decodebin2
chain might receive an EOS before it gets enough data to
expose a decoded pad. In the case that no streams can expose
a pad we should error out instead of hang.
Fixes #542758
Sebastian Dröge [Thu, 19 Nov 2009 11:23:08 +0000 (12:23 +0100)]
playbin2: Fix stupid bug introduced in last commit
Sebastian Dröge [Thu, 19 Nov 2009 11:10:58 +0000 (12:10 +0100)]
playbin2: Aggregate the stream-changed message by looking at the seqnum
Just counting how many messages were sent and how many were received
is not good enough because they might've been duplicated (e.g. by the
visualization audio tee). Comparing the sequence numbers should give
better results in that case.
Sebastian Dröge [Thu, 19 Nov 2009 09:05:28 +0000 (10:05 +0100)]
playbin2: Ignore async state changes of the uridecodebins
Otherwise the async state change from READY->PAUSED of the
uridecodebins will take playbin2 from PLAYING->PAUSED again
during gapless group switches.
Fixes bug #602000.
Tim-Philipp Müller [Thu, 19 Nov 2009 10:30:06 +0000 (10:30 +0000)]
Automatic update of common submodule
From 0702fe1 to 53a2485
Thiago Santos [Wed, 18 Nov 2009 17:50:28 +0000 (14:50 -0300)]
decodebin2: set to buffer less on no-more-pads
When a decodebin2 receives no-more-pads of a group it
can set that group's multiqueue buffering thresholds to
'playing' buffering method, avoiding that it buffers
too long and cause problems when using with queue2.
See the associated bug for details.
Fixes #600787
Wim Taymans [Wed, 18 Nov 2009 16:09:28 +0000 (17:09 +0100)]
baseaudiosink: fix initial calibration
When we are calibrating the internal clock against the external clock take into
account the time offset applied to our internal clock because we will subtract
that in the render_function again.