statement.h 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. #ifndef VIRTUALMATH_STATEMENT_H
  2. #define VIRTUALMATH_STATEMENT_H
  3. #include "__macro.h"
  4. #define makeConnectStatementList(base, condition, var, code, type) connectStatementList(base, makeStatementList(condition, var, code, type))
  5. struct Statement{
  6. enum ValueAuthority aut;
  7. enum StatementType{
  8. start = 1,
  9. base_value,
  10. base_list,
  11. base_dict,
  12. base_var,
  13. base_svar,
  14. base_lambda,
  15. operation,
  16. set_function,
  17. set_class,
  18. call_function,
  19. if_branch,
  20. while_branch,
  21. for_branch,
  22. try_branch,
  23. with_branch,
  24. break_cycle,
  25. continue_cycle,
  26. rego_if,
  27. restart,
  28. return_code,
  29. raise_code,
  30. include_file,
  31. import_file,
  32. from_import_file,
  33. default_var,
  34. assert,
  35. label_,
  36. goto_,
  37. } type;
  38. union StatementU{
  39. struct base_value{
  40. enum BaseValueType{
  41. link_value = 0,
  42. string_str = 1,
  43. number_str = 2,
  44. } type;
  45. struct LinkValue *value;
  46. char *str;
  47. } base_value;
  48. struct base_var{
  49. char *name;
  50. struct Statement *times;
  51. } base_var;
  52. struct base_svar{
  53. struct Statement *name;
  54. struct Statement *times;
  55. } base_svar;
  56. struct {
  57. enum ListType type;
  58. struct Parameter *list;
  59. } base_list;
  60. struct {
  61. struct Parameter *dict;
  62. } base_dict;
  63. struct {
  64. struct Parameter *parameter;
  65. struct Statement *function;
  66. } base_lambda;
  67. struct operation{
  68. enum OperationType{
  69. OPT_ADD = 1,
  70. OPT_SUB = 2,
  71. OPT_MUL = 3,
  72. OPT_DIV = 4,
  73. OPT_ASS = 5,
  74. OPT_POINT = 6,
  75. OPT_BLOCK = 7,
  76. } OperationType;
  77. struct Statement *left;
  78. struct Statement *right;
  79. } operation;
  80. struct {
  81. struct Statement *name;
  82. struct Statement *function;
  83. struct Parameter *parameter;
  84. struct DecorationStatement *decoration;
  85. } set_function;
  86. struct {
  87. struct Statement *name;
  88. struct Statement *st;
  89. struct Parameter *father;
  90. struct DecorationStatement *decoration;
  91. } set_class;
  92. struct {
  93. struct Statement *function;
  94. struct Parameter *parameter;
  95. } call_function;
  96. struct {
  97. struct StatementList *if_list; // if elif
  98. struct Statement *else_list; // else分支(无condition)
  99. struct Statement *finally;
  100. } if_branch;
  101. struct {
  102. enum {
  103. while_,
  104. do_while_,
  105. } type;
  106. struct Statement *first; // first do
  107. struct StatementList *while_list; // while循环体
  108. struct Statement *after; // after do
  109. struct Statement *else_list; // else分支(无condition)
  110. struct Statement *finally;
  111. } while_branch;
  112. struct {
  113. struct Statement *var; // first do
  114. struct Statement *iter; // after do
  115. struct StatementList *for_list; // for循环体
  116. struct Statement *else_list; // else分支(无condition)
  117. struct Statement *finally;
  118. } for_branch;
  119. struct {
  120. struct Statement *try; // first do
  121. struct StatementList *except_list; // for循环体
  122. struct Statement *else_list; // else分支(无condition)
  123. struct Statement *finally;
  124. } try_branch;
  125. struct {
  126. struct StatementList *with_list; // for循环体
  127. struct Statement *else_list; // else分支(无condition)
  128. struct Statement *finally;
  129. } with_branch;
  130. struct {
  131. struct Statement *times;
  132. } break_cycle;
  133. struct {
  134. struct Statement *times;
  135. } continue_cycle;
  136. struct {
  137. struct Statement *times;
  138. } rego_if;
  139. struct {
  140. struct Statement *times;
  141. } restart;
  142. struct {
  143. struct Statement *value;
  144. } return_code;
  145. struct {
  146. struct Statement *value;
  147. } raise_code;
  148. struct {
  149. struct Statement *file;
  150. } include_file;
  151. struct {
  152. struct Statement *file;
  153. struct Statement *as;
  154. } import_file;
  155. struct {
  156. struct Statement *file;
  157. struct Parameter *pt;
  158. struct Parameter *as;
  159. } from_import_file;
  160. struct {
  161. struct Parameter *var;
  162. enum DefaultType{
  163. default_,
  164. global_,
  165. nonlocal_,
  166. } default_type;
  167. } default_var;
  168. struct {
  169. struct Statement *conditions;
  170. } assert;
  171. struct {
  172. struct Statement *command;
  173. struct Statement *as;
  174. char *label;
  175. } label_;
  176. struct {
  177. struct Statement *times;
  178. struct Statement *return_;
  179. struct Statement *label;
  180. } goto_;
  181. }u;
  182. long int line;
  183. char *code_file;
  184. struct Statement *next;
  185. };
  186. struct StatementList{
  187. enum {
  188. if_b,
  189. do_b,
  190. while_b,
  191. except_b,
  192. } type;
  193. struct Statement *condition;
  194. struct Statement *var;
  195. struct Statement *code;
  196. struct StatementList *next;
  197. };
  198. struct DecorationStatement {
  199. struct Statement *decoration;
  200. struct DecorationStatement *next;
  201. };
  202. typedef struct Token Token;
  203. typedef struct Statement Statement;
  204. typedef struct StatementList StatementList;
  205. typedef struct DecorationStatement DecorationStatement;
  206. Statement *makeStatement(long int line, char *file);
  207. void freeStatement(Statement *st);
  208. Statement *copyStatement(Statement *st);
  209. Statement *copyStatementCore(Statement *st);
  210. void connectStatement(Statement *base, Statement *new);
  211. Statement *makeOperationBaseStatement(enum OperationType type, long int line, char *file);
  212. Statement *makeOperationStatement(enum OperationType type, Statement *left, Statement *right);
  213. Statement *makeBaseLinkValueStatement(LinkValue *value, long int line, char *file);
  214. Statement *makeBaseStrValueStatement(char *value, enum BaseValueType type, long int line, char *file);
  215. Statement *makeBaseVarStatement(char *name, Statement *times, long int line, char *file);
  216. Statement *makeBaseSVarStatement(Statement *name, Statement *times);
  217. Statement *makeBaseDictStatement(Parameter *pt, long int line, char *file);
  218. Statement *makeTupleStatement(Parameter *pt, enum ListType type, long int line, char *file);
  219. Statement *makeClassStatement(Statement *name, Statement *function, Parameter *pt);
  220. Statement *makeFunctionStatement(Statement *name, Statement *function, struct Parameter *pt);
  221. Statement *makeLambdaStatement(Statement *function, Parameter *pt);
  222. Statement *makeCallStatement(Statement *function, struct Parameter *pt);
  223. Statement *makeIfStatement(long int line, char *file);
  224. Statement *makeWhileStatement(long int line, char *file);
  225. Statement *makeTryStatement(long int line, char *file);
  226. Statement *makeBreakStatement(Statement *times, long int line, char *file);
  227. Statement *makeWithStatement(long int line, char *file);
  228. Statement *makeContinueStatement(Statement *times, long int line, char *file);
  229. Statement *makeRegoStatement(Statement *times, long int line, char *file);
  230. Statement *makeRestartStatement(Statement *times, long int line, char *file);
  231. Statement *makeReturnStatement(Statement *value, long int line, char *file);
  232. Statement *makeRaiseStatement(Statement *value, long int line, char *file);
  233. Statement *makeAssertStatement(Statement *conditions, long int line, char *file);
  234. Statement *makeIncludeStatement(Statement *file, long int line, char *file_dir);
  235. Statement *makeImportStatement(Statement *file, Statement *as);
  236. Statement *makeFromImportStatement(Statement *file, Parameter *as, Parameter *pt);
  237. Statement *makeDefaultVarStatement(Parameter *var, long int line, char *file_dir, enum DefaultType type);
  238. Statement *makeLabelStatement(Statement *var, Statement *command, char *label, long int line, char *file_dir);
  239. Statement *makeGotoStatement(Statement *return_, Statement *times, Statement *label, long int line, char *file_dir);
  240. struct Token *setOperationFromToken(Statement **st_ad, struct Token *left, struct Token *right, enum OperationType type, bool is_right);
  241. StatementList *makeStatementList(Statement *condition, Statement *var, Statement *code, int type);
  242. StatementList *connectStatementList(StatementList *base, StatementList *new);
  243. void freeStatementList(StatementList *base);
  244. StatementList *copyStatementList(StatementList *sl);
  245. DecorationStatement *makeDecorationStatement();
  246. DecorationStatement *connectDecorationStatement(Statement *decoration, DecorationStatement *base);
  247. void freeDecorationStatement(DecorationStatement *base);
  248. DecorationStatement *copyDecorationStatement(DecorationStatement *ds);
  249. DecorationStatement *copyDecorationStatementCore(DecorationStatement *base);
  250. #endif //VIRTUALMATH_STATEMENT_H