aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-01-20 21:06:38 +0000
committerChris Lattner <sabre@nondot.org>2009-01-20 21:06:38 +0000
commit1833a83368bda46b76388069e52b27f12e60dc9c (patch)
tree304ca6c7129fab29c3ba39abf09813e0141392b9 /lib
parent9e0b600dc7373ee7d2857ef5ccebca599ebb5178 (diff)
Fix a crash Anders' was seeing due to free'ing an invalid pointer
caused by my previous commit. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@62613 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/Sema/SemaDeclCXX.cpp14
1 files changed, 2 insertions, 12 deletions
diff --git a/lib/Sema/SemaDeclCXX.cpp b/lib/Sema/SemaDeclCXX.cpp
index a582540859..d5d83be87d 100644
--- a/lib/Sema/SemaDeclCXX.cpp
+++ b/lib/Sema/SemaDeclCXX.cpp
@@ -1202,12 +1202,7 @@ bool Sema::CheckDestructorDeclarator(Declarator &D, QualType &R,
Diag(D.getIdentifierLoc(), diag::err_destructor_with_params);
// Delete the parameters.
- DeclaratorChunk::FunctionTypeInfo &FTI = D.getTypeObject(0).Fun;
- if (FTI.NumArgs) {
- delete [] FTI.ArgInfo;
- FTI.NumArgs = 0;
- FTI.ArgInfo = 0;
- }
+ D.getTypeObject(0).Fun.freeArgs();
}
// Make sure the destructor isn't variadic.
@@ -1264,12 +1259,7 @@ bool Sema::CheckConversionDeclarator(Declarator &D, QualType &R,
Diag(D.getIdentifierLoc(), diag::err_conv_function_with_params);
// Delete the parameters.
- DeclaratorChunk::FunctionTypeInfo &FTI = D.getTypeObject(0).Fun;
- if (FTI.NumArgs) {
- delete [] FTI.ArgInfo;
- FTI.NumArgs = 0;
- FTI.ArgInfo = 0;
- }
+ D.getTypeObject(0).Fun.freeArgs();
}
// Make sure the conversion function isn't variadic.