Fixing the ClassLoader.defineClass() method issue that could not find the necessary...
[jpf-core.git] / src / peers / gov / nasa / jpf / vm / JPF_java_util_logging_Level.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.vm;
20
21 import gov.nasa.jpf.annotation.MJI;
22 import gov.nasa.jpf.vm.MJIEnv;
23 import gov.nasa.jpf.vm.NativePeer;
24
25 import java.util.logging.Level;
26
27 /**
28  * this is only a skeleton to make basic logging work under JPF
29  */
30 public class JPF_java_util_logging_Level extends NativePeer {
31   @MJI
32   public int getLocalizedName____Ljava_lang_String_2 (MJIEnv env, int objRef){
33     Level level = null;    
34     int val = env.getIntField(objRef, "value");
35     
36     switch (val){
37     case Integer.MIN_VALUE : 
38       level = Level.ALL; break; 
39     case 300 :
40       level = Level.FINEST; break;
41     case 400 :
42       level = Level.FINER; break;
43     case 500 :
44       level = Level.FINE; break;
45     case 700 :
46       level = Level.CONFIG; break;
47     case 800 :
48       level = Level.INFO; break;
49     case 900 :
50       level = Level.WARNING; break;
51     case 1000 :
52       level = Level.SEVERE; break;
53     case Integer.MAX_VALUE :
54       level = Level.OFF; break;      
55     }
56     
57     String localizedName = (level != null) ? level.getLocalizedName() : "UNKNOWN";    
58     return env.newString(localizedName); 
59   }
60 }