searchsymbols.cpp 6.59 KB
Newer Older
1
/**************************************************************************
2 3 4
**
** This file is part of Qt Creator
**
5
** Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
6 7 8
**
** Contact:  Qt Software Information (qt-info@nokia.com)
**
9
** Commercial Usage
10
**
11 12 13 14
** Licensees holding valid Qt Commercial licenses may use this file in
** accordance with the Qt Commercial License Agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and Nokia.
15
**
16
** GNU Lesser General Public License Usage
17
**
18 19 20 21 22 23
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 2.1 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file.  Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
24
**
25 26
** If you are unsure which license is appropriate for your use, please
** contact the sales department at qt-sales@nokia.com.
27
**
28
**************************************************************************/
29 30 31 32 33

#include "searchsymbols.h"

#include <Literals.h>
#include <Scope.h>
34
#include <Names.h>
35 36 37 38 39

using namespace CPlusPlus;
using namespace CppTools::Internal;

SearchSymbols::SearchSymbols():
40 41
    symbolsToSearchFor(Classes | Functions | Enums),
    separateScope(false)
42 43 44
{
}

45
void SearchSymbols::setSymbolsToSearchFor(SymbolTypes types)
46
{
47
    symbolsToSearchFor = types;
48 49
}

50 51 52 53 54
void SearchSymbols::setSeparateScope(bool separateScope)
{
    this->separateScope = separateScope;
}

55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
QList<ModelItemInfo> 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)
{
75
    if (!(symbolsToSearchFor & Enums))
76 77 78
        return false;

    QString name = symbolName(symbol);
79 80 81 82 83
    QString scopedName = scopedSymbolName(name);
    QString previousScope = switchScope(scopedName);
    appendItem(separateScope ? name : scopedName,
               separateScope ? previousScope : QString(),
               ModelItemInfo::Enum, symbol);
84 85 86 87 88 89 90 91 92 93
    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)
{
94
    if (!(symbolsToSearchFor & Functions))
95 96
        return false;

97 98 99 100 101 102 103 104 105 106 107 108
    QString extraScope;
    if (Name *name = symbol->name()) {
        if (QualifiedNameId *nameId = name->asQualifiedNameId()) {
            if (nameId->nameCount() > 1) {
                extraScope = overview.prettyName(nameId->nameAt(nameId->nameCount() - 2));
            }
        }
    }
    QString fullScope = _scope;
    if (!_scope.isEmpty() && !extraScope.isEmpty())
        fullScope += QLatin1String("::");
    fullScope += extraScope;
109
    QString name = symbolName(symbol);
110 111
    QString scopedName = scopedSymbolName(name);
    QString type = overview.prettyType(symbol->type(),
112
                                       separateScope ? symbol->identity() : 0);
113
    appendItem(separateScope ? type : scopedName,
114
               separateScope ? fullScope : type,
115
               ModelItemInfo::Method, symbol);
116 117 118 119 120
    return false;
}

bool SearchSymbols::visit(Namespace *symbol)
{
121
    QString name = findOrInsert(scopedSymbolName(symbol));
122 123 124 125 126 127 128 129 130 131 132 133 134
    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()) {
135
        QString name = scopedSymbolName(symbol);
136
        QString type = overview.prettyType(symbol->type());
137
        appendItems(name, type, ModelItemInfo::Method, symbol->fileName());
138 139 140 141 142 143 144
    }
    return false;
}
#endif

bool SearchSymbols::visit(Class *symbol)
{
145 146 147
    if (!(symbolsToSearchFor & Classes))
        return false;

148
    QString name = symbolName(symbol);
149 150 151 152 153
    QString scopedName = scopedSymbolName(name);
    QString previousScope = switchScope(scopedName);
    appendItem(separateScope ? name : scopedName,
               separateScope ? previousScope : QString(),
               ModelItemInfo::Class, symbol);
154 155 156 157 158 159 160 161
    Scope *members = symbol->members();
    for (unsigned i = 0; i < members->symbolCount(); ++i) {
        accept(members->symbolAt(i));
    }
    (void) switchScope(previousScope);
    return false;
}

162
QString SearchSymbols::scopedSymbolName(const QString &symbolName) const
163 164
{
    QString name = _scope;
165
    if (!name.isEmpty())
166
        name += QLatin1String("::");
167 168 169 170 171 172 173 174 175 176 177
    name += symbolName;
    return name;
}

QString SearchSymbols::scopedSymbolName(const Symbol *symbol) const
{
    return scopedSymbolName(symbolName(symbol));
}

QString SearchSymbols::symbolName(const Symbol *symbol) const
{
178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199
    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("<anonymous ");
        symbolName += type;
        symbolName += QLatin1String(">");
    }
200 201 202 203 204 205
    return symbolName;
}

void SearchSymbols::appendItem(const QString &name,
                               const QString &info,
                               ModelItemInfo::ItemType type,
206
                               const Symbol *symbol)
207
{
208 209 210
    if (!symbol->name())
        return;

211 212 213 214 215
    const QIcon icon = icons.iconForSymbol(symbol);
    items.append(ModelItemInfo(name, info, type,
                               QString::fromUtf8(symbol->fileName(), symbol->fileNameLength()),
                               symbol->line(),
                               icon));
216
}