1
0

object.c 11 KB

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