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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442
  1. .版本 2
  2. .支持库 spec
  3. .程序集 语法分析程序集
  4. .程序集变量 AST根, 抽象语法树节点, 数组
  5. .程序集变量 词, 词, 数组, "0"
  6. .程序集变量 当前词游标, 整数型, 数组
  7. .子程序 语法分析, 抽象语法树节点
  8. .参数 _词, 词, 数组
  9. .局部变量 当前节点, 抽象语法树节点, 数组
  10. .局部变量 res, 抽象语法树节点, 数组
  11. 复制数组 (词, _词)
  12. 当前词游标 = 0
  13. AST根.初始化内存 (“根”)
  14. AST根.设置语类 (#语类_根)
  15. .判断循环首 (下个词 ().类型 ≠ #词类_结尾)
  16. res = 匹配语句 (AST根)
  17. ' 调试输出 (“匹配表达式 结束”, res.生成展示文本 ())
  18. .如果 (res.失败 ())
  19. 跳出循环 ()
  20. .否则
  21. AST根.添加参数节点 (res)
  22. .如果结束
  23. 跳出循环 ()
  24. .判断循环尾 ()
  25. 返回 (AST根)
  26. .子程序 匹配语句, 抽象语法树节点
  27. .参数 父节点, 抽象语法树节点
  28. .局部变量 当前节点, 抽象语法树节点
  29. .局部变量 函数定义, 抽象语法树节点
  30. .局部变量 表达式, 抽象语法树节点
  31. .局部变量 注释, 抽象语法树节点
  32. 当前节点.初始化内存 (“匹配语句 之起始”, )
  33. ' 调试输出 (“当前父节点”, 父节点.获取函数名 ())
  34. .如果真 (下个词 ().类型 = #词类_注释)
  35. 注释 = 父节点.生成自词节点 (下个词 ())
  36. 词游标自增 ()
  37. 返回 (注释)
  38. .如果真结束
  39. .如果 (词存在 (词, #词类_单等号))
  40. ' 这是个赋值语句
  41. 函数定义 = 匹配函数定义 (当前节点)
  42. .如果真 (函数定义.失败 ())
  43. 返回 (父节点.生成匹配失败节点 ())
  44. .如果真结束
  45. 返回 (函数定义)
  46. .否则
  47. 表达式 = 匹配表达式 (当前节点)
  48. .如果真 (表达式.失败 ())
  49. 返回 (父节点.生成匹配失败节点 ())
  50. .如果真结束
  51. 返回 (表达式)
  52. .如果结束
  53. .子程序 匹配函数定义, 抽象语法树节点
  54. .参数 父节点, 抽象语法树节点
  55. .局部变量 函数, 抽象语法树节点
  56. .局部变量 等号, 抽象语法树节点
  57. .局部变量 表达式, 抽象语法树节点
  58. .局部变量 i, 整数型
  59. 函数 = 匹配函数 (父节点)
  60. .如果真 (函数.失败 ())
  61. 返回 (父节点.生成匹配失败节点 ())
  62. .如果真结束
  63. 等号 = 通用词匹配 (#词类_单等号)
  64. .如果真 (等号.失败 ())
  65. 返回 (父节点.生成匹配失败节点 ())
  66. .如果真结束
  67. 表达式 = 匹配表达式 (父节点)
  68. .如果真 (表达式.失败 ())
  69. 返回 (父节点.生成匹配失败节点 ())
  70. .如果真结束
  71. 函数.设置语类 (#语类_函数原型)
  72. .计次循环首 (函数.获取参数数量 (), i)
  73. 函数.获取参数节点 (i).设置语类 (#语类_形式参数)
  74. 函数.获取参数节点 (i).清理语类 (#语类_实际参数)
  75. .计次循环尾 ()
  76. 表达式.设置语类 (#语类_函数调用)
  77. 等号.添加参数节点 (函数)
  78. 等号.添加参数节点 (表达式)
  79. 等号.设置语类 (#语类_定义)
  80. 返回 (等号)
  81. .子程序 匹配表达式, 抽象语法树节点
  82. .参数 父节点, 抽象语法树节点
  83. .局部变量 l, 抽象语法树节点, 数组
  84. .局部变量 r, 抽象语法树节点, 数组
  85. .局部变量 当前节点, 抽象语法树节点, 数组
  86. .局部变量 右侧无穷, 抽象语法树节点, 数组
  87. .局部变量 天父, 抽象语法树节点, 数组
  88. 当前节点.初始化内存 (“匹配表达式 之起始”)
  89. ' 调试输出 (“当前父节点”, 父节点.获取函数名 ())
  90. l = 匹配加后表达式 (当前节点)
  91. l.设置语类 (#语类_实际参数)
  92. .如果真 (l.失败 ())
  93. ' 调试输出 (“未匹配到左加后表达式”)
  94. 返回 (父节点.生成匹配失败节点 ())
  95. .如果真结束
  96. 当前节点.添加参数节点 (l)
  97. ' 调试输出 (“匹配到左加后表达式”, l.获取函数名 ())
  98. 右侧无穷 = 匹配表达式右侧无穷 (父节点)
  99. 右侧无穷.插入参数节点 (l)
  100. 天父 = 右侧无穷
  101. .判断循环首 (天父.获取函数名 () ≠ “nop”)
  102. ' 调试输出 (天父.生成展示文本 ())
  103. 天父 = 天父.获取父节点 ()
  104. .判断循环尾 ()
  105. 天父 = 天父.获取参数节点 (1)
  106. 天父.设置语类 (#语类_函数调用)
  107. 返回 (天父)
  108. .子程序 匹配表达式右侧无穷, 抽象语法树节点
  109. .参数 父节点, 抽象语法树节点
  110. .局部变量 当前节点, 抽象语法树节点, 数组
  111. .局部变量 m, 抽象语法树节点, 数组
  112. .局部变量 r, 抽象语法树节点, 数组
  113. .局部变量 后续无穷, 抽象语法树节点, 数组
  114. 当前节点.初始化内存 (“nop”)
  115. 当前节点.设置语类 (#语类_nop)
  116. .如果真 (下个词 ().内容 ≠ “+” 且 下个词 ().内容 ≠ “-”)
  117. ' 调试输出 (“未匹配到+-中算符”)
  118. 返回 (当前节点)
  119. .如果真结束
  120. m = 父节点.生成自词节点 (下个词 ())
  121. 词游标自增 ()
  122. r = 匹配加后表达式 (当前节点)
  123. r.设置语类 (#语类_实际参数)
  124. .如果真 (r.失败 ())
  125. 返回 (父节点.生成匹配失败节点 ())
  126. .如果真结束
  127. .如果 (下个词 ().类型 ≠ #词类_结尾)
  128. 后续无穷 = 匹配表达式右侧无穷 (r)
  129. .如果真 (后续无穷.失败 ())
  130. 返回 (后续无穷)
  131. .如果真结束
  132. .否则
  133. 后续无穷.初始化内存 (“nop”, )
  134. 后续无穷.设置语类 (#语类_nop)
  135. .如果结束
  136. ' 调试输出 (下个词 ().类型)
  137. m.设置父节点 (后续无穷)
  138. m.添加参数节点 (r)
  139. m.设置语类 (#语类_函数调用)
  140. 后续无穷.插入参数节点 (m)
  141. 返回 (m)
  142. .子程序 匹配加后表达式, 抽象语法树节点
  143. .参数 父节点, 抽象语法树节点
  144. .局部变量 l, 抽象语法树节点, 数组
  145. .局部变量 当前节点, 抽象语法树节点, 数组
  146. .局部变量 右侧无穷, 抽象语法树节点, 数组
  147. .局部变量 r, 抽象语法树节点, 数组
  148. .局部变量 天父, 抽象语法树节点, 数组
  149. 当前节点.初始化内存 ()
  150. ' 调试输出 (“当前父节点”, 父节点.获取函数名 ())
  151. l = 匹配因子 (父节点)
  152. .如果真 (l.失败 ())
  153. 调试输出 (“未匹配到左数字”)
  154. 返回 (父节点.生成匹配失败节点 ())
  155. .如果真结束
  156. ' 调试输出 (“匹配到左数字”, l.获取函数名 ())
  157. 当前节点.添加参数节点 (l)
  158. 右侧无穷 = 匹配加后表达式右侧无穷 (父节点)
  159. .如果真 (右侧无穷.获取参数数量 () > 0)
  160. ' 调试输出 (“右侧无穷”, 右侧无穷.获取参数节点 (1).生成展示文本 ())
  161. .如果真结束
  162. 右侧无穷.插入参数节点 (l)
  163. ' 调试输出 (“右侧无穷”, 右侧无穷.获取参数节点 (1).生成展示文本 ())
  164. 天父 = 右侧无穷
  165. .判断循环首 (天父.获取函数名 () ≠ “nop”)
  166. ' 调试输出 (天父.生成展示文本 ())
  167. 天父 = 天父.获取父节点 ()
  168. .判断循环尾 ()
  169. 天父 = 天父.获取参数节点 (1)
  170. 天父.设置语类 (#语类_函数调用)
  171. 返回 (天父)
  172. .子程序 匹配加后表达式右侧无穷, 抽象语法树节点
  173. .参数 父节点, 抽象语法树节点
  174. .局部变量 当前节点, 抽象语法树节点, 数组
  175. .局部变量 m, 抽象语法树节点, 数组
  176. .局部变量 r, 抽象语法树节点, 数组
  177. .局部变量 后续无穷, 抽象语法树节点, 数组
  178. 当前节点.初始化内存 (“nop”)
  179. 当前节点.设置语类 (#语类_nop)
  180. .如果真 (下个词 ().内容 ≠ “*” 且 下个词 ().内容 ≠ “/”)
  181. ' 调试输出 (“未匹配到*/中算符”)
  182. 返回 (当前节点)
  183. .如果真结束
  184. m = 父节点.生成自词节点 (下个词 ())
  185. 词游标自增 ()
  186. r = 匹配因子 (父节点)
  187. .如果真 (r.失败 ())
  188. 返回 (父节点.生成匹配失败节点 ())
  189. .如果真结束
  190. .如果 (下个词 ().类型 ≠ #词类_结尾)
  191. 后续无穷 = 匹配加后表达式右侧无穷 (r)
  192. .如果真 (后续无穷.失败 ())
  193. 返回 (后续无穷)
  194. .如果真结束
  195. .否则
  196. 后续无穷.初始化内存 (“nop”, )
  197. 后续无穷.设置语类 (#语类_nop)
  198. .如果结束
  199. ' 调试输出 (下个词 ().类型)
  200. m.设置父节点 (后续无穷)
  201. m.添加参数节点 (r)
  202. 后续无穷.插入参数节点 (m)
  203. m.设置语类 (#语类_函数调用)
  204. 返回 (m)
  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. ' sin(x) 当成 sin 后面没了
  242. .如果真 (下个词 ().类型 = #词类_标识符)
  243. 标识符 = 通用词匹配 (#词类_标识符)
  244. 标识符.设置语类 (#语类_实际参数)
  245. 返回 (标识符)
  246. .如果真结束
  247. 返回 (父节点.生成匹配失败节点 ())
  248. .子程序 匹配函数, 抽象语法树节点
  249. .参数 父节点, 抽象语法树节点
  250. .局部变量 当前节点, 抽象语法树节点, 数组
  251. .局部变量 标识符, 抽象语法树节点, 数组
  252. .局部变量 参数, 抽象语法树节点, 数组
  253. .局部变量 右侧无穷, 抽象语法树节点, 数组
  254. .局部变量 括号内下一表达式, 抽象语法树节点, 数组
  255. .如果真 (下个词 ().类型 ≠ #词类_标识符)
  256. 返回 (父节点.生成匹配失败节点 ())
  257. .如果真结束
  258. 标识符 = 通用词匹配 (#词类_标识符)
  259. ' 现在标识符要么是函数的一部分, 要么是参数
  260. .如果真 (下个词 ().内容 ≠ “(”)
  261. 标识符.设置语类 (#语类_实际参数)
  262. 返回 (标识符)
  263. .如果真结束
  264. 标识符.设置语类 (#语类_函数调用)
  265. 词游标自增 ()
  266. .如果真 (下个词 ().内容 = “)”)
  267. 词游标自增 ()
  268. 返回 (标识符)
  269. .如果真结束
  270. 参数 = 匹配表达式 (当前节点)
  271. .如果真 (下个词 ().内容 = “)”)
  272. 标识符.添加参数节点 (参数)
  273. 词游标自增 ()
  274. 返回 (标识符)
  275. .如果真结束
  276. 标识符.添加参数节点 (参数)
  277. .判断循环首 (真)
  278. .如果真 (下个词 ().类型 ≠ #词类_逗号 或 假) ' 去掉「 或 假」后会触发e2txt的bug, 无法从.txt转回.e
  279. 返回 (父节点.生成匹配失败节点 ())
  280. .如果真结束
  281. 词游标自增 ()
  282. 括号内下一表达式 = 匹配表达式 (当前节点)
  283. .如果真 (括号内下一表达式.失败 ())
  284. 返回 (父节点.生成匹配失败节点 ())
  285. .如果真结束
  286. 标识符.添加参数节点 (括号内下一表达式)
  287. .如果真 (下个词 ().内容 = “)”)
  288. 词游标自增 ()
  289. 跳出循环 ()
  290. .如果真结束
  291. .判断循环尾 ()
  292. 返回 (标识符)
  293. .子程序 通用词匹配, 抽象语法树节点
  294. .参数 词类型, 整数型, , #词类枚举
  295. .局部变量 当前节点, 抽象语法树节点, 数组
  296. 当前节点.初始化内存 ()
  297. .如果 (下个词 ().类型 ≠ 词类型)
  298. 当前节点.释放结构内存 ()
  299. 返回 (当前节点.生成匹配失败节点 ())
  300. .否则
  301. 当前节点.设置函数名 (下个词 ().内容)
  302. 当前节点.设置词类 (词类型)
  303. 词游标自增 ()
  304. 返回 (当前节点)
  305. .如果结束
  306. .子程序 下个词, 词
  307. .局部变量 返回词, 词, 数组
  308. .如果 (当前词游标 ≥ 取数组成员数 (词))
  309. 返回词.内容 = “”
  310. 返回词.类型 = #词类_结尾
  311. .否则
  312. 返回词 = 词 [当前词游标 + 1]
  313. .如果结束
  314. 返回 (返回词)
  315. .子程序 词游标自增
  316. 当前词游标 = 当前词游标 + 1
  317. ' 调试输出 (格式化文本 (“游标增至 %d 下一个:(%d,%s)”, 当前词游标, 下个词 ().类型, 下个词 ().内容))
  318. .子程序 词游标自减
  319. 当前词游标 = 当前词游标 - 1
  320. ' 调试输出 (格式化文本 (“游标减至 %d 下一个:(%d,%s)”, 当前词游标, 下个词 ().类型, 下个词 ().内容))
  321. .子程序 重复文本, 文本型
  322. .参数 n, 整数型
  323. .参数 s, 文本型
  324. .局部变量 res, 文本型, 数组
  325. res = “”
  326. .计次循环首 (n, )
  327. res = res + s
  328. .计次循环尾 ()
  329. 返回 (res)
  330. .子程序 输出语法分析结果
  331. .参数 AST, 抽象语法树节点
  332. .参数 当前层级, 整数型, 可空
  333. .局部变量 i, 整数型, 数组
  334. .如果真 (是否为空 (当前层级))
  335. 当前层级 = 0
  336. .如果真结束
  337. 标准输出 (, 重复文本 (当前层级 × 2, “ ”))
  338. 标准输出 (, AST.生成展示文本 () + #换行符)
  339. .计次循环首 (AST.获取参数数量 (), i)
  340. 输出语法分析结果 (AST.获取参数节点 (i), 当前层级 + 1)
  341. .计次循环尾 ()
  342. .子程序 语法分析并输出
  343. .参数 表达式, 文本型
  344. .局部变量 t0, 长整数型, 数组
  345. t0 = 时间_取现行时间戳1 (真)
  346. 词法分析 (表达式, 词)
  347. 语法分析 (词)
  348. 标准输出 (, “用时 ” + 到文本 (时间_取现行时间戳1 (真) - t0) + “ms” + #换行符)
  349. 输出语法分析结果 (AST根)