mvel @includeNamed создает NPE, используя CompiledTemplate

Я использую mvel в первый раз. Использование @includeNamed прекрасно работает при простом запуске TemplateRuntime.eval.

Но если я попытаюсь использовать CompiledTemplate, он выдаст NPE. Я делаю что-то неправильно? Или это ошибка? Я использую mvel 2.1.4.Final

public class App {
    public static void main(String[] args) {


        TemplateRegistry registry = new SimpleTemplateRegistry();
        registry.addNamedTemplate("world", TemplateCompiler.compileTemplate("world!!!"));

        System.out.println(TemplateRuntime.eval("Eval Hello: @includeNamed{'world'}", null, registry));

        CompiledTemplate ct = TemplateCompiler.compileTemplate("Compile Hello: @includeNamed{'world'}");
        System.out.println(TemplateRuntime.execute(ct, null, registry));
    }
}

И трассировка стека (Примечание: Eval печатает нормально):

Eval Hello: world!!!
Exception in thread "main" java.lang.NullPointerException
    at org.mvel2.integration.impl.StackResetResolverFactory.<init>(StackResetResolverFactory.java:15)
    at org.mvel2.compiler.CompiledExpression.getDirectValue(CompiledExpression.java:123)
    at org.mvel2.compiler.CompiledExpression.getValue(CompiledExpression.java:119)
    at org.mvel2.compiler.CompiledExpression.getValue(CompiledExpression.java:113)
    at org.mvel2.MVEL.executeExpression(MVEL.java:930)
    at org.mvel2.templates.res.CompiledNamedIncludeNode.eval(CompiledNamedIncludeNode.java:56)
    at org.mvel2.templates.res.TextNode.eval(TextNode.java:42)
    at org.mvel2.templates.res.TextNode.eval(TextNode.java:42)
    at org.mvel2.templates.TemplateRuntime.execute(TemplateRuntime.java:285)
    at org.mvel2.templates.TemplateRuntime.execute(TemplateRuntime.java:247)
    at org.mvel2.templates.TemplateRuntime.execute(TemplateRuntime.java:255)
    at org.mvel2.templates.TemplateRuntime.execute(TemplateRuntime.java:187)
    at mveltest.App.main(App.java:23)
    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 com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)

person nogridbag    schedule 30.04.2013    source источник


Ответы (1)


Ну, похоже на баг. Я заметил, что NPE возникает в конструкторе StackResetResolverFactory, когда вызывается variableResolverFactory.someMethod.

Поэтому в качестве обходного пути я использую метод execute, который принимает VariableResolverFactory.

Map<String, Object> dummyVariableMap = new HashMap<String, Object>();
VariableResolverFactory dummyResolverFactory = new SimpleVariableResolverFactory(dummyVariableMap);
System.out.println(TemplateRuntime.execute(ct, null, dummyResolverFactory, registry));

Странно, я думал, что выполнение CompiledTemplate с именованным шаблоном будет очень распространенным вариантом использования.

person nogridbag    schedule 01.05.2013