3 // namespace: System.Text.RegularExpressions
\r
6 // author: Dan Lewis (dlewis@gmx.co.uk)
\r
10 // Permission is hereby granted, free of charge, to any person obtaining
11 // a copy of this software and associated documentation files (the
12 // "Software"), to deal in the Software without restriction, including
13 // without limitation the rights to use, copy, modify, merge, publish,
14 // distribute, sublicense, and/or sell copies of the Software, and to
15 // permit persons to whom the Software is furnished to do so, subject to
16 // the following conditions:
18 // The above copyright notice and this permission notice shall be
19 // included in all copies or substantial portions of the Software.
21 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
22 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
23 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
24 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
25 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
27 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
31 using System.Collections;
\r
33 namespace System.Text.RegularExpressions {
\r
35 class FactoryCache {
\r
36 public FactoryCache (int capacity) {
\r
37 this.capacity = capacity;
\r
38 this.factories = new Hashtable (capacity);
\r
39 this.mru_list = new MRUList ();
\r
42 public void Add (string pattern, RegexOptions options, IMachineFactory factory) {
\r
44 Key k = new Key (pattern, options);
\r
46 while (factories.Count >= capacity) {
\r
47 object victim = mru_list.Evict ();
\r
49 factories.Remove ((Key)victim);
\r
52 factories[k] = factory;
\r
57 public IMachineFactory Lookup (string pattern, RegexOptions options) {
\r
59 Key k = new Key (pattern, options);
\r
60 if (factories.Contains (k)) {
\r
62 return (IMachineFactory)factories[k];
\r
69 private int capacity;
\r
70 private Hashtable factories;
\r
71 private MRUList mru_list;
\r
74 public string pattern;
\r
75 public RegexOptions options;
\r
77 public Key (string pattern, RegexOptions options) {
\r
78 this.pattern = pattern;
\r
79 this.options = options;
\r
82 public override int GetHashCode () {
\r
83 return pattern.GetHashCode () ^ (int)options;
\r
86 public override bool Equals (object o) {
\r
87 if (o == null || !(o is Key))
\r
91 return options == k.options && pattern.Equals (k.pattern);
\r
94 public override string ToString () {
\r
95 return "('" + pattern + "', [" + options + "])";
\r
101 public MRUList () {
\r
102 head = tail = null;
\r
105 public void Use (object o) {
\r
108 if (head == null) {
\r
109 node = new Node (o);
\r
110 head = tail = node;
\r
115 while (node != null && !o.Equals (node.value))
\r
116 node = node.previous;
\r
119 node = new Node (o);
\r
127 node.previous.next = node.next;
\r
129 node.next.previous = node.previous;
\r
133 node.previous = head;
\r
138 public object Evict () {
\r
142 object o = tail.value;
\r
148 tail.previous = null;
\r
153 private Node head, tail;
\r
155 private class Node {
\r
156 public object value;
\r
157 public Node previous, next;
\r
159 public Node (object value) {
\r
160 this.value = value;
\r