grammar.c 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941
  1. #include "__grammar.h"
  2. ParserMessage *makeParserMessage(char *file_dir, char *debug){
  3. ParserMessage *tmp = memCalloc(1, sizeof(ParserMessage));
  4. tmp->file = file_dir;
  5. tmp->tm = makeTokenMessage(file_dir, debug);
  6. tmp->status = success;
  7. tmp->status_message = NULL;
  8. tmp->count = 0;
  9. #if OUT_LOG
  10. if (debug != NULL){
  11. char *debug_dir = memStrcat(debug, PASERS_LOG, false), *grammar_dir = memStrcat(debug, GRAMMAR_LOG, false);
  12. if (access(debug_dir, F_OK) != 0 || access(debug_dir, W_OK) == 0)
  13. tmp->paser_debug = fopen(debug_dir, "w");
  14. if (access(grammar_dir, F_OK) != 0 || access(debug_dir, W_OK) == 0)
  15. tmp->grammar_debug = fopen(grammar_dir, "w");
  16. memFree(debug_dir);
  17. memFree(grammar_dir);
  18. }
  19. else{
  20. tmp->paser_debug = NULL;
  21. tmp->grammar_debug = NULL;
  22. }
  23. #else
  24. tmp->paser_debug = NULL;
  25. tmp->grammar_debug = NULL;
  26. #endif
  27. return tmp;
  28. }
  29. void freeParserMessage(ParserMessage *pm, bool self) {
  30. freeBase(pm, return_);
  31. freeTokenMessage(pm->tm, true, true);
  32. #if OUT_LOG
  33. if (pm->paser_debug != NULL)
  34. fclose(pm->paser_debug);
  35. if (pm->grammar_debug != NULL)
  36. fclose(pm->grammar_debug);
  37. #endif
  38. memFree(pm->status_message);
  39. if (self){
  40. memFree(pm);
  41. }
  42. return_:
  43. return;
  44. }
  45. /**
  46. * 命令表匹配
  47. * parserCommandList :
  48. * | MATHER_EOF
  49. * | MATHER_ENTER
  50. * | MATHER_SEMICOLON
  51. * | parserCommand MATHER_ENTER
  52. * | parserCommand MATHER_SEMICOLON
  53. * | parserCommand MATHER_EOF
  54. */
  55. void parserCommandList(PASERSSIGNATURE, bool global, Statement *st) {
  56. int token_type;
  57. char *command_message = global ? "ERROR from command list(get parserCommand)" : NULL;
  58. while (true){
  59. token_type = readBackToken(pm);
  60. if (token_type == MATHER_EOF){
  61. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command List: <EOF>\n", NULL);
  62. delToken(pm);
  63. goto return_;
  64. }
  65. else if (token_type == MATHER_ENTER || token_type == MATHER_SEMICOLON){
  66. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command List: <ENTER>/<SEMICOLON>\n", NULL);
  67. delToken(pm);
  68. continue;
  69. }
  70. else{
  71. Token *command_token = NULL;
  72. int stop;
  73. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command List: call command\n", NULL);
  74. if (!callChildToken(CALLPASERSSIGNATURE, parserCommand, COMMAND, &command_token, command_message, command_list_error))
  75. goto return_;
  76. stop = readBackToken(pm);
  77. if (stop == MATHER_ENTER || stop == MATHER_SEMICOLON)
  78. delToken(pm);
  79. else if(stop != MATHER_EOF){
  80. if (global) {
  81. printf("stop = %d\n", stop);
  82. syntaxError(pm, command_list_error, command_token->line, 1, "ERROR from parserCommand list(get stop)");
  83. freeToken(command_token, true, true);
  84. }
  85. else{
  86. connectStatement(st, command_token->data.st);
  87. freeToken(command_token, true, false);
  88. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG,
  89. "Command List: get command success[at !global end]\n", NULL);
  90. }
  91. goto return_;
  92. }
  93. connectStatement(st, command_token->data.st);
  94. freeToken(command_token, true, false);
  95. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command List: get command success\n", NULL);
  96. }
  97. }
  98. return_:
  99. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command List: return\n", NULL);
  100. }
  101. /**
  102. * 命令匹配
  103. * parserCommand:
  104. * | MATHER_DEF parserDef
  105. * | MATHER_IF parserIf
  106. * | MATHER_WHILE parserWhile
  107. * | MATHER_TRY parserTry
  108. * | MATHER_BREAK parserControl
  109. * | MATHER_CONTINUE parserControl
  110. * | MATHER_RESTART parserControl
  111. * | MATHER_REGO parserControl
  112. * | MATHER_RETURN parserControl
  113. * | MATHER_RAISE parserControl
  114. * | parserOperation
  115. */
  116. void parserCommand(PASERSSIGNATURE){
  117. int token_type, status;
  118. Statement *st = NULL;
  119. token_type = readBackToken(pm);
  120. switch (token_type) {
  121. case MATHER_CLASS :
  122. case MATHER_DEF :
  123. status = commandCallBack_(CALLPASERSSIGNATURE, parserDef, FUNCTION, &st,
  124. "Command: call def\n");
  125. break;
  126. case MATHER_IF :
  127. status = commandCallBack_(CALLPASERSSIGNATURE, parserIf, IF_BRANCH, &st,
  128. "Command: call if\n");
  129. break;
  130. case MATHER_WHILE :
  131. status = commandCallBack_(CALLPASERSSIGNATURE, parserWhile, WHILE_BRANCH, &st,
  132. "Command: call while\n");
  133. break;
  134. case MATHER_TRY :
  135. status = commandCallBack_(CALLPASERSSIGNATURE, parserTry, TRY_BRANCH, &st,
  136. "Command: call try\n");
  137. break;
  138. case MATHER_BREAK :
  139. status = commandCallControl_(CALLPASERSSIGNATURE, makeBreakStatement, BREAK, &st,
  140. "Command: call break\n", false, NULL);
  141. break;
  142. case MATHER_CONTINUE :
  143. status = commandCallControl_(CALLPASERSSIGNATURE, makeContinueStatement, CONTINUE, &st,
  144. "Command: call continue\n", false, NULL);
  145. break;
  146. case MATHER_RESTART :
  147. status = commandCallControl_(CALLPASERSSIGNATURE, makeRestartStatement, RESTART, &st,
  148. "Command: call restart\n", false, NULL);
  149. break;
  150. case MATHER_REGO :
  151. status = commandCallControl_(CALLPASERSSIGNATURE, makeRegoStatement, REGO, &st,
  152. "Command: call rego\n", false, NULL);
  153. break;
  154. case MATHER_RETURN :
  155. status = commandCallControl_(CALLPASERSSIGNATURE, makeReturnStatement, RETURN, &st,
  156. "Command: call return\n", false, NULL);
  157. break;
  158. case MATHER_RAISE :
  159. status = commandCallControl_(CALLPASERSSIGNATURE, makeRaiseStatement, RAISE, &st,
  160. "Command: call raise\n", false, NULL);
  161. break;
  162. case MATHER_INCLUDE :
  163. status = commandCallControl_(CALLPASERSSIGNATURE, makeIncludeStatement, INCLUDE, &st,
  164. "Command: call include\n", true,
  165. "parserInclude: Don't get file after include");
  166. break;
  167. case MATHER_STRING:
  168. case MATHER_NUMBER:
  169. case MATHER_VAR:
  170. case MATHER_SVAR:
  171. case MATHER_LC:
  172. case MATHER_LB:
  173. case MATHER_LP:
  174. case MATHER_SUB:
  175. status = commandCallBack_(CALLPASERSSIGNATURE, parserOperation, OPERATION, &st,
  176. "Command: call operation\n");
  177. break;
  178. default:
  179. status = false;
  180. break;
  181. }
  182. if (!status)
  183. goto return_;
  184. addStatementToken(COMMAND, st, pm);
  185. return_:
  186. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Command: get return\n", NULL);
  187. }
  188. /**
  189. * 控制语句匹配
  190. * parserControl
  191. * | (control token) NULL
  192. * | (control token) parserOperation
  193. *
  194. * @param callBack statement生成函数
  195. * @param type 输出token的类型
  196. * @param must_operation 必须匹配 operation
  197. */
  198. void parserControl(PASERSSIGNATURE, MakeControlFunction callBack, int type, bool must_operation,
  199. char *message) {
  200. Statement *times = NULL;
  201. Statement *st = NULL;
  202. long int line = 0;
  203. line = delToken(pm);
  204. parserOperation(CALLPASERSSIGNATURE);
  205. if (!call_success(pm))
  206. goto return_;
  207. if (readBackToken(pm) == OPERATION){
  208. Token *tmp;
  209. tmp = popAheadToken(pm);
  210. times = tmp->data.st;
  211. freeToken(tmp, true, false);
  212. }
  213. else if (must_operation){
  214. syntaxError(pm, syntax_error, line, 1, message);
  215. goto return_;
  216. }
  217. st = callBack(times, line, pm->file);
  218. addStatementToken(type, st, pm);
  219. return_:
  220. return;
  221. }
  222. /**
  223. * 条件分支匹配
  224. * parserIf:
  225. * | MATHER_IF parserOperation (MATHER_AS parserOperation) callParserCode
  226. * | parserIf MATHER_ELIF parserOperation (MATHER_AS parserOperation) callParserCode
  227. * | parserIf MATHER_DO callParserCode [不允许两次连用]
  228. * | parserIf MATHER_ELSE callParserCode [不允许再出现if和elif以及do] [只出现一次] [4]
  229. * | parserIf MATHER_FINALLY callParserCode [结尾]
  230. * 注释:会自动过滤 <ENTER> , 可以使用 <SEMICOLON> 作为结束表示
  231. * 注释:自动添加 <ENTER> 结尾符号
  232. * 注释:(MATHER_AS parserOperation) 表示允许出现或者不出现, 若出现则 MATHER_AS parserOperation 必须一起出现
  233. * 特别注意:自进入模式[4]后,匹配顺序自上而下不可逆
  234. * @param pm
  235. * @param inter
  236. */
  237. void parserIf(PASERSSIGNATURE){
  238. Statement *st = NULL;
  239. Statement *else_st = NULL;
  240. Statement *finally_st = NULL;
  241. StatementList *sl = NULL;
  242. bool have_if = false;
  243. long int line = 0;
  244. again:
  245. switch (readBackToken(pm)) {
  246. case MATHER_IF:
  247. if (have_if)
  248. goto default_;
  249. else
  250. have_if = true;
  251. line = delToken(pm);
  252. goto not_del;
  253. case MATHER_ELIF: {
  254. Statement *code_tmp = NULL, *var_tmp = NULL, *condition_tmp = NULL;
  255. long int tmp_line = delToken(pm);
  256. if (else_st != NULL) {
  257. syntaxError(pm, syntax_error, tmp_line, 1, "get elif after else");
  258. goto error_;
  259. }
  260. not_del:
  261. if (!callChildStatement(CALLPASERSSIGNATURE, parserOperation, OPERATION, &condition_tmp,
  262. "Don't get a if condition"))
  263. goto error_;
  264. if (!callParserAs(CALLPASERSSIGNATURE, &var_tmp, "Don't get a while var")) {
  265. freeStatement(condition_tmp);
  266. goto error_;
  267. }
  268. if (!callParserCode(CALLPASERSSIGNATURE, &code_tmp, "Don't get a if code", tmp_line)) {
  269. freeStatement(condition_tmp);
  270. freeStatement(var_tmp);
  271. goto error_;
  272. }
  273. sl = makeConnectStatementList(sl, condition_tmp, var_tmp, code_tmp, if_b);
  274. goto again;
  275. }
  276. case MATHER_DO: {
  277. if (else_st != NULL)
  278. goto default_;
  279. Statement *code_tmp = NULL;
  280. long int tmp_line = delToken(pm);
  281. if (!callParserCode(CALLPASERSSIGNATURE, &code_tmp, "Don't get a if...do code", tmp_line))
  282. goto error_;
  283. sl = makeConnectStatementList(sl, NULL, NULL, code_tmp, do_b);
  284. goto again;
  285. }
  286. case MATHER_ELSE: {
  287. long int tmp_line = delToken(pm);
  288. if (else_st != NULL) {
  289. syntaxError(pm, syntax_error, tmp_line, 1, "get else after else");
  290. goto error_;
  291. }
  292. if (!callParserCode(CALLPASERSSIGNATURE, &else_st, "Don't get a if...else code", tmp_line))
  293. goto error_;
  294. goto again;
  295. }
  296. case MATHER_FINALLY: {
  297. long int tmp_line = delToken(pm);
  298. if (!callParserCode(CALLPASERSSIGNATURE, &finally_st, "Don't get a if...else code", tmp_line))
  299. goto error_;
  300. break;
  301. }
  302. case MATHER_ENTER:
  303. delToken(pm);
  304. goto again;
  305. case MATHER_SEMICOLON:
  306. break;
  307. default:{
  308. default_:
  309. addLexToken(pm, MATHER_ENTER);
  310. break;
  311. }
  312. }
  313. st = makeIfStatement(line, pm->file);
  314. st->u.if_branch.if_list = sl;
  315. st->u.if_branch.else_list = else_st;
  316. st->u.if_branch.finally = finally_st;
  317. addStatementToken(IF_BRANCH, st, pm);
  318. return;
  319. error_:
  320. freeStatement(else_st);
  321. freeStatement(finally_st);
  322. freeStatementList(sl);
  323. return;
  324. }
  325. /**
  326. * 条件循环匹配
  327. * parserWhile:
  328. * | MATHER_WHILE parserOperation (MATHER_AS parserOperation) callParserCode
  329. * | parserWhile MATHER_DO callParserCode [只出现一次]
  330. * | parserWhile MATHER_ELSE callParserCode [只出现一次]
  331. * | parserWhile MATHER_FINALLY callParserCode [结尾]
  332. * 注释:同 ``parserIf``
  333. * 特别注意:匹配顺序自上而下不可逆
  334. * @param pm
  335. * @param inter
  336. */
  337. void parserWhile(PASERSSIGNATURE){
  338. Statement *st = NULL;
  339. Statement *else_st = NULL;
  340. Statement *finally_st = NULL;
  341. Statement *do_st = NULL;
  342. StatementList *sl = NULL;
  343. bool have_while = false;
  344. long int line = 0;
  345. again:
  346. switch (readBackToken(pm)) {
  347. case MATHER_WHILE: {
  348. if (have_while)
  349. goto default_;
  350. else
  351. have_while = true;
  352. Statement *code_tmp = NULL, *var_tmp = NULL, *condition_tmp = NULL;
  353. line = delToken(pm);
  354. if (!callChildStatement(CALLPASERSSIGNATURE, parserOperation, OPERATION, &condition_tmp, "Don't get a while condition"))
  355. goto error_;
  356. if (!callParserAs(CALLPASERSSIGNATURE, &var_tmp, "Don't get a while var")){
  357. freeStatement(condition_tmp);
  358. goto error_;
  359. }
  360. if (!callParserCode(CALLPASERSSIGNATURE, &code_tmp, "Don't get a while code", line)) {
  361. freeStatement(condition_tmp);
  362. freeStatement(var_tmp);
  363. goto error_;
  364. }
  365. if (sl != NULL)
  366. freeStatementList(sl);
  367. sl = makeStatementList(condition_tmp, var_tmp, code_tmp, while_b);
  368. goto again;
  369. }
  370. case MATHER_DO: {
  371. if (do_st != NULL || else_st != NULL)
  372. goto default_;
  373. long int tmp_line = delToken(pm);
  374. if (!callParserCode(CALLPASERSSIGNATURE, &do_st, "Don't get a while...do code", tmp_line))
  375. goto error_;
  376. goto again;
  377. }
  378. case MATHER_ELSE: {
  379. long int tmp_line = delToken(pm);
  380. if (else_st != NULL) {
  381. syntaxError(pm, syntax_error, tmp_line, 1, "get else after else\n");
  382. goto error_;
  383. }
  384. if (!callParserCode(CALLPASERSSIGNATURE, &else_st, "Don't get a while...else code", tmp_line))
  385. goto error_;
  386. goto again;
  387. }
  388. case MATHER_FINALLY: {
  389. long int tmp_line = delToken(pm);
  390. if (!callParserCode(CALLPASERSSIGNATURE, &finally_st, "Don't get a while...finally code", tmp_line))
  391. goto error_;
  392. break;
  393. }
  394. case MATHER_ENTER:
  395. delToken(pm);
  396. goto again;
  397. case MATHER_SEMICOLON:
  398. break;
  399. default: {
  400. default_:
  401. addLexToken(pm, MATHER_ENTER);
  402. break;
  403. }
  404. }
  405. st = makeWhileStatement(line, pm->file);
  406. st->u.while_branch.while_list = sl;
  407. st->u.while_branch.else_list = else_st;
  408. st->u.while_branch.finally = finally_st;
  409. st->u.while_branch.after = do_st;
  410. addStatementToken(WHILE_BRANCH, st, pm);
  411. return;
  412. error_:
  413. freeStatement(else_st);
  414. freeStatement(finally_st);
  415. freeStatement(do_st);
  416. freeStatementList(sl);
  417. return;
  418. }
  419. /**
  420. * 异常捕获分支匹配
  421. * parserTry:
  422. * | MATHER_TRY callParserCode
  423. * | parserTry MATHER_EXCEPT (MATHER_AS parserOperation) callParserCode
  424. * | parserTry MATHER_ELSE callParserCode [只出现一次]
  425. * | parserTry MATHER_FINALLY callParserCode [结尾]
  426. * 注释:同 ``parserIf``
  427. * 特别注意:匹配顺序自上而下不可逆
  428. * @param pm
  429. * @param inter
  430. */
  431. void parserTry(PASERSSIGNATURE){
  432. Statement *st = NULL;
  433. Statement *try_st = NULL;
  434. Statement *else_st = NULL;
  435. Statement *finally_st = NULL;
  436. StatementList *sl = NULL;
  437. long int line = 0;
  438. again:
  439. switch (readBackToken(pm)) {
  440. case MATHER_TRY:{
  441. if (try_st != NULL)
  442. goto default_;
  443. line = delToken(pm);
  444. if (!callParserCode(CALLPASERSSIGNATURE, &try_st, "Don't get a try code", line))
  445. goto error_;
  446. goto again;
  447. }
  448. case MATHER_EXCEPT: {
  449. Statement *code_tmp = NULL, *var_tmp = NULL, *condition_tmp = NULL;
  450. long int tmp_line = delToken(pm);
  451. if (else_st != NULL) {
  452. syntaxError(pm, syntax_error, tmp_line, 1, "get except after else");
  453. goto error_;
  454. }
  455. if (readBackToken(pm) != MATHER_LC)
  456. callChildStatement(CALLPASERSSIGNATURE, parserOperation, OPERATION, &condition_tmp, NULL);
  457. if (!callParserAs(CALLPASERSSIGNATURE, &var_tmp, "Don't get a except var")){
  458. freeStatement(condition_tmp);
  459. goto error_;
  460. }
  461. if (!callParserCode(CALLPASERSSIGNATURE, &code_tmp, "Don't get a except code", tmp_line)) {
  462. freeStatement(condition_tmp);
  463. freeStatement(var_tmp);
  464. goto error_;
  465. }
  466. sl = makeConnectStatementList(sl, condition_tmp, var_tmp, code_tmp, except_b);
  467. goto again;
  468. }
  469. case MATHER_ELSE: {
  470. long int tmp_line = delToken(pm);
  471. if (else_st != NULL) {
  472. syntaxError(pm, syntax_error, tmp_line, 1, "get else after else");
  473. goto error_;
  474. }
  475. if (!callParserCode(CALLPASERSSIGNATURE, &else_st, "Don't get a try...else code", tmp_line))
  476. goto error_;
  477. goto again;
  478. }
  479. case MATHER_FINALLY: {
  480. long int tmp_line = delToken(pm);
  481. if (!callParserCode(CALLPASERSSIGNATURE, &finally_st, "Don't get a try...finally code", tmp_line))
  482. goto error_;
  483. break;
  484. }
  485. case MATHER_ENTER:
  486. delToken(pm);
  487. goto again;
  488. case MATHER_SEMICOLON:
  489. break;
  490. default: {
  491. default_:
  492. addLexToken(pm, MATHER_ENTER);
  493. break;
  494. }
  495. }
  496. st = makeTryStatement(line, pm->file);
  497. st->u.try_branch.try = try_st;
  498. st->u.try_branch.except_list = sl;
  499. st->u.try_branch.else_list = else_st;
  500. st->u.try_branch.finally = finally_st;
  501. addStatementToken(TRY_BRANCH, st, pm);
  502. return;
  503. error_:
  504. freeStatement(try_st);
  505. freeStatement(else_st);
  506. freeStatement(finally_st);
  507. freeStatementList(sl);
  508. return;
  509. }
  510. /**
  511. * 函数定义匹配
  512. * parserDef:
  513. * | parserBaseValue MATHER_LP parserParameter(is_formal) MATHER_RP callParserCode
  514. * 注释:自动添加 <ENTER> 结尾符号
  515. * @param pm
  516. * @param inter
  517. */
  518. void parserDef(PASERSSIGNATURE){
  519. Statement *st = NULL;
  520. Statement *name_tmp = NULL;
  521. Statement *code_tmp = NULL;
  522. Parameter *pt = NULL;
  523. int type = readBackToken(pm);
  524. long int line = delToken(pm);
  525. if (!callChildStatement(CALLPASERSSIGNATURE, parserBaseValue, BASEVALUE, &name_tmp,
  526. "Don't get a function/class name"))
  527. goto error_;
  528. if (!checkToken_(pm, MATHER_LP)) {
  529. syntaxError(pm, syntax_error, line, 1, "Don't get a function/class ( before parameter");
  530. goto error_;
  531. }
  532. if (!parserParameter(CALLPASERSSIGNATURE, &pt, true, false, false, MATHER_COMMA, MATHER_ASSIGNMENT)) {
  533. syntaxError(pm, syntax_error, line, 1, "Don't get a function/class parameter");
  534. goto error_;
  535. }
  536. if (!checkToken_(pm, MATHER_RP)) {
  537. syntaxError(pm, syntax_error, line, 1, "Don't get a function/class ) after parameter");
  538. goto error_;
  539. }
  540. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "parserDef: get function title success\n", NULL);
  541. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "parserDef: call parserCode\n", NULL);
  542. if (!callParserCode(CALLPASERSSIGNATURE, &code_tmp, "Don't get a function code", line)) {
  543. syntaxError(pm, syntax_error, line, 1, "Don't get a function code");
  544. goto error_;
  545. }
  546. if (type == MATHER_DEF)
  547. st = makeFunctionStatement(name_tmp, code_tmp, pt);
  548. else
  549. st = makeClassStatement(name_tmp, code_tmp); // TODO-szh 处理pt
  550. addLexToken(pm, MATHER_ENTER);
  551. addStatementToken(FUNCTION, st, pm);
  552. return;
  553. error_:
  554. freeStatement(name_tmp);
  555. freeStatement(code_tmp);
  556. freeParameter(pt, true);
  557. return;
  558. }
  559. /**
  560. * 函数定义匹配
  561. * parserCode:
  562. * | MATHER_LC parserCommandList MATHER_RC
  563. * 注释:自动忽略MATHER_LC前的空格
  564. * @param pm
  565. * @param inter
  566. */
  567. void parserCode(PASERSSIGNATURE) {
  568. long int line = 0;
  569. Statement *st = NULL;
  570. while (true){
  571. if (readBackToken(pm) == MATHER_LC){
  572. line = delToken(pm);
  573. goto again_;
  574. }
  575. break;
  576. again_:
  577. if (!checkToken_(pm, MATHER_ENTER))
  578. goto return_;
  579. }
  580. st = makeStatement(line, pm->file);
  581. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "parserCode: call parserCommandList\n", NULL);
  582. parserCommandList(CALLPASERSSIGNATURE, false, st);
  583. if (!call_success(pm))
  584. goto error_;
  585. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "parserCode: call parserCommandList success\n", NULL);
  586. if (!checkToken_(pm, MATHER_RC)) {
  587. syntaxError(pm, syntax_error, line, 1, "Don't get the }"); // 使用{的行号
  588. goto error_;
  589. }
  590. return_:
  591. addStatementToken(CODE, st, pm);
  592. return;
  593. error_:
  594. freeStatement(st);
  595. return;
  596. }
  597. /**
  598. * 表达式匹配
  599. * parserOperation:
  600. * | parserAssignment
  601. */
  602. void parserOperation(PASERSSIGNATURE){
  603. Statement *operation_st = NULL;
  604. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Operation: call assignment\n", NULL);
  605. if (!callChildStatement(CALLPASERSSIGNATURE, parserAssignment, ASSIGNMENT, &operation_st, NULL))
  606. goto return_;
  607. addStatementToken(OPERATION, operation_st, pm);
  608. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Operation: get polynomial success\n", NULL);
  609. return_:
  610. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Operation: return\n", NULL);
  611. return;
  612. }
  613. /**
  614. * 赋值表达式匹配
  615. * parserAssignment:
  616. * | parserTuple
  617. * | parserAssignment ASSIGNMENT parserTuple [2]
  618. * 注意:在链接statement的时候, 模式[2]相当于 parserTuple ASSIGNMENT parserAssignment
  619. */
  620. bool switchAssignment(PASERSSIGNATURE, int symbol, Statement **st){
  621. switch (symbol) {
  622. case MATHER_ASSIGNMENT:
  623. *st = makeOperationStatement(OPT_ASS, 0, pm->file);
  624. break;
  625. default:
  626. return false;
  627. }
  628. return true;
  629. }
  630. void parserAssignment(PASERSSIGNATURE){
  631. return twoOperation(CALLPASERSSIGNATURE, parserTuple, switchAssignment, TUPLE, ASSIGNMENT,
  632. "polynomial", "assignment", true);
  633. }
  634. /**
  635. * 元组匹配
  636. * parserTuple:
  637. * | parserPolynomial
  638. * | parserTuple COMMA parserPolynomial
  639. * @param pm
  640. * @param inter
  641. */
  642. void parserTuple(PASERSSIGNATURE){
  643. Parameter *pt = NULL;
  644. Statement *st = NULL;
  645. Token *tmp = NULL;
  646. long int line = 0;
  647. if (readBackToken(pm) == MATHER_MUL) {
  648. line = pm->tm->ts->token_list->line;
  649. goto parserPt;
  650. }
  651. if (!callChildToken(CALLPASERSSIGNATURE, parserPolynomial, POLYNOMIAL, &tmp, NULL, syntax_error))
  652. goto return_;
  653. if (readBackToken(pm) != MATHER_COMMA){
  654. tmp->token_type = TUPLE;
  655. addToken_(pm ,tmp);
  656. goto return_;
  657. }
  658. line = tmp->line;
  659. addToken_(pm ,tmp);
  660. parserPt:
  661. if (!parserParameter(CALLPASERSSIGNATURE, &pt, false, true, false, MATHER_COMMA, MATHER_ASSIGNMENT)) {
  662. syntaxError(pm, syntax_error, line, 1, "Don't get tuple element");
  663. goto return_;
  664. }
  665. st = makeTupleStatement(pt, value_tuple, pt->data.value->line, pm->file);
  666. addStatementToken(TUPLE, st, pm);
  667. return_:
  668. return;
  669. }
  670. /**
  671. * 多项式匹配
  672. * parserPolynomial:
  673. * | parserBaseValue
  674. * | parserPolynomial OPT_ADD parserFactor
  675. * | parserPolynomial OPT_SUB parserFactor
  676. */
  677. bool switchPolynomial(PASERSSIGNATURE, int symbol, Statement **st){
  678. switch (symbol) {
  679. case MATHER_ADD:
  680. *st = makeOperationStatement(OPT_ADD, 0, pm->file);
  681. break;
  682. case MATHER_SUB:
  683. *st = makeOperationStatement(OPT_SUB, 0, pm->file);
  684. break;
  685. default:
  686. return false;
  687. }
  688. return true;
  689. }
  690. void parserPolynomial(PASERSSIGNATURE){
  691. return twoOperation(CALLPASERSSIGNATURE, parserFactor, switchPolynomial, FACTOR, POLYNOMIAL,
  692. "factor", "polynomial", false);
  693. }
  694. /**
  695. * 因式匹配
  696. * parserFactor:
  697. * | parserCallBack
  698. * | switchFactor OPT_ADD parserCallBack
  699. * | switchFactor OPT_SUB parserCallBack
  700. */
  701. bool switchFactor(PASERSSIGNATURE, int symbol, Statement **st){
  702. switch (symbol) {
  703. case MATHER_MUL:
  704. *st = makeOperationStatement(OPT_MUL, 0, pm->file);
  705. break;
  706. case MATHER_DIV:
  707. *st = makeOperationStatement(OPT_DIV, 0, pm->file);
  708. break;
  709. default:
  710. return false;
  711. }
  712. return true;
  713. }
  714. void parserFactor(PASERSSIGNATURE){
  715. return twoOperation(CALLPASERSSIGNATURE, parserCallBack, switchFactor, CALLBACK, FACTOR,
  716. "call back", "factor", false);
  717. }
  718. /**
  719. * 函数回调匹配
  720. * parserCallBack:
  721. * | parserBaseValue
  722. * | parserCallBack MATHER_LP parserParameter MATHER_RP
  723. */
  724. int tailCall(PASERSSIGNATURE, Token *left_token, Statement **st){
  725. Parameter *pt = NULL;
  726. if (readBackToken(pm) != MATHER_LP)
  727. return -1;
  728. long int line = delToken(pm);
  729. if (checkToken_(pm, MATHER_RP))
  730. goto not_pt;
  731. if (!parserParameter(CALLPASERSSIGNATURE, &pt, false, false, false, MATHER_COMMA, MATHER_ASSIGNMENT)) {
  732. syntaxError(pm, syntax_error, line, 1, "Don't get call parameter");
  733. return 0;
  734. }
  735. if (!checkToken_(pm, MATHER_RP)){
  736. freeParameter(pt, true);
  737. syntaxError(pm, syntax_error, line, 1, "Don't get ) from call back");
  738. return 0;
  739. }
  740. not_pt:
  741. *st = makeCallStatement(left_token->data.st, pt);
  742. return 1;
  743. }
  744. void parserCallBack(PASERSSIGNATURE){
  745. return tailOperation(CALLPASERSSIGNATURE, parserPoint, tailCall, POINT, CALLBACK,
  746. "point", "call back");
  747. }
  748. /**
  749. * 成员运算符匹配
  750. * parserPoint:
  751. * | parserBaseValue
  752. * | parserBaseValue POINT parserPoint
  753. */
  754. bool switchPoint(PASERSSIGNATURE, int symbol, Statement **st){
  755. switch (symbol) {
  756. case MATHER_POINT:
  757. *st = makeOperationStatement(OPT_POINT, 0, pm->file);
  758. break;
  759. default:
  760. return false;
  761. }
  762. return true;
  763. }
  764. void parserPoint(PASERSSIGNATURE){
  765. return twoOperation(CALLPASERSSIGNATURE, parserBaseValue, switchPoint, BASEVALUE, POINT,
  766. "base value", "point", false);
  767. }
  768. /**
  769. * 字面量匹配
  770. * parserBaseValue:
  771. * | MATHER_NUMBER
  772. * | MATHER_STRING
  773. */
  774. int getOperation(PASERSSIGNATURE, int right_type, Statement **st, char *name){
  775. *st = NULL;
  776. if (checkToken_(pm, right_type))
  777. goto return_;
  778. if (!callChildStatement(CALLPASERSSIGNATURE, parserOperation, OPERATION, st, NULL))
  779. return 0;
  780. if (!checkToken_(pm, right_type)){
  781. freeStatement(*st);
  782. return -1;
  783. }
  784. return_:
  785. return 1;
  786. }
  787. void parserBaseValue(PASERSSIGNATURE){
  788. Token *value_token = popAheadToken(pm);
  789. Statement *st = NULL;
  790. if (MATHER_NUMBER == value_token->token_type){
  791. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Base Value: get number [%s]\n", value_token->data.str);
  792. st = makeBaseStrValueStatement(value_token->data.str, number_str, value_token->line, pm->file);
  793. }
  794. else if (MATHER_STRING == value_token->token_type){
  795. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Base Value: get string [%s]\n", value_token->data.str);
  796. Value *tmp_value = makeStringValue(value_token->data.str, inter);
  797. st = makeBaseStrValueStatement(value_token->data.str, string_str, value_token->line, pm->file);
  798. }
  799. else if (MATHER_VAR == value_token->token_type){
  800. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Base Value: get var [%s]\n", value_token->data.str);
  801. st = makeBaseVarStatement(value_token->data.str, NULL, value_token->line, pm->file);
  802. }
  803. else if (MATHER_SVAR == value_token->token_type){
  804. Statement *svar_st = NULL;
  805. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Base Value: get super var\n", NULL);
  806. if (!callChildStatement(CALLPASERSSIGNATURE, parserBaseValue, BASEVALUE, &svar_st, NULL)){
  807. freeToken(value_token, true, true);
  808. syntaxError(pm, syntax_error, value_token->line, 1, "Don't get super var after $");
  809. goto return_;
  810. }
  811. st = makeBaseSVarStatement(svar_st, NULL);
  812. }
  813. else if (MATHER_LB == value_token->token_type){
  814. int tmp;
  815. Statement *tmp_st = NULL;
  816. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "base value: get operation\n", NULL);
  817. tmp = getOperation(CALLPASERSSIGNATURE, MATHER_RB, &tmp_st, "base value");
  818. if (tmp == 0){
  819. freeToken(value_token, true, true);
  820. syntaxError(pm, syntax_error, value_token->line, 1, "Don't get operation from Base Value");
  821. goto return_;
  822. }
  823. else if(tmp == -1){
  824. freeToken(value_token, true, true);
  825. syntaxError(pm, syntax_error, value_token->line, 1, "Don't get ] from list/var");
  826. goto return_;
  827. }
  828. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "base value: get operation success\n", NULL);
  829. if (MATHER_VAR == readBackToken(pm)){
  830. Token *var_token;
  831. var_token = popAheadToken(pm);
  832. st = makeBaseVarStatement(var_token->data.str, tmp_st, var_token->line, pm->file);
  833. freeToken(var_token, true, false);
  834. }
  835. else{
  836. if (tmp_st == NULL)
  837. st = makeTupleStatement(NULL, value_list, value_token->line, pm->file);
  838. else if (tmp_st->type == base_list && tmp_st->u.base_list.type == value_tuple){
  839. tmp_st->u.base_list.type = value_list;
  840. st = tmp_st;
  841. }
  842. else
  843. st = makeTupleStatement(makeValueParameter(tmp_st), value_list, value_token->token_type, pm->file);
  844. }
  845. }
  846. else if (MATHER_LP == value_token->token_type){
  847. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "base value: get operation\n", NULL);
  848. int tmp = getOperation(CALLPASERSSIGNATURE, MATHER_RP, &st, "base value");
  849. if (tmp == 0){
  850. freeToken(value_token, true, true);
  851. syntaxError(pm, syntax_error, value_token->line, 1, "Don't get operation from Base Value");
  852. goto return_;
  853. }
  854. else if(tmp == -1){
  855. freeToken(value_token, true, true);
  856. syntaxError(pm, syntax_error, value_token->line, 1, "Don't get ) from Base Value");
  857. goto return_;
  858. }
  859. }
  860. else if (MATHER_LC == value_token->token_type){
  861. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "base value: get dict\n", NULL);
  862. Parameter *pt = NULL;
  863. if (!parserParameter(CALLPASERSSIGNATURE, &pt, false, false, true, MATHER_COMMA, MATHER_COLON)) {
  864. freeToken(value_token, true, true);
  865. syntaxError(pm, syntax_error, value_token->line, 1, "Don't get a dict parameter");
  866. goto return_;
  867. }
  868. if (!checkToken_(pm, MATHER_RC)) {
  869. freeToken(value_token, true, true);
  870. freeParameter(pt, true);
  871. syntaxError(pm, syntax_error, value_token->line, 1, "Don't get a } after dict");
  872. goto return_;
  873. }
  874. st = makeBaseDictStatement(pt, value_token->line, pm->file);
  875. }
  876. else{
  877. writeLog_(pm->grammar_debug, GRAMMAR_DEBUG, "Base Value: else\n", NULL);
  878. backToken_(pm, value_token);
  879. goto return_;
  880. }
  881. freeToken(value_token, true, false);
  882. addStatementToken(BASEVALUE, st, pm);
  883. return_:
  884. return;
  885. }