Changelog¶
2025-01-10 RELEASE 7.1.2¶
A minor release that bumped up a few dev dependencies and achieved a few small but notable improvements, particularly with longturtle sorting:
Feature PRs:
PR #2963 Big typing updates
PR #2964 Defined Namesapce warnings fix
PR #2971 convert uses of Optional and some Union usage to union operator |
PR #2989 Fixed incorrect ASK behaviour for dataset with one element
PR #2997 sort longturtle blank nodes
PR #3008 deterministic longturtle serialisation using RDF canonicalization + n-triples sort
PR #3012 Dataset documentation improvements
Dependency bumps:
ruff from 0.71 -> 0.8.6
orjson 3.10.10 ->
pytest-cov to 6.0.0
coverage to 7.6.10
pytest to 8.3.4
poetry to 2.0.0
2024-10-17 RELEASE 7.1.1¶
This minor release removes the dependency on some only Python packages, in particular six which is a problem for some Linux distributions that ship RDFLib.
Other than that, there are a few minor PRs that improve testing and to do with making releases - no new RDFLib core work.
Merged PRs:
2024-10-28 - Replace html5lib with html5rdf, make it an optional dependency PR #2951
2024-10-23 - Prevent crash when comparing ill-typed numeric types. PR #2949
2024-10-23 - Fix parser bug and add test PR #2943
2024-10-23 - Fix import ordering in get_merged_prs. PR #2947
2024-10-17 - post 7.1.0 release PR PR #2934
2024-10-17 - 7.1.0 release PR #2933
2024-10-24 - build(deps): bump poetry from 1.8.3 to 1.8.4 in /devtools PR #2938
2024-10-24 - build(deps-dev): bump poetry from 1.8.3 to 1.8.4 PR #2941
2024-10-24 - build(deps): bump orjson from 3.10.7 to 3.10.10 PR #2950
2024-10-23 - build(deps-dev): bump ruff from 0.6.9 to 0.7.0 PR #2942
2024-10-17 RELEASE 7.1.0¶
This minor release incorporates just over 100 substantive PRs - interesting things submitted by people - and around 140 auto-generated update PRs from dependabot and similar.
There are no major changes in this release over 7.0.0 and this release can be used in place of 7.0.0 without much worry about altered behaviour.
Since the previous release, we have updated the way auto-generated PRs are handled to ease the job of maintainers.
Due to the large numbers of PRs contained in this release, an abbreviated listing of them only is provided here:
Merged human-made PRs:
2024-10-16 - Bovlb patch 1 PR #2931
2024-10-16 - Redo XSD Datetime, Date, Time, Duration parser and serializers PR #2929
2024-10-15 - Don’t export hashes to requirements.txt from poetry, in readthedocs g… PR #2930
2024-10-10 - Use pytest in one more test and update contributing guide PR #2919
2024-10-10 - Fix for reassigned term aliases PR #2925
2024-10-01 - Replace html5lib with html5lib-modern PR #2911
2024-09-29 - Issue #2812: Reflect explicitly XSD-typed Literals in JSON-LD serialization PR #2889
2024-09-01 - Replace deprecated method in csv2rdf PR #2901
2024-08-31 - Fix test logic for datetime PR #2900
2024-08-31 - Format docstring for
Graph.value
to match others PR #28992024-08-27 - In .patch serializer, default to “add” operation if no operation PR #2898
2024-08-26 - Implement RDF Patch serializer PR #2877
2024-08-26 - Add initial implementation of RDF Patch parser. PR #2863
2024-08-26 - jsonld - Improve handling of URNs in norm_url PR #2892
2024-08-10 - chore: fix mypy and test failure PR #2879
2024-08-06 - feat: update DOAP namespace PR #2869
2024-08-06 - fix: typo in PR template PR #2870
2024-08-01 - Change some more internal usages of ConjunctiveGraph to Dataset to silence warnings PR #2867
2024-08-01 - Fix missing features of IdentifiedNode PR #2868
2024-07-31 - Fix explicit dataset (
FROM
andFROM NAMED
clauses) PR #27942024-07-30 - Marks some doctstrings as raw, to silence a SyntaxWarning about invalid escape sequences. PR #2756
2024-07-30 - Convert old string substitutions to f-strings in term.py PR #2864
2024-07-30 - Prevent Collection from adding ‘rdf:nil rdf:rest rdf:nil.’ triples PR #2818
2024-07-29 - Dependabot ignore newer updates to setuptools. PR #2860
2024-07-29 - Add optional orjson support for faster json reading and writing PR #2854
2024-07-28 - Fix and extend implementation of
BytesIOWrapper
PR #28532024-07-28 - Add skolemization support for ntriples, nquads, hextuples and json-ld support at parse time PR #2816
2024-07-26 - Add JSON-LD extraction from HTML PR #2804
2024-07-25 - New sphinx docs fix PR #2852
2024-07-24 - More typing fixes for mypy update PR #2851
2024-07-24 - Fix typo, “ConjunctionGraph” -> “ConjunctiveGraph” PR #2850
2024-07-24 - feat: hextuple parser and serializer now supports anonymous graph names PR #2815
2024-07-24 - Change dependabot strategy back to “auto” PR #2844
2024-07-24 - test: Add test for Graph.items PR #2819
2024-07-24 - Pin black PR #2843
2024-07-24 - Fix bug preventing nested FILTER statements from working (#709) PR #2822
2024-07-24 - Ruff fixes PR #2842
2024-07-24 - Fix typing issues that appeared after latest mypy update PR #2841
2024-07-24 - Reconcile debpendabot PR #2840
2024-07-24 - Update dependabot.yml PR #2838
2024-07-10 - Fix testing for warnings with pytest 8 (#2748) PR #2817
2024-06-17 - Deprecate ConjunctiveGraph (#2405) PR #2786
2024-06-17 - fix: task expected type string, got bool PR #2791
2024-06-17 - fix: lint PR #2792
2024-06-17 - Reformat code, execute task black PR #2798
2024-06-17 - Fix for gha:validation error in Github actions PR #2799
2024-06-12 - Remove test/data/suites/w3c/dawg-data-r2/sort/.manifest.ttl.swp since… PR #2797
2024-05-17 - docs: fix “Build docs” command in developers.rst PR #2783
2024-05-17 - Update .mailmap for Nicholas Car PR #2776
2024-05-17 - Update _GEO.py to include GeoSPARQL 1.1 vocabularies PR #2771
2024-04-27 - set default jsonld version to 1.1. autoformat for corresponding files. PR #2751
2024-04-27 - removed unused #ignore comments in algebra.py PR #2746
2024-04-18 - Let jsonld handle value nodes/Literal for context search PR #2750
2024-03-20 - Cleanup literal comparison ops (#863) PR #2745
2024-03-20 - fix: use guess_format when plugin for format not found PR #2735
2024-03-20 - Remove unused open method in SPARQLUpdateStore PR #2693
2024-03-20 - fix: readthedocs failure with poetry 1.8 PR #2744
2024-03-20 - fix: typo in Container method name: type_of_conatiner –> type_of_container PR #2733
2024-03-13 - fix: gh actions on PR PR #2731
2024-03-12 - Fix LongTurtle multi-BN object serialization bug PR #2700
2024-03-12 - JSON-LD Docco & Examples PR #2529
2024-02-27 - Add SHACL path to RDFLib Path utility and corresponding tests PR #2699
2024-02-18 - Add documentation for optional dependencies PR #2701
2023-11-30 - Update _SOSA.py with ssn-ex IRIs PR #2654
2023-10-29 - fix typo in SPARQLConnector init docstring PR #2619
2023-10-24 - Add changelog to sphinx docs PR #2617
2023-09-26 - Issue 2378 goal: Get CI to pass without ALLOW_UNICODE on doctests PR #2383
2023-09-25 - docs: remove Unicode literals from docstrings PR #2604
2023-09-10 - feat: enable
check_untyped_defs
for Mypy PR #25802023-09-07 - style: Enable most remaining pyupgrade rules for ruff PR #2579
2023-09-07 - style: Eliminate quotes from type hints PR #2578
2023-09-07 - build: fix minimum version testing PR #2577
2023-09-05 - style: add
from __future__ import annotations
PR #25762023-09-05 - style: homogenize docstrings PR #2575
2023-09-04 - style: remove unnecessary shebangs
#!...
PR #25742023-09-04 - style: remove modelines PR #2573
2023-09-04 - style: disable global ignore for E402 in ruff PR #2572
2023-09-04 - build: remove unneeded override for PyParsing PR #2571
2023-09-03 - style: eliminate unused
noqa
statements PR #25662023-09-02 - style: fix more linting/ruff issues in tests PR #2565
2023-09-02 - test: convert more unittest based tests to pytest PR #2564
2023-08-31 - style: fix the naming of test data constants PR #2561
2023-08-31 - test: migrate some tests from unittest to pytest PR #2562
2023-08-31 - style: Fix linting errors in serializer tests PR #2559
2023-08-30 - Add test case for CG operator return type PR #2557
2023-08-30 - style: add noqa to allow camelCase for mock function PR #2558
2023-08-30 - style: fix linting errors in
test/test_graph
PR #25562023-08-30 - fix: SPARQL
LOAD ... INTO GRAPH
handling PR #25542023-08-29 - fix:
queryGraph
selection forquery
andupdate
PR #25462023-08-29 - build: replace Flake8, FlakeHeaven and isort with ruff PR #2548
2023-08-28 - fix: remove
print()
calls from SPARQL algebra code PR #25532023-08-28 - build: remove unused setuptools setting PR #2547
2023-08-26 - test: add python variants to variant based tests PR #2544
2023-08-25 - test: add more accommodation for DBpedia issues PR #2543
2023-08-25 - test: make graph variant tests more granular PR #2540
2023-08-24 - test: add skips to accommodate a DBpedia outage PR #2539
2023-08-15 - fix: make rdflib.term.Node abstract (fixes #2518) PR #2520
2023-08-15 - Fix nested list expansion in JSON-LD PR #2517
2023-08-10 - refactor: don’t use the same variable name for different types PR #2523
2023-08-06 - fix a tiny typo PR #2519
2023-08-02 - Introduce abstract base class PR #2516
Auto-generated PRs:
2024-10-16 - Revert “build(deps): bump library/python from 3.12.7-slim to 3.13.0-slim in /docker/unstable” PR #2932
2024-10-16 - build(deps): bump library/python from 3.12.7-slim to 3.13.0-slim in /docker/unstable PR #2926
2024-10-10 - build(deps): bump library/python from 3.12.6-slim to 3.12.7-slim in /docker/latest PR #2920
2024-10-10 - build(deps-dev): bump ruff from 0.6.8 to 0.6.9 PR #2921
2024-10-10 - build(deps): bump library/python from 3.12.6-slim to 3.12.7-slim in /docker/unstable PR #2922
2024-09-30 - build(deps-dev): bump ruff from 0.6.5 to 0.6.8 PR #2917
2024-09-30 - build(deps): bump library/python from
15bad98
toad48727
in /docker/unstable PR #29152024-09-29 - build(deps-dev): bump ruff from 0.6.2 to 0.6.5 PR #2908
2024-09-21 - build(deps): bump library/python from 3.12.5-slim to 3.12.6-slim in /docker/unstable PR #2910
2024-09-21 - build(deps): bump library/python from 3.12.5-slim to 3.12.6-slim in /docker/latest PR #2909
2024-09-21 - build(deps-dev): bump pytest from 8.3.2 to 8.3.3 PR #2907
2024-08-26 - build(deps): bump lxml from 5.2.2 to 5.3.0 PR #2882
2024-08-26 - build(deps): bump library/python from 3.12.4-slim to 3.12.5-slim in /docker/latest PR #2886
2024-08-26 - build(deps): bump library/python from 3.12.4-slim to 3.12.5-slim in /docker/unstable PR #2885
2024-08-26 - build(deps): bump orjson from 3.10.6 to 3.10.7 PR #2883
2024-08-26 - build(deps-dev): bump mypy from 1.11.1 to 1.11.2 PR #2896
2024-08-26 - build(deps): bump pyparsing from 3.1.2 to 3.1.4 PR #2895
2024-08-26 - build(deps-dev): bump ruff from 0.5.6 to 0.6.2 PR #2894
2024-08-11 - build(deps-dev): bump wheel from 0.43.0 to 0.44.0 PR #2874
2024-08-10 - build(deps-dev): bump ruff from 0.5.5 to 0.5.6 PR #2873
2024-08-10 - build(deps-dev): bump coverage from 7.6.0 to 7.6.1 PR #2872
2024-08-10 - build(deps-dev): bump mypy from 1.11.0 to 1.11.1 PR #2871
2024-08-10 - build(deps): bump library/python from
740d94a
toa3e58f9
in /docker/unstable PR #28752024-08-10 - build(deps): bump library/python from
740d94a
toa3e58f9
in /docker/latest PR #28762024-07-29 - build(deps-dev): bump pytest from 8.3.1 to 8.3.2 PR #2858
2024-07-29 - build(deps-dev): bump ruff from 0.5.4 to 0.5.5 PR #2859
2024-07-29 - build(deps): bump library/python from
52f92c5
to740d94a
in /docker/latest PR #28562024-07-29 - build(deps): bump library/python from
52f92c5
to740d94a
in /docker/unstable PR #28552024-07-24 - build(deps-dev): bump mypy from 1.8.0 to 1.11.0 PR #2848
2024-07-24 - build(deps): bump library/python from 3.12.2-slim to 3.12.4-slim in /docker/unstable PR #2845
2024-07-24 - build(deps): bump library/python from
f11725a
to52f92c5
in /docker/latest PR #28462024-07-24 - build(deps): bump lxml from 4.9.3 to 5.2.2 PR #2847
2024-07-24 - build(deps-dev): bump types-setuptools from 69.5.0.20240513 to 71.1.0.20240723 PR #2834
2024-07-24 - build(deps-dev): bump myst-parser from 2.0.0 to 3.0.1 PR #2773
2024-07-24 - build(deps-dev): bump black from 24.3.0 to 24.4.2 PR #2770
2024-07-24 - build(deps-dev): bump pytest from 7.4.3 to 8.3.1 PR #2837
2024-07-24 - build(deps-dev): bump mypy from 1.6.1 to 1.8.0 PR #2676
2024-07-23 - build(deps): bump library/python from
2fba8e7
tof11725a
in /docker/latest PR #28272024-07-23 - build(deps-dev): bump setuptools from 69.5.1 to 71.1.0 PR #2832
2024-07-23 - build(deps-dev): bump ruff from 0.5.2 to 0.5.4 PR #2831
2024-07-15 - build(deps-dev): bump types-setuptools from 69.5.0.20240415 to 69.5.0.20240513 PR #2789
2024-07-15 - build(deps-dev): bump ruff from 0.4.1 to 0.5.2 PR #2825
2024-07-15 - build(deps-dev): bump coverage from 7.5.4 to 7.6.0 PR #2824
2024-07-15 - build(deps-dev): bump typing-extensions from 4.11.0 to 4.12.2 PR #2826
2024-07-15 - build(deps-dev): bump coverage from 7.4.4 to 7.5.4 PR #2805
2024-07-15 - build(deps): bump library/python from 3.12.2-slim to 3.12.4-slim in /docker/latest PR #2808
2024-07-15 - build(deps): bump berkeleydb from 18.1.8 to 18.1.10 PR #2813
2024-06-19 - [pre-commit.ci] pre-commit autoupdate PR #2777
2024-06-17 - build(deps): bump library/python from
eb53cb9
to5c73034
in /docker/latest PR #27252024-05-17 - build(deps): bump poetry from 1.8.2 to 1.8.3 in /devtools PR #2787
2024-04-27 - [pre-commit.ci] pre-commit autoupdate PR #2755
2024-05-17 - build(deps): bump networkx from 2.6.3 to 3.1 PR #2458
2024-04-27 - build(deps-dev): bump black from 24.3.0 to 24.4.0 PR #2766
2024-04-27 - build(deps-dev): bump ruff from 0.3.4 to 0.4.1 PR #2769
2024-04-18 - build(deps): bump poetry from 1.7.1 to 1.8.2 in /devtools PR #2743
2024-04-18 - build(deps-dev): bump typing-extensions from 4.10.0 to 4.11.0 PR #2759
2024-04-18 - build(deps-dev): bump setuptools from 69.2.0 to 69.5.1 PR #2763
2024-04-18 - build(deps-dev): bump types-setuptools from 69.2.0.20240317 to 69.5.0.20240415 PR #2765
2024-04-03 - build(deps-dev): bump pytest-cov from 4.1.0 to 5.0.0 PR #2754
2024-04-03 - build(deps-dev): bump ruff from 0.3.2 to 0.3.4 PR #2753
2024-04-03 - build(deps-dev): bump coverage from 7.4.3 to 7.4.4 PR #2752
2024-03-20 - build(deps-dev): bump poetry from 1.7.1 to 1.8.2 PR #2741
2024-03-20 - [pre-commit.ci] pre-commit autoupdate PR #2732
2024-03-20 - build(deps-dev): bump types-setuptools from 69.1.0.20240310 to 69.2.0.20240317 PR #2737
2024-03-20 - build(deps): bump library/python from
5c73034
to36d57d7
in /docker/unstable PR #27422024-03-20 - build(deps-dev): bump wheel from 0.42.0 to 0.43.0 PR #2740
2024-03-20 - build(deps-dev): bump setuptools from 69.1.1 to 69.2.0 PR #2739
2024-03-20 - build(deps-dev): bump black from 24.2.0 to 24.3.0 PR #2738
2024-03-12 - build(deps-dev): bump lxml-stubs from 0.4.0 to 0.5.1 PR #2724
2024-03-12 - build(deps-dev): bump types-setuptools from 69.1.0.20240302 to 69.1.0.20240310 PR #2728
2024-03-12 - build(deps-dev): bump ruff from 0.3.0 to 0.3.2 PR #2729
2024-03-12 - [pre-commit.ci] pre-commit autoupdate PR #2630
2024-03-12 - build(deps): bump pyparsing from 3.1.1 to 3.1.2 PR #2730
2024-03-05 - build(deps): bump library/python from
eb53cb9
to5c73034
in /docker/unstable PR #27262024-03-04 - build(deps-dev): bump sphinxcontrib-apidoc from 0.4.0 to 0.5.0 PR #2719
2024-03-04 - build(deps-dev): bump types-setuptools from 69.1.0.20240223 to 69.1.0.20240302 PR #2722
2024-03-04 - build(deps-dev): bump ruff from 0.1.6 to 0.3.0 PR #2718
2024-03-04 - build(deps-dev): bump poetry from 1.8.0 to 1.8.2 PR #2721
2024-02-27 - build(deps-dev): bump types-setuptools from 68.2.0.2 to 69.1.0.20240223 PR #2716
2024-02-27 - build(deps): bump poetry from 1.7.1 to 1.8.0 in /devtools PR #2717
2024-02-27 - build(deps): bump library/python from 3.12.0-slim to 3.12.2-slim in /docker/unstable PR #2706
2024-02-27 - build(deps-dev): bump typing-extensions from 4.8.0 to 4.10.0 PR #2715
2024-02-27 - build(deps-dev): bump coverage from 7.3.2 to 7.4.3 PR #2714
2024-02-27 - build(deps): bump arduino/setup-task from 1 to 2 PR #2707
2024-02-27 - build(deps-dev): bump setuptools from 69.0.2 to 69.1.1 PR #2713
2024-02-27 - build(deps): bump library/python from 3.12.0-slim to 3.12.2-slim in /docker/latest PR #2703
2024-02-27 - build(deps): bump actions/cache from 3 to 4 PR #2690
2024-02-27 - build(deps): bump actions/upload-artifact from 3 to 4 PR #2669
2024-02-27 - build(deps): bump actions/setup-python from 4 to 5 PR #2664
2024-02-27 - build(deps): bump actions/setup-java from 3 to 4 PR #2657
2024-02-27 - build(deps-dev): bump black from 23.11.0 to 24.2.0 PR #2709
2023-12-01 - build(deps): bump library/python from
43a49c9
tobabc0d4
in /docker/latest PR #26272023-12-01 - build(deps-dev): bump poetry from 1.6.1 to 1.7.1 PR #2646
2023-11-30 - build(deps-dev): bump setuptools from 68.2.2 to 69.0.2 PR #2650
2023-11-30 - build(deps-dev): bump ruff from 0.1.1 to 0.1.6 PR #2647
2023-11-30 - build(deps-dev): bump types-setuptools from 68.2.0.1 to 68.2.0.2 PR #2652
2023-11-30 - build(deps): bump library/python from
babc0d4
to32477c7
in /docker/unstable PR #26532023-11-21 - build(deps-dev): bump types-setuptools from 68.2.0.0 to 68.2.0.1 PR #2640
2023-11-21 - build(deps-dev): bump black from 23.10.1 to 23.11.0 PR #2641
2023-11-21 - build(deps-dev): bump sphinx-autodoc-typehints from 1.24.0 to 1.25.2 PR #2639
2023-11-21 - build(deps-dev): bump pytest from 7.4.2 to 7.4.3 PR #2629
2023-11-21 - build(deps): bump library/python from
43a49c9
tobabc0d4
in /docker/unstable PR #26262023-10-29 - build(deps-dev): bump mypy from 1.5.1 to 1.6.1 PR #2624
2023-10-29 - build(deps): bump berkeleydb from 18.1.6 to 18.1.8 PR #2615
2023-10-29 - build(deps-dev): bump black from 23.9.1 to 23.10.1 PR #2625
2023-10-24 - [pre-commit.ci] pre-commit autoupdate PR #2605
2023-10-24 - build(deps-dev): bump ruff from 0.0.291 to 0.1.1 PR #2622
2023-10-24 - build(deps-dev): bump coverage from 7.3.1 to 7.3.2 PR #2614
2023-10-24 - build(deps): bump library/python from 3.11.5-slim to 3.12.0-slim in /docker/latest PR #2612
2023-09-24 - [pre-commit.ci] pre-commit autoupdate PR #2495
2023-10-24 - build(deps): bump library/python from 3.11.5-slim to 3.12.0-slim in /docker/unstable PR #2611
2023-09-25 - build(deps): bump library/python from
9bd704d
toedaf703
in /docker/latest PR #26002023-09-25 - build(deps): bump library/python from
9bd704d
toedaf703
in /docker/unstable PR #26012023-09-25 - build(deps-dev): bump ruff from 0.0.290 to 0.0.291 PR #2602
2023-09-24 - build(deps): bump docker/login-action from 2 to 3 PR #2594
2023-09-24 - build(deps-dev): bump ruff from 0.0.287 to 0.0.290 PR #2596
2023-09-24 - build(deps-dev): bump typing-extensions from 4.7.1 to 4.8.0 PR #2597
2023-09-19 - build(deps-dev): bump setuptools from 68.2.0 to 68.2.2 PR #2595
2023-09-11 - build(deps-dev): bump sphinxcontrib-apidoc from 0.3.0 to 0.4.0 PR #2583
2023-09-11 - build(deps-dev): bump black from 23.7.0 to 23.9.1 PR #2584
2023-09-11 - build(deps): bump actions/checkout from 3 to 4 PR #2582
2023-09-11 - build(deps-dev): bump coverage from 7.3.0 to 7.3.1 PR #2586
2023-09-11 - build(deps-dev): bump types-setuptools from 68.1.0.1 to 68.2.0.0 PR #2587
2023-09-11 - build(deps-dev): bump pytest from 7.4.1 to 7.4.2 PR #2588
2023-09-11 - build(deps): bump library/python from
c499230
to9bd704d
in /docker/latest PR #25892023-09-11 - build(deps-dev): bump setuptools from 68.1.2 to 68.2.0 PR #2585
2023-09-11 - build(deps): bump library/python from
c499230
to9bd704d
in /docker/unstable PR #25812023-09-04 - build(deps-dev): bump types-setuptools from 68.1.0.0 to 68.1.0.1 PR #2569
2023-09-04 - build(deps-dev): bump ruff from 0.0.286 to 0.0.287 PR #2567
2023-09-04 - build(deps-dev): bump pytest from 7.4.0 to 7.4.1 PR #2568
2023-08-28 - build(deps): bump library/python from 3.11.4-slim to 3.11.5-slim in /docker/latest PR #2551
2023-08-28 - build(deps): bump library/python from 3.11.4-slim to 3.11.5-slim in /docker/unstable PR #2550
2023-08-28 - build(deps-dev): bump poetry from 1.5.1 to 1.6.1 PR #2549
2023-08-23 - build(deps-dev): bump types-setuptools from 68.0.0.3 to 68.1.0.0 PR #2532
2023-08-23 - build(deps): bump library/python from
58ae46e
to17d62d6
in /docker/unstable PR #25312023-08-23 - build(deps-dev): bump setuptools from 68.0.0 to 68.1.2 PR #2535
2023-08-22 - build(deps-dev): bump mypy from 1.5.0 to 1.5.1 PR #2534
2023-08-15 - build(deps): bump library/python from
36b544b
to58ae46e
in /docker/latest PR #25272023-08-15 - build(deps): bump library/python from
36b544b
to58ae46e
in /docker/unstable PR #25262023-08-15 - build(deps-dev): bump mypy from 1.4.1 to 1.5.0 PR #2525
2023-08-15 - build(deps-dev): bump coverage from 7.2.7 to 7.3.0 PR #2524
2023-08-07 - build(deps-dev): bump sphinx from 7.1.1 to 7.1.2 PR #2521
2023-08-02 RELEASE 7.0.0¶
This is a major release with relatively slight breaking changes, new features and bug fixes.
The most notable breaking change relates to how RDFLib handles the
publicID
parameter of the Graph.parse
and Dataset.parse
methods.
Most users should not be affected by this change.
Instructions on adapting existing code to the breaking changes can be found in the upgrade guide from Version 6 to Version 7 which should be available here.
It is likely that the next couple of RDFLib releases will all be major versions, mostly because there are some more shortcomings of RDFLib’s public interface that should be addressed.
If you use RDFLib, please consider keeping an eye on discussions, issues and pull-requests labelled with “feedback wanted”.
A big thanks to everyone who contributed to this release.
BREAKING CHANGE: don’t use publicID
as the name for the default graph. (#2406)¶
When parsing data into a ConjunctiveGraph
or Dataset
, the triples in the
default graphs in the sources were loaded into a graph named publicID
.
This behaviour has been changed, and now the triples from the default graph in
source RDF documents will be loaded into ConjunctiveGraph.default_context
or
Dataset.default_context
.
The publicID
parameter to ConjunctiveGraph.parse
and Dataset.parse
constructors will now only be used as the base URI for relative URI resolution.
Fixes https://github.com/RDFLib/rdflib/issues/2404
Fixes https://github.com/RDFLib/rdflib/issues/2375
Fixes https://github.com/RDFLib/rdflib/issues/436
Fixes https://github.com/RDFLib/rdflib/issues/1804
BREAKING CHANGE: drop support for python 3.7 (#2436)¶
Python 3.7 will be end-of-life on the 27th of June 2023 and the next release of RDFLib will be a new major version.
This changes the minimum supported version of Python to 3.8.1 as some of the dependencies we use are not too fond of python 3.8.0. This change also removes all accommodations for older python versions.
feat: add curie
method to NamespaceManager
(#2365)¶
Added a curie
method to NamespaceManager
, which can be used to generate a
CURIE from a URI.
Other changes:
Fixed
NamespaceManager.expand_curie
to work with CURIES that have blank prefixes (e.g.:something
), which are valid according to CURIE Syntax 1.0.Added a test to confirm https://github.com/RDFLib/rdflib/issues/2077.
feat: add optional target_graph
argument to Graph.cbd
and use it for DESCRIBE queries (#2322)¶
Add optional keyword only target_graph
argument to rdflib.graph.Graph.cbd
and use this new argument in evalDescribeQuery
.
This makes it possible to compute a concise bounded description without creating a new graph to hold the result, and also without potentially having to copy it to another final graph.
feat: Don’t generate prefixes for unknown URIs (#2467)¶
Commit bd797ac.
When serializing RDF graphs, URIs with unknown prefixes were assigned a
namespace like ns1:
. While the result would be smaller files, it does
result in output that is not as readable.
This change removes this automatic assignment of namespace prefixes.
This is somewhat of an aesthetic choice, eventually we should have more flexibility in this regard so that users can exercise more control over how URIs in unknown namespaces are handled.
With this change, users can still manually create namespace prefixes for URIs in unknown namespaces, but before it there was no way to avoid the undesired behaviour, so this seems like the better default.
feat: Longturtle improvements (#2500)¶
Improved the output of the longturtle serializer.
fix: SPARQL count with optionals (#2448)¶
Change SPARQL count aggregate to ignore optional that are unbound instead of raising an exception when they are encountered.
fix: GROUP_CONCAT
handling of empty separator (issue) (#2474)¶
GROUP_CONCAT
was handling an empty separator (i.e. ""
) incorrectly,
it would handle it as if the separator were not set, so essentially it was
treated as a single space (i.e. " "
).
This change fixes it so that an empty separator with GROUP_CONCAT
results in a value with nothing between concatenated values.
fix: add NORMALIZE_LITERALS
to rdflib.__all__
(#2489)¶
This gets Sphinx to generate documentation for it, and also clearly indicates that it can be used from outside the module.
fix: bugs with rdflib.extras.infixowl
(#2390)¶
Fix the following issues in rdflib.extras.infixowl
:
getting and setting of max cardinality only considered identifiers and not other RDF terms.
The return value of
manchesterSyntax
was wrong for some cases.The way that
BooleanClass
was generating its string representation (i.e.BooleanClass.__repr__
) was wrong for some cases.
Other changes:
Added an example for using infixowl to create an ontology.
Updated infixowl tests.
Updated infixowl documentation.
This code is based on code from:
fix: correct imports and __all__
(#2340)¶
Disable
implicit_reexport
and eliminate all errors reported by mypy after this.
This helps ensure that import statements import from the right module and that
the __all__
variable is correct.
fix: dbpedia URL to use https instead of http (#2444)¶
The URL for the service keyword had the http address for the dbpedia endpoint, which no longer works. Changing it to https as that works.
fix: eliminate bare except:
(#2350)¶
Replace bare except:
with except Exception
, there are some cases where it
can be narrowed further, but this is already an improvement over the current
situation.
This is somewhat pursuant to eliminating flakeheaven, as it no longer supports the latest version of flake8 [ref]. But it also is just the right thing to do as bare exceptions can cause problems.
fix: eliminate file intermediary in translate algebra (#2267)¶
Previously, rdflib.plugins.sparql.algebra.translateAlgebra()
maintained state via a file, with a fixed filename query.txt
. With this change, use of that file is eliminated; state is now maintained in memory so that multiple concurrent translateAlgebra()
calls, for example, should no longer interfere with each other.
The change is accomplished with no change to the client interface. Basically, the actual functionality has been moved into a class, which is instantiated and used as needed (once per call to algrebra.translateAlgebra()
).
fix: eliminate some mutable default arguments in SPARQL code (#2301)¶
This change eliminates some situations where a mutable object (i.e., a dictionary) was used as the default value for functions in the rdflib.plugins.sparql.processor
module and related code. It replaces these situations with typing.Optinal
that defaults to None, and is then handled within the function. Luckily, some of the code that the SPARQL Processor relied on already had this style, meaning not a lot of changes had to be made.
This change also makes a small update to the logic in the SPARQL Processor’s query function to simplify the if/else statement. This better mirrors the implementation in the UpdateProcessor
.
fix: formatting of SequencePath and AlternativePath (#2504)¶
These path types were formatted without parentheses even if they contained multiple elements, resulting in string representations that did not accurately represent the path.
This change fixes the formatting so that the string representations are enclosed in parentheses when necessary.
fix: handling of rdf:HTML
literals (#2490)¶
Previously, without html5lib
installed, literals withrdf:HTML
datatypes were treated as
ill-typed,
even if they were not ill-typed.
With this change, if html5lib
is not installed, literals with the
rdf:HTML
datatype will not be treated as ill-typed, and will have
Null
as their ill_typed
attribute value, which means that it is
unknown whether they are ill-typed or not.
This change also fixes the mapping from rdf:HTML
literal values to
lexical forms.
Other changes:
Add tests for
rdflib.NORMALIZE_LITERALS
to ensure it behaves correctly.
Related issues:
fix: HTTP 308 Permanent Redirect status code handling (#2389)¶
Commit e0b3152, closes #2389 /docs.python.org/3.11/whatsnew/changelog.html#id128.
Change the handling of HTTP status code 308 to behave more like
urllib.request.HTTPRedirectHandler
, most critically, the new 308 handling will
create a new urllib.request.Request
object with the new URL, which will
prevent state from being carried over from the original request.
One case where this is important is when the domain name changes, for example,
when the original URL is http://www.w3.org/ns/adms.ttl
and the redirect URL is
https://uri.semic.eu/w3c/ns/adms.ttl
. With the previous behaviour, the redirect
would contain a Host
header with the value www.w3.org
instead of
uri.semic.eu
because the Host
header is placed in
Request.unredirected_hdrs
and takes precedence over the Host
header in
Request.headers
.
Other changes:
Only handle HTTP status code 308 on Python versions before 3.11 as Python 3.11
will handle 308 by default [ref].
Move code which uses
http://www.w3.org/ns/adms.ttl
andhttp://www.w3.org/ns/adms.rdf
out oftest_guess_format_for_parse
into a separate parameterized test, which instead uses the embedded http server.This allows the test to fully control the
Content-Type
header in the response instead of relying on the value that the server is sending.This is needed because the server is sending
Content-Type: text/plain
for theadms.ttl
file, which is not a valid RDF format, and the test is expectingContent-Type: text/turtle
.
Fixes:
fix: lexical-to-value mapping of rdf:HTML literals (#2483)¶
Use strict mode when parsing rdf:HTML
literals. This ensures that when
lexical-to-value
mapping
(i.e. parsing) of a literal with rdf:HTML
data type occurs, a value will
only be assigned if the lexical form is a valid HTML5 fragment.
Otherwise, i.e. for invalid fragments, no value will be associated with
the literal
[ref] and
the literal will be ill-typed.
fix: TriG handling of GRAPH keyword without a graph ID (#2469)¶
Commit 8c9608b, closes #2469 /www.w3.org/2013/TriGTests/#trig-graph-bad-01.
The RDF 1.1 TriG grammar only allows the GRAPH
keyword if it
is followed by a graph identifier
[ref].
This change enforces this rule so that the
http://www.w3.org/2013/TriGTests/#trig-graph-bad-01 test passes.
fix: TriG parser error handling for nested graphs (#2468)¶
Commit afea615, closes #2468 /www.w3.org/2013/TriGTests/#trig-graph-bad-07.
Raise an error when nested graphs occur in TriG.
With this change, the http://www.w3.org/2013/TriGTests/#trig-graph-bad-07 test passes.
fix: typing errors from dmypy (#2451)¶
Fix various typing errors that are reported when running with dmypy
,
the mypy daemon.
Also add a task for running dmypy
to the Taskfile that can be selected
as the default mypy variant by setting the MYPY_VARIANT
environment
variable to dmypy
.
fix: widen Graph.__contains__
type-hints to accept Path
values (#2323)¶
Change the type-hints for Graph.__contains__
to also accept Path
values as the parameter is passed to the Graph.triples
function,
which accepts Path
values.
docs: Add CITATION.cff file (#2502)¶
The CITATION.cff
file provides release metadata which is used by
Zenodo and other software and systems.
This file’s content is best-effort, and pull requests with improvements are welcome and will affect future releases.
docs: add guidelines for breaking changes (#2402)¶
Add guidelines on how breaking changes should be approached.
The guidelines take a very pragmatic approach with known downsides, but this seems like the best compromise given the current situation.
For prior discussion on this point see:
https://github.com/RDFLib/rdflib/discussions/2395
https://github.com/RDFLib/rdflib/pull/2108
https://github.com/RDFLib/rdflib/discussions/1841
docs: fix comment that doesn’t describe behavior (#2443)¶
Comment refers to a person that knows bob and the code would return a name,
but this would only work if the triple person foaf:name bob .
is part of the dataset
As this is a very uncommon way to model a foaf:knows
the code was
adjusted to match the description.
docs: recommend making an issue before making an enhancement (#2391)¶
Suggest that contributors first make an issue to get in principle agreement for pull requests before making the pull request.
Enhancements can be controversial, and we may reject the enhancement sometimes, even if the code is good, as it may just not be deemed important enough to increase the maintenance burden of RDFLib.
Other changes:
Updated the checklist in the pull request template to be more accurate to current practice.
Improved grammar and writing in the pull request template, contribution guide and developers guide.
docs: remove unicode string form in rdflib/term.py (#2384)¶
The use of Unicode literals is an artefact of Python 2 and is incorrect in Python 3.
Doctests for docstrings using Unicode literals only pass because ALLOW_UNICODE is set, but this option should be disabled as RDFLib does not support Python 2 any more.
This partially resolves https://github.com/RDFLib/rdflib/issues/2378.
2023-03-26 RELEASE 6.3.2¶
fix: ROUND
, ENCODE_FOR_URI
and SECONDS
SPARQL functions (#2314)¶
ROUND
was not correctly rounding negative numbers towards positive infinity,
ENCODE_FOR_URI
incorrectly treated /
as safe, and SECONDS
did not include
fractional seconds.
This change corrects these issues.
fix: add __hash__
and __eq__
back to rdflib.paths.Path
(#2292)¶
These methods were removed when @total_ordering
was added, but
@total_ordering
does not add them, so removing them essentially
removes functionality.
This change adds the methods back and adds tests to ensure they work correctly.
All path related tests are also moved into one file.
fix: Add to_dict
method to the JSON-LD Context
class. (#2310)¶
Context.to_dict
is used in JSON-LD serialization, but it was not implemented.
This change adds the method.
fix: add the wgs
namespace binding back (#2294)¶
https://github.com/RDFLib/rdflib/pull/1686 inadvertently removed the wgs
prefix.
This change adds it back.
fix: change the prefix for https://schema.org/
back to schema
(#2312)¶
The default prefix for https://schema.org/
registered with
rdflib.namespace.NamespaceManager
was inadvertently changed to sdo
in 6.2.0,
this however constitutes a breaking change, as code that was using the schema
prefix would no longer have the same behaviour. This change changes the prefix
back to schema
.
fix: include docs and examples in the sdist tarball (#2289)¶
The sdists generated by setuptools included the docs
and examples
directories, and they are needed for building docs and running tests using the
sdist.
This change includes these directories in the sdist tarball.
A test:sdist
task is also added to Taskfile.yml
which uses the sdists to run
pytest and build docs.
fix: IRI to URI conversion (#2304)¶
The URI to IRI conversion was percentage-quoting characters that should not have been quoted, like equals in the query string. It was also not quoting things that should have been quoted, like the username and password components of a URI.
This change improves the conversion by only quoting characters that are not allowed in specific parts of the URI and quoting previously unquoted components. The safe characters for each segment are taken from RFC3986.
The new behavior is heavily inspired by
werkzeug.urls.iri_to_uri
though there are some differences.
fix: JSON-LD context construction from a dict
(#2306)¶
A variable was only being initialized for string-valued inputs, but if a dict
input was passed the variable would still be accessed, resulting in a
UnboundLocalError
.
This change initializes the variable always, instead of only when string-valued input is used to construct a JSON-LD context.
fix: reference to global inside get_target_namespace_elements
(#2311)¶
get_target_namespace_elements
references the args
global, which is not
defined if the function is called from outside the module. This commit fixes
that instead referencing the argument passed to the function.
fix: restore the 6.1.1 default bound namespaces (#2313)¶
The namespaces bound by default by rdflib.graph.Graph
and
rdflib.namespace.NamespaceManager
was reduced in version 6.2.0 of RDFLib,
however, this also would cause code that worked with 6.1.1 to break, so this
constituted a breaking change. This change restores the previous behaviour,
binding the same namespaces as was bound in 6.1.1.
To bind a reduced set of namespaces, the bind_namespaces
parameter of
rdflib.graph.Graph
or rdflib.namespace.NamespaceManager
can be used.
test: add webtest
marker to tests that use the internet (#2295)¶
This is being done so that it is easier for downstream packagers to run the test suite without requiring internet access.
To run only tests that does not use the internet, run pytest -m "not webtest"
.
The validation workflow validates that test run without internet access by
running the tests inside firejail --net=none
.
chore: Update CONTRIBUTORS from commit history (#2305)¶
This ensures contributors are credited. Also added .mailmap to fix early misattributed contributions.
docs: fix typo in NamespaceManager documentation (#2291)¶
Changed cdterms
to dcterms
, see https://github.com/RDFLib/rdflib/issues/2196 for more info.
2023-03-18 RELEASE 6.3.1¶
This is a patch release that includes a singular user facing fix, which is the
inclusion of the test
directory in the sdist
release artifact.
The following sections describe the changes included in this version.
build: explicitly specify packages
in pyproject.toml
(#2280)¶
The default behaviour makes it more of a hassle to republish RDFLib to a separate package, something which I plan to do for testing purposes and possibly other reasons.
More changes may follow in a similar vein.
build: include test in sdist (#2282)¶
A perhaps minor regression from earlier versions is that the sdist does not include the test folder, which makes it harder for downstreams to use a single source of truth to build and test a reliable package. This restores the test folder for sdists.
docs: don’t use kroki (#2284)¶
The Kroki server is currently experiencing some issues which breaks our build, this change eliminates the use of Kroki in favour of directly using the generated SVG images which is checked into git alongside the PlantUML sources.
I also added a task to the Taskfile to re-generate the SVG images from the PlantUML sources by calling docker.
2023-03-16 RELEASE 6.3.0¶
This is a minor release that includes bug fixes and features.
Important Information¶
RDFLib will drop support for Python 3.7 when it becomes EOL on 2023-06-27, this will not be considered a breaking change, and RDFLib’s major version number will not be changed solely on the basis of Python 3.7 support being dropped.
User facing changes¶
This section lists changes that have a potential impact on users of RDFLib, changes with no user impact are not included in this section.
Add chunk serializer that facilitates the encoding of a graph into multiple N-Triples encoded chunks. PR #1968.
Fixes passing
NamespaceManager
inConjunctiveGraph
’s methodget_context()
. Theget_context()
method will now pass theNamespaceManager
ofConjunctiveGraph
to thenamespace_manager
attribute of the newly created context graph, instead of theConjunctiveGraph
object itself. This cleans up an oldFIXME
comment. PR #2073.InfixOWL fixes and cleanup. Closed issue #2030. PR #2024, and PR #2033.
rdflib.extras.infixowl.Restriction.__init__
will now raise aValueError
if there is no restriction value instead of anAssertionError
.Fixed numerous issues with
rdflib.extras.infixowl.Restriction.restrictionKind
which was essentially not working at all.Fixed how
rdflib.extras.infixowl.Property.__repr__
usesrdflib.namespace.OWL
.Removed
rdflib.extras.infixowl.Infix.__ror__
andrdflib.extras.infixowl.Infix.__or__
as they were broken.Removed unused
rdflib.extras.infixowl.termDeletionDecorator
.Added
rdflib.extras.infixowl.MalformedClassError
which will replacerdflib.extras.infixowl.MalformedClass
(which is an exception) in the next major version.Eliminated the use of mutable data structures in some argument defaults.
Fixed some cross-referencing issues in RDFLib documentation. Closed issue #1878. PR #2036.
Fixed import of
xml.sax.handler
inrdflib.plugins.parsers.trix
so that it no longer tries to import it fromxml.sax.saxutils
. PR #2041.Removed a pre python 3.5 regex related workaround in the REPLACE SPARQL function. PR #2042.
Fixed some issues with SPARQL XML result parsing that caused problems with
lxml
. Closed issue #2035, issue #1847. PR #2044.Result parsing from
TextIO
streams now work correctly withlxml
installed and with XML documents that are notutf-8
encoded.Elements inside
<results>
that are not<result>
are now ignored.Elements inside
<result>
that are not<binding>
are now ignored.Also added type hints to
rdflib.plugins.sparql.results.xmlresults
.
Added type hints to the following modules:
rdflib.store
. PR #2057.rdflib.graph
. PR #2080.rdflib.plugins.sparql.*
. PR #2094, PR #2133, PR #2265, PR #2097, PR #2268.rdflib.query
. PR #2265.rdflib.parser
andrdflib.plugins.parsers.*
. PR #2232.rdflib.exceptions
. PR #2232rdflib.shared.jsonld.*
. PR #2232.rdflib.collection
. PR #2263.rdflib.util
. PR #2262.rdflib.path
. PR #2261.
Removed pre python 3.7 compatibility code. PR #2066.
Removed fallback in case the
shutil
module does not have themove
function.
Improve file-URI and path handling in
Graph.serialize
andResult.serialize
to address problems with windows path handling inResult.serialize
and to make the behavior betweenGraph.serialize
andResult.serialie
more consistent. Closed issue #2067. PR #2065.String values for the
destination
argument will now only be treated as file URIs ifurllib.parse.urlparse
returns their schema asfile
.Simplified file writing to avoid a temporary file.
Narrow the type of context-identifiers/graph-names from
rdflib.term.Node
tordflib.term.IdentifiedNode
as no supported abstract syntax allows for other types of context-identifiers. PR #2069.Always parse HexTuple files as utf-8. PR #2070.
Fixed handling of
Literal
datatype
to correctly differentiate between blank string values and undefined values, also changed the datatype ofrdflib.term.Literal.datatype
fromOptional[str]
toOptional[URIRef]
now that all non-URIRef
str
values will be converted toURIRef
. PR #2076.Fixed the generation of VALUES block for federated queries. The values block was including non-variable values like BNodes which resulted in invalid queries. Closed issue #2079. PR #2084.
Only register the
rdflib.plugins.stores.berkeleydb.BerkeleyDB
as a store plugin if theberkeleydb
module is present. Closed issue #1816. PR #2096.Fixed serialization of BNodes in TriG. The TriG serializer was only considering BNode references inside a single graph and not counting the BNodes subjects as references when considering if a BNode should be serialized as unlabeled blank nodes (i.e.
[ ]
), and as a result it was serializing BNodes as unlabeled if they were in fact referencing BNodes in other graphs. PR #2085.Deprecated
rdflib.path.evalPath
in favor ofrdflib.path.eval_path
which is PEP-8 compliant. PR #2046Added
charset=UTF-8
to theContent-Type
header sent when doing an update withSPARQLConnector
. Closed issue #2095. PR #2112.Removed the
rdflib.plugins.sparql.parserutils.plist
class as it served no discernible purpose. PR #2143Changed the TriG serializer to not generate prefixes for empty graph IDs. Closed issue #2154. PR #2160.
Fixed handling of relative context files in the JSON-LD parser. Closed issue #2164. PR #2165.
Improved failure handling in when computing QName for an unbound namespace. PR #2169.
Fixed a typo in the default bound namespace for
DCTERMS
. PR #2173.Add support for supplying a custom namespace manager to
n3()
methods. PR #2174.Fixed the query string parameters for
SPARQLConnector
when using POST method. PR #2180.Fixed extra keyword argument and header handling in
SPARQLConnector
that resulted in headers fromSPARQLConnector.update
polluting headers fromSPARQLConnector.query
vice versa. PR #2183Added version restrictions for dependencies. PR #2187
Switch to using
importlib
for getting the version of RDFLib instead of hard-coding it in__version__
. PR #2187.Removed non-runtime extras, for building documentation, running tests and other development operations the versions and dependencies are now managed with Poetry. PR #2187.
Fixed a bug that occurred when
VALUES
was used outside aGROUP BY
clause. PR #2188.Fixed a bug that occurred when using
SELECT *
inside anotherSELECT *
. Closed issue #1722. PR #2190.Added SPARQL DESCRIBE query implementation. Closes issue #479. PR #2221.
Fixed a bug in
rdflib.tools.defined_namespace_creator
that occurred when multiplerdfs:comment
were present on one resource. PR #2254.Fixed
rdflib.util._iri2uri()
to not quote thenetloc
parameter. PR #2255.Fixed the HexTuple parser’s handling of input sources to works for more input sources. PR #2255.
Fixed the creation of input source objects from IO stream sources. PR #2255.
Eliminated the use of the deprecated
rdflib.path.evalPath
function. PR #2266Added documentation for security considerations and available mitigations. Closed issue #1844. PR #2267.
PRs merged since last release¶
fix: validation issues with examples PR #2269
feat: more type hints for
rdflib.plugins.sparql
PR #2268fix: eliminate use of deprecated
rdflib.path.evalPath
PR #2266more type-hinting for SPARQL plugin PR #2265
feat: add diverse type hints PR #2264
feat: add type hints to
rdflib.collection
PR #2263feat: add type hints to
rdflib.util
PR #2262feat: add type hints to
rdflib.path
PR #2261test: fix deprecation warnings PR #2260
docs: update test reports PR #2259
fix: small InputSource related issues PR #2255
defined_namespace_creator: concatenate several rdfs:comments PR #2254
feat: add parser type hints PR #2232
build: bump versions PR #2231
Add SPARQL DESCRIBE query implementation PR #2221
build: rename minimum constraints file to evade dependabot PR #2209
Fix for
SELECT *
insideSELECT *
bug PR #2190Fixing bug applying VALUES outside of a GROUP BY PR #2188
move to poetry for dependency management; consolidate more settings into pyproject.toml PR #2187
build: update black to 22.12.0 PR #2186
Issue2179 incorrect headers PR #2183
Fix missing query string params in sparqlconnector when using POST method PR #2180
[pre-commit.ci] pre-commit autoupdate PR #2178
Add namespace_manager argument for n3 method on Paths PR #2174
fix DCTERMS prefix typo PR #2173
compute_qname handle case where name could be unbound PR #2169
Issue 2164 PR #2165
build: update black to 22.10.0 PR #2163
ci: switch to python 3.11 release PR #2162
fix: type errors resulting from new mypy PR #2161
do not write prefix for empty graph id, fix #2154 PR #2160
Remove redundant class PR #2143
Pass
service_query
to_buildQueryStringForServiceCall
instead of aMatch
PR #2134Add type hint to part in evalServiceQuery PR #2133
Remove outdated comment PR #2129
fix: type ignore compatibility with latest mypy PR #2127
Remove redundant PR template PR #2126
build: use 3.11.0-rc.2 PR #2119
build: docker images for latest release and main branch PR #2116
add charset encoding to SPARQLConnector.update() request. PR #2112
Add test for issue #2011 PR #2107
chore: rename default branch to
main
PR #2101Correct a typo in test_roundtrip.py PR #2100
feat: add type hints to
rdflib.query
and related PR #2097fix: Don’t register berkelydb as a store if it is not available on the system PR #2096
feat: add type hints to
rdflib.plugins.sparql.{algebra,operators}
PR #2094test: Fix
exclude_lines
for coverage PR #2093test: content-type handling with SPARQLStore + CONSTRUCT queries PR #2092
ci: publish test reports for mypy and pytest PR #2091
test: convert more test from unittest to pytest PR #2089
ci: switch from 3.11.0-beta.4 to 3.11.0-rc.1 PR #2087
fix: issue with trig reference counting across graphs PR #2085
Generate VALUES block for federated queries with variables only PR #2084
docs: Add a contributing guide PR #2082
feat: Add type hints to rdflib.graph PR #2080
fix: handling of Literal datatype PR #2076
test: convert some
unittest
based tests topytest
PR #2075test: honour lax cardinality from test manifests PR #2074
Fix passing ConjunctiveGraph as namespace_manager PR #2073
fix: always parse HexTuple files as utf-8 PR #2070
fix: narrow the context identifier type from
Node
toIdentifiedNode
PR #2069build: set a minimum version for flakeheaven PR #2068
chore: remove pre Python 3.7 compatibility code for shutil PR #2066
fix: issues with string destination handling in
{Graph,Result}.serialize
PR #2065build: fix Taskfile.yml for Windows PR #2064
test: convert
test/test_sparql/test_sparql_parser.py
to pytest PR #2063test: convert
test/test_sparql/test_construct_bindings.py
to pytest PR #2062test: convert
test/test_parsers/test_nquads.py
to pytest PR #2061test: convert
test/test_namespace/test_namespace.py
to pytest PR #2060docs: add DOI for RDFLib PR #2058
feat: add type hints for
rdflib.store
andrdflib.plugins.stores
PR #2057Toplevel n80x PR #2046
docs: add some additional badges PR #2045
fix: SPARQL XML result parsing PR #2044
chore: remove pre python 3.5 regex related workaround PR #2042
fix: import xml.sax.handler from the right place PR #2041
test: remove python 2.4 specific behaviour in test PR #2040
build: remove drone config PR #2037
docs: fix sphinx nitpicky issues PR #2036
build: Gitpod integration and Google Cloud Shell Button PR #2034
Infixowl cleanup iii PR #2033
build: Taskfile improvements PR #2032
docs: removed “Other changes” from CHANGELOG.md PR #2031
Infixowl coverage ii PR #2024
add chunk serializer & tests PR #1968
2022-07-16 RELEASE 6.2.0¶
This is a minor release that includes bug fixes and features.
User facing changes¶
This section lists changes that have a potential impact on users of RDFLib, changes with no user impact are not included in this section.
SPARQL: Fixed handing of
HAVING
clause with variable composition. Closed issue #936 and issue #935, PR #1093.JSON-LD parser: better support for content negotiation. Closed issue #1423, PR #1436.
Removed the following functions that were marked as deprecated and scheduled for removal in version 6.0.0:
Graph.load
,Graph.seq
,Graph.comment
,Graph.label
. PR #1527.Use
functools.total_ordering
to implement most comparison operations forrdflib.paths.Path
. Closed issue #685, PR #1528.Fixed error handling for invalid URIs. Closed issue #821, PR #1529.
InfixOWL: Fixed handling of cardinality 0. Closed issue #1453 and issue #944, PR #1530.
Added quad support to handling to
rdflib.graph.ReadOnlyGraphAggregate.quads
. Closed issue #430, PR #1590Fixed base validation used when joining URIs. PR #1607.
Add GEO defined namespace for GeoSPARQL. Closed issue #1371, PR #1622.
Explicitly raise exception when
rdflib.plugins.stores.sparqlstore.SPARQLStore.update
is called. Closed issue #1032, PR #1623.Added
rdflib.plugins.sparql.processor.prepareUpdate
. Closed issue #272 and discussion #1581, PR #1624.Added
rdflib.namespace.DefinedNamespaceMeta.__dir__
. Closed issue #1593, PR #1626.Removed
TypeCheckError
,SubjectTypeError
,PredicateTypeError
,ObjectTypeError
andContextTypeError
as these exceptions are not raised by RDFLib and their existence will only confuse users which may expect them to be used. Also remove correspondingcheck_context
,check_subject
,check_predicate
,check_object
,check_statement
,check_pattern
that is unused. PR #1640.Improved the population of the
Accept
HTTP header so that it is correctly populated for all formats. PR #1643.Fixed some issues with SPARQL Algebra handling/translation. PR #1645.
Add
nquads
to recognized file extensions. PR #1653.Fixed issues that prevented HexTuples roundtripping. PR #1656.
Make
rdflib.plugins.sparql.operators.unregister_custom_function
idempotent. Closed issue #1492, PR #1659.Fixed the handling of escape sequences in the N-Triples and N-Quads parsers. These parsers will now correctly handle strings like
"\\r"
. The time it takes for these parsers to parse strings with escape sequences will be increased, and the increase will be correlated with the amount of escape sequences that occur in a string. For strings with many escape sequences the parsing speed seems to be almost 4 times slower. Closed issue #1655, PR #1663.Also marked
rdflib.compat.decodeStringEscape
as deprecated as this function is not used anywhere in RDFLib anymore and the utility that it does provide is not implemented correctly. It will be removed in RDFLib 7.0.0
Added an abstract class
IdentifiedNode
as a superclass ofBNode
andURIRef
. Closed issue #1526, PR #1680.Fixed turtle serialization of
rdf:type
in subject, object. Closed issue #1649, PR #1649.Fixed turtle serialization of PNames that contain brackets. Closed issue #1661, PR #1678.
Added support for selecting which namespace prefixes to bind. Closed issue #1679 and issue #1880, PR #1686, PR #1845 and PR #2018.
Also added
ConjunctiveGraph.get_graph
.Also added an
override
argument toStore.bind
which behaves similarly to theoverride
parameter forNamespaceManager.bind
.Also fixed handing of support of the
override
parameter toNamespaceManager.bind
by passing.
Eliminated a
DeprecationWarning
related to plugin loading issue #1631, PR #1694.Removed the
rdflib.graph.ContextNode
andrdflib.graph.DatasetQuad
type aliases. These were not being widely used in RDFLib and were also not correct. PR #1695.Added
DefinedNamespace.as_jsonld_context
. PR #1706.Added
rdflib.namespace.WGS
for WGS84. Closed issue #1709, PR #1710.Improved performance of
DefinedNamespace
by caching attribute values. PR #1718.Only configure python logging if
sys.stderr
has aisatty
attribute. Closed issue #1760, PR #1761.Removed unused
rdflib.compat.etree_register_namespace
. PR #1768.Fixed numeric shortcut handling in
rdflib.util.from_n3
. Closed issue #1769, PR #1771.Add ability to detect and mark ill-typed literals. Closed issue #1757 and issue #848, PR #1773 and PR #2003.
Optimized
NamespaceManager.compute_qname
by caching validity. PR #1779.SPARQL: Fixed the handling of
EXISTS
insideBIND
for SPARQL. This was raising an exception during evaluation before but is now correctly handled. Closed issue #1472, PR #1794.Propagate exceptions from SPARQL TSV result parser. Closed issue #1477, PR #1809
Eliminate usage of
rdflib.term.RDFLibGenid
as a type as this caused issues with querying. Closed issue #1808, PR #1821Fixed handing of
DefinedNamespace
control attributes so thatinspect.signature
works correctly on defined namespaces. PR #1825.Fixed namespace rebinding in
Memory
,SimpleMemory
andBerkelyDB
stores. Closed issue #1826, PR #1843.Fixed issues with the N3 serializer. Closed issue #1701 and issue #1807, PR #1858:
The N3 serializer was incorrectly considers a subject as seralized if it is serialized in a quoted graph.
The N3 serializer does not consider that the predicate of a triple can also be a graph.
Added
NamespaceManager.expand_curie
. Closed issue #1868, PR #1869.Added
Literal.__sub__
and support for datetimes to bothLiteral.__add__
andLiteral.__sub__
. PR #1870.SPARQL: Fix
None
/undefined handing inGROUP_CONCAT
. Closed issue #1467, PR #1887.SPARQL: Fixed result handling for
SERVICE
directive. Closed issue #1278, PR #1894.Change the skolem default authority for RDFLib from
http://rdlib.net/
tohttps://rdflib.github.io
and also change other uses ofhttp://rdlib.net/
tohttps://rdflib.github.io
. Closed issue #1824, PR #1901.Fixes handling of non-ascii characters in IRIs. Closed issue #1429, PR #1902.
Pass
generate
toNamespaceManager.compute_qname
fromNamespaceManager.compute_qname_strict
so it raises an error in the same case as the “non-strict” version. PR #1934.Log warnings when encountering ill-typed literals. PR #1944.
Fixed error handling in TriX serializer. PR #1945.
Fixed QName generation in XML serializer. PR #1951
Remove unnecessary hex expansion for PN_LOCAL in SPARQL parser. Closed issue #1957, PR #1959.
Changed the TriX parser to support both
trix
andTriX
as root element. PR #1966.Fix SPARQL CSV result serialization of blank nodes. PR #1979.
Added a
URIRef.fragment
property. PR #1991.Remove superfluous newline from N-Triples output. Closed issue #1998, PR #1999.
Added a bunch of type hints. The following modules have nearly complete type hints now:
rdflib.namespace
rdflib.term
rdflib.parser
PRs merged since last release¶
Fallback to old
Store.bind
signature onTypeError
PR #2018Fix/ignore flake8 errors in
rdflib/parser.py
PR #2016Update black to 22.6.0 PR #2015
Fix for #1873 avoid AttributeError raised … PR #2013
Change Literal.ill_formed to Literal.ill_typed PR #2003
Continuation of infixowl update and coverage improvement PR #2001
Update test README PR #2000
Remove extra newline from N-Triples output PR #1999
Infixowl cleanup PR #1996
Add line-specific # noqa to
infixowl.py
, remove exclusion from pyproject.toml PR #1994Bump actions/setup-python from 3 to 4 PR #1992
Add fragment property to URIRef PR #1991
test: run tests on python 3.11 also PR #1989
test: rework SPARQL test suite PR #1988
test: rework RDF/XML test suite PR #1987
Rework turtle-like test suites PR #1986
Improve docstring of
Graph.serialize
f PR #1984Add more tests for graph_diff PR #1983
Convert some more graph tests to pytest PR #1982
Fix SPARQL test data PR #1981
Add more namespaces to test utils PR #1980
Fix SPARQL CSV result serialization of blank nodes PR #1979
correct italic markup in plugin stores docs PR #1977
escape literal * symbol in
rdflib.paths
docs PR #1976Update sphinx requirement from <5 to <6 PR #1975
Remove
pytest-subtest
PR #1973style: fix/ignore flake8 errors in store related code PR #1971
build: speed up flake8 by ignoring test data PR #1970
Fix trix parser PR #1966
Add more typing for SPARQL PR #1965
style: fix/ignore flake8 errors in
rdflib/plugins/sparql/
PR #1964test: fix
None
comparisons PR #1963style: fix/ingore some flake8 errors in
rdflib/graph.py
PR #1962test: convert
test/jsonld/test_util.py
to pytest PR #1961Fix for issue1957 sparql parser percent encoded reserved chars PR #1959
test: convert
test_graph_http.py
to pytest PR #1956edit tabs to spaces PR #1952
fix sonarcloud-reported bug in xmlwriter, add test PR #1951
test: convert test_literal.py to pytest PR #1949
style: ignore flake8 name errors for existing names PR #1948
test: remove unused imports in test code PR #1947
test: fix
GraphHelper.quad_set
handling of Dataset PR #1946fix for sonarcloud-reported bug PR #1945
Logging exceptions from Literal value converters PR #1944
fix outmoded
x and x or y
idiom ininfixowl.py
PR #1943Address lingering instances of deprecated
tempfile.mktemp
PR #1942Add CODEOWNERS PR #1941
Bump actions/setup-python from 2 to 3 PR #1940
Bump actions/checkout from 2 to 3 PR #1939
Bump actions/cache from 2 to 3 PR #1938
Bump actions/setup-java from 2 to 3 PR #1937
test: move rdfs.ttl into
test/data/defined_namespaces
PR #1936feat: add tests and typing for
rdflib.utils.{get_tree,find_roots}
PR #1935Passing “generate” option through in compute_qname_strict PR #1934
build: add GitHub Actions to dependabot PR #1933
test: move
EARL
andRDFT
namespaces to separate files PR #1931Removed old and unused
test/data/suites/DAWG/data-r2
PR #1930Added SPARQL unicode numeric codepoint escape tests PR #1929
style: enable and baseline flakeheaven PR #1928
feat: add typing for
rdflib/plugins/sparql
PR #1926Switch to latest DAWG test suite PR #1925
Move
test/data/suites/DAWG/rdflib
PR #1924style: normalize quoting with black PR #1916
Added test for example at CBD definition. Fixes #1914. PR #1915
Rename
test/data/suites/DAWG/data-r2-1.0
PR #1908Move
DAWG/data-sparql11
tow3c/sparql11/data-sparql11
PR #1907Add n3 test suite runner PR #1906
Migrated the various
test_*_w3c.py
test files intotest/test_w3c_spec/
PR #1904Fixes #1429, add
iri2uri
PR #1902Fix for #1824
s,http://rdlib.net,http://rdflib.net,g
PR #1901test: Add more tests for Graph serialize PR #1898
test: earlier assert rewrite for test utitlities PR #1897
test: Add more tests for test utilities PR #1896
test: add more graph variants highlighting bugs PR #1895
Fix simple literals returned as NULL using SERVICE (issue #1278) PR #1894
W3 test reorg PR #1891
Improved mock HTTP Server PR #1888
Fix
None
/undefined handing in GROUP_CONCAT PR #1887Move test utility modules into
test/utils/
PR #1879Move coveralls to GitHub Actions PR #1877
test: run doctest on rst files in
docs/
PR #1875Add tests demonstrating forward-slash behaviors in Turtle, JSON-LD, and SPARQL PR #1872
Literal datetime sub PR #1870
resolve issue1868, add a method to expand qname to URI PR #1869
build: add Taskfile with development tasks PR #1867
Delete basically-unusable example PR #1866
Move
test/translate_algebra
intotest/data
PR #1864test: move
test/variants
intotest/data
PR #1862test: convert
test/test_serializers/test_serializer.py
to pytest PR #1861Add remote file fetcher and N3 test suite PR #1860
fix: two issues with the N3 serializer PR #1858
Tell coveragepy to ignore type checking code and
...
PR #1855docs: switch to sphinx-autodoc-typehints PR #1854
More type hints for
rdflib.graph
and related PR #1853Remove testing and debug code from rdflib PR #1849
text: fix pytest config PR #1846
fix: Raise ValueError for unsupported
bind_namespace
values PR #1845fix: namespace rebinding in
Memory
,SimpleMemory
andBerkelyDB
stores. PR #1843test re-org PR #1838
fix: DefinedNamespace: fixed handling of control attributes. PR #1825
docs: change term reference to italicized PR #1823
Fix issue 1808 PR #1821
build: disable building of epub on readthedocs.org PR #1820
docs: fix sphinx warnings PR #1818
style: fix isort config PR #1817
Migrate to pytest, relocate in subfolder PR #1813
test: add a test for n3 serialization with formula PR #1812
refactor: convert
test_n3.py
to pytest PR #1811test: Add tests for SPARQL parsing and serialization PR #1810
fix: propagate exceptions from SPARQL TSV result parser PR #1809
Migrate more tests to pytest PR #1806
Convert
test_sparql/test_tsvresults.py
to pytest PR #1805Ignore pyparsing type hints PR #1802
Add two xfails related to Example 2 from RDF 1.1 TriG specification PR #1801
change pytest.skip to pytest.xfail PR #1799
Black tests PR #1798
Convert
test/test_util.py
topytest
PR #1795Fix handling of EXISTS inside BIND PR #1794
update test_graph_generators to import from test.data PR #1792
Test reorg (continued) PR #1788
Edit readme PR #1787
Add tests for computing qname on invalid URIs PR #1783
Convert namespace tests to pytest PR #1782
Update to black 22.3.0 because of issue with click PR #1780
Isvaliduri optimization PR #1779
Add tests for the parsing of literals for the turtle family of formats PR #1778
Migrate some tests to pytest PR #1774
Add ability to detect and mark ill-typed literals PR #1773
Fix for issue1769 PR #1771
Remove unused compatability function PR #1768
Add pull request guidelines and template. PR #1767
Rename some tests PR #1766
Add config for readthedocs.org PR #1764
Fix black PR #1763
Check if sys.stderr has isatty PR #1761
Remove redundant type ignores and fix typing errors PR #1759
Add documentation about type hints PR #1751
Enable showing typehints in sphinx function/method signature and content PR #1728
Update reference to black.toml PR #1721
black formatting for rdflib/store.py PR #1720
Use the correct warnings module PR #1719
DefinedNamespaceMeta.__getitem__
is slow PR #1718Introduce WGS84 DefinedNamespace PR #1710
#1699 Document
Graph
behavior regarding context in constructor docstring PR #1707Generate JSON-LD context from a DefinedNamespace PR #1706
Use the
property
built-in as a decorator PR #1703Apply IdentifiedNode to Graph iterators PR #1697
Remove singly-used alias obviated by IdentifiedNode PR #1695
Unify plugin loading PR #1694
Rename black.toml to pyproject.toml PR #1692
Improved tox config PR #1691
Add isort PR #1689
Fix black PR #1688
Bind prefixes choices PR #1686
Fix turtle serialization of
rdf:type
in subject, object PR #1684Add typing to rdflib.term PR #1683
Add a class diagram for terms. PR #1682
Add typing to rdflib.namespace PR #1681
Add IdentifiedNode abstract intermediary class PR #1680
Fix turtle serialization of PNames that contain brackets PR #1678
Add a test case for a prefix followed by dot in Turtle format PR #1677
Bump sphinx from 4.3.2 to 4.4.0 PR #1675
pre-commit and pre-commit-ci PR #1672
Eliminate star import PR #1667
Fixed the handling of escape sequences in the ntriples and nquads parsers PR #1663
Remove narrow build detection PR #1660
Make unregister_custom_function idempotent PR #1659
Allow hext to participate in RDF format roundtripping PR #1656
change tests to use urn:example PR #1654
add nquads to recognised file extensions PR #1653
Don’t update
SUFFIX_FORMAT_MAP
inplugins/parsers/jsonld.py
PR #1652Add Contributor Covenant Code of Conduct PR #1651
add test of ConjunctiveGraph operators PR #1647
added three tests to cover changes made by the pull request #1361 PR #1645
Fixed and refactored roundtrip, n3_suite and nt_suite tests PR #1644
Allow parse of RDF from URL with all RDF Media Types PR #1643
Black rdflib except for rdflib/namespace/_GEO.py PR #1642
Remove
(TypeCheck|SubjectType|PredicateType|ObjectType)Error
and related PR #1640Rename
test/triple_store.py
so pytest picks it up PR #1639Convert translate_algebra tests to pytest PR #1636
Add some type annotations to JSON-LD code PR #1634
Add some typing for evaluation related functions in the SPARQL plugin. PR #1633
Add classifier for python 3.10 PR #1630
Add tests for update method on
Graph(store="SPARQLStore")
PR #1629Add dir to DefinedNamespaceMeta. PR #1626
Add
version
to docker-compose config for tests PR #1625Feature prepareupdate PR #1624
Fix issue1032 error on sparqlstore update PR #1623
Restore geosparql defined namespace PR #1622
Fix typing errors in tests PR #1621
Compile docs in GitHub Actions CI PR #1620
Scale down CI checks PR #1619
Revert error-raising change, enable Exception to be raised. PR #1607
Fix for issue430 PR #1590
Fix for infixowl issues 1453 and 944 PR #1530
Fix
self.line
typos in call to BadSyntax. PR #1529Overdue restoration of functools total_order decorator. PR #1528
Remove deprecated PR #1527
Clean up documentation PR #1525
TypeErrors from Results do not propagate through list creation PR #1523
Add typing for parsers PR #1522
Fix for issue #837. Graph.[subjects|objects|predicates] optionally return uniques. PR #1520
Bump sphinx from 4.3.1 to 4.3.2 PR #1518
Start support for mypy –strict PR #1515
Allow URLInputSource to get content-negotiation links from the Link headers PR #1436
Fix issue #936 HAVING clause with variable comparison not correctly evaluated PR #1093
2021-12-20 RELEASE 6.1.1¶
Better testing and tidier code.
This is a semi-major release that:
add support for Python 3.10
updates the test suite to pytest (from nose)
tidies up a lot of continuous integration
gets more tests tested, not skipped
implements lots of mypy tests
updates several parsers and serializers
supports the new HexTuples format!
many bug fixes
This release contains many, many hours of updates from Iwan Aucamp, so thank you Iwan!
PRs merged since last release:
Update the guidelines for writing tests PR #1517
Updated tox config to run mypy in default environment PR #1450
Add type annotations to constructor parameters in Literal PR #1498
Increase fuseki start timeout from 15 to 30 seconds PR #1516
Forbid truthy values for lang when initializing Literal PR #1494
Add Py 3.10 to testing envs PR #1473
Add mypy to GitHub actions validate workflow PR #1512
Improve error messages from with-fuseki.sh PR #1510
Fix pipeline triggers PR #1511
Change python version used for mypy to 3.7 PR #1514
Quench nt test userwarn PR #1500
Raise a more specific Exception when lang isn’t valid PR #1497
Fix for issue893 PR #1504
Fix for issue 893 PR #1501
Re-make of nicholascar’s “Concise Bounded Description” PR #968 … PR #1502
Remove deprecated Statement class PR #1496
Fix BNode.skolemize() returning a URIRef instead of an RDFLibGenid. PR #1493
demo 980 resolution PR #1495
Hextuples Serializer PR #1489
Add bindings for rdflib namespaces. Import DCAM. PR #1491
fix for issue 1484 raised and solved by Graham Klyne: PR #1490
SDO HTTPS and DN creator script PR #1485
Fix typing of create_input_source PR #1487
guess_format() cater for JSON-LD files ending .json-ld PR #1486
Add GitHub actions workflow for validation PR #1461
Improved script for running with fuseki PR #1476
RFC: Add PythonInputSource to create py-based graphs PR #1463
Adapt for pytest and add back import of os in rdflib/parser.py PR #1480
Make the test pass on windows PR #1478
Add type hints PR #1449
Fix shield for CI status PR #1474
Fix test files with bare code PR #1481
Remove some remaining nosetest import PR #1482
Fix JSON-LD data import adds trailing slashes to IRIs (#1443) PR #1456
Iwana 20211114 t1305 pytestx PR #1460
Migrate from nosetest to pytest PR #1452
Add import of os PR #1464
replace pkg_resources with importlib.metadata PR #1445
A new Turtle serializer PR #1425
Fix typos discovered by codespell PR #1446
Use assertTrue instead of assert_ for python 3.11 compatibility. PR #1448
Undefined name: tmppath –> self.tmppath PR #1438
Fix Graph.parse URL handling on windows PR #1441
Make Store.namespaces an empty generator PR #1432
Export DCMITYPE PR #1433
2021-12-20 RELEASE 6.1.0¶
A slightly messed-up release of what is now 6.1.1. Do not use!
2021-10-10 RELEASE 6.0.2¶
Minor release to add OWL.rational & OWL.real which are needed to allow the OWL-RL package to use only rdflib namespaces, not it’s own versions.
Add owl:rational and owl:real to match standard. PR #1428
A few other small things have been added, see the following merged PRs list:
2021-09-17 RELEASE 6.0.1¶
Minor release to fix a few small errors, in particular with JSON-LD parsing & serializing integration from rdflib-jsonld. Also, a few other niceties, such as allowing graph add()
, remove()
etc. to be chainable.
Add test for adding JSON-LD to guess_format() PR #1408
Add JSON-LD to guess_format() PR #1403
add dateTimeStamp, fundamental & constraining facets, 7-prop data model PR #1399
fix: remove log message on import PR #1398
Make graph and other methods chainable PR #1394
fix: use correct name for json-ld PR #1388
Allowing Container Membership Properties in RDF namespace (#873) PR #1386
Update intro_to_sparql.rst PR #1386
Iterate over dataset return quads PR #1382
2021-07-20 RELEASE 6.0.0¶
6.0.0 is a major stable release that drops support for Python 2 and Python 3 < 3.7. Type hinting is now present in much of the toolkit as a result.
It includes the formerly independent JSON-LD parser/serializer, improvements to Namespaces that allow for IDE namespace
prompting, simplified use of g.serialize()
(turtle default, no need to decode()
) and many other updates to
documentation, store backends and so on.
Performance of the in-memory store has also improved since Python 3.6 dictionary improvements.
There are numerous supplementary improvements to the toolkit too, such as:
inclusion of Docker files for easier CI/CD
black config files for standardised code formatting
improved testing with mock SPARQL stores, rather than a reliance on DBPedia etc
All PRs merged since 5.0.0:
Fixes 1190 - pin major version of pyparsing PR #1366
Add init for shared jsonld module PR #1365
Update README with chat info PR #1363
add xsd dayTimeDuration and yearMonthDuration PR #1364
Updated film.py PR #1359
Migration from ClosedNamespace to DeclaredNamespace PR #1074
Add @expectedFailure unit tests for #1294 and type annotations for compare.py PR #1346
JSON-LD Integration PR #1354
ENH: Make ClosedNamespace extend Namespace PR #1213
Add unit test for #919 and more type hints for sparqlconnector and sparqlstore PR #1348
fix #876 Updated term.py to add xsd:normalizedString and xsd:token support for Literals PR #1102
Dev stack update PR #1355
Add make coverage instructions to README PR #1353
Improve running tests locally PR #1352
support day, month and year function for date PR #1154
Prevent
from_n3
from unescaping\xhh
PR #1343Complete clean up of docs for 6.0.0 PR #1296
pathname2url removal PR #1288
Replace Sleepycat with BerkeleyDB PR #1347
Replace use of DBPedia with the new SimpleHTTPMock PR #1345
Update graph operator overloading for subclasses PR #1349
Speedup Literal.hash and Literal.eq by accessing directly _da… PR #1321
Implemented function translateAlgebra. This functions takes a SPARQL … PR #1322
attempt at adding coveralls support to drone runs PR #1337
Fix SPARQL update parsing to handle arbitrary amounts of triples in inserts PR #1340
Add pathlib.PurePath support for Graph.serialize and Graph.parse PR #1309
dataset examples file PR #1289
Add handling for 308 (Permanent Redirect) PR #1342
Speedup of __add_triple_context PR #1320
Fix prov ns PR #1318
Speedup __ctx_to_str. PR #1319
Speedup decodeUnicodeEscape by avoiding useless string replace. PR #1324
Fix errors reported by mypy PR #1330
Require setuptools, rdflib/plugins/sparql/init.py and rdflib/plugin.py import pkg_resources PR #1339
Fix tox config PR #1313
Fix formatting of xsd:decimal PR #1335
Add tests for issue #1299 PR #1328
Add special handling for gYear and gYearMonth PR #1315
Replace incomplete example in intro_to_sparql.rst PR #1331
Added unit test for issue #977. PR #1112
Don’t sort variables in TXTResultSerializer PR #1310
handle encoding of base64Binary Literals PR #1258
Add tests for Graph.transitive_{subjects,objects} PR #1307
Changed to support passing fully qualified queries through the graph … PR #1253
Upgrade to GitHub-native Dependabot PR #1298
Fix transitive_objects/subjects docstrings and signatures PR #1305
Fix typo in ClosedNamespace doc string PR #1293
Allow parentheses in uri PR #1280
Add notes about how to install from git PR #1286
Feature/forward version to 6.0.0-alpha PR #1285
speedup notation3/turtle parser PR #1272
Correct behaviour of compute_qname for URNs PR #1274
Speedup __add_triple_context. PR #1271
Feature/coverage configuration PR #1267
optimize sparql.Bindings PR #1192
issue_771_add_key_error_if_spaces PR #1070
Typo fix PR #1254
Adding Namespace.contains() PR #1237
Add a Drone config file. PR #1247
Add sentence on names not valid as Python IDs. PR #1234
Add trig mimetype PR #1238
Move flake8 config PR #1239
Update SPARQL tests since the DBpedia was updated PR #1240
fix foaf ClosedNamespace PR #1220
add GeoSPARQL ClosedNamespace PR #1221
docs: fix simple typo, -> yield PR #1223
do not use current time in sparql TIMEZONE PR #1193
Reset graph on exit from context PR #1206
Fix usage of default-graph for POST and introduce POST_FORM PR #1185
Changes to graph.serialize() PR #1183
rd2dot Escape HTML in node label and URI text PR #1209
tests: retry on network error (CI) PR #1203
Add documentation and type hints for rdflib.query.Result and rdflib.graph.Graph PR #1211
fix typo PR #1218
Add architecture ppc64le to travis build PR #1212
small cleanups PR #1191
Remove the usage of assert in the SPARQLConnector PR #1186
Remove requests PR #1175
Support parsing paths specified with pathlib PR #1180
URI Validation Performance Improvements PR #1177
Fix serialize with multiple disks on windows PR #1172
Fix for issue #629 - Arithmetic Operations of DateTime in SPARQL PR #1061
Fixes #1043. PR #1054
N3 parser: do not create formulas if the Turtle mode is activated PR #1142
Move to using graph.parse() rather than deprecated graph.load() PR #1167
Small improvement to serialize docs PR #1162
Issue 1160 missing url fragment PR #1163
remove import side-effects PR #1156
Docs update PR #1161
replace cgi by html, fixes issue #1110 PR #1152
Deprecate some more Graph API surface PR #1151
Add deprecation warning on graph.load() PR #1150
Remove all remnants of Python2 compatibility PR #1149
make csv2rdf work in py3 PR #1117
Add a dir attribute to a closed namespace PR #1134
improved Graph().parse() PR #1140
Discussion around new dict-based store implementation PR #1133
fix 913 PR #1139
Make parsers CharacterStream aware PR #1145
More Black formatting changes PR #1146
Fix comment PR #1130
Updating namespace.py to solve issue #801 PR #1044
Fix namespaces for SOSA and SSN. Fix #1126. PR #1128
Create pull request template PR #1114
BNode context dicts for NT and N-Quads parsers PR #1108
Allow distinct blank node contexts from one NTriples parser to the next (#980) PR #1107
Autodetect parse() format PR #1046
fix #910: Updated evaluate.py so that union includes results of both branches, even when identical. PR #1057
Removal of six & styling PR #1051
Add SERVICE clause to documentation PR #1041
add test with ubuntu 20.04 PR #1038
Improved logo PR #1037
Add requests to the tests_requirements PR #1036
Set update endpoint similar to query endpoint for sparqlstore if only one is given PR #1033
fix shebang typo PR #1034
Add the content type ‘application/sparql-update’ when preparing a SPARQL update request PR #1022
Fix typo in README.md PR #1030
add Python 3.8 PR #1023
Fix n3 parser exponent syntax of floats with leading dot. PR #1012
DOC: Use sphinxcontrib-apidoc and various cleanups PR #1010
FIX: Change is comparison to == for tuple PR #1009
Update copyright year in docs conf.py PR #1006
2020-04-18 RELEASE 5.0.0¶
5.0.0 is a major stable release and is the last release to support Python 2 & 3.4. 5.0.0 is mostly backwards- compatible with 4.2.2 and is intended for long-term, bug fix only support.
5.0.0 comes two weeks after the 5.0.0RC1 and includes a small number of additional bug fixes. Note that rdflib-jsonld has released a version 0.5.0 to be compatible with rdflib 5.0.0.
All PRs merged since 5.0.0RC1:
General Bugs Fixed:¶
Enhanced Features:¶
Issue 1003 PR #1005
SPARQL Fixes:¶
CONSTRUCT resolve with initBindings fixes #1001 PR #1002
Documentation Fixes:¶
2020-04-04 RELEASE 5.0.0RC1¶
After more than three years, RDFLib 5.0.0rc1 is finally released.
This is a rollup of all of the bugfixes merged, and features introduced to RDFLib since RDFLib 4.2.2 was released in Jan 2017.
While all effort was taken to minimize breaking changes in this release, there are some.
Please see the upgrade4to5 document in the docs directory for more information on some specific differences from 4.2.2 to 5.0.0.
All issues closed and PRs merged since 4.2.2:
General Bugs Fixed:¶
Pr 451 redux PR #978
NTriples fails to parse URIs with only a scheme ISSUE #920, PR #974
Cannot clone on windows - Remove colons from test result files. ISSUE #901, PR #971
Add requirement for requests to setup.py PR #969
fixed URIRef including native unicode characters PR #961
DCTERMS.format not working ISSUE #932
infixowl.manchesterSyntax do not encode strings PR #906
Fix blank node label to not contain ‘_:’ during parsing PR #886
rename new SPARQLWrapper to SPARQLConnector PR #872
Fix #859. Unquote and Uriquote Literal Datatype. PR #860
Parsing nquads ISSUE #786
ntriples spec allows for upper-cased lang tag, fixes #782 PR #784, ISSUE #782
Adds escaped single quote to literal parser PR #736
N3 parse error on single quote within single quotes ISSUE #732
Fixed #725 PR #730
test for issue #725: canonicalization collapses BNodes PR #726
RGDA1 graph canonicalization sometimes still collapses distinct BNodes ISSUE #725
Accept header should use a q parameter PR #720
Added test for Issue #682 and fixed. PR #718
Incompatibility with Python3: unichr ISSUE #687
namespace.py include colon in ALLOWED_NAME_CHARS PR #663
namespace.py fix compute_qname missing namespaces PR #649
RDFa parsing Error!
__init__()
got an unexpected keyword argument ‘encoding’ ISSUE #639Bugfix:
term.Literal.__add__
PR #451fixup of #443 PR #445
Microdata to rdf second edition bak PR #444
Enhanced Features:¶
Register additional serializer plugins for SPARQL mime types. PR #987
Pr 388 redux PR #979
Allows RDF terms introduced by JSON-LD 1.1 PR #970
make SPARQLConnector work with DBpedia PR #941
ClosedNamespace returns right exception for way of access PR #866
Not adding all namespaces for n3 serializer PR #832
Adds basic support of xsd:duration PR #808
Add possibility to set authority and basepath to skolemize graph PR #807
Change notation3 list realization to non-recursive function. PR #805
Suppress warning for not using custom encoding. PR #800
Add support to parsing large xml inputs ISSUE #749 PR #750
improve hash efficiency by directly using str/unicode hash PR #746
Added the csvw prefix to the RDFa initial context. PR #594
syncing changes from pyMicrodata PR #587
Microdata parser: updated the parser to the latest version of the microdata->rdf note (published in December 2014) PR #443
Literal.toPython() support for xsd:hexBinary PR #388
SPARQL Fixes:¶
Total order patch patch PR #862
use <<= instead of deprecated << PR #861
Fix #847 PR #856
RDF Literal
"1"^^xsd:boolean
should not coerce to True ISSUE #847Makes NOW() return an UTC date PR #844
NOW() SPARQL should return an xsd:dateTime with a timezone ISSUE #843
fix property paths bug: issue #715 PR #822, ISSUE #715
MulPath: correct behaviour of n3() PR #820
Literal total ordering PR #793
Remove SPARQLWrapper dependency PR #744
made UNION faster by not preventing duplicates PR #741
added a hook to add custom functions to SPARQL PR #723
Issue714 PR #717
Use <<= instead of deprecated << in SPARQL parser PR #417
Custom FILTER function for SPARQL engine ISSUE #274
Code Quality and Cleanups:¶
a slightly opinionated autopep8 run PR #870
remove rdfa and microdata parsers from core RDFLib PR #828
ClosedNamespace KeyError -> AttributeError PR #827
typo in rdflib/plugins/sparql/update.py ISSUE #760
Fix logging in interactive mode PR #731
make namespace module flake8-compliant, change exceptions in that mod… PR #711
delete ez_setup.py? ISSUE #669
code duplication issue between rdflib and pymicrodata ISSUE #582
Transition from 2to3 to use of six.py to be merged in 5.0.0-dev PR #519
sparqlstore drop deprecated methods and args PR #516
python3 code seems shockingly inefficient ISSUE #440
removed md5_term_hash, fixes #240 PR #439, ISSUE #240
Testing:¶
Documentation Fixes:¶
Fix a doc string in the query module PR #976
setup.py: Make the license field use an SPDX identifier PR #789
Update README.md PR #764
Update namespaces_and_bindings.rst PR #757
DOC: README.md: rdflib-jsonld, https uris PR #712
make doctest support py2/py3 ISSUE #707
pip install rdflib
(as per README.md) gets OSError on Mint 18.1 ISSUE #704
2017-01-29 RELEASE 4.2.2¶
This is a bug-fix release, and the last release in the 4.X.X series.
Bug fixes:¶
SPARQL bugs fixed:
Fix for filters in sub-queries #693
Fixed bind, initBindings and filter problems #294 #555 #580 #586 #601 #615 #617 #619 #630 #653 #686 #688 #692
Fix sparql, group by and count of null values with
optional
#631Fixed sparql sub-query and aggregation bugs #607 #610 #628 #694
Fixed DISTINCT being ignored inside aggregate functions #404 #611 #678
Fixed SPARQL select nothing no longer returning a
None
row #554 #592Fixed aggregate operators COUNT and SAMPLE to ignore unbound / NULL values #564 #563 #567 #568
SPARQL can now compare xsd:date type as well, fixes #532 #532 #533
fix sparql path order on python3: “TypeError: unorderable types: SequencePath() < SequencePath()”” #492 #525
Let paths be comparable against all nodes even in py3 (preparedQuery error) #545 #552
Made behavior of
initN
inupdate
andquery
more consistent #579 #600
SparqlStore:
Trig bugs fixed:
Fixed Nquads parser handling of triples in default graph #535 #536
Fixed TypeError in Turtle serializer (unorderable types: DocumentFragment() > DocumentFragment()) #613 #648 #666 #676
Fixed RDFa parser from failing on time elements with child nodes #576 #577
Fix ImportError when main already loaded #616
Fixed broken top_level.txt file in distribution #571 #572 #573
Enhancements:¶
Added support for Python 3.5+ #526
More aliases for common formats (nt, turtle) #701
Dependencies updated and improved compatibility with pyparsing, html5lib, SPARQLWrapper and elementtree #550 #589 #606 #641 #642 #650 #671 #675 #684 #696
Improved prefix for SPARQL namespace in XML serialization #493 #588
Performance improvements:
SPARQLStore improvements
SPARQL prepared query now carries the original (unparsed) parameters #565
added .n3 methods for path objects #553
Improved slicing of Resource objects #529
Cleanups:¶
cleanup: SPARQL Prologue and Query new style classes #566
Reduce amount of warnings, especially closing opened file pointers #518 #651
Improved ntriples parsing exceptions to actually tell you what’s wrong #640 #643
Logger output improved #662
properly cite RGDA1 #624
Use find_packages for package discovery. #590
Prepared ClosedNamespace (and _RDFNamespace) to inherit from Namespace (5.0.0) #551 #595
Avoid verbose build logging #534
(ultra petty) Remove an unused import #593
Testing improvements:¶
updating deprecated testing syntax #697
make test 375 more portable (use sys.executable rather than python) #664 #668
Removed outdated, skipped test for #130 that depended on content from the internet #256
enable all warnings during travis nosetests #517
travis updates #659
travis also builds release branches #598
Doc improvements:¶
2015-08-12 RELEASE 4.2.1¶
This is a bug-fix release.
Minor enhancements:¶
Bug fixes:¶
fix
util.from_n3()
parsing Literals with datatypes and Namespace support #503, #502make
Identifier.__hash__
stable wrt. multi processes #501, #500no relative import in
algebra
when run as a script #497Duplicate option in armstrong
theme.conf
removed #491Variable.__repr__
returns a python representation string, not n3 #488fixed broken example #482
trig output fixes #480
set PYTHONPATH to make rdfpipe tests use the right rdflib version #477
fix RDF/XML problem with unqualified use of
rdf:about
#470, #468added asserts for
graph.set([s,p,o])
sos
andp
aren’tNone
#467threading.RLock
instances are context managers #465SPARQLStore does not transform Literal(‘’) into Literal(‘None’) anymore #459, #457
slight performance increase for graph.all_nodes() #458
Testing improvements:¶
travis: migrate to docker container infrastructure #508
test for narrow python builds (chars > 0xFFFF) (related to #453, #454 ) #456, #509
dropped testing py3.2 #448
Running a local fuseki server on travis and making it failsafe #476, #475, #474, #466, #460
exclude
def main():
functions from test coverage analysis #472
2015-02-19 RELEASE 4.2.0¶
This is a new minor version of RDFLib including a handful of new features:
Supporting N-Triples 1.1 syntax using UTF-8 encoding #447, #449, #400
Graph comparison now really works using RGDA1 (RDF Graph Digest Algorithm 1) #441 #385
More graceful degradation than simple crashing for unicode chars > 0xFFFF on narrow python builds. Parsing such characters will now work, but issue a UnicodeWarning. If you run
python -W all
you will already see a warning onimport rdflib
will show a warning (ImportWarning). #453, #454URLInputSource now supports json-ld #425
SPARQLStore now uses SPARQLWrapper for updates #397
Certain logging output is immediately shown in interactive mode #414
Python 3.4 fully supported #418
Minor enhancements & bugs fixed:¶
Fixed double invocation of 2to3 #437
PyRDFa parser missing brackets #434
Correctly handle \uXXXX and \UXXXXXXXX escapes in n3 files #426
microdata: add file:// to base if it’s a filename so rdflib can parse its own output #406 #403
TSV Results parse skips empty bindings in result #390
fixed accidental test run due to name #389
Bad boolean list serialization to Turtle & fixed ambiguity between Literal(False) and None #387 #382
Current version number & PyPI link in README.md #383
2014-04-15 RELEASE 4.1.2¶
This is a bug-fix release.
Fixed unicode/str bug in py3 for rdfpipe #375
2014-03-03 RELEASE 4.1.1¶
This is a bug-fix release.
This will be the last RDFLib release to support python 2.5.
The RDF/XML Parser was made stricter, now raises exceptions for illegal repeated node-elements. #363
The SPARQLUpdateStore now supports non-ascii unicode in update statements #356
Fixed a bug in the NTriple/NQuad parser wrt. to unicode escape sequences #352
HTML5Lib is no longer pinned to 0.95 #355
RDF/XML Serializer now uses parseType=Literal for well-formed XML literals
A bug in the manchester OWL syntax was fixed #355
2013-12-31 RELEASE 4.1¶
This is a new minor version RDFLib, which includes a handful of new features:
A TriG parser was added (we already had a serializer) - it is up-to-date wrt. to the newest spec from: http://www.w3.org/TR/trig/
The Turtle parser was made up to date wrt. to the latest Turtle spec.
Many more tests have been added - RDFLib now has over 2000 (passing!) tests. This is mainly thanks to the NT, Turtle, TriG, NQuads and SPARQL test-suites from W3C. This also included many fixes to the nt and nquad parsers.
ConjunctiveGraph
andDataset
now support directly adding/removing quads withadd/addN/remove
methods.rdfpipe
command now supports datasets, and reading/writing context sensitive formats.Optional graph-tracking was added to the Store interface, allowing empty graphs to be tracked for Datasets. The DataSet class also saw a general clean-up, see: #309
After long deprecation,
BackwardCompatibleGraph
was removed.
Minor enhancements/bugs fixed:¶
Many code samples in the documentation were fixed thanks to @PuckCh
The new
IOMemory
store was optimised a bitSPARQL(Update)Store
has been made more generic.MD5 sums were never reinitialized in
rdflib.compare
Correct default value for empty prefix in N3 #312
Fixed tests when running in a non UTF-8 locale #344
Prefix in the original turtle have an impact on SPARQL query resolution #313
Duplicate BNode IDs from N3 Parser #305
Use QNames for TriG graph names #330
\uXXXX escapes in Turtle/N3 were fixed #335
A way to limit the number of triples retrieved from the
SPARQLStore
was added #346BNode
as Graph’s public ID #300Introduced ordering of
QuotedGraphs
#291
2013-05-22 RELEASE 4.0.1¶
Following RDFLib tradition, some bugs snuck into the 4.0 release. This is a bug-fixing release:
the new URI validation caused lots of problems, but is necessary to avoid ‘’RDF injection’’ vulnerabilities. In the spirit of ‘’be liberal in what you accept, but conservative in what you produce”, we moved validation to serialisation time.
the
rdflib.tools
package was missing from thesetup.py
script, and was therefore not included in the PYPI tarballs.RDF parser choked on empty namespace URI #288
Parsing from
sys.stdin
was broken #285The new IO store had problems with concurrent modifications if several graphs used the same store #286
Moved HTML5Lib dependency to the recently released 1.0b1 which support python3
2013-05-16 RELEASE 4.0¶
This release includes several major changes:
The new SPARQL 1.1 engine (rdflib-sparql) has been included in the core distribution. SPARQL 1.1 queries and updates should work out of the box.
SPARQL paths are exposed as operators on
URIRefs
, these can then be be used with graph.triples and friends:from rdflib import Graph, URIRef from rdflib.namespace import FOAF, RDFS g = Graph() bob = URIRef("...") cls = URIRef("...") # List names of friends of Bob: g.triples((bob, FOAF.knows/FOAF.name , None)) # All super-classes: g.triples((cls, RDFS.subClassOf * '+', None))
a new
graph.update
method will apply SPARQL update statements
Several RDF 1.1 features are available:
A new
DataSet
classXMLLiteral
andHTMLLiterals
BNode
(de)skolemization is supported throughBNode.skolemize
,URIRef.de_skolemize
,Graph.skolemize
andGraph.de_skolemize
Handled of Literal equality was split into lexical comparison (for normal
==
operator) and value space (using newNode.eq
methods). This introduces some slight backwards incompatible changes, but was necessary, as the old version had inconsistent hash and equality methods that could lead the literals not working correctly in dicts/sets. The new way is more in line with how SPARQL 1.1 works. For the full details, see:https://github.com/RDFLib/rdflib/wiki/Literal-reworking
Iterating over
QueryResults
will generateResultRow
objects, these allow access to variable bindings as attributes or as a dict. I.e.for row in g.query('select ... ') : print row.age, row["name"]
“Slicing” of Graphs and Resources as syntactic sugar: (#271)
graph[bob : FOAF.knows/FOAF.name] -> generator over the names of Bobs friends
The
SPARQLStore
andSPARQLUpdateStore
are now included in the RDFLib coreThe documentation has been given a major overhaul, and examples for most features have been added.
Minor Changes:¶
String operations on URIRefs return new URIRefs: (#258)
>>> URIRef('http://example.org/')+'test rdflib.term.URIRef('http://example.org/test')
Parser/Serializer plugins are also found by mime-type, not just by plugin name: (#277)
Namespace
is no longer a subclass ofURIRef
URIRefs and Literal language tags are validated on construction, avoiding some “RDF-injection” issues (#266)
A new memory store needs much less memory when loading large graphs (#268)
Turtle/N3 serializer now supports the base keyword correctly (#248)
py2exe support was fixed (#257)
Several bugs in the TriG serializer were fixed
Several bugs in the NQuads parser were fixed
2013-03-01 RELEASE 3.4¶
This release introduced new parsers for structured data in HTML. In particular formats: hturtle, rdfa, mdata and an auto-detecting html format were added. Thanks to Ivan Herman for this!
This release includes a lot of admin maintentance - correct dependencies for different python versions, etc. Several py3 bugs were also fixed.
This release drops python 2.4 compatibility - it was just getting too expensive for us to maintain. It should however be compatible with any cpython from 2.5 through 3.3.
node.md5_term
is now deprecated, if you use it let us know.Literal.datatype/language are now read-only properties (#226)
Serializing to file fails in py3 (#249)
TriX serializer places two xmlns attributes on same element (#250)
RDF/XML parser fails on when XML namespace is not explicitly declared (#247)
Resource class should “unbox” Resource instances on add (#215)
Turtle/N3 does not encode final quote of a string (#239)
float Literal precision lost when serializing graph to turtle or n3 (#237)
plain-literal representation of xsd:decimals fixed
allow read-only sleepycat stores
language tag parsing in N3/Turtle fixes to allow several subtags.
2012-10-10 RELEASE 3.2.3¶
Almost identical to 3.2.2 A stupid bug snuck into 3.2.2, and querying graphs were broken.
2012-09-25 RELEASE 3.2.2¶
This is mainly a maintenance release.
This release should be compatible with python 2.4 through to 3.
Changes:
Improved serialization/parsing roundtrip tests led to some fixes of obscure parser/serializer bugs. In particular complex string Literals in ntriples improved a lot.
The terms of a triple are now asserted to be RDFLib Node’s in graph.add This should avoid getting strings and other things in the store. (#200)
Added a specific TurtleParser that does not require the store to be non-formula aware. (#214)
A trig-serializer was added, see: http://www4.wiwiss.fu-berlin.de/bizer/trig/
BNode generation was made thread-safe (#209) (also fixed better by dzinxed)
Illegal BNode IDs removed from NT output: (#212)
and more minor bug fixes that had no issues
2012-04-24 RELEASE 3.2.1¶
This is mainly a maintenance release.
Changes:
New setuptools entry points for query processors and results
Literals constructed from other literals copy datatype/lang (#188)
Relative URIs are resolved incorrectly after redirects (#130)
Illegal prefixes in turtle output (#161)
Sleepcat store unstable prefixes (#201)
Consistent toPyton() for all node objects (#174)
Better random BNode ID in multi-thread environments (#185)
2012-01-19 RELEASE 3.2.0¶
Major changes:
Thanks to Thomas Kluyver, rdflib now works under python3, the setup.py script automatically runs 2to3.
Unit tests were updated and cleaned up. Now all tests should pass.
Documentation was updated and cleaned up.
A new resource oriented API was added: http://code.google.com/p/rdflib/issues/detail?id=166
Fixed many minor issues:
http://code.google.com/p/rdflib/issues/detail?id=177 http://code.google.com/p/rdflib/issues/detail?id=129 Restored compatibility with Python 2.4
http://code.google.com/p/rdflib/issues/detail?id=158 Reworking of Query result handling
http://code.google.com/p/rdflib/issues/detail?id=193 generating xml:base attribute in RDF/XML output
http://code.google.com/p/rdflib/issues/detail?id=180 serialize(format=”pretty-xml”) fails on cyclic links
2011-03-17 RELEASE 3.1.0¶
Fixed a range of minor issues:
http://code.google.com/p/rdflib/issues/detail?id=128
Literal.str does not behave like unicode
http://code.google.com/p/rdflib/issues/detail?id=141
(RDFa Parser) Does not handle application/xhtml+xml
http://code.google.com/p/rdflib/issues/detail?id=142
RDFa TC #117: Fragment identifiers stripped from BASE
http://code.google.com/p/rdflib/issues/detail?id=146
Malformed literals produced when rdfa contains newlines
http://code.google.com/p/rdflib/issues/detail?id=152
Namespaces beginning with _ are invalid
http://code.google.com/p/rdflib/issues/detail?id=156
Turtle Files with a UTF-8 BOM fail to parse
http://code.google.com/p/rdflib/issues/detail?id=154
ClosedNamespace.str returns URIRef not str
http://code.google.com/p/rdflib/issues/detail?id=150
IOMemory does not override open
http://code.google.com/p/rdflib/issues/detail?id=153
Timestamps with microseconds and “Z” timezone are not parsed
http://code.google.com/p/rdflib/issues/detail?id=118
DateTime literals with offsets fail to convert to Python
http://code.google.com/p/rdflib/issues/detail?id=157
Timestamps with timezone information are not parsed
http://code.google.com/p/rdflib/issues/detail?id=151
problem with unicode literals in rdflib.compare.graph_diff
http://code.google.com/p/rdflib/issues/detail?id=149
BerkeleyDB Store broken with create=False
http://code.google.com/p/rdflib/issues/detail?id=134
Would be useful if Graph.query could propagate kwargs to a
plugin processor
http://code.google.com/p/rdflib/issues/detail?id=133
Graph.connected exception when passed empty graph
http://code.google.com/p/rdflib/issues/detail?id=129
Not compatible with Python 2.4
http://code.google.com/p/rdflib/issues/detail?id=119
Support Python’s set operations on Graph
http://code.google.com/p/rdflib/issues/detail?id=130
NT output encoding to utf-8 broken as it goes through
_xmlcharrefreplace
http://code.google.com/p/rdflib/issues/detail?id=121#c1
Store SPARQL Support
2010-05-13 RELEASE 3.0.0¶
Working test suite with all tests passing.
Removed dependency on setuptools.
(Issue #43) Updated Package and Module Names to follow conventions outlined in http://www.python.org/dev/peps/pep-0008/
Removed SPARQL bits and non core plugins. They are mostly moving to http://code.google.com/p/rdfextras/ at least until they are stable.
Fixed datatype for Literal(True).
Fixed Literal to enforce constraint of having either a language or datatype but not both.
Fixed Literal’s repr.
Fixed to Graph Add/Sub/Mul opterators.
Upgraded RDFa parser to pyRdfa.
Upgraded N3 parser to the one from CWM.
Fixed unicode encoding issue involving N3Parser.
N3 serializer improvements.
Fixed HTTP content-negotiation
Fixed Store.namespaces method (which caused a few issues depending on Store implementation being used.)
Fixed interoperability issue with plugin module.
Fixed use of Deprecated functionality.
2009-03-30 RELEASE 2.4.1¶
Fixed Literal comparison case involving Literal’s with datatypes of XSD.base64Binary.
Fixed case where XSD.date was matching before XSD.dateTime for datetime instances.
Fixed jython interoperability issue (issue #53).
Fixed Literal repr to handle apostrophes correctly (issue #28).
Fixed Literal’s repr to be consistent with its __init__
(issue #33).
2007-04-04 RELEASE 2.4.0¶
Improved Literal comparison / equality
Sparql cleanup.
getLiteralValue now returns the Literal object instead of the result of toPython(). Now that Literals override a good coverage of comparison operators, they should be passed around as first class objects in the SPARQL evaluation engine.
Added support for session bnodes re: sparql
Fixed prolog reduce/reduce conflict. Added Py_None IncRefs where they were being passed into Python method invocations (per drewp’s patch)
Fixed sparql queries involving empty namespace prefix.
Fixed the selected variables sparql issue
Fixed
Fixed involving multiple unions and queries are nested more than one level (bug in _getAllVariables causing failure when parent.top is None)
Fixed test_sparql_equals.py.
Fixed sparql json result comma errors issue.
Fixed test_sparql_json_results.py (SELECT * variables out of order)
Added a 4Suite-based SPARQL XML Writer implementation. If 4Suite is not installed, the fallback python saxutils is used instead
applied patch from http://rdflib.net/issues/2007/02/23/bugs_in_rdflib.sparql.queryresult/issue
The restriction on GRAPH patterns with variables has been relieved a bit to allow such usage when the variable is provided as an initial binding
Fix for OPTIONAL patterns. P1 OPT P2, where P1 and P2 shared variables which were bound to BNodes were not unifying on these BNode variable efficiently / correctly. The fix was to add bindings for ‘stored’ BNodes so they aren’t confused for wildcards
Added support to n3 parser for retaining namespace bindings.
Fixed several RDFaParser bugs.
Added serializer specific argument support.
Fixed a few PrettyXMLSerializer issues and added a max_depth option.
Fixed some TurtleSerializer issues.
Fixed some N3Serializer issues.
Added support easy_install
added link to long_descriptin for easy_install -U rdflib==dev to work; added download_url back
added continuous-releases-using-subversion bit
Added rdflib_tools package Added rdfpipe Added initial EARLPluging
Improved test running… using nose… added tests
Exposed generated test cases for nose to find. added bit to configure ‘setup.py nosetests’ to run doc tests
added nose test bits
Added md5_term_hash method to terms.
Added commit_pending_transaction argument to Graph’s close method.
Added DeprecationWarning to rdflib.constants
Added a NamespaceDict class for those who want to avoid the Namespace as subclass of URIRef issues
Added bind function
Fixed type of Namespace re: URIRef vs. unicode
Improved ValueError message
Changed value method’s any argument to default to True
Changed __repr__
to always reflect that it’s an rdf.Literal –
as this is the case even though we now have it acting like the
corresponding type in some casses
A DISTINCT was added to the SELECT clause to ensure duplicate triples are not returned (an RDF graph is a set of triples) - which can happen for certain join expressions.
Support for ConditionalAndExpressionList and RelationalExpressionList (|| and && operators in FILTER)
Fixed context column comparison. The hash integer was being compared with ‘F’ causing a warning:Warning: Truncated incorrect DOUBLE value: ‘F’
applied patch in http://rdflib.net/issues/2006/12/13/typos_in_abstractsqlstore.py/issue
fix for http://rdflib.net/issues/2006/12/07/problems_with_graph.seq()_when_sequences_contain_more_than_9_items./issue
General code cleanup (removing redundant imports, changing relative imports to absolute imports etc)
Removed usage of deprecated bits.
Added a number of test cases.
Added DeprecationWarning for save method
refactoring of GraphPattern
ReadOnlyGraphAggregate uses Graph constructor properly to setup (optionally) a common store
Fixed bug with . (fullstop) in localname parts.
Changed Graph’s value method to return None instead of raising an AssertionError.
Fixed conversion of (exiplicit) MySQL ports to integers.
Fixed MySQL store so it properly calculates __len__
of
individual Graphs
Aligned with how BerkeleyDB is generating events (remove events are expressed in terms of interned strings)
Added code to catch unpickling related exceptions
Added BerkeleyDB store implementation.
Merged TextIndex from michel-events branch.
2006-10-15 RELEASE 2.3.3¶
Added TriXParser, N3Serializer and TurtleSerializer.
Added events to store interface: StoreCreated, TripleAdded and TripleRemoved.
Added Journal Reader and Writer.
Removed BerkeleyDB level journaling.
Added support for triple quoted Literal’s.
Fixed some corner cases with Literal comparison.
Fixed PatternResolution for patterns that return contexts only.
Fixed NodePickler not to choke on unhashable objects.
Fixed Namespace’s __getattr__
hack to ignore names starting
with __
Added SPARQL != operator.
Fixed query result __len__
(more efficient).
Fixed and improved RDFa parser.
redland patches from http://rdflib.net/pipermail/dev/2006-September/000069.html
various patches for the testsuite - http://rdflib.net/pipermail/dev/2006-September/000069.html
2006-08-01 RELEASE 2.3.2¶
Added SPARQL query support.
Added XSD to/from Python datatype support to Literals.
Fixed ConjunctiveGraph so that it is a proper subclass of Graph.
Added Deprecation Warning when BackwardCompatGraph gets used.
Added RDFa parser.
Added Collection Class for working with RDF Collections.
Added method to Graph for testing connectedness
Fixed bug in N3 parser where identical BNodes were not being combined.
Fixed literal quoting in N3 serializer.
Fixed RDF/XML serializer to skip over N3 bits.
Changed Literal and URIRef instantiation to catch UnicodeDecodeErrors - which were being thrown when the default decoding method (ascii) was hitting certain characters.
Changed Graph’s bind method to also override the binding in the case of an existing generated bindings.
Added FOPLRelationalModel - a set of utility classes that implement a minimal Relational Model of FOPL implemented as a SQL database (uses identifier/value interning and integer half-md5-hashes for space and index efficiency).
Changed MySQL store to use FOPLRelationalModel plus fixes and improvements.
Added more test cases.
Cleaned up source code to follow pep8 / pep257.
2006-02-27 RELEASE 2.3.1¶
Added save method to BackwardCompatibleGraph so that example.py etc work again.
Applied patch from Drew Perttula to add local_time_zone argument to util’s date_time method.
Fixed a relativize bug in the rdf/xml serializer.
Fixed NameError: global name ‘URIRef’ is not defined error in BerkeleyDB.py by adding missing import.
Applied patch for Seq to sort list by integer, added by Drew Hess.
Added a preserve_bnode_ids option to rdf/xml parser.
Applied assorted patches for tests (see http://tracker.asemantics.com/rdflib/ticket/8 )
Applied redland.diff (see http://tracker.asemantics.com/rdflib/ticket/9 )
Applied changes specified http://tracker.asemantics.com/rdflib/ticket/7
Added a set method to Graph.
Fixed RDF/XML serializer so that it does not choke on n3 bits (rather it’ll just ignore them)
2005-12-23 RELEASE 2.3.0¶
See http://rdflib.net/2.3.0/ for most up-to-date release notes
Added N3 support to Graph and Store.
Added Sean’s n3p parser, and ntriples parser.
BerkeleyDB implementation has been revamped in the process of expanding it to support the new requirements n3 requirements. It also now persists a journal – more to come.
detabified source files.
Literal and parsers now distinguish between datatype of None and datatype of “”.
Store-agnostic ‘fallback’ implementation of REGEX matching (inefficient but provides the capability to stores that don’t support it natively). Implemented as a ‘wrapper’ around any Store which replaces REGEX terms with None (before dispatching to the store) and whittles out results that don’t match the given REGEX term expression(s).
Store-agnostic ‘fallback’ implementation of transactional rollbacks (also inefficient but provides the capability to stores that don’t support it natively). Implemented as a wrapper that tracks a ‘thread-safe’ list of reversal operations (for every add, track the remove call that reverts the store, and vice versa). Upon store.rollback(), execute the reverse operations. However, this doesn’t guarantee durability, since if the system fails before the rollbacks are all executed, the store will remain in an invalid state, but it provides Atomicity in the best case scenario.
2005-10-10 RELEASE 2.2.3¶
Fixed BerkeleyDB backend to commit after an add and remove. This should help just a bit with those unclean shutdowns ;)
Fixed use of logging so that it does not mess with the root logger. Thank you, Arve, for pointing this one out.
Fixed Graph’s value method to have default for subject in addition to predicate and object.
Fixed Fourthought backend to be consistent with interface. It now supports an empty constructor and an open method that takes a configuration string.
2005-09-10 RELEASE 2.2.2¶
Applied patch from inkel to add encoding argument to all serialization related methods.
Fixed XMLSerializer bug regarding default namespace bindings.
Fixed namespace binding bug involving binding a second default namespace.
Applied patch from Gunnar AAstrand Grimnes to add context
support to __iadd__
on Graph. (Am considering the lack of
context support a bug. Any users currently using __iadd__
, let
me know if this breaks any of your code.)
Added Fourthought backend contributed by Chimezie Ogbuji.
Fixed a RDF/XML parser bug relating to XMLLiteral and escaping.
Fixed setup.py so that install does not try to uninstall (rename_old) before installing; there’s now an uninstall command if one needs to uninstall.
2005-08-25 RELEASE 2.2.1¶
Fixed issue regarding Python2.3 compatibility.
Fixed minor issue with URIRef’s absolute method.
2005-08-12 RELEASE 2.1.4¶
Added optional base argument to URIRef.
Fixed bug where load and parse had inconsistent behavior.
Added a FileInputSource.
Added skeleton sparql parser and test framework.
Included pyparsing (pyparsing.sourceforge.net) for sparql parsing.
Added attribute support to namespaces.
2005-06-28 RELEASE 2.1.3¶
Added Ivan’s sparql-p implementation.
Literal is now picklable.
Added optional base argument to serialize methods about which to relativize.
Applied patch to remove some dependencies on Python 2.4 features.
Fixed BNode’s n3 serialization bug (recently introduced).
Fixed a collections related bug.
2005-05-13 RELEASE 2.1.2¶
Added patch from Sidnei da Silva that adds a sqlobject based backend.
Fixed bug in PrettyXMLSerializer (rdf prefix decl was missing sometimes)
Fixed bug in RDF/XML parser where empty collections where causing exceptions.
2005-05-01 RELEASE 2.1.1¶
Fixed a number of bugs relating to 2.0 backward compatibility.
Fixed split_uri to handle URIs with _ in them properly.
Fixed bug in RDF/XML handler’s absolutize that would cause some URIRefs to end in ##
Added check_context to Graph.
Added patch the improves IOMemory implementation.
2005-04-12 RELEASE 2.1.0¶
Merged TripleStore and InformationStore into Graph.
Added plugin support (or at least cleaned up, made consistent the plugin support that existed).
Added value and seq methods to Graph.
Renamed prefix_mapping to bind.
Added namespaces method that is a generator over all prefix, namespace bindings.
Added notion of NamespaceManager.
Added couple new backends, IOMemory and ZODB.
2005-03-19 RELEASE 2.0.6¶
Added pretty-xml serializer (inlines BNodes where possible, typed nodes, Collections).
Fixed bug in NTParser and n3 methods where not all characters where being escaped.
Changed label and comment methods to return default passed in when there is no label or comment. Moved methods to Store Class. Store no longer inherits from Schema.
Fixed bug involving a case with rdf:about=’#’
Changed InMemoryBackend to update third index in the same style it does the first two.
2005-01-08 RELEASE 2.0.5¶
Added publicID argument to Store’s load method.
Added RDF and RDFS to top level rdflib package.
2004-10-14 RELEASE 2.0.4¶
Removed unfinished functionality.
Fixed bug where another prefix other than rdf was getting defined for the rdf namespace (causing an assertion to fail).
Fixed bug in serializer where nodeIDs were not valid NCNames.
2004-04-21 RELEASE 2.0.3¶
Added missing “from future import generators” statement to InformationStore.
Simplified RDF/XML serializer fixing a few bugs involving BNodes.
Added a reset method to RDF/XML parser.
Changed ‘if foo’ to “if foo is not None” in a few places in the RDF/XML parser.
Fully qualified imports in rdflib.syntax {parser, serializer}.
Context now goes through InformationStore (was bypassing it going directly to backend).
2004-03-22 RELEASE 2.0.2¶
Improved performance of Identifier equality tests.
Added missing “from future import generators” statements needed to run on Python2.2.
Added alternative to shlib.move() if it isn’t present.
Fixed bug that occurred when specifying a backend to InformationStore’s constructor.
Fixed bug recently introduced into InformationStore’s remove method.
2004-03-15 RELEASE 2.0.1¶
Fixed a bug in the SleepyCatBackend multi threaded concurrency support. (Tested fairly extensively under the following conditions: multi threaded, multi process, and both).
NOTE: fix involved change to database format – so 2.0.1 will not be able to open databases created with 2.0.0
Removed the use of the Concurrent wrapper around InMemoryBackend and modified InMemoryBackend to handle concurrent requests. (Motivated by Concurrent’s poor performance on bigger TripleStores.)
Improved the speed of len(store) by making backends
responsible for implementing __len__
.
Context objects now have a identifier property.
2004-03-10 RELEASE 2.0.0¶
Fixed a few bugs in the SleepyCatBackend multi process concurrency support.
Removed rdflib.Resource
Changed remove to now take a triple pattern and removed remove_triples method.
Added __iadd__
method to Store in support of store +=
another_store.
2004-01-04 RELEASE 1.3.2¶
Added a serialization dispatcher.
Added format arg to save method.
Store now remembers prefix/namespace bindings.
Backends are now more pluggable
…
2003-10-14 RELEASE 1.3.1¶
Fixed bug in serializer where triples where only getting serialized the first time.
Added type checking for contexts.
Fixed bug that caused comparisons with a Literal to fail when the right hand side was not a string.
Added DB_INIT_CDB flag to SCBacked for supporting multiple reader/single writer access
Changed rdf:RDF to be optional to conform with latest spec.
Fixed handling of XMLLiterals
2003-04-40 RELEASE 1.3.0¶
Removed bag_id support and added it to OLD_TERMS.
Added a double hash for keys in SCBacked.
Fixed _HTTPClient so that it no longer removes metadata about a context right after it adds it.
Added a KDTreeStore and RedlandStore backends.
Added a StoreTester.
2003-02-28 RELEASE 1.2.4¶
Fixed bug in SCBackend where language and datatype information where being ignored.
Fixed bug in transitive_subjects.
Updated some of the test cases that where not up to date.
async_load now adds more http header and error information to the InformationStore.
2003-02-11 RELEASE 1.2.3¶
Fixed bug in load methods where relative URLs where not being absolutized correctly on Windows.
Fixed serializer so that it throws an exception when trying to serialize a graph with a predicate that can not be split.
2003-02-07 RELEASE 1.2.2¶
Added an exists method to the BackwardCompatibility mixin.
Added versions of remove, remove_triples and triples methods to the BackwardCompatility mixin for TripleStores that take an s, p, o as opposed to an (s, p, o).
2003-02-03 RELEASE 1.2.1¶
Added support for parsing XMLLiterals.
Added support for proper charmod checking (only works in Python2.3).
Fixed remaining rdfcore test cases that where not passing.
Fixed windows bug in AbstractInformationStore’s run method.
2003-01-02 RELEASE 1.2.0¶
Added systemID, line #, and column # to error messages.
BNode prefix is now composed of ascii_letters instead of letters.
Added a bsddb backed InformationStore.
Added an asynchronous load method, methods for scheduling context updates, and a run method.
2002-12-16 RELEASE 1.1.5¶
Introduction of InformationStore, a TripleStore with the addition of context support.
Resource __getitem__
now returns object (no longer returns a
Resource for the object).
Fixed bug in parser that was introduced in last release regaurding unqualified names.
2002-12-10 RELEASE 1.1.4¶
Interface realigned with last stable release.
Serializer now uses more of the abbreviated forms where possible.
Parser optimized and cleaned up.
Added third index to InMemoryStore.
The load and parse methods now take a single argument.
Added a StringInputSource for to support parsing from strings.
Renamed rdflib.BTreeTripleStore.TripleStore to rdflib.BTreeTripleStore.BTreeTripleStore.
Minor reorganization of mix-in classes.
2002-12-03 RELEASE 1.1.3¶
BNodes now created with a more unique identifier so BNodes from different sessions do not collide.
Added initial support for XML Literals (for now they are parsed into Literals).
Resource is no longer a special kind of URIRef.
Resource no longer looks at range to determine default return
type for __getitem__
. Instead there is now a get(predicate, default)
method.
2002-11-21 RELEASE 1.1.2¶
Fixed Literal’s __eq__
method so that Literal(‘foo’)==’foo’ etc.
Fixed Resource’s __setitem__
method so that it does not raise
a dictionary changed size while iterating exception.
2002-11-09 RELEASE 1.1.1¶
Resource is now a special kind of URIRef
Resource’s __getitem__
now looks at rdfs:range to determine
return type in default case.
2002-11-05 RELEASE 1.1.0¶
A new development branch¶
Cleaned up interface and promoted it to SIR: Simple Interface for RDF.
Updated parser to use SAX2 interfaces instead of using expat directly.
Added BTreeTripleStore, a ZODB BTree TripleStore backend. And a default pre-mixed TripleStore that uses it.
Synced with latest (Editor’s draft) RDF/XML spec.
Added datatype support.
Cleaned up interfaces for load/parse: removed generate_path from loadsave and renamed parse_URI to parse.
2002-10-08 RELEASE 0.9.6¶
The end of a development branch¶
BNode can now be created with specified value.
Literal now has a language attribute.
Parser now creates Literals with language attribute set appropriately as determined by xml:lang attributes.
TODO: Serializer-Literals-language attribute
TODO: Change __eq__
so that Literal(“foo”)==”foo” etc
TripleStores now support “in” operator. For example: if (s, p, o) in store: print “Found “, s, p, o
Added APIs/object for working at level of a Resource. NOTE: This functionality is still experimental
Consecutive Collections now parse correctly.
2002-08-06 RELEASE 0.9.5¶
Added support for rdf:parseType=”Collection”
Added items generator for getting items in a Collection
Renamed rdflib.triple_store to rdflib.TripleStore to better follow python style conventions.
Added an Identifier Class
Moved each node into its own Python module.
Added rdflib.util with a first and uniq function.
Added a little more to example.py
Removed generate_uri since we have BNodes now.
2002-07-29 RELEASE 0.9.4¶
Added support for proposed rdf:nodeID to both the parser and serializer.
Reimplemented serializer which now nests things where possible.
Added partial support for XML Literal parseTypes.
2002-07-16 RELEASE 0.9.3¶
Fixed bug where bNodes where being created for nested property elements when they where not supposed to be.
Added lax mode that will convert rdf/xml files that contain bare IDs etc. Also, lax mode will only report parse errors instead of raising exceptions.
Added missing check for valid attribute names in the case of production 5.18 of latest WD spec.
2002-07-05 RELEASE 0.9.2¶
Added missing constants for SUBPROPERTYOF, ISDEFINEDBY.
Added test case for running all of the rdf/xml test cases.
Reimplemented rdf/xml parser to conform to latest WD.
2002-06-10 RELEASE 0.9.1¶
There is now a remove and a remove_triples (no more overloaded remove).
Layer 2 has been merged with layer 1 since there is no longer a need for them to be separate layers.
The generate_uri method has moved to LoadSave since triple stores do not have a notion of a uri. [Also, with proper bNode support on its way the need for a generate_uri might not be as high.]
Fixed bug in node’s n3 function: URI -> URIRef.
Replaced string based exceptions with class based exceptions.
Added PyUnit TestCase for parser.py
Added N-Triples parser.
Added __len__
and __eq__
methods to store interface.
2002-06-04 RELEASE 0.9.0¶
Initial release after being split from redfootlib.