Qore Programming Language  0.9.16
QoreNamespace.h
1 /* -*- mode: c++; indent-tabs-mode: nil -*- */
2 /*
3  QoreNamespace.h
4 
5  Qore Programming Language
6 
7  Copyright (C) 2003 - 2020 Qore Technologies, s.r.o.
8 
9  Permission is hereby granted, free of charge, to any person obtaining a
10  copy of this software and associated documentation files (the "Software"),
11  to deal in the Software without restriction, including without limitation
12  the rights to use, copy, modify, merge, publish, distribute, sublicense,
13  and/or sell copies of the Software, and to permit persons to whom the
14  Software is furnished to do so, subject to the following conditions:
15 
16  The above copyright notice and this permission notice shall be included in
17  all copies or substantial portions of the Software.
18 
19  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
22  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
24  FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
25  DEALINGS IN THE SOFTWARE.
26 
27  Note that the Qore library is released under a choice of three open-source
28  licenses: MIT (as above), LGPL 2+, or GPL 2+; see README-LICENSE for more
29  information.
30 */
31 
32 /*
33  namespaces are children of a program object. there is a parse
34  lock per program object to ensure that objects are added (or backed out)
35  atomically per program object. All the objects referenced here should
36  be safe to read & copied at all times. They will only be deleted when the
37  program object is deleted (except the pending structures, which will be
38  deleted any time there is a parse error, together with all other
39  pending structures)
40 */
41 
42 #ifndef _QORE_QORENAMESPACE_H
43 
44 #define _QORE_QORENAMESPACE_H
45 
46 #include <cstdlib>
47 #include <cstring>
48 #include <string>
49 
50 // forward declarations
51 class QoreExternalFunction;
53 class QoreExternalGlobalVar;
54 class QoreProgram;
55 
57 
62 typedef QoreClass* (*q_ns_class_handler_t)(QoreNamespace* ns, const char* cname);
63 
66  friend class QoreNamespaceList;
67  friend class RootQoreNamespace;
68  friend class qore_ns_private;
69  friend class qore_root_ns_private;
70  friend hashdecl NSOInfoBase;
71 
72 public:
74 
77  DLLEXPORT QoreNamespace(const char* n);
78 
80  DLLEXPORT virtual ~QoreNamespace();
81 
83 
87  DLLEXPORT void clear(ExceptionSink* xsink);
88 
90 
96  DLLEXPORT void addConstant(const char* name, QoreValue value);
97 
99 
105  DLLEXPORT void addConstant(const char* name, QoreValue value, const QoreTypeInfo* typeInfo);
106 
108 
111  DLLEXPORT void addSystemClass(QoreClass* oc);
112 
114 
119  DLLEXPORT void addSystemHashDecl(TypedHashDecl* hashdecl);
120 
122 
125  DLLEXPORT QoreNamespace* copy(int po) const;
126 
128 
131  DLLEXPORT QoreNamespace* copy(int64 po = PO_DEFAULT) const;
132 
134 
139  DLLEXPORT QoreHashNode* getClassInfo() const;
140 
142 
147  DLLEXPORT QoreHashNode* getConstantInfo() const;
148 
150 
156  DLLEXPORT QoreHashNode* getInfo() const;
157 
159 
162  DLLEXPORT const char* getName() const;
163 
165 
168  DLLEXPORT void addNamespace(QoreNamespace* ns);
169 
171 
176  DLLEXPORT void addInitialNamespace(QoreNamespace* ns);
177 
179 
191  DLLEXPORT QoreNamespace* findCreateNamespacePath(const char* nspath);
192 
194 
206  DLLEXPORT QoreNamespace* findCreateNamespacePathAll(const char* nspath);
207 
209 
215  DLLEXPORT QoreClass* findLocalClass(const char* cname) const;
216 
218 
226  DLLEXPORT QoreClass* findLoadLocalClass(const char* cname);
227 
229 
233  DLLEXPORT QoreNamespace* findLocalNamespace(const char* nsname) const;
234 
236 
239  DLLEXPORT void setClassHandler(q_ns_class_handler_t class_handler);
240 
242 
244  DLLEXPORT const QoreNamespace* getParent() const;
245 
247  DLLEXPORT void deleteData(ExceptionSink* xsink);
248 
250  DLLEXPORT void addBuiltinVariant(const char* name, q_func_n_t f, int64 code_flags = QCF_NO_FLAGS, int64 functional_domain = QDOM_DEFAULT, const QoreTypeInfo* returnTypeInfo = 0, unsigned num_params = 0, ...);
251 
253 
255  DLLEXPORT void addBuiltinVariant(void* ptr, const char* name, q_external_func_t f,
256  int64 code_flags = QCF_NO_FLAGS, int64 functional_domain = QDOM_DEFAULT,
257  const QoreTypeInfo* returnTypeInfo = nullptr, unsigned num_params = 0, ...);
258 
260 
262  DLLEXPORT const QoreExternalFunction* findLocalFunction(const char* name) const;
263 
265 
267  DLLEXPORT const QoreExternalConstant* findLocalConstant(const char* name) const;
268 
270 
272  DLLEXPORT const QoreExternalGlobalVar* findLocalGlobalVar(const char* name) const;
273 
275 
277  DLLEXPORT const TypedHashDecl* findLocalTypedHash(const char* name) const;
278 
280 
284  DLLEXPORT std::string getPath(bool anchored = false) const;
285 
287 
289  DLLEXPORT bool isModulePublic() const;
290 
292 
294  DLLEXPORT bool isBuiltin() const;
295 
297 
299  DLLEXPORT bool isImported() const;
300 
302 
304  DLLEXPORT bool isRoot() const;
305 
307 
309  DLLEXPORT QoreProgram* getProgram() const;
310 
312 
314  DLLEXPORT const char* getModuleName() const;
315 
316 private:
318  QoreNamespace(const QoreNamespace&) = delete;
319 
321  QoreNamespace& operator=(const QoreNamespace&) = delete;
322 
323 protected:
324  class qore_ns_private* priv; // private implementation
325 
326  // protected, function not exported in the API
327  DLLLOCAL QoreNamespace(qore_ns_private* p);
328 };
329 
331 
336  friend class qore_ns_private;
337  friend class qore_root_ns_private;
338  friend class StaticSystemNamespace;
339 
340 public:
342 
345  DLLEXPORT QoreNamespace* rootGetQoreNamespace() const;
346 
348  DLLLOCAL virtual ~RootQoreNamespace();
349 
351 
353  DLLEXPORT QoreProgram* getProgram() const;
354 
355 protected:
356  // private implementation
357  class qore_root_ns_private* rpriv;
358 
359 private:
361  RootQoreNamespace(const RootQoreNamespace&) = delete;
362 
364  RootQoreNamespace& operator=(const RootQoreNamespace&) = delete;
365 
366  DLLLOCAL RootQoreNamespace(class qore_root_ns_private* p);
367 };
368 
369 class QorePrivateNamespaceIterator;
370 
372 
375 public:
377  DLLEXPORT QoreNamespaceIterator(QoreNamespace& ns);
378 
380  DLLEXPORT virtual ~QoreNamespaceIterator();
381 
383  DLLEXPORT bool next();
384 
386  DLLEXPORT QoreNamespace* operator->();
387 
389  DLLEXPORT QoreNamespace* operator*();
390 
392  DLLEXPORT QoreNamespace& get();
393 
395  DLLEXPORT const QoreNamespace* operator->() const;
397  DLLEXPORT const QoreNamespace* operator*() const;
398 
400  DLLEXPORT const QoreNamespace& get() const;
401 
402 private:
405 
407  QoreNamespaceIterator& operator=(const QoreNamespaceIterator&) = delete;
408 
409  QorePrivateNamespaceIterator* priv;
410 };
411 
413 
416 public:
418  DLLEXPORT QoreNamespaceConstIterator(const QoreNamespace& ns);
419 
421  DLLEXPORT virtual ~QoreNamespaceConstIterator();
422 
424  DLLEXPORT bool next();
425 
427  DLLEXPORT const QoreNamespace* operator->() const;
428 
430  DLLEXPORT const QoreNamespace* operator*() const;
431 
433  DLLEXPORT const QoreNamespace& get() const;
434 
435 private:
438 
440  QoreNamespaceConstIterator& operator=(const QoreNamespaceConstIterator&) = delete;
441 
442  QorePrivateNamespaceIterator* priv;
443 };
444 
446 
449 public:
451  DLLEXPORT QoreNamespaceNamespaceIterator(const QoreNamespace& ns);
452 
454  DLLEXPORT virtual ~QoreNamespaceNamespaceIterator();
455 
457  DLLEXPORT bool next();
458 
460  DLLEXPORT const QoreNamespace& get() const;
461 
462 private:
465 
468 
469  class qore_namespace_namespace_iterator* priv;
470 };
471 
473 
476 public:
478  DLLEXPORT QoreNamespaceFunctionIterator(const QoreNamespace& ns);
479 
481  DLLEXPORT virtual ~QoreNamespaceFunctionIterator();
482 
484  DLLEXPORT bool next();
485 
487  DLLEXPORT const QoreExternalFunction& get() const;
488 
489 private:
492 
495 
496  class qore_namespace_function_iterator* priv;
497 };
498 
500 
503 public:
505  DLLEXPORT QoreNamespaceConstantIterator(const QoreNamespace& ns);
506 
508  DLLEXPORT virtual ~QoreNamespaceConstantIterator();
509 
511  DLLEXPORT bool next();
512 
514  DLLEXPORT const QoreExternalConstant& get() const;
515 
516 private:
519 
522 
523  class qore_namespace_constant_iterator* priv;
524 };
525 
527 
530 public:
532  DLLEXPORT QoreNamespaceClassIterator(const QoreNamespace& ns);
533 
535  DLLEXPORT virtual ~QoreNamespaceClassIterator();
536 
538  DLLEXPORT bool next();
539 
541  DLLEXPORT const QoreClass& get() const;
542 
543 private:
546 
548  QoreNamespaceClassIterator& operator=(const QoreNamespaceClassIterator&) = delete;
549 
550  class ConstClassListIterator* priv;
551 };
552 
554 
557 public:
559  DLLEXPORT QoreNamespaceGlobalVarIterator(const QoreNamespace& ns);
560 
562  DLLEXPORT virtual ~QoreNamespaceGlobalVarIterator();
563 
565  DLLEXPORT bool next();
566 
568  DLLEXPORT const QoreExternalGlobalVar& get() const;
569 
570 private:
573 
576 
577  class qore_namespace_globalvar_iterator* priv;
578 };
579 
581 
584 public:
586  DLLEXPORT QoreNamespaceTypedHashIterator(const QoreNamespace& ns);
587 
589  DLLEXPORT virtual ~QoreNamespaceTypedHashIterator();
590 
592  DLLEXPORT bool next();
593 
595  DLLEXPORT const TypedHashDecl& get() const;
596 
597 private:
600 
603 
604  class ConstHashDeclListIterator* priv;
605 };
606 
607 #endif // QORE_NAMESPACE_H
DLLEXPORT QoreNamespaceConstIterator(const QoreNamespace &ns)
creates the iterator; the namespace given will also be included in the iteration set ...
allows functions in a namespace to be iterated
Definition: QoreNamespace.h:475
DLLEXPORT const QoreNamespace * operator*() const
returns the namespace
#define PO_DEFAULT
no parse options set by default
Definition: Restrictions.h:106
allows all namespaces of a namespace to be iterated (including the namespace passed in the constructo...
Definition: QoreNamespace.h:374
external wrapper class for constants
Definition: QoreReflection.h:200
This is the hash or associative list container type in Qore, dynamically allocated only...
Definition: QoreHashNode.h:50
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT void setClassHandler(q_ns_class_handler_t class_handler)
sets the namespace class handler
DLLEXPORT bool isRoot() const
returns true if the namespace is the root namespace
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
virtual DLLEXPORT ~QoreNamespaceConstantIterator()
destroys the object
DLLEXPORT QoreNamespaceClassIterator(const QoreNamespace &ns)
creates the iterator
DLLEXPORT void addBuiltinVariant(const char *name, q_func_n_t f, int64 code_flags=QCF_NO_FLAGS, int64 functional_domain=QDOM_DEFAULT, const QoreTypeInfo *returnTypeInfo=0, unsigned num_params=0,...)
adds a function variant
DLLEXPORT void addNamespace(QoreNamespace *ns)
adds a namespace to the namespace tree
DLLEXPORT QoreNamespace * operator*()
returns the namespace
virtual DLLEXPORT ~QoreNamespaceTypedHashIterator()
destroys the object
DLLEXPORT void clear(ExceptionSink *xsink)
clears the contents of the namespace before deleting
DLLEXPORT const TypedHashDecl * findLocalTypedHash(const char *name) const
find a typed hash (hashdecl) in the current namespace; returns nullptr if not found ...
DLLEXPORT bool isModulePublic() const
returns true if the namespace has its module public flag set
contains constants, classes, and subnamespaces in QoreProgram objects
Definition: QoreNamespace.h:65
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT const QoreExternalGlobalVar * findLocalGlobalVar(const char *name) const
find a global variable in the current namespace; returns nullptr if not found
DLLEXPORT QoreHashNode * getConstantInfo() const
a hash of all constants in the namespace, the hash keys are the constant names and the values are the...
DLLEXPORT QoreClass * findLocalClass(const char *cname) const
finds a class in this namespace, does not search child namespaces
allows all namespaces of a namespace to be iterated (including the namespace passed in the constructo...
Definition: QoreNamespace.h:415
DLLEXPORT const QoreNamespace * getParent() const
returns a pointer to the parent namespace or nullptr if there is no parent
DLLEXPORT QoreNamespaceTypedHashIterator(const QoreNamespace &ns)
creates the iterator
virtual DLLEXPORT ~QoreNamespaceNamespaceIterator()
destroys the object
DLLEXPORT QoreProgram * getProgram() const
Returns the owning QoreProgram object (if not the static system namespace)
allows typed hashes (hashdecls) in a namespace to be iterated
Definition: QoreNamespace.h:583
DLLEXPORT std::string getPath(bool anchored=false) const
returns the path for the namespace
the root namespace of a QoreProgram object
Definition: QoreNamespace.h:335
DLLEXPORT QoreNamespace(const char *n)
creates a namespace with the given name
DLLEXPORT QoreNamespaceIterator(QoreNamespace &ns)
creates the iterator; the namespace given will also be included in the iteration set ...
virtual DLLLOCAL ~RootQoreNamespace()
destructor is not exported in the library&#39;s public API
defines a Qore-language class
Definition: QoreClass.h:239
DLLEXPORT QoreNamespace * operator->()
returns the namespace
virtual DLLEXPORT ~QoreNamespaceGlobalVarIterator()
destroys the object
The main value class in Qore, designed to be passed by value.
Definition: QoreValue.h:262
DLLEXPORT void addInitialNamespace(QoreNamespace *ns)
adds a subnamespace to the namespace
supports parsing and executing Qore-language code, reference counted, dynamically-allocated only ...
Definition: QoreProgram.h:126
DLLEXPORT QoreNamespace * findCreateNamespacePath(const char *nspath)
finds a Namespace based on the argument; creates it (or the whole path) if necessary ...
static unsigned num_params(const QoreListNode *n)
returns the number of arguments passed to the function
Definition: params.h:54
QoreValue(* q_external_func_t)(const void *ptr, const QoreListNode *args, q_rt_flags_t flags, ExceptionSink *xsink)
the type used for builtin function signatures for external functions
Definition: common.h:319
container for holding Qore-language exception information and also for registering a "thread_exit" ca...
Definition: ExceptionSink.h:48
DLLEXPORT const char * getName() const
returns the name of the namespace
DLLEXPORT void addSystemHashDecl(TypedHashDecl *hashdecl)
adds a hashdecl to a namespace
DLLEXPORT bool isImported() const
returns true if the namespace was imported from another program object
allows classes in a namespace to be iterated
Definition: QoreNamespace.h:529
DLLEXPORT const char * getModuleName() const
Returns the module name the class was loaded from or nullptr if it is a builtin namespace.
allows global variables in a namespace to be iterated
Definition: QoreNamespace.h:556
virtual DLLEXPORT ~QoreNamespaceConstIterator()
destroys the object
DLLEXPORT const QoreNamespace * operator->() const
returns the namespace
allows local namespaces to be iterated
Definition: QoreNamespace.h:448
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 ~QoreNamespace()
destroys the object and frees memory
DLLEXPORT QoreProgram * getProgram() const
Returns the owning QoreProgram object (if not the static system namespace)
DLLEXPORT void addConstant(const char *name, QoreValue value)
adds a constant definition to the namespace
virtual DLLEXPORT ~QoreNamespaceClassIterator()
destroys the object
typed hash declaration
Definition: TypedHashDecl.h:44
DLLEXPORT QoreNamespace * rootGetQoreNamespace() const
returns a pointer to the QoreNamespace for the "Qore" namespace
DLLEXPORT QoreNamespaceFunctionIterator(const QoreNamespace &ns)
creates the iterator
DLLEXPORT QoreHashNode * getInfo() const
returns a hash giving information about the definitions in the namespace
DLLEXPORT QoreClass * findLoadLocalClass(const char *cname)
finds a class in this namespace, does not search child namespaces
DLLEXPORT QoreNamespace * findLocalNamespace(const char *nsname) const
finds a subnamespace in this namespace, does not search child namespaces
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT void deleteData(ExceptionSink *xsink)
this function must be called before the QoreNamespace object is deleted or a crash could result due i...
DLLEXPORT QoreNamespace * copy(int po) const
returns a deep copy of the namespace; DEPRECATED: use copy(int64) instead
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT QoreNamespace * findCreateNamespacePathAll(const char *nspath)
finds a Namespace based on the argument; creates it (or the whole path) if necessary ...
DLLEXPORT void addSystemClass(QoreClass *oc)
adds a class to a namespace
DLLEXPORT const QoreExternalFunction * findLocalFunction(const char *name) const
find a function in the current namespace; returns nullptr if not found
DLLEXPORT QoreHashNode * getClassInfo() const
gets a hash of all classes in the namespace, the hash keys are the class names and the values are lis...
DLLEXPORT QoreNamespaceConstantIterator(const QoreNamespace &ns)
creates the iterator
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT QoreNamespaceGlobalVarIterator(const QoreNamespace &ns)
creates the iterator
virtual DLLEXPORT ~QoreNamespaceFunctionIterator()
destroys the object
allows constants in a namespace to be iterated
Definition: QoreNamespace.h:502
QoreValue(* q_func_n_t)(const QoreListNode *args, q_rt_flags_t flags, ExceptionSink *xsink)
the type used for builtin function signatures
Definition: common.h:307
DLLEXPORT bool isBuiltin() const
returns true if the namespace is builtin
DLLEXPORT const QoreExternalConstant * findLocalConstant(const char *name) const
find a constant in the current namespace; returns nullptr if not found
DLLEXPORT QoreNamespaceNamespaceIterator(const QoreNamespace &ns)
creates the iterator
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
#define QDOM_DEFAULT
the default domain (no domain)
Definition: Restrictions.h:156
virtual DLLEXPORT ~QoreNamespaceIterator()
destroys the object