4.20. kink/PROGRAM¶
Operations on kink programs.
4.20.1. PROGRAM.compile(Program_text ...[$config = {})]¶
`compile` compiles `Program_text` into a top level fun.
Preconditions:
• `Program_text` must be a str
• $config, if given, must be a fun which takes a conf val
The conf val provides the following methods:
• Conf.binding(Binding) : specifies `Binding` as the binding of the top level fun. If not called, a newly created binding is used.
• Conf.locale(Locale) : sets `Locale` as the locale used to create error messages. The default is LOCALE.root.
• Conf.name(Program_name) : uses `Program_name` as the name of the program. If the method is not called, "(compile)" is used as the default.
• Conf.on_success($success_cont): uses $success_cont as the success cont. If the method is not called, VAL.identity is used as the default.
• Conf.on_error($error_cont) : uses $error_cont as the error cont. If the method is not called, the default error cont raises an exception on an compile error.
Result:
• If the compilation succeeds, `compile` tail-calls the success cont with the compiled top level fun.
• If the compilation fails with a compile error, `compile` tail-calls the error cont with (Error_msg, Start_loc, End_loc), where Error_msg is the error message, Start_loc and End_loc are locs indicating the region of the compile error. The following condition holds: 0 <= Start_loc.pos <= End_loc.pos <= Program_text.size.
The top level fun is a fun which contains a sequence of instructions translated from the program, replacing every occurrence of `(binding)` by `(val Binding)`, where `Binding` is the binding of the top level fun.
See Language specification → Semantics about translation.
Example:
:PROGRAM.require_from('kink/')
:BINDING.require_from('kink/')
:LOCALE.require_from('kink/')
:fun <- PROGRAM.compile('10 + 20'){(:C)
C.locale(LOCALE.for('ja-JP'))
C.name('add.kn')
C.on_error{(:Msg :Start_loc :End_loc)
raise('unexpected compile error: {}'.format(Msg))
}
}
stdout.print_line(fun(BINDING.new).repr) # => 30
4.20.2. PROGRAM.compile_error_desc(Error_msg Start_loc End_loc)¶
compile_error_desc makes a typical description str of the compile error.
Parameters:
• Error_msg must be a message str.
• Start_loc must be the start loc of the compile error.
• End_loc must be the end loc of the compile error.
A typical result is: "compile error: unexpected token: [foo.kn L1 C6] 10 + -->+ 20"