Copyright test
[jalview.git] / src / com / stevesoft / pat / Bracket.java
1 /*******************************************************************************
2  * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
3  * Copyright (C) $(date) The Jalview Authors
4  *
5  * This file is part of Jalview.
6  *  
7  * Jalview is free software: you can redistribute it and/or
8  * modify it under the terms of the GNU General Public License 
9  * as published by the Free Software Foundation, either version 3
10  * of the License, or (at your option) any later version.
11  *   
12  * Jalview is distributed in the hope that it will be useful, but 
13  * WITHOUT ANY WARRANTY; without even the implied warranty 
14  * of MERCHANTABILITY or FITNESS FOR A PARTICULAR 
15  * PURPOSE.  See the GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with Jalview.  If not, see <http://www.gnu.org/licenses/>.
19  * The Jalview Authors are detailed in the 'AUTHORS' file.
20  *******************************************************************************/
21 //
22 // This software is now distributed according to
23 // the Lesser Gnu Public License.  Please see
24 // http://www.gnu.org/copyleft/lesser.txt for
25 // the details.
26 //    -- Happy Computing!
27 //
28 package com.stevesoft.pat;
29
30 import java.util.Hashtable;
31 import java.util.Vector;
32
33 /**
34  * The Bracket is a form of the Or class, implements the pattern element [ ].
35  */
36 class Bracket extends Or
37 {
38   boolean neg;
39
40   Bracket(boolean n)
41   {
42     neg = n;
43   }
44
45   String leftForm()
46   {
47     if (neg)
48     {
49       return "[^";
50     }
51     else
52     {
53       return "[";
54     }
55   }
56
57   String rightForm()
58   {
59     return "]";
60   }
61
62   String sepForm()
63   {
64     return "";
65   }
66
67   public int matchInternal(int pos, Pthings pt)
68   {
69     if (pos >= pt.src.length())
70     {
71       return -1;
72     }
73     int r = super.matchInternal(pos, pt);
74     if ((neg && r < 0) || (!neg && r >= 0))
75     {
76       return nextMatch(pos + 1, pt);
77     }
78     return -1;
79   }
80
81   public patInt minChars()
82   {
83     return new patInt(1);
84   }
85
86   public patInt maxChars()
87   {
88     return new patInt(1);
89   }
90
91   public Or addOr(Pattern p)
92   {
93     pv = null;
94     v.addElement(p);
95     p.setParent(null);
96     return this;
97   }
98
99   public Pattern clone1(Hashtable h)
100   {
101     Bracket b = new Bracket(neg);
102     b.v = new Vector();
103     for (int i = 0; i < v.size(); i++)
104     {
105       b.v.addElement(((Pattern) v.elementAt(i)).clone1(h));
106     }
107     return b;
108   }
109 };