Mercurial > hg > svgui
diff widgets/TransformFinder.cpp @ 431:4711b400f976
* Add beginnings of capability to search plugins that are not yet
installed -- lots more work to do here, though
author | Chris Cannam |
---|---|
date | Tue, 14 Oct 2008 16:36:35 +0000 (2008-10-14) |
parents | 6bf3c906b7a5 |
children | 1e0744b2cebe |
line wrap: on
line diff
--- a/widgets/TransformFinder.cpp Fri Oct 10 16:03:48 2008 +0000 +++ b/widgets/TransformFinder.cpp Tue Oct 14 16:36:35 2008 +0000 @@ -131,7 +131,7 @@ std::cerr << results.size() << " result(s)..." << std::endl; - std::set<TransformFactory::Match> sorted; + std::set<TextMatcher::Match> sorted; sorted.clear(); for (TransformFactory::SearchResults::const_iterator j = results.begin(); j != results.end(); ++j) { @@ -139,7 +139,7 @@ } m_sortedResults.clear(); - for (std::set<TransformFactory::Match>::const_iterator j = sorted.end(); + for (std::set<TextMatcher::Match>::const_iterator j = sorted.end(); j != sorted.begin(); ) { --j; m_sortedResults.push_back(*j); @@ -147,7 +147,7 @@ } if (m_sortedResults.empty()) m_selectedTransform = ""; - else m_selectedTransform = m_sortedResults.begin()->transform; + else m_selectedTransform = m_sortedResults.begin()->key; m_upToDateCount = 0; @@ -164,18 +164,29 @@ int i = m_upToDateCount; - std::cerr << "sorted size = " << m_sortedResults.size() << std::endl; +// std::cerr << "sorted size = " << m_sortedResults.size() << std::endl; - TransformDescription desc = - TransformFactory::getInstance()->getTransformDescription - (m_sortedResults[i].transform); + TransformDescription desc; + TransformId tid = m_sortedResults[i].key; + TransformFactory *factory = TransformFactory::getInstance(); + TransformFactory::TransformInstallStatus status = + factory->getTransformInstallStatus(tid); + QString suffix; + + if (status == TransformFactory::TransformInstalled) { + desc = factory->getTransformDescription(tid); + } else { + desc = factory->getUninstalledTransformDescription(tid); + suffix = tr("<i> (not installed)</i>"); + } QString labelText; - labelText += tr("%1<br><small>") - .arg(XmlExportable::encodeEntities(desc.name)); + labelText += tr("%1%2<br><small>") + .arg(XmlExportable::encodeEntities(desc.name)) + .arg(suffix); labelText += "..."; - for (TransformFactory::Match::FragmentMap::const_iterator k = + for (TextMatcher::Match::FragmentMap::const_iterator k = m_sortedResults[i].fragments.begin(); k != m_sortedResults[i].fragments.end(); ++k) { labelText += k->second; @@ -184,16 +195,28 @@ labelText += tr("</small>"); QString selectedText; - selectedText += tr("<b>%1</b><br>") - .arg(XmlExportable::encodeEntities(desc.name)); - selectedText += tr("<small>%1</small>") - .arg(XmlExportable::encodeEntities(desc.longDescription)); + selectedText += tr("<b>%1</b>%2<br>") + .arg(XmlExportable::encodeEntities + (desc.name == "" ? desc.identifier : desc.name)) + .arg(suffix); + + if (desc.longDescription != "") { + selectedText += tr("<small>%1</small>") + .arg(XmlExportable::encodeEntities(desc.longDescription)); + } else if (desc.description != "") { + selectedText += tr("<small>%1</small>") + .arg(XmlExportable::encodeEntities(desc.description)); + } selectedText += tr("<br><small>"); - selectedText += tr(" — Plugin type: %1<br>") - .arg(XmlExportable::encodeEntities(desc.type)); - selectedText += tr(" — Category: %1<br>") - .arg(XmlExportable::encodeEntities(desc.category)); + if (desc.type != "") { + selectedText += tr(" — Plugin type: %1<br>") + .arg(XmlExportable::encodeEntities(desc.type)); + } + if (desc.category != "") { + selectedText += tr(" — Category: %1<br>") + .arg(XmlExportable::encodeEntities(desc.category)); + } selectedText += tr(" — System identifier: %1") .arg(XmlExportable::encodeEntities(desc.identifier)); selectedText += tr("</small>");