clang 17.0.0git
|
A stack of scopes which respond to exceptions, including cleanups and catch blocks. More...
#include "/home/buildbot/as-worker-4/publish-doxygen-docs/llvm-project/clang/lib/CodeGen/EHScopeStack.h"
Classes | |
class | Cleanup |
Information for lazily generating a cleanup. More... | |
class | ConditionalCleanup |
ConditionalCleanup stores the saved form of its parameters, then restores them and performs the cleanup. More... | |
class | iterator |
A non-stable pointer into the scope stack. More... | |
class | stable_iterator |
A saved depth on the scope stack. More... | |
Public Types | |
enum | { ScopeStackAlignment = 8 } |
Public Member Functions | |
EHScopeStack () | |
~EHScopeStack () | |
template<class T , class... As> | |
void | pushCleanup (CleanupKind Kind, As... A) |
Push a lazily-created cleanup on the stack. | |
template<class T , class... As> | |
void | pushCleanupTuple (CleanupKind Kind, std::tuple< As... > A) |
Push a lazily-created cleanup on the stack. Tuple version. | |
template<class T , class... As> | |
T * | pushCleanupWithExtra (CleanupKind Kind, size_t N, As... A) |
Push a cleanup with non-constant storage requirements on the stack. | |
void | pushCopyOfCleanup (CleanupKind Kind, const void *Cleanup, size_t Size) |
void | setCGF (CodeGenFunction *inCGF) |
void | popCleanup () |
Pops a cleanup scope off the stack. This is private to CGCleanup.cpp. | |
class EHCatchScope * | pushCatch (unsigned NumHandlers) |
Push a set of catch handlers on the stack. | |
void | popCatch () |
Pops a catch scope off the stack. This is private to CGException.cpp. | |
class EHFilterScope * | pushFilter (unsigned NumFilters) |
Push an exceptions filter on the stack. | |
void | popFilter () |
Pops an exceptions filter off the stack. | |
void | pushTerminate () |
Push a terminate handler on the stack. | |
void | popTerminate () |
Pops a terminate handler off the stack. | |
bool | containsOnlyLifetimeMarkers (stable_iterator Old) const |
bool | empty () const |
Determines whether the exception-scopes stack is empty. | |
bool | requiresLandingPad () const |
bool | hasNormalCleanups () const |
Determines whether there are any normal cleanups on the stack. | |
stable_iterator | getInnermostNormalCleanup () const |
Returns the innermost normal cleanup on the stack, or stable_end() if there are no normal cleanups. | |
stable_iterator | getInnermostActiveNormalCleanup () const |
stable_iterator | getInnermostEHScope () const |
iterator | begin () const |
Returns an iterator pointing to the innermost EH scope. | |
iterator | end () const |
Returns an iterator pointing to the outermost EH scope. | |
stable_iterator | stable_begin () const |
Create a stable reference to the top of the EH stack. | |
stable_iterator | stabilize (iterator it) const |
Translates an iterator into a stable_iterator. | |
iterator | find (stable_iterator save) const |
Turn a stable reference to a scope depth into a unstable pointer to the EH stack. | |
BranchFixup & | addBranchFixup () |
Add a branch fixup to the current cleanup scope. | |
unsigned | getNumBranchFixups () const |
BranchFixup & | getBranchFixup (unsigned I) |
void | popNullFixups () |
Pops lazily-removed fixups from the end of the list. | |
void | clearFixups () |
Clears the branch-fixups list. | |
Static Public Member Functions | |
static stable_iterator | stable_end () |
Create a stable reference to the bottom of the EH stack. | |
A stack of scopes which respond to exceptions, including cleanups and catch blocks.
Definition at line 94 of file EHScopeStack.h.
anonymous enum |
Enumerator | |
---|---|
ScopeStackAlignment |
Definition at line 97 of file EHScopeStack.h.
|
inline |
Definition at line 269 of file EHScopeStack.h.
|
inline |
Definition at line 273 of file EHScopeStack.h.
|
inline |
Add a branch fixup to the current cleanup scope.
Definition at line 401 of file EHScopeStack.h.
References hasNormalCleanups().
|
inline |
Returns an iterator pointing to the innermost EH scope.
Definition at line 551 of file CGCleanup.h.
Referenced by containsOnlyLifetimeMarkers(), clang::CodeGen::CodeGenFunction::FinallyInfo::exit(), popCatch(), popCleanup(), popFilter(), and popTerminate().
|
inline |
Clears the branch-fixups list.
This should only be called by ResolveAllBranchFixups.
Definition at line 420 of file EHScopeStack.h.
Referenced by ResolveAllBranchFixups().
bool EHScopeStack::containsOnlyLifetimeMarkers | ( | EHScopeStack::stable_iterator | Old | ) | const |
Definition at line 144 of file CGCleanup.cpp.
References begin(), and stabilize().
|
inline |
Determines whether the exception-scopes stack is empty.
Definition at line 350 of file EHScopeStack.h.
Referenced by popCatch(), popCleanup(), popFilter(), and popTerminate().
|
inline |
Returns an iterator pointing to the outermost EH scope.
Definition at line 555 of file CGCleanup.h.
|
inline |
Turn a stable reference to a scope depth into a unstable pointer to the EH stack.
Definition at line 575 of file CGCleanup.h.
References clang::CodeGen::EHScopeStack::stable_iterator::isValid(), and stable_begin().
Referenced by getInnermostActiveNormalCleanup(), IsUsedAsEHCleanup(), IsUsedAsNormalCleanup(), popNullFixups(), requiresLandingPad(), and SetupCleanupBlockActivation().
|
inline |
Definition at line 408 of file EHScopeStack.h.
References getNumBranchFixups().
Referenced by ResolveAllBranchFixups().
EHScopeStack::stable_iterator EHScopeStack::getInnermostActiveNormalCleanup | ( | ) | const |
Definition at line 170 of file CGCleanup.cpp.
References find(), getInnermostNormalCleanup(), and stable_end().
|
inline |
Definition at line 366 of file EHScopeStack.h.
Referenced by IsUsedAsEHCleanup(), pushFilter(), and requiresLandingPad().
|
inline |
Returns the innermost normal cleanup on the stack, or stable_end() if there are no normal cleanups.
Definition at line 361 of file EHScopeStack.h.
Referenced by getInnermostActiveNormalCleanup(), clang::CodeGen::CodeGenFunction::getJumpDestInCurrentScope(), IsUsedAsNormalCleanup(), and clang::CodeGen::CodeGenFunction::LexicalScope::rescopeLabels().
|
inline |
Definition at line 407 of file EHScopeStack.h.
Referenced by getBranchFixup(), and ResolveAllBranchFixups().
|
inline |
Determines whether there are any normal cleanups on the stack.
Definition at line 355 of file EHScopeStack.h.
References stable_end().
Referenced by addBranchFixup(), popCleanup(), and popNullFixups().
|
inline |
Pops a catch scope off the stack. This is private to CGException.cpp.
Definition at line 559 of file CGCleanup.h.
References begin(), empty(), clang::CodeGen::EHScope::getEnclosingEHScope(), clang::CodeGen::EHCatchScope::getNumHandlers(), and clang::CodeGen::EHCatchScope::getSizeForNumHandlers().
void EHScopeStack::popCleanup | ( | ) |
Pops a cleanup scope off the stack. This is private to CGCleanup.cpp.
Definition at line 217 of file CGCleanup.cpp.
References begin(), empty(), hasNormalCleanups(), and popNullFixups().
void EHScopeStack::popFilter | ( | ) |
Pops an exceptions filter off the stack.
Definition at line 250 of file CGCleanup.cpp.
References begin(), empty(), clang::CodeGen::EHScope::getEnclosingEHScope(), clang::CodeGen::EHFilterScope::getNumFilters(), and clang::CodeGen::EHFilterScope::getSizeForNumFilters().
void EHScopeStack::popNullFixups | ( | ) |
Pops lazily-removed fixups from the end of the list.
Remove any 'null' fixups on the stack.
This should only be called by procedures which have just popped a cleanup or resolved one or more fixups.
However, we can't pop more fixups than the fixup depth on the innermost normal cleanup, or else fixups that we try to add to that cleanup will end up in the wrong place. We could try to shrink fixup depths, but that's actually a lot of work for little benefit.
Definition at line 278 of file CGCleanup.cpp.
References find(), and hasNormalCleanups().
Referenced by popCleanup().
|
inline |
Pops a terminate handler off the stack.
Definition at line 567 of file CGCleanup.h.
References begin(), empty(), clang::CodeGen::EHScope::getEnclosingEHScope(), and clang::CodeGen::EHTerminateScope::getSize().
Referenced by InitCatchParam().
EHCatchScope * EHScopeStack::pushCatch | ( | unsigned | NumHandlers | ) |
Push a set of catch handlers on the stack.
The catch is uninitialized and will need to have the given number of handlers set on it.
Definition at line 259 of file CGCleanup.cpp.
References clang::CodeGen::EHCatchScope::getSizeForNumHandlers(), and stable_begin().
Referenced by clang::CodeGen::CGObjCRuntime::EmitTryCatchStmt(), and clang::CodeGen::CodeGenFunction::FinallyInfo::enter().
|
inline |
Push a lazily-created cleanup on the stack.
Definition at line 276 of file EHScopeStack.h.
References ScopeStackAlignment.
|
inline |
Push a lazily-created cleanup on the stack. Tuple version.
Definition at line 286 of file EHScopeStack.h.
References ScopeStackAlignment.
Referenced by clang::CodeGen::CodeGenFunction::pushFullExprCleanup().
|
inline |
Push a cleanup with non-constant storage requirements on the stack.
The cleanup type must provide an additional static method: static size_t getExtraSize(size_t); The argument to this method will be the value N, which will also be passed as the first argument to the constructor.
The data stored in the extra storage must obey the same restrictions as normal cleanup member data.
The pointer returned from this method is valid until the cleanup stack is modified.
Definition at line 308 of file EHScopeStack.h.
References ScopeStackAlignment.
Referenced by EnterNewDeleteCleanup().
|
inline |
Definition at line 315 of file EHScopeStack.h.
EHFilterScope * EHScopeStack::pushFilter | ( | unsigned | NumFilters | ) |
Push an exceptions filter on the stack.
Definition at line 242 of file CGCleanup.cpp.
References getInnermostEHScope(), clang::CodeGen::EHFilterScope::getSizeForNumFilters(), stable_begin(), and stable_end().
void EHScopeStack::pushTerminate | ( | ) |
Push a terminate handler on the stack.
Definition at line 267 of file CGCleanup.cpp.
References clang::CodeGen::EHTerminateScope::getSize(), and stable_begin().
Referenced by InitCatchParam().
bool EHScopeStack::requiresLandingPad | ( | ) | const |
Definition at line 155 of file CGCleanup.cpp.
References find(), getInnermostEHScope(), and stable_end().
Referenced by clang::CodeGen::CodeGenFunction::getInvokeDest(), and clang::CodeGen::CGOpenMPRuntime::getThreadID().
|
inline |
Definition at line 320 of file EHScopeStack.h.
|
inline |
Translates an iterator into a stable_iterator.
Definition at line 582 of file CGCleanup.h.
Referenced by containsOnlyLifetimeMarkers().
|
inline |
Create a stable reference to the top of the EH stack.
The returned reference is valid until that scope is popped off the stack.
Definition at line 384 of file EHScopeStack.h.
Referenced by find(), pushCatch(), pushFilter(), pushTerminate(), clang::CodeGen::CodeGenFunction::RunCleanupsScope::requiresCleanups(), and clang::CodeGen::CodeGenFunction::RunCleanupsScope::RunCleanupsScope().
|
inlinestatic |
Create a stable reference to the bottom of the EH stack.
Definition at line 389 of file EHScopeStack.h.
Referenced by getInnermostActiveNormalCleanup(), hasNormalCleanups(), pushFilter(), requiresLandingPad(), and clang::CodeGen::CodeGenFunction::LexicalScope::rescopeLabels().