Adding graph traversal to find cycles; adding debug mode for ConflictTracker.
[jpf-core.git] / src / main / gov / nasa / jpf / util / TypeSpecMatcher.java
1 /*
2  * Copyright (C) 2014, United States Government, as represented by the
3  * Administrator of the National Aeronautics and Space Administration.
4  * All rights reserved.
5  *
6  * The Java Pathfinder core (jpf-core) platform is licensed under the
7  * Apache License, Version 2.0 (the "License"); you may not use this file except
8  * in compliance with the License. You may obtain a copy of the License at
9  * 
10  *        http://www.apache.org/licenses/LICENSE-2.0. 
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and 
16  * limitations under the License.
17  */
18
19 package gov.nasa.jpf.util;
20
21 import gov.nasa.jpf.vm.ClassInfo;
22
23 /**
24  * a matcher for collections of TypeSpecs
25  */
26 public class TypeSpecMatcher {
27
28   protected TypeSpec[] mypeSpecs;
29   
30   public static TypeSpecMatcher create (String[] specs){
31     if (specs != null && specs.length > 0){
32       return new TypeSpecMatcher(specs);
33     } else {
34       return null;
35     }
36   }
37   
38   public TypeSpecMatcher(String[] specs){
39     int len = specs.length;
40     mypeSpecs = new TypeSpec[len];
41     for (int i=0; i<len; i++){
42       mypeSpecs[i] = TypeSpec.createTypeSpec(specs[i]);
43     }
44   }
45   
46   public boolean matches (Class<?> cls){
47     for (int i=0; i<mypeSpecs.length; i++){
48       if (mypeSpecs[i].matches(cls)){
49         return true;
50       }
51     }
52     
53     return false;
54   }
55   
56   
57   public boolean matches (ClassInfo ci){
58     for (int i=0; i<mypeSpecs.length; i++){
59       if (mypeSpecs[i].matches(ci)){
60         return true;
61       }
62     }
63     
64     return false;
65   }
66 }