KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > soot > jimple > toolkits > pointer > nativemethods > JavaLangReflectConstructorNative


1 /* Soot - a J*va Optimization Framework
2  * Copyright (C) 2003 Feng Qian
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with this library; if not, write to the
16  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17  * Boston, MA 02111-1307, USA.
18  */

19
20 /**
21  * Simulates the native method side effects in class java.lang.reflect.Constructor
22  *
23  * @author Feng Qian
24  * @author <XXX>
25  */

26
27 package soot.jimple.toolkits.pointer.nativemethods;
28
29 import soot.*;
30 import soot.jimple.toolkits.pointer.representations.*;
31 import soot.jimple.toolkits.pointer.util.*;
32
33 public class JavaLangReflectConstructorNative extends NativeMethodClass {
34     public JavaLangReflectConstructorNative( NativeHelper helper ) { super(helper); }
35
36   /**
37    * Implements the abstract method simulateMethod.
38    * It distributes the request to the corresponding methods
39    * by signatures.
40    */

41   public void simulateMethod(SootMethod method,
42                  ReferenceVariable thisVar,
43                  ReferenceVariable returnVar,
44                  ReferenceVariable params[]){
45
46     String JavaDoc subSignature = method.getSubSignature();
47
48     if (subSignature.equals("java.lang.Object newInstance(java.lang.Object[])")){
49       java_lang_reflect_Constructor_newInstance(method, thisVar, returnVar, params);
50       return;
51
52     } else {
53       defaultMethod(method, thisVar, returnVar, params);
54       return;
55
56     }
57   }
58
59   /********************** java.lang.reflect.Constructor ****************/
60   /**
61    * Uses the constructor represented by this Constructor object to
62    * create and initialize a new instance of the constructor's
63    * declaring class, with the specified initialization
64    * parameters. Individual parameters are automatically unwrapped to
65    * match primitive formal parameters, and both primitive and
66    * reference parameters are subject to method invocation conversions
67    * as necessary. Returns the newly created and initialized object.
68    *
69    * NOTE: @return = new Object; but we lose type information.
70    *
71    * public native java.lang.Object newInstance(java.lang.Object[])
72    * throws java.lang.InstantiationException,
73    * java.lang.IllegalAccessException,
74    * java.lang.IllegalArgumentException,
75    * java.lang.reflect.InvocationTargetException;
76    */

77   public
78     void java_lang_reflect_Constructor_newInstance(SootMethod method,
79                            ReferenceVariable thisVar,
80                            ReferenceVariable returnVar,
81                            ReferenceVariable params[]){
82     throw new NativeMethodNotSupportedException(method);
83   }
84 }
85
Popular Tags