This repository has been archived by the owner on Mar 17, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 111
/
Copy pathdefs.bzl
85 lines (74 loc) · 3.09 KB
/
defs.bzl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# Copyright 2024 The Bazel Authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
load("@rules_compdb//:aspects.bzl", "CompilationAspect", "compilation_database_aspect")
def _compilation_database_impl(ctx):
# Generates a single compile_commands.json file with the
# transitive depset of specified targets.
if ctx.attr.disable:
ctx.actions.write(output = ctx.outputs.filename, content = "[]\n")
return
compilation_db = []
all_headers = []
for target in ctx.attr.targets:
compilation_db.append(target[CompilationAspect].compilation_db)
all_headers.append(target[OutputGroupInfo].header_files)
compilation_db = depset(transitive = compilation_db)
all_headers = depset(transitive = all_headers)
exec_root = ctx.attr.output_base + "/execroot/" + ctx.workspace_name
content = compilation_db.to_list()
if ctx.attr.unique:
content = list({element.file: element for element in content}.values())
content = json.encode(content)
content = content.replace("__EXEC_ROOT__", exec_root)
content = content.replace("-isysroot __BAZEL_XCODE_SDKROOT__", "")
ctx.actions.write(output = ctx.outputs.filename, content = content)
return [
OutputGroupInfo(
default = all_headers,
),
]
_compilation_database = rule(
attrs = {
"targets": attr.label_list(
aspects = [compilation_database_aspect],
doc = "List of all cc targets which should be included.",
),
"output_base": attr.string(
default = "__OUTPUT_BASE__",
doc = ("Output base of Bazel as returned by 'bazel info output_base'. " +
"The exec_root is constructed from the output_base as " +
"output_base + '/execroot/' + workspace_name. "),
),
"disable": attr.bool(
default = False,
doc = ("Makes this operation a no-op; useful in combination with a 'select' " +
"for platforms where the internals of this rule are not properly " +
"supported."),
),
"unique": attr.bool(
default = True,
doc = ("Remove duplicate entries before writing the database, reducing file size " +
"and potentially being faster."),
),
"filename": attr.output(
doc = "Name of the generated compilation database.",
),
},
implementation = _compilation_database_impl,
)
def compilation_database(**kwargs):
_compilation_database(
filename = kwargs.pop("filename", "compile_commands.json"),
**kwargs
)