|
@@ -7,8 +7,10 @@
|
|
|
#include <variant>
|
|
#include <variant>
|
|
|
|
|
|
|
|
#include "common/check.h"
|
|
#include "common/check.h"
|
|
|
|
|
+#include "common/error.h"
|
|
|
#include "common/ostream.h"
|
|
#include "common/ostream.h"
|
|
|
#include "explorer/common/arena.h"
|
|
#include "explorer/common/arena.h"
|
|
|
|
|
+#include "explorer/common/trace_stream.h"
|
|
|
#include "explorer/interpreter/interpreter.h"
|
|
#include "explorer/interpreter/interpreter.h"
|
|
|
#include "explorer/interpreter/resolve_control_flow.h"
|
|
#include "explorer/interpreter/resolve_control_flow.h"
|
|
|
#include "explorer/interpreter/resolve_names.h"
|
|
#include "explorer/interpreter/resolve_names.h"
|
|
@@ -21,6 +23,7 @@ namespace Carbon {
|
|
|
auto AnalyzeProgram(Nonnull<Arena*> arena, AST ast,
|
|
auto AnalyzeProgram(Nonnull<Arena*> arena, AST ast,
|
|
|
Nonnull<TraceStream*> trace_stream,
|
|
Nonnull<TraceStream*> trace_stream,
|
|
|
Nonnull<llvm::raw_ostream*> print_stream) -> ErrorOr<AST> {
|
|
Nonnull<llvm::raw_ostream*> print_stream) -> ErrorOr<AST> {
|
|
|
|
|
+ trace_stream->set_current_phase(ProgramPhase::SourceProgram);
|
|
|
if (trace_stream->is_enabled()) {
|
|
if (trace_stream->is_enabled()) {
|
|
|
*trace_stream << "********** source program **********\n";
|
|
*trace_stream << "********** source program **********\n";
|
|
|
for (int i = ast.num_prelude_declarations;
|
|
for (int i = ast.num_prelude_declarations;
|
|
@@ -28,33 +31,39 @@ auto AnalyzeProgram(Nonnull<Arena*> arena, AST ast,
|
|
|
*trace_stream << *ast.declarations[i];
|
|
*trace_stream << *ast.declarations[i];
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
+
|
|
|
SourceLocation source_loc("<Main()>", 0);
|
|
SourceLocation source_loc("<Main()>", 0);
|
|
|
ast.main_call = arena->New<CallExpression>(
|
|
ast.main_call = arena->New<CallExpression>(
|
|
|
source_loc, arena->New<IdentifierExpression>(source_loc, "Main"),
|
|
source_loc, arena->New<IdentifierExpression>(source_loc, "Main"),
|
|
|
arena->New<TupleLiteral>(source_loc));
|
|
arena->New<TupleLiteral>(source_loc));
|
|
|
// Although name resolution is currently done once, generic programming
|
|
// Although name resolution is currently done once, generic programming
|
|
|
// (particularly templates) may require more passes.
|
|
// (particularly templates) may require more passes.
|
|
|
|
|
+ trace_stream->set_current_phase(ProgramPhase::NameResolution);
|
|
|
if (trace_stream->is_enabled()) {
|
|
if (trace_stream->is_enabled()) {
|
|
|
*trace_stream << "********** resolving names **********\n";
|
|
*trace_stream << "********** resolving names **********\n";
|
|
|
}
|
|
}
|
|
|
CARBON_RETURN_IF_ERROR(ResolveNames(ast));
|
|
CARBON_RETURN_IF_ERROR(ResolveNames(ast));
|
|
|
|
|
|
|
|
|
|
+ trace_stream->set_current_phase(ProgramPhase::ControlFlowResolution);
|
|
|
if (trace_stream->is_enabled()) {
|
|
if (trace_stream->is_enabled()) {
|
|
|
*trace_stream << "********** resolving control flow **********\n";
|
|
*trace_stream << "********** resolving control flow **********\n";
|
|
|
}
|
|
}
|
|
|
CARBON_RETURN_IF_ERROR(ResolveControlFlow(ast));
|
|
CARBON_RETURN_IF_ERROR(ResolveControlFlow(ast));
|
|
|
|
|
|
|
|
|
|
+ trace_stream->set_current_phase(ProgramPhase::TypeChecking);
|
|
|
if (trace_stream->is_enabled()) {
|
|
if (trace_stream->is_enabled()) {
|
|
|
*trace_stream << "********** type checking **********\n";
|
|
*trace_stream << "********** type checking **********\n";
|
|
|
}
|
|
}
|
|
|
CARBON_RETURN_IF_ERROR(
|
|
CARBON_RETURN_IF_ERROR(
|
|
|
TypeChecker(arena, trace_stream, print_stream).TypeCheck(ast));
|
|
TypeChecker(arena, trace_stream, print_stream).TypeCheck(ast));
|
|
|
|
|
|
|
|
|
|
+ trace_stream->set_current_phase(ProgramPhase::UnformedVariableResolution);
|
|
|
if (trace_stream->is_enabled()) {
|
|
if (trace_stream->is_enabled()) {
|
|
|
*trace_stream << "********** resolving unformed variables **********\n";
|
|
*trace_stream << "********** resolving unformed variables **********\n";
|
|
|
}
|
|
}
|
|
|
CARBON_RETURN_IF_ERROR(ResolveUnformed(ast));
|
|
CARBON_RETURN_IF_ERROR(ResolveUnformed(ast));
|
|
|
|
|
|
|
|
|
|
+ trace_stream->set_current_phase(ProgramPhase::Declarations);
|
|
|
if (trace_stream->is_enabled()) {
|
|
if (trace_stream->is_enabled()) {
|
|
|
*trace_stream << "********** printing declarations **********\n";
|
|
*trace_stream << "********** printing declarations **********\n";
|
|
|
for (int i = ast.num_prelude_declarations;
|
|
for (int i = ast.num_prelude_declarations;
|
|
@@ -62,16 +71,25 @@ auto AnalyzeProgram(Nonnull<Arena*> arena, AST ast,
|
|
|
*trace_stream << *ast.declarations[i];
|
|
*trace_stream << *ast.declarations[i];
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
+ trace_stream->set_current_phase(ProgramPhase::Unknown);
|
|
|
return ast;
|
|
return ast;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
auto ExecProgram(Nonnull<Arena*> arena, AST ast,
|
|
auto ExecProgram(Nonnull<Arena*> arena, AST ast,
|
|
|
Nonnull<TraceStream*> trace_stream,
|
|
Nonnull<TraceStream*> trace_stream,
|
|
|
Nonnull<llvm::raw_ostream*> print_stream) -> ErrorOr<int> {
|
|
Nonnull<llvm::raw_ostream*> print_stream) -> ErrorOr<int> {
|
|
|
|
|
+ trace_stream->set_current_phase(ProgramPhase::Execution);
|
|
|
if (trace_stream->is_enabled()) {
|
|
if (trace_stream->is_enabled()) {
|
|
|
*trace_stream << "********** starting execution **********\n";
|
|
*trace_stream << "********** starting execution **********\n";
|
|
|
}
|
|
}
|
|
|
- return InterpProgram(ast, arena, trace_stream, print_stream);
|
|
|
|
|
|
|
+ CARBON_ASSIGN_OR_RETURN(
|
|
|
|
|
+ auto interpreter_result,
|
|
|
|
|
+ InterpProgram(ast, arena, trace_stream, print_stream));
|
|
|
|
|
+ if (trace_stream->is_enabled()) {
|
|
|
|
|
+ *trace_stream << "interpreter result: " << interpreter_result << "\n";
|
|
|
|
|
+ }
|
|
|
|
|
+ trace_stream->set_current_phase(ProgramPhase::Unknown);
|
|
|
|
|
+ return interpreter_result;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
} // namespace Carbon
|
|
} // namespace Carbon
|