8

我设法.proto像这样编译我的文件:

def build(bld):
    bld(rule='protoc --cpp_out=. -I.. ${SRC}', source='a.proto b.proto', name='genproto')

似乎工作得很好,当我对源文件进行更改时,它们会被重新编译等等。但结果将是调用的文件build/a.pb.ccbuild/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 中找到它:

https://code.google.com/p/waf/issues/detail?id=1184

4

1 回答 1

3

这种处理记录在 Waf 书中(查找“idl”)。

但是我很确定 protobuf 工具会受到社区的欢迎,所以我建议您尝试创建一个并将其提交给 bug tracker 或 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
)

或类似的东西。

于 2012-07-03T23:11:47.287 回答