Make sure to free the explicit template arguments provided for an

explicit instantiation. Also, tighten up reference-count checking to
help catch these issues earlier. Fixes PR5069.


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@83225 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Douglas Gregor 2009-10-01 23:51:25 +00:00
Родитель d789d3d985
Коммит b2f81cf7f8
3 изменённых файлов: 9 добавлений и 1 удалений

Просмотреть файл

@ -188,7 +188,10 @@ public:
return this; return this;
} }
StmtClass getStmtClass() const { return (StmtClass)sClass; } StmtClass getStmtClass() const {
assert(RefCount >= 1 && "Referencing already-destroyed statement!");
return (StmtClass)sClass;
}
const char *getStmtClassName() const; const char *getStmtClassName() const;
/// SourceLocation tokens are not useful in isolation - they are low level /// SourceLocation tokens are not useful in isolation - they are low level

Просмотреть файл

@ -3414,6 +3414,7 @@ Sema::DeclResult Sema::ActOnExplicitInstantiation(Scope *S,
TemplateId->getTemplateArgLocations(), TemplateId->getTemplateArgLocations(),
TemplateArgs); TemplateArgs);
HasExplicitTemplateArgs = true; HasExplicitTemplateArgs = true;
TemplateArgsPtr.release();
} }
// C++ [temp.explicit]p1: // C++ [temp.explicit]p1:

Просмотреть файл

@ -69,3 +69,7 @@ template void print_type<int>(float*); // expected-error{{does not refer}}
void print_type(double*); void print_type(double*);
template void print_type<double>(double*); template void print_type<double>(double*);
// PR5069
template<int I> void foo0 (int (&)[I + 1]) { }
template void foo0<2> (int (&)[3]);