docstring.py

来自「Boost provides free peer-reviewed portab」· Python 代码 · 共 154 行

PY
154
字号
# Copyright David Abrahams & Ralf W. Grosse-Kunsteve 2004-2006.# Distributed under the Boost Software License, Version 1.0. (See accompanying# file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)'''>>> from docstring_ext import *>>> def selected_doc(obj, *args):...   doc = obj.__doc__.splitlines()...   return "\\n".join(["|"+doc[i] for i in args])>>> print selected_doc(X.__init__, 1, 2, 3, 4, 5)|__init__( (object)self, (int)value) -> None :|    this is the __init__ function|    its documentation has two lines.||    C++ signature :>>> print selected_doc(X.value, 1, 2, 4, 7, 8, 10)|value( (X)self) -> int :|    gets the value of the object|    C++ signature :|value( (X)self) -> int :|    also gets the value of the object|    C++ signature :>>> print selected_doc(create, 1, 2, 3, 4)|create( (int)value) -> X :|    creates a new X object||    C++ signature :>>> print selected_doc(fact, 1, 2, 3, 4)|fact( (int)n) -> int :|    compute the factorial||    C++ signature :>>> len(fact_usr_off_1.__doc__.splitlines())5>>> print selected_doc(fact_usr_off_1, 1, 3)|fact_usr_off_1( (int)n) -> int :|    C++ signature :>>> len(fact_usr_on_1.__doc__.splitlines())6>>> print selected_doc(fact_usr_on_1, 1, 2, 4)|fact_usr_on_1( (int)n) -> int :|    usr on 1|    C++ signature :>>> len(fact_usr_off_2.__doc__.splitlines())5>>> print selected_doc(fact_usr_off_2, 1, 3)|fact_usr_off_2( (int)n) -> int :|    C++ signature :>>> len(fact_usr_on_2.__doc__.splitlines())6>>> print selected_doc(fact_usr_on_2, 1, 2, 4)|fact_usr_on_2( (int)n) -> int :|    usr on 2|    C++ signature :>>> len(fact_sig_off_1.__doc__.splitlines())2>>> print selected_doc(fact_sig_off_1, 1)|sig off 1>>> len(fact_sig_on_1.__doc__.splitlines())6>>> print selected_doc(fact_sig_on_1, 1, 2, 4)|fact_sig_on_1( (int)n) -> int :|    sig on 1|    C++ signature :>>> len(fact_sig_off_2.__doc__.splitlines())2>>> print selected_doc(fact_sig_off_2, 1)|sig off 2>>> len(fact_sig_on_2.__doc__.splitlines())6>>> print selected_doc(fact_sig_on_2, 1, 2, 4)|fact_sig_on_2( (int)n) -> int :|    sig on 2|    C++ signature :>>> print fact_usr_off_sig_off_1.__doc__None>>> len(fact_usr_on_sig_on_1.__doc__.splitlines())6>>> print selected_doc(fact_usr_on_sig_on_1, 1, 2, 4)|fact_usr_on_sig_on_1( (int)n) -> int :|    usr on sig on 1|    C++ signature :>>> len(fact_usr_on_sig_off_1.__doc__.splitlines())2>>> print selected_doc(fact_usr_on_sig_off_1, 1)|usr on sig off 1>>> len(fact_usr_on_sig_on_2.__doc__.splitlines())6>>> print selected_doc(fact_usr_on_sig_on_2, 1, 2, 4)|fact_usr_on_sig_on_2( (int)n) -> int :|    usr on sig on 2|    C++ signature :>>> print selected_doc(fact_usr_on_psig_on_csig_off_1, 1, 2)|fact_usr_on_psig_on_csig_off_1( (int)n) -> int :|    usr on psig on csig off 1>>> print selected_doc(fact_usr_on_psig_off_csig_on_1, 1, 3)|usr on psig off csig on 1|C++ signature :>>> print fact_usr_off_psig_on_csig_off_1.__doc__.splitlines()[1]fact_usr_off_psig_on_csig_off_1( (int)n) -> int>>> print selected_doc(fact_usr_off_psig_off_csig_on_1,1)|C++ signature :'''def run(args = None):    import sys    import doctest    if args is not None:        sys.argv = args    import docstring_ext    result = doctest.testmod(sys.modules.get(__name__))    import pydoc    import re    docmodule = lambda m: re.sub(".\10", "", pydoc.text.docmodule(m))    try:        print 'printing module help:'        print docmodule(docstring_ext)    except object, x:        print '********* failed **********'        print x        result = list(result)        result[0] += 1        return tuple(result)    return resultif __name__ == '__main__':    print "running..."    import sys    status = run()[0]    if (status == 0): print "Done."    sys.exit(status)

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?