Coverage Report

Created: 2022-08-24 06:19

/src/Fast-DDS/src/cpp/rtps/messages/submessages/AckNackMsg.hpp
Line
Count
Source (jump to first uncovered line)
1
// Copyright 2016 Proyectos y Sistemas de Mantenimiento SL (eProsima).
2
//
3
// Licensed under the Apache License, Version 2.0 (the "License");
4
// you may not use this file except in compliance with the License.
5
// You may obtain a copy of the License at
6
//
7
//     http://www.apache.org/licenses/LICENSE-2.0
8
//
9
// Unless required by applicable law or agreed to in writing, software
10
// distributed under the License is distributed on an "AS IS" BASIS,
11
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
// See the License for the specific language governing permissions and
13
// limitations under the License.
14
15
/*
16
 * AckNackMsg.hpp
17
 *
18
 */
19
20
namespace eprosima {
21
namespace fastrtps {
22
namespace rtps {
23
24
bool RTPSMessageCreator::addMessageAcknack(
25
        CDRMessage_t* msg,
26
        const GuidPrefix_t& guidprefix,
27
        const GuidPrefix_t& remoteGuidPrefix,
28
        const EntityId_t& readerId,
29
        const EntityId_t& writerId,
30
        const SequenceNumberSet_t& SNSet,
31
        int32_t count,
32
        bool finalFlag)
33
0
{
34
0
    RTPSMessageCreator::addHeader(msg, guidprefix);
35
0
    RTPSMessageCreator::addSubmessageInfoDST(msg, remoteGuidPrefix);
36
0
    RTPSMessageCreator::addSubmessageAcknack(msg, readerId, writerId, SNSet, count, finalFlag);
37
0
    msg->length = msg->pos;
38
0
    return true;
39
0
}
40
41
bool RTPSMessageCreator::addSubmessageAcknack(
42
        CDRMessage_t* msg,
43
        const EntityId_t& readerId,
44
        const EntityId_t& writerId,
45
        const SequenceNumberSet_t& SNSet,
46
        int32_t count,
47
        bool finalFlag)
48
0
{
49
0
    octet flags = 0x0;
50
0
    Endianness_t old_endianess = msg->msg_endian;
51
#if FASTDDS_IS_BIG_ENDIAN_TARGET
52
    msg->msg_endian = BIGEND;
53
#else
54
0
    flags = flags | BIT(0);
55
0
    msg->msg_endian  = LITTLEEND;
56
0
#endif // if FASTDDS_IS_BIG_ENDIAN_TARGET
57
58
0
    if (finalFlag)
59
0
    {
60
0
        flags = flags | BIT(1);
61
0
    }
62
63
    // Submessage header.
64
0
    CDRMessage::addOctet(msg, ACKNACK);
65
0
    CDRMessage::addOctet(msg, flags);
66
0
    uint32_t submessage_size_pos = msg->pos;
67
0
    uint16_t submessage_size = 0;
68
0
    CDRMessage::addUInt16(msg, submessage_size);
69
0
    uint32_t position_size_count_size = msg->pos;
70
71
0
    CDRMessage::addEntityId(msg, &readerId);
72
0
    CDRMessage::addEntityId(msg, &writerId);
73
    //Add Sequence Number
74
0
    CDRMessage::addSequenceNumberSet(msg, &SNSet);
75
0
    CDRMessage::addInt32(msg, count);
76
77
    //TODO(Ricardo) Improve.
78
0
    submessage_size = uint16_t(msg->pos - position_size_count_size);
79
0
    octet* o = (octet*)&submessage_size;
80
0
    if (msg->msg_endian == DEFAULT_ENDIAN)
81
0
    {
82
0
        msg->buffer[submessage_size_pos] = *(o);
83
0
        msg->buffer[submessage_size_pos + 1] = *(o + 1);
84
0
    }
85
0
    else
86
0
    {
87
0
        msg->buffer[submessage_size_pos] = *(o + 1);
88
0
        msg->buffer[submessage_size_pos + 1] = *(o);
89
0
    }
90
91
0
    msg->msg_endian = old_endianess;
92
93
0
    return true;
94
0
}
95
96
bool RTPSMessageCreator::addMessageNackFrag(
97
        CDRMessage_t* msg,
98
        const GuidPrefix_t& guidprefix,
99
        const GuidPrefix_t& remoteGuidPrefix,
100
        const EntityId_t& readerId,
101
        const EntityId_t& writerId,
102
        SequenceNumber_t& writerSN,
103
        FragmentNumberSet_t fnState,
104
        int32_t count)
105
0
{
106
0
    RTPSMessageCreator::addHeader(msg, guidprefix);
107
0
    RTPSMessageCreator::addSubmessageInfoDST(msg, remoteGuidPrefix);
108
0
    RTPSMessageCreator::addSubmessageNackFrag(msg, readerId, writerId, writerSN, fnState, count);
109
0
    msg->length = msg->pos;
110
0
    return true;
111
0
}
112
113
bool RTPSMessageCreator::addSubmessageNackFrag(
114
        CDRMessage_t* msg,
115
        const EntityId_t& readerId,
116
        const EntityId_t& writerId,
117
        const SequenceNumber_t& writerSN,
118
        FragmentNumberSet_t fnState,
119
        int32_t count)
120
0
{
121
0
    octet flags = 0x0;
122
0
    Endianness_t old_endianess = msg->msg_endian;
123
#if FASTDDS_IS_BIG_ENDIAN_TARGET
124
    msg->msg_endian = BIGEND;
125
#else
126
0
    flags = flags | BIT(0);
127
0
    msg->msg_endian = LITTLEEND;
128
0
#endif // if FASTDDS_IS_BIG_ENDIAN_TARGET
129
130
    // Submessage header.
131
0
    CDRMessage::addOctet(msg, NACK_FRAG);
132
0
    CDRMessage::addOctet(msg, flags);
133
0
    uint32_t submessage_size_pos = msg->pos;
134
0
    uint16_t submessage_size = 0;
135
0
    CDRMessage::addUInt16(msg, submessage_size);
136
0
    uint32_t position_size_count_size = msg->pos;
137
138
0
    CDRMessage::addEntityId(msg, &readerId);
139
0
    CDRMessage::addEntityId(msg, &writerId);
140
    //Add Sequence Number
141
0
    CDRMessage::addSequenceNumber(msg, &writerSN);
142
    // Add fragment number status
143
0
    CDRMessage::addFragmentNumberSet(msg, &fnState);
144
0
    CDRMessage::addUInt32(msg, count);
145
146
    //TODO(Ricardo) Improve.
147
0
    submessage_size = uint16_t(msg->pos - position_size_count_size);
148
0
    octet* o = (octet*)&submessage_size;
149
0
    if (msg->msg_endian == DEFAULT_ENDIAN)
150
0
    {
151
0
        msg->buffer[submessage_size_pos] = *(o);
152
0
        msg->buffer[submessage_size_pos + 1] = *(o + 1);
153
0
    }
154
0
    else
155
0
    {
156
0
        msg->buffer[submessage_size_pos] = *(o + 1);
157
0
        msg->buffer[submessage_size_pos + 1] = *(o);
158
0
    }
159
160
0
    msg->msg_endian = old_endianess;
161
162
0
    return true;
163
0
}
164
165
} // namespace rtps
166
} // namespace fastrtps
167
} // namespace eprosima