Qore Programming Language  0.8.7
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
Public Member Functions | List of all members
SimpleQoreNode Class Reference

The base class for all types in Qore expression trees that cannot throw an exception when deleted. More...

#include <AbstractQoreNode.h>

Inheritance diagram for SimpleQoreNode:
Inheritance graph
[legend]
Collaboration diagram for SimpleQoreNode:
Collaboration graph
[legend]

Public Member Functions

DLLLOCAL SimpleQoreNode (qore_type_t t, bool n_value, bool n_needs_eval, bool n_there_can_be_only_one=false)
 constructor takes the type and value arguments
 
DLLLOCAL SimpleQoreNode (const SimpleQoreNode &v)
 copy constructor
 
- Public Member Functions inherited from AbstractQoreNode
DLLEXPORT AbstractQoreNode (qore_type_t t, bool n_value, bool n_needs_eval, bool n_there_can_be_only_one=false, bool n_custom_reference_handlers=false)
 constructor takes the type
 
DLLEXPORT AbstractQoreNode (const AbstractQoreNode &v)
 copy constructor
 
DLLEXPORT bool getAsBool () const
 returns the boolean value of the object
 
DLLEXPORT int getAsInt () const
 returns the integer value of the object
 
DLLEXPORT int64 getAsBigInt () const
 returns the 64-bit integer value of the object
 
DLLEXPORT double getAsFloat () const
 returns the float value of the object
 
virtual DLLEXPORT QoreStringgetStringRepresentation (bool &del) const
 returns the value of the type converted to a string, default implementation: returns the empty string
 
virtual DLLEXPORT void getStringRepresentation (QoreString &str) const
 concatentates the value of the type to an existing QoreString reference, default implementation does nothing
 
virtual DLLEXPORT class DateTimegetDateTimeRepresentation (bool &del) const
 returns the DateTime representation of this type (default implementation: returns ZeroDate, del = false)
 
virtual DLLEXPORT void getDateTimeRepresentation (DateTime &dt) const
 assigns the date representation of a value to the DateTime reference passed, default implementation does nothing
 
virtual DLLEXPORT int getAsString (QoreString &str, int foff, ExceptionSink *xsink) const =0
 concatenate the verbose string representation of the value (including all contained values for container types) to an existing QoreString
 
virtual DLLEXPORT QoreStringgetAsString (bool &del, int foff, ExceptionSink *xsink) const =0
 returns a QoreString giving the verbose string representation of the value (including all contained values for container types)
 
DLLLOCAL bool needs_eval () const
 returns true if the object needs evaluation to return a value, false if not
 
virtual DLLEXPORT
AbstractQoreNode
realCopy () const =0
 returns a copy of the object; the caller owns the reference count
 
virtual DLLEXPORT bool is_equal_soft (const AbstractQoreNode *v, ExceptionSink *xsink) const =0
 tests for equality ("deep compare" including all contained values for container types) with possible type conversion (soft compare)
 
virtual DLLEXPORT bool is_equal_hard (const AbstractQoreNode *v, ExceptionSink *xsink) const =0
 tests for equality ("deep compare" including all contained values for container types) without type conversions (hard compare)
 
DLLLOCAL qore_type_t getType () const
 returns the data type
 
virtual DLLEXPORT const char * getTypeName () const =0
 returns the type name as a c string
 
DLLEXPORT AbstractQoreNodeeval (ExceptionSink *xsink) const
 evaluates the object and returns a value (or 0)
 
DLLEXPORT AbstractQoreNodeeval (bool &needs_deref, ExceptionSink *xsink) const
 optionally evaluates the argument
 
DLLEXPORT int64 bigIntEval (ExceptionSink *xsink) const
 evaluates the object and returns a 64-bit integer value
 
DLLEXPORT int integerEval (ExceptionSink *xsink) const
 evaluates the object and returns an integer value
 
DLLEXPORT bool boolEval (ExceptionSink *xsink) const
 evaluates the object and returns a boolean value
 
DLLEXPORT double floatEval (ExceptionSink *xsink) const
 evaluates the object and returns a floating-point value
 
DLLLOCAL bool is_value () const
 returns true if the node represents a value
 
DLLEXPORT void deref (ExceptionSink *xsink)
 decrements the reference count and calls derefImpl() if there_can_be_only_one is false, otherwise does nothing
 
DLLEXPORT AbstractQoreNoderefSelf () const
 returns "this" with an incremented reference count
 
DLLEXPORT void ref () const
 increments the reference count
 
DLLLOCAL bool isReferenceCounted () const
 returns true if the object is reference-counted
 
virtual DLLEXPORT
AbstractQoreNode
parseInit (LocalVar *oflag, int pflag, int &lvids, const QoreTypeInfo *&typeInfo)
 for use by parse types to initialize them for execution during stage 1 parsing
 
- Public Member Functions inherited from QoreReferenceCounter
DLLEXPORT QoreReferenceCounter ()
 creates the reference counter object
 
DLLEXPORT ~QoreReferenceCounter ()
 destroys the reference counter object
 
DLLLOCAL int reference_count () const
 gets the reference count
 
DLLLOCAL bool is_unique () const
 returns true if the reference count is 1
 
DLLEXPORT void ROreference () const
 atomically increments the reference count
 
DLLEXPORT bool ROdereference () const
 atomically decrements the reference count
 

Additional Inherited Members

- Protected Member Functions inherited from AbstractQoreNode
virtual DLLEXPORT ~AbstractQoreNode ()
 default destructor does nothing
 
- Protected Attributes inherited from AbstractQoreNode
qore_type_t type: 11
 the type of the object
 
bool value: 1
 this is true for values, if false then either the type needs evaluation to produce a value or is a parse expression
 
bool needs_eval_flag: 1
 if this is true then the type can be evaluated
 
bool there_can_be_only_one: 1
 if this is set to true, then reference counting is turned off for objects of this class
 
bool custom_reference_handlers: 1
 set to one for objects that need custom reference handlers
 

Detailed Description

The base class for all types in Qore expression trees that cannot throw an exception when deleted.

This class adds the deref() function without an ExceptionSink argument.


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