我正在寻求开发一个 TEX 解析器,现在的问题是没有上下文无关语法,也不可能有,因为它不是上下文无关语言,我听说它是某种宏语言并且是建立在自己的基础上的。
所以现在我需要指导这种宏语言具有什么样的语法以及如何在 C# 中构建任何内容。
我将编写分词器和解析器,但是我需要 TEX 中的一些宏规则,这些规则很难找到,其他地方都有关于如何使用 TEX 宏的文档。
TeX 作为一种编程语言,可能是有史以来最复杂(非深奥)的语言,具有大量的“保留字”。您可以在处理器读取每个字符时重新映射每个字符的含义,并且通常可以执行解析语言时通常不会遇到的操作。
如果您确实想创建自己的 TeX 解析器,则必须在原始 TeX 的基础上构建。源代码不仅可用,而且被编写为识字计划 http://en.wikipedia.org/wiki/Literate_programming使用 Knuth 巧妙的 WEB 工具。
让事情变得更加复杂的是,你总是在 TeX 中使用宏包。默认包是 Plain,最著名的是 LaTeX。宏包包含大量代码,您必须合并这些代码才能解析您想要解析的 TeX 的特定“方言”。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)