2021-10-13 18:05:54 +08:00
|
|
|
#include "PikaParser.h"
|
|
|
|
#include "PikaObj.h"
|
|
|
|
#include "dataQueueObj.h"
|
|
|
|
#include "dataStrs.h"
|
|
|
|
|
2021-10-13 20:07:32 +08:00
|
|
|
char* strsPopStmts(Args* buffs, char* stmts) {
|
|
|
|
int32_t size = strGetSize(stmts);
|
|
|
|
if (0 == size) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
char* strOut = args_getBuff(buffs, size);
|
|
|
|
int32_t iOut = 0;
|
|
|
|
char delChar = ' ';
|
|
|
|
int32_t stmtEnd = 0;
|
|
|
|
uint8_t isGetSign = 0;
|
|
|
|
int32_t parentheseDeepth = 0;
|
|
|
|
for (int32_t i = 0; i < size; i++) {
|
|
|
|
if ('(' == stmts[i]) {
|
|
|
|
parentheseDeepth++;
|
|
|
|
}
|
|
|
|
if (')' == stmts[i]) {
|
|
|
|
parentheseDeepth--;
|
|
|
|
}
|
|
|
|
if (parentheseDeepth == 0) {
|
|
|
|
if (',' == stmts[i]) {
|
|
|
|
stmtEnd = i;
|
|
|
|
isGetSign = 1;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!isGetSign) {
|
|
|
|
stmtEnd = size;
|
|
|
|
}
|
|
|
|
for (int32_t i = 0; i < stmtEnd; i++) {
|
|
|
|
strOut[i] = stmts[i];
|
|
|
|
}
|
|
|
|
memmove(stmts, stmts + stmtEnd + 1, size);
|
|
|
|
strOut[stmtEnd] = 0;
|
|
|
|
return strOut;
|
|
|
|
}
|
|
|
|
|
2021-10-13 19:41:04 +08:00
|
|
|
AST* AST_parseStmt(AST* ast, char* stmt) {
|
2021-10-13 18:05:54 +08:00
|
|
|
Args* buffs = New_strBuff();
|
2021-10-13 18:24:38 +08:00
|
|
|
char* assignment = strsGetFirstToken(buffs, stmt, '(');
|
2021-10-13 18:05:54 +08:00
|
|
|
char* direct = NULL;
|
2021-10-13 18:24:38 +08:00
|
|
|
char* method = NULL;
|
2021-10-13 21:20:45 +08:00
|
|
|
char* ref = NULL;
|
2021-10-14 09:51:50 +08:00
|
|
|
char* str = NULL;
|
2021-10-14 15:08:45 +08:00
|
|
|
char* num = NULL;
|
|
|
|
uint8_t directExist = 0, isMethod = 0, isRef = 0, isStr = 0, isNum = 0;
|
2021-10-13 18:05:54 +08:00
|
|
|
if (strIsContain(assignment, '=')) {
|
2021-10-13 21:20:45 +08:00
|
|
|
directExist = 1;
|
|
|
|
}
|
|
|
|
if (strIsContain(stmt, '(') || strIsContain(stmt, ')')) {
|
|
|
|
isMethod = 1;
|
2021-10-14 09:51:50 +08:00
|
|
|
isStr = 0;
|
2021-10-14 15:08:45 +08:00
|
|
|
isNum = 0;
|
|
|
|
isRef = 0;
|
2021-10-14 09:51:50 +08:00
|
|
|
}
|
|
|
|
if (!isMethod && (strIsContain(stmt, '\'') || strIsContain(stmt, '\"'))) {
|
|
|
|
isMethod = 0;
|
|
|
|
isStr = 1;
|
2021-10-14 15:08:45 +08:00
|
|
|
isNum = 0;
|
|
|
|
isRef = 0;
|
2021-10-14 09:51:50 +08:00
|
|
|
}
|
2021-10-14 15:08:45 +08:00
|
|
|
if (!isMethod && !isStr && (stmt[0] >= '0' && stmt[0] <= '9')) {
|
|
|
|
isMethod = 0;
|
|
|
|
isStr = 0;
|
|
|
|
isNum = 1;
|
|
|
|
isRef = 0;
|
|
|
|
}
|
|
|
|
if (!isMethod && !isStr && !isNum) {
|
2021-10-14 09:51:50 +08:00
|
|
|
isMethod = 0;
|
|
|
|
isStr = 0;
|
2021-10-14 15:08:45 +08:00
|
|
|
isNum = 0;
|
|
|
|
isRef = 1;
|
2021-10-13 21:20:45 +08:00
|
|
|
}
|
|
|
|
if (directExist) {
|
2021-10-13 18:05:54 +08:00
|
|
|
direct = strsGetFirstToken(buffs, assignment, '=');
|
2021-10-13 20:07:32 +08:00
|
|
|
obj_setStr(ast, (char*)"direct", direct);
|
2021-10-13 18:05:54 +08:00
|
|
|
}
|
2021-10-13 20:18:12 +08:00
|
|
|
char* subStmts = NULL;
|
2021-10-13 21:20:45 +08:00
|
|
|
if (isMethod) {
|
|
|
|
if (directExist) {
|
|
|
|
method = strsGetLastToken(buffs, assignment, '=');
|
|
|
|
} else {
|
|
|
|
method = assignment;
|
|
|
|
}
|
|
|
|
obj_setStr(ast, (char*)"method", method);
|
2021-10-13 20:18:12 +08:00
|
|
|
subStmts = strsCut(buffs, stmt, '(', ')');
|
|
|
|
while (1) {
|
|
|
|
char* subStmt = strsPopStmts(buffs, subStmts);
|
|
|
|
if (NULL == subStmt) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
queueObj_pushObj(ast, (char*)"stmt");
|
|
|
|
AST_parseStmt(queueObj_getCurrentObj(ast), subStmt);
|
2021-10-13 20:07:32 +08:00
|
|
|
}
|
2021-10-14 09:51:50 +08:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (isRef) {
|
2021-10-13 21:20:45 +08:00
|
|
|
if (directExist) {
|
|
|
|
ref = strsGetLastToken(buffs, assignment, '=');
|
|
|
|
} else {
|
|
|
|
ref = assignment;
|
|
|
|
}
|
|
|
|
obj_setStr(ast, (char*)"ref", ref);
|
2021-10-14 09:51:50 +08:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (isStr) {
|
|
|
|
if (directExist) {
|
|
|
|
str = strsGetLastToken(buffs, assignment, '=');
|
|
|
|
} else {
|
|
|
|
str = assignment;
|
|
|
|
}
|
|
|
|
str = strsDeleteChar(buffs, str, '\'');
|
|
|
|
str = strsDeleteChar(buffs, str, '\"');
|
|
|
|
obj_setStr(ast, (char*)"str", str);
|
|
|
|
goto exit;
|
2021-10-13 20:07:32 +08:00
|
|
|
}
|
2021-10-14 15:08:45 +08:00
|
|
|
if (isNum) {
|
|
|
|
if (directExist) {
|
|
|
|
num = strsGetLastToken(buffs, assignment, '=');
|
|
|
|
} else {
|
|
|
|
num = assignment;
|
|
|
|
}
|
|
|
|
obj_setStr(ast, (char*)"num", num);
|
|
|
|
goto exit;
|
|
|
|
}
|
2021-10-13 18:05:54 +08:00
|
|
|
exit:
|
|
|
|
args_deinit(buffs);
|
|
|
|
return ast;
|
|
|
|
}
|
|
|
|
|
2021-10-13 19:41:04 +08:00
|
|
|
AST* pikaParse(char* line) {
|
|
|
|
AST* ast = New_queueObj();
|
|
|
|
Args* buffs = New_strBuff();
|
2021-10-13 20:07:32 +08:00
|
|
|
char* stmt = strsGetCleanCmd(buffs, line);
|
2021-10-13 19:41:04 +08:00
|
|
|
ast = AST_parseStmt(ast, stmt);
|
|
|
|
goto exit;
|
|
|
|
exit:
|
|
|
|
args_deinit(buffs);
|
|
|
|
return ast;
|
|
|
|
}
|
2021-10-13 22:02:53 +08:00
|
|
|
|
2021-10-14 10:44:59 +08:00
|
|
|
char* pikaParseToAsm(Args* buffs, char* line) {
|
|
|
|
AST* ast = pikaParse(line);
|
|
|
|
char* pikaAsm = AST_toPikaAsm(ast, buffs);
|
|
|
|
AST_deinit(ast);
|
|
|
|
return pikaAsm;
|
|
|
|
}
|
|
|
|
|
2021-10-13 22:17:40 +08:00
|
|
|
char* AST_appandPikaAsm(AST* ast, AST* subAst, Args* buffs, char* pikaAsm) {
|
2021-10-13 22:02:53 +08:00
|
|
|
uint32_t deepth = obj_getInt(ast, "deepth");
|
2021-10-13 21:20:45 +08:00
|
|
|
while (1) {
|
2021-10-13 22:02:53 +08:00
|
|
|
QueueObj* subStmt = queueObj_popObj(subAst);
|
2021-10-13 21:20:45 +08:00
|
|
|
if (NULL == subStmt) {
|
|
|
|
break;
|
|
|
|
}
|
2021-10-13 22:02:53 +08:00
|
|
|
obj_setInt(ast, "deepth", deepth + 1);
|
2021-10-13 22:17:40 +08:00
|
|
|
pikaAsm = AST_appandPikaAsm(ast, subStmt, buffs, pikaAsm);
|
2021-10-13 21:20:45 +08:00
|
|
|
}
|
2021-10-13 22:02:53 +08:00
|
|
|
char* method = obj_getStr(subAst, "method");
|
|
|
|
char* ref = obj_getStr(subAst, "ref");
|
|
|
|
char* direct = obj_getStr(subAst, "direct");
|
2021-10-14 09:51:50 +08:00
|
|
|
char* str = obj_getStr(subAst, "str");
|
2021-10-14 15:08:45 +08:00
|
|
|
char* num = obj_getStr(subAst, "num");
|
2021-10-13 21:20:45 +08:00
|
|
|
if (NULL != ref) {
|
|
|
|
char buff[32] = {0};
|
2021-10-13 21:53:01 +08:00
|
|
|
sprintf(buff, "%d REF %s\n", deepth, ref);
|
2021-10-13 22:17:40 +08:00
|
|
|
pikaAsm = strsAppend(buffs, pikaAsm, buff);
|
2021-10-13 21:20:45 +08:00
|
|
|
}
|
|
|
|
if (NULL != method) {
|
|
|
|
char buff[32] = {0};
|
2021-10-13 21:53:01 +08:00
|
|
|
sprintf(buff, "%d RUN %s\n", deepth, method);
|
2021-10-13 22:17:40 +08:00
|
|
|
pikaAsm = strsAppend(buffs, pikaAsm, buff);
|
2021-10-13 21:20:45 +08:00
|
|
|
}
|
2021-10-14 09:51:50 +08:00
|
|
|
if (NULL != str) {
|
|
|
|
char buff[32] = {0};
|
|
|
|
sprintf(buff, "%d STR %s\n", deepth, str);
|
|
|
|
pikaAsm = strsAppend(buffs, pikaAsm, buff);
|
|
|
|
}
|
2021-10-13 21:20:45 +08:00
|
|
|
if (NULL != direct) {
|
|
|
|
char buff[32] = {0};
|
2021-10-13 21:53:01 +08:00
|
|
|
sprintf(buff, "%d OUT %s\n", deepth, direct);
|
2021-10-13 22:17:40 +08:00
|
|
|
pikaAsm = strsAppend(buffs, pikaAsm, buff);
|
2021-10-13 21:20:45 +08:00
|
|
|
}
|
2021-10-14 15:08:45 +08:00
|
|
|
if (NULL != num) {
|
|
|
|
char buff[32] = {0};
|
|
|
|
sprintf(buff, "%d NUM %s\n", deepth, num);
|
|
|
|
pikaAsm = strsAppend(buffs, pikaAsm, buff);
|
|
|
|
}
|
2021-10-13 22:02:53 +08:00
|
|
|
obj_setInt(ast, "deepth", deepth - 1);
|
2021-10-13 22:17:40 +08:00
|
|
|
return pikaAsm;
|
2021-10-13 21:20:45 +08:00
|
|
|
}
|
|
|
|
|
2021-10-13 22:17:40 +08:00
|
|
|
char* AST_toPikaAsm(AST* ast, Args* buffs) {
|
2021-10-14 10:05:55 +08:00
|
|
|
Args* runBuffs = New_strBuff();
|
|
|
|
char* pikaAsm = strsCopy(runBuffs, "");
|
2021-10-13 22:02:53 +08:00
|
|
|
obj_setInt(ast, "deepth", 0);
|
2021-10-14 10:05:55 +08:00
|
|
|
pikaAsm = AST_appandPikaAsm(ast, ast, runBuffs, pikaAsm);
|
|
|
|
pikaAsm = strsCopy(buffs, pikaAsm);
|
|
|
|
args_deinit(runBuffs);
|
|
|
|
return pikaAsm;
|
2021-10-13 18:05:54 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int32_t AST_deinit(AST* ast) {
|
|
|
|
return obj_deinit(ast);
|
|
|
|
}
|