Peculiar fruits in the JDK
Ulf Zibis
Ulf.Zibis at CoSoCo.de
Wed Jun 25 15:39:07 UTC 2008
Hi Sherman,
Am 24.06.2008 17:58, Xueming Shen schrieb:
> Ulf Zibis wrote:
>> How did you eliminate the dependencies? E.g.:
>> https://java-nio-charset-enhanced.dev.java.net/source/browse/java-nio-charset-enhanced/branches/milestone1/solaris/classes/sun/awt/motif/X11JIS0201.java?rev=201&view=markup
>>
>> I see, my work on sun.io was for the scrapheap. :-(
>>
>
> If you have the source code for 5.x, you would find those X11
> converters were sun.io based, I rewrote
> all of them in JDK6 and modified all the places in awt/font to use the
> java.nio.charset interface..
> fortunately I was the original font/motif guy who wrote them in the
> first place, so not too difficult:-)
Sorry, class X11JIS0201 mistakenly is not an example for the
dependencies of the sun.io package. It's just the only place, were I
found an inner dependency (inheritance) to the
sun.nio.cs.ext.JIS_X_0201.De/Encoder. Do you know about other such
"inner" dependencies?
Please note, that in main I'm working on the refactoring and bugfixing
of the JDBC bridge. From that work I came to enhance the sun.nio.cs
package. On investigating to add methods to terminate the decoding on
occurrence of exclusive cipher (see: Bug 6695386), I discovered, that
the de/encoders of sun.nio.cs could be coded faster and less
footprint-consuming.
>
> I did the same thing for all sun.io.XYZConverter usages to use the
> java.nio.charset interface in J2SE
> workspace then actually removed the J2SE in JDK6 before beta, but had
> to put them back because
> BIG licensee insisted they have their JDBC bridge drivers still using
> sun.io and don't want to migrate.
>
> Yes, don't try to improve anything in sun.io package, our currently
> policy is to keep it there but don't
> do anything. That said, in order to rewrite the sun.nio.cs/ext package
> we might have to touch this
> package again, one of the ideas is to write a adaptor class to bridge
> the sun.io.Converter to sun.nio.cs
> implementation, so we can eliminate all those CharToByte/ByteToChar
> implementation, I have a
> draft implementation in one of my ws, but have not fully tested, will
> dig it out later.
I see, an adaptor class might be better, than my refactoring (just
making the 3 getters static and/or superfluous) on the interface between
sun.io and sun.nio.cs.
... but I'm sure, my refactoring is faster and consumes less footprint.
BTW: Why not shipping the BIG licensee a separate sun.io-jar to include
in his classpath?
>
>> very much thank for appreciating my work,
>>
>
> Really appreciate your work. The charset implementation work currently
> is not my priority
> simply because I lost my main codereviewer Martin (though he is still
> interested in this area
> after moving on to Google, I'm not so sure how much he can continue
> spend on this), so it
> would be easy to work on my other interesting areas. But seems like we
> now have a contributor
> who is very experienced and interested in charset:-) we should give
> it a try. I will send
> you some classes I was working on to share my thoughts/ideas later.
> But I would "warn" you
> that all the changes might not make into JDK7, there are sill some
> debates internally that whether
> or not we should spend our resource (very limited) on something that
> works (don't break it if it
> works:-))
Yes, it works well. My aproach is just about performance an footprint.
I'm still waiting for your classes to share your thoughts/ideas later.
Regards,
Ulf
More information about the core-libs-dev
mailing list