Saxon在安装蜡染光栅后停止工作

时间:2012-06-12 20:15:43

标签: ant xslt-2.0 saxon xalan batik

有人可以帮助我解决以下问题吗?

昨天我试图在我的ANT脚本中添加一个进程(Windows XP,ANT版本1.8.2,主要是XSLT 2.0,Saxon 9只是添加到我的ant / lib),它使用Batik将SVG目录转换为PDF rasterizertask。最初我在让ANT识别rasterizertask时遇到了很多麻烦,但是在从源代码重新安装Batik之后,在以下链接的帮助下,我能够让它工作。

https://mail-archives.apache.org/mod_mbox/xmlgraphics-batik-users/200605.mbox/%3C445B43B9.4010403@harcotechnology.com%3E

虽然这些说明没有说明,但我发现需要重新编译/重建rasterizertask.jar。

作为旁注,我已经按照官方Batik网站的建议,将batik-rasterizer.jar和rasterizertask类的路径添加到我的CLASSPATH中。

瞧,我让rasterizer任务正常工作。唉,我的ANT脚本中rasterizertask之后的所有XSLT 2.0任务都停止了工作。据我所知,我所做的事情导致默认的XSLT处理器被改为Xalan-j。 Xalan不支持我的XSLT。

例如,这是我从Xalan得到的错误(我知道为什么我会收到此错误,这就是我使用Saxon的原因):

[xslt] Processing D:\workDirs\PLMXML2HeirarchalXML\source\plmxml.xml to D:\workDirs\PLMXML2HeirarchalXML\target\step1.xml
 [xslt] Loading stylesheet D:\workDirs\PLMXML2HeirarchalXML\stylesheets\step1.xsl
 [xslt] D:\workDirs\PLMXML2HeirarchalXML\stylesheets\step1.xsl:10:16: Warning! Created using: Apache Software Foundation, http://xml.apache.org/xalan-j
 [xslt] D:\workDirs\PLMXML2HeirarchalXML\stylesheets\step1.xsl:10:16: Warning! Created using: Apache Software Foundation, http://xml.apache.org/xalan-j
 [xslt] Processing D:\workDirs\PLMXML2HeirarchalXML\target\step1.xml to D:\workDirs\PLMXML2HeirarchalXML\target\step2.xml
 [xslt] Loading stylesheet D:\workDirs\PLMXML2HeirarchalXML\stylesheets\step2.xsl
 [xslt] D:\workDirs\PLMXML2HeirarchalXML\stylesheets\step2.xsl:134:53: Fatal Error! java.lang.ClassCastException: org.apache.xpath.objects.XRTreeFrag cannot be cast to org.apache.xpath.objects.XNodeSet Cause: java.lang.ClassCastException: org.apache.xpath.objects.XRTreeFrag cannot be cast to org.apache.xpath.objects.XNodeSet
 [xslt] Failed to process D:\workDirs\PLMXML2HeirarchalXML\target\step1.xml

BUILD FAILED
D:\workDirs\PLMXML2HeirarchalXML\build.xml:5: Fatal error during transformation

我发现并尝试强制ANT使用Saxon的所有方法(即将Saxon添加到CLASSPATH,xslt / factory)似乎导致Saxon被调用而不是Xalan但现在我得到以下错误:

java.lang.NullPointerException
at org.apache.xerces.parsers.AbstractSAXParser.setContentHandler(Unknown Source)
            at net.sf.saxon.Configuration.reuseStyleParser(Configuration.java:2346)
            at net.sf.saxon.PreparedStylesheet.loadStylesheetModule(PreparedStylesheet.java:261)
            at net.sf.saxon.PreparedStylesheet.prepare(PreparedStylesheet.java:185)
            at net.sf.saxon.TransformerFactoryImpl.newTemplates(TransformerFactoryImpl.java:132)
            at org.apache.tools.ant.taskdefs.optional.TraXLiaison.readTemplates(TraXLiaison.java:300)
            at org.apache.tools.ant.taskdefs.optional.TraXLiaison.createTransformer(TraXLiaison.java:317)
            at org.apache.tools.ant.taskdefs.optional.TraXLiaison.transform(TraXLiaison.java:178)
            at org.apache.tools.ant.taskdefs.XSLTProcess.process(XSLTProcess.java:853)
            at org.apache.tools.ant.taskdefs.XSLTProcess.execute(XSLTProcess.java:389)
            at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
            at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
            at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
            at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
            at java.lang.reflect.Method.invoke(Method.java:597)
            at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
            at org.apache.tools.ant.Task.perform(Task.java:348)
            at org.apache.tools.ant.Target.execute(Target.java:392)
            at org.apache.tools.ant.Target.performTasks(Target.java:413)
            at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
            at org.apache.tools.ant.Project.executeTarget(Project.java:1368)
            at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
            at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
            at org.apache.tools.ant.Main.runBuild(Main.java:811)
            at org.apache.tools.ant.Main.startAnt(Main.java:217)
            at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
            at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)

因此,如果我让Xalan进行处理,光栅化器任务仍然有效,但我之前使用的XSLT没有,如果我使用Saxon则无效。我尝试安装ANT 1.8.4,但我得到了相同的结果。

我已经耗尽了我找到的所有资源,包括本网站上的类似帖子,但所有解决方案似乎都指向了我已经尝试过的事情。

希望这足以让某人给我一些建议或帮助。

谢谢, 基思

1 个答案:

答案 0 :(得分:0)

这里有很长的历史,不同的Ant版本存在不同的问题。 (因此,我有一个遗留的Ant代码用于通过命令行界面调用Saxon。)但我相信在最近的Ant版本中,trax工厂机制​​正常工作。你在用

吗?
<xslt...>
  <factory name="net.sf.saxon.TransformerFactoryImpl"/>
</xslt>

尝试通过类路径控制使用哪个XSLT处理器本质上是容易出错的。这适用于任何应用程序,而不仅仅适用于Ant。而且我认为Ant操纵类路径的方式仍然存在缺陷 - 或者无论如何,更为礼貌,行为从文档中看不出来。