mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
[DOC] More details about packed encoding.
This commit is contained in:
parent
8825533222
commit
ac6f80b4e9
@ -609,7 +609,9 @@ Through ``abi.encodePacked()``, Solidity supports a non-standard packed mode whe
|
|||||||
- types shorter than 32 bytes are neither zero padded nor sign extended and
|
- types shorter than 32 bytes are neither zero padded nor sign extended and
|
||||||
- dynamic types are encoded in-place and without the length.
|
- dynamic types are encoded in-place and without the length.
|
||||||
|
|
||||||
As an example encoding ``int8, bytes1, uint16, string`` with values ``-1, 0x42, 0x2424, "Hello, world!"`` results in:
|
This packed mode is mainly used for indexed event parameters.
|
||||||
|
|
||||||
|
As an example, the encoding of ``int8(-1), bytes1(0x42), uint16(0x2424), string("Hello, world!")`` results in:
|
||||||
|
|
||||||
.. code-block:: none
|
.. code-block:: none
|
||||||
|
|
||||||
@ -619,12 +621,18 @@ As an example encoding ``int8, bytes1, uint16, string`` with values ``-1, 0x42,
|
|||||||
^^^^ uint16(0x2424)
|
^^^^ uint16(0x2424)
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^ string("Hello, world!") without a length field
|
^^^^^^^^^^^^^^^^^^^^^^^^^^ string("Hello, world!") without a length field
|
||||||
|
|
||||||
More specifically, each statically-sized type takes as many bytes as its range has
|
More specifically:
|
||||||
and dynamically-sized types like ``string``, ``bytes`` or ``uint[]`` are encoded without
|
- Each value type takes as many bytes as its range has.
|
||||||
their length field. This means that the encoding is ambiguous as soon as there are two
|
- The encoding of a struct or fixed-size array is the concatenation of the
|
||||||
dynamically-sized elements.
|
encoding of its members/elements without any separator or padding.
|
||||||
|
- Mapping members of structs are ignored as usual.
|
||||||
|
- Dynamically-sized types like ``string``, ``bytes`` or ``uint[]`` are encoded without
|
||||||
|
their length field.
|
||||||
|
|
||||||
|
In general, the encoding is ambiguous as soon as there are two dynamically-sized elements,
|
||||||
|
because of the missing length field.
|
||||||
|
|
||||||
If padding is needed, explicit type conversions can be used: ``abi.encodePacked(uint16(0x12)) == hex"0012"``.
|
If padding is needed, explicit type conversions can be used: ``abi.encodePacked(uint16(0x12)) == hex"0012"``.
|
||||||
|
|
||||||
Since packed encoding is not used when calling functions, there is no special support
|
Since packed encoding is not used when calling functions, there is no special support
|
||||||
for prepending a function selector.
|
for prepending a function selector. Since the encoding is ambiguous, there is no decoding function.
|
||||||
|
Loading…
Reference in New Issue
Block a user