ligo/gitlab-pages/docs/reference/bytes.md
Sander 8f60accc24 - Improve darkmode support
- Reenable code block tabs
- Reeneble code blocks highlighting
2020-03-04 13:19:00 +00:00

3.3 KiB

id title
bytes-reference Bytes — Manipulate bytes data

import Syntax from '@theme/Syntax';

Bytes.concat(b1: bytes, b2: bytes) : bytes

Concatenate together two bytes arguments and return the result.

function concat_op (const s : bytes) : bytes is
  begin skip end with bytes_concat(s , 0x7070)
let concat_op (s : bytes) : bytes =
   Bytes.concat s 0x7070
let concat_op = (s: bytes): bytes => Bytes.concat(s, 0x7070);

Bytes.slice(pos1: nat, pos2: nat, data: bytes) : bytes

Extract the bytes between pos1 and pos2. Positions are zero indexed and inclusive. For example if you gave the input "ff7a7aff" to the following:

function slice_op (const s : bytes) : bytes is
  begin skip end with bytes_slice(1n , 2n , s)
let slice_op (s : bytes) : bytes =
   Bytes.slice 1n 2n s
let slice_op = (s: bytes): bytes => Bytes.slice(1n, 2n, s);

It would return "7a7a" rather than "ff7a" or "ff" or "7a".

Bytes.pack(data: a') : bytes

Converts Michelson data structures to a binary format for serialization.

⚠️ PACK and UNPACK are features of Michelson that are intended to be used by people that really know what they're doing. There are several failure cases (such as UNPACKing a lambda from an untrusted source), most of which are beyond the scope of this document. Don't use these functions without doing your homework first.

function id_string (const p : string) : option(string) is block {
  const packed : bytes = bytes_pack(p) ;
} with (bytes_unpack(packed): option(string))
let id_string (p: string) : string option =
  let packed: bytes = Bytes.pack p in
  ((Bytes.unpack packed): string option)
let id_string = (p: string) : option(string) => {
  let packed : bytes = Bytes.pack(p);
  ((Bytes.unpack(packed)): option(string));
};

Bytes.unpack(packed: bytes) : a'

Reverses the result of using unpack on data, going from Michelson's binary serialization format to the option type annotated on the call.

⚠️ PACK and UNPACK are features of Michelson that are intended to be used by people that really know what they're doing. There are several failure cases (such as UNPACKing a lambda from an untrusted source), most of which are beyond the scope of this document. Don't use these functions without doing your homework first.

function id_string (const p : string) : option(string) is block {
  const packed : bytes = bytes_pack(p) ;
} with (bytes_unpack(packed): option(string))
let id_string (p: string) : string option =
  let packed: bytes = Bytes.pack p in
  ((Bytes.unpack packed): string option)
let id_string = (p: string) : option(string) => {
  let packed : bytes = Bytes.pack(p);
  ((Bytes.unpack(packed)): option(string));
};