inter.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. #ifndef AFUN_INTER_H
  2. #define AFUN_INTER_H
  3. #include <list>
  4. #include <mutex>
  5. #include "aFuntool.h"
  6. #include "aFunCoreExport.h"
  7. #include "code.h"
  8. #include "env-var.h"
  9. #include "msg.h"
  10. namespace aFuncore {
  11. class Activation;
  12. class GcObjectBase;
  13. class Var;
  14. class ProtectVarSpace;
  15. class VarSpace;
  16. class VarList;
  17. class Object;
  18. class Inter;
  19. class AFUN_CORE_EXPORT Environment {
  20. friend class Object;
  21. friend class Var;
  22. friend class VarSpace;
  23. friend class Inter;
  24. public:
  25. explicit Environment(int argc = 0, char **argv = nullptr);
  26. ~Environment() noexcept(false);
  27. Environment(Environment &) = delete;
  28. Environment &operator=(Environment &) = delete;
  29. inline size_t operator++();
  30. inline size_t operator--();
  31. inline size_t operator++(int);
  32. inline size_t operator--(int);
  33. private:
  34. std::mutex lock;
  35. size_t reference; // 引用计数
  36. bool destruct;
  37. std::list<GcObjectBase *> gc;
  38. Inter &gc_inter; /* 需要在lock和reference后初始化 */
  39. ProtectVarSpace *const protect; // 保护变量空间
  40. VarSpace *const global; // 全局变量空间
  41. VarList *const global_varlist; // global + protect
  42. EnvVarSpace envvar;
  43. };
  44. class AFUN_CORE_EXPORT Inter {
  45. friend class Activation;
  46. struct LiteralRegex;
  47. public:
  48. typedef enum InterStatus {
  49. inter_creat = 0,
  50. inter_init = 1, // 执行初始化程序
  51. inter_normal = 2, // 正常执行
  52. inter_stop = 3, // 当前运算退出
  53. inter_exit = 4, // 解释器退出
  54. } InterStatus;
  55. typedef enum Prefix {
  56. prefix_quote = 0, // 变量引用
  57. prefix_exec_first = 1,
  58. } Prefix;
  59. static const int PREFIX_COUNT = 2;
  60. constexpr static const char *E_PREFIX = "$`'"; /* NOLINT element前缀 */
  61. constexpr static const char *B_PREFIX = "$`'%^&<?>"; /* NOLINT block前缀 */
  62. constexpr static const char *ALL_PREFIX = "$`'%^&<?>"; /* NOLINT block前缀 */
  63. explicit Inter(Environment &env_);
  64. Inter(const Inter &base_inter);
  65. ~Inter();
  66. Inter &operator=(const Inter &) = delete;
  67. void enable();
  68. [[nodiscard]] inline InterStatus getStatus() const;
  69. [[nodiscard]] inline bool isInterStop() const;
  70. [[nodiscard]] inline bool isInterExit() const;
  71. [[nodiscard]] inline Environment &getEnvironment();
  72. [[nodiscard]] inline ProtectVarSpace *getProtectVarSpace() const;
  73. [[nodiscard]] inline VarSpace *getGlobalVarSpace() const;
  74. [[nodiscard]] inline VarList *getGlobalVarlist() const;
  75. [[nodiscard]] inline const std::list<Activation *> &getStack() const;
  76. [[nodiscard]] inline Activation *getActivation() const;
  77. [[nodiscard]] bool checkLiteral(const std::string &element) const;
  78. [[nodiscard]] bool checkLiteral(const std::string &element, std::string &literaler, bool &in_protect) const;
  79. [[nodiscard]] inline EnvVarSpace &getEnvVarSpace();
  80. [[nodiscard]] inline InterOutMessage &getOutMessageStream();
  81. [[nodiscard]] inline InterInMessage &getInMessageStream();
  82. bool pushLiteral(const std::string &pattern, const std::string &literaler, bool in_protect);
  83. bool runCode();
  84. bool runCode(const Code &code);
  85. bool runCode(Object *obj);
  86. inline InterStatus setInterStop();
  87. inline InterStatus setInterExit();
  88. private:
  89. InterStatus status;
  90. Environment &env;
  91. std::list<Activation *> stack;
  92. Activation *activation; // 活动记录
  93. InterOutMessage out;
  94. InterInMessage in;
  95. std::list<LiteralRegex> literal;
  96. inline void pushActivation(Activation *new_activation);
  97. inline Activation *popActivation();
  98. };
  99. struct Inter::LiteralRegex {
  100. aFuntool::Regex rg;
  101. std::string pattern; // 派生 LiteralRegex 时使用
  102. std::string literaler; // 调用的函数
  103. bool in_protect; // 是否在protect空间
  104. };
  105. }
  106. #include "inter.inline.h"
  107. #endif //AFUN_INTER_H