diff options
Diffstat (limited to 'src/kdedistutils.py')
-rw-r--r-- | src/kdedistutils.py | 2278 |
1 files changed, 0 insertions, 2278 deletions
diff --git a/src/kdedistutils.py b/src/kdedistutils.py deleted file mode 100644 index ceaa499..0000000 --- a/src/kdedistutils.py +++ /dev/null @@ -1,2278 +0,0 @@ -#!/usr/bin/python -########################################################################### -# kdedistutils - description # -# ------------------------------ # -# begin : Thu Apr 21 2005 # -# copyright : (C) 2005 by Simon Edwards # -# email : [email protected] # -# # -########################################################################### -# # -# This program is free software; you can redistribute it and/or modify # -# it under the terms of the GNU Library General Public License as # -# published by the Free Software Foundation; either version 2 of the # -# License, or (at your option) any later version. # -# # -########################################################################### - -import distutils.core -from distutils.core import Extension -from distutils.cmd import Command -from distutils.dist import Distribution -from distutils.command.build import build -from distutils.command.install import install -from distutils.command.install_scripts import install_scripts -from distutils.command.install_data import install_data -from distutils.command.install_lib import install_lib -from distutils.util import change_root, convert_path -from distutils.spawn import find_executable,spawn -from distutils import sysconfig -from distutils import log -from distutils import file_util -from distutils import dir_util -from distutils.util import byte_compile -import qtuicompiler -import stat -import os,os.path,imp,glob -import sys -from types import StringType - -INSTALL_LIST = 'install_log.txt' - -# Trinity-specific paths -tqt_modules = [] -for m_path in sys.path: - if os.path.exists(os.path.join(m_path, 'sip4_tqt')): - m_sip_dir = os.path.join(m_path, 'sip4_tqt') - tqt_modules.insert(0, m_sip_dir) - if os.path.exists(os.path.join(m_path, 'python_tqt')): - m_pyqt_dir = os.path.join(m_path, 'python_tqt') - tqt_modules.insert(0, m_pyqt_dir) -for m_path in tqt_modules: - sys.path.insert(0, m_path) - - -########################################################################### -def setup(**arg_dict): - - if 'cmdclass' not in arg_dict: - arg_dict['cmdclass'] = {} - - cmdclass = arg_dict['cmdclass'] - - arg_dict.setdefault('data_files',[]) - - kdecmdclass = {'install' : InstallKDE, - 'install_executable_links' : InstallExecutableLinks, - 'install_application_data' : InstallApplicationDataAndLinks, - 'build_messages' : BuildI18NMessages, - 'install_messages' : InstallI18NMessages, - 'update_messages' : UpdateI18NMessages, - 'checkpyqt' : CheckPyQt, - 'checkpytde' : CheckPyTDE, - 'uninstall' : Uninstall, - 'build' : BuildKDE, - 'build_kcm' : BuildKControlModule, - 'install_kcm' : InstallKControlModule, - 'build_html' : BuildDocbookHTML, - 'install_html' : InstallDocbookHTML, - 'install_lib' : InstallLibWithRoot, - 'build_tdeioslave' : BuildTdeioslave, - 'install_tdeioslave' : InstallTdeioslave} - - for key in kdecmdclass.iterkeys(): - cmdclass.setdefault(key,kdecmdclass[key]) - - arg_dict.setdefault('distclass',KDEDistribution) - - apply(distutils.core.setup,[],arg_dict) - -########################################################################### -class KDEDistribution(Distribution): - def __init__(self,attrs=None): - self.min_kde_version = None - self.min_qt_version = None - self.kcontrol_modules = None - self.tdeioslaves = None - self.executable_links = None - self.docbooks = None - self.application_data = None - self.i18n = None - Distribution.__init__(self,attrs) - -########################################################################### -def has_kcms(self): - if self.distribution.kcontrol_modules is None: - return 0 - return len(self.distribution.kcontrol_modules)!=0 - -def has_docbook_html(self): - if self.distribution.docbooks is None: - return 0 - return len(self.distribution.docbooks)!=0 - -def has_messages(self): - if self.distribution.i18n is None: - return 0 - return len(self.distribution.i18n)!=0 - -def has_application_data(self): - if self.distribution.application_data is None: - return 0 - return len(self.distribution.application_data)!=0 - -def has_tdeioslaves(self): - if self.distribution.tdeioslaves is None: - return 0 - return len(self.distribution.tdeioslaves)!=0 - -########################################################################### -# Our slightly extended build command. This also does kcontrol modules. -class BuildKDE(build): - - user_options = build.user_options[:] - user_options.append( ('msgfmt-exe=',None,'Path to the msgfmt executable') ) - user_options.append( ('meinproc-exe=',None,'Path to the meinproc executable') ) - - sub_commands = build.sub_commands[:] - sub_commands.append( ('build_kcm',has_kcms) ) - sub_commands.append( ('build_tdeioslave',has_tdeioslaves) ) - sub_commands.append( ('build_html',has_docbook_html) ) - sub_commands.append( ('build_messages',has_messages) ) - - def __init__(self,dist): - build.__init__(self,dist) - self.has_kcms = has_kcms - self.has_tdeioslaves = has_tdeioslaves - self.has_docbook_html = has_docbook_html - self.has_messages = has_messages - - def initialize_options(self): - self.msgfmt_exe = None - self.meinproc_exe = None - build.initialize_options(self) - - def finalize_options(self): - build.finalize_options(self) - - if self.msgfmt_exe is None: - # Find msgfmt - canidatepaths = [] - canidatepaths.append( ask_kde_config('--install exe --expandvars').strip() ) - self.msgfmt_exe = FindExeOnPath('msgfmt',canidatepaths) - if self.msgfmt_exe is None: - raise SystemExit, "Unable to find 'msgfmt', needed to build i18n messages." - - if self.meinproc_exe is None: - # Find meinproc - canidatepaths = [] - canidatepaths.append( ask_kde_config('--install exe --expandvars').strip() ) - self.meinproc_exe = FindExeOnPath('meinproc',canidatepaths) - if self.meinproc_exe is None: - raise SystemExit, "Unable to find 'meinproc', needed to generate Docbook HTML documentation." - -########################################################################### -def has_executable_links(self): - if self.distribution.executable_links is None: - return 0 - return len(self.distribution.executable_links)!=0 - -########################################################################### -class InstallKDE(install): - user_options = install.user_options[:] - user_options.append( ('kde-prefix=',None,"TDE installation prefix") ) - user_options.append( ('install-messages=',None,"installation directory for i18n message files") ) - user_options.append( ('install-html=',None,"installation directory for Docbook HTML files") ) - user_options.append( ('install-cmd=',None,"Command to use to install the files") ) - user_options.append( ('install-xdg-apps=',None,"directory for XDG app files") ) - user_options.append( ('install-kcm=',None,"directory for kcm library files") ) - user_options.append( ('install-tdeioslave',None,"directory for tdeioslave library files") ) - user_options.append( ('install-protocol',None,"directory for tdeioslave protocol files") ) - - sub_commands = install.sub_commands[:] - sub_commands.insert(0, ('checkpytde',None) ) - sub_commands.insert(0, ('checkpyqt',None) ) - sub_commands.append( ('install_executable_links',has_executable_links) ) - sub_commands.append( ('install_messages',has_messages) ) - sub_commands.append( ('install_html',has_docbook_html) ) - sub_commands.append( ('install_kcm',has_kcms) ) - sub_commands.append( ('install_tdeioslave',has_tdeioslaves) ) - sub_commands.append( ('install_application_data',has_application_data) ) - - def initialize_options(self): - self.kde_prefix = None - self.install_messages = None - self.install_html = None - self.install_cmd = None - self.install_xdg_apps = None - self.install_kcm = None - self.install_tdeioslave = None - self.install_protocol = None - self.install_application_data = None - install.initialize_options(self) - - def finalize_options(self): - # If no install prefix was provided, then we try to detect the KDE install prefix. - self.user_supplied_kde_prefix = True - - if self.install_scripts is None: - if self.kde_prefix is not None: - self.install_scripts = os.path.join(self.kde_prefix,'bin') - else: - self.announce("Detecting TDE 'bin' directory...") - self.install_scripts = ask_kde_config('--install exe --expandvars').strip() - self.announce(" ...TDE 'bin' directory is %s" % self.install_scripts) - - if self.install_application_data is None: - if self.kde_prefix is not None: - self.install_application_data = os.path.join(self.kde_prefix,'share/apps',self.distribution.metadata.name) - else: - self.announce("Detecting TDE application directory...") - kdeappdir = ask_kde_config('--install data --expandvars').strip() - self.announce(" ...TDE application directory is %s" % self.install_application_data) - self.install_application_data = os.path.join(kdeappdir,self.distribution.metadata.name) - - if self.install_messages is None: - if self.kde_prefix is not None: - self.install_messages = os.path.join(self.kde_prefix,'share/locale') - else: - self.announce("Detecting TDE messages directory...") - self.install_messages = ask_kde_config('--install locale --expandvars').strip() - self.announce(" ...TDE messages directory is %s" % self.install_messages) - - if self.install_html is None: - if self.kde_prefix is not None: - self.install_html = os.path.join(self.kde_prefix,'share/doc/tde/HTML') - else: - self.announce("Detecting TDE HTML directory...") - self.install_html = ask_kde_config('--install html --expandvars').strip() - self.announce(" ...TDE HTML directory is %s" % self.install_html) - - if self.kde_prefix is None: - self.announce("Detecting TDE install prefix...") - self.kde_prefix = ask_kde_config('--prefix').strip() - self.announce(" ...TDE install prefix is %s" % self.kde_prefix) - self.user_supplied_kde_prefix = False - - if self.install_cmd is None: - self.announce("Detecting 'install' command...") - # Ok, time to find the install command. - self.install_cmd = find_executable('install') - if self.install_cmd is None: - raise SystemExit, "Unable to find the 'install' command, needed to install libraries." - self.announce(" ...'install' command is %s" % self.install_cmd) - - if self.install_xdg_apps is None: - self.announce("Detecting XDG apps directory...") - self.install_xdg_apps = ask_kde_config('--install xdgdata-apps --expandvars').strip() - self.announce(" ...XDG apps directory is %s" % self.install_xdg_apps) - - if self.install_kcm is None: - self.announce("Detecting kcm library directory...") - self.install_kcm = os.path.join(ask_kde_config('--install lib --expandvars').strip(),'trinity') - self.announce(" ...kcm library directory is %s" % self.install_kcm) - - if self.install_tdeioslave is None: - self.announce("Detecting tdeioslave library directory...") - self.install_tdeioslave = os.path.join(ask_kde_config('--install lib --expandvars').strip(),'trinity') - self.announce(" ...tdeioslave library directory is %s" % self.install_tdeioslave) - - if self.install_protocol is None: - self.announce("Detecting tdeioslave protocol directory...") - self.install_protocol = ask_kde_config('--install services --expandvars').strip() - self.announce(" ...tdeioslave protocol directory is %s" % self.install_protocol) - - install.finalize_options(self) - - if self.root is not None: - self.change_roots('application_data','html','messages','xdg_apps','kcm') - - def get_command_name(self): - return 'install' - - def run(self): - global INSTALL_LIST - install.run(self) - - # Write out the uninstall list. - fhandle = open(INSTALL_LIST,'w') - for item in self.get_outputs(): - fhandle.write(item) - fhandle.write('\n') - fhandle.close() - -########################################################################### -class InstallApplicationDataAndLinks(install_data): - def get_command_name(self): - return 'install_application_data' - - def initialize_options(self): - install_data.initialize_options(self) - - self.data_files = self.distribution.application_data - - def finalize_options(self): - self.set_undefined_options('install', - ('install_application_data', 'install_dir'), - ('root', 'root'), - ('force', 'force'), - ) - - def run(self): - self.outfiles.extend(self.mkpath(self.install_dir)) - for f in self.data_files: - if type(f) is StringType: - # it's a simple file, so copy it - f = convert_path(f) - if self.warn_dir: - self.warn("setup script did not provide a directory for " - "'%s' -- installing right in '%s'" % - (f, self.install_dir)) - if os.path.isfile(f): - (out, _) = self.copy_file(f, self.install_dir) - self.outfiles.append(out) - elif os.path.isdir(f): - out = self.copy_tree(f,os.path.join(self.install_dir,f)) - self.outfiles.extend(out) - else: - self.warn("Setup script can't find file or directory %s needed for installation." % f) - else: - # it's a tuple with path to install to and a list of files - dir = convert_path(f[0]) - if not os.path.isabs(dir): - dir = change_root(self.install_dir, dir) - elif self.root: - dir = change_root(self.root, dir) - self.outfiles.extend(self.mkpath(dir)) - - if f[1] == []: - # If there are no files listed, the user must be - # trying to create an empty directory, so add the - # directory to the list of output files. - self.outfiles.append(dir) - else: - # Copy files, adding them to the list of output files. - for data in f[1]: - data = convert_path(data) - if os.path.islink(data): - # Transplant the link to the new location without changing - # where it points to. (ie it is _not_ relocated). - dest = os.path.join(dir, os.path.basename(data)) - if os.path.exists(dest): - os.remove(dest) - os.symlink(os.readlink(data),dest) - log.info("moving link %s -> %s" % (data,dest) ) - #os.chmod(dest, os.stat(data)[stat.ST_MODE]) - elif os.path.isdir(data): - out = self.copy_tree(data,dir) - self.outfiles.extend(out) - else: - (out, _) = self.copy_file(data, dir) - self.outfiles.append(out) - - # Compile the .ui files - install_cmd = self.get_finalized_command('install') - prefix = self.install_dir - if prefix[-1] != os.sep: - prefix = prefix + os.sep - self.outfiles.extend(compile_qtdesigner(self.outfiles, force=1, prefix=prefix, base_dir=install_cmd.prefix, dry_run=self.dry_run)) - - # Byte compile the .py files - from distutils.util import byte_compile - byte_compile(self.outfiles, optimize=0, force=1, prefix=prefix, base_dir=install_cmd.prefix, dry_run=self.dry_run) - - # Add the .pyc files to the list of outfiles. - self.outfiles.extend( [item+'c' for item in self.outfiles if item.endswith('.py')] ) - - def mkpath(self, name, mode=0777): - return dir_util.mkpath(name, mode, dry_run=self.dry_run) - -########################################################################### -class InstallExecutableLinks(Command): - description = "Install symlinks" - - user_options = [] - - def initialize_options(self): - self.outfiles = [] - - def finalize_options(self): - pass - - def get_command_name(self): - return 'install_executable_links' - - def run(self): - # FIXME add cmd options? - install_script_cmd = self.get_finalized_command('install_scripts') - install_data_cmd = self.get_finalized_command('install_application_data') - - destination_dir = install_data_cmd.install_dir - - if not os.path.exists(install_script_cmd.install_dir): - self.outfiles.extend(self.mkpath(install_script_cmd.install_dir)) - - if self.distribution.executable_links is not None: - for link in self.distribution.executable_links: - symname = os.path.join(install_script_cmd.install_dir,link[0]) - target = os.path.join(destination_dir,link[1]) - log.info("symlinking %s -> %s", symname, target) - if not self.dry_run: - if os.path.islink(symname): - os.remove(symname) - os.symlink(target,symname) - self.outfiles.append(symname) - - def get_outputs(self): - return self.outfiles or [] - - def mkpath(self, name, mode=0777): - return dir_util.mkpath(name, mode, dry_run=self.dry_run) - -########################################################################### -# Fix the --root option for the install_lib command. -class InstallLibWithRoot(install_lib): - user_options = install_lib.user_options[:] - user_options.append( ('root=',None,"install everything relative to this alternate root directory") ) - - def initialize_options(self): - install_lib.initialize_options(self) - self.root = None - - def finalize_options(self): - own_install_dir = self.install_dir is not None - - install_lib.finalize_options(self) - self.set_undefined_options('install', ('root', 'root')) - - if self.root is not None and own_install_dir: - self.install_dir = change_root(self.root, self.install_dir) - -########################################################################### -class Uninstall(Command): - description = "Remove all installed files" - - user_options = [] - - def initialize_options(self): - pass - - def finalize_options(self): - pass - - def get_command_name(self): - return 'uninstall' - - def run(self): - global INSTALL_LIST - - if not os.path.isfile(INSTALL_LIST): - self.announce("Unable to uninstall, can't find the file list %s." % INSTALL_LIST) - return - - # Suck in the file list. - fhandle = open(INSTALL_LIST,'r') - file_list = fhandle.readlines() - fhandle.close() - - # Remove the files first. - for item in file_list: - item = item.strip() - if os.path.isfile(item) or os.path.islink(item): - self.announce("removing '%s'" % item) - if not self.dry_run: - try: - os.remove(item) - except OSError, details: - self.warn("Could not remove file: %s" % details) - elif not os.path.isdir(item): - self.announce("skipping removal of '%s' (does not exist)" % item) - - # Remove the directories. - file_list.sort() - file_list.reverse() - # Starting with the longest paths first. - for item in file_list: - item = item.strip() - if os.path.isdir(item): - self.announce("removing '%s'" % item) - if not self.dry_run: - try: - os.rmdir(item) - except OSError, details: - self.warn("Could not remove directory: %s" % details) - -########################################################################### -class BuildKControlModule(Command): - description = "Build KControl extensions" - - user_options = [('no-kcontrol',None,"Don't build kcontrol extensions"), - ('build-dir=','b', "build directory (where to install from)"), - ('python-dir=',None,'Directory containing the Python installation'), - ('python-inc-dir=',None,'Directory containing C Header files for Python'), - ('kde-inc-dir=',None,'Directory containing C++ header files for KDE'), - ('kde-lib-dir=',None,'Directory containing library files for KDE'), - ('kde-kcm-lib-dir=',None,'Directory for KDE kcm library files'), - ('qt-inc-dir=',None,'Directory containing C++ header files for Qt'), - ('qt-lib-dir=',None,'Directory containing library files for Qt'), - ('sip-dir=',None,'Directory containing the sip library files'), - ('clib=',None,'gcc library and path'), - ('pyqt-dir=',None,'PyQt module directory'), - ('pytde-dir=',None,'PyTDE module directory'), - ('data-dir=',None,'installation directory for data (script) files')] - - def initialize_options(self): - self.no_kcontrol = 0 - self.build_dir = None - self.python_inc_dir = None - self.python_dir = None - self.kde_inc_dir = None - self.kde_lib_dir = None - self.kde_kcm_lib_dir = None - self.qt_inc_dir = None - self.qt_lib_dir = None - self.sip_dir = None - self.clib = None - self.pyqt_dir = None - self.pytde_dir = None - self.data_dir = None - - def finalize_options(self): - if self.no_kcontrol==0: - self.set_undefined_options('install', ('build_base', 'build_dir'),('install_application_data','data_dir')) - - install = self.get_finalized_command('install') - self.install_prefix = ask_kde_config('--prefix').strip() - - # KDE inc dir: find it! - if self.kde_inc_dir is None: - canidatepaths = [] - tdedir = os.getenv("TDEDIR") - if tdedir!=None: - canidatepaths.append(os.path.join(tdedir,"include")) - canidatepaths.append(os.path.join(install.prefix,"include")) - canidatepaths.append(os.path.join(self.install_prefix,'include')) - canidatepaths.append(os.path.join(self.install_prefix,'include','tde')) - self.kde_inc_dir = FindFileInPaths('tdeapplication.h',canidatepaths) - if self.kde_inc_dir is None: - raise SystemExit, "Failed to find the KDE header file directory." - if FindFileInPaths('tdeapplication.h',[self.kde_inc_dir]) is None: - raise SystemExit, "Failed to find KDE header files in: %s" % self.kde_inc_dir - self.announce("Using %s for KDE header files" % self.kde_inc_dir) - - # KDE lib dir - if self.kde_lib_dir is None: - self.kde_lib_dir = os.path.join(self.install_prefix,"lib") - self.announce("Using %s for KDE library files" % self.kde_lib_dir) - - # KDE KCM lib dir - if self.kde_kcm_lib_dir is None: - self.kde_kcm_lib_dir = os.path.join(self.kde_lib_dir,"trinity") - if FindFileInPaths('*kcm*.so',[self.kde_kcm_lib_dir]) is None: - raise SystemExit, "Failed to find KDE KCM files in: %s" % self.kde_kcm_lib_dir - self.announce("Using %s for KDE KCM library files" % self.kde_kcm_lib_dir) - - # Qt inc dir - if self.qt_inc_dir is None: - canidatepaths = [] - qtinc = os.getenv("QTINC") - if qtinc != None: - canidatepaths.append(qtinc) - qtdir = os.getenv("QTDIR") - if qtdir != None: - canidatepaths.append(os.path.join(qtdir,"include")) - canidatepaths.append(os.path.join(install.prefix,"lib/tqt3/include")) - canidatepaths.append(os.path.join(install.prefix,"lib/qt3/include")) - canidatepaths.append(os.path.join(install.prefix,"include")) - canidatepaths.append("/opt/tqt3/include") - canidatepaths.append("/opt/qt/include") - canidatepaths.append("/opt/qt/lib/include") - canidatepaths.append("/opt/qt3/lib/include") - canidatepaths.append("/usr/include/tqt3") - canidatepaths.append("/usr/include/qt3") - self.qt_inc_dir = FindFileInPaths('ntqstring.h',canidatepaths) - if self.qt_inc_dir is None: - self.qt_inc_dir = FindFileInPaths('qstring.h',canidatepaths) - if self.qt_inc_dir is None: - raise SystemExit,"Failed to find the Qt header file directory" - if FindFileInPaths('ntqstring.h',[self.qt_inc_dir]) is None: - if FindFileInPaths('qstring.h',[self.qt_inc_dir]) is None: - raise SystemExit, "Failed to find Qt header files in: %s" % self.qt_inc_dir - self.announce("Using %s for Qt header files" % self.qt_inc_dir) - - # Qt lib dir - if self.qt_lib_dir is None: - canidatepaths = [] - qtlib = os.getenv("TQTLIB") - if qtlib != None: - canidatepaths.append(qtlib) - qtdir = os.getenv("TQTDIR") - if qtdir != None: - canidatepaths.append(os.path.join(qtdir,get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,"lib/tqt3/"+get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,"lib/tqt3/"+get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,get_libdir_name())) - canidatepaths.append("/opt/tqt3/"+get_libdir_name()) - canidatepaths.append("/opt/tqt/"+get_libdir_name()) - canidatepaths.append("/opt/tqt/lib/"+get_libdir_name()) - canidatepaths.append("/opt/tqt3/lib/"+get_libdir_name()) - self.qt_lib_dir = FindFileInPaths('libtqt*',canidatepaths) - if self.qt_lib_dir is None: - canidatepaths = [] - qtlib = os.getenv("QTLIB") - if qtlib != None: - canidatepaths.append(qtlib) - qtdir = os.getenv("QTDIR") - if qtdir != None: - canidatepaths.append(os.path.join(qtdir,get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,"lib/tqt3/"+get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,"lib/qt3/"+get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,get_libdir_name())) - canidatepaths.append("/opt/tqt3/"+get_libdir_name()) - canidatepaths.append("/opt/qt/"+get_libdir_name()) - canidatepaths.append("/opt/qt/lib/"+get_libdir_name()) - canidatepaths.append("/opt/qt3/lib/"+get_libdir_name()) - self.qt_lib_dir = FindFileInPaths('libqt*',canidatepaths) - if self.qt_lib_dir is None: - raise SystemExit, "Failed to find Qt library files" - self.announce("Using %s for Qt library files" % self.qt_lib_dir) - - # Python dir - if self.python_dir is None: - self.python_dir = os.path.split(sysconfig.get_config_var("LIBP"))[0] - self.announce("Using %s for the python directory" % self.python_dir) - - # Python include dir. - if self.python_inc_dir is None: - # Find the Python include directory. - self.python_inc_dir = sysconfig.get_config_var("INCLUDEPY") - self.announce("Using %s for Python header files" % self.python_inc_dir) - - # PyQt dir - if self.pyqt_dir is None: - self.pyqt_dir = m_pyqt_dir - if self.pyqt_dir is None: - self.pyqt_dir = os.path.join(sysconfig.get_python_lib(), 'python_tqt') - if (FindFileInPaths("libqtcmodule*",[self.pyqt_dir]) is None) and (FindFileInPaths("qt*",[self.pyqt_dir]) is None): - raise SystemExit, "Failed to find the PyQt directory: %s" % self.pyqt_dir - self.announce("Using %s for PyQt modules" % self.pyqt_dir) - - # PyTDE dir - if self.pytde_dir is None: - self.pytde_dir = sysconfig.get_python_lib() - if (FindFileInPaths("libtdecorecmodule*",[self.pytde_dir]) is None) and (FindFileInPaths("tdecore*",[self.pytde_dir]) is None): - raise SystemExit, "Failed to find the PyTDE directory: %s" % self.pytde_dir - self.announce("Using %s for PyTDE modules" % self.pytde_dir) - - # Sip dir - if self.sip_dir is None: - self.sip_dir = m_sip_dir - if self.sip_dir is None: - self.sip_dir = os.path.join(sysconfig.get_python_lib(), 'sip4_tqt') - if (FindFileInPaths("libsip*", [self.sip_dir]) is None) and (FindFileInPaths("sip*", [self.sip_dir]) is None): - raise SystemExit, "Failed to find libsip files in directory: %s" % self.sip_dir - self.announce("Using %s for libsip files" % self.sip_dir) - - # Find the C library (libgcc, libgcc_s or some other variation). - if self.clib is None: - canidatepaths = ["/usr/"+get_libdir_name(), "/usr/local/"+get_libdir_name(), "/usr/lib" ] - self.clib = FindFileInPaths("libgcc*.so",canidatepaths) - if self.clib!=None: - self.clib = glob.glob(os.path.join(self.clib,'libgcc*.so'))[0] - else: - self.clib = FindFileInPaths("libgcc*.a",canidatepaths) - if self.clib!=None: - self.clib = glob.glob(os.path.join(self.clib,'libgcc*.a'))[0] - if self.clib is None: - raise SystemExit, "kdedistutils.py (1): Failed to find a suitable libgcc library" - self.announce("Using %s for clib" % self.clib) - - # Make a list of places to look for python .so modules - self.python_sub_dirs = sysconfig.get_config_var("LIBSUBDIRS").split() - base = sysconfig.get_config_var("LIBP") - self.python_sub_dirs = [ os.path.join(base,item) for item in self.python_sub_dirs ] - self.python_sub_dirs.append(base) - - def get_command_name(self): - return 'build_kcm' - - def run(self): - if self.no_kcontrol: - self.announce("Skipping KControl modules") - return - - if not os.path.isdir(self.build_dir): - os.mkdir(self.build_dir) - - for moduletuple in self.distribution.kcontrol_modules: - self.announce("Building KControl module from desktop file %s." % moduletuple[0]) - - # Read the desktop file - factoryfunction = None - libraryname = None - cmodulecategory = None - try: - fhandle = open(moduletuple[0],'r') - for line in fhandle.readlines(): - parts = line.strip().split('=') - try: - if parts[0]=="X-TDE-Library": - libraryname = parts[1] - elif parts[0]=="Exec": - shellcmd = parts[1].split() - modulepath = shellcmd[-1] - if '/' in modulepath: - cmodulecategory = os.path.dirname(modulepath) - else: - cmodulecategory = "" - elif parts[0]=="X-TDE-FactoryName": - factoryfunction = 'create_'+parts[1] - except IndexError: - pass - fhandle.close() - except IOError: - raise SystemExit, "Failed to find kcontrol desktop file: %s" % moduletuple[0] - - # Sanity check. - if factoryfunction is None: - raise SystemExit, "Failed to find factory name (Was there a X-TDE-FactoryName entry in the desktop file?)" - if libraryname is None: - raise SystemExit, "Failed to find library name (Was there a X-TDE-Library entry in the desktop file?)" - if cmodulecategory is None: - raise SystemExit, "Failed to find the kcontrol category name (Was there a Exec entry in the desktop file?)" - - modulename = os.path.basename(moduletuple[1]) - if modulename.endswith('.py'): - modulename = modulename[:-3] - desktopfilename = moduletuple[0] - - stub_cpp_name = 'kcm_'+libraryname+'.cpp' - stub_so_name = 'kcm_'+libraryname+'.so' - stub_la_name = 'kcm_'+libraryname+'.la' - python_version = '%i.%i' % (sys.version_info[0],sys.version_info[1]) - - # Build the 'stub' code. - cppcode = self.cpptemplate % {"moduledir": self.data_dir, - "extramodule": os.getenv("EXTRA_MODULE_DIR"), - "modulename": modulename, - "factoryfunction": factoryfunction, - "python_version": python_version} - - # Put it on disk. - cppfile = os.path.join(os.path.dirname(moduletuple[0]),stub_cpp_name) - try: - fhandle = open(cppfile,'w') - fhandle.write(cppcode) - fhandle.close() - except IOError: - raise SystemExit, "Could not write the C++ stub: %s" % cppfile - - # Compile the stub library. - cmdlist = ['libtool'] - - # Couldn't get it to pass without this ... - cmdlist.append("--mode=compile") - cmdlist.append("--tag=CXX") - - # Find the compiler flags and options - # CXX is empty on some Systems, let's do it 'the hard way'. - # FIXME :: get CXX from make.conf for Gentoo. - if len(sysconfig.get_config_var("CXX").split()) >= 2: - cmdlist.extend(sysconfig.get_config_var("CXX").split()) - else: - cmdlist.extend(['g++', '-pthread']) - - #cmdlist.extend(sysconfig.get_config_var("CXX").split()) - - # cc_flags - cmdlist.append("-c") - cmdlist.append("-g") - - # The 4 is randomly chosen! - # FIXME :: get CFLAGS from make.conf for Gentoo. - if len(sysconfig.get_config_var("CFLAGS").split()) >=4: - cmdlist.extend(sysconfig.get_config_var("CFLAGS").split()) - else: - # On Gentoo systems, CFLAGS are not in the environment. - raw = os.popen('emerge info 2> /dev/null|grep CFLAGS') - lines = raw.readlines() - if len(lines): - cflags = lines[0].split('"')[1].split() - print "Got CFLAGS from emerge info." - cmdlist.extend(cflags) - else: - # Still no CFLAGS found, use these ... - cmdlist.extend(['-fno-strict-aliasing', '-DNDEBUG', '-g', '-O3', '-Wall', '-Wstrict-prototypes']) - - #sysconfig.get_config_var("CFLAGS").split() - # includes - cmdlist.append("-I" + sysconfig.get_config_var("INCLUDEDIR")) - cmdlist.append("-I" + sysconfig.get_config_var("INCLUDEDIR")) - cmdlist.append("-I" + sysconfig.get_config_var("INCLUDEPY")) - cmdlist.append("-I" + self.python_inc_dir) - cmdlist.append("-I" + self.kde_inc_dir) - cmdlist.append("-I" + self.kde_inc_dir + "/tde") - cmdlist.append("-I" + self.qt_inc_dir) - cmdlist.append("-I/usr/include/tqt") - cmdlist.append("-I.") - # input - cmdlist.append(cppfile) - # output - outputfile = os.path.join(self.build_dir,libraryname+'.lo') - cmdlist.append("-o") - cmdlist.append(outputfile) - spawn(cmdlist) # Execute!!! - print - - # Link the resulting object file to create a shared library. - cmdlist = ['libtool'] - cmdlist.append("--mode=link") - cmdlist.append("--tag=LD") - - # Grab the linker command name - cmdlist.append(sysconfig.get_config_var("LDSHARED").split()[0]) - # link_flags - cmdlist.append("-module") - cmdlist.append("-avoid-version") - cmdlist.append("-shared") - cmdlist.append("-export-dynamic") - # object - cmdlist.append(outputfile) - cmdlist.append("-rpath"); cmdlist.append(self.kde_kcm_lib_dir) - cmdlist.append("-o"); cmdlist.append(os.path.join(self.build_dir,stub_la_name)) - # Link libs - linklist = [] - linklist.append("-lpython%s" % python_version) - linklist.extend(sysconfig.get_config_var("LIBS").split()) - - # FIXME I doubt half of these libraries need to be here. - linklist.append(self.sip_dir+"/sip.so") - # PyQt libs - linklist.append(self.pyqt_dir+"/qt.so") - # PyTDE libs - linklist.append(self.pytde_dir+"/tdecore.so") - linklist.append(self.pytde_dir+"/tdeui.so") - -# linklist.append("-L"+self.sip_dir); linklist.append("-lsip") -# # PyQt libs -# linklist.append("-L"+self.pyqt_dir); linklist.append("-lqtcmodule") -# # PyTDE libs -# linklist.append("-L"+self.pytde_dir); linklist.append("-ltdecorecmodule"); linklist.append("-ltdeuicmodule") - - linklist.append("-L"+self.kde_lib_dir); linklist.append("-L/opt/trinity/lib"); linklist.append("-ltdecore"); linklist.append("-lpythonize") - linklist.append("-L"+self.qt_lib_dir); linklist.append("-ltqt-mt") - linklist.append("-lm") - linklist.append("-lc") - linklist.append(self.clib) - - linklist.append("-R"); linklist.append(self.python_dir) - linklist.append("-R"); linklist.append(self.qt_lib_dir) - linklist.append("-R"); linklist.append(self.sip_dir) - linklist.append("-R"); linklist.append(self.pyqt_dir) - linklist.append("-R"); linklist.append(self.pytde_dir) - linklist.append("-R"); linklist.append(self.kde_lib_dir) - - cmdlist.extend(linklist) - spawn(cmdlist) # Execute!! - print - - cpptemplate = r""" -/* - * pykcm_launcher.cpp - * - * Launch Control Centre modules written in Python using an embedded Python - * interpreter. - * Based on David Boddie's PyTDE-components. - */ - -// pythonize.h must be included first. -#include <pythonize.h> -#include <tdecmodule.h> -#include <tdeglobal.h> -#include <tdelocale.h> -#include <klibloader.h> -#include <kstandarddirs.h> -#include <ksimpleconfig.h> -#include <tqstring.h> -#include <sip.h> - -#define MODULE_DIR "%(moduledir)s" -#define EXTRA_MODULE_DIR "%(extramodule)s" -#define MODULE_NAME "%(modulename)s" -#define FACTORY "%(factoryfunction)s" -#define CPP_FACTORY %(factoryfunction)s -#define LIB_PYTHON "libpython%(python_version)s.so" -#define debug 1 - -static TDECModule *report_error(char *msg) { - if (debug) printf ("error: %%s\n", msg); - return NULL; -} - -static TDECModule* return_instance( TQWidget *parent, const char *name ) { - TDECModule* tdecmodule; - PyObject *pyTDECModuleTuple; - PyObject *pyTDECModule; - Pythonize *pyize; // Pythonize object to manage the Python interpreter. - int isErr; - - // Try to determine what py script we're loading. Note that "name" - // typically appears to be NULL. - TQString script(MODULE_NAME); - - // Reload libpython, but this time tell the runtime linker to make the - // symbols global and available for later loaded libraries/module. - KLibLoader::self()->globalLibrary(LIB_PYTHON); - - // Start the interpreter. - pyize = initialize(); - if (!pyize) { - return report_error ("***Failed to start interpreter\n"); - } - - // Add the path to the python script to the interpreter search path. - TQString path = TQString(MODULE_DIR); - if(path == TQString::null) { - return report_error ("***Failed to locate script path"); - } - if(!pyize->appendToSysPath (path.latin1 ())) { - return report_error ("***Failed to set sys.path\n"); - } - - // Add the extra path to the python script to the interpreter search path. - TQString extrapath = TQString(EXTRA_MODULE_DIR); - if(!pyize->appendToSysPath (extrapath.latin1 ())) { - return report_error ("***Failed to set extra sys.path\n"); - } - - // Load the Python script. - PyObject *pyModule = pyize->importModule ((char *)script.latin1 ()); - if(!pyModule) { - PyErr_Print(); - return report_error ("***failed to import module\n"); - } - - // Inject a helper function - TQString bridge = TQString("from sip4_tqt import sip\n" - "from python_tqt import qt\n" - "def kcontrol_bridge_" FACTORY "(parent,name):\n" - " if parent!=0:\n" -#if SIP_VERSION >= 0x040200 - " wparent = sip.wrapinstance(parent,qt.TQWidget)\n" -#else - " wparent = sip.wrapinstance(parent,'TQWidget')\n" -#endif - " else:\n" - " wparent = None\n" - " inst = " FACTORY "(wparent, name)\n" - " return (inst,sip.unwrapinstance(inst))\n"); - PyRun_String(bridge.latin1(),Py_file_input,PyModule_GetDict(pyModule),PyModule_GetDict(pyModule)); - - // Get the Python module's factory function. - PyObject *kcmFactory = pyize->getNewObjectRef(pyModule, "kcontrol_bridge_" FACTORY); - if(!kcmFactory) { - return report_error ("***failed to find module factory\n"); - } - - // Call the factory function. Set up the args. - PyObject *pyParent = PyLong_FromVoidPtr(parent); - PyObject *pyName = PyString_FromString(MODULE_NAME); - // Using NN here is effect gives our references to the arguement away. - PyObject *args = Py_BuildValue ("NN", pyParent, pyName); - if(pyName && pyParent && args) { - // run the factory function - pyTDECModuleTuple = pyize->runFunction(kcmFactory, args); - if(!pyTDECModuleTuple) { - PyErr_Print(); - return report_error ("*** runFunction failure\n;"); - } - } else { - return report_error ("***failed to create args\n"); - } - // cleanup a bit - pyize->decref(args); - pyize->decref(kcmFactory); - - // Stop this from getting garbage collected. - Py_INCREF(PyTuple_GET_ITEM(pyTDECModuleTuple,0)); - - // convert the TDECModule PyObject to a real C++ TDECModule *. - isErr = 0; - pyTDECModule = PyTuple_GET_ITEM(pyTDECModuleTuple,1); - tdecmodule = (TDECModule *)PyLong_AsVoidPtr(pyTDECModule); - if(!tdecmodule) { - return report_error ("***failed sip conversion to C++ pointer\n"); - } - pyize->decref(pyTDECModuleTuple); - - // PyTDE can't run the module without this - Pythonize - // grabs the lock at initialization and we have to give - // it back before exiting. At this point, we no longer need - // it. - //pyize->releaseLock (); - - // take care of any translation info - TDEGlobal::locale()->insertCatalogue(script); - - // Return the pointer to our new TDECModule - return tdecmodule; -} - -extern "C" { - // Factory function that kcontrol will call. - TDECModule* CPP_FACTORY(TQWidget *parent, const char *name) { - return return_instance(parent, name); - } -} -""" - -########################################################################### -class InstallKControlModule(Command): - description = "Install Kcontrol module files" - - user_options = [ - ('install-dir=', 'd', "base directory for installing kcontrol module files"), - ('install-cmd=', None, "Command to use to install the files"), - ('xdg-apps-dir=',None,"directory for XDG app files"), - ('build-dir=','b', "build directory (where to install from)"), - ('root=', None, "install everything relative to this alternate root directory"), - ('force', 'f', "force installation (overwrite existing files)"), - ('skip-build', None, "skip the build steps"), - ] - boolean_options = ['force', 'skip-build'] - - def initialize_options(self): - self.build_dir = None - self.install_dir = None - self.install_cmd = None - self.xdg_apps_dir = None - self.outfiles = [] - self.root = None - self.force = 0 - self.warn_dir = 1 - self.skip_build = None - - def finalize_options(self): - own_install_dir = self.install_dir is not None - own_xdg_apps_dir = self.xdg_apps_dir is not None - - self.set_undefined_options('install', - ('build_base', 'build_dir'), - ('install_kcm', 'install_dir'), - ('install_xdg_apps','xdg_apps_dir'), - ('root', 'root'), - ('force', 'force'), - ('skip_build', 'skip_build'), - ('install_cmd', 'install_cmd') - ) - - if own_install_dir and self.root is not None: - self.install_dir = change_root(self.root,self.installdir) - if own_xdg_apps_dir and self.root is not None: - self.xdg_apps_dir = change_root(self.root,self.xdg_apps_dir) - - def get_command_name(self): - return 'install_kcm' - - def run(self): - if not self.skip_build: - self.run_command('build_kcm') - - self.announce("Installing Kcontrol module files...") - - for moduletuple in self.distribution.kcontrol_modules: - self.announce("Building KControl module from desktop file %s." % moduletuple[0]) - - # Read the desktop file - libraryname = None - cmodulecategory = None - try: - fhandle = open(moduletuple[0],'r') - for line in fhandle.readlines(): - parts = line.strip().split('=') - try: - if parts[0]=="X-TDE-Library": - libraryname = parts[1] - elif parts[0]=="Exec": - shellcmd = parts[1].split() - modulepath = shellcmd[-1] - if '/' in modulepath: - cmodulecategory = os.path.dirname(modulepath) - else: - cmodulecategory = "" - except IndexError: - pass - fhandle.close() - except IOError: - raise SystemExit, "Failed to find kcontrol desktop file: %s" % moduletuple[0] - - if libraryname is None: - raise SystemExit, "Failed to find library name (Was there a X-TDE-Library entry in the desktop file?)" - if cmodulecategory is None: - raise SystemExit, "Failed to find the kcontrol category name (Was there a Exec entry in the desktop file?)" - - desktopfilename = moduletuple[0] - self.outfiles.extend(self.mkpath(self.xdg_apps_dir)) - desktopfile_dest = os.path.join(self.xdg_apps_dir,os.path.basename(desktopfilename)) - self.copy_file(desktopfilename, desktopfile_dest) - - stub_la_name = 'kcm_'+libraryname+'.la' - - self.outfiles.extend(self.mkpath(self.install_dir)) - - # Install the library. - cmdlist = ['libtool'] - cmdlist.append("--mode=install") - cmdlist.append(self.install_cmd) - cmdlist.append("-c") - cmdlist.append(os.path.join(self.build_dir,stub_la_name)) - cmdlist.append(os.path.join(self.install_dir,stub_la_name)) - spawn(cmdlist) # Execute!! - print - - self.outfiles = [os.path.join(self.install_dir,os.path.basename(file)) for file in glob.glob(os.path.join(self.build_dir,'.libs','kcm_'+libraryname+'*'))] - self.outfiles.append(desktopfile_dest) - - self.announce("Done installing Kcontrol module files.") - - def get_outputs(self): - return self.outfiles or [] - - def mkpath(self, name, mode=0777): - return dir_util.mkpath(name, mode, dry_run=self.dry_run) - -########################################################################### -class BuildDocbookHTML(Command): - description = "Build Docbook HTML documentation" - - user_options = [('meinproc-exe=',None,"Path to the meinproc executable")] - - def initialize_options(self): - self.html_prefix = None - self.meinproc_exe = None - - def finalize_options(self): - self.set_undefined_options('build', ('meinproc_exe', 'meinproc_exe') ) - - def get_command_name(self): - return 'build_docbook' - - def run(self): - for docbook_tuple in self.distribution.docbooks: - input_dir = docbook_tuple[0] - language_code = docbook_tuple[1] - - self.announce("Building Docbook documentation from directory %s." % input_dir) - - indexdoc_file_name = os.path.join(input_dir,'index.docbook') - if not os.path.exists(indexdoc_file_name): - raise SystemExit, "File %s is missing." % indexdoc_file_name - - cwd = os.getcwd() - os.chdir(input_dir) - try: - spawn([self.meinproc_exe,"--check","--cache",'index.cache.bz2', 'index.docbook']) - spawn([self.meinproc_exe, 'index.docbook']) - finally: - os.chdir(cwd) - -########################################################################### -class InstallDocbookHTML(Command): - description = "Install Docbook HTML files" - - user_options = [ - ('install-dir=', 'd',"base directory for installing docbook HTML files"), - ('root=', None, "install everything relative to this alternate root directory"), - ('force', 'f', "force installation (overwrite existing files)"), - ('skip-build', None, "skip the build steps"), - ] - boolean_options = ['force', 'skip-build'] - - def initialize_options(self): - self.install_dir = None - self.outfiles = [] - self.root = None - self.force = 0 - self.warn_dir = 1 - self.skip_build = None - - def finalize_options(self): - own_install_dir = self.install_dir is not None - - self.set_undefined_options('install', - ('install_html', 'install_dir'), - ('root', 'root'), - ('force', 'force'), - ('skip_build', 'skip_build'), - ) - - if own_install_dir and self.root is not None: - self.install_dir = change_root(self.root,self.installdir) - - def get_command_name(self): - return 'install_html' - - def run(self): - if not self.skip_build: - self.run_command('build_html') - - self.announce("Installing HTML files...") - counter = 0 - for docbook_tuple in self.distribution.docbooks: - input_dir = docbook_tuple[0] - language_code = docbook_tuple[1] - - self.announce("Install Docbook documentation from directory %s." % input_dir) - source_file = os.path.join(input_dir,'index.cache.bz2') - if not os.path.exists(source_file): - raise SystemExit, "File %s is missing." % source_file - - dest_path = os.path.join(self.install_dir, language_code, self.distribution.metadata.name) - self.outfiles.extend(self.mkpath(dest_path)) - dest_file = os.path.join(dest_path,'index.cache.bz2') - - self.copy_file(source_file, dest_file) - self.outfiles.append(dest_file) - counter += 1 - - # Also install any lose HTML files. - for source_file in glob.glob(os.path.join(input_dir,'*.html')): - htmlfile = os.path.basename(source_file) - dest_file = os.path.join(dest_path,htmlfile) - self.copy_file(source_file, dest_file) - self.outfiles.append(dest_file) - counter += 1 - - if len(docbook_tuple)==3: - extra_files = docbook_tuple[2] - for file in extra_files: - source_file = os.path.join(input_dir,file) - dest_file = os.path.join(self.install_dir, language_code, self.distribution.metadata.name,file) - self.copy_file(source_file, dest_file) - self.outfiles.append(dest_file) - counter += 1 - - self.announce("Done installing %i HTML files." % counter) - - def get_outputs(self): - return self.outfiles or [] - - def mkpath(self, name, mode=0777): - return dir_util.mkpath(name, mode, dry_run=self.dry_run) - -########################################################################### -class UpdateI18NMessages(Command): - description = "Extract and update messages for translation" - - user_options = [('xgettext-exe=',None,'Full path to the xgetext executable'),\ - ('kde-pot=',None,'Location of the the KDE pot file'),\ - ('msgmerge-exe=',None,'Full path to the msgmerge executable')] - - def initialize_options(self): - self.xgettext_exe = None - self.msgmerge_exe = None - self.kde_pot = None - - def finalize_options(self): - if self.xgettext_exe is None: - install = self.get_finalized_command('install') - - canidate_paths = [] - if install.user_supplied_kde_prefix: - canidate_paths.append(os.path.join(install.kde_prefix,'bin')) - - self.announce("Detecting xgettext...") - canidate_paths.append(ask_kde_config('--install exe --expandvars').strip()) - self.xgettext_exe = FindExeOnPath('xgettext',canidate_paths) - if self.xgettext_exe is None: - raise SystemExit, "Unable to find 'xgettext'." - self.announce(" ...xgettext found at %s" % self.xgettext_exe) - - if self.msgmerge_exe is None: - install = self.get_finalized_command('install') - - canidate_paths = [] - if install.user_supplied_kde_prefix: - canidate_paths.append(os.path.join(install.kde_prefix,'bin')) - - self.announce("Detecting msgmerge...") - canidate_paths.append(ask_kde_config('--install exe --expandvars').strip()) - self.msgmerge_exe = FindExeOnPath('msgmerge',canidate_paths) - if self.msgmerge_exe is None: - raise SystemExit, "Unable to find 'xgettext'." - self.announce(" ...msgmerge found at %s" % self.msgmerge_exe) - - if self.kde_pot is None: - self.announce("Detecting kde.pot...") - canidatepaths = [] - tdedir = os.getenv("TDEDIR") - if tdedir!=None: - canidatepaths.append(os.path.join(tdedir,"include")) - install = self.get_finalized_command('install') - canidatepaths.append(os.path.join(install.kde_prefix,"include")) - canidatepaths.append('/opt/trinity/include') - canidatepaths.append('/opt/kde/include') - kde_pot_dir = FindFileInPaths('kde.pot',canidatepaths) - - if kde_pot_dir is None: - raise SystemExit, "Failed to find the kde.pot file." - - self.kde_pot = os.path.join(kde_pot_dir,'kde.pot') - self.announce(" ...kde.pot found at %s" % self.kde_pot) - - def get_command_name(self): - return 'update_messages' - - def run(self): - if self.distribution.i18n is None: return - - self.announce("Extracting and merging i18n messages...") - po_dir = self.distribution.i18n[0] - - # FIXME : .rc and .ui files - input_files = [] - - # Compile any UI files - for dir in self.distribution.i18n[1]: - for file in glob.glob(os.path.join(dir,'*.ui')): - qtuicompiler.UpdateUI(file,kde=True) - - # Fetch all of the python files. - for dir in self.distribution.i18n[1]: - input_files.extend(glob.glob(os.path.join(dir,'*.py'))) - - target_pot = os.path.join(po_dir,self.distribution.metadata.name+".pot") - - cmd = [self.xgettext_exe, '-o', target_pot, '-ki18n', '-ktr2i18n', \ - '-kI18N_NOOP', '-ktranslate', '-kaliasLocale','-x',self.kde_pot] - cmd.extend(input_files) - spawn(cmd) - - for po_file in glob.glob(os.path.join(po_dir,'*.po')): - temp_po = po_file + '.temp' - cmd = [self.msgmerge_exe,'-q','-o',temp_po,po_file,target_pot] - spawn(cmd) - os.rename(temp_po,po_file) - - self.announce("Finished with i18n messages.") - -########################################################################### -class BuildI18NMessages(Command): - description = "Build i18n messages" - - user_options = [('msgfmt-exe=',None,'Path to the msgfmt executable')] - - def initialize_options(self): - self.msgfmt_exe = None - - def finalize_options(self): - self.set_undefined_options('build', ('msgfmt_exe', 'msgfmt_exe')) - - def get_command_name(self): - return 'build_messages' - - def run(self): - if self.distribution.i18n is None: return - - self.announce("Building i18n messages...") - po_dir = self.distribution.i18n[0] - - i = 0 - for po_file in [file for file in os.listdir(po_dir) if file.endswith('.po')]: - source = os.path.join(po_dir,po_file) - target = source[:-3]+'.gmo' - cmd = [self.msgfmt_exe,'-o',target, source] - spawn(cmd) - i += 1 - self.announce("Done building %i i18n messages." % i) - -########################################################################### -class InstallI18NMessages(Command): - description = "Install messages" - - user_options = [ - ('install-dir=', 'd',"base directory for installing message files (default: installation base dir)"), - ('root=', None, "install everything relative to this alternate root directory"), - ('force', 'f', "force installation (overwrite existing files)"), - ('skip-build', None, "skip the build steps"), - ] - - boolean_options = ['force', 'skip-build'] - - def initialize_options(self): - self.install_dir = None - self.outfiles = [] - self.root = None - self.force = 0 - self.warn_dir = 1 - self.skip_build = None - - def finalize_options(self): - own_install_dir = self.install_dir is not None - - self.set_undefined_options('install', - ('install_messages', 'install_dir'), - ('root', 'root'), - ('force', 'force'), - ('skip_build', 'skip_build'), - ) - - if own_install_dir and self.root is not None: - self.install_dir = change_root(self.root,self.installdir) - - def get_command_name(self): - return 'install_messages' - - def run(self): - if not self.skip_build: - self.run_command('build_messages') - - self.announce("Installing i18n messages...") - po_dir = self.distribution.i18n[0] - - counter = 0 - for po_file in os.listdir(po_dir): - if po_file.endswith('.po'): - source_file = os.path.join(po_dir,po_file[:-3]) + '.gmo' - - # Setup installation of the translation file. - dest_path = os.path.join(self.install_dir, po_file[:-3],'LC_MESSAGES') - self.outfiles.extend(self.mkpath(dest_path)) - dest_file = os.path.join(dest_path, self.distribution.metadata.name+'.mo') - - self.copy_file(source_file, dest_file) - self.outfiles.append(dest_file) - counter += 1 - self.announce("Done installing %i i18n messages." % counter) - - def get_outputs(self): - return self.outfiles - - def mkpath(self, name, mode=0777): - return dir_util.mkpath(name, mode, dry_run=self.dry_run) - - -########################################################################### -class BuildTdeioslave(Command): - description = "Build Tdeioslaves" - - user_options = [('no-tdeioslave',None,"Don't build tdeioslaves"), - ('build-dir=','b', "build directory (where to install from)"), - ('python-dir=',None,'Directory containing the Python installation'), - ('python-inc-dir=',None,'Directory containing C Header files for Python'), - ('kde-inc-dir=',None,'Directory containing C++ header files for KDE'), - ('kde-lib-dir=',None,'Directory containing library files for KDE'), - ('kde-tdeioslave-lib-dir=',None,'Directory for KDE tdeioslave library files'), - ('kde-protocol-dir=',None,'Directory for KDE tdeioslave protocol files'), - ('qt-inc-dir=',None,'Directory containing C++ header files for Qt'), - ('qt-lib-dir=',None,'Directory containing library files for Qt'), - ('sip-dir=','/usr/lib/pyshared/python*','Directory containing the sip library files'), - ('clib=',None,'gcc library and path'), - ('pyqt-dir=','/usr/lib/pyshared/python*','PyQt module directory'), - ('pytde-dir=',None,'PyTDE module directory'), - ('data-dir=',None,'installation directory for data (script) files')] - - def initialize_options(self): - self.no_tdeioslave = 0 - self.build_dir = None - self.python_inc_dir = None - self.python_dir = None - self.kde_inc_dir = None - self.kde_lib_dir = None - self.kde_tdeioslave_lib_dir = None - self.kde_protocol_dir = None - self.qt_inc_dir = None - self.qt_lib_dir = None - self.sip_dir = None - self.clib = None - self.pyqt_dir = None - self.pytde_dir = None - self.data_dir = None - - def finalize_options(self): - if self.no_tdeioslave==0: - self.set_undefined_options('install', ('build_base', 'build_dir'),('install_application_data','data_dir')) - - install = self.get_finalized_command('install') - self.install_prefix = ask_kde_config('--prefix').strip() - - # KDE inc dir: find it! - if self.kde_inc_dir is None: - canidatepaths = [] - tdedir = os.getenv("TDEDIR") - if tdedir!=None: - canidatepaths.append(os.path.join(tdedir,"include")) - canidatepaths.append(os.path.join(install.prefix,"include")) - canidatepaths.append(os.path.join(self.install_prefix,'include')) - canidatepaths.append(os.path.join(self.install_prefix,'include','tde')) - self.kde_inc_dir = FindFileInPaths('tdeapplication.h',canidatepaths) - if self.kde_inc_dir is None: - raise SystemExit, "Failed to find the KDE header file directory." - if FindFileInPaths('tdeapplication.h',[self.kde_inc_dir]) is None: - raise SystemExit, "Failed to find KDE header files in: %s" % self.kde_inc_dir - self.announce("Using %s for KDE header files" % self.kde_inc_dir) - - # KDE lib dir - if self.kde_lib_dir is None: - self.kde_lib_dir = os.path.join(self.install_prefix,"lib") - self.announce("Using %s for KDE library files" % self.kde_lib_dir) - - # KDE tdeioslave lib dir - if self.kde_tdeioslave_lib_dir is None: - self.kde_tdeioslave_lib_dir = os.path.join(self.kde_lib_dir,"trinity") - if FindFileInPaths('tdeio_*.so',[self.kde_tdeioslave_lib_dir]) is None: - raise SystemExit, "Failed to find KDE Tdeioslave library files in: %s" % self.kde_tdeioslave_lib_dir - self.announce("Using %s for KDE Tdeioslave library files" % self.kde_tdeioslave_lib_dir) - - # Qt inc dir - if self.qt_inc_dir is None: - canidatepaths = [] - qtinc = os.getenv("QTINC") - if qtinc != None: - canidatepaths.append(qtinc) - qtdir = os.getenv("QTDIR") - if qtdir != None: - canidatepaths.append(os.path.join(qtdir,"include")) - canidatepaths.append(os.path.join(install.prefix,"lib/tqt3/include")) - canidatepaths.append(os.path.join(install.prefix,"lib/qt3/include")) - canidatepaths.append(os.path.join(install.prefix,"include")) - canidatepaths.append("/opt/tqt3/include") - canidatepaths.append("/opt/qt/include") - canidatepaths.append("/opt/qt/lib/include") - canidatepaths.append("/opt/qt3/lib/include") - self.qt_inc_dir = FindFileInPaths('ntqstring.h',canidatepaths) - if self.qt_inc_dir is None: - self.qt_inc_dir = FindFileInPaths('qstring.h',canidatepaths) - if self.qt_inc_dir is None: - raise SystemExit,"Failed to find the Qt header file directory" - if FindFileInPaths('ntqstring.h',[self.qt_inc_dir]) is None: - if FindFileInPaths('qstring.h',[self.qt_inc_dir]) is None: - raise SystemExit, "Failed to find Qt header files in: %s" % self.qt_inc_dir - self.announce("Using %s for Qt header files" % self.qt_inc_dir) - - # Qt lib dir - if self.qt_lib_dir is None: - canidatepaths = [] - qtlib = os.getenv("TQTLIB") - if qtlib != None: - canidatepaths.append(qtlib) - qtdir = os.getenv("TQTDIR") - if qtdir != None: - canidatepaths.append(os.path.join(qtdir,get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,"lib/tqt3/"+get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,"lib/tqt3/"+get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,get_libdir_name())) - canidatepaths.append("/opt/tqt3/"+get_libdir_name()) - canidatepaths.append("/opt/tqt/"+get_libdir_name()) - canidatepaths.append("/opt/tqt/lib/"+get_libdir_name()) - canidatepaths.append("/opt/tqt3/lib/"+get_libdir_name()) - self.qt_lib_dir = FindFileInPaths('libtqt*',canidatepaths) - if self.qt_lib_dir is None: - canidatepaths = [] - qtlib = os.getenv("QTLIB") - if qtlib != None: - canidatepaths.append(qtlib) - qtdir = os.getenv("QTDIR") - if qtdir != None: - canidatepaths.append(os.path.join(qtdir,get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,"lib/tqt3/"+get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,"lib/qt3/"+get_libdir_name())) - canidatepaths.append(os.path.join(install.prefix,get_libdir_name())) - canidatepaths.append("/opt/tqt3/"+get_libdir_name()) - canidatepaths.append("/opt/qt/"+get_libdir_name()) - canidatepaths.append("/opt/qt/lib/"+get_libdir_name()) - canidatepaths.append("/opt/qt3/lib/"+get_libdir_name()) - self.qt_lib_dir = FindFileInPaths('libqt*',canidatepaths) - if self.qt_lib_dir is None: - raise SystemExit, "Failed to find Qt library files" - self.announce("Using %s for Qt library files" % self.qt_lib_dir) - - # Python dir - if self.python_dir is None: - self.python_dir = os.path.split(sysconfig.get_config_var("LIBP"))[0] - self.announce("Using %s for the python directory" % self.python_dir) - - # Python include dir. - if self.python_inc_dir is None: - # Find the Python include directory. - self.python_inc_dir = sysconfig.get_config_var("INCLUDEPY") - self.announce("Using %s for Python header files" % self.python_inc_dir) - - # PyQt dir - if self.pyqt_dir is None: - self.pyqt_dir = m_pyqt_dir - if self.pyqt_dir is None: - self.pyqt_dir = os.path.join(sysconfig.get_python_lib(), 'python_tqt') - if (FindFileInPaths("libqtcmodule*",[self.pyqt_dir]) is None) and (FindFileInPaths("qt*",[self.pyqt_dir]) is None): - raise SystemExit, "Failed to find the PyQt directory: %s" % self.pyqt_dir - self.announce("Using %s for PyQt modules" % self.pyqt_dir) - - # PyTDE dir - if self.pytde_dir is None: - self.pytde_dir = sysconfig.get_python_lib() - if (FindFileInPaths("libtdecorecmodule*",[self.pytde_dir]) is None) and (FindFileInPaths("tdecore*",[self.pytde_dir]) is None): - raise SystemExit, "Failed to find the PyTDE directory: %s" % self.pytde_dir - self.announce("Using %s for PyTDE modules" % self.pytde_dir) - - # Sip dir - if self.sip_dir is None: - self.sip_dir = m_sip_dir - if self.sip_dir is None: - self.sip_dir = os.path.join(sysconfig.get_python_lib(), 'sip4_tqt') - if (FindFileInPaths("libsip*", [self.sip_dir]) is None) and (FindFileInPaths("sip*", [self.sip_dir]) is None): - raise SystemExit, "Failed to find libsip files in directory: %s" % self.sip_dir - self.announce("Using %s for libsip files" % self.sip_dir) - - # Find the C library (libgcc, libgcc_s or some other variation). - if self.clib is None: - canidatepaths = ["/usr/"+get_libdir_name(), "/usr/local/"+get_libdir_name() ] - self.clib = FindFileInPaths("libgcc*.so",canidatepaths) - if self.clib!=None: - self.clib = glob.glob(os.path.join(self.clib,'libgcc*.so'))[0] - else: - self.clib = FindFileInPaths("libgcc*.a",canidatepaths) - if self.clib!=None: - self.clib = glob.glob(os.path.join(self.clib,'libgcc*.a'))[0] - if self.clib is None: - raise SystemExit, "kdedistutils.py (2): Failed to find a suitable libgcc library" - self.announce("Using %s for clib" % self.clib) - - # Make a list of places to look for python .so modules - self.python_sub_dirs = sysconfig.get_config_var("LIBSUBDIRS").split() - base = sysconfig.get_config_var("LIBP") - self.python_sub_dirs = [ os.path.join(base,item) for item in self.python_sub_dirs ] - self.python_sub_dirs.append(base) - - def get_command_name(self): - return 'build_tdeioslave' - - def run(self): - if self.no_tdeioslave: - self.announce("Skipping TDEIO Slaves") - return - - if not os.path.isdir(self.build_dir): - os.mkdir(self.build_dir) - - for moduletuple in self.distribution.tdeioslaves: - self.announce("Building TDEIO Slave from protocol file %s." % moduletuple[0]) - - protocolfilename = moduletuple[0] - - # Read the protocol file - libraryname = None - try: - fhandle = open(protocolfilename,'r') - for line in fhandle.readlines(): - parts = line.strip().split('=') - try: - if parts[0]=="exec": - libraryname = parts[1] - except IndexError: - pass - fhandle.close() - except IOError: - raise SystemExit, "Failed to find tdeioslave protocol file: %s" % moduletuple[0] - - # Sanity check. - if libraryname is None: - raise SystemExit, "Failed to find library name (Was there a exec entry in the protocol file?)" - - modulename = os.path.basename(moduletuple[1]) - if modulename.endswith('.py'): - modulename = modulename[:-3] - - stub_cpp_name = libraryname+'.cpp' - stub_so_name = libraryname+'.so' - stub_la_name = libraryname+'.la' - python_version = '%i.%i' % (sys.version_info[0],sys.version_info[1]) - - # Build the 'stub' code. - cppcode = self.cpptemplate % {"moduledir": self.data_dir, - "modulename": modulename, - "python_version": python_version} - - # Put it on disk. - cppfile = os.path.join(os.path.dirname(moduletuple[0]),stub_cpp_name) - try: - fhandle = open(cppfile,'w') - fhandle.write(cppcode) - fhandle.close() - except IOError: - raise SystemExit, "Could not write the C++ stub: %s" % cppfile - - # Compile the stub library. - cmdlist = ['libtool'] - - # Couldn't get it to pass without this ... - cmdlist.append("--mode=compile") - cmdlist.append("--tag=CXX") - - # Find the compiler flags and options - # CXX is empty on some Systems, let's do it 'the hard way'. - # FIXME :: get CXX from make.conf for Gentoo. - if len(sysconfig.get_config_var("CXX").split()) >= 2: - cmdlist.extend(sysconfig.get_config_var("CXX").split()) - else: - cmdlist.extend(['g++', '-pthread']) - - #cmdlist.extend(sysconfig.get_config_var("CXX").split()) - - # cc_flags - cmdlist.append("-c") - cmdlist.append("-g") - - # The 4 is randomly chosen! - # FIXME :: get CFLAGS from make.conf for Gentoo. - if len(sysconfig.get_config_var("CFLAGS").split()) >=4: - cmdlist.extend(sysconfig.get_config_var("CFLAGS").split()) - else: - # On Gentoo systems, CFLAGS are not in the environment. - raw = os.popen('emerge info 2> /dev/null|grep CFLAGS') - lines = raw.readlines() - if len(lines): - cflags = lines[0].split('"')[1].split() - print "Got CFLAGS from emerge info." - cmdlist.extend(cflags) - else: - # Still no CFLAGS found, use these ... - cmdlist.extend(['-fno-strict-aliasing', '-DNDEBUG', '-g', '-O3', '-Wall', '-Wstrict-prototypes']) - - #sysconfig.get_config_var("CFLAGS").split() - # includes - cmdlist.append("-I" + sysconfig.get_config_var("INCLUDEDIR")) - cmdlist.append("-I" + sysconfig.get_config_var("INCLUDEDIR")) - cmdlist.append("-I" + sysconfig.get_config_var("INCLUDEPY")) - cmdlist.append("-I" + self.python_inc_dir) - cmdlist.append("-I" + self.kde_inc_dir) - cmdlist.append("-I" + self.kde_inc_dir + "/tde") - cmdlist.append("-I" + self.qt_inc_dir) - cmdlist.append("-I/usr/include/tqt") - cmdlist.append("-I.") - # input - cmdlist.append(cppfile) - # output - outputfile = os.path.join(self.build_dir,libraryname+'.lo') - cmdlist.append("-o") - cmdlist.append(outputfile) - spawn(cmdlist) # Execute!!! - print - - # Link the resulting object file to create a shared library. - cmdlist = ['libtool'] - cmdlist.append("--mode=link") - cmdlist.append("--tag=LD") - - # Grab the linker command name - cmdlist.append(sysconfig.get_config_var("LDSHARED").split()[0]) - # link_flags - cmdlist.append("-module") - cmdlist.append("-avoid-version") - cmdlist.append("-shared") - cmdlist.append("-export-dynamic") - # object - cmdlist.append(outputfile) - cmdlist.append("-rpath"); cmdlist.append(self.kde_tdeioslave_lib_dir) - cmdlist.append("-o"); cmdlist.append(os.path.join(self.build_dir,stub_la_name)) - # Link libs - linklist = [] - linklist.append("-lpython%s" % python_version) - linklist.extend(sysconfig.get_config_var("LIBS").split()) - - # FIXME I doubt half of these libraries need to be here. - linklist.append(self.sip_dir+"/sip.so") - # PyQt libs - linklist.append(self.pyqt_dir+"/qt.so") - # PyTDE libs - linklist.append(self.pytde_dir+"/tdecore.so") - -# linklist.append("-L"+self.sip_dir); linklist.append("-lsip") -# # PyQt libs -# linklist.append("-L"+self.pyqt_dir); linklist.append("-lqtcmodule") -# # PyTDE libs -# linklist.append("-L"+self.pytde_dir); linklist.append("-ltdecorecmodule"); linklist.append("-ltdeuicmodule") - - linklist.append("-L"+self.kde_lib_dir); linklist.append("-L/opt/trinity/lib"); linklist.append("-ltdecore"); linklist.append("-lpythonize") - linklist.append("-L"+self.qt_lib_dir); linklist.append("-lqt-mt") - linklist.append("-lm") - linklist.append("-lc") - linklist.append(self.clib) - - linklist.append("-R"); linklist.append(self.python_dir) - linklist.append("-R"); linklist.append(self.qt_lib_dir) - linklist.append("-R"); linklist.append(self.sip_dir) - linklist.append("-R"); linklist.append(self.pyqt_dir) - linklist.append("-R"); linklist.append(self.pytde_dir) - linklist.append("-R"); linklist.append(self.kde_lib_dir) - - cmdlist.extend(linklist) - spawn(cmdlist) # Execute!! - print - - cpptemplate = r""" -/* - * Launch Control Centre modules written in Python using an embedded Python - * interpreter. - * Based on David Boddie's PyTDE-components. - */ - -#include <stdio.h> -#include <Python.h> -#include <kinstance.h> -#define MODULE_DIR "%(moduledir)s" -#define MODULE_NAME "%(modulename)s" -#define FACTORY "SlaveFactory" - -const char modname[] = MODULE_NAME; -#define MAIN_METHOD "dispatchLoop" - -FILE *d = NULL; - -PyObject* call_function(PyObject *callable, PyObject *args) { - PyObject *result, *pArgs; - - if (callable == NULL) { - printf(MODULE_NAME " tdeioslave error: callable == NULL in call_function\n"); - return NULL; - } - - if (PyCallable_Check(callable)) { - if(args == NULL) { - pArgs = PyTuple_New(0); - } else { - pArgs = args; - } - result = PyObject_CallObject(callable, pArgs); - - /* If the arguments were created is this function then decrease - their reference count. */ - if(args == NULL) { - Py_XDECREF(pArgs); - /* pDict and pFunc are borrowed and must not be Py_DECREF-ed */ - } - - if(result == NULL) { - PyErr_Print(); - PyErr_Clear(); - } - } - - return result; -} - -extern "C" { - int kdemain( int argc, char **argv) { - PyObject *pModule, *pName, *pDict; - TDEInstance slave(MODULE_NAME); - - Py_SetProgramName(argv[0]); - Py_Initialize(); - //PyEval_InitThreads(); - PySys_SetArgv(1, argv); - - PyRun_SimpleString("import sys\n"); - PyRun_SimpleString("sys.path.append('"MODULE_DIR"')\n"); - - pName = PyString_FromString(modname); - pModule = PyImport_Import(pName); - - Py_XDECREF(pName); - - if(pModule == NULL) { - printf(MODULE_NAME " tdeioslave error: pModule == NULL\n"); - return 1; - } else { - PyObject *pClass, *pMethod, *pArgs, *pArg1, *pArg2, *pInstance; - int i; - - pDict = PyModule_GetDict(pModule); - /* pDict is a borrowed reference */ - - pClass = PyDict_GetItemString(pDict, FACTORY); - - if(pClass == NULL) { - printf(MODULE_NAME " tdeioslave error: pClass == NULL\n"); - return 1; - } else { - pArgs = PyTuple_New(2); - - pArg1 = PyString_FromString(argv[2]); - pArg2 = PyString_FromString(argv[3]); - - PyTuple_SetItem(pArgs, 0, pArg1); - PyTuple_SetItem(pArgs, 1, pArg2); - - call_function(pClass, pArgs); - - /* Some time later... */ - Py_XDECREF(pClass); - Py_XDECREF(pArgs); - } - - Py_XDECREF(pModule); - } - - Py_Finalize(); - return 0; - } -} -""" -########################################################################### -class InstallTdeioslave(Command): - description = "Install Tdeioslave files" - - user_options = [ - ('install-dir=', 'd', "base directory for installing tdeioslave module files"), - ('install-cmd=', None, "Command to use to install the files"), - ('install-protocol-dir=',None,"directory for tdeioslave protocol files"), - ('build-dir=','b', "build directory (where to install from)"), - ('root=', None, "install everything relative to this alternate root directory"), - ('force', 'f', "force installation (overwrite existing files)"), - ('skip-build', None, "skip the build steps"), - ] - boolean_options = ['force', 'skip-build'] - - def initialize_options(self): - self.build_dir = None - self.install_dir = None - self.install_cmd = None - self.install_protocol_dir = None - self.outfiles = [] - self.root = None - self.force = 0 - self.warn_dir = 1 - self.skip_build = None - - def finalize_options(self): - own_install_dir = self.install_dir is not None - own_install_protocol_dir = self.install_protocol_dir is not None - - self.set_undefined_options('install', - ('build_base', 'build_dir'), - ('install_tdeioslave', 'install_dir'), - ('root', 'root'), - ('force', 'force'), - ('skip_build', 'skip_build'), - ('install_cmd', 'install_cmd'), - ('install_protocol','install_protocol_dir') - ) - - if own_install_dir and self.root is not None: - self.install_dir = change_root(self.root,self.installdir) - - if own_install_protocol_dir and self.root is not None: - self.install_protocol_dir = change_root(self.root,self.install_protocol_dir) - - def get_command_name(self): - return 'install_tdeioslave' - - def run(self): - if not self.skip_build: - self.run_command('build_tdeioslave') - - self.announce("Installing Tdeioslave files...") - - for moduletuple in self.distribution.tdeioslaves: - self.announce("Building Tdeioslave module from protocol file %s." % moduletuple[0]) - - protocolfilename = moduletuple[0] - - # Read the protocol file - libraryname = None - try: - fhandle = open(protocolfilename,'r') - for line in fhandle.readlines(): - parts = line.strip().split('=') - try: - if parts[0]=="exec": - libraryname = parts[1] - except IndexError: - pass - fhandle.close() - except IOError: - raise SystemExit, "Failed to find tdeioslave protocol file: %s" % moduletuple[0] - - if libraryname is None: - raise SystemExit, "Failed to find library name (Was there a exec entry in the protocol file?)" - - self.outfiles.extend(self.mkpath(self.install_protocol_dir)) - protocolfile_dest = os.path.join(self.install_protocol_dir,os.path.basename(protocolfilename)) - self.copy_file(protocolfilename, protocolfile_dest) - - stub_la_name = libraryname+'.la' - - self.outfiles.extend(self.mkpath(self.install_dir)) - - # Install the library. - cmdlist = ['libtool'] - cmdlist.append("--mode=install") - cmdlist.append(self.install_cmd) - cmdlist.append("-c") - cmdlist.append(os.path.join(self.build_dir,stub_la_name)) - cmdlist.append(os.path.join(self.install_dir,stub_la_name)) - spawn(cmdlist) # Execute!! - print - - self.outfiles = [os.path.join(self.install_dir,os.path.basename(file)) for file in glob.glob(os.path.join(self.build_dir,'.libs',libraryname+'*'))] - self.outfiles.append(protocolfile_dest) - - self.announce("Done installing Tdeioslave files.") - - def get_outputs(self): - return self.outfiles or [] - - def mkpath(self, name, mode=0777): - return dir_util.mkpath(name, mode, dry_run=self.dry_run) - -########################################################################### -class CheckPyQt(Command): - description = "Checks for the presence of a working PyQt installation" - - user_options = [] - - def initialize_options(self): - pass - - def finalize_options(self): - self.min_qt_version = self.distribution.min_qt_version - - def run(self): - if self.min_qt_version!=None: - qtver,kdever = get_qt_kde_versions() - if compare_versions(self.min_qt_version,qtver)==1: - raise SystemExit, "Your Qt version is too old. Version %s or higher is required, found %s." % (self.min_qt_version,qtver) - self.announce("Found Qt version %s." % qtver) - try: - self.announce("Checking for a working PyQt...") - import qt - self.announce(" ...PyQt is working") - except: - raise SystemExit, "Couldn't import Qt! Please make sure that PyQt is installed and working." - - def get_outputs(self): return [] - -########################################################################### -class CheckPyTDE(Command): - description = "Checks for the presence of a working PyTDE installation" - - user_options = [] - - def initialize_options(self): - pass - - def finalize_options(self): - self.min_kde_version = self.distribution.min_kde_version - - def run(self): - if self.min_kde_version!=None: - qtver,kdever = get_qt_kde_versions() - if compare_versions(self.min_kde_version,kdever)==1: - raise SystemExit, "Your KDE version is too old. Version %s or higher is required, found %s." % (self.min_kde_version,kdever) - self.announce("Found KDE version %s." % kdever) - self.announce("Checking for a working PyTDE...") - - # Try to import modules one by one. - for k_module in ('dcop', 'tdecore', 'tdeui', 'tdeio', 'tdefile', 'tdeparts', 'tdehtml', 'tdespell'): - self.announce(k_module) - try: - exec('import ' + k_module) - except: - raise SystemExit, "Error: Couldn't find module '" + k_module + "'. \n" + \ - "Couldn't import KDE! Please make sure that PyTDE is installed and working.\n" + \ - "PyTDE is available here: http://www.trinitydesktop.org" - self.announce(" ...PyTDE is working") - - def get_outputs(self): return [] - -########################################################################### -def FindFileInPaths2(globpattern,canidatepaths): - if canidatepaths is None or len(canidatepaths)==0: - return (None,None) - - # Look for the globpattern on the path. - for path in canidatepaths: - if path!=None: - files = glob.glob(os.path.join(path, globpattern)) - if len(files)!=0: - return (path,os.path.basename(files[0])) - - # Continue searching with a breadth first search. - dirs = [] - for path in canidatepaths: - # Examine any directories on this path. - dirlist = glob.glob(os.path.join(path, "*")) - for item in dirlist: - if os.path.isdir(item): - # Examine each subdirectory. - dirs.append(item) - # Examine all subdirectories. - return FindFileInPaths2(globpattern, dirs) - -########################################################################### -def FindFileInPaths(globpattern,canidatepaths): - x,y = FindFileInPaths2(globpattern,canidatepaths) - return x - -########################################################################### -# FIXME replace this with spawn.find_executable(). -def FindExeOnPath(exe_name,high_prio_dirs=None,low_prio_dirs=None): - candiate_paths = [] - - if high_prio_dirs is not None: - candiate_paths.extend(high_prio_dirs) - - path_var = os.getenv("PATH") - candiate_paths.extend(path_var.split(':')) - - if low_prio_dirs is not None: - candiate_paths.extend(low_prio_dirs) - - for dir in candiate_paths: - if dir is not None: - candiate = os.path.join(dir,exe_name) - if os.path.isfile(candiate): - if os.access(candiate,os.X_OK): - return candiate - return None - -########################################################################### - -def ask_kde_config(question): - # Look for the tde-config program - kdeconfig = find_executable("tde-config", os.environ['PATH'] + os.pathsep + \ - os.pathsep.join(['/bin','/usr/bin','/opt/trinity/bin','/opt/kde/bin','/usr/local/bin'])) - if kdeconfig!=None: - # Ask the tde-config program for the - fhandle = os.popen(kdeconfig+' ' + question,'r') - result = fhandle.read() - fhandle.close() - return result - else: - return None - -########################################################################### -# Convert for example, "3.1.1a" => [3,1,1,'a'] -# -def split_version_name(name): - result = [] - accu = '' - type = 0 - for c in name: - if type==0: - if c.isdigit(): - type = 1 - else: - type = 2 - accu += c - elif c=='.': - if type==1: - result.append(int(accu)) - else: - result.append(accu) - accu = '' - type = 0 - elif type==1: - # Digits - if c.isdigit(): - accu += c - else: - result.append(int(accu)) - type = 2 - accu = c - else: - if c.isdigit(): - result.append(accu) - type = 1 - accu = c - else: - accu += c - if accu!='': - result.append(accu) - return result - -########################################################################### -# -# Returns: -# -1 if a < b -# 0 if a and b are equal -# 1 if a > b -def compare_versions(a,b): - aparts = split_version_name(a) - bparts = split_version_name(b) - if len(aparts)>len(bparts): - compmax = len(aparts) - else: - compmax = len(bparts) - i = 0 - for i in range(compmax): - abit = 0 - if i<len(aparts): - abit = aparts[i] - bit = 0 - if i<len(bparts): - bbit = bparts[i] - if isinstance(abit,str) and not isinstance(bbit,str): - return 1 - elif not isinstance(abit,str) and isinstance(bbit,str): - return -1 - else: - if abit>bbit: - return 1 - elif abit<bbit: - return -1 - return 0 - -########################################################################### -def get_qt_kde_versions(): - versioninfo = ask_kde_config('--version') - qtver = None - kdever = None - if versioninfo!=None: - for line in versioninfo.splitlines(): - if line.startswith("Qt: "): - qtver = line[4:] - elif line.startswith("TDE: "): - kdever = line[5:] - return qtver,kdever - -########################################################################### -def compile_qtdesigner(ui_files, - force=0, - prefix=None, base_dir=None, - verbose=1, dry_run=0): - """Compile a collection of QT Designer UI files to .py - - If 'dry_run' is true, doesn't actually do anything that would - affect the filesystem. - """ - generated_files = [] - for file in ui_files: - if not file.endswith(".ui"): - continue - - # Terminology from the py_compile module: - # cfile - byte-compiled file - # dfile - purported source filename (same as 'file' by default) - if base_dir: - file = os.path.join(base_dir ,file) - - pyfile = file[:-3] + '.py' - uifile = file - - pyfile_base = os.path.basename(pyfile) - if force or newer(uifile, pyfile): - log.info("compiling Qt-Designer UI %s to %s", file, pyfile_base) - if not dry_run: - qtuicompiler.CompileUI(uifile, pyfile) - generated_files.append(pyfile) - else: - log.debug("skipping Qt-Designer compilation of %s to %s", - file, pyfile_base) - return generated_files - -########################################################################### -def get_libdir_name(): - if os.uname()[4] in ['x86_64','mips64','ppc64','sparc64','s390x']: - return 'lib64' - else: - return 'lib' |