Copyright test
[jalview.git] / src / com / stevesoft / pat / Skipped.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
32 /**
33  * Implements the (?&lt;number) Pattern, where number is an integer telling us
34  * how far to back up in the Pattern. Not in perl 5.
35  */
36 class Skipped extends Pattern
37 {
38   String s;
39
40   Skipped(String s)
41   {
42     this.s = s;
43   }
44
45   public String toString()
46   {
47     return s + nextString();
48   }
49
50   public int matchInternal(int pos, Pthings pt)
51   {
52     // if(pt.no_check || s.regionMatches(pt.ignoreCase,0,pt.src,pos,s.length()))
53     if (pt.no_check
54             || CaseMgr.regionMatches(s, pt.ignoreCase, 0, pt.src, pos,
55                     s.length()))
56     {
57       return nextMatch(pos + s.length(), pt);
58     }
59     return -1;
60   }
61
62   public patInt minChars()
63   {
64     return new patInt(s.length());
65   }
66
67   public patInt maxChars()
68   {
69     return new patInt(s.length());
70   }
71
72   Pattern clone1(Hashtable h)
73   {
74     return new Skipped(s);
75   }
76 };