From 196db2ef0cd44c3fb542b86be7929bd01d83e138 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Thu, 12 Aug 2021 22:33:47 -0400 Subject: Put rdf:type properties first when pretty-printing This is a common convention in Turtle and TriG because the special "a" syntax for rdf type as the first property looks nice, makes things easier to read, and can be useful for streaming implementations because the type of the instance is known before reading its properties. Also significantly clean up the pretty-printing implementation in the process. --- tools/serd-sort.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'tools/serd-sort.c') diff --git a/tools/serd-sort.c b/tools/serd-sort.c index 8ba99445..5e71e95e 100644 --- a/tools/serd-sort.c +++ b/tools/serd-sort.c @@ -176,7 +176,8 @@ print_usage(const char* const name, const bool error) " -c COLLATION An optional \"G\" then the letters \"SPO\" in any order.\n" " -h Display this help and exit.\n" " -k BYTES Parser stack size.\n" - " -o FILENAME Write output to FILENAME instead of stdout.\n"; + " -o FILENAME Write output to FILENAME instead of stdout.\n" + " -t Do not write type as \"a\" before other properties.\n"; FILE* const os = error ? stderr : stdout; fprintf(os, "%s", error ? "\n" : ""); @@ -221,6 +222,11 @@ parse_option(OptionIter* const iter, Options* const opts) case 's': return serd_get_argument(iter, &opts->input_string); + case 't': + opts->common.output.flags |= SERD_WRITE_RDF_TYPE; + opts->flags |= SERD_NO_TYPE_FIRST; + return serd_option_iter_advance(iter); + default: break; } -- cgit v1.2.1