angular-cli/tools/ts_json_schema.bzl
2019-10-24 12:05:25 -07:00

78 lines
2.0 KiB
Python

# Copyright Google Inc. All Rights Reserved.
#
# Use of this source code is governed by an MIT-style license that can be
# found in the LICENSE file at https://angular.io/license
load("@npm_bazel_typescript//:index.bzl", "ts_library")
# @external_begin
def _ts_json_schema_interface_impl(ctx):
args = [
ctx.files.src[0].path,
ctx.outputs.ts.path,
]
ctx.actions.run(
inputs = ctx.files.src + ctx.files.data,
executable = ctx.executable._binary,
outputs = [ctx.outputs.ts],
arguments = args,
)
return [DefaultInfo()]
_ts_json_schema_interface = rule(
_ts_json_schema_interface_impl,
attrs = {
"src": attr.label(
allow_files = [".json"],
mandatory = True,
),
"out": attr.string(
mandatory = True,
),
"data": attr.label_list(
allow_files = [".json"],
),
"_binary": attr.label(
default = Label("//tools:quicktype_runner"),
executable = True,
cfg = "host",
),
},
outputs = {
"ts": "%{out}",
},
)
# @external_end
# Generates a library that contains the interface for a JSON Schema file. Takes a single `src`
# argument as input, an optional data field for reference files, and produces a ts_library()
# rule containing the typescript interface.
# The file produced will have the same name, with the extension replaced from `.json` to `.ts`.
# Any filename collision will be an error thrown by Bazel.
def ts_json_schema(name, src, data = []):
out = src.replace(".json", ".ts")
# @external_begin
_ts_json_schema_interface(
name = name + ".interface",
src = src,
out = out,
data = data,
)
# @external_end
ts_library(
name = name,
deps = [
"@npm//@types/node",
],
# Remove these to empty the rule, since those files are also compiled elsewhere.
# @external_begin
srcs = [
out,
],
# @external_end
)