Doxygen
Loading...
Searching...
No Matches
SymbolResolver Class Reference

#include <src/symbolresolver.h>

Classes

struct  Private

Public Types

enum class  ClearScope { All , Classes , Unresolved }
 Clear the type lookup cache for the current thread. More...

Public Member Functions

 SymbolResolver (const FileDef *fileScope=nullptr)
 ~SymbolResolver ()
const ClassDefresolveClass (const Definition *scope, const QCString &name, bool maybeUnlinkable=false, bool mayBeHidden=false)
 Find the class definition matching name within the scope set.
ClassDefMutableresolveClassMutable (const Definition *scope, const QCString &name, bool mayBeUnlinkable=false, bool mayBeHidden=false)
 Wrapper around resolveClass that returns a mutable interface to the class object or a nullptr if the symbol is immutable.
const DefinitionresolveSymbol (const Definition *scope, const QCString &name, const QCString &args=QCString(), bool checkCV=false, bool insideCode=false, bool onlyLinkable=false)
 Find the symbool definition matching name within the scope set.
int isAccessibleFrom (const Definition *scope, const Definition *item)
 Checks if symbol item is accessible from within scope.
int isAccessibleFromWithExpScope (const Definition *scope, const Definition *item, const QCString &explicitScopePart)
 Check if symbol item is accessible from within scope, where it has to match the explicitScopePart.
void setFileScope (const FileDef *fd)
 Sets or updates the file scope using when resolving symbols.
const MemberDefgetTypedef () const
 In case a call to resolveClass() resolves to a type member (e.g.
QCString getTemplateSpec () const
 In case a call to resolveClass() points to a template specialization, the template part is return via this method.
QCString getResolvedType () const
 In case a call to resolveClass() points to a typedef or using declaration.

Static Public Member Functions

static void clearTypeLookupCache (ClearScope scope)
static void showCacheUsage ()
 Show usage of the type lookup cache.

Private Attributes

std::unique_ptr< Privatep

Detailed Description

Helper class to find a class definition or check if A symbol is accessible in a given scope.

Definition at line 31 of file symbolresolver.h.

Member Enumeration Documentation

◆ ClearScope

enum class SymbolResolver::ClearScope
strong

Clear the type lookup cache for the current thread.

Enumerator
All 
Classes 
Unresolved 

Definition at line 102 of file symbolresolver.h.

102{ All, Classes, Unresolved };

Constructor & Destructor Documentation

◆ SymbolResolver()

SymbolResolver::SymbolResolver ( const FileDef * fileScope = nullptr)
explicit

Definition at line 1661 of file symbolresolver.cpp.

1662 : p(std::make_unique<Private>(fileScope))
1663{
1664}
std::unique_ptr< Private > p

References p.

◆ ~SymbolResolver()

SymbolResolver::~SymbolResolver ( )

Definition at line 1666 of file symbolresolver.cpp.

1667{
1668}

Member Function Documentation

◆ clearTypeLookupCache()

void SymbolResolver::clearTypeLookupCache ( SymbolResolver::ClearScope scope)
static

Definition at line 1788 of file symbolresolver.cpp.

1789{
1790 auto &cache = getTypeLookupCache();
1791 switch (scope)
1792 {
1793 case ClearScope::All:
1794 cache.clear();
1795 break;
1797 {
1798 StringVector elementsToRemove;
1799 for (const auto &ci : cache)
1800 {
1801 const LookupInfo &li = ci.second;
1802 if (li.definition==nullptr && li.typeDef==nullptr)
1803 {
1804 elementsToRemove.push_back(ci.first);
1805 }
1806 }
1807 for (const auto &k : elementsToRemove)
1808 {
1809 cache.remove(k);
1810 }
1811 }
1812 break;
1814 {
1815 StringVector elementsToRemove;
1816 for (const auto &ci : cache)
1817 {
1818 const LookupInfo &li = ci.second;
1819 if (li.definition)
1820 {
1821 elementsToRemove.push_back(ci.first);
1822 }
1823 }
1824 for (const auto &k : elementsToRemove)
1825 {
1826 cache.remove(k);
1827 }
1828 }
1829 break;
1830 }
1831}
std::vector< std::string > StringVector
Definition containers.h:33
const Definition * definition
Definition doxygen.h:59
const MemberDef * typeDef
Definition doxygen.h:60
static LookupCache & getTypeLookupCache()

References All, Classes, LookupInfo::definition, getTypeLookupCache(), LookupInfo::typeDef, and Unresolved.

Referenced by flushCachedTemplateRelations(), flushUnresolvedRelations(), and parseInput().

◆ getResolvedType()

QCString SymbolResolver::getResolvedType ( ) const

In case a call to resolveClass() points to a typedef or using declaration.

The type name it resolved to is returned via this method.

Definition at line 1783 of file symbolresolver.cpp.

1784{
1785 return p->resolvedType;
1786}

References p.

Referenced by getCanonicalTypeForIdentifier(), and SymbolResolver::Private::getResolvedTypeRec().

◆ getTemplateSpec()

QCString SymbolResolver::getTemplateSpec ( ) const

In case a call to resolveClass() points to a template specialization, the template part is return via this method.

Definition at line 1778 of file symbolresolver.cpp.

1779{
1780 return p->templateSpec;
1781}

References p.

Referenced by findClassRelation(), and getCanonicalTypeForIdentifier().

◆ getTypedef()

const MemberDef * SymbolResolver::getTypedef ( ) const

In case a call to resolveClass() resolves to a type member (e.g.

an enum) this method will return it.

Definition at line 1773 of file symbolresolver.cpp.

1774{
1775 return p->typeDef;
1776}

References p.

Referenced by findClassRelation(), getCanonicalTypeForIdentifier(), and linkifyText().

◆ isAccessibleFrom()

int SymbolResolver::isAccessibleFrom ( const Definition * scope,
const Definition * item )

Checks if symbol item is accessible from within scope.

Returns
-1 if item is not accessible or a number indicating how many scope levels up the nearest match was found.

Definition at line 1742 of file symbolresolver.cpp.

1743{
1744 AUTO_TRACE("scope={} item={}",
1745 scope?scope->name():QCString(), item?item->name():QCString());
1746 p->reset();
1747 VisitedKeys visitedKeys;
1748 AccessStack accessStack;
1749 int result = p->isAccessibleFrom(visitedKeys,accessStack,scope,item);
1750 AUTO_TRACE_EXIT("result={}",result);
1751 return result;
1752}
virtual const QCString & name() const =0
#define AUTO_TRACE(...)
Definition docnode.cpp:47
#define AUTO_TRACE_EXIT(...)
Definition docnode.cpp:49
StringVector VisitedKeys

References AUTO_TRACE, AUTO_TRACE_EXIT, Definition::name(), and p.

Referenced by SymbolResolver::Private::isAccessibleFrom(), SymbolResolver::Private::isAccessibleFromWithExpScope(), and resolveTypeDef().

◆ isAccessibleFromWithExpScope()

int SymbolResolver::isAccessibleFromWithExpScope ( const Definition * scope,
const Definition * item,
const QCString & explicitScopePart )

Check if symbol item is accessible from within scope, where it has to match the explicitScopePart.

Returns
-1 if item is not accessible or a number indicating how many scope levels up the nearest match was found.

Definition at line 1754 of file symbolresolver.cpp.

1756{
1757 AUTO_TRACE("scope={} item={} explicitScopePart={}",
1758 scope?scope->name():QCString(), item?item->name():QCString(), explicitScopePart);
1759 p->reset();
1760 VisitedKeys visitedKeys;
1761 VisitedNamespaces visitedNamespaces;
1762 AccessStack accessStack;
1763 int result = p->isAccessibleFromWithExpScope(visitedKeys,visitedNamespaces,accessStack,scope,item,explicitScopePart);
1764 AUTO_TRACE_EXIT("result={}",result);
1765 return result;
1766}
std::unordered_map< std::string, const Definition * > VisitedNamespaces

References AUTO_TRACE, AUTO_TRACE_EXIT, Definition::name(), and p.

Referenced by getMemberFromSymbol(), SymbolResolver::Private::getResolvedSymbol(), SymbolResolver::Private::getResolvedType(), SymbolResolver::Private::isAccessibleFromWithExpScope(), and SymbolResolver::Private::substTypedef().

◆ resolveClass()

const ClassDef * SymbolResolver::resolveClass ( const Definition * scope,
const QCString & name,
bool maybeUnlinkable = false,
bool mayBeHidden = false )

Find the class definition matching name within the scope set.

Parameters
scopeThe scope to search from.
nameThe name of the symbol.
maybeUnlinkableinclude unlinkable symbols in the search.
mayBeHiddeninclude hidden symbols in the search.
Note
As a result of this call the getters getTypedef(), getTemplateSpec(), and getResolvedType() are set as well.

Definition at line 1671 of file symbolresolver.cpp.

1675{
1676 AUTO_TRACE("scope={} name={} mayBeUnlinkable={} mayBeHidden={}",
1677 scope?scope->name():QCString(), name, mayBeUnlinkable, mayBeHidden);
1678 p->reset();
1679
1680 auto lang = scope ? scope->getLanguage() :
1681 p->fileScope() ? p->fileScope()->getLanguage() :
1682 SrcLangExt::Cpp; // fallback to C++
1683
1684 if (scope==nullptr ||
1687 ) ||
1688 (name.stripWhiteSpace().startsWith("::")) ||
1689 ((lang==SrcLangExt::Java || lang==SrcLangExt::CSharp) && QCString(name).find("::")!=-1)
1690 )
1691 {
1693 }
1694 const ClassDef *result=nullptr;
1695 if (Config_getBool(OPTIMIZE_OUTPUT_VHDL))
1696 {
1697 result = getClass(name);
1698 }
1699 else
1700 {
1701 VisitedKeys visitedKeys;
1702 QCString lookupName = lang==SrcLangExt::CSharp ? mangleCSharpGenericName(name) : name;
1703 AUTO_TRACE_ADD("lookup={}",lookupName);
1704 result = p->getResolvedTypeRec(getTypeLookupCache(),visitedKeys,scope,lookupName,&p->typeDef,&p->templateSpec,&p->resolvedType);
1705 if (result==nullptr) // for nested classes imported via tag files, the scope may not
1706 // present, so we check the class name directly as well.
1707 // See also bug701314
1708 {
1709 result = getClass(lookupName);
1710 }
1711 }
1712 if (!mayBeUnlinkable && result && !result->isLinkable())
1713 {
1714 if (!mayBeHidden || !result->isHidden())
1715 {
1716 AUTO_TRACE_ADD("hiding symbol {}",result->name());
1717 result=nullptr; // don't link to artificial/hidden classes unless explicitly allowed
1718 }
1719 }
1720 AUTO_TRACE_EXIT("result={}",result?result->name():QCString());
1721 return result;
1722}
virtual SrcLangExt getLanguage() const =0
Returns the programming language this definition was written in.
virtual bool isLinkable() const =0
virtual DefType definitionType() const =0
virtual bool isHidden() const =0
static NamespaceDefMutable * globalScope
Definition doxygen.h:120
bool startsWith(const char *s) const
Definition qcstring.h:507
QCString stripWhiteSpace() const
returns a copy of this string with leading and trailing whitespace removed
Definition qcstring.h:260
ClassDef * getClass(const QCString &n)
#define Config_getBool(name)
Definition config.h:33
#define AUTO_TRACE_ADD(...)
Definition docnode.cpp:48
QCString mangleCSharpGenericName(const QCString &name)
Definition util.cpp:6931

References AUTO_TRACE, AUTO_TRACE_ADD, AUTO_TRACE_EXIT, Config_getBool, Definition::definitionType(), getClass(), Definition::getLanguage(), getTypeLookupCache(), Doxygen::globalScope, Definition::isHidden(), Definition::isLinkable(), mangleCSharpGenericName(), Definition::name(), p, QCString::startsWith(), QCString::stripWhiteSpace(), Definition::TypeClass, and Definition::TypeNamespace.

Referenced by findClassDefinition(), findClassWithinClassContext(), findUsingDeclImports(), getCanonicalTypeForIdentifier(), isVarWithConstructor(), linkifyText(), normalizeNonTemplateArgumentsInString(), and resolveClassMutable().

◆ resolveClassMutable()

ClassDefMutable * SymbolResolver::resolveClassMutable ( const Definition * scope,
const QCString & name,
bool mayBeUnlinkable = false,
bool mayBeHidden = false )
inline

Wrapper around resolveClass that returns a mutable interface to the class object or a nullptr if the symbol is immutable.

Definition at line 57 of file symbolresolver.h.

61 {
62 return toClassDefMutable(const_cast<ClassDef*>(resolveClass(scope,name,mayBeUnlinkable,mayBeHidden)));
63 }
const ClassDef * resolveClass(const Definition *scope, const QCString &name, bool maybeUnlinkable=false, bool mayBeHidden=false)
Find the class definition matching name within the scope set.
ClassDefMutable * toClassDefMutable(Definition *d)

References resolveClass(), and toClassDefMutable().

Referenced by ClassDefImpl::addTypeConstraint(), findClassRelation(), findUsedClassesForClass(), and resolveTemplateInstanceInType().

◆ resolveSymbol()

const Definition * SymbolResolver::resolveSymbol ( const Definition * scope,
const QCString & name,
const QCString & args = QCString(),
bool checkCV = false,
bool insideCode = false,
bool onlyLinkable = false )

Find the symbool definition matching name within the scope set.

Parameters
scopeThe scope to search from.
nameThe name of the symbol.
argsArgument list associated with the symbol (for functions)
checkCVCheck const/volatile qualifiers (for methods)
insideCodeIs the symbol found in a code fragment
onlyLinkableOnly search linkable definitions

Definition at line 1724 of file symbolresolver.cpp.

1730{
1731 AUTO_TRACE("scope={} name={} args={} checkCV={} insideCode={}",
1732 scope?scope->name():QCString(), name, args, checkCV, insideCode);
1733 p->reset();
1734 if (scope==nullptr) scope=Doxygen::globalScope;
1735 VisitedKeys visitedKeys;
1736 const Definition *result = p->getResolvedSymbolRec(getSymbolLookupCache(),visitedKeys,scope,name,args,checkCV,insideCode,onlyLinkable,&p->typeDef,&p->templateSpec,&p->resolvedType);
1737 AUTO_TRACE_EXIT("result={}{}", qPrint(result?result->qualifiedName():QCString()),
1738 qPrint(result && result->definitionType()==Definition::TypeMember ? toMemberDef(result)->argsString() : QCString()));
1739 return result;
1740}
virtual QCString qualifiedName() const =0
MemberDef * toMemberDef(Definition *d)
const char * qPrint(const char *s)
Definition qcstring.h:687
static LookupCache & getSymbolLookupCache()

References AUTO_TRACE, AUTO_TRACE_EXIT, Definition::definitionType(), getSymbolLookupCache(), Doxygen::globalScope, Definition::name(), p, qPrint(), Definition::qualifiedName(), toMemberDef(), and Definition::TypeMember.

Referenced by findUsingDeclarations(), findUsingDeclImports(), getDefs(), and linkifyText().

◆ setFileScope()

void SymbolResolver::setFileScope ( const FileDef * fd)

Sets or updates the file scope using when resolving symbols.

Definition at line 1768 of file symbolresolver.cpp.

1769{
1770 p->setFileScope(fileScope);
1771}

References p.

Referenced by getDefs().

◆ showCacheUsage()

void SymbolResolver::showCacheUsage ( )
static

Show usage of the type lookup cache.

Definition at line 1849 of file symbolresolver.cpp.

1850{
1851 // merge the stats of the main thread
1854
1855 msg("type lookup cache used {}/{} hits={} misses={}\n",
1860 msg("symbol lookup cache used {}/{} hits={} misses={}\n",
1865 int typeCacheParam = computeIdealCacheParam(static_cast<size_t>(g_typeCacheStatistics.misses*2/3)); // part of the cache is flushed, hence the 2/3 correction factor
1866 int symbolCacheParam = computeIdealCacheParam(static_cast<size_t>(g_symbolCacheStatistics.misses*2/3)); // part of the cache is flushed, hence the 2/3 correction factor
1867 int cacheParam = std::max(typeCacheParam,symbolCacheParam);
1868 if (cacheParam>Config_getInt(LOOKUP_CACHE_SIZE))
1869 {
1870 msg("Note: based on cache misses the ideal setting for LOOKUP_CACHE_SIZE is {} at the cost of higher memory usage.\n",cacheParam);
1871 }
1872}
#define Config_getInt(name)
Definition config.h:34
#define msg(fmt,...)
Definition message.h:94
static void mergeStatistics(CacheStatistics &stats, LookupCache &cache)
static int computeIdealCacheParam(size_t v)
static CacheStatistics g_symbolCacheStatistics
static CacheStatistics g_typeCacheStatistics

References computeIdealCacheParam(), Config_getInt, g_symbolCacheStatistics, g_typeCacheStatistics, getSymbolLookupCache(), getTypeLookupCache(), mergeStatistics(), and msg.

Referenced by generateOutput().

Member Data Documentation

◆ p


The documentation for this class was generated from the following files: