X-Git-Url: http://git.inspyration.org/?a=blobdiff_plain;f=setup.py;h=6e1adadde826c99f3b812c8256c809b9db83c7fb;hb=5d4ff77bd3fed31142d033aa731c0cdda866a7d3;hp=9c88ecca9aefc9b060fb1e6d5f1e9229b62f40ba;hpb=938ac06c4663253ce52b8a55dbb705fe0a3d48ca;p=odoo%2Fodoo.git diff --git a/setup.py b/setup.py index 9c88ecc..6e1adad 100755 --- a/setup.py +++ b/setup.py @@ -3,7 +3,7 @@ ############################################################################## # # OpenERP, Open Source Management Solution -# Copyright (C) 2004-2009 Tiny SPRL (). +# Copyright (C) 2004-2010 Tiny SPRL (). # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as @@ -20,179 +20,62 @@ # ############################################################################## -# setup from TinERP -# taken from straw http://www.nongnu.org/straw/index.html -# taken from gnomolicious http://www.nongnu.org/gnomolicious/ -# adapted by Nicolas Évrard -# - -import imp -import sys -import os -import glob - -from distutils.core import setup, Command -from distutils.command.install import install - -has_py2exe = False -if os.name == 'nt': - import py2exe - has_py2exe = True - -sys.path.append(os.path.join(os.path.abspath(os.path.dirname(__file__)), "bin")) - -opj = os.path.join - -execfile(opj('bin', 'release.py')) - -if sys.argv[1] == 'bdist_rpm': - version = version.split('-')[0] - -# get python short version -py_short_version = '%s.%s' % sys.version_info[:2] - -required_modules = [ - ('psycopg2', 'PostgreSQL module'), - ('xml', 'XML Tools for python'), - ('libxml2', 'libxml2 python bindings'), - ('libxslt', 'libxslt python bindings'), - ('reportlab', 'reportlab module'), - ('pychart', 'pychart module'), - ('pydot', 'pydot module'), - ('lxml', 'lxml module: pythonic libxml2 and libxslt bindings'), - ('mako','Mako templating library'), -] - -def check_modules(): - ok = True - for modname, desc in required_modules: - try: - exec('import %s' % modname) - except ImportError: - ok = False - print 'Error: python module %s (%s) is required' % (modname, desc) - - if not ok: - sys.exit(1) - -def _find_addons(): - for (dp, dn, names) in os.walk(opj('bin', 'addons')): - if '__terp__.py' in names: - modname = os.path.basename(dp) - yield (modname, dp) - #look for extra modules - try: - empath = os.getenv('EXTRA_MODULES_PATH','../addons/') - f = open(opj(empath,'server_modules.list'),'r') - # print 'Getting modules from:' , opj(empath,'server_modules.list') - mods = f.readlines() - for mname in mods: - mname = mname.strip() - if not mname: - continue - if os.path.exists(opj(empath,mname,'__terp__.py')): - yield ( mname, opj(empath,mname) ) - else: - print "Module %s specified, but no valid path." % mname - except: - pass +import glob, os, re, setuptools, sys +from os.path import join, isfile -__found_addons = None - -# Cache the results of _find_addons() and return them -def find_addons(found_addons = None): - if not found_addons: - found_addons = _find_addons() - return found_addons - -def data_files(): - '''Build list of data files to be installed''' +# List all data files +def data(): files = [] + for root, dirnames, filenames in os.walk('openerp'): + for filename in filenames: + if not re.match(r'.*(\.pyc|\.pyo|\~)$',filename): + files.append(os.path.join(root, filename)) + d = {} + for v in files: + k=os.path.dirname(v) + if k in d: + d[k].append(v) + else: + d[k]=[v] + r = d.items() if os.name == 'nt': - os.chdir('bin') - for (dp,dn,names) in os.walk('addons'): - files.append((dp, map(lambda x: opj('bin', dp, x), names))) - os.chdir('..') - for (dp,dn,names) in os.walk('doc'): - files.append((dp, map(lambda x: opj(dp, x), names))) - files.append(('.', [opj('bin', 'import_xml.rng'), - opj('bin', 'server.pkey'), - opj('bin', 'server.cert')])) - else: - man_directory = opj('share', 'man') - files.append((opj(man_directory, 'man1'), ['man/openerp-server.1'])) - files.append((opj(man_directory, 'man5'), ['man/openerp_serverrc.5'])) - - doc_directory = opj('share', 'doc', 'openerp-server-%s' % version) - files.append((doc_directory, [f for f in glob.glob('doc/*') if os.path.isfile(f)])) - files.append((opj(doc_directory, 'migrate', '3.3.0-3.4.0'), [f for f in glob.glob('doc/migrate/3.3.0-3.4.0/*') if os.path.isfile(f)])) - files.append((opj(doc_directory, 'migrate', '3.4.0-4.0.0'), [f for f in glob.glob('doc/migrate/3.4.0-4.0.0/*') if os.path.isfile(f)])) - - openerp_site_packages = opj('lib', 'python%s' % py_short_version, 'site-packages', 'openerp-server') - - files.append((openerp_site_packages, [opj('bin', 'import_xml.rng'), - opj('bin', 'server.pkey'), - opj('bin', 'server.cert')])) - - if sys.version_info[0:2] == (2,5): - files.append((openerp_site_packages, [ opj('python25-compat','BaseHTTPServer.py'), - opj('python25-compat','SimpleXMLRPCServer.py'), - opj('python25-compat','SocketServer.py')])) + r.append(("Microsoft.VC90.CRT", glob.glob('C:\Microsoft.VC90.CRT\*.*'))) - for (addonname, add_path) in find_addons(): - addon_path = opj('lib', 'python%s' % py_short_version, 'site-packages', 'openerp-server','addons', addonname) - pathfiles = [] - for root, dirs, innerfiles in os.walk(add_path): - innerfiles = filter(lambda fil: os.path.splitext(fil)[1] not in ('.pyc', '.pyd', '.pyo'), innerfiles) - if innerfiles: - res = os.path.normpath(opj(addon_path, root.replace(opj(add_path), '.'))) - pathfiles.extend(((res, map(lambda fil: opj(root, fil), innerfiles)),)) - files.extend(pathfiles) + import babel + r.append(("localedata", + glob.glob(os.path.join(os.path.dirname(babel.__file__), "localedata" , '*')))) - # for tup in files: - # print "Files:", tup[0], tup[1] - return files + return r -if not os.getenv('NO_CHECK_MODULES',False) : - check_modules() +def gen_manifest(): + file_list="\n".join(data()) + open('MANIFEST','w').write(file_list) -f = file('openerp-server','w') -start_script = """#!/bin/sh\necho "OpenERP Setup - The content of this file is generated at the install stage\n" """ -f.write(start_script) -f.close() - -def find_package_dirs(): - res = {} - for (mod, path) in find_addons(): - res ['openerp-server.addons.'+ mod ] = path - res ['openerp-server'] = 'bin' - return res +if os.name == 'nt': + sys.path.append("C:\Microsoft.VC90.CRT") -class openerp_server_install(install): - def run(self): - # create startup script - start_script = "#!/bin/sh\ncd %s\nexec %s ./openerp-server.py $@\n" % (opj(self.install_libbase, "openerp-server"), sys.executable) - # write script - f = open('openerp-server', 'w') - f.write(start_script) - f.close() - install.run(self) +def py2exe_options(): + if os.name == 'nt': + import py2exe + return { + "console" : [ { "script": "openerp-server", "icon_resources": [(1, join("install","openerp-icon.ico"))], }], + 'options' : { + "py2exe": { + "skip_archive": 1, + "optimize": 2, + "dist_dir": 'dist', + "packages": [ "DAV", "HTMLParser", "PIL", "asynchat", "asyncore", "commands", "dateutil", "decimal", "email", "encodings", "imaplib", "lxml", "lxml._elementpath", "lxml.builder", "lxml.etree", "lxml.objectify", "mako", "openerp", "poplib", "pychart", "pydot", "pyparsing", "reportlab", "select", "simplejson", "smtplib", "uuid", "vatnumber", "vobject", "xml", "xml.dom", "yaml", ], + "excludes" : ["Tkconstants","Tkinter","tcl"], + } + } + } + else: + return {} -options = { - "py2exe": { - "compressed": 1, - "optimize": 2, - "dist_dir": 'dist', - "packages": ["lxml", "lxml.builder", "lxml._elementpath", "lxml.etree", - "lxml.objectify", "decimal", "xml", "xml.dom", "xml.xpath", - "encodings","mx.DateTime","wizard","pychart","PIL", "pyparsing", - "pydot","asyncore","asynchat", "reportlab", "vobject","mako", - "HTMLParser", "select"], - "excludes" : ["Tkconstants","Tkinter","tcl"], - } -} +execfile(join(os.path.dirname(__file__), 'openerp', 'release.py')) -setup(name = name, +setuptools.setup( + name = 'openerp', version = version, description = description, long_description = long_desc, @@ -201,59 +84,43 @@ setup(name = name, author_email = author_email, classifiers = filter(None, classifiers.split("\n")), license = license, - data_files = data_files(), - cmdclass = { - 'install' : openerp_server_install, - }, scripts = ['openerp-server'], - packages = ['openerp-server', - 'openerp-server.addons', - 'openerp-server.ir', - 'openerp-server.osv', - 'openerp-server.service', - 'openerp-server.tools', - 'openerp-server.report', - 'openerp-server.report.printscreen', - 'openerp-server.report.pyPdf', - 'openerp-server.report.render', - 'openerp-server.report.render.rml2pdf', - 'openerp-server.report.render.rml2html', - 'openerp-server.report.render.rml2txt', - 'openerp-server.report.render.html2html', - 'openerp-server.report.render.makohtml2html', - 'openerp-server.wizard', - 'openerp-server.report.render.odt2odt', - 'openerp-server.workflow'] + \ - list(map( lambda (a, p): 'openerp-server.addons.'+ a ,find_addons())), - package_dir = find_package_dirs(), - console = [ { "script" : "bin\\openerp-server.py", "icon_resources" : [ (1,"pixmaps\\openerp-icon.ico") ] } ], - options = options, - ) + data_files = data(), + packages = setuptools.find_packages(), + #include_package_data = True, + install_requires = [ + # TODO the pychart package we include in openerp corresponds to PyChart 1.37. + # It seems there is a single difference, which is a spurious print in generate_docs.py. + # It is probably safe to move to PyChart 1.39 (the latest one). + # (Let setup.py choose the latest one, and we should check we can remove pychart from + # our tree.) http://download.gna.org/pychart/ + # TODO 'pychart', + 'babel', + 'feedparser', + 'gdata', + 'lxml', + 'mako', + 'psycopg2', + 'pydot', + 'python-dateutil < 2', + 'python-ldap', + 'python-openid', + 'pytz', + 'pywebdav', + 'pyyaml', + 'reportlab', + 'simplejson', + 'vatnumber', + 'vobject', + 'werkzeug', + 'xlwt', + 'zsi', + ], + extras_require = { + 'SSL' : ['pyopenssl'], + }, + **py2exe_options() +) -if has_py2exe: - # Sometime between pytz-2008a and pytz-2008i common_timezones started to - # include only names of zones with a corresponding data file in zoneinfo. - # pytz installs the zoneinfo directory tree in the same directory - # as the pytz/__init__.py file. These data files are loaded using - # pkg_resources.resource_stream. py2exe does not copy this to library.zip so - # resource_stream can't find the files and common_timezones is empty when - # read in the py2exe executable. - # This manually copies zoneinfo into the zip. See also - # http://code.google.com/p/googletransitdatafeed/issues/detail?id=121 - import pytz - import zipfile - # Make sure the layout of pytz hasn't changed - assert (pytz.__file__.endswith('__init__.pyc') or - pytz.__file__.endswith('__init__.py')), pytz.__file__ - zoneinfo_dir = os.path.join(os.path.dirname(pytz.__file__), 'zoneinfo') - # '..\\Lib\\pytz\\__init__.py' -> '..\\Lib' - disk_basedir = os.path.dirname(os.path.dirname(pytz.__file__)) - zipfile_path = os.path.join(options['py2exe']['dist_dir'], 'library.zip') - z = zipfile.ZipFile(zipfile_path, 'a') - for absdir, directories, filenames in os.walk(zoneinfo_dir): - assert absdir.startswith(disk_basedir), (absdir, disk_basedir) - zip_dir = absdir[len(disk_basedir):] - for f in filenames: - z.write(os.path.join(absdir, f), os.path.join(zip_dir, f)) - z.close() +# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: