1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
// Copyright (C) 2014-2016 Bayerische Motoren Werke Aktiengesellschaft (BMW AG)
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
#include <iomanip>
#include <sstream>
#include <boost/asio/write.hpp>
#include <vsomeip/defines.hpp>
#include "../include/endpoint_host.hpp"
#include "../include/local_client_endpoint_impl.hpp"
#include "../../logging/include/logger.hpp"
namespace vsomeip {
local_client_endpoint_impl::local_client_endpoint_impl(
std::shared_ptr< endpoint_host > _host,
endpoint_type _remote,
boost::asio::io_service &_io,
std::uint32_t _max_message_size)
: local_client_endpoint_base_impl(_host, _remote, _remote, _io, _max_message_size) {
// Using _remote for the local(!) endpoint is ok,
// because we have no bind for local endpoints!
is_supporting_magic_cookies_ = false;
}
local_client_endpoint_impl::~local_client_endpoint_impl() {
}
bool local_client_endpoint_impl::is_local() const {
return true;
}
void local_client_endpoint_impl::start() {
if (socket_.is_open()) {
sending_blocked_ = false;
boost::system::error_code its_error;
socket_.cancel(its_error);
socket_.close(its_error);
restart();
} else {
connect();
}
}
void local_client_endpoint_impl::connect() {
boost::system::error_code its_error;
socket_.open(remote_.protocol(), its_error);
if (!its_error || its_error == boost::asio::error::already_open) {
socket_.set_option(boost::asio::socket_base::reuse_address(true));
boost::system::error_code error;
error = socket_.connect(remote_, error);
connect_cbk(error);
} else {
VSOMEIP_WARNING << "local_client_endpoint::connect: Error opening socket: "
<< its_error.message();
}
}
void local_client_endpoint_impl::receive() {
}
void local_client_endpoint_impl::send_queued() {
static byte_t its_start_tag[] = { 0x67, 0x37, 0x6D, 0x07 };
static byte_t its_end_tag[] = { 0x07, 0x6D, 0x37, 0x67 };
std::vector<boost::asio::const_buffer> bufs;
message_buffer_ptr_t its_buffer;
if(queue_.size()) {
its_buffer = queue_.front();
} else {
return;
}
#if 0
std::stringstream msg;
msg << "lce<" << this << ">::sq: ";
for (std::size_t i = 0; i < its_buffer->size(); i++)
msg << std::setw(2) << std::setfill('0') << std::hex
<< (int)(*its_buffer)[i] << " ";
VSOMEIP_DEBUG << msg.str();
#endif
bufs.push_back(boost::asio::buffer(its_start_tag));
bufs.push_back(boost::asio::buffer(*its_buffer));
bufs.push_back(boost::asio::buffer(its_end_tag));
boost::asio::async_write(
socket_,
bufs,
std::bind(
&client_endpoint_impl::send_cbk,
std::dynamic_pointer_cast<
local_client_endpoint_impl
>(shared_from_this()),
std::placeholders::_1,
std::placeholders::_2
)
);
}
void local_client_endpoint_impl::send_magic_cookie() {
}
} // namespace vsomeip
|