/** * Autogenerated by Thrift for thrift/compiler/test/fixtures/basic/src/module.thrift * * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING * @generated @nocommit */ #include #include "thrift/compiler/test/fixtures/basic/gen-cpp2/module_metadata.h" // some of these functions can be so large that the compiler gives up optimizing // them - and issues a warning which may be treated as an error! // // these functions are so rarely called that it is probably okay for them not to // be optimized in practice FOLLY_CLANG_DISABLE_WARNING("-Wignored-optimization-argument") namespace apache { namespace thrift { namespace detail { namespace md { using ThriftMetadata = ::apache::thrift::metadata::ThriftMetadata; using ThriftPrimitiveType = ::apache::thrift::metadata::ThriftPrimitiveType; using ThriftType = ::apache::thrift::metadata::ThriftType; using ThriftService = ::apache::thrift::metadata::ThriftService; using ThriftServiceContext = ::apache::thrift::metadata::ThriftServiceContext; using ThriftFunctionGenerator = void (*)(ThriftMetadata&, ThriftService&); void EnumMetadata<::test::fixtures::basic::MyEnum>::gen(ThriftMetadata& metadata) { auto res = metadata.enums()->emplace("module.MyEnum", ::apache::thrift::metadata::ThriftEnum{}); if (!res.second) { return; } ::apache::thrift::metadata::ThriftEnum& enum_metadata = res.first->second; enum_metadata.name() = "module.MyEnum"; using EnumTraits = TEnumTraits<::test::fixtures::basic::MyEnum>; for (std::size_t i = 0; i != EnumTraits::size; ++i) { enum_metadata.elements()->emplace(static_cast(EnumTraits::values[i]), EnumTraits::names[i]); } } void EnumMetadata<::test::fixtures::basic::HackEnum>::gen(ThriftMetadata& metadata) { auto res = metadata.enums()->emplace("module.HackEnum", ::apache::thrift::metadata::ThriftEnum{}); if (!res.second) { return; } ::apache::thrift::metadata::ThriftEnum& enum_metadata = res.first->second; enum_metadata.name() = "module.HackEnum"; using EnumTraits = TEnumTraits<::test::fixtures::basic::HackEnum>; for (std::size_t i = 0; i != EnumTraits::size; ++i) { enum_metadata.elements()->emplace(static_cast(EnumTraits::values[i]), EnumTraits::names[i]); } enum_metadata.structured_annotations()->push_back(*cvStruct("hack.Name", { {"name", cvString("RenamedEnum") } }).cv_struct_ref()); } const ::apache::thrift::metadata::ThriftStruct& StructMetadata<::test::fixtures::basic::MyStruct>::gen(ThriftMetadata& metadata) { auto res = metadata.structs()->emplace("module.MyStruct", ::apache::thrift::metadata::ThriftStruct{}); if (!res.second) { return res.first->second; } ::apache::thrift::metadata::ThriftStruct& module_MyStruct = res.first->second; module_MyStruct.name() = "module.MyStruct"; module_MyStruct.is_union() = false; static const auto* const module_MyStruct_fields = new std::array{ { { 1, "MyIntField", false, std::make_unique(ThriftPrimitiveType::THRIFT_I64_TYPE), std::vector{ }}, { 2, "MyStringField", false, std::make_unique(ThriftPrimitiveType::THRIFT_STRING_TYPE), std::vector{ }}, { 3, "MyDataField", false, std::make_unique>("module.MyDataItem"), std::vector{ }}, { 4, "myEnum", false, std::make_unique>("module.MyEnum"), std::vector{ }}, { 5, "oneway", false, std::make_unique(ThriftPrimitiveType::THRIFT_BOOL_TYPE), std::vector{ }}, { 6, "readonly", false, std::make_unique(ThriftPrimitiveType::THRIFT_BOOL_TYPE), std::vector{ }}, { 7, "idempotent", false, std::make_unique(ThriftPrimitiveType::THRIFT_BOOL_TYPE), std::vector{ }}, { 8, "floatSet", false, std::make_unique(std::make_unique(ThriftPrimitiveType::THRIFT_FLOAT_TYPE)), std::vector{ *cvStruct("hack.SkipCodegen", { {"reason", cvString("Invalid key type") } }).cv_struct_ref(), }}, { 9, "no_hack_codegen_field", false, std::make_unique(ThriftPrimitiveType::THRIFT_STRING_TYPE), std::vector{ *cvStruct("hack.SkipCodegen", { {"reason", cvString("skip field codegen for deprecation") } }).cv_struct_ref(), }}, }}; for (const auto& f : *module_MyStruct_fields) { ::apache::thrift::metadata::ThriftField field; field.id() = f.id; field.name() = f.name; field.is_optional() = f.is_optional; f.metadata_type_interface->writeAndGenType(*field.type(), metadata); field.structured_annotations() = f.structured_annotations; module_MyStruct.fields()->push_back(std::move(field)); } return res.first->second; } const ::apache::thrift::metadata::ThriftStruct& StructMetadata<::test::fixtures::basic::MyDataItem>::gen(ThriftMetadata& metadata) { auto res = metadata.structs()->emplace("module.MyDataItem", ::apache::thrift::metadata::ThriftStruct{}); if (!res.second) { return res.first->second; } ::apache::thrift::metadata::ThriftStruct& module_MyDataItem = res.first->second; module_MyDataItem.name() = "module.MyDataItem"; module_MyDataItem.is_union() = false; return res.first->second; } const ::apache::thrift::metadata::ThriftStruct& StructMetadata<::test::fixtures::basic::MyUnion>::gen(ThriftMetadata& metadata) { auto res = metadata.structs()->emplace("module.MyUnion", ::apache::thrift::metadata::ThriftStruct{}); if (!res.second) { return res.first->second; } ::apache::thrift::metadata::ThriftStruct& module_MyUnion = res.first->second; module_MyUnion.name() = "module.MyUnion"; module_MyUnion.is_union() = true; static const auto* const module_MyUnion_fields = new std::array{ { { 1, "myEnum", false, std::make_unique>("module.MyEnum"), std::vector{ }}, { 2, "myStruct", false, std::make_unique>("module.MyStruct"), std::vector{ }}, { 3, "myDataItem", false, std::make_unique>("module.MyDataItem"), std::vector{ }}, { 4, "floatSet", false, std::make_unique(std::make_unique(ThriftPrimitiveType::THRIFT_FLOAT_TYPE)), std::vector{ *cvStruct("hack.SkipCodegen", { {"reason", cvString("Invalid key type") } }).cv_struct_ref(), }}, }}; for (const auto& f : *module_MyUnion_fields) { ::apache::thrift::metadata::ThriftField field; field.id() = f.id; field.name() = f.name; field.is_optional() = f.is_optional; f.metadata_type_interface->writeAndGenType(*field.type(), metadata); field.structured_annotations() = f.structured_annotations; module_MyUnion.fields()->push_back(std::move(field)); } return res.first->second; } const ::apache::thrift::metadata::ThriftStruct& StructMetadata<::test::fixtures::basic::ReservedKeyword>::gen(ThriftMetadata& metadata) { auto res = metadata.structs()->emplace("module.ReservedKeyword", ::apache::thrift::metadata::ThriftStruct{}); if (!res.second) { return res.first->second; } ::apache::thrift::metadata::ThriftStruct& module_ReservedKeyword = res.first->second; module_ReservedKeyword.name() = "module.ReservedKeyword"; module_ReservedKeyword.is_union() = false; static const auto* const module_ReservedKeyword_fields = new std::array{ { { 1, "reserved_field", false, std::make_unique(ThriftPrimitiveType::THRIFT_I32_TYPE), std::vector{ *cvStruct("hack.Name", { {"name", cvString("renamed_field") } }).cv_struct_ref(), }}, }}; for (const auto& f : *module_ReservedKeyword_fields) { ::apache::thrift::metadata::ThriftField field; field.id() = f.id; field.name() = f.name; field.is_optional() = f.is_optional; f.metadata_type_interface->writeAndGenType(*field.type(), metadata); field.structured_annotations() = f.structured_annotations; module_ReservedKeyword.fields()->push_back(std::move(field)); } module_ReservedKeyword.structured_annotations()->push_back(*cvStruct("hack.Name", { {"name", cvString("MyRenamedStruct") } }).cv_struct_ref()); return res.first->second; } const ::apache::thrift::metadata::ThriftStruct& StructMetadata<::test::fixtures::basic::UnionToBeRenamed>::gen(ThriftMetadata& metadata) { auto res = metadata.structs()->emplace("module.UnionToBeRenamed", ::apache::thrift::metadata::ThriftStruct{}); if (!res.second) { return res.first->second; } ::apache::thrift::metadata::ThriftStruct& module_UnionToBeRenamed = res.first->second; module_UnionToBeRenamed.name() = "module.UnionToBeRenamed"; module_UnionToBeRenamed.is_union() = true; static const auto* const module_UnionToBeRenamed_fields = new std::array{ { { 1, "reserved_field", false, std::make_unique(ThriftPrimitiveType::THRIFT_I32_TYPE), std::vector{ *cvStruct("hack.Name", { {"name", cvString("renamed_field") } }).cv_struct_ref(), }}, }}; for (const auto& f : *module_UnionToBeRenamed_fields) { ::apache::thrift::metadata::ThriftField field; field.id() = f.id; field.name() = f.name; field.is_optional() = f.is_optional; f.metadata_type_interface->writeAndGenType(*field.type(), metadata); field.structured_annotations() = f.structured_annotations; module_UnionToBeRenamed.fields()->push_back(std::move(field)); } module_UnionToBeRenamed.structured_annotations()->push_back(*cvStruct("hack.Name", { {"name", cvString("MyRenamedUnion") } }).cv_struct_ref()); return res.first->second; } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::FooService>>::gen_simple_rpc([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "simple_rpc"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_VOID_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); func.is_oneway() = false; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::FooService>>::gen(::apache::thrift::metadata::ThriftServiceMetadataResponse& response) { const ::apache::thrift::metadata::ThriftServiceContextRef* self = genRecurse(*response.metadata(), *response.services()); DCHECK(self != nullptr); // TODO(praihan): Remove ThriftServiceContext from response. But in the meantime, we need to fill the field with the result of looking up in ThriftMetadata. ::apache::thrift::metadata::ThriftServiceContext context; context.module() = *self->module(); context.service_info() = response.metadata()->services()->at(*self->service_name()); response.context() = std::move(context); } const ThriftServiceContextRef* ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::FooService>>::genRecurse([[maybe_unused]] ThriftMetadata& metadata, std::vector& services) { ::apache::thrift::metadata::ThriftService module_FooService; module_FooService.name() = "module.FooService"; static const ThriftFunctionGenerator functions[] = { ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::FooService>>::gen_simple_rpc, }; for (auto& function_gen : functions) { function_gen(metadata, module_FooService); } // We need to keep the index around because a reference or iterator could be invalidated. auto selfIndex = services.size(); services.emplace_back(); module_FooService.structured_annotations()->push_back(*cvStruct("hack.Name", { {"name", cvString("RenamedService") } }).cv_struct_ref()); ThriftServiceContextRef& context = services[selfIndex]; metadata.services()->emplace("module.FooService", std::move(module_FooService)); context.service_name() = "module.FooService"; ::apache::thrift::metadata::ThriftModuleContext module; module.name() = "module"; context.module() = std::move(module); return &context; } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::FB303Service>>::gen_simple_rpc([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "simple_rpc"; auto func_ret_type = std::make_unique>("module.ReservedKeyword"); func_ret_type->writeAndGenType(*func.return_type(), metadata); ::apache::thrift::metadata::ThriftField module_FB303Service_simple_rpc_int_parameter_1; module_FB303Service_simple_rpc_int_parameter_1.id() = 1; module_FB303Service_simple_rpc_int_parameter_1.name() = "int_parameter"; module_FB303Service_simple_rpc_int_parameter_1.is_optional() = false; module_FB303Service_simple_rpc_int_parameter_1.structured_annotations() = { *cvStruct("hack.Name", { {"name", cvString("renamed_parameter") } }).cv_struct_ref(), }; auto module_FB303Service_simple_rpc_int_parameter_1_type = std::make_unique(ThriftPrimitiveType::THRIFT_I32_TYPE); module_FB303Service_simple_rpc_int_parameter_1_type->writeAndGenType(*module_FB303Service_simple_rpc_int_parameter_1.type(), metadata); func.arguments()->push_back(std::move(module_FB303Service_simple_rpc_int_parameter_1)); func.is_oneway() = false; func.structured_annotations()->push_back(*cvStruct("hack.Name", { {"name", cvString("renamed_rpc") } }).cv_struct_ref()); service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::FB303Service>>::gen(::apache::thrift::metadata::ThriftServiceMetadataResponse& response) { const ::apache::thrift::metadata::ThriftServiceContextRef* self = genRecurse(*response.metadata(), *response.services()); DCHECK(self != nullptr); // TODO(praihan): Remove ThriftServiceContext from response. But in the meantime, we need to fill the field with the result of looking up in ThriftMetadata. ::apache::thrift::metadata::ThriftServiceContext context; context.module() = *self->module(); context.service_info() = response.metadata()->services()->at(*self->service_name()); response.context() = std::move(context); } const ThriftServiceContextRef* ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::FB303Service>>::genRecurse([[maybe_unused]] ThriftMetadata& metadata, std::vector& services) { ::apache::thrift::metadata::ThriftService module_FB303Service; module_FB303Service.name() = "module.FB303Service"; static const ThriftFunctionGenerator functions[] = { ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::FB303Service>>::gen_simple_rpc, }; for (auto& function_gen : functions) { function_gen(metadata, module_FB303Service); } // We need to keep the index around because a reference or iterator could be invalidated. auto selfIndex = services.size(); services.emplace_back(); ThriftServiceContextRef& context = services[selfIndex]; metadata.services()->emplace("module.FB303Service", std::move(module_FB303Service)); context.service_name() = "module.FB303Service"; ::apache::thrift::metadata::ThriftModuleContext module; module.name() = "module"; context.module() = std::move(module); return &context; } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_ping([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "ping"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_VOID_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); func.is_oneway() = false; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_getRandomData([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "getRandomData"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_STRING_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); func.is_oneway() = false; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_sink([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "sink"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_VOID_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); ::apache::thrift::metadata::ThriftField module_MyService_sink_sink_1; module_MyService_sink_sink_1.id() = 1; module_MyService_sink_sink_1.name() = "sink"; module_MyService_sink_sink_1.is_optional() = false; auto module_MyService_sink_sink_1_type = std::make_unique(ThriftPrimitiveType::THRIFT_I64_TYPE); module_MyService_sink_sink_1_type->writeAndGenType(*module_MyService_sink_sink_1.type(), metadata); func.arguments()->push_back(std::move(module_MyService_sink_sink_1)); func.is_oneway() = false; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_putDataById([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "putDataById"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_VOID_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); ::apache::thrift::metadata::ThriftField module_MyService_putDataById_id_1; module_MyService_putDataById_id_1.id() = 1; module_MyService_putDataById_id_1.name() = "id"; module_MyService_putDataById_id_1.is_optional() = false; auto module_MyService_putDataById_id_1_type = std::make_unique(ThriftPrimitiveType::THRIFT_I64_TYPE); module_MyService_putDataById_id_1_type->writeAndGenType(*module_MyService_putDataById_id_1.type(), metadata); func.arguments()->push_back(std::move(module_MyService_putDataById_id_1)); ::apache::thrift::metadata::ThriftField module_MyService_putDataById_data_2; module_MyService_putDataById_data_2.id() = 2; module_MyService_putDataById_data_2.name() = "data"; module_MyService_putDataById_data_2.is_optional() = false; auto module_MyService_putDataById_data_2_type = std::make_unique(ThriftPrimitiveType::THRIFT_STRING_TYPE); module_MyService_putDataById_data_2_type->writeAndGenType(*module_MyService_putDataById_data_2.type(), metadata); func.arguments()->push_back(std::move(module_MyService_putDataById_data_2)); func.is_oneway() = false; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_hasDataById([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "hasDataById"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_BOOL_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); ::apache::thrift::metadata::ThriftField module_MyService_hasDataById_id_1; module_MyService_hasDataById_id_1.id() = 1; module_MyService_hasDataById_id_1.name() = "id"; module_MyService_hasDataById_id_1.is_optional() = false; auto module_MyService_hasDataById_id_1_type = std::make_unique(ThriftPrimitiveType::THRIFT_I64_TYPE); module_MyService_hasDataById_id_1_type->writeAndGenType(*module_MyService_hasDataById_id_1.type(), metadata); func.arguments()->push_back(std::move(module_MyService_hasDataById_id_1)); func.is_oneway() = false; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_getDataById([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "getDataById"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_STRING_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); ::apache::thrift::metadata::ThriftField module_MyService_getDataById_id_1; module_MyService_getDataById_id_1.id() = 1; module_MyService_getDataById_id_1.name() = "id"; module_MyService_getDataById_id_1.is_optional() = false; auto module_MyService_getDataById_id_1_type = std::make_unique(ThriftPrimitiveType::THRIFT_I64_TYPE); module_MyService_getDataById_id_1_type->writeAndGenType(*module_MyService_getDataById_id_1.type(), metadata); func.arguments()->push_back(std::move(module_MyService_getDataById_id_1)); func.is_oneway() = false; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_deleteDataById([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "deleteDataById"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_VOID_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); ::apache::thrift::metadata::ThriftField module_MyService_deleteDataById_id_1; module_MyService_deleteDataById_id_1.id() = 1; module_MyService_deleteDataById_id_1.name() = "id"; module_MyService_deleteDataById_id_1.is_optional() = false; auto module_MyService_deleteDataById_id_1_type = std::make_unique(ThriftPrimitiveType::THRIFT_I64_TYPE); module_MyService_deleteDataById_id_1_type->writeAndGenType(*module_MyService_deleteDataById_id_1.type(), metadata); func.arguments()->push_back(std::move(module_MyService_deleteDataById_id_1)); func.is_oneway() = false; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_lobDataById([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "lobDataById"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_VOID_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); ::apache::thrift::metadata::ThriftField module_MyService_lobDataById_id_1; module_MyService_lobDataById_id_1.id() = 1; module_MyService_lobDataById_id_1.name() = "id"; module_MyService_lobDataById_id_1.is_optional() = false; auto module_MyService_lobDataById_id_1_type = std::make_unique(ThriftPrimitiveType::THRIFT_I64_TYPE); module_MyService_lobDataById_id_1_type->writeAndGenType(*module_MyService_lobDataById_id_1.type(), metadata); func.arguments()->push_back(std::move(module_MyService_lobDataById_id_1)); ::apache::thrift::metadata::ThriftField module_MyService_lobDataById_data_2; module_MyService_lobDataById_data_2.id() = 2; module_MyService_lobDataById_data_2.name() = "data"; module_MyService_lobDataById_data_2.is_optional() = false; auto module_MyService_lobDataById_data_2_type = std::make_unique(ThriftPrimitiveType::THRIFT_STRING_TYPE); module_MyService_lobDataById_data_2_type->writeAndGenType(*module_MyService_lobDataById_data_2.type(), metadata); func.arguments()->push_back(std::move(module_MyService_lobDataById_data_2)); func.is_oneway() = true; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_invalid_return_for_hack([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "invalid_return_for_hack"; auto func_ret_type = std::make_unique(std::make_unique(ThriftPrimitiveType::THRIFT_FLOAT_TYPE)); func_ret_type->writeAndGenType(*func.return_type(), metadata); func.is_oneway() = false; func.structured_annotations()->push_back(*cvStruct("hack.SkipCodegen", { {"reason", cvString("Invalid key type") } }).cv_struct_ref()); service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_rpc_skipped_codegen([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "rpc_skipped_codegen"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_VOID_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); func.is_oneway() = false; func.structured_annotations()->push_back(*cvStruct("hack.SkipCodegen", { {"reason", cvString("Skip function deprecation") } }).cv_struct_ref()); service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen(::apache::thrift::metadata::ThriftServiceMetadataResponse& response) { const ::apache::thrift::metadata::ThriftServiceContextRef* self = genRecurse(*response.metadata(), *response.services()); DCHECK(self != nullptr); // TODO(praihan): Remove ThriftServiceContext from response. But in the meantime, we need to fill the field with the result of looking up in ThriftMetadata. ::apache::thrift::metadata::ThriftServiceContext context; context.module() = *self->module(); context.service_info() = response.metadata()->services()->at(*self->service_name()); response.context() = std::move(context); } const ThriftServiceContextRef* ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::genRecurse([[maybe_unused]] ThriftMetadata& metadata, std::vector& services) { ::apache::thrift::metadata::ThriftService module_MyService; module_MyService.name() = "module.MyService"; static const ThriftFunctionGenerator functions[] = { ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_ping, ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_getRandomData, ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_sink, ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_putDataById, ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_hasDataById, ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_getDataById, ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_deleteDataById, ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_lobDataById, ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_invalid_return_for_hack, ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::MyService>>::gen_rpc_skipped_codegen, }; for (auto& function_gen : functions) { function_gen(metadata, module_MyService); } // We need to keep the index around because a reference or iterator could be invalidated. auto selfIndex = services.size(); services.emplace_back(); ThriftServiceContextRef& context = services[selfIndex]; metadata.services()->emplace("module.MyService", std::move(module_MyService)); context.service_name() = "module.MyService"; ::apache::thrift::metadata::ThriftModuleContext module; module.name() = "module"; context.module() = std::move(module); return &context; } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::DbMixedStackArguments>>::gen_getDataByKey0([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "getDataByKey0"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_BINARY_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); ::apache::thrift::metadata::ThriftField module_DbMixedStackArguments_getDataByKey0_key_1; module_DbMixedStackArguments_getDataByKey0_key_1.id() = 1; module_DbMixedStackArguments_getDataByKey0_key_1.name() = "key"; module_DbMixedStackArguments_getDataByKey0_key_1.is_optional() = false; auto module_DbMixedStackArguments_getDataByKey0_key_1_type = std::make_unique(ThriftPrimitiveType::THRIFT_STRING_TYPE); module_DbMixedStackArguments_getDataByKey0_key_1_type->writeAndGenType(*module_DbMixedStackArguments_getDataByKey0_key_1.type(), metadata); func.arguments()->push_back(std::move(module_DbMixedStackArguments_getDataByKey0_key_1)); func.is_oneway() = false; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::DbMixedStackArguments>>::gen_getDataByKey1([[maybe_unused]] ThriftMetadata& metadata, ThriftService& service) { ::apache::thrift::metadata::ThriftFunction func; func.name() = "getDataByKey1"; auto func_ret_type = std::make_unique(ThriftPrimitiveType::THRIFT_BINARY_TYPE); func_ret_type->writeAndGenType(*func.return_type(), metadata); ::apache::thrift::metadata::ThriftField module_DbMixedStackArguments_getDataByKey1_key_1; module_DbMixedStackArguments_getDataByKey1_key_1.id() = 1; module_DbMixedStackArguments_getDataByKey1_key_1.name() = "key"; module_DbMixedStackArguments_getDataByKey1_key_1.is_optional() = false; auto module_DbMixedStackArguments_getDataByKey1_key_1_type = std::make_unique(ThriftPrimitiveType::THRIFT_STRING_TYPE); module_DbMixedStackArguments_getDataByKey1_key_1_type->writeAndGenType(*module_DbMixedStackArguments_getDataByKey1_key_1.type(), metadata); func.arguments()->push_back(std::move(module_DbMixedStackArguments_getDataByKey1_key_1)); func.is_oneway() = false; service.functions()->push_back(std::move(func)); } void ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::DbMixedStackArguments>>::gen(::apache::thrift::metadata::ThriftServiceMetadataResponse& response) { const ::apache::thrift::metadata::ThriftServiceContextRef* self = genRecurse(*response.metadata(), *response.services()); DCHECK(self != nullptr); // TODO(praihan): Remove ThriftServiceContext from response. But in the meantime, we need to fill the field with the result of looking up in ThriftMetadata. ::apache::thrift::metadata::ThriftServiceContext context; context.module() = *self->module(); context.service_info() = response.metadata()->services()->at(*self->service_name()); response.context() = std::move(context); } const ThriftServiceContextRef* ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::DbMixedStackArguments>>::genRecurse([[maybe_unused]] ThriftMetadata& metadata, std::vector& services) { ::apache::thrift::metadata::ThriftService module_DbMixedStackArguments; module_DbMixedStackArguments.name() = "module.DbMixedStackArguments"; static const ThriftFunctionGenerator functions[] = { ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::DbMixedStackArguments>>::gen_getDataByKey0, ServiceMetadata<::apache::thrift::ServiceHandler<::test::fixtures::basic::DbMixedStackArguments>>::gen_getDataByKey1, }; for (auto& function_gen : functions) { function_gen(metadata, module_DbMixedStackArguments); } // We need to keep the index around because a reference or iterator could be invalidated. auto selfIndex = services.size(); services.emplace_back(); ThriftServiceContextRef& context = services[selfIndex]; metadata.services()->emplace("module.DbMixedStackArguments", std::move(module_DbMixedStackArguments)); context.service_name() = "module.DbMixedStackArguments"; ::apache::thrift::metadata::ThriftModuleContext module; module.name() = "module"; context.module() = std::move(module); return &context; } } // namespace md } // namespace detail } // namespace thrift } // namespace apache