123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538 |
- #include "aFunCore.hpp"
- #include "__run.hpp"
- #include "__env.hpp"
- /* 工具函数: 初始化类型 */
- static bool iterCodeInit(af_Code *code, int mode, af_Environment *env);
- /* 工具函数: Message类函数 */
- static af_Message *getTopMsg(af_Environment *env);
- /* 工具函数: 检查类型 */
- static bool checkInMsgType(char *type, af_Environment *env);
- static bool checkLiteral(af_Message **msg, af_Environment *env);
- static int checkMacro(af_Message *msg, af_Environment *env);
- static int checkMsg(af_Message *msg, af_Environment *env);
- bool checkNormalEnd(af_Message *msg, af_Environment *env);
- static bool checkGetArgEnd(af_Message *msg, af_Environment *env);
- static bool checkStop(af_Environment *env);
- /* Code 执行函数 */
- static bool codeElement(af_Code *code, af_Environment *env);
- static bool codeBlock(af_Code *code, af_Environment *env);
- static bool runGuardian(af_Environment *env);
- /*
- * 函数名: checkInMsgType
- * 目标: 检查type是否在对应的msg_type中 (检查该activity是否可以处理该信息)
- */
- static bool checkInMsgType(char *type, af_Environment *env) {
- if (env->activity->body_next == nullptr || env->activity->body_next->msg_type == nullptr)
- return false;
- for (char *msg_type_node = *env->activity->body_next->msg_type; msg_type_node != nullptr; msg_type_node++) {
- if (EQ_STR(type, msg_type_node))
- return true;
- }
- return false;
- }
- /*
- * 函数名: checkLiteral
- * 目标: 检查是否字面量调用, 若是则返回true并调用API, 否则返回false不做修改
- */
- static bool checkLiteral(af_Message **msg, af_Environment *env) {
- if (!env->activity->is_literal) // 非字面量
- return true;
- if ((*msg) == nullptr || !EQ_STR((*msg)->type, "NORMAL")) // (*msg)非正常值
- return false;
- af_Object *obj = *(af_Object **)((*msg)->msg);
- auto func = (obj_literalSetting *)findAPI("obj_literalSetting", getObjectAPI(obj));
- if (func == nullptr) {
- gc_delObjectReference(obj, env);
- freeMessage(*msg);
- *msg = makeERRORMessage(TYPE_ERROR, API_NOT_FOUND_INFO(obj_literalSetting), env);
- return false;
- }
- for (af_LiteralDataList *ld = env->activity->ld; ld != nullptr; ld = ld->next)
- func(getObjectID(obj), obj, getObjectData(obj), ld->literal_data, env);
- freeAllLiteralData(env->activity->ld);
- env->activity->ld = nullptr;
- env->activity->is_literal = false;
- writeTrackLog(aFunCoreLogger, "Literal %p", obj);
- return true;
- }
- /*
- * 函数名: checkMacro
- * 目标: 检查是否宏函数调用, 若是则返回true并修改activity隐式调用(activity继续执行时则会执行该调用), 否则返回false不做修改
- * 返回值:
- * -1 非宏函数
- * 0 错误
- * 1 宏函数
- */
- static int checkMacro(af_Message *msg, af_Environment *env) {
- if (env->activity->fi == nullptr || !env->activity->fi->is_macro) // 非宏函数
- return -1;
- if (!EQ_STR(msg->type, "NORMAL")) // msg非正常值
- return -1;
- af_Object *obj = *(af_Object **)(msg->msg);
- bool re = pushMacroFuncActivity(obj, env);
- gc_delObjectReference(obj, env);
- freeMessage(msg);
- if (re)
- return 1;
- return 0;
- }
- /*
- * 函数名: iterCodeInit
- * 目标: 初始化activity和environment (若environment中未存在activity则通过code新增一个TopActivity, 否则沿用原activity)
- *
- * mode 标识运行模式
- * 0. 在top运行
- * 1. 在import运行
- * 2. 直接运行
- * 3. gc模式
- */
- static bool iterCodeInit(af_Code *code, int mode, af_Environment *env) {
- if (env == nullptr || pthread_mutex_trylock(&env->in_run) != 0)
- return false;
- if (env->activity == nullptr) {
- pthread_mutex_unlock(&env->in_run);
- return false;
- }
- switch (mode) {
- case 0:
- if (env->activity->type != act_top || !codeSemanticCheck(code))
- return false;
- setActivityBtTop(nullptr, env->activity); // 直接就在NORMAL期, bt_top不被设定
- setActivityBtStart(code, env->activity);
- break;
- case 1: {
- if (env->activity->type != act_top)
- return false;
- env->activity->file = strCopy("top.aun.sys");
- char *name = getFileName(code->path);
- pushImportActivity(code, nullptr, name, env);
- free(name);
- break;
- }
- case 2:
- if (env->activity->prev == nullptr || env->activity->prev->type != act_top)
- return false;
- env->activity->file = strCopy("top-gc.aun.sys");
- if (env->activity->type == act_guardian || !codeSemanticCheck(env->activity->bt_start) || env->activity->bt_next == nullptr || code != nullptr)
- return false;
- break;
- case 3:
- pthread_mutex_lock(&env->status_lock);
- env->status = core_normal_gc;
- pthread_mutex_unlock(&env->status_lock);
- if (env->activity->type != act_guardian || code != nullptr)
- return false;
- break;
- default:
- return false;
- }
- return true;
- }
- /*
- * 函数名: codeElement
- * 目标: 执行变量访问或字面量生成 (设置bt_next)
- * (1) 执行字面量生成代码 (设置bt_next)
- * 返回-false 表示执行错误 (msg_down中写入消息)
- * 返回-true 表示执行成功 (msg_down中无消息写入, 函数仅设置activity无实质性代码执行)
- * (2) 执行变量访问代码:
- * 返回-false 表示执行失败, 或执行成功得到一个变量值 (msg_down中写入消息)
- * 返回-true 表示执行成功, 得到一个对象函数, 并且隐式调用 (msg_down中无消息写入, 函数仅设置activity无实质性代码执行)
- */
- static bool codeElement(af_Code *code, af_Environment *env) {
- bool in_protect;
- char *func;
- af_Var *var;
- if (checkLiteralCode(code->element.data, &func, &in_protect, env)) {
- /* 字面量执行 */
- if (in_protect)
- var = findVarFromVarSpace(func, env->activity->belong, env->protect);
- else
- var = findVarFromVarList(func, env->activity->belong, env->activity->run_varlist);
- if (var == nullptr) {
- pushMessageDown(makeERRORMessageFormat(LITERAL_ERROR, env, "Literal not found: %s: %s.", code->element.data, func), env);
- return false;
- }
- af_Object *obj = findVarNode(var, nullptr, env);
- writeTrackLog(aFunCoreLogger, "Get literal %s : %p", code->element.data, obj);
- bool res = pushLiteralActivity(code, code->element.data, obj, env);
- gc_delObjectReference(obj, env);
- return res;
- }
- /* 变量执行 */
- var = findVarFromVarList(code->element.data, env->activity->belong, env->activity->run_varlist);
- if (var == nullptr) {
- pushMessageDown(makeERRORMessageFormat(VARIABLE_ERROR, env, "Variable not found: %s.", code->element.data), env);
- return false;
- }
- af_Object *obj = findVarNode(var, nullptr, env);
- obj_isObjFunc *is_obj;
- obj_isInfixFunc *is_infix;
- if (code->prefix != getPrefix(E_QUOTE, env)) {
- af_ObjectAPI *api = getObjectAPI(obj);
- const char *id = getObjectID(obj);
- if ((is_obj = (obj_isObjFunc *)findAPI("obj_isObjFunc", api)) != nullptr && is_obj(id, obj)) {
- bool res = pushVariableActivity(code, obj, env); // 对象函数
- gc_delObjectReference(obj, env);
- return res;
- } else if (env->activity->status != act_func_get && // 在act_func_get 模式下不检查是否为is_infix函数 因为本来就要将其作为函数调用
- (is_infix = (obj_isInfixFunc *)findAPI("obj_isInfixFunc", api)) != nullptr && is_infix(id, obj)) {
- pushMessageDown(makeERRORMessageFormat(INFIX_PROTECT, env,
- "Infix protect variable: %s.", code->element.data), env);
- gc_delObjectReference(obj, env);
- return false;
- }
- }
- pushMessageDown(makeNORMALMessage(obj, env), env);
- setActivityBtNext(env->activity->bt_next->next, env->activity);
- writeTrackLog(aFunCoreLogger, "Get variable %s : %p", code->element.data, obj);
- return false;
- }
- /*
- * 函数名: codeBlock
- * 目标: 执行括号语法 (顺序执行, 函数调用)
- * 返回-false 表示执行错误 (msg_down中写入消息)
- * 返回-true 表示执行成功 (msg_down中无消息写入, 函数仅设置activity无实质性代码执行)
- */
- static bool codeBlock(af_Code *code, af_Environment *env) {
- if (code->prefix == getPrefix(B_EXEC, env) && code->block.type == parentheses) // 顺序执行, 返回尾项
- return pushExecutionActivity(code, false, env);
- else if (code->prefix == getPrefix(B_EXEC_FIRST, env) && code->block.type == brackets) // 顺序执行, 返回首项
- return pushExecutionActivity(code, true, env);
- else
- return pushFuncActivity(env->activity->bt_next, env);
- }
- static bool runGuardian(af_Environment *env) {
- af_GuardianList *gl = nullptr;
- af_GuardianList **pgl = ≷
- for (af_Guardian *gd = env->guardian; gd != nullptr; gd = gd->next) {
- if (gd->always || !env->activity->is_guard) { // guardian被标记为一直执行, 或者非is_guard模式
- af_GuardianList *new_gl = GET_SYMBOL(gd->func)(gd->type, env->activity->is_guard, gd->data, env);
- if (new_gl != nullptr)
- pgl = contectGuardianList(new_gl, pgl);
- }
- }
- if (gl != nullptr) {
- env->activity->process_msg_first++; // guardian开始处理时, 已经在原activity中有msg了, 所以要先处理
- pushGuardianActivity(gl, pgl, env);
- return true;
- }
- return false;
- }
- /*
- * 函数名: getTopMsg
- * 目标: 获取msg_down顶层信息, 若没有则产生错误
- */
- static af_Message *getTopMsg(af_Environment *env) {
- if (env->activity->msg_down == nullptr) // 若未获得 msg
- return makeERRORMessage(RUN_ERROR, NOT_MSG_INFO, env);
- else
- return getFirstMessage(env);
- }
- /*
- * 函数名: checkMsg
- * 目标: 检查msg是否为NORMAL, 并且检查该信号是否可被处理
- * 返回- (1) 正常
- * 返回- (0) 不可处理的信号
- * 返回-(-1) 非正常但通过msg_type判断为可被处理的信号
- */
- static int checkMsg(af_Message *msg, af_Environment *env) {
- if (EQ_STR(msg->type, "NORMAL"))
- return 1; // 正常
- pushMessageDown(msg, env); // msg不弹出
- if (env->activity->status != act_func_normal || !checkInMsgType(msg->type, env)) { // 非normal模式, 或normal模式下msg_type不匹配该msg
- env->activity->return_first = false;
- pthread_mutex_lock(env->activity->gc_lock);
- env->activity->return_obj = nullptr;
- pthread_mutex_unlock(env->activity->gc_lock);
- return 0;
- }
- return -1; // 遇到非normal, 但继续运行
- }
- /*
- * 函数名: checkNormalEnd
- * 目标: 检查act_normal是否运行到结尾 (若运行到结尾则返回true, 否则返回false)
- */
- bool checkNormalEnd(af_Message *msg, af_Environment *env) {
- if (env->activity->bt_next == nullptr) {
- if (env->activity->type == act_top || env->activity->type == act_top_import) {
- pushMessageDown(msg, env);
- return true;
- } else if (setFuncActivityToNormal(env) == 0) { // 已经没有下一步了
- if (msg == nullptr) { // msg 得不到处理
- pushMessageDown(makeERRORMessage(RUN_ERROR, NOT_NORMAL_MSG_INFO, env), env);
- return true;
- }
- switch (checkMacro(msg, env)) {
- case 0:
- return true; // 错误
- case 1:
- return false; // 宏函数
- case -1:
- default:
- break; // 非宏函数
- }
- checkLiteral(&msg, env); // 检查是否字面量
- pushMessageDown(msg, env);
- return true;
- } else if (msg != nullptr) {
- gc_delObjectReference(*(af_Object **) (msg->msg), env); // msg->msg是一个指针, 这个指针的内容是一个af_Object *
- freeMessage(msg);
- }
- } else if (msg != nullptr) {
- if (env->activity->bt_next->type == code_block && env->activity->bt_next->block.type == parentheses &&
- env->activity->bt_next->prefix != getPrefix(B_EXEC, env)) {
- pthread_mutex_lock(env->activity->gc_lock);
- env->activity->parentheses_call = *(af_Object **) (msg->msg); // 类前缀调用
- pthread_mutex_unlock(env->activity->gc_lock);
- }
- gc_delObjectReference(*(af_Object **)(msg->msg), env); // msg->msg是一个指针, 这个指针的内容是一个af_Object *
- freeMessage(msg);
- }
- return false;
- }
- /*
- * 函数名: checkGetArgEnd
- * 目标: 检查act_arg是否运行到结尾 (若运行到结尾则返回true, 否则返回false)
- */
- static bool checkGetArgEnd(af_Message *msg, af_Environment *env) {
- env->activity->acl_done->result = *(af_Object **)(msg->msg); // 保持 gc 引用计数
- freeMessage(msg);
- if (env->activity->acl_done->next == nullptr) { // 参数设定结束
- setArgCodeListToActivity(nullptr, env);
- return true;
- }
- env->activity->acl_done = env->activity->acl_done->next;
- setArgCodeListToActivity(env->activity->acl_done, env);
- return false;
- }
- static bool checkStop(af_Environment *env) {
- enum af_CoreStatus status = getCoreStatus(env);
- if (status == core_stop || status == core_exit) {
- while (env->activity->type != act_top || env->activity->prev != nullptr)
- popActivity(false, nullptr, env); // is_normal=false, 非正常退出, 释放mark
- popActivity(false, nullptr, env); // 再释放 act_top
- return true;
- }
- return false;
- }
- /*
- * 函数名: iterCode
- * 目标: 运行代码 (代码可通过code参数传入, 或通过env->activity传入)
- * 注意: 曾为缩短改函数而将该函数的内容进行大量的封装
- * 但实际上, 这个函数各个部分的关联性是很强的
- * 因此, 取消了封装, 反而提高了代码的可读性
- *
- * 因为该函数的大部分内容运行在循环中, 因此使用continue表示不在运行后面的代码
- */
- bool iterCode(af_Code *code, int mode, af_Environment *env){
- if (!iterCodeInit(code, mode, env))
- return false;
- bool re = true;
- makeMonitor(env); // 启动监视线程
- /*
- * 问题: 如何确保循环跳出之前, top-Activity已经被pop。(即执行释放)
- * 为什么会有这个问题: top-Activity只有在bt_next=nullptr时被pop, 而循环也是在bt_next=nullptr时可能被退出
- * 如此以来就可能导致在pop之前循环就退出了
- * 实际上并不会发生。
- * bt_next设定后,会出现两种情况: 一是马上检查bt_next, 而是设定了pass
- * 设定了pass是意味着压入新的activity。当新的activity被返回时, 必定设置了process_msg_first
- * 而process_msg_first时, 也会检查bt_next
- *
- * 【run-code设置了bt_next】 -> 检查bt_next并可能做pop处理 -> while循环检查bt_next [例如变量访问语句]
- * 【run-code设置了bt_next】 -> 压入了新的activity -> while循环检查 和一系列运行
- * -> 新activity返回, 设定process_msg_first -> while循环检查 (因为process_msg_first, 所以不会跳出循环)
- * -> process_msg_first会处理msg, 检查bt_next.
- *
- * popActivity会是一定会设置process_msg_first, 除了gc机制。
- * 而gc机制前后, bt_next不会改变,这意味着如果gc之后while循环就会被跳出, 那么gc之前while循环早就跳出了
- */
- /* 必须位于act_top, 且无next, 并且无msg处理才退出执行 */
- while (env->activity->type != act_top || env->activity->bt_next != nullptr || env->activity->process_msg_first != 0) {
- /* 检查是否需要退出执行 */
- if (checkStop(env)) {
- re = false;
- goto RETURN;
- }
- if (env->activity->type == act_guardian) {
- if (env->activity->gl_next == nullptr) {
- popActivity(true, nullptr, env); // 结束运行
- if (mode == 3) // mode = 3, 表示只运行守护器
- break;
- } else
- pushGuadianFuncActivity(env->activity->gl_next, env);
- continue;
- }
- /* 切换执行的 var_list */
- pthread_mutex_lock(env->activity->gc_lock);
- if (env->activity->type == act_func && env->activity->status == act_func_arg) {
- if (env->activity->run_in_func && env->activity->func_varlist != nullptr)
- env->activity->run_varlist = env->activity->func_varlist;
- else
- env->activity->run_varlist = env->activity->out_varlist;
- env->activity->count_run_varlist = 0;
- } else if (env->activity->type == act_func && env->activity->status == act_func_get) {
- env->activity->run_varlist = env->activity->out_varlist;
- env->activity->count_run_varlist = 0;
- }
- pthread_mutex_unlock(env->activity->gc_lock);
- /* 无代码运行 */
- if (env->activity->bt_next == nullptr && env->activity->process_msg_first == 0) { // 无代码运行, 并且非msg_first
- switch (env->activity->status) {
- case act_func_get:
- case act_func_normal:
- popActivity(false, makeERRORMessage(RUN_ERROR, NOT_CODE_INFO, env), env);
- break;
- case act_func_arg: // 无参数设定
- if (!setFuncActivityAddVar(env))
- popActivity(false, nullptr, env);
- break;
- default:
- break;
- }
- continue; // 后面的代码不再运行
- }
- /* 有代码运行 */
- bool pass_msg = false; // 表示不处理msg
- if (env->activity->process_msg_first == 0) { /* 运行实际代码 */
- env->activity->bt_done = env->activity->bt_next;
- switch (env->activity->bt_done->type) {
- case code_element:
- if (codeElement(env->activity->bt_done, env))
- pass_msg = true;
- break;
- case code_block:
- if (codeBlock(env->activity->bt_done, env))
- pass_msg = true; // 若运行成功则跳转到下一次运行, 该步骤仅为设置Activity
- break;
- default:
- break;
- }
- } else
- env->activity->process_msg_first--;
- if (pass_msg)
- continue; // 后面的代码不再运行
- /* 执行守护器 */
- if (runGuardian(env))
- continue; // 需要执行守护器
- /* 处理msg */
- af_Message *msg = getTopMsg(env);
- switch (checkMsg(msg, env)) {
- case 0: // 不可处理的信号
- popActivity(false, nullptr, env); // 跳出当前activity
- continue; // 下面的代码不再执行
- case 1: // 正常信号
- if (env->activity->return_first && env->activity->return_obj == nullptr) { // 设置return_first
- pthread_mutex_lock(env->activity->gc_lock);
- env->activity->return_obj = *(af_Object **) msg->msg;
- pthread_mutex_unlock(env->activity->gc_lock);
- }
- break;
- case -1: // NORMAL模式下, 非正常但可处理 [已经放回]
- default:
- assertErrorLog(env->activity->status == act_func_normal, aFunCoreLogger, "");
- break;
- }
- switch (env->activity->status) {
- case act_func_normal: // 需要考虑 msg == nullptr
- if (checkNormalEnd(msg, env))
- popActivity(true, nullptr, env); // 正常退出
- break;
- case act_func_get: {
- af_Object *func = *(af_Object **) (msg->msg); // func仍保留了msg的gc计数
- if (!setFuncActivityToArg(func, env))
- popActivity(false, nullptr, env);
- gc_delObjectReference(func, env); // 释放计数 (setFuncActivityToArg 不需要计数)
- freeMessage(msg);
- break;
- }
- case act_func_arg: {
- if (checkGetArgEnd(msg, env)) { // 参数设定完成
- if (!setFuncActivityAddVar(env))
- popActivity(false, nullptr, env);
- }
- break;
- }
- default:
- break;
- }
- }
- RETURN:
- pthread_mutex_unlock(&env->in_run);
- freeMonitor(env);
- return re;
- }
- /*
- * 函数名: iterDestruct
- * 目标: 对所有ObjectData执行析构函数
- * 会循环不断检测是否有新增ObjectData并且需要析构
- * deep - 表示最大迭代深度 (设置为0表示不限制)
- */
- bool iterDestruct(int deep, af_Environment *env) {
- for (int count = 0; deep == 0 || deep > count; count++) {
- af_GuardianList *gl = nullptr;
- paf_GuardianList pdl = ≷
- pdl = checkAllDestruct(env, pdl);
- if (gl == nullptr)
- return true;
- pushGuardianActivity(gl, pdl, env);
- if (!iterCode(nullptr, 3, env))
- return false;
- }
- pthread_mutex_lock(&env->status_lock);
- env->status = core_exit;
- pthread_mutex_unlock(&env->status_lock);
- return false;
- }
|