Qore Programming Language 1.19.2
Loading...
Searching...
No Matches
TypedHashDecl.h
1/* -*- mode: c++; indent-tabs-mode: nil -*- */
2/*
3 TypedHashDecl.h
4
5 Qore Programming Language
6
7 Copyright (C) 2003 - 2023 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#ifndef _QORE_TYPEDHASHDECL_H
33
34#define _QORE_TYPEDHASHDECL_H
35
36// forward references
37class typed_hash_decl_private;
40
42
45 friend class typed_hash_decl_private;
46
47public:
48 DLLEXPORT TypedHashDecl(const char* name, const char* path);
49
50 DLLEXPORT TypedHashDecl(const TypedHashDecl& old);
51
53 DLLEXPORT const QoreTypeInfo* getTypeInfo(bool or_nothing = false) const;
54
56 DLLEXPORT void addMember(const char* name, const QoreTypeInfo* memberTypeInfo, QoreValue init_val);
57
59 DLLEXPORT const char* getName() const;
60
62 DLLEXPORT bool isSystem() const;
63
65
67 DLLEXPORT bool isPublic() const;
68
70
72 DLLEXPORT const QoreExternalMemberBase* findLocalMember(const char* name) const;
73
75
78
80
84 DLLEXPORT std::string getNamespacePath(bool anchored = false) const;
85
87
90 DLLEXPORT bool equal(const TypedHashDecl* other) const;
91
93
95 DLLEXPORT const char* getModuleName() const;
96
98
100 DLLEXPORT const QoreNamespace* getNamespace() const;
101
103
108 DLLEXPORT QoreHashNode* doRuntimeCast(const QoreHashNode* h, ExceptionSink* xsink) const;
109
110protected:
112 DLLEXPORT ~TypedHashDecl();
113
114private:
115 DLLEXPORT TypedHashDecl(typed_hash_decl_private* p);
116
117 typed_hash_decl_private* priv;
118};
119
121
124public:
126 DLLLOCAL TypedHashDeclHolder(TypedHashDecl* thd) : thd(thd) {
127 }
128
131
133 DLLLOCAL TypedHashDecl* operator*() const {
134 return thd;
135 }
136
138 DLLLOCAL TypedHashDecl* operator->() const {
139 return thd;
140 }
141
144
146 DLLLOCAL TypedHashDecl* release() {
147 auto rv = thd;
148 thd = nullptr;
149 return rv;
150 }
151
152private:
154 TypedHashDecl* thd;
155};
156
159public:
160 DLLEXPORT TypedHashDeclMemberIterator(const TypedHashDecl& thd);
161
163
164 DLLEXPORT bool next();
165
166 DLLEXPORT const QoreExternalMemberBase& getMember() const;
167
168 DLLEXPORT const char* getName() const;
169
170private:
171 class typed_hash_decl_member_iterator* priv;
172};
173
175DLLEXPORT extern const TypedHashDecl* hashdeclStatInfo;
176
178DLLEXPORT extern const TypedHashDecl* hashdeclDirStatInfo;
179
181DLLEXPORT extern const TypedHashDecl* hashdeclFilesystemInfo;
182
184DLLEXPORT extern const TypedHashDecl* hashdeclDateTimeInfo;
185
187DLLEXPORT extern const TypedHashDecl* hashdeclIsoWeekInfo;
188
190DLLEXPORT extern const TypedHashDecl* hashdeclCallStackInfo;
191
193DLLEXPORT extern const TypedHashDecl* hashdeclExceptionInfo;
194
196DLLEXPORT extern const TypedHashDecl* hashdeclStatementInfo;
197
199DLLEXPORT extern const TypedHashDecl* hashdeclNetIfInfo;
200
202DLLEXPORT extern const TypedHashDecl* hashdeclSourceLocationInfo;
203
205
207DLLEXPORT extern const TypedHashDecl* hashdeclSerializationInfo;
208
210
212DLLEXPORT extern const TypedHashDecl* hashdeclObjectSerializationInfo;
213
215
217DLLEXPORT extern const TypedHashDecl* hashdeclIndexedObjectSerializationInfo;
218
220
222DLLEXPORT extern const TypedHashDecl* hashdeclHashSerializationInfo;
223
225
227DLLEXPORT extern const TypedHashDecl* hashdeclListSerializationInfo;
228
230
232DLLEXPORT extern const TypedHashDecl* hashdeclUrlInfo;
233
235
237DLLEXPORT extern const TypedHashDecl* hashdeclFtpResponseInfo;
238
240
242DLLEXPORT extern const TypedHashDecl* hashdeclSocketPollInfo;
243
245
247DLLEXPORT extern const TypedHashDecl* hashdeclPipeInfo;
248
249#endif
container for holding Qore-language exception information and also for registering a "thread_exit" ca...
Definition: ExceptionSink.h:50
external wrapper base class for class and hashdecl members
Definition: QoreReflection.h:118
external wrapper class for source code location information
Definition: QoreReflection.h:187
This is the hash or associative list container type in Qore, dynamically allocated only,...
Definition: QoreHashNode.h:50
contains constants, classes, and subnamespaces in QoreProgram objects
Definition: QoreNamespace.h:65
allows for temporary storage of a TypedHashDecl pointer
Definition: TypedHashDecl.h:123
DLLLOCAL TypedHashDecl * operator->() const
implicit conversion to TypedHashDecl*
Definition: TypedHashDecl.h:138
DLLLOCAL TypedHashDecl * operator*() const
implicit conversion to TypedHashDecl*
Definition: TypedHashDecl.h:133
DLLLOCAL TypedHashDecl * operator=(TypedHashDecl *nhd)
assign new TypedHashDecl value; any managed object is deleted if still managed
DLLEXPORT ~TypedHashDeclHolder()
deletes the TypedHashDecl object if still managed
DLLLOCAL TypedHashDeclHolder(TypedHashDecl *thd)
creates the object
Definition: TypedHashDecl.h:126
DLLLOCAL TypedHashDecl * release()
releases the TypedHashDecl*
Definition: TypedHashDecl.h:146
typed hash declaration
Definition: TypedHashDecl.h:44
DLLEXPORT const char * getName() const
returns the name of the typed hash
DLLEXPORT const QoreExternalProgramLocation * getSourceLocation() const
returns the source location of the typed hash (hashdecl) definition
DLLEXPORT bool equal(const TypedHashDecl *other) const
returns true if the hashdecl passed as an arugment is equal to this hashdecl
DLLEXPORT std::string getNamespacePath(bool anchored=false) const
returns the full namespace path of the class
DLLEXPORT const QoreExternalMemberBase * findLocalMember(const char *name) const
Finds the given local member or returns nullptr.
DLLEXPORT ~TypedHashDecl()
deletes the object and frees all memory
DLLEXPORT bool isPublic() const
returns true if the typed hash has the public (export) flag set
DLLEXPORT const QoreTypeInfo * getTypeInfo(bool or_nothing=false) const
returns the type info object for the hashdecl
DLLEXPORT const QoreNamespace * getNamespace() const
Returns the namespace owning the typed hash declaration.
DLLEXPORT void addMember(const char *name, const QoreTypeInfo *memberTypeInfo, QoreValue init_val)
adds an element to a built-in hashdecl
DLLEXPORT bool isSystem() const
returns true if the typed hash is a builtin typed hash
DLLEXPORT QoreHashNode * doRuntimeCast(const QoreHashNode *h, ExceptionSink *xsink) const
Performs a runtime cast and returns a typed hash if the has passed is compatible.
DLLEXPORT const char * getModuleName() const
Returns the module name the class was loaded from or nullptr if it is a builtin class.
Allows iteration of a hashdecl's members.
Definition: TypedHashDecl.h:158
The main value class in Qore, designed to be passed by value.
Definition: QoreValue.h:276