Copyright (c) 2013-2017 Altenwald Solutions, S.L.
Authors: "Manuel Rubio" ([email protected]
).
PHP Interpreter pure 100% Erlang. This interpreter was made for enhance and give flexibility to projects that requires an interface for plugins or addons without new compilations.
In the same way, you can use for server PHP pages in an easy way.
The port is not 100% complete, please refer to compatibility table.
ePHP requires to be run over an Erlang/OTP +R16, but not all the versions are full compatible or recommended. See the list:
Erlang Version | Support | Notes |
---|---|---|
20.0 | ✔️ | Recommended if you use OTP 20 |
19.3 | ✔️ | Recommended if you use OTP 19 |
19.2 | ✔️ | |
19.1 | ✔️ | |
19.0 | ✔️ | |
18.3 | ✔️ | Recommended if you use OTP 18 |
18.2.1 | ✔️ | |
18.2 | ✔️ | |
18.1 | ✔️ | |
18.0 | ✔️ | |
17.5 | ✔️ | Recommended if you use OTP 17 |
17.4 | ✔️ | |
17.3 | ❌ | fail in SSL |
17.2 | ❌ | no tests available in Travis-CI |
17.1 | ✔️ | |
17.0 | ✔️ | |
R16B03-1 | ✔️ | Recommended if you use OTP R16 |
R16B03 | ✔️ | |
R16B02 | ✔️ | |
R16B01 | ❌ | fails in math lib |
A simple way to use, is include in your project rebar.config
the following dependency line:
{ephp, ".*", {git, "git://github.com/altenwald/ephp.git", master}}
And use the following code in your project:
{ok, Ctx} = ephp:context_new(),
PHP = "<? $a = 5 * 23; ?>Result for $a = <?=$a?>",
{ok, Text} = ephp:eval(Ctx, PHP).
The result stored in Text
should be:
Result for $a = 115
PHP has a lot of built-in libraries. This interpreter has a little implementation of them. You can see the functions in the compatibility table.
You can add your own functions specifying the PHP name, and the module and function, as follow:
ephp_context:register_func(Ctx, <<"time">>, ephp_lib_date, time).