Limnoria/setup.py

288 lines
11 KiB
Python
Raw Normal View History

2005-01-19 14:14:38 +01:00
#!/usr/bin/env python
###
# Copyright (c) 2002-2005, Jeremiah Fincher
# Copyright (c) 2009, James McCoy
2005-01-19 14:14:38 +01:00
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
#
# * Redistributions of source code must retain the above copyright notice,
# this list of conditions, and the following disclaimer.
# * Redistributions in binary form must reproduce the above copyright notice,
# this list of conditions, and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
# * Neither the name of the author of this software nor the name of
# contributors to this software may be used to endorse or promote products
# derived from this software without specific prior written consent.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
###
import os
2005-01-19 14:14:38 +01:00
import sys
import time
import datetime
2013-02-02 20:47:31 +01:00
import tempfile
import subprocess
from math import ceil
2005-01-19 14:14:38 +01:00
2013-02-22 20:50:38 +01:00
debug = '--debug' in sys.argv
2013-02-02 19:59:03 +01:00
path = os.path.dirname(__file__)
2013-02-22 20:50:38 +01:00
if debug:
print('DEBUG: Changing dir from %r to %r' % (os.getcwd(), path))
2013-02-02 19:59:03 +01:00
if path:
os.chdir(path)
version = None
try:
proc = subprocess.Popen('git show HEAD --format=%ci', shell=True,
stdout=subprocess.PIPE, stderr=subprocess.PIPE)
date = proc.stdout.readline()
2015-08-09 22:45:12 +02:00
if sys.version_info[0] >= 3:
date = date.decode()
date = time.strptime(date.strip(), '%Y-%m-%d %H:%M:%S %z')
utc_date = time.gmtime(time.mktime(date))
version = time.strftime('%Y.%m.%d', utc_date)
else:
(date, timezone) = date.strip().rsplit(' ', 1)
date = datetime.datetime.strptime(date.strip(), '%Y-%m-%d %H:%M:%S')
offset = time.strptime(timezone[1:], '%H%M')
offset = datetime.timedelta(hours=offset.tm_hour,
minutes=offset.tm_min)
utc_date = date - offset
version = utc_date.strftime('%Y.%m.%d')
except:
pass
if not version:
from time import gmtime, strftime
version = 'installed on ' + strftime("%Y-%m-%dT%H-%M-%S", gmtime())
try:
os.unlink(os.path.join('src', 'version.py'))
except OSError: # Does not exist
pass
fd = open(os.path.join('src', 'version.py'), 'a')
fd.write("version = '0.83.4.1+limnoria %s'\n" % version)
fd.close()
if sys.version_info < (2, 6, 0):
sys.stderr.write("Supybot requires Python 2.6 or newer.")
sys.stderr.write(os.linesep)
sys.exit(-1)
import textwrap
clean = False
while '--clean' in sys.argv:
clean = True
sys.argv.remove('--clean')
import glob
import shutil
import os
plugins = [s for s in os.listdir('plugins') if
os.path.exists(os.path.join('plugins', s, 'plugin.py'))]
2005-01-19 14:14:38 +01:00
def normalizeWhitespace(s):
return ' '.join(s.split())
try:
from distutils.core import setup
from distutils.sysconfig import get_python_lib
except ImportError as e:
s = normalizeWhitespace("""Supybot requires the distutils package to
install. This package is normally included with Python, but for some
unfathomable reason, many distributions to take it out of standard Python
and put it in another package, usually caled 'python-dev' or python-devel'
or something similar. This is one of the dumbest things a distribution can
do, because it means that developers cannot rely on *STANDARD* Python
modules to be present on systems of that distribution. Complain to your
distribution, and loudly. If you how much of our time we've wasted telling
people to install what should be included by default with Python you'd
understand why we're unhappy about this. Anyway, to reiterate, install the
development package for Python that your distribution supplies.""")
sys.stderr.write(os.linesep*2)
sys.stderr.write(textwrap.fill(s))
sys.stderr.write(os.linesep*2)
sys.exit(-1)
try:
from distutils.command.build_py import build_py_2to3
class build_py(build_py_2to3):
def run_2to3(self, files, options=None):
from distutils import log
from lib2to3.refactor import RefactoringTool, get_fixers_from_package
if not files:
return
# Make this class local, to delay import of 2to3
from lib2to3.refactor import RefactoringTool, get_fixers_from_package
class DistutilsRefactoringTool(RefactoringTool):
def refactor(self, files, *args, **kwargs):
self._total_files = len(files)
self._refactored_files = 0
super(DistutilsRefactoringTool, self).refactor(files,
*args, **kwargs)
del self._total_files
del self._refactored_files
def refactor_file(self, filename, *args, **kwargs):
if self._total_files//10 != 0 and \
self._refactored_files % (self._total_files//10) == 0:
print('Refactoring files: %i%% (%i on %i).' %
(ceil(self._refactored_files*100./self._total_files),
self._refactored_files, self._total_files))
self._refactored_files += 1
return super(DistutilsRefactoringTool, self).refactor_file(
filename, *args, **kwargs)
def log_error(self, msg, *args, **kw):
log.error(msg, *args)
def log_message(self, msg, *args):
log.info(msg, *args)
def log_debug(self, msg, *args):
log.debug(msg, *args)
fixer_names = ['fix_basestring',
'fix_imports',
'fix_metaclass', 'fix_methodattrs',
'fix_numliterals',
'fix_types',
'fix_unicode', 'fix_urllib', 'fix_xrange']
2014-01-20 13:59:25 +01:00
fixers = list(map(lambda x:'lib2to3.fixes.'+x, fixer_names))
fixers += get_fixers_from_package('2to3')
r = DistutilsRefactoringTool(fixers, options=options)
r.refactor(files, write=True)
except ImportError:
# 2.x
from distutils.command.build_py import build_py
if clean:
previousInstall = os.path.join(get_python_lib(), 'supybot')
if os.path.exists(previousInstall):
try:
print('Removing current installation.')
shutil.rmtree(previousInstall)
except Exception as e:
print('Couldn\'t remove former installation: %s' % e)
sys.exit(-1)
2005-01-19 14:14:38 +01:00
packages = ['supybot',
'supybot.locales',
'supybot.utils',
2005-01-19 14:14:38 +01:00
'supybot.drivers',
'supybot.plugins',] + \
2005-02-02 07:59:08 +01:00
['supybot.plugins.'+s for s in plugins] + \
[
'supybot.plugins.Dict.local',
'supybot.plugins.Math.local',
]
2005-01-19 14:14:38 +01:00
package_dir = {'supybot': 'src',
'supybot.utils': 'src/utils',
'supybot.locales': 'locales',
2005-01-19 14:14:38 +01:00
'supybot.plugins': 'plugins',
2005-02-02 07:59:08 +01:00
'supybot.drivers': 'src/drivers',
'supybot.plugins.Dict.local': 'plugins/Dict/local',
'supybot.plugins.Math.local': 'plugins/Math/local',
}
2005-01-19 14:14:38 +01:00
package_data = {'supybot.locales': [s for s in os.listdir('locales/')]}
2005-01-19 14:14:38 +01:00
for plugin in plugins:
package_dir['supybot.plugins.' + plugin] = 'plugins/' + plugin
locales_path = 'plugins/' + plugin + '/locales/'
locales_name = 'supybot.plugins.'+plugin
if os.path.exists(locales_path):
package_data.update({locales_name: ['locales/'+s for s in os.listdir(locales_path)]})
2005-01-19 14:14:38 +01:00
try:
shutil.rmtree('2to3/__pycache__')
except OSError:
pass
2005-01-19 14:14:38 +01:00
setup(
# Metadata
name='limnoria',
2013-01-21 20:33:09 +01:00
provides=['supybot'],
2005-01-19 14:14:38 +01:00
version=version,
author='Valentin Lorentz',
url='https://github.com/ProgVal/Limnoria',
author_email='progval+limnoria@progval.net',
download_url='http://builds.progval.net/limnoria/',
description='A modified version of Supybot (an IRC bot and framework)',
platforms=['linux', 'linux2', 'win32', 'cygwin', 'darwin'],
2005-01-19 14:14:38 +01:00
long_description=normalizeWhitespace("""A robust, full-featured Python IRC
bot with a clean and flexible plugin API. Equipped with a complete ACL
system for specifying user permissions with as much as per-command
granularity. Batteries are included in the form of numerous plugins
already written."""),
classifiers = [
'Development Status :: 4 - Beta',
'Environment :: Console',
'Environment :: No Input/Output (Daemon)',
'Intended Audience :: End Users/Desktop',
'Intended Audience :: Developers',
'License :: OSI Approved :: BSD License',
'Topic :: Communications :: Chat :: Internet Relay Chat',
'Natural Language :: English',
'Natural Language :: Finnish',
'Natural Language :: French',
'Natural Language :: Hungarian',
'Natural Language :: Italian',
2005-01-19 14:14:38 +01:00
'Operating System :: OS Independent',
'Operating System :: POSIX',
'Operating System :: Microsoft :: Windows',
'Programming Language :: Python :: 2.6',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3.2',
'Programming Language :: Python :: 3.3',
'Programming Language :: Python :: 3.4',
2005-01-19 14:14:38 +01:00
],
cmdclass = {'build_py': build_py},
2005-01-19 14:14:38 +01:00
# Installation data
packages=packages,
package_dir=package_dir,
package_data=package_data,
2005-01-19 14:14:38 +01:00
scripts=['scripts/supybot',
2005-01-20 00:12:50 +01:00
'scripts/supybot-test',
2005-02-03 15:55:31 +01:00
'scripts/supybot-botchk',
2005-01-19 14:14:38 +01:00
'scripts/supybot-wizard',
'scripts/supybot-adduser',
'scripts/supybot-plugin-doc',
'scripts/supybot-plugin-create',
],
2014-12-08 08:51:59 +01:00
data_files=[('share/man/man1', ['man/supybot.1']),
('share/man/man1', ['man/supybot-test.1']),
('share/man/man1', ['man/supybot-botchk.1']),
('share/man/man1', ['man/supybot-wizard.1']),
('share/man/man1', ['man/supybot-adduser.1']),
('share/man/man1', ['man/supybot-plugin-doc.1']),
('share/man/man1', ['man/supybot-plugin-create.1']),
],
2005-01-19 14:14:38 +01:00
)
# vim:set shiftwidth=4 softtabstop=4 expandtab textwidth=79: