gpt4 book ai didi

c# - 如何使用infragistics语法解析引擎?

转载 作者:太空宇宙 更新时间:2023-11-03 21:39:09 26 4
gpt4 key购买 nike

我想利用 infragistics 语法解析引擎来做这样的事情:

  1. 用户以 EBNF 格式为语言定义语法。
  2. 上面定义的语法用于验证文本框中的用户输入是否有效(即匹配或可能匹配上面的语法)。

我已经阅读了他们拥有的所有文档,但我看不出什么是好的第一步。任何帮助将不胜感激。

最佳答案

我在为 Infragistics 开发解析引擎,这听起来是一种完美的使用方式。框架创建的解析器类型完全基于语法实例,并且可以从 EBNF 文件创建此类。我们有一个自定义格式,可以在文件开头或每个非终端符号定义之前的特殊序列中使用,分别为语法或非终端符号提供属性,但也可以识别没有这些特殊属性的普通 EBNF .如需有关此格式的帮助,您可以查看此链接:http://help.infragistics.com/doc/WPF/2013.2/CLR4.0/?page=IG_SPE_EBNF_Format.html .有关框架的一般帮助,请参阅此链接:http://help.infragistics.com/doc/WPF/2013.2/CLR4.0/?page=IG_SPE.html .

要创建包含要解析文档的语法定义的 Grammar 实例,您可以使用静态 Grammar.LoadEbnf(…) 方法之一从 EBNF 文件或原始 EBNF 内容创建 Grammar 实例,或者您可以通过使用代码添加终结符和非终结符来手动构建语法。出于您的目的,听起来最好的方法是使用 LoadEbnf 方法并将用户指定的 EBNF 传递给它。

创建语法实例后,您需要为其创建解析器。当 Grammar 包装在 LanguageBase 派生类中时,这一切都在内部处理。您可以使用代码生成器写出特定于您的语法的派生语言类(通过 LanguageGenerator.GenerateClass 方法),或者您可以创建一个新的 CustomLanguage 实例,将语法传递给它的构造函数。出于您的目的,听起来后一种选择是最好的。这允许您在运行时读取 EBNF 并创建语言实例,而无需生成代码和重新编译。

一旦你有了一个代表你的语法和解析器的 LanguageBase 实例,你需要做的就是在 TextDocument 的 Language 属性上指定它。如果您有一个 XamSyntaxEditor,用户可以在其中键入输入,则此编辑器的 Document 属性将是一个 TextDocument 实例,您可以在该实例上设置 Language 属性。然后编辑器会根据语法定义自动显示错误的内容。如果您没有编辑器,或者您希望通过程序控制更多的错误检测,您可以创建一个 TextDocument,使用 InitializeText 方法设置其文本,使用 Parse() 或 ParseAsync() 方法解析文本,然后获取使用 SyntaxTree 属性解析的内容。

SyntaxTree 以与语法定义完全匹配的结构保存已解析文本的树状表示(用户输入中缺少的任何必需内容将插入错误节点以表示该内容,任何意外内容将位于树中下一个节点的前导忽略内容集合中)。从此 SyntaxTree 中,您可以访问 RootNode.ContainsDiagnostics 属性以查看整个树中是否有任何错误(您还可以在任何内部节点上使用 ContainsDiagnostics 以查看该节点上或节点内是否有错误)。您可以在节点上使用 GetDiagnostics 方法来枚举该节点上或该节点内的所有错误。

希望对您有所帮助。让我知道是否有任何不清楚的地方,或者您想了解有关任何事情的更多信息。另外,查看我的博客以获取有关解析的更多信息:http://www.infragistics.com/community/blogs/mike_dour/

关于c# - 如何使用infragistics语法解析引擎?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20253098/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com