X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=setup.py;h=aac46c35acabadc0be241dbd2f29c077a702c30c;hb=6129ac97d25b0172419883e26784c457da3b454d;hp=3e06aacd17b77239aa3dfecc60708019c64d5c9e;hpb=733090b377106f1c2457690c1ce2226af6c6ee9d;p=roundup.git diff --git a/setup.py b/setup.py index 3e06aac..aac46c3 100644 --- a/setup.py +++ b/setup.py @@ -16,94 +16,238 @@ # BASIS, AND THERE IS NO OBLIGATION WHATSOEVER TO PROVIDE MAINTENANCE, # SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS. # -# $Id: setup.py,v 1.18 2001-08-30 06:01:17 richard Exp $ +# $Id: setup.py,v 1.59 2004-03-24 05:56:06 richard Exp $ from distutils.core import setup, Extension from distutils.util import get_platform +from distutils.command.build_scripts import build_scripts +import sys, os, string from glob import glob -import os -from roundup.templatebuilder import makeHtmlBase -print 'Running unit tests...' -import test -test.go() +# patch distutils if it can't cope with the "classifiers" keyword +from distutils.dist import DistributionMetadata +if not hasattr(DistributionMetadata, 'classifiers'): + DistributionMetadata.classifiers = None + DistributionMetadata.download_url = None -templates = 'classic', 'extended' -packagelist = [ 'roundup', 'roundup.backends', 'roundup.templates' ] -installdatafiles = [] -for t in templates: - makeHtmlBase(os.path.join('roundup', 'templates', t)) - packagelist.append('roundup.templates.%s'%t) - packagelist.append('roundup.templates.%s.detectors'%t) - tfiles = glob(os.path.join('roundup','templates', t, 'html', '*')) - tfiles = filter(os.path.isfile, tfiles) +############################################################################# +### Build script files +############################################################################# +class build_scripts_create(build_scripts): + """ Overload the build_scripts command and create the scripts + from scratch, depending on the target platform. -setup ( name = "roundup", - version = "0.2.8", - description = "Roundup issue tracking system.", + You have to define the name of your package in an inherited + class (due to the delayed instantiation of command classes + in distutils, this cannot be passed to __init__). + + The scripts are created in an uniform scheme: they start the + run() function in the module + + .scripts. + + The mangling of script names replaces '-' and '/' characters + with '-' and '.', so that they are valid module paths. + """ + package_name = None + + def copy_scripts(self): + """ Create each script listed in 'self.scripts' + """ + if not self.package_name: + raise Exception("You have to inherit build_scripts_create and" + " provide a package name") + + to_module = string.maketrans('-/', '_.') + + self.mkpath(self.build_dir) + for script in self.scripts: + outfile = os.path.join(self.build_dir, os.path.basename(script)) + + #if not self.force and not newer(script, outfile): + # self.announce("not copying %s (up-to-date)" % script) + # continue + + if self.dry_run: + self.announce("would create %s" % outfile) + continue + + module = os.path.splitext(os.path.basename(script))[0] + module = string.translate(module, to_module) + cmdopt=self.distribution.command_options + if (cmdopt.has_key('install') and + cmdopt['install'].has_key('prefix')): + prefix = cmdopt['install']['prefix'][1] + version = '%d.%d'%sys.version_info[:2] + prefix = ''' +import sys +sys.path.insert(1, "%s/lib/python%s/site-packages") +'''%(prefix, version) + else: + prefix = '' + script_vars = { + 'python': os.path.normpath(sys.executable), + 'package': self.package_name, + 'module': module, + 'prefix': prefix, + } + + self.announce("creating %s" % outfile) + file = open(outfile, 'w') + + try: + if sys.platform == "win32": + file.write('@echo off\n' + 'if NOT "%%_4ver%%" == "" "%(python)s" -O -c "from %(package)s.scripts.%(module)s import run; run()" %%$\n' + 'if "%%_4ver%%" == "" "%(python)s" -O -c "from %(package)s.scripts.%(module)s import run; run()" %%*\n' + % script_vars) + else: + file.write('#! %(python)s -O\n%(prefix)s' + 'from %(package)s.scripts.%(module)s import run\n' + 'run()\n' + % script_vars) + finally: + file.close() + os.chmod(outfile, 0755) + + +class build_scripts_roundup(build_scripts_create): + package_name = 'roundup' + + +def scriptname(path): + """ Helper for building a list of script names from a list of + module files. + """ + script = os.path.splitext(os.path.basename(path))[0] + script = string.replace(script, '_', '-') + if sys.platform == "win32": + script = script + ".bat" + return script + + + +############################################################################# +### Main setup stuff +############################################################################# + +def main(): + # build list of scripts from their implementation modules + roundup_scripts = map(scriptname, glob('roundup/scripts/[!_]*.py')) + + # template munching + packagelist = [ + 'roundup', + 'roundup.cgi', + 'roundup.cgi.PageTemplates', + 'roundup.cgi.TAL', + 'roundup.cgi.ZTUtils', + 'roundup.backends', + 'roundup.scripts' + ] + installdatafiles = [ + ('share/roundup/cgi-bin', ['cgi-bin/roundup.cgi']), + ] + + # install man pages on POSIX platforms + if os.name == 'posix': + installdatafiles.append(('man/man1', ['doc/roundup-admin.1', + 'doc/roundup-mailgw.1', 'doc/roundup-server.1'])) + + # add the templates to the data files lists + from roundup.init import listTemplates + templates = [t['path'] for t in listTemplates('templates').values()] + for tdir in templates: + # scan for data files + for idir in '. detectors html'.split(): + idir = os.path.join(tdir, idir) + tfiles = [] + for f in os.listdir(idir): + if f.startswith('.'): + continue + ifile = os.path.join(idir, f) + if os.path.isfile(ifile): + tfiles.append(ifile) + installdatafiles.append( + (os.path.join('share', 'roundup', idir), tfiles) + ) + + # perform the setup action + from roundup import __version__ + setup( + name = "roundup", + version = __version__, + description = "A simple-to-use and -install issue-tracking system" + " with command-line, web and e-mail interfaces. Highly" + " customisable.", + long_description = +'''Roundup is a simple-to-use and -install issue-tracking system with +command-line, web and e-mail interfaces. It is based on the winning design +from Ka-Ping Yee in the Software Carpentry "Track" design competition. + +If you're upgrading from an older version of Roundup you *must* follow +the "Software Upgrade" guidelines given in the maintenance documentation. + +No, really, this is a BETA and if you don't follow the upgrading steps, +particularly the bit about BACKING UP YOUR DATA, I'm NOT GOING TO BE HELD +RESPONSIBLE. This release is NOT FOR GENERAL USE. + +I would *greatly* appreciate people giving this release a whirl with a +copy of their existing setup. It's only through real-world testing of +beta releases that we can ensure that older trackers will be OK. + +This release introduces far too many features to list here. Some +highlights: + +- added postgresql backend (originally from sf patch 761740, many changes + since) +- RDBMS backends implement their session and one-time-key stores and + full-text indexers; thus they are now performing their own locking + internally +- added new "actor" automatic property (indicates user who cause the last + "activity") +- all RDBMS backends have sensible data typed columns and indexes on + several columns +- we support confirming registration by replying to the email (sf bug + 763668) +- all HTML templating methods now automatically check for permissions + (either view or edit as appropriate), greatly simplifying templates +''', author = "Richard Jones", - author_email = "richard@sourceforge.net", - url = 'http://sourceforge.net/projects/roundup/', + author_email = "richard@users.sourceforge.net", + url = 'http://roundup.sourceforge.net/', + download_url = 'http://sourceforge.net/project/showfiles.php?group_id=31577', packages = packagelist, - scripts = ['roundup-admin', 'roundup-mailgw', 'roundup-server'] -) + classifiers = [ + 'Development Status :: 4 - Beta', + 'Environment :: Console', + 'Environment :: Web Environment', + 'Intended Audience :: End Users/Desktop', + 'Intended Audience :: Developers', + 'Intended Audience :: System Administrators', + 'License :: OSI Approved :: Python Software Foundation License', + 'Operating System :: MacOS :: MacOS X', + 'Operating System :: Microsoft :: Windows', + 'Operating System :: POSIX', + 'Programming Language :: Python', + 'Topic :: Communications :: Email', + 'Topic :: Office/Business', + 'Topic :: Software Development :: Bug Tracking', + ], + + # Override certain command classes with our own ones + cmdclass = { + 'build_scripts': build_scripts_roundup, + }, + scripts = roundup_scripts, + + data_files = installdatafiles + ) + +if __name__ == '__main__': + main() -# -# $Log: not supported by cvs2svn $ -# Revision 1.17 2001/08/08 03:29:35 richard -# Next release is 0.2.6 -# -# Revision 1.16 2001/08/07 00:24:42 richard -# stupid typo -# -# Revision 1.15 2001/08/07 00:15:51 richard -# Added the copyright/license notice to (nearly) all files at request of -# Bizar Software. -# -# Revision 1.14 2001/08/06 23:57:20 richard -# Am now bundling unittest with the package so that everyone can use the unit -# tests. -# -# Revision 1.13 2001/08/03 07:18:57 richard -# updated version number for 0.2.6 -# -# Revision 1.12 2001/08/03 02:51:06 richard -# detect unit tests -# -# Revision 1.11 2001/08/03 01:54:58 richard -# Started stuff off for the 0.2.5 release -# -# Revision 1.10 2001/07/30 07:17:44 richard -# Just making sure we've got the right version in there for development. -# -# Revision 1.9 2001/07/29 23:34:26 richard -# Added unit tests so they're run whenever we package/install/whatever. -# -# Revision 1.8 2001/07/29 09:43:46 richard -# Make sure that the htmlbase is up-to-date when we build a source dist. -# -# Revision 1.7 2001/07/29 08:37:58 richard -# changes -# -# Revision 1.6 2001/07/29 07:01:39 richard -# Added vim command to all source so that we don't get no steenkin' tabs :) -# -# Revision 1.5 2001/07/28 00:39:18 richard -# changes for the 0.2.1 distribution build. -# -# Revision 1.4 2001/07/27 07:20:17 richard -# Makefile is now obsolete - setup does what it used to do. -# -# Revision 1.3 2001/07/27 06:56:25 richard -# Added scripts to the setup and added the config so the default script -# install dir is /usr/local/bin. -# -# Revision 1.2 2001/07/26 07:14:27 richard -# Made setup.py executable, added id and log. -# -# -# # vim: set filetype=python ts=4 sw=4 et si