我让set来解析一个方程,其中包含了许多不同的方法调用。在解析该方法之后,是否有方法确定原始字符串中的索引值?也许Parse有一个“当前索引”值和“长度”值,这是可以访问的吗?
示例输入字符串:
IndexOf("fred", 2) + IndexOf("bob")使用这样的解析器..。
Parser<Expression> FunctionCall = from namePart in Parse.Letter.Many().Text()
from lparen in Parse.Char('(')
from expr in Parameter.DelimitedBy(ListDelimiter)
from rparen in Parse.Char(')')
select CallMethod(namePart, Enumerable.Repeat(sourceData, 1)
.Concat(expr)
.ToArray());有人能想到一个“技巧”来让我确定第一个CallMethod处理SubString(0,18),第二个CallMethod处理原始字符串中的SubString(21,14)吗?
发布于 2019-07-22 18:50:25
我已经回答了我自己的问题。定位()解析器扩展调用允许解析器跟踪原始文本中的位置。
Parser<Expression> FunctionCall = (from namePart in Parse.Letter.Many().Text()
from lparen in Parse.Char('(')
from expr in Parameter.DelimitedBy(ListDelimiter)
from rparen in Parse.Char(')')
select new MethodPosAware(namePart, expr)).Positioned()
.Select(x => CallMethod(x.Value, Enumerable.Repeat(sourceData, 1)
.Concat(x.Params)
.ToArray(),
x.Pos.Pos, x.Length));我必须创建一个新的MethodPosAware类来保存职位信息,这是来自于西普的MethodPosAware
class MethodPosAware : IPositionAware<MethodPosAware>
{
public MethodPosAware(string methodName, IEnumerable<Expression> parameters)
{
Value = methodName;
Params = parameters;
}
public MethodPosAware SetPos(Position startPos, int length)
{
Pos = startPos;
Length = length;
return this;
}
public Position Pos { get; set; }
public int Length { get; set; }
public string Value { get; set; }
public IEnumerable<Expression> Params { get; set; }
}我认为我将进一步扩展它,以处理不仅仅是方法名称,但这足以回答我的问题。我希望这能帮上一个人。
发布于 2019-08-22 07:01:52
如果使用泛型类和扩展方法,则可以使用更通用的方法。
public class PositionAware<T> : IPositionAware<PositionAware<T>>
{
public PositionAware(T value)
{
Value = value;
}
public T Value { get; }
public Position Start { get; private set; }
public int Length { get; private set; }
public PositionAware<T> SetPos(Position startPos, int length)
{
Start = startPos;
Length = length;
return this;
}
}
public static Parser<PositionAware<T>> WithPosition<T>(this Parser<T> value)
{
return value.Select(x => new PositionAware<T>(x)).Positioned();
}使用它:
from c in Parse.Char('a').WithPosition()
select (c.Start, c.Value)
from c in Parameter.DelimitedBy(ListDelimiter).WithPosition()
select (c.Start, c.Value)https://stackoverflow.com/questions/57120923
复制相似问题