value.h 4.9 KB

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