Trying to embed gnu.xml.dom.DomDocumentBuilderFactory
Mohsen Saboorian
mohsens@gmail.com
Sat Apr 21 13:28:00 GMT 2007
I filled a bug report:
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=31647
Andrew, newing DomDocumentBuilderFactory workaround didn't work for
me. Do you know any other workaround ;)?
Thanks.
On 4/20/07, Andrew Haley <aph@littlepinkcloud.com> wrote:
> Mohsen Saboorian writes:
> > Thanks,
> > There was no DomDocumentBuilderFactory entry in the output of command:
> > nm --demangle=java myapp.exe
> > even when I explicitly imported and did "new
> > DomDocumentBuilderFactory()" in the code.
> >
> > I extracted a portion of libgcj-4.2.0.jar (the whole content of
> > gnu.xml.* package), say gcj-dom.jar, and compiled and linked it with
> > my application. The result executable has DomDocumentBuilderFactory
> > but this time I'm facing with NoClassDefFoundError for
> > gnu.xml.dom.DomImpl.
> > Again I put the trivial code new DomImpl() and linked the app. This
> > time again I'm facing with:
> >
> > java.lang.NoClassDefFoundError: gnu.xml.dom.DomImpl
> > java.lang.Class.initializeClass(zekr_static_olpc.exe)
> > gnu.xml.dom.ImplementationSource.<clinit>(zekr_static_olpc.exe)
> > java.lang.Class.initializeClass(zekr_static_olpc.exe)
> > java.lang.Class.newInstance(zekr_static_olpc.exe)
> > org.w3c.dom.bootstrap.DOMImplementationRegistry.newInstance(zekr_static_olpc.exe)
> > gnu.xml.dom.DomDocumentBuilderFactory.<init>(zekr_static_olpc.exe)
> > net.sf.zekr.engine.xml.XmlReader.<init>(zekr_static_olpc.exe)
> > net.sf.zekr.common.config.ApplicationConfig.extractLangProps(zekr_static_olpc.exe)
> > ...
> >
> > It's strange that although there exists some entry for gnu.xml.dom.DomImpl with:
> > nm --demangle=java myapp.exe
> > it gives me that error.
> >
> > I should also say that I tried to embed xercesImpl.jar with my app, setting:
> > javax.xml.parsers.DocumentBuilderFactory=org.apache.xerces.jaxp.DocumentBuilderFactoryImpl
> > so that it uses xerces instead of gnu.xml.*. It gives me again a
> > NoClassDefFoundError.
> >
> > It seems that even when a class file is embedded in a static binary,
> > class loader (java.lang.Class.initializeClass()) cannot load that.
>
> I think this is a bug in libgcj. The NoClassDefFoundError is
> reporting the wrong missing class. It's actually one of
> DomDocumentBuilderFactory's dependencies that isn't being found. If
> you use "jcf-dump -v" on the class you'll see what its dependencies
> are.
>
> I'm sorry this is turning into such a PITA.
>
> Andrew.
>
More information about the Java
mailing list