fix: Using covariant interface for IParser and IParseResult.
Rename CanonSharp.Common to CanonSharp.Pascal.
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;
|
||||
|
||||
Reference in New Issue
Block a user