我想解析文件,
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栏);最近消费:矿石 } }
任何线索都会有所帮助。
答案 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();