from ez_setup import use_setuptools
use_setuptools()
from setuptools import setup, find_packages
+from distutils.command.build_py import build_py as _build_py
+from setuptools.command.sdist import sdist as _sdist
+import os
+from os import path
+
+v = open(path.join(path.dirname(__file__), 'VERSION'))
+VERSION = v.readline().strip()
+v.close()
+
+class build_py(_build_py):
+ def run(self):
+ init = path.join(self.build_lib, 'sqlalchemy', '__init__.py')
+ if path.exists(init):
+ os.unlink(init)
+ _build_py.run(self)
+ _stamp_version(init)
+ self.byte_compile([init])
+
+class sdist(_sdist):
+ def make_release_tree (self, base_dir, files):
+ _sdist.make_release_tree(self, base_dir, files)
+ orig = path.join('lib', 'sqlalchemy', '__init__.py')
+ assert path.exists(orig)
+ dest = path.join(base_dir, orig)
+ if hasattr(os, 'link') and path.exists(dest):
+ os.unlink(dest)
+ self.copy_file(orig, dest)
+ _stamp_version(dest)
+
+def _stamp_version(filename):
+ found, out = False, []
+ f = open(filename, 'r')
+ for line in f:
+ if '__version__ =' in line:
+ line = line.replace("'svn'", "'%s'" % VERSION)
+ found = True
+ out.append(line)
+ f.close()
+
+ if found:
+ f = open(filename, 'w')
+ f.writelines(out)
+ f.close()
+
setup(name = "SQLAlchemy",
- version = "0.4.0",
- description = "Database Abstraction Library",
- author = "Mike Bayer",
- author_email = "mike_mp@zzzcomputing.com",
- url = "http://www.sqlalchemy.org",
- packages = find_packages('lib'),
- package_dir = {'':'lib'},
- entry_points = {
- 'sqlalchemy.databases': [
- '%s = sqlalchemy.databases.%s:dialect' % (f,f) for f in
- ['sqlite', 'postgres', 'mysql', 'oracle', 'mssql', 'firebird']]},
- license = "MIT License",
- long_description = """\
+ cmdclass={'build_py': build_py, 'sdist': sdist},
+ version = VERSION,
+ description = "Database Abstraction Library",
+ author = "Mike Bayer",
+ author_email = "mike_mp@zzzcomputing.com",
+ url = "http://www.sqlalchemy.org",
+ packages = find_packages('lib'),
+ package_dir = {'':'lib'},
+ entry_points = {
+ 'sqlalchemy.databases': [
+ '%s = sqlalchemy.databases.%s:dialect' % (f,f) for f in
+ ['sqlite', 'postgres', 'mysql', 'oracle', 'mssql', 'firebird']]},
+ license = "MIT License",
+ long_description = """\
SQLAlchemy is:
* The Python SQL toolkit and Object Relational Mapper that gives application developers the full power and flexibility of SQL. SQLAlchemy provides a full suite of well known enterprise-level persistence patterns, designed for efficient and high-performing database access, adapted into a simple and Pythonic domain language.
<http://svn.sqlalchemy.org/sqlalchemy/trunk#egg=SQLAlchemy-dev>
""",
- classifiers = [
+ classifiers = [
"Development Status :: 4 - Beta",
"Intended Audience :: Developers",
"License :: OSI Approved :: MIT License",
"Programming Language :: Python",
"Topic :: Database :: Front-Ends",
- ]
- )
-
-
-
-
+ ]
+ )