Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / WIN_WINDOWS / lh_tools_devdiv_wpf / Windows / wcp / Speech / Src / Internal / StringBlob.cs / 1 / StringBlob.cs
//---------------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // // // Description: // Manages a list of strings stored in an array of chars. This code is // ported from the SAPI source code. Starting from scratch, this code // would not make a lot of sense. However, since grammar generarion must // produce bit per bit equivallent output between the SAPI COM object and // the managed compiler, we must to use it. // // History: // 5/1/2004 jeanfp Created from the Sapi Managed code //--------------------------------------------------------------------------- using System; using System.Collections.Generic; namespace System.Speech.Internal { ////// Summary description for StringBlob. /// internal class StringBlob { //******************************************************************* // // Constructors // //******************************************************************* #region Constructors internal StringBlob () { } internal StringBlob (char [] pszStringArray) { int cch = pszStringArray.Length; if (cch > 0) { // First string is always empty. if (pszStringArray [0] != 0) { throw new FormatException (SR.Get (SRID.RecognizerInvalidBinaryGrammar)); } // First pass to copy data and count strings. for (int iPos = 1, iEnd = cch, iStart = 1; iPos < iEnd; iPos++) { if (pszStringArray [iPos] == '\0') { string sWord = new string (pszStringArray, iStart, iPos - iStart); _refStrings.Add (sWord); _offsetStrings.Add (_totalStringSizes); _strings.Add (sWord, ++_cWords); _totalStringSizes += sWord.Length + 1; iStart = iPos + 1; } } } } #endregion //******************************************************************** // // Internal Methods // //******************************************************************* #region internal Methods // // The ID for a null string is always 0, the ID for subsequent strings is the // index of the string + 1; // internal int Add (string psz, out int idWord) { int offset = 0; idWord = 0; if (!string.IsNullOrEmpty (psz)) { // Check if the string is already in the table if (!_strings.TryGetValue (psz, out idWord)) { System.Diagnostics.Debug.Assert (_strings.Count == _refStrings.Count); // No add it to the string table idWord = ++_cWords; offset = _totalStringSizes; _refStrings.Add (psz); _offsetStrings.Add (offset); _strings.Add (psz, _cWords); _totalStringSizes += psz.Length + 1; } else { offset = OffsetFromId (idWord); } } return offset; } // Returns idWord; use IndexFromId to recover string offset internal int Find (string psz) { // Compatibility the SAPI version if (string.IsNullOrEmpty (psz) || _cWords == 0) { return 0; } // Use the dictionary to find the value int iWord; return _strings.TryGetValue (psz, out iWord) ? iWord : -1; } internal string this [int index] { get { if ((index < 1) || index > _cWords) { throw new InvalidOperationException (); } return _refStrings [index - 1]; } } ////// Only DEBUG code should use this /// /// ///internal string FromOffset (int offset) { int iPos = 1; int iWord = 1; System.Diagnostics.Debug.Assert (offset > 0); if (offset == 1 && _cWords >= 1) { return this [iWord]; } foreach (string s in _refStrings) { iWord++; iPos += s.Length + 1; if (offset == iPos) { return this [iWord]; } } return null; } internal int StringSize () { return _cWords > 0 ? _totalStringSizes : 0; } internal int SerializeSize () { return ((StringSize () * _sizeOfChar + 3) & ~3) / 2; } internal char [] SerializeData () { // force a 0xcccc at the end of the buffer if the length is odd int iEnd = SerializeSize (); char [] aData = new char [iEnd]; // aData [0] is set by the framework to zero int iPos = 1; foreach (string s in _refStrings) { for (int i = 0; i < s.Length; i++) { aData [iPos++] = s [i]; } aData [iPos++] = '\0'; } if (StringSize () % 2 == 1) { aData [iPos++] = (char) 0xCCCC; } System.Diagnostics.Debug.Assert (iEnd == 0 || iPos == SerializeSize ()); return aData; } internal int OffsetFromId (int index) { System.Diagnostics.Debug.Assert (index <= _cWords); if (index > 0) { return _offsetStrings [index - 1]; } return 0; } #endregion //******************************************************************** // // Internal Properties // //******************************************************************** #region internal Properties internal int Count { get { return _cWords; } } #endregion //******************************************************************* // // Private Fields // //******************************************************************** #region Private Fields // List of words, end-to-end private Dictionary _strings = new Dictionary (); // List of indices in the dictionary of words private List _refStrings = new List (); // List of indices in the dictionary of words private List _offsetStrings = new List (); // Number of words private int _cWords; // Cached value for the total string sizes - The first digit is always zero. private int _totalStringSizes = 1; // .Net is Unicode so 2 bytes per characters private const int _sizeOfChar = 2; #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------------- // // Copyright (c) Microsoft Corporation. All rights reserved. // // // // // Description: // Manages a list of strings stored in an array of chars. This code is // ported from the SAPI source code. Starting from scratch, this code // would not make a lot of sense. However, since grammar generarion must // produce bit per bit equivallent output between the SAPI COM object and // the managed compiler, we must to use it. // // History: // 5/1/2004 jeanfp Created from the Sapi Managed code //--------------------------------------------------------------------------- using System; using System.Collections.Generic; namespace System.Speech.Internal { ////// Summary description for StringBlob. /// internal class StringBlob { //******************************************************************* // // Constructors // //******************************************************************* #region Constructors internal StringBlob () { } internal StringBlob (char [] pszStringArray) { int cch = pszStringArray.Length; if (cch > 0) { // First string is always empty. if (pszStringArray [0] != 0) { throw new FormatException (SR.Get (SRID.RecognizerInvalidBinaryGrammar)); } // First pass to copy data and count strings. for (int iPos = 1, iEnd = cch, iStart = 1; iPos < iEnd; iPos++) { if (pszStringArray [iPos] == '\0') { string sWord = new string (pszStringArray, iStart, iPos - iStart); _refStrings.Add (sWord); _offsetStrings.Add (_totalStringSizes); _strings.Add (sWord, ++_cWords); _totalStringSizes += sWord.Length + 1; iStart = iPos + 1; } } } } #endregion //******************************************************************** // // Internal Methods // //******************************************************************* #region internal Methods // // The ID for a null string is always 0, the ID for subsequent strings is the // index of the string + 1; // internal int Add (string psz, out int idWord) { int offset = 0; idWord = 0; if (!string.IsNullOrEmpty (psz)) { // Check if the string is already in the table if (!_strings.TryGetValue (psz, out idWord)) { System.Diagnostics.Debug.Assert (_strings.Count == _refStrings.Count); // No add it to the string table idWord = ++_cWords; offset = _totalStringSizes; _refStrings.Add (psz); _offsetStrings.Add (offset); _strings.Add (psz, _cWords); _totalStringSizes += psz.Length + 1; } else { offset = OffsetFromId (idWord); } } return offset; } // Returns idWord; use IndexFromId to recover string offset internal int Find (string psz) { // Compatibility the SAPI version if (string.IsNullOrEmpty (psz) || _cWords == 0) { return 0; } // Use the dictionary to find the value int iWord; return _strings.TryGetValue (psz, out iWord) ? iWord : -1; } internal string this [int index] { get { if ((index < 1) || index > _cWords) { throw new InvalidOperationException (); } return _refStrings [index - 1]; } } ////// Only DEBUG code should use this /// /// ///internal string FromOffset (int offset) { int iPos = 1; int iWord = 1; System.Diagnostics.Debug.Assert (offset > 0); if (offset == 1 && _cWords >= 1) { return this [iWord]; } foreach (string s in _refStrings) { iWord++; iPos += s.Length + 1; if (offset == iPos) { return this [iWord]; } } return null; } internal int StringSize () { return _cWords > 0 ? _totalStringSizes : 0; } internal int SerializeSize () { return ((StringSize () * _sizeOfChar + 3) & ~3) / 2; } internal char [] SerializeData () { // force a 0xcccc at the end of the buffer if the length is odd int iEnd = SerializeSize (); char [] aData = new char [iEnd]; // aData [0] is set by the framework to zero int iPos = 1; foreach (string s in _refStrings) { for (int i = 0; i < s.Length; i++) { aData [iPos++] = s [i]; } aData [iPos++] = '\0'; } if (StringSize () % 2 == 1) { aData [iPos++] = (char) 0xCCCC; } System.Diagnostics.Debug.Assert (iEnd == 0 || iPos == SerializeSize ()); return aData; } internal int OffsetFromId (int index) { System.Diagnostics.Debug.Assert (index <= _cWords); if (index > 0) { return _offsetStrings [index - 1]; } return 0; } #endregion //******************************************************************** // // Internal Properties // //******************************************************************** #region internal Properties internal int Count { get { return _cWords; } } #endregion //******************************************************************* // // Private Fields // //******************************************************************** #region Private Fields // List of words, end-to-end private Dictionary _strings = new Dictionary (); // List of indices in the dictionary of words private List _refStrings = new List (); // List of indices in the dictionary of words private List _offsetStrings = new List (); // Number of words private int _cWords; // Cached value for the total string sizes - The first digit is always zero. private int _totalStringSizes = 1; // .Net is Unicode so 2 bytes per characters private const int _sizeOfChar = 2; #endregion } } // 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
- Trace.cs
- WebControlAdapter.cs
- SettingsPropertyValue.cs
- TrimSurroundingWhitespaceAttribute.cs
- _BufferOffsetSize.cs
- SchemaImporterExtensionElementCollection.cs
- SignatureToken.cs
- CustomWebEventKey.cs
- wgx_exports.cs
- PrePrepareMethodAttribute.cs
- OdbcError.cs
- SystemNetHelpers.cs
- EtwTrace.cs
- MimeMapping.cs
- ImageClickEventArgs.cs
- CompilerGeneratedAttribute.cs
- SimpleWebHandlerParser.cs
- NativeRightsManagementAPIsStructures.cs
- IfAction.cs
- StyleHelper.cs
- GiveFeedbackEvent.cs
- HostingEnvironment.cs
- StringInfo.cs
- ClockController.cs
- ObjectDataSourceMethodEventArgs.cs
- LoginNameDesigner.cs
- SupportingTokenChannel.cs
- DynamicControlParameter.cs
- MessageQueueException.cs
- ToolStripSplitStackLayout.cs
- Point3DAnimationBase.cs
- OpacityConverter.cs
- AliasGenerator.cs
- CollectionBuilder.cs
- TableItemPattern.cs
- COAUTHINFO.cs
- XmlComment.cs
- CapiHashAlgorithm.cs
- KernelTypeValidation.cs
- SqlCacheDependencyDatabaseCollection.cs
- SingleQueryOperator.cs
- SchemaElementDecl.cs
- NetPipeSectionData.cs
- PartBasedPackageProperties.cs
- SessionStateItemCollection.cs
- SqlVersion.cs
- InfoCardRSAPKCS1KeyExchangeDeformatter.cs
- ADConnectionHelper.cs
- MediaContextNotificationWindow.cs
- BindingCompleteEventArgs.cs
- TextEditorDragDrop.cs
- CustomAttributeBuilder.cs
- RectAnimationUsingKeyFrames.cs
- NetworkCredential.cs
- xmlfixedPageInfo.cs
- ByteStreamMessageEncoder.cs
- MethodBuilder.cs
- Site.cs
- NumericUpDownAcceleration.cs
- UrlAuthFailedErrorFormatter.cs
- ColorConverter.cs
- ContextMenuService.cs
- RangeValidator.cs
- FrameworkElementFactory.cs
- EncryptedReference.cs
- XmlNodeComparer.cs
- DeferredTextReference.cs
- DeclarativeCatalogPart.cs
- PositiveTimeSpanValidatorAttribute.cs
- TextView.cs
- Assembly.cs
- ColorContext.cs
- securestring.cs
- RepeaterItemEventArgs.cs
- NotifyIcon.cs
- CompleteWizardStep.cs
- ProfileModule.cs
- AtomicFile.cs
- BrushMappingModeValidation.cs
- mansign.cs
- Int32.cs
- DiagnosticTrace.cs
- InvalidWMPVersionException.cs
- LowerCaseStringConverter.cs
- SystemDiagnosticsSection.cs
- TemplateControlCodeDomTreeGenerator.cs
- TextRange.cs
- InkCanvasFeedbackAdorner.cs
- ExceptionUtil.cs
- Matrix.cs
- SqlStatistics.cs
- SessionStateItemCollection.cs
- XmlQueryOutput.cs
- ListItemCollection.cs
- LogWriteRestartAreaState.cs
- StorageRoot.cs
- DesignerTextViewAdapter.cs
- Point4D.cs
- dataSvcMapFileLoader.cs
- KeyMatchBuilder.cs