forked from OSchip/llvm-project
parent
a2a0eb940a
commit
9dff378a12
|
@ -63,8 +63,7 @@ class CXXTryStmt : public Stmt {
|
||||||
SourceLocation TryLoc;
|
SourceLocation TryLoc;
|
||||||
unsigned NumHandlers;
|
unsigned NumHandlers;
|
||||||
|
|
||||||
CXXTryStmt(SourceLocation tryLoc, Stmt *tryBlock, Stmt **handlers,
|
CXXTryStmt(SourceLocation tryLoc, Stmt *tryBlock, ArrayRef<Stmt*> handlers);
|
||||||
unsigned numHandlers);
|
|
||||||
|
|
||||||
CXXTryStmt(EmptyShell Empty, unsigned numHandlers)
|
CXXTryStmt(EmptyShell Empty, unsigned numHandlers)
|
||||||
: Stmt(CXXTryStmtClass), NumHandlers(numHandlers) { }
|
: Stmt(CXXTryStmtClass), NumHandlers(numHandlers) { }
|
||||||
|
@ -78,8 +77,7 @@ class CXXTryStmt : public Stmt {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static CXXTryStmt *Create(ASTContext &C, SourceLocation tryLoc,
|
static CXXTryStmt *Create(ASTContext &C, SourceLocation tryLoc,
|
||||||
Stmt *tryBlock, Stmt **handlers,
|
Stmt *tryBlock, ArrayRef<Stmt*> handlers);
|
||||||
unsigned numHandlers);
|
|
||||||
|
|
||||||
static CXXTryStmt *Create(ASTContext &C, EmptyShell Empty,
|
static CXXTryStmt *Create(ASTContext &C, EmptyShell Empty,
|
||||||
unsigned numHandlers);
|
unsigned numHandlers);
|
||||||
|
|
|
@ -769,13 +769,12 @@ SourceLocation ObjCAtTryStmt::getLocEnd() const {
|
||||||
}
|
}
|
||||||
|
|
||||||
CXXTryStmt *CXXTryStmt::Create(ASTContext &C, SourceLocation tryLoc,
|
CXXTryStmt *CXXTryStmt::Create(ASTContext &C, SourceLocation tryLoc,
|
||||||
Stmt *tryBlock, Stmt **handlers,
|
Stmt *tryBlock, ArrayRef<Stmt*> handlers) {
|
||||||
unsigned numHandlers) {
|
|
||||||
std::size_t Size = sizeof(CXXTryStmt);
|
std::size_t Size = sizeof(CXXTryStmt);
|
||||||
Size += ((numHandlers + 1) * sizeof(Stmt));
|
Size += ((handlers.size() + 1) * sizeof(Stmt));
|
||||||
|
|
||||||
void *Mem = C.Allocate(Size, llvm::alignOf<CXXTryStmt>());
|
void *Mem = C.Allocate(Size, llvm::alignOf<CXXTryStmt>());
|
||||||
return new (Mem) CXXTryStmt(tryLoc, tryBlock, handlers, numHandlers);
|
return new (Mem) CXXTryStmt(tryLoc, tryBlock, handlers);
|
||||||
}
|
}
|
||||||
|
|
||||||
CXXTryStmt *CXXTryStmt::Create(ASTContext &C, EmptyShell Empty,
|
CXXTryStmt *CXXTryStmt::Create(ASTContext &C, EmptyShell Empty,
|
||||||
|
@ -788,11 +787,11 @@ CXXTryStmt *CXXTryStmt::Create(ASTContext &C, EmptyShell Empty,
|
||||||
}
|
}
|
||||||
|
|
||||||
CXXTryStmt::CXXTryStmt(SourceLocation tryLoc, Stmt *tryBlock,
|
CXXTryStmt::CXXTryStmt(SourceLocation tryLoc, Stmt *tryBlock,
|
||||||
Stmt **handlers, unsigned numHandlers)
|
ArrayRef<Stmt*> handlers)
|
||||||
: Stmt(CXXTryStmtClass), TryLoc(tryLoc), NumHandlers(numHandlers) {
|
: Stmt(CXXTryStmtClass), TryLoc(tryLoc), NumHandlers(handlers.size()) {
|
||||||
Stmt **Stmts = reinterpret_cast<Stmt **>(this + 1);
|
Stmt **Stmts = reinterpret_cast<Stmt **>(this + 1);
|
||||||
Stmts[0] = tryBlock;
|
Stmts[0] = tryBlock;
|
||||||
std::copy(handlers, handlers + NumHandlers, Stmts + 1);
|
std::copy(handlers.begin(), handlers.end(), Stmts + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
CXXForRangeStmt::CXXForRangeStmt(DeclStmt *Range, DeclStmt *BeginEndStmt,
|
CXXForRangeStmt::CXXForRangeStmt(DeclStmt *Range, DeclStmt *BeginEndStmt,
|
||||||
|
|
|
@ -2757,7 +2757,7 @@ Sema::ActOnCXXTryBlock(SourceLocation TryLoc, Stmt *TryBlock,
|
||||||
// and warns.
|
// and warns.
|
||||||
|
|
||||||
return Owned(CXXTryStmt::Create(Context, TryLoc, TryBlock,
|
return Owned(CXXTryStmt::Create(Context, TryLoc, TryBlock,
|
||||||
Handlers, NumHandlers));
|
llvm::makeArrayRef(Handlers, NumHandlers)));
|
||||||
}
|
}
|
||||||
|
|
||||||
StmtResult
|
StmtResult
|
||||||
|
|
Loading…
Reference in New Issue