dataArg.c 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671
  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 copy
  10. * of this software and associated documentation files (the "Software"), to deal
  11. * in the Software without restriction, including without limitation the rights
  12. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  13. * copies of the Software, and to permit persons to whom the Software is
  14. * 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 FROM,
  24. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  25. * SOFTWARE.
  26. */
  27. #include "dataArg.h"
  28. #include "PikaObj.h"
  29. #include "dataArgs.h"
  30. #include "dataMemory.h"
  31. #include "dataString.h"
  32. #include "stdlib.h"
  33. static PIKA_BOOL _arg_cache_push(Arg* self, uint32_t size) {
  34. #if !PIKA_ARG_CACHE_ENABLE
  35. return PIKA_FALSE;
  36. #else
  37. if (PIKA_FALSE == pika_hook_arg_cache_filter(self)) {
  38. return PIKA_FALSE;
  39. }
  40. extern PikaMemInfo g_PikaMemInfo;
  41. if (self->heap_size < PIKA_ARG_CACHE_SIZE ||
  42. self->heap_size > 2 * PIKA_ARG_CACHE_SIZE) {
  43. return PIKA_FALSE;
  44. }
  45. if (PIKA_ARG_CACHE_POOL_SIZE <= g_PikaMemInfo.cache_pool_top) {
  46. return PIKA_FALSE;
  47. }
  48. g_PikaMemInfo.cache_pool[g_PikaMemInfo.cache_pool_top++] = (uint8_t*)self;
  49. g_PikaMemInfo.heapUsed -= mem_align(sizeof(Arg) + size);
  50. return PIKA_TRUE;
  51. #endif
  52. }
  53. static Arg* _arg_cache_pop(uint32_t size) {
  54. #if !PIKA_ARG_CACHE_ENABLE
  55. return NULL;
  56. #else
  57. uint32_t req_heap_size = mem_align(sizeof(Arg) + size);
  58. extern PikaMemInfo g_PikaMemInfo;
  59. if (req_heap_size > PIKA_ARG_CACHE_SIZE) {
  60. return NULL;
  61. }
  62. if (!(g_PikaMemInfo.cache_pool_top > 0)) {
  63. return NULL;
  64. }
  65. --g_PikaMemInfo.cache_pool_top;
  66. Arg* self = (Arg*)g_PikaMemInfo.cache_pool[g_PikaMemInfo.cache_pool_top];
  67. g_PikaMemInfo.heapUsed += mem_align(sizeof(Arg) + size);
  68. return self;
  69. #endif
  70. }
  71. uint32_t arg_getTotleSize(Arg* self) {
  72. return arg_totleSize(self);
  73. }
  74. /**
  75. * time33 hash
  76. */
  77. Hash hash_time33EndWith(char* str, char end) {
  78. pika_assert(str != NULL);
  79. if (*str == 0) {
  80. return 5381;
  81. }
  82. Hash hash = 5381;
  83. while (*str && *str != end) {
  84. hash += (hash << 5) + (*str++);
  85. }
  86. return (hash & 0x7FFFFFFF);
  87. }
  88. Hash hash_time33(char* str) {
  89. pika_assert(str != NULL);
  90. if (*str == 0) {
  91. return 5381;
  92. }
  93. Hash hash = 5381;
  94. while (*str) {
  95. hash += (hash << 5) + (*str++);
  96. }
  97. return (hash & 0x7FFFFFFF);
  98. }
  99. static Arg* _arg_set_hash(Arg* self,
  100. Hash nameHash,
  101. ArgType type,
  102. uint8_t* content,
  103. uint32_t size,
  104. Arg* next) {
  105. /* create arg if not exist */
  106. if (NULL == self || self->size < size) {
  107. self = _arg_cache_pop(size);
  108. uint32_t heap_size = sizeof(Arg) + size;
  109. #if PIKA_ARG_CACHE_ENABLE
  110. // if (heap_size < PIKA_ARG_CACHE_SIZE) {
  111. // heap_size = PIKA_ARG_CACHE_SIZE;
  112. // }
  113. extern PikaMemInfo g_PikaMemInfo;
  114. g_PikaMemInfo.alloc_times++;
  115. g_PikaMemInfo.alloc_times_cache++;
  116. #endif
  117. if (NULL == self) {
  118. self = (Arg*)pikaMalloc(heap_size);
  119. #if PIKA_ARG_CACHE_ENABLE
  120. extern PikaMemInfo g_PikaMemInfo;
  121. g_PikaMemInfo.alloc_times_cache--;
  122. self->heap_size = mem_align(heap_size);
  123. #endif
  124. }
  125. self->size = size;
  126. self->flag = 0;
  127. arg_setSerialized(self, PIKA_TRUE);
  128. // arg_setIsKeyword(self, PIKA_FALSE);
  129. arg_setNext(self, next);
  130. }
  131. self->name_hash = nameHash;
  132. self->type = type;
  133. if (NULL != content) {
  134. pika_platform_memcpy(arg_getContent(self), content, size);
  135. } else {
  136. pika_platform_memset(arg_getContent(self), 0,
  137. align_by(size, sizeof(uint32_t)));
  138. }
  139. pika_assert(self->flag < ARG_FLAG_MAX);
  140. return self;
  141. }
  142. static Arg* arg_create_hash(Hash nameHash,
  143. ArgType type,
  144. uint8_t* content,
  145. uint32_t size,
  146. Arg* next) {
  147. return _arg_set_hash(NULL, nameHash, type, content, size, next);
  148. }
  149. static Arg* arg_create(char* name,
  150. ArgType type,
  151. uint8_t* content,
  152. uint32_t size,
  153. Arg* next) {
  154. Hash nameHash = hash_time33(name);
  155. return arg_create_hash(nameHash, type, content, size, next);
  156. }
  157. static Arg* arg_set(Arg* self,
  158. char* name,
  159. ArgType type,
  160. uint8_t* content,
  161. uint32_t size) {
  162. Hash nameHash = hash_time33(name);
  163. return _arg_set_hash(self, nameHash, type, content, size, NULL);
  164. }
  165. void arg_init_stack(Arg* self, uint8_t* buffer, uint32_t size) {
  166. self->_.buffer = buffer;
  167. self->size = size;
  168. }
  169. uint32_t arg_totleSize(Arg* self) {
  170. return ((Arg*)self)->size + sizeof(Arg);
  171. }
  172. void arg_freeContent(Arg* self) {
  173. pika_assert(NULL != self);
  174. if (_arg_cache_push(self, self->size)) {
  175. return;
  176. }
  177. pikaFree(self, arg_totleSize(self));
  178. return;
  179. }
  180. Arg* arg_setContent(Arg* self, uint8_t* content, uint32_t size) {
  181. if (NULL == self) {
  182. /* malloc */
  183. return arg_create("", ARG_TYPE_NONE, content, size, NULL);
  184. }
  185. /* only copy */
  186. if (arg_getSize(self) >= size) {
  187. pika_platform_memcpy(arg_getContent((Arg*)self), content, size);
  188. return self;
  189. }
  190. /* realloc */
  191. Hash nameHash = arg_getNameHash(self);
  192. ArgType type = arg_getType(self);
  193. Arg* next = arg_getNext(self);
  194. Arg* newContent = arg_create_hash(nameHash, type, content, size, next);
  195. arg_freeContent(self);
  196. return newContent;
  197. }
  198. Arg* arg_setNameHash(Arg* self, Hash nameHash) {
  199. if (NULL == self) {
  200. return arg_create_hash(nameHash, ARG_TYPE_NONE, NULL, 0, NULL);
  201. }
  202. Arg* arg = (Arg*)self;
  203. arg->name_hash = nameHash;
  204. return self;
  205. }
  206. Arg* arg_setName(Arg* self, char* name) {
  207. pika_assert(NULL != name);
  208. return arg_setNameHash(self, hash_time33(name));
  209. }
  210. Arg* arg_setBytes(Arg* self, char* name, uint8_t* src, size_t size) {
  211. self = arg_newContent(size + sizeof(size_t) + 1);
  212. if (NULL == self) {
  213. return NULL;
  214. }
  215. self = arg_setName(self, name);
  216. pika_assert(NULL != self);
  217. arg_setType(self, ARG_TYPE_BYTES);
  218. void* dir = arg_getContent(self);
  219. /* set content all to 0 */
  220. pika_platform_memset(dir, 0, size + sizeof(size_t) + 1);
  221. /* setsize */
  222. pika_platform_memcpy(dir, &size, sizeof(size_t));
  223. /* set init value */
  224. if (NULL != src) {
  225. pika_platform_memcpy((void*)((uintptr_t)dir + sizeof(size_t)), src,
  226. size);
  227. }
  228. pika_assert(self->flag < ARG_FLAG_MAX);
  229. return self;
  230. }
  231. Arg* arg_newContent(uint32_t size) {
  232. Arg* newContent = arg_create("", ARG_TYPE_NONE, NULL, size, NULL);
  233. return newContent;
  234. }
  235. uint8_t* arg_getBytes(Arg* self) {
  236. return arg_getContent(self) + sizeof(size_t);
  237. }
  238. Arg* arg_toStrArg(Arg* arg) {
  239. ArgType type = arg_getType(arg);
  240. char buff[PIKA_SPRINTF_BUFF_SIZE] = {0};
  241. if (type == ARG_TYPE_BYTES) {
  242. char buff_item[16] = {0};
  243. size_t bytes_size = arg_getBytesSize(arg);
  244. uint8_t* bytes = arg_getBytes(arg);
  245. Arg* str_arg = arg_newStr("b\'");
  246. for (size_t i = 0; i < bytes_size; i++) {
  247. pika_platform_snprintf(buff_item, 16, "\\x%02x", bytes[i]);
  248. char* str_item = (char*)buff_item;
  249. str_arg = arg_strAppend(str_arg, str_item);
  250. }
  251. str_arg = arg_strAppend(str_arg, "\'");
  252. return str_arg;
  253. }
  254. if (type == ARG_TYPE_INT) {
  255. #if PIKA_PRINT_LLD_ENABLE
  256. pika_platform_snprintf(buff, PIKA_SPRINTF_BUFF_SIZE, "%lld",
  257. (long long int)arg_getInt(arg));
  258. #else
  259. pika_platform_snprintf(buff, PIKA_SPRINTF_BUFF_SIZE, "%d",
  260. (int)arg_getInt(arg));
  261. #endif
  262. return arg_newStr(buff);
  263. }
  264. if (type == ARG_TYPE_BOOL) {
  265. if (arg_getBool(arg)) {
  266. return arg_newStr("True");
  267. }
  268. return arg_newStr("False");
  269. }
  270. if (type == ARG_TYPE_FLOAT) {
  271. pika_platform_snprintf(buff, PIKA_SPRINTF_BUFF_SIZE, "%f",
  272. arg_getFloat(arg));
  273. return arg_newStr(buff);
  274. }
  275. if (type == ARG_TYPE_STRING) {
  276. return arg_newStr(arg_getStr(arg));
  277. }
  278. if (type == ARG_TYPE_POINTER) {
  279. pika_platform_snprintf(buff, PIKA_SPRINTF_BUFF_SIZE, "%p",
  280. arg_getPtr(arg));
  281. return arg_newStr(buff);
  282. }
  283. if (argType_isCallable(type)) {
  284. /* support basic type */
  285. if (type == ARG_TYPE_METHOD_NATIVE) {
  286. MethodProp* method_store = (MethodProp*)arg_getContent(arg);
  287. if (strEqu(method_store->name, "int") ||
  288. strEqu(method_store->name, "bool") ||
  289. strEqu(method_store->name, "float") ||
  290. strEqu(method_store->name, "str") ||
  291. strEqu(method_store->name, "bytes") ||
  292. strEqu(method_store->name, "list") ||
  293. strEqu(method_store->name, "dict") ||
  294. strEqu(method_store->name, "tuple")) {
  295. pika_platform_snprintf(buff, PIKA_SPRINTF_BUFF_SIZE,
  296. "<class '%s'>", method_store->name);
  297. return arg_newStr(buff);
  298. }
  299. pika_platform_snprintf(buff, PIKA_SPRINTF_BUFF_SIZE,
  300. "<built-in function %s>",
  301. method_store->name);
  302. return arg_newStr(buff);
  303. }
  304. if (argType_isConstructor(type)) {
  305. pika_platform_snprintf(buff, PIKA_SPRINTF_BUFF_SIZE,
  306. "<class 'object'>");
  307. return arg_newStr(buff);
  308. }
  309. pika_platform_snprintf(buff, PIKA_SPRINTF_BUFF_SIZE,
  310. "<class 'function'>");
  311. return arg_newStr(buff);
  312. }
  313. if (type == ARG_TYPE_NONE) {
  314. return arg_newStr("None");
  315. }
  316. if (argType_isObject(type)) {
  317. return arg_newStr(obj_toStr(arg_getPtr(arg)));
  318. }
  319. if (type == ARG_TYPE_OBJECT_META) {
  320. pika_platform_snprintf(buff, PIKA_SPRINTF_BUFF_SIZE,
  321. "<meta object at %p>", arg_getPtr(arg));
  322. return arg_newStr(buff);
  323. }
  324. return NULL;
  325. }
  326. void arg_print(Arg* self, PIKA_BOOL in_REPL, char* end) {
  327. /* use arg_toStrArg() */
  328. Arg* str_arg = arg_toStrArg(self);
  329. if (NULL == str_arg) {
  330. return;
  331. }
  332. if (in_REPL && arg_getType(self) == ARG_TYPE_STRING) {
  333. pika_platform_printf("'%s'%s", arg_getStr(str_arg), end);
  334. } else {
  335. pika_platform_printf("%s%s", arg_getStr(str_arg), end);
  336. }
  337. arg_deinit(str_arg);
  338. return;
  339. }
  340. size_t arg_getBytesSize(Arg* self) {
  341. size_t mem_size = 0;
  342. void* content = (void*)arg_getContent(self);
  343. if (NULL == content) {
  344. return 0;
  345. }
  346. pika_platform_memcpy(&mem_size, content, sizeof(size_t));
  347. return mem_size;
  348. }
  349. Arg* arg_setStruct(Arg* self,
  350. char* name,
  351. void* struct_ptr,
  352. uint32_t struct_size) {
  353. if (NULL == struct_ptr) {
  354. return NULL;
  355. }
  356. return arg_set(self, name, ARG_TYPE_STRUCT, (uint8_t*)struct_ptr,
  357. struct_size);
  358. }
  359. Arg* arg_setHeapStruct(Arg* self,
  360. char* name,
  361. void* struct_ptr,
  362. uint32_t struct_size,
  363. void* struct_deinit_fun) {
  364. if (NULL == struct_ptr) {
  365. return NULL;
  366. }
  367. Arg* struct_arg =
  368. arg_setContent(NULL, (uint8_t*)&struct_deinit_fun, sizeof(void*));
  369. struct_arg = arg_append(struct_arg, (uint8_t*)struct_ptr, struct_size);
  370. pika_assert(NULL != struct_arg);
  371. arg_setType(struct_arg, ARG_TYPE_STRUCT_HEAP);
  372. struct_arg = arg_setName(struct_arg, name);
  373. return struct_arg;
  374. }
  375. void* arg_getHeapStructDeinitFun(Arg* self) {
  376. void* deinit_fun = NULL;
  377. pika_platform_memcpy(&deinit_fun, arg_getContent(self), sizeof(void*));
  378. return deinit_fun;
  379. }
  380. Arg* arg_setInt(Arg* self, char* name, int64_t val) {
  381. return arg_set(self, name, ARG_TYPE_INT, (uint8_t*)&val, sizeof(val));
  382. }
  383. Arg* arg_setBool(Arg* self, char* name, PIKA_BOOL val) {
  384. return arg_set(self, name, ARG_TYPE_BOOL, (uint8_t*)&val, sizeof(val));
  385. }
  386. Arg* arg_setNull(Arg* self) {
  387. return arg_set(self, "", ARG_TYPE_NONE, NULL, 0);
  388. }
  389. Arg* arg_setFloat(Arg* self, char* name, pika_float val) {
  390. return arg_set(self, name, ARG_TYPE_FLOAT, (uint8_t*)&val, sizeof(val));
  391. }
  392. pika_float arg_getFloat(Arg* self) {
  393. if (NULL == arg_getContent(self)) {
  394. return -999.999;
  395. }
  396. return *(pika_float*)arg_getContent(self);
  397. }
  398. Arg* arg_setPtr(Arg* self, char* name, ArgType type, void* pointer) {
  399. return arg_set(self, name, type, (uint8_t*)&pointer, sizeof(uintptr_t));
  400. }
  401. Arg* arg_setStr(Arg* self, char* name, char* string) {
  402. if (NULL == string) {
  403. return NULL;
  404. }
  405. return arg_set(self, name, ARG_TYPE_STRING, (uint8_t*)string,
  406. strGetSize(string) + 1);
  407. }
  408. int64_t arg_getInt(Arg* self) {
  409. pika_assert(NULL != self);
  410. if (NULL == arg_getContent(self)) {
  411. return _PIKA_INT_ERR;
  412. }
  413. return *(int64_t*)arg_getContent(self);
  414. }
  415. PIKA_BOOL arg_getBool(Arg* self) {
  416. pika_assert(NULL != self);
  417. if (NULL == arg_getContent(self)) {
  418. return _PIKA_BOOL_ERR;
  419. }
  420. return *(PIKA_BOOL*)arg_getContent(self);
  421. }
  422. void* arg_getPtr(Arg* self) {
  423. if (arg_getType(self) == ARG_TYPE_NONE) {
  424. return NULL;
  425. }
  426. if (NULL == arg_getContent(self)) {
  427. return NULL;
  428. }
  429. return *(void**)arg_getContent(self);
  430. }
  431. char* arg_getStr(Arg* self) {
  432. return (char*)arg_getContent(self);
  433. }
  434. uint32_t arg_getContentSize(Arg* self) {
  435. return arg_getSize(self);
  436. }
  437. Arg* New_arg(void* voidPointer) {
  438. return NULL;
  439. }
  440. void arg_refcntInc(Arg* self) {
  441. ArgType arg_type = arg_getType(self);
  442. if (ARG_TYPE_OBJECT != arg_type) {
  443. return;
  444. }
  445. if (arg_getIsWeakRef(self)) {
  446. return;
  447. }
  448. obj_refcntInc((PikaObj*)arg_getPtr(self));
  449. }
  450. void arg_refcntDec(Arg* self) {
  451. ArgType arg_type = arg_getType(self);
  452. if (ARG_TYPE_OBJECT != arg_type) {
  453. return;
  454. }
  455. if (arg_getIsWeakRef(self)) {
  456. return;
  457. }
  458. obj_refcntDec((PikaObj*)arg_getPtr(self));
  459. }
  460. Arg* arg_copy_content(Arg* arg_dict, Arg* arg_src) {
  461. arg_dict = arg_setContent(arg_dict, arg_getContent(arg_src),
  462. arg_getContentSize(arg_src));
  463. arg_dict = arg_setNameHash(arg_dict, arg_getNameHash(arg_src));
  464. pika_assert(NULL != arg_dict);
  465. arg_setType(arg_dict, arg_getType(arg_src));
  466. arg_setIsKeyword(arg_dict, arg_getIsKeyword(arg_src));
  467. arg_setIsWeakRef(arg_dict, arg_getIsWeakRef(arg_src));
  468. return arg_dict;
  469. }
  470. Arg* arg_copy(Arg* arg_src) {
  471. if (NULL == arg_src) {
  472. return NULL;
  473. }
  474. pika_assert(arg_src->flag < ARG_FLAG_MAX);
  475. arg_refcntInc(arg_src);
  476. Arg* arg_dict = New_arg(NULL);
  477. arg_dict = arg_copy_content(arg_dict, arg_src);
  478. return arg_dict;
  479. }
  480. Arg* arg_copy_noalloc(Arg* arg_src, Arg* arg_dict) {
  481. if (NULL == arg_src) {
  482. return NULL;
  483. }
  484. if (NULL == arg_dict) {
  485. return arg_copy(arg_src);
  486. }
  487. /* size is too big to be copied by noalloc */
  488. if (arg_getSize(arg_src) > arg_getSize(arg_dict)) {
  489. return arg_copy(arg_src);
  490. }
  491. arg_refcntInc(arg_src);
  492. arg_setSerialized(arg_dict, PIKA_FALSE);
  493. arg_dict = arg_copy_content(arg_dict, arg_src);
  494. return arg_dict;
  495. }
  496. Arg* arg_append(Arg* self, void* new_content, size_t new_size) {
  497. uint8_t* old_content = arg_getContent(self);
  498. size_t old_size = arg_getContentSize(self);
  499. Arg* new_arg = NULL;
  500. #if PIKA_ARG_CACHE_ENABLE
  501. /* create arg_out */
  502. if (self->heap_size > mem_align(sizeof(Arg) + old_size + new_size)) {
  503. new_arg = self;
  504. new_arg->size = old_size + new_size;
  505. extern PikaMemInfo g_PikaMemInfo;
  506. g_PikaMemInfo.heapUsed += mem_align(sizeof(Arg) + old_size + new_size) -
  507. mem_align(sizeof(Arg) + old_size);
  508. }
  509. #endif
  510. if (NULL == new_arg) {
  511. new_arg = arg_setContent(NULL, NULL, old_size + new_size);
  512. }
  513. pika_assert(NULL != new_arg);
  514. arg_setType(new_arg, arg_getType(self));
  515. arg_setNameHash(new_arg, arg_getNameHash(self));
  516. if (self != new_arg) {
  517. /* copy old content */
  518. pika_platform_memcpy(arg_getContent(new_arg), old_content, old_size);
  519. }
  520. /* copy new content */
  521. pika_platform_memcpy(arg_getContent(new_arg) + old_size, new_content,
  522. new_size);
  523. if (self != new_arg) {
  524. arg_deinit(self);
  525. }
  526. return new_arg;
  527. }
  528. void* arg_getHeapStruct(Arg* self) {
  529. return arg_getContent(self) + sizeof(void*);
  530. }
  531. void arg_deinitHeap(Arg* self) {
  532. if (arg_getIsWeakRef(self)) {
  533. return;
  534. }
  535. ArgType type = arg_getType(self);
  536. /* deinit heap struct */
  537. if (type == ARG_TYPE_STRUCT_HEAP) {
  538. /* deinit heap strcut */
  539. StructDeinitFun struct_deinit_fun =
  540. (StructDeinitFun)arg_getHeapStructDeinitFun(self);
  541. struct_deinit_fun(arg_getHeapStruct(self));
  542. return;
  543. }
  544. /* deinit sub object */
  545. if (ARG_TYPE_OBJECT == type) {
  546. PikaObj* subObj = arg_getPtr(self);
  547. obj_GC(subObj);
  548. return;
  549. }
  550. // if (ARG_TYPE_METHOD_OBJECT == type) {
  551. // PikaObj* hostObj = methodArg_getHostObj(self);
  552. // if (NULL != hostObj) {
  553. // obj_GC(hostObj);
  554. // }
  555. // }
  556. }
  557. /* load file as byte array */
  558. Arg* arg_loadFile(Arg* self, char* filename) {
  559. size_t file_size = 0;
  560. char* file_buff = pika_platform_malloc(PIKA_READ_FILE_BUFF_SIZE);
  561. Arg* res = New_arg(NULL);
  562. pika_platform_memset(file_buff, 0, PIKA_READ_FILE_BUFF_SIZE);
  563. FILE* input_file = pika_platform_fopen(filename, "rb");
  564. if (NULL == input_file) {
  565. pika_platform_printf("Error: Couldn't open file '%s'\n", filename);
  566. res = NULL;
  567. goto exit;
  568. }
  569. file_size =
  570. pika_platform_fread(file_buff, 1, PIKA_READ_FILE_BUFF_SIZE, input_file);
  571. if (file_size >= PIKA_READ_FILE_BUFF_SIZE) {
  572. pika_platform_printf("Error: Not enough buff for input file.\r\n");
  573. return NULL;
  574. }
  575. /* add '\0' to the end of the string */
  576. res = arg_setBytes(res, "", (uint8_t*)file_buff, file_size + 1);
  577. exit:
  578. pika_platform_free(file_buff);
  579. if (NULL != input_file) {
  580. pika_platform_fclose(input_file);
  581. }
  582. return res;
  583. }
  584. void arg_deinit(Arg* self) {
  585. pika_assert(NULL != self);
  586. /* deinit arg pointed heap */
  587. arg_deinitHeap(self);
  588. if (!arg_isSerialized(self)) {
  589. return;
  590. }
  591. /* free the ref */
  592. arg_freeContent(self);
  593. }
  594. PIKA_BOOL arg_isEqual(Arg* self, Arg* other) {
  595. if (NULL == self || NULL == other) {
  596. return PIKA_FALSE;
  597. }
  598. if (arg_getType(self) != arg_getType(other)) {
  599. return PIKA_FALSE;
  600. }
  601. if (arg_getType(self) == ARG_TYPE_OBJECT) {
  602. if (arg_getPtr(self) != arg_getPtr(other)) {
  603. return PIKA_FALSE;
  604. }
  605. }
  606. if (arg_getType(self) == ARG_TYPE_STRING) {
  607. if (strEqu(arg_getStr(self), arg_getStr(other))) {
  608. return PIKA_TRUE;
  609. }
  610. }
  611. if (0 != pika_platform_memcmp(arg_getContent(self), arg_getContent(other),
  612. arg_getContentSize(self))) {
  613. return PIKA_FALSE;
  614. }
  615. return PIKA_TRUE;
  616. }