object.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362
  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 ? "Unknow" : 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. * 函数名: freeObjectData
  84. * 目标: 释放ObjectData, 仅GC函数可用
  85. * 对外API中, 创建对象的基本单位都是af_Object, 无法直接操控af_ObjectData
  86. */
  87. void freeObjectData(af_ObjectData *od, af_Environment *env) {
  88. if (od->size != 0) {
  89. obj_destructData *func = findAPI("obj_destructData", od->api);
  90. if (func != NULL)
  91. func(od->id, od->base, od->data, env);
  92. }
  93. free(od->id);
  94. free(od->data);
  95. if (od->free_api)
  96. freeObjectAPI(od->api);
  97. freeAllInherit(od->inherit);
  98. GC_FREE_EXCHANGE(od, ObjectData, env->core);
  99. free(od);
  100. }
  101. void freeObject(af_Object *obj, af_Environment *env) {
  102. GC_FREE_EXCHANGE(obj, Object, env->core);
  103. free(obj);
  104. }
  105. void freeObjectByCore(af_Object *obj, af_Core *core) {
  106. GC_FREE_EXCHANGE(obj, Object, core);
  107. free(obj);
  108. }
  109. void *getObjectData(af_Object *obj) {
  110. return obj->data->data;
  111. }
  112. af_Object *getBelongObject(af_Object *object){
  113. if (object->belong == NULL)
  114. return object;
  115. return object->belong;
  116. }
  117. af_Inherit *makeInherit(af_Object *obj) {
  118. if (!obj->data->allow_inherit)
  119. return NULL;
  120. obj_getShareVarSpace *func = findAPI("obj_getShareVarSpace", obj->data->api);
  121. af_VarSpace *vs = NULL;
  122. if (func == NULL || (vs = func(obj->data->id, obj)) == NULL)
  123. return NULL;
  124. af_Inherit *ih = calloc(1, sizeof(af_Inherit));
  125. ih->vs = vs;
  126. ih->obj = obj; // 调用API获取vs
  127. return ih;
  128. }
  129. af_Inherit **pushInherit(af_Inherit **base, af_Inherit *new) {
  130. while ((*base) != NULL)
  131. base = &((*base)->next);
  132. *base = new;
  133. while ((*base) != NULL)
  134. base = &((*base)->next);
  135. return base;
  136. }
  137. static af_Inherit *freeInherit(af_Inherit *ih) {
  138. af_Inherit *next = ih->next; // vs一定是被gc托管的
  139. free(ih);
  140. return next;
  141. }
  142. void freeAllInherit(af_Inherit *ih) {
  143. while (ih != NULL)
  144. ih = freeInherit(ih);
  145. }
  146. bool checkPosterity(af_Object *base, af_Object *posterity) {
  147. for (af_Inherit *ih = base->data->inherit; ih != NULL; ih = ih->next) {
  148. if (ih->obj->data == posterity->data)
  149. return true;
  150. }
  151. return false;
  152. }
  153. static af_ObjectAPINode *makeObjectAPINode(DLC_SYMBOL(objectAPIFunc) func, char *api_name) {
  154. if (func == NULL)
  155. return NULL;
  156. af_ObjectAPINode *apin = calloc(1, sizeof(af_ObjectAPINode));
  157. apin->api = COPY_SYMBOL(func, objectAPIFunc);
  158. apin->name = strCopy(api_name);
  159. return apin;
  160. }
  161. static af_ObjectAPINode *freeObjectAPINode(af_ObjectAPINode *apin) {
  162. af_ObjectAPINode *next = apin->next;
  163. FREE_SYMBOL(apin->api);
  164. free(apin->name);
  165. free(apin);
  166. return next;
  167. }
  168. static void freeAllObjectAPINode(af_ObjectAPINode *apin) {
  169. while (apin != NULL)
  170. apin = freeObjectAPINode(apin);
  171. }
  172. af_ObjectAPI *makeObjectAPI(void) {
  173. af_ObjectAPI *api = calloc(1, sizeof(af_ObjectAPI));
  174. return api;
  175. }
  176. void freeObjectAPI(af_ObjectAPI *api) {
  177. for (int i = 0; i < API_HASHTABLE_SIZE; i++)
  178. freeAllObjectAPINode(api->node[i]);
  179. free(api);
  180. }
  181. /*
  182. * 函数名: addAPIToObjectData
  183. * 目标: 从DLC中获取函数并写入api
  184. * 若已存在api则返回0且不作修改
  185. * 若dlc中不存在指定函数则返回-1且不作修改
  186. * 操作成功返回1
  187. */
  188. int addAPI(DLC_SYMBOL(objectAPIFunc) func, char *api_name, af_ObjectAPI *api) {
  189. time33_t index = time33(api_name) % API_HASHTABLE_SIZE;
  190. af_ObjectAPINode **pNode = &api->node[index];
  191. for (NULL; *pNode != NULL; pNode = &((*pNode)->next)) {
  192. if (EQ_STR((*pNode)->name, api_name))
  193. return 0;
  194. }
  195. *pNode = makeObjectAPINode(func, api_name);
  196. api->count++;
  197. return *pNode == NULL ? -1 : 1;
  198. }
  199. void *findAPI(char *api_name, af_ObjectAPI *api) {
  200. time33_t index = time33(api_name) % API_HASHTABLE_SIZE;
  201. for (af_ObjectAPINode *node = api->node[index]; node != NULL; node = node->next) {
  202. if (EQ_STR(node->name, api_name))
  203. return GET_SYMBOL(node->api);
  204. }
  205. return NULL;
  206. }
  207. /*
  208. * 函数名: addAPIToObjectData
  209. * 目标: 从DLC中获取函数并写入api
  210. * 若已存在api则返回0且不作修改
  211. * 若dlc中不存在指定函数则返回-1且不作修改
  212. * 操作成功返回1
  213. */
  214. static int addAPIToObjectData(DLC_SYMBOL(objectAPIFunc) func, char *api_name,
  215. af_ObjectData *od) {
  216. time33_t index = time33(api_name) % API_HASHTABLE_SIZE;
  217. af_ObjectAPINode **pNode = &od->api->node[index];
  218. for (NULL; *pNode != NULL; pNode = &((*pNode)->next)) {
  219. if (EQ_STR((*pNode)->name, api_name))
  220. return 0;
  221. }
  222. *pNode = makeObjectAPINode(func, api_name);
  223. od->api->count++;
  224. return *pNode == NULL ? -1 : 1;
  225. }
  226. static af_ObjectAPINode *findObjectDataAPINode(char *api_name, af_ObjectData *od) {
  227. time33_t index = time33(api_name) % API_HASHTABLE_SIZE;
  228. for (af_ObjectAPINode *node = od->api->node[index]; node != NULL; node = node->next) {
  229. if (EQ_STR(node->name, api_name))
  230. return node;
  231. }
  232. return NULL;
  233. }
  234. /*
  235. * 函数名: findObjectDataAPINode
  236. * 目标: 从DLC中获取函数并写入Object的API
  237. */
  238. int addAPIToObject(DLC_SYMBOL(objectAPIFunc) func, char *api_name,
  239. af_Object *obj) {
  240. return addAPIToObjectData(func, api_name, obj->data);
  241. }
  242. /*
  243. * 函数名: findObjectAPI
  244. * 目标: 从Object中获取指定api的函数指针
  245. */
  246. void *findObjectAPI(char *api_name, af_Object *obj) {
  247. af_ObjectAPINode *node = findObjectDataAPINode(api_name, obj->data);
  248. if (node == NULL)
  249. return NULL;
  250. return GET_SYMBOL(node->api);
  251. }
  252. af_Object *findObjectAttributes(char *name, af_Object *visitor, af_Object *obj) {
  253. af_Var *var = findVarFromVarSpace(name, visitor, obj->data->var_space);
  254. if (var != NULL)
  255. return var->vn->obj;
  256. for (af_Inherit *ih = obj->data->inherit; ih != NULL; ih = ih->next) {
  257. var = findVarFromVarSpace(name, visitor, ih->vs); // 搜索共享变量空间
  258. if (var != NULL)
  259. return var->vn->obj;
  260. }
  261. return NULL;
  262. }
  263. bool setObjectAttributes(char *name, char p_self, char p_posterity, char p_external, af_Object *attributes,
  264. af_Object *obj, af_Object *visitor, af_Environment *env){
  265. return makeVarToVarSpace(name, p_self, p_posterity, p_external, attributes, obj->data->var_space, visitor, env);
  266. }
  267. af_Object *findObjectAttributesByObjectData(char *name, af_Object *visitor, af_ObjectData *od) {
  268. af_Var *var = findVarFromVarSpace(name, visitor, od->var_space);
  269. if (var != NULL)
  270. return var->vn->obj;
  271. for (af_Inherit *ih = od->inherit; ih != NULL; ih = ih->next) {
  272. var = findVarFromVarSpace(name, visitor, ih->vs); // 搜索共享变量空间
  273. if (var != NULL)
  274. return var->vn->obj;
  275. }
  276. return NULL;
  277. }
  278. char *getObjectID(af_Object *obj) {
  279. return obj->data->id;
  280. }
  281. af_ObjectAPI *getObjectAPI(af_Object *obj) {
  282. return obj->data->api;
  283. }
  284. af_Inherit *getObjectInherit(af_Object *obj) {
  285. return obj->data->inherit;
  286. }
  287. af_Inherit *getInheritNext(af_Inherit *ih) {
  288. return ih->next;
  289. }
  290. af_Object *getInheritObject(af_Inherit *ih) {
  291. return ih->obj;
  292. }
  293. af_VarSpace *getInheritVarSpace(af_Inherit *ih) {
  294. return ih->vs;
  295. }
  296. ObjAPIUint getAPICount(af_ObjectAPI *api) {
  297. return api->count;
  298. }
  299. void objectSetAllowInherit(af_Object *obj, bool allow) {
  300. obj->data->allow_inherit = allow;
  301. }