dataArg.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378
  1. /*
  2. * This file is part of the PikaPython project.
  3. * http://github.com/pikastech/pikapython
  4. *
  5. * MIT License
  6. *
  7. * Copyright (c) 2021 lyon liang6516@outlook.com
  8. *
  9. * Permission is hereby granted, free of charge, to any person obtaining a
  10. * copy of this software and associated documentation files (the
  11. * "Software"), to deal in the Software without restriction, including
  12. * without limitation the rights to use, copy, modify, merge, publish,
  13. * distribute, sublicense, and/or sell copies of the Software, and to
  14. * permit persons to whom the Software is furnished to do so, subject to
  15. * the following conditions:
  16. *
  17. * The above copyright notice and this permission notice shall be included
  18. * in all copies or substantial portions of the Software.
  19. *
  20. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
  21. * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  22. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
  23. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
  24. * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
  25. * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
  26. * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  27. */
  28. #ifdef __cplusplus
  29. extern "C" {
  30. #endif
  31. #ifndef _arg__H
  32. #define _arg__H
  33. #include "dataLink.h"
  34. #include "dataMemory.h"
  35. typedef uint32_t Hash;
  36. typedef enum {
  37. ARG_TYPE_UNDEF = 0,
  38. ARG_TYPE_NONE,
  39. ARG_TYPE_INT,
  40. ARG_TYPE_BOOL,
  41. ARG_TYPE_FLOAT,
  42. ARG_TYPE_STRING,
  43. ARG_TYPE_BYTES,
  44. ARG_TYPE_POINTER,
  45. ARG_TYPE_BIG_ARG_PTR,
  46. ARG_TYPE_OBJECT,
  47. ARG_TYPE_OBJECT_WEAK,
  48. ARG_TYPE_OBJECT_META,
  49. ARG_TYPE_OBJECT_NEW,
  50. ARG_TYPE_METHOD_NATIVE,
  51. ARG_TYPE_METHOD_NATIVE_ACTIVE,
  52. ARG_TYPE_METHOD_NATIVE_CONSTRUCTOR,
  53. ARG_TYPE_METHOD_CONSTRUCTOR,
  54. ARG_TYPE_METHOD_OBJECT,
  55. ARG_TYPE_METHOD_STATIC,
  56. ARG_TYPE_STRUCT,
  57. ARG_TYPE_STRUCT_HEAP,
  58. ARG_TYPE_TUPLE,
  59. } ArgType;
  60. typedef void (*StructDeinitFun)(void* struct_);
  61. typedef struct PikaObj PikaObj;
  62. typedef struct Arg Arg;
  63. typedef union {
  64. Arg* next;
  65. uint8_t* buffer;
  66. } _arg_union;
  67. typedef union {
  68. int64_t int_;
  69. pika_bool bool_;
  70. pika_float float_;
  71. PikaObj* obj;
  72. void* ptr;
  73. } _arg_value;
  74. struct Arg {
  75. _arg_union _;
  76. uint32_t size;
  77. #if PIKA_ARG_CACHE_ENABLE
  78. uint32_t heap_size;
  79. #endif
  80. ArgType type;
  81. uint8_t flag;
  82. Hash name_hash;
  83. #if PIKA_KERNAL_DEBUG_ENABLE
  84. char* name;
  85. _arg_value* value;
  86. char* str;
  87. uint8_t* bytes;
  88. char _name_buff[PIKA_NAME_BUFF_SIZE];
  89. #endif
  90. uint8_t content[];
  91. };
  92. typedef struct ConstArg {
  93. _arg_union _;
  94. uint32_t size;
  95. #if PIKA_ARG_CACHE_ENABLE
  96. uint32_t heap_size;
  97. #endif
  98. ArgType type;
  99. uint8_t flag;
  100. Hash name_hash;
  101. #if PIKA_KERNAL_DEBUG_ENABLE
  102. char* name;
  103. _arg_value* value;
  104. char* str;
  105. uint8_t* bytes;
  106. char _name_buff[PIKA_NAME_BUFF_SIZE];
  107. #endif
  108. } ConstArg;
  109. uint32_t arg_totleSize(Arg* self);
  110. uint32_t arg_getTotleSize(Arg* self);
  111. void arg_freeContent(Arg* self);
  112. Arg* arg_setName(Arg* self, char* name);
  113. Arg* arg_setNameHash(Arg* self, Hash nameHash);
  114. Arg* arg_setContent(Arg* self, uint8_t* content, uint32_t size);
  115. Arg* arg_newContent(uint32_t size);
  116. void arg_refcntInc(Arg* self);
  117. void arg_refcntDec(Arg* self);
  118. static inline void arg_setType(Arg* self, ArgType type) {
  119. self->type = type;
  120. }
  121. static inline Hash arg_getNameHash(Arg* self) {
  122. pika_assert(self != NULL);
  123. return self->name_hash;
  124. }
  125. static inline ArgType arg_getType(Arg* self) {
  126. pika_assert(self != 0);
  127. return (ArgType)self->type;
  128. }
  129. uint32_t arg_getContentSize(Arg* self);
  130. Hash hash_time33(char* str);
  131. Arg* arg_setInt(Arg* self, char* name, int64_t val);
  132. Arg* arg_setBool(Arg* self, char* name, pika_bool val);
  133. Arg* arg_setFloat(Arg* self, char* name, pika_float val);
  134. Arg* arg_setPtr(Arg* self, char* name, ArgType type, void* pointer);
  135. Arg* arg_setStr(Arg* self, char* name, char* string);
  136. Arg* arg_setStrN(Arg* self, char* name, char* string, size_t len);
  137. Arg* arg_setNone(Arg* self);
  138. Arg* arg_setBytes(Arg* self, char* name, uint8_t* src, size_t size);
  139. static inline Arg* arg_newInt(int64_t val) {
  140. return arg_setInt(NULL, (char*)"", (val));
  141. }
  142. static inline Arg* arg_newBool(pika_bool val) {
  143. return arg_setBool(NULL, (char*)"", (val));
  144. }
  145. static inline Arg* arg_newFloat(pika_float val) {
  146. return arg_setFloat(NULL, (char*)"", (val));
  147. }
  148. static inline Arg* arg_newPtr(ArgType type, void* pointer) {
  149. return arg_setPtr(NULL, (char*)"", (type), (pointer));
  150. }
  151. static inline Arg* arg_newStr(char* string) {
  152. return arg_setStr(NULL, (char*)"", (string));
  153. }
  154. static inline Arg* arg_newStrN(char* string, size_t size) {
  155. return arg_setStrN(NULL, (char*)"", (string), size);
  156. }
  157. static inline Arg* arg_newNone() {
  158. return arg_setNone(NULL);
  159. }
  160. static inline Arg* arg_newBytes(uint8_t* src, size_t size) {
  161. return arg_setBytes(NULL, (char*)"", (src), (size));
  162. }
  163. int64_t arg_getInt(Arg* self);
  164. pika_bool arg_getBool(Arg* self);
  165. pika_float arg_getFloat(Arg* self);
  166. void* arg_getPtr(Arg* self);
  167. char* arg_getStr(Arg* self);
  168. uint8_t* arg_getBytes(Arg* self);
  169. size_t arg_getBytesSize(Arg* self);
  170. Arg* arg_copy(Arg* argToBeCopy);
  171. Arg* arg_copy_noalloc(Arg* argToBeCopy, Arg* argToBeCopyTo);
  172. Arg* arg_copy_content(Arg* arg_dict, Arg* arg_src);
  173. void arg_deinit(Arg* self);
  174. Arg* New_arg(void* voidPointer);
  175. Arg* arg_append(Arg* arg_in, void* new_content, size_t new_size);
  176. Arg* arg_setStruct(Arg* self,
  177. char* name,
  178. void* struct_ptr,
  179. uint32_t struct_size);
  180. Arg* arg_setHeapStruct(Arg* self,
  181. char* name,
  182. void* struct_ptr,
  183. uint32_t struct_size,
  184. void* struct_deinit_fun);
  185. void* arg_getHeapStruct(Arg* self);
  186. void arg_deinitHeap(Arg* self);
  187. Arg* arg_toStrArg(Arg* arg);
  188. void arg_print(Arg* self, pika_bool in_REPL, char* end);
  189. Arg* arg_loadFile(Arg* self, char* filename);
  190. #define ARG_FLAG_SERIALIZED 0x01
  191. #define ARG_FLAG_KEYWORD 0x02
  192. #define ARG_FLAG_WEAK_REF 0x04
  193. #define ARG_FLAG_STARRED 0x08
  194. #define ARG_FLAG_DOUBLE_STARRED 0x10
  195. #define ARG_FLAG_MAX 0x18
  196. static inline Arg* arg_getNext(Arg* self) {
  197. return self->_.next;
  198. }
  199. static inline void arg_setNext(Arg* self, Arg* next) {
  200. pika_assert(NULL != self);
  201. self->_.next = next;
  202. }
  203. static inline uint32_t arg_getSize(Arg* self) {
  204. pika_assert(NULL != self);
  205. return self->size;
  206. }
  207. static inline uint8_t arg_isSerialized(Arg* self) {
  208. pika_assert(NULL != self);
  209. pika_assert(self->flag <= ARG_FLAG_MAX);
  210. return self->flag & ARG_FLAG_SERIALIZED;
  211. }
  212. static inline void arg_setSerialized(Arg* self, uint8_t serialized) {
  213. self->flag = (self->flag & ~ARG_FLAG_SERIALIZED) |
  214. (serialized ? ARG_FLAG_SERIALIZED : 0);
  215. }
  216. static inline uint8_t arg_getIsKeyword(Arg* self) {
  217. pika_assert(self->flag <= ARG_FLAG_MAX);
  218. return self->flag & ARG_FLAG_KEYWORD;
  219. }
  220. static inline void arg_setIsKeyword(Arg* self, uint8_t isKeyword) {
  221. self->flag =
  222. (self->flag & ~ARG_FLAG_KEYWORD) | (isKeyword ? ARG_FLAG_KEYWORD : 0);
  223. }
  224. static inline uint8_t arg_getIsWeakRef(Arg* self) {
  225. pika_assert(self->flag <= ARG_FLAG_MAX);
  226. return self->flag & ARG_FLAG_WEAK_REF;
  227. }
  228. static inline void arg_setIsWeakRef(Arg* self, uint8_t isWeakRef) {
  229. pika_assert(NULL != self);
  230. self->flag =
  231. (self->flag & ~ARG_FLAG_WEAK_REF) | (isWeakRef ? ARG_FLAG_WEAK_REF : 0);
  232. }
  233. static inline void arg_setIsStarred(Arg* self, uint8_t isStarred) {
  234. self->flag =
  235. (self->flag & ~ARG_FLAG_STARRED) | (isStarred ? ARG_FLAG_STARRED : 0);
  236. }
  237. static inline uint8_t arg_getIsStarred(Arg* self) {
  238. pika_assert(self->flag <= ARG_FLAG_MAX);
  239. return self->flag & ARG_FLAG_STARRED;
  240. }
  241. static inline void arg_setIsDoubleStarred(Arg* self, uint8_t isDoubleStarred) {
  242. self->flag = (self->flag & ~ARG_FLAG_DOUBLE_STARRED) |
  243. (isDoubleStarred ? ARG_FLAG_DOUBLE_STARRED : 0);
  244. }
  245. static inline uint8_t arg_getIsDoubleStarred(Arg* self) {
  246. pika_assert(self->flag <= ARG_FLAG_MAX);
  247. return self->flag & ARG_FLAG_DOUBLE_STARRED;
  248. }
  249. static inline uint8_t* arg_getContent(Arg* self) {
  250. pika_assert(NULL != self);
  251. pika_assert(self->flag <= ARG_FLAG_MAX);
  252. return (arg_isSerialized(self)) ? (self)->content : ((self)->_.buffer);
  253. }
  254. static inline uint8_t argType_isObject(ArgType type) {
  255. return ((type) == ARG_TYPE_OBJECT || (type) == ARG_TYPE_OBJECT_NEW ||
  256. (type) == ARG_TYPE_OBJECT_WEAK);
  257. }
  258. static inline uint8_t argType_isCallable(ArgType type) {
  259. return ((type) == ARG_TYPE_METHOD_CONSTRUCTOR ||
  260. (type) == ARG_TYPE_METHOD_OBJECT ||
  261. (type) == ARG_TYPE_METHOD_STATIC ||
  262. (type) == ARG_TYPE_METHOD_NATIVE ||
  263. (type) == ARG_TYPE_METHOD_NATIVE_CONSTRUCTOR ||
  264. (type) == ARG_TYPE_METHOD_NATIVE_ACTIVE);
  265. }
  266. static inline uint8_t argType_isObjectMethod(ArgType type) {
  267. return ((type) == ARG_TYPE_METHOD_OBJECT ||
  268. (type) == ARG_TYPE_METHOD_NATIVE);
  269. }
  270. static inline uint8_t argType_isObjectMethodActive(ArgType type) {
  271. return ((type) == ARG_TYPE_METHOD_OBJECT ||
  272. (type) == ARG_TYPE_METHOD_NATIVE_ACTIVE);
  273. }
  274. static inline uint8_t argType_isConstructor(ArgType type) {
  275. return ((type) == ARG_TYPE_METHOD_CONSTRUCTOR ||
  276. (type) == ARG_TYPE_METHOD_NATIVE_CONSTRUCTOR);
  277. }
  278. static inline uint8_t argType_isNative(ArgType type) {
  279. return ((type) == ARG_TYPE_METHOD_NATIVE ||
  280. (type) == ARG_TYPE_METHOD_NATIVE_CONSTRUCTOR ||
  281. (type) == ARG_TYPE_METHOD_NATIVE_ACTIVE);
  282. }
  283. static inline uint8_t _argType_or(ArgType type, ArgType type1, ArgType type2) {
  284. return ((type) == (type1) || (type) == (type2));
  285. }
  286. static inline uint8_t argType_isEqual(ArgType type1, ArgType type2) {
  287. if (type1 == type2) {
  288. return 1;
  289. }
  290. if (_argType_or(type1, ARG_TYPE_METHOD_NATIVE,
  291. ARG_TYPE_METHOD_NATIVE_ACTIVE) &&
  292. _argType_or(type2, ARG_TYPE_METHOD_NATIVE,
  293. ARG_TYPE_METHOD_NATIVE_ACTIVE)) {
  294. return 1;
  295. }
  296. return 0;
  297. }
  298. static inline uint8_t argType_isIterable(ArgType type) {
  299. return ((type) == ARG_TYPE_STRING || (type) == ARG_TYPE_BYTES ||
  300. argType_isObject(type));
  301. }
  302. #define arg_isObject(__self) \
  303. ((__self != NULL) && (argType_isObject(arg_getType(__self))))
  304. #define arg_isCallable(__self) \
  305. ((__self != NULL) && (argType_isCallable(arg_getType(__self))))
  306. #define arg_isConstructor(__self) \
  307. ((__self != NULL) && (argType_isConstructor(arg_getType(__self))))
  308. #define arg_isNative(__self) \
  309. ((__self != NULL) && (argType_isNative(arg_getType(__self))))
  310. #define arg_isIterable(__self) \
  311. ((__self != NULL) && (argType_isIterable(arg_getType(__self))))
  312. #define arg_newReg(__name, __size) \
  313. Arg __name = {0}; \
  314. uint8_t __##__name##_buff[__size] = {0}; \
  315. arg_init_stack(&__name, __##__name##_buff, __size)
  316. void arg_init_stack(Arg* self, uint8_t* buffer, uint32_t size);
  317. pika_bool arg_isEqual(Arg* self, Arg* other);
  318. Hash hash_time33EndWith(char* str, char end);
  319. #endif
  320. #ifdef __cplusplus
  321. }
  322. #endif