Bitcoin Core 31.0.0
P2P Digital Currency
Loading...
Searching...
No Matches
script_descriptor_cache.cpp
Go to the documentation of this file.
1// Copyright (c) 2020-present 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#include <pubkey.h>
6#include <script/descriptor.h>
8#include <test/fuzz/fuzz.h>
9#include <test/fuzz/util.h>
10
11#include <cstdint>
12#include <optional>
13#include <string>
14#include <vector>
15
17{
18 FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size());
21 const std::vector<uint8_t> code = fuzzed_data_provider.ConsumeBytes<uint8_t>(BIP32_EXTKEY_SIZE);
22 if (code.size() == BIP32_EXTKEY_SIZE) {
24 xpub.Decode(code.data());
28 (void)descriptor_cache.GetCachedParentExtPubKey(key_exp_pos, xpub_fetched);
29 descriptor_cache.CacheParentExtPubKey(key_exp_pos, xpub);
30 assert(descriptor_cache.GetCachedParentExtPubKey(key_exp_pos, xpub_fetched));
31 } else {
33 (void)descriptor_cache.GetCachedDerivedExtPubKey(key_exp_pos, der_index, xpub_fetched);
34 descriptor_cache.CacheDerivedExtPubKey(key_exp_pos, der_index, xpub);
35 assert(descriptor_cache.GetCachedDerivedExtPubKey(key_exp_pos, der_index, xpub_fetched));
36 }
38 }
39 (void)descriptor_cache.GetCachedParentExtPubKeys();
40 (void)descriptor_cache.GetCachedDerivedExtPubKeys();
41 }
42}
Cache for single descriptor's derived extended pubkeys.
Definition descriptor.h:19
std::vector< T > ConsumeBytes(size_t num_bytes)
#define FUZZ_TARGET(...)
Definition fuzz.h:35
#define LIMITED_WHILE(condition, limit)
Can be used to limit a theoretically unbounded loop.
Definition fuzz.h:22
const unsigned int BIP32_EXTKEY_SIZE
Definition pubkey.h:19
void Decode(const unsigned char code[BIP32_EXTKEY_SIZE])
Definition pubkey.cpp:394
constexpr auto Ticks(Dur2 d)
Helper to count the seconds of a duration/time_point.
Definition time.h:73
assert(!tx.IsCoinBase())
FuzzedDataProvider & fuzzed_data_provider
Definition fees.cpp:38