diff --git a/setup.py b/setup.py
index 78f4315d466182d945e0fec8eef8695bb173b4cf..c2589f11850d66d29dbda17943aec83c9f6bfe36 100644 (file)
--- a/setup.py
+++ b/setup.py
# FOR A PARTICULAR PURPOSE. THE CODE PROVIDED HEREUNDER IS ON AN "AS IS"
# BASIS, AND THERE IS NO OBLIGATION WHATSOEVER TO PROVIDE MAINTENANCE,
# SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
-#
-# $Id: setup.py,v 1.17 2001-08-08 03:29:35 richard Exp $
+#
+
-from distutils.core import setup, Extension
-from distutils.util import get_platform
+from roundup.dist.command.build_doc import build_doc
+from roundup.dist.command.build_scripts import build_scripts
+from roundup.dist.command.build_py import build_py
+from roundup.dist.command.build import build, list_message_files
+from roundup.dist.command.bdist_rpm import bdist_rpm
+from distutils.core import setup
+import sys, os
from glob import glob
-import os
-from roundup.templatebuilder import makeHtmlBase
-
-print 'Running unit tests...'
-import test
-test.go()
-
-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)
-
-
-setup ( name = "roundup",
- version = "0.2.7",
- description = "Roundup issue tracking system.",
- author = "Richard Jones",
- author_email = "richard@sourceforge.net",
- url = 'http://sourceforge.net/projects/roundup/',
- packages = packagelist,
- scripts = ['roundup-admin', 'roundup-mailgw', 'roundup-server']
-)
-#
-# $Log: not supported by cvs2svn $
-# 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
+# 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
+
+def include(d, e):
+ """Generate a pair of (directory, file-list) for installation.
+
+ 'd' -- A directory
+
+ 'e' -- A glob pattern"""
+
+ return (d, [f for f in glob('%s/%s'%(d, e)) if os.path.isfile(f)])
+
+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 = script.replace('_', '-')
+ return script
+
+def main():
+ # template munching
+ packages = [
+ 'roundup',
+ 'roundup.anypy',
+ 'roundup.cgi',
+ 'roundup.cgi.PageTemplates',
+ 'roundup.cgi.TAL',
+ 'roundup.cgi.ZTUtils',
+ 'roundup.backends',
+ 'roundup.scripts',
+ ]
+ py_modules = ['roundup.demo',]
+
+ # build list of scripts from their implementation modules
+ scripts = [scriptname(f) for f in glob('roundup/scripts/[!_]*.py')]
+
+ data_files = [
+ ('share/roundup/cgi-bin', ['frontends/roundup.cgi']),
+ ]
+ # install man pages on POSIX platforms
+ if os.name == 'posix':
+ data_files.append(include('share/man/man1', '*'))
+
+ # add the templates to the data files lists
+ from roundup.init import listTemplates
+ templates = [t['path']
+ for t in listTemplates('share/roundup/templates').values()]
+ for tdir in templates:
+ for idir in '. detectors extensions html'.split():
+ data_files.append(include(os.path.join(tdir, idir), '*'))
+
+ # add message files
+ for (_dist_file, _mo_file) in list_message_files():
+ data_files.append((os.path.dirname(_mo_file),
+ [os.path.join("build", _mo_file)]))
+
+ # add docs
+ data_files.append(include('share/doc/roundup/html', '*'))
+
+ # perform the setup action
+ from roundup import __version__
+
+ setup(name='roundup',
+ version=__version__,
+ author="Richard Jones",
+ author_email="richard@users.sourceforge.net",
+ description="A simple-to-use and -install issue-tracking system"
+ " with command-line, web and e-mail interfaces. Highly"
+ " customisable.",
+ long_description='''This version of Roundup fixes some bugs:
+
+- Minor update of doc/developers.txt to point to the new resources
+ on www.roundup-tracker.org (Bernhard Reiter)
+- Small CSS improvements regaring the search box (thanks Thomas Arendsan Hein)
+ (issue 2550589)
+- Indexers behaviour made more consistent regarding length of indexed words
+ and stopwords (thanks Thomas Arendsen Hein, Bernhard Reiter)(issue 2550584)
+- fixed typos in the installation instructions (thanks Thomas Arendsen Hein)
+ (issue 2550573)
+- New config option csv_field_size: Pythons csv module (which is used
+ for export/import) has a new field size limit starting with python2.5.
+ We now issue a warning during export if the limit is too small and use
+ the csv_field_size configuration during import to set the limit for
+ the csv module.
+- Small fix for CGI-handling of XMLRPC requests for python2.4, this
+ worked only for 2.5 and beyond due to a change in the xmlrpc interface
+ in python
+- Document filter method of xmlrpc interface
+- Fix interaction of SSL and XMLRPC, now XMLRPC works with SSL
+
+If you're upgrading from an older version of Roundup you *must* follow
+the "Software Upgrade" guidelines given in the maintenance documentation.
+
+Roundup requires python 2.3 or later (but not 3+) for correct operation.
+
+To give Roundup a try, just download (see below), unpack and run::
+
+ roundup-demo
+
+Documentation is available at the website:
+ http://roundup.sourceforge.net/
+Mailing lists - the place to ask questions:
+ http://sourceforge.net/mail/?group_id=31577
+
+About Roundup
+=============
+
+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.
+
+Note: Ping is not responsible for this project. The contact for this
+project is richard@users.sourceforge.net.
+
+Roundup manages a number of issues (with flexible properties such as
+"description", "priority", and so on) and provides the ability to:
+
+(a) submit new issues,
+(b) find and edit existing issues, and
+(c) discuss issues with other participants.
+
+The system will facilitate communication among the participants by managing
+discussions and notifying interested parties when issues are edited. One of
+the major design goals for Roundup that it be simple to get going. Roundup
+is therefore usable "out of the box" with any python 2.3+ (but not 3+)
+installation. It doesn't even need to be "installed" to be operational,
+though an install script is provided.
+
+It comes with two issue tracker templates (a classic bug/feature tracker and
+a minimal skeleton) and five database back-ends (anydbm, sqlite, metakit,
+mysql and postgresql).
+''',
+ url='http://www.roundup-tracker.org',
+ download_url='http://pypi.python.org/pypi/roundup',
+ classifiers=['Development Status :: 5 - Production/Stable',
+ '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_doc': build_doc,
+ 'build_scripts': build_scripts,
+ 'build_py': build_py,
+ 'build': build,
+ 'bdist_rpm': bdist_rpm,
+ },
+ packages=packages,
+ py_modules=py_modules,
+ scripts=scripts,
+ data_files=data_files)
+
+if __name__ == '__main__':
+ main()
+
+# vim: set filetype=python sts=4 sw=4 et si :