aboutsummaryrefslogtreecommitdiffstats
path: root/test
AgeCommit message (Collapse)AuthorFilesLines
2023-12-02Cache commonly used nodes in the worldDavid Robillard1-2/+1
2023-12-02Add SerdNodes for storing a cache of interned nodesDavid Robillard7-67/+688
2023-12-02Make blank node prefixing automaticDavid Robillard8-69/+3
Though potentially useful, I don't think the complexity cost of the old interface (both to the implementation and to the user) is worth it. A special tool to transform blank node labels (for example with regular expressions) would be a better approach to this if it's ever needed in the future.
2023-12-02Split SERD_READ_VERBATIM into two more precise flagsDavid Robillard1-1/+2
Although the "verbatim" idea is nice and simple, more fine-grained control is necessary since these features (relative URI preservation and blank node label clash avoidance) are useful in different situations.
2023-12-02Add a reader flag to disable generated blank label avoidanceDavid Robillard1-0/+1
2023-12-02Collapse input and output options into single flagsDavid Robillard5-30/+31
2023-12-02Expose serd_strncasecmp in public APIDavid Robillard1-7/+6
2023-12-02[WIP] Add support for converting literals to canonical formDavid Robillard12-0/+352
2023-12-02[WIP] Generalize node construction APIDavid Robillard12-307/+521
2023-12-02Add support for custom allocatorsDavid Robillard17-447/+1016
This makes it explicit in the API where memory is allocated, and allows the user to provide a custom allocator to avoid the use of the default system allocator for whatever reason.
2023-12-02Test handling of deferred write errors that happen when closingDavid Robillard2-5/+18
2023-12-02Add command-line option to write output to a fileDavid Robillard3-6/+14
2023-12-02[WIP] Remove SERD_CURIE node datatype entirelyDavid Robillard5-67/+32
2023-12-02[WIP] Expand URIs in readerDavid Robillard11-11/+133
This expands relative and prefixed URIs in the reader on the stack, rather than passing them to the caller to be dealt with. This pushes these context-full forms to the edge of the system as much as possible to minimise the headaches they can cause. Towards having stricter guarantees about nodes and eliminating the CURIE node type altogether.
2023-12-02[WIP] Move SerdEnv mutation from writer to readerDavid Robillard4-48/+48
Writing having side-effects seems questionable in general, and this prepares things for expanding URIs in the reader.
2023-12-02[WIP] Preserve long or short quoting from input documentsDavid Robillard24-109/+129
2023-12-02Leave statement caret at the start of literalsDavid Robillard1-0/+56
This allows a precise location to be reported for errors within literals, by adding the offset of the error in the literal to the caret. This will be used to report nice errors for things like regular expressions and supported XSD datatypes.
2023-12-02[WIP] Add extensible logging APIDavid Robillard2-2/+148
2023-12-02[WIP] Add support for reading and writing variablesDavid Robillard18-12/+148
[WIP] Command line option, move later? This adds a reader flag and serdi option for extending a syntax with support for SPARQL-like variables, for storing things like patterns or simple queries.
2023-12-02[TESTED] Replace -b and -e options with a block size optionDavid Robillard1-2/+6
This is more powerful, and reduces the number of command line options that almost nobody needs to care about.
2023-12-02Add support for reading multiple files at onceDavid Robillard5-0/+52
2023-12-02Simplify handling of input string argumentsDavid Robillard1-1/+2
2023-12-02Add base URI command-line optionDavid Robillard5-14/+52
2023-12-02Rename serdi to serd-pipeDavid Robillard7-33/+40
2023-12-02Move serdi to tools subdirectoryDavid Robillard2-2/+2
This separates the command-line tool code from the library implementation.
2023-12-02Remove datatype arguments from integer and base64 constructorsDavid Robillard1-12/+9
2023-12-02Simplify output stream APIDavid Robillard3-56/+97
2023-12-02Simplify input stream APIDavid Robillard4-55/+151
2023-12-02Make SerdBuffer an output streamDavid Robillard3-17/+22
2023-12-02Strengthen handling of corrupt UTF-8 inputDavid Robillard8-26/+208
2023-12-02Support writing all escapes in Turtle and TriG prefixed namesDavid Robillard3-2/+82
2023-12-02Separate Turtle and TriG reading codeDavid Robillard1-1/+2
2023-12-02Factor out NQuads readerDavid Robillard2-0/+10
2023-12-02Factor out NTriples readerDavid Robillard9-7/+74
2023-12-02Use Zix attributes directlyDavid Robillard3-4/+5
2023-12-02Use portable zix filesystem API in testsDavid Robillard4-57/+39
2023-12-02[WIP] Add zix dependencyDavid Robillard1-1/+3
Most of the system-specific code will be replaced with calls to portable zix functions, and the data structures will be used for in-memory node and statement storage.
2023-12-02Clean up SerdEnv testsDavid Robillard1-65/+249
2023-12-02Add serd_env_copy() and serd_env_equals()David Robillard1-0/+43
2023-12-02Simplify SerdEnv APIDavid Robillard1-40/+45
2023-12-02Test lax NTriples parsing separatelyDavid Robillard14-25/+89
2023-12-02Support reading lone lists in lax modeDavid Robillard3-0/+10
This allows parsing documents like "(42) ."
2023-12-02Align nodes on the reader stackDavid Robillard1-1/+3
2023-12-02Replace serd_reader_set_strict() with SerdReaderFlagsDavid Robillard3-11/+11
2023-12-02Split out simple reader unit testsDavid Robillard3-317/+404
2023-12-02Reduce complexity of statement writing functionsDavid Robillard1-1/+1
2023-12-02Add empty syntax type for suppressing outputDavid Robillard3-0/+68
2023-12-02Factor out test runner script argument parsingDavid Robillard4-46/+41
2023-12-02Use a simple type-safe stack in writerDavid Robillard1-0/+47
2023-12-02Add a set of limits to the worldDavid Robillard2-9/+19
The idea here is to remove the burden of passing things around like stack sizes (where most users don't care and will be happy with a reasonably large default) and keeping the call sites to things like serd_reader_new() clean. The cost is a bit more state, so it's both more powerful and more potentially flaky, since changing the limits has action at a distance that isn't clear from the call site. I think it's worth it for the cleaner API in the common case, and the much better forward compatibility.