value.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. #ifndef VIRTUALMATH_VALUE_H
  2. #define VIRTUALMATH_VALUE_H
  3. #include "__macro.h"
  4. #include "gc.h"
  5. #include "run.h"
  6. struct VarList;
  7. struct Argument;
  8. struct FatherValue;
  9. typedef enum ResultType (*OfficialFunction)(OfficialFunctionSig);
  10. typedef void (*Registered)(RegisteredFunctionSig);
  11. enum ValueAuthority{
  12. auto_aut,
  13. public_aut,
  14. protect_aut,
  15. private_aut
  16. };
  17. struct Value{
  18. struct GCStatus gc_status;
  19. enum ValueType{
  20. none=0,
  21. number=1,
  22. string=2,
  23. function=3,
  24. list=4,
  25. dict=5,
  26. class=6,
  27. object_=7,
  28. bool_=8,
  29. pass_=9,
  30. } type;
  31. struct {
  32. struct VarList *var;
  33. struct VarList *out_var;
  34. struct FatherValue *father;
  35. } object;
  36. union data{
  37. struct Number{
  38. NUMBER_TYPE num;
  39. } num;
  40. struct String{
  41. char *str;
  42. } str;
  43. struct Function{
  44. enum{
  45. c_function,
  46. vm_function,
  47. } type;
  48. struct Statement *function;
  49. struct Parameter *pt;
  50. OfficialFunction of;
  51. struct {
  52. enum FunctionPtType{
  53. free_, // 不包含任何隐式传递的参数
  54. static_, // 不包含self参数
  55. object_static_, // self参数不允许class
  56. class_static_, // self参数允许一切father
  57. object_free_, // 同object_static_但不包含func参数
  58. class_free_, // 同object_static_但不包含func参数
  59. } pt_type;
  60. } function_data;
  61. } function;
  62. struct List{
  63. enum ListType{
  64. value_tuple,
  65. value_list,
  66. } type;
  67. struct LinkValue **list;
  68. NUMBER_TYPE size; // TODO-szh typedef NUMBER_TYPE
  69. } list;
  70. struct Dict{
  71. struct HashTable *dict;
  72. NUMBER_TYPE size;
  73. } dict;
  74. struct Bool{
  75. bool bool_;
  76. } bool_;
  77. }data;
  78. struct Value *gc_next;
  79. struct Value *gc_last;
  80. };
  81. struct LinkValue{
  82. struct GCStatus gc_status;
  83. enum ValueAuthority aut;
  84. struct Value *value;
  85. struct LinkValue *father;
  86. struct LinkValue *gc_next;
  87. struct LinkValue *gc_last;
  88. };
  89. struct Result{
  90. enum ResultType{
  91. not_return = 1, // 无返回值
  92. function_return=2, // 函数返回值
  93. operation_return=3, // 表达式返回值
  94. error_return=4, // 错误
  95. break_return=5,
  96. continue_return=6,
  97. rego_return=7,
  98. restart_return=8,
  99. goto_return=9,
  100. yield_return=10,
  101. } type;
  102. char *label;
  103. struct LinkValue *value;
  104. struct Error *error;
  105. int times;
  106. struct Statement *node;
  107. };
  108. struct Error{
  109. char *type;
  110. char *messgae;
  111. char *file;
  112. long int line;
  113. struct Error *next;
  114. };
  115. struct FatherValue{
  116. struct LinkValue *value;
  117. struct FatherValue *next;
  118. };
  119. typedef struct Inter Inter;
  120. typedef struct Value Value;
  121. typedef struct LinkValue LinkValue;
  122. typedef struct Result Result;
  123. typedef struct Error Error;
  124. typedef struct FatherValue FatherValue;
  125. typedef enum ResultType ResultType;
  126. Value *makeObject(Inter *inter, VarList *object, VarList *out_var, FatherValue *father);
  127. void freeValue(Value **Value);
  128. LinkValue *makeLinkValue(Value *value, LinkValue *linkValue,Inter *inter);
  129. void freeLinkValue(LinkValue **value);
  130. LinkValue *copyLinkValue(LinkValue *value, Inter *inter);
  131. Value *makeNoneValue(Inter *inter);
  132. Value *makeBoolValue(bool bool_num, Inter *inter);
  133. Value *makePassValue(Inter *inter);
  134. Value *makeNumberValue(long num, Inter *inter);
  135. Value *makeStringValue(char *str, Inter *inter);
  136. Value *makeVMFunctionValue(struct Statement *st, struct Parameter *pt, struct VarList *var_list, Inter *inter);
  137. Value *makeCFunctionValue(OfficialFunction of, VarList *var_list, Inter *inter);
  138. Value *makeClassValue(VarList *var_list, Inter *inter, FatherValue *father);
  139. Value *makeListValue(struct Argument **arg_ad, Inter *inter, enum ListType type);
  140. Value *makeDictValue(struct Argument **arg_ad, bool new_hash, INTER_FUNCTIONSIG_NOT_ST);
  141. void setResultCore(Result *ru);
  142. void setResult(Result *ru, Inter *inter, LinkValue *father);
  143. void setResultBase(Result *ru, Inter *inter, LinkValue *father);
  144. void setResultErrorSt(Result *ru, Inter *inter, char *error_type, char *error_message, Statement *st, LinkValue *father, bool new);
  145. void setResultError(Result *ru, Inter *inter, char *error_type, char *error_message, long int line, char *file, LinkValue *father, bool new);
  146. void setResultOperationNone(Result *ru, Inter *inter, LinkValue *father);
  147. void setResultOperation(Result *ru, LinkValue *value);
  148. void setResultOperationBase(Result *ru, LinkValue *value);
  149. void freeResult(Result *ru);
  150. void freeResultSafe(Result *ru);
  151. Error *makeError(char *type, char *message, long int line, char *file);
  152. void freeError(Result *base);
  153. Error *connectError(Error *new, Error *base);
  154. void printError(Result *result, Inter *inter, bool free);
  155. void printValue(Value *value, FILE *debug, bool print_father);
  156. void printLinkValue(LinkValue *value, char *first, char *last, FILE *debug);
  157. bool isType(Value *value, enum ValueType type);
  158. FatherValue *makeFatherValue(LinkValue *value);
  159. FatherValue *copyFatherValue(FatherValue *value);
  160. FatherValue *freeFatherValue(FatherValue *value);
  161. FatherValue *connectFatherValue(FatherValue *base, FatherValue *back);
  162. FatherValue *connectSafeFatherValue(FatherValue *base, FatherValue *back);
  163. bool checkAttribution(Value *self, Value *father);
  164. FatherValue *getFatherFromValue(Value *value, Inter *inter);
  165. #endif //VIRTUALMATH_VALUE_H