From 86e0980d19d58bb43636df770c7cf43557f7cc65 Mon Sep 17 00:00:00 2001 From: Andreas Schildbach Date: Tue, 4 Apr 2023 11:08:02 +0200 Subject: [PATCH] TransactionInput: fix `toString()` throws on unparseable script --- .../org/bitcoinj/core/TransactionInput.java | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/core/src/main/java/org/bitcoinj/core/TransactionInput.java b/core/src/main/java/org/bitcoinj/core/TransactionInput.java index 83ed6fbbd..869945697 100644 --- a/core/src/main/java/org/bitcoinj/core/TransactionInput.java +++ b/core/src/main/java/org/bitcoinj/core/TransactionInput.java @@ -578,20 +578,21 @@ public class TransactionInput { @Override public String toString() { StringBuilder s = new StringBuilder("TxIn"); - try { - if (isCoinBase()) { - s.append(": COINBASE"); - } else { - s.append(" for [").append(outpoint).append("]: ").append(getScriptSig()); + if (isCoinBase()) { + s.append(": COINBASE"); + } else { + s.append(" for [").append(outpoint).append("]: "); + try { + s.append(getScriptSig()); String flags = InternalUtils.commaJoin(hasWitness() ? "witness" : null, hasSequence() ? "sequence: " + Long.toHexString(sequence) : null, isOptInFullRBF() ? "opts into full RBF" : null); if (!flags.isEmpty()) s.append(" (").append(flags).append(')'); + } catch (ScriptException e) { + s.append(" [exception: ").append(e.getMessage()).append("]"); } - return s.toString(); - } catch (ScriptException e) { - throw new RuntimeException(e); } + return s.toString(); } }