Skip to content

Commit be67831

Browse files
committed
Make DummySignatureCreator a singleton
1 parent 190b8d2 commit be67831

File tree

4 files changed

+26
-33
lines changed

4 files changed

+26
-33
lines changed

src/script/ismine.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -146,7 +146,7 @@ isminetype IsMine(const CKeyStore &keystore, const CScript& scriptPubKey, bool&
146146
if (keystore.HaveWatchOnly(scriptPubKey)) {
147147
// TODO: This could be optimized some by doing some work after the above solver
148148
SignatureData sigs;
149-
return ProduceSignature(keystore, DummySignatureCreator(), scriptPubKey, sigs) ? ISMINE_WATCH_SOLVABLE : ISMINE_WATCH_UNSOLVABLE;
149+
return ProduceSignature(keystore, DUMMY_SIGNATURE_CREATOR, scriptPubKey, sigs) ? ISMINE_WATCH_SOLVABLE : ISMINE_WATCH_UNSOLVABLE;
150150
}
151151
return ISMINE_NO;
152152
}

src/script/sign.cpp

Lines changed: 23 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -392,54 +392,51 @@ SignatureData CombineSignatures(const CScript& scriptPubKey, const BaseSignature
392392

393393
namespace {
394394
/** Dummy signature checker which accepts all signatures. */
395-
class DummySignatureChecker : public BaseSignatureChecker
395+
class DummySignatureChecker final : public BaseSignatureChecker
396396
{
397397
public:
398398
DummySignatureChecker() {}
399+
bool CheckSig(const std::vector<unsigned char>& scriptSig, const std::vector<unsigned char>& vchPubKey, const CScript& scriptCode, SigVersion sigversion) const override { return true; }
400+
};
401+
const DummySignatureChecker DUMMY_CHECKER;
399402

400-
bool CheckSig(const std::vector<unsigned char>& scriptSig, const std::vector<unsigned char>& vchPubKey, const CScript& scriptCode, SigVersion sigversion) const override
403+
class DummySignatureCreator final : public BaseSignatureCreator {
404+
public:
405+
DummySignatureCreator() {}
406+
const BaseSignatureChecker& Checker() const override { return DUMMY_CHECKER; }
407+
bool CreateSig(const SigningProvider& provider, std::vector<unsigned char>& vchSig, const CKeyID& keyid, const CScript& scriptCode, SigVersion sigversion) const override
401408
{
409+
// Create a dummy signature that is a valid DER-encoding
410+
vchSig.assign(72, '\000');
411+
vchSig[0] = 0x30;
412+
vchSig[1] = 69;
413+
vchSig[2] = 0x02;
414+
vchSig[3] = 33;
415+
vchSig[4] = 0x01;
416+
vchSig[4 + 33] = 0x02;
417+
vchSig[5 + 33] = 32;
418+
vchSig[6 + 33] = 0x01;
419+
vchSig[6 + 33 + 32] = SIGHASH_ALL;
402420
return true;
403421
}
404422
};
405-
const DummySignatureChecker dummyChecker;
406-
} // namespace
407-
408-
const BaseSignatureChecker& DummySignatureCreator::Checker() const
409-
{
410-
return dummyChecker;
411423
}
412424

413-
bool DummySignatureCreator::CreateSig(const SigningProvider& provider, std::vector<unsigned char>& vchSig, const CKeyID& keyid, const CScript& scriptCode, SigVersion sigversion) const
414-
{
415-
// Create a dummy signature that is a valid DER-encoding
416-
vchSig.assign(72, '\000');
417-
vchSig[0] = 0x30;
418-
vchSig[1] = 69;
419-
vchSig[2] = 0x02;
420-
vchSig[3] = 33;
421-
vchSig[4] = 0x01;
422-
vchSig[4 + 33] = 0x02;
423-
vchSig[5 + 33] = 32;
424-
vchSig[6 + 33] = 0x01;
425-
vchSig[6 + 33 + 32] = SIGHASH_ALL;
426-
return true;
427-
}
425+
const BaseSignatureCreator& DUMMY_SIGNATURE_CREATOR = DummySignatureCreator();
428426

429427
bool IsSolvable(const SigningProvider& provider, const CScript& script)
430428
{
431429
// This check is to make sure that the script we created can actually be solved for and signed by us
432430
// if we were to have the private keys. This is just to make sure that the script is valid and that,
433431
// if found in a transaction, we would still accept and relay that transaction. In particular,
434432
// it will reject witness outputs that require signing with an uncompressed public key.
435-
static const DummySignatureCreator creator;
436433
SignatureData sigs;
437434
// Make sure that STANDARD_SCRIPT_VERIFY_FLAGS includes SCRIPT_VERIFY_WITNESS_PUBKEYTYPE, the most
438435
// important property this function is designed to test for.
439436
static_assert(STANDARD_SCRIPT_VERIFY_FLAGS & SCRIPT_VERIFY_WITNESS_PUBKEYTYPE, "IsSolvable requires standard script flags to include WITNESS_PUBKEYTYPE");
440-
if (ProduceSignature(provider, creator, script, sigs)) {
437+
if (ProduceSignature(provider, DUMMY_SIGNATURE_CREATOR, script, sigs)) {
441438
// VerifyScript check is just defensive, and should never fail.
442-
assert(VerifyScript(sigs.scriptSig, script, &sigs.scriptWitness, STANDARD_SCRIPT_VERIFY_FLAGS, creator.Checker()));
439+
assert(VerifyScript(sigs.scriptSig, script, &sigs.scriptWitness, STANDARD_SCRIPT_VERIFY_FLAGS, DUMMY_CHECKER));
443440
return true;
444441
}
445442
return false;

src/script/sign.h

Lines changed: 1 addition & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -58,11 +58,7 @@ class MutableTransactionSignatureCreator : public TransactionSignatureCreator {
5858
};
5959

6060
/** A signature creator that just produces 72-byte empty signatures. */
61-
class DummySignatureCreator : public BaseSignatureCreator {
62-
public:
63-
const BaseSignatureChecker& Checker() const override;
64-
bool CreateSig(const SigningProvider& provider, std::vector<unsigned char>& vchSig, const CKeyID& keyid, const CScript& scriptCode, SigVersion sigversion) const override;
65-
};
61+
extern const BaseSignatureCreator& DUMMY_SIGNATURE_CREATOR;
6662

6763
struct SignatureData {
6864
CScript scriptSig;

src/wallet/wallet.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1535,7 +1535,7 @@ bool CWallet::DummySignInput(CTxIn &tx_in, const CTxOut &txout) const
15351535
const CScript& scriptPubKey = txout.scriptPubKey;
15361536
SignatureData sigdata;
15371537

1538-
if (!ProduceSignature(*this, DummySignatureCreator(), scriptPubKey, sigdata))
1538+
if (!ProduceSignature(*this, DUMMY_SIGNATURE_CREATOR, scriptPubKey, sigdata))
15391539
{
15401540
return false;
15411541
} else {

0 commit comments

Comments
 (0)