FYI: JamVM: JSR 335: Lambda Expressions; JSR 292: enable for OpenJDK 7/IcedTea 2; Updated to 2013-07-14 revision.
Andrew Hughes
gnu.andrew at redhat.com
Wed Aug 14 08:55:47 PDT 2013
----- Original Message -----
> Robert Lougher have made stellar progress to enable stable JSR 335 and JSR
> 292 in JamVM.
>
> I have pushed his JamVM work to IcedTea 1.x, 2.x and 3.x HEAD:
> http://icedtea.classpath.org/hg/icedtea6/rev/e565715c45a7
> http://icedtea.classpath.org/hg/icedtea7/rev/b5fa79fec364
> http://icedtea.classpath.org/hg/icedtea/rev/8b48635893db
>
> This update brings in two major highlights quoted below:
> Thank you Robert for all the good work!
> A back-port to the OpenJDK 7/IcedTea 2.4 release branch will follow.
>
No. This is not acceptable for a release branch.
> Cheers
> Xerxes
>
>
>
> "JSR 292: enable for OpenJDK 7/IcedTea 2
> IcedTea 2.4.0 is now based on OpenJDK update 40, which
> contains the backport of JSR 292 from OpenJDK 8.
>
> With a minor tweak (see previous checkins), JamVM's support
> for JSR 292 with OpenJDK 8 works with IcedTea 2.4.0. As IcedTea
> is the primary upstream client for JamVM/OpenJDK, this change
> enables JSR 292 for OpenJDK 7 in addition to OpenJDK 8.
>
> Signed-off-by: Robert Lougher <rob at jamvm.org.uk>"
> http://git.berlios.de/cgi-bin/cgit.cgi/jamvm/commit/?id=1a58072f8339270f9372c273d82a00790e04375d
>
>
>
> Proper JSR 335: Lambda Expressions
> "JSR 335: handle multiple defaults and conflicts
>
> With JSR 335, an interface can define default methods which
> are used if a class which implements the interface does not
> provide an implementation for that method.
>
> While this is straight-forward to understand in the simple
> case where a class ends up with a single default method, it
> gets complicated when a class ends up with multiple defaults
> from different interfaces.
>
> A class implements not only its direct interfaces but also
> the interfaces which its direct interfaces extends (recursively),
> plus all the interfaces of its superclasses.
>
> For a given unimplemented interface method there will potentially
> be several definitions in the set of implemented interfaces -
> some will be abstract and some will be defaults.
>
> In that set, only the most specific are relevant, i.e. if
> two interfaces define a default method foo, and B extends A,
> then B's default takes precedence over A. If we end up with
> only abstract most-specific methods, or a single most-specific
> default things are OK. However, if we end up with multiple
> defaults from unrelated interfaces we have a conflict.
>
> JamVM previously handled unimplemented interface methods
> (which before JSR 335 were all abstract) by creating Miranda
> methods for them when constructing the interface method table
> (if they were invoked, they threw an AbstractMethodError).
>
> For JSR 335, this was extended to create Miranda methods for
> unimplemented defaults - if they were invoked they executed
> the default. This change modifies the code to also handle
> multiple defaults and conflicting defaults. Previously, as
> all methods were abstract, multiple definitions didn't matter.
> Now, we need to ensure the correct default is chosen. This
> is made more complex as a Miranda may be inherited from a
> superclass. This Miranda may need to be overridden by an
> additional Miranda in the subclass.
>
> Note, if we have conflicting defaults an AbstractMethodError
> is thrown. This copies HotSpot. However, the JSR 335 spec
> states that an IncompatibleClassChangeError is thrown. I prefer
> to follow HotSpot rather than the spec, but I will keep a lookout
> in case HotSpot (or the spec) changes in the future...
>
> Signed-off-by: Robert Lougher <rob at jamvm.org.uk>"
> http://git.berlios.de/cgi-bin/cgit.cgi/jamvm/commit/?id=08e4b93b752f107eec983205c2225cef58b6ea7f
>
--
Andrew :)
Free Java Software Engineer
Red Hat, Inc. (http://www.redhat.com)
PGP Key: 248BDC07 (https://keys.indymedia.org/)
Fingerprint = EC5A 1F5E C0AD 1D15 8F1F 8F91 3B96 A578 248B DC07
More information about the distro-pkg-dev
mailing list