aboutsummaryrefslogtreecommitdiffstats
path: root/tools/serd-sort.c
AgeCommit message (Collapse)AuthorFilesLines
2022-01-28Fix handling of deferred write errors that happen when closingDavid Robillard1-1/+1
2022-01-28Use more human-readable status codesDavid Robillard1-2/+2
2022-01-28Simplify output stream APIDavid Robillard1-1/+1
This makes the paging mechanism an internal detail once again. While it's conceptually elegant to simply have a single write interface and have the block dumper just be another implementation of that, unfortunately it is not practical. The inlining of serd_block_dumper_write() is a significant performance boost, because it avoids a non-inlinable function call of overhead per character. Compared to the SerdByteSink approach, this removes the burden and overhead of needing to dynamically allocate the structure itself.
2022-01-28Provide a full output stream implementation for SerdBufferDavid Robillard1-0/+5
Essentially replaces serd_buffer_sink_finish() with serd_buffer_close(), which makes writing to a buffer consistent with writing to a file or anything else.
2022-01-28Put rdf:type properties first when pretty-printingDavid Robillard1-1/+7
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.
2022-01-28Make tools read stdin by defaultDavid Robillard1-2/+5
2022-01-28Replace serdi with more fine-grained toolsDavid Robillard1-0/+274
Especially with the new functionality, the complexity of the command-line interface alone was really becoming unmanageable. The serdi implementation also had the highest cyclomatic complexity of the entire codebase by a huge margin. So, take a page from the Unix philosophy and split serdi into several more finely-honed tools that can be freely composed. Though there is still unfortunately quite a bit of option overlap between them due to the common details of reading RDF, I think the resulting tools are a lot easier to understand, both from a user and a developer perspective.