rdf_core 0.9.23  rdf_core: ^0.9.23 copied to clipboard
rdf_core: ^0.9.23 copied to clipboard
A type-safe, modular Dart library for modeling, encoding, and decoding RDF data.
Changelog #
All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
0.9.23 - 2025-10-18 #
Added #
- RdfGraph: Enhanced pattern matching with *Inparameters for set-based queries- Added subjectIn,predicateIn, andobjectInparameters tofindTriples()method
- Added subjectIn,predicateIn, andobjectInparameters tohasTriples()method
- Allows efficient querying for triples matching any value in a set of subjects/predicates/objects
- Optimized implementation leverages existing index structure for improved performance
- Internal refactoring of _matches()method to use set-based matching logic
 
- Added 
0.9.22 - 2025-10-16 #
Changed #
- Logging: Reduced log level from info to fine for all methods that used to use info log level.
0.9.21 - 2025-10-10 #
Fixed #
- Turtle Encoder: Fixed incorrect serialization of blank nodes referenced multiple times as RDF collections
- Blank nodes that appear as objects in multiple triples are now correctly serialized as regular blank nodes instead of collection syntax
- Added validation to ensure collection heads are only referenced once before applying collection syntax
 
0.9.20 - 2025-09-28 #
0.9.19 - 2025-09-26 #
Added #
- RDF 1.1 Dataset Support: New RdfDataset,Quad, andRdfNamedGraphclasses for managing collections of named graphs
- N-Quads Format Support: Complete implementation with NQuadsCodecfor serializing/parsing RDF datasets (application/n-quads)
- Enhanced Plugin Architecture: New RdfDatasetCodecbase class andRdfDatasetCodecRegistryfor dataset format plugins
- Unified Decoder/Encoder API: New base classes RdfGraphDecoder,RdfGraphEncoder,RdfDatasetDecoder,RdfDatasetEncoder
Enhanced #
- RdfCore API: Added decodeDataset(),encodeDataset(), anddatasetCodec()methods for dataset operations
- N-Triples Implementation: Refactored to delegate to N-Quads decoder for better code reuse
- Encoder Options: Added canonicalparameter toNQuadsEncoderOptionsandNTriplesEncoderOptionswith proper equals/hashCode implementation
Changed #
- Plugin Architecture: Reorganized codec files and added new RdfDatasetCodechierarchy alongside existingRdfGraphCodec
- Library Exports: Refined public API with explicit showclauses for controlled exports, added canonical RDF support
- Class Design: Made RdfDatasetandRdfNamedGraphfinal classes to prevent inheritance
- N-Quads Enhancement: Added decode()andencode()methods with blank node label preservation support
- Documentation: Enhanced RdfGraphequality documentation explaining syntactic vs semantic comparison
0.9.18 - 2025-09-25 #
Added #
- RdfGraph: True subgraph extraction with reachability traversal
- subgraph(root, {filter})follows object references to extract all reachable triples
- TraversalFiltercallback with depth tracking for fine-grained traversal control
- TraversalDecisionenum:- include,- skip,- includeButDontDescend,- skipButDescend
- Automatic cycle detection and memory-conscious implementation
- New skipButDescendtraversal option: Skip triple but continue traversal from its object- Useful for list filtering (e.g., extract rdf:firstvalues while skippingrdf:reststructure)
- Enables selective extraction while maintaining graph connectivity
- Documented with practical examples for RDF list processing
 
- Useful for list filtering (e.g., extract 
 
Enhanced #
- Test Coverage: 17 comprehensive tests covering edge cases, performance, and real-world scenarios
- 6 new tests specifically for skipButDescendfunctionality
- List filtering examples and complex traversal scenarios
 
- 6 new tests specifically for 
- Performance: Optimized for large graphs with efficient cycle detection
- Documentation: Enhanced subgraphmethod documentation withskipButDescendexamples
0.9.17 - 2025-09-24 #
Changed #
- RdfGraph: Renamed subgraph()method tomatching()for clarity- Method name now clearly indicates pattern-matching behavior
- Avoids confusion with graph-theory "subgraph" concept (which would include reachable nodes)
- No functional changes - same parameters, return type, and performance characteristics
 
0.9.16 - 2025-09-24 #
Added #
- 
RdfGraph: New hasTriples()method for efficient boolean pattern matching- Returns true/false for triple existence without retrieval overhead
- Supports wildcard pattern matching with null parameters
- Uses lazy indexing for O(1) performance on subject-based queries
 
- 
RdfGraph: New subgraph()method for creating filtered graph instances- Returns new RdfGraph containing only triples matching the specified pattern
- Enables graph chaining and composition workflows
- Index optimization for subject-based filtering with automatic index reuse
- Delegates to findTriples()for non-optimized cases to leverage existing optimizations
 
Enhanced #
- 
Performance: Transparent lazy indexing provides automatic query optimization - Indexing is enabled by default with zero memory cost until first query
- Subject-based queries automatically benefit from O(1) performance after index creation
- No API changes required - existing code gets performance boost automatically
 
- 
Documentation: Comprehensive RdfGraph API documentation improvements - Added missing parameter documentation for all public methods
- Clarified lazy indexing behavior and performance characteristics
- Enhanced documentation for withOptions(),subjects,predicates,objectsgetters
 
- 
Test Coverage: Added comprehensive tests for previously untested methods - Full test coverage for hasTriples(),withOptions(), and getter methods
- Edge case testing for indexed vs non-indexed graph behavior
 
- Full test coverage for 
0.9.15 - 2025-09-23 #
Changed #
- Updated all code examples and documentation to use const IriTerm()constructor- All examples in README.md, documentation, and example files now consistently use the const constructor
- Follows the pattern established in v0.9.15 where IriTermconstructor became const-compatible
- Example: IriTerm('http://example.org/subject')→const IriTerm('http://example.org/subject')
- Improves compile-time optimization and developer experience with better const usage patterns
 
- Introduced IriTerm.validated()non-const constructor to replace the oldIriTerm()for cases where the input needs to be validated
- Deprecated IriTerm.prevalidated()const constructor in favour ofconst IriTerm()
- Deprecated IriTerm.iriattribute in favour ofIriTerm.valuewhich is more expected by most developers.
0.9.14 - 2025-08-13 #
Added #
- Absolute-Path Relativization: New support for RFC 3986 absolute-path references in IRI relativization
- Added allowAbsolutePathoption (defaults to true) toIriRelativizationOptionsfor controlling absolute-path relativization
- Enables generation of shorter relative IRIs like /simple.txtinstead of../../../../simple.txt
- Automatically selects the shorter option between dot notation and absolute-path references
 
- Added 
Improved #
- RFC 3986 Compliance: Enhanced IRI relativization algorithm for better standards compliance
- Base URI fragments are now properly stripped per RFC 3986 Section 5.1 before relativization
- Improved handling of file vs. directory path segments in common prefix calculation
- Better preservation of trailing slashes in relative path generation
- Fixed edge cases in relativization when base IRI contains fragments
 
- IRI Relativization Algorithm: Significant improvements to dot notation path generation
- Enhanced common prefix calculation for more accurate relative path generation
- Better handling of file vs. directory path components
- Improved sibling directory navigation with configurable constraints
- More robust edge case handling for malformed IRIs and complex path structures
 
- Enhanced Format Detection: Improved Turtle and JSON-LD format detection accuracy
- Enhanced Turtle canParsemethod with better HTML rejection and more specific pattern matching
- Added comprehensive test coverage for format detection edge cases
- Better discrimination between Turtle content and HTML/XML documents
 
- Enhanced Turtle 
0.9.13 - 2025-08-04 #
Fixed #
- Types should not be relative but rather prefixed in turtle and jsonld formats
0.9.12 2025-07- #
Added #
- Advanced IRI Relativization System: Comprehensive configurable IRI relativization with dot notation support
- New IriRelativizationOptionsclass for fine-grained control over relative IRI generation
- Three built-in presets: none()(no relativization),local()(same-directory only),full()(maximum relativization)
- Configurable options: maxUpLevels,maxAdditionalLength,allowSiblingDirectories
- Support for dot notation paths like ../sibling/file.txtand../../parent/file.txt
- Enhanced relativizeIri()function with options parameter for backward-compatible configuration
- All encoders (Turtle, JSON-LD, N-Triples) now support configurable relativization through options
 
- New 
- Fragment IRI Rendering Control: New renderFragmentsAsPrefixedoption for Turtle encoder- Controls how fragment IRIs are rendered in Turtle output (prefixed vs. relative format)
- When true(default):http://example.org/doc#termbecomes:termwith@prefix : <#> .
- When false:http://example.org/doc#termbecomes<#term>when using base URI
- Provides flexibility for different RDF serialization preferences and use cases
 
- Dot Notation Demo Example: New example demonstrating enhanced IRI relativization capabilities
- Shows different relativization modes and their effects
- Demonstrates custom configuration options
- Includes roundtrip consistency verification
 
Improved #
- Enhanced Encoder Options API: Unified IRI relativization support across all encoders
- Added iriRelativizationproperty toRdfGraphEncoderOptionsbase class
- Updated all encoder option classes (TurtleEncoderOptions,JsonLdEncoderOptions,NTriplesEncoderOptions) to support relativization configuration
- Enhanced copyWith()methods for immutable option updates with relativization support
- RdfGraphEncoderOptions.copyWith()for immutable option updates
- TurtleEncoderOptions.copyWith()with full parameter support including new fragment rendering option
- JsonLdEncoderOptions.copyWith()and- NTriplesEncoderOptions.copyWith()for consistency
- Enables fluent API patterns and easier configuration management
 
- Added 
- IRI Compaction Infrastructure: Enhanced internal IRI processing with sophisticated dot notation support
- Improved _tryDotNotationRelativization()algorithm with comprehensive path analysis
- Added option-aware relativization constraints and length checking
- Enhanced roundtrip consistency verification for all relativization results
 
- Improved 
- Documentation Updates: Updated roadmap with better Turtle relative IRI handling plans
0.9.10 - 2025-07-24 #
Improved #
- Enhanced IRI Compaction Error Handling: Improved robustness and reliability of namespace prefix handling
- IriCompactionResult.compactIri()now provides guaranteed non-null results with automatic fallback to full IRI format
- Added helpful warning messages when IRIs cannot be compacted, including suggestions for correct IriRoleusage
- Eliminates potential null pointer exceptions in serializers by ensuring graceful degradation
- Improved type safety in Turtle and JSON-LD encoders by removing null-handling branches
- Better handling of rdf:typeobject serialization with proper IRI role context
 
0.9.9 - 2025-07-23 #
Added #
- Extension API for Third-Party Codec Implementers: New rdf_core_extend.dartlibrary opens internal APIs- BREAKING THE ENCAPSULATION BARRIER: Exposes previously internal utilities for external codec developers
- Makes relativizeIriandresolveIrifunctions available to libraries likerdf_xml.
- Provides public access to the IriCompactionsystem used internally by Turtle and JSON-LD encoders
- Enables external codecs to achieve the same level of namespace handling and IRI processing
- Includes comprehensive documentation and examples for building production-quality RDF serialization formats
- Strategic API Decision: Allows ecosystem growth while maintaining internal consistency across all formats
 
Changed #
- IRI Compaction System Refactoring: Major improvements to namespace and prefix handling
- Moved IriCompactionfromlib/src/vocab/tolib/src/for better organization
- Added IriRole.typeenum value for proper handling ofrdf:typeobject IRIs
- Replaced boolean flags with type-safe AllowedCompactionTypesconfiguration
- IriCompactionconstructor now accepts configurable local name validation function
- Enhanced type safety with sealed CompactIriclasses and pattern matching
- Both Turtle and JSON-LD encoders now use unified compaction logic
- Improved handling of rdf:typeobjects in serializers for semantic accuracy
 
- Moved 
0.9.8 - 2025-07-23 #
Added #
- 
IRI Utilities: New iri_util.dartlibrary providing standardized IRI relativization and resolution- relativizeIri()function converts absolute IRIs to relative form when possible
- resolveIri()function resolves relative IRIs against base URIs with RFC 3986 compliance
- Ensures roundtrip consistency between relativization and resolution operations
- Handles edge cases including malformed IRIs, international characters, and various URI schemes
- Used internally by serializers for consistent base URI handling
 
- 
IRI Compaction System: New centralized prefix management and IRI compaction infrastructure - IriCompactionclass provides unified logic for namespace prefix extraction and generation
- Shared between Turtle and JSON-LD encoders for consistent behavior
- Automatic prefix generation for unknown namespaces with proper RDF delimiter validation
- Smart handling of overlapping prefixes (selects most specific match)
- Validates local name compliance with format-specific requirements
 
Enhanced #
- 
TurtleEncoder: Major improvements to prefix handling and base URI support - Added includeBaseDeclarationoption to control@basedirective output
- Improved automatic prefix generation with validation of numeric local names
- Better handling of relative IRIs when base URI is provided
- Enhanced validation prevents generation of invalid Turtle syntax
- Predicates now always use prefixes or full IRIs (never relative IRIs for better compliance)
 
- Added 
- 
JsonLdEncoder: Enhanced context generation and base URI handling - Added includeBaseDeclarationoption for@basein JSON-LD context
- Improved automatic prefix generation with shared logic from IRI compaction system
- Better relative IRI handling in JSON-LD objects
- Enhanced @typeserialization (now outputs compact IRI strings instead of@idobjects)
- More efficient namespace detection and context minimization
 
- Added 
- 
JsonLdDecoder: Improved IRI resolution and context handling - Better relative IRI resolution using centralized resolveIri()function
- Enhanced context processing for prefix expansion
- More robust handling of base URI resolution edge cases
 
- Better relative IRI resolution using centralized 
- 
TurtleDecoder: Enhanced IRI resolution with centralized utilities - Uses new resolveIri()function for consistent relative IRI handling
- Better error messages for missing base URI scenarios
- Improved RFC 3986 compliance for IRI resolution
 
- Uses new 
Changed #
- RdfNamespaceMappings: Enhanced validation and local name checking
- Added isValidLocalPart()method for validating local name components
- Better handling of numeric local names and special characters
- Improved validation prevents generation of invalid namespace prefixes
 
- Added 
Fixed #
- Cross-format consistency: Both Turtle and JSON-LD now use identical prefix generation logic
- Base URI handling: Consistent relative IRI resolution across all decoders and encoders
- Prefix conflicts: Better detection and handling of overlapping namespace prefixes
- Test compatibility: Updated test expectations to reflect improved prefix generation behavior
0.9.6 - 2025-07-18 #
Fixed #
- 
NTriplesDecoder: Improved blank node identity consistency during parsing - Blank nodes with the same label (e.g., _:node1) now map to identicalBlankNodeTerminstances throughout the document
- Maintains proper RDF semantics where blank node labels within a document scope refer to the same resource
- Uses efficient label-to-instance mapping to ensure reference identity consistency
- Critical for applications that rely on blank node identity for data integrity and graph operations
 
- Blank nodes with the same label (e.g., 
- 
NTriplesEncoder: Implemented proper blank node labeling with sequential numbering - Blank nodes now receive consistent, sequential labels (b0, b1, b2, etc.) following N-Triples best practices
- Maintains stable mapping of BlankNodeTerminstances to labels throughout serialization
- Replaced non-deterministic hash-based labeling with predictable counter-based approach
- Ensures same blank node instance always serializes to the same label across multiple references
- Added comprehensive test coverage for blank node consistency and sequential labeling
 
0.9.4 - 2025-07-09 #
Added #
- 
RdfGraph: Added without(RdfGraph other)method for graph subtraction operations- Enables removing all triples from another graph to compute graph differences
- Useful for removing knowledge subsets, undoing merge operations, and comparing graph versions
- Returns a new immutable graph instance with specified triples removed
 
- 
RdfGraph: Added withoutTriples(Iterable<Triple> triples)method for bulk triple removal- Performs set subtraction to remove multiple triples in a single operation
- Supports removing collections of triples based on exact equality matching
- Optimized for removing temporary working sets or outdated statements
 
Changed #
- RdfGraph: merge(RdfGraph other)andwithTriples(Iterable<Triple> triples)behavior updated- Now automatically remove duplicate triples to enforce mathematical set semantics
- BREAKING: Triple ordering is no longer preserved in the resulting graph
- Aligns with RDF specification that treats graphs as sets rather than ordered collections
- Improves performance by eliminating redundant triple storage
 
Enhanced #
- Documentation: Comprehensive API documentation added for new graph subtraction methods
- Added detailed method descriptions, parameter documentation, and usage examples
- Included performance considerations and common use case scenarios
- Enhanced code examples showing practical applications in RDF data management
- Updated documentation for mergeandwithTriplesto reflect new deduplication behavior
 
0.9.3 - 2025-06-24 #
Fixed #
- 
TurtleDecoder: Fixed parsing of prefixed names with colons in local parts - Corrected prefixed name splitting to only split on the first colon, allowing colons in local names per W3C Turtle specification
- Updated parser to properly handle IRIs like prefix:local:namewhich are valid according to PN_LOCAL grammar
 
- 
TurtleTokenizer: Enhanced local name validation according to PN_LOCAL specification - Implemented proper PN_LOCAL grammar validation that prevents invalid patterns like dots at the end of local names
- Added validation to reject local names ending with dots (e.g., author.me→ invalid)
- Added validation to reject local names starting with dots or hyphens
- Added validation to reject double dots and hyphen-dot patterns
- Improved tokenizer to properly handle dots in the middle of valid local names
- Fixed tokenizer backtracking when invalid trailing dots are detected
 
- 
RdfNamespaceMappings: Enhanced IRI validation for prefix generation - Added comprehensive _isValidPnLocalvalidation function that enforces W3C Turtle PN_LOCAL rules
- Improved extractNamespaceAndLocalPartto reject IRIs with invalid local name patterns
- Added validation for domain-like suffixes and percent encoding in local names
- Performance optimization: pre-compiled regex patterns as static final fields to avoid repeated compilation
 
- Added comprehensive 
Enhanced #
- Performance: Optimized regex usage in TurtleTokenizer by using static final compiled patterns
- Replaced inline RegExp(r'[0-9]')calls with pre-compiled_isDigitRegExp
- Replaced inline character class regexes with static compiled patterns for better performance
 
- Replaced inline 
Added #
- Testing: Added comprehensive test suite for Turtle local name validation
- Tests for invalid PN_LOCAL patterns (dots at end, double dots, hyphen-dot combinations)
- Tests for valid PN_LOCAL patterns with dots in the middle
- Validation that invalid local names are serialized as full IRIs instead of using prefix notation
 
0.9.2 - 2025-05-15 #
Fixed #
- Turtle encoding of IRIs that contain url escape (e.g. %20) must not use prefixes
0.9.1 - 2025-05-15 #
Changed #
- 
TurtleEncoder: Fixed prefix and relative URI handling with base URI - Improved handling of IRIs with baseUri to correctly prioritize relative IRIs for subjects/objects
- Always use prefixes for predicates, even when they fall under the base URI
- Apply prefixes only to subjects/objects when their namespace is longer than the base URI
- Fixed issue where base URI namespaces were sometimes incorrectly used as prefixes
 
- 
TurtleEncoder: Improved handling of local names that start with a digit - Local names that start with a digit are now consistently serialized as full IRIs rather than using prefix notation by default
- This behavior can be configured through the useNumericLocalNamesoption inTurtleEncoderOptions
- Fixed internal parameter consistency to ensure proper serialization of IRIs with numeric local names regardless of prefix availability
 
- 
RdfNamespaceMappings: Improved prefix generation for URIs with hyphens - Changed prefix generation strategy to use initials for components with hyphens (e.g., "test-complex-ontology" → "tco")
- Ensures compliance with RDF specifications that prohibit hyphens in prefixes
- Makes prefix generation consistent between domain names and path components with hyphens
- Added comprehensive tests for hyphen handling in prefix generation
 
0.9.0 - 2025-05-14 #
Breaking Changes #
- 
RdfCore API: Changed signature for codec retrieval - Modified how codecs are accessed and configured in the RdfCore class
- Users who directly access or modify codecs will need to update their code
 
- 
Codec Architecture: Enhanced options support - RdfGraphCodec,- RdfGraphEncoder, and- RdfGraphDecodernow support distinct- RdfGraphEncoderOptionsand- RdfGraphDecoderOptions
- All codec implementations must now properly handle these options
 
Added #
- TurtleEncoder: Added support for automatic prefix generation
- New generateMissingPrefixesoption inTurtleEncoderOptions(enabled by default)
- The encoder now automatically generates meaningful prefixes for IRIs that don't match existing prefixes
- Reuses generated prefixes consistently within the same serialization
 
- New 
Enhanced #
- 
Documentation was greatly enhanced for all exported classes 
- 
RdfNamespaceMappings: Added static utility method for namespace manipulation - New public static method extractNamespaceAndLocalPartfor splitting IRIs into namespace and local part
- Can be used by clients to implement custom namespace-aware functionality
 
- New public static method 
- 
TurtleEncoder: Improved handling of base URIs and relative IRIs - Properly writes base directive in Turtle output when baseUri is provided
- Correctly converts absolute IRIs to relative IRIs when they start with the base URI
- Ensures no prefix generation for IRIs that should be serialized as relative paths
 
0.8.2 - 2025-05-13 #
Fixed #
- AutoDetectingGraphCodec: Improved handling of codec detection failures
- Fixed implementation to properly delegate to registry.detectGraphCodec
- Modified AutoDetectingGraphDecoder to try all registered codecs in sequence when auto-detection fails
- Corrected supportedMimeTypes to use the default codec's supported types
 
- Turtle Encoder: Enhanced relative URI support
- Added proper handling of relative URIs when baseUri is provided
- Improved base URI handling in the Turtle output format
 
- Exception Handling: Updated tests to handle both FormatException and custom exception types:
- Modified tests to accept RdfSyntaxException, RdfDecoderException in addition to FormatException
- Fixed encoder comparison to check for runtimeType equality instead of instance identity
 
0.8.1 - 2025-05-13 #
Breaking Changes - DO NOT USE 0.8.0 please #
- API Refactoring: In preparation for RDF 1.1 Dataset support:
- Renamed RdfCodec→RdfGraphCodec
- Renamed RdfEncoder→RdfGraphEncoder
- Renamed RdfDecoder→RdfGraphDecoder
 
- Renamed 
0.8.0 - 2025-05-12 #
Breaking Changes #
- API Refactoring: Changed terminology to align with dart:convert standards
- Renamed parse→decode
- Renamed serialize→encode
- Renamed RdfFormat→RdfCodec
- Renamed withStandardFormats→withStandardCodecs
- Renamed withFormats→withCodecs
 
- Renamed 
Added #
- Added additionalCodecsparameter towithStandardCodecsfactory constructor
- Added global convenience variables (turtle,jsonld,ntriples,rdf) for easier API usage
- Improved documentation for registry access through the registryproperty
0.7.6 - 2025-05-08 #
0.7.5 - 2025-05-07 #
Changed #
- Another turtle tweak: suppress duplicate objects in multivalue predicates
0.7.2 - 2025-05-07 #
Added #
- Added additional well-known namespaces to standard mappings:
- Added geo (http://www.w3.org/2003/01/geo/wgs84_pos#)
- Added contact (http://www.w3.org/2000/10/swap/pim/contact#)
- Added time (http://www.w3.org/2006/time#)
- Added vs (http://www.w3.org/2003/06/sw-vocab-status/ns#)
- Added dcmitype (http://purl.org/dc/dcmitype/)
- Added void (http://rdfs.org/ns/void#)
- Added prov (http://www.w3.org/ns/prov#)
- Added gr (http://purl.org/goodrelations/v1#)
 
Changed #
- Enhanced Turtle serialization for improved readability:
- Implemented inline blank node serialization for nodes referenced exactly once
- Added support for nested inline blank nodes in square bracket notation
- Added proper whitespace formatting with double line breaks between subject groups
- Optimized collection serialization to work with inline blank nodes
 
- Added linting configuration using package:lints/core.yaml
- Improved code quality with lint fixes and optimized Dart idioms
0.7.1 - 2025-05-06 #
Changed #
- Triple,- IriTerm,- BlankNodeTermand- LiteralTermclasses now output in n-triple style in- .toString()for better readability of debug output.
- Included information about json-ld in README and homepage.
0.7.0 - 2025-05-05 #
Added #
- Added support for N-Triples format, including parser and serializer implementations
- Implemented N-Triples as per W3C RDF 1.1 N-Triples specification
- Added proper escaping and validation for N-Triples syntax
- Integrated N-Triples format into the standard formats registry
- Available via MIME type 'application/n-triples' and file extension '.nt'
 
0.6.10 - 2025-05-05 #
Added #
- Added new factory methods LiteralTerm.integer(),LiteralTerm.decimal(), andLiteralTerm.boolean()for more concise and type-safe creation of common literal types.
- Updated TurtleParser to use these specialized factory methods for literal values.
- Enhanced TurtleSerializer to use native syntax for integer, decimal and boolean literals, resulting in more idiomatic and concise Turtle output.
- Enhanced TurtleSerializer to use native syntax for lists (aka rdf collections: ex:Person1 ex:someProperty ("foo" "bar" "blub");) and sets (aka multiple triple per subject/predicate pair:ex:Person1 ex:someProperty "foo", "bar", "blub";).
0.6.5 - 2025-05-02 #
Fixed #
- TurtleFormat and JsonLdFormat should have been exported
- unused http dependency was removed
0.6.4 - 2025-05-02 #
Fixed #
- Fixed tests to use relative paths instead of absolute paths for better portability
- Improved examples for handling broken Turtle syntax
0.6.3 - 2025-05-02 #
Added #
- Enhanced Turtle parsing flexibility with configurable parsing flags in TurtleTokenizer
- Added TurtleParsingFlagenum with options for handling non-standard Turtle syntax
- Implemented support for digits in local names (allowDigitInLocalName)
- Added support for missing dots after prefix declarations (allowMissingDotAfterPrefix)
- Implemented auto-addition of common prefixes (autoAddCommonPrefixes)
- Added support for prefix declarations without @ symbol (allowPrefixWithoutAtSign)
- Improved handling of missing final dots (allowMissingFinalDot)
- Implemented support for identifiers without colons (allowIdentifiersWithoutColon)
 
- Added 
- Improved error reporting with detailed position information and diagnostics
- Added comprehensive logging to help diagnose parsing issues in real-world Turtle files
Changed #
- Refactored TurtleTokenizer for better maintainability and modularity
- Improved documentation with practical examples of non-standard Turtle syntax handling
Fixed #
- Made Turtle parser more robust when processing real-world datasets with syntax variations
- Enhanced error messages to be more informative for debugging parsing issues
0.6.2 - 2025-05-01 #
Fixed #
- Important fix: build.yaml should not have been committed, it breaks the build of user projects
0.6.1 - 2025-05-01 #
Changed #
- Removed a deprecated annotation that was no longer needed after the vocabulary cleanup
0.6.0 - 2025-05-01 #
Removed #
- BREAKING CHANGE: Removed all deprecated vocabulary classes from the vocab directory
- Removed all previously deprecated vocabulary classes (SchemaProperties, SchemaTypes, SchemaPersonProperties, etc.)
- Users should now use direct IriTerm instances instead of vocabulary classes
- Example: replace SchemaProperties.namewithconst IriTerm('https://schema.org/name')
 
- Updated examples to use direct IriTerm instances rather than vocabulary constants
Added #
- Improved documentation around IriTerm usage patterns
- Added more comprehensive test coverage for core RDF functionality
- Support for multiline strings in turtle files
0.5.1 - 2025-04-30 #
Fixed #
- Fixed release script to correctly parse the changelog format with square brackets
- Added missing development dependencies required for the release tooling
0.5.0 - 2025-04-30 #
- BREAKING CHANGE: Marked all vocabulary classes as deprecated
- Added @deprecatedannotation to all classes in vocabulary modules (acl, dc, dc_terms, foaf, ldp, etc.)
- Classes will be removed in a future release due to API design concerns
- Users should migrate to the upcoming new vocabulary API
 
- Added 
- Improved code documentation
- Enhanced developer warnings for approaching breaking changes
0.4.0 - 2025-04-29 #
- BREAKING CHANGE: Reorganized API structure for better modularity and usability
- Added RdfNamespaceMappingsfor improved namespace handling
- Enhanced serializers to support custom namespace mappings
- Improved documentation across the codebase
- Updated API documentation to reflect new structure
0.3.1 #
- Extended Schema.org vocabulary with postal address support
- Added PostalAddress,ContactPoint, andCountryclasses
- Added SchemaAddressPropertiesfor complete address modeling
- Added properties for street address, locality, region, postal code, country, etc.
 
- Added 
- Added comprehensive tests for new postal address components
- Added example demonstrating postal address usage with Schema.org vocabulary
0.3.0 #
- Enhanced blank node handling in RDF serialization and parsing
- Refactored IriTerm usage with prevalidated constructor and improved validation logic
- Refactored RDF Core Vocabulary: replaced constants with vocabulary modules
- Added RDF vocabularies for RDFS, Schema.org, SKOS, Solid, and vCard
- Improved documentation and consistency across RDF vocabularies
- Added comprehensive tests for RDF exception handling and parsing
- Enhanced test coverage for TurtleTokenizer and JsonLdFormat functionality
- Fixed edge cases in blank node handling
- Improved test assertions and documentation for various RDF vocabularies
0.2.0 #
- Numerous improvements and new features since 0.1.2.
- See commit history for details on all enhancements and fixes.
0.1.2 #
- Cleaned up all library names for consistency (removed rdf_core. prefix, now use simple names like exceptions.base).
- Minor formatting and style improvements in core files.
- No breaking changes; all public APIs remain backward compatible.
0.1.1 #
- Example and documentation now consistently use canonical RDF vocabularies (e.g., http://xmlns.com/foaf/0.1/) with http://, not https://.
- Turtle and JSON-LD serializers automatically warn if non-canonical (https) namespaces are used when canonical (http) is available.
- Added documentation and comments on best practices for prefixes and vocabularies.
- Improved prefix handling and static analysis compliance.
- Added and refined tests for prefix usage and serialization correctness.
0.1.0 #
- Initial release of rdf_core: type-safe, extensible Dart library for RDF data manipulation.
- Implements RDF graph, triple, term, and serialization/parsing for Turtle and JSON-LD.
- Plugin architecture for formats and adapters.
- Comprehensive test coverage.