Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / 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
- DrawingVisualDrawingContext.cs
- ExpressionVisitor.cs
- StyleHelper.cs
- basemetadatamappingvisitor.cs
- ArcSegment.cs
- DataPagerFieldCommandEventArgs.cs
- HttpListenerRequestUriBuilder.cs
- TemplateBuilder.cs
- Encoding.cs
- HostProtectionPermission.cs
- DecoderFallbackWithFailureFlag.cs
- CheckBox.cs
- TagMapCollection.cs
- PropertyConverter.cs
- DefaultSection.cs
- CapiHashAlgorithm.cs
- FlowNode.cs
- Psha1DerivedKeyGenerator.cs
- SystemWebExtensionsSectionGroup.cs
- Image.cs
- PageTheme.cs
- Interlocked.cs
- Point.cs
- XmlWellformedWriter.cs
- httpserverutility.cs
- _NtlmClient.cs
- EditorPartCollection.cs
- SplitterEvent.cs
- Types.cs
- RadioButtonFlatAdapter.cs
- InputReportEventArgs.cs
- DetailsViewInsertEventArgs.cs
- DesignObjectWrapper.cs
- followingquery.cs
- DataControlFieldHeaderCell.cs
- Gdiplus.cs
- TransformGroup.cs
- backend.cs
- MessageHeaderInfoTraceRecord.cs
- DataShape.cs
- IsolatedStorage.cs
- GZipUtils.cs
- SafeArrayTypeMismatchException.cs
- Mappings.cs
- Triplet.cs
- AuthenticationManager.cs
- PathHelper.cs
- ExpressionParser.cs
- PolicyStatement.cs
- CompiledIdentityConstraint.cs
- codemethodreferenceexpression.cs
- GenericTransactionFlowAttribute.cs
- BmpBitmapDecoder.cs
- EdmMember.cs
- FileSecurity.cs
- MetadataCollection.cs
- InlineObject.cs
- ExternalException.cs
- GenerateScriptTypeAttribute.cs
- Html32TextWriter.cs
- Compiler.cs
- RtfToXamlReader.cs
- Msmq4SubqueuePoisonHandler.cs
- ObjectFullSpanRewriter.cs
- BezierSegment.cs
- ThicknessAnimationUsingKeyFrames.cs
- base64Transforms.cs
- Command.cs
- WebPartDescription.cs
- EditingMode.cs
- PointAnimationClockResource.cs
- PointCollection.cs
- TextHintingModeValidation.cs
- DefaultAuthorizationContext.cs
- Substitution.cs
- ProtocolElementCollection.cs
- ReadOnlyHierarchicalDataSource.cs
- SerialStream.cs
- LowerCaseStringConverter.cs
- ObjectNavigationPropertyMapping.cs
- ExpressionBuilderContext.cs
- InvalidOleVariantTypeException.cs
- UrlMappingCollection.cs
- LockedBorderGlyph.cs
- IconBitmapDecoder.cs
- XmlSchemaSimpleType.cs
- RoleService.cs
- Pointer.cs
- RequestCacheManager.cs
- CompoundFileReference.cs
- ConfigurationUtility.cs
- RadioButtonBaseAdapter.cs
- TemplateAction.cs
- ReadOnlyHierarchicalDataSource.cs
- Hash.cs
- Connection.cs
- WmlLinkAdapter.cs
- SystemIPGlobalProperties.cs
- StyleHelper.cs
- BooleanExpr.cs