first commit based on psycopg2 2.9 version
This commit is contained in:
50
doc/src/tools/lib/dbapi_extension.py
Executable file
50
doc/src/tools/lib/dbapi_extension.py
Executable file
@ -0,0 +1,50 @@
|
||||
"""
|
||||
extension
|
||||
~~~~~~~~~
|
||||
|
||||
A directive to create a box warning that a certain bit of Psycopg is an
|
||||
extension to the DBAPI 2.0.
|
||||
|
||||
:copyright: Copyright 2010 by Daniele Varrazzo.
|
||||
"""
|
||||
|
||||
from docutils import nodes
|
||||
|
||||
from sphinx.locale import _
|
||||
from docutils.parsers.rst import Directive
|
||||
|
||||
class extension_node(nodes.Admonition, nodes.Element): pass
|
||||
|
||||
|
||||
class Extension(Directive):
|
||||
"""
|
||||
An extension entry, displayed as an admonition.
|
||||
"""
|
||||
|
||||
has_content = True
|
||||
required_arguments = 0
|
||||
optional_arguments = 0
|
||||
final_argument_whitespace = False
|
||||
option_spec = {}
|
||||
|
||||
def run(self):
|
||||
node = extension_node('\n'.join(self.content))
|
||||
node += nodes.title(_('DB API extension'), _('DB API extension'))
|
||||
self.state.nested_parse(self.content, self.content_offset, node)
|
||||
node['classes'].append('dbapi-extension')
|
||||
return [node]
|
||||
|
||||
|
||||
def visit_extension_node(self, node):
|
||||
self.visit_admonition(node)
|
||||
|
||||
def depart_extension_node(self, node):
|
||||
self.depart_admonition(node)
|
||||
|
||||
def setup(app):
|
||||
app.add_node(extension_node,
|
||||
html=(visit_extension_node, depart_extension_node),
|
||||
latex=(visit_extension_node, depart_extension_node),
|
||||
text=(visit_extension_node, depart_extension_node))
|
||||
|
||||
app.add_directive('extension', Extension)
|
||||
19
doc/src/tools/lib/sql_role.py
Normal file
19
doc/src/tools/lib/sql_role.py
Normal file
@ -0,0 +1,19 @@
|
||||
"""
|
||||
sql role
|
||||
~~~~~~~~
|
||||
|
||||
An interpreted text role to style SQL syntax in Psycopg documentation.
|
||||
|
||||
:copyright: Copyright 2010 by Daniele Varrazzo.
|
||||
"""
|
||||
|
||||
from docutils import nodes, utils
|
||||
from docutils.parsers.rst import roles
|
||||
|
||||
def sql_role(name, rawtext, text, lineno, inliner, options={}, content=[]):
|
||||
text = utils.unescape(text)
|
||||
options['classes'] = ['sql']
|
||||
return [nodes.literal(rawtext, text, **options)], []
|
||||
|
||||
def setup(app):
|
||||
roles.register_local_role('sql', sql_role)
|
||||
57
doc/src/tools/lib/ticket_role.py
Normal file
57
doc/src/tools/lib/ticket_role.py
Normal file
@ -0,0 +1,57 @@
|
||||
"""
|
||||
ticket role
|
||||
~~~~~~~~~~~
|
||||
|
||||
An interpreted text role to link docs to tickets issues.
|
||||
|
||||
:copyright: Copyright 2013 by Daniele Varrazzo.
|
||||
"""
|
||||
|
||||
import re
|
||||
from docutils import nodes, utils
|
||||
from docutils.parsers.rst import roles
|
||||
|
||||
def ticket_role(name, rawtext, text, lineno, inliner, options={}, content=[]):
|
||||
cfg = inliner.document.settings.env.app.config
|
||||
if cfg.ticket_url is None:
|
||||
msg = inliner.reporter.warning(
|
||||
"ticket not configured: please configure ticket_url in conf.py")
|
||||
prb = inliner.problematic(rawtext, rawtext, msg)
|
||||
return [prb], [msg]
|
||||
|
||||
rv = [nodes.Text(name + ' ')]
|
||||
tokens = re.findall(r'(#?\d+)|([^\d#]+)', text)
|
||||
for ticket, noise in tokens:
|
||||
if ticket:
|
||||
num = int(ticket.replace('#', ''))
|
||||
|
||||
# Push numbers of the oldel tickets ahead.
|
||||
# We moved the tickets from a different tracker to GitHub and the
|
||||
# latter already had a few ticket numbers taken (as merge
|
||||
# requests).
|
||||
remap_until = cfg.ticket_remap_until
|
||||
remap_offset = cfg.ticket_remap_offset
|
||||
if remap_until and remap_offset:
|
||||
if num <= remap_until:
|
||||
num += remap_offset
|
||||
|
||||
url = cfg.ticket_url % num
|
||||
roles.set_classes(options)
|
||||
node = nodes.reference(ticket, utils.unescape(ticket),
|
||||
refuri=url, **options)
|
||||
|
||||
rv.append(node)
|
||||
|
||||
else:
|
||||
assert noise
|
||||
rv.append(nodes.Text(noise))
|
||||
|
||||
return rv, []
|
||||
|
||||
|
||||
def setup(app):
|
||||
app.add_config_value('ticket_url', None, 'env')
|
||||
app.add_config_value('ticket_remap_until', None, 'env')
|
||||
app.add_config_value('ticket_remap_offset', None, 'env')
|
||||
app.add_role('ticket', ticket_role)
|
||||
app.add_role('tickets', ticket_role)
|
||||
Reference in New Issue
Block a user