Compartilhar via


BinaryFormat.Choice

Sintaxe

BinaryFormat.Choice(binaryFormat as function, chooseFunction as function, optional type as nullable type, optional combineFunction as nullable function) as function

Sobre

Retorna um formato binário que escolhe o próximo formato binário com base em um valor que já foi lido. O valor de formato binário produzido por essa função funciona em estágios:

  • O formato binário especificado pelo parâmetro binaryFormat é usado para ler um valor.
  • O valor é passado para a função choice especificada pelo parâmetro chooseFunction.
  • A função choice inspeciona o valor e retorna um segundo formato binário.
  • O segundo formato binário é usado para ler um segundo valor.
  • Se a função combine for especificada, o primeiro e o segundo valores serão passados para a função combine e o valor resultante será retornado.
  • Se a função combine não for especificada, o segundo valor será retornado.
  • O segundo valor é retornado.

O parâmetro opcional type indica o tipo de formato binário que será retornado pela função choice. type any, type list ou type binary pode ser especificado. Se o parâmetro type não for especificado, type any será usado. Se type list ou type binary for usado, o sistema poderá retornar um valor binary ou list de streaming, em vez de um armazenado em buffer, o que pode reduzir a quantidade de memória necessária para ler o formato.

Exemplo 1

Leia uma lista de bytes em que o número de elementos é determinado pelo primeiro byte.

Usage

let
    binaryData = #binary({2, 3, 4, 5}),
    listFormat = BinaryFormat.Choice(
        BinaryFormat.Byte,
        (length) => BinaryFormat.List(BinaryFormat.Byte, length)
    )
in
    listFormat(binaryData)

Saída

{3,4}

Exemplo 2

Leia uma lista de bytes em que o número de elementos seja determinado pelo primeiro byte e preserve o primeiro byte lido.

Usage

let
    binaryData = #binary({2, 3, 4, 5}),
    listFormat = BinaryFormat.Choice(
        BinaryFormat.Byte,
        (length) => BinaryFormat.Record([
            length = length,
            list = BinaryFormat.List(BinaryFormat.Byte, length)
        ])
    )
in
    listFormat(binaryData)

Saída

[length = 2, list = {3, 4}]

Exemplo 3

Leia uma lista de bytes em que o número de elementos seja determinado pelo primeiro byte usando uma lista de fluxo.

Usage

let
    binaryData = #binary({2, 3, 4, 5}),
    listFormat = BinaryFormat.Choice(
        BinaryFormat.Byte,
        (length) => BinaryFormat.List(BinaryFormat.Byte, length),
        type list
    )
in
    listFormat(binaryData)

Saída

{3, 4}