Author: akirtzidis
Date: Wed Mar 4 10:03:07 2015
New Revision: 231251
URL: http://llvm.org/viewvc/llvm-project?rev=231251&view=rev
Log:
[Modules] Fix crash in Preprocessor::getLastMacroWithSpelling().
Macro names that got undefined inside a module may not have their MacroInfo set.
Added:
cfe/trunk/test/Modules/crashes.m
Modified:
cfe/trunk/lib/Lex/Preprocessor.cpp
cfe/trunk/test/Modules/Inputs/Module.framework/Headers/Module.h
Modified: cfe/trunk/lib/Lex/Preprocessor.cpp
URL:
http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Lex/Preprocessor.cpp?rev=231251&r1=231250&r2=231251&view=diff
==============================================================================
--- cfe/trunk/lib/Lex/Preprocessor.cpp (original)
+++ cfe/trunk/lib/Lex/Preprocessor.cpp Wed Mar 4 10:03:07 2015
@@ -321,11 +321,11 @@ StringRef Preprocessor::getLastMacroWith
StringRef BestSpelling;
for (Preprocessor::macro_iterator I = macro_begin(), E = macro_end();
I != E; ++I) {
- if (!I->second->getMacroInfo()->isObjectLike())
- continue;
const MacroDirective::DefInfo
Def = I->second->findDirectiveAtLoc(Loc, SourceMgr);
- if (!Def)
+ if (!Def || !Def.getMacroInfo())
+ continue;
+ if (!Def.getMacroInfo()->isObjectLike())
continue;
if (!MacroDefinitionEquals(Def.getMacroInfo(), Tokens))
continue;
Modified: cfe/trunk/test/Modules/Inputs/Module.framework/Headers/Module.h
URL:
http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Modules/Inputs/Module.framework/Headers/Module.h?rev=231251&r1=231250&r2=231251&view=diff
==============================================================================
--- cfe/trunk/test/Modules/Inputs/Module.framework/Headers/Module.h (original)
+++ cfe/trunk/test/Modules/Inputs/Module.framework/Headers/Module.h Wed Mar 4
10:03:07 2015
@@ -31,4 +31,7 @@ typedef struct __sFILE {
extern FILE *myFile;
+#define SOME_MACRO_GETTING_UNDEFINED 1
+#undef SOME_MACRO_GETTING_UNDEFINED
+
#endif // MODULE_H
Added: cfe/trunk/test/Modules/crashes.m
URL:
http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Modules/crashes.m?rev=231251&view=auto
==============================================================================
--- cfe/trunk/test/Modules/crashes.m (added)
+++ cfe/trunk/test/Modules/crashes.m Wed Mar 4 10:03:07 2015
@@ -0,0 +1,14 @@
+// RUN: rm -rf %t.mcp
+// RUN: %clang_cc1 -fmodules-cache-path=%t.mcp -fmodules -F %S/Inputs
-fobjc-arc %s -verify
+
+@import Module;
+
+__attribute__((objc_root_class))
+@interface Test
+// rdar://19904648
+@property (assign) id newFile; // expected-error {{property follows Cocoa
naming convention for returning 'owned' objects}} \
+ // expected-note {{explicitly declare getter}}
+@end
+
+@implementation Test
+@end
_______________________________________________
cfe-commits mailing list
[email protected]
http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits