diff options
author | Emile Anclin <emile.anclin@logilab.fr> | 2010-11-10 11:11:51 +0100 |
---|---|---|
committer | Emile Anclin <emile.anclin@logilab.fr> | 2010-11-10 11:11:51 +0100 |
commit | 4ec4201c489fb4fd608b333db7f35b6933f1eaa6 (patch) | |
tree | ef794196961d5a78be5255bc71d555267713d31f /setup.py | |
parent | 9684d0fb05c4721876c2b7274b6af3f3122ff62d (diff) | |
download | astroid-git-4ec4201c489fb4fd608b333db7f35b6933f1eaa6.tar.gz |
packaging : add py3k target; update setup.py and other files to make py3k packaging work
Diffstat (limited to 'setup.py')
-rw-r--r-- | setup.py | 146 |
1 files changed, 44 insertions, 102 deletions
@@ -1,33 +1,31 @@ #!/usr/bin/env python -# pylint: disable-msg=W0404,W0622,W0704,W0613,W0152 +# -*- coding: utf-8 -*- +# pylint: disable=W0404,W0622,W0704,W0613 # copyright 2003-2010 LOGILAB S.A. (Paris, FRANCE), all rights reserved. # contact http://www.logilab.fr/ -- mailto:contact@logilab.fr -# copyright 2003-2010 Sylvain Thenault, all rights reserved. -# contact mailto:thenault@gmail.com # # This file is part of logilab-astng. # -# logilab-astng is free software: you can redistribute it and/or modify it -# under the terms of the GNU Lesser General Public License as published by the -# Free Software Foundation, either version 2.1 of the License, or (at your -# option) any later version. +# logilab-astng is free software: you can redistribute it and/or modify it under +# the terms of the GNU Lesser General Public License as published by the Free +# Software Foundation, either version 2.1 of the License, or (at your option) any +# later version. # -# logilab-astng is distributed in the hope that it will be useful, but -# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License -# for more details. +# logilab-astng is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS +# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more +# details. # # You should have received a copy of the GNU Lesser General Public License along -# with logilab-astng. If not, see <http://www.gnu.org/licenses/>. +# with logilab-astng. If not, see <http://www.gnu.org/licenses/>. """Generic Setup script, takes package info from __pkginfo__.py file. - """ __docformat__ = "restructuredtext en" import os import sys import shutil -from os.path import isdir, exists, join, walk +from os.path import isdir, exists, join try: if os.environ.get('NO_SETUPTOOLS'): @@ -35,54 +33,38 @@ try: from setuptools import setup from setuptools.command import install_lib USE_SETUPTOOLS = 1 -except ImportError: +except ImportError: from distutils.core import setup from distutils.command import install_lib USE_SETUPTOOLS = 0 - + + sys.modules.pop('__pkginfo__', None) # import required features -from __pkginfo__ import modname, version, license, short_desc, long_desc, \ +from __pkginfo__ import modname, version, license, description, \ web, author, author_email # import optional features -try: - from __pkginfo__ import distname -except ImportError: - distname = modname -try: - from __pkginfo__ import scripts -except ImportError: - scripts = [] -try: - from __pkginfo__ import data_files -except ImportError: - data_files = None -try: - from __pkginfo__ import subpackage_of -except ImportError: - subpackage_of = None -try: - from __pkginfo__ import include_dirs -except ImportError: - include_dirs = [] -try: - from __pkginfo__ import ext_modules -except ImportError: - ext_modules = None -try: - from __pkginfo__ import install_requires -except ImportError: - install_requires = None +import __pkginfo__ +distname = getattr(__pkginfo__, 'distname', modname) +scripts = getattr(__pkginfo__, 'scripts', []) +data_files = getattr(__pkginfo__, 'data_files', None) +subpackage_of = getattr(__pkginfo__, 'subpackage_of', None) +include_dirs = getattr(__pkginfo__, 'include_dirs', []) +ext_modules = getattr(__pkginfo__, 'ext_modules', None) +install_requires = getattr(__pkginfo__, 'install_requires', None) +dependency_links = getattr(__pkginfo__, 'dependency_links', []) STD_BLACKLIST = ('CVS', '.svn', '.hg', 'debian', 'dist', 'build') IGNORED_EXTENSIONS = ('.pyc', '.pyo', '.elc', '~') - +if exists('README'): + long_description = open('README').read() +else: + long_description = '' def ensure_scripts(linux_scripts): - """ - Creates the proper script names required for each platform + """Creates the proper script names required for each platform (taken from 4Suite) """ from distutils import util @@ -92,10 +74,8 @@ def ensure_scripts(linux_scripts): scripts_ = linux_scripts return scripts_ - def get_packages(directory, prefix): - """return a list of subpackages for the given directory - """ + """return a list of subpackages for the given directory""" result = [] for package in os.listdir(directory): absfile = join(directory, package) @@ -109,48 +89,7 @@ def get_packages(directory, prefix): result += get_packages(absfile, result[-1]) return result -def export(from_dir, to_dir, - blacklist=STD_BLACKLIST, - ignore_ext=IGNORED_EXTENSIONS, - verbose=True): - """make a mirror of from_dir in to_dir, omitting directories and files - listed in the black list - """ - def make_mirror(arg, directory, fnames): - """walk handler""" - for norecurs in blacklist: - try: - fnames.remove(norecurs) - except ValueError: - pass - for filename in fnames: - # don't include binary files - if filename[-4:] in ignore_ext: - continue - if filename[-1] == '~': - continue - src = join(directory, filename) - dest = to_dir + src[len(from_dir):] - if verbose: - print >> sys.stderr, src, '->', dest - if os.path.isdir(src): - if not exists(dest): - os.mkdir(dest) - else: - if exists(dest): - os.remove(dest) - shutil.copy2(src, dest) - try: - os.mkdir(to_dir) - except OSError, ex: - # file exists ? - import errno - if ex.errno != errno.EEXIST: - raise - walk(from_dir, make_mirror, None) - - -EMPTY_FILE = '''"""generated file, don\'t modify or your data will be lost""" +EMPTY_FILE = '''"""generated file, don't modify or your data will be lost""" try: __import__('pkg_resources').declare_namespace(__name__) except ImportError: @@ -180,15 +119,17 @@ class MyInstallLib(install_lib.install_lib): base = modname for directory in include_dirs: dest = join(self.install_dir, base, directory) - export(directory, dest, verbose=False) - + shutil.rmtree(dest, ignore_errors=True) + shutil.copytree(directory, dest) + def install(**kwargs): """setup entry point""" - try: - if USE_SETUPTOOLS: + if USE_SETUPTOOLS: + if '--force-manifest' in sys.argv: sys.argv.remove('--force-manifest') - except: - pass + # install-layout option was introduced in 2.5.3-1~exp1 + elif sys.version_info < (2, 5, 4) and '--install-layout=deb' in sys.argv: + sys.argv.remove('--install-layout=deb') if subpackage_of: package = subpackage_of + '.' + modname kwargs['package_dir'] = {package : '.'} @@ -200,12 +141,13 @@ def install(**kwargs): packages = [modname] + get_packages(os.getcwd(), modname) if USE_SETUPTOOLS and install_requires: kwargs['install_requires'] = install_requires + kwargs['dependency_links'] = dependency_links kwargs['packages'] = packages return setup(name = distname, version = version, license = license, - description = short_desc, - long_description = long_desc, + description = description, + long_description = long_description, author = author, author_email = author_email, url = web, @@ -215,6 +157,6 @@ def install(**kwargs): cmdclass = {'install_lib': MyInstallLib}, **kwargs ) - + if __name__ == '__main__' : install() |