comparison env/lib/python3.9/site-packages/rdflib_jsonld/util.py @ 0:4f3585e2f14b draft default tip

"planemo upload commit 60cee0fc7c0cda8592644e1aad72851dec82c959"
author shellac
date Mon, 22 Mar 2021 18:12:50 +0000
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:4f3585e2f14b
1 try:
2 import json
3 assert json # workaround for pyflakes issue #13
4 except ImportError:
5 import simplejson as json
6
7 from ._compat import IS_PY3 as PY3
8
9 from os import sep
10 from os.path import normpath
11 if PY3:
12 from urllib.parse import urljoin, urlsplit, urlunsplit
13 else:
14 from urllib.parse import urljoin, urlsplit, urlunsplit
15
16 from rdflib.parser import create_input_source
17 if PY3:
18 from io import StringIO
19
20
21 def source_to_json(source):
22 # TODO: conneg for JSON (fix support in rdflib's URLInputSource!)
23 source = create_input_source(source, format='json-ld')
24
25 stream = source.getByteStream()
26 try:
27 if PY3:
28 return json.load(StringIO(stream.read().decode('utf-8')))
29 else:
30 return json.load(stream)
31 finally:
32 stream.close()
33
34
35 VOCAB_DELIMS = ('#', '/', ':')
36
37 def split_iri(iri):
38 for delim in VOCAB_DELIMS:
39 at = iri.rfind(delim)
40 if at > -1:
41 return iri[:at+1], iri[at+1:]
42 return iri, None
43
44 def norm_url(base, url):
45 """
46 >>> norm_url('http://example.org/', '/one')
47 'http://example.org/one'
48 >>> norm_url('http://example.org/', '/one#')
49 'http://example.org/one#'
50 >>> norm_url('http://example.org/one', 'two')
51 'http://example.org/two'
52 >>> norm_url('http://example.org/one/', 'two')
53 'http://example.org/one/two'
54 >>> norm_url('http://example.org/', 'http://example.net/one')
55 'http://example.net/one'
56 >>> norm_url('http://example.org/', 'http://example.org//one')
57 'http://example.org//one'
58 """
59 parts = urlsplit(urljoin(base, url))
60 path = normpath(parts[2])
61 if sep != '/':
62 path = '/'.join(path.split(sep))
63 if parts[2].endswith('/') and not path.endswith('/'):
64 path += '/'
65 result = urlunsplit(parts[0:2] + (path,) + parts[3:])
66 if url.endswith('#') and not result.endswith('#'):
67 result += '#'
68 return result
69
70 def context_from_urlinputsource(source):
71 if source.content_type == 'application/json':
72 # response_info was added to InputSource in rdflib 4.2
73 try:
74 links = source.response_info.getallmatchingheaders('Link')
75 except AttributeError:
76 return
77 for link in links:
78 if ' rel="http://www.w3.org/ns/json-ld#context"' in link:
79 i, j = link.index('<'), link.index('>')
80 if i > -1 and j > -1:
81 return urljoin(source.url, link[i+1:j])