/*************************************************************************** ** ** This file is part of Qt Creator ** ** Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies). ** ** Contact: Qt Software Information (qt-info@nokia.com) ** ** ** Non-Open Source Usage ** ** Licensees may use this file in accordance with the Qt Beta Version ** License Agreement, Agreement version 2.2 provided with the Software or, ** alternatively, in accordance with the terms contained in a written ** agreement between you and Nokia. ** ** GNU General Public License Usage ** ** Alternatively, this file may be used under the terms of the GNU General ** Public License versions 2.0 or 3.0 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the packaging ** of this file. Please review the following information to ensure GNU ** General Public Licensing requirements will be met: ** ** http://www.fsf.org/licensing/licenses/info/GPLv2.html and ** http://www.gnu.org/copyleft/gpl.html. ** ** In addition, as a special exception, Nokia gives you certain additional ** rights. These rights are described in the Nokia Qt GPL Exception ** version 1.2, included in the file GPL_EXCEPTION.txt in this package. ** ***************************************************************************/ #include "searchsymbols.h" #include #include using namespace CPlusPlus; using namespace CppTools::Internal; SearchSymbols::SearchSymbols(): symbolsToSearchFor(Classes | Functions | Enums), separateScope(false) { } void SearchSymbols::setSymbolsToSearchFor(SymbolTypes types) { symbolsToSearchFor = types; } void SearchSymbols::setSeparateScope(bool separateScope) { this->separateScope = separateScope; } QList SearchSymbols::operator()(Document::Ptr doc, const QString &scope) { QString previousScope = switchScope(scope); items.clear(); for (unsigned i = 0; i < doc->globalSymbolCount(); ++i) { accept(doc->globalSymbolAt(i)); } (void) switchScope(previousScope); return items; } QString SearchSymbols::switchScope(const QString &scope) { QString previousScope = _scope; _scope = scope; return previousScope; } bool SearchSymbols::visit(Enum *symbol) { if (!(symbolsToSearchFor & Enums)) return false; QString name = symbolName(symbol); QString scopedName = scopedSymbolName(name); QString previousScope = switchScope(scopedName); appendItem(separateScope ? name : scopedName, separateScope ? previousScope : QString(), ModelItemInfo::Enum, symbol); Scope *members = symbol->members(); for (unsigned i = 0; i < members->symbolCount(); ++i) { accept(members->symbolAt(i)); } (void) switchScope(previousScope); return false; } bool SearchSymbols::visit(Function *symbol) { if (!(symbolsToSearchFor & Functions)) return false; QString name = symbolName(symbol); QString scopedName = scopedSymbolName(name); QString type = overview.prettyType(symbol->type(), separateScope ? symbol->name() : 0); appendItem(separateScope ? type : scopedName, separateScope ? _scope : type, ModelItemInfo::Method, symbol); return false; } bool SearchSymbols::visit(Namespace *symbol) { QString name = findOrInsert(scopedSymbolName(symbol)); QString previousScope = switchScope(name); Scope *members = symbol->members(); for (unsigned i = 0; i < members->symbolCount(); ++i) { accept(members->symbolAt(i)); } (void) switchScope(previousScope); return false; } #if 0 bool SearchSymbols::visit(Declaration *symbol) { if (symbol->type()->isFunction()) { QString name = scopedSymbolName(symbol); QString type = overview.prettyType(symbol->type()); appendItems(name, type, ModelItemInfo::Method, symbol->fileName()); } return false; } #endif bool SearchSymbols::visit(Class *symbol) { if (!(symbolsToSearchFor & Classes)) return false; QString name = symbolName(symbol); QString scopedName = scopedSymbolName(name); QString previousScope = switchScope(scopedName); appendItem(separateScope ? name : scopedName, separateScope ? previousScope : QString(), ModelItemInfo::Class, symbol); Scope *members = symbol->members(); for (unsigned i = 0; i < members->symbolCount(); ++i) { accept(members->symbolAt(i)); } (void) switchScope(previousScope); return false; } QString SearchSymbols::scopedSymbolName(const QString &symbolName) const { QString name = _scope; if (! name.isEmpty()) name += QLatin1String("::"); name += symbolName; return name; } QString SearchSymbols::scopedSymbolName(const Symbol *symbol) const { return scopedSymbolName(symbolName(symbol)); } QString SearchSymbols::symbolName(const Symbol *symbol) const { QString symbolName = overview.prettyName(symbol->name()); if (symbolName.isEmpty()) { QString type; if (symbol->isNamespace()) { type = QLatin1String("namespace"); } else if (symbol->isEnum()) { type = QLatin1String("enum"); } else if (const Class *c = symbol->asClass()) { if (c->isUnion()) { type = QLatin1String("union"); } else if (c->isStruct()) { type = QLatin1String("struct"); } else { type = QLatin1String("class"); } } else { type = QLatin1String("symbol"); } symbolName = QLatin1String(""); } return symbolName; } void SearchSymbols::appendItem(const QString &name, const QString &info, ModelItemInfo::ItemType type, const CPlusPlus::Symbol *symbol) { const QIcon icon = icons.iconForSymbol(symbol); items.append(ModelItemInfo(name, info, type, QString::fromUtf8(symbol->fileName(), symbol->fileNameLength()), symbol->line(), icon)); }