TRLD is a transpilable implementation of algorithms for working with Linked Data as JSON-LD. This includes translating to and from various RDF syntaxes and mapping of vocabularies.
TRLD is written in typed Python, with some extra care taken to support transpilation. The implementation can currently be transpiled into:
- Java
- Javascript
The transpiler is part of the codebase and only supports the small (somewhat redundantly cast) subset of type-annotated Python needed to implement these algorithms. It is not a generic transpiler.
When parsing RDF, the syntactic statements are transcribed verbatim into JSON-LD, keeping compact forms and ordering as much as possible. Conversely, serialization is done by writing the JSON-LD shape out as is, using the chosen syntax.
In order to control the exact shape of this data, use the JSON-LD algorithms for expansion, flattening and compaction.
At this time, care must be taken to use simple JSON-LD contexts in order for Turtle or TriG serialization to work. That means that, apart from prefixes and some support for language indexes and type coercion, no advanced compaction features of JSON-LD 1.1 will work when transcribing the data out as Turtle or TriG. If you process such compacted data, ensure to expand it first, and preferably re-compact it into a simpler form.
JSON-LD 1.1 (W3C Spec)
- Expansion
- Compaction
- Flattening
- RDF Serialization/Deserialization
N-Quads (W3C Spec)
- Parser
- Serializer
TriG (W3C Spec)
- Parser
- Serializer
RDF Dataset Canonicalization (W3C Spec)
- Canonicalization
- Canonical n-quads form
Target Vocabulary Maps (Experimental)
- Basic RDFS & OWL
- Property chains
- Reified forms
- SKOS matches
Python-based command-line usage:
$ python3 -m trld [-h] [-c CONTEXT] [-e [EXPAND_CONTEXT]] [-b BASE] [-f] \
[-i INPUT_FORMAT] [-o OUTPUT_FORMAT] [SOURCE ...]
Java-based command-line usage:
$ java -jar build/java/build/libs/trld-with-deps.jar [-f] [-c CONTEXT] FILE
JS-based command-line usage:
$ cd build/js
$ node -r esm lib/jsonld/cli.js [-f] [-c CONTEXT] FILE
Build requirements:
- Make
- For Python: Python >=3.10,<3.14 (plus mypy and pytest for development, and hatchling for packaging)
- For Java: Java 11+ (uses Gradle Wrapper)
- For JS: Node 20+ (using ES6 & ESM)
Note: TRLD runs well on Python 3.14, but the transpiler does not (yet).
(A pixi.toml file is available for declarative development environments using Pixi.)
For Python, this runs mypy, pytest and the test suite:
$ make pytest
[...]
Running test suite: cache/json-ld-api/tests/expand-manifest.jsonld
Ran 376 test cases. Passed: 372. Failed: 3. Errors: 1.
Running test suite: cache/json-ld-api/tests/compact-manifest.jsonld
Ran 244 test cases. Passed: 241. Failed: 2. Errors: 1.
Running test suite: cache/json-ld-api/tests/flatten-manifest.jsonld
Ran 55 test cases. Passed: 55. Failed: 0. Errors: 0.
Running test suite: cache/json-ld-api/tests/fromRdf-manifest.jsonld
Ran 52 test cases. Passed: 52. Failed: 0. Errors: 0.
Running test suite: cache/json-ld-api/tests/toRdf-manifest.jsonld
Ran 456 test cases. Passed: 405. Failed: 50. Errors: 1.
python3 -m trld.tvm.test
Running [...]: OK
python3 -m trld.trig.test | grep '^Ran '
Ran 335 tests. Passed 303, failed 32
python3 -m trld.trig.test_serializer | grep '^Examined '
Examined 335 tests. Round-tripped 232, passed 223, failed 6
For the other languages, this will generate packages for each language in the build directory, then run their respective test suites:
$ make java
[...]
java -cp build/java/build/libs/trld-with-deps.jar trld.jsonld.TestRunner [...]
Ran 371 test cases. Passed: 330. Failed: 14. Errors: 27.
java -cp build/java/build/libs/trld-with-deps.jar trld.trig.Test [...]
Ran 335 tests. Passed 252, failed 83
$ make js
[...]
1..551
# tests 551
# pass 540
# fail 11
[...] node [...] lib/trig/test.js [...]
Ran 335 tests. Passed 270, failed 65
To generate transpiled source code without source line comments, use:
$ make TRFLAGS=-L javatr