2024-08-13 14:46:11 +08:00
|
|
|
using CanonSharp.Combinator.Abstractions;
|
|
|
|
using CanonSharp.Combinator.Extensions;
|
|
|
|
|
|
|
|
namespace CanonSharp.Combinator.Parsers.Primitives;
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// 解析指定数量的解析器
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="count">需要解析的数量</param>
|
|
|
|
/// <typeparam name="TToken">输入流类型</typeparam>
|
|
|
|
internal sealed class TakeParser<TToken>(int count) : PrimitiveParser<TToken, IEnumerable<TToken>>
|
|
|
|
{
|
2024-08-14 19:41:10 +08:00
|
|
|
protected override IParseResult<TToken, IEnumerable<TToken>> Run<TState>(TState state)
|
2024-08-13 14:46:11 +08:00
|
|
|
{
|
|
|
|
List<TState> result = state.AsEnumerable<TToken, TState>().Take(count).ToList();
|
|
|
|
|
|
|
|
return result.Count == count
|
|
|
|
? ParseResultBuilder.Succeed<TToken, TState, IEnumerable<TToken>>(result.Select(s => s.Current),
|
|
|
|
result.Count == 0 ? state : result.Last().Next)
|
|
|
|
: ParseResultBuilder.Fail<TToken, TState, IEnumerable<TToken>>("An input does not have required length.",
|
|
|
|
state);
|
|
|
|
}
|
|
|
|
}
|