X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=setup.py;h=8fe03db6e38a8a163c7d92e1d990ecf15e61d512;hb=840af79b7d2c41ed0dfd70b496b6b5f3ffefc510;hp=9c1d9f6f27ddd8551377bb82c65b92e7addfad32;hpb=43f2108e486f7a937491bd0df9a68fa4b498b48f;p=roundup.git diff --git a/setup.py b/setup.py index 9c1d9f6..8fe03db 100644 --- a/setup.py +++ b/setup.py @@ -15,285 +15,140 @@ # 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.46 2003-04-10 04:33:02 richard Exp $ +# + -from distutils.core import setup, Extension -from distutils.util import get_platform -from distutils.command.build_scripts import build_scripts +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 roundup.dist.command.install_lib import install_lib +from distutils.core import setup -import sys, os, string +import sys, os from glob import glob # patch distutils if it can't cope with the "classifiers" keyword -if sys.version < '2.2.3': - from distutils.dist import DistributionMetadata +from distutils.dist import DistributionMetadata +if not hasattr(DistributionMetadata, 'classifiers'): DistributionMetadata.classifiers = None DistributionMetadata.download_url = None -from roundup.templates.builder import makeHtmlBase - - -############################################################################# -### 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. - - 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) - script_vars = { - 'python': os.path.normpath(sys.executable), - 'package': self.package_name, - 'module': module, - } +def include(d, e): + """Generate a pair of (directory, file-list) for installation. - self.announce("creating %s" % outfile) - file = open(outfile, 'w') + 'd' -- A directory - 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' - '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' + '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 = string.replace(script, '_', '-') - if sys.platform == "win32": - script = script + ".bat" + script = script.replace('_', '-') return script - - -############################################################################# -### Main setup stuff -############################################################################# - -def isTemplateDir(dir): - return dir[0] != '.' and dir != 'CVS' and os.path.isdir(dir) \ - and os.path.isfile(os.path.join(dir, '__init__.py')) - -# use that function to list all the templates -templates = map(os.path.basename, filter(isTemplateDir, - glob(os.path.join('roundup', 'templates', '*')))) - -def buildTemplates(): - for template in templates: - tdir = os.path.join('roundup', 'templates', template) - makeHtmlBase(tdir) - def main(): - # build list of scripts from their implementation modules - roundup_scripts = map(scriptname, glob('roundup/scripts/[!_]*.py')) - # template munching - templates = map(os.path.basename, filter(isTemplateDir, - glob(os.path.join('roundup', 'templates', '*')))) - packagelist = [ + packages = [ 'roundup', + 'roundup.anypy', 'roundup.cgi', 'roundup.cgi.PageTemplates', 'roundup.cgi.TAL', 'roundup.cgi.ZTUtils', 'roundup.backends', 'roundup.scripts', - 'roundup.templates' ] - installdatafiles = [ - ('share/roundup/cgi-bin', ['cgi-bin/roundup.cgi']), - ] + 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': - installdatafiles.append(('man/man1', ['doc/roundup-admin.1', - 'doc/roundup-mailgw.1', 'doc/roundup-server.1'])) + data_files.append(include('share/man/man1', '*')) - # munge the template HTML into the htmlbase module - buildTemplates() + # 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 the templates to the setup packages and data files lists - for template in templates: - tdir = os.path.join('roundup', 'templates', template) + # 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 the template package and subpackage - packagelist.append('roundup.templates.%s' % template) - packagelist.append('roundup.templates.%s.detectors' % template) - - # scan for data files - tfiles = glob(os.path.join(tdir, 'html', '*')) - tfiles = filter(os.path.isfile, tfiles) - installdatafiles.append( - ('share/roundup/templates/%s/html' % template, tfiles) - ) + # add docs + data_files.append(include('share/doc/roundup/html', '*')) # perform the setup action from roundup import __version__ - setup( - name = "roundup", - version = __version__, - description = "Roundup issue tracking system.", - author = "Richard Jones", - author_email = "richard@users.sourceforge.net", - url = 'http://sourceforge.net/projects/roundup/', - download_url = 'http://sourceforge.net/project/showfiles.php?group_id=31577', - packages = packagelist, - 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 - ) - -def install_demo(): - ''' Install a demo server for users to play with for instant gratification. - - Sets up the web service on localhost port 8080. Disables nosy lists. - ''' - import shutil, socket, errno, BaseHTTPServer - - # create the instance - home = os.path.abspath('demo') - try: - shutil.rmtree(home) - except os.error, error: - if error.errno != errno.ENOENT: - raise - from roundup import init, instance, password - init.install(home, 'classic') - # don't have email flying around - os.remove(os.path.join(home, 'detectors', 'nosyreaction.py')) - init.write_select_db(home, 'anydbm') - - # figure basic params for server - hostname = socket.gethostname() - port = 8080 - while 1: - print 'Trying to set up web server on port %d ...'%port, - s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) - s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) - try: - s.connect((hostname, port)) - except socket.error, e: - if not hasattr(e, 'args') or e.args[0] != errno.ECONNREFUSED: - raise - print 'should be ok.' - break - else: - s.close() - print 'already in use.' - port += 100 - url = 'http://%s:%s/demo/'%(hostname, port) - - # write the config - f = open(os.path.join(home, 'config.py'), 'r') - s = f.read().replace('http://tracker.example/cgi-bin/roundup.cgi/bugs/', - url) - f.close() - f = open(os.path.join(home, 'config.py'), 'w') - f.write(s) - f.close() - - # initialise the database - init.initialise(home, 'admin') - - # add the "demo" user - tracker = instance.open(home) - db = tracker.open('admin') - db.user.create(username='demo', password=password.Password('demo'), - realname='Demo User', roles='User') - db.commit() - db.close() - # ok, so start up the server - from roundup.scripts.roundup_server import RoundupRequestHandler - RoundupRequestHandler.TRACKER_HOMES = {'demo': home} - httpd = BaseHTTPServer.HTTPServer((hostname, port), RoundupRequestHandler) - print 'Server running - connect to:\n %s'%url - print 'You may log in as "demo"/"demo" or "admin"/"admin".' - print 'Hit Control-C to stop the server.' + # long_description may not contain non-ascii characters. Distutils + # will produce an non-installable installer on linux *and* we can't + # run the bdist_wininst on Linux if there are non-ascii characters + # because the distutils installer will try to use the mbcs codec + # which isn't available on non-windows platforms. See also + # http://bugs.python.org/issue10945 + long_description=open('doc/announcement.txt').read().decode('utf8') try: - httpd.serve_forever() - except KeyboardInterrupt: - print 'Keyboard Interrupt: exiting' + long_description = long_description.encode('ascii') + except UnicodeEncodeError, cause: + print >> sys.stderr, "doc/announcement.txt contains non-ascii: %s" \ + % cause + sys.exit(42) + + 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=long_description, + 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, + 'install_lib': install_lib, + }, + packages=packages, + py_modules=py_modules, + scripts=scripts, + data_files=data_files) if __name__ == '__main__': - if len(sys.argv) > 1 and sys.argv[1] == 'demo': - install_demo() - else: - main() + main() -# vim: set filetype=python ts=4 sw=4 et si +# vim: set filetype=python sts=4 sw=4 et si :