2013-04-12 22:09:00 +02:00
|
|
|
# vim:fileencoding=utf-8:noet
|
2014-08-31 20:55:26 +02:00
|
|
|
from __future__ import (unicode_literals, division, absolute_import, print_function)
|
|
|
|
|
2015-03-11 20:49:36 +01:00
|
|
|
import os
|
|
|
|
|
2013-04-12 22:09:00 +02:00
|
|
|
from inspect import formatargspec
|
2014-08-31 20:55:26 +02:00
|
|
|
|
|
|
|
from sphinx.ext import autodoc
|
|
|
|
|
2013-04-12 22:09:00 +02:00
|
|
|
from powerline.lint.inspect import getconfigargspec
|
2014-08-24 17:13:47 +02:00
|
|
|
from powerline.segments import Segment
|
2014-08-31 20:55:26 +02:00
|
|
|
from powerline.lib.unicode import unicode
|
2013-03-17 19:26:57 +01:00
|
|
|
|
|
|
|
|
|
|
|
def formatvalue(val):
|
|
|
|
if type(val) is str:
|
|
|
|
return '="' + unicode(val, 'utf-8').replace('"', '\\"').replace('\\', '\\\\') + '"'
|
|
|
|
else:
|
|
|
|
return '=' + repr(val)
|
|
|
|
|
2013-03-17 17:20:21 +01:00
|
|
|
|
|
|
|
class ThreadedDocumenter(autodoc.FunctionDocumenter):
|
|
|
|
'''Specialized documenter subclass for ThreadedSegment subclasses.'''
|
|
|
|
@classmethod
|
|
|
|
def can_document_member(cls, member, membername, isattr, parent):
|
2014-08-24 17:13:47 +02:00
|
|
|
return (isinstance(member, Segment) or
|
2013-03-17 17:20:21 +01:00
|
|
|
super(ThreadedDocumenter, cls).can_document_member(member, membername, isattr, parent))
|
|
|
|
|
|
|
|
def format_args(self):
|
2013-04-12 22:09:00 +02:00
|
|
|
argspec = getconfigargspec(self.object)
|
2013-03-17 19:26:57 +01:00
|
|
|
return formatargspec(*argspec, formatvalue=formatvalue).replace('\\', '\\\\')
|
2013-03-17 17:20:21 +01:00
|
|
|
|
|
|
|
|
2015-03-11 20:49:36 +01:00
|
|
|
class Repr(object):
|
|
|
|
def __init__(self, repr_contents):
|
|
|
|
self.repr_contents = repr_contents
|
|
|
|
|
|
|
|
def __repr__(self):
|
|
|
|
return '<{0}>'.format(self.repr_contents)
|
|
|
|
|
|
|
|
|
|
|
|
class EnvironDocumenter(autodoc.AttributeDocumenter):
|
|
|
|
@classmethod
|
|
|
|
def can_document_member(cls, member, membername, isattr, parent):
|
|
|
|
if type(member) is dict and member.get('environ') is os.environ:
|
|
|
|
return True
|
|
|
|
else:
|
|
|
|
return False
|
|
|
|
|
|
|
|
def import_object(self, *args, **kwargs):
|
|
|
|
ret = super(EnvironDocumenter, self).import_object(*args, **kwargs)
|
|
|
|
if not ret:
|
|
|
|
return ret
|
|
|
|
self.object = self.object.copy()
|
|
|
|
if 'home' in self.object:
|
|
|
|
self.object.update(home=Repr('home directory'))
|
|
|
|
self.object.update(environ=Repr('environ dictionary'))
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
2013-03-17 17:20:21 +01:00
|
|
|
def setup(app):
|
|
|
|
autodoc.setup(app)
|
|
|
|
app.add_autodocumenter(ThreadedDocumenter)
|
2015-03-11 20:49:36 +01:00
|
|
|
app.add_autodocumenter(EnvironDocumenter)
|