Hotfix pithos 500 error
[pithos] / snf-pithos-tools / setup.py
1 #!/usr/bin/env python
2
3 # Copyright 2011-2012 GRNET S.A. All rights reserved.
4 #
5 # Redistribution and use in source and binary forms, with or
6 # without modification, are permitted provided that the following
7 # conditions are met:
8 #
9 #   1. Redistributions of source code must retain the above
10 #      copyright notice, this list of conditions and the following
11 #      disclaimer.
12 #
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.
17 #
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.
30 #
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.
35 #
36
37 import distribute_setup
38 distribute_setup.use_setuptools()
39
40 import os
41
42 from distutils.util import convert_path
43 from fnmatch import fnmatchcase
44 from setuptools import setup, find_packages
45
46 HERE = os.path.abspath(os.path.normpath(os.path.dirname(__file__)))
47 try:
48     # try to update the version file
49     from synnefo.util import version
50     version.update_version('pithos.tools', 'version', HERE)
51 except ImportError:
52     pass
53
54 from pithos.tools.version import __version__
55
56 # Package info
57 VERSION = __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'
61
62 PACKAGES_ROOT = '.'
63 PACKAGES = find_packages(PACKAGES_ROOT)
64
65 # Package meta
66 CLASSIFIERS = []
67
68 # Package requirements
69 INSTALL_REQUIRES = [
70     'snf-common>0.9.13',
71     'progress>=1.0'
72 ]
73
74 EXTRAS_REQUIRES = {
75 }
76
77 TESTS_REQUIRES = [
78 ]
79
80
81 # Provided as an attribute, so you can append to these instead
82 # of replicating them:
83 standard_exclude = ["*.py", "*.pyc", "*$py.class", "*~", ".*", "*.bak"]
84 standard_exclude_directories = [
85     ".*", "CVS", "_darcs", "./build", "./dist", "EGG-INFO", "*.egg-info", "snf-0.7"
86 ]
87
88 # (c) 2005 Ian Bicking and contributors; written for Paste (http://pythonpaste.org)
89 # Licensed under the MIT license: 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.
93 def find_package_data(
94     where=".",
95     package="",
96     exclude=standard_exclude,
97     exclude_directories=standard_exclude_directories,
98     only_in_packages=True,
99     show_ignored=False):
100     """
101     Return a dictionary suitable for use in ``package_data``
102     in a distutils ``setup.py`` file.
103
104     The dictionary looks like::
105
106         {"package": [files]}
107
108     Where ``files`` is a list of all the files in that package that
109     don"t match anything in ``exclude``.
110
111     If ``only_in_packages`` is true, then top-level directories that
112     are not packages won"t be included (but directories under packages
113     will).
114
115     Directories matching any pattern in ``exclude_directories`` will
116     be ignored; by default directories with leading ``.``, ``CVS``,
117     and ``_darcs`` will be ignored.
118
119     If ``show_ignored`` is true, then all the files that aren"t
120     included in package data are shown on stderr (for debugging
121     purposes).
122
123     Note patterns use wildcards, or can be exact paths (including
124     leading ``./``), and all searching is case-insensitive.
125     """
126     out = {}
127     stack = [(convert_path(where), "", package, only_in_packages)]
128     while stack:
129         where, prefix, package, only_in_packages = stack.pop(0)
130         for name in os.listdir(where):
131             fn = os.path.join(where, name)
132             if os.path.isdir(fn):
133                 bad_name = False
134                 for pattern in exclude_directories:
135                     if (fnmatchcase(name, pattern)
136                         or fn.lower() == pattern.lower()):
137                         bad_name = True
138                         if show_ignored:
139                             print >> sys.stderr, (
140                                 "Directory %s ignored by pattern %s"
141                                 % (fn, pattern))
142                         break
143                 if bad_name:
144                     continue
145                 if (os.path.isfile(os.path.join(fn, "__init__.py"))
146                     and not prefix):
147                     if not package:
148                         new_package = name
149                     else:
150                         new_package = package + "." + name
151                     stack.append((fn, "", new_package, False))
152                 else:
153                     stack.append((fn, prefix + name + "/", package, only_in_packages))
154             elif package or not only_in_packages:
155                 # is a file
156                 bad_name = False
157                 for pattern in exclude:
158                     if (fnmatchcase(name, pattern)
159                         or fn.lower() == pattern.lower()):
160                         bad_name = True
161                         if show_ignored:
162                             print >> sys.stderr, (
163                                 "File %s ignored by pattern %s"
164                                 % (fn, pattern))
165                         break
166                 if bad_name:
167                     continue
168                 out.setdefault(package, []).append(prefix+name)
169     return out
170
171 setup(
172     name = 'snf-pithos-tools',
173     version = VERSION,
174     license = 'BSD',
175     url = 'http://code.grnet.gr/',
176     description = SHORT_DESCRIPTION,
177     long_description=README + '\n\n' +  CHANGES,
178     classifiers = CLASSIFIERS,
179
180     author = 'Package author',
181     author_email = 'author@grnet.gr',
182     maintainer = 'Package maintainer',
183     maintainer_email = 'maintainer@grnet.gr',
184
185     namespace_packages = ['pithos'],
186     packages = PACKAGES,
187     package_dir= {'': PACKAGES_ROOT},
188     include_package_data = True,
189     package_data = find_package_data('.'),
190     zip_safe = False,
191
192     dependency_links = [
193         'http://docs.dev.grnet.gr/pypi/'],
194
195     install_requires = INSTALL_REQUIRES,
196     extras_require = EXTRAS_REQUIRES,
197     tests_require = TESTS_REQUIRES,
198
199     entry_points = {
200      'console_scripts': [
201          'pithos-sh = pithos.tools.sh:main',
202          'pithos-sync = pithos.tools.sync:main',
203          'pithos-test = pithos.tools.test:main',
204          'pithos-fs = pithos.tools.fs:main',
205          'pithos-dispatcher = pithos.tools.dispatcher:main',
206          ],
207       },
208 )