lean2/src/shell/emscripten.cpp
2015-06-18 10:23:49 -07:00

89 lines
2.5 KiB
C++

/*
Copyright (c) 2015 Microsoft Corporation. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Author: Leonardo de Moura
*/
#include <string>
#include "util/script_state.h"
#include "util/thread_script_state.h"
#include "library/module.h"
#include "library/standard_kernel.h"
#include "library/kernel_bindings.h"
#include "library/error_handling/error_handling.h"
#include "frontends/lean/pp.h"
#include "frontends/lean/parser.h"
#include "init/init.h"
#include "shell/simple_pos_info_provider.h"
namespace lean {
class emscripten_shell {
private:
unsigned trust_lvl;
unsigned num_threads;
options opts;
environment env;
io_state ios;
script_state S;
set_environment set1;
set_io_state set2;
public:
emscripten_shell() : trust_lvl(LEAN_BELIEVER_TRUST_LEVEL+1), num_threads(1), opts("flycheck", true),
env(mk_environment(trust_lvl)), ios(opts, lean::mk_pretty_formatter_factory()),
S(lean::get_thread_script_state()), set1(S, env), set2(S, ios) {
}
int import_module(std::string mname) {
try {
module_name mod(mname);
std::string base = ".";
bool num_threads = 1;
bool keep_proofs = false;
env = import_modules(env, base, 1, &mod, num_threads, keep_proofs, ios);
} catch (lean::exception & ex) {
simple_pos_info_provider pp("import_module");
lean::display_error(diagnostic(env, ios), &pp, ex);
return 1;
}
return 0;
}
int process_file(std::string input_filename) {
bool ok = true;
try {
environment temp_env(env);
io_state temp_ios(ios);
if (!parse_commands(temp_env, temp_ios, input_filename.c_str(), false, num_threads)) {
ok = false;
}
} catch (lean::exception & ex) {
simple_pos_info_provider pp(input_filename.c_str());
ok = false;
lean::display_error(diagnostic(env, ios), &pp, ex);
}
return ok ? 0 : 1;
}
};
}
static lean::initializer * g_init = nullptr;
static lean::emscripten_shell * g_shell = nullptr;
void initialize_emscripten() {
g_init = new lean::initializer();
g_shell = new lean::emscripten_shell();
}
void finalize_emscripten() {
delete g_shell;
delete g_init;
}
int emscripten_import_module(std::string mname) {
return g_shell->import_module(mname);
}
int emscripten_process_file(std::string input_filename) {
return g_shell->process_file(input_filename);
}