Skip to content
Draft
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions lib/pyld/jsonld.py
Original file line number Diff line number Diff line change
Expand Up @@ -498,7 +498,7 @@ def compact(self, input_, ctx, options):
options.setdefault('extractAllScripts', False)
options.setdefault('processingMode', 'json-ld-1.1')
options.setdefault('link', False)
if options['link']:
if isinstance(options['link'], dict):
# force skip expansion when linking, "link" is not part of the
# public API, it should only be called from framing
options['skipExpansion'] = True
Expand Down Expand Up @@ -1589,7 +1589,7 @@ def _compact(self, active_ctx, active_property, element, options):

# recursively compact object
if _is_object(element):
if(options['link'] and '@id' in element and
if(isinstance(options['link'], dict) and '@id' in element and
element['@id'] in options['link']):
# check for a linked element to reuse
linked = options['link'][element['@id']]
Expand All @@ -1601,7 +1601,7 @@ def _compact(self, active_ctx, active_property, element, options):
if _is_value(element) or _is_subject_reference(element):
rval = self._compact_value(
active_ctx, active_property, element, options)
if options['link'] and _is_subject_reference(element):
if isinstance(options['link'], dict) and _is_subject_reference(element):
# store linked element
options['link'].setdefault(element['@id'], []).append(
{'expanded': element, 'compacted': rval})
Expand Down Expand Up @@ -1637,7 +1637,7 @@ def _compact(self, active_ctx, active_property, element, options):
propagate=True,
override_protected=True)

if options['link'] and '@id' in element:
if isinstance(options['link'], dict) and '@id' in element:
# store linked element
options['link'].setdefault(element['@id'], []).append(
{'expanded': element, 'compacted': rval})
Expand Down
Loading