Merge #18863: refactor: Make CScriptVisitor stateless

3351c91ed4 refactor: Make CScriptVisitor stateless (João Barbosa)

Pull request description:

  `CScriptVisitor` was added in 1025440184 (#1357) and the visitor return type was never used. Now `CScriptVisitor` is stateless and `CScript` is the return type.

ACKs for top commit:
  MarcoFalke:
    ACK 3351c91ed4 🏤
  sipa:
    utACK 3351c91ed4

Tree-SHA512: d158ad2ebe8ea4dc8cc090b943dd66fa5421a84f9443e16ab2d661df38e1a85de16ff13cbaa56924489d8d43cba25fa3cd8b6904bbbcbf356b886ffe8ffba19a
This commit is contained in:
MarcoFalke 2020-06-19 07:52:19 -04:00
commit 5f72ddb7ee
No known key found for this signature in database
GPG key ID: CE2B75697E69A548

View file

@ -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)