//------------------------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // The CaptureCollection lists the captured Capture numbers // contained in a compiled Regex. // namespace System.Text.RegularExpressions { using System.Collections; // This collection returns the Captures for a group // in the order in which they were matched (left to right // or right to left). It is created by Group.Captures //| /// /// /// Represents a sequence of capture substrings. The object is used /// to return the set of captures done by a single capturing group. /// /// //[ Serializable() ] public class CaptureCollection : ICollection { internal Group _group; internal int _capcount; internal Capture[] _captures; // Nonpublic constructor internal CaptureCollection(Group group) { _group = group; _capcount = _group._capcount; } // The object on which to synchronize //| /// /// [To be supplied.] /// public Object SyncRoot { get { return _group; } } // ICollection //| /// /// [To be supplied.] /// public bool IsSynchronized { get { return false; } } // ICollection //| /// /// [To be supplied.] /// public bool IsReadOnly { get { return true; } } // The number of captures for the group //| /// /// /// Returns the number of captures. /// /// public int Count { get { return _capcount; } } // The ith capture in the group //| /// /// /// Provides a means of accessing a specific capture in the collection. /// /// public Capture this[int i] { get { return GetCapture(i); } } // As required by ICollection //| /// /// /// Copies all the elements of the collection to the given array /// beginning at the given index. /// /// 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 //| /// /// /// Provides an enumerator in the same order as Item[]. /// /// public IEnumerator GetEnumerator() { return new CaptureEnumerator(this); } // Nonpublic code to return set of captures for the group internal Capture GetCapture(int i) { if (i == _capcount - 1 && i >= 0) return _group; if (i >= _capcount || i < 0) throw new ArgumentOutOfRangeException("i"); // first time a capture is accessed, compute them all if (_captures == null) { _captures = new Capture[_capcount]; for (int j = 0; j < _capcount - 1; j++) { _captures[j] = new Capture(_group._text, _group._caps[j * 2], _group._caps[j * 2 + 1]); } } return _captures[i]; } } // This non-public enumerator lists all the captures // Should it be public? //[ Serializable() ] internal class CaptureEnumerator : IEnumerator { internal CaptureCollection _rcc; internal int _curindex; // Nonpublic constructor internal CaptureEnumerator(CaptureCollection rcc) { _curindex = -1; _rcc = rcc; } // As required by IEnumerator public bool MoveNext() { int size = _rcc.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 > _rcc.Count) throw new InvalidOperationException("Enum not started");//XXX: SR.GetString(SR.EnumNotStarted)); return _rcc[_curindex]; } } // Reset to before the first item public void Reset() { _curindex = -1; } } }