Bitcoin ABC  0.29.2
P2P Digital Currency
keyorigin.h
Go to the documentation of this file.
1 // Copyright (c) 2019 The Bitcoin Core developers
2 // Distributed under the MIT software license, see the accompanying
3 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
4 
5 #ifndef BITCOIN_SCRIPT_KEYORIGIN_H
6 #define BITCOIN_SCRIPT_KEYORIGIN_H
7 
8 #include <serialize.h>
9 #include <vector>
10 
11 struct KeyOriginInfo {
13  uint8_t fingerprint[4];
14  std::vector<uint32_t> path;
15 
16  friend bool operator==(const KeyOriginInfo &a, const KeyOriginInfo &b) {
17  return std::equal(std::begin(a.fingerprint), std::end(a.fingerprint),
18  std::begin(b.fingerprint)) &&
19  a.path == b.path;
20  }
21 
23  READWRITE(obj.fingerprint, obj.path);
24  }
25 
26  void clear() {
27  memset(fingerprint, 0, 4);
28  path.clear();
29  }
30 };
31 
32 #endif // BITCOIN_SCRIPT_KEYORIGIN_H
#define READWRITE(...)
Definition: serialize.h:166
friend bool operator==(const KeyOriginInfo &a, const KeyOriginInfo &b)
Definition: keyorigin.h:16
SERIALIZE_METHODS(KeyOriginInfo, obj)
Definition: keyorigin.h:22
std::vector< uint32_t > path
Definition: keyorigin.h:14
uint8_t fingerprint[4]
First 32 bits of the Hash160 of the public key at the root of the path.
Definition: keyorigin.h:13
void clear()
Definition: keyorigin.h:26