我设法编译了这样的.proto
文件:
def build(bld):
bld(rule='protoc --cpp_out=. -I.. ${SRC}', source='a.proto b.proto', name='genproto')
似乎工作得很好,当我对源文件进行更改时,它们会被重新编译,等等。但结果将是名为build/a.pb.cc
和build/b.pb.cc
的文件,我需要将其包含在我的主程序源列表中。当然我知道如何从我的协议缓冲区文件名中手动构造它们,但我不认为这是要走的路。任何人都可以给我一个提示吗?
最好的问候,菲利普
更新
在IRC人员的帮助下,我能够设法构建一个工具,如下所示。
#!/usr/bin/env python
# encoding: utf-8
# Philipp Bender, 2012
from waflib.Task import Task
from waflib.TaskGen import extension
"""
A simple tool to integrate protocol buffers into your build system.
def configure(conf):
conf.load('compiler_cxx cxx protoc_cxx')
def build(bld):
bld.program(source = "main.cpp file1.proto proto/file2.proto",
target = "executable")
"""
class protoc(Task):
run_str = '${PROTOC} ${SRC} --cpp_out=. -I..'
color = 'BLUE'
ext_out = ['.h', 'pb.cc']
@extension('.proto')
def process_protoc(self, node):
cpp_node = node.change_ext('.pb.cc')
hpp_node = node.change_ext('.pb.h')
self.create_task('protoc', node, [cpp_node, hpp_node])
self.source.append(cpp_node)
self.env.append_value('INCLUDES', ['.'] )
self.use = self.to_list(getattr(self, 'use', '')) + ['PROTOBUF']
def configure(conf):
conf.check_cfg(package="protobuf", uselib_store="PROTOBUF",
args=['--cflags', '--libs'])
conf.find_program('protoc', var='PROTOC')
你也可以在bugtracker中找到它:
答案 0 :(得分:2)
这种处理记录在Waf书中(寻找“idl”)。
但是我很确定社区会欢迎protobuf工具,因此我建议您尝试创建一个并将其提交给错误跟踪器或IRC进行审核。这样,您将减少维护负担,缩短wscript。
我希望使用这样的工具:
bld(
name="protobufs",
features="protoc cxx",
source=["protobuf/a.proto", "protobuf/b.proto"],
includes=["protobuf", "..."],
)
bld(
target="test",
features="cxx cxxprogram",
source="test.cpp",
use="protobufs", # uses the generated C++ code, links to -lprotobuf
)
或类似的东西。