Fix static initialization order fiasco in some plugins.
Some static variables were initialized using QMediaMetaData values, which are also statically initialized. Task-number: QTBUG-39202 Change-Id: Ibedc0a77d96cdfa575aad122c4ec654e6830e1f7 Reviewed-by: Andrew den Exter <andrew.den.exter@qinetic.com.au>
This commit is contained in:
committed by
The Qt Project
parent
8a66559e0b
commit
eadf1c8c41
@@ -46,80 +46,82 @@
|
||||
#include <gst/gst.h>
|
||||
#include <gst/gstversion.h>
|
||||
|
||||
struct QGstreamerMetaDataKeyLookup
|
||||
|
||||
typedef QMap<QString, QByteArray> QGstreamerMetaDataKeyLookup;
|
||||
Q_GLOBAL_STATIC(QGstreamerMetaDataKeyLookup, metadataKeys)
|
||||
|
||||
static const QGstreamerMetaDataKeyLookup *qt_gstreamerMetaDataKeys()
|
||||
{
|
||||
QString key;
|
||||
const char *token;
|
||||
};
|
||||
if (metadataKeys->isEmpty()) {
|
||||
metadataKeys->insert(QMediaMetaData::Title, GST_TAG_TITLE);
|
||||
metadataKeys->insert(QMediaMetaData::SubTitle, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::Author, 0);
|
||||
metadataKeys->insert(QMediaMetaData::Comment, GST_TAG_COMMENT);
|
||||
metadataKeys->insert(QMediaMetaData::Description, GST_TAG_DESCRIPTION);
|
||||
//metadataKeys->insert(QMediaMetaData::Category, 0);
|
||||
metadataKeys->insert(QMediaMetaData::Genre, GST_TAG_GENRE);
|
||||
//metadataKeys->insert(QMediaMetaData::Year, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::UserRating, 0);
|
||||
|
||||
static const QGstreamerMetaDataKeyLookup qt_gstreamerMetaDataKeys[] =
|
||||
{
|
||||
{ QMediaMetaData::Title, GST_TAG_TITLE },
|
||||
//{ QMediaMetaData::SubTitle, 0 },
|
||||
//{ QMediaMetaData::Author, 0 },
|
||||
{ QMediaMetaData::Comment, GST_TAG_COMMENT },
|
||||
{ QMediaMetaData::Description, GST_TAG_DESCRIPTION },
|
||||
//{ QMediaMetaData::Category, 0 },
|
||||
{ QMediaMetaData::Genre, GST_TAG_GENRE },
|
||||
//{ QMediaMetaData::Year, 0 },
|
||||
//{ QMediaMetaData::UserRating, 0 },
|
||||
metadataKeys->insert(QMediaMetaData::Language, GST_TAG_LANGUAGE_CODE);
|
||||
|
||||
{ QMediaMetaData::Language, GST_TAG_LANGUAGE_CODE },
|
||||
metadataKeys->insert(QMediaMetaData::Publisher, GST_TAG_ORGANIZATION);
|
||||
metadataKeys->insert(QMediaMetaData::Copyright, GST_TAG_COPYRIGHT);
|
||||
//metadataKeys->insert(QMediaMetaData::ParentalRating, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::RatingOrganisation, 0);
|
||||
|
||||
{ QMediaMetaData::Publisher, GST_TAG_ORGANIZATION },
|
||||
{ QMediaMetaData::Copyright, GST_TAG_COPYRIGHT },
|
||||
//{ QMediaMetaData::ParentalRating, 0 },
|
||||
//{ QMediaMetaData::RatingOrganisation, 0 },
|
||||
// Media
|
||||
//metadataKeys->insert(QMediaMetaData::Size, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::MediaType, 0);
|
||||
metadataKeys->insert(QMediaMetaData::Duration, GST_TAG_DURATION);
|
||||
|
||||
// Media
|
||||
//{ QMediaMetaData::Size, 0 },
|
||||
//{ QMediaMetaData::MediaType, 0 },
|
||||
{ QMediaMetaData::Duration, GST_TAG_DURATION },
|
||||
// Audio
|
||||
metadataKeys->insert(QMediaMetaData::AudioBitRate, GST_TAG_BITRATE);
|
||||
metadataKeys->insert(QMediaMetaData::AudioCodec, GST_TAG_AUDIO_CODEC);
|
||||
//metadataKeys->insert(QMediaMetaData::ChannelCount, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::SampleRate, 0);
|
||||
|
||||
// Audio
|
||||
{ QMediaMetaData::AudioBitRate, GST_TAG_BITRATE },
|
||||
{ QMediaMetaData::AudioCodec, GST_TAG_AUDIO_CODEC },
|
||||
//{ QMediaMetaData::ChannelCount, 0 },
|
||||
//{ QMediaMetaData::SampleRate, 0 },
|
||||
|
||||
// Music
|
||||
{ QMediaMetaData::AlbumTitle, GST_TAG_ALBUM },
|
||||
{ QMediaMetaData::AlbumArtist, GST_TAG_ARTIST},
|
||||
{ QMediaMetaData::ContributingArtist, GST_TAG_PERFORMER },
|
||||
// Music
|
||||
metadataKeys->insert(QMediaMetaData::AlbumTitle, GST_TAG_ALBUM);
|
||||
metadataKeys->insert(QMediaMetaData::AlbumArtist, GST_TAG_ARTIST);
|
||||
metadataKeys->insert(QMediaMetaData::ContributingArtist, GST_TAG_PERFORMER);
|
||||
#if (GST_VERSION_MAJOR >= 0) && (GST_VERSION_MINOR >= 10) && (GST_VERSION_MICRO >= 19)
|
||||
{ QMediaMetaData::Composer, GST_TAG_COMPOSER },
|
||||
metadataKeys->insert(QMediaMetaData::Composer, GST_TAG_COMPOSER);
|
||||
#endif
|
||||
//{ QMediaMetaData::Conductor, 0 },
|
||||
//{ QMediaMetaData::Lyrics, 0 },
|
||||
//{ QMediaMetaData::Mood, 0 },
|
||||
{ QMediaMetaData::TrackNumber, GST_TAG_TRACK_NUMBER },
|
||||
//metadataKeys->insert(QMediaMetaData::Conductor, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::Lyrics, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::Mood, 0);
|
||||
metadataKeys->insert(QMediaMetaData::TrackNumber, GST_TAG_TRACK_NUMBER);
|
||||
|
||||
//{ QMediaMetaData::CoverArtUrlSmall, 0 },
|
||||
//{ QMediaMetaData::CoverArtUrlLarge, 0 },
|
||||
//metadataKeys->insert(QMediaMetaData::CoverArtUrlSmall, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::CoverArtUrlLarge, 0);
|
||||
|
||||
// Image/Video
|
||||
//{ QMediaMetaData::Resolution, 0 },
|
||||
//{ QMediaMetaData::PixelAspectRatio, 0 },
|
||||
// Image/Video
|
||||
//metadataKeys->insert(QMediaMetaData::Resolution, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::PixelAspectRatio, 0);
|
||||
|
||||
// Video
|
||||
//{ QMediaMetaData::VideoFrameRate, 0 },
|
||||
//{ QMediaMetaData::VideoBitRate, 0 },
|
||||
{ QMediaMetaData::VideoCodec, GST_TAG_VIDEO_CODEC },
|
||||
// Video
|
||||
//metadataKeys->insert(QMediaMetaData::VideoFrameRate, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::VideoBitRate, 0);
|
||||
metadataKeys->insert(QMediaMetaData::VideoCodec, GST_TAG_VIDEO_CODEC);
|
||||
|
||||
//{ QMediaMetaData::PosterUrl, 0 },
|
||||
//metadataKeys->insert(QMediaMetaData::PosterUrl, 0);
|
||||
|
||||
// Movie
|
||||
//{ QMediaMetaData::ChapterNumber, 0 },
|
||||
//{ QMediaMetaData::Director, 0 },
|
||||
{ QMediaMetaData::LeadPerformer, GST_TAG_PERFORMER },
|
||||
//{ QMediaMetaData::Writer, 0 },
|
||||
// Movie
|
||||
//metadataKeys->insert(QMediaMetaData::ChapterNumber, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::Director, 0);
|
||||
metadataKeys->insert(QMediaMetaData::LeadPerformer, GST_TAG_PERFORMER);
|
||||
//metadataKeys->insert(QMediaMetaData::Writer, 0);
|
||||
|
||||
// Photos
|
||||
//{ QMediaMetaData::CameraManufacturer, 0 },
|
||||
//{ QMediaMetaData::CameraModel, 0 },
|
||||
//{ QMediaMetaData::Event, 0 },
|
||||
//{ QMediaMetaData::Subject, 0 }
|
||||
};
|
||||
// Photos
|
||||
//metadataKeys->insert(QMediaMetaData::CameraManufacturer, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::CameraModel, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::Event, 0);
|
||||
//metadataKeys->insert(QMediaMetaData::Subject, 0 }
|
||||
}
|
||||
|
||||
return metadataKeys;
|
||||
}
|
||||
|
||||
QGstreamerCaptureMetaDataControl::QGstreamerCaptureMetaDataControl(QObject *parent)
|
||||
:QMetaDataWriterControl(parent)
|
||||
@@ -128,50 +130,30 @@ QGstreamerCaptureMetaDataControl::QGstreamerCaptureMetaDataControl(QObject *pare
|
||||
|
||||
QVariant QGstreamerCaptureMetaDataControl::metaData(const QString &key) const
|
||||
{
|
||||
static const int count = sizeof(qt_gstreamerMetaDataKeys) / sizeof(QGstreamerMetaDataKeyLookup);
|
||||
QGstreamerMetaDataKeyLookup::const_iterator it = qt_gstreamerMetaDataKeys()->find(key);
|
||||
if (it != qt_gstreamerMetaDataKeys()->constEnd())
|
||||
return m_values.value(it.value());
|
||||
|
||||
for (int i = 0; i < count; ++i) {
|
||||
if (qt_gstreamerMetaDataKeys[i].key == key) {
|
||||
const char *name = qt_gstreamerMetaDataKeys[i].token;
|
||||
|
||||
return m_values.value(QByteArray::fromRawData(name, qstrlen(name)));
|
||||
}
|
||||
}
|
||||
return QVariant();
|
||||
}
|
||||
|
||||
void QGstreamerCaptureMetaDataControl::setMetaData(const QString &key, const QVariant &value)
|
||||
{
|
||||
static const int count = sizeof(qt_gstreamerMetaDataKeys) / sizeof(QGstreamerMetaDataKeyLookup);
|
||||
QGstreamerMetaDataKeyLookup::const_iterator it = qt_gstreamerMetaDataKeys()->find(key);
|
||||
if (it != qt_gstreamerMetaDataKeys()->constEnd()) {
|
||||
m_values.insert(it.value(), value);
|
||||
|
||||
for (int i = 0; i < count; ++i) {
|
||||
if (qt_gstreamerMetaDataKeys[i].key == key) {
|
||||
const char *name = qt_gstreamerMetaDataKeys[i].token;
|
||||
|
||||
m_values.insert(QByteArray::fromRawData(name, qstrlen(name)), value);
|
||||
|
||||
emit QMetaDataWriterControl::metaDataChanged();
|
||||
emit QMetaDataWriterControl::metaDataChanged(key, value);
|
||||
emit metaDataChanged(m_values);
|
||||
|
||||
return;
|
||||
}
|
||||
emit QMetaDataWriterControl::metaDataChanged();
|
||||
emit QMetaDataWriterControl::metaDataChanged(key, value);
|
||||
emit metaDataChanged(m_values);
|
||||
}
|
||||
}
|
||||
|
||||
QStringList QGstreamerCaptureMetaDataControl::availableMetaData() const
|
||||
{
|
||||
static QMap<QByteArray, QString> keysMap;
|
||||
if (keysMap.isEmpty()) {
|
||||
const int count = sizeof(qt_gstreamerMetaDataKeys) / sizeof(QGstreamerMetaDataKeyLookup);
|
||||
for (int i = 0; i < count; ++i) {
|
||||
keysMap[QByteArray(qt_gstreamerMetaDataKeys[i].token)] = qt_gstreamerMetaDataKeys[i].key;
|
||||
}
|
||||
}
|
||||
|
||||
QStringList res;
|
||||
foreach (const QByteArray &key, m_values.keys()) {
|
||||
QString tag = keysMap.value(key);
|
||||
QString tag = qt_gstreamerMetaDataKeys()->key(key);
|
||||
if (!tag.isEmpty())
|
||||
res.append(tag);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user