File: Matcher`1.cs
Web Access
Project: ..\..\..\src\Workspaces\Core\Portable\Microsoft.CodeAnalysis.Workspaces.csproj (Microsoft.CodeAnalysis.Workspaces)
// 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);
    }
}