32 #ifndef _QORE_QORELISTNODE_H
34 #define _QORE_QORELISTNODE_H
36 #include <qore/AbstractQoreNode.h>
53 friend class StackList;
54 friend hashdecl qore_list_private;
67 hashdecl qore_list_private *
priv;
152 DLLEXPORT
QoreValue& getEntryReference(
size_t index);
435 #include <qore/ReferenceHolder.h>
469 DLLLOCAL
void *
operator new(size_t);
507 DLLEXPORT
int set(
size_t n_pos);
524 DLLLOCAL
size_t index()
const {
return pos; }
527 DLLLOCAL
size_t max()
const {
return l->
size(); }
539 return pos == -1 ? false :
true;
604 DLLEXPORT
int set(
size_t n_pos);
621 DLLLOCAL
size_t index()
const {
return pos; }
624 DLLLOCAL
size_t max()
const {
return l->
size(); }
636 return pos == -1 ? false :
true;
The base class for all value and parse types in Qore expression trees.
Definition: AbstractQoreNode.h:57
For use on the stack only: iterates through elements of a const QoreListNode.
Definition: QoreListNode.h:563
DLLEXPORT bool prev()
moves the iterator to the previous element, returns true if the iterator is pointing to an element of...
DLLLOCAL bool valid() const
returns true if the iterator is pointing to a valid element
Definition: QoreListNode.h:635
DLLLOCAL const QoreListNode * getList() const
returns the list
Definition: QoreListNode.h:627
DLLLOCAL bool empty() const
returns true if the list is empty
Definition: QoreListNode.h:630
DLLEXPORT QoreValue getReferencedValue() const
returns the referenced value of the list element
DLLEXPORT bool next()
moves the iterator to the next element, returns true if the iterator is pointing to an element of the...
DLLEXPORT int set(size_t n_pos)
sets the iterator to a specific position in the list
DLLLOCAL size_t max() const
returns the number of elements in the list
Definition: QoreListNode.h:624
DLLEXPORT const QoreValue getValue() const
returns a pointer to the value of the list element
DLLEXPORT void reset()
resets the iterator to its initial state
DLLEXPORT bool first() const
returns true when the iterator is pointing to the first element in the list
DLLLOCAL size_t index() const
returns the current iterator position in the list or -1 if not pointing at a valid element
Definition: QoreListNode.h:621
DLLEXPORT bool last() const
returns true when the iterator is pointing to the last element in the list
DLLEXPORT ConstListIterator(const QoreListNode *lst, size_t n_pos=-1)
initializes the iterator to the position given or, if omitted, just before the first element
container for holding Qore-language exception information and also for registering a "thread_exit" ca...
Definition: ExceptionSink.h:48
For use on the stack only: iterates through a the elements of a QoreListNode.
Definition: QoreListNode.h:463
DLLLOCAL size_t max() const
returns the number of elements in the list
Definition: QoreListNode.h:527
DLLLOCAL bool empty() const
returns true if the list is empty
Definition: QoreListNode.h:533
DLLEXPORT QoreValue getValue() const
returns a pointer to the value of the list element
DLLEXPORT bool last() const
returns true when the iterator is pointing to the last element in the list
DLLEXPORT ListIterator(QoreListNode *lst, size_t n_pos=-1)
initializes the iterator to the position given or, if omitted, just before the first element
DLLEXPORT bool prev()
moves the iterator to the previous element, returns true if the iterator is pointing to an element of...
DLLEXPORT bool first() const
returns true when the iterator is pointing to the first element in the list
DLLEXPORT int set(size_t n_pos)
sets the iterator to a specific position in the list
DLLLOCAL bool valid() const
returns true if the iterator is pointing to a valid element
Definition: QoreListNode.h:538
DLLEXPORT bool next()
moves the iterator to the next element, returns true if the iterator is pointing to an element of the...
DLLEXPORT QoreValue getReferencedValue() const
returns the referenced value of the list element
DLLLOCAL QoreListNode * getList()
returns the list
Definition: QoreListNode.h:530
DLLLOCAL size_t index() const
returns the current iterator position in the list or -1 if not pointing at a valid element
Definition: QoreListNode.h:524
This is the list container type in Qore, dynamically allocated only, reference counted.
Definition: QoreListNode.h:52
virtual DLLEXPORT bool getAsBoolImpl() const
returns false unless perl-boolean-evaluation is enabled, in which case it returns false only when emp...
virtual DLLEXPORT AbstractQoreNode * realCopy() const
returns true if the list contains parse expressions and therefore needs evaluation to return a value,...
hashdecl qore_list_private * priv
this structure holds the private implementation for the type
Definition: QoreListNode.h:67
DLLLOCAL bool isVariableList() const
this function is not exported in the qore library
DLLEXPORT QoreValue shift()
returns the first element of the list, all other entries are moved down to fill up the first position...
virtual DLLEXPORT bool is_equal_soft(const AbstractQoreNode *v, ExceptionSink *xsink) const
tests for equality ("deep compare" including all contained values) with possible type conversion (sof...
DLLEXPORT QoreListNode * extract(qore_offset_t offset)
truncates the list at position "offset" (first element is offset 0) and returns any elements removed ...
DLLEXPORT QoreValue min(ExceptionSink *xsink) const
returns the element having the lowest value (determined by calling OP_LOG_LT - the less-than "<" oper...
DLLEXPORT size_t size() const
returns the number of elements in the list
DLLEXPORT int merge(const QoreListNode *list, ExceptionSink *xsink)
appends the elements of "list" to this list
virtual DLLEXPORT bool is_equal_hard(const AbstractQoreNode *v, ExceptionSink *xsink) const
tests for equality ("deep compare" including all contained values) without type conversions (hard com...
DLLEXPORT QoreListNode * evalList(ExceptionSink *xsink) const
evaluates the list and returns a value (or 0)
DLLEXPORT int push(QoreValue val, ExceptionSink *xsink)
adds a value to the list
DLLEXPORT QoreListNode * copyListFrom(size_t index) const
performs a deep copy of the list starting from element "offset" and returns the new list
DLLEXPORT QoreListNode * sort(ExceptionSink *xsink) const
returns a new list based on quicksorting the source list ("this")
virtual DLLEXPORT ~QoreListNode()
the destructor is protected so it cannot be called directly
DLLEXPORT const QoreTypeInfo * getValueTypeInfo() const
returns the value type declaration (if set)
DLLEXPORT const QoreTypeInfo * getTypeInfo() const
returns the type info structure for the current value; also works for lists with a specific value typ...
DLLEXPORT QoreListNode * listRefSelf() const
returns "this" with an incremented reference count
DLLEXPORT QoreListNode * splice(qore_offset_t offset)
truncates the list at position "offset" (first element is offset 0) and returns any elements removed ...
DLLEXPORT QoreValue getReferencedEntry(size_t index) const
returns the element at "index" (first element is index 0), the caller owns the reference
DLLEXPORT int getAsString(QoreString &str, int foff, ExceptionSink *xsink) const
concatenate the verbose string representation of the list (including all contained values) to an exis...
DLLEXPORT int setEntry(size_t index, QoreValue val, ExceptionSink *xsink)
sets the value of a list element
DLLLOCAL void setFinalized()
this function is not exported in the qore library
DLLEXPORT QoreListNode * copy() const
performs a deep copy of the list and returns the new list
static DLLLOCAL const char * getStaticTypeName()
returns true if the list does not contain any parse expressions, otherwise returns false
Definition: QoreListNode.h:148
virtual DLLEXPORT const char * getTypeName() const
returns the type name as a c string
DLLEXPORT QoreValue retrieveEntry(size_t index)
returns the element at "index" (first element is index 0)
virtual DLLEXPORT bool derefImpl(ExceptionSink *xsink)
dereferences all elements of the list
DLLEXPORT QoreListNode * sortDescending(ExceptionSink *xsink) const
returns a new list based on quicksorting the source list ("this") in descending order
DLLEXPORT int getEntryAsInt(size_t index) const
returns the value of element at "index" as an integer (first element is index 0)
DLLEXPORT QoreListNode * sortStable(ExceptionSink *xsink) const
returns a new list based on executing mergesort on the source list ("this")
DLLEXPORT QoreValue max(ExceptionSink *xsink) const
returns the element having the highest value (determined by calling OP_LOG_GT - the greater-than ">" ...
DLLEXPORT QoreListNode * reverse() const
returns a list with the order of the elements reversed
DLLEXPORT int insert(QoreValue val, ExceptionSink *xsink)
inserts a value in the first position of the list
DLLEXPORT QoreListNode * sortDescendingStable(ExceptionSink *xsink) const
returns a new list based on executing mergesort on the source list ("this") in descending order
virtual DLLLOCAL int parseInit(QoreValue &val, QoreParseContext &parse_context)
for initialization of lists in the parse tree at parse time (always returns "this")
virtual DLLLOCAL QoreValue evalImpl(bool &needs_deref, ExceptionSink *xsink) const
optionally evaluates the argument
DLLEXPORT QoreListNode()
create an empty list
DLLEXPORT bool empty() const
returns true if the list is empty
DLLEXPORT QoreValue pop()
returns the last element of the list, the length is decremented by one, caller owns the reference
DLLLOCAL bool isFinalized() const
this function is not exported in the qore library
DLLLOCAL void setVariableList()
this function is not exported in the qore library
Qore's string type supported by the QoreEncoding class.
Definition: QoreString.h:93
base class for resolved call references
Definition: CallReferenceNode.h:109
intptr_t qore_offset_t
used for offsets that could be negative
Definition: common.h:76
The main value class in Qore, designed to be passed by value.
Definition: QoreValue.h:275