summaryrefslogtreecommitdiff
path: root/implementation/protocol/src/release_service_command.cpp
blob: 41475ec10f8811f9911daa60eb951b7c63f643f5 (plain)
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
// Copyright (C) 2021 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 <limits>

#include "../include/release_service_command.hpp"

namespace vsomeip_v3 {
namespace protocol {

release_service_command::release_service_command()
    : command(id_e::RELEASE_SERVICE_ID) {

}

void
release_service_command::serialize(std::vector<byte_t> &_buffer,
        error_e &_error) const {

    size_t its_size(COMMAND_HEADER_SIZE
                + sizeof(service::service_) + sizeof(service::instance_));

    if (its_size > std::numeric_limits<command_size_t>::max()) {

        _error = error_e::ERROR_MAX_COMMAND_SIZE_EXCEEDED;
        return;
    }

    // resize buffer
    _buffer.resize(its_size);

    // set size
    size_ = static_cast<command_size_t>(its_size - COMMAND_HEADER_SIZE);

    // serialize header
    command::serialize(_buffer, _error);
    if (_error != error_e::ERROR_OK)
        return;

    // serialize payload
    size_t its_offset(COMMAND_HEADER_SIZE);
    std::memcpy(&_buffer[its_offset], &service_.service_, sizeof(service_.service_));
    its_offset += sizeof(service_.service_);
    std::memcpy(&_buffer[its_offset], &service_.instance_, sizeof(service_.instance_));
}

void
release_service_command::deserialize(const std::vector<byte_t> &_buffer,
        error_e &_error) {

    size_t its_size(COMMAND_HEADER_SIZE
            + sizeof(service::service_) + sizeof(service::instance_));

    if (its_size > _buffer.size()) {

        _error = error_e::ERROR_NOT_ENOUGH_BYTES;
        return;
    }

    // deserialize header
    command::deserialize(_buffer, _error);
    if (_error != error_e::ERROR_OK)
        return;

    // deserialize payload
    size_t its_offset(COMMAND_POSITION_PAYLOAD);
    std::memcpy(&service_.service_, &_buffer[its_offset],
            sizeof(service_.service_));
    its_offset += sizeof(service_.service_);
    std::memcpy(&service_.instance_, &_buffer[its_offset],
            sizeof(service_.instance_));
}

service_t
release_service_command::get_service() const {

    return (service_.service_);
}

void
release_service_command::set_service(service_t _service) {

    service_.service_ = _service;
}

instance_t
release_service_command::get_instance() const {

    return (service_.instance_);
}

void
release_service_command::set_instance(instance_t _instance) {

    service_.instance_ = _instance;
}

} // namespace protocol
} // namespace vsomeip