From 6d93f97b511e21c54ae99eda97d3ae03d48e1bed Mon Sep 17 00:00:00 2001 From: Lex Berezhny Date: Fri, 14 Feb 2020 11:35:48 -0500 Subject: [PATCH] Transaction._deserialize now optionally accepts stream and returns self --- lbry/wallet/transaction.py | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/lbry/wallet/transaction.py b/lbry/wallet/transaction.py index df9beddcf..8536ddad2 100644 --- a/lbry/wallet/transaction.py +++ b/lbry/wallet/transaction.py @@ -674,9 +674,9 @@ class Transaction: stream.write_uint32(self.signature_hash_type(1)) # signature hash type: SIGHASH_ALL return stream.get_bytes() - def _deserialize(self): - if self._raw is not None: - stream = BCDataStream(self._raw) + def _deserialize(self, stream=None): + if self._raw is not None or stream is not None: + stream = stream or BCDataStream(self._raw) self.version = stream.read_uint32() input_count = stream.read_compact_size() if input_count == 0: @@ -697,6 +697,7 @@ class Transaction: for _ in range(stream.read_compact_size()): self.witnesses.append(stream.read(stream.read_compact_size())) self.locktime = stream.read_uint32() + return self @classmethod def ensure_all_have_same_ledger_and_wallet(