2017-11-11 14:40:20 +04:00
|
|
|
from docutils import nodes
|
|
|
|
import os
|
|
|
|
import os.path
|
2018-02-19 19:53:22 +04:00
|
|
|
import re
|
2017-11-11 14:40:20 +04:00
|
|
|
|
|
|
|
def setup(app):
|
|
|
|
app.add_role('package', package_role)
|
2018-02-19 19:53:22 +04:00
|
|
|
app.add_role('package-name', package_role)
|
|
|
|
app.add_role('package-src', package_role)
|
|
|
|
app.add_role('opam', opam_role)
|
|
|
|
app.add_role('src', src_role)
|
|
|
|
|
|
|
|
def find_dot_opam(name):
|
|
|
|
for path, dirs, files in os.walk('..'):
|
|
|
|
for file in files:
|
|
|
|
if file == name + '.opam':
|
|
|
|
return path.lstrip('../')
|
|
|
|
raise ValueError('opam file ' + name + '.opam does not exist in the odoc')
|
2017-11-11 14:40:20 +04:00
|
|
|
|
|
|
|
def package_role(name, rawtext, text, lineno, inliner, options={}, content=[]):
|
|
|
|
rel_lvl = inliner.document.current_source.replace(os.getcwd(),'').count('/')
|
2018-02-19 19:53:22 +04:00
|
|
|
parts = re.match("^([^<>]*)<([^<>]*)>$", text)
|
|
|
|
if parts:
|
|
|
|
text = parts.group(2)
|
|
|
|
lib = parts.group(1)
|
|
|
|
else:
|
|
|
|
lib = text
|
|
|
|
src = find_dot_opam(lib)
|
2018-07-09 14:20:56 +04:00
|
|
|
branch = os.environ.get('CI_COMMIT_REF_NAME', 'master')
|
|
|
|
project_url = os.environ.get('CI_PROJECT_URL', 'https://gitlab.com/tezos/tezos')
|
|
|
|
src_url = project_url + "/tree/" + branch + "/" + src
|
2018-02-19 19:53:22 +04:00
|
|
|
if os.path.isdir('_build/api/odoc/'+lib):
|
|
|
|
if os.path.isdir(os.path.join('_build','api','odoc',lib,lib.replace('-','_').capitalize())):
|
|
|
|
lib = lib + '/' + lib.replace('-','_').capitalize()
|
|
|
|
url = "api/api-inline.html#" + lib + '/index.html'
|
|
|
|
for i in range(1,rel_lvl):
|
2017-11-11 14:40:20 +04:00
|
|
|
url = '../' + url
|
2018-02-19 19:53:22 +04:00
|
|
|
else:
|
|
|
|
url = src_url
|
|
|
|
if name == 'package':
|
|
|
|
node = nodes.reference(rawtext, text, refuri=url, **options)
|
|
|
|
elif name == 'package-name':
|
|
|
|
node = nodes.literal(text, text)
|
|
|
|
elif name == 'package-src':
|
|
|
|
node = nodes.reference(rawtext, src, refuri=src_url, **options)
|
|
|
|
return [node], []
|
|
|
|
|
|
|
|
def opam_role(name, rawtext, text, lineno, inliner, options={}, content=[]):
|
|
|
|
rel_lvl = inliner.document.current_source.replace(os.getcwd(),'').count('/')
|
|
|
|
parts = re.match("^([^<>]*)<([^<>]*)>$", text)
|
|
|
|
if parts:
|
|
|
|
text = parts.group(2)
|
|
|
|
lib = parts.group(1)
|
|
|
|
else:
|
|
|
|
lib = text
|
|
|
|
tagged = re.match('([^.]+)[.].*', lib)
|
|
|
|
if tagged:
|
|
|
|
url = "https://opam.ocaml.org/packages/" + tagged.group(1) + "/" + lib
|
|
|
|
else:
|
|
|
|
url = "https://opam.ocaml.org/packages/" + lib
|
|
|
|
node = nodes.reference(rawtext, text, refuri=url, **options)
|
|
|
|
return [node], []
|
|
|
|
|
|
|
|
def src_role(name, rawtext, text, lineno, inliner, options={}, content=[]):
|
|
|
|
rel_lvl = inliner.document.current_source.replace(os.getcwd(),'').count('/')
|
|
|
|
parts = re.match("^([^<>]*)<([^<>]*)>$", text)
|
|
|
|
if parts:
|
|
|
|
text = parts.group(2)
|
|
|
|
src = parts.group(1)
|
|
|
|
else:
|
|
|
|
src = text
|
|
|
|
text = text
|
2018-07-09 14:20:56 +04:00
|
|
|
branch = os.environ.get('CI_COMMIT_REF_NAME', 'master')
|
|
|
|
project_url = os.environ.get('CI_PROJECT_URL', 'https://gitlab.com/tezos/tezos')
|
|
|
|
url = project_url + "/tree/" + branch + "/" + src
|
2017-11-11 14:40:20 +04:00
|
|
|
node = nodes.reference(rawtext, text, refuri=url, **options)
|
|
|
|
return [node], []
|