即时解释虚拟机.static.e.txt 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322
  1. .版本 2
  2. .支持库 spec
  3. .支持库 eAPI
  4. .程序集 即时解释虚拟机
  5. .程序集变量 词, 词, , "0"
  6. .程序集变量 函数列表, 抽象语法树节点, , "0"
  7. .程序集变量 上一运算结果, 双精度小数型
  8. .子程序 解释代码入口
  9. .参数 代码, 文本型
  10. .局部变量 行, 文本型, , "0"
  11. .局部变量 i, 整数型
  12. .局部变量 根, 抽象语法树节点
  13. 行 = 分割文本 (代码, #换行符, )
  14. .计次循环首 (取数组成员数 (行), i)
  15. 词法分析 (行 [i], 词)
  16. 根 = 语法分析 (词)
  17. ' 输出语法分析结果 (根, )
  18. 解释代码 (根)
  19. .计次循环尾 ()
  20. .子程序 交互运行
  21. .局部变量 根, 抽象语法树节点
  22. .局部变量 解释返回, 文本型
  23. .判断循环首 (真)
  24. 标准输出 (, “ve > ”)
  25. 词法分析 (标准输入 (), 词)
  26. 根 = 语法分析 (词)
  27. .如果真 (解释代码 (根) = “表达式求值”)
  28. 标准输出 (, 到文本 (上一运算结果) + #换行符)
  29. .如果真结束
  30. .判断循环尾 ()
  31. .子程序 解释代码, 文本型
  32. .参数 节点, 抽象语法树节点
  33. .局部变量 节点语类, 整数型
  34. .局部变量 节点词类, 整数型
  35. .局部变量 节点参量, 整数型
  36. .局部变量 节点名, 文本型
  37. 节点语类 = 节点.获取语类 ()
  38. 节点词类 = 节点.获取词类 ()
  39. 节点参量 = 节点.获取参数数量 ()
  40. 节点名 = 节点.获取函数名 ()
  41. .如果真 (节点语类 = #语类_根)
  42. .如果 (节点参量 = 1)
  43. 返回 (解释代码 (节点.获取参数节点 (1)))
  44. .否则
  45. .如果真 (节点参量 > 1)
  46. 调试输出 (“警告 根节点有超过一个子节点”)
  47. .如果真结束
  48. .如果结束
  49. .如果真结束
  50. .如果真 (节点.包含语类 (#语类_nop))
  51. 调试输出 (“警告 nop 泄露到了运行时”)
  52. .如果真结束
  53. .如果真 (节点词类 = #词类_注释)
  54. 返回 (“注释”)
  55. .如果真结束
  56. .如果真 (节点语类 = #语类_定义)
  57. ' 现在所有的定义都是函数定义
  58. 添加函数 (节点)
  59. 返回 (“定义”)
  60. .如果真结束
  61. .如果真 (节点.包含语类 (#语类_函数调用))
  62. ' 这里的函数调用包含 f(x) 式的, 也包含 1+1 式的
  63. 上一运算结果 = 表达式求值 (节点, , )
  64. 返回 (“表达式求值”)
  65. .如果真结束
  66. 返回 (“无匹配”)
  67. .子程序 表达式求值, 双精度小数型
  68. .参数 节点, 抽象语法树节点
  69. .参数 可用上层参数名, 文本型, 可空 数组
  70. .参数 可用上层参数值, 双精度小数型, 可空 数组
  71. .局部变量 节点名, 文本型
  72. .局部变量 i, 整数型
  73. .局部变量 待输出文本组, 文本型, , "0"
  74. .局部变量 待输出文本, 文本型
  75. .局部变量 节点词类, 整数型
  76. 节点名 = 节点.获取函数名 ()
  77. 节点词类 = 节点.获取词类 ()
  78. ' 调试输出 (“准备表达式求值”, 节点.生成展示文本 (), 可用上层参数名, 可用上层参数值)
  79. .如果真 (节点名 = “output”)
  80. 清除数组 (待输出文本组)
  81. .计次循环首 (节点.获取参数数量 (), i)
  82. 加入成员 (待输出文本组, 格式化文本 (“%s”, 到文本 (表达式求值 (节点.获取参数节点 (i)))))
  83. .计次循环尾 ()
  84. 待输出文本 = 连接字符串 (待输出文本组, “, ”) + #换行符
  85. 标准输出 (, 待输出文本)
  86. 返回 (取文本长度 (待输出文本) - 2) ' #换行符长度为2
  87. .如果真结束
  88. .如果真 (节点名 = “dir”)
  89. 标准输出 (, “当前函数如下: ” + #换行符)
  90. .计次循环首 (取数组成员数 (函数列表), i)
  91. 标准输出 (, 到文本 (i) + #换行符)
  92. 输出语法分析结果 (函数列表 [i], )
  93. .计次循环尾 ()
  94. 返回 (取数组成员数 (函数列表))
  95. .如果真结束
  96. .如果真 (节点词类 = #词类_数字)
  97. 返回 (到数值 (节点名))
  98. .如果真结束
  99. .如果真 (节点词类 = #词类_算符)
  100. 返回 (处理算符 (节点, 可用上层参数名, 可用上层参数值))
  101. .如果真结束
  102. .如果真 (节点词类 = #词类_括号)
  103. 返回 (表达式求值 (节点.获取参数节点 (1), 可用上层参数名, 可用上层参数值))
  104. .如果真结束
  105. .如果真 (节点.获取参数数量 () = 0 且 节点词类 = #词类_标识符)
  106. 返回 (处理标识符 (节点, 可用上层参数名, 可用上层参数值))
  107. .如果真结束
  108. ' 到这个地步 只有 f(x) 式的函数调用了
  109. 返回 (处理函数调用 (节点, 可用上层参数名, 可用上层参数值))
  110. .子程序 处理标识符, 双精度小数型, , 如果要处理标识符值, 应当从当前函数参数值中找匹配的标识符
  111. .参数 节点, 抽象语法树节点
  112. .参数 可用上层参数名, 文本型, 可空 数组
  113. .参数 可用上层参数值, 双精度小数型, 可空 数组
  114. .局部变量 i, 整数型
  115. .局部变量 节点名, 文本型
  116. 节点名 = 节点.获取函数名 ()
  117. ' 调试输出 (可用上层参数名, 可用上层参数值)
  118. .计次循环首 (取数组成员数 (可用上层参数名), i)
  119. .如果真 (节点名 = 可用上层参数名 [i])
  120. 返回 (可用上层参数值 [i])
  121. .如果真结束
  122. .计次循环尾 ()
  123. 标准输出 (, “[错误] 找不到标识符: ” + 节点名 + #换行符)
  124. 标准输入 ()
  125. 结束 ()
  126. 返回 (0)
  127. .子程序 处理函数调用, 双精度小数型, , 只处理 f(x) 式的
  128. .参数 节点, 抽象语法树节点
  129. .参数 可用上层参数名, 文本型, 可空 数组
  130. .参数 可用上层参数值, 双精度小数型, 可空 数组
  131. .局部变量 节点名, 文本型
  132. .局部变量 节点词类, 整数型
  133. .局部变量 参数数量, 整数型
  134. .局部变量 i, 整数型
  135. .局部变量 函数原型, 抽象语法树节点
  136. .局部变量 同参量函数, 抽象语法树节点, , "0"
  137. .局部变量 同参量函数_匹配度, 整数型, , "0"
  138. .局部变量 当前最大匹配度, 整数型
  139. .局部变量 当前最大匹配度索引, 整数型
  140. .局部变量 同名函数数, 整数型
  141. .局部变量 参数求值结果, 双精度小数型, , "0"
  142. .局部变量 参数值完全匹配数量, 整数型
  143. .局部变量 函数参数索引, 整数型
  144. .局部变量 待匹配参数节点, 抽象语法树节点
  145. .局部变量 当前待匹配值, 双精度小数型
  146. .局部变量 当前匹配度, 整数型
  147. .局部变量 可用本层参数名, 文本型, 数组, "0"
  148. .局部变量 可用本层参数值, 双精度小数型, 数组, "0"
  149. .局部变量 待调用函数, 抽象语法树节点
  150. .局部变量 当前结果, 双精度小数型
  151. 节点名 = 节点.获取函数名 ()
  152. 节点词类 = 节点.获取词类 ()
  153. 参数数量 = 节点.获取参数数量 ()
  154. 清除数组 (参数求值结果)
  155. .计次循环首 (参数数量, i)
  156. 当前结果 = 表达式求值 (节点.获取参数节点 (i), 可用上层参数名, 可用上层参数值)
  157. 加入成员 (参数求值结果, 当前结果)
  158. ' 调试输出 (“参数求值结果”, 节点.获取参数节点 (i).获取函数名 (), 当前结果)
  159. .计次循环尾 ()
  160. ' 找同名函数
  161. 清除数组 (同参量函数)
  162. 清除数组 (同参量函数_匹配度)
  163. 清除数组 (可用本层参数名)
  164. 清除数组 (可用本层参数值)
  165. .计次循环首 (取数组成员数 (函数列表), i)
  166. 函数原型 = 函数列表 [i].获取参数节点 (1)
  167. .如果真 (函数原型.获取函数名 () = 节点名)
  168. 同名函数数 = 同名函数数 + 1
  169. .如果真 (函数原型.获取参数数量 () = 参数数量)
  170. 加入成员 (同参量函数, 函数列表 [i])
  171. 参数值完全匹配数量 = 0
  172. .计次循环首 (参数数量, 函数参数索引)
  173. 待匹配参数节点 = 函数原型.获取参数节点 (函数参数索引)
  174. ' 词类是标识符的是未知数 不论如何不会增加最佳匹配量, 之外的, 可以求值然后对比值
  175. ' 如果求值结果不同, 一定不能加入匹配, 直接打散到最小上
  176. .如果真 (待匹配参数节点.获取词类 () ≠ #词类_标识符)
  177. 当前待匹配值 = 表达式求值 (待匹配参数节点)
  178. .如果 (当前待匹配值 = 参数求值结果 [函数参数索引])
  179. 参数值完全匹配数量 = 参数值完全匹配数量 + 1
  180. .否则
  181. 参数值完全匹配数量 = -9999
  182. 跳出循环 ()
  183. .如果结束
  184. .如果真结束
  185. .计次循环尾 ()
  186. 加入成员 (同参量函数_匹配度, 参数值完全匹配数量)
  187. .如果真结束
  188. .如果真结束
  189. .计次循环尾 ()
  190. ' 给出合适的报错
  191. .如果真 (同名函数数 = 0)
  192. 标准输出 (, “[错误] 找不到函数 ” + 节点名 + “. 相关上下文如下: ” + #换行符 + #换行符)
  193. 输出语法分析结果 (节点, )
  194. 标准输入 ()
  195. 结束 ()
  196. .如果真结束
  197. .如果真 (取数组成员数 (同参量函数) = 0)
  198. 标准输出 (, “[错误] 找不到可重载函数, 同名函数有: ” + #换行符)
  199. .计次循环首 (取数组成员数 (同参量函数), i)
  200. 标准输出 (, 到文本 (i) + “:” + #换行符)
  201. 输出语法分析结果 (同参量函数 [i], )
  202. .计次循环尾 ()
  203. 标准输入 ()
  204. 结束 ()
  205. .如果真结束
  206. ' 找到最佳匹配度的那个函数
  207. 当前最大匹配度 = -99999
  208. 当前最大匹配度索引 = 0
  209. .计次循环首 (取数组成员数 (同参量函数), i)
  210. 当前匹配度 = 同参量函数_匹配度 [i]
  211. .如果真 (当前匹配度 > 当前最大匹配度)
  212. 当前最大匹配度索引 = i
  213. 当前最大匹配度 = 当前匹配度
  214. .如果真结束
  215. .计次循环尾 ()
  216. ' 把标识符参数拿出来并给值
  217. 函数原型 = 同参量函数 [当前最大匹配度索引].获取参数节点 (1)
  218. 待调用函数 = 同参量函数 [当前最大匹配度索引].获取参数节点 (2)
  219. ' 输出语法分析结果 (同参量函数 [当前最大匹配度索引], )
  220. ' 输出语法分析结果 (函数原型, )
  221. .计次循环首 (参数数量, 函数参数索引)
  222. 待匹配参数节点 = 函数原型.获取参数节点 (函数参数索引)
  223. ' 输出语法分析结果 (待匹配参数节点, )
  224. .如果真 (待匹配参数节点.获取词类 () = #词类_标识符)
  225. 加入成员 (可用本层参数名, 函数原型.获取参数节点 (函数参数索引).获取函数名 ())
  226. 加入成员 (可用本层参数值, 参数求值结果 [函数参数索引])
  227. ' 调试输出 (“可用本层参数”, 函数原型.获取参数节点 (函数参数索引).获取函数名 (), 参数求值结果 [函数参数索引])
  228. .如果真结束
  229. .计次循环尾 ()
  230. ' 调试输出 (“调用一个函数”, 节点.生成展示文本 ())
  231. 返回 (表达式求值 (待调用函数, 可用本层参数名, 可用本层参数值))
  232. .子程序 处理算符, 双精度小数型
  233. .参数 节点, 抽象语法树节点
  234. .参数 可用上层参数名, 文本型, 可空 数组
  235. .参数 可用上层参数值, 双精度小数型, 可空 数组
  236. .局部变量 节点名, 文本型
  237. .局部变量 l, 双精度小数型
  238. .局部变量 r, 双精度小数型
  239. 节点名 = 节点.获取函数名 ()
  240. ' 调试输出 (可用上层参数名, 可用上层参数值)
  241. l = 表达式求值 (节点.获取参数节点 (1), 可用上层参数名, 可用上层参数值)
  242. r = 表达式求值 (节点.获取参数节点 (2), 可用上层参数名, 可用上层参数值)
  243. .判断开始 (节点名 = “+”)
  244. 返回 (l + r)
  245. .判断 (节点名 = “-”)
  246. 返回 (l - r)
  247. .判断 (节点名 = “*”)
  248. 返回 (l × r)
  249. .判断 (节点名 = “/”)
  250. 返回 (l ÷ r)
  251. .默认
  252. 调试输出 (“警告 遇到奇怪的算符”, 节点名)
  253. .判断结束
  254. 返回 (0)
  255. .子程序 添加函数
  256. .参数 节点, 抽象语法树节点
  257. 调试输出 (“新增一个函数”, 节点.获取参数节点 (1).获取函数名 ())
  258. 加入成员 (函数列表, 节点)
  259. .子程序 取最小, 双精度小数型
  260. .参数 a, 双精度小数型
  261. .参数 b, 双精度小数型
  262. .如果真 (a > b)
  263. 返回 (b)
  264. .如果真结束
  265. 返回 (a)