mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-06 14:09:52 +01:00
allow expressions to end in a $ eg. in PHP "test$" is valid, no longer throwing an error if expression cant be parsed, just log the error and return expression literally
This commit is contained in:
parent
420234cb46
commit
efa9c562bb
@ -64,6 +64,12 @@
|
|||||||
str += '$$';
|
str += '$$';
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
// check for '$' as last char, as in PHP "test$" === 'test$', $ as last char is NOT expanded
|
||||||
|
if (_p.pos == _p.expr.length)
|
||||||
|
{
|
||||||
|
str += '$';
|
||||||
|
break;
|
||||||
|
}
|
||||||
if (str)
|
if (str)
|
||||||
{
|
{
|
||||||
_tree.push(str); str = "";
|
_tree.push(str); str = "";
|
||||||
@ -401,6 +407,7 @@
|
|||||||
_vars = [];
|
_vars = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
// Initialize the parser object and create the syntax tree for the given
|
// Initialize the parser object and create the syntax tree for the given
|
||||||
// expression
|
// expression
|
||||||
var parser = _php_parser(_expr);
|
var parser = _php_parser(_expr);
|
||||||
@ -415,7 +422,13 @@
|
|||||||
|
|
||||||
// Log the successfull compiling
|
// Log the successfull compiling
|
||||||
egw.debug("log", "Compiled PHP " + _expr + " --> " + js);
|
egw.debug("log", "Compiled PHP " + _expr + " --> " + js);
|
||||||
|
}
|
||||||
|
catch(e) {
|
||||||
|
// if expression does NOT compile use it literally and log an error, but not stop execution
|
||||||
|
egw.debug("error", "Error compiling PHP "+_expr+" --> using it literally ("+
|
||||||
|
(typeof e == 'string' ? e : e.message)+")!");
|
||||||
|
return function(){ return _expr; };
|
||||||
|
}
|
||||||
// Prepate the attributes for the function constuctor
|
// Prepate the attributes for the function constuctor
|
||||||
var attrs = [];
|
var attrs = [];
|
||||||
for (var i = 0; i < _vars.length; i++)
|
for (var i = 0; i < _vars.length; i++)
|
||||||
|
Loading…
Reference in New Issue
Block a user