[py-svn] r20355 - py/branch/setup

jan at codespeak.net jan at codespeak.net
Mon Nov 28 14:57:13 CET 2005


Author: jan
Date: Mon Nov 28 14:57:12 2005
New Revision: 20355

Added:
   py/branch/setup/
      - copied from r20353, py/dist/
   py/branch/setup/finddata.py
Modified:
   py/branch/setup/setup.py
Log:
Branch for moving py-lib to setuptools
Ian Bicking submitted setup.py and finddata.py



Added: py/branch/setup/finddata.py
==============================================================================
--- (empty file)
+++ py/branch/setup/finddata.py	Mon Nov 28 14:57:12 2005
@@ -0,0 +1,96 @@
+# Note: you may want to copy this into your setup.py file verbatim, as
+# you can't import this from another package, when you don't know if
+# that package is installed yet.
+
+import os
+import sys
+from fnmatch import fnmatchcase
+from distutils.util import convert_path
+
+# Provided as an attribute, so you can append to these instead
+# of replicating them:
+standard_exclude = ('*.py', '*.pyc', '*~', '.*', '*.bak')
+standard_exclude_directories = ('.*', 'CVS', '_darcs', './build',
+                                './dist', 'EGG-INFO', '*.egg-info')
+
+def find_package_data(
+    where='.', package='',
+    exclude=standard_exclude,
+    exclude_directories=standard_exclude_directories,
+    only_in_packages=True,
+    show_ignored=False):
+    """
+    Return a dictionary suitable for use in ``package_data``
+    in a distutils ``setup.py`` file.
+
+    The dictionary looks like::
+
+        {'package': [files]}
+
+    Where ``files`` is a list of all the files in that package that
+    don't match anything in ``exclude``.
+
+    If ``only_in_packages`` is true, then top-level directories that
+    are not packages won't be included (but directories under packages
+    will).
+
+    Directories matching any pattern in ``exclude_directories`` will
+    be ignored; by default directories with leading ``.``, ``CVS``,
+    and ``_darcs`` will be ignored.
+
+    If ``show_ignored`` is true, then all the files that aren't
+    included in package data are shown on stderr (for debugging
+    purposes).
+
+    Note patterns use wildcards, or can be exact paths (including
+    leading ``./``), and all searching is case-insensitive.
+    """
+    
+    out = {}
+    stack = [(convert_path(where), '', package, only_in_packages)]
+    while stack:
+        where, prefix, package, only_in_packages = stack.pop(0)
+        for name in os.listdir(where):
+            fn = os.path.join(where, name)
+            if os.path.isdir(fn):
+                bad_name = False
+                for pattern in exclude_directories:
+                    if (fnmatchcase(name, pattern)
+                        or fn.lower() == pattern.lower()):
+                        bad_name = True
+                        if show_ignored:
+                            print >> sys.stderr, (
+                                "Directory %s ignored by pattern %s"
+                                % (fn, pattern))
+                        break
+                if bad_name:
+                    continue
+                if os.path.isfile(os.path.join(fn, '__init__.py')):
+                    if not package:
+                        new_package = name
+                    else:
+                        new_package = package + '.' + name
+                    stack.append((fn, '', new_package, False))
+                else:
+                    stack.append((fn, prefix + name + '/', package, only_in_packages))
+            elif package or not only_in_packages:
+                # is a file
+                bad_name = False
+                for pattern in exclude:
+                    if (fnmatchcase(name, pattern)
+                        or fn.lower() == pattern.lower()):
+                        bad_name = True
+                        if show_ignored:
+                            print >> sys.stderr, (
+                                "File %s ignored by pattern %s"
+                                % (fn, pattern))
+                        break
+                if bad_name:
+                    continue
+                out.setdefault(package, []).append(prefix+name)
+    return out
+
+if __name__ == '__main__':
+    import pprint
+    pprint.pprint(
+        find_package_data(show_ignored=True))

Modified: py/branch/setup/setup.py
==============================================================================
--- py/dist/setup.py	(original)
+++ py/branch/setup/setup.py	Mon Nov 28 14:57:12 2005
@@ -1,2 +1,27 @@
-import py 
-py._dist.setup(py) 
+from setuptools import setup, find_packages
+from finddata import find_package_data
+
+setup(
+    name="py",
+    version="0.8.0-alpha2",
+    description="py.test and the py lib",
+    long_description="""\
+The py lib is a development support library featuring
+py.test, an interactive testing tool which supports
+unit-testing with practically no boilerplate.""",
+    url="http://codespeak.net/py",
+    author="Holger Krekel & others",
+    author_email="hpk at merlinux.de",
+    license="MIT license",
+    download_url="http://codespeak.net/download/py/py-0.8.0-alpha2.tar.gz",
+    packages=find_packages(),
+    package_data=find_package_data(),
+    scripts=['py/bin/_findpy.py',
+             'py/bin/_makepyrelease.py',
+             'py/bin/py.cleanup',
+             'py/bin/py.countloc',
+             'py/bin/py.lookup',
+             'py/bin/py.rest',
+             'py/bin/py.test',
+             'py/bin/pytest.cmd'],
+    )



More information about the pytest-commit mailing list