Fix remaining expansion, normalize, compact bugs.

This commit is contained in:
Dave Longley 2012-04-23 15:52:56 -04:00
parent 1b8a833bd1
commit 084727c586

View file

@ -201,15 +201,20 @@ class JsonLdProcessor {
} }
// do compaction // do compaction
$compacted = $this->_compact($active_ctx, null, $input, $options); $compacted = $this->_compact($active_ctx, null, $expanded, $options);
// always use an array if graph options is on // always use an array if graph options is on
if($options['graph'] === true) { if($options['graph'] === true) {
$output = self::arrayify(); $compacted = self::arrayify($compacted);
} }
// else if compacted is an array with 1 entry, remove array // else if compacted is an array with 1 entry, remove array
else if(is_array($output) && count($output) === 1) { else if(is_array($compacted) && count($compacted) === 1) {
$output = $output[0]; $compacted = $compacted[0];
}
// follow @context key
if(is_object($ctx) && property_exists($ctx, '@context')) {
$ctx = $ctx->{'@context'};
} }
// build output context // build output context
@ -239,7 +244,7 @@ class JsonLdProcessor {
$kwgraph = $this->_compactIri($active_ctx, '@graph'); $kwgraph = $this->_compactIri($active_ctx, '@graph');
$graph = $compacted; $graph = $compacted;
$compacted = new stdClass(); $compacted = new stdClass();
if($hasContext) { if($has_context) {
$compacted->{'@context'} = $ctx; $compacted->{'@context'} = $ctx;
} }
$compacted->{$kwgraph} = $graph; $compacted->{$kwgraph} = $graph;
@ -534,15 +539,16 @@ class JsonLdProcessor {
} }
} }
else if(property_exists($subject, $property)) { else if(property_exists($subject, $property)) {
$hasValue = self::hasValue($subject, $property, $value); $has_value = self::hasValue($subject, $property, $value);
// make property an array if value not present or always an array // make property an array if value not present or always an array
if(!is_array($subject->{$property}) && (!$hasValue || $propertyIsArray)) { if(!is_array($subject->{$property}) &&
(!$has_value || $propertyIsArray)) {
$subject->{$property} = array($subject->{$property}); $subject->{$property} = array($subject->{$property});
} }
// add new value // add new value
if(!$hasValue) { if(!$has_value) {
$subject->{$property}[] = $value; $subject->{$property}[] = $value;
} }
} }
@ -875,7 +881,7 @@ class JsonLdProcessor {
} }
// compact property and add value // compact property and add value
$prop = $this->_compactIri(ctx, key); $prop = $this->_compactIri($ctx, $key);
$isArray = (is_array($value) && count($value) === 0); $isArray = (is_array($value) && count($value) === 0);
self::addValue($rval, $prop, $value, $isArray); self::addValue($rval, $prop, $value, $isArray);
continue; continue;
@ -902,7 +908,7 @@ class JsonLdProcessor {
} }
// recursively compact value // recursively compact value
$v = $this->compact($ctx, $prop, $v, $options); $v = $this->_compact($ctx, $prop, $v, $options);
// get container type for property // get container type for property
$container = self::getContextValue($ctx, $prop, '@container'); $container = self::getContextValue($ctx, $prop, '@container');
@ -2348,9 +2354,9 @@ class JsonLdProcessor {
// get context entry for term // get context entry for term
$entry = $ctx->mappings->{$term}; $entry = $ctx->mappings->{$term};
$hasType = property_exists($entry, '@type'); $has_type = property_exists($entry, '@type');
$hasLanguage = property_exists($entry, '@language'); $has_language = property_exists($entry, '@language');
$hasDefaultLanguage = property_exists($ctx, '@language'); $has_default_language = property_exists($ctx, '@language');
// @list rank is the sum of its values' ranks // @list rank is the sum of its values' ranks
if(self::_isListValue($value)) { if(self::_isListValue($value)) {
@ -2371,23 +2377,23 @@ class JsonLdProcessor {
if(is_bool($value)) { if(is_bool($value)) {
$type = self::XSD_BOOLEAN; $type = self::XSD_BOOLEAN;
} }
else if(is_double(value)) { else if(is_double($value)) {
$type = self::XSD_DOUBLE; $type = self::XSD_DOUBLE;
} }
else { else {
$type = self::XSD_INTEGER; $type = self::XSD_INTEGER;
} }
if($entry->{'@type'} === $type) { if($has_type && $entry->{'@type'} === $type) {
return 3; return 3;
} }
return (!$hasType && !$hasLanguage) ? 2 : 1; return (!$has_type && !$has_language) ? 2 : 1;
} }
// rank string (this means the value has no @language) // rank string (this means the value has no @language)
if(is_string($value)) { if(is_string($value)) {
// entry @language is specifically null or no @type, @language, or default // entry @language is specifically null or no @type, @language, or default
if(($hasLanguage && $entry->{'@language'} === null) || if(($has_language && $entry->{'@language'} === null) ||
(!$hasType && !$hasLanguage && !$hasDefaultLanguage)) { (!$has_type && !$has_language && !$has_default_language)) {
return 3; return 3;
} }
return 0; return 0;
@ -2399,27 +2405,27 @@ class JsonLdProcessor {
if(self::_isValue($value)) { if(self::_isValue($value)) {
if(property_exists($value, '@type')) { if(property_exists($value, '@type')) {
// @types match // @types match
if($hasType && $value->{'@type'} === $entry->{'@type'}) { if($has_type && $value->{'@type'} === $entry->{'@type'}) {
return 3; return 3;
} }
return (!$hasType && !$hasLanguage) ? 1 : 0; return (!$has_type && !$has_language) ? 1 : 0;
} }
// @languages match or entry has no @type or @language but default // @languages match or entry has no @type or @language but default
// @language matches // @language matches
if(($hasLanguage && $value->{'@language'} === $entry->{'@language'}) || if(($has_language && $value->{'@language'} === $entry->{'@language'}) ||
(!$hasType && !$hasLanguage && (!$has_type && !$has_language && $has_default_language &&
$value->{'@language'} === $ctx->{'@language'})) { $value->{'@language'} === $ctx->{'@language'})) {
return 3; return 3;
} }
return (!$hasType && !$hasLanguage) ? 1 : 0; return (!$has_type && !$has_language) ? 1 : 0;
} }
// value must be a subject/reference // value must be a subject/reference
if($entry->{'@type'} === '@id') { if($has_type && $entry->{'@type'} === '@id') {
return 3; return 3;
} }
return (!$hasType && !$hasLanguage) ? 1 : 0; return (!$has_type && !$has_language) ? 1 : 0;
} }
/** /**
@ -2461,22 +2467,24 @@ class JsonLdProcessor {
$highest = 0; $highest = 0;
$listContainer = false; $listContainer = false;
$isList = self::_isListValue($value); $isList = self::_isListValue($value);
foreach($ctx->mappings as $term) { foreach($ctx->mappings as $term => $entry) {
$has_container = property_exists($entry, '@container');
// skip terms with non-matching iris // skip terms with non-matching iris
$entry = $ctx->mappings->{$term};
if($entry->{'@id'} !== $iri) { if($entry->{'@id'} !== $iri) {
continue; continue;
} }
// skip @set containers for @lists // skip @set containers for @lists
if($isList && $entry->{'@container'} === '@set') { if($isList && $has_container && $entry->{'@container'} === '@set') {
continue; continue;
} }
// skip @list containers for non-@lists // skip @list containers for non-@lists
if(!$isList && $entry->{'@container'} === '@list') { if(!$isList && $has_container && $entry->{'@container'} === '@list') {
continue; continue;
} }
// for @lists, if listContainer is set, skip non-list containers // for @lists, if listContainer is set, skip non-list containers
if($isList && $listContainer && $entry->{'@container'} !== '@list') { if($isList && $listContainer && (!$has_container ||
$entry->{'@container'} !== '@list')) {
continue; continue;
} }
@ -2484,12 +2492,13 @@ class JsonLdProcessor {
$rank = $this->_rankTerm($ctx, $term, $value); $rank = $this->_rankTerm($ctx, $term, $value);
if($rank > 0) { if($rank > 0) {
// add 1 to rank if container is a @set // add 1 to rank if container is a @set
if($entry->{'@container'} === '@set') { if($has_container && $entry->{'@container'} === '@set') {
$rank += 1; $rank += 1;
} }
// for @lists, give preference to @list containers // for @lists, give preference to @list containers
if($isList && !$listContainer && $entry->{'@container'} === '@list') { if($isList && !$listContainer && $has_container &&
$entry->{'@container'} === '@list') {
$listContainer = true; $listContainer = true;
$terms = array(); $terms = array();
$highest = $rank; $highest = $rank;
@ -3239,7 +3248,7 @@ class JsonLdException extends Exception {
$rval .= 'details: ' . print_r($this->details, true) . "\n"; $rval .= 'details: ' . print_r($this->details, true) . "\n";
} }
if($this->cause) { if($this->cause) {
$rval .= 'cause: ' . $this->cause->toString(); $rval .= 'cause: ' . $this->cause;
} }
$rval .= $this->getTraceAsString() . "\n"; $rval .= $this->getTraceAsString() . "\n";
return $rval; return $rval;