Поддерживает ли avro C поддержку потоковой передачи, а не выход файла?

Я просмотрел документ C на avro и я вижу, что я могу получить только файл avro для файла. Как получить сериализованный вывод в буфер, чтобы я мог отправлять через tcp-сокет. Любая помощь очень ценится.

Ответ 1

Для этого случая существует avro_writer_memory(), он принимает указатель и длину буфера как параметры и дает вам avro_writer_t, который может использоваться в обычных функциях записи. Вы можете найти его использование в тестах, например this или this, Минимальным примером будет что-то вроде этого (вывод закодированного значения в stderr, поэтому лучше перенаправить его в некоторый файл и изучить его после запуска программы):

#include <avro.h>
#include <stdio.h>
#include <unistd.h>

static const char json_schema[] = "{ \"type\": \"string\" }";

int main(void)
{
    char buf[1024];
    avro_writer_t writer;
    avro_schema_t schema;
    avro_value_iface_t* iface;
    avro_value_t val;
    size_t len;

    if (avro_schema_from_json_literal(json_schema, &schema) != 0) {
        printf("failed to initialize schema\n");
        goto out;
    }
    if ((writer = avro_writer_memory(buf, sizeof(buf))) == NULL) {
        printf("failed to initialize writer\n");
        goto out_schema;
    }
    if ((iface = avro_generic_class_from_schema(schema)) == NULL) {
        printf("failed to get class from schema\n");
        goto out_writer;
    }
    if (avro_generic_value_new(iface, &val) != 0) {
        printf("failed to create new value\n");
        goto out_iface;
    }
    if (avro_value_reset(&val) != 0) {
        printf("failed to reset value\n");
        goto out_val;
    }
    if (avro_value_set_string(&val, "some string wrapped by avro") != 0) {
        printf("failed to set value string\n");
        goto out_val;
    }
    if (avro_value_write(writer, &val) != 0) {
        printf("failed to write value into the buffer\n");
        goto out_val;
    }
    len = avro_writer_tell(writer);
    printf("got %lu bytes\n", (unsigned long)len);
    if (write(STDERR_FILENO, buf, len) != len) {
        printf("failed to write to stderr, oops\n");
        goto out_val;
    }
out_val:
    avro_value_decref(&val);
out_iface:
    avro_value_iface_decref(iface);
out_writer:
    avro_writer_free(writer);
out_schema:
    avro_schema_decref(schema);
out:
    return 0;
}

Кроме того, существует avro_writer_memory_set_dest(), который позволяет установить новый буфер для использования существующим автором.