blob: e90e0f22a74188cd3bbfc9b964425b0ffd2d5d80 (
plain) (
blame)
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
|
/**
* Copyright 2018 VMware
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "hotstuff/entity.h"
#include "hotstuff/hotstuff.h"
namespace hotstuff {
void Block::serialize(DataStream &s) const {
s << htole((uint32_t)parent_hashes.size());
for (const auto &hash: parent_hashes)
s << hash;
s << htole((uint32_t)cmds.size());
for (auto cmd: cmds)
s << cmd;
if (qc)
s << (uint8_t)1 << *qc;
else
s << (uint8_t)0;
s << htole((uint32_t)extra.size()) << extra;
}
void Block::unserialize(DataStream &s, HotStuffCore *hsc) {
uint32_t n;
uint8_t flag;
s >> n;
n = letoh(n);
parent_hashes.resize(n);
for (auto &hash: parent_hashes)
s >> hash;
s >> n;
n = letoh(n);
cmds.resize(n);
for (auto &cmd: cmds)
s >> cmd;
// for (auto &cmd: cmds)
// cmd = hsc->parse_cmd(s);
s >> flag;
qc = flag ? hsc->parse_quorum_cert(s) : nullptr;
s >> n;
n = letoh(n);
if (n == 0)
extra.clear();
else
{
auto base = s.get_data_inplace(n);
extra = bytearray_t(base, base + n);
}
this->hash = salticidae::get_hash(*this);
}
}
|