On 18/02/2014 12:45, Florian Weimer wrote:

Thanks for the bug number and these suggestions. The new version is here: <http://fweimer.fedorapeople.org/openjdk/8035105/>

I had to adjust the checked exceptions, so I wrapped the InvalidNameException from DnsName in a CommunicationException as well.

I eliminated the recursion and from the name parser and added yet another check for invalid label types. (Other implementations treat extended label types as errors as well, so there is no need to implement them here.)

Is this code actually used? (I discovered it because I looked at DatagramSocket users in the JDK.) If it is, there are some other fixes besides the ArrayIndexOutOfBoundsException handling that would make sense.

Thanks for the update.

It's good to replace the recursion. Do you have the regular label case right? It looks like the type is being used by the length. Also is it necessary to catch InvalidNameException at line 363 as I don't think this is throw anymore.

One thing about communication exceptions is that the DNS client will retry. I think this is okay here but potentially it means that we fail with too many compression references a number of times.

As to whether the DNS provider is widely used then I don't have data on that. I think most of the JNDI usages are LDAP but probably a small market beyond that.

-Alan.

Reply via email to