mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-11 20:32:35 -03:00
Merge #18863: refactor: Make CScriptVisitor stateless
3351c91ed4
refactor: Make CScriptVisitor stateless (João Barbosa) Pull request description: `CScriptVisitor` was added in1025440184
(#1357) and the visitor return type was never used. Now `CScriptVisitor` is stateless and `CScript` is the return type. ACKs for top commit: MarcoFalke: ACK3351c91ed4
🏤 sipa: utACK3351c91ed4
Tree-SHA512: d158ad2ebe8ea4dc8cc090b943dd66fa5421a84f9443e16ab2d661df38e1a85de16ff13cbaa56924489d8d43cba25fa3cd8b6904bbbcbf356b886ffe8ffba19a
This commit is contained in:
commit
5f72ddb7ee
1 changed files with 26 additions and 38 deletions
|
@ -241,59 +241,47 @@ bool ExtractDestinations(const CScript& scriptPubKey, txnouttype& typeRet, std::
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
class CScriptVisitor : public boost::static_visitor<bool>
|
class CScriptVisitor : public boost::static_visitor<CScript>
|
||||||
{
|
{
|
||||||
private:
|
|
||||||
CScript *script;
|
|
||||||
public:
|
public:
|
||||||
explicit CScriptVisitor(CScript *scriptin) { script = scriptin; }
|
CScript operator()(const CNoDestination& dest) const
|
||||||
|
|
||||||
bool operator()(const CNoDestination &dest) const {
|
|
||||||
script->clear();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool operator()(const PKHash &keyID) const {
|
|
||||||
script->clear();
|
|
||||||
*script << OP_DUP << OP_HASH160 << ToByteVector(keyID) << OP_EQUALVERIFY << OP_CHECKSIG;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool operator()(const ScriptHash &scriptID) const {
|
|
||||||
script->clear();
|
|
||||||
*script << OP_HASH160 << ToByteVector(scriptID) << OP_EQUAL;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool operator()(const WitnessV0KeyHash& id) const
|
|
||||||
{
|
{
|
||||||
script->clear();
|
return CScript();
|
||||||
*script << OP_0 << ToByteVector(id);
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator()(const WitnessV0ScriptHash& id) const
|
CScript operator()(const PKHash& keyID) const
|
||||||
{
|
{
|
||||||
script->clear();
|
return CScript() << OP_DUP << OP_HASH160 << ToByteVector(keyID) << OP_EQUALVERIFY << OP_CHECKSIG;
|
||||||
*script << OP_0 << ToByteVector(id);
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator()(const WitnessUnknown& id) const
|
CScript operator()(const ScriptHash& scriptID) const
|
||||||
{
|
{
|
||||||
script->clear();
|
return CScript() << OP_HASH160 << ToByteVector(scriptID) << OP_EQUAL;
|
||||||
*script << CScript::EncodeOP_N(id.version) << std::vector<unsigned char>(id.program, id.program + id.length);
|
}
|
||||||
return true;
|
|
||||||
|
CScript operator()(const WitnessV0KeyHash& id) const
|
||||||
|
{
|
||||||
|
return CScript() << OP_0 << ToByteVector(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
CScript operator()(const WitnessV0ScriptHash& id) const
|
||||||
|
{
|
||||||
|
return CScript() << OP_0 << ToByteVector(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
CScript operator()(const WitnessUnknown& id) const
|
||||||
|
{
|
||||||
|
return CScript() << CScript::EncodeOP_N(id.version) << std::vector<unsigned char>(id.program, id.program + id.length);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const CScriptVisitor g_script_visitor;
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
CScript GetScriptForDestination(const CTxDestination& dest)
|
CScript GetScriptForDestination(const CTxDestination& dest)
|
||||||
{
|
{
|
||||||
CScript script;
|
return boost::apply_visitor(::g_script_visitor, dest);
|
||||||
|
|
||||||
boost::apply_visitor(CScriptVisitor(&script), dest);
|
|
||||||
return script;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CScript GetScriptForRawPubKey(const CPubKey& pubKey)
|
CScript GetScriptForRawPubKey(const CPubKey& pubKey)
|
||||||
|
|
Loading…
Reference in a new issue