aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/javassist/CtNewClass.java
blob: 09bf345d77cf5da89436655970aae46a73d797a4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/*
 * This file is part of the Javassist toolkit.
 *
 * The contents of this file are subject to the Mozilla Public License
 * Version 1.1 (the "License"); you may not use this file except in
 * compliance with the License.  You may obtain a copy of the License at
 * either http://www.mozilla.org/MPL/.
 *
 * Software distributed under the License is distributed on an "AS IS"
 * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied.  See
 * the License for the specific language governing rights and limitations
 * under the License.
 *
 * The Original Code is Javassist.
 *
 * The Initial Developer of the Original Code is Shigeru Chiba.  Portions
 * created by Shigeru Chiba are Copyright (C) 1999-2003 Shigeru Chiba.
 * All Rights Reserved.
 *
 * Contributor(s):
 *
 * The development of this software is supported in part by the PRESTO
 * program (Sakigake Kenkyu 21) of Japan Science and Technology Corporation.
 */

package javassist;

import java.io.DataOutputStream;
import java.io.IOException;
import javassist.bytecode.ClassFile;

class CtNewClass extends CtClassType {
    /* true if the class is an interface.
     */
    protected boolean hasConstructor;

    CtNewClass(String name, ClassPool cp,
	       boolean isInterface, CtClass superclass) {
	super(name, cp);
	wasChanged = true;
	eraseCache();
	String superName;
	if (superclass == null)
	    superName = null;
	else
	    superName = superclass.getName();

	classfile = new ClassFile(isInterface, name, superName);

	setModifiers(Modifier.setPublic(getModifiers()));
	hasConstructor = isInterface;
    }

    public void addConstructor(CtConstructor c)
	throws CannotCompileException
    {
	hasConstructor = true;
	super.addConstructor(c);
    }

    void toBytecode(DataOutputStream out)
	throws CannotCompileException, IOException
    {
	if (!hasConstructor)
	    try {
		inheritAllConstructors();
	    }
	    catch (NotFoundException e) {
		throw new CannotCompileException(e);
	    }

	super.toBytecode(out);
    }

    /**
     * Adds constructors inhrited from the super class.
     *
     * <p>After this method is called, the class inherits all the
     * constructors from the super class.  The added constructor
     * calls the super's constructor with the same signature.
     */
    public void inheritAllConstructors()
	throws CannotCompileException, NotFoundException
    {
	CtClass superclazz;
	CtConstructor[] cs;

	superclazz = getSuperclass();
	cs = superclazz.getDeclaredConstructors();

	int n = 0;
	for (int i = 0; i < cs.length; ++i) {
	    CtConstructor c = cs[i];
	    if (Modifier.isPublic(c.getModifiers())) {
		CtConstructor cons
		    = CtNewConstructor.make(c.getParameterTypes(),
					    c.getExceptionTypes(), this);
		addConstructor(cons);
		++n;
	    }
	}

	if (n < 1)
	    throw new CannotCompileException(
			"no public constructor in " + superclazz.getName());

    }
}