// author: Dan Lewis (dlewis@gmx.co.uk)
// (c) 2002
+//
+// Permission is hereby granted, free of charge, to any person obtaining
+// a copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to
+// permit persons to whom the Software is furnished to do so, subject to
+// the following conditions:
+//
+// The above copyright notice and this permission notice shall be
+// included in all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+//
+
using System;
using System.Collections;
public override void Compile (ICompiler cmp, bool reverse) {
// can't invoke Group.Compile from here :(
// so I'll just repeat the code
-
+
+ LinkRef tail = cmp.NewLink ();
+
+ cmp.EmitBalanceStart (this.Number, balance.Number, this.IsNamed, tail);
+
int count = Expressions.Count;
for (int i = 0; i < count; ++ i) {
Expression e;
e.Compile (cmp, reverse);
}
- cmp.EmitBalance (this.Number, balance.Number);
+ cmp.EmitBalance ();
+ cmp.ResolveLink(tail);
}
private CapturingGroup balance;
// initialize pos/neg category arrays
- Array cat_values = Enum.GetValues (typeof (Category));
- int cat_size = (int)(Category)cat_values.GetValue (cat_values.Length - 1) + 1;
- pos_cats = new bool[cat_size];
- neg_cats = new bool[cat_size];
- for (int i = 0; i < cat_size; ++ i) {
- pos_cats[i] = false;
- neg_cats[i] = false;
- }
+ int cat_size = (int) Category.LastValue;
+ pos_cats = new BitArray (cat_size);
+ neg_cats = new BitArray (cat_size);
}
public CharacterClass (Category cat, bool negate) : this (false, false) {
int n = (int)cat;
if (negate) {
- if (pos_cats[n])
- pos_cats[n] = false;
-
neg_cats[n] = true;
- }
- else {
- if (neg_cats[n])
- neg_cats[n] = false;
-
+ } else {
pos_cats[n] = true;
}
}
// emit categories
for (int i = 0; i < pos_cats.Length; ++ i) {
- if (pos_cats[i])
- cmp.EmitCategory ((Category)i, negate, reverse);
- else if (neg_cats[i])
+ if (pos_cats[i]) {
+ if (neg_cats [i])
+ cmp.EmitCategory (Category.AnySingleline, negate, reverse);
+ else
+ cmp.EmitCategory ((Category)i, negate, reverse);
+ } else if (neg_cats[i]) {
cmp.EmitCategory ((Category)i, !negate, reverse);
+ }
}
// emit character/range/sets from meta-collection
private static Interval upper_case_characters = new Interval ((char)65, (char)90);
private const int distance_between_upper_and_lower_case = 32;
private bool negate, ignore;
- private bool[] pos_cats, neg_cats;
+ private BitArray pos_cats, neg_cats;
private IntervalCollection intervals;
}