grammar.c 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822
  1. #include "__grammar.h"
  2. ParserMessage *makeParserMessage(char *file_dir, char *debug){
  3. ParserMessage *tmp = memCalloc(1, sizeof(ParserMessage));
  4. tmp->tm = makeTokenMessage(file_dir, debug);
  5. tmp->status = success;
  6. tmp->status_message = NULL;
  7. tmp->count = 0;
  8. #if OUT_LOG
  9. if (debug != NULL){
  10. char *debug_dir = memStrcat(debug, PASERS_LOG), *grammar_dir = memStrcat(debug, GRAMMAR_LOG);
  11. tmp->paser_debug = fopen(debug_dir, "w");
  12. tmp->grammar_debug = fopen(grammar_dir, "w");
  13. memFree(debug_dir);
  14. memFree(grammar_dir);
  15. }
  16. else{
  17. tmp->paser_debug = NULL;
  18. tmp->grammar_debug = NULL;
  19. }
  20. #else
  21. tmp->paser_debug = NULL;
  22. tmp->grammar_debug = NULL;
  23. #endif
  24. return tmp;
  25. }
  26. void freeParserMessage(ParserMessage *pm, bool self) {
  27. freeTokenMessage(pm->tm, true);
  28. #if OUT_LOG
  29. if (pm->paser_debug != NULL)
  30. fclose(pm->paser_debug);
  31. if (pm->grammar_debug != NULL)
  32. fclose(pm->grammar_debug);
  33. #endif
  34. memFree(pm->status_message);
  35. if (self){
  36. memFree(pm);
  37. }
  38. }
  39. /**
  40. * 命令表匹配
  41. * parserCommandList :
  42. * | MATHER_EOF
  43. * | parserCommand MATHER_ENTER
  44. * | parserCommand MATHER_EOF
  45. */
  46. void parserCommandList(ParserMessage *pm, Inter *inter, bool global, Statement *st) {
  47. int token_type, stop;
  48. struct Statement *base_st = st;
  49. while (true){
  50. token_type = readBackToken(pm);
  51. if (token_type == MATHER_EOF){
  52. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command List: <EOF>\n", NULL);
  53. delToken(pm);
  54. goto return_;
  55. }
  56. else if (token_type == MATHER_ENTER){
  57. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command List: <ENTER>\n", NULL);
  58. delToken(pm);
  59. continue;
  60. }
  61. else{
  62. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command List: call command\n", NULL);
  63. Token *command_token;
  64. if (!callChildToken(CALLPASERSSIGNATURE, parserCommand, COMMAND, &command_token,
  65. (global ? "ERROR from command list(get parserCommand)" : NULL),
  66. command_list_error)){
  67. goto return_;
  68. }
  69. stop = readBackToken(pm);
  70. if (stop == MATHER_ENTER || stop == MATHER_SEMICOLON){
  71. delToken(pm);
  72. }
  73. else if(stop == MATHER_EOF){
  74. PASS;
  75. }
  76. else{
  77. if (global) {
  78. syntaxError(pm, command_list_error, 1, "ERROR from parserCommand list(get stop)");
  79. printf("stop = %d\n", stop);
  80. freeToken(command_token, true, true);
  81. }
  82. else{
  83. // 若非global模式, 即可以匹配大括号, token保留在ahead中
  84. connectStatement(base_st, command_token->data.st);
  85. freeToken(command_token, true, false);
  86. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG,
  87. "Command List: get command success[at !global end]\n", NULL);
  88. }
  89. goto return_;
  90. }
  91. /*...do something for commandList...*/
  92. connectStatement(base_st, command_token->data.st);
  93. freeToken(command_token, true, false);
  94. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command List: get command success\n", NULL);
  95. }
  96. }
  97. return_:
  98. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command List: return\n", NULL);
  99. addStatementToken(COMMANDLIST, base_st, pm);
  100. }
  101. /**
  102. * 命令匹配
  103. * parserCommand:
  104. * | parserOperation
  105. */
  106. void parserCommand(PASERSSIGNATURE){
  107. int token_type, status;
  108. Statement *st = NULL;
  109. token_type = readBackToken(pm);
  110. switch (token_type) {
  111. case MATHER_DEF :
  112. status = commandCallBack_(CALLPASERSSIGNATURE, parserDef, FUNCTION, &st, "Command: call def\n");
  113. break;
  114. case MATHER_IF :
  115. status = commandCallBack_(CALLPASERSSIGNATURE, parserIf, IF_BRANCH, &st, "Command: call if\n");
  116. break;
  117. case MATHER_WHILE :
  118. status = commandCallBack_(CALLPASERSSIGNATURE, parserWhile, WHILE_BRANCH, &st, "Command: call while\n");
  119. break;
  120. case MATHER_TRY :
  121. status = commandCallBack_(CALLPASERSSIGNATURE, parserTry, TRY_BRANCH, &st, "Command: call try\n");
  122. break;
  123. case MATHER_BREAK :
  124. status = commandCallControl_(CALLPASERSSIGNATURE, makeBreakStatement, BREAK, &st, "Command: call break\n");
  125. break;
  126. case MATHER_CONTINUE :
  127. status = commandCallControl_(CALLPASERSSIGNATURE, makeContinueStatement, CONTINUE, &st, "Command: call continue\n");
  128. break;
  129. case MATHER_RESTART :
  130. status = commandCallControl_(CALLPASERSSIGNATURE, makeRestartStatement, RESTART, &st, "Command: call restart\n");
  131. break;
  132. case MATHER_REGO :
  133. status = commandCallControl_(CALLPASERSSIGNATURE, makeRegoStatement, REGO, &st, "Command: call rego\n");
  134. break;
  135. case MATHER_RETURN :
  136. status = commandCallControl_(CALLPASERSSIGNATURE, makeReturnStatement, RETURN, &st, "Command: call return\n");
  137. break;
  138. case MATHER_RAISE :
  139. status = commandCallControl_(CALLPASERSSIGNATURE, makeRaiseStatement, RAISE, &st, "Command: call raise\n");
  140. break;
  141. default :
  142. status = commandCallBack_(CALLPASERSSIGNATURE, parserOperation, OPERATION, &st, "Command: call operation\n");
  143. break;
  144. }
  145. if (!status)
  146. goto return_;
  147. addStatementToken(COMMAND, st, pm);
  148. return_:
  149. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command: get return\n", NULL);
  150. }
  151. void parserControl(PASERSSIGNATURE, Statement *(*callBack)(Statement *), int type){
  152. Statement *times = NULL, *st = NULL;
  153. delToken(pm);
  154. parserOperation(CALLPASERSSIGNATURE);
  155. if (!call_success(pm))
  156. goto return_;
  157. if (readBackToken(pm) == OPERATION){
  158. Token *tmp;
  159. tmp= popAheadToken(pm);
  160. times = tmp->data.st;
  161. freeToken(tmp, true, false);
  162. }
  163. st = callBack(times);
  164. addStatementToken(type, st, pm);
  165. return_:
  166. return;
  167. }
  168. void parserIf(PASERSSIGNATURE){
  169. struct Statement *st = NULL, *else_st = NULL, *finally_st = NULL;
  170. StatementList *sl = NULL;
  171. bool have_if = false;
  172. // TODO-szh 设置重复警告 (添加PASS语句)
  173. again:
  174. switch (readBackToken(pm)) {
  175. case MATHER_IF:
  176. if (have_if)
  177. goto default_;
  178. else
  179. have_if = true;
  180. case MATHER_ELIF: {
  181. if (else_st != NULL) {
  182. syntaxError(pm, syntax_error, 1, "get elif after else\n");
  183. goto error_;
  184. }
  185. Statement *code_tmp = NULL, *var_tmp = NULL, *condition_tmp = NULL;
  186. delToken(pm);
  187. if (!callChildStatement(CALLPASERSSIGNATURE, parserOperation, OPERATION, &condition_tmp, "Don't get a if condition"))
  188. goto error_;
  189. if (!callParserAs(CALLPASERSSIGNATURE, &var_tmp, "Don't get a while var")) {
  190. freeStatement(condition_tmp);
  191. goto error_;
  192. }
  193. if (!callParserCode(CALLPASERSSIGNATURE, &code_tmp, "Don't get a if code")) {
  194. freeStatement(condition_tmp);
  195. freeStatement(var_tmp);
  196. goto error_;
  197. }
  198. sl = makeConnectStatementList(sl, condition_tmp, var_tmp, code_tmp, if_b);
  199. goto again;
  200. }
  201. case MATHER_DO: {
  202. if (else_st != NULL)
  203. goto default_;
  204. Statement *code_tmp = NULL;
  205. delToken(pm);
  206. if (!callParserCode(CALLPASERSSIGNATURE, &code_tmp, "Don't get a if...do code"))
  207. goto error_;
  208. sl = makeConnectStatementList(sl, NULL, NULL, code_tmp, do_b);
  209. goto again;
  210. }
  211. case MATHER_ELSE:
  212. if (else_st != NULL){
  213. syntaxError(pm, syntax_error, 1, "get else after else\n");
  214. goto error_;
  215. }
  216. delToken(pm);
  217. if (!callParserCode(CALLPASERSSIGNATURE, &else_st, "Don't get a if...else code"))
  218. goto error_;
  219. goto again;
  220. case MATHER_FINALLY:
  221. delToken(pm);
  222. if (!callParserCode(CALLPASERSSIGNATURE, &finally_st, "Don't get a if...else code"))
  223. goto error_;
  224. break;
  225. case MATHER_ENTER:
  226. delToken(pm);
  227. goto again;
  228. case MATHER_SEMICOLON:
  229. break;
  230. default:{
  231. default_:
  232. addLexToken(pm, MATHER_ENTER);
  233. break;
  234. }
  235. }
  236. st = makeIfStatement();
  237. st->u.if_branch.if_list = sl;
  238. st->u.if_branch.else_list = else_st;
  239. st->u.if_branch.finally = finally_st;
  240. addStatementToken(IF_BRANCH, st, pm);
  241. return;
  242. error_:
  243. freeStatement(else_st);
  244. freeStatement(finally_st);
  245. freeStatementList(sl);
  246. return;
  247. }
  248. void parserWhile(PASERSSIGNATURE){
  249. struct Statement *st = NULL, *else_st = NULL, *finally_st = NULL,*do_st = NULL;
  250. StatementList *sl = NULL;
  251. bool have_while = false;
  252. again:
  253. switch (readBackToken(pm)) {
  254. case MATHER_WHILE: {
  255. if (have_while)
  256. goto default_;
  257. else
  258. have_while = true;
  259. Statement *code_tmp = NULL, *var_tmp = NULL, *condition_tmp = NULL;
  260. delToken(pm);
  261. if (!callChildStatement(CALLPASERSSIGNATURE, parserOperation, OPERATION, &condition_tmp, "Don't get a while condition"))
  262. goto error_;
  263. if (!callParserAs(CALLPASERSSIGNATURE, &var_tmp, "Don't get a while var")){
  264. freeStatement(condition_tmp);
  265. goto error_;
  266. }
  267. if (!callParserCode(CALLPASERSSIGNATURE, &code_tmp, "Don't get a while code")) {
  268. freeStatement(condition_tmp);
  269. freeStatement(var_tmp);
  270. goto error_;
  271. }
  272. if (sl != NULL)
  273. freeStatementList(sl);
  274. sl = makeStatementList(condition_tmp, var_tmp, code_tmp, while_b);
  275. goto again;
  276. }
  277. case MATHER_DO:
  278. if (do_st != NULL || else_st != NULL)
  279. goto default_;
  280. delToken(pm);
  281. if (!callParserCode(CALLPASERSSIGNATURE, &do_st, "Don't get a while...do code"))
  282. goto error_;
  283. goto again;
  284. case MATHER_ELSE:
  285. if (else_st != NULL) {
  286. syntaxError(pm, syntax_error, 1, "get else after else\n");
  287. goto error_;
  288. }
  289. delToken(pm);
  290. if (!callParserCode(CALLPASERSSIGNATURE, &else_st, "Don't get a while...else code"))
  291. goto error_;
  292. goto again;
  293. case MATHER_FINALLY:
  294. delToken(pm);
  295. if (!callParserCode(CALLPASERSSIGNATURE, &finally_st, "Don't get a while...finally code"))
  296. goto error_;
  297. break;
  298. case MATHER_ENTER:
  299. delToken(pm);
  300. goto again;
  301. case MATHER_SEMICOLON:
  302. break;
  303. default: {
  304. default_:
  305. addLexToken(pm, MATHER_ENTER);
  306. break;
  307. }
  308. }
  309. st = makeWhileStatement();
  310. st->u.while_branch.while_list = sl;
  311. st->u.while_branch.else_list = else_st;
  312. st->u.while_branch.finally = finally_st;
  313. st->u.while_branch.after = do_st;
  314. addStatementToken(WHILE_BRANCH, st, pm);
  315. return;
  316. error_:
  317. freeStatement(else_st);
  318. freeStatement(finally_st);
  319. freeStatement(do_st);
  320. freeStatementList(sl);
  321. return;
  322. }
  323. void parserTry(PASERSSIGNATURE){
  324. struct Statement *st = NULL, *try_st = NULL, *else_st = NULL, *finally_st = NULL;
  325. StatementList *sl = NULL;
  326. again:
  327. switch (readBackToken(pm)) {
  328. case MATHER_TRY:{
  329. if (try_st != NULL)
  330. goto default_;
  331. delToken(pm);
  332. if (!callParserCode(CALLPASERSSIGNATURE, &try_st, "Don't get a try code"))
  333. goto error_;
  334. goto again;
  335. }
  336. case MATHER_EXCEPT: {
  337. Statement *code_tmp = NULL, *var_tmp = NULL, *condition_tmp = NULL;
  338. delToken(pm);
  339. callChildStatement(CALLPASERSSIGNATURE, parserOperation, OPERATION, &condition_tmp, NULL);
  340. if (!callParserAs(CALLPASERSSIGNATURE, &var_tmp, "Don't get a except var")){
  341. freeStatement(condition_tmp);
  342. goto error_;
  343. }
  344. if (!callParserCode(CALLPASERSSIGNATURE, &code_tmp, "Don't get a except code")) {
  345. freeStatement(condition_tmp);
  346. freeStatement(var_tmp);
  347. goto error_;
  348. }
  349. sl = makeConnectStatementList(sl, condition_tmp, var_tmp, code_tmp, except_b);
  350. goto again;
  351. }
  352. case MATHER_ELSE:
  353. if (else_st != NULL) {
  354. syntaxError(pm, syntax_error, 1, "get else after else\n");
  355. goto error_;
  356. }
  357. delToken(pm);
  358. if (!callParserCode(CALLPASERSSIGNATURE, &else_st, "Don't get a try...else code"))
  359. goto error_;
  360. goto again;
  361. case MATHER_FINALLY:
  362. delToken(pm);
  363. if (!callParserCode(CALLPASERSSIGNATURE, &finally_st, "Don't get a try...finally code"))
  364. goto error_;
  365. break;
  366. case MATHER_ENTER:
  367. delToken(pm);
  368. goto again;
  369. case MATHER_SEMICOLON:
  370. break;
  371. default: {
  372. default_:
  373. addLexToken(pm, MATHER_ENTER);
  374. break;
  375. }
  376. }
  377. st = makeTryStatement();
  378. st->u.try_branch.try = try_st;
  379. st->u.try_branch.except_list = sl;
  380. st->u.try_branch.else_list = else_st;
  381. st->u.try_branch.finally = finally_st;
  382. addStatementToken(TRY_BRANCH, st, pm);
  383. return;
  384. error_:
  385. freeStatement(try_st);
  386. freeStatement(else_st);
  387. freeStatement(finally_st);
  388. freeStatementList(sl);
  389. return;
  390. }
  391. /**
  392. * @param pm
  393. * @param inter
  394. * @param pt
  395. * @param is_formal 是否为形式参数, 若为true,则限定*args为only_value的结尾, **kwargs为name_value结尾
  396. * @param is_list 若为true则关闭对name_value和**kwargs的支持
  397. * @param is_dict 若为true则关闭对only_value和*args的支持
  398. * @param sep 设定分割符号
  399. * @param ass 设定赋值符号
  400. * @return
  401. */
  402. bool parserParameter(ParserMessage *pm, Inter *inter, Parameter **pt, bool is_formal, bool is_list, bool is_dict, int sep,
  403. int ass) {
  404. Parameter *new_pt = NULL;
  405. Token *tmp;
  406. enum {
  407. s_1, // only_value模式
  408. s_2, // name_value模式
  409. s_3, // only_args模式
  410. } status;
  411. if (is_dict)
  412. status = s_2; // is_formal关闭对only_value的支持
  413. else
  414. status = s_1;
  415. bool last_pt = false;
  416. while (!last_pt){
  417. tmp = NULL;
  418. if (!is_dict && status != s_2 && checkToken_(pm, MATHER_MUL)) // is_formal关闭对*args的支持
  419. status = s_3;
  420. parserPolynomial(CALLPASERSSIGNATURE);
  421. if (!call_success(pm))
  422. goto error_;
  423. if (readBackToken(pm) != POLYNOMIAL) {
  424. if (status == s_3) {
  425. syntaxError(pm, syntax_error, 1, "Don't get a parameter after *");
  426. goto error_;
  427. }
  428. break;
  429. }
  430. tmp = popAheadToken(pm);
  431. int pt_type = only_value;
  432. if (status == s_1){
  433. if (!checkToken_(pm, sep)){
  434. if (is_list || !checkToken_(pm, ass)) // // is_list关闭对name_value的支持
  435. last_pt = true;
  436. else {
  437. pt_type = name_value;
  438. status = s_2;
  439. }
  440. }
  441. }
  442. else if (status == s_2){
  443. pt_type = name_value;
  444. if (!checkToken_(pm, ass))
  445. goto error_;
  446. }
  447. else if (status == s_3){
  448. pt_type = only_args;
  449. if (!checkToken_(pm, sep))
  450. last_pt = true;
  451. }
  452. if (pt_type == only_value)
  453. new_pt = connectOnlyValueParameter(tmp->data.st, new_pt);
  454. else if (pt_type == name_value){
  455. Statement *tmp_value;
  456. if (!callChildStatement(CALLPASERSSIGNATURE, parserPolynomial, POLYNOMIAL, &tmp_value, "Don't get a parameter value"))
  457. goto error_;
  458. new_pt = connectNameValueParameter(tmp_value, tmp->data.st, new_pt);
  459. if (!checkToken_(pm, sep))
  460. last_pt = true;
  461. }
  462. else if (pt_type == only_args){
  463. new_pt = connectOnlyArgsParameter(tmp->data.st, new_pt);
  464. if (is_formal)
  465. status = s_2; // 是否规定*args只出现一次
  466. else
  467. status = s_1;
  468. }
  469. freeToken(tmp, true, false);
  470. }
  471. *pt = new_pt;
  472. return true;
  473. error_:
  474. freeToken(tmp, true, true);
  475. freeParameter(new_pt, true);
  476. *pt = NULL;
  477. return false;
  478. }
  479. void parserDef(PASERSSIGNATURE){
  480. struct Statement *st = NULL, *name_tmp = NULL, *code_tmp = NULL;
  481. Parameter *pt = NULL;
  482. delToken(pm);
  483. if (!callChildStatement(CALLPASERSSIGNATURE, parserBaseValue, BASEVALUE, &name_tmp, "Don't get a function name"))
  484. goto error_;
  485. if (!checkToken_(pm, MATHER_LP)) {
  486. syntaxError(pm, syntax_error, 1, "Don't get a function ( before parameter");
  487. goto error_;
  488. }
  489. if (!parserParameter(CALLPASERSSIGNATURE, &pt, true, false, false, MATHER_COMMA, MATHER_ASSIGNMENT)) {
  490. syntaxError(pm, syntax_error, 1, "Don't get a function parameter");
  491. goto error_;
  492. }
  493. if (!checkToken_(pm, MATHER_RP)) {
  494. syntaxError(pm, syntax_error, 1, "Don't get a function ) after parameter");
  495. goto error_;
  496. }
  497. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "parserDef: get function title success\n", NULL);
  498. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "parserDef: call parserCode\n", NULL);
  499. if (!callParserCode(CALLPASERSSIGNATURE, &code_tmp, "Don't get a function code")) {
  500. syntaxError(pm, syntax_error, 1, "Don't get a function code");
  501. goto error_;
  502. }
  503. st = makeFunctionStatement(name_tmp, code_tmp, pt);
  504. addLexToken(pm, MATHER_ENTER);
  505. addStatementToken(FUNCTION, st, pm);
  506. return;
  507. error_:
  508. freeStatement(name_tmp);
  509. freeStatement(code_tmp);
  510. return;
  511. }
  512. void parserCode(PASERSSIGNATURE){
  513. Token *code_token = NULL, *tk = NULL;
  514. Statement *st = makeStatement();
  515. while (true){
  516. if (!checkToken_(pm, MATHER_LC))
  517. goto again_;
  518. break;
  519. again_:
  520. if (!checkToken_(pm, MATHER_ENTER))
  521. goto return_;
  522. }
  523. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "parserCode: call parserCommandList\n", NULL);
  524. parserCommandList(CALLPASERSSIGNATURE, false, st);
  525. if (!call_success(pm)){
  526. goto error_;
  527. }
  528. if (readBackToken(pm) != COMMANDLIST){
  529. syntaxError(pm, syntax_error, 1, "Not CommandList\n");
  530. goto error_;
  531. }
  532. code_token = popAheadToken(pm);
  533. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "parserCode: call parserCommandList success\n", NULL);
  534. if (!checkToken_(pm, MATHER_RC)) {
  535. syntaxError(pm, syntax_error, 1, "Don't get the }");
  536. goto error_;
  537. }
  538. return_:
  539. addStatementToken(CODE, st, pm);
  540. freeToken(code_token, true, false);
  541. return;
  542. error_:
  543. freeToken(code_token, true, true);
  544. }
  545. /**
  546. * 表达式匹配
  547. * parserOperation:
  548. * | parserAssignment
  549. */
  550. void parserOperation(PASERSSIGNATURE){
  551. Statement *operation_st = NULL;
  552. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Operation: call assignment\n", NULL);
  553. if (!callChildStatement(CALLPASERSSIGNATURE, parserAssignment, ASSIGNMENT, &operation_st, NULL))
  554. goto return_;
  555. addStatementToken(OPERATION, operation_st, pm);
  556. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Operation: get polynomial success\n", NULL);
  557. return_:
  558. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Operation: return\n", NULL);
  559. return;
  560. }
  561. /**
  562. * 赋值表达式匹配
  563. * parserAssignment:
  564. * | parserPolynomial
  565. * | parserAssignment ASSIGNMENT parserPolynomial
  566. */
  567. bool switchAssignment(PASERSSIGNATURE, int symbol, Statement **st){
  568. switch (symbol) {
  569. case MATHER_ASSIGNMENT:
  570. *st = makeOperationStatement(ASS);
  571. break;
  572. default:
  573. return false;
  574. }
  575. return true;
  576. }
  577. void parserAssignment(PASERSSIGNATURE){
  578. return twoOperation(CALLPASERSSIGNATURE, parserTuple, switchAssignment, TUPLE, ASSIGNMENT,
  579. "polynomial", "assignment", true);
  580. }
  581. /**
  582. * 元组匹配
  583. * parserTuple
  584. * | switchPolynomial
  585. * | parserTuple COMMA switchPolynomial
  586. * @param pm
  587. * @param inter
  588. */
  589. void parserTuple(PASERSSIGNATURE){
  590. struct Parameter *pt = NULL;
  591. struct Statement *st = NULL;
  592. Token *tmp = NULL;
  593. if (!callChildToken(CALLPASERSSIGNATURE, parserPolynomial, POLYNOMIAL, &tmp, NULL, syntax_error))
  594. goto return_;
  595. if (!checkToken_(pm, MATHER_COMMA)){
  596. tmp->token_type = TUPLE;
  597. addToken_(pm ,tmp);
  598. goto return_;
  599. }
  600. addLexToken(pm, MATHER_COMMA);
  601. addToken_(pm ,tmp);
  602. if (!parserParameter(CALLPASERSSIGNATURE, &pt, false, true, false, MATHER_COMMA, MATHER_ASSIGNMENT)) {
  603. syntaxError(pm, syntax_error, 1, "Don't get tuple element");
  604. goto return_;
  605. }
  606. st = makeTupleStatement(pt, tuple_);
  607. addStatementToken(TUPLE, st, pm);
  608. return_:
  609. return;
  610. }
  611. /**
  612. * 多项式匹配
  613. * parserPolynomial:
  614. * | parserBaseValue
  615. * | parserPolynomial ADD parserFactor
  616. * | parserPolynomial SUB parserFactor
  617. */
  618. bool switchPolynomial(PASERSSIGNATURE, int symbol, Statement **st){
  619. switch (symbol) {
  620. case MATHER_ADD:
  621. *st = makeOperationStatement(ADD);
  622. break;
  623. case MATHER_SUB:
  624. *st = makeOperationStatement(SUB);
  625. break;
  626. default:
  627. return false;
  628. }
  629. return true;
  630. }
  631. void parserPolynomial(PASERSSIGNATURE){
  632. return twoOperation(CALLPASERSSIGNATURE, parserFactor, switchPolynomial, FACTOR, POLYNOMIAL,
  633. "factor", "polynomial", false);
  634. }
  635. /**
  636. * 因式匹配
  637. * parserFactor:
  638. * | parserBaseValue [1]
  639. * | switchFactor ADD parserBaseValue
  640. * | switchFactor SUB parserBaseValue
  641. */
  642. bool switchFactor(PASERSSIGNATURE, int symbol, Statement **st){
  643. switch (symbol) {
  644. case MATHER_MUL:
  645. *st = makeOperationStatement(MUL);
  646. break;
  647. case MATHER_DIV:
  648. *st = makeOperationStatement(DIV);
  649. break;
  650. default:
  651. return false;
  652. }
  653. return true;
  654. }
  655. void parserFactor(PASERSSIGNATURE){
  656. return twoOperation(CALLPASERSSIGNATURE, parserCallBack, switchFactor, CALLBACK, FACTOR,
  657. "call back", "factor", false);
  658. }
  659. int tailCall(PASERSSIGNATURE, Token *left_token, Statement **st){
  660. struct Parameter *pt = NULL;
  661. if (readBackToken(pm) != MATHER_LP)
  662. return -1;
  663. delToken(pm);
  664. if (!parserParameter(CALLPASERSSIGNATURE, &pt, false, false, false, MATHER_COMMA, MATHER_ASSIGNMENT)) {
  665. syntaxError(pm, syntax_error, 1, "Don't get call parameter");
  666. return 0;
  667. }
  668. if (!checkToken_(pm, MATHER_RP)){
  669. syntaxError(pm, syntax_error, 1, "Don't get ) from call back");
  670. return 0;
  671. }
  672. *st = makeCallStatement(left_token->data.st, pt);
  673. return 1;
  674. }
  675. void parserCallBack(PASERSSIGNATURE){
  676. return tailOperation(CALLPASERSSIGNATURE, parserBaseValue, tailCall, BASEVALUE, CALLBACK,
  677. "Base Value", "Call Back");
  678. }
  679. int getOperation(PASERSSIGNATURE, int right_type, Statement **st, char *name){
  680. if (!callChildStatement(CALLPASERSSIGNATURE, parserOperation, OPERATION, st, NULL))
  681. return 0;
  682. if (readBackToken(pm) != right_type){
  683. freeStatement(*st);
  684. return -1;
  685. }
  686. delToken(pm);
  687. return 1;
  688. }
  689. /**
  690. * 字面量匹配
  691. * parserBaseValue:
  692. * | MATHER_NUMBER
  693. * | MATHER_STRING
  694. */
  695. void parserBaseValue(PASERSSIGNATURE){
  696. int token_type;
  697. Token *value_token = NULL;
  698. struct Statement *st = NULL;
  699. token_type = readBackToken(pm);
  700. if(MATHER_NUMBER == token_type){
  701. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Base Value: get number\n", NULL);
  702. value_token= popAheadToken(pm);
  703. char *stop;
  704. st = makeStatement();
  705. st->type = base_value;
  706. st->u.base_value.value = makeLinkValue(makeNumberValue(strtol(value_token->data.str, &stop, 10), inter), NULL, inter);
  707. }
  708. else if(MATHER_STRING == token_type){
  709. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Base Value: get string\n", NULL);
  710. value_token= popAheadToken(pm);
  711. st = makeStatement();
  712. st->type = base_value;
  713. st->u.base_value.value = makeLinkValue(makeStringValue(value_token->data.str, inter), NULL, inter);
  714. }
  715. else if(MATHER_VAR == token_type){
  716. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Base Value: get var\n", NULL);
  717. value_token= popAheadToken(pm);
  718. st = makeStatement();
  719. st->type = base_var;
  720. st->u.base_var.name = memStrcpy(value_token->data.str, 0, false, false);
  721. st->u.base_var.times = NULL;
  722. }
  723. else if(MATHER_LB == token_type){
  724. int tmp;
  725. Statement *tmp_st = NULL;
  726. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "base value: get operation\n", NULL);
  727. value_token= popAheadToken(pm);
  728. tmp = getOperation(CALLPASERSSIGNATURE, MATHER_RB, &tmp_st, "base value");
  729. if (tmp == 0){
  730. freeToken(value_token, true, true);
  731. syntaxError(pm, syntax_error, 1, "Don't get operation from list/var");
  732. goto return_;
  733. }
  734. else if(tmp == -1){
  735. freeToken(value_token, true, true);
  736. syntaxError(pm, syntax_error, 1, "Don't get ] from list/var");
  737. goto return_;
  738. }
  739. if (MATHER_VAR == readBackToken(pm)){
  740. Token *var_token;
  741. var_token= popAheadToken(pm);
  742. st = makeStatement();
  743. st->type = base_var;
  744. st->u.base_var.name = memStrcpy(var_token->data.str, 0, false, false);
  745. st->u.base_var.times = tmp_st;
  746. freeToken(var_token, true, false);
  747. }
  748. // TODO-szh list处理
  749. }
  750. else if(MATHER_LP == token_type){
  751. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "base value: get operation\n", NULL);
  752. value_token= popAheadToken(pm);
  753. int tmp = getOperation(CALLPASERSSIGNATURE, MATHER_RP, &st, "base value");
  754. if (tmp == 0){
  755. freeToken(value_token, true, true);
  756. syntaxError(pm, syntax_error, 1, "Don't get operation from Base Value");
  757. goto return_;
  758. }
  759. else if(tmp == -1){
  760. freeToken(value_token, true, true);
  761. syntaxError(pm, syntax_error, 1, "Don't get ) from Base Value");
  762. goto return_;
  763. }
  764. }
  765. else{
  766. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Base Value: else\n", NULL);
  767. goto return_;
  768. }
  769. freeToken(value_token, true, false);
  770. addStatementToken(BASEVALUE, st, pm);
  771. return_:
  772. return;
  773. }