diff --git a/lib/Serialization/ASTReaderDecl.cpp b/lib/Serialization/ASTReaderDecl.cpp index 8dd53ee7d206b0ade4315de880d2bd3311601038..15aa90b3516e502eb569f3d143dc2fc11bbb0c1d 100644 --- a/lib/Serialization/ASTReaderDecl.cpp +++ b/lib/Serialization/ASTReaderDecl.cpp @@ -629,6 +629,8 @@ void ASTDeclReader::VisitObjCMethodDecl(ObjCMethodDecl *MD) { if (Record[Idx++]) { // In practice, this won't be executed (since method definitions // don't occur in header files). + // Switch case IDs are per method body. + Reader.ClearSwitchCaseIDs(); MD->setBody(Reader.ReadStmt(F)); MD->setSelfDecl(ReadDeclAs<ImplicitParamDecl>(Record, Idx)); MD->setCmdDecl(ReadDeclAs<ImplicitParamDecl>(Record, Idx)); diff --git a/test/PCH/objc_methods.h b/test/PCH/objc_methods.h index c9b1ad4342c6c5cc8260892fe51db9cce52ec486..7b9e22decb61410c78a3807dea80512762daae54 100644 --- a/test/PCH/objc_methods.h +++ b/test/PCH/objc_methods.h @@ -9,3 +9,19 @@ // FIXME: @compatibility_alias AliasForTestPCH TestPCH; +// http://llvm.org/PR12689 +@interface PR12689 +@end + +@implementation PR12689 +-(void)mugi:(int)x { + switch(x) { + case 23: {} + } +} +-(void)bonk:(int)x { + switch(x) { + case 42: {} + } +} +@end