3 # Copyright 2011-2012 GRNET S.A. All rights reserved.
5 # Redistribution and use in source and binary forms, with or
6 # without modification, are permitted provided that the following
9 # 1. Redistributions of source code must retain the above
10 # copyright notice, this list of conditions and the following
13 # 2. Redistributions in binary form must reproduce the above
14 # copyright notice, this list of conditions and the following
15 # disclaimer in the documentation and/or other materials
16 # provided with the distribution.
18 # THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
19 # OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20 # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
22 # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
25 # USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
26 # AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
28 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 # POSSIBILITY OF SUCH DAMAGE.
31 # The views and conclusions contained in the software and
32 # documentation are those of the authors and should not be
33 # interpreted as representing official policies, either expressed
34 # or implied, of GRNET S.A.
37 import distribute_setup
38 distribute_setup.use_setuptools()
42 from distutils.util import convert_path
43 from fnmatch import fnmatchcase
44 from setuptools import setup, find_packages
46 HERE = os.path.abspath(os.path.normpath(os.path.dirname(__file__)))
48 # try to update the version file
49 from synnefo.util import version
50 version.update_version('pithos.tools', 'version', HERE)
54 from pithos.tools.version import __version__
58 README = open(os.path.join(HERE, 'README')).read()
59 CHANGES = open(os.path.join(HERE, 'Changelog')).read()
60 SHORT_DESCRIPTION = 'Package short description'
63 PACKAGES = find_packages(PACKAGES_ROOT)
68 # Package requirements
80 # Provided as an attribute, so you can append to these instead
81 # of replicating them:
82 standard_exclude = ["*.py", "*.pyc", "*$py.class", "*~", ".*", "*.bak"]
83 standard_exclude_directories = [
84 ".*", "CVS", "_darcs", "./build", "./dist", "EGG-INFO", "*.egg-info", "snf-0.7"
87 # (c) 2005 Ian Bicking and contributors; written for Paste (http://pythonpaste.org)
88 # Licensed under the MIT license: http://www.opensource.org/licenses/mit-license.php
89 # Note: you may want to copy this into your setup.py file verbatim, as
90 # you can't import this from another package, when you don't know if
91 # that package is installed yet.
92 def find_package_data(
95 exclude=standard_exclude,
96 exclude_directories=standard_exclude_directories,
97 only_in_packages=True,
100 Return a dictionary suitable for use in ``package_data``
101 in a distutils ``setup.py`` file.
103 The dictionary looks like::
107 Where ``files`` is a list of all the files in that package that
108 don"t match anything in ``exclude``.
110 If ``only_in_packages`` is true, then top-level directories that
111 are not packages won"t be included (but directories under packages
114 Directories matching any pattern in ``exclude_directories`` will
115 be ignored; by default directories with leading ``.``, ``CVS``,
116 and ``_darcs`` will be ignored.
118 If ``show_ignored`` is true, then all the files that aren"t
119 included in package data are shown on stderr (for debugging
122 Note patterns use wildcards, or can be exact paths (including
123 leading ``./``), and all searching is case-insensitive.
126 stack = [(convert_path(where), "", package, only_in_packages)]
128 where, prefix, package, only_in_packages = stack.pop(0)
129 for name in os.listdir(where):
130 fn = os.path.join(where, name)
131 if os.path.isdir(fn):
133 for pattern in exclude_directories:
134 if (fnmatchcase(name, pattern)
135 or fn.lower() == pattern.lower()):
138 print >> sys.stderr, (
139 "Directory %s ignored by pattern %s"
144 if (os.path.isfile(os.path.join(fn, "__init__.py"))
149 new_package = package + "." + name
150 stack.append((fn, "", new_package, False))
152 stack.append((fn, prefix + name + "/", package, only_in_packages))
153 elif package or not only_in_packages:
156 for pattern in exclude:
157 if (fnmatchcase(name, pattern)
158 or fn.lower() == pattern.lower()):
161 print >> sys.stderr, (
162 "File %s ignored by pattern %s"
167 out.setdefault(package, []).append(prefix+name)
171 name = 'snf-pithos-tools',
174 url = 'http://code.grnet.gr/',
175 description = SHORT_DESCRIPTION,
176 long_description=README + '\n\n' + CHANGES,
177 classifiers = CLASSIFIERS,
179 author = 'Package author',
180 author_email = 'author@grnet.gr',
181 maintainer = 'Package maintainer',
182 maintainer_email = 'maintainer@grnet.gr',
184 namespace_packages = ['pithos'],
186 package_dir= {'': PACKAGES_ROOT},
187 include_package_data = True,
188 package_data = find_package_data('.'),
192 'http://docs.dev.grnet.gr/pypi/'],
194 install_requires = INSTALL_REQUIRES,
195 extras_require = EXTRAS_REQUIRES,
196 tests_require = TESTS_REQUIRES,
200 'pithos-sh = pithos.tools.sh:main',
201 'pithos-sync = pithos.tools.sync:main',
202 'pithos-test = pithos.tools.test:main',
203 'pithos-fs = pithos.tools.fs:main',
204 'pithos-dispatcher = pithos.tools.dispatcher:main',