Mercurial > pub > ImplabNet
view Implab/Parsing/EnumAlphabet.cs @ 89:ce0171cacec4 v2
improved performance of a chained map operation
author | cin |
---|---|
date | Wed, 08 Oct 2014 02:19:45 +0400 |
parents | 653c4e04968b |
children | 97fbbf816844 |
line wrap: on
line source
using Implab; using System; using System.Collections.Generic; using System.Diagnostics; using System.Globalization; using System.Linq; using System.Text; using System.Threading.Tasks; namespace Implab.Parsing { /// <summary> /// Алфавит символами которого являются элементы перечислений. /// </summary> /// <typeparam name="T">Тип перечислений</typeparam> public class EnumAlphabet<T> : AlphabetBase<T> where T : struct, IConvertible { static readonly T[] _symbols; static readonly EnumAlphabet<T> _fullAlphabet; [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Design", "CA1065:DoNotRaiseExceptionsInUnexpectedLocations")] static EnumAlphabet() { if (!typeof(T).IsEnum) throw new InvalidOperationException("Invalid generic parameter, enumeration is required"); if (Enum.GetUnderlyingType(typeof(T)) != typeof(Int32)) throw new InvalidOperationException("Only enums based on Int32 are supported"); _symbols = ((T[])Enum.GetValues(typeof(T))) .OrderBy(x => x.ToInt32(CultureInfo.InvariantCulture)) .ToArray(); if ( _symbols[_symbols.Length - 1].ToInt32(CultureInfo.InvariantCulture) >= _symbols.Length || _symbols[0].ToInt32(CultureInfo.InvariantCulture) != 0 ) throw new InvalidOperationException("The specified enumeration must be zero-based and continuously numbered"); _fullAlphabet = new EnumAlphabet<T>(_symbols.Select(x => x.ToInt32(CultureInfo.InvariantCulture)).ToArray()); } public static EnumAlphabet<T> FullAlphabet { get { return _fullAlphabet; } } public EnumAlphabet() : base(_symbols.Length) { } public EnumAlphabet(int[] map) : base(map) { Debug.Assert(map.Length == _symbols.Length); } public override int GetSymbolIndex(T symbol) { return symbol.ToInt32(CultureInfo.InvariantCulture); } public override IEnumerable<T> InputSymbols { get { return _symbols; } } } }