Zhenkai Zhu | a7e3da7 | 2012-12-27 13:45:00 -0800 | [diff] [blame] | 1 | # -*- Mode: python; py-indent-offset: 4; indent-tabs-mode: nil; coding: utf-8; -*- |
| 2 | |
| 3 | #! /usr/bin/env python |
| 4 | # encoding: utf-8 |
| 5 | |
| 6 | ''' |
| 7 | |
| 8 | When using this tool, the wscript will look like: |
| 9 | |
| 10 | def options(opt): |
| 11 | opt.tool_options("protobuf", tooldir=["waf-tools"]) |
| 12 | |
| 13 | def configure(conf): |
| 14 | conf.load("compiler_cxx protobuf") |
| 15 | |
| 16 | def build(bld): |
| 17 | bld(source="main.cpp", target="app", use="PROTOBUF") |
| 18 | |
| 19 | Options are generated, in order to specify the location of protobuf includes/libraries. |
| 20 | |
| 21 | ''' |
| 22 | |
| 23 | from waflib import Utils, TaskGen, Task, Logs |
| 24 | |
| 25 | from waflib import Utils,Logs,Errors |
| 26 | from waflib.Configure import conf |
| 27 | |
| 28 | def options(opt): |
| 29 | pass |
| 30 | |
| 31 | def configure(conf): |
| 32 | """ |
| 33 | """ |
| 34 | conf.check_cfg(package='protobuf', args=['--cflags', '--libs'], uselib_store='PROTOBUF', mandatory=True) |
| 35 | |
| 36 | conf.find_program ('protoc', var='PROTOC', path_list = conf.env['PATH'], mandatory = True) |
| 37 | |
| 38 | @TaskGen.extension('.proto') |
| 39 | def add_proto(self, node): |
| 40 | """ |
| 41 | Compile PROTOBUF protocol specifications |
| 42 | """ |
| 43 | prototask = self.create_task ("protobuf", node, node.change_ext (".pb")) |
| 44 | try: |
| 45 | self.compiled_tasks.append (prototask) |
| 46 | except AttributeError: |
| 47 | self.compiled_tasks = [prototask] |
| 48 | |
| 49 | class protobuf(Task.Task): |
| 50 | """ |
| 51 | Task for compiling PROTOBUF protocol specifications |
| 52 | """ |
| 53 | run_str = '${PROTOC} --cpp_out ${TGT[0].parent.abspath()} --proto_path ${SRC[0].parent.abspath()} ${SRC[0].abspath()} -o${TGT[0].abspath()}' |
| 54 | color = 'BLUE' |
| 55 | |
| 56 | @TaskGen.feature('cxxshlib') |
| 57 | @TaskGen.before_method('process_source') |
| 58 | def dynamic_post(self): |
| 59 | if not getattr(self, 'dynamic_source', None): |
| 60 | return |
| 61 | self.source = Utils.to_list(self.source) |
| 62 | |
| 63 | src = self.bld.path.get_bld().ant_glob (Utils.to_list(self.dynamic_source)) |
| 64 | |
| 65 | for cc in src: |
| 66 | # Signature for the source |
| 67 | cc.sig = Utils.h_file (cc.abspath()) |
| 68 | # Signature for the header |
| 69 | h = cc.change_ext (".h") |
| 70 | h.sig = Utils.h_file (h.abspath()) |
| 71 | |
| 72 | self.source.extend (src) |