rdflib 2.2.22-1e22b5ce → 2.2.22-2f49e8ef
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/rdflib.min.js +1 -1
- package/dist/rdflib.min.js.map +1 -1
- package/esm/convert.js +60 -0
- package/esm/index.js +2 -1
- package/esm/jsonldparser.js +3 -12
- package/esm/serialize.js +6 -15
- package/lib/convert.d.ts +2 -0
- package/lib/convert.js +71 -0
- package/lib/index.d.ts +2 -1
- package/lib/index.js +4 -1
- package/lib/jsonldparser.js +3 -12
- package/lib/serialize.js +6 -14
- package/package.json +6 -7
- package/src/convert.js +70 -0
- package/src/index.ts +2 -0
- package/src/jsonldparser.js +4 -13
- package/src/serialize.ts +6 -9
package/esm/convert.js
ADDED
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import asyncLib from 'async'; // @@ Goal: remove this dependency
|
|
2
|
+
import jsonld from 'jsonld';
|
|
3
|
+
import { Parser, Writer } from 'n3'; // @@ Goal: remove this dependency
|
|
4
|
+
|
|
5
|
+
export function convertToJson(n3String, jsonCallback) {
|
|
6
|
+
var jsonString;
|
|
7
|
+
var n3Parser = new Parser();
|
|
8
|
+
var n3Writer = new Writer({
|
|
9
|
+
format: 'N-Quads'
|
|
10
|
+
});
|
|
11
|
+
asyncLib.waterfall([function (callback) {
|
|
12
|
+
n3Parser.parse(n3String, function (error, quad, prefixes) {
|
|
13
|
+
if (error) {
|
|
14
|
+
callback(error);
|
|
15
|
+
} else if (quad !== null) {
|
|
16
|
+
n3Writer.addQuad(quad);
|
|
17
|
+
} else {
|
|
18
|
+
n3Writer.end(callback);
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
}, function (result, callback) {
|
|
22
|
+
try {
|
|
23
|
+
jsonld.fromRDF(result, {
|
|
24
|
+
format: 'application/nquads'
|
|
25
|
+
}).then(result => {
|
|
26
|
+
callback(null, result);
|
|
27
|
+
});
|
|
28
|
+
} catch (err) {
|
|
29
|
+
callback(err);
|
|
30
|
+
}
|
|
31
|
+
}, function (json, callback) {
|
|
32
|
+
jsonString = JSON.stringify(json);
|
|
33
|
+
jsonCallback(null, jsonString);
|
|
34
|
+
}], function (err, result) {
|
|
35
|
+
jsonCallback(err, jsonString);
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
export function convertToNQuads(n3String, nquadCallback) {
|
|
39
|
+
var nquadString;
|
|
40
|
+
var n3Parser = new Parser();
|
|
41
|
+
var n3Writer = new Writer({
|
|
42
|
+
format: 'N-Quads'
|
|
43
|
+
});
|
|
44
|
+
asyncLib.waterfall([function (callback) {
|
|
45
|
+
n3Parser.parse(n3String, function (error, triple, prefixes) {
|
|
46
|
+
if (error) {
|
|
47
|
+
callback(error);
|
|
48
|
+
} else if (quad !== null) {
|
|
49
|
+
n3Writer.addQuad(quad);
|
|
50
|
+
} else {
|
|
51
|
+
n3Writer.end(callback);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}, function (result, callback) {
|
|
55
|
+
nquadString = result;
|
|
56
|
+
nquadCallback(null, nquadString);
|
|
57
|
+
}], function (err, result) {
|
|
58
|
+
nquadCallback(err, nquadString);
|
|
59
|
+
});
|
|
60
|
+
}
|
package/esm/index.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
2
|
import BlankNode from './blank-node';
|
|
3
3
|
import Collection from './collection';
|
|
4
|
+
import * as convert from './convert';
|
|
4
5
|
import Empty from './empty';
|
|
5
6
|
import Fetcher from './fetcher';
|
|
6
7
|
import Formula from './formula';
|
|
@@ -56,7 +57,7 @@ const term = Node.fromValue;
|
|
|
56
57
|
// it exports the _current_ value of nextId, which is always 0
|
|
57
58
|
const NextId = BlankNode.nextId;
|
|
58
59
|
export * from './utils/terms';
|
|
59
|
-
export { BlankNode, Collection, DataFactory, Empty, Fetcher, Formula, Store, jsonParser, Literal, log, N3Parser, NamedNode, Namespace, Node, parse, Query, queryToSPARQL, RDFaProcessor, RDFParser, serialize, Serializer, SPARQLToQuery, sparqlUpdateParser, Statement, term, UpdateManager, UpdatesSocket, UpdatesVia, uri, Util, Variable, Store as IndexedFormula,
|
|
60
|
+
export { BlankNode, Collection, convert, DataFactory, Empty, Fetcher, Formula, Store, jsonParser, Literal, log, N3Parser, NamedNode, Namespace, Node, parse, Query, queryToSPARQL, RDFaProcessor, RDFParser, serialize, Serializer, SPARQLToQuery, sparqlUpdateParser, Statement, term, UpdateManager, UpdatesSocket, UpdatesVia, uri, Util, Variable, Store as IndexedFormula,
|
|
60
61
|
// Alias
|
|
61
62
|
|
|
62
63
|
NextId, fromNT, fetcher, graph, lit, st, namedNode as sym,
|
package/esm/jsonldparser.js
CHANGED
|
@@ -18,7 +18,7 @@ export function jsonldObjectToTerm(kb, obj) {
|
|
|
18
18
|
return listToStatements(kb, obj);
|
|
19
19
|
}
|
|
20
20
|
if (Object.prototype.hasOwnProperty.call(obj, '@id')) {
|
|
21
|
-
return
|
|
21
|
+
return kb.rdfFactory.namedNode(obj['@id']);
|
|
22
22
|
}
|
|
23
23
|
if (Object.prototype.hasOwnProperty.call(obj, '@language')) {
|
|
24
24
|
return kb.rdfFactory.literal(obj['@value'], obj['@language']);
|
|
@@ -36,7 +36,7 @@ export function jsonldObjectToTerm(kb, obj) {
|
|
|
36
36
|
* Adds the statements in a json-ld list object to {kb}.
|
|
37
37
|
*/
|
|
38
38
|
function listToStatements(kb, obj) {
|
|
39
|
-
const listId = obj['@id'] ?
|
|
39
|
+
const listId = obj['@id'] ? kb.rdfFactory.namedNode(obj['@id']) : kb.rdfFactory.blankNode();
|
|
40
40
|
const items = obj['@list'].map(listItem => jsonldObjectToTerm(kb, listItem));
|
|
41
41
|
const statements = arrayToStatements(kb.rdfFactory, listId, items);
|
|
42
42
|
kb.addAll(statements);
|
|
@@ -63,17 +63,8 @@ export default function jsonldParser(str, kb, base, callback) {
|
|
|
63
63
|
return kb;
|
|
64
64
|
}, kb)).then(callback).catch(callback);
|
|
65
65
|
}
|
|
66
|
-
function nodeType(kb, obj) {
|
|
67
|
-
if (obj['@id'].startsWith('_:')) {
|
|
68
|
-
// This object is a Blank Node.. pass the id without the preceding _:
|
|
69
|
-
return kb.rdfFactory.blankNode(obj['@id'].substring(2));
|
|
70
|
-
} else {
|
|
71
|
-
// This object is a Named Node
|
|
72
|
-
return kb.rdfFactory.namedNode(obj['@id']);
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
66
|
function processResource(kb, base, flatResource) {
|
|
76
|
-
const id = flatResource['@id'] ?
|
|
67
|
+
const id = flatResource['@id'] ? kb.rdfFactory.namedNode(flatResource['@id']) : kb.rdfFactory.blankNode();
|
|
77
68
|
for (const property of Object.keys(flatResource)) {
|
|
78
69
|
if (property === '@id') {
|
|
79
70
|
continue;
|
package/esm/serialize.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
+
import * as convert from './convert';
|
|
1
2
|
import Serializer from './serializer';
|
|
2
3
|
import { JSONLDContentType, N3ContentType, N3LegacyContentType, NQuadsAltContentType, NQuadsContentType, NTriplesContentType, RDFXMLContentType, TurtleContentType, TurtleLegacyContentType } from './types';
|
|
3
|
-
import * as jsonld from 'jsonld';
|
|
4
|
-
|
|
5
4
|
/**
|
|
6
5
|
* Serialize to the appropriate format
|
|
7
6
|
*/
|
|
@@ -54,13 +53,17 @@ contentType, callback, options) {
|
|
|
54
53
|
sz.setFlags('deinprstux'); // Use adapters to connect to incmpatible parser
|
|
55
54
|
n3String = sz.statementsToNTriples(newSts);
|
|
56
55
|
// n3String = sz.statementsToN3(newSts)
|
|
57
|
-
|
|
56
|
+
convert.convertToJson(n3String, callback);
|
|
57
|
+
break;
|
|
58
58
|
case NQuadsContentType:
|
|
59
59
|
case NQuadsAltContentType:
|
|
60
60
|
// @@@ just outpout the quads? Does not work for collections
|
|
61
61
|
sz.setFlags('deinprstux q'); // Suppress nice parts of N3 to make ntriples
|
|
62
62
|
documentString = sz.statementsToNTriples(newSts); // q in flag means actually quads
|
|
63
63
|
return executeCallback(null, documentString);
|
|
64
|
+
// n3String = sz.statementsToN3(newSts)
|
|
65
|
+
// documentString = convert.convertToNQuads(n3String, callback)
|
|
66
|
+
// break
|
|
64
67
|
default:
|
|
65
68
|
throw new Error('Serialize: Content-type ' + contentType + ' not supported for data write.');
|
|
66
69
|
}
|
|
@@ -80,16 +83,4 @@ contentType, callback, options) {
|
|
|
80
83
|
return result;
|
|
81
84
|
}
|
|
82
85
|
}
|
|
83
|
-
function toJsonld(item) {
|
|
84
|
-
try {
|
|
85
|
-
return jsonld.fromRDF(item, {
|
|
86
|
-
format: 'application/n-quads'
|
|
87
|
-
}).then(docJsonld => {
|
|
88
|
-
return JSON.stringify(docJsonld);
|
|
89
|
-
});
|
|
90
|
-
// return JSON.stringify(await jsonld.fromRDF(item, {format: 'application/n-quads'}))
|
|
91
|
-
} catch (e) {
|
|
92
|
-
throw e;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
86
|
}
|
package/lib/convert.d.ts
ADDED
package/lib/convert.js
ADDED
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.convertToJson = convertToJson;
|
|
8
|
+
exports.convertToNQuads = convertToNQuads;
|
|
9
|
+
var _async = _interopRequireDefault(require("async"));
|
|
10
|
+
var _jsonld = _interopRequireDefault(require("jsonld"));
|
|
11
|
+
var _n = require("n3");
|
|
12
|
+
// @@ Goal: remove this dependency
|
|
13
|
+
|
|
14
|
+
// @@ Goal: remove this dependency
|
|
15
|
+
|
|
16
|
+
function convertToJson(n3String, jsonCallback) {
|
|
17
|
+
var jsonString;
|
|
18
|
+
var n3Parser = new _n.Parser();
|
|
19
|
+
var n3Writer = new _n.Writer({
|
|
20
|
+
format: 'N-Quads'
|
|
21
|
+
});
|
|
22
|
+
_async.default.waterfall([function (callback) {
|
|
23
|
+
n3Parser.parse(n3String, function (error, quad, prefixes) {
|
|
24
|
+
if (error) {
|
|
25
|
+
callback(error);
|
|
26
|
+
} else if (quad !== null) {
|
|
27
|
+
n3Writer.addQuad(quad);
|
|
28
|
+
} else {
|
|
29
|
+
n3Writer.end(callback);
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
}, function (result, callback) {
|
|
33
|
+
try {
|
|
34
|
+
_jsonld.default.fromRDF(result, {
|
|
35
|
+
format: 'application/nquads'
|
|
36
|
+
}).then(result => {
|
|
37
|
+
callback(null, result);
|
|
38
|
+
});
|
|
39
|
+
} catch (err) {
|
|
40
|
+
callback(err);
|
|
41
|
+
}
|
|
42
|
+
}, function (json, callback) {
|
|
43
|
+
jsonString = JSON.stringify(json);
|
|
44
|
+
jsonCallback(null, jsonString);
|
|
45
|
+
}], function (err, result) {
|
|
46
|
+
jsonCallback(err, jsonString);
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
function convertToNQuads(n3String, nquadCallback) {
|
|
50
|
+
var nquadString;
|
|
51
|
+
var n3Parser = new _n.Parser();
|
|
52
|
+
var n3Writer = new _n.Writer({
|
|
53
|
+
format: 'N-Quads'
|
|
54
|
+
});
|
|
55
|
+
_async.default.waterfall([function (callback) {
|
|
56
|
+
n3Parser.parse(n3String, function (error, triple, prefixes) {
|
|
57
|
+
if (error) {
|
|
58
|
+
callback(error);
|
|
59
|
+
} else if (quad !== null) {
|
|
60
|
+
n3Writer.addQuad(quad);
|
|
61
|
+
} else {
|
|
62
|
+
n3Writer.end(callback);
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
}, function (result, callback) {
|
|
66
|
+
nquadString = result;
|
|
67
|
+
nquadCallback(null, nquadString);
|
|
68
|
+
}], function (err, result) {
|
|
69
|
+
nquadCallback(err, nquadString);
|
|
70
|
+
});
|
|
71
|
+
}
|
package/lib/index.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import BlankNode from './blank-node';
|
|
2
2
|
import Collection from './collection';
|
|
3
|
+
import * as convert from './convert';
|
|
3
4
|
import Empty from './empty';
|
|
4
5
|
import Fetcher from './fetcher';
|
|
5
6
|
import Formula from './formula';
|
|
@@ -34,7 +35,7 @@ declare const term: <T extends import("./types").FromValueReturns<any>>(value: i
|
|
|
34
35
|
declare const NextId: number;
|
|
35
36
|
export * from './utils/terms';
|
|
36
37
|
export type { AutoInitOptions, ExtendedResponse, FetchError } from './fetcher';
|
|
37
|
-
export { BlankNode, Collection, DataFactory, Empty, Fetcher, Formula, Store, jsonParser, Literal, log, N3Parser, NamedNode, Namespace, Node, parse, Query, queryToSPARQL, RDFaProcessor, RDFParser, serialize, Serializer, SPARQLToQuery, sparqlUpdateParser, Statement, term, UpdateManager, UpdatesSocket, UpdatesVia, uri, Util, Variable, Store as IndexedFormula, // Alias
|
|
38
|
+
export { BlankNode, Collection, convert, DataFactory, Empty, Fetcher, Formula, Store, jsonParser, Literal, log, N3Parser, NamedNode, Namespace, Node, parse, Query, queryToSPARQL, RDFaProcessor, RDFParser, serialize, Serializer, SPARQLToQuery, sparqlUpdateParser, Statement, term, UpdateManager, UpdatesSocket, UpdatesVia, uri, Util, Variable, Store as IndexedFormula, // Alias
|
|
38
39
|
NextId, fromNT, fetcher, graph, lit, st, namedNode as sym, blankNode, defaultGraph, literal, namedNode, quad, triple, variable, };
|
|
39
40
|
export { termValue } from './utils/termValue';
|
|
40
41
|
export declare class ConnectedStore extends Store {
|
package/lib/index.js
CHANGED
|
@@ -24,6 +24,7 @@ var _exportNames = {
|
|
|
24
24
|
LiveStore: true,
|
|
25
25
|
BlankNode: true,
|
|
26
26
|
Collection: true,
|
|
27
|
+
convert: true,
|
|
27
28
|
Empty: true,
|
|
28
29
|
Fetcher: true,
|
|
29
30
|
Formula: true,
|
|
@@ -197,7 +198,7 @@ Object.defineProperty(exports, "Variable", {
|
|
|
197
198
|
return _variable.default;
|
|
198
199
|
}
|
|
199
200
|
});
|
|
200
|
-
exports.graph = exports.fromNT = exports.fetcher = exports.defaultGraph = exports.blankNode = void 0;
|
|
201
|
+
exports.graph = exports.fromNT = exports.fetcher = exports.defaultGraph = exports.convert = exports.blankNode = void 0;
|
|
201
202
|
Object.defineProperty(exports, "jsonParser", {
|
|
202
203
|
enumerable: true,
|
|
203
204
|
get: function () {
|
|
@@ -248,6 +249,8 @@ exports.variable = exports.uri = exports.triple = void 0;
|
|
|
248
249
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
249
250
|
var _blankNode = _interopRequireDefault(require("./blank-node"));
|
|
250
251
|
var _collection = _interopRequireDefault(require("./collection"));
|
|
252
|
+
var convert = _interopRequireWildcard(require("./convert"));
|
|
253
|
+
exports.convert = convert;
|
|
251
254
|
var _empty = _interopRequireDefault(require("./empty"));
|
|
252
255
|
var _fetcher = _interopRequireDefault(require("./fetcher"));
|
|
253
256
|
var _formula = _interopRequireDefault(require("./formula"));
|
package/lib/jsonldparser.js
CHANGED
|
@@ -25,7 +25,7 @@ function jsonldObjectToTerm(kb, obj) {
|
|
|
25
25
|
return listToStatements(kb, obj);
|
|
26
26
|
}
|
|
27
27
|
if (Object.prototype.hasOwnProperty.call(obj, '@id')) {
|
|
28
|
-
return
|
|
28
|
+
return kb.rdfFactory.namedNode(obj['@id']);
|
|
29
29
|
}
|
|
30
30
|
if (Object.prototype.hasOwnProperty.call(obj, '@language')) {
|
|
31
31
|
return kb.rdfFactory.literal(obj['@value'], obj['@language']);
|
|
@@ -43,7 +43,7 @@ function jsonldObjectToTerm(kb, obj) {
|
|
|
43
43
|
* Adds the statements in a json-ld list object to {kb}.
|
|
44
44
|
*/
|
|
45
45
|
function listToStatements(kb, obj) {
|
|
46
|
-
const listId = obj['@id'] ?
|
|
46
|
+
const listId = obj['@id'] ? kb.rdfFactory.namedNode(obj['@id']) : kb.rdfFactory.blankNode();
|
|
47
47
|
const items = obj['@list'].map(listItem => jsonldObjectToTerm(kb, listItem));
|
|
48
48
|
const statements = (0, _utils.arrayToStatements)(kb.rdfFactory, listId, items);
|
|
49
49
|
kb.addAll(statements);
|
|
@@ -70,17 +70,8 @@ function jsonldParser(str, kb, base, callback) {
|
|
|
70
70
|
return kb;
|
|
71
71
|
}, kb)).then(callback).catch(callback);
|
|
72
72
|
}
|
|
73
|
-
function nodeType(kb, obj) {
|
|
74
|
-
if (obj['@id'].startsWith('_:')) {
|
|
75
|
-
// This object is a Blank Node.. pass the id without the preceding _:
|
|
76
|
-
return kb.rdfFactory.blankNode(obj['@id'].substring(2));
|
|
77
|
-
} else {
|
|
78
|
-
// This object is a Named Node
|
|
79
|
-
return kb.rdfFactory.namedNode(obj['@id']);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
73
|
function processResource(kb, base, flatResource) {
|
|
83
|
-
const id = flatResource['@id'] ?
|
|
74
|
+
const id = flatResource['@id'] ? kb.rdfFactory.namedNode(flatResource['@id']) : kb.rdfFactory.blankNode();
|
|
84
75
|
for (const property of Object.keys(flatResource)) {
|
|
85
76
|
if (property === '@id') {
|
|
86
77
|
continue;
|
package/lib/serialize.js
CHANGED
|
@@ -5,9 +5,9 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
7
|
exports.default = serialize;
|
|
8
|
+
var convert = _interopRequireWildcard(require("./convert"));
|
|
8
9
|
var _serializer = _interopRequireDefault(require("./serializer"));
|
|
9
10
|
var _types = require("./types");
|
|
10
|
-
var jsonld = _interopRequireWildcard(require("jsonld"));
|
|
11
11
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
12
12
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
13
13
|
/**
|
|
@@ -62,13 +62,17 @@ contentType, callback, options) {
|
|
|
62
62
|
sz.setFlags('deinprstux'); // Use adapters to connect to incmpatible parser
|
|
63
63
|
n3String = sz.statementsToNTriples(newSts);
|
|
64
64
|
// n3String = sz.statementsToN3(newSts)
|
|
65
|
-
|
|
65
|
+
convert.convertToJson(n3String, callback);
|
|
66
|
+
break;
|
|
66
67
|
case _types.NQuadsContentType:
|
|
67
68
|
case _types.NQuadsAltContentType:
|
|
68
69
|
// @@@ just outpout the quads? Does not work for collections
|
|
69
70
|
sz.setFlags('deinprstux q'); // Suppress nice parts of N3 to make ntriples
|
|
70
71
|
documentString = sz.statementsToNTriples(newSts); // q in flag means actually quads
|
|
71
72
|
return executeCallback(null, documentString);
|
|
73
|
+
// n3String = sz.statementsToN3(newSts)
|
|
74
|
+
// documentString = convert.convertToNQuads(n3String, callback)
|
|
75
|
+
// break
|
|
72
76
|
default:
|
|
73
77
|
throw new Error('Serialize: Content-type ' + contentType + ' not supported for data write.');
|
|
74
78
|
}
|
|
@@ -88,16 +92,4 @@ contentType, callback, options) {
|
|
|
88
92
|
return result;
|
|
89
93
|
}
|
|
90
94
|
}
|
|
91
|
-
function toJsonld(item) {
|
|
92
|
-
try {
|
|
93
|
-
return jsonld.fromRDF(item, {
|
|
94
|
-
format: 'application/n-quads'
|
|
95
|
-
}).then(docJsonld => {
|
|
96
|
-
return JSON.stringify(docJsonld);
|
|
97
|
-
});
|
|
98
|
-
// return JSON.stringify(await jsonld.fromRDF(item, {format: 'application/n-quads'}))
|
|
99
|
-
} catch (e) {
|
|
100
|
-
throw e;
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
95
|
}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "rdflib",
|
|
3
3
|
"description": "an RDF library for node.js. Suitable for client and server side.",
|
|
4
|
-
"version": "2.2.22-
|
|
4
|
+
"version": "2.2.22-2f49e8ef",
|
|
5
5
|
"private": false,
|
|
6
6
|
"browserslist": [
|
|
7
7
|
"> 0.5%"
|
|
@@ -46,6 +46,7 @@
|
|
|
46
46
|
"dependencies": {
|
|
47
47
|
"@babel/runtime": "^7.20.1",
|
|
48
48
|
"@xmldom/xmldom": "^0.8.6",
|
|
49
|
+
"async": "^3.2.4",
|
|
49
50
|
"cross-fetch": "^3.1.5",
|
|
50
51
|
"jsonld": "^8.1.0",
|
|
51
52
|
"n3": "^1.16.3",
|
|
@@ -91,15 +92,14 @@
|
|
|
91
92
|
"build:esm": "babel src --extensions \".ts,.js\" --env-name esm -d esm",
|
|
92
93
|
"build:browser": "webpack --progress",
|
|
93
94
|
"build:types": "tsc --emitDeclarationOnly -d --moduleResolution node --declarationDir lib",
|
|
94
|
-
"build:all": "npm run build && npm run build:types && npm run build:browser && npm run build:esm ",
|
|
95
95
|
"doc": "typedoc --out ./doc ./src/index.ts --excludePrivate --excludeInternal --tsconfig ./tsconfig.json",
|
|
96
|
-
"ignore:prepublishOnly": "npm ci && npm run build:
|
|
96
|
+
"ignore:prepublishOnly": "npm ci && npm run build && npm run build:types && npm run build:browser && npm run build:esm",
|
|
97
97
|
"postversion": "git push --follow-tags",
|
|
98
98
|
"start": "webpack serve --port 4800",
|
|
99
99
|
"test": "npm run test:unit && npm run test:serialize && npm run test:types",
|
|
100
100
|
"test:clean": "rimraf tests/serialize/,*",
|
|
101
101
|
"test:serialize": "npm run build && npm run test:serialize:all && npm run test:clean",
|
|
102
|
-
"test:serialize:all": "npm run test:serialize:
|
|
102
|
+
"test:serialize:all": "npm run test:serialize:1 && npm run test:serialize:2 && npm run test:serialize:3 && npm run test:serialize:4 && npm run test:serialize:5 && npm run test:serialize:6 && npm run test:serialize:7 && npm run test:serialize:10 && npm run test:serialize:11 && npm run test:serialize:12 && npm run test:serialize:13 && npm run test:serialize:14 && npm run test:serialize:15",
|
|
103
103
|
"test:serialize:1": "cd ./tests/serialize && node ./data.js -in=t1.ttl -format=application/rdf+xml -out=,t1.xml && fs-grep http://www.w3.org/2001/XMLSchema#integer ,t1.xml",
|
|
104
104
|
"test:serialize:2": "cd ./tests/serialize && node ./data.js -in=t2.ttl -format=application/rdf+xml -out=,t2.xml && node diff ,t2.xml t2-ref.xml",
|
|
105
105
|
"test:serialize:3": "cd ./tests/serialize && node ./data.js -in=t3.ttl -format=application/rdf+xml -out=,t3.xml && node diff ,t3.xml t3-ref.xml",
|
|
@@ -107,15 +107,14 @@
|
|
|
107
107
|
"test:serialize:5": "cd ./tests/serialize && node ./data.js -in=t5.n3 -format=text/turtle -out=,t5.ttl && node diff ,t5.ttl t5-ref.ttl",
|
|
108
108
|
"test:serialize:6": "cd ./tests/serialize && node ./data.js -in=t5.n3 -format=text/n3 -out=,t6.n3 && node diff ,t6.n3 t6-ref.n3",
|
|
109
109
|
"test:serialize:7": "cd ./tests/serialize && node ./data.js -in=t7.n3 -format=application/n-triples -out=,t7.nt && node diff ,t7.nt t7-ref.nt",
|
|
110
|
-
"test:serialize:8": "cd ./tests/serialize && node ./data.js -in=t5.n3 -format=application/n-quads -
|
|
111
|
-
"test:serialize:9": "cd ./tests/serialize && node ./data.js -in=t7.n3 -format=application/ld+json -out=,t9.
|
|
110
|
+
"test:serialize:8": "cd ./tests/serialize && node ./data.js -in=t5.n3 -format=application/n-quads -dump=,t8.nq && node diff ,t8.nq t8-ref.nq",
|
|
111
|
+
"test:serialize:9": "cd ./tests/serialize && node ./data.js -in=t7.n3 -format=application/ld+json -out=,t9.json && node diff ,t9.json t9-ref.json",
|
|
112
112
|
"test:serialize:10": "cd ./tests/serialize && node ./data.js -in=details.ttl -format=text/turtle -out=,t10.ttl && node diff ,t10.ttl t10-ref.ttl",
|
|
113
113
|
"test:serialize:11": "cd ./tests/serialize && node ./data.js -in=structures.n3 -format=application/rdf+xml -out=,structures.xml && node diff ,structures.xml t11-ref.xml",
|
|
114
114
|
"test:serialize:12": "cd ./tests/serialize && node ./data.js -in=structures.n3 -format=text/turtle -out=,structures.ttl && node diff ,structures.ttl t12-ref.ttl",
|
|
115
115
|
"test:serialize:13": "cd ./tests/serialize && node ./data.js -in=structures.n3 -format=application/n-triples -out=,structures.nt && node ./data.js -format=application/n-triples -in=,structures.nt -format=text/turtle -out=,structures.nt.ttl && node diff ,structures.nt.ttl t13-ref.ttl",
|
|
116
116
|
"test:serialize:14": "cd ./tests/serialize && node ./data.js -in=t14.html -format=text/turtle -out=,t14.ttl && node diff ,t14.ttl t14-ref.ttl",
|
|
117
117
|
"test:serialize:15": "cd ./tests/serialize && node ./data.js -in=t15.html -format=text/turtle -out=,t15.ttl && node diff ,t15.ttl t15-ref.ttl",
|
|
118
|
-
"test:serialize:16": "cd ./tests/serialize && node ./data.js -in=t1.ttl -format=application/ld+json -out=,t1.jsonld && node diff ,t1.jsonld t16-ref.jsonld",
|
|
119
118
|
"test:types": "tsc --noEmit --target es2019 --moduleResolution node tests/types/*.ts",
|
|
120
119
|
"test:unit": "mocha --growl --require ./tests/babel-register.js tests/unit/**-test.*",
|
|
121
120
|
"test:unit:egp": "mocha --require ./tests/babel-register.js tests/unit/fetcher-egp-test.js",
|
package/src/convert.js
ADDED
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import asyncLib from 'async' // @@ Goal: remove this dependency
|
|
2
|
+
import jsonld from 'jsonld'
|
|
3
|
+
import { Parser, Writer } from 'n3' // @@ Goal: remove this dependency
|
|
4
|
+
|
|
5
|
+
export function convertToJson (n3String, jsonCallback) {
|
|
6
|
+
var jsonString
|
|
7
|
+
var n3Parser = new Parser()
|
|
8
|
+
var n3Writer = new Writer({
|
|
9
|
+
format: 'N-Quads'
|
|
10
|
+
})
|
|
11
|
+
asyncLib.waterfall([
|
|
12
|
+
function (callback) {
|
|
13
|
+
n3Parser.parse(n3String, function (error, quad, prefixes) {
|
|
14
|
+
if (error) {
|
|
15
|
+
callback(error);
|
|
16
|
+
} else if (quad !== null) {
|
|
17
|
+
n3Writer.addQuad(quad);
|
|
18
|
+
} else {
|
|
19
|
+
n3Writer.end(callback);
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
},
|
|
23
|
+
function (result, callback) {
|
|
24
|
+
try {
|
|
25
|
+
jsonld.fromRDF(result, {
|
|
26
|
+
format: 'application/nquads'
|
|
27
|
+
}).then((result) => {
|
|
28
|
+
callback(null, result)
|
|
29
|
+
})
|
|
30
|
+
} catch (err) {
|
|
31
|
+
callback(err)
|
|
32
|
+
}
|
|
33
|
+
},
|
|
34
|
+
function (json, callback) {
|
|
35
|
+
jsonString = JSON.stringify(json)
|
|
36
|
+
jsonCallback(null, jsonString)
|
|
37
|
+
}
|
|
38
|
+
], function (err, result) {
|
|
39
|
+
jsonCallback(err, jsonString)
|
|
40
|
+
}
|
|
41
|
+
)
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export function convertToNQuads (n3String, nquadCallback) {
|
|
45
|
+
var nquadString
|
|
46
|
+
var n3Parser = new Parser()
|
|
47
|
+
var n3Writer = new Writer({
|
|
48
|
+
format: 'N-Quads'
|
|
49
|
+
})
|
|
50
|
+
asyncLib.waterfall([
|
|
51
|
+
function (callback) {
|
|
52
|
+
n3Parser.parse(n3String, function (error, triple, prefixes) {
|
|
53
|
+
if (error) {
|
|
54
|
+
callback(error);
|
|
55
|
+
} else if (quad !== null) {
|
|
56
|
+
n3Writer.addQuad(quad);
|
|
57
|
+
} else {
|
|
58
|
+
n3Writer.end(callback);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
},
|
|
62
|
+
function (result, callback) {
|
|
63
|
+
nquadString = result
|
|
64
|
+
nquadCallback(null, nquadString)
|
|
65
|
+
}
|
|
66
|
+
], function (err, result) {
|
|
67
|
+
nquadCallback(err, nquadString)
|
|
68
|
+
}
|
|
69
|
+
)
|
|
70
|
+
}
|
package/src/index.ts
CHANGED
|
@@ -2,6 +2,7 @@ import { IRDFlibDataFactory } from './types'
|
|
|
2
2
|
|
|
3
3
|
import BlankNode from './blank-node'
|
|
4
4
|
import Collection from './collection'
|
|
5
|
+
import * as convert from './convert'
|
|
5
6
|
import Empty from './empty'
|
|
6
7
|
import Fetcher from './fetcher'
|
|
7
8
|
import Formula from './formula'
|
|
@@ -65,6 +66,7 @@ export type { AutoInitOptions, ExtendedResponse, FetchError } from './fetcher'
|
|
|
65
66
|
export {
|
|
66
67
|
BlankNode,
|
|
67
68
|
Collection,
|
|
69
|
+
convert,
|
|
68
70
|
DataFactory,
|
|
69
71
|
Empty,
|
|
70
72
|
Fetcher,
|
package/src/jsonldparser.js
CHANGED
|
@@ -22,7 +22,7 @@ export function jsonldObjectToTerm (kb, obj) {
|
|
|
22
22
|
}
|
|
23
23
|
|
|
24
24
|
if (Object.prototype.hasOwnProperty.call(obj, '@id')) {
|
|
25
|
-
return
|
|
25
|
+
return kb.rdfFactory.namedNode(obj['@id'])
|
|
26
26
|
}
|
|
27
27
|
|
|
28
28
|
if (Object.prototype.hasOwnProperty.call(obj, '@language')) {
|
|
@@ -44,7 +44,7 @@ export function jsonldObjectToTerm (kb, obj) {
|
|
|
44
44
|
* Adds the statements in a json-ld list object to {kb}.
|
|
45
45
|
*/
|
|
46
46
|
function listToStatements (kb, obj) {
|
|
47
|
-
const listId = obj['@id'] ?
|
|
47
|
+
const listId = obj['@id'] ? kb.rdfFactory.namedNode(obj['@id']) : kb.rdfFactory.blankNode()
|
|
48
48
|
|
|
49
49
|
const items = obj['@list'].map((listItem => jsonldObjectToTerm(kb, listItem)))
|
|
50
50
|
const statements = arrayToStatements(kb.rdfFactory, listId, items)
|
|
@@ -82,19 +82,10 @@ export default function jsonldParser (str, kb, base, callback) {
|
|
|
82
82
|
.catch(callback)
|
|
83
83
|
}
|
|
84
84
|
|
|
85
|
-
function nodeType (kb, obj) {
|
|
86
|
-
if (obj['@id'].startsWith('_:')) {
|
|
87
|
-
// This object is a Blank Node.. pass the id without the preceding _:
|
|
88
|
-
return kb.rdfFactory.blankNode(obj['@id'].substring(2));
|
|
89
|
-
} else {
|
|
90
|
-
// This object is a Named Node
|
|
91
|
-
return kb.rdfFactory.namedNode(obj['@id']);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
85
|
|
|
95
86
|
function processResource(kb, base, flatResource) {
|
|
96
87
|
const id = flatResource['@id']
|
|
97
|
-
?
|
|
88
|
+
? kb.rdfFactory.namedNode(flatResource['@id'])
|
|
98
89
|
: kb.rdfFactory.blankNode()
|
|
99
90
|
|
|
100
91
|
for (const property of Object.keys(flatResource)) {
|
|
@@ -145,4 +136,4 @@ function createStatement(kb, id, property, value, base) {
|
|
|
145
136
|
object = jsonldObjectToTerm(kb, value)
|
|
146
137
|
}
|
|
147
138
|
return kb.rdfFactory.quad(id, predicate, object, kb.rdfFactory.namedNode(base))
|
|
148
|
-
}
|
|
139
|
+
}
|
package/src/serialize.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import * as convert from './convert'
|
|
1
2
|
import Formula from './formula'
|
|
2
3
|
import Serializer from './serializer'
|
|
3
4
|
import {
|
|
@@ -14,7 +15,6 @@ import {
|
|
|
14
15
|
} from './types'
|
|
15
16
|
import IndexedFormula from './store'
|
|
16
17
|
import { BlankNode, NamedNode } from './tf-types'
|
|
17
|
-
import * as jsonld from 'jsonld'
|
|
18
18
|
|
|
19
19
|
/**
|
|
20
20
|
* Serialize to the appropriate format
|
|
@@ -85,12 +85,16 @@ export default function serialize (
|
|
|
85
85
|
sz.setFlags('deinprstux') // Use adapters to connect to incmpatible parser
|
|
86
86
|
n3String = sz.statementsToNTriples(newSts)
|
|
87
87
|
// n3String = sz.statementsToN3(newSts)
|
|
88
|
-
|
|
88
|
+
convert.convertToJson(n3String, callback)
|
|
89
|
+
break
|
|
89
90
|
case NQuadsContentType:
|
|
90
91
|
case NQuadsAltContentType: // @@@ just outpout the quads? Does not work for collections
|
|
91
92
|
sz.setFlags('deinprstux q') // Suppress nice parts of N3 to make ntriples
|
|
92
93
|
documentString = sz.statementsToNTriples(newSts) // q in flag means actually quads
|
|
93
94
|
return executeCallback(null, documentString)
|
|
95
|
+
// n3String = sz.statementsToN3(newSts)
|
|
96
|
+
// documentString = convert.convertToNQuads(n3String, callback)
|
|
97
|
+
// break
|
|
94
98
|
default:
|
|
95
99
|
throw new Error('Serialize: Content-type ' + contentType + ' not supported for data write.')
|
|
96
100
|
}
|
|
@@ -110,11 +114,4 @@ export default function serialize (
|
|
|
110
114
|
return result as string
|
|
111
115
|
}
|
|
112
116
|
}
|
|
113
|
-
|
|
114
|
-
function toJsonld (item ) {
|
|
115
|
-
try {
|
|
116
|
-
return jsonld.fromRDF(item, {format: 'application/n-quads'}).then( docJsonld => { return JSON.stringify(docJsonld) })
|
|
117
|
-
// return JSON.stringify(await jsonld.fromRDF(item, {format: 'application/n-quads'}))
|
|
118
|
-
} catch (e) { throw e }
|
|
119
|
-
}
|
|
120
117
|
}
|