Qore Programming Language  0.9.1
QoreObject.h
1 /* -*- mode: c++; indent-tabs-mode: nil -*- */
2 /*
3  QoreObject.h
4 
5  thread-safe object definition
6 
7  Qore Programming Language
8 
9  Copyright (C) 2003 - 2018 Qore Technologies, s.r.o.
10 
11  Permission is hereby granted, free of charge, to any person obtaining a
12  copy of this software and associated documentation files (the "Software"),
13  to deal in the Software without restriction, including without limitation
14  the rights to use, copy, modify, merge, publish, distribute, sublicense,
15  and/or sell copies of the Software, and to permit persons to whom the
16  Software is furnished to do so, subject to the following conditions:
17 
18  The above copyright notice and this permission notice shall be included in
19  all copies or substantial portions of the Software.
20 
21  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
24  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
25  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
26  FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
27  DEALINGS IN THE SOFTWARE.
28 
29  Note that the Qore library is released under a choice of three open-source
30  licenses: MIT (as above), LGPL 2+, or GPL 2+; see README-LICENSE for more
31  information.
32 */
33 
34 #ifndef _QORE_QOREOBJECT_H
35 
36 #define _QORE_QOREOBJECT_H
37 
38 class AutoVLock;
39 class VRMutex;
40 class BuiltinCopy;
41 class BuiltinDeleteBlocker;
42 class BuiltinNormalMethodVariantBase;
43 class BuiltinCopyVariantBase;
45 class QoreProgram;
46 
48 
61 class QoreObject : public AbstractQoreNode {
62  friend class qore_object_private;
63  friend class ObjectRSetHelper;
64  friend class ObjectRSet;
65  friend class qore_object_dereference_helper;
66 
67 private:
69  class qore_object_private* priv;
70 
72  DLLLOCAL QoreObject(const QoreObject&);
73 
75  DLLLOCAL QoreObject& operator=(const QoreObject&);
76 
77 protected:
79 
83  DLLEXPORT virtual bool derefImpl(ExceptionSink* xsink);
84 
86 
88  DLLLOCAL virtual QoreValue evalImpl(bool& needs_deref, ExceptionSink* xsink) const;
89 
91  DLLLOCAL virtual void customRef() const;
92 
94  DLLLOCAL virtual void customDeref(ExceptionSink* xsink);
95 
97  DLLLOCAL virtual ~QoreObject();
98 
99  public:
101 
105  DLLEXPORT QoreObject(const QoreClass* oc, QoreProgram* p);
106 
108 
113  DLLEXPORT QoreObject(const QoreClass* oc, QoreProgram* p, AbstractPrivateData* data);
114 
116  DLLEXPORT bool hasMember(const char* mem, ExceptionSink* xsink) const;
117 
119 
121  DLLEXPORT virtual bool getAsBoolImpl() const;
122 
124 
130  DLLEXPORT virtual int getAsString(QoreString &str, int foff, ExceptionSink* xsink) const;
131 
133 
140  DLLEXPORT virtual QoreString* getAsString(bool& del, int foff, ExceptionSink* xsink) const;
141 
143  DLLEXPORT virtual AbstractQoreNode* realCopy() const;
144 
146 
150  DLLEXPORT virtual bool is_equal_soft(const AbstractQoreNode* v, ExceptionSink* xsink) const;
151 
153 
157  DLLEXPORT virtual bool is_equal_hard(const AbstractQoreNode* v, ExceptionSink* xsink) const;
158 
160  DLLEXPORT virtual const char* getTypeName() const;
161 
163  DLLLOCAL static const char* getStaticTypeName() {
164  return "object";
165  }
166 
168  DLLLOCAL static qore_type_t getStaticTypeCode() {
169  return NT_OBJECT;
170  }
171 
173 
177  DLLEXPORT bool validInstanceOf(qore_classid_t cid) const;
178 
180 
182  DLLEXPORT bool validInstanceOf(const QoreClass& qc) const;
183 
185 
190  DLLEXPORT void setValue(const char* key, QoreValue val, ExceptionSink* xsink);
191 
193 
196  DLLEXPORT QoreListNode* getMemberList(ExceptionSink* xsink) const;
197 
199 
203  DLLEXPORT void deleteMemberValue(const QoreString* key, ExceptionSink* xsink);
204 
206 
210  DLLEXPORT void deleteMemberValue(const char* key, ExceptionSink* xsink);
211 
213 
217  DLLEXPORT void removeMember(const QoreString* key, ExceptionSink* xsink);
218 
220 
224  DLLEXPORT void removeMember(const char* key, ExceptionSink* xsink);
225 
227 
232  DLLEXPORT QoreValue takeMember(const QoreString* key, ExceptionSink* xsink);
233 
235 
240  DLLEXPORT QoreValue takeMember(const char* key, ExceptionSink* xsink);
241 
243 
246  DLLEXPORT int size(ExceptionSink* xsink) const;
247 
249 
253  DLLEXPORT bool compareSoft(const QoreObject* obj, ExceptionSink* xsink) const;
254 
256 
260  DLLEXPORT bool compareHard(const QoreObject* obj, ExceptionSink* xsink) const;
261 
263 
268  DLLEXPORT QoreValue getReferencedMemberNoMethod(const char* mem, ExceptionSink* xsink) const;
269 
271 
277  DLLEXPORT int64 getMemberAsBigInt(const char* mem, bool& found, ExceptionSink* xsink) const;
278 
280 
283  DLLEXPORT QoreHashNode* copyData(ExceptionSink* xsink) const;
284 
286 
290  DLLEXPORT void mergeDataToHash(QoreHashNode* hash, ExceptionSink* xsink);
291 
293 
297  DLLEXPORT void setPrivate(qore_classid_t key, AbstractPrivateData* pd);
298 
300 
305 
307 
314 
316 
321  DLLEXPORT QoreValue evalMethod(const QoreString* name, const QoreListNode* args, ExceptionSink* xsink);
322 
324 
329  DLLEXPORT QoreValue evalMethod(const char* name, const QoreListNode* args, ExceptionSink* xsink);
330 
332 
337  DLLEXPORT QoreValue evalMethod(const QoreMethod& method, const QoreListNode* args, ExceptionSink* xsink);
338 
340 
350  DLLEXPORT QoreValue evalMethod(const QoreMethod& method, const QoreClass* class_ctx, const QoreListNode* args, ExceptionSink* xsink);
351 
353 
356  DLLEXPORT void doDelete(ExceptionSink* xsink);
357 
359 
363  DLLEXPORT const QoreClass* getClass(qore_classid_t cid) const;
364 
366 
373  DLLEXPORT const QoreClass* getClass(qore_classid_t cid, bool& priv) const;
374 
376 
382  DLLEXPORT ClassAccess getClassAccess(const QoreClass& cls) const;
383 
385 
388  DLLEXPORT const QoreClass* getClass() const;
389 
391 
394  DLLEXPORT const char* getClassName() const;
395 
397 
400  DLLEXPORT bool isValid() const;
401 
403 
406  DLLEXPORT QoreProgram* getProgram() const;
407 
409 
412  DLLEXPORT bool isSystemObject() const;
413 
415 
420  DLLEXPORT void tRef() const;
421 
423 
426  DLLEXPORT void tDeref();
427 
429  DLLEXPORT void realRef();
430 
432  DLLEXPORT void realDeref(ExceptionSink* xsink);
433 
435 
443  DLLEXPORT QoreValue getMemberValueNoMethod(const QoreString* key, AutoVLock* vl, ExceptionSink* xsink) const;
444 
446 
452  DLLEXPORT QoreValue getMemberValueNoMethod(const char* key, AutoVLock* vl, ExceptionSink* xsink) const;
453 
455 
461  DLLEXPORT QoreValue getReferencedMemberNoMethod(const char* key, const QoreClass* cls, ExceptionSink* xsink) const;
462 
464 
473  DLLEXPORT int setMemberValue(const char* key, const QoreClass* cls, const QoreValue val, ExceptionSink* xsink);
474 
476 
478  DLLEXPORT void deleteBlockerRef() const;
479 
481 
485  DLLEXPORT void externalDelete(qore_classid_t key, ExceptionSink* xsink);
486 
488  DLLEXPORT QoreValue evalMethodVariant(const QoreMethod& method, const QoreExternalMethodVariant* variant, const QoreListNode* args, ExceptionSink* xsink);
489 
491 
493  DLLEXPORT QoreValue evalMethodVariant(const QoreMethod& method, const QoreClass* class_ctx, const QoreExternalMethodVariant* variant, const QoreListNode* args, ExceptionSink* xsink);
494 
496 
498  DLLEXPORT static QoreValue evalStaticMethod(const QoreMethod& method, const QoreListNode* args, ExceptionSink* xsink);
499 
501 
503  DLLEXPORT static QoreValue evalStaticMethod(const QoreMethod& method, const QoreClass* class_ctx, const QoreListNode* args, ExceptionSink* xsink);
504 
506 
508  DLLEXPORT static QoreValue evalStaticMethodVariant(const QoreMethod& method, const QoreExternalMethodVariant* variant, const QoreListNode* args, ExceptionSink* xsink);
509 
511 
513  DLLEXPORT static QoreValue evalStaticMethodVariant(const QoreMethod& method, const QoreClass* class_ctx, const QoreExternalMethodVariant* variant, const QoreListNode* args, ExceptionSink* xsink);
514 
515  DLLLOCAL int getStatus() const;
516 
518 
522  DLLLOCAL QoreValue evalMember(const QoreString* member, ExceptionSink* xsink);
523 
524  DLLLOCAL class KeyNode* getReferencedPrivateDataNode(qore_classid_t key);
525 
527 
532 
534 
540  DLLLOCAL QoreValue evalBuiltinMethodWithPrivateData(const QoreMethod& method, const BuiltinNormalMethodVariantBase* meth, const QoreListNode* args, ExceptionSink* xsink);
541 
543  DLLLOCAL void evalCopyMethodWithPrivateData(const QoreClass &thisclass, const BuiltinCopyVariantBase* meth, QoreObject* self, ExceptionSink* xsink);
544 
546 
550  DLLLOCAL void addPrivateDataToString(QoreString* str, ExceptionSink* xsink) const;
551 
553 
556  DLLLOCAL void obliterate(ExceptionSink* xsink);
557 
559 
563  DLLLOCAL void defaultSystemDestructor(qore_classid_t classID, ExceptionSink* xsink);
564 
565  // returns a new hash consisting of just the members of value_list
566  DLLLOCAL QoreHashNode* getSlice(const QoreListNode* value_list, ExceptionSink* xsink) const;
567 
569  DLLLOCAL QoreObject(const QoreClass* oc, QoreProgram* p, QoreHashNode* d);
570 
572  DLLLOCAL bool evalDeleteBlocker(qore_classid_t classid_for_method, BuiltinDeleteBlocker* meth);
573 
575  DLLLOCAL bool hasMemberNotification() const;
576 
578  DLLLOCAL void execMemberNotification(const char* member, ExceptionSink* xsink);
579 };
580 
582 template <class T>
584 public:
585  DLLLOCAL PrivateDataRefHolder(const QoreObject* o, qore_classid_t cid, ExceptionSink* xsink) : ReferenceHolder<T>(reinterpret_cast<T*>(o->getReferencedPrivateData(cid, xsink)), xsink) {
586  }
587 };
588 
590 template <class T>
592 public:
593  DLLLOCAL TryPrivateDataRefHolder(const QoreObject* o, qore_classid_t cid, ExceptionSink* xsink) : ReferenceHolder<T>(reinterpret_cast<T*>(o->tryGetReferencedPrivateData(cid, xsink)), xsink) {
594  }
595 };
596 
597 class QorePrivateObjectAccessHelper {
598 public:
599  DLLLOCAL QorePrivateObjectAccessHelper(ExceptionSink* xs) : xsink(xs), ptr(0) {
600  }
601 
602  DLLLOCAL operator bool() const {
603  return (bool)ptr;
604  }
605 
606 private:
607  DLLLOCAL QorePrivateObjectAccessHelper(const QorePrivateObjectAccessHelper&) = delete;
608  DLLLOCAL QorePrivateObjectAccessHelper& operator=(const QorePrivateObjectAccessHelper&) = delete;
609  DLLLOCAL void* operator new(size_t) = delete;
610 
611 protected:
612  ExceptionSink* xsink;
613  void* ptr;
614 };
615 
616 #endif
DLLLOCAL void evalCopyMethodWithPrivateData(const QoreClass &thisclass, const BuiltinCopyVariantBase *meth, QoreObject *self, ExceptionSink *xsink)
called on the old object (this) to acquire private data, copy method called with pointer to "self" (n...
AutoVLock is a container for safely managing global variable and object lock handovers, required for functions accessing global variables and object data where locking is necessary.
Definition: AutoVLock.h:80
virtual 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...
DLLLOCAL void execMemberNotification(const char *member, ExceptionSink *xsink)
executes the member notification on the object the given member
This is the hash or associative list container type in Qore, dynamically allocated only...
Definition: QoreHashNode.h:50
virtual DLLEXPORT const char * getTypeName() const
returns the type name as a c string
virtual DLLLOCAL void customRef() const
custom reference handler
DLLEXPORT void doDelete(ExceptionSink *xsink)
runs the destructor on the object (if it hasn&#39;t already been deleted)
the base class for all data to be used as private data of Qore objects
Definition: AbstractPrivateData.h:44
DLLEXPORT int64 getMemberAsBigInt(const char *mem, bool &found, ExceptionSink *xsink) const
returns the value of the given member as an int64
DLLEXPORT void mergeDataToHash(QoreHashNode *hash, ExceptionSink *xsink)
copies all member data of the current object to the passed QoreHashNode
DLLEXPORT void externalDelete(qore_classid_t key, ExceptionSink *xsink)
call this function when an object&#39;s private data is deleted externally
DLLEXPORT QoreHashNode * copyData(ExceptionSink *xsink) const
retuns all member data of the object (or 0 if there&#39;s an exception), caller owns the QoreHashNode ref...
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 void removeMember(const QoreString *key, ExceptionSink *xsink)
removes a member from the object without explicitly calling destructors; the value is only dereferenc...
DLLEXPORT bool compareHard(const QoreObject *obj, ExceptionSink *xsink) const
tests for equality ("deep compare" including all contained values) with possible type conversion of c...
DLLEXPORT void deleteBlockerRef() const
increment the reference count of the object, to be called only from within a delete blocker ...
DLLEXPORT void realRef()
increments the standard reference count of the object for references that cannot be part of a recursi...
The base class for all value and parse types in Qore expression trees.
Definition: AbstractQoreNode.h:54
virtual DLLLOCAL QoreValue evalImpl(bool &needs_deref, ExceptionSink *xsink) const
should never be called, does nothing
const qore_type_t NT_OBJECT
type value for QoreObject
Definition: node_types.h:52
DLLEXPORT bool compareSoft(const QoreObject *obj, ExceptionSink *xsink) const
tests for equality ("deep compare" including all contained values) with possible type conversion of c...
DLLLOCAL bool hasMemberNotification() const
returns true if the class has a memberNotification method
virtual DLLLOCAL ~QoreObject()
destructor
DLLEXPORT ClassAccess getClassAccess(const QoreClass &cls) const
returns the accessibility of the class in the object&#39;s hierachy or Inaccessible the object does not i...
DLLEXPORT void tRef() const
increments the existence reference count
DLLEXPORT bool isValid() const
returns true if the object is valid
virtual DLLLOCAL void customDeref(ExceptionSink *xsink)
custom dereference handler - with delete
virtual DLLEXPORT bool derefImpl(ExceptionSink *xsink)
runs the destructor if necessary and dereferences all members
Qore&#39;s string type supported by the QoreEncoding class.
Definition: QoreString.h:81
DLLLOCAL void obliterate(ExceptionSink *xsink)
destroys all members and dereferences all private data structures
DLLEXPORT int setMemberValue(const char *key, const QoreClass *cls, const QoreValue val, ExceptionSink *xsink)
sets the value of the given member as accessed from the given class
static DLLLOCAL qore_type_t getStaticTypeCode()
returns the type code (useful in templates)
Definition: QoreObject.h:168
DLLEXPORT void tDeref()
decrements the existence reference count, when it reaches 0 the C++ object ("this") will be deleted ...
This is the list container type in Qore, dynamically allocated only, reference counted.
Definition: QoreListNode.h:52
convenience class for holding AbstractPrivateData references
Definition: QoreObject.h:583
DLLLOCAL bool evalDeleteBlocker(qore_classid_t classid_for_method, BuiltinDeleteBlocker *meth)
evaluates the delete blocker function for the managed private data
defines a Qore-language class
Definition: QoreClass.h:237
DLLEXPORT QoreListNode * getMemberList(ExceptionSink *xsink) const
returns the list of members, caller owns the list returned
DLLEXPORT const QoreClass * getClass() const
returns a pointer to the QoreClass of this object
virtual DLLEXPORT bool getAsBoolImpl() const
returns false unless perl-boolean-evaluation is enabled, in which case it returns false only when emp...
DLLLOCAL QoreValue evalMember(const QoreString *member, ExceptionSink *xsink)
returns the value of the member with an incremented reference count, or executes the memberGate() met...
DLLEXPORT bool isSystemObject() const
returns true if the object is a system object (created with the system constructor) ...
The main value class in Qore, designed to be passed by value.
Definition: QoreValue.h:262
supports parsing and executing Qore-language code, reference counted, dynamically-allocated only ...
Definition: QoreProgram.h:126
DLLEXPORT AbstractPrivateData * getReferencedPrivateData(qore_classid_t key, ExceptionSink *xsink) const
returns the private data corresponding to the class ID passed with an incremented reference count...
the implementation of Qore&#39;s object data type, reference counted, dynamically-allocated only ...
Definition: QoreObject.h:61
DLLLOCAL void defaultSystemDestructor(qore_classid_t classID, ExceptionSink *xsink)
runs the destructor for system objects
unsigned qore_classid_t
used for the unique class ID for QoreClass objects
Definition: common.h:79
external wrapper class for method variants
Definition: QoreReflection.h:90
container for holding Qore-language exception information and also for registering a "thread_exit" ca...
Definition: ExceptionSink.h:46
static DLLEXPORT QoreValue evalStaticMethod(const QoreMethod &method, const QoreListNode *args, ExceptionSink *xsink)
executes a static method
DLLEXPORT QoreValue takeMember(const QoreString *key, ExceptionSink *xsink)
removes a member from the object without explicitly calling destructors and returns the value removed...
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 bool hasMember(const char *mem, ExceptionSink *xsink) const
returns true if the object has the given member (note that the member may not have a value) ...
long long int64
64bit integer type, cannot use int64_t here since it breaks the API on some 64-bit systems due to equ...
Definition: common.h:260
virtual DLLEXPORT AbstractQoreNode * realCopy() const
performs a the same object with its reference count increased
DLLEXPORT bool validInstanceOf(qore_classid_t cid) const
returns true if this object is a valid instance of the classid passed
DLLEXPORT QoreValue evalMethod(const QoreString *name, const QoreListNode *args, ExceptionSink *xsink)
evaluates the given method with the arguments passed and returns the return value, caller owns any reference returned
DLLLOCAL AbstractPrivateData * getAndClearPrivateData(qore_classid_t key, ExceptionSink *xsink)
retrieves the private data pointer and clears it from the object&#39;s private data store, used when executing destructors
DLLEXPORT void deleteMemberValue(const QoreString *key, ExceptionSink *xsink)
removes a member from the object, if the member&#39;s value is an object it is deleted as well (destructo...
DLLEXPORT QoreProgram * getProgram() const
returns the QoreProgram object associated with this object
DLLEXPORT void realDeref(ExceptionSink *xsink)
decrements the standard reference count of the object for references that cannot be part of a recursi...
DLLEXPORT QoreValue evalMethodVariant(const QoreMethod &method, const QoreExternalMethodVariant *variant, const QoreListNode *args, ExceptionSink *xsink)
executes a normal object method variant
convenience class for holding AbstractPrivateData references
Definition: QoreObject.h:591
static DLLEXPORT QoreValue evalStaticMethodVariant(const QoreMethod &method, const QoreExternalMethodVariant *variant, const QoreListNode *args, ExceptionSink *xsink)
executes a static method variant
int16_t qore_type_t
used to identify unique Qore data and parse types (descendents of AbstractQoreNode) ...
Definition: common.h:70
static DLLLOCAL const char * getStaticTypeName()
returns the type name (useful in templates)
Definition: QoreObject.h:163
DLLEXPORT QoreValue getReferencedMemberNoMethod(const char *mem, ExceptionSink *xsink) const
returns the value of the given member with the reference count incremented, the caller owns any refer...
DLLEXPORT void setValue(const char *key, QoreValue val, ExceptionSink *xsink)
sets the value of the given member to the given value
DLLEXPORT AbstractPrivateData * tryGetReferencedPrivateData(qore_classid_t key, ExceptionSink *xsink) const
returns the private data corresponding to the class ID passed with an incremented reference count if ...
DLLEXPORT int size(ExceptionSink *xsink) const
returns the number of members of the object
DLLEXPORT const char * getClassName() const
returns the name of the class
a method in a QoreClass
Definition: QoreClass.h:123
DLLLOCAL QoreValue evalBuiltinMethodWithPrivateData(const QoreMethod &method, const BuiltinNormalMethodVariantBase *meth, const QoreListNode *args, ExceptionSink *xsink)
called to evaluate a builtin method when private data is available
DLLEXPORT void setPrivate(qore_classid_t key, AbstractPrivateData *pd)
sets private data for the object against the class ID passed, used in C++ functions implementing Qore...
a templated class to manage a reference count of an object that can throw a Qore-language exception w...
Definition: ReferenceHolder.h:52
DLLLOCAL void addPrivateDataToString(QoreString *str, ExceptionSink *xsink) const
concatenates info about private data to a string
DLLEXPORT QoreValue getMemberValueNoMethod(const QoreString *key, AutoVLock *vl, ExceptionSink *xsink) const
returns the pointer to the value of the member