void sim_client_session::send(message_ptr& msg) { sim_network_provider* rnet = nullptr; if (!s_switch[task_spec::get(msg->header().local_rpc_code)->rpc_call_channel].get(msg->header().to_address, rnet)) { dwarn("cannot find destination node %s:%d in simulator", msg->header().to_address.name.c_str(), static_cast<int>(msg->header().to_address.port) ); return; } auto server_session = rnet->get_server_session(_net.address()); if (nullptr == server_session) { rpc_client_session_ptr cptr = this; server_session.reset(new sim_server_session(*rnet, _net.address(), cptr)); rnet->on_server_session_accepted(server_session); } message_ptr recv_msg(new message(msg->writer().get_buffer())); recv_msg->header().from_address = msg->header().from_address; recv_msg->header().to_address = msg->header().to_address; server_session->on_recv_request(recv_msg, recv_msg->header().from_address == recv_msg->header().to_address ? 0 : rnet->net_delay_milliseconds() ); }
void sim_server_session::send(message_ptr& reply_msg) { message_ptr recv_msg(new message(reply_msg->writer().get_buffer())); recv_msg->header().from_address = reply_msg->header().from_address; recv_msg->header().to_address = reply_msg->header().to_address; _client->on_recv_reply(recv_msg->header().id, recv_msg, recv_msg->header().from_address == recv_msg->header().to_address ? 0 : (static_cast<sim_network_provider*>(&_net))->net_delay_milliseconds() ); }