使用Sprache解析文件时获取异常“解析失败:达到了意外的输入结束;预期=”

时间:2017-08-28 07:06:05

标签: sprache

我想解析文件,

first=The_First_Step
{
    {
        value=First.Value,
    }
}

second=The_Second_Step
{
    {
        another = Second_Value,
        more =  Yet.More,
    }
}

我写的是语法,

public static NGSection ParseSections(string ngServerConfig)
{
    return Sections.End().Parse(ngServerConfig);
}

internal static Parser<string> ValueText = Parse.LetterOrDigit.AtLeastOnce().Text().Token();

internal static Parser<string> Identifier = Parse.AnyChar.AtLeastOnce().Text().Token();

internal static Parser<Config> Config =
      from id in Identifier
      from equal in Parse.Char('=').Token()
      from value in ValueText
      from comma in Parse.Char(',').Token()
      select new Config(id, value);

internal static Parser<Section> Section =
      from id in Identifier
      from equal in Parse.Char('=').Token()
      from title in ValueText
      from lbracket in Parse.Char('{').Token()
      from inbracket in Parse.Char('{').Token()
      from configs in Config.AtLeastOnce()
      from outbracket in Parse.Char('}').Token()
      from rbracket in Parse.Char('}').Token()
      select new Section(id, title, configs);

internal static Parser<NGSection> Sections =
     from sections in Section.AtLeastOnce()
     select new NGSection(sections);

我的异常是

解析失败:达到了意外的输入结束;预期=(第13行,第2栏);最近消费:矿石     } }

任何线索都会有所帮助。

1 个答案:

答案 0 :(得分:1)

两个问题:首先,您的示例中的值可以包含_.,因此LetterOrDigit不会覆盖它。应该是:

internal static Parser<string> ValueText =
  Parse.LetterOrDigit.Or(Parse.Chars('_', '.')).AtLeastOnce().Text().Token();

接下来,Identifier解析器的AnyChar太贪心了;您需要排除=,否则它将被视为标识符的一部分:

internal static Parser<string> Identifier =
  Parse.CharExcept('=').AtLeastOnce().Text().Token();