statement.h 7.1 KB

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