mirror of
https://github.com/angular/angular
synced 2026-05-24 09:28:37 +00:00
Migrate the remaing usages of esbuild and nodejs_binary in adev to the new toolchain versions. PR Close #62435
71 lines
2.5 KiB
Python
71 lines
2.5 KiB
Python
def _generate_stackblitz(ctx):
|
|
"""Implementation of the stackblitz generator rule"""
|
|
|
|
# Determine the stackblitz template base directory
|
|
# Create an initial string of length greater than the length the stackblitz template path will
|
|
# be. This is used so that the first file path we encounter is used as the initial value.
|
|
template_srcs = " " * 10000
|
|
for file in ctx.files.template_srcs:
|
|
file_path = file.dirname
|
|
if (len(file_path) < len(template_srcs)):
|
|
template_srcs = file_path
|
|
|
|
# File declaration of the generated html file
|
|
html_output = ctx.actions.declare_file("%s.html" % ctx.attr.name)
|
|
|
|
# Temporary directory for the generation to utilize
|
|
tmp_directory = ctx.actions.declare_directory("TMP_" + ctx.label.name)
|
|
|
|
# Set the arguments for the actions inputs and output location.
|
|
args = ctx.actions.args()
|
|
|
|
# Path to the example being generated.
|
|
args.add(ctx.attr.example_srcs.label.package)
|
|
|
|
# Path to the actions temporary directory.
|
|
args.add(tmp_directory.short_path)
|
|
|
|
# Path to the stackblitz template
|
|
args.add(template_srcs)
|
|
|
|
# Path to the html output file to write to.
|
|
args.add(html_output.path)
|
|
|
|
ctx.runfiles(files = ctx.files.template_srcs)
|
|
|
|
ctx.actions.run(
|
|
ctx = ctx,
|
|
inputs = depset(ctx.files.example_srcs + ctx.files.template_srcs),
|
|
executable = ctx.executable._generate_stackblitz,
|
|
outputs = [html_output, tmp_directory],
|
|
arguments = [args],
|
|
env = {
|
|
"BAZEL_BINDIR": ".",
|
|
},
|
|
)
|
|
|
|
# The return value describes what the rule is producing. In this case we need to specify
|
|
# the "DefaultInfo" with the output html files.
|
|
return [DefaultInfo(files = depset([html_output]))]
|
|
|
|
generate_stackblitz = rule(
|
|
# Point to the starlark function that will execute for this rule.
|
|
implementation = _generate_stackblitz,
|
|
doc = """Rule that generates stackblitz post API html opener""",
|
|
|
|
# The attributes that can be set to this rule.
|
|
attrs = {
|
|
"example_srcs": attr.label(
|
|
doc = """Files used for the stackblitz generation.""",
|
|
),
|
|
"template_srcs": attr.label(
|
|
doc = """The stackblitz template directory to base generated stackblitz on.""",
|
|
default = Label("//adev/shared-docs/pipeline/examples/template:files"),
|
|
),
|
|
"_generate_stackblitz": attr.label(
|
|
default = Label("//adev/shared-docs/pipeline:stackblitz"),
|
|
executable = True,
|
|
cfg = "exec",
|
|
),
|
|
},
|
|
)
|