inter.h 4.2 KB

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