#!/usr/bin/env python

##############################################################################
##
## This file is part of Taurus, a Tango User Interface Library
## 
## http://www.tango-controls.org/static/taurus/latest/doc/html/index.html
##
## Copyright 2011 CELLS / ALBA Synchrotron, Bellaterra, Spain
## 
## Taurus is free software: you can redistribute it and/or modify
## it under the terms of the GNU Lesser General Public License as published by
## the Free Software Foundation, either version 3 of the License, or
## (at your option) any later version.
## 
## Taurus is distributed in the hope that it will be useful,
## but WITHOUT ANY WARRANTY; without even the implied warranty of
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
## GNU Lesser General Public License for more details.
## 
## You should have received a copy of the GNU Lesser General Public License
## along with Taurus.  If not, see <http://www.gnu.org/licenses/>.
##
##############################################################################

from __future__ import print_function

import os
import sys
import copy
import shutil
import imp
import StringIO

from distutils.core import setup, Command
from distutils.command.build import build as dftbuild
from distutils.command.install import install as dftinstall

try:
    import sphinx
    import sphinx.util.console
    sphinx.util.console.color_terminal = lambda : False
except:
    sphinx = None

def abspath(*path):
    """A method to determine absolute path for a given relative path to the
    directory where this setup.py script is located"""
    setup_dir = os.path.dirname(os.path.abspath(__file__))
    return os.path.join(setup_dir, *path)

def get_release_info():
    name = "release"
    release_dir = abspath('lib', 'taurus', 'core')
    data = imp.find_module(name, [release_dir])
    release = imp.load_module(name, *data)
    return release

Release = get_release_info()

author = Release.authors['Tiago']

package_dir = { 'taurus' : abspath('lib', 'taurus') }

packages = [
    'taurus',
    'taurus.core',
    'taurus.core.util',
    'taurus.core.util.argparse',
    'taurus.core.util.decorator',
    'taurus.core.util.report',
    'taurus.core.resource',
    'taurus.core.simulation',
    'taurus.core.evaluation',
    'taurus.core.tango',
    'taurus.core.tango.sardana',
    'taurus.core.tango.img',
    'taurus.core.tango.sardana',
    
    'taurus.console',
    'taurus.console.util',
    
    'taurus.qt',

    'taurus.qt.qtcore',
    'taurus.qt.qtcore.communication',
    'taurus.qt.qtcore.configuration',
    'taurus.qt.qtcore.mimetypes',
    'taurus.qt.qtcore.model',
    'taurus.qt.qtcore.tango',
    'taurus.qt.qtcore.tango.sardana',
    'taurus.qt.qtcore.util',

    'taurus.qt.qtdesigner',
    'taurus.qt.qtdesigner.taurusplugin',
    
    'taurus.qt.qtgui',
    'taurus.qt.qtgui.application',
    'taurus.qt.qtgui.base',
    'taurus.qt.qtgui.button',
#    'taurus.qt.qtgui.console',
    'taurus.qt.qtgui.container',
    'taurus.qt.qtgui.dialog',
    'taurus.qt.qtgui.display',
    'taurus.qt.qtgui.display.demo',
    'taurus.qt.qtgui.editor',
    'taurus.qt.qtgui.gauge',
    'taurus.qt.qtgui.gauge.demo',
    'taurus.qt.qtgui.graphic',
    'taurus.qt.qtgui.graphic.jdraw',
    'taurus.qt.qtgui.image',
    'taurus.qt.qtgui.input',
    'taurus.qt.qtgui.model',
    'taurus.qt.qtgui.panel',
    'taurus.qt.qtgui.panel.report',
    'taurus.qt.qtgui.panel.ui',
    'taurus.qt.qtgui.plot',
    'taurus.qt.qtgui.plot.ui',
    'taurus.qt.qtgui.resource',
#    'taurus.qt.qtgui.shell',
    'taurus.qt.qtgui.style',
    'taurus.qt.qtgui.table',
    'taurus.qt.qtgui.taurusgui',
    'taurus.qt.qtgui.taurusgui.conf',
    'taurus.qt.qtgui.taurusgui.ui',
    'taurus.qt.qtgui.tree',
    'taurus.qt.qtgui.ui',
    'taurus.qt.qtgui.util',
    
    'taurus.qt.uic',
]

extra_packages = [
    'taurus.qt.qtgui.extra_macroexecutor',
    'taurus.qt.qtgui.extra_macroexecutor.favouriteseditor',
    'taurus.qt.qtgui.extra_macroexecutor.macroparameterseditor',
    'taurus.qt.qtgui.extra_macroexecutor.macroparameterseditor.customeditors',
    'taurus.qt.qtgui.extra_macroexecutor.sequenceeditor',
    
    'taurus.qt.qtgui.extra_sardana',
    'taurus.qt.qtgui.extra_sardana.ui',
    
    'taurus.qt.qtgui.extra_nexus',
    
    'taurus.qt.qtgui.extra_pool',
    
    'taurus.qt.qtgui.extra_xterm',
    
    'taurus.qt.qtgui.extra_guiqwt',
    'taurus.qt.qtgui.extra_guiqwt.ui',
    
    'taurus.qt.qtgui.taurusgui.conf.tgconf_example01',
    #'taurus.qt.qtgui.taurusgui.conf.tgconf_example01.images',
    'taurus.qt.qtgui.taurusgui.conf.tgconf_macrogui',
]

provides = [
    'taurus',
    'taurus.core',
    'taurus.qt',
]

requires = [
    'numpy (>=1.1)',
    'PyTango (>=7.1)',
    'PyQt4 (>=4.4)',
    'PyQt4.Qwt5 (>=5.2.0)',   # plotting
    'ply (>=2.3)',            # jdraw parser
    'lxml (>=2.1)',           # tau2taurus, taurusuic4
    'spyder (>=2.1)',         # shell, editor
]

def get_resource_package_data():
    data = ['*.rcc']
    import PyQt4.Qt
    if not hasattr(PyQt4.Qt.QIcon, "fromTheme"):
        tango_icons_dir = abspath('lib', 'taurus', 'qt', 'qtgui', 'resource',
                                  'tango-icons')
        for tango_icon_item in os.listdir(tango_icons_dir):
            if tango_icon_item.startswith("."):
                continue
            abs_item = os.path.join(tango_icons_dir, tango_icon_item)
            if not os.path.isdir(abs_item):
                continue
            data.append('tango-icons/%s/*' % tango_icon_item)
    return data
 
package_data = { 
    'taurus.qt.qtgui.resource' : get_resource_package_data(),
    'taurus.qt.qtgui.util'     : ['tauruswidget_template', 
                                  'tauruswidget_qtdesignerplugin_template'],
    'taurus.qt.uic'            : ['pyuic4/*'],
    'taurus.qt.qtgui.taurusgui.conf.tgconf_example01' : ['images/*'],
}

def get_script_files():
    scripts_dir = abspath('scripts')
    scripts = []
    for item in os.listdir(scripts_dir):
        # avoid hidden files
        if item.startswith("."):
            continue
        abs_item = os.path.join(scripts_dir, item)
        # avoid non files
        if not os.path.isfile(abs_item):
            continue
        # avoid files that have any extension
        if len(os.path.splitext(abs_item)[1]) > 0:
            continue 
        scripts.append('scripts/' + item)
    return scripts

scripts = get_script_files()

data_files = [
]

classifiers = [
    'Development Status :: 3 - Alpha',
    'Environment :: Console',
    'Environment :: X11 Applications :: Qt',
    'Environment :: Win32 (MS Windows)',
    'Intended Audience :: Developers',
    'Intended Audience :: Science/Research',
    'License :: OSI Approved :: GNU Library or Lesser General Public License (LGPL)',
    'Operating System :: Microsoft :: Windows',
    'Operating System :: POSIX',
    'Operating System :: POSIX :: Linux',
    'Operating System :: Unix',
    'Operating System :: OS Independent',
    'Programming Language :: Python',
    'Topic :: Scientific/Engineering',
    'Topic :: Software Development :: Libraries',
    'Topic :: Software Development :: User Interfaces',
    'Topic :: Software Development :: Widget Sets',
]


class build_resources(Command):

    description = "\"build\" Qt resource files"
    
    user_options = [('logo=', None, "alternative logo file (default is taurus.png)"),]
    
    AllowedExt = ('svg', 'png', 'jpg', 'jpeg', 'gif')
    
    def initialize_options (self):
        self.resource_dir = abspath('lib', 'taurus', 'qt', 'qtgui', 'resource')
        self.taurus = os.path.join(self.resource_dir, 'taurus.png')
        self.logo = None #os.path.join(self.resource_dir,'taurus.png')
        if self.distribution.verbose:
            self.out = sys.stdout
        else:
            self.out = StringIO.StringIO()

    def finalize_options (self):
        if self.logo is None:
            build = self.get_finalized_command('build')
            if build:
                self.logo = build.logo
            if self.logo is None:
                self.logo = self.taurus
        if not os.path.isabs(self.logo):
            self.logo = os.path.abspath(self.logo)
        self.logo = os.path.realpath(self.logo)
    
    def run(self):
        orig_dir = os.path.abspath(os.curdir)
        os.chdir(self.resource_dir)
        try:
            cur_dir = os.path.abspath(os.curdir)
            
            result = self._build_general_res()
            result2 = self._build_res(cur_dir)
            
            result[0].extend(result2[0])
            result[1].extend(result2[1])
        finally:
            os.chdir(orig_dir)
    
    def _build_general_res(self):
        qrc_filename = 'general.qrc'
        rcc_filename = 'qrc_general.rcc'
        out = self.out
        print("Generating %s... " % qrc_filename, file=out, end='')
        out.flush()
        f = file(qrc_filename, 'w')
        try:
            logo_relpath = os.path.relpath(self.logo)
            taurus_relpath = os.path.relpath(self.taurus)
            f.write('<RCC>\n    <qresource>\n')
            f.write('        <file alias="logo.png">%s</file>\n' % logo_relpath)
            f.write('        <file alias="taurus.png">%s</file>\n' % taurus_relpath)
            f.write('    </qresource>\n')
            f.write('</RCC>\n')
        except Exception, e:
            print("[FAILED]\nDescription:\n%s" % str(e), file=out)
            raise e
        finally:
            f.close()
        print("[DONE]", file=out)
        
        # Generate binary rcc file
        print("Generating %s... " % rcc_filename, file=out, end='')
        out.flush()
        cmd = 'rcc -binary %s -o %s' % (qrc_filename, rcc_filename)
        if os.system(cmd):
            print("[FAILED]", file=out)
        else:
            print("[DONE]", file=out)
        
        return [ [qrc_filename], [rcc_filename]]
    
    def _build_res(self, abs_dir, bases=list()):
        """Builds the resources in the abs_dir recursively.
        The result is a list of 5 items:
            - a list of generated qrc files
            - a list of generated rcc files
        """
        result = [[], []]
        res_name = os.path.basename(abs_dir)
        local_elems, local_bases = [], copy.copy(bases)
        local_bases.append(res_name)
        out = self.out
        for elem in os.listdir(abs_dir):
            if elem.startswith('.'): continue
            abs_elem = os.path.abspath(os.path.join(abs_dir, elem))
            if os.path.isdir(abs_elem):
                ret = self._build_res(abs_elem, local_bases)
                result[0].extend(ret[0])
                result[1].extend(ret[1])
            elif os.path.splitext(abs_elem)[1][1:].lower() in build_resources.AllowedExt:
                local_elems.append(elem)
        
        if local_elems and local_bases[1:]:
            base_dir = os.path.join(*local_bases[1:])
            base_filename = "_".join(local_bases[1:])
            base_filename = base_filename.replace('-','_')
            qrc_filename = base_filename + ".qrc"
            rcc_filename = 'qrc_' + base_filename + ".rcc"
            
            # Generate qrc file
            print("Generating %s... " % qrc_filename, file=out, end='')
            out.flush()
            f = file(qrc_filename, 'w')
            try:
                qresource_prefix = ""
                if len(local_bases) > 2:
                    qresource_prefix = "/" + "/".join(local_bases[2:])
                    f.write('<RCC>\n    <qresource prefix="%s">\n' % qresource_prefix)
                else:
                    f.write('<RCC>\n    <qresource>\n')
                qresource_prefix = ":" + qresource_prefix
                qresource_prefix += "/"
                for elem in local_elems:
                    rel_elem = os.path.join(base_dir, elem)
                    f.write('        <file alias="%s">%s</file>\n' % (elem, rel_elem))
                f.write('    </qresource>\n</RCC>')
            except Exception, e:
                print("[FAILED]\nDescription:\n%s" % str(e), file=out)
                raise e
            finally:
                f.close()
            result[0].append(qrc_filename)
            print("[DONE]", file=out)
            
            # Generate binary rcc file
            print("Generating %s... " % rcc_filename, file=out, end='')
            out.flush()
            cmd = 'rcc -binary %s -o %s' % (qrc_filename, rcc_filename)
            if os.system(cmd):
                print("[FAILED]", file=out)
            else:
                result[1].append(rcc_filename)
                print("[DONE]", file=out)
            
        return result


class build(dftbuild):

    user_options = dftbuild.user_options + \
        [('logo=', None, "alternative logo file (default is taurus.png)"),
         ('with-extra-widgets', None, "distribute extra widgets"),
         ('no-doc', None, "do not build documentation")]

    boolean_options = dftbuild.boolean_options + ['with-extra-widgets', 'no-doc']

    def initialize_options (self):
        dftbuild.initialize_options(self)
        self.logo = None
        self.doc_fmt = None
        self.no_doc = None
        self.with_extra_widgets = True

    def finalize_options (self):
        dftbuild.finalize_options(self)
        if self.logo is None:
            self.logo = abspath('lib','taurus','qt','qtgui','resource','taurus.png')
      
    def run(self):
        if self.with_extra_widgets:
            self.distribution.packages.extend(extra_packages)

        dftbuild.run(self)

    def has_doc(self):
        if self.no_doc:
            return False
        if not sphinx:
            print("Sphinx not available: Documentation will not be build!")
            return False
        return os.path.isdir(abspath('doc'))

    def has_resources(self):
        return os.path.isdir(abspath('lib','taurus','qt','qtgui','resource'))

    sub_commands = [('build_resources', has_resources)] + \
                   dftbuild.sub_commands + \
                   [('build_doc', has_doc)]


class install_man(Command):
    
    user_options = [
        ('install-dir=', 'd', 'base directory for installing man page files')]
    
    def initialize_options(self):
        self.install_dir = None
        
    def finalize_options(self):
        self.set_undefined_options('install',
                                   ('install_man', 'install_dir'))
                                   
    def run(self):
        src_man_dir = abspath('doc', 'man')
        man_elems = os.listdir(src_man_dir)
        man_pages = []
        for f in man_elems:
            f = os.path.join(src_man_dir,f)
            if not os.path.isfile(f): continue
            if not f.endswith(".1"): continue
            man_pages.append(f)
        
        install_dir = os.path.join(self.install_dir, 'man1')
        
        if not os.path.isdir(install_dir):
            os.makedirs(install_dir)
        
        for man_page in man_pages:
            self.copy_file(man_page, install_dir)


class install_html(Command):

    user_options = [
        ('install-dir=', 'd', 'base directory for installing HTML documentation files')]
    
    def initialize_options(self):
        self.install_dir = None
        
    def finalize_options(self):
        self.set_undefined_options('install',
                                   ('install_html', 'install_dir'))
                                   
    def run(self):
        build_doc = self.get_finalized_command('build_doc')
        src_html_dir = abspath(build_doc.build_dir, 'html')
        self.copy_tree(src_html_dir, self.install_dir)


class install(dftinstall):
    
    user_options = list(dftinstall.user_options)
    user_options.extend([
            ('install-man=', None, 'installation directory for Unix man pages'),
            ('install-html=', None, "installation directory for HTML documentation"),
            ('no-doc', None, "do not install HTML documentation")])

    def initialize_options(self):
        self.install_man = None
        self.install_html = None
        self.no_doc = None
        dftinstall.initialize_options(self)
    
    def finalize_options(self):
        
        # We do a hack here. We cannot trust the 'install_base' value because it
        # is not always the final target. For example, in unix, the install_base
        # is '/usr' and all other install_* are directly relative to it. However,
        # in unix-local (like ubuntu) install_base is still '/usr' but, for 
        # example, install_data, is '$install_base/local' which breaks everything.
        #
        # The hack consists in using install_data instead of install_base since
        # install_data seems to be, in practice, the proper install_base on all
        # different systems.
        
        dftinstall.finalize_options(self)
        if os.name != "posix":
            if self.install_man is not None:
                self.warn("install-man option ignored on this platform")
                self.install_man = None
        else:
            if self.install_man is None:
                self.install_man = os.path.join(self.install_data, 'share', 'man')
        if self.install_html is None:
            self.install_html = os.path.join(self.install_data, 'share', 'doc', 'taurus', 'html')
        if self.no_doc is None:
            self.no_doc = False
        self.dump_dirs("Installation directories")

    def expand_dirs(self):
        dftinstall.expand_dirs(self)
        self._expand_attrs(['install_man'])

    def has_man(self):
        return os.name == "posix"
    
    def has_html(self):
        if self.no_doc:
            return False
        return sphinx is not None
    
    sub_commands = list(dftinstall.sub_commands)
    sub_commands.append(('install_man', has_man))
    sub_commands.append(('install_html', has_html))


class build_doc_api(Command):
    
    user_options = []
    
    description = "\"build\" sphinx RST files for API"

    def initialize_options (self):
        if self.distribution.verbose:
            self.out = sys.stdout
        else:
            self.out = StringIO.StringIO()


    def finalize_options (self):
        pass 
        
    def run(self):
        #print("SKIPPING API");return
        buildcmd = self.get_finalized_command('build_doc')
        name = "auto_rst4api"
        data = imp.find_module(name, [abspath('doc')])
        auto_rst4api = imp.load_module(name, *data)
        
        docpreffix = abspath('doc', 'source', 'devel', 'api')
        templatespath = abspath('doc')
        rstCreator = auto_rst4api.Auto_rst4API_Creator(exclude_patterns=['.*\.ui', '_[^\.]*[^_]'],
                                                       templatespath=templatespath,
                                                       overwrite_old=buildcmd.all_files,
                                                       verbose=self.distribution.verbose)
        if buildcmd.all_files:
            rstCreator.cleanAutogenerated(docpreffix) #@todo: This may need to be called *only* if --fres-env or --all-files options are given
        r = rstCreator.documentModule('taurus', docpreffix)
        out=self.out
        print("Auto Creation of API docs Finished with %i warnings:"%len(r),file=out)
        for i in r:
            print(i,file=out)

cmdclass = { 'build' : build,
             'build_resources' : build_resources,
             'install' : install,
             'install_man' : install_man,
             'install_html' : install_html,
             'build_doc_api' : build_doc_api }

if sphinx:
    from sphinx.setup_command import BuildDoc

    class build_catalog(object):

        AllowedExt = build_resources.AllowedExt
        
        HTML_IL = """<tr height="30"><td width="30" align="center"><img width="24" src="%s" alt="%s"/></td><td width="400">%s%s</td><td width="400">%s</td><td width="200">%s</td></tr>\n"""
        HTML_T = '<table border="1" cellspacing="0" cellpadding="2">\n' \
                 '<th colspan="4">Resource: "%s" Directory: "%s"</th>\n' \
                 '<tr><th>Preview</th><th>Resouce</th><th>File name</th><th>Theme</th></tr>\n'
        
        def run(self):
            self.resource_dir = abspath('lib', 'taurus', 'qt', 'qtgui', 'resource')
            self.taurus = os.path.join(self.resource_dir, 'taurus.png')
            orig_dir = os.path.abspath(os.curdir)
            os.chdir(self.resource_dir)
            
            catalog = file('catalog.html', 'w')
            catalog.write("<html><head>\n<title>taurus Icon Catalog</title>\n" \
            "<style>table { border-collapse: collapse; }</style>\n</head>\n<body>\n")
            
            try:
                cur_dir = os.path.abspath(os.curdir)
                
                result = self._build_general_res()
                result2 = self._build_res(cur_dir)
                
                result[0].extend(result2[0])
                result[1].extend(result2[1])

                catalog.write("<h1>Index</h1>\n<ul>")
                for anchor in result[1]:
                    catalog.write("<li>%s</li>\n" % anchor)
                catalog.write("</ul>\n")
                catalog.writelines(result[0])
            finally:
                catalog.write("""</body></html>""")
                catalog.close()
                os.chdir(orig_dir)

        def getThemeIcon(self, resource):
            try:
                import PyQt4.Qt
                if not hasattr(PyQt4.Qt.QIcon, "hasThemeIcon"):
                    return "Unknown"
                i = resource.rfind("/")
                if i >= 0: resource = resource[i+1:]
                i = resource.rfind(".")
                if i >= 0: resource = resource[:i]
                if PyQt4.Qt.QIcon.hasThemeIcon(resource):
                    return resource
                return "No"
            except:
                return "Unknown"

        def _build_general_res(self):
            out = self.out
            html = '<h2><a name="_base">Base icons</a></h2>\n'
            html += self.HTML_T % (':/','')
            anchor = '<a href="#_base">Base icons</a>'
            try:
                taurus_relpath = os.path.relpath(self.taurus)
                html += self.HTML_IL % (taurus_relpath, taurus_relpath, ":/", taurus_relpath, taurus_relpath, self.getThemeIcon("taurus.png"))
            except Exception, e:
                print("[FAILED]\nDescription:\n%s" % str(e), file=out)
                import traceback
                traceback.print_exc()
                raise e
            finally:
                html += '</table>\n'
            
            return [ [html], [anchor] ]
        
        def _build_res(self, abs_dir, bases=list()):
            """Builds the resources in the abs_dir recursively.
            The result is a list of 5 items:
                - a list of HTML strings
                - a list of HTML anchors
            """
            result = [[], []]
            res_name = os.path.basename(abs_dir)
            local_elems, local_bases = [], copy.copy(bases)
            local_bases.append(res_name)
            out = self.out
            for elem in os.listdir(abs_dir):
                if elem.startswith('.'): continue
                abs_elem = os.path.abspath(os.path.join(abs_dir, elem))
                if os.path.isdir(abs_elem):
                    ret = self._build_res(abs_elem, local_bases)
                    result[0].extend(ret[0])
                    result[1].extend(ret[1])
                elif os.path.splitext(abs_elem)[1][1:].lower() in build_resources.AllowedExt:
                    local_elems.append(elem)
            
            if local_elems and local_bases[1:]:
                base_dir = os.path.join(*local_bases[1:])
                base_filename = "_".join(local_bases[1:])
                base_filename = base_filename.replace('-','_')
                
                html = ''
                anchor = ''
                try:
                    qresource_prefix = ""
                    if len(local_bases) > 2:
                        qresource_prefix = "/" + "/".join(local_bases[2:])
                    qresource_prefix = ":" + qresource_prefix
                    qresource_prefix += "/"

                    html += '<h2><a name="%s">%s (%s)</a></h2>\n' % (base_dir, qresource_prefix, base_dir)
                    html += self.HTML_T % (qresource_prefix , base_dir)
                    anchor = '<a href="#%s">%s (%s)</a>' % (base_dir, base_dir, qresource_prefix)
                    for elem in local_elems:
                        rel_elem = os.path.join(base_dir, elem)
                        base_elem, _ = os.path.splitext(rel_elem)
                        rel_png_elem = base_elem + ".png"
                        html += self.HTML_IL % (rel_png_elem, rel_elem, qresource_prefix, elem, rel_elem, self.getThemeIcon(elem))
                except Exception, e:
                    print("[FAILED]\nDescription:\n%s" % str(e), file=out)
                    raise e
                finally:
                    html += '</table>\n'
                result[0].append(html)
                result[1].append(anchor)
            return result

    class build_doc(BuildDoc):
        user_options = BuildDoc.user_options + \
                     [('use-inkscape', None, 
                       "Use inkscape for building the icon catalog (useful if QApplication cannot be used when building, but requires inkscape)")]
        boolean_options = BuildDoc.boolean_options + ['use-inkscape']
        
        def initialize_options (self):
            BuildDoc.initialize_options(self)
            self.use_inkscape = False
        
        def has_doc_api(self):
            return True

        sub_commands = BuildDoc.sub_commands + [(('build_doc_api', has_doc_api))]
        
        def run(self):
            try:
                return self.doit()
            except Exception,e:
                self.warn("Failed to build doc. Reason: %s" % str(e))
        
        def doit(self):
            if self.distribution.verbose:
                out = sys.stdout
            else:
                out = StringIO.StringIO()

            catalog = build_catalog()
            catalog.verbose = self.distribution.verbose
            catalog.out = out
            catalog.run()
            
            resource = abspath('lib','taurus','qt','qtgui','resource')
            tango_catalog = os.path.join(resource, 'catalog.html')
            build_dir = os.path.abspath(self.builder_target_dir)
            target = abspath('doc', 'source', 'devel')
            target_catalog = os.path.join(target, 'catalog.html')
            
            # copy the icon catalog.html to the doc directory
            refresh = self.fresh_env or self.all_files
            if not os.path.isfile(target_catalog) or refresh:
                print("copying",tango_catalog,'->',target_catalog,file=out)
                shutil.copyfile(tango_catalog, target_catalog)
            
            # make sure the python path is pointing to the newly built
            # code so that the documentation is built on this and not a
            # previously installed version
            build_cmd = self.get_finalized_command('build')
            build_lib = os.path.abspath(build_cmd.build_lib)
            sys.path.insert(0, build_lib)
            try:
                for cmd_name in self.get_sub_commands():
                    self.run_command(cmd_name)
                BuildDoc.run(self)
            finally:
                sys.path.pop(0)
            
            # copy the tango icons to the build directory of documentation
            target = os.path.join(build_dir, 'devel')
            
            if not self.use_inkscape:
                import PyQt4.Qt
                if PyQt4.Qt.qApp.instance() is None:
                    self.app = PyQt4.Qt.QApplication([])
            
            print("\tBuilding PNGs for icon catalog")   
            os.path.walk(resource, svg_to_png, (resource, target, self.use_inkscape))
            return
    
    cmdclass['build_doc'] = build_doc

def svg_to_png(arg, dirname, fnames):
    resource, target, use_inkscape = arg
    if not use_inkscape:
        import PyQt4.Qt
    relpath = os.path.relpath(dirname, start=resource)
    path = os.path.join(target, relpath)
    if not os.path.isdir(path):
        os.makedirs(path)
    for fname in fnames:
        fbase, f_ext  = os.path.splitext(fname)
        if f_ext[1:] in build_catalog.AllowedExt:
            full_source_fname = os.path.join(dirname, fname)
            target_fname = fbase + ".png"
            full_target_fname = os.path.join(path, target_fname)
            if not os.path.isfile(full_target_fname):
                if use_inkscape:
                    cmd = "inkscape -z '%s' -e '%s' -w 24 >/dev/null 2>/dev/null"%(full_source_fname, full_target_fname)
                    ok = not(os.system(cmd))
                    if not ok:
                        cmd = "convert -resize 24 '%s' '%s' >/dev/null 2>/dev/null"%(full_source_fname, full_target_fname)
                        ok = not(os.system(cmd))
                else:
                    pixmap = PyQt4.Qt.QPixmap(full_source_fname)
                    pix = pixmap.scaledToWidth(24, PyQt4.Qt.Qt.SmoothTransformation)
                    ok = pix.save(full_target_fname)
                print(ok and "[OK]" or "[FAIL]", full_source_fname,'->',full_target_fname)
                
                

setup(name             = 'taurus',
      version          = Release.version,
      description      = Release.description,
      long_description = Release.long_description,
      author           = author[0],
      author_email     = author[1],
      url              = Release.url,
      download_url     = Release.download_url,
      platforms        = Release.platforms,
      license          = Release.license,
      packages         = packages,
      package_dir      = package_dir,
      classifiers      = classifiers,
      package_data     = package_data,
      data_files       = data_files,
      scripts          = scripts,
      provides         = provides,
      keywords         = Release.keywords,
      requires         = requires,
      cmdclass         = cmdclass)

