LLVM API Documentation

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Public Member Functions | List of all members
llvm::AssertingVH< ValueTy > Class Template Reference

#include <ValueHandle.h>

Inheritance diagram for llvm::AssertingVH< ValueTy >:
Inheritance graph
[legend]
Collaboration diagram for llvm::AssertingVH< ValueTy >:
Collaboration graph
[legend]

Public Member Functions

 AssertingVH ()
 
 AssertingVH (ValueTy *P)
 
 AssertingVH (const AssertingVH &RHS)
 
 operator ValueTy * () const
 
ValueTy * operator= (ValueTy *RHS)
 
ValueTy * operator= (const AssertingVH< ValueTy > &RHS)
 
ValueTy * operator-> () const
 
ValueTy & operator* () const
 
- Public Member Functions inherited from llvm::ValueHandleBase
 ValueHandleBase (HandleBaseKind Kind)
 
 ValueHandleBase (HandleBaseKind Kind, Value *V)
 
 ValueHandleBase (HandleBaseKind Kind, const ValueHandleBase &RHS)
 
 ~ValueHandleBase ()
 
Valueoperator= (Value *RHS)
 
Valueoperator= (const ValueHandleBase &RHS)
 
Valueoperator-> () const
 
Valueoperator* () const
 

Additional Inherited Members

- Static Public Member Functions inherited from llvm::ValueHandleBase
static void ValueIsDeleted (Value *V)
 
static void ValueIsRAUWd (Value *Old, Value *New)
 
- Protected Types inherited from llvm::ValueHandleBase
enum  HandleBaseKind { Assert, Callback, Tracking, Weak }
 
- Protected Member Functions inherited from llvm::ValueHandleBase
ValuegetValPtr () const
 
void setValPtrInt (unsigned K)
 
unsigned getValPtrInt () const
 
- Static Protected Member Functions inherited from llvm::ValueHandleBase
static bool isValid (Value *V)
 

Detailed Description

template<typename ValueTy>
class llvm::AssertingVH< ValueTy >

AssertingVH - This is a Value Handle that points to a value and asserts out if the value is destroyed while the handle is still live. This is very useful for catching dangling pointer bugs and other things which can be non-obvious. 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 an AssertingVH ensures that an assert is triggered as soon as the bad delete occurs.

Note that an AssertingVH handle does not follow values across RAUW operations. This means that RAUW's need to explicitly update the AssertingVH'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 187 of file ValueHandle.h.

Constructor & Destructor Documentation

template<typename ValueTy>
llvm::AssertingVH< ValueTy >::AssertingVH ( )
inline

Definition at line 213 of file ValueHandle.h.

template<typename ValueTy>
llvm::AssertingVH< ValueTy >::AssertingVH ( ValueTy *  P)
inline

Definition at line 214 of file ValueHandle.h.

template<typename ValueTy>
llvm::AssertingVH< ValueTy >::AssertingVH ( const AssertingVH< ValueTy > &  RHS)
inline

Definition at line 215 of file ValueHandle.h.

Member Function Documentation

template<typename ValueTy>
llvm::AssertingVH< ValueTy >::operator ValueTy * ( ) const
inline

Definition at line 221 of file ValueHandle.h.

template<typename ValueTy>
ValueTy& llvm::AssertingVH< ValueTy >::operator* ( ) const
inline

Definition at line 235 of file ValueHandle.h.

template<typename ValueTy>
ValueTy* llvm::AssertingVH< ValueTy >::operator-> ( ) const
inline

Definition at line 234 of file ValueHandle.h.

template<typename ValueTy>
ValueTy* llvm::AssertingVH< ValueTy >::operator= ( ValueTy *  RHS)
inline

Definition at line 225 of file ValueHandle.h.

template<typename ValueTy>
ValueTy* llvm::AssertingVH< ValueTy >::operator= ( const AssertingVH< ValueTy > &  RHS)
inline

Definition at line 229 of file ValueHandle.h.


The documentation for this class was generated from the following file: