Fixes null captured parameters
[jpf-core.git] / src / main / gov / nasa / jpf / vm / ClinitRequired.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 package gov.nasa.jpf.vm;
19
20 /**
21  * this one is kind of a hack for situations where we detect deep from
22  * the stack that we need a clinit to be executed, but we can't flag this
23  * to the currently executed insn via a return value. referencing annotation
24  * elements that are enums is a good (bad) example
25  */
26 public class ClinitRequired extends RuntimeException {
27   ClassInfo ci;
28   
29   public ClinitRequired (ClassInfo ci){
30     this.ci = ci;
31   }
32   
33   ClassInfo getRequiredClassInfo() {
34     return ci;
35   }
36   
37   @Override
38   public String getMessage(){
39     return ci.getName();
40   }
41 }