A Discrete-Event Network Simulator
API
bit-deserializer.cc
Go to the documentation of this file.
1/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/*
3 * Copyright (c) 2020 Universita' di Firenze, Italy
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation;
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 *
18 * Author: Tommaso Pecorella <tommaso.pecorella@unifi.it>
19 */
20
21#include <iostream>
22#include "bit-deserializer.h"
23#include "ns3/log.h"
24#include "ns3/abort.h"
25
26namespace ns3 {
27
28NS_LOG_COMPONENT_DEFINE ("BitDeserializer");
29
31{
32 NS_LOG_FUNCTION (this);
33 m_deserializing = false;
34}
35
36void BitDeserializer::PushBytes (std::vector<uint8_t> bytes)
37{
38 NS_LOG_FUNCTION (this << bytes);
39 NS_ABORT_MSG_IF (m_deserializing, "Can't add bytes after deserialization started");
40 m_bytesBlob.insert (m_bytesBlob.end (), bytes.begin (), bytes.end ());
41}
42
43void BitDeserializer::PushBytes (uint8_t* bytes, uint32_t size)
44{
45 NS_LOG_FUNCTION (this << bytes << size);
46 NS_ABORT_MSG_IF (m_deserializing, "Can't add bytes after deserialization started");
47 for (uint32_t index = 0; index < size; index++)
48 {
49 m_bytesBlob.push_back (bytes[index]);
50 }
51}
52
53void BitDeserializer::PushByte (uint8_t byte)
54{
55 NS_LOG_FUNCTION (this << +byte);
56 NS_ABORT_MSG_IF (m_deserializing, "Can't add bytes after deserialization started");
57 m_bytesBlob.push_back (byte);
58}
59
60uint64_t BitDeserializer::GetBits (uint8_t size)
61{
62 NS_LOG_FUNCTION (this << +size);
63 uint8_t result = 0;
65
66 NS_ABORT_MSG_IF (size > 64, "Number of requested bits exceeds 64");
67 NS_ABORT_MSG_IF (size > m_blob.size (), "Number of requested bits exceeds blob size");
68
69 for (uint8_t i = 0; i < size; i++)
70 {
71 result <<= 1;
72 result |= m_blob.front ();
73 m_blob.pop_front ();
74 }
75 return result;
76}
77
79{
80 NS_LOG_FUNCTION (this);
81 if (m_deserializing == false)
82 {
83 m_deserializing = true;
84 for (auto index = m_bytesBlob.begin (); index != m_bytesBlob.end (); index++)
85 {
86 m_blob.push_back (*index & 0x80);
87 m_blob.push_back (*index & 0x40);
88 m_blob.push_back (*index & 0x20);
89 m_blob.push_back (*index & 0x10);
90 m_blob.push_back (*index & 0x8);
91 m_blob.push_back (*index & 0x4);
92 m_blob.push_back (*index & 0x2);
93 m_blob.push_back (*index & 0x1);
94 }
95 }
96}
97
98} // namespace ns3
void PushBytes(std::vector< uint8_t > bytes)
Pushes some bytes into the blob to be deserialized.
std::vector< uint8_t > m_bytesBlob
Blob of bytes to be deserialized.
void PrepareDeserialization()
Prepare the byte array to the deserialization.
void PushByte(uint8_t byte)
Pushes one byte into the blob to be deserialized.
bool m_deserializing
True if the deserialization did start already.
std::deque< bool > m_blob
Blob of bits ready to be deserialized.
uint64_t GetBits(uint8_t size)
Pops a given number of bits from the blob front.
#define NS_ABORT_MSG_IF(cond, msg)
Abnormal program termination if a condition is true, with a message.
Definition: abort.h:108
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:205
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
Every class exported by the ns3 library is enclosed in the ns3 namespace.