#include "bitcoin/script.h" #include "bitcoin/tx.h" #include "find_p2sh_out.h" #include #include #include static u32 find_output(const struct bitcoin_tx *tx, const u8 *scriptpubkey) { u32 i; for (i = 0; i < tx->output_count; i++) { if (tx->output[i].script_length != tal_count(scriptpubkey)) continue; if (memcmp(tx->output[i].script, scriptpubkey, tal_count(scriptpubkey)) == 0) break; } /* FIXME: Return failure! */ if (i == tx->output_count) errx(1, "No matching output in tx"); return i; } u32 find_p2sh_out(const struct bitcoin_tx *tx, const u8 *redeemscript) { /* This is the scriptPubKey commit tx will have */ u8 *p2sh = scriptpubkey_p2sh(NULL, redeemscript); u32 i; i = find_output(tx, p2sh); tal_free(p2sh); return i; } u32 find_p2wsh_out(const struct bitcoin_tx *tx, const u8 *witnessscript) { /* This is the scriptPubKey commit tx will have */ u8 *p2wsh = scriptpubkey_p2wsh(NULL, witnessscript); u32 i; i = find_output(tx, p2wsh); tal_free(p2wsh); return i; }