1
0

run.c 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529
  1. #include "aFunCore.h"
  2. #include "__sig.h"
  3. #include "__run.h"
  4. #include "__env.h"
  5. /* 工具函数: 初始化类型 */
  6. static bool iterCodeInit(af_Code *code, int mode, af_Environment *env);
  7. /* 工具函数: Message类函数 */
  8. static af_Message *getTopMsg(af_Environment *env);
  9. /* 工具函数: 检查类型 */
  10. static bool checkInMsgType(char *type, af_Environment *env);
  11. static bool checkLiteral(af_Message **msg, af_Environment *env);
  12. static int checkMacro(af_Message *msg, af_Environment *env);
  13. static bool checkRunGC(af_Environment *env);
  14. static int checkMsg(af_Message *msg, af_Environment *env);
  15. bool checkNormalEnd(af_Message *msg, af_Environment *env);
  16. static bool checkGetArgEnd(af_Message *msg, af_Environment *env);
  17. static bool checkStop(af_Environment *env);
  18. /* Code 执行函数 */
  19. static bool codeElement(af_Code *code, af_Environment *env);
  20. static bool codeBlock(af_Code *code, af_Environment *env);
  21. static bool runGuardian(af_Environment *env);
  22. /*
  23. * 函数名: checkInMsgType
  24. * 目标: 检查type是否在对应的msg_type中 (检查该activity是否可以处理该信息)
  25. */
  26. static bool checkInMsgType(char *type, af_Environment *env) {
  27. if (env->activity->body_next == NULL || env->activity->body_next->msg_type == NULL)
  28. return false;
  29. for (char *msg_type_node = *env->activity->body_next->msg_type; msg_type_node != NULL; msg_type_node++) {
  30. if (EQ_STR(type, msg_type_node))
  31. return true;
  32. }
  33. return false;
  34. }
  35. /*
  36. * 函数名: checkLiteral
  37. * 目标: 检查是否字面量调用, 若是则返回true并调用API, 否则返回false不做修改
  38. */
  39. static bool checkLiteral(af_Message **msg, af_Environment *env) {
  40. if (!env->activity->is_literal) // 非字面量
  41. return true;
  42. if ((*msg) == NULL || !EQ_STR((*msg)->type, "NORMAL")) // (*msg)非正常值
  43. return false;
  44. af_Object *obj = *(af_Object **)((*msg)->msg);
  45. obj_literalSetting *func = findAPI("obj_literalSetting", obj->data->api);
  46. if (func == NULL) {
  47. gc_delReference(obj);
  48. freeMessage(*msg);
  49. *msg = makeERRORMessage(TYPE_ERROR, API_NOT_FOUND_INFO(obj_literalSetting), env);
  50. return false;
  51. }
  52. for (af_LiteralDataList *ld = env->activity->ld; ld != NULL; ld = ld->next)
  53. func(obj->data->id, obj, obj->data->data, ld->literal_data, env);
  54. freeAllLiteralData(env->activity->ld);
  55. env->activity->ld = NULL;
  56. env->activity->is_literal = false;
  57. writeTrackLog(aFunCoreLogger, "Literal %p", obj);
  58. return true;
  59. }
  60. /*
  61. * 函数名: checkMacro
  62. * 目标: 检查是否宏函数调用, 若是则返回true并修改activity隐式调用(activity继续执行时则会执行该调用), 否则返回false不做修改
  63. * 返回值:
  64. * -1 非宏函数
  65. * 0 错误
  66. * 1 宏函数
  67. */
  68. static int checkMacro(af_Message *msg, af_Environment *env) {
  69. if (env->activity->fi == NULL || !env->activity->fi->is_macro) // 非宏函数
  70. return -1;
  71. if (!EQ_STR(msg->type, "NORMAL")) // msg非正常值
  72. return -1;
  73. af_Object *obj = *(af_Object **)(msg->msg);
  74. bool re = pushMacroFuncActivity(obj, env);
  75. gc_delReference(obj);
  76. freeMessage(msg);
  77. if (re)
  78. return 1;
  79. return 0;
  80. }
  81. /*
  82. * 函数名: checkRunGC
  83. * 目标: 检查是否该运行gc, 若是则返回true并运行gc, 否则返回false
  84. */
  85. static bool checkRunGC(af_Environment *env) {
  86. if (env->core->gc_runtime->num == grt_always ||
  87. env->core->gc_runtime->num == grt_count && env->core->gc_count->num >= env->core->gc_max->num) {
  88. env->core->gc_count->num = 0; // 清零
  89. gc_RunGC(env);
  90. return true;
  91. }
  92. return false;
  93. }
  94. /*
  95. * 函数名: iterCodeInit
  96. * 目标: 初始化activity和environment (若environment中未存在activity则通过code新增一个TopActivity, 否则沿用原activity)
  97. *
  98. * mode 标识运行模式
  99. * 0. 在top运行
  100. * 1. 在import运行
  101. * 2. 直接运行
  102. * 3. gc模式
  103. */
  104. static bool iterCodeInit(af_Code *code, int mode, af_Environment *env) {
  105. if (env == NULL || env->core == NULL || env->activity == NULL || env->core->status == core_exit || env->in_run)
  106. return false;
  107. if (env->core->status == core_stop)
  108. env->core->status = core_normal;
  109. switch (mode) {
  110. case 0:
  111. if (env->activity->type != act_top || !codeSemanticCheck(code))
  112. return false;
  113. setActivityBtTop(NULL, env->activity); // 直接就在NORMAL期, bt_top不被设定
  114. setActivityBtStart(code, env->activity);
  115. break;
  116. case 1: {
  117. if (env->activity->type != act_top)
  118. return false;
  119. env->activity->file = strCopy("top.aun.sys");
  120. char *name = getFileName(code->path);
  121. pushImportActivity(code, NULL, name, env);
  122. free(name);
  123. break;
  124. }
  125. case 2:
  126. if (env->activity->prev == NULL || env->activity->prev->type != act_top)
  127. return false;
  128. env->activity->file = strCopy("top-gc.aun.sys");
  129. if (env->activity->type == act_gc || !codeSemanticCheck(env->activity->bt_start) || env->activity->bt_next == NULL || code != NULL)
  130. return false;
  131. break;
  132. case 3:
  133. if (env->activity->type != act_gc || code != NULL)
  134. return false;
  135. break;
  136. default:
  137. return false;
  138. }
  139. env->in_run = true;
  140. return true;
  141. }
  142. /*
  143. * 函数名: codeElement
  144. * 目标: 执行变量访问或字面量生成 (设置bt_next)
  145. * (1) 执行字面量生成代码 (设置bt_next)
  146. * 返回-false 表示执行错误 (msg_down中写入消息)
  147. * 返回-true 表示执行成功 (msg_down中无消息写入, 函数仅设置activity无实质性代码执行)
  148. * (2) 执行变量访问代码:
  149. * 返回-false 表示执行失败, 或执行成功得到一个变量值 (msg_down中写入消息)
  150. * 返回-true 表示执行成功, 得到一个对象函数, 并且隐式调用 (msg_down中无消息写入, 函数仅设置activity无实质性代码执行)
  151. */
  152. static bool codeElement(af_Code *code, af_Environment *env) {
  153. bool in_protect;
  154. char *func;
  155. af_Var *var;
  156. if (checkLiteralCode(code->element.data, &func, &in_protect, env)) {
  157. /* 字面量执行 */
  158. if (in_protect)
  159. var = findVarFromVarSpace(func, env->activity->belong, env->core->protect);
  160. else
  161. var = findVarFromVarList(func, env->activity->belong, env->activity->vsl);
  162. if (var == NULL) {
  163. pushMessageDown(makeERRORMessageFormat(LITERAL_ERROR, env, "Literal not found: %s: %s.", code->element.data, func), env);
  164. return false;
  165. }
  166. writeTrackLog(aFunCoreLogger, "Get literal %s : %p", code->element.data, var->vn->obj);
  167. return pushLiteralActivity(code, code->element.data, var->vn->obj, env);
  168. }
  169. /* 变量执行 */
  170. var = findVarFromVarList(code->element.data, env->activity->belong, env->activity->vsl);
  171. if (var == NULL) {
  172. pushMessageDown(makeERRORMessageFormat(VARIABLE_ERROR, env, "Variable not found: %s.", code->element.data), env);
  173. return false;
  174. }
  175. af_Object *obj = var->vn->obj;
  176. obj_isObjFunc *is_obj;
  177. obj_isInfixFunc *is_infix;
  178. if (code->prefix != getPrefix(E_QUOTE, env)) {
  179. if ((is_obj = findAPI("obj_isObjFunc", obj->data->api)) != NULL && is_obj(obj->data->id, obj))
  180. return pushVariableActivity(code, var->vn->obj, env); // 对象函数
  181. else if (env->activity->status != act_func_get && // 在act_func_get 模式下不检查是否为is_infix函数 因为本来就要将其作为函数调用
  182. (is_infix = findAPI("obj_isInfixFunc", obj->data->api)) != NULL && is_infix(obj->data->id, obj)) {
  183. pushMessageDown(makeERRORMessageFormat(INFIX_PROTECT, env,
  184. "Infix protect variable: %s.", code->element.data), env);
  185. return false;
  186. }
  187. }
  188. pushMessageDown(makeNORMALMessage(obj), env);
  189. setActivityBtNext(env->activity->bt_next->next, env->activity);
  190. writeTrackLog(aFunCoreLogger, "Get variable %s : %p", code->element.data, obj);
  191. return false;
  192. }
  193. /*
  194. * 函数名: codeBlock
  195. * 目标: 执行括号语法 (顺序执行, 函数调用)
  196. * 返回-false 表示执行错误 (msg_down中写入消息)
  197. * 返回-true 表示执行成功 (msg_down中无消息写入, 函数仅设置activity无实质性代码执行)
  198. */
  199. static bool codeBlock(af_Code *code, af_Environment *env) {
  200. if (code->prefix == getPrefix(B_EXEC, env) && code->block.type == parentheses) // 顺序执行, 返回尾项
  201. return pushExecutionActivity(code, false, env);
  202. else if (code->prefix == getPrefix(B_EXEC_FIRST, env) && code->block.type == brackets) // 顺序执行, 返回首项
  203. return pushExecutionActivity(code, true, env);
  204. else
  205. return pushFuncActivity(env->activity->bt_next, env);
  206. }
  207. static bool runGuardian(af_Environment *env) {
  208. af_GuardianList *gl = NULL;
  209. af_GuardianList **pgl = ≷
  210. for (af_Guardian *gd = env->guardian; gd != NULL; gd = gd->next) {
  211. if (gd->always || !env->activity->is_guard) { // guardian被标记为一直执行, 或者非is_guard模式
  212. af_GuardianList *new = GET_SYMBOL(gd->func)(gd->type, env->activity->is_guard, gd->data, env);
  213. if (new != NULL)
  214. pgl = contectGuardianList(new, pgl);
  215. }
  216. }
  217. if (gl != NULL) {
  218. pushGuardianActivity(gl, pgl, env);
  219. return true;
  220. }
  221. return false;
  222. }
  223. /*
  224. * 函数名: getTopMsg
  225. * 目标: 获取msg_down顶层信息, 若没有则产生错误
  226. */
  227. static af_Message *getTopMsg(af_Environment *env) {
  228. if (env->activity->msg_down == NULL) // 若未获得 msg
  229. return makeERRORMessage(RUN_ERROR, NOT_MSG_INFO, env);
  230. else
  231. return getFirstMessage(env);
  232. }
  233. /*
  234. * 函数名: checkMsg
  235. * 目标: 检查msg是否为NORMAL, 并且检查该信号是否可被处理
  236. * 返回- (1) 正常
  237. * 返回- (0) 不可处理的信号
  238. * 返回-(-1) 非正常但通过msg_type判断为可被处理的信号
  239. */
  240. static int checkMsg(af_Message *msg, af_Environment *env) {
  241. if (EQ_STR(msg->type, "NORMAL"))
  242. return 1; // 正常
  243. pushMessageDown(msg, env); // msg不弹出
  244. if (env->activity->status != act_func_normal || !checkInMsgType(msg->type, env)) { // 非normal模式, 或normal模式下msg_type不匹配该msg
  245. env->activity->return_first = false;
  246. env->activity->return_obj = NULL;
  247. return 0;
  248. }
  249. return -1; // 遇到非normal, 但继续运行
  250. }
  251. /*
  252. * 函数名: checkNormalEnd
  253. * 目标: 检查act_normal是否运行到结尾 (若运行到结尾则返回true, 否则返回false)
  254. */
  255. bool checkNormalEnd(af_Message *msg, af_Environment *env) {
  256. if (env->activity->bt_next == NULL) {
  257. if (env->activity->type == act_top || env->activity->type == act_top_import) {
  258. pushMessageDown(msg, env);
  259. return true;
  260. } else if (setFuncActivityToNormal(env) == 0) { // 已经没有下一步了
  261. if (msg == NULL) { // msg 得不到处理
  262. pushMessageDown(makeERRORMessage(RUN_ERROR, NOT_NORMAL_MSG_INFO, env), env);
  263. return true;
  264. }
  265. switch (checkMacro(msg, env)) {
  266. case 0:
  267. return true; // 错误
  268. case 1:
  269. return false; // 宏函数
  270. case -1:
  271. default:
  272. break; // 非宏函数
  273. }
  274. checkLiteral(&msg, env); // 检查是否字面量
  275. pushMessageDown(msg, env);
  276. return true;
  277. } else if (msg != NULL) {
  278. gc_delReference(*(af_Object **) (msg->msg)); // msg->msg是一个指针, 这个指针的内容是一个af_Object *
  279. freeMessage(msg);
  280. }
  281. } else if (msg != NULL) {
  282. if (env->activity->bt_next->type == code_block && env->activity->bt_next->block.type == parentheses &&
  283. env->activity->bt_next->prefix != getPrefix(B_EXEC, env)) {
  284. env->activity->parentheses_call = *(af_Object **) (msg->msg); // 类前缀调用
  285. }
  286. gc_delReference(*(af_Object **)(msg->msg)); // msg->msg是一个指针, 这个指针的内容是一个af_Object *
  287. freeMessage(msg);
  288. }
  289. return false;
  290. }
  291. /*
  292. * 函数名: checkGetArgEnd
  293. * 目标: 检查act_arg是否运行到结尾 (若运行到结尾则返回true, 否则返回false)
  294. */
  295. static bool checkGetArgEnd(af_Message *msg, af_Environment *env) {
  296. env->activity->acl_done->result = *(af_Object **)(msg->msg);
  297. freeMessage(msg);
  298. if (env->activity->acl_done->next == NULL) { // 参数设定结束
  299. setArgCodeListToActivity(NULL, env);
  300. return true;
  301. }
  302. env->activity->acl_done = env->activity->acl_done->next;
  303. setArgCodeListToActivity(env->activity->acl_done, env);
  304. return false;
  305. }
  306. static bool checkStop(af_Environment *env) {
  307. if (env->core->status == core_stop || env->core->status == core_exit) {
  308. while (env->activity->type != act_top || env->activity->prev != NULL)
  309. popActivity(false, NULL, env); // is_normal=false, 非正常退出, 释放mark
  310. popActivity(false, NULL, env); // 再释放 act_top
  311. return true;
  312. }
  313. return false;
  314. }
  315. /*
  316. * 函数名: iterCode
  317. * 目标: 运行代码 (代码可通过code参数传入, 或通过env->activity传入)
  318. * 注意: 曾为缩短改函数而将该函数的内容进行大量的封装
  319. * 但实际上, 这个函数各个部分的关联性是很强的
  320. * 因此, 取消了封装, 反而提高了代码的可读性
  321. *
  322. * 因为该函数的大部分内容运行在循环中, 因此使用continue表示不在运行后面的代码
  323. */
  324. bool iterCode(af_Code *code, int mode, af_Environment *env){
  325. if (!iterCodeInit(code, mode, env))
  326. return false;
  327. bool re = true;
  328. af_SignalInfo si;
  329. aFunSignalInit(&si);
  330. /*
  331. * 问题: 如何确保循环跳出之前, top-Activity已经被pop。(即执行释放)
  332. * 为什么会有这个问题: top-Activity只有在bt_next=NULL时被pop, 而循环也是在bt_next=NULL时可能被退出
  333. * 如此以来就可能导致在pop之前循环就退出了
  334. * 实际上并不会发生。
  335. * bt_next设定后,会出现两种情况: 一是马上检查bt_next, 而是设定了pass
  336. * 设定了pass是意味着压入新的activity。当新的activity被返回时, 必定设置了process_msg_first
  337. * 而process_msg_first时, 也会检查bt_next
  338. *
  339. * 【run-code设置了bt_next】 -> 检查bt_next并可能做pop处理 -> while循环检查bt_next [例如变量访问语句]
  340. * 【run-code设置了bt_next】 -> 压入了新的activity -> while循环检查 和一系列运行
  341. * -> 新activity返回, 设定process_msg_first -> while循环检查 (因为process_msg_first, 所以不会跳出循环)
  342. * -> process_msg_first会处理msg, 检查bt_next.
  343. *
  344. * popActivity会是一定会设置process_msg_first, 除了gc机制。
  345. * 而gc机制前后, bt_next不会改变,这意味着如果gc之后while循环就会被跳出, 那么gc之前while循环早就跳出了
  346. */
  347. /* 必须位于act_top, 且无next, 并且无msg处理才退出执行 */
  348. while (env->activity->type != act_top || env->activity->bt_next != NULL || env->activity->process_msg_first != 0) {
  349. /* 检查是否需要退出执行 */
  350. if (checkStop(env)) {
  351. re = false;
  352. goto RETURN;
  353. }
  354. /* 检查gc机制 */
  355. checkRunGC(env);
  356. if (env->activity->type == act_gc) {
  357. if (env->activity->dl_next == NULL)
  358. popActivity(true, NULL, env); // 结束运行
  359. else
  360. pushDestructActivity(env->activity->dl_next, env);
  361. continue;
  362. } else if (env->activity->type == act_guardian) {
  363. if (env->activity->dl_next == NULL)
  364. popActivity(true, NULL, env); // 结束运行
  365. else
  366. pushGuadianFuncActivity(env->activity->gl_next, env);
  367. continue;
  368. }
  369. /* 切换执行的var_list */
  370. if (env->activity->type == act_func && env->activity->status == act_func_arg &&
  371. env->activity->run_in_func && env->activity->func_var_list != NULL)
  372. env->activity->vsl = env->activity->func_var_list;
  373. else
  374. env->activity->vsl = env->activity->var_list;
  375. /* 无代码运行 */
  376. if (env->activity->bt_next == NULL && env->activity->process_msg_first == 0) { // 无代码运行, 并且非msg_first
  377. switch (env->activity->status) {
  378. case act_func_get:
  379. case act_func_normal:
  380. popActivity(false, makeERRORMessage(RUN_ERROR, NOT_CODE_INFO, env), env);
  381. break;
  382. case act_func_arg: // 无参数设定
  383. if (!setFuncActivityAddVar(env))
  384. popActivity(false, NULL, env);
  385. break;
  386. default:
  387. break;
  388. }
  389. continue; // 后面的代码不再运行
  390. }
  391. /* 有代码运行 */
  392. bool pass_msg = false; // 表示不处理msg
  393. if (env->activity->process_msg_first == 0) { /* 运行实际代码 */
  394. switch (env->activity->bt_next->type) {
  395. case code_element:
  396. if (codeElement(env->activity->bt_next, env))
  397. pass_msg = true;
  398. break;
  399. case code_block:
  400. if (codeBlock(env->activity->bt_next, env))
  401. pass_msg = true; // 若运行成功则跳转到下一次运行, 该步骤仅为设置Activity
  402. break;
  403. default:
  404. break;
  405. }
  406. } else
  407. env->activity->process_msg_first--;
  408. if (pass_msg)
  409. continue; // 后面的代码不再运行
  410. /* 执行守护器 */
  411. if (runGuardian(env))
  412. continue; // 需要执行守护器
  413. /* 处理msg */
  414. af_Message *msg = getTopMsg(env);
  415. switch (checkMsg(msg, env)) {
  416. case 0: // 不可处理的信号
  417. popActivity(false, NULL, env); // 跳出当前activity
  418. continue; // 下面的代码不再执行
  419. case 1: // 正常信号
  420. if (env->activity->return_first && env->activity->return_obj == NULL) // 设置return_first
  421. env->activity->return_obj = *(af_Object **)msg->msg;
  422. break;
  423. case -1: // NORMAL模式下, 非正常但可处理 [已经放回]
  424. default:
  425. assertErrorLog(env->activity->status == act_func_normal, aFunCoreLogger, "");
  426. break;
  427. }
  428. switch (env->activity->status) {
  429. case act_func_normal: // 需要考虑 msg == NULL
  430. if (checkNormalEnd(msg, env))
  431. popActivity(true, NULL, env); // 正常退出
  432. break;
  433. case act_func_get: {
  434. af_Object *func = *(af_Object **) (msg->msg); // func仍保留了msg的gc计数
  435. gc_delReference(func); // 释放计数
  436. freeMessage(msg);
  437. if (!setFuncActivityToArg(func, env))
  438. popActivity(false, NULL, env);
  439. break;
  440. }
  441. case act_func_arg: {
  442. if (checkGetArgEnd(msg, env)) { // 参数设定完成
  443. if (!setFuncActivityAddVar(env))
  444. popActivity(false, NULL, env);
  445. }
  446. break;
  447. }
  448. default:
  449. break;
  450. }
  451. }
  452. RETURN:
  453. aFunSignalRecover(&si);
  454. env->in_run = false;
  455. return re;
  456. }
  457. /*
  458. * 函数名: iterDestruct
  459. * 目标: 对所有ObjectData执行析构函数
  460. * 会循环不断检测是否有新增ObjectData并且需要析构
  461. * deep - 表示最大迭代深度 (设置为0表示不限制)
  462. */
  463. bool iterDestruct(int deep, af_Environment *env) {
  464. for (int count = 0; deep == 0 || deep > count; count++) {
  465. gc_DestructList *dl = NULL;
  466. pgc_DestructList pdl = &dl;
  467. pdl = checkAllDestruct(env, pdl);
  468. if (dl == NULL)
  469. return true;
  470. pushGCActivity(dl, pdl, env);
  471. if (!iterCode(NULL, 3, env))
  472. return false;
  473. }
  474. return false;
  475. }