Code

Indexers behaviour made more consistent regarding length of indexed words
[roundup.git] / setup.py
1 #! /usr/bin/env python
2 #
3 # Copyright (c) 2001 Bizar Software Pty Ltd (http://www.bizarsoftware.com.au/)
4 # This module is free software, and you may redistribute it and/or modify
5 # under the same terms as Python, so long as this copyright message and
6 # disclaimer are retained in their original form.
7 #
8 # IN NO EVENT SHALL BIZAR SOFTWARE PTY LTD BE LIABLE TO ANY PARTY FOR
9 # DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING
10 # OUT OF THE USE OF THIS CODE, EVEN IF THE AUTHOR HAS BEEN ADVISED OF THE
11 # POSSIBILITY OF SUCH DAMAGE.
12 #
13 # BIZAR SOFTWARE PTY LTD SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
14 # BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
15 # FOR A PARTICULAR PURPOSE.  THE CODE PROVIDED HEREUNDER IS ON AN "AS IS"
16 # BASIS, AND THERE IS NO OBLIGATION WHATSOEVER TO PROVIDE MAINTENANCE,
17 # SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
18 #
21 from roundup.dist.command.build_doc import build_doc
22 from roundup.dist.command.build_scripts import build_scripts
23 from roundup.dist.command.build_py import build_py
24 from roundup.dist.command.build import build, list_message_files
25 from roundup.dist.command.bdist_rpm import bdist_rpm
26 from distutils.core import setup
28 import sys, os
29 from glob import glob
31 # patch distutils if it can't cope with the "classifiers" keyword
32 from distutils.dist import DistributionMetadata
33 if not hasattr(DistributionMetadata, 'classifiers'):
34     DistributionMetadata.classifiers = None
35     DistributionMetadata.download_url = None
37 def include(d, e):
38     """Generate a pair of (directory, file-list) for installation.
40     'd' -- A directory
42     'e' -- A glob pattern"""
44     return (d, [f for f in glob('%s/%s'%(d, e)) if os.path.isfile(f)])
46 def scriptname(path):
47     """ Helper for building a list of script names from a list of
48         module files.
49     """
50     script = os.path.splitext(os.path.basename(path))[0]
51     script = script.replace('_', '-')
52     return script
54 def main():
55     # template munching
56     packages = [
57         'roundup',
58         'roundup.anypy',
59         'roundup.cgi',
60         'roundup.cgi.PageTemplates',
61         'roundup.cgi.TAL',
62         'roundup.cgi.ZTUtils',
63         'roundup.backends',
64         'roundup.scripts',
65     ]
66     py_modules = ['roundup.demo',]
68     # build list of scripts from their implementation modules
69     scripts = [scriptname(f) for f in glob('roundup/scripts/[!_]*.py')]
71     data_files = [
72         ('share/roundup/cgi-bin', ['frontends/roundup.cgi']),
73     ]
74     # install man pages on POSIX platforms
75     if os.name == 'posix':
76         data_files.append(include('share/man/man1', '*'))
78     # add the templates to the data files lists
79     from roundup.init import listTemplates
80     templates = [t['path']
81                  for t in listTemplates('share/roundup/templates').values()]
82     for tdir in templates:
83         for idir in '. detectors extensions html'.split():
84             data_files.append(include(os.path.join(tdir, idir), '*'))
86     # add message files
87     for (_dist_file, _mo_file) in list_message_files():
88         data_files.append((os.path.dirname(_mo_file),
89                            [os.path.join("build", _mo_file)]))
91     # add docs
92     data_files.append(include('share/doc/roundup/html', '*'))
94     # perform the setup action
95     from roundup import __version__
97     setup(name='roundup',
98           version=__version__,
99           author="Richard Jones",
100           author_email="richard@users.sourceforge.net",
101           description="A simple-to-use and -install issue-tracking system"
102             " with command-line, web and e-mail interfaces. Highly"
103             " customisable.",
104           long_description='''This version of Roundup fixes some bugs:
106 - fixed action taken in response to invalid GET request
107 - fixed classic tracker template to submit POST requests when appropriate
108 - fix problems with french and german locale files (issue 2550546)
109 - Run each message of the mail-gateway in a separate transaction,
110   see http://thread.gmane.org/gmane.comp.bug-tracking.roundup.user/9500
111 - fix problem with bounce-message if incoming mail has insufficient
112   privilege, e.g., user not existing (issue 2550534)
113 - fix construction of individual messages to nosy recipents with
114   attachments (issue 2550568)
115 - re-order sqlite imports to handle multiple installed versions (issue
116   2550570)
117 - don't show entire history by default
118   (fixes http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=540629)
119 - remove use of string exception
121 If you're upgrading from an older version of Roundup you *must* follow
122 the "Software Upgrade" guidelines given in the maintenance documentation.
124 Roundup requires python 2.3 or later (but not 3+) for correct operation.
126 To give Roundup a try, just download (see below), unpack and run::
128     roundup-demo
130 Documentation is available at the website:
131      http://roundup.sourceforge.net/
132 Mailing lists - the place to ask questions:
133      http://sourceforge.net/mail/?group_id=31577
135 About Roundup
136 =============
138 Roundup is a simple-to-use and -install issue-tracking system with
139 command-line, web and e-mail interfaces. It is based on the winning design
140 from Ka-Ping Yee in the Software Carpentry "Track" design competition.
142 Note: Ping is not responsible for this project. The contact for this
143 project is richard@users.sourceforge.net.
145 Roundup manages a number of issues (with flexible properties such as
146 "description", "priority", and so on) and provides the ability to:
148 (a) submit new issues,
149 (b) find and edit existing issues, and
150 (c) discuss issues with other participants.
152 The system will facilitate communication among the participants by managing
153 discussions and notifying interested parties when issues are edited. One of
154 the major design goals for Roundup that it be simple to get going. Roundup
155 is therefore usable "out of the box" with any python 2.3+ (but not 3+)
156 installation. It doesn't even need to be "installed" to be operational,
157 though an install script is provided.
159 It comes with two issue tracker templates (a classic bug/feature tracker and
160 a minimal skeleton) and five database back-ends (anydbm, sqlite, metakit,
161 mysql and postgresql).
162 ''',
163           url='http://www.roundup-tracker.org',
164           download_url='http://pypi.python.org/pypi/roundup',
165           classifiers=['Development Status :: 5 - Production/Stable',
166                        'Environment :: Console',
167                        'Environment :: Web Environment',
168                        'Intended Audience :: End Users/Desktop',
169                        'Intended Audience :: Developers',
170                        'Intended Audience :: System Administrators',
171                        'License :: OSI Approved :: Python Software Foundation License',
172                        'Operating System :: MacOS :: MacOS X',
173                        'Operating System :: Microsoft :: Windows',
174                        'Operating System :: POSIX',
175                        'Programming Language :: Python',
176                        'Topic :: Communications :: Email',
177                        'Topic :: Office/Business',
178                        'Topic :: Software Development :: Bug Tracking',
179                        ],
181           # Override certain command classes with our own ones
182           cmdclass= {'build_doc': build_doc,
183                      'build_scripts': build_scripts,
184                      'build_py': build_py,
185                      'build': build,
186                      'bdist_rpm': bdist_rpm,
187                      },
188           packages=packages,
189           py_modules=py_modules,
190           scripts=scripts,
191           data_files=data_files)
193 if __name__ == '__main__':
194     main()
196 # vim: set filetype=python sts=4 sw=4 et si :