first commit
This commit is contained in:
commit
1c2342574c
8
.gitignore
vendored
Normal file
8
.gitignore
vendored
Normal file
@ -0,0 +1,8 @@
|
||||
*build*
|
||||
bin/
|
||||
cmake-build*
|
||||
.cache
|
||||
.idea
|
||||
.vscode
|
||||
.cache
|
||||
*__pycache__*
|
56
CMakeLists.txt
Normal file
56
CMakeLists.txt
Normal file
@ -0,0 +1,56 @@
|
||||
cmake_minimum_required(VERSION 3.0)
|
||||
|
||||
project(grpc)
|
||||
|
||||
set(CMAKE_CXX_STANDARD 20)
|
||||
|
||||
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
|
||||
|
||||
option(CMAKE_BUILD_TYPE Release) # Debug Release RelWithDebInfo
|
||||
|
||||
# set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fno-elide-constructors")
|
||||
# set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-elide-constructors")
|
||||
# set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fPIC")
|
||||
|
||||
if (${CMAKE_SYSTEM_NAME} STREQUAL "Linux")
|
||||
message("Building for Linux platform")
|
||||
elseif (${CMAKE_SYSTEM_NAME} STREQUAL "Darwin")
|
||||
message("Building for macOS platform")
|
||||
set(CMAKE_C_COMPILER "/opt/homebrew/bin/aarch64-apple-darwin23-gcc-14") # gcc clang` 指定c编译器
|
||||
set(CMAKE_CXX_COMPILER "/opt/homebrew/bin/aarch64-apple-darwin23-g++-14") # g++ clang++` 指定c++编译器
|
||||
elseif (${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
|
||||
message("Building for Windows platform")
|
||||
else()
|
||||
message(FATAL_ERROR "Unsupported platform: ${CMAKE_SYSTEM_NAME}")
|
||||
endif()
|
||||
|
||||
|
||||
find_package(debugstream)
|
||||
include_directories(include)
|
||||
|
||||
find_package(Protobuf REQUIRED CONFIG)
|
||||
find_package(gRPC CONFIG REQUIRED)
|
||||
|
||||
|
||||
include_directories(protoc)
|
||||
|
||||
set(LIB
|
||||
gRPC::grpc++
|
||||
gRPC::grpc++_reflection
|
||||
protobuf::libprotobuf
|
||||
)
|
||||
|
||||
# add_executable(grpc src/main.cc)
|
||||
# target_link_libraries(libhv ${LIB})
|
||||
|
||||
file(GLOB_RECURSE PROTOC_SRCS "protoc/*.cc")
|
||||
|
||||
|
||||
add_executable(grpc_server src/grpc_server_main.cc
|
||||
${PROTOC_SRCS}
|
||||
)
|
||||
add_executable(grpc_client src/grpc_client_main.cc
|
||||
${PROTOC_SRCS}
|
||||
)
|
||||
target_link_libraries(grpc_server ${LIB} debugstream)
|
||||
target_link_libraries(grpc_client ${LIB} debugstream)
|
2
include/common.h
Normal file
2
include/common.h
Normal file
@ -0,0 +1,2 @@
|
||||
#pragma once
|
||||
#include <debugstream/debugstream.h>
|
26
include/protoc.h
Normal file
26
include/protoc.h
Normal file
@ -0,0 +1,26 @@
|
||||
#pragma once
|
||||
|
||||
#include <grpc/grpc.h>
|
||||
#include <grpcpp/security/server_credentials.h>
|
||||
#include <grpcpp/server.h>
|
||||
#include <grpcpp/server_builder.h>
|
||||
#include <grpcpp/server_context.h>
|
||||
|
||||
#include "market_data.grpc.pb.h"
|
||||
|
||||
using grpc::Server;
|
||||
using grpc::ServerBuilder;
|
||||
using grpc::ServerContext;
|
||||
using grpc::ServerReader;
|
||||
using grpc::ServerReaderWriter;
|
||||
using grpc::ServerWriter;
|
||||
using grpc::Status;
|
||||
|
||||
inline long GetTimeUs() {
|
||||
// 获取当前时间点
|
||||
auto now = std::chrono::high_resolution_clock::now();
|
||||
// 将时间点转换为微秒
|
||||
auto duration = std::chrono::duration_cast<std::chrono::microseconds>(
|
||||
now.time_since_epoch());
|
||||
return duration.count();
|
||||
}
|
123
market_data.proto
Normal file
123
market_data.proto
Normal file
@ -0,0 +1,123 @@
|
||||
syntax = "proto3";
|
||||
|
||||
option java_multiple_files = true;
|
||||
option java_package = "io.grpc.example.market_data";
|
||||
|
||||
option java_outer_classname = "market_data";
|
||||
option objc_class_prefix = "HLW";
|
||||
|
||||
package market_data;
|
||||
|
||||
service TestService {
|
||||
rpc GetData1(CThostFtdcDepthMarketDataField) returns(MsgReply) {}
|
||||
rpc GetData2(ResMsg) returns(MsgReply) {}
|
||||
}
|
||||
|
||||
message CThostFtdcDepthMarketDataField {
|
||||
// 交易日
|
||||
string TradingDay = 1;
|
||||
// 保留的无效字段
|
||||
string reserve1 = 2;
|
||||
// 交易所代码
|
||||
string ExchangeID = 3;
|
||||
// 保留的无效字段
|
||||
string reserve2 = 4;
|
||||
// 最新价
|
||||
double LastPrice = 5;
|
||||
// 上次结算价
|
||||
double PreSettlementPrice = 6;
|
||||
// 昨收盘
|
||||
double PreClosePrice = 7;
|
||||
// 昨持仓量
|
||||
double PreOpenInterest = 8;
|
||||
// 今开盘
|
||||
double OpenPrice = 9;
|
||||
// 最高价
|
||||
double HighestPrice = 10;
|
||||
// 最低价
|
||||
double LowestPrice = 11;
|
||||
// 数量
|
||||
int32 Volume = 12;
|
||||
// 成交金额
|
||||
double Turnover = 13;
|
||||
// 持仓量
|
||||
double OpenInterest = 14;
|
||||
// 今收盘
|
||||
double ClosePrice = 15;
|
||||
// 本次结算价
|
||||
double SettlementPrice = 16;
|
||||
// 涨停板价
|
||||
double UpperLimitPrice = 17;
|
||||
// 跌停板价
|
||||
double LowerLimitPrice = 18;
|
||||
// 昨虚实度
|
||||
double PreDelta = 19;
|
||||
// 今虚实度
|
||||
double CurrDelta = 20;
|
||||
// 最后修改时间
|
||||
string UpdateTime = 21;
|
||||
// 最后修改毫秒
|
||||
int32 UpdateMillisec = 22;
|
||||
// 申买价一
|
||||
double BidPrice1 = 23;
|
||||
// 申买量一
|
||||
int32 BidVolume1 = 24;
|
||||
// 申卖价一
|
||||
double AskPrice1 = 25;
|
||||
// 申卖量一
|
||||
int32 AskVolume1 = 26;
|
||||
// 申买价二
|
||||
double BidPrice2 = 27;
|
||||
// 申买量二
|
||||
int32 BidVolume2 = 28;
|
||||
// 申卖价二
|
||||
double AskPrice2 = 29;
|
||||
// 申卖量二
|
||||
int32 AskVolume2 = 30;
|
||||
// 申买价三
|
||||
double BidPrice3 = 31;
|
||||
// 申买量三
|
||||
int32 BidVolume3 = 32;
|
||||
// 申卖价三
|
||||
double AskPrice3 = 33;
|
||||
// 申卖量三
|
||||
int32 AskVolume3 = 34;
|
||||
// 申买价四
|
||||
double BidPrice4 = 35;
|
||||
// 申买量四
|
||||
int32 BidVolume4 = 36;
|
||||
// 申卖价四
|
||||
double AskPrice4 = 37;
|
||||
// 申卖量四
|
||||
int32 AskVolume4 = 38;
|
||||
// 申买价五
|
||||
double BidPrice5 = 39;
|
||||
// 申买量五
|
||||
int32 BidVolume5 = 40;
|
||||
// 申卖价五
|
||||
double AskPrice5 = 41;
|
||||
// 申卖量五
|
||||
int32 AskVolume5 = 42;
|
||||
// 当日均价
|
||||
double AveragePrice = 43;
|
||||
// 业务日期
|
||||
string ActionDay = 44;
|
||||
// 合约代码
|
||||
string InstrumentID = 45;
|
||||
// 合约在交易所的代码
|
||||
string ExchangeInstID = 46;
|
||||
}
|
||||
|
||||
message ResMsg {
|
||||
string signame = 1;
|
||||
string InstrumentID = 2;
|
||||
int32 sigflag = 3;
|
||||
double sigvalue = 4;
|
||||
string offset = 5; // char 替换为 string
|
||||
string dir = 6; // char 替换为 string
|
||||
int32 vol = 7;
|
||||
repeated double other_params = 8;
|
||||
repeated string other_msg = 9;
|
||||
}
|
||||
|
||||
message MsgReply { string message = 1; }
|
128
protoc/market_data.grpc.pb.cc
Normal file
128
protoc/market_data.grpc.pb.cc
Normal file
@ -0,0 +1,128 @@
|
||||
// Generated by the gRPC C++ plugin.
|
||||
// If you make any local change, they will be lost.
|
||||
// source: market_data.proto
|
||||
|
||||
#include "market_data.pb.h"
|
||||
#include "market_data.grpc.pb.h"
|
||||
|
||||
#include <functional>
|
||||
#include <grpcpp/support/async_stream.h>
|
||||
#include <grpcpp/support/async_unary_call.h>
|
||||
#include <grpcpp/impl/channel_interface.h>
|
||||
#include <grpcpp/impl/client_unary_call.h>
|
||||
#include <grpcpp/support/client_callback.h>
|
||||
#include <grpcpp/support/message_allocator.h>
|
||||
#include <grpcpp/support/method_handler.h>
|
||||
#include <grpcpp/impl/rpc_service_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/sync_stream.h>
|
||||
namespace market_data {
|
||||
|
||||
static const char* TestService_method_names[] = {
|
||||
"/market_data.TestService/GetData1",
|
||||
"/market_data.TestService/GetData2",
|
||||
};
|
||||
|
||||
std::unique_ptr< TestService::Stub> TestService::NewStub(const std::shared_ptr< ::grpc::ChannelInterface>& channel, const ::grpc::StubOptions& options) {
|
||||
(void)options;
|
||||
std::unique_ptr< TestService::Stub> stub(new TestService::Stub(channel, options));
|
||||
return stub;
|
||||
}
|
||||
|
||||
TestService::Stub::Stub(const std::shared_ptr< ::grpc::ChannelInterface>& channel, const ::grpc::StubOptions& options)
|
||||
: channel_(channel), rpcmethod_GetData1_(TestService_method_names[0], options.suffix_for_stats(),::grpc::internal::RpcMethod::NORMAL_RPC, channel)
|
||||
, rpcmethod_GetData2_(TestService_method_names[1], options.suffix_for_stats(),::grpc::internal::RpcMethod::NORMAL_RPC, channel)
|
||||
{}
|
||||
|
||||
::grpc::Status TestService::Stub::GetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::market_data::MsgReply* response) {
|
||||
return ::grpc::internal::BlockingUnaryCall< ::market_data::CThostFtdcDepthMarketDataField, ::market_data::MsgReply, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), rpcmethod_GetData1_, context, request, response);
|
||||
}
|
||||
|
||||
void TestService::Stub::async::GetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField* request, ::market_data::MsgReply* response, std::function<void(::grpc::Status)> f) {
|
||||
::grpc::internal::CallbackUnaryCall< ::market_data::CThostFtdcDepthMarketDataField, ::market_data::MsgReply, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_GetData1_, context, request, response, std::move(f));
|
||||
}
|
||||
|
||||
void TestService::Stub::async::GetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField* request, ::market_data::MsgReply* response, ::grpc::ClientUnaryReactor* reactor) {
|
||||
::grpc::internal::ClientCallbackUnaryFactory::Create< ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_GetData1_, context, request, response, reactor);
|
||||
}
|
||||
|
||||
::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>* TestService::Stub::PrepareAsyncGetData1Raw(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::grpc::CompletionQueue* cq) {
|
||||
return ::grpc::internal::ClientAsyncResponseReaderHelper::Create< ::market_data::MsgReply, ::market_data::CThostFtdcDepthMarketDataField, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), cq, rpcmethod_GetData1_, context, request);
|
||||
}
|
||||
|
||||
::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>* TestService::Stub::AsyncGetData1Raw(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::grpc::CompletionQueue* cq) {
|
||||
auto* result =
|
||||
this->PrepareAsyncGetData1Raw(context, request, cq);
|
||||
result->StartCall();
|
||||
return result;
|
||||
}
|
||||
|
||||
::grpc::Status TestService::Stub::GetData2(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::market_data::MsgReply* response) {
|
||||
return ::grpc::internal::BlockingUnaryCall< ::market_data::ResMsg, ::market_data::MsgReply, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), rpcmethod_GetData2_, context, request, response);
|
||||
}
|
||||
|
||||
void TestService::Stub::async::GetData2(::grpc::ClientContext* context, const ::market_data::ResMsg* request, ::market_data::MsgReply* response, std::function<void(::grpc::Status)> f) {
|
||||
::grpc::internal::CallbackUnaryCall< ::market_data::ResMsg, ::market_data::MsgReply, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_GetData2_, context, request, response, std::move(f));
|
||||
}
|
||||
|
||||
void TestService::Stub::async::GetData2(::grpc::ClientContext* context, const ::market_data::ResMsg* request, ::market_data::MsgReply* response, ::grpc::ClientUnaryReactor* reactor) {
|
||||
::grpc::internal::ClientCallbackUnaryFactory::Create< ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(stub_->channel_.get(), stub_->rpcmethod_GetData2_, context, request, response, reactor);
|
||||
}
|
||||
|
||||
::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>* TestService::Stub::PrepareAsyncGetData2Raw(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::grpc::CompletionQueue* cq) {
|
||||
return ::grpc::internal::ClientAsyncResponseReaderHelper::Create< ::market_data::MsgReply, ::market_data::ResMsg, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(channel_.get(), cq, rpcmethod_GetData2_, context, request);
|
||||
}
|
||||
|
||||
::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>* TestService::Stub::AsyncGetData2Raw(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::grpc::CompletionQueue* cq) {
|
||||
auto* result =
|
||||
this->PrepareAsyncGetData2Raw(context, request, cq);
|
||||
result->StartCall();
|
||||
return result;
|
||||
}
|
||||
|
||||
TestService::Service::Service() {
|
||||
AddMethod(new ::grpc::internal::RpcServiceMethod(
|
||||
TestService_method_names[0],
|
||||
::grpc::internal::RpcMethod::NORMAL_RPC,
|
||||
new ::grpc::internal::RpcMethodHandler< TestService::Service, ::market_data::CThostFtdcDepthMarketDataField, ::market_data::MsgReply, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(
|
||||
[](TestService::Service* service,
|
||||
::grpc::ServerContext* ctx,
|
||||
const ::market_data::CThostFtdcDepthMarketDataField* req,
|
||||
::market_data::MsgReply* resp) {
|
||||
return service->GetData1(ctx, req, resp);
|
||||
}, this)));
|
||||
AddMethod(new ::grpc::internal::RpcServiceMethod(
|
||||
TestService_method_names[1],
|
||||
::grpc::internal::RpcMethod::NORMAL_RPC,
|
||||
new ::grpc::internal::RpcMethodHandler< TestService::Service, ::market_data::ResMsg, ::market_data::MsgReply, ::grpc::protobuf::MessageLite, ::grpc::protobuf::MessageLite>(
|
||||
[](TestService::Service* service,
|
||||
::grpc::ServerContext* ctx,
|
||||
const ::market_data::ResMsg* req,
|
||||
::market_data::MsgReply* resp) {
|
||||
return service->GetData2(ctx, req, resp);
|
||||
}, this)));
|
||||
}
|
||||
|
||||
TestService::Service::~Service() {
|
||||
}
|
||||
|
||||
::grpc::Status TestService::Service::GetData1(::grpc::ServerContext* context, const ::market_data::CThostFtdcDepthMarketDataField* request, ::market_data::MsgReply* response) {
|
||||
(void) context;
|
||||
(void) request;
|
||||
(void) response;
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
|
||||
::grpc::Status TestService::Service::GetData2(::grpc::ServerContext* context, const ::market_data::ResMsg* request, ::market_data::MsgReply* response) {
|
||||
(void) context;
|
||||
(void) request;
|
||||
(void) response;
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
|
||||
|
||||
} // namespace market_data
|
||||
|
397
protoc/market_data.grpc.pb.h
Normal file
397
protoc/market_data.grpc.pb.h
Normal file
@ -0,0 +1,397 @@
|
||||
// Generated by the gRPC C++ plugin.
|
||||
// If you make any local change, they will be lost.
|
||||
// source: market_data.proto
|
||||
#ifndef GRPC_market_5fdata_2eproto__INCLUDED
|
||||
#define GRPC_market_5fdata_2eproto__INCLUDED
|
||||
|
||||
#include "market_data.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 market_data {
|
||||
|
||||
class TestService final {
|
||||
public:
|
||||
static constexpr char const* service_full_name() {
|
||||
return "market_data.TestService";
|
||||
}
|
||||
class StubInterface {
|
||||
public:
|
||||
virtual ~StubInterface() {}
|
||||
virtual ::grpc::Status GetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::market_data::MsgReply* response) = 0;
|
||||
std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>> AsyncGetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::grpc::CompletionQueue* cq) {
|
||||
return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>>(AsyncGetData1Raw(context, request, cq));
|
||||
}
|
||||
std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>> PrepareAsyncGetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::grpc::CompletionQueue* cq) {
|
||||
return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>>(PrepareAsyncGetData1Raw(context, request, cq));
|
||||
}
|
||||
virtual ::grpc::Status GetData2(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::market_data::MsgReply* response) = 0;
|
||||
std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>> AsyncGetData2(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::grpc::CompletionQueue* cq) {
|
||||
return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>>(AsyncGetData2Raw(context, request, cq));
|
||||
}
|
||||
std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>> PrepareAsyncGetData2(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::grpc::CompletionQueue* cq) {
|
||||
return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>>(PrepareAsyncGetData2Raw(context, request, cq));
|
||||
}
|
||||
class async_interface {
|
||||
public:
|
||||
virtual ~async_interface() {}
|
||||
virtual void GetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField* request, ::market_data::MsgReply* response, std::function<void(::grpc::Status)>) = 0;
|
||||
virtual void GetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField* request, ::market_data::MsgReply* response, ::grpc::ClientUnaryReactor* reactor) = 0;
|
||||
virtual void GetData2(::grpc::ClientContext* context, const ::market_data::ResMsg* request, ::market_data::MsgReply* response, std::function<void(::grpc::Status)>) = 0;
|
||||
virtual void GetData2(::grpc::ClientContext* context, const ::market_data::ResMsg* request, ::market_data::MsgReply* response, ::grpc::ClientUnaryReactor* 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< ::market_data::MsgReply>* AsyncGetData1Raw(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::grpc::CompletionQueue* cq) = 0;
|
||||
virtual ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>* PrepareAsyncGetData1Raw(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::grpc::CompletionQueue* cq) = 0;
|
||||
virtual ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>* AsyncGetData2Raw(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::grpc::CompletionQueue* cq) = 0;
|
||||
virtual ::grpc::ClientAsyncResponseReaderInterface< ::market_data::MsgReply>* PrepareAsyncGetData2Raw(::grpc::ClientContext* context, const ::market_data::ResMsg& 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 GetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::market_data::MsgReply* response) override;
|
||||
std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>> AsyncGetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::grpc::CompletionQueue* cq) {
|
||||
return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>>(AsyncGetData1Raw(context, request, cq));
|
||||
}
|
||||
std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>> PrepareAsyncGetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::grpc::CompletionQueue* cq) {
|
||||
return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>>(PrepareAsyncGetData1Raw(context, request, cq));
|
||||
}
|
||||
::grpc::Status GetData2(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::market_data::MsgReply* response) override;
|
||||
std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>> AsyncGetData2(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::grpc::CompletionQueue* cq) {
|
||||
return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>>(AsyncGetData2Raw(context, request, cq));
|
||||
}
|
||||
std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>> PrepareAsyncGetData2(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::grpc::CompletionQueue* cq) {
|
||||
return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>>(PrepareAsyncGetData2Raw(context, request, cq));
|
||||
}
|
||||
class async final :
|
||||
public StubInterface::async_interface {
|
||||
public:
|
||||
void GetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField* request, ::market_data::MsgReply* response, std::function<void(::grpc::Status)>) override;
|
||||
void GetData1(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField* request, ::market_data::MsgReply* response, ::grpc::ClientUnaryReactor* reactor) override;
|
||||
void GetData2(::grpc::ClientContext* context, const ::market_data::ResMsg* request, ::market_data::MsgReply* response, std::function<void(::grpc::Status)>) override;
|
||||
void GetData2(::grpc::ClientContext* context, const ::market_data::ResMsg* request, ::market_data::MsgReply* response, ::grpc::ClientUnaryReactor* 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< ::market_data::MsgReply>* AsyncGetData1Raw(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::grpc::CompletionQueue* cq) override;
|
||||
::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>* PrepareAsyncGetData1Raw(::grpc::ClientContext* context, const ::market_data::CThostFtdcDepthMarketDataField& request, ::grpc::CompletionQueue* cq) override;
|
||||
::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>* AsyncGetData2Raw(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::grpc::CompletionQueue* cq) override;
|
||||
::grpc::ClientAsyncResponseReader< ::market_data::MsgReply>* PrepareAsyncGetData2Raw(::grpc::ClientContext* context, const ::market_data::ResMsg& request, ::grpc::CompletionQueue* cq) override;
|
||||
const ::grpc::internal::RpcMethod rpcmethod_GetData1_;
|
||||
const ::grpc::internal::RpcMethod rpcmethod_GetData2_;
|
||||
};
|
||||
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 GetData1(::grpc::ServerContext* context, const ::market_data::CThostFtdcDepthMarketDataField* request, ::market_data::MsgReply* response);
|
||||
virtual ::grpc::Status GetData2(::grpc::ServerContext* context, const ::market_data::ResMsg* request, ::market_data::MsgReply* response);
|
||||
};
|
||||
template <class BaseClass>
|
||||
class WithAsyncMethod_GetData1 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithAsyncMethod_GetData1() {
|
||||
::grpc::Service::MarkMethodAsync(0);
|
||||
}
|
||||
~WithAsyncMethod_GetData1() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable synchronous version of this method
|
||||
::grpc::Status GetData1(::grpc::ServerContext* /*context*/, const ::market_data::CThostFtdcDepthMarketDataField* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
void RequestGetData1(::grpc::ServerContext* context, ::market_data::CThostFtdcDepthMarketDataField* request, ::grpc::ServerAsyncResponseWriter< ::market_data::MsgReply>* 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_GetData2 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithAsyncMethod_GetData2() {
|
||||
::grpc::Service::MarkMethodAsync(1);
|
||||
}
|
||||
~WithAsyncMethod_GetData2() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable synchronous version of this method
|
||||
::grpc::Status GetData2(::grpc::ServerContext* /*context*/, const ::market_data::ResMsg* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
void RequestGetData2(::grpc::ServerContext* context, ::market_data::ResMsg* request, ::grpc::ServerAsyncResponseWriter< ::market_data::MsgReply>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) {
|
||||
::grpc::Service::RequestAsyncUnary(1, context, request, response, new_call_cq, notification_cq, tag);
|
||||
}
|
||||
};
|
||||
typedef WithAsyncMethod_GetData1<WithAsyncMethod_GetData2<Service > > AsyncService;
|
||||
template <class BaseClass>
|
||||
class WithCallbackMethod_GetData1 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithCallbackMethod_GetData1() {
|
||||
::grpc::Service::MarkMethodCallback(0,
|
||||
new ::grpc::internal::CallbackUnaryHandler< ::market_data::CThostFtdcDepthMarketDataField, ::market_data::MsgReply>(
|
||||
[this](
|
||||
::grpc::CallbackServerContext* context, const ::market_data::CThostFtdcDepthMarketDataField* request, ::market_data::MsgReply* response) { return this->GetData1(context, request, response); }));}
|
||||
void SetMessageAllocatorFor_GetData1(
|
||||
::grpc::MessageAllocator< ::market_data::CThostFtdcDepthMarketDataField, ::market_data::MsgReply>* allocator) {
|
||||
::grpc::internal::MethodHandler* const handler = ::grpc::Service::GetHandler(0);
|
||||
static_cast<::grpc::internal::CallbackUnaryHandler< ::market_data::CThostFtdcDepthMarketDataField, ::market_data::MsgReply>*>(handler)
|
||||
->SetMessageAllocator(allocator);
|
||||
}
|
||||
~WithCallbackMethod_GetData1() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable synchronous version of this method
|
||||
::grpc::Status GetData1(::grpc::ServerContext* /*context*/, const ::market_data::CThostFtdcDepthMarketDataField* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
virtual ::grpc::ServerUnaryReactor* GetData1(
|
||||
::grpc::CallbackServerContext* /*context*/, const ::market_data::CThostFtdcDepthMarketDataField* /*request*/, ::market_data::MsgReply* /*response*/) { return nullptr; }
|
||||
};
|
||||
template <class BaseClass>
|
||||
class WithCallbackMethod_GetData2 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithCallbackMethod_GetData2() {
|
||||
::grpc::Service::MarkMethodCallback(1,
|
||||
new ::grpc::internal::CallbackUnaryHandler< ::market_data::ResMsg, ::market_data::MsgReply>(
|
||||
[this](
|
||||
::grpc::CallbackServerContext* context, const ::market_data::ResMsg* request, ::market_data::MsgReply* response) { return this->GetData2(context, request, response); }));}
|
||||
void SetMessageAllocatorFor_GetData2(
|
||||
::grpc::MessageAllocator< ::market_data::ResMsg, ::market_data::MsgReply>* allocator) {
|
||||
::grpc::internal::MethodHandler* const handler = ::grpc::Service::GetHandler(1);
|
||||
static_cast<::grpc::internal::CallbackUnaryHandler< ::market_data::ResMsg, ::market_data::MsgReply>*>(handler)
|
||||
->SetMessageAllocator(allocator);
|
||||
}
|
||||
~WithCallbackMethod_GetData2() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable synchronous version of this method
|
||||
::grpc::Status GetData2(::grpc::ServerContext* /*context*/, const ::market_data::ResMsg* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
virtual ::grpc::ServerUnaryReactor* GetData2(
|
||||
::grpc::CallbackServerContext* /*context*/, const ::market_data::ResMsg* /*request*/, ::market_data::MsgReply* /*response*/) { return nullptr; }
|
||||
};
|
||||
typedef WithCallbackMethod_GetData1<WithCallbackMethod_GetData2<Service > > CallbackService;
|
||||
typedef CallbackService ExperimentalCallbackService;
|
||||
template <class BaseClass>
|
||||
class WithGenericMethod_GetData1 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithGenericMethod_GetData1() {
|
||||
::grpc::Service::MarkMethodGeneric(0);
|
||||
}
|
||||
~WithGenericMethod_GetData1() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable synchronous version of this method
|
||||
::grpc::Status GetData1(::grpc::ServerContext* /*context*/, const ::market_data::CThostFtdcDepthMarketDataField* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
};
|
||||
template <class BaseClass>
|
||||
class WithGenericMethod_GetData2 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithGenericMethod_GetData2() {
|
||||
::grpc::Service::MarkMethodGeneric(1);
|
||||
}
|
||||
~WithGenericMethod_GetData2() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable synchronous version of this method
|
||||
::grpc::Status GetData2(::grpc::ServerContext* /*context*/, const ::market_data::ResMsg* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
};
|
||||
template <class BaseClass>
|
||||
class WithRawMethod_GetData1 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithRawMethod_GetData1() {
|
||||
::grpc::Service::MarkMethodRaw(0);
|
||||
}
|
||||
~WithRawMethod_GetData1() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable synchronous version of this method
|
||||
::grpc::Status GetData1(::grpc::ServerContext* /*context*/, const ::market_data::CThostFtdcDepthMarketDataField* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
void RequestGetData1(::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_GetData2 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithRawMethod_GetData2() {
|
||||
::grpc::Service::MarkMethodRaw(1);
|
||||
}
|
||||
~WithRawMethod_GetData2() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable synchronous version of this method
|
||||
::grpc::Status GetData2(::grpc::ServerContext* /*context*/, const ::market_data::ResMsg* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
void RequestGetData2(::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(1, context, request, response, new_call_cq, notification_cq, tag);
|
||||
}
|
||||
};
|
||||
template <class BaseClass>
|
||||
class WithRawCallbackMethod_GetData1 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithRawCallbackMethod_GetData1() {
|
||||
::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->GetData1(context, request, response); }));
|
||||
}
|
||||
~WithRawCallbackMethod_GetData1() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable synchronous version of this method
|
||||
::grpc::Status GetData1(::grpc::ServerContext* /*context*/, const ::market_data::CThostFtdcDepthMarketDataField* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
virtual ::grpc::ServerUnaryReactor* GetData1(
|
||||
::grpc::CallbackServerContext* /*context*/, const ::grpc::ByteBuffer* /*request*/, ::grpc::ByteBuffer* /*response*/) { return nullptr; }
|
||||
};
|
||||
template <class BaseClass>
|
||||
class WithRawCallbackMethod_GetData2 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithRawCallbackMethod_GetData2() {
|
||||
::grpc::Service::MarkMethodRawCallback(1,
|
||||
new ::grpc::internal::CallbackUnaryHandler< ::grpc::ByteBuffer, ::grpc::ByteBuffer>(
|
||||
[this](
|
||||
::grpc::CallbackServerContext* context, const ::grpc::ByteBuffer* request, ::grpc::ByteBuffer* response) { return this->GetData2(context, request, response); }));
|
||||
}
|
||||
~WithRawCallbackMethod_GetData2() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable synchronous version of this method
|
||||
::grpc::Status GetData2(::grpc::ServerContext* /*context*/, const ::market_data::ResMsg* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
virtual ::grpc::ServerUnaryReactor* GetData2(
|
||||
::grpc::CallbackServerContext* /*context*/, const ::grpc::ByteBuffer* /*request*/, ::grpc::ByteBuffer* /*response*/) { return nullptr; }
|
||||
};
|
||||
template <class BaseClass>
|
||||
class WithStreamedUnaryMethod_GetData1 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithStreamedUnaryMethod_GetData1() {
|
||||
::grpc::Service::MarkMethodStreamed(0,
|
||||
new ::grpc::internal::StreamedUnaryHandler<
|
||||
::market_data::CThostFtdcDepthMarketDataField, ::market_data::MsgReply>(
|
||||
[this](::grpc::ServerContext* context,
|
||||
::grpc::ServerUnaryStreamer<
|
||||
::market_data::CThostFtdcDepthMarketDataField, ::market_data::MsgReply>* streamer) {
|
||||
return this->StreamedGetData1(context,
|
||||
streamer);
|
||||
}));
|
||||
}
|
||||
~WithStreamedUnaryMethod_GetData1() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable regular version of this method
|
||||
::grpc::Status GetData1(::grpc::ServerContext* /*context*/, const ::market_data::CThostFtdcDepthMarketDataField* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
// replace default version of method with streamed unary
|
||||
virtual ::grpc::Status StreamedGetData1(::grpc::ServerContext* context, ::grpc::ServerUnaryStreamer< ::market_data::CThostFtdcDepthMarketDataField,::market_data::MsgReply>* server_unary_streamer) = 0;
|
||||
};
|
||||
template <class BaseClass>
|
||||
class WithStreamedUnaryMethod_GetData2 : public BaseClass {
|
||||
private:
|
||||
void BaseClassMustBeDerivedFromService(const Service* /*service*/) {}
|
||||
public:
|
||||
WithStreamedUnaryMethod_GetData2() {
|
||||
::grpc::Service::MarkMethodStreamed(1,
|
||||
new ::grpc::internal::StreamedUnaryHandler<
|
||||
::market_data::ResMsg, ::market_data::MsgReply>(
|
||||
[this](::grpc::ServerContext* context,
|
||||
::grpc::ServerUnaryStreamer<
|
||||
::market_data::ResMsg, ::market_data::MsgReply>* streamer) {
|
||||
return this->StreamedGetData2(context,
|
||||
streamer);
|
||||
}));
|
||||
}
|
||||
~WithStreamedUnaryMethod_GetData2() override {
|
||||
BaseClassMustBeDerivedFromService(this);
|
||||
}
|
||||
// disable regular version of this method
|
||||
::grpc::Status GetData2(::grpc::ServerContext* /*context*/, const ::market_data::ResMsg* /*request*/, ::market_data::MsgReply* /*response*/) override {
|
||||
abort();
|
||||
return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "");
|
||||
}
|
||||
// replace default version of method with streamed unary
|
||||
virtual ::grpc::Status StreamedGetData2(::grpc::ServerContext* context, ::grpc::ServerUnaryStreamer< ::market_data::ResMsg,::market_data::MsgReply>* server_unary_streamer) = 0;
|
||||
};
|
||||
typedef WithStreamedUnaryMethod_GetData1<WithStreamedUnaryMethod_GetData2<Service > > StreamedUnaryService;
|
||||
typedef Service SplitStreamedService;
|
||||
typedef WithStreamedUnaryMethod_GetData1<WithStreamedUnaryMethod_GetData2<Service > > StreamedService;
|
||||
};
|
||||
|
||||
} // namespace market_data
|
||||
|
||||
|
||||
#endif // GRPC_market_5fdata_2eproto__INCLUDED
|
2203
protoc/market_data.pb.cc
Normal file
2203
protoc/market_data.pb.cc
Normal file
File diff suppressed because it is too large
Load Diff
3069
protoc/market_data.pb.h
Normal file
3069
protoc/market_data.pb.h
Normal file
File diff suppressed because it is too large
Load Diff
8
protoc_generate.sh
Normal file
8
protoc_generate.sh
Normal file
@ -0,0 +1,8 @@
|
||||
mkdir -p gen_code
|
||||
|
||||
generate_code(){
|
||||
protoc -I ./ --grpc_out=./protoc --plugin=protoc-gen-grpc=`which grpc_cpp_plugin` $1
|
||||
protoc -I ./ --cpp_out=./protoc $1
|
||||
}
|
||||
|
||||
generate_code $@
|
90
src/grpc_client_main.cc
Normal file
90
src/grpc_client_main.cc
Normal file
@ -0,0 +1,90 @@
|
||||
#include <grpc/grpc.h>
|
||||
#include <grpcpp/channel.h>
|
||||
#include <grpcpp/client_context.h>
|
||||
#include <grpcpp/create_channel.h>
|
||||
#include <grpcpp/security/credentials.h>
|
||||
|
||||
#include <iostream>
|
||||
#include <memory>
|
||||
#include <string>
|
||||
|
||||
#include "common.h"
|
||||
#include "market_data.pb.h"
|
||||
#include "protoc.h"
|
||||
|
||||
class MyClient {
|
||||
public:
|
||||
// create stub
|
||||
MyClient(std::shared_ptr<grpc::Channel> channel)
|
||||
: stub_(market_data::TestService::NewStub(channel)) {}
|
||||
void GetReplyMsg1() {
|
||||
market_data::CThostFtdcDepthMarketDataField data;
|
||||
market_data::MsgReply msg_reply;
|
||||
data.set_turnover(10);
|
||||
GetOneData1(data, &msg_reply);
|
||||
}
|
||||
void GetReplyMsg2() {
|
||||
market_data::ResMsg data;
|
||||
market_data::MsgReply msg_reply;
|
||||
data.add_other_msg("123");
|
||||
GetOneData2(data, &msg_reply);
|
||||
}
|
||||
|
||||
private:
|
||||
bool GetOneData1(const market_data::CThostFtdcDepthMarketDataField &data,
|
||||
market_data::MsgReply *msg_reply) {
|
||||
grpc::ClientContext context;
|
||||
// auto start_time = GetTimeUs();
|
||||
Status status = stub_->GetData1(&context, data, msg_reply);
|
||||
// auto end_time = GetTimeUs();
|
||||
// std::cout << "time diff:" << end_time - start_time << "us" << std::endl;
|
||||
if (!status.ok()) {
|
||||
std::cout << "GetData rpc failed." << std::endl;
|
||||
return false;
|
||||
}
|
||||
if (msg_reply->message().empty()) {
|
||||
std::cout << "message empty." << std::endl;
|
||||
return false;
|
||||
} else {
|
||||
std::cout << "MsgReply:" << msg_reply->message() << std::endl;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
bool GetOneData2(const market_data::ResMsg &data,
|
||||
market_data::MsgReply *msg_reply) {
|
||||
grpc::ClientContext context;
|
||||
// auto start_time = GetTimeUs();
|
||||
Status status = stub_->GetData2(&context, data, msg_reply);
|
||||
// auto end_time = GetTimeUs();
|
||||
// std::cout << "time diff:" << end_time - start_time << "us" << std::endl;
|
||||
if (!status.ok()) {
|
||||
std::cout << "GetData rpc failed." << std::endl;
|
||||
return false;
|
||||
}
|
||||
if (msg_reply->message().empty()) {
|
||||
std::cout << "message empty." << std::endl;
|
||||
return false;
|
||||
} else {
|
||||
std::cout << "MsgReply:" << msg_reply->message() << std::endl;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
std::unique_ptr<market_data::TestService::Stub> stub_;
|
||||
};
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
// create a gRPC channel for our stub
|
||||
// grpc::CreateChannel("locakhost:50051",grpc::InsecureChannelCredentials());
|
||||
|
||||
MyClient client(grpc::CreateChannel("localhost:1234",
|
||||
grpc::InsecureChannelCredentials()));
|
||||
std::cout << "=====================" << std::endl;
|
||||
while (true) {
|
||||
gxt::SleepMs(500);
|
||||
client.GetReplyMsg1();
|
||||
gxt::SleepMs(500);
|
||||
client.GetReplyMsg2();
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
65
src/grpc_server_main.cc
Normal file
65
src/grpc_server_main.cc
Normal file
@ -0,0 +1,65 @@
|
||||
#include <forward_list>
|
||||
#include <future>
|
||||
#include <iostream>
|
||||
#include <memory>
|
||||
#include <mutex>
|
||||
#include <string>
|
||||
|
||||
#include "common.h"
|
||||
#include "protoc.h"
|
||||
|
||||
using market_data::CThostFtdcDepthMarketDataField;
|
||||
|
||||
class MyServer final : public market_data::TestService::Service {
|
||||
public:
|
||||
Status GetData1(ServerContext *context,
|
||||
const CThostFtdcDepthMarketDataField *data,
|
||||
market_data::MsgReply *msg) override {
|
||||
// cout << "[get data]: " << data->data() << endl;
|
||||
// string tmp("data received 12345");
|
||||
// msg->set_message(data->data());
|
||||
msg->set_message("getdata1"); // 原路返回
|
||||
// gDebug(data->data().size());
|
||||
return Status::OK;
|
||||
}
|
||||
Status GetData2(ServerContext *context, const market_data::ResMsg *data,
|
||||
market_data::MsgReply *msg) override {
|
||||
// cout << "[get data]: " << data->data() << endl;
|
||||
// string tmp("data received 12345");
|
||||
// msg->set_message(data->data());
|
||||
msg->set_message("getdata2"); // 原路返回
|
||||
// gDebug(data->data().size());
|
||||
return Status::OK;
|
||||
}
|
||||
};
|
||||
|
||||
void RunServer() {
|
||||
std::string server_addr("0.0.0.0:1234");
|
||||
// std::string server_addr("127.0.0.1:1235");
|
||||
// create an instance of our service implementation class Test1Impl
|
||||
MyServer service;
|
||||
|
||||
// Create an instance of factory ServerBuilder class
|
||||
ServerBuilder builder;
|
||||
|
||||
// Specify the address and port we want to use to listen for client requests
|
||||
// using the builder’s AddListeningPort() method.
|
||||
builder.AddListeningPort(server_addr, grpc::InsecureServerCredentials());
|
||||
|
||||
// Register our service implementation with the builder.
|
||||
builder.RegisterService(&service);
|
||||
|
||||
// Call BuildAndStart() on the builder to create and start an RPC server for
|
||||
// our service.
|
||||
std::unique_ptr<Server> server(builder.BuildAndStart());
|
||||
std::cout << "Server listening on " << server_addr << std::endl;
|
||||
|
||||
// Call Wait() on the server to do a blocking wait until process is killed or
|
||||
// Shutdown() is called
|
||||
server->Wait();
|
||||
}
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
RunServer();
|
||||
return 0;
|
||||
}
|
Loading…
Reference in New Issue
Block a user