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_client_session::send(uint64_t sig) { for (auto& msg : _sending_msgs) { sim_network_provider* rnet = nullptr; if (!s_switch[task_spec::get(msg->local_rpc_code)->rpc_call_channel].get(remote_address(), rnet)) { derror("cannot find destination node %s in simulator", remote_address().to_string() ); //on_disconnected(); // disable this to avoid endless resending } else { auto server_session = rnet->get_server_session(_net.address()); if (nullptr == server_session) { rpc_session_ptr cptr = this; auto parser = _net.new_message_parser(); server_session = new sim_server_session(*rnet, _net.address(), cptr, parser); rnet->on_server_session_accepted(server_session); } message_ex* recv_msg = virtual_send_message(msg); { node_scoper ns(rnet->node()); server_session->on_recv_request(recv_msg, recv_msg->to_address == recv_msg->from_address ? 0 : rnet->net_delay_milliseconds() ); } } } on_send_completed(sig); }