diff options
author | Lorry Tar Creator <lorry-tar-importer@baserock.org> | 2013-06-25 22:59:01 +0000 |
---|---|---|
committer | <> | 2013-09-27 11:49:28 +0000 |
commit | 8c4528713d907ee2cfd3bfcbbad272c749867f84 (patch) | |
tree | c09e2ce80f47b90c85cc720f5139089ad9c8cfff /libs/python/test/docstring.py | |
download | boost-tarball-baserock/morph.tar.gz |
Imported from /home/lorry/working-area/delta_boost-tarball/boost_1_54_0.tar.bz2.boost_1_54_0baserock/morph
Diffstat (limited to 'libs/python/test/docstring.py')
-rw-r--r-- | libs/python/test/docstring.py | 153 |
1 files changed, 153 insertions, 0 deletions
diff --git a/libs/python/test/docstring.py b/libs/python/test/docstring.py new file mode 100644 index 000000000..528ce8456 --- /dev/null +++ b/libs/python/test/docstring.py @@ -0,0 +1,153 @@ +# 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 result + +if __name__ == '__main__': + print "running..." + import sys + status = run()[0] + if (status == 0): print "Done." + sys.exit(status) |