mirror of
https://github.com/peklaiho/madlisp.git
synced 2025-01-08 09:36:21 +00:00
64 lines
2.0 KiB
PHP
64 lines
2.0 KiB
PHP
|
<?php
|
||
|
namespace MadLisp;
|
||
|
|
||
|
class LispFactory
|
||
|
{
|
||
|
public function make(array $libraries = []): Lisp
|
||
|
{
|
||
|
$tokenizer = new Tokenizer();
|
||
|
$reader = new Reader();
|
||
|
$printer = new Printer();
|
||
|
$eval = new Evaller($tokenizer, $reader, $printer);
|
||
|
|
||
|
// Root environment
|
||
|
$env = new Env('root');
|
||
|
|
||
|
// Register core functions
|
||
|
$env->set('doc', new CoreFunc('doc', 'Get documentation for a function.', 1, 1,
|
||
|
function ($a) {
|
||
|
if ($a instanceof Func) {
|
||
|
return $a->getDoc();
|
||
|
}
|
||
|
|
||
|
throw new MadLispException('first argument to doc is not function');
|
||
|
}
|
||
|
));
|
||
|
|
||
|
$env->set('read', new CoreFunc('read', 'Read string as code.', 1, 1,
|
||
|
fn (string $a) => $reader->read($tokenizer->tokenize($a))
|
||
|
));
|
||
|
|
||
|
$env->set('print', new CoreFunc('print', 'Print argument. Give second argument as true to show strings in readable format.', 1, 2,
|
||
|
function ($a, bool $readable = false) use ($printer) {
|
||
|
$printer->print($a, $readable);
|
||
|
return null;
|
||
|
}
|
||
|
));
|
||
|
|
||
|
$env->set('error', new CoreFunc('error', 'Throw an exception using argument (string) as message.', 1, 1,
|
||
|
function (string $error) {
|
||
|
throw new MadLispException($error);
|
||
|
}
|
||
|
));
|
||
|
|
||
|
// Register core libraries
|
||
|
(new Lib\Collections())->register($env);
|
||
|
(new Lib\Compare())->register($env);
|
||
|
(new Lib\IO())->register($env);
|
||
|
(new Lib\Math())->register($env);
|
||
|
(new Lib\Strings())->register($env);
|
||
|
(new Lib\Time())->register($env);
|
||
|
(new Lib\Types())->register($env);
|
||
|
|
||
|
// Register additional libraries
|
||
|
foreach ($libraries as $lib) {
|
||
|
$lib->register($env);
|
||
|
}
|
||
|
|
||
|
// User environment
|
||
|
$env = new Env('user', $env);
|
||
|
|
||
|
return new Lisp($tokenizer, $reader, $eval, $printer, $env);
|
||
|
}
|
||
|
}
|