[kaffe] CVS kaffe-extras (guilhem): New patch to fix extra generated '<clinit>' methods. This method should
Kaffe CVS
Kaffe Mailing List <kaffe@kaffe.org>
Fri Dec 26 10:41:02 2003
PatchSet 24
Date: 2003/12/26 18:40:31
Author: guilhem
Branch: HEAD
Tag: (none)
Log:
New patch to fix extra generated '<clinit>' methods. This method should
not be generated if it is empty. But empty methods should be authorized ;-)
This is the least ugly method to do it I've found so far.
Members:
build.xml:1.13->1.14
patches/kjc-static-init.diff:INITIAL->1.1
Index: kaffe-extras/build.xml
diff -u kaffe-extras/build.xml:1.13 kaffe-extras/build.xml:1.14
--- kaffe-extras/build.xml:1.13 Tue Dec 23 14:57:47 2003
+++ kaffe-extras/build.xml Fri Dec 26 18:40:31 2003
@@ -260,6 +260,9 @@
<patch patchfile="${patches_dir}/kjc-parser-ClassnameDotThis.diff"
strip="1"
dir="${kjcsuite_dir}"/>
+ <patch patchfile="${patches_dir}/kjc-static-init.diff"
+ strip="1"
+ dir="${kjcsuite_dir}"/>
<touch file="${kjcsuite_unpacked_stamp}"/>
</target>
===================================================================
Checking out kaffe-extras/patches/kjc-static-init.diff
RCS: /home/cvs/kaffe/kaffe-extras/patches/kjc-static-init.diff,v
VERS: 1.1
***************
--- /dev/null Sun Aug 4 19:57:58 2002
+++ kaffe-extras/patches/kjc-static-init.diff Fri Dec 26 18:40:33 2003
@@ -0,0 +1,182 @@
+diff -ur -x 'KjcScanner.*' -x 'KjcParser.*' kjc-suite-2.1B.old/src/kjc/CClass.java kjc-suite-2.1B/src/kjc/CClass.java
+--- kjc-suite-2.1B.old/src/kjc/CClass.java 2002-07-15 20:53:32.000000000 +0200
++++ kjc-suite-2.1B/src/kjc/CClass.java 2003-12-26 18:30:55.000000000 +0100
+@@ -1177,6 +1177,18 @@
+ }
+
+ /**
++ * Remove a method. To use with care.
++ */
++ public void removeMethod(CSourceMethod method) {
++ CMethod[] tmp = new CMethod[methods.length-1];
++ for (int i = 0, j = 0; i < methods.length; i++) {
++ if (methods[i] != method)
++ tmp[j++] = methods[i];
++ }
++ methods = tmp;
++ }
++
++ /**
+ * Adds a inner class.
+ */
+ public void addInnerClass(CReferenceType innerClass) {
+diff -ur -x 'KjcScanner.*' -x 'KjcParser.*' kjc-suite-2.1B.old/src/kjc/CSourceClass.java kjc-suite-2.1B/src/kjc/CSourceClass.java
+--- kjc-suite-2.1B.old/src/kjc/CSourceClass.java 2003-12-26 19:02:55.000000000 +0100
++++ kjc-suite-2.1B/src/kjc/CSourceClass.java 2003-12-26 19:00:38.000000000 +0100
+@@ -503,12 +503,30 @@
+ throws ClassFileFormatException
+ {
+ CMethod[] source = getMethods();
+- MethodInfo[] result;
++ MethodInfo[] tmp_result, result;
++ int real_methods = 0;
+
+- result = new MethodInfo[source.length];
++ tmp_result = new MethodInfo[source.length];
+ for (int i = 0; i < source.length; i++) {
+- result[i] = ((CSourceMethod)source[i]).genMethodInfo(optimizer, factory);
++ try {
++ tmp_result[i] = ((CSourceMethod)source[i]).genMethodInfo(optimizer, factory);
++ real_methods++;
++ }
++ catch (EmptyMethodException e) {
++ removeMethod((CSourceMethod)source[i]);
++ }
+ }
++
++ if (real_methods != source.length) {
++ result = new MethodInfo[real_methods];
++ for (int i = 0, j = 0; i < source.length; i++) {
++ if (tmp_result[i] != null)
++ result[j++] = tmp_result[i];
++ }
++ }
++ else
++ result = tmp_result;
++
+ return result;
+ }
+
+diff -ur -x 'KjcScanner.*' -x 'KjcParser.*' kjc-suite-2.1B.old/src/kjc/CSourceMethod.java kjc-suite-2.1B/src/kjc/CSourceMethod.java
+--- kjc-suite-2.1B.old/src/kjc/CSourceMethod.java 2002-07-15 20:53:32.000000000 +0200
++++ kjc-suite-2.1B/src/kjc/CSourceMethod.java 2003-12-26 19:06:05.000000000 +0100
+@@ -180,7 +180,9 @@
+ *
+ * @param optimizer the bytecode optimizer to use
+ */
+- public MethodInfo genMethodInfo(BytecodeOptimizer optimizer, TypeFactory factory) throws ClassFileFormatException {
++ public MethodInfo genMethodInfo(BytecodeOptimizer optimizer, TypeFactory factory)
++ throws ClassFileFormatException, EmptyMethodException {
++
+ CReferenceType[] excs = getThrowables();
+ String[] exceptions = new String[excs.length];
+
+@@ -188,12 +190,20 @@
+ exceptions[i] = excs[i].getQualifiedName();
+ }
+
++ CodeInfo code = null;
++ if (body != null) {
++ code = genCode(factory);
++
++ if (code == null)
++ throw new EmptyMethodException();
++ }
++
+ MethodInfo methodInfo = new MethodInfo((short)getModifiers(),
+ getIdent(),
+ getSignature(),
+ getGenericSignature(),
+ exceptions,
+- body != null ? genCode(factory): null,
++ code,
+ isDeprecated(),
+ isSynthetic());
+ methodInfo = optimizer.run(methodInfo);
+@@ -301,6 +311,9 @@
+ GenerationContext context = new GenerationContext(factory, code);
+
+ body.genCode(context);
++ if (code.size() == 0 && getIdent().equals(JAV_STATIC_INIT))
++ return null;
++
+ if (getReturnType().getTypeID() == TID_VOID) {
+ code.plantNoArgInstruction(opc_return);
+ }
+@@ -324,6 +337,8 @@
+
+ // generate byte code
+ info = genByteCode(factory);
++ if (info == null)
++ return null;
+
+ // set necessary additional information
+ for (int i = 0; i < parameters.length; i++) {
+diff -ur -x 'KjcScanner.*' -x 'KjcParser.*' kjc-suite-2.1B.old/src/kjc/JClassDeclaration.java kjc-suite-2.1B/src/kjc/JClassDeclaration.java
+--- kjc-suite-2.1B.old/src/kjc/JClassDeclaration.java 2002-07-15 20:53:32.000000000 +0200
++++ kjc-suite-2.1B/src/kjc/JClassDeclaration.java 2003-12-26 19:09:38.000000000 +0100
+@@ -674,7 +675,8 @@
+ * Collects all initializers and builds a single method.
+ * @param isStatic class or instance initializers ?
+ */
+- private JInitializerDeclaration constructInitializers(boolean isStatic, boolean always, TypeFactory factory) {
++ private JInitializerDeclaration constructInitializers(boolean isStatic,
++ boolean always, TypeFactory factory) throws PositionedError {
+ ArrayList elems = new ArrayList();
+ boolean needGen = false;
+
+@@ -684,10 +686,13 @@
+ elems.add(body[i]);
+ needGen = true;
+ } else {
+- if ((body[i] instanceof JFieldDeclaration)
+- && (((JFieldDeclaration)body[i]).getVariable().isStatic() == isStatic)) {
+- needGen |= ((JFieldDeclaration)body[i]).needInitialization();
+- elems.add(new JClassFieldDeclarator(getTokenReference(), (JFieldDeclaration)body[i]));
++ if (body[i] instanceof JFieldDeclaration) {
++ JFieldDeclaration fd = (JFieldDeclaration)body[i];
++
++ if (fd.getVariable().isStatic() == isStatic) {
++ needGen |= fd.needInitialization();
++ elems.add(new JClassFieldDeclarator(getTokenReference(), fd));
++ }
+ }
+ }
+ }
+diff -ur -x 'KjcScanner.*' -x 'KjcParser.*' kjc-suite-2.1B.old/src/kjc/Makefile kjc-suite-2.1B/src/kjc/Makefile
+--- kjc-suite-2.1B.old/src/kjc/Makefile 2002-07-15 20:53:32.000000000 +0200
++++ kjc-suite-2.1B/src/kjc/Makefile 2003-12-26 18:29:13.000000000 +0100
+@@ -33,7 +33,7 @@
+ SCANNER1 = Kjc
+
+ # Compiler classes
+-JAVAFILES += BytecodeOptimizer \
++JAVAFILES += BytecodeOptimizer EmptyMethodException \
+ CArrayType CBadClass \
+ CBinaryClass CBinaryField CBinaryMethod CBlockContext \
+ CBlockError CBodyContext CBooleanType \
+--- /dev/null 1970-01-01 01:00:00.000000000 +0100
++++ kjc-suite-2.1B/src/kjc/EmptyMethodException.java 2003-12-26 18:01:15.000000000 +0100
+@@ -0,0 +1,22 @@
++/*
++ * Copyright (C) 2003 Kaffe.org's developers
++ *
++ * This program is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * This program is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with this program; if not, write to the Free Software
++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
++ */
++package at.dms.kjc;
++
++public class EmptyMethodException extends Exception
++{
++}