diff options
author | Przemyslaw Gorszkowski <pgorszkowski@gmail.com> | 2013-01-12 22:05:41 +0100 |
---|---|---|
committer | Przemyslaw Gorszkowski <pgorszkowski@gmail.com> | 2013-01-30 18:49:25 +0100 |
commit | ffba28d26ab6aaf9a953f42d5fa15c55a85c75a7 (patch) | |
tree | 010c0eb03d5caf768b3206ee7b69fe68b93a333c /src/libs/3rdparty/cplusplus/Templates.cpp | |
parent | 0135609973b8c8f9b380aefb618659f698c5c2c5 (diff) | |
download | qt-creator-ffba28d26ab6aaf9a953f42d5fa15c55a85c75a7.tar.gz |
C++: Fix code compl. for instantiation of template specialization
It works for full specialization. Instantiate of the partial
specialization has to be implemented(finding appropriate partial
specialization-on going)
Added unit test.
Change-Id: I8ef5ea963e7c665e0d67d390b3a833486773dab0
Reviewed-by: Erik Verbruggen <erik.verbruggen@digia.com>
Diffstat (limited to 'src/libs/3rdparty/cplusplus/Templates.cpp')
-rw-r--r-- | src/libs/3rdparty/cplusplus/Templates.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/src/libs/3rdparty/cplusplus/Templates.cpp b/src/libs/3rdparty/cplusplus/Templates.cpp index fd1ee873d9..c81ed51b09 100644 --- a/src/libs/3rdparty/cplusplus/Templates.cpp +++ b/src/libs/3rdparty/cplusplus/Templates.cpp @@ -414,9 +414,10 @@ void CloneName::visit(const TemplateNameId *name) for (unsigned i = 0; i < args.size(); ++i) args[i] = _clone->type(name->templateArgumentAt(i), _subst); if (args.empty()) - _name = _control->templateNameId(_clone->identifier(name->identifier())); + _name = _control->templateNameId(_clone->identifier(name->identifier()), name->isSpecialization()); else - _name = _control->templateNameId(_clone->identifier(name->identifier()), &args[0], args.size()); + _name = _control->templateNameId(_clone->identifier(name->identifier()), name->isSpecialization(), + &args[0], args.size()); } void CloneName::visit(const DestructorNameId *name) @@ -528,7 +529,8 @@ FullySpecifiedType Subst::apply(const Name *name) const const NamedType *name = apply(q->base())->asNamedType(); const NamedType *unqualified = apply(q->name())->asNamedType(); if (name && name->name()->identifier() != 0 && unqualified) - return control()->namedType(control()->qualifiedNameId(name->name()->identifier(), unqualified->name())); + return control()->namedType(control()->qualifiedNameId(name->name()->identifier(), + unqualified->name())); } } |