3

我正在使用 ST-4.0.7.jar,我的模板如下所示:

backtrack_result(btresult) ::=<<
    <backtrack-result>
        <pattern id="$btresult.pattern.id$">$btresult.pattern.description$</pattern>
        <file>$btresult.file.file.path$</file>
        <line>$btresult.codeline.lineNr$</line>
        <method>$btresult.codeline.method.name$</method>        
    </backtrack-result>
>>

但是,当我查看我的输出文件时,我得到了

<method></method>

在 BTResult 中:

public CodeLineInterface getCodeline() {
    return cl;
} 

在代码行中:

public MethodInterface getMethod() {
    return method;
}

在方法中:

public String getName() {
    return name;
}

我在 getMethod 方法的代码行对象中设置了一个断点,它从未被调用过。所以我得出结论,不知何故 stringtemplate 在解析正确的 getter 时存在问题。

我添加了一个 STErrorListener 发现 ST 抛出以下错误:

STReportGenerator  - context [/report /backtrack_results /backtrack_result] 5:19 no such property or can't access: ju.no.need.toknow.BTResult.method
Caused by: org.stringtemplate.v4.misc.STNoSuchPropertyException: no such property: ju.no.need.toknow.BTResult.method
    at org.stringtemplate.v4.misc.ObjectModelAdaptor.throwNoSuchProperty(ObjectModelAdaptor.java:106)
    at org.stringtemplate.v4.misc.ObjectModelAdaptor.lookupMethod(ObjectModelAdaptor.java:99)
    at org.stringtemplate.v4.misc.ObjectModelAdaptor.getProperty(ObjectModelAdaptor.java:67)
    at org.stringtemplate.v4.Interpreter.getObjectProperty(Interpreter.java:1158)

对此我特别困惑的是:当模板说它应该得到 btresult 时,为什么它会尝试解析为 BTReult.method。代码行.method.name

4

1 回答 1

2

好的。这是我自己的愚蠢:虽然我确实修复了我的模板,但代码实际上使用了一个旧模板,所以在我看来,我的所有修复都不起作用。OSI 第 8 层问题 ;-)

于 2013-03-06T12:27:24.130 回答