SPVM::Builder::Config - build config
SPVM::Builder::Config is configuration of c/c++ compile and link.
my $bconf = SPVM::Builder::Config->new;
Create SPVM::Builder::Config object.
my $config = {cc => 'g++', ld => 'g++'}; $bconf->replace_all_config($config);
Replace all config.
All of old configs is removed and added new config.
my $config = $bconf->to_hash;
Convert configs to hash reference.
my $cc = $bconf->get_config('cc');
Get a config value.
$bconf->set_config(cc => $cc);
Set a config value.
$bconf->set_std('gnu99');
Set std.
std
Internally, remove -std=old if exists and add -std=new after extra_compiler_flags.
-std=old
-std=new
extra_compiler_flags
$bconf->delete_std;
Delete std.
Internally, remove -std=old if exists from extra_compiler_flags.
$bconf->set_cc($cc);
Set cc.
cc
my $cc = $bconf->get_cc;
Get cc.
$bconf->set_optimize($optimize);
Set optimize.
optimize
my $optimize = $bconf->get_optimize;
Get optimize.
$bconf->set_ld($ld);
Set ld.
ld
my $ld = $bconf->get_ld;
Get ld.
$bconf->set_lddlflags($lddlflags);
Set lddlflags.
lddlflags
my $lddlflags = $bconf->get_lddlflags;
Get lddlflags.
$bconf->add_lddlflags($lddlflags);
Add lddlflags after current lddlflags.
my $bconf = SPVM::Builder::Config->new_c99;
Create defaulgt build config. This is SPVM::Builder::Config object.
my $extra_compiler_flags = $bconf->get_extra_compiler_flags;
Get extra_compiler_flags.
$bconf->set_extra_compiler_flags($extra_compiler_flags);
Set extra_compiler_flags.
$bconf->add_extra_compiler_flags($extra_compiler_flags);
Add new extra_compiler_flags after current extra_compiler_flags.
my $extra_linker_flags = $bconf->get_extra_linker_flags;
Get extra_linker_flags.
extra_linker_flags
$bconf->set_extra_linker_flags($extra_linker_flags);
Set extra_linker_flags.
$bconf->add_extra_linker_flags($extra_linker_flags);
Add new extra_linker_flags after current extra_linker_flags.
my $include_dirs = $bconf->get_include_dirs;
Get include_dirs field. This field is array refernce.
include_dirs
include_dirs field is used by compile method of SPVM::Builder::CC to set -inculde_dir.
compile
Default is "SPVM/Builder/include" of one up of directory SPVM::Buidler::Config.pm loaded and the values of -include_dir in $Config{ccflags}.
$bconf->set_include_dirs($include_dirs);
Set include_dirs field. This field is array refernce.
See get_include_dirs method about include_dirs field.
get_include_dirs
$bconf->add_lib_dirs($lib_dir1, $lib_dir2, ...);
Add a element before the first element of lib_dirs field.
lib_dirs
See get_lib_dirs method about lib_dirs field.
get_lib_dirs
my $lib_dirs = $bconf->get_lib_dirs;
Get lib_dirs field. This field is array refernce.
lib_dirs field is used by compile method of SPVM::Builder::CC to set -lib_dir.
Default is the values of -lib_dir in $Config{lddlflags}.
$bconf->set_lib_dirs($lib_dirs);
Set lib_dirs field. This field is array refernce.
my $libs = $bconf->get_libs;
Get libs field. This field is array refernce.
libs
libs field is used by link method of SPVM::Builder::CC to set -l<lib>.
link
$bconf->set_libs($libs);
Set libs field. This field is array refernce.
See get_libs method about libs field.
get_libs
$bconf->use_lib($lib1, $lib2, ...);
Add a library after the last element of libs field.
Don't use prefix '-l' or 'lib' for library name.
my $force_compile = $bconf->get_force_compile;
Get force_compile field.
force_compile
force_compile field is used by compile method of SPVM::Builder::CC to determine whether the method should force compilation of source codes without cache.
$bconf->set_force_compile($force_compile);
Set force_compile field.
See get_force_compile method about force_compile field.
get_force_compile
my $quiet = $bconf->get_quiet;
Get quiet field.
quiet
quiet field is used by compile method of SPVM::Builder::CC to determine whether the method output compiler messages , default to 1.
1
$bconf->set_quiet($quiet);
Set quiet field.
See get_quiet method about quiet field.
get_quiet
To install SPVM, copy and paste the appropriate command in to your terminal.
cpanm
cpanm SPVM
CPAN shell
perl -MCPAN -e shell install SPVM
For more information on module installation, please visit the detailed CPAN module installation guide.