void JsonKitsPage::setupProjectFiles(const JsonWizard::GeneratorFiles &files) { Project *project = 0; QList<IProjectManager *> managerList = ExtensionSystem::PluginManager::getObjects<IProjectManager>(); foreach (const JsonWizard::GeneratorFile &f, files) { if (f.file.attributes() & GeneratedFile::OpenProjectAttribute) { QString errorMessage; QString path = f.file.path(); const QFileInfo fi(path); if (fi.exists()) path = fi.canonicalFilePath(); Utils::MimeDatabase mdb; Utils::MimeType mt = mdb.mimeTypeForFile(fi); if (!mt.isValid()) continue; auto manager = Utils::findOrDefault(managerList, Utils::equal(&IProjectManager::mimeType, mt.name())); project = manager ? manager->openProject(path, &errorMessage) : 0; if (project) { if (setupProject(project)) project->saveSettings(); delete project; project = 0; } } } }
void ProjectFileAdder::addMapping(const char *mimeName, ProjectFile::Kind kind) { Utils::MimeDatabase mdb; Utils::MimeType mimeType = mdb.mimeTypeForName(QLatin1String(mimeName)); if (mimeType.isValid()) m_mimeNameMapping.insert(mimeType.name(), kind); }
// Switch between form ('ui') and source file ('cpp'): // Find corresponding 'other' file, simply assuming it is in the same directory. static QString otherFile() { // Determine mime type of current file. const QString current = currentFile(); if (current.isEmpty()) return QString(); Utils::MimeDatabase mdb; const Utils::MimeType currentMimeType = mdb.mimeTypeForFile(current); if (!currentMimeType.isValid()) return QString(); // Determine potential suffixes of candidate files // 'ui' -> 'cpp', 'cpp/h' -> 'ui'. QStringList candidateSuffixes; if (currentMimeType.matchesName(QLatin1String(FORM_MIMETYPE))) { candidateSuffixes += mdb.mimeTypeForName( QLatin1String(CppTools::Constants::CPP_SOURCE_MIMETYPE)).suffixes(); } else if (currentMimeType.matchesName(QLatin1String(CppTools::Constants::CPP_SOURCE_MIMETYPE)) || currentMimeType.matchesName(QLatin1String(CppTools::Constants::CPP_HEADER_MIMETYPE))) { candidateSuffixes += mdb.mimeTypeForName(QLatin1String(FORM_MIMETYPE)).suffixes(); } else { return QString(); } // Try to find existing file with desired suffix const QFileInfo currentFI(current); const QString currentBaseName = currentFI.path() + QLatin1Char('/') + currentFI.baseName() + QLatin1Char('.'); foreach (const QString &candidateSuffix, candidateSuffixes) { const QFileInfo fi(currentBaseName + candidateSuffix); if (fi.isFile()) return fi.absoluteFilePath(); } return QString(); }
bool TreeScanner::isMimeBinary(const Utils::MimeType &mimeType, const Utils::FileName &/*fn*/) { bool isBinary = false; if (mimeType.isValid()) { QStringList mimes; mimes << mimeType.name() << mimeType.allAncestors(); isBinary = !mimes.contains(QLatin1String("text/plain")); } return isBinary; }
CppFileSettingsWidget::CppFileSettingsWidget(QWidget *parent) : QWidget(parent), m_ui(new Internal::Ui::CppFileSettingsPage) { m_ui->setupUi(this); // populate suffix combos const Utils::MimeType sourceMt = Utils::mimeTypeForName(QLatin1String(CppTools::Constants::CPP_SOURCE_MIMETYPE)); if (sourceMt.isValid()) { foreach (const QString &suffix, sourceMt.suffixes()) m_ui->sourceSuffixComboBox->addItem(suffix); }
QString BaseFileWizardFactory::preferredSuffix(const QString &mimeType) { QString rc; Utils::MimeDatabase mdb; Utils::MimeType mt = mdb.mimeTypeForName(mimeType); if (mt.isValid()) rc = mt.preferredSuffix(); if (rc.isEmpty()) qWarning("%s: WARNING: Unable to find a preferred suffix for %s.", Q_FUNC_INFO, mimeType.toUtf8().constData()); return rc; }
QString Manager::definitionIdByMimeType(const Utils::MimeType &mimeType) const { Utils::MimeDatabase mdb; QList<Utils::MimeType> queue; queue.append(mimeType); while (!queue.isEmpty()) { const Utils::MimeType mt = queue.takeFirst(); const QString id = m_register.m_idByMimeType.value(mt.name()); if (!id.isEmpty()) return id; foreach (const QString &parent, mt.parentMimeTypes()) { const Utils::MimeType parentMt = mdb.mimeTypeForName(parent); if (parentMt.isValid()) queue.append(parentMt); } } return QString(); }
void AbstractSettings::setSupportedMimeTypes(const QString &mimes) { const QStringList stringTypes = mimes.split(';'); const Utils::MimeDatabase mdb; QStringList types; for (const QString &type : stringTypes) { const Utils::MimeType mime = mdb.mimeTypeForName(type.trimmed()); if (!mime.isValid()) continue; const QString canonicalName = mime.name(); if (!types.contains(canonicalName)) types << canonicalName; } if (m_supportedMimeTypes != types) { m_supportedMimeTypes = types; emit supportedMimeTypesChanged(); } }
ProjectFile::Kind ProjectFile::classify(const QString &file) { Utils::MimeDatabase mdb; const Utils::MimeType mimeType = mdb.mimeTypeForFile(file); if (!mimeType.isValid()) return Unclassified; const QString mt = mimeType.name(); if (mt == QLatin1String(CppTools::Constants::C_SOURCE_MIMETYPE)) return CSource; if (mt == QLatin1String(CppTools::Constants::C_HEADER_MIMETYPE)) return CHeader; if (mt == QLatin1String(CppTools::Constants::CPP_SOURCE_MIMETYPE)) return CXXSource; if (mt == QLatin1String(CppTools::Constants::CPP_HEADER_MIMETYPE)) return CXXHeader; if (mt == QLatin1String(CppTools::Constants::OBJECTIVE_C_SOURCE_MIMETYPE)) return ObjCSource; if (mt == QLatin1String(CppTools::Constants::OBJECTIVE_CPP_SOURCE_MIMETYPE)) return ObjCXXSource; return Unclassified; }