rdflib
Version:
an RDF library for node.js. Suitable for client and server side.
111 lines (105 loc) • 3.71 kB
text/typescript
import Formula from './formula'
import Serializer from './serializer'
import {
ContentType,
JSONLDContentType,
N3ContentType,
N3LegacyContentType,
NQuadsAltContentType,
NQuadsContentType,
NTriplesContentType,
RDFXMLContentType,
TurtleContentType,
TurtleLegacyContentType,
} from './types'
import IndexedFormula from './store'
import { BlankNode, NamedNode } from './tf-types'
/**
* Serialize to the appropriate format
*/
export default function serialize (
/** The graph or nodes that should be serialized */
target: Formula | NamedNode | BlankNode | null,
/** The store */
kb: Formula,
base?: unknown,
/**
* The mime type.
* Defaults to Turtle.
*/
contentType?: string | ContentType,
callback?: (err: Error | undefined | null, result?: string) => any,
options?: {
/**
* A string of letters, each of which set an options
* e.g. `deinprstux`
*/
flags?: string,
/**
* A set of [prefix, uri] pairs that define namespace prefixes
*/
namespaces?: Record<string, string>
}
): string | undefined {
base = base || target?.value
const opts = options || {}
contentType = contentType || TurtleContentType // text/n3 if complex?
var documentString: string | undefined = undefined
try {
var sz = Serializer(kb)
if ((opts as any).flags) sz.setFlags((opts as any).flags)
var newSts = kb!.statementsMatching(undefined, undefined, undefined, target as NamedNode)
// If an IndexedFormula, use the namespaces from the given graph as suggestions
if ('namespaces' in kb) {
sz.suggestNamespaces( (kb as IndexedFormula).namespaces);
}
// use the provided options.namespaces are mandatory prefixes
if (opts.namespaces) {
sz.setNamespaces( opts.namespaces);
}
sz.setBase(base)
switch (contentType) {
case RDFXMLContentType:
documentString = sz.statementsToXML(newSts)
return executeCallback(null, documentString)
case N3ContentType:
case N3LegacyContentType:
documentString = sz.statementsToN3(newSts)
return executeCallback(null, documentString)
case TurtleContentType:
case TurtleLegacyContentType:
sz.setFlags('si') // Suppress = for sameAs and => for implies
documentString = sz.statementsToN3(newSts)
return executeCallback(null, documentString)
case NTriplesContentType:
sz.setFlags('deinprstux') // Suppress nice parts of N3 to make ntriples
documentString = sz.statementsToNTriples(newSts)
return executeCallback(null, documentString)
case JSONLDContentType:
sz.setFlags('si dr') // turtle + dr (means no default, no relative prefix)
documentString = sz.statementsToJsonld(newSts) // convert via turtle
return executeCallback(null, documentString)
case NQuadsContentType:
case NQuadsAltContentType: // @@@ just outpout the quads? Does not work for collections
sz.setFlags('deinprstux q') // Suppress nice parts of N3 to make ntriples
documentString = sz.statementsToNTriples(newSts) // q in flag means actually quads
return executeCallback(null, documentString)
default:
throw new Error('Serialize: Content-type ' + contentType + ' not supported for data write.')
}
} catch (err) {
if (callback) {
// @ts-ignore
return callback(err, undefined)
}
throw err // Don't hide problems from caller in sync mode
}
function executeCallback (err: Error | null | undefined, result: string | undefined): string | undefined {
if (callback) {
callback(err, result)
return
} else {
return result as string
}
}
}