Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / 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
- WsdlInspector.cs
- VisualBasicValue.cs
- DiffuseMaterial.cs
- oledbmetadatacolumnnames.cs
- Maps.cs
- _SSPISessionCache.cs
- ImageSource.cs
- CharConverter.cs
- TextProperties.cs
- DecimalStorage.cs
- DeploymentSectionCache.cs
- ScheduleChanges.cs
- AuthenticationSection.cs
- SubpageParaClient.cs
- WebScriptEnablingBehavior.cs
- HtmlCommandAdapter.cs
- PolicyVersion.cs
- XPathNode.cs
- MessageFault.cs
- Calendar.cs
- GregorianCalendar.cs
- UserControlCodeDomTreeGenerator.cs
- DefaultMemberAttribute.cs
- BinaryNode.cs
- SqlServices.cs
- TextElementEnumerator.cs
- TextEmbeddedObject.cs
- FastEncoderWindow.cs
- Queue.cs
- PersianCalendar.cs
- MailSettingsSection.cs
- SizeKeyFrameCollection.cs
- ProtectedConfigurationSection.cs
- BindingContext.cs
- EntitySetDataBindingList.cs
- FilterFactory.cs
- SerializationHelper.cs
- EntityDescriptor.cs
- NamespaceQuery.cs
- VoiceInfo.cs
- WindowsImpersonationContext.cs
- DataGridRow.cs
- MemberPath.cs
- COMException.cs
- AttributeCollection.cs
- WebSysDisplayNameAttribute.cs
- XmlComplianceUtil.cs
- AppDomainGrammarProxy.cs
- HttpCachePolicy.cs
- XmlSchemaImporter.cs
- EncryptedPackageFilter.cs
- SynchronizedPool.cs
- NodeFunctions.cs
- XmlSchemaImport.cs
- HtmlPanelAdapter.cs
- SlipBehavior.cs
- EtwTrace.cs
- StorageEntityTypeMapping.cs
- WinInetCache.cs
- ThicknessAnimation.cs
- SqlPersistenceProviderFactory.cs
- SmtpNetworkElement.cs
- AuthenticationServiceManager.cs
- CopyAttributesAction.cs
- COM2PropertyBuilderUITypeEditor.cs
- HttpModuleAction.cs
- Metadata.cs
- SQLCharsStorage.cs
- WindowsIdentity.cs
- RemoteWebConfigurationHostStream.cs
- VerticalAlignConverter.cs
- WindowsStatusBar.cs
- ConsoleTraceListener.cs
- TimeSpanSecondsOrInfiniteConverter.cs
- IteratorDescriptor.cs
- DataSourceBooleanViewSchemaConverter.cs
- Int16AnimationBase.cs
- RoutedEvent.cs
- QueryReaderSettings.cs
- GAC.cs
- EmptyReadOnlyDictionaryInternal.cs
- sqlmetadatafactory.cs
- EventLogEntryCollection.cs
- TypeUsageBuilder.cs
- Crc32Helper.cs
- httpserverutility.cs
- ArglessEventHandlerProxy.cs
- DataServiceHostFactory.cs
- Label.cs
- MatcherBuilder.cs
- FileLevelControlBuilderAttribute.cs
- SafeProcessHandle.cs
- TextServicesProperty.cs
- DashStyles.cs
- SerializerWriterEventHandlers.cs
- KeyBinding.cs
- DesignerListAdapter.cs
- XmlAttributeProperties.cs
- SQLChars.cs
- SqlDataAdapter.cs