/* Tencent is pleased to support the open source community by making PhxRPC available. Copyright (C) 2016 THL A29 Limited, a Tencent company. All rights reserved. Licensed under the BSD 3-Clause License (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at https://opensource.org/licenses/BSD-3-Clause Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" basis, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. See the AUTHORS file for names of contributors. */ #include #include #include #include #include #include #include #include "syntax_tree.h" #include "name_render.h" #include "proto_utils.h" #include "tool_code_render.h" using namespace phxrpc; using namespace std; static void PrintHelp(const char *program) { printf("\n"); printf("PhxRPC ProtoBuf tool\n"); printf("\n"); printf("%s <-f profo file> <-d destination file dir> [-v]\n", program); printf(" Usage: -f # proto file\n"); printf(" -d # destination file dir\n"); printf(" -I # include path dir\n"); printf(" -v # print this screen\n"); printf("\n"); return; } void Proto2Tool(const char *program, const char *pb_file, const char *dir_path, const vector &include_list) { SyntaxTree syntax_tree; int ret{ProtoUtils::Parse(pb_file, &syntax_tree, include_list)}; if (0 != ret) { printf("parse proto file fail, please check error log\n"); return; } NameRender name_render(syntax_tree.GetPrefix()); ToolCodeRender code_render(name_render); char filename[256]{0}, tmp[256]{0}; // [xx]tool.h { name_render.GetToolFileName(syntax_tree.GetName(), tmp, sizeof(tmp)); snprintf(filename, sizeof(filename), "%s/%s.h", dir_path, tmp); FILE *fp{fopen(filename, "w")}; assert(nullptr != fp); code_render.GenerateToolHpp(&syntax_tree, fp); fclose(fp); printf("\n%s: Build %s file ... done\n", program, filename); } // [xx]tool.cpp { name_render.GetToolFileName(syntax_tree.GetName(), tmp, sizeof(tmp)); snprintf(filename, sizeof(filename), "%s/%s.cpp", dir_path, tmp); FILE *fp{fopen(filename, "w")}; assert(nullptr != fp); code_render.GenerateToolCpp(&syntax_tree, fp); fclose(fp); printf("\n%s: Build %s file ... done\n", program, filename); } // [xx]toolimpl.h { name_render.GetToolImplFileName(syntax_tree.GetName(), tmp, sizeof(tmp)); snprintf(filename, sizeof(filename), "%s/%s.h", dir_path, tmp); if (0 != access(filename, F_OK)) { FILE *fp{fopen(filename, "w")}; assert(nullptr != fp); code_render.GenerateToolImplHpp(&syntax_tree, fp); fclose(fp); printf("\n%s: Build %s file ... done\n", program, filename); } else { printf("\n%s: %s is exist, skip\n", program, filename); } } // [xx]toolimpl.cpp { name_render.GetToolImplFileName(syntax_tree.GetName(), tmp, sizeof(tmp)); snprintf(filename, sizeof(filename), "%s/%s.cpp", dir_path, tmp); if (0 != access(filename, F_OK)) { FILE *fp{fopen(filename, "w")}; assert(nullptr != fp); code_render.GenerateToolImplCpp(&syntax_tree, fp); fclose(fp); printf("\n%s: Build %s file ... done\n", program, filename); } else { printf("\n%s: %s is exist, skip\n", program, filename); } } // [xx]toolmain.cpp { name_render.GetToolMainFileName(syntax_tree.GetName(), tmp, sizeof(tmp)); snprintf(filename, sizeof(filename), "%s/%s.cpp", dir_path, tmp); if (0 != access(filename, F_OK)) { FILE *fp{fopen(filename, "w")}; assert(nullptr != fp); code_render.GenerateToolMainCpp(&syntax_tree, fp); fclose(fp); printf("\n%s: Build %s file ... done\n", program, filename); } else { printf("\n%s: %s is exist, skip\n", program, filename); } } } int tool_main(int argc, char **argv) { const char *pb_file{nullptr}; const char *dir_path{nullptr}; extern char *optarg; int c; vector include_list; char real_path[1024]{0}; char *rp{nullptr}; while (EOF != (c = getopt(argc, argv, "f:d:I:v"))) { switch (c) { case 'f': pb_file = optarg; break; case 'd': dir_path = optarg; break; case 'I': rp = realpath(optarg, real_path); if (rp != nullptr) { include_list.push_back(rp); } break; default: PrintHelp(argv[0]); exit(-1); break; } } if (nullptr == pb_file || nullptr == dir_path) { printf("Invalid arguments\n"); PrintHelp(argv[0]); exit(0); } if (0 != access(dir_path, R_OK | W_OK | X_OK)) { printf("Invalid dir: %s, errno %d, %s\n\n", dir_path, errno, strerror(errno)); PrintHelp(argv[0]); exit(0); } char path[128]{0}; strncpy(path, dir_path, sizeof(path)); if ('/' == path[strlen(path) - 1]) { path[strlen(path) - 1] = '\0'; } Proto2Tool(argv[0], pb_file, path, include_list); printf("\n"); return 0; }