如何修复Jaspersoft studio插件中由TraceGovernor引起的java.lang.NullPointerException?

时间:2016-07-21 18:13:10

标签: java nullpointerexception eclipse-plugin jasper-reports jaspersoft-studio

我正在为Jaspersoft工作室的插件编写最新版本。当插件尝试打开报告预览时,插件崩溃了。 (来自插件)java.lang.NullPoinpointerException的堆栈跟踪:

com.jaspersoft.studio.debug.TraceGovernor.setup(TraceGovernor.java:111)
com.jaspersoft.studio.debug.TraceGovernor.initMaps(TraceGovernor.java:118)
com.jaspersoft.studio.debug.TraceGovernor.beforeReportInit(TraceGovernor.java:162)
net.sf.jasperreports.engine.fill.JRFillDatasetScriptlet.beforeReportInit(JRFillDatasetScriptlet.java:74)
net.sf.jasperreports.engine.JRAbstractScriptlet.callBeforeReportInit(JRAbstractScriptlet.java:176)
net.sf.jasperreports.engine.fill.JRVerticalFiller.fillReportStart(JRVerticalFiller.java:236)
net.sf.jasperreports.engine.fill.JRVerticalFiller.fillReport(JRVerticalFiller.java:115)
net.sf.jasperreports.engine.fill.JRBaseFiller.fill(JRBaseFiller.java:580)
net.sf.jasperreports.engine.fill.BaseReportFiller.fill(BaseReportFiller.java:414)
net.sf.jasperreports.engine.fill.BaseFillHandle$ReportFill.run(BaseFillHandle.java:119)
java.lang.Thread.run(Thread.java:745)

堆栈跟踪中的非代码是我的。我认为它无法加载必要的类。 (Jaspersoft工作室可以加载所有必要的库)有谁知道,请问该怎么办?非常感谢。

修改

我发现,它是由Jaspersoft工作室中的这个属性引起的,它加载扩展,即加载TraceGovernor。这是用于调试报告,但它与我的插件不兼容。

net.sf.jasperreports.extension.registry.factory.governor=com.jaspersoft.studio.debug.TraceGovernorExtensionsRegistryFactory

我已经通过从java包com.jaspersoft.studio_6.3.0.final.jar\jasperreports_extension.properties中删除它来解决这个问题,但我想要一些非破坏性的方法,如何禁用此扩展。

1 个答案:

答案 0 :(得分:2)

相关的源代码可在以下网址获得:

http://anonsvn:anonsvn@code.jaspersoft.com/svn/repos/jaspersoftstudio/tags/6_3_0_final/com.jaspersoft.studio/src/com/jaspersoft/studio/debug/TraceGovernor.java

NPE似乎是jrConfig类中未初始化的TraceGovernor字段的结果,该字段在getJasperReportsContext()的构造函数ScriptletFactoryContext context中被TraceGovernor初始化{1}}已返回instanceof JasperReportsConfiguration

您可以结帐并导航存储库以进一步调查NPE的原因。否则,我只能建议向JasperSoft提交错误报告。