[kaffe] kaffe/jikes makes incompatible code for jdk1.3? (was: [Detelin Batchovski] Bug#262897: libservlet2.3-java_4.0-4: Failed start Tomcat4 after upgrade)

Dalibor Topic robilad at kaffe.org
Thu Aug 5 02:05:47 PDT 2004


Arnaud Vandyck wrote:
> Hi everybody,
> 
> I built javax.servlet with kaffe/jikes/ant1.6, but when running with
> jre1.3, it seems there is a problem... log is attached.
> 
> Thanks to help.
> 
> Debian:
> 
>   If the problem could not be solved soon, it means we'll have to build
>   servlet with non-free JDK again!
> 
>   It means libservlet2.3-java back to contrib!
> 
> I'll wait two or three days before uploading a servlet compiled with
> non-free jdk back to contrib, hoping kaffe guys can resolve this (but I
> assume it's not trivial!).
> 
> Comments?

Salut Arnaud,

Sorry for not being able to respond sooner.

The problem is in the class versions. Depending on which version of 
jikes you use, it generates class files for different target vms by 
default. More recent versions of jikes target more recent versions of 
JDK. The same thing could happen if you had used JDK 1.4 to build the 
classes.

Since Sun changed[1] the byte code format with every major JDK relese 
(and ocassionally in-between releases), you need to tell Jikes 
explicitely which is the lowest JDK version you want to target. If you 
are using ant, you can do that by setting the target attribute of the 
javac task to the runtime version you ant to target.

Caveat: If the code uses APIs or language features from a different 
version of Java and JDK, then compiling to an earlier byte code format 
would not solve the problem. But if libservlet is supposed to work with 
JDK 1.3, then changing the build.xml file to target 1.3 by default and 
filing a bug upstream should be a quick solution.

cheers,
dalibor topic

[1] And didn't document the changes, of course. :)




More information about the kaffe mailing list