 |
Qore Programming Language - C/C++ Library
0.9.4.6
|
42 #ifndef _QORE_QORENAMESPACE_H
44 #define _QORE_QORENAMESPACE_H
51 class QoreExternalFunction;
53 class QoreExternalGlobalVar;
65 friend class QoreNamespaceList;
67 friend class qore_ns_private;
68 friend class qore_root_ns_private;
69 friend struct NSOInfoBase;
245 DLLEXPORT std::string
getPath(
bool anchored =
false)
const;
275 class qore_ns_private* priv;
287 friend class qore_ns_private;
288 friend class qore_root_ns_private;
289 friend class StaticSystemNamespace;
303 class qore_root_ns_private* rpriv;
315 class QorePrivateNamespaceIterator;
355 QorePrivateNamespaceIterator* priv;
388 QorePrivateNamespaceIterator* priv;
415 class qore_namespace_namespace_iterator* priv;
433 DLLEXPORT
const QoreExternalFunction&
get()
const;
442 class qore_namespace_function_iterator* priv;
469 class qore_namespace_constant_iterator* priv;
496 class ConstClassListIterator* priv;
514 DLLEXPORT
const QoreExternalGlobalVar&
get()
const;
523 class qore_namespace_globalvar_iterator* priv;
550 class ConstHashDeclListIterator* priv;
553 #endif // QORE_NAMESPACE_H
DLLEXPORT QoreNamespaceClassIterator(const QoreNamespace &ns)
creates the iterator
DLLEXPORT void addSystemHashDecl(TypedHashDecl *hashdecl)
adds a hashdecl to a namespace
#define PO_DEFAULT
no parse options set by default
Definition: Restrictions.h:105
DLLEXPORT bool isBuiltin() const
returns true if the namespace is builtin
virtual DLLEXPORT ~QoreNamespaceTypedHashIterator()
destroys the object
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
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 const QoreExternalConstant & get() const
returns the constant
allows typed hashes (hashdecls) in a namespace to be iterated
Definition: QoreNamespace.h:529
The main value class in Qore, designed to be passed by value.
Definition: QoreValue.h:262
#define QDOM_DEFAULT
the default domain (no domain)
Definition: Restrictions.h:155
This is the hash or associative list container type in Qore, dynamically allocated only,...
Definition: QoreHashNode.h:50
virtual DLLEXPORT ~QoreNamespaceIterator()
destroys the object
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT const QoreClass & get() const
returns the class
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:421
DLLEXPORT const QoreNamespace * operator->() const
returns the namespace
virtual DLLEXPORT ~QoreNamespaceClassIterator()
destroys the object
defines a Qore-language class
Definition: QoreClass.h:239
DLLEXPORT void addConstant(const char *name, QoreValue value)
adds a constant definition to the namespace
DLLEXPORT const QoreExternalFunction * findLocalFunction(const char *name) const
find a function in the current namespace; returns nullptr if not found
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
virtual DLLEXPORT ~QoreNamespaceConstIterator()
destroys the object
DLLEXPORT QoreHashNode * getInfo() const
returns a hash giving information about the definitions in the namespace
DLLEXPORT const QoreNamespace * getParent() const
returns a pointer to the parent namespace or nullptr if there is no parent
DLLEXPORT QoreClass * findLocalClass(const char *cname) const
finds a class in this namespace, does not search child namespaces
DLLEXPORT std::string getPath(bool anchored=false) const
returns the path for the namespace
DLLEXPORT QoreNamespaceConstantIterator(const QoreNamespace &ns)
creates the iterator
DLLEXPORT const QoreNamespace & get() const
returns the namespace
DLLEXPORT QoreNamespace * copy(int po) const
returns a deep copy of the namespace; DEPRECATED: use copy(int64) instead
DLLEXPORT QoreNamespaceIterator(QoreNamespace &ns)
creates the iterator; the namespace given will also be included in the iteration set
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
DLLEXPORT QoreNamespaceNamespaceIterator(const QoreNamespace &ns)
creates the iterator
DLLEXPORT QoreNamespace * operator*()
returns the namespace
DLLEXPORT QoreNamespace * operator->()
returns the namespace
DLLEXPORT const QoreExternalGlobalVar * findLocalGlobalVar(const char *name) const
find a global variable in the current namespace; returns nullptr if not found
allows all namespaces of a namespace to be iterated (including the namespace passed in the constructo...
Definition: QoreNamespace.h:361
contains constants, classes, and subnamespaces in QoreProgram objects
Definition: QoreNamespace.h:64
DLLEXPORT QoreNamespace * findLocalNamespace(const char *nsname) const
finds a subnamespace in this namespace, does not search child namespaces
external wrapper class for constants
Definition: QoreReflection.h:200
DLLEXPORT QoreNamespace * rootGetQoreNamespace() const
returns a pointer to the QoreNamespace for the "Qore" namespace
virtual DLLEXPORT ~QoreNamespace()
destroys the object and frees memory
DLLEXPORT void deleteData(ExceptionSink *xsink)
this function must be called before the QoreNamespace object is deleted or a crash could result due i...
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
virtual DLLLOCAL ~RootQoreNamespace()
destructor is not exported in the library's public API
DLLEXPORT bool isRoot() const
returns true if the namespace is the root namespace
DLLEXPORT const QoreNamespace * operator*() const
returns the namespace
DLLEXPORT const TypedHashDecl * findLocalTypedHash(const char *name) const
find a typed hash (hashdecl) in the current namespace; returns nullptr if not found
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
typed hash declaration
Definition: TypedHashDecl.h:44
DLLEXPORT QoreNamespaceFunctionIterator(const QoreNamespace &ns)
creates the iterator
DLLEXPORT QoreNamespaceGlobalVarIterator(const QoreNamespace &ns)
creates the iterator
DLLEXPORT QoreNamespaceTypedHashIterator(const QoreNamespace &ns)
creates the iterator
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT QoreNamespace & get()
returns the namespace
DLLEXPORT const char * getName() const
returns the name of the namespace
DLLEXPORT QoreHashNode * getConstantInfo() const
a hash of all constants in the namespace, the hash keys are the constant names and the values are the...
container for holding Qore-language exception information and also for registering a "thread_exit" ca...
Definition: ExceptionSink.h:46
DLLEXPORT const QoreExternalConstant * findLocalConstant(const char *name) const
find a constant in the current namespace; returns nullptr if not found
virtual DLLEXPORT ~QoreNamespaceFunctionIterator()
destroys the object
DLLEXPORT void setClassHandler(q_ns_class_handler_t class_handler)
sets the namespace class handler
allows classes in a namespace to be iterated
Definition: QoreNamespace.h:475
DLLEXPORT const QoreExternalFunction & get() const
returns the function
allows local namespaces to be iterated
Definition: QoreNamespace.h:394
virtual DLLEXPORT ~QoreNamespaceNamespaceIterator()
destroys the object
DLLEXPORT const QoreExternalGlobalVar & get() const
returns the global variable
DLLEXPORT void addNamespace(QoreNamespace *ns)
adds a namespace to the namespace tree
virtual DLLEXPORT ~QoreNamespaceConstantIterator()
destroys the object
virtual DLLEXPORT ~QoreNamespaceGlobalVarIterator()
destroys the object
allows global variables in a namespace to be iterated
Definition: QoreNamespace.h:502
DLLEXPORT bool isModulePublic() const
returns true if the namespace has its module public flag set
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...
static unsigned num_params(const QoreListNode *n)
returns the number of arguments passed to the function
Definition: params.h:54
DLLEXPORT const QoreNamespace & get() const
returns the namespace
DLLEXPORT const TypedHashDecl & get() const
returns the typed hash (hashdecl)
DLLEXPORT void addInitialNamespace(QoreNamespace *ns)
adds a subnamespace to the namespace
allows constants in a namespace to be iterated
Definition: QoreNamespace.h:448
DLLEXPORT bool isImported() const
returns true if the namespace was imported from another program object
DLLEXPORT QoreNamespace * findCreateNamespacePath(const char *nspath)
finds a Namespace based on the argument; creates it (or the whole path) if necessary
the root namespace of a QoreProgram object
Definition: QoreNamespace.h:286
allows all namespaces of a namespace to be iterated (including the namespace passed in the constructo...
Definition: QoreNamespace.h:320
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT void clear(ExceptionSink *xsink)
clears the contents of the namespace before deleting
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT QoreNamespace(const char *n)
creates a namespace with the given name
DLLEXPORT bool next()
moves to the next position; returns true if on a valid position
DLLEXPORT void addSystemClass(QoreClass *oc)
adds a class to a namespace