Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / WIN_WINDOWS / lh_tools_devdiv_wpf / Windows / wcp / Speech / Src / Recognition / SrgsGrammar / SrgsToken.cs / 1 / SrgsToken.cs
//---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // // Description: // // History: // 5/1/2004 jeanfp Created from the Kurosawa Code //--------------------------------------------------------------------------- using System; using System.Diagnostics; using System.Speech.Internal; using System.Speech.Internal.SrgsParser; using System.Text; using System.Xml; namespace System.Speech.Recognition.SrgsGrammar { /// TODOC <_include file='doc\Token.uex' path='docs/doc[@for="Token"]/*' /> // Note that currently if multiple words are stored in a Token they are treated internally // and in the result as multiple tokens. [Serializable] [DebuggerDisplay ("{DebuggerDisplayString ()}")] public class SrgsToken : SrgsElement, IToken { //******************************************************************* // // Constructors // //******************************************************************* #region Constructors /// TODOC <_include file='doc\Token.uex' path='docs/doc[@for="Token.Token2"]/*' /> public SrgsToken (string text) { Helpers.ThrowIfEmptyOrNull (text, "text"); Text = text; } #endregion //******************************************************************** // // Public Properties // //******************************************************************* #region public Properties /// TODOC <_include file='doc\Token.uex' path='docs/doc[@for="Token.Text"]/*' /> public string Text { get { return _text; } set { Helpers.ThrowIfEmptyOrNull (value, "value"); // remove all spaces if any string text = value.Trim (Helpers._achTrimChars); if (string.IsNullOrEmpty (text) || text.IndexOf ('\"') >= 0) { throw new ArgumentException (SR.Get (SRID.InvalidTokenString), "value"); } _text = text; } } /// TODOC <_include file='doc\Token.uex' path='docs/doc[@for="Token.Pronunciation"]/*' /> public string Pronunciation { get { return _pronunciation; } set { Helpers.ThrowIfEmptyOrNull (value, "value"); _pronunciation = value; } } /// TODOC <_include file='doc\Token.uex' path='docs/doc[@for="Token.Display"]/*' /> public string Display { get { return _display; } set { Helpers.ThrowIfEmptyOrNull (value, "value"); _display = value; } } #endregion //******************************************************************** // // Internal methods // //******************************************************************** #region Internal methods internal override void WriteSrgs (XmlWriter writer) { // Write_text writer.WriteStartElement ("token"); if (_display != null) { writer.WriteAttributeString ("sapi", "display", XmlParser.sapiNamespace, _display); } if (_pronunciation != null) { writer.WriteAttributeString ("sapi", "pron", XmlParser.sapiNamespace, _pronunciation); } // If an empty string is provided, skip the WriteString // to have the XmlWrite to putrather than if (_text != null && _text.Length > 0) { writer.WriteString (_text); } writer.WriteEndElement (); } internal override void Validate (SrgsGrammar grammar) { if (_pronunciation != null || _display != null) { grammar.HasPronunciation = true; } // Validate the pronunciation if any if (_pronunciation != null) { for (int iCurPron = 0, iDeliminator = 0; iCurPron < _pronunciation.Length; iCurPron = iDeliminator + 1) { // Find semi-colon deliminator and replace with null iDeliminator = _pronunciation.IndexOf (';', iCurPron); if (iDeliminator == -1) { iDeliminator = _pronunciation.Length; } string subPronunciation = _pronunciation.Substring (iCurPron, iDeliminator - iCurPron); // Convert the pronunciation, will throw if error switch (grammar.PhoneticAlphabet) { case AlphabetType.Sapi: PhonemeConverter.ConvertPronToId (subPronunciation, grammar.Culture.LCID); break; case AlphabetType.Ups: PhonemeConverter.UpsConverter.ConvertPronToId (subPronunciation); break; case AlphabetType.Ipa: PhonemeConverter.ValidateUpsIds (subPronunciation.ToCharArray ()); break; } } } base.Validate (grammar); } internal override string DebuggerDisplayString () { StringBuilder sb = new StringBuilder ("Token '"); sb.Append (_text); sb.Append ("'"); if (_pronunciation != null) { sb.Append (" Pronunciation '"); sb.Append (_pronunciation); sb.Append ("'"); } return sb.ToString (); } #endregion //******************************************************************* // // Private Fields // //******************************************************************** #region Private Fields private string _text = string.Empty; private string _pronunciation; private string _display; #endregion } } // 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: // // History: // 5/1/2004 jeanfp Created from the Kurosawa Code //--------------------------------------------------------------------------- using System; using System.Diagnostics; using System.Speech.Internal; using System.Speech.Internal.SrgsParser; using System.Text; using System.Xml; namespace System.Speech.Recognition.SrgsGrammar { /// TODOC <_include file='doc\Token.uex' path='docs/doc[@for="Token"]/*' /> // Note that currently if multiple words are stored in a Token they are treated internally // and in the result as multiple tokens. [Serializable] [DebuggerDisplay ("{DebuggerDisplayString ()}")] public class SrgsToken : SrgsElement, IToken { //******************************************************************* // // Constructors // //******************************************************************* #region Constructors /// TODOC <_include file='doc\Token.uex' path='docs/doc[@for="Token.Token2"]/*' /> public SrgsToken (string text) { Helpers.ThrowIfEmptyOrNull (text, "text"); Text = text; } #endregion //******************************************************************** // // Public Properties // //******************************************************************* #region public Properties /// TODOC <_include file='doc\Token.uex' path='docs/doc[@for="Token.Text"]/*' /> public string Text { get { return _text; } set { Helpers.ThrowIfEmptyOrNull (value, "value"); // remove all spaces if any string text = value.Trim (Helpers._achTrimChars); if (string.IsNullOrEmpty (text) || text.IndexOf ('\"') >= 0) { throw new ArgumentException (SR.Get (SRID.InvalidTokenString), "value"); } _text = text; } } /// TODOC <_include file='doc\Token.uex' path='docs/doc[@for="Token.Pronunciation"]/*' /> public string Pronunciation { get { return _pronunciation; } set { Helpers.ThrowIfEmptyOrNull (value, "value"); _pronunciation = value; } } /// TODOC <_include file='doc\Token.uex' path='docs/doc[@for="Token.Display"]/*' /> public string Display { get { return _display; } set { Helpers.ThrowIfEmptyOrNull (value, "value"); _display = value; } } #endregion //******************************************************************** // // Internal methods // //******************************************************************** #region Internal methods internal override void WriteSrgs (XmlWriter writer) { // Write_text writer.WriteStartElement ("token"); if (_display != null) { writer.WriteAttributeString ("sapi", "display", XmlParser.sapiNamespace, _display); } if (_pronunciation != null) { writer.WriteAttributeString ("sapi", "pron", XmlParser.sapiNamespace, _pronunciation); } // If an empty string is provided, skip the WriteString // to have the XmlWrite to putrather than if (_text != null && _text.Length > 0) { writer.WriteString (_text); } writer.WriteEndElement (); } internal override void Validate (SrgsGrammar grammar) { if (_pronunciation != null || _display != null) { grammar.HasPronunciation = true; } // Validate the pronunciation if any if (_pronunciation != null) { for (int iCurPron = 0, iDeliminator = 0; iCurPron < _pronunciation.Length; iCurPron = iDeliminator + 1) { // Find semi-colon deliminator and replace with null iDeliminator = _pronunciation.IndexOf (';', iCurPron); if (iDeliminator == -1) { iDeliminator = _pronunciation.Length; } string subPronunciation = _pronunciation.Substring (iCurPron, iDeliminator - iCurPron); // Convert the pronunciation, will throw if error switch (grammar.PhoneticAlphabet) { case AlphabetType.Sapi: PhonemeConverter.ConvertPronToId (subPronunciation, grammar.Culture.LCID); break; case AlphabetType.Ups: PhonemeConverter.UpsConverter.ConvertPronToId (subPronunciation); break; case AlphabetType.Ipa: PhonemeConverter.ValidateUpsIds (subPronunciation.ToCharArray ()); break; } } } base.Validate (grammar); } internal override string DebuggerDisplayString () { StringBuilder sb = new StringBuilder ("Token '"); sb.Append (_text); sb.Append ("'"); if (_pronunciation != null) { sb.Append (" Pronunciation '"); sb.Append (_pronunciation); sb.Append ("'"); } return sb.ToString (); } #endregion //******************************************************************* // // Private Fields // //******************************************************************** #region Private Fields private string _text = string.Empty; private string _pronunciation; private string _display; #endregion } } // 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
- MarkupObject.cs
- DataGridViewComboBoxCell.cs
- CellPartitioner.cs
- AssemblyAttributes.cs
- DiagnosticsConfiguration.cs
- CaseStatementSlot.cs
- ColumnWidthChangedEvent.cs
- CodeBinaryOperatorExpression.cs
- CookieHandler.cs
- SupportingTokenDuplexChannel.cs
- SQLBoolean.cs
- RewritingSimplifier.cs
- PrintDocument.cs
- GridView.cs
- InteropExecutor.cs
- FormsAuthenticationTicket.cs
- ToolBarButtonClickEvent.cs
- _ContextAwareResult.cs
- ResourceProviderFactory.cs
- ServiceBehaviorElement.cs
- RotateTransform.cs
- MD5.cs
- Parser.cs
- StringCollection.cs
- SelectionUIService.cs
- Peer.cs
- NotificationContext.cs
- IssuedTokensHeader.cs
- ElementProxy.cs
- MultipartContentParser.cs
- DataGridViewTextBoxCell.cs
- TraceInternal.cs
- ECDiffieHellman.cs
- FixedPageProcessor.cs
- EntityDataSourceWrapperCollection.cs
- Frame.cs
- ObjectDataSourceDisposingEventArgs.cs
- MD5CryptoServiceProvider.cs
- webproxy.cs
- ExpandableObjectConverter.cs
- ExpressionBindingCollection.cs
- AppModelKnownContentFactory.cs
- RewritingSimplifier.cs
- KeyGestureValueSerializer.cs
- MessageContractImporter.cs
- DummyDataSource.cs
- NavigationWindowAutomationPeer.cs
- TaiwanLunisolarCalendar.cs
- XPathSelectionIterator.cs
- DriveNotFoundException.cs
- ToolStripOverflowButton.cs
- PenLineJoinValidation.cs
- RegexCaptureCollection.cs
- GridViewDeleteEventArgs.cs
- BindingExpressionUncommonField.cs
- NameObjectCollectionBase.cs
- PropertyTabAttribute.cs
- RangeValuePattern.cs
- TreeViewHitTestInfo.cs
- SqlMultiplexer.cs
- DataGridViewRowDividerDoubleClickEventArgs.cs
- PermissionSetTriple.cs
- NamespaceList.cs
- TileBrush.cs
- TrustManagerPromptUI.cs
- Sql8ConformanceChecker.cs
- MapPathBasedVirtualPathProvider.cs
- ThrowHelper.cs
- CommandArguments.cs
- ViewLoader.cs
- ThousandthOfEmRealPoints.cs
- Completion.cs
- ToolbarAUtomationPeer.cs
- SystemKeyConverter.cs
- ChildTable.cs
- DateTimeConstantAttribute.cs
- TableParaClient.cs
- ListenDesigner.cs
- Polyline.cs
- ColumnWidthChangingEvent.cs
- ToolboxCategory.cs
- UriWriter.cs
- FormatStringEditor.cs
- ImageCreator.cs
- XamlVector3DCollectionSerializer.cs
- CoTaskMemHandle.cs
- TypeTypeConverter.cs
- SvcMapFileLoader.cs
- NativeObjectSecurity.cs
- Soap.cs
- HttpServerUtilityWrapper.cs
- DataViewManager.cs
- EventLogEntry.cs
- PathSegment.cs
- WebPartPersonalization.cs
- ByteAnimationBase.cs
- ToolStripComboBox.cs
- HtmlHead.cs
- TraceUtility.cs
- ObjectViewEntityCollectionData.cs