PHP 7.1 «Обнаружено нечисловое значение» с Twig 1.35

Я использую механизм шаблонов Twig и только что обновил свою версию PHP до 7.1.

Теперь я получаю следующее предупреждение при рендеринге любой страницы:

A PHP Error was encountered
Severity: Warning

Message: A non-numeric value encountered

Filename: Twig/Environment.php(469) : eval()'d code

Line Number: 91

Backtrace:

File: /var/www/html/application/third_party/Twig/lib/Twig/Environment.php(471) : eval()'d code
Line: 91
Function: _error_handler

File: /var/ww...

...

...html/index.php
Line: 320
Function: require_once

0" />

Это похоже на следующую строку в файле Twig/Environment.php

eval('?>'.$content);

Вот содержимое переменной $content:

parent = $this->loadTemplate("base.twig", "twig/index.twig", 1);
        $this->blocks = array(
            'content' => array($this, 'block_content'),
        );
    }

    protected function doGetParent(array $context)
    {
        return "base.twig";
    }

    protected function doDisplay(array $context, array $blocks = array())
    {
        $this->parent->display($context, array_merge($this->blocks, $blocks));
    }

    // line 3
    public function block_content($context, array $blocks = array())
    {
        // line 4
        echo "        
";
    }

    public function getTemplateName()
    {
        return "twig/index.twig";
    }

    public function isTraitable()
    {
        return false;
    }

    public function getDebugInfo()
    {
        return array (  31 => 4,  28 => 3,  11 => 1,);
    }

    /** @deprecated since 1.27 (to be removed in 2.0). Use getSourceContext() instead */
    public function getSource()
    {
        @trigger_error('The '.__METHOD__.' method is deprecated since version 1.27 and will be removed in 2.0. Use getSourceContext() instead.', E_USER_DEPRECATED);

        return $this->getSourceContext()->getCode();
    }

    public function getSourceContext()
    {
        return new Twig_Source("", "twig/index.twig", "/var/www/html/application/views/twig/index.twig");
    }
}

Я просто не слишком уверен, где находится нечисловое значение. Любые идеи, пожалуйста?

Я не уверен, что это актуально, но я использую Codeigniter 3...


person Tom    schedule 23.01.2018    source источник


Ответы (1)


Итак, похоже, в этом случае мне просто нужно было просмотреть мой файл ветки, найти нечисловое значение и присвоить ему значение по умолчанию, равное 0, если оно не установлено.

<input type="hidden" name="vals" value="{{ (my_var * 'now'|date('Y') }}" />

становится

<input type="hidden" name="vals" value="{{ (my_var|default(0) * 'now'|date('Y') }}" />
person Tom    schedule 29.01.2018