1 # Copyright 2011 GRNET S.A. All rights reserved.
3 # Redistribution and use in source and binary forms, with or
4 # without modification, are permitted provided that the following
7 # 1. Redistributions of source code must retain the above
8 # copyright notice, this list of conditions and the following
11 # 2. Redistributions in binary form must reproduce the above
12 # copyright notice, this list of conditions and the following
13 # disclaimer in the documentation and/or other materials
14 # provided with the distribution.
16 # THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
17 # OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
20 # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
23 # USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24 # AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 # POSSIBILITY OF SUCH DAMAGE.
29 # The views and conclusions contained in the software and
30 # documentation are those of the authors and should not be
31 # interpreted as representing official policies, either expressed
32 # or implied, of GRNET S.A.
35 import distribute_setup
36 distribute_setup.use_setuptools()
41 from distutils.util import convert_path
42 from fnmatch import fnmatchcase
43 from setuptools import setup, find_packages
45 #HERE = os.path.abspath(os.path.normpath(os.path.dirname(__file__)))
46 TOPDIR = os.environ['TOPDIR']
47 DEBIANDIR = os.path.join(TOPDIR, 'debian')
48 DEBIANDIR = os.path.normpath(DEBIANDIR)
50 from xseg.version import __version__
53 if os.path.isdir(DEBIANDIR):
54 README = open(os.path.join(DEBIANDIR, 'README')).read()
55 CHANGES = open(os.path.join(DEBIANDIR, 'changelog')).read()
60 SHORT_DESCRIPTION = 'Package short description'
63 PACKAGES = find_packages(PACKAGES_ROOT)
68 # Package requirements
79 # Provided as an attribute, so you can append to these instead
80 # of replicating them:
81 standard_exclude = ["*.py", "*.pyc", "*$py.class", "*~", ".*", "*.bak"]
82 standard_exclude_directories = [
83 ".*", "CVS", "_darcs", "./build", "./dist", "EGG-INFO", "*.egg-info"
86 # (c) 2005 Ian Bicking and contributors; written for Paste
87 # (http://pythonpaste.org)
88 # Licensed under the MIT license:
89 # http://www.opensource.org/licenses/mit-license.php
90 # Note: you may want to copy this into your setup.py file verbatim, as
91 # you can't import this from another package, when you don't know if
92 # that package is installed yet.
95 def find_package_data(
98 exclude=standard_exclude,
99 exclude_directories=standard_exclude_directories,
100 only_in_packages=True,
103 Return a dictionary suitable for use in ``package_data``
104 in a distutils ``setup.py`` file.
106 The dictionary looks like::
110 Where ``files`` is a list of all the files in that package that
111 don"t match anything in ``exclude``.
113 If ``only_in_packages`` is true, then top-level directories that
114 are not packages won"t be included (but directories under packages
117 Directories matching any pattern in ``exclude_directories`` will
118 be ignored; by default directories with leading ``.``, ``CVS``,
119 and ``_darcs`` will be ignored.
121 If ``show_ignored`` is true, then all the files that aren"t
122 included in package data are shown on stderr (for debugging
125 Note patterns use wildcards, or can be exact paths (including
126 leading ``./``), and all searching is case-insensitive.
129 stack = [(convert_path(where), "", package, only_in_packages)]
131 where, prefix, package, only_in_packages = stack.pop(0)
132 for name in os.listdir(where):
133 fn = os.path.join(where, name)
134 if os.path.isdir(fn):
136 for pattern in exclude_directories:
137 if (fnmatchcase(name, pattern)
138 or fn.lower() == pattern.lower()):
141 print >> sys.stderr, (
142 "Directory %s ignored by pattern %s"
147 if (os.path.isfile(os.path.join(fn, "__init__.py"))
152 new_package = package + "." + name
153 stack.append((fn, "", new_package, False))
155 stack.append((fn, prefix + name + "/", package,
157 elif package or not only_in_packages:
160 for pattern in exclude:
161 if (fnmatchcase(name, pattern)
162 or fn.lower() == pattern.lower()):
165 print >> sys.stderr, (
166 "File %s ignored by pattern %s"
171 out.setdefault(package, []).append(prefix+name)
178 url='http://code.grnet.gr/',
179 description=SHORT_DESCRIPTION,
180 long_description=README + '\n\n' + CHANGES,
181 classifiers=CLASSIFIERS,
183 author='Filippos Giannakos',
184 author_email='philipgian@grnet.gr',
185 maintainer='Filippos Giannakos',
186 maintainer_email='philipgianr@grnet.gr',
189 package_dir={'': PACKAGES_ROOT},
190 include_package_data=True,
191 package_data=find_package_data('.'),
194 install_requires=INSTALL_REQUIRES,
195 extras_require=EXTRAS_REQUIRES,
196 tests_require=TESTS_REQUIRES,
198 dependency_links=['http://docs.dev.grnet.gr/pypi'],