fix: Using covariant interface for IParser and IParseResult.
Rename CanonSharp.Common to CanonSharp.Pascal.
This commit is contained in:
@@ -9,18 +9,20 @@ namespace CanonSharp.Combinator.Parsers;
|
||||
/// <typeparam name="TToken">输入流类型</typeparam>
|
||||
/// <typeparam name="TIntermediate">需要修改结果的解析器</typeparam>
|
||||
/// <typeparam name="T">最终返回的解析结果</typeparam>
|
||||
public abstract class ModifiedParser<TToken, TIntermediate, T>(Parser<TToken, TIntermediate> parser) : Parser<TToken, T>
|
||||
public abstract class ModifiedParser<TToken, TIntermediate, T>(IParser<TToken, TIntermediate> parser)
|
||||
: IParser<TToken, T>
|
||||
{
|
||||
protected abstract ParseResult<TToken, T> Fail<TState>(TState state,
|
||||
FailedResult<TToken, TIntermediate> failedResult)
|
||||
protected abstract IParseResult<TToken, T> Fail<TState>(TState state,
|
||||
IFailedResult<TToken, TIntermediate> failedResult)
|
||||
where TState : IReadState<TToken, TState>;
|
||||
|
||||
protected abstract ParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
SuccessfulResult<TToken, TIntermediate> successfulResult)
|
||||
protected abstract IParseResult<TToken, T> Succeed<TState>(TState state,
|
||||
ISuccessfulResult<TToken, TIntermediate> successfulResult)
|
||||
where TState : IReadState<TToken, TState>;
|
||||
|
||||
internal override ParseResult<TToken, TResult> Run<TState, TResult>(TState state,
|
||||
Func<ParseResult<TToken, T>, ParseResult<TToken, TResult>> continuation)
|
||||
public IParseResult<TToken, TResult> Run<TState, TResult>(TState state,
|
||||
Func<IParseResult<TToken, T>, IParseResult<TToken, TResult>> continuation)
|
||||
where TState : IReadState<TToken, TState>
|
||||
=> parser.Run(state, result => result.CaseOf(
|
||||
success => continuation(Succeed(state, success)),
|
||||
failure => continuation(Fail(state, failure))));
|
||||
|
||||
Reference in New Issue
Block a user