feat: Grammar Parser (#3)
Reviewed-on: https://git.bupt-hpc.cn/jackfiled/CanonSharp/pulls/3 Co-authored-by: jackfiled <xcrenchangjun@outlook.com> Co-committed-by: jackfiled <xcrenchangjun@outlook.com>
This commit is contained in:
@@ -11,18 +11,18 @@ namespace CanonSharp.Combinator.Parsers.Modifiers;
|
||||
/// <typeparam name="TToken">输入流类型</typeparam>
|
||||
/// <typeparam name="T">解析结果类型</typeparam>
|
||||
internal sealed class DoParser<TToken, T>(
|
||||
Parser<TToken, T> parser,
|
||||
IParser<TToken, T> parser,
|
||||
Action<T> succeed,
|
||||
Action<FailedResult<TToken, T>> fail) : ModifiedParser<TToken, T, T>(parser)
|
||||
Action<IFailedResult<TToken, T>> fail) : ModifiedParser<TToken, T, T>(parser)
|
||||
{
|
||||
protected override ParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
SuccessfulResult<TToken, T> successfulResult)
|
||||
protected override IParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
ISuccessfulResult<TToken, T> successfulResult)
|
||||
{
|
||||
succeed(successfulResult.Value);
|
||||
return successfulResult;
|
||||
}
|
||||
|
||||
protected override ParseResult<TToken, T> Fail<TState>(TState state, FailedResult<TToken, T> failedResult)
|
||||
protected override IParseResult<TToken, T> Fail<TState>(TState state, IFailedResult<TToken, T> failedResult)
|
||||
{
|
||||
fail(failedResult);
|
||||
return failedResult;
|
||||
|
@@ -10,12 +10,12 @@ namespace CanonSharp.Combinator.Parsers.Modifiers;
|
||||
/// <param name="parser">需要向前看的解析器</param>
|
||||
/// <typeparam name="TToken">输入流令牌</typeparam>
|
||||
/// <typeparam name="T">返回的解析结果类型</typeparam>
|
||||
internal sealed class LookAheadParser<TToken, T>(Parser<TToken, T> parser) : ModifiedParser<TToken, T, T>(parser)
|
||||
internal sealed class LookAheadParser<TToken, T>(IParser<TToken, T> parser) : ModifiedParser<TToken, T, T>(parser)
|
||||
{
|
||||
protected override ParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
SuccessfulResult<TToken, T> successfulResult)
|
||||
protected override IParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
ISuccessfulResult<TToken, T> successfulResult)
|
||||
=> ParseResultBuilder.Succeed<TToken, TState, T>(successfulResult.Value, state);
|
||||
|
||||
protected override ParseResult<TToken, T> Fail<TState>(TState state, FailedResult<TToken, T> failedResult)
|
||||
protected override IParseResult<TToken, T> Fail<TState>(TState state, IFailedResult<TToken, T> failedResult)
|
||||
=> ParseResultBuilder.Fail<TToken, TState, T>($"Failed when looking ahead: {failedResult}", state);
|
||||
}
|
||||
|
@@ -12,15 +12,15 @@ namespace CanonSharp.Combinator.Parsers.Modifiers;
|
||||
/// <typeparam name="TToken">输入流的类型</typeparam>
|
||||
/// <typeparam name="TIntermediate">上游解析器结果类型</typeparam>
|
||||
/// <typeparam name="T">最终的返回结果</typeparam>
|
||||
internal sealed class ReverseParser<TToken, TIntermediate, T>(Parser<TToken, TIntermediate> parser, T result)
|
||||
internal sealed class ReverseParser<TToken, TIntermediate, T>(IParser<TToken, TIntermediate> parser, T result)
|
||||
: ModifiedParser<TToken, TIntermediate, T>(parser)
|
||||
{
|
||||
protected override ParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
SuccessfulResult<TToken, TIntermediate> successfulResult)
|
||||
protected override IParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
ISuccessfulResult<TToken, TIntermediate> successfulResult)
|
||||
=> ParseResultBuilder.Fail<TToken, TState, T>($"Unexpected successful result: {successfulResult.Value}",
|
||||
state);
|
||||
|
||||
protected override ParseResult<TToken, T> Fail<TState>(TState state,
|
||||
FailedResult<TToken, TIntermediate> failedResult)
|
||||
protected override IParseResult<TToken, T> Fail<TState>(TState state,
|
||||
IFailedResult<TToken, TIntermediate> failedResult)
|
||||
=> ParseResultBuilder.Succeed<TToken, TState, T>(result, state);
|
||||
}
|
||||
|
@@ -12,15 +12,15 @@ namespace CanonSharp.Combinator.Parsers.Modifiers;
|
||||
/// <typeparam name="TIntermediate">上游解析器解析结果类型</typeparam>
|
||||
/// <typeparam name="T">最终的解析结果类型</typeparam>
|
||||
internal sealed class SuccessfulMapParser<TToken, TIntermediate, T>(
|
||||
Parser<TToken, TIntermediate> parser,
|
||||
IParser<TToken, TIntermediate> parser,
|
||||
Func<TIntermediate, T> successfulHandler,
|
||||
Func<FailedResult<TToken, TIntermediate>, T> failedHandler) : ModifiedParser<TToken, TIntermediate, T>(parser)
|
||||
Func<IFailedResult<TToken, TIntermediate>, T> failedHandler) : ModifiedParser<TToken, TIntermediate, T>(parser)
|
||||
{
|
||||
protected override ParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
SuccessfulResult<TToken, TIntermediate> successfulResult)
|
||||
protected override IParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
ISuccessfulResult<TToken, TIntermediate> successfulResult)
|
||||
=> successfulResult.Map(successfulHandler);
|
||||
|
||||
protected override ParseResult<TToken, T> Fail<TState>(TState state,
|
||||
FailedResult<TToken, TIntermediate> failedResult)
|
||||
protected override IParseResult<TToken, T> Fail<TState>(TState state,
|
||||
IFailedResult<TToken, TIntermediate> failedResult)
|
||||
=> ParseResultBuilder.Succeed<TToken, TState, T>(failedHandler(failedResult), state);
|
||||
}
|
||||
|
@@ -11,13 +11,13 @@ namespace CanonSharp.Combinator.Parsers.Modifiers;
|
||||
/// <param name="resume">处理失败结果的恢复函数</param>
|
||||
/// <typeparam name="TToken">输入流令牌</typeparam>
|
||||
/// <typeparam name="T">解析器返回结果类型</typeparam>
|
||||
internal sealed class TryParser<TToken, T>(Parser<TToken, T> parser, Func<FailedResult<TToken, T>, T> resume)
|
||||
internal sealed class TryParser<TToken, T>(IParser<TToken, T> parser, Func<IFailedResult<TToken, T>, T> resume)
|
||||
: ModifiedParser<TToken, T, T>(parser)
|
||||
{
|
||||
protected override ParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
SuccessfulResult<TToken, T> successfulResult)
|
||||
protected override IParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
ISuccessfulResult<TToken, T> successfulResult)
|
||||
=> successfulResult;
|
||||
|
||||
protected override ParseResult<TToken, T> Fail<TState>(TState state, FailedResult<TToken, T> failedResult)
|
||||
protected override IParseResult<TToken, T> Fail<TState>(TState state, IFailedResult<TToken, T> failedResult)
|
||||
=> ParseResultBuilder.Succeed<TToken, TState, T>(resume(failedResult), state);
|
||||
}
|
||||
|
Reference in New Issue
Block a user