summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDimitri van Heesch <doxygen@gmail.com>2020-11-17 20:03:32 (GMT)
committerDimitri van Heesch <doxygen@gmail.com>2020-11-17 20:03:32 (GMT)
commitfa65bb38f81457d00f9c900bb57eb68bea59b1b4 (patch)
tree8925096bf69965cdbf8b2adf9f7809373972cf8e
parent4eab118227f2775c9f5d0e5ff6b7c283b91bca0c (diff)
downloadDoxygen-fa65bb38f81457d00f9c900bb57eb68bea59b1b4.zip
Doxygen-fa65bb38f81457d00f9c900bb57eb68bea59b1b4.tar.gz
Doxygen-fa65bb38f81457d00f9c900bb57eb68bea59b1b4.tar.bz2
issue #8177: Incorrect inheritance with forward declared templated classes
-rw-r--r--src/doxygen.cpp23
1 files changed, 9 insertions, 14 deletions
diff --git a/src/doxygen.cpp b/src/doxygen.cpp
index ef0828f..6089470 100644
--- a/src/doxygen.cpp
+++ b/src/doxygen.cpp
@@ -166,7 +166,7 @@ DefinesPerFileList Doxygen::macroDefinitions;
bool Doxygen::clangAssistedParsing = FALSE;
// locally accessible globals
-static std::map< std::string, const Entry* > g_classEntries;
+static std::multimap< std::string, const Entry* > g_classEntries;
static StringVector g_inputFiles;
static QDict<void> g_compoundKeywordDict(7); // keywords recognised as compounds
static OutputList *g_outputList = 0; // list of output generating objects
@@ -972,8 +972,8 @@ static void addClassToContext(const Entry *root)
// see if we already found the class before
ClassDefMutable *cd = getClassMutable(qualifiedName);
- Debug::print(Debug::Classes,0, " Found class with name %s (qualifiedName=%s -> cd=%p)\n",
- cd ? qPrint(cd->name()) : qPrint(root->name), qPrint(qualifiedName),cd);
+ //Debug::print(Debug::Classes,0, " Found class with name %s (qualifiedName=%s -> cd=%p)\n",
+ // cd ? qPrint(cd->name()) : qPrint(root->name), qPrint(qualifiedName),cd);
if (cd)
{
@@ -4025,8 +4025,8 @@ static void findBaseClassesForClass(
const ArgumentList &formalArgs = masterCd->templateArguments();
for (const BaseInfo &bi : root->extends)
{
- //printf("masterCd=%s bi->name='%s' #actualArgs=%d\n",
- // masterCd->localName().data(),bi->name.data(),actualArgs?(int)actualArgs->count():-1);
+ //printf("masterCd=%s bi.name='%s' #actualArgs=%d\n",
+ // masterCd->localName().data(),bi.name.data(),actualArgs ? (int)actualArgs->size() : -1);
bool delTempNames=FALSE;
if (templateNames==0)
{
@@ -4107,8 +4107,8 @@ static bool findTemplateInstanceRelation(const Entry *root,
// search for new template instances caused by base classes of
// instanceClass
- auto it = g_classEntries.find(templateClass->name().data());
- if (it!=g_classEntries.end())
+ auto it_pair = g_classEntries.equal_range(templateClass->name().data());
+ for (auto it=it_pair.first ; it!=it_pair.second ; ++it)
{
const Entry *templateRoot = it->second;
Debug::print(Debug::Classes,0," template root found %s templSpec=%s!\n",
@@ -4120,11 +4120,6 @@ static bool findTemplateInstanceRelation(const Entry *root,
findUsedClassesForClass(templateRoot,context,templateClass,instanceClass,
isArtificial,templArgs,templateNames);
}
- else
- {
- Debug::print(Debug::Classes,0," no template root entry found!\n");
- // TODO: what happened if we get here?
- }
//Debug::print(Debug::Classes,0," Template instance %s : \n",instanceClass->name().data());
//ArgumentList *tl = templateClass->templateArguments();
@@ -4602,7 +4597,7 @@ static void findClassEntries(const Entry *root)
{
if (isClassSection(root))
{
- g_classEntries.insert({root->name.data(),root});
+ g_classEntries.insert({root->name.str(),root});
}
for (const auto &e : root->children()) findClassEntries(e.get());
}
@@ -4650,7 +4645,7 @@ static void findInheritedTemplateInstances()
ClassDefMutable *cdm = toClassDefMutable(cd);
if (cdm)
{
- //printf("Class %s %d\n",cd->name().data(),root->extends->count());
+ //printf("Class %s %zu\n",cd->name().data(),root->extends.size());
findBaseClassesForClass(root,cd,cdm,cdm,TemplateInstances,FALSE);
}
}