Name
spvmdeps - Class Dependencies Analyzer
Description
spvmdeps command is a class dependencies analyzer.
Usage
Usage: spvmdeps [OPTIONS] SCRIPT_NAME
spvmdeps myapp.spvm
spvmdeps --with-version myapp.spvm
spvmdeps --cpanm --with-version myapp.spvm
spvmdeps --cpanfile --with-version myapp.spvm
Options:
-h, --help Shows this message
-v, --version Shows the version
-I DIRECTORY Adds a include directory
-Mblib Same as "-Mblib" in perl
--json Prints JSON that contains all dependent class information.
--cpanm Prints cpanm commands that contains dependent cpan modules
--cpanfile Prints cpanfile that contains dependent cpan modules
--with-version Output(default, --cpanm, --json) contains version information.
--exclude CLASS_NAME Excludes a class name. This option can be used repeatedly.
--resource-info Shows config files of dependent resources
Details
spvmdeps [OPTIONS] SCRIPT_NAME
The spvmdeps command prints class dependency information.
Output Examples:
Sys
Regex
Foo
Bar
# --with-version
Sys 1.201
Regex 0.980
Foo (version_from Sys)
Bar
OPTIONS are options.
SCRIPT_NAME is a script name that contains a bootstrap method in an anon class.
class {
static method main : void () {
}
}
See Class Search Directories about default class search directories.
Options
--help
See "--help" in spvm.
-h
-h
See "-h" in spvm.
--version
See "--version" in spvm.
-v
-v
See "-v" in spvm.
-I
-I DIR
See "-I" in spvm.
-B
-B DIR
See "-B" in spvm.
-Mblib
-Mblib
See "-Mblib" in spvm.
--json
--json
Prints JSON that contains all dependent class information.
Output Examples:
[
{"class_name":"Address"},
{"class_name":"Bool"},
{"class_name":"Byte"},
{"class_name":"CommandInfo"},
{"class_name":"Double"},
{"class_name":"Error"},
{"class_name":"Error::Compile"},
{"class_name":"Error::NotSupported"},
{"class_name":"Error::System"},
{"class_name":"Float"},
{"class_name":"Int"},
{"class_name":"Long"},
{"class_name":"SPVM"},
{"class_name":"Short"},
{"class_name":"TestCase::NativeAPI2"},
{"class_name":"TestCase::Precompile"}
]
# --with-version
[
{"class_name":"Address","version_from":"SPVM"},
{"class_name":"Bool","version_from":"SPVM"},
{"class_name":"Byte","version_from":"SPVM"},
{"class_name":"CommandInfo","version_from":"SPVM"},
{"class_name":"Double","version_from":"SPVM"},
{"class_name":"Error","version_from":"SPVM"},
{"class_name":"Error::Compile","version_from":"SPVM"},
{"class_name":"Error::NotSupported","version_from":"SPVM"},
{"class_name":"Error::System","version_from":"SPVM"},
{"class_name":"Float","version_from":"SPVM"},
{"class_name":"Int","version_from":"SPVM"},
{"class_name":"Long","version_from":"SPVM"},
{"class_name":"SPVM","version":"0.990036"},
{"class_name":"Short","version_from":"SPVM"},
{"class_name":"TestCase::NativeAPI2","version":"1.002"},
{"class_name":"TestCase::Precompile","version":"2.005"}
]
--cpanm
--cpanm
Prints cpanm commands that contains dependent CPAN modules. Classes its version is specified are treated as dependent CPAN modules.
Output Examples:
cpanm SPVM
cpanm SPVM::Sys
cpanm SPVM::Regex
# --with-version
cpanm SPVM@1.001
cpanm SPVM::Sys@1.201
cpanm SPVM::Regex@0.980
--cpanfile
--cpanfile
Prints cpanfile that contains dependent CPAN modules. Classes its version is specified are treated as dependent CPAN modules.
Output Examples:
requires 'SPVM';
requires 'SPVM::Sys';
requires 'SPVM::Regex';
# --with-version
requires 'SPVM', '== 1.001';
requires 'SPVM::Sys', '== 1.201';
requires 'SPVM::Regex', '== 0.980';
--with-version
--with-version
Output(default, "--cpanm", "--cpanfile", "--json") contains version information.
--exclude
--exclude=<class_name>
Excludes a class name. This option can be used repeatedly.
Examples:
--exclude TestCase::Foo
Wildcard * can be used.
--exclude TestCase::*
--resource-info
--resource-info
Shows all config files loading resources.
lib Directive
If the source code specified by SCRIPT_NAME contains lib directives, The directories specified by lib directive is prepeneded to class search directories.
#lib "$FindBin::Bin/lib"
class {
}
This directories specified by lib directive is placed after the directories specified by "-I" option.
Copyright & License
Copyright 2023 Yuki Kimoto. All Rights Reserved.
MIT License.