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