File: src\Workspaces\SharedUtilitiesAndExtensions\Compiler\Core\Utilities\Matcher`1.cs
Web Access
Project: src\src\CodeStyle\Core\Analyzers\Microsoft.CodeAnalysis.CodeStyle.csproj (Microsoft.CodeAnalysis.CodeStyle)
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
 
using System;
using System.Collections.Generic;
 
namespace Microsoft.CodeAnalysis.Shared.Utilities;
 
/// <summary>
/// Helper class to allow one to do simple regular expressions over a sequence of objects (as
/// opposed to a sequence of characters).
/// </summary>
internal abstract partial class Matcher<T>
{
    // Tries to match this matcher against the provided sequence at the given index.  If the
    // match succeeds, 'true' is returned, and 'index' points to the location after the match
    // ends.  If the match fails, then false it returned and index remains the same.  Note: the
    // matcher does not need to consume to the end of the sequence to succeed.
    public abstract bool TryMatch(IList<T> sequence, ref int index);
 
    internal static Matcher<T> Repeat(Matcher<T> matcher)
        => new RepeatMatcher(matcher);
 
    internal static Matcher<T> OneOrMore(Matcher<T> matcher)
    {
        // m+ is the same as (m m*)
        return Sequence(matcher, Repeat(matcher));
    }
 
    internal static Matcher<T> Choice(params Matcher<T>[] matchers)
        => new ChoiceMatcher(matchers);
 
    internal static Matcher<T> Sequence(params Matcher<T>[] matchers)
        => new SequenceMatcher(matchers);
 
    internal static Matcher<T> Single(Func<T, bool> predicate, string description)
        => new SingleMatcher(predicate, description);
}