397 lines
23 KiB
C++
397 lines
23 KiB
C++
// 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 <functional>
|
|
#include <grpcpp/generic/async_generic_service.h>
|
|
#include <grpcpp/support/async_stream.h>
|
|
#include <grpcpp/support/async_unary_call.h>
|
|
#include <grpcpp/support/client_callback.h>
|
|
#include <grpcpp/client_context.h>
|
|
#include <grpcpp/completion_queue.h>
|
|
#include <grpcpp/support/message_allocator.h>
|
|
#include <grpcpp/support/method_handler.h>
|
|
#include <grpcpp/impl/proto_utils.h>
|
|
#include <grpcpp/impl/rpc_method.h>
|
|
#include <grpcpp/support/server_callback.h>
|
|
#include <grpcpp/impl/server_callback_handlers.h>
|
|
#include <grpcpp/server_context.h>
|
|
#include <grpcpp/impl/service_type.h>
|
|
#include <grpcpp/support/status.h>
|
|
#include <grpcpp/support/stub_options.h>
|
|
#include <grpcpp/support/sync_stream.h>
|
|
|
|
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<void(::grpc::Status)>) = 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<void(::grpc::Status)>) 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<Stub> 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 BaseClass>
|
|
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 BaseClass>
|
|
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<WithAsyncMethod_StreamMarketData<Service > > AsyncService;
|
|
template <class BaseClass>
|
|
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 BaseClass>
|
|
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<WithCallbackMethod_StreamMarketData<Service > > CallbackService;
|
|
typedef CallbackService ExperimentalCallbackService;
|
|
template <class BaseClass>
|
|
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 BaseClass>
|
|
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 BaseClass>
|
|
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 BaseClass>
|
|
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 BaseClass>
|
|
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 BaseClass>
|
|
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 BaseClass>
|
|
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<Service > StreamedUnaryService;
|
|
template <class BaseClass>
|
|
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<Service > SplitStreamedService;
|
|
typedef WithStreamedUnaryMethod_SendOrder<WithSplitStreamingMethod_StreamMarketData<Service > > StreamedService;
|
|
};
|
|
|
|
} // namespace trading
|
|
|
|
|
|
#endif // GRPC_trading_2eproto__INCLUDED
|