2023-06-20 14:33:09 +10:00
|
|
|
#include "StarRootLoader.hpp"
|
|
|
|
#include "StarRootLuaBindings.hpp"
|
|
|
|
#include "StarUtilityLuaBindings.hpp"
|
|
|
|
#include "StarRootLuaBindings.hpp"
|
|
|
|
|
|
|
|
using namespace Star;
|
|
|
|
|
|
|
|
int main(int argc, char** argv) {
|
|
|
|
RootLoader rootLoader({{}, {}, {}, LogLevel::Error, false, {}});
|
|
|
|
RootUPtr root;
|
|
|
|
OptionParser::Options options;
|
|
|
|
tie(root, options) = rootLoader.commandInitOrDie(argc, argv);
|
|
|
|
|
|
|
|
auto engine = LuaEngine::create(true);
|
|
|
|
auto context = engine->createContext();
|
|
|
|
context.setCallbacks("sb", LuaBindings::makeUtilityCallbacks());
|
|
|
|
context.setCallbacks("root", LuaBindings::makeRootCallbacks());
|
|
|
|
|
|
|
|
String code;
|
|
|
|
bool continuation = false;
|
|
|
|
while (!std::cin.eof()) {
|
|
|
|
auto getline = [](std::istream& stream) -> String {
|
|
|
|
std::string line;
|
|
|
|
std::getline(stream, line);
|
2024-02-19 16:55:19 +01:00
|
|
|
return String(std::move(line));
|
2023-06-20 14:33:09 +10:00
|
|
|
};
|
|
|
|
|
|
|
|
if (continuation) {
|
|
|
|
std::cout << ">> ";
|
|
|
|
std::cout.flush();
|
|
|
|
code += getline(std::cin);
|
|
|
|
code += '\n';
|
|
|
|
} else {
|
|
|
|
std::cout << "> ";
|
|
|
|
std::cout.flush();
|
|
|
|
code = getline(std::cin);
|
|
|
|
code += '\n';
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
auto result = context.eval<LuaVariadic<LuaValue>>(code);
|
|
|
|
for (auto r : result)
|
2023-06-27 20:23:44 +10:00
|
|
|
coutf("{}\n", r);
|
2023-06-20 14:33:09 +10:00
|
|
|
continuation = false;
|
|
|
|
} catch (LuaIncompleteStatementException const&) {
|
|
|
|
continuation = true;
|
|
|
|
} catch (std::exception const& e) {
|
2023-06-27 20:23:44 +10:00
|
|
|
coutf("Error: {}\n", outputException(e, false));
|
2023-06-20 14:33:09 +10:00
|
|
|
continuation = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|