From 7c7ce13ac09d1a3a3807d0f4fea97688554d28d3 Mon Sep 17 00:00:00 2001 From: Roberto Raggi <roberto.raggi@nokia.com> Date: Tue, 1 Dec 2009 12:46:15 +0100 Subject: [PATCH] Use const names. --- src/libs/cplusplus/CheckUndefinedSymbols.cpp | 16 +- src/libs/cplusplus/CheckUndefinedSymbols.h | 4 +- src/libs/cplusplus/CppBindings.cpp | 44 ++--- src/libs/cplusplus/CppBindings.h | 18 +- src/libs/cplusplus/GenTemplateInstance.cpp | 32 ++-- src/libs/cplusplus/LookupContext.cpp | 40 ++--- src/libs/cplusplus/LookupContext.h | 30 ++-- src/libs/cplusplus/NamePrettyPrinter.cpp | 18 +- src/libs/cplusplus/NamePrettyPrinter.h | 16 +- src/libs/cplusplus/Overview.cpp | 4 +- src/libs/cplusplus/Overview.h | 8 +- src/libs/cplusplus/ResolveExpression.cpp | 44 ++--- src/libs/cplusplus/ResolveExpression.h | 14 +- src/libs/cplusplus/TypePrettyPrinter.cpp | 2 +- src/plugins/cppeditor/cppeditor.cpp | 47 ++--- src/plugins/cppeditor/cpphoverhandler.cpp | 12 +- src/plugins/cpptools/cppcodecompletion.cpp | 22 +-- src/plugins/cpptools/searchsymbols.cpp | 4 +- src/plugins/designer/qtcreatorintegration.cpp | 24 +-- src/shared/cplusplus/AST.h | 4 +- src/shared/cplusplus/CheckDeclaration.cpp | 38 ++-- src/shared/cplusplus/CheckDeclarator.cpp | 12 +- src/shared/cplusplus/CheckDeclarator.h | 6 +- src/shared/cplusplus/CheckExpression.cpp | 7 +- src/shared/cplusplus/CheckName.cpp | 33 ++-- src/shared/cplusplus/CheckName.h | 10 +- src/shared/cplusplus/CheckSpecifier.cpp | 12 +- src/shared/cplusplus/CheckStatement.cpp | 11 +- src/shared/cplusplus/Control.cpp | 167 +++++++++--------- src/shared/cplusplus/Control.h | 66 +++---- src/shared/cplusplus/CoreTypes.cpp | 16 +- src/shared/cplusplus/CoreTypes.h | 12 +- src/shared/cplusplus/Name.cpp | 4 +- src/shared/cplusplus/Name.h | 14 +- src/shared/cplusplus/NameVisitor.cpp | 4 +- src/shared/cplusplus/NameVisitor.h | 20 +-- src/shared/cplusplus/Names.cpp | 100 ++++------- src/shared/cplusplus/Names.h | 65 ++----- src/shared/cplusplus/Scope.cpp | 20 +-- src/shared/cplusplus/Scope.h | 2 +- src/shared/cplusplus/Semantic.cpp | 8 +- src/shared/cplusplus/Semantic.h | 8 +- src/shared/cplusplus/Symbol.cpp | 48 ++--- src/shared/cplusplus/Symbol.h | 10 +- src/shared/cplusplus/Symbols.cpp | 68 +++---- src/shared/cplusplus/Symbols.h | 55 +++--- 46 files changed, 577 insertions(+), 642 deletions(-) diff --git a/src/libs/cplusplus/CheckUndefinedSymbols.cpp b/src/libs/cplusplus/CheckUndefinedSymbols.cpp index f3d27df502d..ee5d76bf7e8 100644 --- a/src/libs/cplusplus/CheckUndefinedSymbols.cpp +++ b/src/libs/cplusplus/CheckUndefinedSymbols.cpp @@ -122,7 +122,7 @@ bool CheckUndefinedSymbols::isType(const Identifier *id) const return isType(QByteArray::fromRawData(id->chars(), id->size())); } -void CheckUndefinedSymbols::addType(Name *name) +void CheckUndefinedSymbols::addType(const Name *name) { if (! name) return; @@ -131,7 +131,7 @@ void CheckUndefinedSymbols::addType(Name *name) _types.insert(QByteArray(id->chars(), id->size())); } -void CheckUndefinedSymbols::addProtocol(Name *name) +void CheckUndefinedSymbols::addProtocol(const Name *name) { if (!name) return; @@ -294,7 +294,7 @@ bool CheckUndefinedSymbols::visit(ClassSpecifierAST *ast) Symbol *symbol = klass->memberAt(i); if (symbol->name() && symbol->name()->isNameId()) { - NameId *nameId = symbol->name()->asNameId(); + const NameId *nameId = symbol->name()->asNameId(); if (! qstrcmp(nameId->identifier()->chars(), "qt_check_for_QOBJECT_macro")) { hasQ_OBJECT_CHECK = true; @@ -367,7 +367,7 @@ bool CheckUndefinedSymbols::visit(BaseSpecifierAST *base) if (NameAST *nameAST = base->name) { bool resolvedBaseClassName = false; - if (Name *name = nameAST->name) { + if (const Name *name = nameAST->name) { const Identifier *id = name->identifier(); const QByteArray spell = QByteArray::fromRawData(id->chars(), id->size()); if (isType(spell)) @@ -403,9 +403,9 @@ bool CheckUndefinedSymbols::visit(UsingDirectiveAST *ast) bool CheckUndefinedSymbols::visit(QualifiedNameAST *ast) { if (ast->name) { - QualifiedNameId *q = ast->name->asQualifiedNameId(); + const QualifiedNameId *q = ast->name->asQualifiedNameId(); for (unsigned i = 0; i < q->nameCount() - 1; ++i) { - Name *name = q->nameAt(i); + const Name *name = q->nameAt(i); if (const Identifier *id = name->identifier()) { const QByteArray spell = QByteArray::fromRawData(id->chars(), id->size()); if (! (_namespaceNames.contains(spell) || isType(id))) { @@ -474,7 +474,7 @@ bool CheckUndefinedSymbols::visit(ObjCClassDeclarationAST *ast) if (NameAST *nameAST = ast->superclass) { bool resolvedSuperClassName = false; - if (Name *name = nameAST->name) { + if (const Name *name = nameAST->name) { const Identifier *id = name->identifier(); const QByteArray spell = QByteArray::fromRawData(id->chars(), id->size()); if (isType(spell)) @@ -496,7 +496,7 @@ bool CheckUndefinedSymbols::visit(ObjCProtocolRefsAST *ast) if (NameAST *nameAST = iter->value) { bool resolvedProtocolName = false; - if (Name *name = nameAST->name) { + if (const Name *name = nameAST->name) { const Identifier *id = name->identifier(); const QByteArray spell = QByteArray::fromRawData(id->chars(), id->size()); if (isProtocol(spell)) diff --git a/src/libs/cplusplus/CheckUndefinedSymbols.h b/src/libs/cplusplus/CheckUndefinedSymbols.h index e6610a2564f..c8569bd2103 100644 --- a/src/libs/cplusplus/CheckUndefinedSymbols.h +++ b/src/libs/cplusplus/CheckUndefinedSymbols.h @@ -55,11 +55,11 @@ protected: bool isType(const Identifier *id) const; bool isType(const QByteArray &name) const; - void addType(Name *name); + void addType(const Name *name); void buildTypeMap(Class *klass); void buildMemberTypeMap(Symbol *member); void buildTypeMap(NamespaceBinding *binding, QSet<NamespaceBinding *> *processed); - void addProtocol(Name *name); + void addProtocol(const Name *name); bool isProtocol(const QByteArray &name) const; FunctionDeclaratorAST *currentFunctionDeclarator() const; diff --git a/src/libs/cplusplus/CppBindings.cpp b/src/libs/cplusplus/CppBindings.cpp index 2faf1aa6b7f..d9b0a32eacd 100644 --- a/src/libs/cplusplus/CppBindings.cpp +++ b/src/libs/cplusplus/CppBindings.cpp @@ -79,11 +79,11 @@ NamespaceBinding::~NamespaceBinding() qDeleteAll(classBindings); } -NameId *NamespaceBinding::name() const +const NameId *NamespaceBinding::name() const { if (symbols.size()) { - if (Name *name = symbols.first()->name()) { - NameId *nameId = name->asNameId(); + if (const Name *name = symbols.first()->name()) { + const NameId *nameId = name->asNameId(); Q_ASSERT(nameId != 0); return nameId; @@ -95,7 +95,7 @@ NameId *NamespaceBinding::name() const const Identifier *NamespaceBinding::identifier() const { - if (NameId *nameId = name()) + if (const NameId *nameId = name()) return nameId->identifier(); return 0; @@ -144,7 +144,7 @@ Binding *NamespaceBinding::findClassOrNamespaceBinding(const Identifier *id, QSe return 0; } -ClassBinding *NamespaceBinding::findClassBinding(Name *name, QSet<Binding *> *processed) +ClassBinding *NamespaceBinding::findClassBinding(const Name *name, QSet<Binding *> *processed) { if (! name) return 0; @@ -191,19 +191,19 @@ ClassBinding *NamespaceBinding::findClassBinding(Name *name, QSet<Binding *> *pr return 0; } -NamespaceBinding *NamespaceBinding::findNamespaceBinding(Name *name) +NamespaceBinding *NamespaceBinding::findNamespaceBinding(const Name *name) { if (! name) return anonymousNamespaceBinding; - else if (NameId *nameId = name->asNameId()) + else if (const NameId *nameId = name->asNameId()) return findNamespaceBindingForNameId(nameId, /*lookAtParent = */ true); else if (const QualifiedNameId *q = name->asQualifiedNameId()) { NamespaceBinding *current = this; for (unsigned i = 0; i < q->nameCount(); ++i) { - NameId *namespaceName = q->nameAt(i)->asNameId(); + const NameId *namespaceName = q->nameAt(i)->asNameId(); if (! namespaceName) return 0; @@ -225,14 +225,14 @@ NamespaceBinding *NamespaceBinding::findNamespaceBinding(Name *name) return 0; } -NamespaceBinding *NamespaceBinding::findNamespaceBindingForNameId(NameId *name, +NamespaceBinding *NamespaceBinding::findNamespaceBindingForNameId(const NameId *name, bool lookAtParentNamespace) { QSet<NamespaceBinding *> processed; return findNamespaceBindingForNameId_helper(name, lookAtParentNamespace, &processed); } -NamespaceBinding *NamespaceBinding::findNamespaceBindingForNameId_helper(NameId *name, +NamespaceBinding *NamespaceBinding::findNamespaceBindingForNameId_helper(const NameId *name, bool lookAtParentNamespace, QSet<NamespaceBinding *> *processed) { @@ -242,12 +242,12 @@ NamespaceBinding *NamespaceBinding::findNamespaceBindingForNameId_helper(NameId processed->insert(this); foreach (NamespaceBinding *binding, children) { - Name *bindingName = binding->name(); + const Name *bindingName = binding->name(); if (! bindingName) continue; - if (NameId *bindingNameId = bindingName->asNameId()) { + if (const NameId *bindingNameId = bindingName->asNameId()) { if (name->isEqualTo(bindingNameId)) return binding; } @@ -296,7 +296,7 @@ NamespaceBinding *NamespaceBinding::findOrCreateNamespaceBinding(Namespace *symb } static void closure(const Location &loc, - NamespaceBinding *binding, Name *name, + NamespaceBinding *binding, const Name *name, QList<NamespaceBinding *> *bindings) { if (bindings->contains(binding)) @@ -334,13 +334,13 @@ static void closure(const Location &loc, NamespaceBinding *NamespaceBinding::resolveNamespace(const Location &loc, - Name *name, + const Name *name, bool lookAtParent) { if (! name) return 0; - else if (NameId *nameId = name->asNameId()) { + else if (const NameId *nameId = name->asNameId()) { QList<NamespaceBinding *> bindings; closure(loc, this, nameId, &bindings); @@ -447,7 +447,7 @@ Binding *ClassBinding::findClassOrNamespaceBinding(const Identifier *id, QSet<Bi return 0; } -ClassBinding *ClassBinding::findClassBinding(Name *name, QSet<Binding *> *processed) +ClassBinding *ClassBinding::findClassBinding(const Name *name, QSet<Binding *> *processed) { if (! name) return 0; @@ -549,7 +549,7 @@ ClassBinding::ClassBinding(ClassBinding *parentClass) ClassBinding::~ClassBinding() { qDeleteAll(children); } -Name *ClassBinding::name() const +const Name *ClassBinding::name() const { if (symbols.isEmpty()) return 0; @@ -559,7 +559,7 @@ Name *ClassBinding::name() const const Identifier *ClassBinding::identifier() const { - if (Name *n = name()) + if (const Name *n = name()) return n->identifier(); return 0; @@ -623,12 +623,12 @@ protected: NamespaceBinding *bind(Symbol *symbol, NamespaceBinding *binding); NamespaceBinding *findOrCreateNamespaceBinding(Namespace *symbol); - NamespaceBinding *resolveNamespace(const Location &loc, Name *name); + NamespaceBinding *resolveNamespace(const Location &loc, const Name *name); NamespaceBinding *switchNamespaceBinding(NamespaceBinding *binding); ClassBinding *findOrCreateClassBinding(Class *classSymbol); - ClassBinding *findClassBinding(Name *name); + ClassBinding *findClassBinding(const Name *name); ClassBinding *switchClassBinding(ClassBinding *binding); @@ -665,7 +665,7 @@ NamespaceBinding *Binder::bind(Symbol *symbol, NamespaceBinding *binding) NamespaceBinding *Binder::findOrCreateNamespaceBinding(Namespace *symbol) { return namespaceBinding->findOrCreateNamespaceBinding(symbol); } -NamespaceBinding *Binder::resolveNamespace(const Location &loc, Name *name) +NamespaceBinding *Binder::resolveNamespace(const Location &loc, const Name *name) { if (! namespaceBinding) return 0; @@ -694,7 +694,7 @@ ClassBinding *Binder::findOrCreateClassBinding(Class *classSymbol) return binding; } -ClassBinding *Binder::findClassBinding(Name *name) +ClassBinding *Binder::findClassBinding(const Name *name) { QSet<Binding *> processed; diff --git a/src/libs/cplusplus/CppBindings.h b/src/libs/cplusplus/CppBindings.h index 4bce41bcbc5..41ed9638c71 100644 --- a/src/libs/cplusplus/CppBindings.h +++ b/src/libs/cplusplus/CppBindings.h @@ -84,7 +84,7 @@ public: virtual NamespaceBinding *asNamespaceBinding() { return 0; } virtual ClassBinding *asClassBinding() { return 0; } - virtual ClassBinding *findClassBinding(Name *name, QSet<Binding *> *processed) = 0; + virtual ClassBinding *findClassBinding(const Name *name, QSet<Binding *> *processed) = 0; virtual Binding *findClassOrNamespaceBinding(const Identifier *id, QSet<Binding *> *processed) = 0; }; @@ -98,7 +98,7 @@ public: virtual ~NamespaceBinding(); /// Returns this binding's name. - NameId *name() const; + const NameId *name() const; /// Returns this binding's identifier. const Identifier *identifier() const; @@ -107,16 +107,16 @@ public: NamespaceBinding *globalNamespaceBinding(); /// Returns the binding for the given namespace symbol. - NamespaceBinding *findNamespaceBinding(Name *name); + NamespaceBinding *findNamespaceBinding(const Name *name); /// Returns the binding associated with the given symbol. NamespaceBinding *findOrCreateNamespaceBinding(Namespace *symbol); NamespaceBinding *resolveNamespace(const Location &loc, - Name *name, + const Name *name, bool lookAtParent = true); - virtual ClassBinding *findClassBinding(Name *name, QSet<Binding *> *processed); + virtual ClassBinding *findClassBinding(const Name *name, QSet<Binding *> *processed); virtual Binding *findClassOrNamespaceBinding(const Identifier *id, QSet<Binding *> *processed); /// Helpers. @@ -129,10 +129,10 @@ public: static ClassBinding *find(Class *symbol, NamespaceBinding *binding); private: - NamespaceBinding *findNamespaceBindingForNameId(NameId *name, + NamespaceBinding *findNamespaceBindingForNameId(const NameId *name, bool lookAtParentNamespace); - NamespaceBinding *findNamespaceBindingForNameId_helper(NameId *name, + NamespaceBinding *findNamespaceBindingForNameId_helper(const NameId *name, bool lookAtParentNamespace, QSet<NamespaceBinding *> *processed); @@ -165,13 +165,13 @@ public: virtual ClassBinding *asClassBinding() { return this; } /// Returns this binding's name. - Name *name() const; + const Name *name() const; /// Returns this binding's identifier. const Identifier *identifier() const; virtual QByteArray qualifiedId() const; - virtual ClassBinding *findClassBinding(Name *name, QSet<Binding *> *processed); + virtual ClassBinding *findClassBinding(const Name *name, QSet<Binding *> *processed); virtual Binding *findClassOrNamespaceBinding(const Identifier *id, QSet<Binding *> *processed); void dump(); diff --git a/src/libs/cplusplus/GenTemplateInstance.cpp b/src/libs/cplusplus/GenTemplateInstance.cpp index eaa515923a3..16aee2f9577 100644 --- a/src/libs/cplusplus/GenTemplateInstance.cpp +++ b/src/libs/cplusplus/GenTemplateInstance.cpp @@ -52,7 +52,7 @@ public: Control *control() const { return context.control(); } - FullySpecifiedType apply(Name *name); + FullySpecifiedType apply(const Name *name); FullySpecifiedType apply(const FullySpecifiedType &type); int findSubstitution(const Identifier *id) const; @@ -207,7 +207,7 @@ private: public: ApplyToName(ApplySubstitution *q): q(q) {} - FullySpecifiedType operator()(Name *name) + FullySpecifiedType operator()(const Name *name) { FullySpecifiedType previousType = switchType(FullySpecifiedType()); accept(name); @@ -231,7 +231,7 @@ private: return previousType; } - virtual void visit(NameId *name) + virtual void visit(const NameId *name) { int index = findSubstitution(name->identifier()); @@ -242,7 +242,7 @@ private: _type = control()->namedType(name); } - virtual void visit(TemplateNameId *name) + virtual void visit(const TemplateNameId *name) { QVarLengthArray<FullySpecifiedType, 8> arguments(name->templateArgumentCount()); for (unsigned i = 0; i < name->templateArgumentCount(); ++i) { @@ -250,17 +250,19 @@ private: arguments[i] = q->apply(argTy); } - TemplateNameId *templId = control()->templateNameId(name->identifier(), arguments.data(), arguments.size()); + const TemplateNameId *templId = control()->templateNameId(name->identifier(), + arguments.data(), + arguments.size()); _type = control()->namedType(templId); } - virtual void visit(QualifiedNameId *name) + virtual void visit(const QualifiedNameId *name) { - QVarLengthArray<Name *, 8> names(name->nameCount()); + QVarLengthArray<const Name *, 8> names(name->nameCount()); for (unsigned i = 0; i < name->nameCount(); ++i) { - Name *n = name->nameAt(i); + const Name *n = name->nameAt(i); - if (TemplateNameId *templId = n->asTemplateNameId()) { + if (const TemplateNameId *templId = n->asTemplateNameId()) { QVarLengthArray<FullySpecifiedType, 8> arguments(templId->templateArgumentCount()); for (unsigned templateArgIndex = 0; templateArgIndex < templId->templateArgumentCount(); ++templateArgIndex) { FullySpecifiedType argTy = templId->templateArgumentAt(templateArgIndex); @@ -273,29 +275,29 @@ private: names[i] = n; } - QualifiedNameId *q = control()->qualifiedNameId(names.data(), names.size(), name->isGlobal()); + const QualifiedNameId *q = control()->qualifiedNameId(names.data(), names.size(), name->isGlobal()); _type = control()->namedType(q); } - virtual void visit(DestructorNameId *name) + virtual void visit(const DestructorNameId *name) { Overview oo; qWarning() << "ignored name:" << oo(name); } - virtual void visit(OperatorNameId *name) + virtual void visit(const OperatorNameId *name) { Overview oo; qWarning() << "ignored name:" << oo(name); } - virtual void visit(ConversionNameId *name) + virtual void visit(const ConversionNameId *name) { Overview oo; qWarning() << "ignored name:" << oo(name); } - virtual void visit(SelectorNameId *name) + virtual void visit(const SelectorNameId *name) { Overview oo; qWarning() << "ignored name:" << oo(name); @@ -325,7 +327,7 @@ ApplySubstitution::~ApplySubstitution() { } -FullySpecifiedType ApplySubstitution::apply(Name *name) +FullySpecifiedType ApplySubstitution::apply(const Name *name) { FullySpecifiedType ty = applyToName(name); return ty; diff --git a/src/libs/cplusplus/LookupContext.cpp b/src/libs/cplusplus/LookupContext.cpp index dbfa6710210..942c0dc764e 100644 --- a/src/libs/cplusplus/LookupContext.cpp +++ b/src/libs/cplusplus/LookupContext.cpp @@ -109,14 +109,14 @@ bool LookupContext::maybeValidSymbol(Symbol *symbol, return false; } -QList<Scope *> LookupContext::resolveNestedNameSpecifier(QualifiedNameId *q, - const QList<Scope *> &visibleScopes) const +QList<Scope *> LookupContext::resolveNestedNameSpecifier(const QualifiedNameId *q, + const QList<Scope *> &visibleScopes) const { QList<Symbol *> candidates; QList<Scope *> scopes = visibleScopes; for (unsigned i = 0; i < q->nameCount() - 1; ++i) { - Name *name = q->nameAt(i); + const Name *name = q->nameAt(i); candidates = resolveClassOrNamespace(name, scopes); @@ -137,7 +137,7 @@ QList<Scope *> LookupContext::resolveNestedNameSpecifier(QualifiedNameId *q, return scopes; } -QList<Symbol *> LookupContext::resolveQualifiedNameId(QualifiedNameId *q, +QList<Symbol *> LookupContext::resolveQualifiedNameId(const QualifiedNameId *q, const QList<Scope *> &visibleScopes, ResolveMode mode) const { @@ -153,7 +153,7 @@ QList<Symbol *> LookupContext::resolveQualifiedNameId(QualifiedNameId *q, else if (! symbol->isClass()) continue; - QualifiedNameId *qq = symbol->name()->asQualifiedNameId(); + const QualifiedNameId *qq = symbol->name()->asQualifiedNameId(); if (! qq) continue; @@ -167,8 +167,8 @@ QList<Symbol *> LookupContext::resolveQualifiedNameId(QualifiedNameId *q, unsigned j = 0; for (; j < q->nameCount(); ++j) { - Name *classOrNamespaceName1 = q->nameAt(j); - Name *classOrNamespaceName2 = qq->nameAt(j); + const Name *classOrNamespaceName1 = q->nameAt(j); + const Name *classOrNamespaceName2 = qq->nameAt(j); if (! classOrNamespaceName1->isEqualTo(classOrNamespaceName2)) break; @@ -205,7 +205,7 @@ QList<Symbol *> LookupContext::resolveQualifiedNameId(QualifiedNameId *q, return candidates; } -QList<Symbol *> LookupContext::resolveOperatorNameId(OperatorNameId *opId, +QList<Symbol *> LookupContext::resolveOperatorNameId(const OperatorNameId *opId, const QList<Scope *> &visibleScopes, ResolveMode) const { @@ -226,7 +226,7 @@ QList<Symbol *> LookupContext::resolveOperatorNameId(OperatorNameId *opId, return candidates; } -QList<Symbol *> LookupContext::resolve(Name *name, const QList<Scope *> &visibleScopes, +QList<Symbol *> LookupContext::resolve(const Name *name, const QList<Scope *> &visibleScopes, ResolveMode mode) const { QList<Symbol *> candidates; @@ -234,10 +234,10 @@ QList<Symbol *> LookupContext::resolve(Name *name, const QList<Scope *> &visible if (!name) return candidates; // nothing to do, the symbol is anonymous. - else if (QualifiedNameId *q = name->asQualifiedNameId()) + else if (const QualifiedNameId *q = name->asQualifiedNameId()) return resolveQualifiedNameId(q, visibleScopes, mode); - else if (OperatorNameId *opId = name->asOperatorNameId()) + else if (const OperatorNameId *opId = name->asOperatorNameId()) return resolveOperatorNameId(opId, visibleScopes, mode); else if (const Identifier *id = name->identifier()) { @@ -256,14 +256,14 @@ QList<Symbol *> LookupContext::resolve(Name *name, const QList<Scope *> &visible continue; // skip it, the symbol's id is not compatible with this lookup. } - if (QualifiedNameId *q = symbol->name()->asQualifiedNameId()) { + if (const QualifiedNameId *q = symbol->name()->asQualifiedNameId()) { if (name->isDestructorNameId() != q->unqualifiedNameId()->isDestructorNameId()) continue; else if (q->nameCount() > 1) { - Name *classOrNamespaceName = control()->qualifiedNameId(q->names(), - q->nameCount() - 1); + const Name *classOrNamespaceName = control()->qualifiedNameId(q->names(), + q->nameCount() - 1); if (const Identifier *classOrNamespaceNameId = identifier(classOrNamespaceName)) { if (classOrNamespaceNameId->isEqualTo(id)) @@ -418,7 +418,7 @@ void LookupContext::expandNamespace(Namespace *ns, if (Scope *encl = ns->enclosingNamespaceScope()) expand(encl, visibleScopes, expandedScopes); - if (Name *nsName = ns->name()) { + if (const Name *nsName = ns->name()) { const QList<Symbol *> namespaceList = resolveNamespace(nsName, visibleScopes); foreach (Symbol *otherNs, namespaceList) { if (otherNs == ns) @@ -478,7 +478,7 @@ void LookupContext::expandClass(Class *klass, for (unsigned i = 0; i < klass->baseClassCount(); ++i) { BaseClass *baseClass = klass->baseClassAt(i); - Name *baseClassName = baseClass->name(); + const Name *baseClassName = baseClass->name(); const QList<Symbol *> baseClassCandidates = resolveClass(baseClassName, classVisibleScopes); @@ -515,8 +515,8 @@ void LookupContext::expandFunction(Function *function, if (! expandedScopes->contains(function->arguments())) expandedScopes->append(function->arguments()); - if (QualifiedNameId *q = function->name()->asQualifiedNameId()) { - Name *nestedNameSpec = 0; + if (const QualifiedNameId *q = function->name()->asQualifiedNameId()) { + const Name *nestedNameSpec = 0; if (q->nameCount() == 1) nestedNameSpec = q->nameAt(0); else @@ -565,7 +565,7 @@ void LookupContext::expandObjCClass(ObjCClass *klass, // expand the base class: if (ObjCBaseClass *baseClass = klass->baseClass()) { - Name *baseClassName = baseClass->name(); + const Name *baseClassName = baseClass->name(); const QList<Symbol *> baseClassCandidates = resolveObjCClass(baseClassName, visibleScopes); @@ -577,7 +577,7 @@ void LookupContext::expandObjCClass(ObjCClass *klass, // expand the protocols: for (unsigned i = 0; i < klass->protocolCount(); ++i) { - Name *protocolName = klass->protocolAt(i)->name(); + const Name *protocolName = klass->protocolAt(i)->name(); const QList<Symbol *> protocolCandidates = resolveObjCProtocol(protocolName, visibleScopes); for (int j = 0; j < protocolCandidates.size(); ++j) { if (ObjCProtocol *protocolSymbol = protocolCandidates.at(j)->asObjCProtocol()) diff --git a/src/libs/cplusplus/LookupContext.h b/src/libs/cplusplus/LookupContext.h index 06339d0a980..bced5f4cf49 100644 --- a/src/libs/cplusplus/LookupContext.h +++ b/src/libs/cplusplus/LookupContext.h @@ -94,22 +94,22 @@ public: static Symbol *canonicalSymbol(const QList<LookupItem> &candidates, NamespaceBinding *globalNamespaceBinding); - QList<Symbol *> resolve(Name *name) const + QList<Symbol *> resolve(const Name *name) const { return resolve(name, visibleScopes()); } - QList<Symbol *> resolveNamespace(Name *name) const + QList<Symbol *> resolveNamespace(const Name *name) const { return resolveNamespace(name, visibleScopes()); } - QList<Symbol *> resolveClass(Name *name) const + QList<Symbol *> resolveClass(const Name *name) const { return resolveClass(name, visibleScopes()); } - QList<Symbol *> resolveClassOrNamespace(Name *name) const + QList<Symbol *> resolveClassOrNamespace(const Name *name) const { return resolveClassOrNamespace(name, visibleScopes()); } - QList<Symbol *> resolveObjCClass(Name *name) const + QList<Symbol *> resolveObjCClass(const Name *name) const { return resolveObjCClass(name, visibleScopes()); } - QList<Symbol *> resolveObjCProtocol(Name *name) const + QList<Symbol *> resolveObjCProtocol(const Name *name) const { return resolveObjCProtocol(name, visibleScopes()); } enum ResolveMode { @@ -122,22 +122,22 @@ public: ResolveAll = ResolveSymbol | ResolveClassOrNamespace | ResolveObjCClass | ResolveObjCProtocol }; - QList<Symbol *> resolve(Name *name, const QList<Scope *> &visibleScopes, + QList<Symbol *> resolve(const Name *name, const QList<Scope *> &visibleScopes, ResolveMode mode = ResolveAll) const; - QList<Symbol *> resolveNamespace(Name *name, const QList<Scope *> &visibleScopes) const + QList<Symbol *> resolveNamespace(const Name *name, const QList<Scope *> &visibleScopes) const { return resolve(name, visibleScopes, ResolveNamespace); } - QList<Symbol *> resolveClass(Name *name, const QList<Scope *> &visibleScopes) const + QList<Symbol *> resolveClass(const Name *name, const QList<Scope *> &visibleScopes) const { return resolve(name, visibleScopes, ResolveClass); } - QList<Symbol *> resolveClassOrNamespace(Name *name, const QList<Scope *> &visibleScopes) const + QList<Symbol *> resolveClassOrNamespace(const Name *name, const QList<Scope *> &visibleScopes) const { return resolve(name, visibleScopes, ResolveClassOrNamespace); } - QList<Symbol *> resolveObjCClass(Name *name, const QList<Scope *> &visibleScopes) const + QList<Symbol *> resolveObjCClass(const Name *name, const QList<Scope *> &visibleScopes) const { return resolve(name, visibleScopes, ResolveObjCClass); } - QList<Symbol *> resolveObjCProtocol(Name *name, const QList<Scope *> &visibleScopes) const + QList<Symbol *> resolveObjCProtocol(const Name *name, const QList<Scope *> &visibleScopes) const { return resolve(name, visibleScopes, ResolveObjCProtocol); } QList<Scope *> visibleScopes() const @@ -187,15 +187,15 @@ public: private: static Symbol *canonicalSymbol(Symbol *symbol); - QList<Symbol *> resolveQualifiedNameId(QualifiedNameId *q, + QList<Symbol *> resolveQualifiedNameId(const QualifiedNameId *q, const QList<Scope *> &visibleScopes, ResolveMode mode) const; - QList<Symbol *> resolveOperatorNameId(OperatorNameId *opId, + QList<Symbol *> resolveOperatorNameId(const OperatorNameId *opId, const QList<Scope *> &visibleScopes, ResolveMode mode) const; - QList<Scope *> resolveNestedNameSpecifier(QualifiedNameId *q, + QList<Scope *> resolveNestedNameSpecifier(const QualifiedNameId *q, const QList<Scope *> &visibleScopes) const; const Identifier *identifier(const Name *name) const; diff --git a/src/libs/cplusplus/NamePrettyPrinter.cpp b/src/libs/cplusplus/NamePrettyPrinter.cpp index 607d3a65923..99274198a2a 100644 --- a/src/libs/cplusplus/NamePrettyPrinter.cpp +++ b/src/libs/cplusplus/NamePrettyPrinter.cpp @@ -48,7 +48,7 @@ const Overview *NamePrettyPrinter::overview() const return _overview; } -QString NamePrettyPrinter::operator()(Name *name) +QString NamePrettyPrinter::operator()(const Name *name) { QString previousName = switchName(); accept(name); @@ -62,7 +62,7 @@ QString NamePrettyPrinter::switchName(const QString &name) return previousName; } -void NamePrettyPrinter::visit(NameId *name) +void NamePrettyPrinter::visit(const NameId *name) { const Identifier *id = name->identifier(); if (id) @@ -71,7 +71,7 @@ void NamePrettyPrinter::visit(NameId *name) _name = QLatin1String("anonymous"); } -void NamePrettyPrinter::visit(TemplateNameId *name) +void NamePrettyPrinter::visit(const TemplateNameId *name) { const Identifier *id = name->identifier(); if (id) @@ -93,14 +93,14 @@ void NamePrettyPrinter::visit(TemplateNameId *name) _name += QLatin1Char('>'); } -void NamePrettyPrinter::visit(DestructorNameId *name) +void NamePrettyPrinter::visit(const DestructorNameId *name) { const Identifier *id = name->identifier(); _name += QLatin1Char('~'); _name += QString::fromLatin1(id->chars(), id->size()); } -void NamePrettyPrinter::visit(OperatorNameId *name) +void NamePrettyPrinter::visit(const OperatorNameId *name) { _name += QLatin1String("operator "); switch (name->kind()) { // ### i should probably do this in OperatorNameId @@ -236,13 +236,13 @@ void NamePrettyPrinter::visit(OperatorNameId *name) } // switch } -void NamePrettyPrinter::visit(ConversionNameId *name) +void NamePrettyPrinter::visit(const ConversionNameId *name) { _name += QLatin1String("operator "); _name += overview()->prettyType(name->type()); } -void NamePrettyPrinter::visit(QualifiedNameId *name) +void NamePrettyPrinter::visit(const QualifiedNameId *name) { if (name->isGlobal()) _name += QLatin1String("::"); @@ -254,10 +254,10 @@ void NamePrettyPrinter::visit(QualifiedNameId *name) } } -void NamePrettyPrinter::visit(SelectorNameId *name) +void NamePrettyPrinter::visit(const SelectorNameId *name) { for (unsigned i = 0; i < name->nameCount(); ++i) { - Name *n = name->nameAt(i); + const Name *n = name->nameAt(i); if (!n) continue; diff --git a/src/libs/cplusplus/NamePrettyPrinter.h b/src/libs/cplusplus/NamePrettyPrinter.h index f1855bb2ab5..d1d40696252 100644 --- a/src/libs/cplusplus/NamePrettyPrinter.h +++ b/src/libs/cplusplus/NamePrettyPrinter.h @@ -44,18 +44,18 @@ public: virtual ~NamePrettyPrinter(); const Overview *overview() const; - QString operator()(Name *name); + QString operator()(const Name *name); protected: QString switchName(const QString &name = QString()); - virtual void visit(NameId *name); - virtual void visit(TemplateNameId *name); - virtual void visit(DestructorNameId *name); - virtual void visit(OperatorNameId *name); - virtual void visit(ConversionNameId *name); - virtual void visit(QualifiedNameId *name); - virtual void visit(SelectorNameId *name); + virtual void visit(const NameId *name); + virtual void visit(const TemplateNameId *name); + virtual void visit(const DestructorNameId *name); + virtual void visit(const OperatorNameId *name); + virtual void visit(const ConversionNameId *name); + virtual void visit(const QualifiedNameId *name); + virtual void visit(const SelectorNameId *name); private: const Overview *_overview; diff --git a/src/libs/cplusplus/Overview.cpp b/src/libs/cplusplus/Overview.cpp index 19ac3b95bbe..6f4483187ef 100644 --- a/src/libs/cplusplus/Overview.cpp +++ b/src/libs/cplusplus/Overview.cpp @@ -117,13 +117,13 @@ void Overview::setShowFullyQualifiedNamed(bool showFullyQualifiedNames) _showFullyQualifiedNames = showFullyQualifiedNames; } -QString Overview::prettyName(Name *name) const +QString Overview::prettyName(const Name *name) const { NamePrettyPrinter pp(this); return pp(name); } -QString Overview::prettyType(const FullySpecifiedType &ty, Name *name) const +QString Overview::prettyType(const FullySpecifiedType &ty, const Name *name) const { return prettyType(ty, prettyName(name)); } diff --git a/src/libs/cplusplus/Overview.h b/src/libs/cplusplus/Overview.h index 95ab7515db3..756a2307fe6 100644 --- a/src/libs/cplusplus/Overview.h +++ b/src/libs/cplusplus/Overview.h @@ -66,14 +66,14 @@ public: int markedArgumentEnd() const; void setMarkedArgumentEnd(int end); - QString operator()(Name *name) const + QString operator()(const Name *name) const { return prettyName(name); } - QString operator()(const FullySpecifiedType &type, Name *name = 0) const + QString operator()(const FullySpecifiedType &type, const Name *name = 0) const { return prettyType(type, name); } - QString prettyName(Name *name) const; - QString prettyType(const FullySpecifiedType &type, Name *name = 0) const; + QString prettyName(const Name *name) const; + QString prettyType(const FullySpecifiedType &type, const Name *name = 0) const; QString prettyType(const FullySpecifiedType &type, const QString &name) const; private: diff --git a/src/libs/cplusplus/ResolveExpression.cpp b/src/libs/cplusplus/ResolveExpression.cpp index 3701728557d..c6aa2f9ae0f 100644 --- a/src/libs/cplusplus/ResolveExpression.cpp +++ b/src/libs/cplusplus/ResolveExpression.cpp @@ -181,11 +181,11 @@ bool ResolveExpression::visit(NewExpressionAST *ast) bool ResolveExpression::visit(TypeidExpressionAST *) { - Name *std_type_info[2]; + const Name *std_type_info[2]; std_type_info[0] = control()->nameId(control()->findOrInsertIdentifier("std")); std_type_info[1] = control()->nameId(control()->findOrInsertIdentifier("type_info")); - Name *q = control()->qualifiedNameId(std_type_info, 2, /*global=*/ true); + const Name *q = control()->qualifiedNameId(std_type_info, 2, /*global=*/ true); FullySpecifiedType ty(control()->namedType(q)); addResult(ty); @@ -277,8 +277,8 @@ bool ResolveExpression::visit(ThisExpressionAST *) FullySpecifiedType ptrTy(control()->pointerType(classTy)); addResult(ptrTy, fun); break; - } else if (QualifiedNameId *q = fun->name()->asQualifiedNameId()) { - Name *nestedNameSpecifier = 0; + } else if (const QualifiedNameId *q = fun->name()->asQualifiedNameId()) { + const Name *nestedNameSpecifier = 0; if (q->nameCount() == 1 && q->isGlobal()) nestedNameSpecifier = q->nameAt(0); else @@ -355,7 +355,7 @@ bool ResolveExpression::visit(CompoundLiteralAST *ast) bool ResolveExpression::visit(QualifiedNameAST *ast) { ResolveClass resolveClass; - Name *name = ast->name; + const Name *name = ast->name; QList<Symbol *> symbols = _context.resolve(name); foreach (Symbol *symbol, symbols) { @@ -451,7 +451,7 @@ bool ResolveExpression::visit(CallAST *ast) ++actualArgumentCount; } - Name *functionCallOp = control()->operatorNameId(OperatorNameId::FunctionCallOp); + const Name *functionCallOp = control()->operatorNameId(OperatorNameId::FunctionCallOp); foreach (const LookupItem &result, baseResults) { FullySpecifiedType ty = result.type().simplified(); @@ -495,7 +495,7 @@ bool ResolveExpression::visit(ArrayAccessAST *ast) const QList<LookupItem> indexResults = operator()(ast->expression); ResolveClass resolveClass; - Name *arrayAccessOp = control()->operatorNameId(OperatorNameId::ArrayAccessOp); + const Name *arrayAccessOp = control()->operatorNameId(OperatorNameId::ArrayAccessOp); foreach (const LookupItem &result, baseResults) { FullySpecifiedType ty = result.type().simplified(); @@ -537,7 +537,7 @@ bool ResolveExpression::visit(MemberAccessAST *ast) QList<LookupItem> baseResults = _results; // Evaluate the expression-id that follows the access operator. - Name *memberName = 0; + const Name *memberName = 0; if (ast->member_name) memberName = ast->member_name->name; @@ -594,7 +594,7 @@ ResolveExpression::resolveBaseExpression(const QList<LookupItem> &baseResults, i if (NamedType *namedTy = ty->asNamedType()) { ResolveClass resolveClass; - Name *arrowAccessOp = control()->operatorNameId(OperatorNameId::ArrowOp); + const Name *arrowAccessOp = control()->operatorNameId(OperatorNameId::ArrowOp); const QList<Symbol *> candidates = resolveClass(namedTy->name(), result, _context); foreach (Symbol *classObject, candidates) { @@ -663,7 +663,7 @@ ResolveExpression::resolveBaseExpression(const QList<LookupItem> &baseResults, i QList<LookupItem> ResolveExpression::resolveMemberExpression(const QList<LookupItem> &baseResults, unsigned accessOp, - Name *memberName, + const Name *memberName, bool *replacedDotOperator) const { ResolveClass resolveClass; @@ -677,7 +677,7 @@ ResolveExpression::resolveMemberExpression(const QList<LookupItem> &baseResults, results += resolveMember(memberName, klass); else if (NamedType *namedTy = ty->asNamedType()) { - Name *className = namedTy->name(); + const Name *className = namedTy->name(); const QList<Symbol *> classes = resolveClass(className, r, _context); foreach (Symbol *c, classes) { @@ -691,8 +691,8 @@ ResolveExpression::resolveMemberExpression(const QList<LookupItem> &baseResults, } QList<LookupItem> -ResolveExpression::resolveMember(Name *memberName, Class *klass, - Name *className) const +ResolveExpression::resolveMember(const Name *memberName, Class *klass, + const Name *className) const { QList<LookupItem> results; @@ -709,19 +709,19 @@ ResolveExpression::resolveMember(Name *memberName, Class *klass, foreach (Symbol *candidate, candidates) { FullySpecifiedType ty = candidate->type(); - Name *unqualifiedNameId = className; + const Name *unqualifiedNameId = className; - if (QualifiedNameId *q = className->asQualifiedNameId()) + if (const QualifiedNameId *q = className->asQualifiedNameId()) unqualifiedNameId = q->unqualifiedNameId(); - if (TemplateNameId *templId = unqualifiedNameId->asTemplateNameId()) { + if (const TemplateNameId *templId = unqualifiedNameId->asTemplateNameId()) { GenTemplateInstance::Substitution subst; for (unsigned i = 0; i < templId->templateArgumentCount(); ++i) { FullySpecifiedType templArgTy = templId->templateArgumentAt(i); if (i < klass->templateParameterCount()) { - Name *templArgName = klass->templateParameterAt(i)->name(); + const Name *templArgName = klass->templateParameterAt(i)->name(); if (templArgName && templArgName->identifier()) { const Identifier *templArgId = templArgName->identifier(); subst.append(qMakePair(templArgId, templArgTy)); @@ -741,7 +741,7 @@ ResolveExpression::resolveMember(Name *memberName, Class *klass, QList<LookupItem> -ResolveExpression::resolveMember(Name *memberName, ObjCClass *klass) const +ResolveExpression::resolveMember(const Name *memberName, ObjCClass *klass) const { QList<LookupItem> results; @@ -774,7 +774,7 @@ bool ResolveExpression::visit(ObjCMessageExpressionAST *ast) if (!receiverResults.isEmpty()) { LookupItem result = receiverResults.first(); FullySpecifiedType ty = result.type().simplified(); - Name *klassName = 0; + const Name *klassName = 0; if (const ObjCClass *classTy = ty->asObjCClassType()) { // static access, e.g.: @@ -805,7 +805,7 @@ bool ResolveExpression::visit(ObjCMessageExpressionAST *ast) ResolveClass::ResolveClass() { } -QList<Symbol *> ResolveClass::operator()(Name *name, +QList<Symbol *> ResolveClass::operator()(const Name *name, const LookupItem &p, const LookupContext &context) { @@ -815,7 +815,7 @@ QList<Symbol *> ResolveClass::operator()(Name *name, return symbols; } -QList<Symbol *> ResolveClass::resolveClass(Name *name, +QList<Symbol *> ResolveClass::resolveClass(const Name *name, const LookupItem &p, const LookupContext &context) { @@ -873,7 +873,7 @@ QList<Symbol *> ResolveClass::resolveClass(Name *name, ResolveObjCClass::ResolveObjCClass() {} -QList<Symbol *> ResolveObjCClass::operator ()(Name *name, +QList<Symbol *> ResolveObjCClass::operator ()(const Name *name, const LookupItem &p, const LookupContext &context) { diff --git a/src/libs/cplusplus/ResolveExpression.h b/src/libs/cplusplus/ResolveExpression.h index f4c00352daa..1d613228d83 100644 --- a/src/libs/cplusplus/ResolveExpression.h +++ b/src/libs/cplusplus/ResolveExpression.h @@ -48,17 +48,17 @@ public: QList<LookupItem> resolveMemberExpression(const QList<LookupItem> &baseResults, unsigned accessOp, - Name *memberName, + const Name *memberName, bool *replacedDotOperator = 0) const; QList<LookupItem> resolveBaseExpression(const QList<LookupItem> &baseResults, int accessOp, bool *replacedDotOperator = 0) const; - QList<LookupItem> resolveMember(Name *memberName, Class *klass, - Name *className = 0) const; + QList<LookupItem> resolveMember(const Name *memberName, Class *klass, + const Name *className = 0) const; - QList<LookupItem> resolveMember(Name *memberName, ObjCClass *klass) const; + QList<LookupItem> resolveMember(const Name *memberName, ObjCClass *klass) const; protected: QList<LookupItem> switchResults(const QList<LookupItem> &symbols); @@ -125,12 +125,12 @@ class CPLUSPLUS_EXPORT ResolveClass public: ResolveClass(); - QList<Symbol *> operator()(Name *name, + QList<Symbol *> operator()(const Name *name, const LookupItem &p, const LookupContext &context); private: - QList<Symbol *> resolveClass(Name *name, + QList<Symbol *> resolveClass(const Name *name, const LookupItem &p, const LookupContext &context); @@ -143,7 +143,7 @@ class CPLUSPLUS_EXPORT ResolveObjCClass public: ResolveObjCClass(); - QList<Symbol *> operator()(Name *name, + QList<Symbol *> operator()(const Name *name, const LookupItem &p, const LookupContext &context); }; diff --git a/src/libs/cplusplus/TypePrettyPrinter.cpp b/src/libs/cplusplus/TypePrettyPrinter.cpp index 3baa14c06d0..2434e866127 100644 --- a/src/libs/cplusplus/TypePrettyPrinter.cpp +++ b/src/libs/cplusplus/TypePrettyPrinter.cpp @@ -327,7 +327,7 @@ void TypePrettyPrinter::visit(Function *type) if (index + 1 == _overview->markedArgument()) const_cast<Overview*>(_overview)->setMarkedArgumentBegin(_text.length()); - Name *name = 0; + const Name *name = 0; if (_overview->showArgumentNames()) name = arg->name(); diff --git a/src/plugins/cppeditor/cppeditor.cpp b/src/plugins/cppeditor/cppeditor.cpp index e627e4ddc3f..7e8c06f14fa 100644 --- a/src/plugins/cppeditor/cppeditor.cpp +++ b/src/plugins/cppeditor/cppeditor.cpp @@ -477,7 +477,7 @@ protected: class FindFunctionDefinitions: protected SymbolVisitor { - Name *_declarationName; + const Name *_declarationName; QList<Function *> *_functions; public: @@ -486,7 +486,7 @@ public: _functions(0) { } - void operator()(Name *declarationName, Scope *globals, + void operator()(const Name *declarationName, Scope *globals, QList<Function *> *functions) { _declarationName = declarationName; @@ -502,8 +502,8 @@ protected: virtual bool visit(Function *function) { - Name *name = function->name(); - if (QualifiedNameId *q = name->asQualifiedNameId()) + const Name *name = function->name(); + if (const QualifiedNameId *q = name->asQualifiedNameId()) name = q->unqualifiedNameId(); if (_declarationName->isEqualTo(name)) @@ -515,19 +515,19 @@ protected: } // end of anonymous namespace -static QualifiedNameId *qualifiedNameIdForSymbol(Symbol *s, const LookupContext &context) +static const QualifiedNameId *qualifiedNameIdForSymbol(Symbol *s, const LookupContext &context) { - Name *symbolName = s->name(); + const Name *symbolName = s->name(); if (! symbolName) return 0; // nothing to do. - QVector<Name *> names; + QVector<const Name *> names; for (Scope *scope = s->scope(); scope; scope = scope->enclosingScope()) { if (scope->isClassScope() || scope->isNamespaceScope()) { if (scope->owner() && scope->owner()->name()) { - Name *ownerName = scope->owner()->name(); - if (QualifiedNameId *q = ownerName->asQualifiedNameId()) { + const Name *ownerName = scope->owner()->name(); + if (const QualifiedNameId *q = ownerName->asQualifiedNameId()) { for (unsigned i = 0; i < q->nameCount(); ++i) { names.prepend(q->nameAt(i)); } @@ -538,7 +538,7 @@ static QualifiedNameId *qualifiedNameIdForSymbol(Symbol *s, const LookupContext } } - if (QualifiedNameId *q = symbolName->asQualifiedNameId()) { + if (const QualifiedNameId *q = symbolName->asQualifiedNameId()) { for (unsigned i = 0; i < q->nameCount(); ++i) { names.append(q->nameAt(i)); } @@ -1021,27 +1021,28 @@ void CPPEditor::updateUsesNow() semanticRehighlight(); } -static bool isCompatible(Name *name, Name *otherName) +static bool isCompatible(const Name *name, const Name *otherName) { - if (NameId *nameId = name->asNameId()) { - if (TemplateNameId *otherTemplId = otherName->asTemplateNameId()) + if (const NameId *nameId = name->asNameId()) { + if (const TemplateNameId *otherTemplId = otherName->asTemplateNameId()) return nameId->identifier()->isEqualTo(otherTemplId->identifier()); - } else if (TemplateNameId *templId = name->asTemplateNameId()) { - if (NameId *otherNameId = otherName->asNameId()) + } else if (const TemplateNameId *templId = name->asTemplateNameId()) { + if (const NameId *otherNameId = otherName->asNameId()) return templId->identifier()->isEqualTo(otherNameId->identifier()); } return name->isEqualTo(otherName); } -static bool isCompatible(Function *definition, Symbol *declaration, QualifiedNameId *declarationName) +static bool isCompatible(Function *definition, Symbol *declaration, + const QualifiedNameId *declarationName) { Function *declTy = declaration->type()->asFunctionType(); if (! declTy) return false; - Name *definitionName = definition->name(); - if (QualifiedNameId *q = definitionName->asQualifiedNameId()) { + const Name *definitionName = definition->name(); + if (const QualifiedNameId *q = definitionName->asQualifiedNameId()) { if (! isCompatible(q->unqualifiedNameId(), declaration->name())) return false; else if (q->nameCount() > declarationName->nameCount()) @@ -1061,8 +1062,8 @@ static bool isCompatible(Function *definition, Symbol *declaration, QualifiedNam } for (unsigned i = 0; i != q->nameCount(); ++i) { - Name *n = q->nameAt(q->nameCount() - i - 1); - Name *m = declarationName->nameAt(declarationName->nameCount() - i - 1); + const Name *n = q->nameAt(q->nameCount() - i - 1); + const Name *m = declarationName->nameAt(declarationName->nameCount() - i - 1); if (! isCompatible(n, m)) return false; } @@ -1105,7 +1106,7 @@ void CPPEditor::switchDeclarationDefinition() QList<LookupItem> resolvedSymbols = typeOfExpression(QString(), doc, lastSymbol); const LookupContext &context = typeOfExpression.lookupContext(); - QualifiedNameId *q = qualifiedNameIdForSymbol(f, context); + const QualifiedNameId *q = qualifiedNameIdForSymbol(f, context); QList<Symbol *> symbols = context.resolve(q); Symbol *declaration = 0; @@ -1278,11 +1279,11 @@ Symbol *CPPEditor::findDefinition(Symbol *symbol) if (! funTy) return 0; // symbol does not have function type. - Name *name = symbol->name(); + const Name *name = symbol->name(); if (! name) return 0; // skip anonymous functions! - if (QualifiedNameId *q = name->asQualifiedNameId()) + if (const QualifiedNameId *q = name->asQualifiedNameId()) name = q->unqualifiedNameId(); // map from file names to function definitions. diff --git a/src/plugins/cppeditor/cpphoverhandler.cpp b/src/plugins/cppeditor/cpphoverhandler.cpp index 5bcaba448d6..3db38f6f716 100644 --- a/src/plugins/cppeditor/cpphoverhandler.cpp +++ b/src/plugins/cppeditor/cpphoverhandler.cpp @@ -138,7 +138,7 @@ void CppHoverHandler::showToolTip(TextEditor::ITextEditor *editor, const QPoint } } -static QString buildHelpId(Symbol *symbol, Name *name) +static QString buildHelpId(Symbol *symbol, const Name *name) { Scope *scope = 0; @@ -161,13 +161,13 @@ static QString buildHelpId(Symbol *symbol, Name *name) Symbol *owner = scope->owner(); if (owner && owner->name() && ! scope->isEnumScope()) { - Name *name = owner->name(); + const Name *name = owner->name(); const Identifier *id = 0; - if (NameId *nameId = name->asNameId()) + if (const NameId *nameId = name->asNameId()) id = nameId->identifier(); - else if (TemplateNameId *nameId = name->asTemplateNameId()) + else if (const TemplateNameId *nameId = name->asTemplateNameId()) id = nameId->identifier(); if (id) @@ -182,7 +182,7 @@ static QString buildHelpId(Symbol *symbol, Name *name) static FullySpecifiedType resolve(const FullySpecifiedType &ty, const LookupContext &context, Symbol **resolvedSymbol, - Name **resolvedName) + const Name **resolvedName) { Control *control = context.control(); @@ -334,7 +334,7 @@ void CppHoverHandler::updateHelpIdAndTooltip(TextEditor::ITextEditor *editor, in Symbol *lookupSymbol = result.lastVisibleSymbol(); // lookup symbol Symbol *resolvedSymbol = lookupSymbol; - Name *resolvedName = lookupSymbol ? lookupSymbol->name() : 0; + const Name *resolvedName = lookupSymbol ? lookupSymbol->name() : 0; firstType = resolve(firstType, typeOfExpression.lookupContext(), &resolvedSymbol, &resolvedName); diff --git a/src/plugins/cpptools/cppcodecompletion.cpp b/src/plugins/cpptools/cppcodecompletion.cpp index 37ea378d2e1..a61cfde23ff 100644 --- a/src/plugins/cpptools/cppcodecompletion.cpp +++ b/src/plugins/cpptools/cppcodecompletion.cpp @@ -192,7 +192,7 @@ protected: return previousItem; } - TextEditor::CompletionItem newCompletionItem(Name *name) + TextEditor::CompletionItem newCompletionItem(const Name *name) { TextEditor::CompletionItem item(_collector); item.text = overview.prettyName(name); @@ -200,25 +200,25 @@ protected: return item; } - virtual void visit(NameId *name) + virtual void visit(const NameId *name) { _item = newCompletionItem(name); } - virtual void visit(TemplateNameId *name) + virtual void visit(const TemplateNameId *name) { _item = newCompletionItem(name); _item.text = QLatin1String(name->identifier()->chars()); } - virtual void visit(DestructorNameId *name) + virtual void visit(const DestructorNameId *name) { _item = newCompletionItem(name); } - virtual void visit(OperatorNameId *name) + virtual void visit(const OperatorNameId *name) { _item = newCompletionItem(name); } - virtual void visit(ConversionNameId *name) + virtual void visit(const ConversionNameId *name) { _item = newCompletionItem(name); } - virtual void visit(QualifiedNameId *name) + virtual void visit(const QualifiedNameId *name) { _item = newCompletionItem(name->unqualifiedNameId()); } }; @@ -890,13 +890,13 @@ bool CppCodeCompletion::completeConstructorOrFunction(const QList<LookupItem> &r FullySpecifiedType exprTy = result.type().simplified(); if (Class *klass = exprTy->asClassType()) { - Name *className = klass->name(); + const Name *className = klass->name(); if (! className) continue; // nothing to do for anonymoous classes. for (unsigned i = 0; i < klass->memberCount(); ++i) { Symbol *member = klass->memberAt(i); - Name *memberName = member->name(); + const Name *memberName = member->name(); if (! memberName) continue; // skip anonymous member. @@ -945,7 +945,7 @@ bool CppCodeCompletion::completeConstructorOrFunction(const QList<LookupItem> &r if (functions.isEmpty()) { ResolveExpression resolveExpression(context); ResolveClass resolveClass; - Name *functionCallOp = context.control()->operatorNameId(OperatorNameId::FunctionCallOp); + const Name *functionCallOp = context.control()->operatorNameId(OperatorNameId::FunctionCallOp); foreach (const LookupItem &result, results) { FullySpecifiedType ty = result.type().simplified(); @@ -1092,7 +1092,7 @@ bool CppCodeCompletion::completeMember(const QList<LookupItem> &baseResults, classObjectCandidates.append(klass); else if (NamedType *namedTy = ty->asNamedType()) { - Name *className = namedTy->name(); + const Name *className = namedTy->name(); const QList<Symbol *> classes = resolveClass(className, r, context); foreach (Symbol *c, classes) { diff --git a/src/plugins/cpptools/searchsymbols.cpp b/src/plugins/cpptools/searchsymbols.cpp index ae2c6edc641..1e101cb4ef0 100644 --- a/src/plugins/cpptools/searchsymbols.cpp +++ b/src/plugins/cpptools/searchsymbols.cpp @@ -95,8 +95,8 @@ bool SearchSymbols::visit(Function *symbol) return false; QString extraScope; - if (Name *name = symbol->name()) { - if (QualifiedNameId *nameId = name->asQualifiedNameId()) { + if (const Name *name = symbol->name()) { + if (const QualifiedNameId *nameId = name->asQualifiedNameId()) { if (nameId->nameCount() > 1) { extraScope = overview.prettyName(nameId->nameAt(nameId->nameCount() - 2)); } diff --git a/src/plugins/designer/qtcreatorintegration.cpp b/src/plugins/designer/qtcreatorintegration.cpp index 636627c40f8..4f08b925fae 100644 --- a/src/plugins/designer/qtcreatorintegration.cpp +++ b/src/plugins/designer/qtcreatorintegration.cpp @@ -251,8 +251,8 @@ static bool isCompatible(const Function *definition, const Symbol *declaration, if (! declTy) return false; - Name *definitionName = definition->name(); - if (QualifiedNameId *q = definitionName->asQualifiedNameId()) { + const Name *definitionName = definition->name(); + if (const QualifiedNameId *q = definitionName->asQualifiedNameId()) { if (! isCompatible(q->unqualifiedNameId(), declaration->name())) return false; else if (q->nameCount() > declarationName->nameCount()) @@ -272,8 +272,8 @@ static bool isCompatible(const Function *definition, const Symbol *declaration, } for (unsigned i = 0; i != q->nameCount(); ++i) { - Name *n = q->nameAt(q->nameCount() - i - 1); - Name *m = declarationName->nameAt(declarationName->nameCount() - i - 1); + const Name *n = q->nameAt(q->nameCount() - i - 1); + const Name *m = declarationName->nameAt(declarationName->nameCount() - i - 1); if (! isCompatible(n, m)) return false; } @@ -291,13 +291,13 @@ static Document::Ptr findDefinition(const Function *functionDeclaration, int *li if (!cppModelManager) return Document::Ptr(); - QVector<Name *> qualifiedName; + QVector<const Name *> qualifiedName; Scope *scope = functionDeclaration->scope(); for (; scope; scope = scope->enclosingScope()) { if (scope->isClassScope() || scope->isNamespaceScope()) { if (scope->owner() && scope->owner()->name()) { - Name *scopeOwnerName = scope->owner()->name(); - if (QualifiedNameId *q = scopeOwnerName->asQualifiedNameId()) { + const Name *scopeOwnerName = scope->owner()->name(); + if (const QualifiedNameId *q = scopeOwnerName->asQualifiedNameId()) { for (unsigned i = 0; i < q->nameCount(); ++i) { qualifiedName.prepend(q->nameAt(i)); @@ -312,7 +312,7 @@ static Document::Ptr findDefinition(const Function *functionDeclaration, int *li qualifiedName.append(functionDeclaration->name()); Control control; - QualifiedNameId *q = control.qualifiedNameId(&qualifiedName[0], qualifiedName.size()); + const QualifiedNameId *q = control.qualifiedNameId(&qualifiedName[0], qualifiedName.size()); LookupContext context(&control); const Snapshot documents = cppModelManager->snapshot(); foreach (Document::Ptr doc, documents) { @@ -321,13 +321,13 @@ static Document::Ptr findDefinition(const Function *functionDeclaration, int *li visibleScopes = context.expand(visibleScopes); foreach (Scope *visibleScope, visibleScopes) { Symbol *symbol = 0; - if (NameId *nameId = q->unqualifiedNameId()->asNameId()) + if (const NameId *nameId = q->unqualifiedNameId()->asNameId()) symbol = visibleScope->lookat(nameId->identifier()); - else if (DestructorNameId *dtorId = q->unqualifiedNameId()->asDestructorNameId()) + else if (const DestructorNameId *dtorId = q->unqualifiedNameId()->asDestructorNameId()) symbol = visibleScope->lookat(dtorId->identifier()); - else if (TemplateNameId *templNameId = q->unqualifiedNameId()->asTemplateNameId()) + else if (const TemplateNameId *templNameId = q->unqualifiedNameId()->asTemplateNameId()) symbol = visibleScope->lookat(templNameId->identifier()); - else if (OperatorNameId *opId = q->unqualifiedNameId()->asOperatorNameId()) + else if (const OperatorNameId *opId = q->unqualifiedNameId()->asOperatorNameId()) symbol = visibleScope->lookat(opId->kind()); // ### cast operators for (; symbol; symbol = symbol->next()) { diff --git a/src/shared/cplusplus/AST.h b/src/shared/cplusplus/AST.h index 3902fcb5c52..47342c2e045 100644 --- a/src/shared/cplusplus/AST.h +++ b/src/shared/cplusplus/AST.h @@ -303,7 +303,7 @@ public: class CPLUSPLUS_EXPORT NameAST: public ExpressionAST { public: // annotations - Name *name; + const Name *name; public: virtual NameAST *asName() { return this; } @@ -342,7 +342,7 @@ public: class CPLUSPLUS_EXPORT ObjCSelectorAST: public AST { public: // annotation - Name *selector_name; + const Name *selector_name; public: virtual ObjCSelectorAST *asObjCSelector() { return this; } diff --git a/src/shared/cplusplus/CheckDeclaration.cpp b/src/shared/cplusplus/CheckDeclaration.cpp index 3fa5922a026..bd6be26743f 100644 --- a/src/shared/cplusplus/CheckDeclaration.cpp +++ b/src/shared/cplusplus/CheckDeclaration.cpp @@ -153,7 +153,7 @@ bool CheckDeclaration::visit(SimpleDeclarationAST *ast) if (elab_type_spec->name) sourceLocation = elab_type_spec->name->firstToken(); - Name *name = semantic()->check(elab_type_spec->name, _scope); + const Name *name = semantic()->check(elab_type_spec->name, _scope); ForwardClassDeclaration *symbol = control()->newForwardClassDeclaration(sourceLocation, name); @@ -172,7 +172,7 @@ bool CheckDeclaration::visit(SimpleDeclarationAST *ast) List<Declaration *> **decl_it = &ast->symbols; for (DeclaratorListAST *it = ast->declarator_list; it; it = it->next) { - Name *name = 0; + const Name *name = 0; FullySpecifiedType declTy = semantic()->check(it->value, qualTy, _scope, &name); @@ -268,7 +268,7 @@ bool CheckDeclaration::visit(ExceptionDeclarationAST *ast) FullySpecifiedType ty = semantic()->check(ast->type_specifier_list, _scope); FullySpecifiedType qualTy = ty.qualifiedType(); - Name *name = 0; + const Name *name = 0; FullySpecifiedType declTy = semantic()->check(ast->declarator, qualTy, _scope, &name); @@ -293,7 +293,7 @@ bool CheckDeclaration::visit(FunctionDefinitionAST *ast) { FullySpecifiedType ty = semantic()->check(ast->decl_specifier_list, _scope); FullySpecifiedType qualTy = ty.qualifiedType(); - Name *name = 0; + const Name *name = 0; FullySpecifiedType funTy = semantic()->check(ast->declarator, qualTy, _scope, &name); if (! (funTy && funTy->isFunctionType())) { @@ -379,7 +379,7 @@ bool CheckDeclaration::visit(LinkageSpecificationAST *ast) bool CheckDeclaration::visit(NamespaceAST *ast) { const Identifier *id = identifier(ast->identifier_token); - Name *namespaceName = control()->nameId(id); + const Name *namespaceName = control()->nameId(id); unsigned sourceLocation = ast->firstToken(); @@ -411,7 +411,7 @@ bool CheckDeclaration::visit(ParameterDeclarationAST *ast) sourceLocation = ast->firstToken(); } - Name *argName = 0; + const Name *argName = 0; FullySpecifiedType ty = semantic()->check(ast->type_specifier_list, _scope); FullySpecifiedType argTy = semantic()->check(ast->declarator, ty.qualifiedType(), _scope, &argName); @@ -445,7 +445,7 @@ bool CheckDeclaration::visit(TypenameTypeParameterAST *ast) if (ast->name) sourceLocation = ast->name->firstToken(); - Name *name = semantic()->check(ast->name, _scope); + const Name *name = semantic()->check(ast->name, _scope); Argument *arg = control()->newArgument(sourceLocation, name); // ### new template type ast->symbol = arg; _scope->enterSymbol(arg); @@ -458,7 +458,7 @@ bool CheckDeclaration::visit(TemplateTypeParameterAST *ast) if (ast->name) sourceLocation = ast->name->firstToken(); - Name *name = semantic()->check(ast->name, _scope); + const Name *name = semantic()->check(ast->name, _scope); Argument *arg = control()->newArgument(sourceLocation, name); // ### new template type ast->symbol = arg; _scope->enterSymbol(arg); @@ -467,7 +467,7 @@ bool CheckDeclaration::visit(TemplateTypeParameterAST *ast) bool CheckDeclaration::visit(UsingAST *ast) { - Name *name = semantic()->check(ast->name, _scope); + const Name *name = semantic()->check(ast->name, _scope); unsigned sourceLocation = ast->firstToken(); if (ast->name) @@ -481,7 +481,7 @@ bool CheckDeclaration::visit(UsingAST *ast) bool CheckDeclaration::visit(UsingDirectiveAST *ast) { - Name *name = semantic()->check(ast->name, _scope); + const Name *name = semantic()->check(ast->name, _scope); unsigned sourceLocation = ast->firstToken(); if (ast->name) @@ -510,7 +510,7 @@ bool CheckDeclaration::visit(ObjCProtocolForwardDeclarationAST *ast) else declarationLocation = sourceLocation; - Name *protocolName = semantic()->check(it->value, _scope); + const Name *protocolName = semantic()->check(it->value, _scope); ObjCForwardProtocolDeclaration *fwdProtocol = control()->newObjCForwardProtocolDeclaration(sourceLocation, protocolName); fwdProtocol->setStartOffset(tokenAt(ast->firstToken()).offset); fwdProtocol->setEndOffset(tokenAt(ast->lastToken()).offset); @@ -533,7 +533,7 @@ bool CheckDeclaration::visit(ObjCProtocolDeclarationAST *ast) else sourceLocation = ast->firstToken(); - Name *protocolName = semantic()->check(ast->name, _scope); + const Name *protocolName = semantic()->check(ast->name, _scope); ObjCProtocol *protocol = control()->newObjCProtocol(sourceLocation, protocolName); protocol->setStartOffset(tokenAt(ast->firstToken()).offset); protocol->setEndOffset(tokenAt(ast->lastToken()).offset); @@ -541,7 +541,7 @@ bool CheckDeclaration::visit(ObjCProtocolDeclarationAST *ast) if (ast->protocol_refs && ast->protocol_refs->identifier_list) { for (ObjCIdentifierListAST *iter = ast->protocol_refs->identifier_list; iter; iter = iter->next) { NameAST* name = iter->value; - Name *protocolName = semantic()->check(name, _scope); + const Name *protocolName = semantic()->check(name, _scope); ObjCBaseProtocol *baseProtocol = control()->newObjCBaseProtocol(name->firstToken(), protocolName); protocol->addProtocol(baseProtocol); } @@ -571,7 +571,7 @@ bool CheckDeclaration::visit(ObjCClassForwardDeclarationAST *ast) else declarationLocation = sourceLocation; - Name *className = semantic()->check(it->value, _scope); + const Name *className = semantic()->check(it->value, _scope); ObjCForwardClassDeclaration *fwdClass = control()->newObjCForwardClassDeclaration(sourceLocation, className); fwdClass->setStartOffset(tokenAt(ast->firstToken()).offset); fwdClass->setEndOffset(tokenAt(ast->lastToken()).offset); @@ -594,7 +594,7 @@ bool CheckDeclaration::visit(ObjCClassDeclarationAST *ast) else sourceLocation = ast->firstToken(); - Name *className = semantic()->check(ast->class_name, _scope); + const Name *className = semantic()->check(ast->class_name, _scope); ObjCClass *klass = control()->newObjCClass(sourceLocation, className); klass->setStartOffset(tokenAt(ast->firstToken()).offset); klass->setEndOffset(tokenAt(ast->lastToken()).offset); @@ -603,12 +603,12 @@ bool CheckDeclaration::visit(ObjCClassDeclarationAST *ast) klass->setInterface(ast->interface_token != 0); if (ast->category_name) { - Name *categoryName = semantic()->check(ast->category_name, _scope); + const Name *categoryName = semantic()->check(ast->category_name, _scope); klass->setCategoryName(categoryName); } if (ast->superclass) { - Name *superClassName = semantic()->check(ast->superclass, _scope); + const Name *superClassName = semantic()->check(ast->superclass, _scope); ObjCBaseClass *superKlass = control()->newObjCBaseClass(ast->superclass->firstToken(), superClassName); klass->setBaseClass(superKlass); } @@ -616,7 +616,7 @@ bool CheckDeclaration::visit(ObjCClassDeclarationAST *ast) if (ast->protocol_refs && ast->protocol_refs->identifier_list) { for (ObjCIdentifierListAST *iter = ast->protocol_refs->identifier_list; iter; iter = iter->next) { NameAST* name = iter->value; - Name *protocolName = semantic()->check(name, _scope); + const Name *protocolName = semantic()->check(name, _scope); ObjCBaseProtocol *baseProtocol = control()->newObjCBaseProtocol(name->firstToken(), protocolName); klass->addProtocol(baseProtocol); } @@ -711,7 +711,7 @@ bool CheckDeclaration::visit(ObjCPropertyDeclarationAST *ast) } int propAttrs = ObjCPropertyDeclaration::None; - Name *getterName = 0, *setterName = 0; + const Name *getterName = 0, *setterName = 0; for (ObjCPropertyAttributeListAST *iter= ast->property_attribute_list; iter; iter = iter->next) { ObjCPropertyAttributeAST *attrAst = iter->value; diff --git a/src/shared/cplusplus/CheckDeclarator.cpp b/src/shared/cplusplus/CheckDeclarator.cpp index 9f283811059..7af4e02268a 100644 --- a/src/shared/cplusplus/CheckDeclarator.cpp +++ b/src/shared/cplusplus/CheckDeclarator.cpp @@ -70,12 +70,12 @@ CheckDeclarator::~CheckDeclarator() FullySpecifiedType CheckDeclarator::check(DeclaratorAST *declarator, const FullySpecifiedType &type, Scope *scope, - Name **name) + const Name **name) { FullySpecifiedType previousType = switchFullySpecifiedType(type); Scope *previousScope = switchScope(scope); DeclaratorAST *previousDeclarator = switchDeclarator(declarator); - Name **previousName = switchName(name); + const Name **previousName = switchName(name); accept(declarator); (void) switchName(previousName); (void) switchDeclarator(previousDeclarator); @@ -124,9 +124,9 @@ Scope *CheckDeclarator::switchScope(Scope *scope) return previousScope; } -Name **CheckDeclarator::switchName(Name **name) +const Name **CheckDeclarator::switchName(const Name **name) { - Name **previousName = _name; + const Name **previousName = _name; _name = name; return previousName; } @@ -149,7 +149,7 @@ bool CheckDeclarator::visit(DeclaratorAST *ast) bool CheckDeclarator::visit(DeclaratorIdAST *ast) { - Name *name = semantic()->check(ast->name, _scope); + const Name *name = semantic()->check(ast->name, _scope); if (_name) *_name = name; return false; @@ -219,7 +219,7 @@ bool CheckDeclarator::visit(ArrayDeclaratorAST *ast) bool CheckDeclarator::visit(PointerToMemberAST *ast) { - Name *memberName = semantic()->check(ast->nested_name_specifier_list, _scope); + const Name *memberName = semantic()->check(ast->nested_name_specifier_list, _scope); PointerToMemberType *ptrTy = control()->pointerToMemberType(memberName, _fullySpecifiedType); FullySpecifiedType ty(ptrTy); _fullySpecifiedType = ty; diff --git a/src/shared/cplusplus/CheckDeclarator.h b/src/shared/cplusplus/CheckDeclarator.h index 1b9e14cb813..81d6c0e4f5c 100644 --- a/src/shared/cplusplus/CheckDeclarator.h +++ b/src/shared/cplusplus/CheckDeclarator.h @@ -65,7 +65,7 @@ public: FullySpecifiedType check(DeclaratorAST *declarator, const FullySpecifiedType &type, Scope *scope, - Name **name); + const Name **name); FullySpecifiedType check(PtrOperatorListAST *ptrOperators, const FullySpecifiedType &type, @@ -78,7 +78,7 @@ protected: DeclaratorAST *switchDeclarator(DeclaratorAST *declarator); FullySpecifiedType switchFullySpecifiedType(const FullySpecifiedType &type); Scope *switchScope(Scope *scope); - Name **switchName(Name **name); + const Name **switchName(const Name **name); using ASTVisitor::visit; @@ -102,7 +102,7 @@ protected: private: DeclaratorAST *_declarator; Scope *_scope; - Name **_name; + const Name **_name; FullySpecifiedType _fullySpecifiedType; }; diff --git a/src/shared/cplusplus/CheckExpression.cpp b/src/shared/cplusplus/CheckExpression.cpp index ad1bb3a46e5..f8da07534c5 100644 --- a/src/shared/cplusplus/CheckExpression.cpp +++ b/src/shared/cplusplus/CheckExpression.cpp @@ -120,7 +120,7 @@ bool CheckExpression::visit(CastExpressionAST *ast) bool CheckExpression::visit(ConditionAST *ast) { FullySpecifiedType typeSpecTy = semantic()->check(ast->type_specifier_list, _scope); - Name *name = 0; + const Name *name = 0; FullySpecifiedType declTy = semantic()->check(ast->declarator, typeSpecTy.qualifiedType(), _scope, &name); Declaration *decl = control()->newDeclaration(ast->declarator->firstToken(), name); @@ -302,8 +302,7 @@ bool CheckExpression::visit(ThrowExpressionAST *ast) bool CheckExpression::visit(TypeIdAST *ast) { FullySpecifiedType typeSpecTy = semantic()->check(ast->type_specifier_list, _scope); - FullySpecifiedType declTy = semantic()->check(ast->declarator, typeSpecTy.qualifiedType(), - _scope); + FullySpecifiedType declTy = semantic()->check(ast->declarator, typeSpecTy.qualifiedType(), _scope); _fullySpecifiedType = declTy; return false; } @@ -316,7 +315,7 @@ bool CheckExpression::visit(UnaryExpressionAST *ast) bool CheckExpression::visit(QtMethodAST *ast) { - Name *name = 0; + const Name *name = 0; Scope dummy; FullySpecifiedType methTy = semantic()->check(ast->declarator, FullySpecifiedType(), &dummy, &name); diff --git a/src/shared/cplusplus/CheckName.cpp b/src/shared/cplusplus/CheckName.cpp index 1ad29a27d30..11688aba481 100644 --- a/src/shared/cplusplus/CheckName.cpp +++ b/src/shared/cplusplus/CheckName.cpp @@ -69,9 +69,9 @@ CheckName::CheckName(Semantic *semantic) CheckName::~CheckName() { } -Name *CheckName::check(NameAST *name, Scope *scope) +const Name *CheckName::check(NameAST *name, Scope *scope) { - Name *previousName = switchName(0); + const Name *previousName = switchName(0); Scope *previousScope = switchScope(scope); accept(name); @@ -82,12 +82,12 @@ Name *CheckName::check(NameAST *name, Scope *scope) return switchName(previousName); } -Name *CheckName::check(NestedNameSpecifierListAST *nested_name_specifier_list, Scope *scope) +const Name *CheckName::check(NestedNameSpecifierListAST *nested_name_specifier_list, Scope *scope) { - Name *previousName = switchName(0); + const Name *previousName = switchName(0); Scope *previousScope = switchScope(scope); - std::vector<Name *> names; + std::vector<const Name *> names; for (NestedNameSpecifierListAST *it = nested_name_specifier_list; it; it = it->next) { NestedNameSpecifierAST *nested_name_specifier = it->value; names.push_back(semantic()->check(nested_name_specifier->class_or_namespace_name, _scope)); @@ -100,9 +100,9 @@ Name *CheckName::check(NestedNameSpecifierListAST *nested_name_specifier_list, S return switchName(previousName); } -Name *CheckName::check(ObjCSelectorAST *args, Scope *scope) +const Name *CheckName::check(ObjCSelectorAST *args, Scope *scope) { - Name *previousName = switchName(0); + const Name *previousName = switchName(0); Scope *previousScope = switchScope(scope); accept(args); @@ -113,7 +113,7 @@ Name *CheckName::check(ObjCSelectorAST *args, Scope *scope) void CheckName::check(ObjCMessageArgumentDeclarationAST *arg, Scope *scope) { - Name *previousName = switchName(0); + const Name *previousName = switchName(0); Scope *previousScope = switchScope(scope); accept(arg); @@ -122,9 +122,9 @@ void CheckName::check(ObjCMessageArgumentDeclarationAST *arg, Scope *scope) (void) switchName(previousName); } -Name *CheckName::switchName(Name *name) +const Name *CheckName::switchName(const Name *name) { - Name *previousName = _name; + const Name *previousName = _name; _name = name; return previousName; } @@ -138,14 +138,13 @@ Scope *CheckName::switchScope(Scope *scope) bool CheckName::visit(QualifiedNameAST *ast) { - std::vector<Name *> names; + std::vector<const Name *> names; for (NestedNameSpecifierListAST *it = ast->nested_name_specifier_list; it; it = it->next) { NestedNameSpecifierAST *nested_name_specifier = it->value; names.push_back(semantic()->check(nested_name_specifier->class_or_namespace_name, _scope)); } names.push_back(semantic()->check(ast->unqualified_name, _scope)); - _name = control()->qualifiedNameId(&names[0], names.size(), - ast->global_scope_token != 0); + _name = control()->qualifiedNameId(&names[0], names.size(), ast->global_scope_token != 0); ast->name = _name; return false; @@ -379,9 +378,9 @@ bool CheckName::visit(TemplateIdAST *ast) bool CheckName::visit(ObjCSelectorWithoutArgumentsAST *ast) { if (ast->name_token) { - std::vector<Name *> names; + std::vector<const Name *> names; const Identifier *id = control()->findOrInsertIdentifier(spell(ast->name_token)); - NameId *nameId = control()->nameId(id); + const NameId *nameId = control()->nameId(id); names.push_back(nameId); _name = control()->selectorNameId(&names[0], names.size(), false); ast->selector_name = _name; @@ -392,11 +391,11 @@ bool CheckName::visit(ObjCSelectorWithoutArgumentsAST *ast) bool CheckName::visit(ObjCSelectorWithArgumentsAST *ast) { - std::vector<Name *> names; + std::vector<const Name *> names; for (ObjCSelectorArgumentListAST *it = ast->selector_argument_list; it; it = it->next) { if (it->value->name_token) { const Identifier *id = control()->findOrInsertIdentifier(spell(it->value->name_token)); - NameId *nameId = control()->nameId(id); + const NameId *nameId = control()->nameId(id); names.push_back(nameId); } else { // we have an incomplete name due, probably due to error recovery. So, back out completely diff --git a/src/shared/cplusplus/CheckName.h b/src/shared/cplusplus/CheckName.h index 7f86d751671..1484cb7848e 100644 --- a/src/shared/cplusplus/CheckName.h +++ b/src/shared/cplusplus/CheckName.h @@ -61,13 +61,13 @@ public: CheckName(Semantic *semantic); virtual ~CheckName(); - Name *check(NameAST *name, Scope *scope); - Name *check(NestedNameSpecifierListAST *name, Scope *scope); - Name *check(ObjCSelectorAST *args, Scope *scope); + const Name *check(NameAST *name, Scope *scope); + const Name *check(NestedNameSpecifierListAST *name, Scope *scope); + const Name *check(ObjCSelectorAST *args, Scope *scope); void check(ObjCMessageArgumentDeclarationAST *arg, Scope *scope); protected: - Name *switchName(Name *name); + const Name *switchName(const Name *name); Scope *switchScope(Scope *scope); using ASTVisitor::visit; @@ -85,7 +85,7 @@ protected: virtual bool visit(ObjCMessageArgumentDeclarationAST *ast); private: - Name *_name; + const Name *_name; Scope *_scope; }; diff --git a/src/shared/cplusplus/CheckSpecifier.cpp b/src/shared/cplusplus/CheckSpecifier.cpp index 7f06e2de386..03b2d53d97d 100644 --- a/src/shared/cplusplus/CheckSpecifier.cpp +++ b/src/shared/cplusplus/CheckSpecifier.cpp @@ -312,7 +312,7 @@ bool CheckSpecifier::visit(ClassSpecifierAST *ast) if (ast->name) sourceLocation = ast->name->firstToken(); - Name *className = semantic()->check(ast->name, _scope); + const Name *className = semantic()->check(ast->name, _scope); Class *klass = control()->newClass(sourceLocation, className); klass->setStartOffset(tokenAt(ast->firstToken()).offset); klass->setEndOffset(tokenAt(ast->lastToken()).offset); @@ -330,7 +330,7 @@ bool CheckSpecifier::visit(ClassSpecifierAST *ast) for (BaseSpecifierListAST *it = ast->base_clause_list; it; it = it->next) { BaseSpecifierAST *base = it->value; - Name *baseClassName = semantic()->check(base->name, _scope); + const Name *baseClassName = semantic()->check(base->name, _scope); BaseClass *baseClass = control()->newBaseClass(ast->firstToken(), baseClassName); base->symbol = baseClass; if (base->virtual_token) @@ -359,14 +359,14 @@ bool CheckSpecifier::visit(ClassSpecifierAST *ast) bool CheckSpecifier::visit(NamedTypeSpecifierAST *ast) { - Name *name = semantic()->check(ast->name, _scope); + const Name *name = semantic()->check(ast->name, _scope); _fullySpecifiedType.setType(control()->namedType(name)); return false; } bool CheckSpecifier::visit(ElaboratedTypeSpecifierAST *ast) { - Name *name = semantic()->check(ast->name, _scope); + const Name *name = semantic()->check(ast->name, _scope); _fullySpecifiedType.setType(control()->namedType(name)); return false; } @@ -377,7 +377,7 @@ bool CheckSpecifier::visit(EnumSpecifierAST *ast) if (ast->name) sourceLocation = ast->name->firstToken(); - Name *name = semantic()->check(ast->name, _scope); + const Name *name = semantic()->check(ast->name, _scope); Enum *e = control()->newEnum(sourceLocation, name); e->setStartOffset(tokenAt(ast->firstToken()).offset); e->setEndOffset(tokenAt(ast->lastToken()).offset); @@ -389,7 +389,7 @@ bool CheckSpecifier::visit(EnumSpecifierAST *ast) const Identifier *id = identifier(enumerator->identifier_token); if (! id) continue; - NameId *enumeratorName = control()->nameId(id); + const NameId *enumeratorName = control()->nameId(id); Declaration *decl = control()->newDeclaration(enumerator->firstToken(), enumeratorName); e->addMember(decl); diff --git a/src/shared/cplusplus/CheckStatement.cpp b/src/shared/cplusplus/CheckStatement.cpp index dec68b1ea4c..ec9f6590e29 100644 --- a/src/shared/cplusplus/CheckStatement.cpp +++ b/src/shared/cplusplus/CheckStatement.cpp @@ -154,7 +154,7 @@ bool CheckStatement::visit(ForeachStatementAST *ast) Scope *previousScope = switchScope(block->members()); if (ast->type_specifier_list && ast->declarator) { FullySpecifiedType ty = semantic()->check(ast->type_specifier_list, _scope); - Name *name = 0; + const Name *name = 0; ty = semantic()->check(ast->declarator, ty, _scope, &name); unsigned location = ast->declarator->firstToken(); if (CoreDeclaratorAST *core_declarator = ast->declarator->core_declarator) @@ -183,7 +183,7 @@ bool CheckStatement::visit(ObjCFastEnumerationAST *ast) Scope *previousScope = switchScope(block->members()); if (ast->type_specifier_list && ast->declarator) { FullySpecifiedType ty = semantic()->check(ast->type_specifier_list, _scope); - Name *name = 0; + const Name *name = 0; ty = semantic()->check(ast->declarator, ty, _scope, &name); unsigned location = ast->declarator->firstToken(); if (CoreDeclaratorAST *core_declarator = ast->declarator->core_declarator) @@ -312,7 +312,7 @@ bool CheckStatement::visit(WhileStatementAST *ast) bool CheckStatement::visit(QtMemberDeclarationAST *ast) { - Name *name = 0; + const Name *name = 0; if (tokenKind(ast->q_token) == T_Q_D) name = control()->nameId(control()->findOrInsertIdentifier("d")); @@ -323,12 +323,13 @@ bool CheckStatement::visit(QtMemberDeclarationAST *ast) if (tokenKind(ast->q_token) == T_Q_D) { if (NamedType *namedTy = declTy->asNamedType()) { - if (NameId *nameId = namedTy->name()->asNameId()) { + if (const NameId *nameId = namedTy->name()->asNameId()) { std::string privateClass; privateClass += nameId->identifier()->chars(); privateClass += "Private"; - Name *privName = control()->nameId(control()->findOrInsertIdentifier(privateClass.c_str(), privateClass.size())); + const Name *privName = control()->nameId(control()->findOrInsertIdentifier(privateClass.c_str(), + privateClass.size())); declTy.setType(control()->namedType(privName)); } } diff --git a/src/shared/cplusplus/Control.cpp b/src/shared/cplusplus/Control.cpp index 1cd2ad51b02..ec14aa796b3 100644 --- a/src/shared/cplusplus/Control.cpp +++ b/src/shared/cplusplus/Control.cpp @@ -184,79 +184,78 @@ public: delete_array_entries(symbols); } - NameId *findOrInsertNameId(const Identifier *id) + const NameId *findOrInsertNameId(const Identifier *id) { if (! id) return 0; - std::map<const Identifier *, NameId *>::iterator it = nameIds.lower_bound(id); + std::map<const Identifier *, const NameId *>::iterator it = nameIds.lower_bound(id); if (it == nameIds.end() || it->first != id) it = nameIds.insert(it, std::make_pair(id, new NameId(id))); return it->second; } - TemplateNameId *findOrInsertTemplateNameId(const Identifier *id, - const std::vector<FullySpecifiedType> &templateArguments) + const TemplateNameId *findOrInsertTemplateNameId(const Identifier *id, + const std::vector<FullySpecifiedType> &templateArguments) { if (! id) return 0; const TemplateNameIdKey key(id, templateArguments); - std::map<TemplateNameIdKey, TemplateNameId *>::iterator it = + std::map<TemplateNameIdKey, const TemplateNameId *>::iterator it = templateNameIds.lower_bound(key); if (it == templateNameIds.end() || it->first != key) { const FullySpecifiedType *args = 0; if (templateArguments.size()) args = &templateArguments[0]; - TemplateNameId *templ = new TemplateNameId(id, args, - templateArguments.size()); + const TemplateNameId *templ = new TemplateNameId(id, args, templateArguments.size()); it = templateNameIds.insert(it, std::make_pair(key, templ)); } return it->second; } - DestructorNameId *findOrInsertDestructorNameId(const Identifier *id) + const DestructorNameId *findOrInsertDestructorNameId(const Identifier *id) { if (! id) return 0; - std::map<const Identifier *, DestructorNameId *>::iterator it = destructorNameIds.lower_bound(id); + std::map<const Identifier *, const DestructorNameId *>::iterator it = destructorNameIds.lower_bound(id); if (it == destructorNameIds.end() || it->first != id) it = destructorNameIds.insert(it, std::make_pair(id, new DestructorNameId(id))); return it->second; } - OperatorNameId *findOrInsertOperatorNameId(int kind) + const OperatorNameId *findOrInsertOperatorNameId(int kind) { const int key(kind); - std::map<int, OperatorNameId *>::iterator it = operatorNameIds.lower_bound(key); + std::map<int, const OperatorNameId *>::iterator it = operatorNameIds.lower_bound(key); if (it == operatorNameIds.end() || it->first != key) it = operatorNameIds.insert(it, std::make_pair(key, new OperatorNameId(kind))); return it->second; } - ConversionNameId *findOrInsertConversionNameId(const FullySpecifiedType &type) + const ConversionNameId *findOrInsertConversionNameId(const FullySpecifiedType &type) { - std::map<FullySpecifiedType, ConversionNameId *>::iterator it = + std::map<FullySpecifiedType, const ConversionNameId *>::iterator it = conversionNameIds.lower_bound(type); if (it == conversionNameIds.end() || it->first != type) it = conversionNameIds.insert(it, std::make_pair(type, new ConversionNameId(type))); return it->second; } - QualifiedNameId *findOrInsertQualifiedNameId(const std::vector<Name *> &names, bool isGlobal) + const QualifiedNameId *findOrInsertQualifiedNameId(const std::vector<const Name *> &names, bool isGlobal) { const QualifiedNameIdKey key(names, isGlobal); - std::map<QualifiedNameIdKey, QualifiedNameId *>::iterator it = + std::map<QualifiedNameIdKey, const QualifiedNameId *>::iterator it = qualifiedNameIds.lower_bound(key); if (it == qualifiedNameIds.end() || it->first != key) { - QualifiedNameId *name = new QualifiedNameId(&names[0], names.size(), isGlobal); + const QualifiedNameId *name = new QualifiedNameId(&names[0], names.size(), isGlobal); it = qualifiedNameIds.insert(it, std::make_pair(key, name)); } return it->second; } - SelectorNameId *findOrInsertSelectorNameId(const std::vector<Name *> &names, bool hasArguments) + const SelectorNameId *findOrInsertSelectorNameId(const std::vector<const Name *> &names, bool hasArguments) { const SelectorNameIdKey key(names, hasArguments); - std::map<SelectorNameIdKey, SelectorNameId *>::iterator it = selectorNameIds.lower_bound(key); + std::map<SelectorNameIdKey, const SelectorNameId *>::iterator it = selectorNameIds.lower_bound(key); if (it == selectorNameIds.end() || it->first != key) it = selectorNameIds.insert(it, std::make_pair(key, new SelectorNameId(&names[0], names.size(), hasArguments))); return it->second; @@ -272,7 +271,7 @@ public: return floatTypes.intern(FloatType(kind)); } - PointerToMemberType *findOrInsertPointerToMemberType(Name *memberName, const FullySpecifiedType &elementType) + PointerToMemberType *findOrInsertPointerToMemberType(const Name *memberName, const FullySpecifiedType &elementType) { return pointerToMemberTypes.intern(PointerToMemberType(memberName, elementType)); } @@ -292,12 +291,12 @@ public: return arrayTypes.intern(ArrayType(elementType, size)); } - NamedType *findOrInsertNamedType(Name *name) + NamedType *findOrInsertNamedType(const Name *name) { return namedTypes.intern(NamedType(name)); } - Declaration *newDeclaration(unsigned sourceLocation, Name *name) + Declaration *newDeclaration(unsigned sourceLocation, const Name *name) { Declaration *declaration = new Declaration(translationUnit, sourceLocation, name); @@ -305,7 +304,7 @@ public: return declaration; } - Argument *newArgument(unsigned sourceLocation, Name *name) + Argument *newArgument(unsigned sourceLocation, const Name *name) { Argument *argument = new Argument(translationUnit, sourceLocation, name); @@ -313,7 +312,7 @@ public: return argument; } - Function *newFunction(unsigned sourceLocation, Name *name) + Function *newFunction(unsigned sourceLocation, const Name *name) { Function *function = new Function(translationUnit, sourceLocation, name); @@ -321,7 +320,7 @@ public: return function; } - BaseClass *newBaseClass(unsigned sourceLocation, Name *name) + BaseClass *newBaseClass(unsigned sourceLocation, const Name *name) { BaseClass *baseClass = new BaseClass(translationUnit, sourceLocation, name); @@ -336,7 +335,7 @@ public: return block; } - Class *newClass(unsigned sourceLocation, Name *name) + Class *newClass(unsigned sourceLocation, const Name *name) { Class *klass = new Class(translationUnit, sourceLocation, name); @@ -344,7 +343,7 @@ public: return klass; } - Namespace *newNamespace(unsigned sourceLocation, Name *name) + Namespace *newNamespace(unsigned sourceLocation, const Name *name) { Namespace *ns = new Namespace(translationUnit, sourceLocation, name); @@ -352,7 +351,7 @@ public: return ns; } - UsingNamespaceDirective *newUsingNamespaceDirective(unsigned sourceLocation, Name *name) + UsingNamespaceDirective *newUsingNamespaceDirective(unsigned sourceLocation, const Name *name) { UsingNamespaceDirective *u = new UsingNamespaceDirective(translationUnit, sourceLocation, name); @@ -360,7 +359,7 @@ public: return u; } - ForwardClassDeclaration *newForwardClassDeclaration(unsigned sourceLocation, Name *name) + ForwardClassDeclaration *newForwardClassDeclaration(unsigned sourceLocation, const Name *name) { ForwardClassDeclaration *c = new ForwardClassDeclaration(translationUnit, sourceLocation, name); @@ -368,63 +367,63 @@ public: return c; } - ObjCBaseClass *newObjCBaseClass(unsigned sourceLocation, Name *name) + ObjCBaseClass *newObjCBaseClass(unsigned sourceLocation, const Name *name) { ObjCBaseClass *c = new ObjCBaseClass(translationUnit, sourceLocation, name); symbols.push_back(c); return c; } - ObjCBaseProtocol *newObjCBaseProtocol(unsigned sourceLocation, Name *name) + ObjCBaseProtocol *newObjCBaseProtocol(unsigned sourceLocation, const Name *name) { ObjCBaseProtocol *p = new ObjCBaseProtocol(translationUnit, sourceLocation, name); symbols.push_back(p); return p; } - ObjCClass *newObjCClass(unsigned sourceLocation, Name *name) + ObjCClass *newObjCClass(unsigned sourceLocation, const Name *name) { ObjCClass *c = new ObjCClass(translationUnit, sourceLocation, name); symbols.push_back(c); return c; } - ObjCForwardClassDeclaration *newObjCForwardClassDeclaration(unsigned sourceLocation, Name *name) + ObjCForwardClassDeclaration *newObjCForwardClassDeclaration(unsigned sourceLocation, const Name *name) { ObjCForwardClassDeclaration *fwd = new ObjCForwardClassDeclaration(translationUnit, sourceLocation, name); symbols.push_back(fwd); return fwd; } - ObjCProtocol *newObjCProtocol(unsigned sourceLocation, Name *name) + ObjCProtocol *newObjCProtocol(unsigned sourceLocation, const Name *name) { ObjCProtocol *p = new ObjCProtocol(translationUnit, sourceLocation, name); symbols.push_back(p); return p; } - ObjCForwardProtocolDeclaration *newObjCForwardProtocolDeclaration(unsigned sourceLocation, Name *name) + ObjCForwardProtocolDeclaration *newObjCForwardProtocolDeclaration(unsigned sourceLocation, const Name *name) { ObjCForwardProtocolDeclaration *fwd = new ObjCForwardProtocolDeclaration(translationUnit, sourceLocation, name); symbols.push_back(fwd); return fwd; } - ObjCMethod *newObjCMethod(unsigned sourceLocation, Name *name) + ObjCMethod *newObjCMethod(unsigned sourceLocation, const Name *name) { ObjCMethod *method = new ObjCMethod(translationUnit, sourceLocation, name); symbols.push_back(method); return method; } - ObjCPropertyDeclaration *newObjCPropertyDeclaration(unsigned sourceLocation, Name *name) + ObjCPropertyDeclaration *newObjCPropertyDeclaration(unsigned sourceLocation, const Name *name) { ObjCPropertyDeclaration *decl = new ObjCPropertyDeclaration(translationUnit, sourceLocation, name); symbols.push_back(decl); return decl; } - Enum *newEnum(unsigned sourceLocation, Name *name) + Enum *newEnum(unsigned sourceLocation, const Name *name) { Enum *e = new Enum(translationUnit, sourceLocation, name); @@ -432,7 +431,7 @@ public: return e; } - UsingDeclaration *newUsingDeclaration(unsigned sourceLocation, Name *name) + UsingDeclaration *newUsingDeclaration(unsigned sourceLocation, const Name *name) { UsingDeclaration *u = new UsingDeclaration(translationUnit, sourceLocation, name); @@ -466,10 +465,10 @@ public: }; struct QualifiedNameIdKey { - std::vector<Name *> names; + std::vector<const Name *> names; bool isGlobal; - QualifiedNameIdKey(const std::vector<Name *> &names, bool isGlobal) : + QualifiedNameIdKey(const std::vector<const Name *> &names, bool isGlobal) : names(names), isGlobal(isGlobal) { } @@ -489,10 +488,10 @@ public: }; struct SelectorNameIdKey { - std::vector<Name *> _names; + std::vector<const Name *> _names; bool _hasArguments; - SelectorNameIdKey(const std::vector<Name *> &names, bool hasArguments): _names(names), _hasArguments(hasArguments) {} + SelectorNameIdKey(const std::vector<const Name *> &names, bool hasArguments): _names(names), _hasArguments(hasArguments) {} bool operator==(const SelectorNameIdKey &other) const { return _names == other._names && _hasArguments == other._hasArguments; } @@ -522,13 +521,13 @@ public: // ### replace std::map with lookup tables. ASAP! // names - std::map<const Identifier *, NameId *> nameIds; - std::map<const Identifier *, DestructorNameId *> destructorNameIds; - std::map<int, OperatorNameId *> operatorNameIds; - std::map<FullySpecifiedType, ConversionNameId *> conversionNameIds; - std::map<TemplateNameIdKey, TemplateNameId *> templateNameIds; - std::map<QualifiedNameIdKey, QualifiedNameId *> qualifiedNameIds; - std::map<SelectorNameIdKey, SelectorNameId *> selectorNameIds; + std::map<const Identifier *, const NameId *> nameIds; + std::map<const Identifier *, const DestructorNameId *> destructorNameIds; + std::map<int, const OperatorNameId *> operatorNameIds; + std::map<FullySpecifiedType, const ConversionNameId *> conversionNameIds; + std::map<TemplateNameIdKey, const TemplateNameId *> templateNameIds; + std::map<QualifiedNameIdKey, const QualifiedNameId *> qualifiedNameIds; + std::map<SelectorNameIdKey, const SelectorNameId *> selectorNameIds; // types VoidType voidType; @@ -635,39 +634,39 @@ const NumericLiteral *Control::findOrInsertNumericLiteral(const char *chars) return findOrInsertNumericLiteral(chars, length); } -NameId *Control::nameId(const Identifier *id) +const NameId *Control::nameId(const Identifier *id) { return d->findOrInsertNameId(id); } -TemplateNameId *Control::templateNameId(const Identifier *id, - FullySpecifiedType *const args, - unsigned argv) +const TemplateNameId *Control::templateNameId(const Identifier *id, + const FullySpecifiedType *const args, + unsigned argv) { std::vector<FullySpecifiedType> templateArguments(args, args + argv); return d->findOrInsertTemplateNameId(id, templateArguments); } -DestructorNameId *Control::destructorNameId(const Identifier *id) +const DestructorNameId *Control::destructorNameId(const Identifier *id) { return d->findOrInsertDestructorNameId(id); } -OperatorNameId *Control::operatorNameId(int kind) +const OperatorNameId *Control::operatorNameId(int kind) { return d->findOrInsertOperatorNameId(kind); } -ConversionNameId *Control::conversionNameId(const FullySpecifiedType &type) +const ConversionNameId *Control::conversionNameId(const FullySpecifiedType &type) { return d->findOrInsertConversionNameId(type); } -QualifiedNameId *Control::qualifiedNameId(Name *const *names, - unsigned nameCount, - bool isGlobal) +const QualifiedNameId *Control::qualifiedNameId(const Name *const *names, + unsigned nameCount, + bool isGlobal) { - std::vector<Name *> classOrNamespaceNames(names, names + nameCount); + std::vector<const Name *> classOrNamespaceNames(names, names + nameCount); return d->findOrInsertQualifiedNameId(classOrNamespaceNames, isGlobal); } -SelectorNameId *Control::selectorNameId(Name *const *names, - unsigned nameCount, - bool hasArguments) +const SelectorNameId *Control::selectorNameId(const Name *const *names, + unsigned nameCount, + bool hasArguments) { - std::vector<Name *> selectorNames(names, names + nameCount); + std::vector<const Name *> selectorNames(names, names + nameCount); return d->findOrInsertSelectorNameId(selectorNames, hasArguments); } @@ -681,7 +680,7 @@ IntegerType *Control::integerType(int kind) FloatType *Control::floatType(int kind) { return d->findOrInsertFloatType(kind); } -PointerToMemberType *Control::pointerToMemberType(Name *memberName, const FullySpecifiedType &elementType) +PointerToMemberType *Control::pointerToMemberType(const Name *memberName, const FullySpecifiedType &elementType) { return d->findOrInsertPointerToMemberType(memberName, elementType); } PointerType *Control::pointerType(const FullySpecifiedType &elementType) @@ -693,66 +692,66 @@ ReferenceType *Control::referenceType(const FullySpecifiedType &elementType) ArrayType *Control::arrayType(const FullySpecifiedType &elementType, unsigned size) { return d->findOrInsertArrayType(elementType, size); } -NamedType *Control::namedType(Name *name) +NamedType *Control::namedType(const Name *name) { return d->findOrInsertNamedType(name); } -Argument *Control::newArgument(unsigned sourceLocation, Name *name) +Argument *Control::newArgument(unsigned sourceLocation, const Name *name) { return d->newArgument(sourceLocation, name); } -Function *Control::newFunction(unsigned sourceLocation, Name *name) +Function *Control::newFunction(unsigned sourceLocation, const Name *name) { return d->newFunction(sourceLocation, name); } -Namespace *Control::newNamespace(unsigned sourceLocation, Name *name) +Namespace *Control::newNamespace(unsigned sourceLocation, const Name *name) { return d->newNamespace(sourceLocation, name); } -BaseClass *Control::newBaseClass(unsigned sourceLocation, Name *name) +BaseClass *Control::newBaseClass(unsigned sourceLocation, const Name *name) { return d->newBaseClass(sourceLocation, name); } -Class *Control::newClass(unsigned sourceLocation, Name *name) +Class *Control::newClass(unsigned sourceLocation, const Name *name) { return d->newClass(sourceLocation, name); } -Enum *Control::newEnum(unsigned sourceLocation, Name *name) +Enum *Control::newEnum(unsigned sourceLocation, const Name *name) { return d->newEnum(sourceLocation, name); } Block *Control::newBlock(unsigned sourceLocation) { return d->newBlock(sourceLocation); } -Declaration *Control::newDeclaration(unsigned sourceLocation, Name *name) +Declaration *Control::newDeclaration(unsigned sourceLocation, const Name *name) { return d->newDeclaration(sourceLocation, name); } UsingNamespaceDirective *Control::newUsingNamespaceDirective(unsigned sourceLocation, - Name *name) + const Name *name) { return d->newUsingNamespaceDirective(sourceLocation, name); } -UsingDeclaration *Control::newUsingDeclaration(unsigned sourceLocation, Name *name) +UsingDeclaration *Control::newUsingDeclaration(unsigned sourceLocation, const Name *name) { return d->newUsingDeclaration(sourceLocation, name); } ForwardClassDeclaration *Control::newForwardClassDeclaration(unsigned sourceLocation, - Name *name) + const Name *name) { return d->newForwardClassDeclaration(sourceLocation, name); } -ObjCBaseClass *Control::newObjCBaseClass(unsigned sourceLocation, Name *name) +ObjCBaseClass *Control::newObjCBaseClass(unsigned sourceLocation, const Name *name) { return d->newObjCBaseClass(sourceLocation, name); } -ObjCBaseProtocol *Control::newObjCBaseProtocol(unsigned sourceLocation, Name *name) +ObjCBaseProtocol *Control::newObjCBaseProtocol(unsigned sourceLocation, const Name *name) { return d->newObjCBaseProtocol(sourceLocation, name); } -ObjCClass *Control::newObjCClass(unsigned sourceLocation, Name *name) +ObjCClass *Control::newObjCClass(unsigned sourceLocation, const Name *name) { return d->newObjCClass(sourceLocation, name); } -ObjCForwardClassDeclaration *Control::newObjCForwardClassDeclaration(unsigned sourceLocation, Name *name) +ObjCForwardClassDeclaration *Control::newObjCForwardClassDeclaration(unsigned sourceLocation, const Name *name) { return d->newObjCForwardClassDeclaration(sourceLocation, name); } -ObjCProtocol *Control::newObjCProtocol(unsigned sourceLocation, Name *name) +ObjCProtocol *Control::newObjCProtocol(unsigned sourceLocation, const Name *name) { return d->newObjCProtocol(sourceLocation, name); } -ObjCForwardProtocolDeclaration *Control::newObjCForwardProtocolDeclaration(unsigned sourceLocation, Name *name) +ObjCForwardProtocolDeclaration *Control::newObjCForwardProtocolDeclaration(unsigned sourceLocation, const Name *name) { return d->newObjCForwardProtocolDeclaration(sourceLocation, name); } -ObjCMethod *Control::newObjCMethod(unsigned sourceLocation, Name *name) +ObjCMethod *Control::newObjCMethod(unsigned sourceLocation, const Name *name) { return d->newObjCMethod(sourceLocation, name); } -ObjCPropertyDeclaration *Control::newObjCPropertyDeclaration(unsigned sourceLocation, Name *name) +ObjCPropertyDeclaration *Control::newObjCPropertyDeclaration(unsigned sourceLocation, const Name *name) { return d->newObjCPropertyDeclaration(sourceLocation, name); } const Identifier *Control::objcGetterId() const diff --git a/src/shared/cplusplus/Control.h b/src/shared/cplusplus/Control.h index 3fc8543ab1e..4881b416e8e 100644 --- a/src/shared/cplusplus/Control.h +++ b/src/shared/cplusplus/Control.h @@ -66,30 +66,30 @@ public: void setDiagnosticClient(DiagnosticClient *diagnosticClient); /// Returns the canonical name id. - NameId *nameId(const Identifier *id); + const NameId *nameId(const Identifier *id); /// Returns the canonical template name id. - TemplateNameId *templateNameId(const Identifier *id, - FullySpecifiedType *const args = 0, - unsigned argc = 0); + const TemplateNameId *templateNameId(const Identifier *id, + const FullySpecifiedType *const args = 0, + unsigned argc = 0); /// Returns the canonical destructor name id. - DestructorNameId *destructorNameId(const Identifier *id); + const DestructorNameId *destructorNameId(const Identifier *id); /// Returns the canonical operator name id. - OperatorNameId *operatorNameId(int operatorId); + const OperatorNameId *operatorNameId(int operatorId); /// Returns the canonical conversion name id. - ConversionNameId *conversionNameId(const FullySpecifiedType &type); + const ConversionNameId *conversionNameId(const FullySpecifiedType &type); /// Returns the canonical qualified name id. - QualifiedNameId *qualifiedNameId(Name *const *names, - unsigned nameCount, - bool isGlobal = false); + const QualifiedNameId *qualifiedNameId(const Name *const *names, + unsigned nameCount, + bool isGlobal = false); - SelectorNameId *selectorNameId(Name *const *names, - unsigned nameCount, - bool hasArguments); + const SelectorNameId *selectorNameId(const Name *const *names, + unsigned nameCount, + bool hasArguments); /// Returns a Type object of type VoidType. VoidType *voidType(); @@ -101,7 +101,7 @@ public: FloatType *floatType(int floatId); /// Returns a Type object of type PointertoMemberType. - PointerToMemberType *pointerToMemberType(Name *memberName, + PointerToMemberType *pointerToMemberType(const Name *memberName, const FullySpecifiedType &elementType); /// Returns a Type object of type PointerType. @@ -114,61 +114,61 @@ public: ArrayType *arrayType(const FullySpecifiedType &elementType, unsigned size = 0); /// Returns a Type object of type NamedType. - NamedType *namedType(Name *name); + NamedType *namedType(const Name *name); /// Creates a new Declaration symbol. - Declaration *newDeclaration(unsigned sourceLocation, Name *name); + Declaration *newDeclaration(unsigned sourceLocation, const Name *name); /// Creates a new Argument symbol. - Argument *newArgument(unsigned sourceLocation, Name *name = 0); + Argument *newArgument(unsigned sourceLocation, const Name *name = 0); /// Creates a new Function symbol. - Function *newFunction(unsigned sourceLocation, Name *name = 0); + Function *newFunction(unsigned sourceLocation, const Name *name = 0); /// Creates a new Namespace symbol. - Namespace *newNamespace(unsigned sourceLocation, Name *name = 0); + Namespace *newNamespace(unsigned sourceLocation, const Name *name = 0); /// Creates a new BaseClass symbol. - BaseClass *newBaseClass(unsigned sourceLocation, Name *name = 0); + BaseClass *newBaseClass(unsigned sourceLocation, const Name *name = 0); /// Creates a new Class symbol. - Class *newClass(unsigned sourceLocation, Name *name = 0); + Class *newClass(unsigned sourceLocation, const Name *name = 0); /// Creates a new Enum symbol. - Enum *newEnum(unsigned sourceLocation, Name *name = 0); + Enum *newEnum(unsigned sourceLocation, const Name *name = 0); /// Creates a new Block symbol. Block *newBlock(unsigned sourceLocation); /// Creates a new UsingNamespaceDirective symbol. - UsingNamespaceDirective *newUsingNamespaceDirective(unsigned sourceLocation, Name *name = 0); + UsingNamespaceDirective *newUsingNamespaceDirective(unsigned sourceLocation, const Name *name = 0); /// Creates a new UsingDeclaration symbol. - UsingDeclaration *newUsingDeclaration(unsigned sourceLocation, Name *name = 0); + UsingDeclaration *newUsingDeclaration(unsigned sourceLocation, const Name *name = 0); /// Creates a new ForwardClassDeclaration symbol. - ForwardClassDeclaration *newForwardClassDeclaration(unsigned sourceLocation, Name *name = 0); + ForwardClassDeclaration *newForwardClassDeclaration(unsigned sourceLocation, const Name *name = 0); - ObjCBaseClass *newObjCBaseClass(unsigned sourceLocation, Name *name); - ObjCBaseProtocol *newObjCBaseProtocol(unsigned sourceLocation, Name *name); + ObjCBaseClass *newObjCBaseClass(unsigned sourceLocation, const Name *name); + ObjCBaseProtocol *newObjCBaseProtocol(unsigned sourceLocation, const Name *name); /// Creates a new Objective-C class symbol. - ObjCClass *newObjCClass(unsigned sourceLocation, Name *name = 0); + ObjCClass *newObjCClass(unsigned sourceLocation, const Name *name = 0); /// Creates a new Objective-C class forward declaration symbol. - ObjCForwardClassDeclaration *newObjCForwardClassDeclaration(unsigned sourceLocation, Name *name = 0); + ObjCForwardClassDeclaration *newObjCForwardClassDeclaration(unsigned sourceLocation, const Name *name = 0); /// Creates a new Objective-C protocol symbol. - ObjCProtocol *newObjCProtocol(unsigned sourceLocation, Name *name = 0); + ObjCProtocol *newObjCProtocol(unsigned sourceLocation, const Name *name = 0); /// Creates a new Objective-C protocol forward declaration symbol. - ObjCForwardProtocolDeclaration *newObjCForwardProtocolDeclaration(unsigned sourceLocation, Name *name = 0); + ObjCForwardProtocolDeclaration *newObjCForwardProtocolDeclaration(unsigned sourceLocation, const Name *name = 0); /// Creates a new Objective-C method symbol. - ObjCMethod *newObjCMethod(unsigned sourceLocation, Name *name = 0); + ObjCMethod *newObjCMethod(unsigned sourceLocation, const Name *name = 0); /// Creates a new Objective-C @property declaration symbol. - ObjCPropertyDeclaration *newObjCPropertyDeclaration(unsigned sourceLocation, Name *name); + ObjCPropertyDeclaration *newObjCPropertyDeclaration(unsigned sourceLocation, const Name *name); // Objective-C specific context keywords. const Identifier *objcGetterId() const; diff --git a/src/shared/cplusplus/CoreTypes.cpp b/src/shared/cplusplus/CoreTypes.cpp index 9bdd17a827f..43d9f8bab00 100644 --- a/src/shared/cplusplus/CoreTypes.cpp +++ b/src/shared/cplusplus/CoreTypes.cpp @@ -90,7 +90,7 @@ bool VoidType::matchType0(const Type *otherType, TypeMatcher *matcher) const return false; } -PointerToMemberType::PointerToMemberType(Name *memberName, const FullySpecifiedType &elementType) +PointerToMemberType::PointerToMemberType(const Name *memberName, const FullySpecifiedType &elementType) : _memberName(memberName), _elementType(elementType) { } @@ -98,7 +98,7 @@ PointerToMemberType::PointerToMemberType(Name *memberName, const FullySpecifiedT PointerToMemberType::~PointerToMemberType() { } -Name *PointerToMemberType::memberName() const +const Name *PointerToMemberType::memberName() const { return _memberName; } FullySpecifiedType PointerToMemberType::elementType() const @@ -275,14 +275,14 @@ FullySpecifiedType ArrayType::elementType() const unsigned ArrayType::size() const { return _size; } -NamedType::NamedType(Name *name) +NamedType::NamedType(const Name *name) : _name(name) { } NamedType::~NamedType() { } -Name *NamedType::name() const +const Name *NamedType::name() const { return _name; } bool NamedType::isEqualTo(const Type *other) const @@ -291,12 +291,12 @@ bool NamedType::isEqualTo(const Type *other) const if (! o) return false; - Name *name = _name; - if (QualifiedNameId *q = name->asQualifiedNameId()) + const Name *name = _name; + if (const QualifiedNameId *q = name->asQualifiedNameId()) name = q->unqualifiedNameId(); - Name *otherName = o->name(); - if (QualifiedNameId *q = otherName->asQualifiedNameId()) + const Name *otherName = o->name(); + if (const QualifiedNameId *q = otherName->asQualifiedNameId()) otherName = q->unqualifiedNameId(); return name->isEqualTo(otherName); diff --git a/src/shared/cplusplus/CoreTypes.h b/src/shared/cplusplus/CoreTypes.h index dc70f06ddf6..42d69b4cb39 100644 --- a/src/shared/cplusplus/CoreTypes.h +++ b/src/shared/cplusplus/CoreTypes.h @@ -186,10 +186,10 @@ private: class CPLUSPLUS_EXPORT PointerToMemberType: public Type { public: - PointerToMemberType(Name *memberName, const FullySpecifiedType &elementType); + PointerToMemberType(const Name *memberName, const FullySpecifiedType &elementType); virtual ~PointerToMemberType(); - Name *memberName() const; + const Name *memberName() const; FullySpecifiedType elementType() const; virtual bool isEqualTo(const Type *other) const; @@ -205,7 +205,7 @@ protected: virtual bool matchType0(const Type *otherType, TypeMatcher *matcher) const; private: - Name *_memberName; + const Name *_memberName; FullySpecifiedType _elementType; }; @@ -262,10 +262,10 @@ private: class CPLUSPLUS_EXPORT NamedType: public Type { public: - NamedType(Name *name); + NamedType(const Name *name); virtual ~NamedType(); - Name *name() const; + const Name *name() const; virtual bool isEqualTo(const Type *other) const; @@ -280,7 +280,7 @@ protected: virtual bool matchType0(const Type *otherType, TypeMatcher *matcher) const; private: - Name *_name; + const Name *_name; }; } // end of namespace CPlusPlus diff --git a/src/shared/cplusplus/Name.cpp b/src/shared/cplusplus/Name.cpp index 6354382551d..b185409cf6b 100644 --- a/src/shared/cplusplus/Name.cpp +++ b/src/shared/cplusplus/Name.cpp @@ -79,14 +79,14 @@ bool Name::isQualifiedNameId() const bool Name::isSelectorNameId() const { return asSelectorNameId() != 0; } -void Name::accept(NameVisitor *visitor) +void Name::accept(NameVisitor *visitor) const { if (visitor->preVisit(this)) accept0(visitor); visitor->postVisit(this); } -void Name::accept(Name *name, NameVisitor *visitor) +void Name::accept(const Name *name, NameVisitor *visitor) { if (! name) return; diff --git a/src/shared/cplusplus/Name.h b/src/shared/cplusplus/Name.h index 8559b6ea2ee..ea740bd2497 100644 --- a/src/shared/cplusplus/Name.h +++ b/src/shared/cplusplus/Name.h @@ -78,21 +78,13 @@ public: virtual const QualifiedNameId *asQualifiedNameId() const { return 0; } virtual const SelectorNameId *asSelectorNameId() const { return 0; } - virtual NameId *asNameId() { return 0; } - virtual TemplateNameId *asTemplateNameId() { return 0; } - virtual DestructorNameId *asDestructorNameId() { return 0; } - virtual OperatorNameId *asOperatorNameId() { return 0; } - virtual ConversionNameId *asConversionNameId() { return 0; } - virtual QualifiedNameId *asQualifiedNameId() { return 0; } - virtual SelectorNameId *asSelectorNameId() { return 0; } - virtual bool isEqualTo(const Name *other) const = 0; - void accept(NameVisitor *visitor); - static void accept(Name *name, NameVisitor *visitor); + void accept(NameVisitor *visitor) const; + static void accept(const Name *name, NameVisitor *visitor); protected: - virtual void accept0(NameVisitor *visitor) = 0; + virtual void accept0(NameVisitor *visitor) const = 0; }; } // end of namespace CPlusPlus diff --git a/src/shared/cplusplus/NameVisitor.cpp b/src/shared/cplusplus/NameVisitor.cpp index 29630661d78..fe9d5cda09b 100644 --- a/src/shared/cplusplus/NameVisitor.cpp +++ b/src/shared/cplusplus/NameVisitor.cpp @@ -57,7 +57,5 @@ NameVisitor::NameVisitor() NameVisitor::~NameVisitor() { } -void NameVisitor::accept(Name *name) +void NameVisitor::accept(const Name *name) { Name::accept(name, this); } - - diff --git a/src/shared/cplusplus/NameVisitor.h b/src/shared/cplusplus/NameVisitor.h index f8889b7d7f6..d567c30be8b 100644 --- a/src/shared/cplusplus/NameVisitor.h +++ b/src/shared/cplusplus/NameVisitor.h @@ -63,18 +63,18 @@ public: NameVisitor(); virtual ~NameVisitor(); - void accept(Name *name); + void accept(const Name *name); - virtual bool preVisit(Name *) { return true; } - virtual void postVisit(Name *) {} + virtual bool preVisit(const Name *) { return true; } + virtual void postVisit(const Name *) {} - virtual void visit(NameId *) {} - virtual void visit(TemplateNameId *) {} - virtual void visit(DestructorNameId *) {} - virtual void visit(OperatorNameId *) {} - virtual void visit(ConversionNameId *) {} - virtual void visit(QualifiedNameId *) {} - virtual void visit(SelectorNameId *) {} + virtual void visit(const NameId *) {} + virtual void visit(const TemplateNameId *) {} + virtual void visit(const DestructorNameId *) {} + virtual void visit(const OperatorNameId *) {} + virtual void visit(const ConversionNameId *) {} + virtual void visit(const QualifiedNameId *) {} + virtual void visit(const SelectorNameId *) {} }; } // end of namespace CPlusPlus diff --git a/src/shared/cplusplus/Names.cpp b/src/shared/cplusplus/Names.cpp index 65703f804b3..4bc64f497d7 100644 --- a/src/shared/cplusplus/Names.cpp +++ b/src/shared/cplusplus/Names.cpp @@ -54,51 +54,42 @@ using namespace CPlusPlus; -QualifiedNameId::QualifiedNameId(Name *const names[], +QualifiedNameId::QualifiedNameId(const Name *const *names, unsigned nameCount, bool isGlobal) - : _names(0), - _nameCount(nameCount), + : _names(names, names + nameCount), _isGlobal(isGlobal) -{ - if (_nameCount) { - _names = new Name *[_nameCount]; - std::copy(&names[0], &names[nameCount], _names); - } -} +{ } QualifiedNameId::~QualifiedNameId() -{ delete[] _names; } +{ } -void QualifiedNameId::accept0(NameVisitor *visitor) +void QualifiedNameId::accept0(NameVisitor *visitor) const { visitor->visit(this); } const Identifier *QualifiedNameId::identifier() const { - if (Name *u = unqualifiedNameId()) + if (const Name *u = unqualifiedNameId()) return u->identifier(); return 0; } unsigned QualifiedNameId::nameCount() const -{ return _nameCount; } +{ return _names.size(); } -Name *QualifiedNameId::nameAt(unsigned index) const +const Name *QualifiedNameId::nameAt(unsigned index) const { return _names[index]; } -Name *const *QualifiedNameId::names() const -{ return _names; } - bool QualifiedNameId::isGlobal() const { return _isGlobal; } -Name *QualifiedNameId::unqualifiedNameId() const +const Name *QualifiedNameId::unqualifiedNameId() const { - if (! _nameCount) + if (_names.empty()) return 0; - return _names[_nameCount - 1]; + return _names.back(); } bool QualifiedNameId::isEqualTo(const Name *other) const @@ -113,8 +104,8 @@ bool QualifiedNameId::isEqualTo(const Name *other) const if (count != q->nameCount()) return false; for (unsigned i = 0; i < count; ++i) { - Name *l = nameAt(i); - Name *r = q->nameAt(i); + const Name *l = nameAt(i); + const Name *r = q->nameAt(i); if (! l->isEqualTo(r)) return false; } @@ -129,7 +120,7 @@ NameId::NameId(const Identifier *identifier) NameId::~NameId() { } -void NameId::accept0(NameVisitor *visitor) +void NameId::accept0(NameVisitor *visitor) const { visitor->visit(this); } const Identifier *NameId::identifier() const @@ -152,7 +143,7 @@ DestructorNameId::DestructorNameId(const Identifier *identifier) DestructorNameId::~DestructorNameId() { } -void DestructorNameId::accept0(NameVisitor *visitor) +void DestructorNameId::accept0(NameVisitor *visitor) const { visitor->visit(this); } const Identifier *DestructorNameId::identifier() const @@ -169,37 +160,27 @@ bool DestructorNameId::isEqualTo(const Name *other) const } TemplateNameId::TemplateNameId(const Identifier *identifier, - const FullySpecifiedType templateArguments[], - unsigned templateArgumentCount) + const FullySpecifiedType templateArguments[], + unsigned templateArgumentCount) : _identifier(identifier), - _templateArguments(0), - _templateArgumentCount(templateArgumentCount) -{ - if (_templateArgumentCount) { - _templateArguments = new FullySpecifiedType[_templateArgumentCount]; - std::copy(&templateArguments[0], &templateArguments[_templateArgumentCount], - _templateArguments); - } -} + _templateArguments(templateArguments, templateArguments + templateArgumentCount) +{ } TemplateNameId::~TemplateNameId() -{ delete[] _templateArguments; } +{ } -void TemplateNameId::accept0(NameVisitor *visitor) +void TemplateNameId::accept0(NameVisitor *visitor) const { visitor->visit(this); } const Identifier *TemplateNameId::identifier() const { return _identifier; } unsigned TemplateNameId::templateArgumentCount() const -{ return _templateArgumentCount; } +{ return _templateArguments.size(); } const FullySpecifiedType &TemplateNameId::templateArgumentAt(unsigned index) const { return _templateArguments[index]; } -const FullySpecifiedType *TemplateNameId::templateArguments() const -{ return _templateArguments; } - bool TemplateNameId::isEqualTo(const Name *other) const { const TemplateNameId *t = other->asTemplateNameId(); @@ -209,9 +190,9 @@ bool TemplateNameId::isEqualTo(const Name *other) const const Identifier *r = t->identifier(); if (! l->isEqualTo(r)) return false; - if (_templateArgumentCount != t->_templateArgumentCount) + if (templateArgumentCount() != t->templateArgumentCount()) return false; - for (unsigned i = 0; i < _templateArgumentCount; ++i) { + for (unsigned i = 0; i < templateArgumentCount(); ++i) { const FullySpecifiedType &l = _templateArguments[i]; const FullySpecifiedType &r = t->_templateArguments[i]; if (! l.isEqualTo(r)) @@ -227,7 +208,7 @@ OperatorNameId::OperatorNameId(int kind) OperatorNameId::~OperatorNameId() { } -void OperatorNameId::accept0(NameVisitor *visitor) +void OperatorNameId::accept0(NameVisitor *visitor) const { visitor->visit(this); } int OperatorNameId::kind() const @@ -251,7 +232,7 @@ ConversionNameId::ConversionNameId(const FullySpecifiedType &type) ConversionNameId::~ConversionNameId() { } -void ConversionNameId::accept0(NameVisitor *visitor) +void ConversionNameId::accept0(NameVisitor *visitor) const { visitor->visit(this); } FullySpecifiedType ConversionNameId::type() const @@ -268,42 +249,33 @@ bool ConversionNameId::isEqualTo(const Name *other) const return _type.isEqualTo(c->type()); } -SelectorNameId::SelectorNameId(Name *const names[], +SelectorNameId::SelectorNameId(const Name *const *names, unsigned nameCount, bool hasArguments) - : _names(0), - _nameCount(nameCount), + : _names(names, names + nameCount), _hasArguments(hasArguments) -{ - if (_nameCount) { - _names = new Name *[_nameCount]; - std::copy(&names[0], &names[nameCount], _names); - } -} +{ } SelectorNameId::~SelectorNameId() -{ delete[] _names; } +{ } -void SelectorNameId::accept0(NameVisitor *visitor) +void SelectorNameId::accept0(NameVisitor *visitor) const { visitor->visit(this); } const Identifier *SelectorNameId::identifier() const { - if (! _nameCount) + if (_names.empty()) return 0; return nameAt(0)->identifier(); } unsigned SelectorNameId::nameCount() const -{ return _nameCount; } +{ return _names.size(); } -Name *SelectorNameId::nameAt(unsigned index) const +const Name *SelectorNameId::nameAt(unsigned index) const { return _names[index]; } -Name *const *SelectorNameId::names() const -{ return _names; } - bool SelectorNameId::hasArguments() const { return _hasArguments; } @@ -319,8 +291,8 @@ bool SelectorNameId::isEqualTo(const Name *other) const if (count != q->nameCount()) return false; for (unsigned i = 0; i < count; ++i) { - Name *l = nameAt(i); - Name *r = q->nameAt(i); + const Name *l = nameAt(i); + const Name *r = q->nameAt(i); if (! l->isEqualTo(r)) return false; } diff --git a/src/shared/cplusplus/Names.h b/src/shared/cplusplus/Names.h index 5629747de3f..9bae0e07fb5 100644 --- a/src/shared/cplusplus/Names.h +++ b/src/shared/cplusplus/Names.h @@ -52,24 +52,22 @@ #include "CPlusPlusForwardDeclarations.h" #include "Name.h" #include "FullySpecifiedType.h" +#include <vector> namespace CPlusPlus { class CPLUSPLUS_EXPORT QualifiedNameId: public Name { public: - QualifiedNameId(Name *const names[], - unsigned nameCount, - bool isGlobal = false); + QualifiedNameId(const Name *const *names, unsigned nameCount, bool isGlobal = false); virtual ~QualifiedNameId(); virtual const Identifier *identifier() const; unsigned nameCount() const; - Name *nameAt(unsigned index) const; - Name *const *names() const; - Name *unqualifiedNameId() const; - + const Name *nameAt(unsigned index) const; + const Name *unqualifiedNameId() const; + const Name *const *names() const { return &_names[0]; } // ### remove me bool isGlobal() const; virtual bool isEqualTo(const Name *other) const; @@ -77,15 +75,11 @@ public: virtual const QualifiedNameId *asQualifiedNameId() const { return this; } - virtual QualifiedNameId *asQualifiedNameId() - { return this; } - protected: - virtual void accept0(NameVisitor *visitor); + virtual void accept0(NameVisitor *visitor) const; private: - Name **_names; - unsigned _nameCount; + std::vector<const Name *> _names; bool _isGlobal; }; @@ -102,11 +96,8 @@ public: virtual const NameId *asNameId() const { return this; } - virtual NameId *asNameId() - { return this; } - protected: - virtual void accept0(NameVisitor *visitor); + virtual void accept0(NameVisitor *visitor) const; private: const Identifier *_identifier; @@ -125,11 +116,8 @@ public: virtual const DestructorNameId *asDestructorNameId() const { return this; } - virtual DestructorNameId *asDestructorNameId() - { return this; } - protected: - virtual void accept0(NameVisitor *visitor); + virtual void accept0(NameVisitor *visitor) const; private: const Identifier *_identifier; @@ -148,23 +136,18 @@ public: // ### find a better name unsigned templateArgumentCount() const; const FullySpecifiedType &templateArgumentAt(unsigned index) const; - const FullySpecifiedType *templateArguments() const; virtual bool isEqualTo(const Name *other) const; virtual const TemplateNameId *asTemplateNameId() const { return this; } - virtual TemplateNameId *asTemplateNameId() - { return this; } - protected: - virtual void accept0(NameVisitor *visitor); + virtual void accept0(NameVisitor *visitor) const; private: const Identifier *_identifier; - FullySpecifiedType *_templateArguments; - unsigned _templateArgumentCount; + std::vector<FullySpecifiedType> _templateArguments; }; class CPLUSPLUS_EXPORT OperatorNameId: public Name @@ -236,11 +219,8 @@ public: virtual const OperatorNameId *asOperatorNameId() const { return this; } - virtual OperatorNameId *asOperatorNameId() - { return this; } - protected: - virtual void accept0(NameVisitor *visitor); + virtual void accept0(NameVisitor *visitor) const; private: int _kind; @@ -260,11 +240,8 @@ public: virtual const ConversionNameId *asConversionNameId() const { return this; } - virtual ConversionNameId *asConversionNameId() - { return this; } - protected: - virtual void accept0(NameVisitor *visitor); + virtual void accept0(NameVisitor *visitor) const; private: FullySpecifiedType _type; @@ -273,17 +250,13 @@ private: class CPLUSPLUS_EXPORT SelectorNameId: public Name { public: - SelectorNameId(Name *const names[], - unsigned nameCount, - bool hasArguments); + SelectorNameId(const Name *const *names, unsigned nameCount, bool hasArguments); virtual ~SelectorNameId(); virtual const Identifier *identifier() const; unsigned nameCount() const; - Name *nameAt(unsigned index) const; - Name *const *names() const; - + const Name *nameAt(unsigned index) const; bool hasArguments() const; virtual bool isEqualTo(const Name *other) const; @@ -291,15 +264,11 @@ public: virtual const SelectorNameId *asSelectorNameId() const { return this; } - virtual SelectorNameId *asSelectorNameId() - { return this; } - protected: - virtual void accept0(NameVisitor *visitor); + virtual void accept0(NameVisitor *visitor) const; private: - Name **_names; - unsigned _nameCount; + std::vector<const Name *> _names; bool _hasArguments; }; diff --git a/src/shared/cplusplus/Scope.cpp b/src/shared/cplusplus/Scope.cpp index 76d09eb2dcf..0fae6db3919 100644 --- a/src/shared/cplusplus/Scope.cpp +++ b/src/shared/cplusplus/Scope.cpp @@ -204,12 +204,12 @@ void Scope::enterSymbol(Symbol *symbol) } } -Symbol *Scope::lookat(Name *name) const +Symbol *Scope::lookat(const Name *name) const { if (! name) return 0; - else if (OperatorNameId *opId = name->asOperatorNameId()) + else if (const OperatorNameId *opId = name->asOperatorNameId()) return lookat(opId->kind()); else if (const Identifier *id = name->identifier()) @@ -227,21 +227,21 @@ Symbol *Scope::lookat(const Identifier *id) const const unsigned h = id->hashCode() % _hashSize; Symbol *symbol = _hash[h]; for (; symbol; symbol = symbol->_next) { - Name *identity = symbol->identity(); + const Name *identity = symbol->identity(); if (! identity) { continue; - } else if (NameId *nameId = identity->asNameId()) { + } else if (const NameId *nameId = identity->asNameId()) { if (nameId->identifier()->isEqualTo(id)) break; - } else if (TemplateNameId *t = identity->asTemplateNameId()) { + } else if (const TemplateNameId *t = identity->asTemplateNameId()) { if (t->identifier()->isEqualTo(id)) break; - } else if (DestructorNameId *d = identity->asDestructorNameId()) { + } else if (const DestructorNameId *d = identity->asDestructorNameId()) { if (d->identifier()->isEqualTo(id)) break; } else if (identity->isQualifiedNameId()) { - assert(0); - } else if (SelectorNameId *selectorNameId = identity->asSelectorNameId()) { + return 0; + } else if (const SelectorNameId *selectorNameId = identity->asSelectorNameId()) { if (selectorNameId->identifier()->isEqualTo(id)) break; } @@ -257,8 +257,8 @@ Symbol *Scope::lookat(int operatorId) const const unsigned h = operatorId % _hashSize; Symbol *symbol = _hash[h]; for (; symbol; symbol = symbol->_next) { - Name *identity = symbol->identity(); - if (OperatorNameId *op = identity->asOperatorNameId()) { + const Name *identity = symbol->identity(); + if (const OperatorNameId *op = identity->asOperatorNameId()) { if (op->kind() == operatorId) break; } diff --git a/src/shared/cplusplus/Scope.h b/src/shared/cplusplus/Scope.h index 8587ade8c58..04f735bf2a6 100644 --- a/src/shared/cplusplus/Scope.h +++ b/src/shared/cplusplus/Scope.h @@ -129,7 +129,7 @@ public: /// Returns the last Symbol in the scope. iterator lastSymbol() const; - Symbol *lookat(Name *name) const; + Symbol *lookat(const Name *name) const; Symbol *lookat(const Identifier *id) const; Symbol *lookat(int operatorId) const; diff --git a/src/shared/cplusplus/Semantic.cpp b/src/shared/cplusplus/Semantic.cpp index 74d870a91c0..57ac5fe99f3 100644 --- a/src/shared/cplusplus/Semantic.cpp +++ b/src/shared/cplusplus/Semantic.cpp @@ -132,7 +132,7 @@ void Semantic::check(DeclarationAST *declaration, Scope *scope, TemplateParamete { d->checkDeclaration->check(declaration, scope, templateParameters); } FullySpecifiedType Semantic::check(DeclaratorAST *declarator, const FullySpecifiedType &type, - Scope *scope, Name **name) + Scope *scope, const Name **name) { return d->checkDeclarator->check(declarator, type, scope, name); } FullySpecifiedType Semantic::check(PtrOperatorListAST *ptrOperators, const FullySpecifiedType &type, @@ -154,13 +154,13 @@ FullySpecifiedType Semantic::check(ExpressionAST *expression, Scope *scope) void Semantic::check(StatementAST *statement, Scope *scope) { d->checkStatement->check(statement, scope); } -Name *Semantic::check(NameAST *name, Scope *scope) +const Name *Semantic::check(NameAST *name, Scope *scope) { return d->checkName->check(name, scope); } -Name *Semantic::check(NestedNameSpecifierListAST *name, Scope *scope) +const Name *Semantic::check(NestedNameSpecifierListAST *name, Scope *scope) { return d->checkName->check(name, scope); } -Name *Semantic::check(ObjCSelectorAST *args, Scope *scope) +const Name *Semantic::check(ObjCSelectorAST *args, Scope *scope) { return d->checkName->check(args, scope); } bool Semantic::skipFunctionBodies() const diff --git a/src/shared/cplusplus/Semantic.h b/src/shared/cplusplus/Semantic.h index f6a4e528f48..6ca0b81c70b 100644 --- a/src/shared/cplusplus/Semantic.h +++ b/src/shared/cplusplus/Semantic.h @@ -70,7 +70,7 @@ public: FullySpecifiedType check(SpecifierListAST *specifier, Scope *scope); FullySpecifiedType check(DeclaratorAST *declarator, const FullySpecifiedType &type, - Scope *scope, Name **name = 0); // ### ugly + Scope *scope, const Name **name = 0); // ### ugly FullySpecifiedType check(PtrOperatorListAST *ptrOperators, const FullySpecifiedType &type, Scope *scope); @@ -83,11 +83,11 @@ public: void check(StatementAST *statement, Scope *scope); - Name *check(NameAST *name, Scope *scope); + const Name *check(NameAST *name, Scope *scope); - Name *check(NestedNameSpecifierListAST *name, Scope *scope); + const Name *check(NestedNameSpecifierListAST *name, Scope *scope); - Name *check(ObjCSelectorAST *args, Scope *scope); + const Name *check(ObjCSelectorAST *args, Scope *scope); FullySpecifiedType check(ObjCTypeNameAST *typeName, Scope *scope); void check(ObjCMessageArgumentDeclarationAST *arg, Scope *scope); diff --git a/src/shared/cplusplus/Symbol.cpp b/src/shared/cplusplus/Symbol.cpp index 57e74e13839..221af1ad828 100644 --- a/src/shared/cplusplus/Symbol.cpp +++ b/src/shared/cplusplus/Symbol.cpp @@ -70,7 +70,7 @@ public: virtual ~HashCode() { } - unsigned operator()(Name *name) + unsigned operator()(const Name *name) { unsigned previousValue = switchValue(0); accept(name); @@ -85,25 +85,25 @@ protected: return previousValue; } - virtual void visit(NameId *name) + virtual void visit(const NameId *name) { _value = name->identifier()->hashCode(); } - virtual void visit(TemplateNameId *name) + virtual void visit(const TemplateNameId *name) { _value = name->identifier()->hashCode(); } - virtual void visit(DestructorNameId *name) + virtual void visit(const DestructorNameId *name) { _value = name->identifier()->hashCode(); } - virtual void visit(OperatorNameId *name) + virtual void visit(const OperatorNameId *name) { _value = unsigned(name->kind()); } - virtual void visit(ConversionNameId *) + virtual void visit(const ConversionNameId *) { _value = 0; } // ### TODO: implement me - virtual void visit(QualifiedNameId *name) + virtual void visit(const QualifiedNameId *name) { _value = operator()(name->unqualifiedNameId()); } - virtual void visit(SelectorNameId *name) + virtual void visit(const SelectorNameId *name) { _value = name->identifier()->hashCode(); } private: @@ -120,47 +120,47 @@ public: virtual ~IdentityForName() { } - Name *operator()(Name *name) + const Name *operator()(const Name *name) { - Name *previousIdentity = switchIdentity(0); + const Name *previousIdentity = switchIdentity(0); accept(name); return switchIdentity(previousIdentity); } protected: - Name *switchIdentity(Name *identity) + const Name *switchIdentity(const Name *identity) { - Name *previousIdentity = _identity; + const Name *previousIdentity = _identity; _identity = identity; return previousIdentity; } - virtual void visit(NameId *name) + virtual void visit(const NameId *name) { _identity = name; } - virtual void visit(TemplateNameId *name) + virtual void visit(const TemplateNameId *name) { _identity = name; } - virtual void visit(DestructorNameId *name) + virtual void visit(const DestructorNameId *name) { _identity = name; } - virtual void visit(OperatorNameId *name) + virtual void visit(const OperatorNameId *name) { _identity = name; } - virtual void visit(ConversionNameId *name) + virtual void visit(const ConversionNameId *name) { _identity = name; } - virtual void visit(QualifiedNameId *name) + virtual void visit(const QualifiedNameId *name) { _identity = name->unqualifiedNameId(); } - virtual void visit(SelectorNameId *name) + virtual void visit(const SelectorNameId *name) { _identity = name; } private: - Name *_identity; + const Name *_identity; }; -Symbol::Symbol(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +Symbol::Symbol(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : _control(translationUnit->control()), _sourceLocation(sourceLocation), _sourceOffset(0), @@ -280,16 +280,16 @@ unsigned Symbol::endOffset() const void Symbol::setEndOffset(unsigned offset) { _endOffset = offset; } -Name *Symbol::identity() const +const Name *Symbol::identity() const { IdentityForName id; return id(_name); } -Name *Symbol::name() const +const Name *Symbol::name() const { return _name; } -void Symbol::setName(Name *name) +void Symbol::setName(const Name *name) { _name = name; diff --git a/src/shared/cplusplus/Symbol.h b/src/shared/cplusplus/Symbol.h index 7230a8e0c8d..e8615dc75b8 100644 --- a/src/shared/cplusplus/Symbol.h +++ b/src/shared/cplusplus/Symbol.h @@ -81,7 +81,7 @@ public: public: /// Constructs a Symbol with the given source location, name and translation unit. - Symbol(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + Symbol(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); /// Destroy this Symbol. virtual ~Symbol(); @@ -121,10 +121,10 @@ public: void getEndPosition(unsigned *line, unsigned *column = 0, const StringLiteral **fileId = 0) const; /// Returns this Symbol's name. - Name *name() const; + const Name *name() const; /// Sets this Symbol's name. - void setName(Name *name); // ### dangerous + void setName(const Name *name); // ### dangerous /// Returns this Symbol's (optional) identifier const Identifier *identifier() const; @@ -282,7 +282,7 @@ public: /// Returns this Symbol's index. unsigned index() const; - Name *identity() const; + const Name *identity() const; bool isGenerated() const; @@ -320,7 +320,7 @@ private: unsigned _sourceOffset; unsigned _startOffset; unsigned _endOffset; - Name *_name; + const Name *_name; unsigned _hashCode; int _storage; int _visibility; diff --git a/src/shared/cplusplus/Symbols.cpp b/src/shared/cplusplus/Symbols.cpp index 8c044ef03ca..22098f82b56 100644 --- a/src/shared/cplusplus/Symbols.cpp +++ b/src/shared/cplusplus/Symbols.cpp @@ -76,7 +76,7 @@ Scope *TemplateParameters::scope() const { return _scope; } UsingNamespaceDirective::UsingNamespaceDirective(TranslationUnit *translationUnit, - unsigned sourceLocation, Name *name) + unsigned sourceLocation, const Name *name) : Symbol(translationUnit, sourceLocation, name) { } @@ -90,7 +90,7 @@ void UsingNamespaceDirective::visitSymbol0(SymbolVisitor *visitor) { visitor->visit(this); } UsingDeclaration::UsingDeclaration(TranslationUnit *translationUnit, - unsigned sourceLocation, Name *name) + unsigned sourceLocation, const Name *name) : Symbol(translationUnit, sourceLocation, name) { } @@ -103,7 +103,7 @@ FullySpecifiedType UsingDeclaration::type() const void UsingDeclaration::visitSymbol0(SymbolVisitor *visitor) { visitor->visit(this); } -Declaration::Declaration(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +Declaration::Declaration(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : Symbol(translationUnit, sourceLocation, name), _templateParameters(0) { } @@ -126,7 +126,7 @@ FullySpecifiedType Declaration::type() const void Declaration::visitSymbol0(SymbolVisitor *visitor) { visitor->visit(this); } -Argument::Argument(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +Argument::Argument(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : Symbol(translationUnit, sourceLocation, name), _initializer(false) { } @@ -149,7 +149,7 @@ FullySpecifiedType Argument::type() const void Argument::visitSymbol0(SymbolVisitor *visitor) { visitor->visit(this); } -Function::Function(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +Function::Function(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : ScopedSymbol(translationUnit, sourceLocation, name), _templateParameters(0), _flags(0) @@ -203,8 +203,8 @@ bool Function::isEqualTo(const Type *other) const else if (isVolatile() != o->isVolatile()) return false; - Name *l = identity(); - Name *r = o->identity(); + const Name *l = identity(); + const Name *r = o->identity(); if (l == r || (l && l->isEqualTo(r))) { if (_arguments->symbolCount() != o->_arguments->symbolCount()) return false; @@ -315,7 +315,7 @@ void Function::visitSymbol0(SymbolVisitor *visitor) } } -ScopedSymbol::ScopedSymbol(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +ScopedSymbol::ScopedSymbol(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : Symbol(translationUnit, sourceLocation, name) { _members = new Scope(this); } @@ -361,7 +361,7 @@ void Block::visitSymbol0(SymbolVisitor *visitor) } } -Enum::Enum(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +Enum::Enum(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : ScopedSymbol(translationUnit, sourceLocation, name) { } @@ -376,8 +376,8 @@ bool Enum::isEqualTo(const Type *other) const const Enum *o = other->asEnumType(); if (! o) return false; - Name *l = identity(); - Name *r = o->identity(); + const Name *l = identity(); + const Name *r = o->identity(); if (l == r) return true; else if (! l) @@ -405,7 +405,7 @@ void Enum::visitSymbol0(SymbolVisitor *visitor) } } -Namespace::Namespace(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +Namespace::Namespace(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : ScopedSymbol(translationUnit, sourceLocation, name) { } @@ -417,8 +417,8 @@ bool Namespace::isEqualTo(const Type *other) const const Namespace *o = other->asNamespaceType(); if (! o) return false; - Name *l = identity(); - Name *r = o->identity(); + const Name *l = identity(); + const Name *r = o->identity(); if (l == r || (l && l->isEqualTo(r))) return true; return false; @@ -447,7 +447,7 @@ void Namespace::visitSymbol0(SymbolVisitor *visitor) FullySpecifiedType Namespace::type() const { return FullySpecifiedType(const_cast<Namespace *>(this)); } -BaseClass::BaseClass(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +BaseClass::BaseClass(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : Symbol(translationUnit, sourceLocation, name), _isVirtual(false) { } @@ -468,7 +468,7 @@ void BaseClass::visitSymbol0(SymbolVisitor *visitor) { visitor->visit(this); } ForwardClassDeclaration::ForwardClassDeclaration(TranslationUnit *translationUnit, - unsigned sourceLocation, Name *name) + unsigned sourceLocation, const Name *name) : Symbol(translationUnit, sourceLocation, name), _templateParameters(0) { } @@ -512,7 +512,7 @@ bool ForwardClassDeclaration::matchType0(const Type *otherType, TypeMatcher *mat return false; } -Class::Class(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +Class::Class(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : ScopedSymbol(translationUnit, sourceLocation, name), _key(ClassKey), _templateParameters(0) @@ -581,8 +581,8 @@ bool Class::isEqualTo(const Type *other) const const Class *o = other->asClassType(); if (! o) return false; - Name *l = identity(); - Name *r = o->identity(); + const Name *l = identity(); + const Name *r = o->identity(); if (l == r || (l && l->isEqualTo(r))) return true; else @@ -601,7 +601,7 @@ void Class::visitSymbol0(SymbolVisitor *visitor) } } -ObjCBaseClass::ObjCBaseClass(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +ObjCBaseClass::ObjCBaseClass(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : Symbol(translationUnit, sourceLocation, name) { } @@ -614,7 +614,7 @@ FullySpecifiedType ObjCBaseClass::type() const void ObjCBaseClass::visitSymbol0(SymbolVisitor *visitor) { visitor->visit(this); } -ObjCBaseProtocol::ObjCBaseProtocol(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +ObjCBaseProtocol::ObjCBaseProtocol(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : Symbol(translationUnit, sourceLocation, name) { } @@ -627,7 +627,7 @@ FullySpecifiedType ObjCBaseProtocol::type() const void ObjCBaseProtocol::visitSymbol0(SymbolVisitor *visitor) { visitor->visit(this); } -ObjCClass::ObjCClass(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name): +ObjCClass::ObjCClass(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name): ScopedSymbol(translationUnit, sourceLocation, name), _isInterface(false), _categoryName(0), @@ -647,8 +647,8 @@ bool ObjCClass::isEqualTo(const Type *other) const if (!o) return false; - Name *l = identity(); - Name *r = o->identity(); + const Name *l = identity(); + const Name *r = o->identity(); if (l == r || (l && l->isEqualTo(r))) return true; else @@ -680,7 +680,7 @@ bool ObjCClass::matchType0(const Type *otherType, TypeMatcher *matcher) const return false; } -ObjCProtocol::ObjCProtocol(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name): +ObjCProtocol::ObjCProtocol(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name): ScopedSymbol(translationUnit, sourceLocation, name) { } @@ -697,8 +697,8 @@ bool ObjCProtocol::isEqualTo(const Type *other) const if (!o) return false; - Name *l = identity(); - Name *r = o->identity(); + const Name *l = identity(); + const Name *r = o->identity(); if (l == r || (l && l->isEqualTo(r))) return true; else @@ -724,7 +724,8 @@ bool ObjCProtocol::matchType0(const Type *otherType, TypeMatcher *matcher) const return false; } -ObjCForwardClassDeclaration::ObjCForwardClassDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name): +ObjCForwardClassDeclaration::ObjCForwardClassDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, + const Name *name): Symbol(translationUnit, sourceLocation, name) { } @@ -763,7 +764,8 @@ bool ObjCForwardClassDeclaration::matchType0(const Type *otherType, TypeMatcher return false; } -ObjCForwardProtocolDeclaration::ObjCForwardProtocolDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name): +ObjCForwardProtocolDeclaration::ObjCForwardProtocolDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, + const Name *name): Symbol(translationUnit, sourceLocation, name) { } @@ -802,7 +804,7 @@ bool ObjCForwardProtocolDeclaration::matchType0(const Type *otherType, TypeMatch return false; } -ObjCMethod::ObjCMethod(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name) +ObjCMethod::ObjCMethod(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name) : ScopedSymbol(translationUnit, sourceLocation, name), _flags(0) { _arguments = new Scope(this); } @@ -818,8 +820,8 @@ bool ObjCMethod::isEqualTo(const Type *other) const if (! o) return false; - Name *l = identity(); - Name *r = o->identity(); + const Name *l = identity(); + const Name *r = o->identity(); if (l == r || (l && l->isEqualTo(r))) { if (_arguments->symbolCount() != o->_arguments->symbolCount()) return false; @@ -902,7 +904,7 @@ void ObjCMethod::visitSymbol0(SymbolVisitor *visitor) ObjCPropertyDeclaration::ObjCPropertyDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, - Name *name): + const Name *name): Symbol(translationUnit, sourceLocation, name), _propertyAttributes(None), _getterName(0), diff --git a/src/shared/cplusplus/Symbols.h b/src/shared/cplusplus/Symbols.h index 022846d3c02..a75d09e0ffd 100644 --- a/src/shared/cplusplus/Symbols.h +++ b/src/shared/cplusplus/Symbols.h @@ -76,7 +76,7 @@ private: class CPLUSPLUS_EXPORT UsingNamespaceDirective: public Symbol { public: - UsingNamespaceDirective(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + UsingNamespaceDirective(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~UsingNamespaceDirective(); // Symbol's interface @@ -95,7 +95,7 @@ protected: class CPLUSPLUS_EXPORT UsingDeclaration: public Symbol { public: - UsingDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + UsingDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~UsingDeclaration(); // Symbol's interface @@ -114,7 +114,7 @@ protected: class CPLUSPLUS_EXPORT Declaration: public Symbol { public: - Declaration(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + Declaration(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~Declaration(); TemplateParameters *templateParameters() const; @@ -142,7 +142,7 @@ private: class CPLUSPLUS_EXPORT Argument: public Symbol { public: - Argument(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + Argument(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~Argument(); void setType(const FullySpecifiedType &type); @@ -170,7 +170,7 @@ private: class CPLUSPLUS_EXPORT ScopedSymbol: public Symbol { public: - ScopedSymbol(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + ScopedSymbol(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~ScopedSymbol(); unsigned memberCount() const; @@ -210,7 +210,7 @@ protected: class CPLUSPLUS_EXPORT ForwardClassDeclaration: public Symbol, public Type { public: - ForwardClassDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + ForwardClassDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~ForwardClassDeclaration(); TemplateParameters *templateParameters() const; @@ -244,7 +244,7 @@ private: class CPLUSPLUS_EXPORT Enum: public ScopedSymbol, public Type { public: - Enum(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + Enum(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~Enum(); // Symbol's interface @@ -281,7 +281,7 @@ public: }; public: - Function(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + Function(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~Function(); bool isNormal() const; @@ -372,7 +372,7 @@ private: class CPLUSPLUS_EXPORT Namespace: public ScopedSymbol, public Type { public: - Namespace(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + Namespace(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~Namespace(); // Symbol's interface @@ -402,7 +402,7 @@ protected: class CPLUSPLUS_EXPORT BaseClass: public Symbol { public: - BaseClass(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + BaseClass(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~BaseClass(); bool isVirtual() const; @@ -427,7 +427,7 @@ private: class CPLUSPLUS_EXPORT Class: public ScopedSymbol, public Type { public: - Class(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + Class(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~Class(); enum Key { @@ -484,7 +484,7 @@ private: class CPLUSPLUS_EXPORT ObjCBaseClass: public Symbol { public: - ObjCBaseClass(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + ObjCBaseClass(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~ObjCBaseClass(); // Symbol's interface @@ -505,7 +505,7 @@ private: class CPLUSPLUS_EXPORT ObjCBaseProtocol: public Symbol { public: - ObjCBaseProtocol(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + ObjCBaseProtocol(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~ObjCBaseProtocol(); // Symbol's interface @@ -526,7 +526,7 @@ private: class CPLUSPLUS_EXPORT ObjCForwardProtocolDeclaration: public Symbol, public Type { public: - ObjCForwardProtocolDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + ObjCForwardProtocolDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~ObjCForwardProtocolDeclaration(); virtual FullySpecifiedType type() const; @@ -556,7 +556,7 @@ private: class CPLUSPLUS_EXPORT ObjCProtocol: public ScopedSymbol, public Type { public: - ObjCProtocol(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + ObjCProtocol(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~ObjCProtocol(); unsigned protocolCount() const @@ -598,7 +598,7 @@ private: class CPLUSPLUS_EXPORT ObjCForwardClassDeclaration: public Symbol, public Type { public: - ObjCForwardClassDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + ObjCForwardClassDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~ObjCForwardClassDeclaration(); virtual FullySpecifiedType type() const; @@ -628,15 +628,15 @@ private: class CPLUSPLUS_EXPORT ObjCClass: public ScopedSymbol, public Type { public: - ObjCClass(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + ObjCClass(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~ObjCClass(); bool isInterface() const { return _isInterface; } void setInterface(bool isInterface) { _isInterface = isInterface; } bool isCategory() const { return _categoryName != 0; } - Name *categoryName() const { return _categoryName; } - void setCategoryName(Name *categoryName) { _categoryName = categoryName; } + const Name *categoryName() const { return _categoryName; } + void setCategoryName(const Name *categoryName) { _categoryName = categoryName; } ObjCBaseClass *baseClass() const { return _baseClass; } @@ -677,7 +677,7 @@ protected: private: bool _isInterface; - Name *_categoryName; + const Name *_categoryName; ObjCBaseClass * _baseClass; Array<ObjCBaseProtocol *> _protocols; }; @@ -685,7 +685,7 @@ private: class CPLUSPLUS_EXPORT ObjCMethod: public ScopedSymbol, public Type { public: - ObjCMethod(TranslationUnit *translationUnit, unsigned sourceLocation, Name *name); + ObjCMethod(TranslationUnit *translationUnit, unsigned sourceLocation, const Name *name); virtual ~ObjCMethod(); FullySpecifiedType returnType() const; @@ -760,7 +760,7 @@ public: public: ObjCPropertyDeclaration(TranslationUnit *translationUnit, unsigned sourceLocation, - Name *name); + const Name *name); virtual ~ObjCPropertyDeclaration(); bool hasAttribute(int attribute) const @@ -775,16 +775,16 @@ public: bool hasSetter() const { return hasAttribute(Setter); } - Name *getterName() const + const Name *getterName() const { return _getterName; } - void setGetterName(Name *getterName) + void setGetterName(const Name *getterName) { _getterName = getterName; } - Name *setterName() const + const Name *setterName() const { return _setterName; } - void setSetterName(Name *setterName) + void setSetterName(const Name *setterName) { _setterName = setterName; } void setType(const FullySpecifiedType &type) @@ -805,7 +805,8 @@ protected: private: FullySpecifiedType _type; int _propertyAttributes; - Name *_getterName, *_setterName; + const Name *_getterName; + const Name *_setterName; }; } // end of namespace CPlusPlus -- GitLab