1 /* 2 * 3 * Copyright 2015, Google Inc. 4 * All rights reserved. 5 * 6 * Redistribution and use in source and binary forms, with or without 7 * modification, are permitted provided that the following conditions are 8 * met: 9 * 10 * * Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * * Redistributions in binary form must reproduce the above 13 * copyright notice, this list of conditions and the following disclaimer 14 * in the documentation and/or other materials provided with the 15 * distribution. 16 * * Neither the name of Google Inc. nor the names of its 17 * contributors may be used to endorse or promote products derived from 18 * this software without specific prior written permission. 19 * 20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 24 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 25 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 26 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 31 * 32 */ 33 34 #ifndef GRPC_INTERNAL_COMPILER_CPP_GENERATOR_H 35 #define GRPC_INTERNAL_COMPILER_CPP_GENERATOR_H 36 37 // cpp_generator.h/.cc do not directly depend on GRPC/ProtoBuf, such that they 38 // can be used to generate code for other serialization systems, such as 39 // FlatBuffers. 40 41 #include <memory> 42 #include <vector> 43 44 #include "src/compiler/schema_interface.h" 45 46 namespace grpc_cpp_generator { 47 48 // Contains all the parameters that are parsed from the command line. 49 struct Parameters { 50 // Puts the service into a namespace 51 grpc::string services_namespace; 52 // Use system includes (<>) or local includes ("") 53 bool use_system_headers; 54 // Prefix to any grpc include 55 grpc::string grpc_search_path; 56 }; 57 58 // Return the prologue of the generated header file. 59 grpc::string GetHeaderPrologue(grpc_generator::File *file, const Parameters ¶ms); 60 61 // Return the includes needed for generated header file. 62 grpc::string GetHeaderIncludes(grpc_generator::File *file, const Parameters ¶ms); 63 64 // Return the includes needed for generated source file. 65 grpc::string GetSourceIncludes(grpc_generator::File *file, const Parameters ¶ms); 66 67 // Return the epilogue of the generated header file. 68 grpc::string GetHeaderEpilogue(grpc_generator::File *file, const Parameters ¶ms); 69 70 // Return the prologue of the generated source file. 71 grpc::string GetSourcePrologue(grpc_generator::File *file, const Parameters ¶ms); 72 73 // Return the services for generated header file. 74 grpc::string GetHeaderServices(grpc_generator::File *file, const Parameters ¶ms); 75 76 // Return the services for generated source file. 77 grpc::string GetSourceServices(grpc_generator::File *file, const Parameters ¶ms); 78 79 // Return the epilogue of the generated source file. 80 grpc::string GetSourceEpilogue(grpc_generator::File *file, const Parameters ¶ms); 81 82 } // namespace grpc_cpp_generator 83 84 #endif // GRPC_INTERNAL_COMPILER_CPP_GENERATOR_H 85