[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