object.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377
  1. #include "__object.h"
  2. #include "__env.h"
  3. #include "tool.h"
  4. /* ObjectData 创建与释放 */
  5. static af_ObjectData * makeObjectData_Pri(char *id, bool free_api, af_ObjectAPI *api, bool allow_inherit, af_Object *base_obj,
  6. af_Environment *env);
  7. static af_Object *makeObject_Pri(char *id, bool free_api, af_ObjectAPI *api, bool allow_inherit, af_Environment *env);
  8. /* ObjectData API 创建与释放 */
  9. static af_ObjectAPINode *makeObjectAPINode(DLC_SYMBOL(objectAPIFunc) func, char *api_name);
  10. static af_ObjectAPINode *freeObjectAPINode(af_ObjectAPINode *apin);
  11. static void freeAllObjectAPINode(af_ObjectAPINode *apin);
  12. /* ObjectData API 管理函数 */
  13. static af_ObjectAPINode *findObjectDataAPINode(char *api_name, af_ObjectData *od);
  14. static int addAPIToObjectData(DLC_SYMBOL(objectAPIFunc) func, char *api_name, af_ObjectData *od);
  15. /*
  16. * 函数名: makeObjectData_Pri
  17. * 目标: 创建ObjectData
  18. * 注意: af_ObjectData不是对外开放的结构体
  19. * 注意: api不能为NULL
  20. */
  21. static af_ObjectData * makeObjectData_Pri(char *id, bool free_api, af_ObjectAPI *api, bool allow_inherit, af_Object *base_obj,
  22. af_Environment *env){
  23. af_ObjectData *od = calloc(1, sizeof(af_ObjectData));
  24. od->base = base_obj;
  25. base_obj->data = od;
  26. od->id = strCopy(id == NULL ? "Unknown" : id);
  27. od->api = api;
  28. od->free_api = free_api;
  29. od->allow_inherit = allow_inherit;
  30. od->var_space = makeVarSpace(base_obj, 3, 2, 0, env);
  31. od->inherit = NULL;
  32. obj_getDataSize *func = findAPI("obj_getDataSize", api);
  33. obj_initData *init = findAPI("obj_initData", api);
  34. if (func != NULL)
  35. od->size = func(id, base_obj);
  36. else
  37. od->size = 0;
  38. if (od->size != 0) {
  39. od->data = calloc(1, od->size);
  40. if (init != NULL)
  41. init(id, base_obj, od->data, env);
  42. }
  43. gc_addObjectData(od, env);
  44. return od;
  45. }
  46. static af_Object *makeObject_Pri(char *id, bool free_api, af_ObjectAPI *api, bool allow_inherit, af_Environment *env){
  47. af_Object *obj = calloc(1, sizeof(af_Object));
  48. obj->belong = NULL;
  49. makeObjectData_Pri(id, free_api, api, allow_inherit, obj, env);
  50. gc_addObject(obj, env);
  51. return obj;
  52. }
  53. /*
  54. * 函数名: 创建一个object
  55. * 目标: 生成Object和ObjectData, 并且添加到gc链表中
  56. * 若处于初始化模式, 则belong, inherit等可以设置为NULL, 由后期统一填上
  57. */
  58. af_Object *makeObject(char *id, bool free_api, af_ObjectAPI *api, bool allow_inherit, af_Object *belong,
  59. af_Inherit *inherit, af_Environment *env) {
  60. if (api == NULL)
  61. return NULL;
  62. af_Inherit *ih = NULL;
  63. if (inherit != NULL)
  64. ih = inherit;
  65. else if (env->core->global != NULL) // init模式生成: global
  66. ih = makeInherit(env->core->global);
  67. else if (env->core->status != core_creat)
  68. return NULL;
  69. if (belong == NULL) {
  70. if (env->activity != NULL)
  71. belong = env->activity->belong;
  72. else if (env->core->status == core_init) // init模式生成: global
  73. belong = env->core->global;
  74. else if (env->core->status != core_creat) // 只有creat可以使用belong=NULL
  75. return NULL;
  76. }
  77. af_Object *obj = makeObject_Pri(id, free_api, api, allow_inherit, env);
  78. obj->belong = belong;
  79. obj->data->inherit = ih;
  80. return obj;
  81. }
  82. /*
  83. * 函数名: freeObjectDataData
  84. * 目标: 释放ObjectData的void *data, 仅GC函数可用
  85. * 对外API中, 创建对象的基本单位都是af_Object, 无法直接操控af_ObjectData
  86. */
  87. void freeObjectDataData(af_ObjectData *od, af_Environment *env) {
  88. if (od->size == 0)
  89. return;
  90. obj_destructData *func = findAPI("obj_destructData", od->api);
  91. if (func != NULL)
  92. func(od->id, od->base, od->data, env);
  93. od->size = 0;
  94. free(od->data);
  95. }
  96. /*
  97. * 函数名: freeObjectData
  98. * 目标: 释放ObjectData, 仅GC函数可用
  99. * 对外API中, 创建对象的基本单位都是af_Object, 无法直接操控af_ObjectData
  100. */
  101. void freeObjectData(af_ObjectData *od, af_Environment *env) {
  102. if (od->size != 0) {
  103. obj_destructData *func = findAPI("obj_destructData", od->api);
  104. if (func != NULL)
  105. func(od->id, od->base, od->data, env);
  106. }
  107. free(od->id);
  108. free(od->data);
  109. if (od->free_api)
  110. freeObjectAPI(od->api);
  111. freeAllInherit(od->inherit);
  112. GC_FREE_EXCHANGE(od, ObjectData, env->core);
  113. free(od);
  114. }
  115. void freeObject(af_Object *obj, af_Environment *env) {
  116. GC_FREE_EXCHANGE(obj, Object, env->core);
  117. free(obj);
  118. }
  119. void freeObjectByCore(af_Object *obj, af_Core *core) {
  120. GC_FREE_EXCHANGE(obj, Object, core);
  121. free(obj);
  122. }
  123. void *getObjectData(af_Object *obj) {
  124. return obj->data->data;
  125. }
  126. af_Object *getBelongObject(af_Object *object){
  127. if (object->belong == NULL)
  128. return object;
  129. return object->belong;
  130. }
  131. af_Inherit *makeInherit(af_Object *obj) {
  132. if (!obj->data->allow_inherit)
  133. return NULL;
  134. obj_getShareVarSpace *func = findAPI("obj_getShareVarSpace", obj->data->api);
  135. af_VarSpace *vs = NULL;
  136. if (func == NULL || (vs = func(obj->data->id, obj)) == NULL)
  137. return NULL;
  138. af_Inherit *ih = calloc(1, sizeof(af_Inherit));
  139. ih->vs = vs;
  140. ih->obj = obj; // 调用API获取vs
  141. return ih;
  142. }
  143. af_Inherit **pushInherit(af_Inherit **base, af_Inherit *new) {
  144. while ((*base) != NULL)
  145. base = &((*base)->next);
  146. *base = new;
  147. while ((*base) != NULL)
  148. base = &((*base)->next);
  149. return base;
  150. }
  151. static af_Inherit *freeInherit(af_Inherit *ih) {
  152. af_Inherit *next = ih->next; // vs一定是被gc托管的
  153. free(ih);
  154. return next;
  155. }
  156. void freeAllInherit(af_Inherit *ih) {
  157. while (ih != NULL)
  158. ih = freeInherit(ih);
  159. }
  160. bool checkPosterity(af_Object *base, af_Object *posterity) {
  161. for (af_Inherit *ih = base->data->inherit; ih != NULL; ih = ih->next) {
  162. if (ih->obj->data == posterity->data)
  163. return true;
  164. }
  165. return false;
  166. }
  167. static af_ObjectAPINode *makeObjectAPINode(DLC_SYMBOL(objectAPIFunc) func, char *api_name) {
  168. if (func == NULL)
  169. return NULL;
  170. af_ObjectAPINode *apin = calloc(1, sizeof(af_ObjectAPINode));
  171. apin->api = COPY_SYMBOL(func, objectAPIFunc);
  172. apin->name = strCopy(api_name);
  173. return apin;
  174. }
  175. static af_ObjectAPINode *freeObjectAPINode(af_ObjectAPINode *apin) {
  176. af_ObjectAPINode *next = apin->next;
  177. FREE_SYMBOL(apin->api);
  178. free(apin->name);
  179. free(apin);
  180. return next;
  181. }
  182. static void freeAllObjectAPINode(af_ObjectAPINode *apin) {
  183. while (apin != NULL)
  184. apin = freeObjectAPINode(apin);
  185. }
  186. af_ObjectAPI *makeObjectAPI(void) {
  187. af_ObjectAPI *api = calloc(1, sizeof(af_ObjectAPI));
  188. return api;
  189. }
  190. void freeObjectAPI(af_ObjectAPI *api) {
  191. for (int i = 0; i < API_HASHTABLE_SIZE; i++)
  192. freeAllObjectAPINode(api->node[i]);
  193. free(api);
  194. }
  195. /*
  196. * 函数名: addAPIToObjectData
  197. * 目标: 从DLC中获取函数并写入api
  198. * 若已存在api则返回0且不作修改
  199. * 若dlc中不存在指定函数则返回-1且不作修改
  200. * 操作成功返回1
  201. */
  202. int addAPI(DLC_SYMBOL(objectAPIFunc) func, char *api_name, af_ObjectAPI *api) {
  203. time33_t index = time33(api_name) % API_HASHTABLE_SIZE;
  204. af_ObjectAPINode **pNode = &api->node[index];
  205. for (NULL; *pNode != NULL; pNode = &((*pNode)->next)) {
  206. if (EQ_STR((*pNode)->name, api_name))
  207. return 0;
  208. }
  209. *pNode = makeObjectAPINode(func, api_name);
  210. api->count++;
  211. return *pNode == NULL ? -1 : 1;
  212. }
  213. void *findAPI(char *api_name, af_ObjectAPI *api) {
  214. time33_t index = time33(api_name) % API_HASHTABLE_SIZE;
  215. for (af_ObjectAPINode *node = api->node[index]; node != NULL; node = node->next) {
  216. if (EQ_STR(node->name, api_name))
  217. return GET_SYMBOL(node->api);
  218. }
  219. return NULL;
  220. }
  221. /*
  222. * 函数名: addAPIToObjectData
  223. * 目标: 从DLC中获取函数并写入api
  224. * 若已存在api则返回0且不作修改
  225. * 若dlc中不存在指定函数则返回-1且不作修改
  226. * 操作成功返回1
  227. */
  228. static int addAPIToObjectData(DLC_SYMBOL(objectAPIFunc) func, char *api_name,
  229. af_ObjectData *od) {
  230. time33_t index = time33(api_name) % API_HASHTABLE_SIZE;
  231. af_ObjectAPINode **pNode = &od->api->node[index];
  232. for (NULL; *pNode != NULL; pNode = &((*pNode)->next)) {
  233. if (EQ_STR((*pNode)->name, api_name))
  234. return 0;
  235. }
  236. *pNode = makeObjectAPINode(func, api_name);
  237. od->api->count++;
  238. return *pNode == NULL ? -1 : 1;
  239. }
  240. static af_ObjectAPINode *findObjectDataAPINode(char *api_name, af_ObjectData *od) {
  241. time33_t index = time33(api_name) % API_HASHTABLE_SIZE;
  242. for (af_ObjectAPINode *node = od->api->node[index]; node != NULL; node = node->next) {
  243. if (EQ_STR(node->name, api_name))
  244. return node;
  245. }
  246. return NULL;
  247. }
  248. /*
  249. * 函数名: findObjectDataAPINode
  250. * 目标: 从DLC中获取函数并写入Object的API
  251. */
  252. int addAPIToObject(DLC_SYMBOL(objectAPIFunc) func, char *api_name,
  253. af_Object *obj) {
  254. return addAPIToObjectData(func, api_name, obj->data);
  255. }
  256. /*
  257. * 函数名: findObjectAPI
  258. * 目标: 从Object中获取指定api的函数指针
  259. */
  260. void *findObjectAPI(char *api_name, af_Object *obj) {
  261. af_ObjectAPINode *node = findObjectDataAPINode(api_name, obj->data);
  262. if (node == NULL)
  263. return NULL;
  264. return GET_SYMBOL(node->api);
  265. }
  266. af_Object *findObjectAttributes(char *name, af_Object *visitor, af_Object *obj) {
  267. af_Var *var = findVarFromVarSpace(name, visitor, obj->data->var_space);
  268. if (var != NULL)
  269. return var->vn->obj;
  270. for (af_Inherit *ih = obj->data->inherit; ih != NULL; ih = ih->next) {
  271. var = findVarFromVarSpace(name, visitor, ih->vs); // 搜索共享变量空间
  272. if (var != NULL)
  273. return var->vn->obj;
  274. }
  275. return NULL;
  276. }
  277. bool setObjectAttributes(char *name, char p_self, char p_posterity, char p_external, af_Object *attributes,
  278. af_Object *obj, af_Object *visitor, af_Environment *env){
  279. return makeVarToVarSpace(name, p_self, p_posterity, p_external, attributes, obj->data->var_space, visitor, env);
  280. }
  281. af_Object *findObjectAttributesByObjectData(char *name, af_Object *visitor, af_ObjectData *od) {
  282. af_Var *var = findVarFromVarSpace(name, visitor, od->var_space);
  283. if (var != NULL)
  284. return var->vn->obj;
  285. for (af_Inherit *ih = od->inherit; ih != NULL; ih = ih->next) {
  286. var = findVarFromVarSpace(name, visitor, ih->vs); // 搜索共享变量空间
  287. if (var != NULL)
  288. return var->vn->obj;
  289. }
  290. return NULL;
  291. }
  292. char *getObjectID(af_Object *obj) {
  293. return obj->data->id;
  294. }
  295. af_ObjectAPI *getObjectAPI(af_Object *obj) {
  296. return obj->data->api;
  297. }
  298. af_Inherit *getObjectInherit(af_Object *obj) {
  299. return obj->data->inherit;
  300. }
  301. af_Inherit *getInheritNext(af_Inherit *ih) {
  302. return ih->next;
  303. }
  304. af_Object *getInheritObject(af_Inherit *ih) {
  305. return ih->obj;
  306. }
  307. af_VarSpace *getInheritVarSpace(af_Inherit *ih) {
  308. return ih->vs;
  309. }
  310. ObjAPIUint getAPICount(af_ObjectAPI *api) {
  311. return api->count;
  312. }
  313. void objectSetAllowInherit(af_Object *obj, bool allow) {
  314. obj->data->allow_inherit = allow;
  315. }