Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / wpf / src / Framework / MS / Internal / Globalization / BamlResourceContent.cs / 1 / BamlResourceContent.cs
//---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: Utility that handles parsing Baml Resource Content // // History: 11/29/2003 garyyang Rewrote // //--------------------------------------------------------------------------- using System; using System.Text; using System.Text.RegularExpressions; using System.Collections; using System.Diagnostics; using System.Collections.Generic; using System.Windows; namespace MS.Internal.Globalization { internal static class BamlResourceContentUtil { //------------------------------------- // Internal methods //------------------------------------- ////// Escape a string /// internal static string EscapeString(string content) { if (content == null) return null; StringBuilder builder = new StringBuilder(); for (int i = 0; i < content.Length; i++) { switch (content[i]) { case BamlConst.ChildStart : case BamlConst.ChildEnd : case BamlConst.EscapeChar : { builder.Append(BamlConst.EscapeChar); builder.Append(content[i]); break; } case '&' : { builder.Append("&"); break; } case '<' : { builder.Append("<"); break; } case '>' : { builder.Append(">"); break; } case '\'': { builder.Append("'"); break; } case '\"': { builder.Append("""); break; } default : { builder.Append(content[i]); break; } } } return builder.ToString(); } ////// Unescape a string. Note: /// Backslash following any character will become that character. /// Backslash by itself will be skipped. /// internal static string UnescapeString(string content) { return UnescapePattern.Replace( content, UnescapeMatchEvaluator ); } // Regular expression // need to use 4 backslash here because it is escaped by compiler and regular expressions private static Regex UnescapePattern = new Regex("(\\\\.?|<|>|"|'|&)", RegexOptions.CultureInvariant | RegexOptions.Compiled); // delegates to escape and unesacpe a matched pattern private static MatchEvaluator UnescapeMatchEvaluator = new MatchEvaluator(UnescapeMatch); ////// the delegate to Unescape the matched pattern /// private static string UnescapeMatch(Match match) { switch (match.Value) { case "<" : return "<"; case ">" : return ">"; case "&" : return "&"; case "'": return "'"; case """: return "\""; default: { // this is a '\' followed by 0 or 1 character Debug.Assert(match.Value.Length > 0 && match.Value[0] == BamlConst.EscapeChar); if (match.Value.Length == 2) { return match.Value[1].ToString(); } else { return string.Empty; } } } } ////// Parse the input string into an array of text/child-placeholder tokens. /// Element placeholders start with '#' and end with ';'. /// In case of error, a null array is returned. /// internal static BamlStringToken[] ParseChildPlaceholder(string input) { if (input == null) return null; Listtokens = new List (8); int tokenStart = 0; bool inPlaceHolder = false; for (int i = 0; i < input.Length; i++) { if (input[i] == BamlConst.ChildStart) { if (i == 0 || input[i - 1]!= BamlConst.EscapeChar) { if (inPlaceHolder) { // All # needs to be escaped in a child place holder return null; // error } inPlaceHolder = true; if (tokenStart < i) { tokens.Add( new BamlStringToken( BamlStringToken.TokenType.Text, UnescapeString(input.Substring(tokenStart, i - tokenStart)) ) ); tokenStart = i; } } } else if (input[i] == BamlConst.ChildEnd) { if ( i > 0 && input[i - 1] != BamlConst.EscapeChar && inPlaceHolder) { // It is a valid child placeholder end tokens.Add( new BamlStringToken( BamlStringToken.TokenType.ChildPlaceHolder, UnescapeString(input.Substring(tokenStart + 1, i - tokenStart - 1)) ) ); // Advance the token index tokenStart = i + 1; inPlaceHolder = false; } } } if (inPlaceHolder) { // at the end of the string, all child placeholder must be closed return null; // error } if (tokenStart < input.Length) { tokens.Add( new BamlStringToken( BamlStringToken.TokenType.Text, UnescapeString(input.Substring(tokenStart)) ) ); } return tokens.ToArray(); } } internal struct BamlStringToken { internal readonly TokenType Type; internal readonly string Value; internal BamlStringToken(TokenType type, string value) { Type = type; Value = value; } internal enum TokenType { Text, ChildPlaceHolder, } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //---------------------------------------------------------------------------- // // // Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: Utility that handles parsing Baml Resource Content // // History: 11/29/2003 garyyang Rewrote // //--------------------------------------------------------------------------- using System; using System.Text; using System.Text.RegularExpressions; using System.Collections; using System.Diagnostics; using System.Collections.Generic; using System.Windows; namespace MS.Internal.Globalization { internal static class BamlResourceContentUtil { //------------------------------------- // Internal methods //------------------------------------- ////// Escape a string /// internal static string EscapeString(string content) { if (content == null) return null; StringBuilder builder = new StringBuilder(); for (int i = 0; i < content.Length; i++) { switch (content[i]) { case BamlConst.ChildStart : case BamlConst.ChildEnd : case BamlConst.EscapeChar : { builder.Append(BamlConst.EscapeChar); builder.Append(content[i]); break; } case '&' : { builder.Append("&"); break; } case '<' : { builder.Append("<"); break; } case '>' : { builder.Append(">"); break; } case '\'': { builder.Append("'"); break; } case '\"': { builder.Append("""); break; } default : { builder.Append(content[i]); break; } } } return builder.ToString(); } ////// Unescape a string. Note: /// Backslash following any character will become that character. /// Backslash by itself will be skipped. /// internal static string UnescapeString(string content) { return UnescapePattern.Replace( content, UnescapeMatchEvaluator ); } // Regular expression // need to use 4 backslash here because it is escaped by compiler and regular expressions private static Regex UnescapePattern = new Regex("(\\\\.?|<|>|"|'|&)", RegexOptions.CultureInvariant | RegexOptions.Compiled); // delegates to escape and unesacpe a matched pattern private static MatchEvaluator UnescapeMatchEvaluator = new MatchEvaluator(UnescapeMatch); ////// the delegate to Unescape the matched pattern /// private static string UnescapeMatch(Match match) { switch (match.Value) { case "<" : return "<"; case ">" : return ">"; case "&" : return "&"; case "'": return "'"; case """: return "\""; default: { // this is a '\' followed by 0 or 1 character Debug.Assert(match.Value.Length > 0 && match.Value[0] == BamlConst.EscapeChar); if (match.Value.Length == 2) { return match.Value[1].ToString(); } else { return string.Empty; } } } } ////// Parse the input string into an array of text/child-placeholder tokens. /// Element placeholders start with '#' and end with ';'. /// In case of error, a null array is returned. /// internal static BamlStringToken[] ParseChildPlaceholder(string input) { if (input == null) return null; Listtokens = new List (8); int tokenStart = 0; bool inPlaceHolder = false; for (int i = 0; i < input.Length; i++) { if (input[i] == BamlConst.ChildStart) { if (i == 0 || input[i - 1]!= BamlConst.EscapeChar) { if (inPlaceHolder) { // All # needs to be escaped in a child place holder return null; // error } inPlaceHolder = true; if (tokenStart < i) { tokens.Add( new BamlStringToken( BamlStringToken.TokenType.Text, UnescapeString(input.Substring(tokenStart, i - tokenStart)) ) ); tokenStart = i; } } } else if (input[i] == BamlConst.ChildEnd) { if ( i > 0 && input[i - 1] != BamlConst.EscapeChar && inPlaceHolder) { // It is a valid child placeholder end tokens.Add( new BamlStringToken( BamlStringToken.TokenType.ChildPlaceHolder, UnescapeString(input.Substring(tokenStart + 1, i - tokenStart - 1)) ) ); // Advance the token index tokenStart = i + 1; inPlaceHolder = false; } } } if (inPlaceHolder) { // at the end of the string, all child placeholder must be closed return null; // error } if (tokenStart < input.Length) { tokens.Add( new BamlStringToken( BamlStringToken.TokenType.Text, UnescapeString(input.Substring(tokenStart)) ) ); } return tokens.ToArray(); } } internal struct BamlStringToken { internal readonly TokenType Type; internal readonly string Value; internal BamlStringToken(TokenType type, string value) { Type = type; Value = value; } internal enum TokenType { Text, ChildPlaceHolder, } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ProcessRequestArgs.cs
- MessageQueueConverter.cs
- TransactionBridge.cs
- Int16AnimationBase.cs
- SearchForVirtualItemEventArgs.cs
- Exceptions.cs
- SHA1.cs
- RIPEMD160Managed.cs
- PackageProperties.cs
- DelayedRegex.cs
- Avt.cs
- Encoder.cs
- TaskFileService.cs
- InputReportEventArgs.cs
- NamespaceList.cs
- ScriptBehaviorDescriptor.cs
- Track.cs
- RelationshipWrapper.cs
- SoapExtensionTypeElement.cs
- SafeNativeMethods.cs
- HtmlControlAdapter.cs
- GeneratedCodeAttribute.cs
- BufferedStream.cs
- MappingItemCollection.cs
- TextSelectionHelper.cs
- Separator.cs
- followingquery.cs
- LineProperties.cs
- TextEndOfParagraph.cs
- Int32CAMarshaler.cs
- DataGridLength.cs
- UriParserTemplates.cs
- XmlSchemaIdentityConstraint.cs
- FilterFactory.cs
- PermissionToken.cs
- SoapIncludeAttribute.cs
- Invariant.cs
- XamlReaderHelper.cs
- StructuralObject.cs
- HtmlInputImage.cs
- OLEDB_Util.cs
- WorkflowMarkupSerializationException.cs
- HandleRef.cs
- Unit.cs
- LoginUtil.cs
- ArglessEventHandlerProxy.cs
- ConnectivityStatus.cs
- HttpDateParse.cs
- RecordManager.cs
- SafeSystemMetrics.cs
- PipelineModuleStepContainer.cs
- RelationshipNavigation.cs
- HttpConfigurationSystem.cs
- ContentHostHelper.cs
- figurelength.cs
- ServiceModelConfiguration.cs
- QilVisitor.cs
- PathTooLongException.cs
- DataGridTable.cs
- BufferedReadStream.cs
- PointCollection.cs
- CustomTrackingQuery.cs
- CallbackWrapper.cs
- TextTreeExtractElementUndoUnit.cs
- TypeDescriptionProviderAttribute.cs
- SQLChars.cs
- ObjectDataSourceView.cs
- CodeDirectoryCompiler.cs
- ToolStripItemEventArgs.cs
- WebPartZoneBase.cs
- PreviewPageInfo.cs
- RegexCharClass.cs
- MdiWindowListItemConverter.cs
- Size3D.cs
- ValidatorCompatibilityHelper.cs
- SuppressMessageAttribute.cs
- RemoveStoryboard.cs
- MetadataUtilsSmi.cs
- DataObjectSettingDataEventArgs.cs
- SafeNativeMethodsCLR.cs
- PackWebRequestFactory.cs
- invalidudtexception.cs
- ConditionalDesigner.cs
- CodeSubDirectoriesCollection.cs
- SoapReflectionImporter.cs
- TickBar.cs
- SymLanguageVendor.cs
- PEFileEvidenceFactory.cs
- dataSvcMapFileLoader.cs
- ContainerUIElement3D.cs
- CommonDialog.cs
- Int32CAMarshaler.cs
- Imaging.cs
- GraphicsContainer.cs
- xml.cs
- Rijndael.cs
- FederatedMessageSecurityOverHttp.cs
- DllHostInitializer.cs
- SmiEventSink_Default.cs
- PropertyChange.cs