summaryrefslogtreecommitdiff
path: root/setup.py
diff options
context:
space:
mode:
Diffstat (limited to 'setup.py')
-rwxr-xr-xsetup.py126
1 files changed, 95 insertions, 31 deletions
diff --git a/setup.py b/setup.py
index 446b3c7..73a641b 100755
--- a/setup.py
+++ b/setup.py
@@ -1,10 +1,91 @@
#!/usr/bin/env python
-from distutils.core import setup
+import os
+import re
+import sys
+import distutils
+from distutils import core, log
+from glob import glob
-__version__ = open("VERSION").read().strip()
+__version__ = os.getenv('VERSION', default='9999')
-setup(
+cwd = os.getcwd()
+
+# Bash files that need `VERSION=""` subbed, relative to this dir:
+bash_scripts = [os.path.join(cwd, path) for path in (
+ 'bin/euse',
+ 'bin/revdep-rebuild',
+)]
+
+# Python files that need `__version__ = ""` subbed, relative to this dir:
+python_scripts = [os.path.join(cwd, path) for path in (
+ 'bin/eclean',
+ 'bin/epkginfo',
+ 'bin/glsa-check',
+ 'pym/gentoolkit/equery/__init__.py'
+)]
+
+
+class set_version(core.Command):
+ """Set python __version__ and bash VERSION to our __version__."""
+ description = "hardcode scripts' version using VERSION from environment"
+ user_options = [] # [(long_name, short_name, desc),]
+
+ def initialize_options (self):
+ pass
+
+ def finalize_options (self):
+ pass
+
+ def run(self):
+ ver = 'svn' if __version__ == '9999' else __version__
+ def sub(files, pattern):
+ for f in files:
+ updated_file = []
+ with open(f) as s:
+ for line in s:
+ newline = re.sub(pattern, '"%s"' % ver, line, 1)
+ if newline != line:
+ log.info("%s: %s" % (f, newline))
+ updated_file.append(newline)
+ with open(f, 'w') as s:
+ s.writelines(updated_file)
+ quote = r'[\'"]{1}'
+ bash_re = r'(?<=^VERSION=)' + quote + '[^\'"]*' + quote
+ sub(bash_scripts, bash_re)
+ python_re = r'(?<=^__version__ = )' + quote + '[^\'"]*' + quote
+ sub(python_scripts, python_re)
+
+
+def load_test():
+ """Only return the real test class if it's actually being run so that we
+ don't depend on snakeoil just to install."""
+
+ desc = "run the test suite"
+ if 'test' in sys.argv[1:]:
+ try:
+ from snakeoil import distutils_extensions
+ except ImportError:
+ sys.stderr.write("Error: We depend on dev-python/snakeoil ")
+ sys.stderr.write("to run tests.\n")
+ sys.exit(1)
+ class test(distutils_extensions.test):
+ description = desc
+ default_test_namespace = 'gentoolkit.test'
+ else:
+ class test(core.Command):
+ description = desc
+
+ return test
+
+
+packages = [
+ '.'.join(root.split(os.sep)[1:])
+ for root, dirs, files in os.walk('pym/gentoolkit')
+ if '__init__.py' in files
+]
+
+core.setup(
name='gentoolkit',
version=__version__,
description='Set of tools that work with and enhance portage.',
@@ -16,35 +97,18 @@ setup(
download_url='http://distfiles.gentoo.org/distfiles/gentoolkit-%s.tar.gz'\
% __version__,
package_dir={'': 'pym'},
- packages=(
- 'gentoolkit',
- 'gentoolkit.equery',
- 'gentoolkit.glsa'
- ),
- scripts=(
- 'bin/eclean',
- 'bin/epkginfo',
- 'bin/equery',
- 'bin/eread',
- 'bin/euse',
- 'bin/glsa-check',
- 'bin/revdep-rebuild'
- ),
+ packages=packages,
+ scripts=(glob('bin/*')),
data_files=(
('/etc/env.d', ['data/99gentoolkit-env']),
('/etc/revdep-rebuild', ['data/revdep-rebuild/99revdep-rebuild']),
- ('/etc/eclean', [
- 'data/eclean/distfiles.exclude',
- 'data/eclean/packages.exclude'
- ]),
- ('/usr/share/man/man1', [
- 'man/eclean.1',
- 'man/epkginfo.1',
- 'man/equery.1',
- 'man/eread.1',
- 'man/euse.1',
- 'man/glsa-check.1',
- 'man/revdep-rebuild.1'
- ])
- )
+ ('/etc/eclean', glob('data/eclean/*')),
+ ('/usr/share/man/man1', glob('man/*'))
+ ),
+ cmdclass={
+ 'test': load_test(),
+ 'set_version': set_version,
+ },
)
+
+# vim: set ts=4 sw=4 tw=79: