aboutsummaryrefslogtreecommitdiffstats
path: root/www
diff options
context:
space:
mode:
authorlwhsu <lwhsu@FreeBSD.org>2009-05-22 13:10:32 +0800
committerlwhsu <lwhsu@FreeBSD.org>2009-05-22 13:10:32 +0800
commitf4133f33a429e97cc616919223122fe08149a37e (patch)
tree73fe3f7fb1f18f1877b2d57e5c54adee8aeb0811 /www
parent60606dd76cb4fd0e935f55be8b59e7a1c2071b76 (diff)
downloadfreebsd-ports-gnome-f4133f33a429e97cc616919223122fe08149a37e.tar.gz
freebsd-ports-gnome-f4133f33a429e97cc616919223122fe08149a37e.tar.zst
freebsd-ports-gnome-f4133f33a429e97cc616919223122fe08149a37e.zip
- Add a patch for be compatible with sphinx 0.6.1
PR: ports/134781 Obtained from: http://osdir.com/ml/debian-bugs-dist/2009-05/msg02233.html (patch for trunk was adopted by debian team for 1.0.2, and slightly modified for FreeBSD)
Diffstat (limited to 'www')
-rw-r--r--www/py-django/Makefile1
-rw-r--r--www/py-django/files/patch-sphinx130
-rw-r--r--www/py-django11/Makefile1
-rw-r--r--www/py-django11/files/patch-sphinx130
-rw-r--r--www/py-django12/Makefile1
-rw-r--r--www/py-django12/files/patch-sphinx130
-rw-r--r--www/py-django13/Makefile1
-rw-r--r--www/py-django13/files/patch-sphinx130
8 files changed, 524 insertions, 0 deletions
diff --git a/www/py-django/Makefile b/www/py-django/Makefile
index b8a1fd9cc6ef..728302b12e0c 100644
--- a/www/py-django/Makefile
+++ b/www/py-django/Makefile
@@ -7,6 +7,7 @@
PORTNAME= django
PORTVERSION= 1.0.2
+PORTREVISION= 1
CATEGORIES= www python
MASTER_SITES= http://media.djangoproject.com/releases/${PORTVERSION}/ \
http://www.cs.nctu.edu.tw/~lwhsu/ports/distfiles/
diff --git a/www/py-django/files/patch-sphinx b/www/py-django/files/patch-sphinx
new file mode 100644
index 000000000000..8a120c052a77
--- /dev/null
+++ b/www/py-django/files/patch-sphinx
@@ -0,0 +1,130 @@
+--- ./docs/_ext/djangodocs.py.orig 2008-11-19 13:44:34.000000000 +0800
++++ ./docs/_ext/djangodocs.py 2009-05-21 23:41:11.495238717 +0800
+@@ -6,10 +6,16 @@
+ import docutils.transforms
+ import sphinx
+ import sphinx.addnodes
+-import sphinx.builder
++try:
++ from sphinx import builders
++except ImportError:
++ import sphinx.builder as builders
+ import sphinx.directives
+ import sphinx.environment
+-import sphinx.htmlwriter
++try:
++ import sphinx.writers.html as sphinx_htmlwriter
++except ImportError:
++ import sphinx.htmlwriter as sphinx_htmlwriter
+
+ def setup(app):
+ app.add_crossref_type(
+@@ -42,7 +48,7 @@
+ directivename = "django-admin-option",
+ rolename = "djadminopt",
+ indextemplate = "pair: %s; django-admin command-line option",
+- parse_node = lambda env, sig, signode: sphinx.directives.parse_option_desc(signode, sig),
++ parse_node = parse_django_adminopt_node,
+ )
+ app.add_transform(SuppressBlockquotes)
+
+@@ -71,7 +77,7 @@
+ if len(node.children) == 1 and isinstance(node.children[0], self.suppress_blockquote_child_nodes):
+ node.replace_self(node.children[0])
+
+-class DjangoHTMLTranslator(sphinx.htmlwriter.SmartyPantsHTMLTranslator):
++class DjangoHTMLTranslator(sphinx_htmlwriter.SmartyPantsHTMLTranslator):
+ """
+ Django-specific reST to HTML tweaks.
+ """
+@@ -94,10 +100,10 @@
+ #
+ def visit_literal_block(self, node):
+ self.no_smarty += 1
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.visit_literal_block(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.visit_literal_block(self, node)
+
+ def depart_literal_block(self, node):
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.depart_literal_block(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.depart_literal_block(self, node)
+ self.no_smarty -= 1
+
+ #
+@@ -132,7 +138,7 @@
+ # This is different on docutils 0.5 vs. 0.4...
+
+ # The docutils 0.4 override.
+- if hasattr(sphinx.htmlwriter.SmartyPantsHTMLTranslator, 'start_tag_with_title'):
++ if hasattr(sphinx_htmlwriter.SmartyPantsHTMLTranslator, 'start_tag_with_title'):
+ def start_tag_with_title(self, node, tagname, **atts):
+ node = {
+ 'classes': node.get('classes', []),
+@@ -145,7 +151,7 @@
+ def visit_section(self, node):
+ old_ids = node.get('ids', [])
+ node['ids'] = ['s-' + i for i in old_ids]
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.visit_section(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.visit_section(self, node)
+ node['ids'] = old_ids
+
+ def parse_django_admin_node(env, sig, signode):
+@@ -155,6 +161,25 @@
+ signode += sphinx.addnodes.desc_name(title, title)
+ return sig
+
++def parse_django_adminopt_node(env, sig, signode):
++ """A copy of sphinx.directives.CmdoptionDesc.parse_signature()"""
++ from sphinx import addnodes
++ from sphinx.directives.desc import option_desc_re
++ count = 0
++ firstname = ''
++ for m in option_desc_re.finditer(sig):
++ optname, args = m.groups()
++ if count:
++ signode += addnodes.desc_addname(', ', ', ')
++ signode += addnodes.desc_name(optname, optname)
++ signode += addnodes.desc_addname(args, args)
++ if not count:
++ firstname = optname
++ count += 1
++ if not firstname:
++ raise ValueError
++ return firstname
++
+ def monkeypatch_pickle_builder():
+ import shutil
+ from os import path
+@@ -183,12 +208,12 @@
+
+ # copy the environment file from the doctree dir to the output dir
+ # as needed by the web app
+- shutil.copyfile(path.join(self.doctreedir, sphinx.builder.ENV_PICKLE_FILENAME),
+- path.join(self.outdir, sphinx.builder.ENV_PICKLE_FILENAME))
++ shutil.copyfile(path.join(self.doctreedir, builders.ENV_PICKLE_FILENAME),
++ path.join(self.outdir, builders.ENV_PICKLE_FILENAME))
+
+ # touch 'last build' file, used by the web application to determine
+ # when to reload its environment and clear the cache
+- open(path.join(self.outdir, sphinx.builder.LAST_BUILD_FILENAME), 'w').close()
++ open(path.join(self.outdir, builders.LAST_BUILD_FILENAME), 'w').close()
+
+- sphinx.builder.PickleHTMLBuilder.handle_finish = handle_finish
++ builders.PickleHTMLBuilder.handle_finish = handle_finish
+
+--- ./docs/_templates/layout.html.orig 2008-11-19 13:44:33.000000000 +0800
++++ ./docs/_templates/layout.html 2009-05-21 23:41:17.886376469 +0800
+@@ -1,6 +1,6 @@
+ {% extends "!layout.html" %}
+
+-{%- macro secondnav %}
++{%- macro secondnav() %}
+ {%- if prev %}
+ &laquo; <a href="{{ prev.link|e }}" title="{{ prev.title|e }}">previous</a>
+ {{ reldelim2 }}
+@@ -84,4 +84,4 @@
+ {% block relbar2 %}{% endblock %}
+ {% block sidebar1 %}{% endblock %}
+ {% block sidebar2 %}{% endblock %}
+-{% block footer %}{% endblock %}
+\ No newline at end of file
++{% block footer %}{% endblock %}
diff --git a/www/py-django11/Makefile b/www/py-django11/Makefile
index b8a1fd9cc6ef..728302b12e0c 100644
--- a/www/py-django11/Makefile
+++ b/www/py-django11/Makefile
@@ -7,6 +7,7 @@
PORTNAME= django
PORTVERSION= 1.0.2
+PORTREVISION= 1
CATEGORIES= www python
MASTER_SITES= http://media.djangoproject.com/releases/${PORTVERSION}/ \
http://www.cs.nctu.edu.tw/~lwhsu/ports/distfiles/
diff --git a/www/py-django11/files/patch-sphinx b/www/py-django11/files/patch-sphinx
new file mode 100644
index 000000000000..8a120c052a77
--- /dev/null
+++ b/www/py-django11/files/patch-sphinx
@@ -0,0 +1,130 @@
+--- ./docs/_ext/djangodocs.py.orig 2008-11-19 13:44:34.000000000 +0800
++++ ./docs/_ext/djangodocs.py 2009-05-21 23:41:11.495238717 +0800
+@@ -6,10 +6,16 @@
+ import docutils.transforms
+ import sphinx
+ import sphinx.addnodes
+-import sphinx.builder
++try:
++ from sphinx import builders
++except ImportError:
++ import sphinx.builder as builders
+ import sphinx.directives
+ import sphinx.environment
+-import sphinx.htmlwriter
++try:
++ import sphinx.writers.html as sphinx_htmlwriter
++except ImportError:
++ import sphinx.htmlwriter as sphinx_htmlwriter
+
+ def setup(app):
+ app.add_crossref_type(
+@@ -42,7 +48,7 @@
+ directivename = "django-admin-option",
+ rolename = "djadminopt",
+ indextemplate = "pair: %s; django-admin command-line option",
+- parse_node = lambda env, sig, signode: sphinx.directives.parse_option_desc(signode, sig),
++ parse_node = parse_django_adminopt_node,
+ )
+ app.add_transform(SuppressBlockquotes)
+
+@@ -71,7 +77,7 @@
+ if len(node.children) == 1 and isinstance(node.children[0], self.suppress_blockquote_child_nodes):
+ node.replace_self(node.children[0])
+
+-class DjangoHTMLTranslator(sphinx.htmlwriter.SmartyPantsHTMLTranslator):
++class DjangoHTMLTranslator(sphinx_htmlwriter.SmartyPantsHTMLTranslator):
+ """
+ Django-specific reST to HTML tweaks.
+ """
+@@ -94,10 +100,10 @@
+ #
+ def visit_literal_block(self, node):
+ self.no_smarty += 1
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.visit_literal_block(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.visit_literal_block(self, node)
+
+ def depart_literal_block(self, node):
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.depart_literal_block(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.depart_literal_block(self, node)
+ self.no_smarty -= 1
+
+ #
+@@ -132,7 +138,7 @@
+ # This is different on docutils 0.5 vs. 0.4...
+
+ # The docutils 0.4 override.
+- if hasattr(sphinx.htmlwriter.SmartyPantsHTMLTranslator, 'start_tag_with_title'):
++ if hasattr(sphinx_htmlwriter.SmartyPantsHTMLTranslator, 'start_tag_with_title'):
+ def start_tag_with_title(self, node, tagname, **atts):
+ node = {
+ 'classes': node.get('classes', []),
+@@ -145,7 +151,7 @@
+ def visit_section(self, node):
+ old_ids = node.get('ids', [])
+ node['ids'] = ['s-' + i for i in old_ids]
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.visit_section(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.visit_section(self, node)
+ node['ids'] = old_ids
+
+ def parse_django_admin_node(env, sig, signode):
+@@ -155,6 +161,25 @@
+ signode += sphinx.addnodes.desc_name(title, title)
+ return sig
+
++def parse_django_adminopt_node(env, sig, signode):
++ """A copy of sphinx.directives.CmdoptionDesc.parse_signature()"""
++ from sphinx import addnodes
++ from sphinx.directives.desc import option_desc_re
++ count = 0
++ firstname = ''
++ for m in option_desc_re.finditer(sig):
++ optname, args = m.groups()
++ if count:
++ signode += addnodes.desc_addname(', ', ', ')
++ signode += addnodes.desc_name(optname, optname)
++ signode += addnodes.desc_addname(args, args)
++ if not count:
++ firstname = optname
++ count += 1
++ if not firstname:
++ raise ValueError
++ return firstname
++
+ def monkeypatch_pickle_builder():
+ import shutil
+ from os import path
+@@ -183,12 +208,12 @@
+
+ # copy the environment file from the doctree dir to the output dir
+ # as needed by the web app
+- shutil.copyfile(path.join(self.doctreedir, sphinx.builder.ENV_PICKLE_FILENAME),
+- path.join(self.outdir, sphinx.builder.ENV_PICKLE_FILENAME))
++ shutil.copyfile(path.join(self.doctreedir, builders.ENV_PICKLE_FILENAME),
++ path.join(self.outdir, builders.ENV_PICKLE_FILENAME))
+
+ # touch 'last build' file, used by the web application to determine
+ # when to reload its environment and clear the cache
+- open(path.join(self.outdir, sphinx.builder.LAST_BUILD_FILENAME), 'w').close()
++ open(path.join(self.outdir, builders.LAST_BUILD_FILENAME), 'w').close()
+
+- sphinx.builder.PickleHTMLBuilder.handle_finish = handle_finish
++ builders.PickleHTMLBuilder.handle_finish = handle_finish
+
+--- ./docs/_templates/layout.html.orig 2008-11-19 13:44:33.000000000 +0800
++++ ./docs/_templates/layout.html 2009-05-21 23:41:17.886376469 +0800
+@@ -1,6 +1,6 @@
+ {% extends "!layout.html" %}
+
+-{%- macro secondnav %}
++{%- macro secondnav() %}
+ {%- if prev %}
+ &laquo; <a href="{{ prev.link|e }}" title="{{ prev.title|e }}">previous</a>
+ {{ reldelim2 }}
+@@ -84,4 +84,4 @@
+ {% block relbar2 %}{% endblock %}
+ {% block sidebar1 %}{% endblock %}
+ {% block sidebar2 %}{% endblock %}
+-{% block footer %}{% endblock %}
+\ No newline at end of file
++{% block footer %}{% endblock %}
diff --git a/www/py-django12/Makefile b/www/py-django12/Makefile
index b8a1fd9cc6ef..728302b12e0c 100644
--- a/www/py-django12/Makefile
+++ b/www/py-django12/Makefile
@@ -7,6 +7,7 @@
PORTNAME= django
PORTVERSION= 1.0.2
+PORTREVISION= 1
CATEGORIES= www python
MASTER_SITES= http://media.djangoproject.com/releases/${PORTVERSION}/ \
http://www.cs.nctu.edu.tw/~lwhsu/ports/distfiles/
diff --git a/www/py-django12/files/patch-sphinx b/www/py-django12/files/patch-sphinx
new file mode 100644
index 000000000000..8a120c052a77
--- /dev/null
+++ b/www/py-django12/files/patch-sphinx
@@ -0,0 +1,130 @@
+--- ./docs/_ext/djangodocs.py.orig 2008-11-19 13:44:34.000000000 +0800
++++ ./docs/_ext/djangodocs.py 2009-05-21 23:41:11.495238717 +0800
+@@ -6,10 +6,16 @@
+ import docutils.transforms
+ import sphinx
+ import sphinx.addnodes
+-import sphinx.builder
++try:
++ from sphinx import builders
++except ImportError:
++ import sphinx.builder as builders
+ import sphinx.directives
+ import sphinx.environment
+-import sphinx.htmlwriter
++try:
++ import sphinx.writers.html as sphinx_htmlwriter
++except ImportError:
++ import sphinx.htmlwriter as sphinx_htmlwriter
+
+ def setup(app):
+ app.add_crossref_type(
+@@ -42,7 +48,7 @@
+ directivename = "django-admin-option",
+ rolename = "djadminopt",
+ indextemplate = "pair: %s; django-admin command-line option",
+- parse_node = lambda env, sig, signode: sphinx.directives.parse_option_desc(signode, sig),
++ parse_node = parse_django_adminopt_node,
+ )
+ app.add_transform(SuppressBlockquotes)
+
+@@ -71,7 +77,7 @@
+ if len(node.children) == 1 and isinstance(node.children[0], self.suppress_blockquote_child_nodes):
+ node.replace_self(node.children[0])
+
+-class DjangoHTMLTranslator(sphinx.htmlwriter.SmartyPantsHTMLTranslator):
++class DjangoHTMLTranslator(sphinx_htmlwriter.SmartyPantsHTMLTranslator):
+ """
+ Django-specific reST to HTML tweaks.
+ """
+@@ -94,10 +100,10 @@
+ #
+ def visit_literal_block(self, node):
+ self.no_smarty += 1
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.visit_literal_block(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.visit_literal_block(self, node)
+
+ def depart_literal_block(self, node):
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.depart_literal_block(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.depart_literal_block(self, node)
+ self.no_smarty -= 1
+
+ #
+@@ -132,7 +138,7 @@
+ # This is different on docutils 0.5 vs. 0.4...
+
+ # The docutils 0.4 override.
+- if hasattr(sphinx.htmlwriter.SmartyPantsHTMLTranslator, 'start_tag_with_title'):
++ if hasattr(sphinx_htmlwriter.SmartyPantsHTMLTranslator, 'start_tag_with_title'):
+ def start_tag_with_title(self, node, tagname, **atts):
+ node = {
+ 'classes': node.get('classes', []),
+@@ -145,7 +151,7 @@
+ def visit_section(self, node):
+ old_ids = node.get('ids', [])
+ node['ids'] = ['s-' + i for i in old_ids]
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.visit_section(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.visit_section(self, node)
+ node['ids'] = old_ids
+
+ def parse_django_admin_node(env, sig, signode):
+@@ -155,6 +161,25 @@
+ signode += sphinx.addnodes.desc_name(title, title)
+ return sig
+
++def parse_django_adminopt_node(env, sig, signode):
++ """A copy of sphinx.directives.CmdoptionDesc.parse_signature()"""
++ from sphinx import addnodes
++ from sphinx.directives.desc import option_desc_re
++ count = 0
++ firstname = ''
++ for m in option_desc_re.finditer(sig):
++ optname, args = m.groups()
++ if count:
++ signode += addnodes.desc_addname(', ', ', ')
++ signode += addnodes.desc_name(optname, optname)
++ signode += addnodes.desc_addname(args, args)
++ if not count:
++ firstname = optname
++ count += 1
++ if not firstname:
++ raise ValueError
++ return firstname
++
+ def monkeypatch_pickle_builder():
+ import shutil
+ from os import path
+@@ -183,12 +208,12 @@
+
+ # copy the environment file from the doctree dir to the output dir
+ # as needed by the web app
+- shutil.copyfile(path.join(self.doctreedir, sphinx.builder.ENV_PICKLE_FILENAME),
+- path.join(self.outdir, sphinx.builder.ENV_PICKLE_FILENAME))
++ shutil.copyfile(path.join(self.doctreedir, builders.ENV_PICKLE_FILENAME),
++ path.join(self.outdir, builders.ENV_PICKLE_FILENAME))
+
+ # touch 'last build' file, used by the web application to determine
+ # when to reload its environment and clear the cache
+- open(path.join(self.outdir, sphinx.builder.LAST_BUILD_FILENAME), 'w').close()
++ open(path.join(self.outdir, builders.LAST_BUILD_FILENAME), 'w').close()
+
+- sphinx.builder.PickleHTMLBuilder.handle_finish = handle_finish
++ builders.PickleHTMLBuilder.handle_finish = handle_finish
+
+--- ./docs/_templates/layout.html.orig 2008-11-19 13:44:33.000000000 +0800
++++ ./docs/_templates/layout.html 2009-05-21 23:41:17.886376469 +0800
+@@ -1,6 +1,6 @@
+ {% extends "!layout.html" %}
+
+-{%- macro secondnav %}
++{%- macro secondnav() %}
+ {%- if prev %}
+ &laquo; <a href="{{ prev.link|e }}" title="{{ prev.title|e }}">previous</a>
+ {{ reldelim2 }}
+@@ -84,4 +84,4 @@
+ {% block relbar2 %}{% endblock %}
+ {% block sidebar1 %}{% endblock %}
+ {% block sidebar2 %}{% endblock %}
+-{% block footer %}{% endblock %}
+\ No newline at end of file
++{% block footer %}{% endblock %}
diff --git a/www/py-django13/Makefile b/www/py-django13/Makefile
index b8a1fd9cc6ef..728302b12e0c 100644
--- a/www/py-django13/Makefile
+++ b/www/py-django13/Makefile
@@ -7,6 +7,7 @@
PORTNAME= django
PORTVERSION= 1.0.2
+PORTREVISION= 1
CATEGORIES= www python
MASTER_SITES= http://media.djangoproject.com/releases/${PORTVERSION}/ \
http://www.cs.nctu.edu.tw/~lwhsu/ports/distfiles/
diff --git a/www/py-django13/files/patch-sphinx b/www/py-django13/files/patch-sphinx
new file mode 100644
index 000000000000..8a120c052a77
--- /dev/null
+++ b/www/py-django13/files/patch-sphinx
@@ -0,0 +1,130 @@
+--- ./docs/_ext/djangodocs.py.orig 2008-11-19 13:44:34.000000000 +0800
++++ ./docs/_ext/djangodocs.py 2009-05-21 23:41:11.495238717 +0800
+@@ -6,10 +6,16 @@
+ import docutils.transforms
+ import sphinx
+ import sphinx.addnodes
+-import sphinx.builder
++try:
++ from sphinx import builders
++except ImportError:
++ import sphinx.builder as builders
+ import sphinx.directives
+ import sphinx.environment
+-import sphinx.htmlwriter
++try:
++ import sphinx.writers.html as sphinx_htmlwriter
++except ImportError:
++ import sphinx.htmlwriter as sphinx_htmlwriter
+
+ def setup(app):
+ app.add_crossref_type(
+@@ -42,7 +48,7 @@
+ directivename = "django-admin-option",
+ rolename = "djadminopt",
+ indextemplate = "pair: %s; django-admin command-line option",
+- parse_node = lambda env, sig, signode: sphinx.directives.parse_option_desc(signode, sig),
++ parse_node = parse_django_adminopt_node,
+ )
+ app.add_transform(SuppressBlockquotes)
+
+@@ -71,7 +77,7 @@
+ if len(node.children) == 1 and isinstance(node.children[0], self.suppress_blockquote_child_nodes):
+ node.replace_self(node.children[0])
+
+-class DjangoHTMLTranslator(sphinx.htmlwriter.SmartyPantsHTMLTranslator):
++class DjangoHTMLTranslator(sphinx_htmlwriter.SmartyPantsHTMLTranslator):
+ """
+ Django-specific reST to HTML tweaks.
+ """
+@@ -94,10 +100,10 @@
+ #
+ def visit_literal_block(self, node):
+ self.no_smarty += 1
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.visit_literal_block(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.visit_literal_block(self, node)
+
+ def depart_literal_block(self, node):
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.depart_literal_block(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.depart_literal_block(self, node)
+ self.no_smarty -= 1
+
+ #
+@@ -132,7 +138,7 @@
+ # This is different on docutils 0.5 vs. 0.4...
+
+ # The docutils 0.4 override.
+- if hasattr(sphinx.htmlwriter.SmartyPantsHTMLTranslator, 'start_tag_with_title'):
++ if hasattr(sphinx_htmlwriter.SmartyPantsHTMLTranslator, 'start_tag_with_title'):
+ def start_tag_with_title(self, node, tagname, **atts):
+ node = {
+ 'classes': node.get('classes', []),
+@@ -145,7 +151,7 @@
+ def visit_section(self, node):
+ old_ids = node.get('ids', [])
+ node['ids'] = ['s-' + i for i in old_ids]
+- sphinx.htmlwriter.SmartyPantsHTMLTranslator.visit_section(self, node)
++ sphinx_htmlwriter.SmartyPantsHTMLTranslator.visit_section(self, node)
+ node['ids'] = old_ids
+
+ def parse_django_admin_node(env, sig, signode):
+@@ -155,6 +161,25 @@
+ signode += sphinx.addnodes.desc_name(title, title)
+ return sig
+
++def parse_django_adminopt_node(env, sig, signode):
++ """A copy of sphinx.directives.CmdoptionDesc.parse_signature()"""
++ from sphinx import addnodes
++ from sphinx.directives.desc import option_desc_re
++ count = 0
++ firstname = ''
++ for m in option_desc_re.finditer(sig):
++ optname, args = m.groups()
++ if count:
++ signode += addnodes.desc_addname(', ', ', ')
++ signode += addnodes.desc_name(optname, optname)
++ signode += addnodes.desc_addname(args, args)
++ if not count:
++ firstname = optname
++ count += 1
++ if not firstname:
++ raise ValueError
++ return firstname
++
+ def monkeypatch_pickle_builder():
+ import shutil
+ from os import path
+@@ -183,12 +208,12 @@
+
+ # copy the environment file from the doctree dir to the output dir
+ # as needed by the web app
+- shutil.copyfile(path.join(self.doctreedir, sphinx.builder.ENV_PICKLE_FILENAME),
+- path.join(self.outdir, sphinx.builder.ENV_PICKLE_FILENAME))
++ shutil.copyfile(path.join(self.doctreedir, builders.ENV_PICKLE_FILENAME),
++ path.join(self.outdir, builders.ENV_PICKLE_FILENAME))
+
+ # touch 'last build' file, used by the web application to determine
+ # when to reload its environment and clear the cache
+- open(path.join(self.outdir, sphinx.builder.LAST_BUILD_FILENAME), 'w').close()
++ open(path.join(self.outdir, builders.LAST_BUILD_FILENAME), 'w').close()
+
+- sphinx.builder.PickleHTMLBuilder.handle_finish = handle_finish
++ builders.PickleHTMLBuilder.handle_finish = handle_finish
+
+--- ./docs/_templates/layout.html.orig 2008-11-19 13:44:33.000000000 +0800
++++ ./docs/_templates/layout.html 2009-05-21 23:41:17.886376469 +0800
+@@ -1,6 +1,6 @@
+ {% extends "!layout.html" %}
+
+-{%- macro secondnav %}
++{%- macro secondnav() %}
+ {%- if prev %}
+ &laquo; <a href="{{ prev.link|e }}" title="{{ prev.title|e }}">previous</a>
+ {{ reldelim2 }}
+@@ -84,4 +84,4 @@
+ {% block relbar2 %}{% endblock %}
+ {% block sidebar1 %}{% endblock %}
+ {% block sidebar2 %}{% endblock %}
+-{% block footer %}{% endblock %}
+\ No newline at end of file
++{% block footer %}{% endblock %}