summaryrefslogtreecommitdiff
path: root/implementation/protocol/src/register_events_command.cpp
blob: 830e22312c93e255faba39e5c1b14b6c7a8dc29c (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
102
103
104
105
106
107
108
109
110
// 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/register_events_command.hpp"
#include <vsomeip/internal/logger.hpp>

namespace vsomeip_v3 {
namespace protocol {

register_events_command::register_events_command()
        : command(id_e::REGISTER_EVENT_ID) {
}

bool
register_events_command::add_registration(const register_event &_register_event) {

    size_t its_size(size_ + COMMAND_HEADER_SIZE
            + sizeof(_register_event.get_service()) + sizeof(_register_event.get_instance())
            + sizeof(_register_event.get_event()) + sizeof(_register_event.get_event_type())
            + sizeof(_register_event.is_provided()) + sizeof(_register_event.get_reliability())
            + sizeof(_register_event.is_cyclic()) + sizeof(_register_event.get_num_eventgroups())
            + (_register_event.get_num_eventgroups() * sizeof(eventgroup_t) ));
    if (its_size > std::numeric_limits<command_size_t>::max()) {
        return false;
    } else {
        // set size
        size_ = static_cast<command_size_t>(its_size - COMMAND_HEADER_SIZE);
        registrations_.push_back(_register_event);
    }
    return true;
}

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

    if (size_ + COMMAND_HEADER_SIZE> std::numeric_limits<command_size_t>::max()) {

        _error = error_e::ERROR_MAX_COMMAND_SIZE_EXCEEDED;
        return;
    }

    // resize buffer
    _buffer.resize(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);
    for(auto &reg : registrations_) {
        reg.serialize(_buffer, its_offset);
    }
}

void
register_events_command::deserialize(const std::vector<byte_t> &_buffer, error_e &_error) {
    registrations_.clear();

    if(_buffer.size() < COMMAND_HEADER_SIZE) {
        _error = error_e::ERROR_NOT_ENOUGH_BYTES;
        return;
    }

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

    size_t its_offset(COMMAND_HEADER_SIZE);

    while(its_offset < _buffer.size()) {
        size_t its_size(its_offset+ sizeof(service_t) + sizeof(instance_t)
            + sizeof(event_t) + sizeof(event_type_e)
            + sizeof(bool) + sizeof(bool) + sizeof(bool) + sizeof(uint16_t)
            + sizeof(eventgroup_t)); // at least one is needed
        if (its_size > _buffer.size()) {
             _error = error_e::ERROR_NOT_ENOUGH_BYTES;
            return;
        }

        register_event event_command;
        event_command.deserialize(_buffer, its_offset);
        registrations_.push_back(event_command);
    }
}

std::size_t
register_events_command::get_num_registrations() const {

    return registrations_.size();
}

bool
register_events_command::get_registration_at(std::size_t _position, register_event & _reg) const {

    if(_position < registrations_.size()) {
        _reg = registrations_[_position];
        return true;
    }
    return false;
}

} // namespace protocol
} // namespace vsomeip_v3