mirror of
https://github.com/bitcoin/bips.git
synced 2025-01-18 21:35:13 +01:00
Script witness encoding.
This commit is contained in:
parent
2010cf4979
commit
ecdfa0a029
@ -63,8 +63,8 @@ The serialization has the following structure:
|
||||
| A list of one or more transaction outputs
|
||||
|-
|
||||
| 1+
|
||||
| witness
|
||||
| witness
|
||||
| script_witnesses
|
||||
| script_witnesses[]
|
||||
| The witness structure as a serialized byte array
|
||||
|-
|
||||
| 4
|
||||
@ -77,7 +77,7 @@ Parsers supporting this BIP will be able to distinguish between the old serializ
|
||||
|
||||
If the witness is empty, the old serialization format should be used.
|
||||
|
||||
Witness objects can be extended to contain other kinds of witness data not yet specified. This BIP is agnostic to the witness data structure, defined in [https://github.com/bitcoin/bips/blob/master/bip-0141.mediawiki BIP141] (Consensus segwit BIP), and treats it as an arbitrary byte array.
|
||||
Currently, the only witness objects type supported are script witnesses which consist of a stack of byte arrays. It is encoded as a var_int item count followed by each item encoded as a var_int length followed by a string of bytes. Each txin has its own script witness. The number of script witnesses is not explicitly encoded as it is implied by txin_count. Empty script witnesses are encoded as a zero byte. The order of the script witnesses follows the same order as the associated txins.
|
||||
|
||||
* '''Rationale for not having an independent message type with its own serialization''': this would require separate "tx" and "block" messages, and all RPC calls operating on raw transactions would need to be duplicated, or need inefficinent or nondeterministic guesswork to know which type is to be used.
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user