Skip to content

Commit

Permalink
[asr->python] Initial ASR to Python implementation (lcompilers#2362)
Browse files Browse the repository at this point in the history
  • Loading branch information
khushi-411 authored and hankluo6 committed Mar 8, 2024
1 parent 46d73a7 commit de7d9c6
Show file tree
Hide file tree
Showing 21 changed files with 897 additions and 1 deletion.
6 changes: 6 additions & 0 deletions run_tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ def is_included(backend):
llvm_dbg = is_included("llvm_dbg")
cpp = is_included("cpp")
c = is_included("c")
python = is_included("python")
is_cumulative = is_included("cumulative")
wat = is_included("wat")
run = is_included("run")
Expand Down Expand Up @@ -133,6 +134,11 @@ def is_included(backend):
else:
run_test(filename, "c", "lpython --no-color --show-c {infile}",
filename, update_reference, extra_args)

if python:
run_test(filename, "python", "lpython --no-color --show-python {infile}",
filename, update_reference, extra_args)

if wat:
run_test(filename, "wat", "lpython --no-color --show-wat {infile}",
filename, update_reference, extra_args)
Expand Down
58 changes: 57 additions & 1 deletion src/bin/lpython.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
#include <libasr/codegen/asr_to_llvm.h>
#include <libasr/codegen/asr_to_cpp.h>
#include <libasr/codegen/asr_to_c.h>
#include <libasr/codegen/asr_to_python.h>
#include <libasr/codegen/asr_to_py.h>
#include <libasr/codegen/asr_to_x86.h>
#include <libasr/codegen/asr_to_wasm.h>
Expand Down Expand Up @@ -55,7 +56,7 @@ using LCompilers::CompilerOptions;
using LCompilers::LPython::parse_python_file;

enum class Backend {
llvm, cpp, c, x86, wasm, wasm_x86, wasm_x64
llvm, cpp, c, x86, wasm, wasm_x86, wasm_x64, python
};


Expand Down Expand Up @@ -385,6 +386,56 @@ int emit_c_to_file(const std::string &infile, const std::string &outfile,
return 0;
}

int emit_python(const std::string &infile,
const std::string &runtime_library_dir,
CompilerOptions &compiler_options)
{
Allocator al(4*1024);
LCompilers::diag::Diagnostics diagnostics;
LCompilers::LocationManager lm;
{
LCompilers::LocationManager::FileLocations fl;
fl.in_filename = infile;
lm.files.push_back(fl);
std::string input = LCompilers::read_file(infile);
lm.init_simple(input);
lm.file_ends.push_back(input.size());
}
LCompilers::Result<LCompilers::LPython::AST::ast_t*> r = parse_python_file(
al, runtime_library_dir, infile, diagnostics, 0, compiler_options.new_parser);
std::cerr << diagnostics.render(lm, compiler_options);
if (!r.ok) {
return 1;
}
LCompilers::LPython::AST::ast_t* ast = r.result;

diagnostics.diagnostics.clear();

// AST -> ASR
LCompilers::Result<LCompilers::ASR::TranslationUnit_t*>
r1 = LCompilers::LPython::python_ast_to_asr(al, lm, nullptr, *ast, diagnostics, compiler_options, true, "__main__", infile);
std::cerr << diagnostics.render(lm, compiler_options);
if (!r1.ok) {
LCOMPILERS_ASSERT(diagnostics.has_error())
return 2;
}
LCompilers::ASR::TranslationUnit_t* asr = r1.result;

diagnostics.diagnostics.clear();

// ASR -> LPython
bool color = false;
int indent = 0;
LCompilers::Result<std::string> res = LCompilers::asr_to_python(al, *asr, diagnostics, compiler_options, color, indent);
std::cerr << diagnostics.render(lm, compiler_options);
if (!res.ok) {
LCOMPILERS_ASSERT(diagnostics.has_error())
return 3;
}
std::cout << res.result;
return 0;
}

int emit_wat(const std::string &infile,
const std::string &runtime_library_dir,
CompilerOptions &compiler_options)
Expand Down Expand Up @@ -1490,6 +1541,7 @@ int main(int argc, char *argv[])
bool show_asr = false;
bool show_cpp = false;
bool show_c = false;
bool show_python = false;
bool show_document_symbols = false;
bool show_errors = false;
bool with_intrinsic_modules = false;
Expand Down Expand Up @@ -1556,6 +1608,7 @@ int main(int argc, char *argv[])
app.add_flag("--show-llvm", show_llvm, "Show LLVM IR for the given file and exit");
app.add_flag("--show-cpp", show_cpp, "Show C++ translation source for the given python file and exit");
app.add_flag("--show-c", show_c, "Show C translation source for the given python file and exit");
app.add_flag("--show-python", show_python, "Show Python translation source for the given python file and exit");
app.add_flag("--show-asm", show_asm, "Show assembly for the given file and exit");
app.add_flag("--show-wat", show_wat, "Show WAT (WebAssembly Text Format) and exit");
app.add_flag("--show-stacktrace", compiler_options.show_stacktrace, "Show internal stacktrace on compiler errors");
Expand Down Expand Up @@ -1789,6 +1842,9 @@ int main(int argc, char *argv[])
return emit_c(arg_file, runtime_library_dir, lpython_pass_manager,
compiler_options);
}
if (show_python) {
return emit_python(arg_file, runtime_library_dir, compiler_options);
}
if (show_wat) {
return emit_wat(arg_file, runtime_library_dir, compiler_options);
}
Expand Down
1 change: 1 addition & 0 deletions src/libasr/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ set(SRC
codegen/asr_to_cpp.cpp
codegen/asr_to_c.cpp
codegen/asr_to_julia.cpp
codegen/asr_to_python.cpp
codegen/asr_to_fortran.cpp
codegen/asr_to_py.cpp
codegen/x86_assembler.cpp
Expand Down
Loading

0 comments on commit de7d9c6

Please sign in to comment.