KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > javacc > parser > RRepetitionRange


1 /*
2  * Copyright © 2002 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
3  * California 95054, U.S.A. All rights reserved. Sun Microsystems, Inc. has
4  * intellectual property rights relating to technology embodied in the product
5  * that is described in this document. In particular, and without limitation,
6  * these intellectual property rights may include one or more of the U.S.
7  * patents listed at http://www.sun.com/patents and one or more additional
8  * patents or pending patent applications in the U.S. and in other countries.
9  * U.S. Government Rights - Commercial software. Government users are subject
10  * to the Sun Microsystems, Inc. standard license agreement and applicable
11  * provisions of the FAR and its supplements. Use is subject to license terms.
12  * Sun, Sun Microsystems, the Sun logo and Java are trademarks or registered
13  * trademarks of Sun Microsystems, Inc. in the U.S. and other countries. This
14  * product is covered and controlled by U.S. Export Control laws and may be
15  * subject to the export or import laws in other countries. Nuclear, missile,
16  * chemical biological weapons or nuclear maritime end uses or end users,
17  * whether direct or indirect, are strictly prohibited. Export or reexport
18  * to countries subject to U.S. embargo or to entities identified on U.S.
19  * export exclusion lists, including, but not limited to, the denied persons
20  * and specially designated nationals lists is strictly prohibited.
21  */

22
23 package org.javacc.parser;
24
25 import java.util.Vector JavaDoc;
26
27 /**
28  * Describes one-or-more regular expressions (<foo+>).
29  */

30
31 public class RRepetitionRange extends RegularExpression {
32
33   /**
34    * The regular expression which is repeated one or more times.
35    */

36   public RegularExpression regexpr;
37   public int min = 0;
38   public int max = -1;
39   public boolean hasMax;
40
41   public Nfa GenerateNfa(boolean ignoreCase)
42   {
43      Vector JavaDoc units = new Vector JavaDoc();
44      RSequence seq;
45      int i;
46
47      for (i = 0; i < min; i++)
48      {
49         units.addElement(regexpr);
50      }
51
52      if (hasMax && max == -1) // Unlimited
53
{
54         RZeroOrMore zoo = new RZeroOrMore();
55         zoo.regexpr = regexpr;
56         units.addElement(zoo);
57      }
58
59      while (i++ < max)
60      {
61         RZeroOrOne zoo = new RZeroOrOne();
62         zoo.regexpr = regexpr;
63         units.addElement(zoo);
64      }
65      seq = new RSequence(units);
66      return seq.GenerateNfa(ignoreCase);
67   }
68 }
69
Popular Tags