From 5149bf383c55ca1eb958b8f9643cc267452ddd96 Mon Sep 17 00:00:00 2001 From: Dave Longley Date: Sun, 13 May 2012 16:31:11 -0400 Subject: [PATCH] Add escaping to N-Quads. --- jsonld.php | 32 ++++++++++++++++++++------------ 1 file changed, 20 insertions(+), 12 deletions(-) diff --git a/jsonld.php b/jsonld.php index 6b3081b..3d9b004 100644 --- a/jsonld.php +++ b/jsonld.php @@ -903,15 +903,15 @@ class JsonLdProcessor { // parse quad if(!preg_match($quad, $line, $match)) { throw new JsonLdException( - 'Error while parsing N-Quads; invalid quad.', - 'jsonld.ParseError', array('line' => $line_number)); + 'Error while parsing N-Quads; invalid quad.', + 'jsonld.ParseError', array('line' => $line_number)); } // create RDF statement $s = (object)array( - 'subject' => new stdClass(), - 'property' => new stdClass(), - 'object' => new stdClass()); + 'subject' => new stdClass(), + 'property' => new stdClass(), + 'object' => new stdClass()); // get subject if($match[1] !== '') { @@ -936,12 +936,16 @@ class JsonLdProcessor { $s->object->nominalValue = $match[5]; $s->object->interfaceName = 'BlankNode'; } - else { - $s->object->nominalValue = $match[6]; + else { + $unescaped = str_replace( + array('\"', '\t', '\n', '\r', '\\\\'), + array('"', "\t", "\n", "\r", '\\'), + $match[6]); + $s->object->nominalValue = $unescaped; $s->object->interfaceName = 'LiteralNode'; if(isset($match[7]) && $match[7] !== '') { $s->object->datatype = (object)array( - 'nominalValue' => $match[7], 'interfaceName' => 'IRI'); + 'nominalValue' => $match[7], 'interfaceName' => 'IRI'); } else if(isset($match[8]) && $match[8] !== '') { $s->object->language = $match[8]; @@ -951,11 +955,11 @@ class JsonLdProcessor { // get graph if(isset($match[9]) && $match[9] !== '') { $s->name = (object)array( - 'nominalValue' => $match[9], 'interfaceName' => 'IRI'); + 'nominalValue' => $match[9], 'interfaceName' => 'IRI'); } else if(isset($match[10]) && $match[10] !== '') { $s->name = (object)array( - 'nominalValue' => $match[10], 'interfaceName' => 'BlankNode'); + 'nominalValue' => $match[10], 'interfaceName' => 'BlankNode'); } // add statement @@ -1012,8 +1016,12 @@ class JsonLdProcessor { $quad .= $o->nominalValue; } } - else { - $quad .= '"' . $o->nominalValue . '"'; + else { + $escaped = str_replace( + array('\\', "\t", "\n", "\r", '"'), + array('\\\\', '\t', '\n', '\r', '\"'), + $o->nominalValue); + $quad .= '"' . $escaped . '"'; if(property_exists($o, 'datatype')) { $quad .= "^^<{$o->datatype->nominalValue}>"; }