We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
run-emitter.c //--------------------------
#include <yaml.h> #include <stdlib.h> #include <stdio.h> #include <string.h> #ifdef NDEBUG #undef NDEBUG #endif #include <assert.h> #define BUFFER_SIZE 65536 #define MAX_EVENTS 1024 int copy_event(yaml_event_t *event_to, yaml_event_t *event_from) { switch (event_from->type) { case YAML_STREAM_START_EVENT: return yaml_stream_start_event_initialize(event_to, event_from->data.stream_start.encoding); case YAML_STREAM_END_EVENT: return yaml_stream_end_event_initialize(event_to); case YAML_DOCUMENT_START_EVENT: return yaml_document_start_event_initialize(event_to, event_from->data.document_start.version_directive, event_from->data.document_start.tag_directives.start, event_from->data.document_start.tag_directives.end, event_from->data.document_start.implicit); case YAML_DOCUMENT_END_EVENT: return yaml_document_end_event_initialize(event_to, event_from->data.document_end.implicit); case YAML_ALIAS_EVENT: return yaml_alias_event_initialize(event_to, event_from->data.alias.anchor); case YAML_SCALAR_EVENT: return yaml_scalar_event_initialize(event_to, event_from->data.scalar.anchor, event_from->data.scalar.tag, event_from->data.scalar.value, event_from->data.scalar.length, event_from->data.scalar.plain_implicit, event_from->data.scalar.quoted_implicit, event_from->data.scalar.style); case YAML_SEQUENCE_START_EVENT: return yaml_sequence_start_event_initialize(event_to, event_from->data.sequence_start.anchor, event_from->data.sequence_start.tag, event_from->data.sequence_start.implicit, event_from->data.sequence_start.style); case YAML_SEQUENCE_END_EVENT: return yaml_sequence_end_event_initialize(event_to); case YAML_MAPPING_START_EVENT: return yaml_mapping_start_event_initialize(event_to, event_from->data.mapping_start.anchor, event_from->data.mapping_start.tag, event_from->data.mapping_start.implicit, event_from->data.mapping_start.style); case YAML_MAPPING_END_EVENT: return yaml_mapping_end_event_initialize(event_to); default: assert(1); } return 0; } int print_output(char *name, unsigned char *buffer, size_t size, int count) { FILE *file; char data[BUFFER_SIZE]; size_t data_size = 1; size_t total_size = 0; if (count >= 0) { printf("FAILED (at the event #%d)\nSOURCE:\n", count+1); } file = fopen(name, "rb"); assert(file); while (data_size > 0) { data_size = fread(data, 1, BUFFER_SIZE, file); assert(!ferror(file)); if (!data_size) break; assert(fwrite(data, 1, data_size, stdout) == data_size); total_size += data_size; if (feof(file)) break; } fclose(file); printf("#### (length: %ld)\n", (long)total_size); printf("OUTPUT:\n%s#### (length: %ld)\n", buffer, (long)size); return 0; } int main(int argc, char *argv[]) { int number; int canonical = 0; int unicode = 0; number = 1; while (number < argc) { if (strcmp(argv[number], "-c") == 0) { canonical = 1; } else if (strcmp(argv[number], "-u") == 0) { unicode = 1; } else if (argv[number][0] == '-') { printf("Unknown option: '%s'\n", argv[number]); return 0; } if (argv[number][0] == '-') { if (number < argc-1) { memmove(argv+number, argv+number+1, (argc-number-1)*sizeof(char *)); } argc --; } else { number ++; } } if (argc < 2) { printf("Usage: %s [-c] [-u] file1.yaml ...\n", argv[0]); return 0; } for (number = 1; number < argc; number ++) { FILE *file; yaml_parser_t parser; yaml_emitter_t emitter; yaml_event_t event; unsigned char buffer[BUFFER_SIZE+1]; size_t written = 0; yaml_event_t events[MAX_EVENTS]; size_t event_number = 0; int done = 0; int count = 0; int error = 0; int k; memset(buffer, 0, BUFFER_SIZE+1); memset(events, 0, MAX_EVENTS*sizeof(yaml_event_t)); printf("[%d] Parsing, emitting, and parsing again '%s': ", number, argv[number]); fflush(stdout); file = fopen(argv[number], "rb"); assert(file); assert(yaml_parser_initialize(&parser)); yaml_parser_set_input_file(&parser, file); assert(yaml_emitter_initialize(&emitter)); if (canonical) { yaml_emitter_set_canonical(&emitter, 1); } if (unicode) { yaml_emitter_set_unicode(&emitter, 1); } yaml_emitter_set_output_string(&emitter, buffer, BUFFER_SIZE, &written); while (!done) { if (!yaml_parser_parse(&parser, &event)) { error = 1; break; } done = (event.type == YAML_STREAM_END_EVENT); assert(event_number < MAX_EVENTS); assert(copy_event(&(events[event_number]), &event)); //assert(yaml_emitter_emit(&emitter, &event) || assert(yaml_emitter_emit(&emitter, events+event_number) || print_output(argv[number], buffer, written, count)); count ++; event_number ++; } yaml_parser_delete(&parser); assert(!fclose(file)); yaml_emitter_delete(&emitter); for (k = 0; k < event_number; k ++) { yaml_event_delete(events+k); } printf("PASSED (length: %ld)\n", (long)written); print_output(argv[number], buffer, written, -1); } return 0; }
//---------
e.yaml //-----------
body: keys: - index: 1 type: asymm|others alg: algname keysize: 32
//-----------
[1] Parsing, emitting, and parsing again 'e.yaml': *** Error in `./run-emitter': double free or corruption (fasttop): 0x0000000000621760 *** ======= Backtrace: ========= /lib64/libc.so.6(+0x81329)[0x7ffff786e329] ... #error : (gdb) yaml_event_delete(events+k) p event->data.scalar $2 = {anchor = 0x0, tag = 0x0, value = 0x621760 "\240\026b", length = 5, plain_implicit = 1, quoted_implicit = 0, style = YAML_PLAIN_SCALAR_STYLE} //value = "index"
The text was updated successfully, but these errors were encountered:
Approval
Sorry, something went wrong.
No branches or pull requests
run-emitter.c
//--------------------------
//---------
e.yaml
//-----------
//-----------
# gcc run-editter.c -o run-emitter
# ./run-emitter -u e.yaml
The text was updated successfully, but these errors were encountered: