- Allow overriding of protected terms when redefining to the same
definition, modulo the
protected
flag itself. - Fix type-scoped context application:
- Ensure values and subject references are expanded and compacted using type-scoped contexts, if available.
- Ensure
@type
values are evaluated against the previous context, not the type-scoped context.
- Ensure
@type
-scoped terms are limited to their@type
-scoped object.
- Testing: Use explicit id and description skipping regexes.
- Usage of JavaScript Object property names in data.
- NOTE: A class of bugs was causing term names such as
toString
,valueOf
, and others to be dropped or produce bogus output. The fix could cause output triples to differ from previous versions if those special names were used. - Specifically, the problem was using
x in obj
instead ofobj.hasOwnProperty(x)
or aMap
. - Fixed usage in contexts for expand and compact.
- Attempted fixes in other parts of the code with similar
x in obj
usage. Finding actual realistic failing test cases proved difficult.
- NOTE: A class of bugs was causing term names such as
- Testing: Improve skip logging.
- Testing:
skip
andonly
flags in manifests. - Testing:
VERBOSE_SKIP=true
env var to debug skipping. - Support
@protected
. - Support experimental non-standard
protectedMode
option.
- Handle
<subject> <rdf:first> <rdf:nil>
triple.
- Improve handling of canonize test cases.
- Update rdf-canonize dependency to address N-Quads parsing bug.
- Switch to eslint.
- Optimize ensuring value is an array.
- Update canonize docs.
- rdf-canonize updated:
- BREAKING: A fix was applied that makes the canonical output format
properly match the N-Triples canoncial format. This fixes the format to no
longer escape tabs in literals. This may cause canonical output from
jsonld.normalize()
/jsonld.canonize()
to differ from previous versions depending on your literal data. If a backwards compatibility mode is needed please use 1.4.x and file an issue. - BREAKING: rdf-canonize-native was removed as an indirect optional
dependency and the JavaScript implemenation is now the default. The former
usePureJavaScript
flag was removed and a newuseNative
flag was added to force use of the native bindings. Higher level applications must explicitly installrdf-canonize-native
to use this mode. Note that in many cases the JavaScript implemenation will be faster. Apps should be benchmarked before using the specialized native mode. - NOTE: The Travis-CI C++11 compiler update fixes are no longer needed when using jsonld.js! rdf-canonize-native was updated to not use C++11 features and is also no longer a direct or indirect dependency of jsonld.js.
- BREAKING: A fix was applied that makes the canonical output format
properly match the N-Triples canoncial format. This fixes the format to no
longer escape tabs in literals. This may cause canonical output from
rdfn:Urgna2012EvalTest
andrdfn:Urdna2015EvalTest
tests should compare with expected output.
- PhantomJS is deprecated, now using headless Chrome with Karma.
- NOTE: Using headless Chrome vs PhantomJS may cause newer JS features to slip into releases without proper support for older runtimes and browsers. Please report such issues and they will be addressed.
- Update webpack and babel.
- Use CommonJS style in main file.
- NOTE: This change might cause problems if code somehow was still
using the long deprecated
jsonldjs
global. Any dependants on this feature should update to use bundler tools such as webpack or usejsonld
in the distributed bundle.
- NOTE: This change might cause problems if code somehow was still
using the long deprecated
- Use rdf-canonize to compare n-quads test results.
- Maintain multiple graphs.
- Sort
@type
when looking for scoped contexts.
- Use JSON-LD WG tests.
- Categorize and skip failing tests.
- Fix source map generation.
- The updated rdf-canonize extracted out native support into rdf-canonize-native and now has an optional dependency on this new module. If you have build tools available it will still build and use native support otherwise it will fallback to less performant JS code.
- If you wish to require the native
rdf-canonize
bindings, add a dependency in your code tordf-canonize-native
to insure it is installed. - Some systems such as Travis CI currently only have
ancient compilers installed by default. Users of
rdf-canonize
, and hencejsonld.js
, previously required special setup so therdf-canonize
native bindings would be installable. If CI testing is not performance critical you can now simplify your CI config, let those bindings fail to install, and use the JS fallback code.
- Update
rdf-canonize
dependency to 0.3.
- Initial support for benchmarking.
- Basic callback interface tests.
- Add README note about running json-ld.org test suite.
- Callback version of every test.
- Callback interface tests added to catch callback API errors.
- Avoids duplication of running every test for promises and callbacks.
- Simplifies testing code and makes async/await conversion easier.
- Add
skipExpansion
flag totoRdf
andcanonize
.
- Fix
_findContextUrls
refactoring bug from 1.0.3.
- Improve performance of active context cache and find context urls:
- Use Map/Set.
- Cache initial contexts based on options.
- Reduce lookups.
- Update webpack/karma core-js usage:
- Add Map, Set, and Array.from support.
- Handle compactArrays option in
@graph
compaction. - Many eslint fixes.
- Add missing await to createNodeMap() and merge().
- Don't always use arrays for
@graph
. Fixes 1.0 compatibility issue.
- 1.0.0!
- Semantic Versioning is now past the "initial development" 0.x.y stage (after 7+ years!).
- Conformance:
- JSON-LD 1.0 + JSON-LD 1.0 errata
- JSON-LD 1.1 drafts
- Thanks to the JSON-LD and related communities and the many many people over the years who contributed ideas, code, bug reports, and support!
- Expansion and Compaction using scoped contexts on property and
@type
terms. - Expansion and Compaction of nested properties.
- Index graph containers using
@id
and@index
, with@set
variations. - Index node objects using
@id
and@type
, with@set
variations. - Framing default and named graphs in addition to merged graph.
- Value patterns when framing, allowing a subset of values to appear in the output.
- ES2018 features are being used. Update version check to use generated Node.js 6 code when using Node.js earlier than 8.6.0.
- Typo handling legacy N-Quads dataset format.
- Include String startsWith() compatibility code.
- Use the W3C standard MIME type for N-Quads of "application/n-quads". Accept "application/nquads" for compatibility.
- Fix fromRdf with input triple having a nil subject.
- BREAKING: Release 0.5.x as latest branch. See the many many changes below since 0.4.x including many potential breaking changes.
- BREAKING: Remove
jsonld.version
API andpkginfo
dependency. This feature added complexity and browser issues and the use case is likely handled by semantic versioning and using a proper dependency.
- Do not use native types to create IRIs in value expansion.
- Improved error detection for
@container
variations. - Handle empty and relative
@base
. - Remove shortcut from compactIri when IRI is a keyword (fixes compact-0073).
- Set processingMode from options or first encountered context.
- Use array representation of
@container
in processing. - BREAKING: Check for keys in term definition outside that expected:
@container
,@id
,@language
,@reverse
, and@type
. This also sets up for additional keywords in 1.1.
- BREAKING: Use RDF JS (rdf.js.org) interfaces for internal representation of dataset and quads. This should only break code that was using undocumented internal data structures, backwards-compat code exists to handle external RDF parsers.
- Update
rdf-canonize
to dependency with native support.
- Allow empty lists to be compacted to any
@list
container term. Fixes compact-0074 test.
- Remote context retrieval bug.
- BREAKING: Remove
promisify
API.
- BREAKING: Remove top-layer errors.
- BREAKING: Remove deprecated extensions API, including
jsonld.request
.
- Add
expansionMap
andcompactionMap
options. These functions may be provided that will be called when an unmapped value or property will be dropped during expansion or compaction, respectively. The function map return eitherundefined
to cause the default behavior, some other value to use instead of the default expanded/compacted value, or it may throw an error to stop expansion/compaction.
- BREAKING: Remove deprecated
objectify
andprependBase
APIs. Nowobjectify
can be achieved via the@link
option in framing andprependBase
can be found viaurl.prependBase
. - BREAKING: Remove deprecated
namer
option from all public APIs, useissuer
instead. - BREAKING: Last active context used is no longer returned as an optional
parameter to the
compact
callback. - BREAKING: Do not expose deprecated
DocumentCache
.
- BREAKING: Change default canonicalization algorithm to
URDNA2015
.
- Callbackify bugs.
- Document loaders.
- Request queue.
- Handling of exceptions in callbacks.
- Various toRDF tests.
- Move tests from test/ to tests/.
- Run all test-suite tests with promises and callbacks.
- Use Node.js "global" or webpack polyfill.
- Distribute all js files, for real this time.
- Fix
toRDF()
.
- Distribute all js files.
- Generate all js files for Node.js 6.
- Significant code reorganization and splitting into multiple files.
- BREAKING: Explicit IE8 support. Webpack, babel, and/or polyfills may be of help if support is still needed.
- BREAKING: jQuery document loader. Use the XHR loader.
Object.keys
polyfill. Other tools can provide this.
- Handling of "global".
- Distribute browser files.
- Distribute unminified bundle.
- Add .editorconfig support.
fetch-test-suites
and relatedfetch-*-test-suite
NPM scripts.- Support for
@graph
@container
.
- Bower support. Use NPM, a NPM proxy site, or build your own bundle.
- Makefile. Use NPM script targets.
- Update url parser to remove default ports from URLs.
- Skip spec version 1.1 tests.
- BREAKING: Only support Node.js 6.x and later with ES2015 features.
- Build and use custom Node.js 6.x output so async/await/etc can be used.
- BREAKING: Move
js/jsonld.js
tolib/jsonld.js
. - BREAKING: Switch to CommonJS.
- BREAKING: Fixes to allow RFC3986 tests to pass. Some URI edge cases and certain base URIs with dot segments may cause different URI outputs.
- Switch to Karma for browser testing.
- Switch to webpack to build browser bundles.
- Add explicit feature compatibility libs to browser bundles.
- Use async APIs for test generation.
- Done to allow testing in Node.js and browsers.
- Required major testing changes to make everything async.
- Workarounds added to get async generated mocha tests working.
- Improved support for loading various types of tests.
- Can load local files, test manifests, or plain js files (in Node.js).
- Use ES2015 in tests and babel/webpack to support older platforms.
- Use rdf-canonize library, remove local implementation.
- Fix
promises.compact
API when called with only 2 parameters.
- Add optimization for finding best CURIE matches.
- Add optimization for compacting keywords.
- Add optimizations for _compactIri.
- Revert es6-promise dependency to 2.x to avoid auto-polyfill behavior.
- Testing document loader.
- Add
headers
andrequest
option for node doc loader.
- Include local tests.
- N-Quads comments pattern.
- Local tests.
- Document cache in default node document loader is broken; disable until HTTP caching is implemented.
- N-Quads may contain comments.
- Add inputFormat and algorithm options to normalize.
- Add support for normalization test suite.
- Support URDNA2015 normalization algorithm.
- Add async scheduling of normalization algorithms.
- Ignore null values in language maps.
- Ignore jsonld-request and pkginfo for browserify.
- "request" extension moved to jsonld-request. This was done to simplify
the core JSON-LD processing library. In particular, the extension pulled in
RDFa processing code and related dependencies. The old method of using this
extension of
jsonld.use('request')
is deprecated in favor of using the new module directly. - The
jsonld
tool moved to jsonld-cli. This was also done to simplify the core JSON-LD processing library and because it uses the jsonld-request module.
- See git history for changes.