statement.h 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  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. } type;
  36. union StatementU{
  37. struct base_value{
  38. enum BaseValueType{
  39. link_value = 0,
  40. string_str = 1,
  41. number_str = 2,
  42. } type;
  43. struct LinkValue *value;
  44. char *str;
  45. } base_value;
  46. struct base_var{
  47. char *name;
  48. struct Statement *times;
  49. } base_var;
  50. struct base_svar{
  51. struct Statement *name;
  52. struct Statement *times;
  53. } base_svar;
  54. struct {
  55. enum ListType type;
  56. struct Parameter *list;
  57. } base_list;
  58. struct {
  59. struct Parameter *dict;
  60. } base_dict;
  61. struct {
  62. struct Parameter *parameter;
  63. struct Statement *function;
  64. } base_lambda;
  65. struct operation{
  66. enum OperationType{
  67. OPT_ADD = 1,
  68. OPT_SUB = 2,
  69. OPT_MUL = 3,
  70. OPT_DIV = 4,
  71. OPT_ASS = 5,
  72. OPT_POINT = 6,
  73. OPT_BLOCK = 7,
  74. } OperationType;
  75. struct Statement *left;
  76. struct Statement *right;
  77. } operation;
  78. struct {
  79. struct Statement *name;
  80. struct Statement *function;
  81. struct Parameter *parameter;
  82. } set_function;
  83. struct {
  84. struct Statement *name;
  85. struct Statement *st;
  86. struct Parameter *father;
  87. } set_class;
  88. struct {
  89. struct Statement *function;
  90. struct Parameter *parameter;
  91. } call_function;
  92. struct {
  93. struct StatementList *if_list; // if elif
  94. struct Statement *else_list; // else分支(无condition)
  95. struct Statement *finally;
  96. } if_branch;
  97. struct {
  98. enum {
  99. while_,
  100. do_while_,
  101. } type;
  102. struct Statement *first; // first do
  103. struct StatementList *while_list; // while循环体
  104. struct Statement *after; // after do
  105. struct Statement *else_list; // else分支(无condition)
  106. struct Statement *finally;
  107. } while_branch;
  108. struct {
  109. struct Statement *var; // first do
  110. struct Statement *iter; // after do
  111. struct StatementList *for_list; // for循环体
  112. struct Statement *else_list; // else分支(无condition)
  113. struct Statement *finally;
  114. } for_branch;
  115. struct {
  116. struct Statement *try; // first do
  117. struct StatementList *except_list; // for循环体
  118. struct Statement *else_list; // else分支(无condition)
  119. struct Statement *finally;
  120. } try_branch;
  121. struct {
  122. struct StatementList *with_list; // for循环体
  123. struct Statement *else_list; // else分支(无condition)
  124. struct Statement *finally;
  125. } with_branch;
  126. struct {
  127. struct Statement *times;
  128. } break_cycle;
  129. struct {
  130. struct Statement *times;
  131. } continue_cycle;
  132. struct {
  133. struct Statement *times;
  134. } rego_if;
  135. struct {
  136. struct Statement *times;
  137. } restart;
  138. struct {
  139. struct Statement *value;
  140. } return_code;
  141. struct {
  142. struct Statement *value;
  143. } raise_code;
  144. struct {
  145. struct Statement *file;
  146. } include_file;
  147. struct {
  148. struct Statement *file;
  149. struct Statement *as;
  150. } import_file;
  151. struct {
  152. struct Statement *file;
  153. struct Parameter *pt;
  154. struct Parameter *as;
  155. } from_import_file;
  156. struct {
  157. struct Parameter *var;
  158. enum DefaultType{
  159. default_,
  160. global_,
  161. nonlocal_,
  162. } default_type;
  163. } default_var;
  164. struct {
  165. struct Statement *conditions;
  166. } assert;
  167. }u;
  168. long int line;
  169. char *code_file;
  170. struct Statement *next;
  171. };
  172. struct StatementList{
  173. enum {
  174. if_b,
  175. do_b,
  176. while_b,
  177. except_b,
  178. } type;
  179. struct Statement *condition;
  180. struct Statement *var;
  181. struct Statement *code;
  182. struct StatementList *next;
  183. };
  184. typedef struct Token Token;
  185. typedef struct Statement Statement;
  186. typedef struct StatementList StatementList;
  187. Statement *makeStatement(long int line, char *file);
  188. void freeStatement(Statement *st);
  189. Statement *copyStatement(Statement *st);
  190. Statement *copyStatementCore(Statement *st);
  191. void connectStatement(Statement *base, Statement *new);
  192. Statement *makeOperationBaseStatement(enum OperationType type, long int line, char *file);
  193. Statement *makeOperationStatement(enum OperationType type, Statement *left, Statement *right);
  194. Statement *makeBaseLinkValueStatement(LinkValue *value, long int line, char *file);
  195. Statement *makeBaseStrValueStatement(char *value, enum BaseValueType type, long int line, char *file);
  196. Statement *makeBaseVarStatement(char *name, Statement *times, long int line, char *file);
  197. Statement *makeBaseSVarStatement(Statement *name, Statement *times);
  198. Statement *makeBaseDictStatement(Parameter *pt, long int line, char *file);
  199. Statement *makeTupleStatement(Parameter *pt, enum ListType type, long int line, char *file);
  200. Statement *makeClassStatement(Statement *name, Statement *function, Parameter *pt);
  201. Statement *makeFunctionStatement(Statement *name, Statement *function, struct Parameter *pt);
  202. Statement *makeLambdaStatement(Statement *function, Parameter *pt);
  203. Statement *makeCallStatement(Statement *function, struct Parameter *pt);
  204. Statement *makeIfStatement(long int line, char *file);
  205. Statement *makeWhileStatement(long int line, char *file);
  206. Statement *makeTryStatement(long int line, char *file);
  207. Statement *makeBreakStatement(Statement *times, long int line, char *file);
  208. Statement *makeContinueStatement(Statement *times, long int line, char *file);
  209. Statement *makeRegoStatement(Statement *times, long int line, char *file);
  210. Statement *makeRestartStatement(Statement *times, long int line, char *file);
  211. Statement *makeReturnStatement(Statement *value, long int line, char *file);
  212. Statement *makeRaiseStatement(Statement *value, long int line, char *file);
  213. Statement *makeAssertStatement(Statement *conditions, long int line, char *file);
  214. Statement *makeIncludeStatement(Statement *file, long int line, char *file_dir);
  215. Statement *makeImportStatement(Statement *file, Statement *as);
  216. Statement *makeFromImportStatement(Statement *file, Parameter *as, Parameter *pt);
  217. Statement *makeDefaultVarStatement(Parameter *var, long int line, char *file_dir, enum DefaultType type);
  218. struct Token *setOperationFromToken(Statement **st_ad, struct Token *left, struct Token *right, enum OperationType type, bool is_right);
  219. StatementList *makeStatementList(Statement *condition, Statement *var, Statement *code, int type);
  220. StatementList *connectStatementList(StatementList *base, StatementList *new);
  221. void freeStatementList(StatementList *base);
  222. StatementList *copyStatementList(StatementList *sl);
  223. #endif //VIRTUALMATH_STATEMENT_H