/*! Returns the list of MIBs for all available codecs. Call QTextCodec::codecForMib() to obtain the QTextCodec for the MIB. \sa availableCodecs(), mibEnum() */ QList<int> QTextCodec::availableMibs() { QMutexLocker locker(textCodecsMutex()); setup(); QList<int> codecs; if (!validCodecs()) return codecs; for (int i = 0; i < all->size(); ++i) codecs += all->at(i)->mibEnum(); locker.unlock(); #if ! defined(QT_NO_TEXTCODECPLUGIN) QFactoryLoader *l = loader(); QStringList keys = l->keys(); for (int i = 0; i < keys.size(); ++i) { if (keys.at(i).startsWith(QLatin1String("MIB: "))) { int mib = keys.at(i).mid(5).toInt(); if (!codecs.contains(mib)) codecs += mib; } } #endif return codecs; }
/*! Returns the list of image formats supported by QImageWriter. By default, Qt can write the following formats: \table \header \o Format \o Description \row \o BMP \o Windows Bitmap \row \o JPG \o Joint Photographic Experts Group \row \o JPEG \o Joint Photographic Experts Group \row \o PNG \o Portable Network Graphics \row \o PPM \o Portable Pixmap \row \o TIFF \o Tagged Image File Format \row \o XBM \o X11 Bitmap \row \o XPM \o X11 Pixmap \endtable \sa setFormat(), QImageReader::supportedImageFormats(), QImageIOPlugin */ QList<QByteArray> QImageWriter::supportedImageFormats() { QSet<QByteArray> formats; formats << "bmp"; #ifndef QT_NO_IMAGEFORMAT_PPM formats << "ppm"; #endif #ifndef QT_NO_IMAGEFORMAT_XBM formats << "xbm"; #endif #ifndef QT_NO_IMAGEFORMAT_XPM formats << "xpm"; #endif #ifndef QT_NO_IMAGEFORMAT_PNG formats << "png"; #endif #ifndef QT_NO_LIBRARY QFactoryLoader *l = loader(); QStringList keys = l->keys(); for (int i = 0; i < keys.count(); ++i) { QImageIOPlugin *plugin = qobject_cast<QImageIOPlugin *>(l->instance(keys.at(i))); if (plugin && (plugin->capabilities(0, keys.at(i).toLatin1()) & QImageIOPlugin::CanWrite) != 0) formats << keys.at(i).toLatin1(); } #endif // QT_NO_LIBRARY QList<QByteArray> sortedFormats; for (QSet<QByteArray>::ConstIterator it = formats.constBegin(); it != formats.constEnd(); ++it) sortedFormats << *it; qSort(sortedFormats); return sortedFormats; }
/*! Returns the list of all available codecs, by name. Call QTextCodec::codecForName() to obtain the QTextCodec for the name. The list may contain many mentions of the same codec if the codec has aliases. \sa availableMibs(), name(), aliases() */ QList<QByteArray> QTextCodec::availableCodecs() { QMutexLocker locker(textCodecsMutex()); setup(); QList<QByteArray> codecs; if (!validCodecs()) return codecs; for (int i = 0; i < all->size(); ++i) { codecs += all->at(i)->name(); codecs += all->at(i)->aliases(); } locker.unlock(); #if ! defined(QT_NO_TEXTCODECPLUGIN) QFactoryLoader *l = loader(); QStringList keys = l->keys(); for (int i = 0; i < keys.size(); ++i) { if (!keys.at(i).startsWith(QLatin1String("MIB: "))) { QByteArray name = keys.at(i).toLatin1(); if (!codecs.contains(name)) codecs += name; } } #endif return codecs; }
static QTextCodec *createForName(const QByteArray &name) { #ifndef QT_NO_TEXTCODECPLUGIN QFactoryLoader *l = loader(); QStringList keys = l->keys(); for (int i = 0; i < keys.size(); ++i) { if (nameMatch(name, keys.at(i).toLatin1())) { QString realName = keys.at(i); if (QTextCodecFactoryInterface *factory = qobject_cast<QTextCodecFactoryInterface*>(l->instance(realName))) { return factory->create(realName); } } } #else Q_UNUSED(name); #endif return 0; }
/*! Returns the list of MIBs for all available codecs. Call QTextCodec::codecForMib() to obtain the QTextCodec for the MIB. \sa availableCodecs(), mibEnum() */ QList<int> QTextCodec::availableMibs() { setup(); QList<int> codecs; for (int i = 0; i < all->size(); ++i) codecs += all->at(i)->mibEnum(); #ifndef QT_NO_TEXTCODECPLUGIN QFactoryLoader *l = loader(); QStringList keys = l->keys(); for (int i = 0; i < keys.size(); ++i) { if (keys.at(i).startsWith(QLatin1String("MIB: "))) { int mib = keys.at(i).mid(5).toInt(); if (!codecs.contains(mib)) codecs += mib; } } #endif return codecs; }
/*! Returns the list of all available codecs, by name. Call QTextCodec::codecForName() to obtain the QTextCodec for the name. The list may contain many mentions of the same codec if the codec has aliases. \sa availableMibs(), name(), aliases() */ QList<QByteArray> QTextCodec::availableCodecs() { setup(); QList<QByteArray> codecs; for (int i = 0; i < all->size(); ++i) { codecs += all->at(i)->name(); codecs += all->at(i)->aliases(); } #ifndef QT_NO_TEXTCODECPLUGIN QFactoryLoader *l = loader(); QStringList keys = l->keys(); for (int i = 0; i < keys.size(); ++i) { if (!keys.at(i).startsWith(QLatin1String("MIB: "))) { QByteArray name = keys.at(i).toLatin1(); if (!codecs.contains(name)) codecs += name; } } #endif return codecs; }
static QImageIOHandler *createWriteHandler(QIODevice *device, const QByteArray &format) { QByteArray form = format.toLower(); QByteArray suffix; QImageIOHandler *handler = 0; #ifndef QT_NO_LIBRARY // check if any plugins can write the image QFactoryLoader *l = loader(); QStringList keys = l->keys(); int suffixPluginIndex = -1; #endif if (device && format.isEmpty()) { // if there's no format, see if \a device is a file, and if so, find // the file suffix and find support for that format among our plugins. // this allows plugins to override our built-in handlers. if (QFile *file = qobject_cast<QFile *>(device)) { if (!(suffix = QFileInfo(file->fileName()).suffix().toLower().toLatin1()).isEmpty()) { #ifndef QT_NO_LIBRARY int index = keys.indexOf(QString::fromLatin1(suffix)); if (index != -1) suffixPluginIndex = index; #endif } } } QByteArray testFormat = !form.isEmpty() ? form : suffix; #ifndef QT_NO_LIBRARY if (suffixPluginIndex != -1) { // when format is missing, check if we can find a plugin for the // suffix. QImageIOPlugin *plugin = qobject_cast<QImageIOPlugin *>(l->instance(QString::fromLatin1(suffix))); if (plugin && (plugin->capabilities(device, suffix) & QImageIOPlugin::CanWrite)) handler = plugin->create(device, suffix); } #endif // Q_NO_LIBRARY // check if any built-in handlers can write the image if (!handler && !testFormat.isEmpty()) { if (false) { #ifndef QT_NO_IMAGEFORMAT_PNG } else if (testFormat == "png") { handler = new QPngHandler; #endif #ifndef QT_NO_IMAGEFORMAT_BMP } else if (testFormat == "bmp") { handler = new QBmpHandler; #endif #ifndef QT_NO_IMAGEFORMAT_XPM } else if (testFormat == "xpm") { handler = new QXpmHandler; #endif #ifndef QT_NO_IMAGEFORMAT_XBM } else if (testFormat == "xbm") { handler = new QXbmHandler; handler->setOption(QImageIOHandler::SubType, testFormat); #endif #ifndef QT_NO_IMAGEFORMAT_PPM } else if (testFormat == "pbm" || testFormat == "pbmraw" || testFormat == "pgm" || testFormat == "pgmraw" || testFormat == "ppm" || testFormat == "ppmraw") { handler = new QPpmHandler; handler->setOption(QImageIOHandler::SubType, testFormat); #endif } } #ifndef QT_NO_LIBRARY if (!testFormat.isEmpty()) { for (int i = 0; i < keys.size(); ++i) { QImageIOPlugin *plugin = qobject_cast<QImageIOPlugin *>(l->instance(keys.at(i))); if (plugin && (plugin->capabilities(device, testFormat) & QImageIOPlugin::CanWrite)) { handler = plugin->create(device, testFormat); break; } } } #endif if (!handler) return 0; handler->setDevice(device); if (!testFormat.isEmpty()) handler->setFormat(testFormat); return handler; }