import mmloader
import mmbuilder
import typing
+import icode_generation
# Loader of nit source files
class SrcModuleLoader
special ModuleLoader
redef type MODULE: MMSrcModule
- redef meth file_type do return "nit"
+ redef fun file_type do return "nit"
- redef meth parse_file(context, file, filename, name, dir)
+ redef fun parse_file(context, file, filename, name, dir)
do
var lexer = new Lexer(file, filename)
var parser = new Parser(lexer)
var node_tree = parser.parse
if node_tree.n_base == null then
var err = node_tree.n_eof
- assert err isa PError
- context.error("{err.locate}: {err.message}")
- exit(1)
+ assert err isa AError
+ context.fatal_error(err.location, err.message)
end
var node_module = node_tree.n_base
- assert node_module isa AModule
- var module = new MMSrcModule(context, node_module, dir, name, filename)
+ assert node_module != null
+ var module_loc = new Location.with_file(filename)
+ var module = new MMSrcModule(context, node_module, dir, name, module_loc)
return module
end
- redef meth process_metamodel(context, module)
+ redef fun process_metamodel(context, module)
do
module.process_supermodules(context)
+ context.info("Syntax analysis for module: {module.name}", 2)
module.process_syntax(context)
end
redef class MMSrcModule
# Loading and syntax analysis of super modules
- private meth process_supermodules(tc: ToolContext)
+ private fun process_supermodules(tc: ToolContext)
do
node.import_super_modules(tc, self)
end
# Syntax analysis and MM construction for the module
# Require than supermodules are processed
- private meth process_syntax(tc: ToolContext)
+ private fun process_syntax(tc: ToolContext)
do
do_mmbuilder(tc)
- if tc.error_count > 0 then exit(1)
+ tc.check_errors
do_typing(tc)
- if tc.error_count > 0 then exit(1)
+ tc.check_errors
+
+ generate_icode(tc)
+ tc.check_errors
+
+ if not tc.keep_ast then clear_ast
end
end
+redef class ToolContext
+ # Should the AST be preserved in source modules after syntax processing?
+ # Default is false.
+ readable writable var _keep_ast: Bool = false
+end