Introduce Transform::Config::DropDefaultArg

Currently only implemented for the STL collection.

This could eventually be used to allow customization
of which default argument to strip and which class template.

For now, it is only used to prevent the addition of template
default template argument to the STL collection ... which
we would any strip.

This fixes the secondary issue in ROOT-6020 (one class template
instance having more than one corresponding TClass due to the
inconsistency in the normalization (not adding vs not stripping)
This commit is contained in:
Philippe Canal 2014-01-31 18:45:59 -06:00 committed by sftnight
parent 1004034c75
commit c6501ffe97
2 changed files with 33 additions and 0 deletions

View File

@ -27,6 +27,7 @@ namespace clang {
class QualType; class QualType;
class Sema; class Sema;
class TagDecl; class TagDecl;
class TemplateDecl;
class Type; class Type;
class TypedefNameDecl; class TypedefNameDecl;
} }
@ -135,6 +136,12 @@ namespace utils {
SkipCollection m_toSkip; SkipCollection m_toSkip;
ReplaceCollection m_toReplace; ReplaceCollection m_toReplace;
///\brief Returns the number of default argument that should be dropped.
/// from the name of the template instances.
///
///\param[in] decl - The declaration being analyzed.
unsigned int DropDefaultArg(clang::TemplateDecl &Template) const;
bool empty() const { return m_toSkip.size()==0 && m_toReplace.empty(); } bool empty() const { return m_toSkip.size()==0 && m_toReplace.empty(); }
}; };

View File

@ -583,6 +583,32 @@ namespace utils {
return false; return false;
} }
unsigned int
Transform::Config::DropDefaultArg(clang::TemplateDecl &Template) const
{
/// Return the number of default argument to drop.
if (Analyze::IsStdClass(Template)) {
static const char *stls[] = //container names
{"vector","list","deque","map","multimap","set","multiset",0};
static unsigned int values[] = //number of default arg.
{1,1,1,2,2,2,2};
StringRef name = Template.getName();
for(int k=0;stls[k];k++) {
if ( name.equals(stls[k]) ) return values[k];
}
}
// Check in some struct if the Template decl is registered something like
/*
DefaultCollection::const_iterator iter;
iter = m_defaultArgs.find(&Template);
if (iter != m_defaultArgs.end()) {
return iter->second;
}
*/
return 0;
}
static bool ShouldKeepTypedef(QualType QT, static bool ShouldKeepTypedef(QualType QT,
const llvm::SmallSet<const Type*, 4>& TypesToSkip) const llvm::SmallSet<const Type*, 4>& TypesToSkip)
{ {