// Generated by the gRPC C++ plugin. // If you make any local change, they will be lost. // source: trading.proto #ifndef GRPC_trading_2eproto__INCLUDED #define GRPC_trading_2eproto__INCLUDED #include "trading.pb.h" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include namespace trading { class TradingService final { public: static constexpr char const* service_full_name() { return "trading.TradingService"; } class StubInterface { public: virtual ~StubInterface() {} virtual ::grpc::Status SendOrder(::grpc::ClientContext* context, const ::trading::Order& request, ::trading::OrderAck* response) = 0; std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::trading::OrderAck>> AsyncSendOrder(::grpc::ClientContext* context, const ::trading::Order& request, ::grpc::CompletionQueue* cq) { return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::trading::OrderAck>>(AsyncSendOrderRaw(context, request, cq)); } std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::trading::OrderAck>> PrepareAsyncSendOrder(::grpc::ClientContext* context, const ::trading::Order& request, ::grpc::CompletionQueue* cq) { return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::trading::OrderAck>>(PrepareAsyncSendOrderRaw(context, request, cq)); } std::unique_ptr< ::grpc::ClientReaderInterface< ::trading::MarketData>> StreamMarketData(::grpc::ClientContext* context, const ::trading::MarketRequest& request) { return std::unique_ptr< ::grpc::ClientReaderInterface< ::trading::MarketData>>(StreamMarketDataRaw(context, request)); } std::unique_ptr< ::grpc::ClientAsyncReaderInterface< ::trading::MarketData>> AsyncStreamMarketData(::grpc::ClientContext* context, const ::trading::MarketRequest& request, ::grpc::CompletionQueue* cq, void* tag) { return std::unique_ptr< ::grpc::ClientAsyncReaderInterface< ::trading::MarketData>>(AsyncStreamMarketDataRaw(context, request, cq, tag)); } std::unique_ptr< ::grpc::ClientAsyncReaderInterface< ::trading::MarketData>> PrepareAsyncStreamMarketData(::grpc::ClientContext* context, const ::trading::MarketRequest& request, ::grpc::CompletionQueue* cq) { return std::unique_ptr< ::grpc::ClientAsyncReaderInterface< ::trading::MarketData>>(PrepareAsyncStreamMarketDataRaw(context, request, cq)); } class async_interface { public: virtual ~async_interface() {} virtual void SendOrder(::grpc::ClientContext* context, const ::trading::Order* request, ::trading::OrderAck* response, std::function) = 0; virtual void SendOrder(::grpc::ClientContext* context, const ::trading::Order* request, ::trading::OrderAck* response, ::grpc::ClientUnaryReactor* reactor) = 0; virtual void StreamMarketData(::grpc::ClientContext* context, const ::trading::MarketRequest* request, ::grpc::ClientReadReactor< ::trading::MarketData>* reactor) = 0; }; typedef class async_interface experimental_async_interface; virtual class async_interface* async() { return nullptr; } class async_interface* experimental_async() { return async(); } private: virtual ::grpc::ClientAsyncResponseReaderInterface< ::trading::OrderAck>* AsyncSendOrderRaw(::grpc::ClientContext* context, const ::trading::Order& request, ::grpc::CompletionQueue* cq) = 0; virtual ::grpc::ClientAsyncResponseReaderInterface< ::trading::OrderAck>* PrepareAsyncSendOrderRaw(::grpc::ClientContext* context, const ::trading::Order& request, ::grpc::CompletionQueue* cq) = 0; virtual ::grpc::ClientReaderInterface< ::trading::MarketData>* StreamMarketDataRaw(::grpc::ClientContext* context, const ::trading::MarketRequest& request) = 0; virtual ::grpc::ClientAsyncReaderInterface< ::trading::MarketData>* AsyncStreamMarketDataRaw(::grpc::ClientContext* context, const ::trading::MarketRequest& request, ::grpc::CompletionQueue* cq, void* tag) = 0; virtual ::grpc::ClientAsyncReaderInterface< ::trading::MarketData>* PrepareAsyncStreamMarketDataRaw(::grpc::ClientContext* context, const ::trading::MarketRequest& request, ::grpc::CompletionQueue* cq) = 0; }; class Stub final : public StubInterface { public: Stub(const std::shared_ptr< ::grpc::ChannelInterface>& channel, const ::grpc::StubOptions& options = ::grpc::StubOptions()); ::grpc::Status SendOrder(::grpc::ClientContext* context, const ::trading::Order& request, ::trading::OrderAck* response) override; std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::trading::OrderAck>> AsyncSendOrder(::grpc::ClientContext* context, const ::trading::Order& request, ::grpc::CompletionQueue* cq) { return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::trading::OrderAck>>(AsyncSendOrderRaw(context, request, cq)); } std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::trading::OrderAck>> PrepareAsyncSendOrder(::grpc::ClientContext* context, const ::trading::Order& request, ::grpc::CompletionQueue* cq) { return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::trading::OrderAck>>(PrepareAsyncSendOrderRaw(context, request, cq)); } std::unique_ptr< ::grpc::ClientReader< ::trading::MarketData>> StreamMarketData(::grpc::ClientContext* context, const ::trading::MarketRequest& request) { return std::unique_ptr< ::grpc::ClientReader< ::trading::MarketData>>(StreamMarketDataRaw(context, request)); } std::unique_ptr< ::grpc::ClientAsyncReader< ::trading::MarketData>> AsyncStreamMarketData(::grpc::ClientContext* context, const ::trading::MarketRequest& request, ::grpc::CompletionQueue* cq, void* tag) { return std::unique_ptr< ::grpc::ClientAsyncReader< ::trading::MarketData>>(AsyncStreamMarketDataRaw(context, request, cq, tag)); } std::unique_ptr< ::grpc::ClientAsyncReader< ::trading::MarketData>> PrepareAsyncStreamMarketData(::grpc::ClientContext* context, const ::trading::MarketRequest& request, ::grpc::CompletionQueue* cq) { return std::unique_ptr< ::grpc::ClientAsyncReader< ::trading::MarketData>>(PrepareAsyncStreamMarketDataRaw(context, request, cq)); } class async final : public StubInterface::async_interface { public: void SendOrder(::grpc::ClientContext* context, const ::trading::Order* request, ::trading::OrderAck* response, std::function) override; void SendOrder(::grpc::ClientContext* context, const ::trading::Order* request, ::trading::OrderAck* response, ::grpc::ClientUnaryReactor* reactor) override; void StreamMarketData(::grpc::ClientContext* context, const ::trading::MarketRequest* request, ::grpc::ClientReadReactor< ::trading::MarketData>* reactor) override; private: friend class Stub; explicit async(Stub* stub): stub_(stub) { } Stub* stub() { return stub_; } Stub* stub_; }; class async* async() override { return &async_stub_; } private: std::shared_ptr< ::grpc::ChannelInterface> channel_; class async async_stub_{this}; ::grpc::ClientAsyncResponseReader< ::trading::OrderAck>* AsyncSendOrderRaw(::grpc::ClientContext* context, const ::trading::Order& request, ::grpc::CompletionQueue* cq) override; ::grpc::ClientAsyncResponseReader< ::trading::OrderAck>* PrepareAsyncSendOrderRaw(::grpc::ClientContext* context, const ::trading::Order& request, ::grpc::CompletionQueue* cq) override; ::grpc::ClientReader< ::trading::MarketData>* StreamMarketDataRaw(::grpc::ClientContext* context, const ::trading::MarketRequest& request) override; ::grpc::ClientAsyncReader< ::trading::MarketData>* AsyncStreamMarketDataRaw(::grpc::ClientContext* context, const ::trading::MarketRequest& request, ::grpc::CompletionQueue* cq, void* tag) override; ::grpc::ClientAsyncReader< ::trading::MarketData>* PrepareAsyncStreamMarketDataRaw(::grpc::ClientContext* context, const ::trading::MarketRequest& request, ::grpc::CompletionQueue* cq) override; const ::grpc::internal::RpcMethod rpcmethod_SendOrder_; const ::grpc::internal::RpcMethod rpcmethod_StreamMarketData_; }; static std::unique_ptr NewStub(const std::shared_ptr< ::grpc::ChannelInterface>& channel, const ::grpc::StubOptions& options = ::grpc::StubOptions()); class Service : public ::grpc::Service { public: Service(); virtual ~Service(); virtual ::grpc::Status SendOrder(::grpc::ServerContext* context, const ::trading::Order* request, ::trading::OrderAck* response); virtual ::grpc::Status StreamMarketData(::grpc::ServerContext* context, const ::trading::MarketRequest* request, ::grpc::ServerWriter< ::trading::MarketData>* writer); }; template class WithAsyncMethod_SendOrder : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithAsyncMethod_SendOrder() { ::grpc::Service::MarkMethodAsync(0); } ~WithAsyncMethod_SendOrder() override { BaseClassMustBeDerivedFromService(this); } // disable synchronous version of this method ::grpc::Status SendOrder(::grpc::ServerContext* /*context*/, const ::trading::Order* /*request*/, ::trading::OrderAck* /*response*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } void RequestSendOrder(::grpc::ServerContext* context, ::trading::Order* request, ::grpc::ServerAsyncResponseWriter< ::trading::OrderAck>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) { ::grpc::Service::RequestAsyncUnary(0, context, request, response, new_call_cq, notification_cq, tag); } }; template class WithAsyncMethod_StreamMarketData : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithAsyncMethod_StreamMarketData() { ::grpc::Service::MarkMethodAsync(1); } ~WithAsyncMethod_StreamMarketData() override { BaseClassMustBeDerivedFromService(this); } // disable synchronous version of this method ::grpc::Status StreamMarketData(::grpc::ServerContext* /*context*/, const ::trading::MarketRequest* /*request*/, ::grpc::ServerWriter< ::trading::MarketData>* /*writer*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } void RequestStreamMarketData(::grpc::ServerContext* context, ::trading::MarketRequest* request, ::grpc::ServerAsyncWriter< ::trading::MarketData>* writer, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) { ::grpc::Service::RequestAsyncServerStreaming(1, context, request, writer, new_call_cq, notification_cq, tag); } }; typedef WithAsyncMethod_SendOrder > AsyncService; template class WithCallbackMethod_SendOrder : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithCallbackMethod_SendOrder() { ::grpc::Service::MarkMethodCallback(0, new ::grpc::internal::CallbackUnaryHandler< ::trading::Order, ::trading::OrderAck>( [this]( ::grpc::CallbackServerContext* context, const ::trading::Order* request, ::trading::OrderAck* response) { return this->SendOrder(context, request, response); }));} void SetMessageAllocatorFor_SendOrder( ::grpc::MessageAllocator< ::trading::Order, ::trading::OrderAck>* allocator) { ::grpc::internal::MethodHandler* const handler = ::grpc::Service::GetHandler(0); static_cast<::grpc::internal::CallbackUnaryHandler< ::trading::Order, ::trading::OrderAck>*>(handler) ->SetMessageAllocator(allocator); } ~WithCallbackMethod_SendOrder() override { BaseClassMustBeDerivedFromService(this); } // disable synchronous version of this method ::grpc::Status SendOrder(::grpc::ServerContext* /*context*/, const ::trading::Order* /*request*/, ::trading::OrderAck* /*response*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } virtual ::grpc::ServerUnaryReactor* SendOrder( ::grpc::CallbackServerContext* /*context*/, const ::trading::Order* /*request*/, ::trading::OrderAck* /*response*/) { return nullptr; } }; template class WithCallbackMethod_StreamMarketData : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithCallbackMethod_StreamMarketData() { ::grpc::Service::MarkMethodCallback(1, new ::grpc::internal::CallbackServerStreamingHandler< ::trading::MarketRequest, ::trading::MarketData>( [this]( ::grpc::CallbackServerContext* context, const ::trading::MarketRequest* request) { return this->StreamMarketData(context, request); })); } ~WithCallbackMethod_StreamMarketData() override { BaseClassMustBeDerivedFromService(this); } // disable synchronous version of this method ::grpc::Status StreamMarketData(::grpc::ServerContext* /*context*/, const ::trading::MarketRequest* /*request*/, ::grpc::ServerWriter< ::trading::MarketData>* /*writer*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } virtual ::grpc::ServerWriteReactor< ::trading::MarketData>* StreamMarketData( ::grpc::CallbackServerContext* /*context*/, const ::trading::MarketRequest* /*request*/) { return nullptr; } }; typedef WithCallbackMethod_SendOrder > CallbackService; typedef CallbackService ExperimentalCallbackService; template class WithGenericMethod_SendOrder : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithGenericMethod_SendOrder() { ::grpc::Service::MarkMethodGeneric(0); } ~WithGenericMethod_SendOrder() override { BaseClassMustBeDerivedFromService(this); } // disable synchronous version of this method ::grpc::Status SendOrder(::grpc::ServerContext* /*context*/, const ::trading::Order* /*request*/, ::trading::OrderAck* /*response*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } }; template class WithGenericMethod_StreamMarketData : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithGenericMethod_StreamMarketData() { ::grpc::Service::MarkMethodGeneric(1); } ~WithGenericMethod_StreamMarketData() override { BaseClassMustBeDerivedFromService(this); } // disable synchronous version of this method ::grpc::Status StreamMarketData(::grpc::ServerContext* /*context*/, const ::trading::MarketRequest* /*request*/, ::grpc::ServerWriter< ::trading::MarketData>* /*writer*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } }; template class WithRawMethod_SendOrder : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithRawMethod_SendOrder() { ::grpc::Service::MarkMethodRaw(0); } ~WithRawMethod_SendOrder() override { BaseClassMustBeDerivedFromService(this); } // disable synchronous version of this method ::grpc::Status SendOrder(::grpc::ServerContext* /*context*/, const ::trading::Order* /*request*/, ::trading::OrderAck* /*response*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } void RequestSendOrder(::grpc::ServerContext* context, ::grpc::ByteBuffer* request, ::grpc::ServerAsyncResponseWriter< ::grpc::ByteBuffer>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) { ::grpc::Service::RequestAsyncUnary(0, context, request, response, new_call_cq, notification_cq, tag); } }; template class WithRawMethod_StreamMarketData : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithRawMethod_StreamMarketData() { ::grpc::Service::MarkMethodRaw(1); } ~WithRawMethod_StreamMarketData() override { BaseClassMustBeDerivedFromService(this); } // disable synchronous version of this method ::grpc::Status StreamMarketData(::grpc::ServerContext* /*context*/, const ::trading::MarketRequest* /*request*/, ::grpc::ServerWriter< ::trading::MarketData>* /*writer*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } void RequestStreamMarketData(::grpc::ServerContext* context, ::grpc::ByteBuffer* request, ::grpc::ServerAsyncWriter< ::grpc::ByteBuffer>* writer, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) { ::grpc::Service::RequestAsyncServerStreaming(1, context, request, writer, new_call_cq, notification_cq, tag); } }; template class WithRawCallbackMethod_SendOrder : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithRawCallbackMethod_SendOrder() { ::grpc::Service::MarkMethodRawCallback(0, new ::grpc::internal::CallbackUnaryHandler< ::grpc::ByteBuffer, ::grpc::ByteBuffer>( [this]( ::grpc::CallbackServerContext* context, const ::grpc::ByteBuffer* request, ::grpc::ByteBuffer* response) { return this->SendOrder(context, request, response); })); } ~WithRawCallbackMethod_SendOrder() override { BaseClassMustBeDerivedFromService(this); } // disable synchronous version of this method ::grpc::Status SendOrder(::grpc::ServerContext* /*context*/, const ::trading::Order* /*request*/, ::trading::OrderAck* /*response*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } virtual ::grpc::ServerUnaryReactor* SendOrder( ::grpc::CallbackServerContext* /*context*/, const ::grpc::ByteBuffer* /*request*/, ::grpc::ByteBuffer* /*response*/) { return nullptr; } }; template class WithRawCallbackMethod_StreamMarketData : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithRawCallbackMethod_StreamMarketData() { ::grpc::Service::MarkMethodRawCallback(1, new ::grpc::internal::CallbackServerStreamingHandler< ::grpc::ByteBuffer, ::grpc::ByteBuffer>( [this]( ::grpc::CallbackServerContext* context, const::grpc::ByteBuffer* request) { return this->StreamMarketData(context, request); })); } ~WithRawCallbackMethod_StreamMarketData() override { BaseClassMustBeDerivedFromService(this); } // disable synchronous version of this method ::grpc::Status StreamMarketData(::grpc::ServerContext* /*context*/, const ::trading::MarketRequest* /*request*/, ::grpc::ServerWriter< ::trading::MarketData>* /*writer*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } virtual ::grpc::ServerWriteReactor< ::grpc::ByteBuffer>* StreamMarketData( ::grpc::CallbackServerContext* /*context*/, const ::grpc::ByteBuffer* /*request*/) { return nullptr; } }; template class WithStreamedUnaryMethod_SendOrder : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithStreamedUnaryMethod_SendOrder() { ::grpc::Service::MarkMethodStreamed(0, new ::grpc::internal::StreamedUnaryHandler< ::trading::Order, ::trading::OrderAck>( [this](::grpc::ServerContext* context, ::grpc::ServerUnaryStreamer< ::trading::Order, ::trading::OrderAck>* streamer) { return this->StreamedSendOrder(context, streamer); })); } ~WithStreamedUnaryMethod_SendOrder() override { BaseClassMustBeDerivedFromService(this); } // disable regular version of this method ::grpc::Status SendOrder(::grpc::ServerContext* /*context*/, const ::trading::Order* /*request*/, ::trading::OrderAck* /*response*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } // replace default version of method with streamed unary virtual ::grpc::Status StreamedSendOrder(::grpc::ServerContext* context, ::grpc::ServerUnaryStreamer< ::trading::Order,::trading::OrderAck>* server_unary_streamer) = 0; }; typedef WithStreamedUnaryMethod_SendOrder StreamedUnaryService; template class WithSplitStreamingMethod_StreamMarketData : public BaseClass { private: void BaseClassMustBeDerivedFromService(const Service* /*service*/) {} public: WithSplitStreamingMethod_StreamMarketData() { ::grpc::Service::MarkMethodStreamed(1, new ::grpc::internal::SplitServerStreamingHandler< ::trading::MarketRequest, ::trading::MarketData>( [this](::grpc::ServerContext* context, ::grpc::ServerSplitStreamer< ::trading::MarketRequest, ::trading::MarketData>* streamer) { return this->StreamedStreamMarketData(context, streamer); })); } ~WithSplitStreamingMethod_StreamMarketData() override { BaseClassMustBeDerivedFromService(this); } // disable regular version of this method ::grpc::Status StreamMarketData(::grpc::ServerContext* /*context*/, const ::trading::MarketRequest* /*request*/, ::grpc::ServerWriter< ::trading::MarketData>* /*writer*/) override { abort(); return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); } // replace default version of method with split streamed virtual ::grpc::Status StreamedStreamMarketData(::grpc::ServerContext* context, ::grpc::ServerSplitStreamer< ::trading::MarketRequest,::trading::MarketData>* server_split_streamer) = 0; }; typedef WithSplitStreamingMethod_StreamMarketData SplitStreamedService; typedef WithStreamedUnaryMethod_SendOrder > StreamedService; }; } // namespace trading #endif // GRPC_trading_2eproto__INCLUDED