blob: f64a00dfb35ba435cec22c678f51e23c97d7c26c [file] [log] [blame]
/*
* Copyright (C) 2013 Cable Television Laboratories, Inc.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "config.h"
#if ENABLE(VIDEO) && USE(GSTREAMER)
#include "AudioTrackPrivateGStreamer.h"
#include "MediaPlayerPrivateGStreamer.h"
#include <gst/pbutils/pbutils.h>
namespace WebCore {
AudioTrackPrivateGStreamer::AudioTrackPrivateGStreamer(WeakPtr<MediaPlayerPrivateGStreamer> player, unsigned index, GRefPtr<GstPad>&& pad, bool shouldHandleStreamStartEvent)
: TrackPrivateBaseGStreamer(TrackPrivateBaseGStreamer::TrackType::Audio, this, index, WTFMove(pad), shouldHandleStreamStartEvent)
, m_player(player)
{
}
AudioTrackPrivateGStreamer::AudioTrackPrivateGStreamer(WeakPtr<MediaPlayerPrivateGStreamer> player, unsigned index, GstStream* stream)
: TrackPrivateBaseGStreamer(TrackPrivateBaseGStreamer::TrackType::Audio, this, index, stream)
, m_player(player)
{
int kind;
auto tags = adoptGRef(gst_stream_get_tags(m_stream));
if (tags && gst_tag_list_get_int(tags.get(), "webkit-media-stream-kind", &kind) && kind == static_cast<int>(AudioTrackPrivate::Kind::Main)) {
auto streamFlags = gst_stream_get_stream_flags(m_stream);
gst_stream_set_stream_flags(m_stream, static_cast<GstStreamFlags>(streamFlags | GST_STREAM_FLAG_SELECT));
}
g_signal_connect_swapped(m_stream, "notify::caps", G_CALLBACK(+[](AudioTrackPrivateGStreamer* track) {
track->m_taskQueue.enqueueTask([track]() {
track->updateConfigurationFromCaps();
});
}), this);
g_signal_connect_swapped(m_stream, "notify::tags", G_CALLBACK(+[](AudioTrackPrivateGStreamer* track) {
track->m_taskQueue.enqueueTask([track]() {
track->updateConfigurationFromTags();
});
}), this);
updateConfigurationFromCaps();
updateConfigurationFromTags();
}
void AudioTrackPrivateGStreamer::updateConfigurationFromTags()
{
ASSERT(isMainThread());
auto tags = adoptGRef(gst_stream_get_tags(m_stream));
unsigned bitrate;
if (!tags || !gst_tag_list_get_uint(tags.get(), GST_TAG_BITRATE, &bitrate))
return;
auto configuration = this->configuration();
configuration.bitrate = bitrate;
setConfiguration(WTFMove(configuration));
}
void AudioTrackPrivateGStreamer::updateConfigurationFromCaps()
{
ASSERT(isMainThread());
auto caps = adoptGRef(gst_stream_get_caps(m_stream));
if (!caps || !gst_caps_is_fixed(caps.get()))
return;
auto configuration = this->configuration();
GstAudioInfo info;
if (gst_audio_info_from_caps(&info, caps.get())) {
configuration.sampleRate = GST_AUDIO_INFO_RATE(&info);
configuration.numberOfChannels = GST_AUDIO_INFO_CHANNELS(&info);
}
#if GST_CHECK_VERSION(1, 20, 0)
GUniquePtr<char> codec(gst_codec_utils_caps_get_mime_codec(caps.get()));
configuration.codec = String::fromLatin1(codec.get());
#endif
setConfiguration(WTFMove(configuration));
}
AudioTrackPrivate::Kind AudioTrackPrivateGStreamer::kind() const
{
if (m_stream && gst_stream_get_stream_flags(m_stream) & GST_STREAM_FLAG_SELECT)
return AudioTrackPrivate::Kind::Main;
return AudioTrackPrivate::kind();
}
void AudioTrackPrivateGStreamer::disconnect()
{
m_taskQueue.startAborting();
if (m_stream)
g_signal_handlers_disconnect_matched(m_stream, G_SIGNAL_MATCH_DATA, 0, 0, nullptr, nullptr, this);
m_player = nullptr;
TrackPrivateBaseGStreamer::disconnect();
m_taskQueue.finishAborting();
}
void AudioTrackPrivateGStreamer::setEnabled(bool enabled)
{
if (enabled == this->enabled())
return;
AudioTrackPrivate::setEnabled(enabled);
if (m_player)
m_player->updateEnabledAudioTrack();
}
} // namespace WebCore
#endif // ENABLE(VIDEO) && USE(GSTREAMER)