Protomódulo

Es un módulo para el procesamiento de mensajes de protocolo.

Miembros

encode_text

string ProtoModule.encode_text(x)

Muestra la codificación del argumento struct como un mensaje de protocolo de formato de texto. La estructura de datos debe estar compuesta de forma recurrente por cadenas, números enteros, números de punto flotante o bools, o estructuras, secuencias y diccionarios de estos tipos.

Un struct se convierte en un mensaje. Los campos se emiten en orden de nombre.

Una secuencia (como una lista o una tupla) se convierte en un campo repetido. Sus elementos no deben ser secuencias ni dicts.

Un diccionario se convierte en un campo repetido de mensajes con campos llamados “clave” y “valor”. Las entradas se emiten en orden de iteración (inserción). Las claves del diccionario deben ser strings, ints o bools, y sus valores no deben ser secuencias ni dicts. Ejemplos:

struct(field=123).to_proto()
# field: 123

struct(field=True).to_proto()
# field: true

struct(field=[1, 2, 3]).to_proto()
# field: 1
# field: 2
# field: 3

struct(field='text').to_proto()
# field: "text"

struct(field=struct(inner_field='text')).to_proto()
# field {
#   inner_field: "text"
# }

struct(field=[struct(inner_field=1), struct(inner_field=2)]).to_proto()
# field {
#   inner_field: 1
# }
# field {
#   inner_field: 2
# }

struct(field=struct(inner_field=struct(inner_inner_field='text'))).to_proto()
# field {
#    inner_field {
#     inner_inner_field: "text"
#   }
# }

struct(foo={4: 3, 2: 1}).to_proto()
# foo: {
#   key: 4
#   value: 3
# }
# foo: {
#   key: 2
#   value: 1
# }

Parámetros

Parámetro Descripción
x obligatorio