Mercurial > p > roundup > code
diff setup.py @ 602:c242455d9b46 config-0-4-0-branch
Brought the config branch up to date with HEAD
| author | Richard Jones <richard@users.sourceforge.net> |
|---|---|
| date | Wed, 06 Feb 2002 04:05:55 +0000 |
| parents | a1e778940f92 |
| children |
line wrap: on
line diff
--- a/setup.py Wed Feb 06 03:47:17 2002 +0000 +++ b/setup.py Wed Feb 06 04:05:55 2002 +0000 @@ -16,19 +16,107 @@ # BASIS, AND THERE IS NO OBLIGATION WHATSOEVER TO PROVIDE MAINTENANCE, # SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS. # -# $Id: setup.py,v 1.26 2001-12-08 07:06:20 jhermann Exp $ +# $Id: setup.py,v 1.26.2.1 2002-02-06 04:05:53 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() + +############################################################################# +### 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 + + <packagename>.scripts.<mangled_scriptname> + + 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, + } + + self.announce("creating %s" % outfile) + file = open(outfile, 'w') + + try: + if sys.platform == "win32": + file.write('@echo off\n' + '%(python)s -c "from %(package)s.scripts.%(module)s import run; run()" %%$\n' + % script_vars) + else: + file.write('#! %(python)s\n' + 'from %(package)s.scripts.%(module)s import run\n' + 'run()\n' + % script_vars) + finally: + file.close() + + +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 + +# build list of scripts from their implementation modules +roundup_scripts = map(scriptname, glob('roundup/scripts/[!_]*.py')) + + +############################################################################# +### Main setup stuff +############################################################################# def isTemplateDir(dir): return dir[0] != '.' and dir != 'CVS' and os.path.isdir(dir) \ @@ -39,6 +127,7 @@ packagelist = [ 'roundup', 'roundup.backends', + 'roundup.scripts', 'roundup.templates' ] installdatafiles = [ @@ -63,19 +152,40 @@ setup( name = "roundup", - version = "0.3.0", + version = "0.4.0", description = "Roundup issue tracking system.", author = "Richard Jones", author_email = "richard@users.sourceforge.net", url = 'http://sourceforge.net/projects/roundup/', packages = packagelist, - scripts = ['roundup-admin', 'roundup-mailgw', 'roundup-server'], + + # Override certain command classes with our own ones + cmdclass = { + 'build_scripts': build_scripts_roundup, + }, + scripts = roundup_scripts, + data_files = installdatafiles ) # # $Log: not supported by cvs2svn $ +# Revision 1.30 2002/01/29 20:07:15 jhermann +# Conversion to generated script stubs +# +# Revision 1.29 2002/01/23 06:05:36 richard +# prep work for release +# +# Revision 1.28 2002/01/11 03:24:15 richard +# minor changes for 0.4.0b2 +# +# Revision 1.27 2002/01/05 02:09:46 richard +# make setup abort if tests fail +# +# Revision 1.26 2001/12/08 07:06:20 jhermann +# Install html template files to share/roundup/templates +# # Revision 1.25 2001/11/21 23:42:54 richard # Some version number and documentation fixes. #
