RFC: Only enable NIO2 by default when building with IcedTea
Andrew John Hughes
gnu_andrew at member.fsf.org
Tue Feb 10 11:50:35 PST 2009
2009/2/10 Mark Wielaard <mark at klomp.org>:
> Hi Andrew,
>
> On Tue, 2009-02-10 at 19:07 +0000, Andrew John Hughes wrote:
>> It appears that some older versions of ecj fail when building the
>> NIO2 code:
>>
>> 1. ERROR in ../../../src/share/classes/org/classpath/icedtea/java/nio/file/spi/AbstractPath.java (at line 276)
>> public final WatchKey register(WatchService watcher, WatchEvent.Kind<?>... events)
>> throws IOException
>> ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
>> Name clash: The method register(WatchService, WatchEvent.Kind<?>...) of type AbstractPath has the same erasure as register(WatchService, WatchEvent.Kind<?>...) of type Watchable but does not override it
>> ----------
>
> I can confirm this bug against Eclipse Java Compiler 0.793_R33x, 3.3.2.
>
>> The attached patch sets the NIO2 default based on whether with_icedtea is enabled. So this works,
>> and to be consistent with the rest of the autotools macro, it switches the values used from true/false
>> to yes/no.
>>
>> Okay to commit?
>>
>> ChangeLog:
>>
>> 2009-02-10 Andrew John Hughes <ahughes at redhat.com>
>>
>> * Makefile.am:
>> Only build NIO2 by default if building with
>> IcedTea. Fix with_icedtea/with_openjdk to use
>> yes/no rather than true/false.
>
> The attached patch is for configure.ac, not for Makefile.am.
> I am slightly confused by why this works.
> Are you counting on the fact that if --with-icedtea is given the
> provided javac will not be based on ecj and so not have the bug?
--with-icedtea uses ICEDTEA_HOME/bin/javac so yeah but...
> Wouldn't it be more correct to disable nio2 by default and/or add a
> compiler configure check to see if these kind of constructs can be
> compiled?
...I'd prefer this. But given I can't duplicate this myself, someone
else needs to write the test... ;)
>
> Cheers,
>
> Mark
>
>
--
Andrew :-)
Free Java Software Engineer
Red Hat, Inc. (http://www.redhat.com)
Support Free Java!
Contribute to GNU Classpath and the OpenJDK
http://www.gnu.org/software/classpath
http://openjdk.java.net
PGP Key: 94EFD9D8 (http://subkeys.pgp.net)
Fingerprint: F8EF F1EA 401E 2E60 15FA 7927 142C 2591 94EF D9D8
More information about the distro-pkg-dev
mailing list