Commits

Michael Manfre committed ad802c1

Start of v1.1. License switch to MIT. Borrowing setup.py from jezdez and changing to the much friendlier PEP 386 versioning.

  • Participants
  • Parent commits b8ea2d0

Comments (0)

Files changed (2)

+import os
+import re
+import sys
+import codecs
+from fnmatch import fnmatchcase
+from distutils.util import convert_path
 from setuptools import setup, find_packages
 
-version = __import__('sqlserver_ado').get_version()
+
+def read(*parts):
+    return codecs.open(os.path.join(os.path.dirname(__file__), *parts)).read()
+
+
+def find_version(*file_paths):
+    version_file = read(*file_paths)
+    version_match = re.search(r"^__version__ = ['\"]([^'\"]*)['\"]",
+                              version_file, re.M)
+    if version_match:
+        return version_match.group(1)
+    raise RuntimeError("Unable to find version string.")
+
+
+# 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
 
 setup(
-    name='django-mssql',
-    version=version.replace(' ', '-'),
-    maintainer='Michael Manfre',
-    maintainer_email='mmanfre@gmail.com',
-    url='http://django-mssql.googlecode.com/',
+    name="django-mssql",
+    version=find_version("sqlserver_ado", "__init__.py"),
+    url='https://bitbucket.org/Manfre/django-mssql',
+    license='MIT',
     description="Django backend database support for MS SQL 2005 and up.",
-    license='Apache License, Version 2.0',
+    long_description=read('README.txt'),
+    author='Michael Manfre',
+    author_email='mmanfre@gmail.com',
     packages=find_packages(),
-    include_package_data=True,
+    package_data=find_package_data(),
     classifiers=[
-        "Programming Language :: Python",
-        "Topic :: Software Development :: Libraries :: Python Modules",
-        "Framework :: Django",
-        "Environment :: Web Environment",
+        'Development Status :: 5 - Production/Stable',
+        'Framework :: Django',
+        'Programming Language :: Python',
+        'Programming Language :: Python :: 2.6',
+        'Programming Language :: Python :: 2.7',
+        'Topic :: Internet :: WWW/HTTP',
+    ],
+    zip_safe=False,
+    install_requires=[
     ],
 )

sqlserver_ado/__init__.py

-import os.path
-
-VERSION = [1, 0, 1, 'stable']
-
-
-def get_version():
-    """
-    Return the version as a string. If this is flagged as a development
-    release and mercurial can be loaded the specifics about the changeset
-    will be appended to the version string. 
-    """
-    if 'dev' in VERSION:
-        try:
-            from mercurial import hg, ui
-    
-            repo_path = os.path.join(os.path.dirname(__file__), '..')
-            repo = hg.repository(ui.ui(), repo_path)
-            ctx = repo['tip']
-            build_info = 'dev %s %s:%s' % (ctx.branch(), ctx.rev(), str(ctx))
-        except:
-            # mercurial module missing or repository not found
-            build_info = 'dev-unknown'
-        v = VERSION[:-1] + [build_info]
-    else:
-        v = VERSION[:-1]
-    return '.'.join(map(str, v))
+# following PEP 386
+__version__ = "1.1a1"