190 lines
6.8 KiB
Python
190 lines
6.8 KiB
Python
|
#!/usr/bin/env python
|
||
|
|
||
|
# Dosage, the webcomic downloader
|
||
|
# Copyright (C) 2004-2005 Tristan Seligmann and Jonathan Jacobs
|
||
|
#
|
||
|
# This program is free software; you can redistribute it and/or modify
|
||
|
# it under the terms of version 2 of the GNU General Public License as
|
||
|
# published by the Free Software Foundation.
|
||
|
#
|
||
|
# This program 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 General Public License for more details.
|
||
|
#
|
||
|
# You should have received a copy of the GNU General Public License
|
||
|
# along with this program; if not, write to the Free Software
|
||
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||
|
import os
|
||
|
import sys
|
||
|
import re
|
||
|
from distutils.core import setup, Distribution
|
||
|
from distutils.command.install_lib import install_lib
|
||
|
from distutils import util
|
||
|
from distutils.file_util import write_file
|
||
|
|
||
|
AppVersion = '1.7'
|
||
|
AppName = 'Dosage'
|
||
|
|
||
|
def normpath (path):
|
||
|
"""Norm a path name to platform specific notation."""
|
||
|
return os.path.normpath(path)
|
||
|
|
||
|
|
||
|
def cnormpath (path):
|
||
|
"""Norm a path name to platform specific notation and make it absolute."""
|
||
|
path = normpath(path)
|
||
|
if os.name == 'nt':
|
||
|
# replace slashes with backslashes
|
||
|
path = path.replace("/", "\\")
|
||
|
if not os.path.isabs(path):
|
||
|
path = normpath(os.path.join(sys.prefix, path))
|
||
|
return path
|
||
|
|
||
|
|
||
|
release_ro = re.compile(r"\(released (.+)\)")
|
||
|
def get_release_date ():
|
||
|
"""Parse and return relase date as string from doc/changelog.txt."""
|
||
|
fname = os.path.join("doc", "changelog.txt")
|
||
|
release_date = "unknown"
|
||
|
with open(fname) as fd:
|
||
|
# the release date is on the first line
|
||
|
line = fd.readline()
|
||
|
mo = release_ro.search(line)
|
||
|
if mo:
|
||
|
release_date = mo.groups(1)
|
||
|
return release_date
|
||
|
|
||
|
|
||
|
class MyInstallLib (install_lib, object):
|
||
|
"""Custom library installation."""
|
||
|
|
||
|
def install (self):
|
||
|
"""Install the generated config file."""
|
||
|
outs = super(MyInstallLib, self).install()
|
||
|
infile = self.create_conf_file()
|
||
|
outfile = os.path.join(self.install_dir, os.path.basename(infile))
|
||
|
self.copy_file(infile, outfile)
|
||
|
outs.append(outfile)
|
||
|
return outs
|
||
|
|
||
|
def create_conf_file (self):
|
||
|
"""Create configuration file."""
|
||
|
cmd_obj = self.distribution.get_command_obj("install")
|
||
|
cmd_obj.ensure_finalized()
|
||
|
# we have to write a configuration file because we need the
|
||
|
# <install_data> directory (and other stuff like author, url, ...)
|
||
|
# all paths are made absolute by cnormpath()
|
||
|
data = []
|
||
|
for d in ['purelib', 'platlib', 'lib', 'headers', 'scripts', 'data']:
|
||
|
attr = 'install_%s' % d
|
||
|
if cmd_obj.root:
|
||
|
# cut off root path prefix
|
||
|
cutoff = len(cmd_obj.root)
|
||
|
# don't strip the path separator
|
||
|
if cmd_obj.root.endswith(os.sep):
|
||
|
cutoff -= 1
|
||
|
val = getattr(cmd_obj, attr)[cutoff:]
|
||
|
else:
|
||
|
val = getattr(cmd_obj, attr)
|
||
|
if attr == 'install_data':
|
||
|
cdir = os.path.join(val, "share", "dosage")
|
||
|
data.append('config_dir = %r' % cnormpath(cdir))
|
||
|
elif attr == 'install_lib':
|
||
|
if cmd_obj.root:
|
||
|
_drive, tail = os.path.splitdrive(val)
|
||
|
if tail.startswith(os.sep):
|
||
|
tail = tail[1:]
|
||
|
self.install_lib = os.path.join(cmd_obj.root, tail)
|
||
|
else:
|
||
|
self.install_lib = val
|
||
|
data.append("%s = %r" % (attr, cnormpath(val)))
|
||
|
self.distribution.create_conf_file(data, directory=self.install_lib)
|
||
|
return self.get_conf_output()
|
||
|
|
||
|
def get_conf_output (self):
|
||
|
return self.distribution.get_conf_filename(self.install_lib)
|
||
|
|
||
|
def get_outputs (self):
|
||
|
"""Add the generated config file to the list of outputs."""
|
||
|
outs = super(MyInstallLib, self).get_outputs()
|
||
|
outs.append(self.get_conf_output())
|
||
|
return outs
|
||
|
|
||
|
|
||
|
class MyDistribution (Distribution, object):
|
||
|
"""Custom distribution class generating config file."""
|
||
|
|
||
|
def __init__ (self, attrs):
|
||
|
"""Set console and windows scripts."""
|
||
|
super(MyDistribution, self).__init__(attrs)
|
||
|
self.console = ['dosage']
|
||
|
|
||
|
def run_commands (self):
|
||
|
"""Generate config file and run commands."""
|
||
|
cwd = os.getcwd()
|
||
|
data = []
|
||
|
data.append('config_dir = %r' % os.path.join(cwd, "config"))
|
||
|
data.append("install_data = %r" % cwd)
|
||
|
data.append("install_scripts = %r" % cwd)
|
||
|
self.create_conf_file(data)
|
||
|
super(MyDistribution, self).run_commands()
|
||
|
|
||
|
def get_conf_filename (self, directory):
|
||
|
"""Get name for config file."""
|
||
|
return os.path.join(directory, "_%s_configdata.py" % self.get_name())
|
||
|
|
||
|
def create_conf_file (self, data, directory=None):
|
||
|
"""Create local config file from given data (list of lines) in
|
||
|
the directory (or current directory if not given)."""
|
||
|
data.insert(0, "# this file is automatically created by setup.py")
|
||
|
data.insert(0, "# -*- coding: iso-8859-1 -*-")
|
||
|
if directory is None:
|
||
|
directory = os.getcwd()
|
||
|
filename = self.get_conf_filename(directory)
|
||
|
# add metadata
|
||
|
metanames = ("name", "version", "author", "author_email",
|
||
|
"maintainer", "maintainer_email", "url",
|
||
|
"license", "description", "long_description",
|
||
|
"keywords", "platforms", "fullname", "contact",
|
||
|
"contact_email")
|
||
|
for name in metanames:
|
||
|
method = "get_" + name
|
||
|
val = getattr(self.metadata, method)()
|
||
|
if isinstance(val, str):
|
||
|
val = unicode(val)
|
||
|
cmd = "%s = %r" % (name, val)
|
||
|
data.append(cmd)
|
||
|
data.append('release_date = "%s"' % get_release_date())
|
||
|
# write the config file
|
||
|
util.execute(write_file, (filename, data),
|
||
|
"creating %s" % filename, self.verbose >= 1, self.dry_run)
|
||
|
|
||
|
|
||
|
args = dict(
|
||
|
name = AppName,
|
||
|
version = AppVersion,
|
||
|
description = 'a powerful webcomic downloader and archiver',
|
||
|
author = 'Tristan Seligmann, Jonathan Jacobs, Bastian Kleineidam',
|
||
|
author_email = 'calvin@users.sourceforge.net',
|
||
|
maintainer = 'Bastian Kleineidam',
|
||
|
maintainer_email = 'calvin@users.sourceforge.net',
|
||
|
license = 'MIT',
|
||
|
url = 'https://github.com/wummel/dosage',
|
||
|
packages = (
|
||
|
'dosagelib',
|
||
|
'dosagelib.plugins',
|
||
|
),
|
||
|
scripts = (
|
||
|
'dosage',
|
||
|
),
|
||
|
distclass = MyDistribution,
|
||
|
cmdclass = {
|
||
|
'install_lib': MyInstallLib,
|
||
|
},
|
||
|
)
|
||
|
|
||
|
if __name__ == '__main__':
|
||
|
setup(**args)
|
||
|
|