clang 20.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 () | |
EHScopeStack (const EHScopeStack &)=delete | |
EHScopeStack & | operator= (const EHScopeStack &)=delete |
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 275 of file EHScopeStack.h.
|
inline |
Definition at line 279 of file EHScopeStack.h.
|
delete |
|
inline |
Add a branch fixup to the current cleanup scope.
Definition at line 410 of file EHScopeStack.h.
References hasNormalCleanups().
|
inline |
Returns an iterator pointing to the innermost EH scope.
Definition at line 615 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 429 of file EHScopeStack.h.
Referenced by ResolveAllBranchFixups().
bool EHScopeStack::containsOnlyLifetimeMarkers | ( | EHScopeStack::stable_iterator | Old | ) | const |
Definition at line 115 of file CGCleanup.cpp.
References begin(), and stabilize().
|
inline |
Determines whether the exception-scopes stack is empty.
Definition at line 359 of file EHScopeStack.h.
Referenced by popCatch(), popCleanup(), popFilter(), and popTerminate().
|
inline |
Returns an iterator pointing to the outermost EH scope.
Definition at line 619 of file CGCleanup.h.
|
inline |
Turn a stable reference to a scope depth into a unstable pointer to the EH stack.
Definition at line 639 of file CGCleanup.h.
References clang::CodeGen::EHScopeStack::stable_iterator::isValid(), and stable_begin().
Referenced by getInnermostActiveNormalCleanup(), IsUsedAsEHCleanup(), popNullFixups(), requiresLandingPad(), and SetupCleanupBlockActivation().
|
inline |
Definition at line 417 of file EHScopeStack.h.
References getNumBranchFixups().
Referenced by ResolveAllBranchFixups().
EHScopeStack::stable_iterator EHScopeStack::getInnermostActiveNormalCleanup | ( | ) | const |
Definition at line 141 of file CGCleanup.cpp.
References find(), getInnermostNormalCleanup(), and stable_end().
|
inline |
Definition at line 375 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 370 of file EHScopeStack.h.
Referenced by getInnermostActiveNormalCleanup(), clang::CodeGen::CodeGenFunction::getJumpDestInCurrentScope(), and clang::CodeGen::CodeGenFunction::LexicalScope::rescopeLabels().
|
inline |
Definition at line 416 of file EHScopeStack.h.
Referenced by getBranchFixup(), and ResolveAllBranchFixups().
|
inline |
Determines whether there are any normal cleanups on the stack.
Definition at line 364 of file EHScopeStack.h.
References stable_end().
Referenced by addBranchFixup(), popCleanup(), and popNullFixups().
|
delete |
|
inline |
Pops a catch scope off the stack. This is private to CGException.cpp.
Definition at line 623 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 193 of file CGCleanup.cpp.
References begin(), empty(), hasNormalCleanups(), and popNullFixups().
void EHScopeStack::popFilter | ( | ) |
Pops an exceptions filter off the stack.
Definition at line 226 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 254 of file CGCleanup.cpp.
References find(), and hasNormalCleanups().
Referenced by popCleanup().
|
inline |
Pops a terminate handler off the stack.
Definition at line 631 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 235 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 285 of file EHScopeStack.h.
References Kind, ScopeStackAlignment, and clang::T.
|
inline |
Push a lazily-created cleanup on the stack. Tuple version.
Definition at line 295 of file EHScopeStack.h.
References Kind, ScopeStackAlignment, and clang::T.
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 317 of file EHScopeStack.h.
References Kind, ScopeStackAlignment, and clang::T.
Referenced by EnterNewDeleteCleanup().
|
inline |
Definition at line 324 of file EHScopeStack.h.
References Kind.
EHFilterScope * EHScopeStack::pushFilter | ( | unsigned | NumFilters | ) |
Push an exceptions filter on the stack.
Definition at line 218 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 243 of file CGCleanup.cpp.
References clang::CodeGen::EHTerminateScope::getSize(), and stable_begin().
Referenced by InitCatchParam().
bool EHScopeStack::requiresLandingPad | ( | ) | const |
Definition at line 126 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 329 of file EHScopeStack.h.
|
inline |
Translates an iterator into a stable_iterator.
Definition at line 646 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 393 of file EHScopeStack.h.
Referenced by find(), pushCatch(), clang::CodeGen::CodeGenFunction::pushCleanupAndDeferDeactivation(), 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 398 of file EHScopeStack.h.
Referenced by getInnermostActiveNormalCleanup(), hasNormalCleanups(), pushFilter(), requiresLandingPad(), and clang::CodeGen::CodeGenFunction::LexicalScope::rescopeLabels().