value.h 4.7 KB

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