1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199
|
#!/usr/bin/env python
# -*- coding: ISO-8859-1 -*-
"""Python package for the generation of PostScript and PDF files
PyX is a Python package for the creation of PostScript and PDF files. It
combines an abstraction of the PostScript drawing model with a TeX/LaTeX
interface. Complex tasks like 2d and 3d plots in publication-ready quality are
built out of these primitives.
"""
try:
from distutils import log
except:
log = None
from distutils.core import setup, Extension
from distutils.util import change_root, convert_path
from distutils.command.build_py import build_py
from distutils.command.install_data import install_data
from distutils.command.install_lib import install_lib
import ConfigParser
import sys, os
import pyx
#
# build list of extension modules
#
ext_modules = []
pykpathsea_ext_module = Extension("pyx.pykpathsea._pykpathsea",
sources=["pyx/pykpathsea/pykpathsea.c"],
libraries=["kpathsea"])
t1code_ext_module = Extension("pyx.font._t1code",
sources=["pyx/font/_t1code.c"])
# obtain information on which modules have to be built from setup.cfg file
cfg = ConfigParser.ConfigParser()
cfg.read("setup.cfg")
if cfg.has_section("PyX"):
if cfg.has_option("PyX", "build_pykpathsea") and cfg.getboolean("PyX", "build_pykpathsea"):
ext_modules.append(pykpathsea_ext_module)
if cfg.has_option("PyX", "build_t1code") and cfg.getboolean("PyX", "build_t1code"):
ext_modules.append(t1code_ext_module)
################################################################################
# data files
#
# share/pyx is taken relative to "setup.py install --home=..."
# whereas /etc is taken relative to "setup.py install --root=..."
data_files = []
# variable names in siteconfig.py for a list of files in data_files
siteconfignames = {}
def adddatafiles(siteconfigname, dir, files):
"""store siteconfigname for files in siteconfignames and add (dir, files) to data_files"""
# convert files to a tuple to make it hashable
files = tuple(files)
data_files.append((dir, files))
siteconfignames[files] = siteconfigname
adddatafiles("lfsdir", "share/pyx", ["pyx/lfs/10pt.lfs",
"pyx/lfs/11pt.lfs",
"pyx/lfs/12pt.lfs",
"pyx/lfs/10ptex.lfs",
"pyx/lfs/11ptex.lfs",
"pyx/lfs/12ptex.lfs",
"pyx/lfs/foils17pt.lfs",
"pyx/lfs/foils20pt.lfs",
"pyx/lfs/foils25pt.lfs",
"pyx/lfs/foils30pt.lfs"])
adddatafiles("sharedir", "share/pyx", ["contrib/pyx.def"])
# Note that on windows we can't install to absolute paths. Hence
# we put the global pyxrc into the share directory as well.
adddatafiles("pyxrcdir", os.name != "nt" and "/etc" or "share/pyx", ["pyxrc"])
################################################################################
# extend install commands to overwrite siteconfig.py during build and install
#
class pyx_build_py(build_py):
def build_module(self, module, module_file, package):
if package == "pyx" and module == "siteconfig":
# generate path information as the original build_module does it
outfile = self.get_module_outfile(self.build_lib, [package], module)
outdir = os.path.dirname(outfile)
self.mkpath(outdir)
if log:
log.info("creating proper %s" % outfile)
# create the additional relative path parts to be inserted into the
# os.path.join methods in the original siteconfig.py
indir = os.path.dirname(module_file)
addjoinstring = ", ".join(["'..'" for d in outdir.split(os.path.sep)] +
["'%s'" % d for d in indir.split(os.path.sep)])
# write a modifed version of siteconfig.py
fin = open(module_file, "r")
fout = open(outfile, "w")
for line in fin.readlines():
fout.write(line.replace("os.path.join(os.path.dirname(__file__), ",
"os.path.join(os.path.dirname(__file__), %s, " % addjoinstring))
fin.close()
fout.close()
else:
return build_py.build_module(self, module, module_file, package)
class pyx_install_data(install_data):
def run(self):
self.siteconfiglines = []
for dir, files in self.data_files:
# append siteconfiglines by "<siteconfigname> = <dir>"
# get the install directory
# (the following four lines are copied from within the install_data.run loop)
dir = convert_path(dir)
if not os.path.isabs(dir):
dir = os.path.join(self.install_dir, dir)
elif self.root:
dir = change_root(self.root, dir)
self.siteconfiglines.append("%s = '%s'\n" % (siteconfignames[files], dir))
install_data.run(self)
class pyx_install_lib(install_lib):
def run(self):
# siteconfig.py depends on install_data:
self.run_command('install_data')
install_lib.run(self)
def install(self):
# first we perform the tree_copy
result = install_lib.install(self)
# siteconfiglines have been created by install_data
siteconfiglines = self.distribution.command_obj["install_data"].siteconfiglines
# such that we can easily overwrite siteconfig.py
outfile = os.path.join(self.install_dir, "pyx", "siteconfig.py")
if log:
log.info("creating proper %s" % outfile)
f = open(outfile, "w")
f.writelines(siteconfiglines)
f.close()
return result
################################################################################
# additional package metadata (only available in Python 2.3 and above)
#
if sys.version_info >= (2, 3):
addargs = { "classifiers":
[ "Development Status :: 3 - Alpha",
"Intended Audience :: Developers",
"Intended Audience :: End Users/Desktop",
"License :: OSI Approved :: GNU General Public License (GPL)",
"Operating System :: OS Independent",
"Programming Language :: Python",
"Topic :: Multimedia :: Graphics",
"Topic :: Scientific/Engineering :: Visualization",
"Topic :: Software Development :: Libraries :: Python Modules" ],
"download_url":
"http://sourceforge.net/project/showfiles.php?group_id=45430",
"platforms":
"OS independent",
}
else:
addargs = {}
# We're using the module docstring as the distutils descriptions. (seen in Zope3 setup.py)
doclines = __doc__.split("\n")
setup(name="PyX",
version=pyx.__version__,
author="Jrg Lehmann, Andr Wobst",
author_email="pyx-devel@lists.sourceforge.net",
url="http://pyx.sourceforge.net/",
description=doclines[0],
long_description="\n".join(doclines[2:]),
license="GPL",
packages=["pyx", "pyx/graph", "pyx/graph/axis", "pyx/font", "pyx/pykpathsea"],
ext_modules=ext_modules,
data_files=data_files,
cmdclass = {"build_py": pyx_build_py,
"install_data": pyx_install_data,
"install_lib": pyx_install_lib},
**addargs)
|