Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / xsp / System / Web / Configuration / CapabilitiesPattern.cs / 1 / CapabilitiesPattern.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.Configuration { using System.Collections; using System.Collections.Specialized; using System.Diagnostics; using System.Globalization; using System.Reflection; using System.Security; using System.Text; using System.Text.RegularExpressions; using System.Threading; using System.Web.Caching; using System.Web.Compilation; using System.Web.Hosting; using System.Security.Permissions; // // Represents a single pattern to be expanded // internal class CapabilitiesPattern { internal String[] _strings; internal int[] _rules; internal const int Literal = 0; // literal string internal const int Reference = 1; // regex reference ${name} or $number internal const int Variable = 2; // regex reference %{name} internal static readonly Regex refPat = new Regex("\\G\\$(?:(?\\d+)|\\{(? \\w+)\\})"); internal static readonly Regex varPat = new Regex("\\G\\%\\{(? \\w+)\\}"); internal static readonly Regex textPat = new Regex("\\G[^$%\\\\]*(?:\\.[^$%\\\\]*)*"); internal static readonly Regex errorPat = new Regex(".{0,8}"); internal static readonly CapabilitiesPattern Default = new CapabilitiesPattern(); internal CapabilitiesPattern() { _strings = new String[1]; _strings[0] = String.Empty; _rules = new int[1]; _rules[0] = Variable; } internal CapabilitiesPattern(String text) { ArrayList strings = new ArrayList(); ArrayList rules = new ArrayList(); int textpos = 0; for (;;) { Match match = null; // 1: scan text if ((match = textPat.Match(text, textpos)).Success && match.Length > 0) { rules.Add(Literal); strings.Add(Regex.Unescape(match.ToString())); textpos = match.Index + match.Length; } if (textpos == text.Length) break; // 2: look for regex references if ((match = refPat.Match(text, textpos)).Success) { rules.Add(Reference); strings.Add(match.Groups["name"].Value); } // 3: look for variables else if ((match = varPat.Match(text, textpos)).Success) { rules.Add(Variable); strings.Add(match.Groups["name"].Value); } // 4: encountered a syntax error ( else { match = errorPat.Match(text, textpos); throw new ArgumentException( SR.GetString(SR.Unrecognized_construct_in_pattern, match.ToString(), text)); } textpos = match.Index + match.Length; } _strings = (String[])strings.ToArray(typeof(String)); _rules = new int[rules.Count]; for (int i = 0; i < rules.Count; i++) _rules[i] = (int)rules[i]; } internal virtual String Expand(CapabilitiesState matchstate) { StringBuilder sb = null; String result = null; for (int i = 0; i < _rules.Length; i++) { if (sb == null && result != null) sb = new StringBuilder(result); switch (_rules[i]) { case Literal: result = _strings[i]; break; case Reference: result = matchstate.ResolveReference(_strings[i]); break; case Variable: result = matchstate.ResolveVariable(_strings[i]); break; } if (sb != null && result != null) sb.Append(result); } if (sb != null) return sb.ToString(); if (result != null) return result; return String.Empty; } #if DBG internal virtual String Dump() { StringBuilder sb = new StringBuilder(); for (int i = 0; i < _rules.Length; i++) { switch (_rules[i]) { case Literal: sb.Append("\"" + _strings[i] + "\""); break; case Reference: sb.Append("${" + _strings[i] + "}"); break; default: sb.Append("??"); break; } if (i < _rules.Length - 1) sb.Append(" "); } return sb.ToString(); } internal virtual String Dump(String indent) { return indent + Dump() + "\n"; } #endif } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.Configuration { using System.Collections; using System.Collections.Specialized; using System.Diagnostics; using System.Globalization; using System.Reflection; using System.Security; using System.Text; using System.Text.RegularExpressions; using System.Threading; using System.Web.Caching; using System.Web.Compilation; using System.Web.Hosting; using System.Security.Permissions; // // Represents a single pattern to be expanded // internal class CapabilitiesPattern { internal String[] _strings; internal int[] _rules; internal const int Literal = 0; // literal string internal const int Reference = 1; // regex reference ${name} or $number internal const int Variable = 2; // regex reference %{name} internal static readonly Regex refPat = new Regex("\\G\\$(?:(?\\d+)|\\{(? \\w+)\\})"); internal static readonly Regex varPat = new Regex("\\G\\%\\{(? \\w+)\\}"); internal static readonly Regex textPat = new Regex("\\G[^$%\\\\]*(?:\\.[^$%\\\\]*)*"); internal static readonly Regex errorPat = new Regex(".{0,8}"); internal static readonly CapabilitiesPattern Default = new CapabilitiesPattern(); internal CapabilitiesPattern() { _strings = new String[1]; _strings[0] = String.Empty; _rules = new int[1]; _rules[0] = Variable; } internal CapabilitiesPattern(String text) { ArrayList strings = new ArrayList(); ArrayList rules = new ArrayList(); int textpos = 0; for (;;) { Match match = null; // 1: scan text if ((match = textPat.Match(text, textpos)).Success && match.Length > 0) { rules.Add(Literal); strings.Add(Regex.Unescape(match.ToString())); textpos = match.Index + match.Length; } if (textpos == text.Length) break; // 2: look for regex references if ((match = refPat.Match(text, textpos)).Success) { rules.Add(Reference); strings.Add(match.Groups["name"].Value); } // 3: look for variables else if ((match = varPat.Match(text, textpos)).Success) { rules.Add(Variable); strings.Add(match.Groups["name"].Value); } // 4: encountered a syntax error ( else { match = errorPat.Match(text, textpos); throw new ArgumentException( SR.GetString(SR.Unrecognized_construct_in_pattern, match.ToString(), text)); } textpos = match.Index + match.Length; } _strings = (String[])strings.ToArray(typeof(String)); _rules = new int[rules.Count]; for (int i = 0; i < rules.Count; i++) _rules[i] = (int)rules[i]; } internal virtual String Expand(CapabilitiesState matchstate) { StringBuilder sb = null; String result = null; for (int i = 0; i < _rules.Length; i++) { if (sb == null && result != null) sb = new StringBuilder(result); switch (_rules[i]) { case Literal: result = _strings[i]; break; case Reference: result = matchstate.ResolveReference(_strings[i]); break; case Variable: result = matchstate.ResolveVariable(_strings[i]); break; } if (sb != null && result != null) sb.Append(result); } if (sb != null) return sb.ToString(); if (result != null) return result; return String.Empty; } #if DBG internal virtual String Dump() { StringBuilder sb = new StringBuilder(); for (int i = 0; i < _rules.Length; i++) { switch (_rules[i]) { case Literal: sb.Append("\"" + _strings[i] + "\""); break; case Reference: sb.Append("${" + _strings[i] + "}"); break; default: sb.Append("??"); break; } if (i < _rules.Length - 1) sb.Append(" "); } return sb.ToString(); } internal virtual String Dump(String indent) { return indent + Dump() + "\n"; } #endif } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- TextRangeEditLists.cs
- PolicyConversionContext.cs
- WebHttpBinding.cs
- VectorCollectionValueSerializer.cs
- ListViewTableCell.cs
- AsyncOperation.cs
- BitmapVisualManager.cs
- PageBuildProvider.cs
- CachedTypeface.cs
- EntityRecordInfo.cs
- XamlGridLengthSerializer.cs
- NullableDoubleMinMaxAggregationOperator.cs
- ThreadInterruptedException.cs
- ClientUrlResolverWrapper.cs
- CatalogPart.cs
- SamlAudienceRestrictionCondition.cs
- DesignerAdapterAttribute.cs
- FileEnumerator.cs
- NegotiationTokenAuthenticator.cs
- MaskedTextBoxTextEditor.cs
- XmlElement.cs
- ResourceType.cs
- VirtualPathExtension.cs
- EvidenceBase.cs
- QilFactory.cs
- PrimitiveXmlSerializers.cs
- BStrWrapper.cs
- WindowsNonControl.cs
- InputMethodStateChangeEventArgs.cs
- AnimationClock.cs
- TimeZone.cs
- NativeMethods.cs
- EdmScalarPropertyAttribute.cs
- OutputCacheProfileCollection.cs
- LassoHelper.cs
- GeneratedContractType.cs
- XmlSchemaInfo.cs
- ExceptionAggregator.cs
- XmlAttributeAttribute.cs
- HtmlInputHidden.cs
- VisualTreeUtils.cs
- JpegBitmapDecoder.cs
- WebPartConnectionsConfigureVerb.cs
- MenuStrip.cs
- IntSecurity.cs
- CompiledAction.cs
- ControlCachePolicy.cs
- XmlEnumAttribute.cs
- BatchStream.cs
- HwndStylusInputProvider.cs
- SerializerDescriptor.cs
- PipelineModuleStepContainer.cs
- Icon.cs
- DefaultParameterValueAttribute.cs
- SectionUpdates.cs
- BinaryObjectWriter.cs
- HostedNamedPipeTransportManager.cs
- HttpBindingExtension.cs
- TextContainer.cs
- TextAnchor.cs
- StreamedWorkflowDefinitionContext.cs
- XmlReaderSettings.cs
- TextTabProperties.cs
- DelayedRegex.cs
- XmlDocumentViewSchema.cs
- Hashtable.cs
- CfgSemanticTag.cs
- MasterPageCodeDomTreeGenerator.cs
- ActiveDesignSurfaceEvent.cs
- HtmlControlAdapter.cs
- FunctionCommandText.cs
- IssuedTokensHeader.cs
- SpellerHighlightLayer.cs
- SingleConverter.cs
- Update.cs
- DescendantBaseQuery.cs
- BrowserDefinitionCollection.cs
- InstancePersistence.cs
- WindowsTokenRoleProvider.cs
- UTF7Encoding.cs
- ExpressionBuilder.cs
- EventsTab.cs
- SystemIPv6InterfaceProperties.cs
- WebPartExportVerb.cs
- Localizer.cs
- ServiceContractGenerator.cs
- TCPListener.cs
- XmlDataImplementation.cs
- RectangleConverter.cs
- NotificationContext.cs
- JoinTreeSlot.cs
- ServicePoint.cs
- SharedPersonalizationStateInfo.cs
- ConfigurationManagerHelper.cs
- PermissionSetEnumerator.cs
- SemanticBasicElement.cs
- VirtualPathUtility.cs
- TokenBasedSet.cs
- SystemResourceKey.cs
- DateTime.cs