The Perl Toolchain utilizes the relocatable perl project.
To import rules_perl in your project, you first need to add it to your WORKSPACE
file:
If you are still using WORKSPACE
to manage your dependencies:
git_repository(
name = "rules_perl",
remote = "https://github.com/bazelbuild/rules_perl.git",
branch = "main",
)
load("@rules_perl//perl:deps.bzl", "perl_register_toolchains", "perl_rules_dependencies")
perl_rules_dependencies()
perl_register_toolchains()
Once you've imported the rule set into your WORKSPACE
, you can then load the perl rules in your BUILD
files with:
load("@rules_perl//perl:perl.bzl", "perl_binary")
perl_binary(
name = "hello_world",
srcs = ["hello_world.pl"]
)
Please see example
folder for more examples of how to include Perl scripts.
Currently, simple perl programs and Pure Perl modules work.
Modules that require compiling are not yet supported.
This repository provides a hermetic Strawberry Perl bazel toolchain for Windows. Usage of the toolchain in perl_
rules is not yet supported.
Perl modules from CPAN can be generated using the cpan_compiler
rule in
conjunction with the cpan
module extension.
- Create a
cpanfile
per the Carton documentation. - Create an empty
*.json
will need to be created for Bazel to use a lockfile (e.g.cpanfile.snapshot.lock.json
) - Define a
cpan_compiler
target:
load("//perl/cpan:cpan_compiler.bzl", "cpan_compiler")
cpan_compiler(
name = "compiler",
cpanfile = "cpanfile",
lockfile = "cpanfile.snapshot.lock.json",
visibility = ["//visibility:public"],
)
bazel run
the new target.- Define a new module in
MODULE.bazel
pointing to the Bazel*.json
lock file:
cpan = use_extension("@rules_perl//perl/cpan:extensions.bzl", "cpan")
cpan.install(
name = "cpan",
lock = "//perl/cpan/3rdparty:cpanfile.snapshot.lock.json",
)
use_repo(
cpan,
"cpan",
)
Once the cpan
module extension is defined, dependencies will be available through the name given to the module.
Using the example in the steps above, dependencies can be accessed through @cpan//...
. (e.g. @cpan//:DateTime
).
Note that xs
dependencies are currently not supported by the cpan
extension module.
Downloaded and unpacked: Test::Mock::Simple
This modules was chosen because it has no dependencies and is pure Perl.
Moved the required file to examples/cpan/Test-Mock-Simple-0.10/lib
NOTE: this location has been chosen so you can compare what is in the tar vs what as actually needed. This is a bad location! It would be better to be in cpan/lib
.
Create a target for the module in your BUILD file (which resides in the cpan
directory):
perl_library(
name = "TestMockSimple",
srcs = ["Test-Mock-Simple-0.10/lib/Test/Mock/Simple.pm"],
)
Now you can specify it as a dependency to any script that requires that module:
env = {
"PERL5LIB": "examples/cpan/Test-Mock-Simple-0.10/lib",
},
deps = ["//examples/cpan:TestMockSimple"],
NOTE: at this time you need to provide the directory that Perl needs to add to @INC.
perl_binary
(and perl_test
) sets up the PERL5LIB
environment variable with values for all perl_library
dep's includes
.
The default includes are [".", "lib"]
.