forked from OSchip/llvm-project
Relax valid location check. This fixes a clang crash while emitting debug info for properties that are synthesized by the compiler by default.
llvm-svn: 149929
This commit is contained in:
parent
02cb1715ec
commit
f93d0b8b28
|
@ -233,7 +233,8 @@ llvm::DIFile CGDebugInfo::getOrCreateMainFile() {
|
|||
/// getLineNumber - Get line number for the location. If location is invalid
|
||||
/// then use current location.
|
||||
unsigned CGDebugInfo::getLineNumber(SourceLocation Loc) {
|
||||
assert((Loc.isValid() || CurLoc.isValid()) && "Invalid current location!");
|
||||
if (Loc.isInvalid() && CurLoc.isInvalid())
|
||||
return 0;
|
||||
SourceManager &SM = CGM.getContext().getSourceManager();
|
||||
PresumedLoc PLoc = SM.getPresumedLoc(Loc.isValid() ? Loc : CurLoc);
|
||||
return PLoc.isValid()? PLoc.getLine() : 0;
|
||||
|
@ -242,7 +243,8 @@ unsigned CGDebugInfo::getLineNumber(SourceLocation Loc) {
|
|||
/// getColumnNumber - Get column number for the location. If location is
|
||||
/// invalid then use current location.
|
||||
unsigned CGDebugInfo::getColumnNumber(SourceLocation Loc) {
|
||||
assert((Loc.isValid() || CurLoc.isValid()) && "Invalid current location!");
|
||||
if (Loc.isInvalid() && CurLoc.isInvalid())
|
||||
return 0;
|
||||
SourceManager &SM = CGM.getContext().getSourceManager();
|
||||
PresumedLoc PLoc = SM.getPresumedLoc(Loc.isValid() ? Loc : CurLoc);
|
||||
return PLoc.isValid()? PLoc.getColumn() : 0;
|
||||
|
|
|
@ -0,0 +1,17 @@
|
|||
// RUN: %clang_cc1 -fobjc-default-synthesize-properties -masm-verbose -S -g %s -o - | FileCheck %s
|
||||
|
||||
// CHECK: AT_APPLE_property_name
|
||||
// CHECK: AT_APPLE_property_getter
|
||||
// CHECK: AT_APPLE_property_setter
|
||||
// CHECK: AT_APPLE_property_attribute
|
||||
// CHECK: AT_APPLE_property
|
||||
|
||||
|
||||
@interface I1
|
||||
@property int p1;
|
||||
@end
|
||||
|
||||
@implementation I1
|
||||
@end
|
||||
|
||||
void foo(I1 *ptr) {}
|
Loading…
Reference in New Issue