summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2010-02-03 00:01:43 +0000
committerFariborz Jahanian <fjahanian@apple.com>2010-02-03 00:01:43 +0000
commit08d614d92eab71487a1ef7c9f343bae6bfaea081 (patch)
tree5e3d084f6dccf83a478df77490b9444caeb472e8 /clang
parent5f238a96508c03a1ebb6b41b9e0c27adc80b3c47 (diff)
downloadbcm5719-llvm-08d614d92eab71487a1ef7c9f343bae6bfaea081.tar.gz
bcm5719-llvm-08d614d92eab71487a1ef7c9f343bae6bfaea081.zip
Fix DeclContext of an objective-c @catch variable
declaration. Fixes radar 7590273. llvm-svn: 95164
Diffstat (limited to 'clang')
-rw-r--r--clang/include/clang/Parse/Action.h2
-rw-r--r--clang/lib/Parse/ParseObjc.cpp1
-rw-r--r--clang/lib/Sema/Sema.h1
-rw-r--r--clang/lib/Sema/SemaDecl.cpp13
-rw-r--r--clang/test/CodeGenObjC/blocks-4.m21
5 files changed, 38 insertions, 0 deletions
diff --git a/clang/include/clang/Parse/Action.h b/clang/include/clang/Parse/Action.h
index 6b398f62f60..91854aa480c 100644
--- a/clang/include/clang/Parse/Action.h
+++ b/clang/include/clang/Parse/Action.h
@@ -459,6 +459,8 @@ public:
virtual DeclPtrTy ActOnParamDeclarator(Scope *S, Declarator &D) {
return DeclPtrTy();
}
+ virtual void ActOnObjCCatchParam(DeclPtrTy D) {
+ }
/// AddInitializerToDecl - This action is called immediately after
/// ActOnDeclarator (when an initializer is present). The code is factored
diff --git a/clang/lib/Parse/ParseObjc.cpp b/clang/lib/Parse/ParseObjc.cpp
index ae85aa3a8ae..e837c765bff 100644
--- a/clang/lib/Parse/ParseObjc.cpp
+++ b/clang/lib/Parse/ParseObjc.cpp
@@ -1482,6 +1482,7 @@ Parser::OwningStmtResult Parser::ParseObjCTryStmt(SourceLocation atLoc) {
// Inform the actions module about the parameter declarator, so it
// gets added to the current scope.
FirstPart = Actions.ActOnParamDeclarator(CurScope, ParmDecl);
+ Actions.ActOnObjCCatchParam(FirstPart);
} else
ConsumeToken(); // consume '...'
diff --git a/clang/lib/Sema/Sema.h b/clang/lib/Sema/Sema.h
index d971b9caebf..b8831b4b7ab 100644
--- a/clang/lib/Sema/Sema.h
+++ b/clang/lib/Sema/Sema.h
@@ -676,6 +676,7 @@ public:
bool &OverloadableAttrRequired);
void CheckMain(FunctionDecl *FD);
virtual DeclPtrTy ActOnParamDeclarator(Scope *S, Declarator &D);
+ virtual void ActOnObjCCatchParam(DeclPtrTy D);
virtual void ActOnParamDefaultArgument(DeclPtrTy param,
SourceLocation EqualLoc,
ExprArg defarg);
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp
index c604f6a4eef..8c217f8e0d2 100644
--- a/clang/lib/Sema/SemaDecl.cpp
+++ b/clang/lib/Sema/SemaDecl.cpp
@@ -3934,6 +3934,19 @@ Sema::ActOnParamDeclarator(Scope *S, Declarator &D) {
return DeclPtrTy::make(New);
}
+void Sema::ActOnObjCCatchParam(DeclPtrTy D) {
+ ParmVarDecl *Param = cast<ParmVarDecl>(D.getAs<Decl>());
+
+ if (FunctionDecl *Function = dyn_cast<FunctionDecl>(CurContext))
+ Param->setDeclContext(Function);
+ else if (CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(CurContext))
+ Param->setDeclContext(MD);
+ else if (BlockDecl *BD = dyn_cast<BlockDecl>(CurContext))
+ Param->setDeclContext(BD);
+ // FIXME. Other contexts?
+
+}
+
void Sema::ActOnFinishKNRParamDeclarations(Scope *S, Declarator &D,
SourceLocation LocAfterDecls) {
assert(D.getTypeObject(0).Kind == DeclaratorChunk::Function &&
diff --git a/clang/test/CodeGenObjC/blocks-4.m b/clang/test/CodeGenObjC/blocks-4.m
new file mode 100644
index 00000000000..d945ed44fac
--- /dev/null
+++ b/clang/test/CodeGenObjC/blocks-4.m
@@ -0,0 +1,21 @@
+// RUN: %clang_cc1 -triple i386-apple-darwin9 -emit-llvm -fblocks -o %t %s
+// rdar://7590273
+
+void EXIT(id e);
+
+@interface NSBlockOperation {
+}
++(id)blockOperationWithBlock:(void (^)(void))block ;
+@end
+
+void FUNC() {
+ [NSBlockOperation blockOperationWithBlock:^{
+ @try {
+
+ }
+ @catch (id exception) {
+ EXIT(exception);
+ }
+ }];
+
+}
OpenPOWER on IntegriCloud