LLVM 22.0.0git
|
Value handle that poisons itself if the Value is deleted. More...
#include "llvm/IR/ValueHandle.h"
Public Member Functions | |
PoisoningVH ()=default | |
PoisoningVH (ValueTy *P) | |
operator ValueTy * () const | |
ValueTy * | operator-> () const |
ValueTy & | operator* () const |
Friends | |
struct | DenseMapInfo< PoisoningVH< ValueTy > > |
Value handle that poisons itself if the Value is deleted.
This is a Value Handle that points to a value and poisons itself if the value is destroyed while the handle is still live. This is very useful for catching dangling pointer bugs where an AssertingVH
cannot be used because the dangling handle needs to outlive the value without ever being used.
One particularly useful place to use this is as the Key of a map. Dangling pointer bugs often lead to really subtle bugs that only occur if another object happens to get allocated to the same address as the old one. Using a PoisoningVH ensures that an assert is triggered if looking up a new value in the map finds a handle from the old value.
Note that a PoisoningVH handle does not follow values across RAUW operations. This means that RAUW's need to explicitly update the PoisoningVH's as it moves. This is required because in non-assert mode this class turns into a trivial wrapper around a pointer.
Definition at line 446 of file ValueHandle.h.
|
default |
References P.
|
inline |
Definition at line 517 of file ValueHandle.h.
References P.
|
inline |
Definition at line 520 of file ValueHandle.h.
|
inline |
Definition at line 523 of file ValueHandle.h.
|
inline |
Definition at line 522 of file ValueHandle.h.
|
friend |
Definition at line 424 of file ValueHandle.h.