singrdk/base/Applications/Runtime/Full/System/Text/RegularExpressions/regexgroupcollection.cs

219 lines
6.9 KiB
C#
Raw Permalink Normal View History

2008-03-05 09:52:00 -05:00
//------------------------------------------------------------------------------
// Copyright (c) Microsoft Corporation. All rights reserved.
//------------------------------------------------------------------------------
// The GroupCollection lists the captured Capture numbers
// contained in a compiled Regex.
//
2008-11-17 18:29:00 -05:00
namespace System.Text.RegularExpressions
{
2008-03-05 09:52:00 -05:00
using System.Collections;
//| <include file='doc\RegexGroupCollection.uex' path='docs/doc[@for="GroupCollection"]/*' />
/// <devdoc>
/// <para>
/// Represents a sequence of capture substrings. The object is used
/// to return the set of captures done by a single capturing group.
/// </para>
/// </devdoc>
2008-11-17 18:29:00 -05:00
//[ Serializable() ]
2008-03-05 09:52:00 -05:00
public class GroupCollection : ICollection {
internal Match _match;
internal Hashtable _captureMap;
// cache of Group objects fed to the user
internal Group[] _groups;
// Nonpublic constructor
internal GroupCollection(Match match, Hashtable caps) {
_match = match;
_captureMap = caps;
}
// The object on which to synchronize
//| <include file='doc\RegexGroupCollection.uex' path='docs/doc[@for="GroupCollection.SyncRoot"]/*' />
/// <devdoc>
/// <para>[To be supplied.]</para>
/// </devdoc>
public Object SyncRoot {
get {
return _match;
}
}
// ICollection
//| <include file='doc\RegexGroupCollection.uex' path='docs/doc[@for="GroupCollection.IsSynchronized"]/*' />
/// <devdoc>
/// <para>[To be supplied.]</para>
/// </devdoc>
public bool IsSynchronized {
get {
return false;
}
}
// ICollection
//| <include file='doc\RegexGroupCollection.uex' path='docs/doc[@for="GroupCollection.IsReadOnly"]/*' />
/// <devdoc>
/// <para>[To be supplied.]</para>
/// </devdoc>
public bool IsReadOnly {
get {
return true;
}
}
//| <include file='doc\RegexGroupCollection.uex' path='docs/doc[@for="GroupCollection.Count"]/*' />
/// <devdoc>
/// <para>
/// Returns the number of groups.
/// </para>
/// </devdoc>
public int Count {
get {
return _match._matchcount.Length;
}
}
//| <include file='doc\RegexGroupCollection.uex' path='docs/doc[@for="GroupCollection.this"]/*' />
/// <devdoc>
/// <para>[To be supplied.]</para>
/// </devdoc>
public Group this[int groupnum]
{
get {
return GetGroup(groupnum);
}
}
//| <include file='doc\RegexGroupCollection.uex' path='docs/doc[@for="GroupCollection.this1"]/*' />
/// <devdoc>
/// <para>[To be supplied.]</para>
/// </devdoc>
public Group this[String groupname] {
get {
if (_match._regex == null)
return Group._emptygroup;
return GetGroup(_match._regex.GroupNumberFromName(groupname));
}
}
internal Group GetGroup(int groupnum) {
if (_captureMap != null) {
Object o;
o = _captureMap[groupnum];
if (o == null)
return Group._emptygroup;
2008-11-17 18:29:00 -05:00
//throw new ArgumentOutOfRangeException("groupnum");
2008-03-05 09:52:00 -05:00
return GetGroupImpl((int)o);
}
else {
//if (groupnum >= _match._regex.CapSize || groupnum < 0)
2008-11-17 18:29:00 -05:00
// throw new ArgumentOutOfRangeException("groupnum");
2008-03-05 09:52:00 -05:00
if (groupnum >= _match._matchcount.Length || groupnum < 0)
return Group._emptygroup;
return GetGroupImpl(groupnum);
}
}
// Caches the group objects
internal Group GetGroupImpl(int groupnum) {
if (groupnum == 0)
return _match;
// Construct all the Group objects the first time GetGroup is called
if (_groups == null) {
_groups = new Group[_match._matchcount.Length - 1];
for (int i = 0; i < _groups.Length; i++) {
_groups[i] = new Group(_match._text, _match._matches[i + 1], _match._matchcount[i + 1]);
}
}
return _groups[groupnum - 1];
}
// As required by ICollection
//| <include file='doc\RegexGroupCollection.uex' path='docs/doc[@for="GroupCollection.CopyTo"]/*' />
/// <devdoc>
/// <para>
/// Copies all the elements of the collection to the given array
/// beginning at the given index.
/// </para>
/// </devdoc>
public void CopyTo(Array array, int arrayIndex) {
if (array == null)
throw new ArgumentNullException("array");
for (int i = arrayIndex, j = 0; j < Count; i++, j++) {
array.SetValue(this[j], i);
}
}
// As required by ICollection
//| <include file='doc\RegexGroupCollection.uex' path='docs/doc[@for="GroupCollection.GetEnumerator"]/*' />
/// <devdoc>
/// <para>
/// Provides an enumerator in the same order as Item[].
/// </para>
/// </devdoc>
public IEnumerator GetEnumerator() {
return new GroupEnumerator(this);
}
}
// This non-public enumerator lists all the captures
// Should it be public?
internal class GroupEnumerator : IEnumerator {
internal GroupCollection _rgc;
internal int _curindex;
// Nonpublic constructor
internal GroupEnumerator(GroupCollection rgc) {
_curindex = -1;
_rgc = rgc;
}
// As required by IEnumerator
public bool MoveNext() {
int size = _rgc.Count;
if (_curindex >= size)
return false;
_curindex++;
return(_curindex < size);
}
// As required by IEnumerator
public Object Current {
get { return Capture;}
}
// Returns the current capture
public Capture Capture {
get {
if (_curindex < 0 || _curindex > _rgc.Count)
throw new InvalidOperationException("Enum not started");//XXX: SR.GetString(SR.EnumNotStarted));
return _rgc[_curindex];
}
}
// Reset to before the first item
public void Reset() {
_curindex = -1;
}
}
}