From Fedora Project Wiki

(Initial page creation)
 
No edit summary
Line 1: Line 1:
= This page lists packages that need to be fixed and rebuilt with java-1.7.0-openjdk for F17 =
== How to edit the table below ==
# When you are ready to taken on a package, edit the table below to add your name in the "Taken by" column
# If you want, you can update the status and the color, but please don't set it to green until it is all done and built in Koji. That way a cursory glance would catch anything that needs work.
# Once the new package is built in koji, update the status accordingly and change the color to green.
== Packages that need to be fixed (see below for issue description) ==
{| border="1"
{| border="1"
| Package || Issue || Taken by || status
| Package || Issue || Taken by || Status
|-
|-
| apache-commons-validator-1.3.1-5.fc16 || Invalid ASCII chars || || style="font-style:italic; color:red;" | New package not built
| apache-commons-validator-1.3.1-5.fc16 || Invalid ASCII chars || || style="font-style:italic; color:red;" | New package not built
Line 63: Line 72:
|-
|-
| plexus-containers-1.5.5-3.fc16 || Needs tools.jar in build/runtime classpath || || style="font-style:italic; color:red;" | New package not built
| plexus-containers-1.5.5-3.fc16 || Needs tools.jar in build/runtime classpath || || style="font-style:italic; color:red;" | New package not built
|}
== Issues ==
I have tried my best to categorize packages by issue. If there are any mistakes, feel free to update accordingly.
{| border="1"
| Issue || Explanation || How to fix
|-
| Invalid ASCII chars
| Prior to Java 7, unmappable characters in the source were treated as warnings. Java treats them as errors.
| To fix it, simply build, look at the error locations and patch to replace the unmappable characters with appropriate characters.
|-
| Incompatible with new JDBC
| Java 7 contains a newer version of JDBC. Some of the abstract classes/interfaces in the new version specify new methods.
| Because the newer API needs additional methods, fixing just involves patching to add those methods (either as stubs, or proper implementations) to the classes. Most (if not all) new methods look like they would just be one-liners.
|-
| com.sun.image.codec
| Java 7 has completely removed support for com.sun.image.codec.* classes (deprecated since Java 1.4).
| These are probably the most complex of all issues to fix. The first thing is to check if upstream has fixed it and then just backport that fix. If not fixed upstream, patch to use ImageIO instead, as specified [http://docs.oracle.com/javase/tutorial/2d/images/index.html here].
|-
| -source/-target mismatch
| The -source argument to javac specifies a newer version than the -target argument.
| Patch to use the same -source and -target. Only bouncycastle seems to be affected, and for it, -source 1.5 -target 1.5 would be best.
|-
| Same type erasure
| This is a bug in the original code itself. The Java 6 compiler incorrectly accepted bad input. Java 7 does not. The issue is that the code is specifying multiple methods with the same name and one takes an argument type that is the parent type of what the other takes. See [http://lists.fedoraproject.org/pipermail/devel/2011-December/160132.html this] for more explanation.
| The code needs to be matched to change method names for methods that have the same type erasure. If the method is part of a public api, we need to contact upstream to get it fixed correctly.
|-
| Needs tools.jar in build/runtime classpath
| Java 6 and lower used to provide tools.jar on the classpath by default. Java 7 no longer does it, and as a result, error related to missing classes (that exist in tools.jar) are seen.
| The package should be patched to supply tools.jar when building, and to ensure that tools.jar is on run-time classpath if it is needed during runtime as well.
|}
|}

Revision as of 21:53, 10 January 2012

This page lists packages that need to be fixed and rebuilt with java-1.7.0-openjdk for F17

How to edit the table below

  1. When you are ready to taken on a package, edit the table below to add your name in the "Taken by" column
  2. If you want, you can update the status and the color, but please don't set it to green until it is all done and built in Koji. That way a cursory glance would catch anything that needs work.
  3. Once the new package is built in koji, update the status accordingly and change the color to green.


Packages that need to be fixed (see below for issue description)

Package Issue Taken by Status
apache-commons-validator-1.3.1-5.fc16 Invalid ASCII chars New package not built
bcel-5.2-9.fc15 Invalid ASCII chars New package not built
cortado-0.6.0-3.fc15 Invalid ASCII chars New package not built
hibernate-jpa-2.0-api-1.0.1-2.fc17 Invalid ASCII chars New package not built
jBCrypt-0.3-4.fc15 Invalid ASCII chars New package not built
maven-changelog-plugin-2.2-7.fc16 Invalid ASCII chars New package not built
maven-jflex-plugin-1.4.3-5.fc16 Invalid ASCII chars New package not built
metadata-extractor-2.3.1-6.fc15 Invalid ASCII chars New package not built
MiniCopier-0.5-2.fc15 Invalid ASCII chars New package not built
slf4j-1.6.1-3.fc16 Invalid ASCII chars New package not built
xjavadoc-1.1-10.fc15 Invalid ASCII chars New package not built
avalon-logkit-2.1-6.fc17 Incompatible with new JDBC New package not built
btm-2.1.1-3.fc16 Incompatible with new JDBC New package not built
c3p0-0.9.2-0.5.pre1.fc15 Incompatible with new JDBC New package not built
h2-1.2.147-3.fc16 Incompatible with new JDBC New package not built
hsqldb-1.8.1.3-3.fc15 Incompatible with new JDBC New package not built
jakarta-taglibs-standard-1.1.2-1.fc16 Incompatible with new JDBC New package not built
mchange-commons-0.2-0.3.20110130hg.fc15 Incompatible with new JDBC New package not built
mysql-connector-java-5.1.17-1.fc17 Incompatible with new JDBC New package not built
tomcat-7.0.23-1.fc17 Incompatible with new JDBC New package not built
velocity-1.7-1.fc16 Incompatible with new JDBC New package not built
batik-1.7-12.fc16 Uses com.sun.image.codec New package not built
jcharts-0.7.5-5.fc15 Uses com.sun.image.codec New package not built
jrefactory-2.9.19-3.fc15 Uses com.sun.image.codec New package not built
xmlgraphics-commons-1.4-3 Uses com.sun.image.codec New package not built
bouncycastle-1.46-1.fc16 -source/-target mismatch New package not built
bouncycastle-mail-1.46-1.fc16 -source/-target mismatch New package not built
bouncycastle-tsp-1.46-1.fc16 -source/-target mismatch New package not built
easymock2-2.5.2-4.fc15 Same type erasure New package not built
jide-oss-2.7.6-4.1340svn.fc15 Same type erasure New package not built
plexus-containers-1.5.5-3.fc16 Needs tools.jar in build/runtime classpath New package not built


Issues

I have tried my best to categorize packages by issue. If there are any mistakes, feel free to update accordingly.

Issue Explanation How to fix
Invalid ASCII chars Prior to Java 7, unmappable characters in the source were treated as warnings. Java treats them as errors. To fix it, simply build, look at the error locations and patch to replace the unmappable characters with appropriate characters.
Incompatible with new JDBC Java 7 contains a newer version of JDBC. Some of the abstract classes/interfaces in the new version specify new methods. Because the newer API needs additional methods, fixing just involves patching to add those methods (either as stubs, or proper implementations) to the classes. Most (if not all) new methods look like they would just be one-liners.
com.sun.image.codec Java 7 has completely removed support for com.sun.image.codec.* classes (deprecated since Java 1.4). These are probably the most complex of all issues to fix. The first thing is to check if upstream has fixed it and then just backport that fix. If not fixed upstream, patch to use ImageIO instead, as specified here.
-source/-target mismatch The -source argument to javac specifies a newer version than the -target argument. Patch to use the same -source and -target. Only bouncycastle seems to be affected, and for it, -source 1.5 -target 1.5 would be best.
Same type erasure This is a bug in the original code itself. The Java 6 compiler incorrectly accepted bad input. Java 7 does not. The issue is that the code is specifying multiple methods with the same name and one takes an argument type that is the parent type of what the other takes. See this for more explanation. The code needs to be matched to change method names for methods that have the same type erasure. If the method is part of a public api, we need to contact upstream to get it fixed correctly.
Needs tools.jar in build/runtime classpath Java 6 and lower used to provide tools.jar on the classpath by default. Java 7 no longer does it, and as a result, error related to missing classes (that exist in tools.jar) are seen. The package should be patched to supply tools.jar when building, and to ensure that tools.jar is on run-time classpath if it is needed during runtime as well.