| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | .. _examples:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ********
 | 
					
						
							|  |  |  | Examples
 | 
					
						
							|  |  |  | ********
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This chapter provides a number of basic examples to help get started with
 | 
					
						
							|  |  |  | distutils.  Additional information about using distutils can be found in the
 | 
					
						
							|  |  |  | Distutils Cookbook.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. seealso::
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-11 14:32:37 +00:00
										 |  |  |    `Distutils Cookbook <http://wiki.python.org/moin/Distutils/Cookbook>`_
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |       Collection of recipes showing how to achieve more control over distutils.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _pure-mod:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Pure Python distribution (by module)
 | 
					
						
							|  |  |  | ====================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If you're just distributing a couple of modules, especially if they don't live
 | 
					
						
							|  |  |  | in a particular package, you can specify them individually using the
 | 
					
						
							|  |  |  | :option:`py_modules` option in the setup script.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | In the simplest case, you'll have two files to worry about: a setup script and
 | 
					
						
							|  |  |  | the single module you're distributing, :file:`foo.py` in this example::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    <root>/
 | 
					
						
							|  |  |  |            setup.py
 | 
					
						
							|  |  |  |            foo.py
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (In all diagrams in this section, *<root>* will refer to the distribution root
 | 
					
						
							|  |  |  | directory.)  A minimal setup script to describe this situation would be::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from distutils.core import setup
 | 
					
						
							|  |  |  |    setup(name='foo',
 | 
					
						
							|  |  |  |          version='1.0',
 | 
					
						
							|  |  |  |          py_modules=['foo'],
 | 
					
						
							|  |  |  |          )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Note that the name of the distribution is specified independently with the
 | 
					
						
							|  |  |  | :option:`name` option, and there's no rule that says it has to be the same as
 | 
					
						
							|  |  |  | the name of the sole module in the distribution (although that's probably a good
 | 
					
						
							|  |  |  | convention to follow).  However, the distribution name is used to generate
 | 
					
						
							|  |  |  | filenames, so you should stick to letters, digits, underscores, and hyphens.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Since :option:`py_modules` is a list, you can of course specify multiple
 | 
					
						
							|  |  |  | modules, eg. if you're distributing modules :mod:`foo` and :mod:`bar`, your
 | 
					
						
							|  |  |  | setup might look like this::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    <root>/
 | 
					
						
							|  |  |  |            setup.py
 | 
					
						
							|  |  |  |            foo.py
 | 
					
						
							|  |  |  |            bar.py
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | and the setup script might be  ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from distutils.core import setup
 | 
					
						
							|  |  |  |    setup(name='foobar',
 | 
					
						
							|  |  |  |          version='1.0',
 | 
					
						
							|  |  |  |          py_modules=['foo', 'bar'],
 | 
					
						
							|  |  |  |          )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | You can put module source files into another directory, but if you have enough
 | 
					
						
							|  |  |  | modules to do that, it's probably easier to specify modules by package rather
 | 
					
						
							|  |  |  | than listing them individually.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _pure-pkg:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Pure Python distribution (by package)
 | 
					
						
							|  |  |  | =====================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If you have more than a couple of modules to distribute, especially if they are
 | 
					
						
							|  |  |  | in multiple packages, it's probably easier to specify whole packages rather than
 | 
					
						
							|  |  |  | individual modules.  This works even if your modules are not in a package; you
 | 
					
						
							|  |  |  | can just tell the Distutils to process modules from the root package, and that
 | 
					
						
							|  |  |  | works the same as any other package (except that you don't have to have an
 | 
					
						
							|  |  |  | :file:`__init__.py` file).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The setup script from the last example could also be written as  ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from distutils.core import setup
 | 
					
						
							|  |  |  |    setup(name='foobar',
 | 
					
						
							|  |  |  |          version='1.0',
 | 
					
						
							|  |  |  |          packages=[''],
 | 
					
						
							|  |  |  |          )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (The empty string stands for the root package.)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If those two files are moved into a subdirectory, but remain in the root
 | 
					
						
							|  |  |  | package, e.g.::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    <root>/
 | 
					
						
							|  |  |  |            setup.py
 | 
					
						
							|  |  |  |            src/      foo.py
 | 
					
						
							|  |  |  |                      bar.py
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | then you would still specify the root package, but you have to tell the
 | 
					
						
							|  |  |  | Distutils where source files in the root package live::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from distutils.core import setup
 | 
					
						
							|  |  |  |    setup(name='foobar',
 | 
					
						
							|  |  |  |          version='1.0',
 | 
					
						
							|  |  |  |          package_dir={'': 'src'},
 | 
					
						
							|  |  |  |          packages=[''],
 | 
					
						
							|  |  |  |          )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | More typically, though, you will want to distribute multiple modules in the same
 | 
					
						
							|  |  |  | package (or in sub-packages).  For example, if the :mod:`foo`  and :mod:`bar`
 | 
					
						
							|  |  |  | modules belong in package :mod:`foobar`, one way to layout your source tree is
 | 
					
						
							|  |  |  | ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    <root>/
 | 
					
						
							|  |  |  |            setup.py
 | 
					
						
							|  |  |  |            foobar/
 | 
					
						
							|  |  |  |                     __init__.py
 | 
					
						
							|  |  |  |                     foo.py
 | 
					
						
							|  |  |  |                     bar.py
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This is in fact the default layout expected by the Distutils, and the one that
 | 
					
						
							|  |  |  | requires the least work to describe in your setup script::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from distutils.core import setup
 | 
					
						
							|  |  |  |    setup(name='foobar',
 | 
					
						
							|  |  |  |          version='1.0',
 | 
					
						
							|  |  |  |          packages=['foobar'],
 | 
					
						
							|  |  |  |          )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If you want to put modules in directories not named for their package, then you
 | 
					
						
							|  |  |  | need to use the :option:`package_dir` option again.  For example, if the
 | 
					
						
							|  |  |  | :file:`src` directory holds modules in the :mod:`foobar` package::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    <root>/
 | 
					
						
							|  |  |  |            setup.py
 | 
					
						
							|  |  |  |            src/
 | 
					
						
							|  |  |  |                     __init__.py
 | 
					
						
							|  |  |  |                     foo.py
 | 
					
						
							|  |  |  |                     bar.py
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | an appropriate setup script would be  ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from distutils.core import setup
 | 
					
						
							|  |  |  |    setup(name='foobar',
 | 
					
						
							|  |  |  |          version='1.0',
 | 
					
						
							|  |  |  |          package_dir={'foobar': 'src'},
 | 
					
						
							|  |  |  |          packages=['foobar'],
 | 
					
						
							|  |  |  |          )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Or, you might put modules from your main package right in the distribution
 | 
					
						
							|  |  |  | root::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    <root>/
 | 
					
						
							|  |  |  |            setup.py
 | 
					
						
							|  |  |  |            __init__.py
 | 
					
						
							|  |  |  |            foo.py
 | 
					
						
							|  |  |  |            bar.py
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | in which case your setup script would be  ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from distutils.core import setup
 | 
					
						
							|  |  |  |    setup(name='foobar',
 | 
					
						
							|  |  |  |          version='1.0',
 | 
					
						
							|  |  |  |          package_dir={'foobar': ''},
 | 
					
						
							|  |  |  |          packages=['foobar'],
 | 
					
						
							|  |  |  |          )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (The empty string also stands for the current directory.)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If you have sub-packages, they must be explicitly listed in :option:`packages`,
 | 
					
						
							|  |  |  | but any entries in :option:`package_dir` automatically extend to sub-packages.
 | 
					
						
							|  |  |  | (In other words, the Distutils does *not* scan your source tree, trying to
 | 
					
						
							|  |  |  | figure out which directories correspond to Python packages by looking for
 | 
					
						
							|  |  |  | :file:`__init__.py` files.)  Thus, if the default layout grows a sub-package::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    <root>/
 | 
					
						
							|  |  |  |            setup.py
 | 
					
						
							|  |  |  |            foobar/
 | 
					
						
							|  |  |  |                     __init__.py
 | 
					
						
							|  |  |  |                     foo.py
 | 
					
						
							|  |  |  |                     bar.py
 | 
					
						
							|  |  |  |                     subfoo/
 | 
					
						
							|  |  |  |                               __init__.py
 | 
					
						
							|  |  |  |                               blah.py
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | then the corresponding setup script would be  ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from distutils.core import setup
 | 
					
						
							|  |  |  |    setup(name='foobar',
 | 
					
						
							|  |  |  |          version='1.0',
 | 
					
						
							|  |  |  |          packages=['foobar', 'foobar.subfoo'],
 | 
					
						
							|  |  |  |          )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (Again, the empty string in :option:`package_dir` stands for the current
 | 
					
						
							|  |  |  | directory.)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _single-ext:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Single extension module
 | 
					
						
							|  |  |  | =======================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Extension modules are specified using the :option:`ext_modules` option.
 | 
					
						
							|  |  |  | :option:`package_dir` has no effect on where extension source files are found;
 | 
					
						
							|  |  |  | it only affects the source for pure Python modules.  The simplest  case, a
 | 
					
						
							|  |  |  | single extension module in a single C source file, is::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    <root>/
 | 
					
						
							|  |  |  |            setup.py
 | 
					
						
							|  |  |  |            foo.c
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If the :mod:`foo` extension belongs in the root package, the setup script for
 | 
					
						
							|  |  |  | this could be  ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from distutils.core import setup
 | 
					
						
							|  |  |  |    from distutils.extension import Extension
 | 
					
						
							|  |  |  |    setup(name='foobar',
 | 
					
						
							|  |  |  |          version='1.0',
 | 
					
						
							|  |  |  |          ext_modules=[Extension('foo', ['foo.c'])],
 | 
					
						
							|  |  |  |          )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If the extension actually belongs in a package, say :mod:`foopkg`, then
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | With exactly the same source tree layout, this extension can be put in the
 | 
					
						
							|  |  |  | :mod:`foopkg` package simply by changing the name of the extension::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from distutils.core import setup
 | 
					
						
							|  |  |  |    from distutils.extension import Extension
 | 
					
						
							|  |  |  |    setup(name='foobar',
 | 
					
						
							|  |  |  |          version='1.0',
 | 
					
						
							|  |  |  |          ext_modules=[Extension('foopkg.foo', ['foo.c'])],
 | 
					
						
							|  |  |  |          )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  | Checking a package
 | 
					
						
							|  |  |  | ==================
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 76235 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
................
  r76235 | benjamin.peterson | 2009-11-12 20:25:08 -0600 (Thu, 12 Nov 2009) | 170 lines
  Merged revisions 75149,75260-75263,75265-75267,75292,75300,75376,75405,75429-75433,75437,75445,75501,75551,75572,75589-75591,75657,75742,75868,75952-75957,76057,76105,76139,76143,76162,76223 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r75149 | gregory.p.smith | 2009-09-29 16:56:31 -0500 (Tue, 29 Sep 2009) | 3 lines
    Mention issue6972 in extractall docs about overwriting things outside of
    the supplied path.
  ........
    r75260 | andrew.kuchling | 2009-10-05 16:24:20 -0500 (Mon, 05 Oct 2009) | 1 line
    Wording fix
  ........
    r75261 | andrew.kuchling | 2009-10-05 16:24:35 -0500 (Mon, 05 Oct 2009) | 1 line
    Fix narkup
  ........
    r75262 | andrew.kuchling | 2009-10-05 16:25:03 -0500 (Mon, 05 Oct 2009) | 1 line
    Document 'skip' parameter to constructor
  ........
    r75263 | andrew.kuchling | 2009-10-05 16:25:35 -0500 (Mon, 05 Oct 2009) | 1 line
    Note side benefit of socket.create_connection()
  ........
    r75265 | andrew.kuchling | 2009-10-05 17:31:11 -0500 (Mon, 05 Oct 2009) | 1 line
    Reword sentence
  ........
    r75266 | andrew.kuchling | 2009-10-05 17:32:48 -0500 (Mon, 05 Oct 2009) | 1 line
    Use standard comma punctuation; reword some sentences in the docs
  ........
    r75267 | andrew.kuchling | 2009-10-05 17:42:56 -0500 (Mon, 05 Oct 2009) | 1 line
    Backport r73983: Document the thousands separator.
  ........
    r75292 | benjamin.peterson | 2009-10-08 22:11:36 -0500 (Thu, 08 Oct 2009) | 1 line
    death to old CVS keyword
  ........
    r75300 | benjamin.peterson | 2009-10-09 16:48:14 -0500 (Fri, 09 Oct 2009) | 1 line
    fix some coding style
  ........
    r75376 | benjamin.peterson | 2009-10-11 20:26:07 -0500 (Sun, 11 Oct 2009) | 1 line
    platform we don't care about
  ........
    r75405 | neil.schemenauer | 2009-10-14 12:17:14 -0500 (Wed, 14 Oct 2009) | 4 lines
    Issue #1754094: Improve the stack depth calculation in the compiler.
    There should be no other effect than a small decrease in memory use.
    Patch by Christopher Tur Lesniewski-Laas.
  ........
    r75429 | benjamin.peterson | 2009-10-14 20:47:28 -0500 (Wed, 14 Oct 2009) | 1 line
    pep8ify if blocks
  ........
    r75430 | benjamin.peterson | 2009-10-14 20:49:37 -0500 (Wed, 14 Oct 2009) | 1 line
    use floor division and add a test that exercises the tabsize codepath
  ........
    r75431 | benjamin.peterson | 2009-10-14 20:56:25 -0500 (Wed, 14 Oct 2009) | 1 line
    change test to what I intended
  ........
    r75432 | benjamin.peterson | 2009-10-14 22:05:39 -0500 (Wed, 14 Oct 2009) | 1 line
    some cleanups
  ........
    r75433 | benjamin.peterson | 2009-10-14 22:06:55 -0500 (Wed, 14 Oct 2009) | 1 line
    make inspect.isabstract() always return a boolean; add a test for it, too #7069
  ........
    r75437 | benjamin.peterson | 2009-10-15 10:44:46 -0500 (Thu, 15 Oct 2009) | 1 line
    only clear a module's __dict__ if the module is the only one with a reference to it #7140
  ........
    r75445 | vinay.sajip | 2009-10-16 09:06:44 -0500 (Fri, 16 Oct 2009) | 1 line
    Issue #7120: logging: Removed import of multiprocessing which is causing crash in GAE.
  ........
    r75501 | antoine.pitrou | 2009-10-18 13:37:11 -0500 (Sun, 18 Oct 2009) | 3 lines
    Add a comment about unreachable code, and fix a typo
  ........
    r75551 | benjamin.peterson | 2009-10-19 22:14:10 -0500 (Mon, 19 Oct 2009) | 1 line
    use property api
  ........
    r75572 | benjamin.peterson | 2009-10-20 16:55:17 -0500 (Tue, 20 Oct 2009) | 1 line
    clarify buffer arg #7178
  ........
    r75589 | benjamin.peterson | 2009-10-21 21:26:47 -0500 (Wed, 21 Oct 2009) | 1 line
    whitespace
  ........
    r75590 | benjamin.peterson | 2009-10-21 21:36:47 -0500 (Wed, 21 Oct 2009) | 1 line
    rewrite to be nice to other implementations
  ........
    r75591 | benjamin.peterson | 2009-10-21 21:50:38 -0500 (Wed, 21 Oct 2009) | 4 lines
    rewrite for style, clarify, and comments
    Also, use the hasattr() like scheme of allowing BaseException exceptions through.
  ........
    r75657 | antoine.pitrou | 2009-10-24 07:41:27 -0500 (Sat, 24 Oct 2009) | 3 lines
    Fix compilation error in debug mode.
  ........
    r75742 | benjamin.peterson | 2009-10-26 17:51:16 -0500 (Mon, 26 Oct 2009) | 1 line
    use 'is' instead of id()
  ........
    r75868 | benjamin.peterson | 2009-10-27 15:59:18 -0500 (Tue, 27 Oct 2009) | 1 line
    test expect base classes
  ........
    r75952 | georg.brandl | 2009-10-29 15:38:32 -0500 (Thu, 29 Oct 2009) | 1 line
    Use the correct function name in docstring.
  ........
    r75953 | georg.brandl | 2009-10-29 15:39:50 -0500 (Thu, 29 Oct 2009) | 1 line
    Remove mention of the old -X command line switch.
  ........
    r75954 | georg.brandl | 2009-10-29 15:53:00 -0500 (Thu, 29 Oct 2009) | 1 line
    Use constants instead of magic integers for test result.  Do not re-run with --verbose3 for environment changing tests.
  ........
    r75955 | georg.brandl | 2009-10-29 15:54:03 -0500 (Thu, 29 Oct 2009) | 1 line
    Use a single style for all the docstrings in the math module.
  ........
    r75956 | georg.brandl | 2009-10-29 16:16:34 -0500 (Thu, 29 Oct 2009) | 1 line
    I do not think the "railroad" program mentioned is still available.
  ........
    r75957 | georg.brandl | 2009-10-29 16:44:56 -0500 (Thu, 29 Oct 2009) | 1 line
    Fix constant name.
  ........
    r76057 | benjamin.peterson | 2009-11-02 09:06:45 -0600 (Mon, 02 Nov 2009) | 1 line
    prevent a rather unlikely segfault
  ........
    r76105 | georg.brandl | 2009-11-04 01:38:12 -0600 (Wed, 04 Nov 2009) | 1 line
    #7259: show correct equivalent for operator.i* operations in docstring; fix minor issues in operator docs.
  ........
    r76139 | benjamin.peterson | 2009-11-06 19:04:38 -0600 (Fri, 06 Nov 2009) | 1 line
    spelling
  ........
    r76143 | georg.brandl | 2009-11-07 02:26:07 -0600 (Sat, 07 Nov 2009) | 1 line
    #7271: fix typo.
  ........
    r76162 | benjamin.peterson | 2009-11-08 22:10:53 -0600 (Sun, 08 Nov 2009) | 1 line
    discuss how to use -p
  ........
    r76223 | georg.brandl | 2009-11-12 02:29:46 -0600 (Thu, 12 Nov 2009) | 1 line
    Give the profile module a module directive.
  ........
................
											
										 
											2009-11-13 02:29:35 +00:00
										 |  |  | The ``check`` command allows you to verify if your package meta-data
 | 
					
						
							|  |  |  | meet the minimum requirements to build a distribution.
 | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 76235 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
................
  r76235 | benjamin.peterson | 2009-11-12 20:25:08 -0600 (Thu, 12 Nov 2009) | 170 lines
  Merged revisions 75149,75260-75263,75265-75267,75292,75300,75376,75405,75429-75433,75437,75445,75501,75551,75572,75589-75591,75657,75742,75868,75952-75957,76057,76105,76139,76143,76162,76223 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r75149 | gregory.p.smith | 2009-09-29 16:56:31 -0500 (Tue, 29 Sep 2009) | 3 lines
    Mention issue6972 in extractall docs about overwriting things outside of
    the supplied path.
  ........
    r75260 | andrew.kuchling | 2009-10-05 16:24:20 -0500 (Mon, 05 Oct 2009) | 1 line
    Wording fix
  ........
    r75261 | andrew.kuchling | 2009-10-05 16:24:35 -0500 (Mon, 05 Oct 2009) | 1 line
    Fix narkup
  ........
    r75262 | andrew.kuchling | 2009-10-05 16:25:03 -0500 (Mon, 05 Oct 2009) | 1 line
    Document 'skip' parameter to constructor
  ........
    r75263 | andrew.kuchling | 2009-10-05 16:25:35 -0500 (Mon, 05 Oct 2009) | 1 line
    Note side benefit of socket.create_connection()
  ........
    r75265 | andrew.kuchling | 2009-10-05 17:31:11 -0500 (Mon, 05 Oct 2009) | 1 line
    Reword sentence
  ........
    r75266 | andrew.kuchling | 2009-10-05 17:32:48 -0500 (Mon, 05 Oct 2009) | 1 line
    Use standard comma punctuation; reword some sentences in the docs
  ........
    r75267 | andrew.kuchling | 2009-10-05 17:42:56 -0500 (Mon, 05 Oct 2009) | 1 line
    Backport r73983: Document the thousands separator.
  ........
    r75292 | benjamin.peterson | 2009-10-08 22:11:36 -0500 (Thu, 08 Oct 2009) | 1 line
    death to old CVS keyword
  ........
    r75300 | benjamin.peterson | 2009-10-09 16:48:14 -0500 (Fri, 09 Oct 2009) | 1 line
    fix some coding style
  ........
    r75376 | benjamin.peterson | 2009-10-11 20:26:07 -0500 (Sun, 11 Oct 2009) | 1 line
    platform we don't care about
  ........
    r75405 | neil.schemenauer | 2009-10-14 12:17:14 -0500 (Wed, 14 Oct 2009) | 4 lines
    Issue #1754094: Improve the stack depth calculation in the compiler.
    There should be no other effect than a small decrease in memory use.
    Patch by Christopher Tur Lesniewski-Laas.
  ........
    r75429 | benjamin.peterson | 2009-10-14 20:47:28 -0500 (Wed, 14 Oct 2009) | 1 line
    pep8ify if blocks
  ........
    r75430 | benjamin.peterson | 2009-10-14 20:49:37 -0500 (Wed, 14 Oct 2009) | 1 line
    use floor division and add a test that exercises the tabsize codepath
  ........
    r75431 | benjamin.peterson | 2009-10-14 20:56:25 -0500 (Wed, 14 Oct 2009) | 1 line
    change test to what I intended
  ........
    r75432 | benjamin.peterson | 2009-10-14 22:05:39 -0500 (Wed, 14 Oct 2009) | 1 line
    some cleanups
  ........
    r75433 | benjamin.peterson | 2009-10-14 22:06:55 -0500 (Wed, 14 Oct 2009) | 1 line
    make inspect.isabstract() always return a boolean; add a test for it, too #7069
  ........
    r75437 | benjamin.peterson | 2009-10-15 10:44:46 -0500 (Thu, 15 Oct 2009) | 1 line
    only clear a module's __dict__ if the module is the only one with a reference to it #7140
  ........
    r75445 | vinay.sajip | 2009-10-16 09:06:44 -0500 (Fri, 16 Oct 2009) | 1 line
    Issue #7120: logging: Removed import of multiprocessing which is causing crash in GAE.
  ........
    r75501 | antoine.pitrou | 2009-10-18 13:37:11 -0500 (Sun, 18 Oct 2009) | 3 lines
    Add a comment about unreachable code, and fix a typo
  ........
    r75551 | benjamin.peterson | 2009-10-19 22:14:10 -0500 (Mon, 19 Oct 2009) | 1 line
    use property api
  ........
    r75572 | benjamin.peterson | 2009-10-20 16:55:17 -0500 (Tue, 20 Oct 2009) | 1 line
    clarify buffer arg #7178
  ........
    r75589 | benjamin.peterson | 2009-10-21 21:26:47 -0500 (Wed, 21 Oct 2009) | 1 line
    whitespace
  ........
    r75590 | benjamin.peterson | 2009-10-21 21:36:47 -0500 (Wed, 21 Oct 2009) | 1 line
    rewrite to be nice to other implementations
  ........
    r75591 | benjamin.peterson | 2009-10-21 21:50:38 -0500 (Wed, 21 Oct 2009) | 4 lines
    rewrite for style, clarify, and comments
    Also, use the hasattr() like scheme of allowing BaseException exceptions through.
  ........
    r75657 | antoine.pitrou | 2009-10-24 07:41:27 -0500 (Sat, 24 Oct 2009) | 3 lines
    Fix compilation error in debug mode.
  ........
    r75742 | benjamin.peterson | 2009-10-26 17:51:16 -0500 (Mon, 26 Oct 2009) | 1 line
    use 'is' instead of id()
  ........
    r75868 | benjamin.peterson | 2009-10-27 15:59:18 -0500 (Tue, 27 Oct 2009) | 1 line
    test expect base classes
  ........
    r75952 | georg.brandl | 2009-10-29 15:38:32 -0500 (Thu, 29 Oct 2009) | 1 line
    Use the correct function name in docstring.
  ........
    r75953 | georg.brandl | 2009-10-29 15:39:50 -0500 (Thu, 29 Oct 2009) | 1 line
    Remove mention of the old -X command line switch.
  ........
    r75954 | georg.brandl | 2009-10-29 15:53:00 -0500 (Thu, 29 Oct 2009) | 1 line
    Use constants instead of magic integers for test result.  Do not re-run with --verbose3 for environment changing tests.
  ........
    r75955 | georg.brandl | 2009-10-29 15:54:03 -0500 (Thu, 29 Oct 2009) | 1 line
    Use a single style for all the docstrings in the math module.
  ........
    r75956 | georg.brandl | 2009-10-29 16:16:34 -0500 (Thu, 29 Oct 2009) | 1 line
    I do not think the "railroad" program mentioned is still available.
  ........
    r75957 | georg.brandl | 2009-10-29 16:44:56 -0500 (Thu, 29 Oct 2009) | 1 line
    Fix constant name.
  ........
    r76057 | benjamin.peterson | 2009-11-02 09:06:45 -0600 (Mon, 02 Nov 2009) | 1 line
    prevent a rather unlikely segfault
  ........
    r76105 | georg.brandl | 2009-11-04 01:38:12 -0600 (Wed, 04 Nov 2009) | 1 line
    #7259: show correct equivalent for operator.i* operations in docstring; fix minor issues in operator docs.
  ........
    r76139 | benjamin.peterson | 2009-11-06 19:04:38 -0600 (Fri, 06 Nov 2009) | 1 line
    spelling
  ........
    r76143 | georg.brandl | 2009-11-07 02:26:07 -0600 (Sat, 07 Nov 2009) | 1 line
    #7271: fix typo.
  ........
    r76162 | benjamin.peterson | 2009-11-08 22:10:53 -0600 (Sun, 08 Nov 2009) | 1 line
    discuss how to use -p
  ........
    r76223 | georg.brandl | 2009-11-12 02:29:46 -0600 (Thu, 12 Nov 2009) | 1 line
    Give the profile module a module directive.
  ........
................
											
										 
											2009-11-13 02:29:35 +00:00
										 |  |  | To run it, just call it using your :file:`setup.py` script. If something is
 | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  | missing, ``check`` will display a warning.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Let's take an example with a simple script::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     from distutils.core import setup
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     setup(name='foobar')
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Running the ``check`` command will display some warnings::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $ python setup.py check
 | 
					
						
							|  |  |  |     running check
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 76235 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
................
  r76235 | benjamin.peterson | 2009-11-12 20:25:08 -0600 (Thu, 12 Nov 2009) | 170 lines
  Merged revisions 75149,75260-75263,75265-75267,75292,75300,75376,75405,75429-75433,75437,75445,75501,75551,75572,75589-75591,75657,75742,75868,75952-75957,76057,76105,76139,76143,76162,76223 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r75149 | gregory.p.smith | 2009-09-29 16:56:31 -0500 (Tue, 29 Sep 2009) | 3 lines
    Mention issue6972 in extractall docs about overwriting things outside of
    the supplied path.
  ........
    r75260 | andrew.kuchling | 2009-10-05 16:24:20 -0500 (Mon, 05 Oct 2009) | 1 line
    Wording fix
  ........
    r75261 | andrew.kuchling | 2009-10-05 16:24:35 -0500 (Mon, 05 Oct 2009) | 1 line
    Fix narkup
  ........
    r75262 | andrew.kuchling | 2009-10-05 16:25:03 -0500 (Mon, 05 Oct 2009) | 1 line
    Document 'skip' parameter to constructor
  ........
    r75263 | andrew.kuchling | 2009-10-05 16:25:35 -0500 (Mon, 05 Oct 2009) | 1 line
    Note side benefit of socket.create_connection()
  ........
    r75265 | andrew.kuchling | 2009-10-05 17:31:11 -0500 (Mon, 05 Oct 2009) | 1 line
    Reword sentence
  ........
    r75266 | andrew.kuchling | 2009-10-05 17:32:48 -0500 (Mon, 05 Oct 2009) | 1 line
    Use standard comma punctuation; reword some sentences in the docs
  ........
    r75267 | andrew.kuchling | 2009-10-05 17:42:56 -0500 (Mon, 05 Oct 2009) | 1 line
    Backport r73983: Document the thousands separator.
  ........
    r75292 | benjamin.peterson | 2009-10-08 22:11:36 -0500 (Thu, 08 Oct 2009) | 1 line
    death to old CVS keyword
  ........
    r75300 | benjamin.peterson | 2009-10-09 16:48:14 -0500 (Fri, 09 Oct 2009) | 1 line
    fix some coding style
  ........
    r75376 | benjamin.peterson | 2009-10-11 20:26:07 -0500 (Sun, 11 Oct 2009) | 1 line
    platform we don't care about
  ........
    r75405 | neil.schemenauer | 2009-10-14 12:17:14 -0500 (Wed, 14 Oct 2009) | 4 lines
    Issue #1754094: Improve the stack depth calculation in the compiler.
    There should be no other effect than a small decrease in memory use.
    Patch by Christopher Tur Lesniewski-Laas.
  ........
    r75429 | benjamin.peterson | 2009-10-14 20:47:28 -0500 (Wed, 14 Oct 2009) | 1 line
    pep8ify if blocks
  ........
    r75430 | benjamin.peterson | 2009-10-14 20:49:37 -0500 (Wed, 14 Oct 2009) | 1 line
    use floor division and add a test that exercises the tabsize codepath
  ........
    r75431 | benjamin.peterson | 2009-10-14 20:56:25 -0500 (Wed, 14 Oct 2009) | 1 line
    change test to what I intended
  ........
    r75432 | benjamin.peterson | 2009-10-14 22:05:39 -0500 (Wed, 14 Oct 2009) | 1 line
    some cleanups
  ........
    r75433 | benjamin.peterson | 2009-10-14 22:06:55 -0500 (Wed, 14 Oct 2009) | 1 line
    make inspect.isabstract() always return a boolean; add a test for it, too #7069
  ........
    r75437 | benjamin.peterson | 2009-10-15 10:44:46 -0500 (Thu, 15 Oct 2009) | 1 line
    only clear a module's __dict__ if the module is the only one with a reference to it #7140
  ........
    r75445 | vinay.sajip | 2009-10-16 09:06:44 -0500 (Fri, 16 Oct 2009) | 1 line
    Issue #7120: logging: Removed import of multiprocessing which is causing crash in GAE.
  ........
    r75501 | antoine.pitrou | 2009-10-18 13:37:11 -0500 (Sun, 18 Oct 2009) | 3 lines
    Add a comment about unreachable code, and fix a typo
  ........
    r75551 | benjamin.peterson | 2009-10-19 22:14:10 -0500 (Mon, 19 Oct 2009) | 1 line
    use property api
  ........
    r75572 | benjamin.peterson | 2009-10-20 16:55:17 -0500 (Tue, 20 Oct 2009) | 1 line
    clarify buffer arg #7178
  ........
    r75589 | benjamin.peterson | 2009-10-21 21:26:47 -0500 (Wed, 21 Oct 2009) | 1 line
    whitespace
  ........
    r75590 | benjamin.peterson | 2009-10-21 21:36:47 -0500 (Wed, 21 Oct 2009) | 1 line
    rewrite to be nice to other implementations
  ........
    r75591 | benjamin.peterson | 2009-10-21 21:50:38 -0500 (Wed, 21 Oct 2009) | 4 lines
    rewrite for style, clarify, and comments
    Also, use the hasattr() like scheme of allowing BaseException exceptions through.
  ........
    r75657 | antoine.pitrou | 2009-10-24 07:41:27 -0500 (Sat, 24 Oct 2009) | 3 lines
    Fix compilation error in debug mode.
  ........
    r75742 | benjamin.peterson | 2009-10-26 17:51:16 -0500 (Mon, 26 Oct 2009) | 1 line
    use 'is' instead of id()
  ........
    r75868 | benjamin.peterson | 2009-10-27 15:59:18 -0500 (Tue, 27 Oct 2009) | 1 line
    test expect base classes
  ........
    r75952 | georg.brandl | 2009-10-29 15:38:32 -0500 (Thu, 29 Oct 2009) | 1 line
    Use the correct function name in docstring.
  ........
    r75953 | georg.brandl | 2009-10-29 15:39:50 -0500 (Thu, 29 Oct 2009) | 1 line
    Remove mention of the old -X command line switch.
  ........
    r75954 | georg.brandl | 2009-10-29 15:53:00 -0500 (Thu, 29 Oct 2009) | 1 line
    Use constants instead of magic integers for test result.  Do not re-run with --verbose3 for environment changing tests.
  ........
    r75955 | georg.brandl | 2009-10-29 15:54:03 -0500 (Thu, 29 Oct 2009) | 1 line
    Use a single style for all the docstrings in the math module.
  ........
    r75956 | georg.brandl | 2009-10-29 16:16:34 -0500 (Thu, 29 Oct 2009) | 1 line
    I do not think the "railroad" program mentioned is still available.
  ........
    r75957 | georg.brandl | 2009-10-29 16:44:56 -0500 (Thu, 29 Oct 2009) | 1 line
    Fix constant name.
  ........
    r76057 | benjamin.peterson | 2009-11-02 09:06:45 -0600 (Mon, 02 Nov 2009) | 1 line
    prevent a rather unlikely segfault
  ........
    r76105 | georg.brandl | 2009-11-04 01:38:12 -0600 (Wed, 04 Nov 2009) | 1 line
    #7259: show correct equivalent for operator.i* operations in docstring; fix minor issues in operator docs.
  ........
    r76139 | benjamin.peterson | 2009-11-06 19:04:38 -0600 (Fri, 06 Nov 2009) | 1 line
    spelling
  ........
    r76143 | georg.brandl | 2009-11-07 02:26:07 -0600 (Sat, 07 Nov 2009) | 1 line
    #7271: fix typo.
  ........
    r76162 | benjamin.peterson | 2009-11-08 22:10:53 -0600 (Sun, 08 Nov 2009) | 1 line
    discuss how to use -p
  ........
    r76223 | georg.brandl | 2009-11-12 02:29:46 -0600 (Thu, 12 Nov 2009) | 1 line
    Give the profile module a module directive.
  ........
................
											
										 
											2009-11-13 02:29:35 +00:00
										 |  |  |     warning: check: missing required meta-data: version, url
 | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  |     warning: check: missing meta-data: either (author and author_email) or
 | 
					
						
							|  |  |  |              (maintainer and maintainer_email) must be supplied
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 77236,77383,77399,77857,78238,78861-78862,78958 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k
................
  r77236 | georg.brandl | 2010-01-02 15:51:12 +0100 (Sa, 02 Jan 2010) | 1 line
  #7592: remove duplicate description.
................
  r77383 | georg.brandl | 2010-01-09 10:48:46 +0100 (Sa, 09 Jan 2010) | 9 lines
  Merged revisions 77382 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r77382 | georg.brandl | 2010-01-09 10:47:11 +0100 (Sa, 09 Jan 2010) | 1 line
    #7422: make it clear that getargspec() only works on Python functions.
  ........
................
  r77399 | georg.brandl | 2010-01-09 23:39:42 +0100 (Sa, 09 Jan 2010) | 1 line
  Remove redundant brackets in signatures.
................
  r77857 | georg.brandl | 2010-01-30 18:54:04 +0100 (Sa, 30 Jan 2010) | 1 line
  #7814: fix wrong example function usage.
................
  r78238 | georg.brandl | 2010-02-19 10:10:15 +0100 (Fr, 19 Feb 2010) | 1 line
  #5341: fix parenthesis placement.
................
  r78861 | georg.brandl | 2010-03-12 11:04:37 +0100 (Fr, 12 Mär 2010) | 1 line
  Make tool compatible with 2.x and 3.x.
................
  r78862 | georg.brandl | 2010-03-12 11:06:40 +0100 (Fr, 12 Mär 2010) | 13 lines
  Merged revisions 78859-78860 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r78859 | georg.brandl | 2010-03-12 10:57:43 +0100 (Fr, 12 Mär 2010) | 1 line
    Get rid of backticks.
  ........
    r78860 | georg.brandl | 2010-03-12 11:02:03 +0100 (Fr, 12 Mär 2010) | 1 line
    Fix warnings from "make check".
  ........
................
  r78958 | georg.brandl | 2010-03-14 11:51:01 +0100 (So, 14 Mär 2010) | 37 lines
  Merged revisions 78101,78115,78117,78182,78188,78245,78386,78496 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r78101 | georg.brandl | 2010-02-08 01:04:54 +0100 (Mo, 08 Feb 2010) | 1 line
    Fix test_fnmatch.
  ........
    r78115 | georg.brandl | 2010-02-08 23:40:51 +0100 (Mo, 08 Feb 2010) | 1 line
    Fix missing string formatting placeholder.
  ........
    r78117 | georg.brandl | 2010-02-08 23:48:37 +0100 (Mo, 08 Feb 2010) | 1 line
    Convert test failure from output-producing to self.fail().
  ........
    r78182 | georg.brandl | 2010-02-14 09:18:23 +0100 (So, 14 Feb 2010) | 1 line
    #7926: fix stray parens.
  ........
    r78188 | georg.brandl | 2010-02-14 14:38:12 +0100 (So, 14 Feb 2010) | 1 line
    #7926: fix-up wording.
  ........
    r78245 | georg.brandl | 2010-02-19 20:36:08 +0100 (Fr, 19 Feb 2010) | 1 line
    #7967: PyXML is no more.
  ........
    r78386 | georg.brandl | 2010-02-23 22:48:57 +0100 (Di, 23 Feb 2010) | 1 line
    #6544: fix refleak in kqueue, occurring in certain error conditions.
  ........
    r78496 | georg.brandl | 2010-02-27 15:58:08 +0100 (Sa, 27 Feb 2010) | 1 line
    Link to http://www.python.org/dev/workflow/ from bugs page.
  ........
................
											
										 
											2010-10-06 07:55:35 +00:00
										 |  |  | If you use the reStructuredText syntax in the ``long_description`` field and
 | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  | `docutils <http://docutils.sourceforge.net/>`_ is installed you can check if
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 77236,77383,77399,77857,78238,78861-78862,78958 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k
................
  r77236 | georg.brandl | 2010-01-02 15:51:12 +0100 (Sa, 02 Jan 2010) | 1 line
  #7592: remove duplicate description.
................
  r77383 | georg.brandl | 2010-01-09 10:48:46 +0100 (Sa, 09 Jan 2010) | 9 lines
  Merged revisions 77382 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r77382 | georg.brandl | 2010-01-09 10:47:11 +0100 (Sa, 09 Jan 2010) | 1 line
    #7422: make it clear that getargspec() only works on Python functions.
  ........
................
  r77399 | georg.brandl | 2010-01-09 23:39:42 +0100 (Sa, 09 Jan 2010) | 1 line
  Remove redundant brackets in signatures.
................
  r77857 | georg.brandl | 2010-01-30 18:54:04 +0100 (Sa, 30 Jan 2010) | 1 line
  #7814: fix wrong example function usage.
................
  r78238 | georg.brandl | 2010-02-19 10:10:15 +0100 (Fr, 19 Feb 2010) | 1 line
  #5341: fix parenthesis placement.
................
  r78861 | georg.brandl | 2010-03-12 11:04:37 +0100 (Fr, 12 Mär 2010) | 1 line
  Make tool compatible with 2.x and 3.x.
................
  r78862 | georg.brandl | 2010-03-12 11:06:40 +0100 (Fr, 12 Mär 2010) | 13 lines
  Merged revisions 78859-78860 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r78859 | georg.brandl | 2010-03-12 10:57:43 +0100 (Fr, 12 Mär 2010) | 1 line
    Get rid of backticks.
  ........
    r78860 | georg.brandl | 2010-03-12 11:02:03 +0100 (Fr, 12 Mär 2010) | 1 line
    Fix warnings from "make check".
  ........
................
  r78958 | georg.brandl | 2010-03-14 11:51:01 +0100 (So, 14 Mär 2010) | 37 lines
  Merged revisions 78101,78115,78117,78182,78188,78245,78386,78496 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r78101 | georg.brandl | 2010-02-08 01:04:54 +0100 (Mo, 08 Feb 2010) | 1 line
    Fix test_fnmatch.
  ........
    r78115 | georg.brandl | 2010-02-08 23:40:51 +0100 (Mo, 08 Feb 2010) | 1 line
    Fix missing string formatting placeholder.
  ........
    r78117 | georg.brandl | 2010-02-08 23:48:37 +0100 (Mo, 08 Feb 2010) | 1 line
    Convert test failure from output-producing to self.fail().
  ........
    r78182 | georg.brandl | 2010-02-14 09:18:23 +0100 (So, 14 Feb 2010) | 1 line
    #7926: fix stray parens.
  ........
    r78188 | georg.brandl | 2010-02-14 14:38:12 +0100 (So, 14 Feb 2010) | 1 line
    #7926: fix-up wording.
  ........
    r78245 | georg.brandl | 2010-02-19 20:36:08 +0100 (Fr, 19 Feb 2010) | 1 line
    #7967: PyXML is no more.
  ........
    r78386 | georg.brandl | 2010-02-23 22:48:57 +0100 (Di, 23 Feb 2010) | 1 line
    #6544: fix refleak in kqueue, occurring in certain error conditions.
  ........
    r78496 | georg.brandl | 2010-02-27 15:58:08 +0100 (Sa, 27 Feb 2010) | 1 line
    Link to http://www.python.org/dev/workflow/ from bugs page.
  ........
................
											
										 
											2010-10-06 07:55:35 +00:00
										 |  |  | the syntax is fine with the ``check`` command, using the ``restructuredtext``
 | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  | option.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | For example, if the :file:`setup.py` script is changed like this::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     from distutils.core import setup
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     desc = """\
 | 
					
						
							|  |  |  |     My description
 | 
					
						
							|  |  |  |     =============
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     This is the description of the ``foobar`` package.
 | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     setup(name='foobar', version='1', author='tarek',
 | 
					
						
							|  |  |  |         author_email='tarek@ziade.org',
 | 
					
						
							|  |  |  |         url='http://example.com', long_description=desc)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Where the long description is broken, ``check`` will be able to detect it
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 77236,77383,77399,77857,78238,78861-78862,78958 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k
................
  r77236 | georg.brandl | 2010-01-02 15:51:12 +0100 (Sa, 02 Jan 2010) | 1 line
  #7592: remove duplicate description.
................
  r77383 | georg.brandl | 2010-01-09 10:48:46 +0100 (Sa, 09 Jan 2010) | 9 lines
  Merged revisions 77382 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r77382 | georg.brandl | 2010-01-09 10:47:11 +0100 (Sa, 09 Jan 2010) | 1 line
    #7422: make it clear that getargspec() only works on Python functions.
  ........
................
  r77399 | georg.brandl | 2010-01-09 23:39:42 +0100 (Sa, 09 Jan 2010) | 1 line
  Remove redundant brackets in signatures.
................
  r77857 | georg.brandl | 2010-01-30 18:54:04 +0100 (Sa, 30 Jan 2010) | 1 line
  #7814: fix wrong example function usage.
................
  r78238 | georg.brandl | 2010-02-19 10:10:15 +0100 (Fr, 19 Feb 2010) | 1 line
  #5341: fix parenthesis placement.
................
  r78861 | georg.brandl | 2010-03-12 11:04:37 +0100 (Fr, 12 Mär 2010) | 1 line
  Make tool compatible with 2.x and 3.x.
................
  r78862 | georg.brandl | 2010-03-12 11:06:40 +0100 (Fr, 12 Mär 2010) | 13 lines
  Merged revisions 78859-78860 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r78859 | georg.brandl | 2010-03-12 10:57:43 +0100 (Fr, 12 Mär 2010) | 1 line
    Get rid of backticks.
  ........
    r78860 | georg.brandl | 2010-03-12 11:02:03 +0100 (Fr, 12 Mär 2010) | 1 line
    Fix warnings from "make check".
  ........
................
  r78958 | georg.brandl | 2010-03-14 11:51:01 +0100 (So, 14 Mär 2010) | 37 lines
  Merged revisions 78101,78115,78117,78182,78188,78245,78386,78496 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r78101 | georg.brandl | 2010-02-08 01:04:54 +0100 (Mo, 08 Feb 2010) | 1 line
    Fix test_fnmatch.
  ........
    r78115 | georg.brandl | 2010-02-08 23:40:51 +0100 (Mo, 08 Feb 2010) | 1 line
    Fix missing string formatting placeholder.
  ........
    r78117 | georg.brandl | 2010-02-08 23:48:37 +0100 (Mo, 08 Feb 2010) | 1 line
    Convert test failure from output-producing to self.fail().
  ........
    r78182 | georg.brandl | 2010-02-14 09:18:23 +0100 (So, 14 Feb 2010) | 1 line
    #7926: fix stray parens.
  ........
    r78188 | georg.brandl | 2010-02-14 14:38:12 +0100 (So, 14 Feb 2010) | 1 line
    #7926: fix-up wording.
  ........
    r78245 | georg.brandl | 2010-02-19 20:36:08 +0100 (Fr, 19 Feb 2010) | 1 line
    #7967: PyXML is no more.
  ........
    r78386 | georg.brandl | 2010-02-23 22:48:57 +0100 (Di, 23 Feb 2010) | 1 line
    #6544: fix refleak in kqueue, occurring in certain error conditions.
  ........
    r78496 | georg.brandl | 2010-02-27 15:58:08 +0100 (Sa, 27 Feb 2010) | 1 line
    Link to http://www.python.org/dev/workflow/ from bugs page.
  ........
................
											
										 
											2010-10-06 07:55:35 +00:00
										 |  |  | by using the :mod:`docutils` parser::
 | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-22 21:27:10 +02:00
										 |  |  |     $ python setup.py check --restructuredtext
 | 
					
						
							| 
									
										
										
										
											2009-04-11 15:00:43 +00:00
										 |  |  |     running check
 | 
					
						
							|  |  |  |     warning: check: Title underline too short. (line 2)
 | 
					
						
							|  |  |  |     warning: check: Could not finish the parsing.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | .. % \section{Multiple extension modules}
 | 
					
						
							|  |  |  | .. % \label{multiple-ext}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. % \section{Putting it all together}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |