klee
klee::ReadExpr Class Reference

Class representing a one byte read from an array. More...

#include <Expr.h>

Inheritance diagram for klee::ReadExpr:
Collaboration diagram for klee::ReadExpr:

Public Member Functions

Width getWidth () const
 
Kind getKind () const
 
unsigned getNumKids () const
 
ref< ExprgetKid (unsigned i) const
 
int compareContents (const Expr &b) const
 
virtual ref< Exprrebuild (ref< Expr > kids[]) const
 
virtual unsigned computeHash ()
 
- Public Member Functions inherited from klee::Expr
 Expr ()
 
virtual ~Expr ()
 
virtual Kind getKind () const =0
 
virtual Width getWidth () const =0
 
virtual unsigned getNumKids () const =0
 
virtual ref< ExprgetKid (unsigned i) const =0
 
virtual void print (llvm::raw_ostream &os) const
 
void dump () const
 dump - Print the expression to stderr. More...
 
virtual unsigned hash () const
 Returns the pre-computed hash of the current expression. More...
 
virtual unsigned computeHash ()
 
int compare (const Expr &b) const
 
virtual ref< Exprrebuild (ref< Expr > kids[]) const =0
 
bool isZero () const
 isZero - Is this a constant zero. More...
 
bool isTrue () const
 isTrue - Is this the true expression. More...
 
bool isFalse () const
 isFalse - Is this the false expression. More...
 

Static Public Member Functions

static ref< Expralloc (const UpdateList &updates, const ref< Expr > &index)
 
static ref< Exprcreate (const UpdateList &updates, ref< Expr > i)
 
static bool classof (const Expr *E)
 
static bool classof (const ReadExpr *)
 
- Static Public Member Functions inherited from klee::NonConstantExpr
static bool classof (const Expr *E)
 
static bool classof (const NonConstantExpr *)
 
- Static Public Member Functions inherited from klee::Expr
static void printKind (llvm::raw_ostream &os, Kind k)
 
static void printWidth (llvm::raw_ostream &os, Expr::Width w)
 
static unsigned getMinBytesForWidth (Width w)
 returns the smallest number of bytes in which the given width fits More...
 
static ref< ExprcreateSExtToPointerWidth (ref< Expr > e)
 
static ref< ExprcreateZExtToPointerWidth (ref< Expr > e)
 
static ref< ExprcreateImplies (ref< Expr > hyp, ref< Expr > conc)
 
static ref< ExprcreateIsZero (ref< Expr > e)
 
static ref< ExprcreateTempRead (const Array *array, Expr::Width w)
 
static ref< ConstantExprcreatePointer (uint64_t v)
 
static ref< ExprcreateFromKind (Kind k, std::vector< CreateArg > args)
 
static bool isValidKidWidth (unsigned kid, Width w)
 
static bool needsResultType ()
 
static bool classof (const Expr *)
 

Public Attributes

UpdateList updates
 
ref< Exprindex
 
- Public Attributes inherited from klee::Expr
class ReferenceCounter _refCount
 Required by klee::ref-managed objects. More...
 

Static Public Attributes

static const Kind kind = Read
 
static const unsigned numKids = 1
 
- Static Public Attributes inherited from klee::Expr
static unsigned count = 0
 
static const unsigned MAGIC_HASH_CONSTANT = 39
 
static const Width InvalidWidth = 0
 
static const Width Bool = 1
 
static const Width Int8 = 8
 
static const Width Int16 = 16
 
static const Width Int32 = 32
 
static const Width Int64 = 64
 
static const Width Fl80 = 80
 

Private Member Functions

 ReadExpr (const UpdateList &_updates, const ref< Expr > &_index)
 

Additional Inherited Members

- Public Types inherited from klee::Expr
enum  Kind {
  InvalidKind = -1 , Constant = 0 , NotOptimized , Read =NotOptimized+2 ,
  Select , Concat , Extract , ZExt ,
  SExt , Not , Add , Sub ,
  Mul , UDiv , SDiv , URem ,
  SRem , And , Or , Xor ,
  Shl , LShr , AShr , Eq ,
  Ne , Ult , Ule , Ugt ,
  Uge , Slt , Sle , Sgt ,
  Sge , LastKind =Sge , CastKindFirst =ZExt , CastKindLast =SExt ,
  BinaryKindFirst =Add , BinaryKindLast =Sge , CmpKindFirst =Eq , CmpKindLast =Sge
}
 
typedef unsigned Width
 The type of an expression is simply its width, in bits. More...
 
virtual int compareContents (const Expr &b) const =0
 
- Protected Attributes inherited from klee::Expr
unsigned hashValue
 

Detailed Description

Class representing a one byte read from an array.

Definition at line 565 of file Expr.h.

Constructor & Destructor Documentation

◆ ReadExpr()

klee::ReadExpr::ReadExpr ( const UpdateList _updates,
const ref< Expr > &  _index 
)
inlineprivate

Definition at line 598 of file Expr.h.

References klee::UpdateList::root, and updates.

Referenced by alloc().

Here is the caller graph for this function:

Member Function Documentation

◆ alloc()

static ref< Expr > klee::ReadExpr::alloc ( const UpdateList updates,
const ref< Expr > &  index 
)
inlinestatic

Definition at line 575 of file Expr.h.

References klee::Expr::computeHash(), index, ReadExpr(), and updates.

Referenced by create().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ classof() [1/2]

static bool klee::ReadExpr::classof ( const Expr E)
inlinestatic

Definition at line 602 of file Expr.h.

References klee::Expr::getKind(), and klee::Expr::Read.

Here is the call graph for this function:

◆ classof() [2/2]

static bool klee::ReadExpr::classof ( const ReadExpr )
inlinestatic

Definition at line 605 of file Expr.h.

◆ compareContents()

int ReadExpr::compareContents ( const Expr b) const
virtual

Compares b to this Expr and determines how they are ordered (ignoring their kid expressions - i.e. those returned by getKid()).

Typically this requires comparing internal attributes of the Expr.

Implementations can assume that b and this are of the same kind.

This method effectively defines a partial order over Expr of the same kind (partial because kid Expr are not compared).

This method should not be called directly. Instead compare() should be used.

Parameters
[in]bExpr to compare this to.
Returns
One of the following values:
  • -1 if this is < b ignoring kid expressions.
  • 1 if this is > b ignoring kid expressions.
  • 0 if this and b are not ordered.

< and > are binary relations that express the partial order.

Implements klee::Expr.

Definition at line 588 of file Expr.cpp.

References klee::UpdateList::compare(), and updates.

Here is the call graph for this function:

◆ computeHash()

unsigned ReadExpr::computeHash ( )
virtual

(Re)computes the hash of the current expression. Returns the hash value.

Reimplemented from klee::Expr.

Definition at line 218 of file Expr.cpp.

References klee::Expr::hash(), klee::UpdateList::hash(), klee::Expr::hashValue, index, klee::Expr::MAGIC_HASH_CONSTANT, and updates.

Here is the call graph for this function:

◆ create()

◆ getKid()

ref< Expr > klee::ReadExpr::getKid ( unsigned  i) const
inlinevirtual

Implements klee::Expr.

Definition at line 587 of file Expr.h.

References index.

◆ getKind()

Kind klee::ReadExpr::getKind ( ) const
inlinevirtual

Implements klee::Expr.

Definition at line 584 of file Expr.h.

References klee::Expr::Read.

◆ getNumKids()

unsigned klee::ReadExpr::getNumKids ( ) const
inlinevirtual

Implements klee::Expr.

Definition at line 586 of file Expr.h.

References numKids.

◆ getWidth()

◆ rebuild()

virtual ref< Expr > klee::ReadExpr::rebuild ( ref< Expr kids[]) const
inlinevirtual

Implements klee::Expr.

Definition at line 591 of file Expr.h.

References create(), and updates.

Here is the call graph for this function:

Member Data Documentation

◆ index

◆ kind

const Kind klee::ReadExpr::kind = Read
static

Definition at line 567 of file Expr.h.

◆ numKids

const unsigned klee::ReadExpr::numKids = 1
static

Definition at line 568 of file Expr.h.

Referenced by getNumKids().

◆ updates


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