语法分析程序集.static.e.txt 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. .版本 2
  2. .支持库 spec
  3. .支持库 eAPI
  4. .程序集 语法分析程序集
  5. .程序集变量 AST根, 抽象语法树节点
  6. .程序集变量 词, 词, , "0"
  7. .程序集变量 当前词游标, 整数型
  8. .子程序 语法分析
  9. .参数 _词, 词, 数组
  10. .局部变量 当前节点, 抽象语法树节点
  11. .局部变量 res, 抽象语法树节点
  12. 复制数组 (词, _词)
  13. 当前词游标 = 0
  14. AST根.初始化内存 (“根”)
  15. .判断循环首 (当前词游标 ≤ 取数组成员数 (词))
  16. res = 匹配表达式 (AST根)
  17. 调试输出 (“匹配表达式 结束”, res.生成展示文本 ())
  18. .如果 (res.失败 ())
  19. 跳出循环 ()
  20. .否则
  21. AST根.添加参数节点 (res)
  22. .如果结束
  23. 跳出循环 ()
  24. .判断循环尾 ()
  25. .子程序 匹配表达式, 抽象语法树节点
  26. .参数 父节点, 抽象语法树节点
  27. .局部变量 l, 抽象语法树节点
  28. .局部变量 r, 抽象语法树节点
  29. .局部变量 当前节点, 抽象语法树节点
  30. .局部变量 右侧无穷, 抽象语法树节点
  31. .局部变量 天父, 抽象语法树节点
  32. 当前节点.初始化内存 (“匹配表达式 之起始”)
  33. 调试输出 (“当前父节点”, 父节点.获取函数名 ())
  34. l = 匹配加后表达式 (当前节点)
  35. .如果真 (l.失败 ())
  36. 调试输出 (“未匹配到左加后表达式”)
  37. 返回 (父节点.生成匹配失败节点 ())
  38. .如果真结束
  39. 当前节点.添加参数节点 (l)
  40. 调试输出 (“匹配到左加后表达式”, l.获取函数名 ())
  41. 右侧无穷 = 匹配表达式右侧无穷 (父节点)
  42. 右侧无穷.插入参数节点 (l)
  43. 天父 = 右侧无穷
  44. .判断循环首 (天父.获取函数名 () ≠ “nop”)
  45. 调试输出 (天父.生成展示文本 ())
  46. 天父 = 天父.获取父节点 ()
  47. .判断循环尾 ()
  48. 天父 = 天父.获取参数节点 (1)
  49. 返回 (天父)
  50. .子程序 匹配表达式右侧无穷, 抽象语法树节点
  51. .参数 父节点, 抽象语法树节点
  52. .局部变量 当前节点, 抽象语法树节点
  53. .局部变量 m, 抽象语法树节点
  54. .局部变量 r, 抽象语法树节点
  55. .局部变量 后续无穷, 抽象语法树节点
  56. 当前节点.初始化内存 (“nop”)
  57. .如果真 (下个词 ().内容 ≠ “+” 且 下个词 ().内容 ≠ “-”)
  58. 调试输出 (“未匹配到+-中算符”)
  59. 返回 (当前节点)
  60. .如果真结束
  61. m = 父节点.生成自词节点 (下个词 ())
  62. 词游标自增 ()
  63. r = 匹配加后表达式 (当前节点)
  64. .如果真 (r.失败 ())
  65. 返回 (父节点.生成匹配失败节点 ())
  66. .如果真结束
  67. .如果 (下个词 ().类型 ≠ #词类_结尾)
  68. 后续无穷 = 匹配表达式右侧无穷 (r)
  69. .如果真 (后续无穷.失败 ())
  70. 返回 (后续无穷)
  71. .如果真结束
  72. .否则
  73. 后续无穷.初始化内存 (“nop”, )
  74. .如果结束
  75. 调试输出 (下个词 ().类型)
  76. m.设置父节点 (后续无穷)
  77. m.添加参数节点 (r)
  78. 后续无穷.插入参数节点 (m)
  79. 返回 (m)
  80. .子程序 匹配加后表达式, 抽象语法树节点
  81. .参数 父节点, 抽象语法树节点
  82. .局部变量 l, 抽象语法树节点
  83. .局部变量 当前节点, 抽象语法树节点
  84. .局部变量 右侧无穷, 抽象语法树节点
  85. .局部变量 r, 抽象语法树节点
  86. .局部变量 天父, 抽象语法树节点
  87. 当前节点.初始化内存 ()
  88. 调试输出 (“当前父节点”, 父节点.获取函数名 ())
  89. l = 匹配因子 (父节点)
  90. .如果真 (l.失败 ())
  91. 调试输出 (“未匹配到左数字”)
  92. 返回 (父节点.生成匹配失败节点 ())
  93. .如果真结束
  94. 调试输出 (“匹配到左数字”, l.获取函数名 ())
  95. 当前节点.添加参数节点 (l)
  96. 右侧无穷 = 匹配加后表达式右侧无穷 (父节点)
  97. .如果真 (右侧无穷.获取参数数量 () > 0)
  98. 调试输出 (“右侧无穷”, 右侧无穷.获取参数节点 (1).生成展示文本 ())
  99. .如果真结束
  100. 右侧无穷.插入参数节点 (l)
  101. 调试输出 (“右侧无穷”, 右侧无穷.获取参数节点 (1).生成展示文本 ())
  102. 天父 = 右侧无穷
  103. .判断循环首 (天父.获取函数名 () ≠ “nop”)
  104. 调试输出 (天父.生成展示文本 ())
  105. 天父 = 天父.获取父节点 ()
  106. .判断循环尾 ()
  107. 天父 = 天父.获取参数节点 (1)
  108. 返回 (天父)
  109. .子程序 匹配加后表达式右侧无穷, 抽象语法树节点
  110. .参数 父节点, 抽象语法树节点
  111. .局部变量 当前节点, 抽象语法树节点
  112. .局部变量 m, 抽象语法树节点
  113. .局部变量 r, 抽象语法树节点
  114. .局部变量 后续无穷, 抽象语法树节点
  115. 当前节点.初始化内存 (“nop”)
  116. .如果真 (下个词 ().内容 ≠ “*” 且 下个词 ().内容 ≠ “/”)
  117. 调试输出 (“未匹配到*/中算符”)
  118. 返回 (当前节点)
  119. .如果真结束
  120. m = 父节点.生成自词节点 (下个词 ())
  121. 词游标自增 ()
  122. r = 匹配因子 (父节点)
  123. .如果真 (r.失败 ())
  124. 返回 (父节点.生成匹配失败节点 ())
  125. .如果真结束
  126. .如果 (下个词 ().类型 ≠ #词类_结尾)
  127. 后续无穷 = 匹配加后表达式右侧无穷 (r)
  128. .如果真 (后续无穷.失败 ())
  129. 返回 (后续无穷)
  130. .如果真结束
  131. .否则
  132. 后续无穷.初始化内存 (“nop”, )
  133. .如果结束
  134. 调试输出 (下个词 ().类型)
  135. m.设置父节点 (后续无穷)
  136. m.添加参数节点 (r)
  137. 后续无穷.插入参数节点 (m)
  138. 返回 (m)
  139. .子程序 匹配因子, 抽象语法树节点
  140. .参数 父节点, 抽象语法树节点
  141. .局部变量 当前节点, 抽象语法树节点
  142. .局部变量 左括号, 抽象语法树节点
  143. .局部变量 中表达式, 抽象语法树节点
  144. .局部变量 右括号, 抽象语法树节点
  145. .局部变量 数字, 抽象语法树节点
  146. .局部变量 函数, 抽象语法树节点
  147. .判断开始 (下个词 ().类型 = #词类_括号)
  148. .如果真 (下个词 ().内容 ≠ “(”)
  149. 返回 (父节点.生成匹配失败节点 ())
  150. .如果真结束
  151. 左括号 = 当前节点.生成自词节点 (下个词 ())
  152. 词游标自增 ()
  153. 中表达式 = 匹配表达式 (当前节点)
  154. .如果真 (下个词 ().内容 ≠ “)”)
  155. 返回 (父节点.生成匹配失败节点 ())
  156. .如果真结束
  157. 右括号 = 当前节点.生成自词节点 (下个词 ())
  158. 词游标自增 ()
  159. 当前节点.初始化内存 (“括号”, 父节点.获取当前节点指针 ())
  160. 当前节点.添加参数节点 (中表达式)
  161. 返回 (当前节点)
  162. .判断 (下个词 ().类型 = #词类_数字)
  163. 数字 = 匹配数字 ()
  164. 返回 (数字)
  165. .默认
  166. 函数 = 匹配函数 (当前节点)
  167. .如果真 (函数.失败 ())
  168. 返回 (父节点.生成匹配失败节点 ())
  169. .如果真结束
  170. ' 当前节点.初始化内存 (“函数”, 父节点.获取当前节点指针 ())
  171. ' 当前节点.添加参数节点 (函数)
  172. 返回 (函数)
  173. .判断结束
  174. .子程序 匹配函数, 抽象语法树节点
  175. .参数 父节点, 抽象语法树节点
  176. .局部变量 当前节点, 抽象语法树节点
  177. .局部变量 标识符, 抽象语法树节点
  178. .局部变量 参数, 抽象语法树节点
  179. .局部变量 右侧无穷, 抽象语法树节点
  180. .局部变量 括号内下一表达式, 抽象语法树节点
  181. .如果真 (下个词 ().类型 ≠ #词类_标识符)
  182. 返回 (父节点.生成匹配失败节点 ())
  183. .如果真结束
  184. 标识符 = 匹配标识符 (当前节点)
  185. .如果真 (下个词 ().内容 ≠ “(”)
  186. 返回 (父节点.生成匹配失败节点 ())
  187. .如果真结束
  188. 词游标自增 ()
  189. .如果真 (下个词 ().内容 = “)”)
  190. 词游标自增 ()
  191. 返回 (标识符)
  192. .如果真结束
  193. 参数 = 匹配表达式 (当前节点)
  194. .如果真 (下个词 ().内容 = “)”)
  195. 标识符.添加参数节点 (参数)
  196. 词游标自增 ()
  197. 返回 (标识符)
  198. 返回 (父节点.生成匹配失败节点 ())
  199. .如果真结束
  200. 标识符.添加参数节点 (参数)
  201. .判断循环首 (真)
  202. .如果真 (下个词 ().类型 ≠ #词类_逗号 或 假) ' 去掉「 或 假」后会触发e2txt的bug, 无法从.txt转回.e
  203. 返回 (父节点.生成匹配失败节点 ())
  204. .如果真结束
  205. 词游标自增 ()
  206. 括号内下一表达式 = 匹配表达式 (当前节点)
  207. .如果真 (括号内下一表达式.失败 ())
  208. 返回 (父节点.生成匹配失败节点 ())
  209. .如果真结束
  210. 标识符.添加参数节点 (括号内下一表达式)
  211. .如果真 (下个词 ().内容 = “)”)
  212. 词游标自增 ()
  213. 跳出循环 ()
  214. .如果真结束
  215. .判断循环尾 ()
  216. 返回 (标识符)
  217. .子程序 匹配标识符, 抽象语法树节点
  218. .参数 父节点, 抽象语法树节点
  219. .局部变量 当前节点, 抽象语法树节点
  220. 当前节点.初始化内存 ()
  221. .如果 (下个词 ().类型 ≠ #词类_标识符)
  222. 当前节点.释放结构内存 ()
  223. 返回 (当前节点.生成匹配失败节点 ())
  224. .否则
  225. 当前节点.设置函数名 (下个词 ().内容)
  226. 词游标自增 ()
  227. 返回 (当前节点)
  228. .如果结束
  229. .子程序 匹配数字, 抽象语法树节点
  230. .局部变量 当前节点, 抽象语法树节点
  231. 当前节点.初始化内存 ()
  232. .如果 (下个词 ().类型 ≠ #词类_数字)
  233. 当前节点.释放结构内存 ()
  234. 返回 (当前节点.生成匹配失败节点 ())
  235. .否则
  236. 当前节点.设置函数名 (下个词 ().内容)
  237. 词游标自增 ()
  238. 返回 (当前节点)
  239. .如果结束
  240. .子程序 下个词, 词
  241. .局部变量 返回词, 词
  242. .如果 (当前词游标 ≥ 取数组成员数 (词))
  243. 返回词.内容 = “”
  244. 返回词.类型 = #词类_结尾
  245. .否则
  246. 返回词 = 词 [当前词游标 + 1]
  247. .如果结束
  248. 返回 (返回词)
  249. .子程序 词游标自增
  250. 当前词游标 = 当前词游标 + 1
  251. 调试输出 (格式化文本 (“游标增至 %d 下一个:(%d,%s)”, 当前词游标, 下个词 ().类型, 下个词 ().内容))
  252. .子程序 词游标自减
  253. 当前词游标 = 当前词游标 - 1
  254. 调试输出 (格式化文本 (“游标减至 %d 下一个:(%d,%s)”, 当前词游标, 下个词 ().类型, 下个词 ().内容))
  255. .子程序 重复文本, 文本型
  256. .参数 n, 整数型
  257. .参数 s, 文本型
  258. .局部变量 res, 文本型
  259. res = “”
  260. .计次循环首 (n, )
  261. res = res + s
  262. .计次循环尾 ()
  263. 返回 (res)
  264. .子程序 输出语法分析结果
  265. .参数 AST, 抽象语法树节点
  266. .参数 当前层级, 整数型, 可空
  267. .局部变量 i, 整数型
  268. .如果真 (是否为空 (当前层级))
  269. 当前层级 = 0
  270. .如果真结束
  271. 标准输出 (, 重复文本 (当前层级 × 2, “ ”))
  272. 标准输出 (, AST.生成展示文本 () + #换行符)
  273. .计次循环首 (AST.获取参数数量 (), i)
  274. 输出语法分析结果 (AST.获取参数节点 (i), 当前层级 + 1)
  275. .计次循环尾 ()
  276. .子程序 语法分析并输出
  277. .参数 表达式, 文本型
  278. .局部变量 t0, 长整数型
  279. t0 = 时间_取现行时间戳1 (真)
  280. 词法分析 (表达式, 词)
  281. 语法分析 (词)
  282. 标准输出 (, “用时 ” + 到文本 (时间_取现行时间戳1 (真) - t0) + “ms” + #换行符)
  283. 输出语法分析结果 (AST根)