diff options
author | Emiel Bruijntjes <emiel.bruijntjes@copernica.com> | 2014-07-26 13:39:16 +0200 |
---|---|---|
committer | Emiel Bruijntjes <emiel.bruijntjes@copernica.com> | 2014-07-26 13:39:16 +0200 |
commit | 340b05438b13fbe7cd937835e1abe935967330d3 (patch) | |
tree | 36099ce148c3278c10d4e203769818b16a7150fc /zend/eval.cpp | |
parent | ff83769a9d5fc2f0f88cd42bdb3355f509294ad9 (diff) |
renamed fastcall.cpp to eval.cpp, and moved the Php::eval() definition to the call.h header file
Diffstat (limited to 'zend/eval.cpp')
-rw-r--r-- | zend/eval.cpp | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/zend/eval.cpp b/zend/eval.cpp new file mode 100644 index 0000000..e0baaed --- /dev/null +++ b/zend/eval.cpp @@ -0,0 +1,56 @@ +/** + * Eval.cpp + * + * This file holds the implementation for the Php::eval() function + * + * @author andot <https://github.com/andot> + */ + +/** + * Dependencies + */ +#include "includes.h" + +/** + * Open PHP namespace + */ +namespace Php { + +/** + * Evaluate a PHP string + * @param phpCode The PHP code to evaluate + * @return Value The result of the evaluation + */ +Value eval(const std::string &phpCode) +{ + // we need the tsrm_ls variable + TSRMLS_FETCH(); + + // the current exception + zval* oldException = EG(exception); + + // the return zval + zval* retval = nullptr; + if (zend_eval_stringl_ex((char *)phpCode.c_str(), (int32_t)phpCode.length(), retval, (char *)"", 1 TSRMLS_CC) != SUCCESS) + { + // throw an exception, php couldn't evaluate code + throw Exception("PHP eval error"); + + // unreachable, but let's return at least something to prevent compiler warnings + return nullptr; + } + else + { + // was an exception thrown inside the function? In that case we throw a C++ new exception + // to give the C++ code the chance to catch it + if (oldException != EG(exception) && EG(exception)) throw OrigException(EG(exception) TSRMLS_CC); + + // no (additional) exception was thrown + return retval ? Value(retval) : nullptr; + } +} + +/** + * End of namespace + */ +} |