Compare commits
No commits in common. "9840269ab7e69d3bd1bfdf870c95898807848e3f" and "105a4eed8be96294c1b3d33ec560de99cf5f09dc" have entirely different histories.
9840269ab7
...
105a4eed8b
@ -3,5 +3,3 @@ export * from "./ast.ts";
|
||||
export * from "./arch.ts";
|
||||
export * from "./lexer.ts";
|
||||
export * from "./token.ts";
|
||||
|
||||
export * from "./temputils.ts";
|
||||
|
@ -1,31 +0,0 @@
|
||||
import { Checker } from "./checker.ts";
|
||||
import { Reporter } from "./info.ts";
|
||||
import { Lexer } from "./lexer.ts";
|
||||
import { Lowerer } from "./lowerer.ts";
|
||||
import { Parser } from "./parser.ts";
|
||||
import { Resolver } from "./resolver.ts";
|
||||
|
||||
/// TODO: find a better place for this function
|
||||
export async function compileWithDebug(path: string): Promise<number[]> {
|
||||
const text = await Deno.readTextFile(path);
|
||||
|
||||
const reporter = new Reporter();
|
||||
|
||||
const lexer = new Lexer(text, reporter);
|
||||
|
||||
const parser = new Parser(lexer, reporter);
|
||||
const ast = parser.parseStmts();
|
||||
|
||||
new Resolver(reporter).resolve(ast);
|
||||
new Checker(reporter).check(ast);
|
||||
|
||||
if (reporter.errorOccured()) {
|
||||
console.error("Errors occurred, stopping compilation.");
|
||||
}
|
||||
|
||||
const lowerer = new Lowerer();
|
||||
lowerer.lower(ast);
|
||||
lowerer.printProgram();
|
||||
const program = lowerer.finish();
|
||||
return program;
|
||||
}
|
@ -15,8 +15,7 @@ auto sliger::rpc::action::FlameGraph::perform_action(
|
||||
{
|
||||
auto json = vm.flame_graph_json();
|
||||
if (json) {
|
||||
writer->write(
|
||||
std::format("{{ ok: true, flameGraph: \"{}\" }}", json.value()));
|
||||
writer->write(json.value());
|
||||
} else {
|
||||
writer->write("null");
|
||||
}
|
||||
@ -29,10 +28,9 @@ auto sliger::rpc::action::CodeCoverage::perform_action(
|
||||
{
|
||||
auto json = vm.code_coverage_json();
|
||||
if (json) {
|
||||
writer->write(
|
||||
std::format("{{ ok: true, codeCoverage: \"{}\" }}", json.value()));
|
||||
writer->write(json.value());
|
||||
} else {
|
||||
writer->write("{ ok: false }");
|
||||
writer->write("null");
|
||||
}
|
||||
writer->flush();
|
||||
};
|
||||
|
@ -20,7 +20,6 @@ const runtime = new Runtime(13370);
|
||||
|
||||
async function compileProgram(filepath: string) {
|
||||
const result = await compiler.compileWithDebug(filepath);
|
||||
return result;
|
||||
}
|
||||
|
||||
async function runProgramWithDebug(program: number[]) {
|
||||
@ -38,8 +37,6 @@ async function runProgramWithDebug(program: number[]) {
|
||||
}
|
||||
}
|
||||
|
||||
await compileProgram(filepath).then(runProgramWithDebug);
|
||||
|
||||
const router = new Router();
|
||||
|
||||
router.get("/api/source", (ctx) => {
|
||||
|
Loading…
Reference in New Issue
Block a user