
Added AutoSelectParser, picks LxmlParser if lxml is available, falls back to HtmlParser if not, also the new default. Created a special BeautifulSoupTest in order to still test this parser. Updated README, installation and settings docs to reflect these changes.
125 lines
4.6 KiB
Python
125 lines
4.6 KiB
Python
import os
|
|
import sys
|
|
from fnmatch import fnmatchcase
|
|
from distutils.util import convert_path
|
|
from setuptools import setup, find_packages
|
|
|
|
def read(fname):
|
|
return open(os.path.join(os.path.dirname(__file__), fname)).read()
|
|
|
|
# Provided as an attribute, so you can append to these instead
|
|
# of replicating them:
|
|
standard_exclude = ('*.py', '*.pyc', '*$py.class', '*~', '.*', '*.bak')
|
|
standard_exclude_directories = ('.*', 'CVS', '_darcs', './build',
|
|
'./dist', 'EGG-INFO', '*.egg-info')
|
|
|
|
# (c) 2005 Ian Bicking and contributors; written for Paste (http://pythonpaste.org)
|
|
# Licensed under the MIT license: http://www.opensource.org/licenses/mit-license.php
|
|
# 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.
|
|
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'))
|
|
and not prefix):
|
|
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
|
|
|
|
|
|
README = read('README.rst')
|
|
VERSION = __import__("compressor").__version__
|
|
|
|
setup(
|
|
name = "django_compressor",
|
|
version = VERSION,
|
|
url = 'http://django_compressor.readthedocs.org/',
|
|
license = 'BSD',
|
|
description = "Compresses linked and inline JavaScript or CSS into single cached files.",
|
|
long_description = README,
|
|
author = 'Jannis Leidel',
|
|
author_email = 'jannis@leidel.info',
|
|
packages = find_packages(),
|
|
package_data = find_package_data('compressor', only_in_packages=False),
|
|
classifiers = [
|
|
'Development Status :: 4 - Beta',
|
|
'Framework :: Django',
|
|
'Intended Audience :: Developers',
|
|
'License :: OSI Approved :: BSD License',
|
|
'Operating System :: OS Independent',
|
|
'Programming Language :: Python',
|
|
'Topic :: Internet :: WWW/HTTP',
|
|
],
|
|
zip_safe = False,
|
|
)
|