Bazel头文件代码生成器

时间:2015-09-23 14:30:26

标签: c++ c code-generation bazel

我正在尝试通过编写规则来执行生成器来为我的bazel构建添加代码生成器,但我坚持将生成的头文件添加为我正在尝试构建的库的包含路径依赖项。

规则如下:

def _impl(ctx):
  output = ctx.outputs.out
  input = ctx.attr.defs
  md_dir = list(ctx.attr.md_dir.files)[0]
  print("generating", output.path)
  ctx.action(
      outputs=[output],
      progress_message="Generating %s" % md_dir,
      command="python codegen.py -md_dir %s %s -o %s" % (md_dir.path, input, output.path)
  )

code_generate = rule(
  implementation=_impl,
  attrs={
       "defs": attr.string(),
       "md_dir": attr.label(allow_files=True, single_file=True),
       "out": attr.output()
       },
)

和这样的BUILD文件:

load("/common/code_generate", "code_generate")

code_generate(
  name="generate_header_defs",
  defs="common/header_definition_file",
  md_dir="header_defs",
  out="gen_header.h",
)

cc_library(
  name="lnt",
  hdrs=glob(["*.h"]),
  srcs=["source.c":gen_header.h"],
  visibility=["//visibility:public"],
  deps=["@dep1//:x", "@dep2//:y", "@dep3//:z"],
)

代码生成工作并将代码写入 bazel-out / local-fastbuild / bin / common / gen_header.h ,但gcc命令行不会将include路径添加到生成的头文件中是什么导致错误:gen_header.h:没有这样的文件或目录

1 个答案:

答案 0 :(得分:8)

两种可能的解决方案:

1)使用output_to_genfiles属性:

code_generate = rule(
  implementation = _impl,
  output_to_genfiles = True,
  attrs = {...}
)

基本上它会将你生成的输出放在bazel-genfiles中,cc_ *会查找标题。它没有完整记录here

2)您可以创建一个运行python codegen.py的genrule(而不是在Skylark规则中执行)。