Skip to content

griffinbank/rules_babashka

Repository files navigation

Babashka rules for Bazel

Status: Alpha.

Features

  • babashka toolchains for multiple execution platforms

Setup

Add the following to your WORKSPACE:

RULES_BABASHKA_SHA = $CURRENT_SHA1
http_archive(
    name = "rules_babashka",
    strip_prefix = "rules_babashka-%s" % RULES_BABASHKA_SHA,
    url = "https://github.com/griffinbank/rules_babashka/archive/%s.zip" % RULES_BABASHKA_SHA
)

load("@rules_babashka//:repo.bzl", "babashka")

BABASHKA_VERSION="1.12.196"

babashka(
    name = "babashka-local",
    version = BABASHKA_VERSION,
)
register_toolchains("@babashka-local//:toolchain")

You can then use the bb binary within a genrule as a tool:

genrule(
    name = "bb-rule",
    srcs = ["bb.edn"],
    outs = ["output.edn"],
    tools = ["@babashka-local//:bin/bb"],
    cmd = """
        $(execpath @babashka-local//:bin/bb) task:bb
    """
)

If you need to use an alternate Babashka to the execution environment, to build into a deployment artifact, you can override the arch and os:

babashka(
    name = "babashka-linux-x86",
    arch = "amd64",
    os = "linux",
    version = BABASHKA_VERSION,
)

and then reference the bb binary from the alternate version.

Script dependencies

Use the babashka_deps_jar rule within a BUILD file to generate a jar of all the dependencies referenced in bb.edn:

load("@rules_babashka//deps:deps.bzl", "babashka_deps_jar")

babashka_deps_jar(
    name = "deps",
    bb_edn = "bb.edn",
)

The output will be called {name}.jar. If that's not suitable, it can be overridden with the output parameter:

load("@rules_babashka//deps:deps.bzl", "babashka_deps_jar")

babashka_deps_jar(
    name = "deps-jar",
    bb_edn = "bb.edn",
    output = "deps.jar",
)

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published