使用protobuf过程中,需要先对消息结构进行定义,文件以.proto格式结尾。然后要使用google提供的protoc命令行,把.proto文件转成对应的代码文件。
protoc --proto_path=IMPORT_PATH --cpp_out=DST_DIR path/to/file.proto
这个步骤看起来非常简单,但是在实际项目中,编译过程文件众多,不可能对这个进行单独生成和编译。新的代码文件要保证能随时更新引入。
最后通过scons,研究了会builder,自己定义了protobuf的编译规则。在每次执行项目编译时,均会对.proto格式的文件进行代码生成,引入项目进行编译。
下面附上编译脚本,适用于大多复杂项目:
1 #!/usr/bin/python 2 # -*- coding: UTF-8 -*- 3 4 import os 5 6 #--------------protobuf------------------- 7 #proto file path 8 SRC_DIR = ARGUMENTS.get("SRC_DIR","./") 9 DST_DIR = ARGUMENTS.get("DST_DIR","./") 10 11 #construct proto 12 PROTOC = Builder(action="protoc -I=" + SRC_DIR + " --cpp_out=" + DST_DIR + " " + SRC_DIR + "$SOURCES",src_surffix=".proto") 13 ENV_PB = Environment(BUILDERS={'Protoc':PROTOC}) 14 PROTOFILE = Glob('*.proto') 15 CCFILE = Glob('*.cc') 16 ENV_PB.Protoc(PROTOFILE) 17 18 #--------------cpp------------------- 19 ENV_CPP = Environment(CC = 'g++') 20 21 #compile info 22 TARGETNAME = 'Server' 23 LIB = Split('pthread jsoncpp protobuf amqpcpp') 24 FILELIST = Glob('*.cpp') 25 FILELIST = FILELIST + CCFILE 26 HEADFILEPATH = Split('../Thrid ../Common') 27 LIB_DIR = Split('../Thrid/lib') 28 FLAGS = Split('-std=c++11 -Wall -g -D _DEBUG') 29 30 #Program target 31 TARGETFILE = ENV_CPP.Program(target = TARGETNAME,source = FILELIST,LIBS = LIB,CPPPATH = HEADFILEPATH,LIBPATH = LIB_DIR,CCFLAGS = FLAGS) 32 33 #install 34 INSTALL = ENV_CPP.Install('../bin', TARGETFILE) 35 ENV_CPP.Alias('install',INSTALL)