Name
SPVM::Compiler - Compiler
Description
SPVM::Compiler
is the Compiler
class in the SPVM language. It compiles SPVM source codes and builds the runtime.
The instance of the Runtime class is build by the "build_runtime" method in this class.
Usage
use
Compiler;
my
$compiler
= Compiler->new;
$compiler
->add_class_path(
"lib"
);
$compiler
->set_start_file(__FILE__);
{
my
$class_name
=
"Foo"
;
$compiler
->set_start_line(__LINE__ + 1);
my
$success
=
$compiler
->compile(
$class_name
);
unless
(
$success
) {
my
$error_messages
=
$compiler
->get_error_messages;
for
my
$error_message
(
@$error_messages
) {
warn
"$error_message"
;
}
die
"Can't compile the \"$class_name\" class"
;
}
}
{
my
$class_name
=
"Bar"
;
$compiler
->set_start_line(__LINE__ + 1);
my
$success
=
$compiler
->compile(
$class_name
);
unless
(
$success
) {
my
$error_messages
=
$compiler
->get_error_messages;
for
my
$error_message
(
@$error_messages
) {
warn
"$error_message"
;
}
die
"Can't compile the \"$class_name\" class"
;
}
}
my
$runtime
=
$compiler
->build_runtime;
Pointer
The Compiler
class is a pointer class.
Its insntace has a pointer to a compiler object.
Class Methods
new
native static method new : Compiler ();
Creates a new Compiler
object and returns it.
Instance Methods
add_class_path
native method add_class_path : void (
$class_path
: string);
Adds a class directory to search for classes.
set_start_file
native method set_start_file : void (
$start_file
: string);
Sets the name of the file to start the compiling by the "compile" method.
set_start_line
native method set_start_line : void (
$start_line
:
int
);
Sets the line to start compiling by the "compile" method.
compile
native method compile :
int
(
$class_name
: string);
Compiles the specified class and the classes that are load in the specified class.
Returns 1 on success, 0 on failure.
This method can be called multiple times.
get_error_messages
native method get_error_messages : string[] ();
Returns compilation error messages in this compiling by the "compile" method.
build_runtime
native method build_runtime : Runtime ();
Builds the runtime and returns it.
The return value is a Runtime object.
See Also
Runtime
The instance of the Runtime class is build by the "build_runtime" method in this class.
Copyright & License
Copyright 2023-2023 Yuki Kimoto, all rights reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
Copyright & License
Copyright (c) 2023 Yuki Kimoto
MIT License