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