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

94 lines
3.3 KiB
C#
Raw Permalink Normal View History

2008-03-05 09:52:00 -05:00
//------------------------------------------------------------------------------
// Copyright (c) Microsoft Corporation. All rights reserved.
//------------------------------------------------------------------------------
// Group represents the substring or substrings that
// are captured by a single capturing group after one
// regular expression match.
//
2008-11-17 18:29:00 -05:00
namespace System.Text.RegularExpressions
{
2008-03-05 09:52:00 -05:00
//| <include file='doc\RegexGroup.uex' path='docs/doc[@for="Group"]/*' />
/// <devdoc>
2008-11-17 18:29:00 -05:00
/// Group
2008-03-05 09:52:00 -05:00
/// represents the results from a single capturing group. A capturing group can
/// capture zero, one, or more strings in a single match because of quantifiers, so
2008-11-17 18:29:00 -05:00
/// Group supplies a collection of Capture objects.
2008-03-05 09:52:00 -05:00
/// </devdoc>
2008-11-17 18:29:00 -05:00
//[ Serializable() ]
2008-03-05 09:52:00 -05:00
public class Group : Capture {
// the empty group object
internal static Group _emptygroup = new Group(String.Empty, new int[0], 0);
2008-11-17 18:29:00 -05:00
2008-03-05 09:52:00 -05:00
internal int[] _caps;
internal int _capcount;
internal CaptureCollection _capcoll;
internal Group(String text, int[] caps, int capcount)
: base(text, capcount == 0 ? 0 : caps[(capcount - 1) * 2],
capcount == 0 ? 0 : caps[(capcount * 2) - 1]) {
_caps = caps;
_capcount = capcount;
}
// True if the match was successful
//| <include file='doc\RegexGroup.uex' path='docs/doc[@for="Group.Success"]/*' />
/// <devdoc>
/// <para>Indicates whether the match is successful.</para>
/// </devdoc>
public bool Success {
get {
return _capcount != 0;
}
}
// The collection of all captures for this group
//| <include file='doc\RegexGroup.uex' path='docs/doc[@for="Group.Captures"]/*' />
/// <devdoc>
/// <para>
/// Returns a collection of all the captures matched by the capturing
/// group, in innermost-leftmost-first order (or innermost-rightmost-first order if
/// compiled with the "r" option). The collection may have zero or more items.
/// </para>
/// </devdoc>
public CaptureCollection Captures {
get {
if (_capcoll == null)
_capcoll = new CaptureCollection(this);
return _capcoll;
}
}
// Convert to a thread-safe object by precomputing cache contents
//| <include file='doc\RegexGroup.uex' path='docs/doc[@for="Group.Synchronized"]/*' />
/// <devdoc>
2008-11-17 18:29:00 -05:00
/// <para>Returns
2008-03-05 09:52:00 -05:00
/// a Group object equivalent to the one supplied that is safe to share between
/// multiple threads.</para>
/// </devdoc>
static public Group Synchronized(Group inner) {
if (inner == null)
throw new ArgumentNullException("inner");
// force Captures to be computed.
CaptureCollection capcoll;
Capture dummy;
capcoll = inner.Captures;
if (inner._capcount > 0)
dummy = capcoll[0];
return inner;
}
}
}