Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / clr / src / BCL / System / Globalization / TextElementEnumerator.cs / 1 / TextElementEnumerator.cs
// ==++==
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// ==--==
////////////////////////////////////////////////////////////////////////////
//
// Class: TextElementEnumerator
//
// Purpose:
//
// Date: [....] 31, 1999
//
////////////////////////////////////////////////////////////////////////////
using System.Runtime.Serialization;
namespace System.Globalization {
using System.Collections;
//
// This is public because GetTextElement() is public.
//
[Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public class TextElementEnumerator: IEnumerator
{
private String str;
private int index;
private int startIndex;
[NonSerialized]
private int strLen; // This is the length of the total string, counting from the beginning of string.
[NonSerialized]
private int currTextElementLen; // The current text element lenght after MoveNext() is called.
[OptionalField(VersionAdded = 2)]
private UnicodeCategory uc;
[OptionalField(VersionAdded = 2)]
private int charLen; // The next abstract char to look at after MoveNext() is called. It could be 1 or 2, depending on if it is a surrogate or not.
internal TextElementEnumerator(String str, int startIndex, int strLen)
{
BCLDebug.Assert(str != null, "TextElementEnumerator(): str != null");
BCLDebug.Assert(startIndex >= 0 && strLen >= 0, "TextElementEnumerator(): startIndex >= 0 && strLen >= 0");
BCLDebug.Assert(strLen >= startIndex, "TextElementEnumerator(): strLen >= startIndex");
this.str = str;
this.startIndex = startIndex;
this.strLen = strLen;
Reset();
}
#region Serialization
// the following fields is defined to keep the compatibility with Everett.
// don't change/remove the names/types of these fields.
private int endIndex;
private int nextTextElementLen;
[OnDeserializing]
private void OnDeserializing(StreamingContext ctx)
{
charLen = -1;
}
[OnDeserialized]
private void OnDeserialized(StreamingContext ctx)
{
strLen = endIndex + 1;
currTextElementLen = nextTextElementLen;
if (charLen == -1)
{
uc = CharUnicodeInfo.InternalGetUnicodeCategory(str, index, out charLen);
}
}
[OnSerializing]
private void OnSerializing(StreamingContext ctx)
{
endIndex = strLen - 1;
nextTextElementLen = currTextElementLen;
}
#endregion Serialization
public bool MoveNext()
{
if (index >= strLen)
{
// Make the index to be greater than strLen so that we can throw exception if GetTextElement() is called.
index = strLen + 1;
return (false);
}
currTextElementLen = StringInfo.GetCurrentTextElementLen(str, index, strLen, ref uc, ref charLen);
index += currTextElementLen;
return (true);
}
//
// Get the current text element.
//
public Object Current {
get {
return (GetTextElement());
}
}
//
// Get the current text element.
//
public String GetTextElement()
{
if (index == startIndex) {
throw new InvalidOperationException(Environment.GetResourceString("InvalidOperation_EnumNotStarted"));
}
if (index > strLen) {
throw new InvalidOperationException(Environment.GetResourceString("InvalidOperation_EnumEnded"));
}
return (str.Substring(index - currTextElementLen, currTextElementLen));
}
//
// Get the starting index of the current text element.
//
public int ElementIndex
{
get
{
if (index == startIndex)
{
throw new InvalidOperationException(Environment.GetResourceString("InvalidOperation_EnumNotStarted"));
}
return (index - currTextElementLen);
}
}
public void Reset()
{
index = startIndex;
if (index < strLen) {
// If we have more than 1 character, get the category of the current char.
uc = CharUnicodeInfo.InternalGetUnicodeCategory(str, index, out charLen);
}
}
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// ==++==
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// ==--==
////////////////////////////////////////////////////////////////////////////
//
// Class: TextElementEnumerator
//
// Purpose:
//
// Date: [....] 31, 1999
//
////////////////////////////////////////////////////////////////////////////
using System.Runtime.Serialization;
namespace System.Globalization {
using System.Collections;
//
// This is public because GetTextElement() is public.
//
[Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public class TextElementEnumerator: IEnumerator
{
private String str;
private int index;
private int startIndex;
[NonSerialized]
private int strLen; // This is the length of the total string, counting from the beginning of string.
[NonSerialized]
private int currTextElementLen; // The current text element lenght after MoveNext() is called.
[OptionalField(VersionAdded = 2)]
private UnicodeCategory uc;
[OptionalField(VersionAdded = 2)]
private int charLen; // The next abstract char to look at after MoveNext() is called. It could be 1 or 2, depending on if it is a surrogate or not.
internal TextElementEnumerator(String str, int startIndex, int strLen)
{
BCLDebug.Assert(str != null, "TextElementEnumerator(): str != null");
BCLDebug.Assert(startIndex >= 0 && strLen >= 0, "TextElementEnumerator(): startIndex >= 0 && strLen >= 0");
BCLDebug.Assert(strLen >= startIndex, "TextElementEnumerator(): strLen >= startIndex");
this.str = str;
this.startIndex = startIndex;
this.strLen = strLen;
Reset();
}
#region Serialization
// the following fields is defined to keep the compatibility with Everett.
// don't change/remove the names/types of these fields.
private int endIndex;
private int nextTextElementLen;
[OnDeserializing]
private void OnDeserializing(StreamingContext ctx)
{
charLen = -1;
}
[OnDeserialized]
private void OnDeserialized(StreamingContext ctx)
{
strLen = endIndex + 1;
currTextElementLen = nextTextElementLen;
if (charLen == -1)
{
uc = CharUnicodeInfo.InternalGetUnicodeCategory(str, index, out charLen);
}
}
[OnSerializing]
private void OnSerializing(StreamingContext ctx)
{
endIndex = strLen - 1;
nextTextElementLen = currTextElementLen;
}
#endregion Serialization
public bool MoveNext()
{
if (index >= strLen)
{
// Make the index to be greater than strLen so that we can throw exception if GetTextElement() is called.
index = strLen + 1;
return (false);
}
currTextElementLen = StringInfo.GetCurrentTextElementLen(str, index, strLen, ref uc, ref charLen);
index += currTextElementLen;
return (true);
}
//
// Get the current text element.
//
public Object Current {
get {
return (GetTextElement());
}
}
//
// Get the current text element.
//
public String GetTextElement()
{
if (index == startIndex) {
throw new InvalidOperationException(Environment.GetResourceString("InvalidOperation_EnumNotStarted"));
}
if (index > strLen) {
throw new InvalidOperationException(Environment.GetResourceString("InvalidOperation_EnumEnded"));
}
return (str.Substring(index - currTextElementLen, currTextElementLen));
}
//
// Get the starting index of the current text element.
//
public int ElementIndex
{
get
{
if (index == startIndex)
{
throw new InvalidOperationException(Environment.GetResourceString("InvalidOperation_EnumNotStarted"));
}
return (index - currTextElementLen);
}
}
public void Reset()
{
index = startIndex;
if (index < strLen) {
// If we have more than 1 character, get the category of the current char.
uc = CharUnicodeInfo.InternalGetUnicodeCategory(str, index, out charLen);
}
}
}
}
// 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
- mediaeventshelper.cs
- SchemaElementLookUpTable.cs
- ObjectHandle.cs
- Compilation.cs
- TypeDescriptionProvider.cs
- XamlStream.cs
- AxisAngleRotation3D.cs
- LinqToSqlWrapper.cs
- ViewLoader.cs
- DynamicValidatorEventArgs.cs
- HashHelper.cs
- CompilerTypeWithParams.cs
- RowToParametersTransformer.cs
- CatalogZoneBase.cs
- dataprotectionpermission.cs
- KeysConverter.cs
- DrawingContextWalker.cs
- ReachVisualSerializerAsync.cs
- SymLanguageVendor.cs
- DataRowExtensions.cs
- ListSourceHelper.cs
- PersistStreamTypeWrapper.cs
- ViewgenGatekeeper.cs
- FileClassifier.cs
- ContainerActivationHelper.cs
- SortKey.cs
- TreeView.cs
- PathFigureCollection.cs
- DefaultClaimSet.cs
- AppLevelCompilationSectionCache.cs
- PartitionedDataSource.cs
- DataRowComparer.cs
- IndexingContentUnit.cs
- PagedControl.cs
- CompositeFontInfo.cs
- QueryContinueDragEventArgs.cs
- documentsequencetextcontainer.cs
- WindowsSecurityToken.cs
- ExpandableObjectConverter.cs
- QilStrConcat.cs
- SeparatorAutomationPeer.cs
- UnauthorizedWebPart.cs
- TableLayoutCellPaintEventArgs.cs
- RoleBoolean.cs
- BamlRecordReader.cs
- TableProviderWrapper.cs
- ApplicationDirectoryMembershipCondition.cs
- CanonicalXml.cs
- BitmapDownload.cs
- AnonymousIdentificationModule.cs
- WsatProxy.cs
- GrammarBuilderBase.cs
- AppSettingsExpressionBuilder.cs
- ZipArchive.cs
- GPRECTF.cs
- BaseHashHelper.cs
- WebDisplayNameAttribute.cs
- SmtpSpecifiedPickupDirectoryElement.cs
- FieldToken.cs
- CodeLinePragma.cs
- DocumentXmlWriter.cs
- RowVisual.cs
- XmlSerializerAssemblyAttribute.cs
- RowCache.cs
- basemetadatamappingvisitor.cs
- WebPartConnectionsCancelVerb.cs
- Content.cs
- EntityDataSourceUtil.cs
- CompilationUtil.cs
- Label.cs
- ColorEditor.cs
- HwndTarget.cs
- SslStream.cs
- ConfigXmlText.cs
- Pkcs7Recipient.cs
- SynchronizationContext.cs
- DataMember.cs
- ActiveXHelper.cs
- ControlPaint.cs
- RowToFieldTransformer.cs
- SByteStorage.cs
- XmlDeclaration.cs
- SafeEventHandle.cs
- SByteStorage.cs
- ContentDisposition.cs
- RelatedEnd.cs
- SQLInt16Storage.cs
- QuaternionIndependentAnimationStorage.cs
- UniqueEventHelper.cs
- TargetConverter.cs
- IndexedEnumerable.cs
- PointHitTestParameters.cs
- XsdDuration.cs
- DataGridViewCellStateChangedEventArgs.cs
- PermissionToken.cs
- UriTemplateHelpers.cs
- TripleDESCryptoServiceProvider.cs
- ForEachAction.cs
- DiscoveryMessageSequence11.cs
- TabItem.cs