Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
qimagereaderwriterhelpers.cpp
Go to the documentation of this file.
1// Copyright (C) 2018 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
4#include "private/qimagereaderwriterhelpers_p.h"
5
6#include <qcborarray.h>
7#include <qmutex.h>
8#include <private/qfactoryloader_p.h>
9
11
12using namespace Qt::StringLiterals;
13
15
16#ifndef QT_NO_IMAGEFORMATPLUGIN
17
19 (QImageIOHandlerFactoryInterface_iid, "/imageformats"_L1))
20Q_GLOBAL_STATIC(QMutex, irhLoaderMutex)
21
22static void appendImagePluginFormats(QFactoryLoader *loader,
24 QList<QByteArray> *result)
25{
26 typedef QMultiMap<int, QString> PluginKeyMap;
27 typedef PluginKeyMap::const_iterator PluginKeyMapConstIterator;
28
29 const PluginKeyMap keyMap = loader->keyMap();
31 int i = -1;
33 result->reserve(result->size() + keyMap.size());
34 for (PluginKeyMapConstIterator it = keyMap.constBegin(); it != cend; ++it) {
35 if (it.key() != i) {
36 i = it.key();
37 plugin = qobject_cast<QImageIOPlugin *>(loader->instance(i));
38 }
39 const QByteArray key = it.value().toLatin1();
40 if (plugin && (plugin->capabilities(nullptr, key) & cap) != 0)
41 result->append(key);
42 }
43}
44
47 QList<QByteArray> *result,
48 QList<QByteArray> *resultKeys = nullptr)
49{
50 QList<QPluginParsedMetaData> metaDataList = loader->metaData();
51 const int pluginCount = metaDataList.size();
52 for (int i = 0; i < pluginCount; ++i) {
53 const QCborMap metaData = metaDataList.at(i).value(QtPluginMetaDataKeys::MetaData).toMap();
54 const QCborArray keys = metaData.value("Keys"_L1).toArray();
55 const QCborArray mimeTypes = metaData.value("MimeTypes"_L1).toArray();
56 QImageIOPlugin *plugin = qobject_cast<QImageIOPlugin *>(loader->instance(i));
57 const int keyCount = keys.size();
58 for (int k = 0; k < keyCount; ++k) {
59 const QByteArray key = keys.at(k).toString().toLatin1();
60 if (plugin && (plugin->capabilities(nullptr, key) & cap) != 0) {
61 result->append(mimeTypes.at(k).toString().toLatin1());
62 if (resultKeys)
63 resultKeys->append(key);
64 }
65 }
66 }
67}
68
69QSharedPointer<QFactoryLoader> pluginLoader()
70{
71 irhLoaderMutex()->lock();
72 return QSharedPointer<QFactoryLoader>(irhLoader(), [](QFactoryLoader *) {
73 irhLoaderMutex()->unlock();
74 });
75}
76
81
82#endif // QT_NO_IMAGEFORMATPLUGIN
83
85{
86 QList<QByteArray> formats;
87 formats.reserve(_qt_NumFormats);
88 for (int i = 0; i < _qt_NumFormats; ++i)
90
91#ifndef QT_NO_IMAGEFORMATPLUGIN
92 appendImagePluginFormats(irhLoader(), pluginCapability(cap), &formats);
93#endif // QT_NO_IMAGEFORMATPLUGIN
94
95 std::sort(formats.begin(), formats.end());
96 formats.erase(std::unique(formats.begin(), formats.end()), formats.end());
97 return formats;
98}
99
100static constexpr QByteArrayView imagePrefix() noexcept { return "image/"; }
101
103{
104 QList<QByteArray> mimeTypes;
105 mimeTypes.reserve(_qt_NumFormats);
106 for (const auto &fmt : _qt_BuiltInFormats)
107 mimeTypes.emplace_back(imagePrefix() + fmt.mimeType);
108
109#ifndef QT_NO_IMAGEFORMATPLUGIN
110 appendImagePluginMimeTypes(irhLoader(), pluginCapability(cap), &mimeTypes);
111#endif // QT_NO_IMAGEFORMATPLUGIN
112
113 std::sort(mimeTypes.begin(), mimeTypes.end());
114 mimeTypes.erase(std::unique(mimeTypes.begin(), mimeTypes.end()), mimeTypes.end());
115 return mimeTypes;
116}
117
119{
120 QList<QByteArray> formats;
121 if (mimeType.startsWith(imagePrefix())) {
123 for (const auto &fmt : _qt_BuiltInFormats) {
124 if (fmt.mimeType == type && !formats.contains(fmt.extension))
125 formats << fmt.extension;
126 }
127 }
128
129#ifndef QT_NO_IMAGEFORMATPLUGIN
130 QList<QByteArray> mimeTypes;
131 QList<QByteArray> keys;
132 appendImagePluginMimeTypes(irhLoader(), pluginCapability(cap), &mimeTypes, &keys);
133 for (int i = 0; i < mimeTypes.size(); ++i) {
134 if (mimeTypes.at(i) == mimeType) {
135 const auto &key = keys.at(i);
136 if (!formats.contains(key))
137 formats << key;
138 }
139 }
140#endif // QT_NO_IMAGEFORMATPLUGIN
141
142 return formats;
143}
144
145} // QImageReaderWriterHelpers
146
\inmodule QtCore
Definition qbytearray.h:57
\inmodule QtCore\reentrant
Definition qcborarray.h:20
QCborValue at(qsizetype i) const
Returns the QCborValue element at position i in the array.
\inmodule QtCore\reentrant
Definition qcbormap.h:21
QCborValue value(qint64 key) const
Returns the QCborValue element in this map that corresponds to key key, if there is one.
Definition qcbormap.h:248
QString toString(const QString &defaultValue={}) const
Returns the string value stored in this QCborValue, if it is of the string type.
QCborArray toArray() const
QCborMap toMap() const
QMultiMap< int, QString > keyMap() const
MetaDataList metaData() const
QObject * instance(int index) const
\inmodule QtGui
Capability
This enum describes the capabilities of a QImageIOPlugin.
virtual Capabilities capabilities(QIODevice *device, const QByteArray &format) const =0
Returns the capabilities of the plugin, based on the data in device and the format format.
\inmodule QtCore
Definition qmutex.h:281
QByteArray toLatin1() const &
Definition qstring.h:630
void extension()
[6]
Definition dialogs.cpp:230
QSet< QString >::iterator it
EGLint EGLint * formats
PluginKeyMap::const_iterator PluginKeyMapConstIterator
static QImageIOPlugin::Capability pluginCapability(Capability cap)
QList< QByteArray > imageFormatsForMimeType(QByteArrayView mimeType, Capability cap)
static void appendImagePluginMimeTypes(QFactoryLoader *loader, QImageIOPlugin::Capability cap, QList< QByteArray > *result, QList< QByteArray > *resultKeys=nullptr)
static constexpr QByteArrayView imagePrefix() noexcept
QSharedPointer< QFactoryLoader > pluginLoader()
QList< QByteArray > supportedImageFormats(Capability cap)
const PluginKeyMapConstIterator cend
static const _qt_BuiltInFormatStruct _qt_BuiltInFormats[]
QList< QByteArray > supportedMimeTypes(Capability cap)
Combined button and popup list for selecting options.
const char * mimeType
#define Q_GLOBAL_STATIC_WITH_ARGS(TYPE, NAME, ARGS)
#define Q_GLOBAL_STATIC(TYPE, NAME,...)
#define QImageIOHandlerFactoryInterface_iid
GLuint64 key
GLenum GLuint GLintptr GLsizeiptr size
[1]
GLenum type
GLuint64EXT * result
[6]
GLenum cap
QVideoFrameFormat::PixelFormat fmt
QStringList keys