[英]Compile C++ file with Python.h import using Bazel
我想编译一个使用Python嵌入的C ++文件。 因此,我#include在我的C ++源代码中。 当使用g ++作为编译器时,我将指定以下标志:
g ++ -o pybridge pybridge.cc -I / usr / include / python2.7 / -lpython2.7
我现在想使用Bazel进行编译,并尝试了以下目标规则:
cc_binary(
name = "pybridge",
srcs = ["pybridge.cc"],
copts = ["-I/usr/include/python2.7/"],
linkopts = ["-lpython2.7"]
)
运行bazel build
会给出如下错误消息:
pybridge.cc:(.text+0x10): undefined reference to Py_Initialize
Bazel在沙箱中执行您的构建,以防止其访问您的系统中不存在的随机资源,例如您的同事的系统中不存在的资源。
这意味着,除非您将文件(如Python库)声明为依赖项,否则Bazel不会将其放在沙箱中,并且您的构建将无法找到它。
有两种选择:
最简单的方法是使用--spawn_strategy=standalone
进行构建( bazel build --spawn_strategy=standalone :pybridge
)。 这告诉Bazel在此构建中不要使用沙箱。 请注意,据Bazel所知,沙盒运行和非沙盒运行之间没有任何变化,因此您必须在重新运行之前先进行清理,而无需沙盒操作,否则您只会得到缓存的错误。
较难的选择是声明/usr/lib/libpython2.7.so
作为构建的输入。 如果要这样做,请将以下内容添加到WORKSPACE文件中:
local_repository(
name = "system_python",
path = "/usr/lib/python2.7/config-x86_64-linux-gnu", # Figure out where it is on your system, this is where it is on mine
build_file_content = """
cc_library(
name = "my-python-lib",
srcs = ["libpython2.7.so"],
visibility = ["//visibility:public"],
)
""",
)
然后在您的BUILD文件中,而不是linkopts = ["-lpython2.7"]
,添加deps = ["@system_python//:my-python-lib"]
。 然后,Bazel将了解您的构建依赖于libpython2.7.so(并将其包含在沙箱中)。
( 试图评论OP的职位,但我缺少必需的业力。 )
FWIW,即使在我不使用Bazel而是手动运行链接器的情况下,也无法在Python 2.7的库(在Windows上)上进行链接,因此此问题可能与Bazel无关。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.