[svn r37912] Made some small changes to the initpkg mechanism so docstrings are, if
provided in the exportdefs, copied to the namespaces (from whereever they come), and added docstrings to all exposed namespaces (except for _thread for now). --HG-- branch : trunk
This commit is contained in:
parent
4791dd6501
commit
7852ead1fe
|
@ -9,8 +9,8 @@ version = "0.8.80-alpha2"
|
||||||
|
|
||||||
initpkg(__name__,
|
initpkg(__name__,
|
||||||
description = "py.test and the py lib",
|
description = "py.test and the py lib",
|
||||||
revision = int('$LastChangedRevision: 37863 $'.split(':')[1][:-1]),
|
revision = int('$LastChangedRevision: 37912 $'.split(':')[1][:-1]),
|
||||||
lastchangedate = '$LastChangedDate: 2007-02-03 13:15:23 +0100 (Sat, 03 Feb 2007) $',
|
lastchangedate = '$LastChangedDate: 2007-02-04 15:27:10 +0100 (Sun, 04 Feb 2007) $',
|
||||||
version = version,
|
version = version,
|
||||||
url = "http://codespeak.net/py",
|
url = "http://codespeak.net/py",
|
||||||
download_url = "http://codespeak.net/download/py/%s.tar.gz" %(version,),
|
download_url = "http://codespeak.net/download/py/%s.tar.gz" %(version,),
|
||||||
|
@ -22,6 +22,7 @@ initpkg(__name__,
|
||||||
|
|
||||||
exportdefs = {
|
exportdefs = {
|
||||||
# helpers for use from test functions or collectors
|
# helpers for use from test functions or collectors
|
||||||
|
'test.__doc__' : ('./test/__init__.py', '__doc__'),
|
||||||
'test.raises' : ('./test/raises.py', 'raises'),
|
'test.raises' : ('./test/raises.py', 'raises'),
|
||||||
'test.deprecated_call' : ('./test/deprecate.py', 'deprecated_call'),
|
'test.deprecated_call' : ('./test/deprecate.py', 'deprecated_call'),
|
||||||
'test.skip' : ('./test/item.py', 'skip'),
|
'test.skip' : ('./test/item.py', 'skip'),
|
||||||
|
@ -52,14 +53,17 @@ initpkg(__name__,
|
||||||
# hook into the top-level standard library
|
# hook into the top-level standard library
|
||||||
'std' : ('./misc/std.py', 'std'),
|
'std' : ('./misc/std.py', 'std'),
|
||||||
|
|
||||||
|
'process.__doc__' : ('./process/__init__.py', '__doc__'),
|
||||||
'process.cmdexec' : ('./process/cmdexec.py', 'cmdexec'),
|
'process.cmdexec' : ('./process/cmdexec.py', 'cmdexec'),
|
||||||
|
|
||||||
# path implementations
|
# path implementation
|
||||||
|
'path.__doc__' : ('./path/__init__.py', '__doc__'),
|
||||||
'path.svnwc' : ('./path/svn/wccommand.py', 'SvnWCCommandPath'),
|
'path.svnwc' : ('./path/svn/wccommand.py', 'SvnWCCommandPath'),
|
||||||
'path.svnurl' : ('./path/svn/urlcommand.py', 'SvnCommandPath'),
|
'path.svnurl' : ('./path/svn/urlcommand.py', 'SvnCommandPath'),
|
||||||
'path.local' : ('./path/local/local.py', 'LocalPath'),
|
'path.local' : ('./path/local/local.py', 'LocalPath'),
|
||||||
|
|
||||||
# some nice slightly magic APIs
|
# some nice slightly magic APIs
|
||||||
|
'magic.__doc__' : ('./magic/__init__.py', '__doc__'),
|
||||||
'magic.greenlet' : ('./magic/greenlet.py', 'greenlet'),
|
'magic.greenlet' : ('./magic/greenlet.py', 'greenlet'),
|
||||||
'magic.invoke' : ('./magic/invoke.py', 'invoke'),
|
'magic.invoke' : ('./magic/invoke.py', 'invoke'),
|
||||||
'magic.revoke' : ('./magic/invoke.py', 'revoke'),
|
'magic.revoke' : ('./magic/invoke.py', 'revoke'),
|
||||||
|
@ -69,6 +73,7 @@ initpkg(__name__,
|
||||||
'magic.AssertionError' : ('./magic/assertion.py', 'AssertionError'),
|
'magic.AssertionError' : ('./magic/assertion.py', 'AssertionError'),
|
||||||
|
|
||||||
# python inspection/code-generation API
|
# python inspection/code-generation API
|
||||||
|
'code.__doc__' : ('./code/__init__.py', '__doc__'),
|
||||||
'code.compile' : ('./code/source.py', 'compile_'),
|
'code.compile' : ('./code/source.py', 'compile_'),
|
||||||
'code.Source' : ('./code/source.py', 'Source'),
|
'code.Source' : ('./code/source.py', 'Source'),
|
||||||
'code.Code' : ('./code/code.py', 'Code'),
|
'code.Code' : ('./code/code.py', 'Code'),
|
||||||
|
@ -77,6 +82,7 @@ initpkg(__name__,
|
||||||
'code.Traceback' : ('./code/traceback2.py', 'Traceback'),
|
'code.Traceback' : ('./code/traceback2.py', 'Traceback'),
|
||||||
|
|
||||||
# backports and additions of builtins
|
# backports and additions of builtins
|
||||||
|
'builtin.__doc__' : ('./builtin/__init__.py', '__doc__'),
|
||||||
'builtin.enumerate' : ('./builtin/enumerate.py', 'enumerate'),
|
'builtin.enumerate' : ('./builtin/enumerate.py', 'enumerate'),
|
||||||
'builtin.reversed' : ('./builtin/reversed.py', 'reversed'),
|
'builtin.reversed' : ('./builtin/reversed.py', 'reversed'),
|
||||||
'builtin.sorted' : ('./builtin/sorted.py', 'sorted'),
|
'builtin.sorted' : ('./builtin/sorted.py', 'sorted'),
|
||||||
|
@ -85,6 +91,7 @@ initpkg(__name__,
|
||||||
'builtin.frozenset' : ('./builtin/set.py', 'frozenset'),
|
'builtin.frozenset' : ('./builtin/set.py', 'frozenset'),
|
||||||
|
|
||||||
# gateways into remote contexts
|
# gateways into remote contexts
|
||||||
|
'execnet.__doc__' : ('./execnet/__init__.py', '__doc__'),
|
||||||
'execnet.SocketGateway' : ('./execnet/register.py', 'SocketGateway'),
|
'execnet.SocketGateway' : ('./execnet/register.py', 'SocketGateway'),
|
||||||
'execnet.PopenGateway' : ('./execnet/register.py', 'PopenGateway'),
|
'execnet.PopenGateway' : ('./execnet/register.py', 'PopenGateway'),
|
||||||
'execnet.SshGateway' : ('./execnet/register.py', 'SshGateway'),
|
'execnet.SshGateway' : ('./execnet/register.py', 'SshGateway'),
|
||||||
|
@ -93,6 +100,7 @@ initpkg(__name__,
|
||||||
'execnet.RSync' : ('./execnet/rsync.py', 'RSync'),
|
'execnet.RSync' : ('./execnet/rsync.py', 'RSync'),
|
||||||
|
|
||||||
# input-output helping
|
# input-output helping
|
||||||
|
'io.__doc__' : ('./io/__init__.py', '__doc__'),
|
||||||
'io.dupfile' : ('./io/dupfile.py', 'dupfile'),
|
'io.dupfile' : ('./io/dupfile.py', 'dupfile'),
|
||||||
'io.FDCapture' : ('./io/fdcapture.py', 'FDCapture'),
|
'io.FDCapture' : ('./io/fdcapture.py', 'FDCapture'),
|
||||||
'io.StdCapture' : ('./io/stdcapture.py', 'StdCapture'),
|
'io.StdCapture' : ('./io/stdcapture.py', 'StdCapture'),
|
||||||
|
@ -102,6 +110,7 @@ initpkg(__name__,
|
||||||
'error' : ('./misc/error.py', 'error'),
|
'error' : ('./misc/error.py', 'error'),
|
||||||
|
|
||||||
# small and mean xml/html generation
|
# small and mean xml/html generation
|
||||||
|
'xml.__doc__' : ('./xmlobj/__init__.py', '__doc__'),
|
||||||
'xml.html' : ('./xmlobj/html.py', 'html'),
|
'xml.html' : ('./xmlobj/html.py', 'html'),
|
||||||
'xml.Tag' : ('./xmlobj/xml.py', 'Tag'),
|
'xml.Tag' : ('./xmlobj/xml.py', 'Tag'),
|
||||||
'xml.raw' : ('./xmlobj/xml.py', 'raw'),
|
'xml.raw' : ('./xmlobj/xml.py', 'raw'),
|
||||||
|
@ -109,6 +118,7 @@ initpkg(__name__,
|
||||||
'xml.escape' : ('./xmlobj/misc.py', 'escape'),
|
'xml.escape' : ('./xmlobj/misc.py', 'escape'),
|
||||||
|
|
||||||
# logging API ('producers' and 'consumers' connected via keywords)
|
# logging API ('producers' and 'consumers' connected via keywords)
|
||||||
|
'log.__doc__' : ('./log/__init__.py', '__doc__'),
|
||||||
'log.Producer' : ('./log/producer.py', 'Producer'),
|
'log.Producer' : ('./log/producer.py', 'Producer'),
|
||||||
'log.default' : ('./log/producer.py', 'default'),
|
'log.default' : ('./log/producer.py', 'default'),
|
||||||
'log._getstate' : ('./log/producer.py', '_getstate'),
|
'log._getstate' : ('./log/producer.py', '_getstate'),
|
||||||
|
@ -121,8 +131,10 @@ initpkg(__name__,
|
||||||
'log.get' : ('./log/logger.py', 'get'),
|
'log.get' : ('./log/logger.py', 'get'),
|
||||||
|
|
||||||
# compatibility modules (taken from 2.4.4)
|
# compatibility modules (taken from 2.4.4)
|
||||||
|
'compat.__doc__' : ('./compat/__init__.py', '__doc__'),
|
||||||
'compat.doctest' : ('./compat/doctest.py', '*'),
|
'compat.doctest' : ('./compat/doctest.py', '*'),
|
||||||
'compat.optparse' : ('./compat/optparse.py', '*'),
|
'compat.optparse' : ('./compat/optparse.py', '*'),
|
||||||
'compat.textwrap' : ('./compat/textwrap.py', '*'),
|
'compat.textwrap' : ('./compat/textwrap.py', '*'),
|
||||||
'compat.subprocess' : ('./compat/subprocess.py', '*'),
|
'compat.subprocess' : ('./compat/subprocess.py', '*'),
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
|
@ -1 +1,2 @@
|
||||||
#
|
""" backports and additions of builtins """
|
||||||
|
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
#
|
""" python inspection/code generation API """
|
||||||
|
|
|
@ -1 +1,2 @@
|
||||||
#
|
""" compatibility modules (taken from 2.4.4) """
|
||||||
|
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
#
|
""" ad-hoc networking mechanism """
|
||||||
|
|
|
@ -258,8 +258,12 @@ def initpkg(pkgname, exportdefs, **kw):
|
||||||
assert mod is pkg.module, \
|
assert mod is pkg.module, \
|
||||||
"only root modules are allowed to be non-lazy. "
|
"only root modules are allowed to be non-lazy. "
|
||||||
deferred_imports.append((mod, pyparts[-1], extpy))
|
deferred_imports.append((mod, pyparts[-1], extpy))
|
||||||
|
else:
|
||||||
|
if extpy[1] == '__doc__':
|
||||||
|
mod.__doc__ = pkg._resolve(extpy)
|
||||||
else:
|
else:
|
||||||
mod.__map__[lastmodpart] = extpy
|
mod.__map__[lastmodpart] = extpy
|
||||||
|
|
||||||
for mod, pypart, extpy in deferred_imports:
|
for mod, pypart, extpy in deferred_imports:
|
||||||
setattr(mod, pypart, pkg._resolve(extpy))
|
setattr(mod, pypart, pkg._resolve(extpy))
|
||||||
|
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
#
|
""" input/output helping """
|
||||||
|
|
|
@ -1 +1,2 @@
|
||||||
#
|
""" logging API ('producers' and 'consumers' connected via keywords) """
|
||||||
|
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
#
|
""" some nice, slightly magic APIs """
|
||||||
|
|
|
@ -2,6 +2,8 @@
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
class Std(object):
|
class Std(object):
|
||||||
|
""" (lazily) hook into the top-level standard library """
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.__dict__ = sys.modules
|
self.__dict__ = sys.modules
|
||||||
|
|
||||||
|
|
|
@ -127,12 +127,15 @@ class TestRealModule:
|
||||||
tfile.write(py.code.Source("""
|
tfile.write(py.code.Source("""
|
||||||
import py
|
import py
|
||||||
py.initpkg('realtest', {
|
py.initpkg('realtest', {
|
||||||
|
'x.module.__doc__': ('./testmodule.py', '__doc__'),
|
||||||
'x.module': ('./testmodule.py', '*'),
|
'x.module': ('./testmodule.py', '*'),
|
||||||
})
|
})
|
||||||
"""))
|
"""))
|
||||||
|
|
||||||
tfile = pkgdir.join('testmodule.py')
|
tfile = pkgdir.join('testmodule.py')
|
||||||
tfile.write(py.code.Source("""
|
tfile.write(py.code.Source("""
|
||||||
|
'test module'
|
||||||
|
|
||||||
__all__ = ['mytest0', 'mytest1', 'MyTest']
|
__all__ = ['mytest0', 'mytest1', 'MyTest']
|
||||||
|
|
||||||
def mytest0():
|
def mytest0():
|
||||||
|
@ -186,6 +189,11 @@ class TestRealModule:
|
||||||
assert 'mytest1' in moddict
|
assert 'mytest1' in moddict
|
||||||
assert 'MyTest' in moddict
|
assert 'MyTest' in moddict
|
||||||
|
|
||||||
|
def test_realmodule___doc__(self):
|
||||||
|
"""test whether the __doc__ attribute is set properly from initpkg"""
|
||||||
|
import realtest.x.module
|
||||||
|
assert realtest.x.module.__doc__ == 'test module'
|
||||||
|
|
||||||
#class TestStdHook:
|
#class TestStdHook:
|
||||||
# """Tests imports for the standard Python library hook."""
|
# """Tests imports for the standard Python library hook."""
|
||||||
#
|
#
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
#
|
""" unified file system api """
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
#
|
""" high-level sub-process handling """
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
#
|
""" versatile unit-testing tool + libraries """
|
||||||
|
|
|
@ -1 +1,2 @@
|
||||||
#
|
""" small and mean xml/html generation """
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue