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