UNPKG

link-rdflib

Version:

an RDF library for node.js, patched for speed.

185 lines (176 loc) 3.99 kB
/* * Implements URI-specific functions * * See RFC 2386 * * See also: * http://www.w3.org/2005/10/ajaw/uri.js * http://www.w3.org/2000/10/swap/uripath.py * */ var alert = alert || console.log module.exports.docpart = docpart module.exports.document = document module.exports.hostpart = hostpart module.exports.join = join module.exports.protocol = protocol module.exports.refTo = refTo const NamedNode = require('./named-node') function docpart (uri) { var i i = uri.indexOf('#') if (i < 0) { return uri } else { return uri.slice(0, i) } } function document (x) { return new NamedNode(docpart(x.uri)) } function hostpart (u) { var m = /[^\/]*\/\/([^\/]*)\//.exec(u) if (m) { return m[1] } else { return '' } } function join (given, base) { var baseColon, baseScheme, baseSingle var colon, lastSlash, path var baseHash = base.indexOf('#') if (baseHash > 0) { base = base.slice(0, baseHash) } if (given.length === 0) { return base } if (given.indexOf('#') === 0) { return base + given } colon = given.indexOf(':') if (colon >= 0) { return given } baseColon = base.indexOf(':') if (base.length === 0) { return given } if (baseColon < 0) { alert('Invalid base: ' + base + ' in join with given: ' + given) return given } baseScheme = base.slice(0, +baseColon + 1 || 9e9) if (given.indexOf('//') === 0) { return baseScheme + given } if (base.indexOf('//', baseColon) === baseColon + 1) { baseSingle = base.indexOf('/', baseColon + 3) if (baseSingle < 0) { if (base.length - baseColon - 3 > 0) { return base + '/' + given } else { return baseScheme + given } } } else { baseSingle = base.indexOf('/', baseColon + 1) if (baseSingle < 0) { if (base.length - baseColon - 1 > 0) { return base + '/' + given } else { return baseScheme + given } } } if (given.indexOf('/') === 0) { return base.slice(0, baseSingle) + given } path = base.slice(baseSingle) lastSlash = path.lastIndexOf('/') if (lastSlash < 0) { return baseScheme + given } if (lastSlash >= 0 && lastSlash < path.length - 1) { path = path.slice(0, +lastSlash + 1 || 9e9) } path += given while (path.match(/[^\/]*\/\.\.\//)) { path = path.replace(/[^\/]*\/\.\.\//, '') } path = path.replace(/\.\//g, '') path = path.replace(/\/\.$/, '/') return base.slice(0, baseSingle) + path } function protocol (uri) { var i i = uri.indexOf(':') if (i < 0) { return null } else { return uri.slice(0, i) } } function refTo (base, uri) { var c, i, k, l, len, len1, n, o, p, q, ref, ref1, s var commonHost = new RegExp('^[-_a-zA-Z0-9.]+:(//[^/]*)?/[^/]*$') if (!base) { return uri } if (base === uri) { return '' } for (i = o = 0, len = uri.length; o < len; i = ++o) { c = uri[i] if (c !== base[i]) { break } } if (base.slice(0, i).match(commonHost)) { k = uri.indexOf('//') if (k < 0) { k = -2 } l = uri.indexOf('/', k + 2) if (uri[l + 1] !== '/' && base[l + 1] !== '/' && uri.slice(0, l) === base.slice(0, l)) { return uri.slice(l) } } if (uri[i] === '#' && base.length === i) { return uri.slice(i) } while (i > 0 && uri[i - 1] !== '/') { i-- } if (i < 3) { return uri } if (base.indexOf('//', i - 2) > 0 || uri.indexOf('//', i - 2) > 0) { return uri } if (base.indexOf(':', i) > 0) { return uri } n = 0 ref = base.slice(i) for (p = 0, len1 = ref.length; p < len1; p++) { c = ref[p] if (c === '/') { n++ } } if (n === 0 && i < uri.length && uri[i] === '#') { return './' + uri.slice(i) } if (n === 0 && i === uri.length) { return './' } s = '' if (n > 0) { for (q = 1, ref1 = n; ref1 >= 1 ? q <= ref1 : q >= ref1; ref1 >= 1 ? ++q : --q) { s += '../' } } return s + uri.slice(i) }