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.
35 import distribute_setup
36 distribute_setup.use_setuptools()
41 from fnmatch import fnmatchcase
42 from distutils.util import convert_path
44 from setuptools import setup, find_packages
47 HERE = os.path.abspath(os.path.normpath(os.path.dirname(__file__)))
49 # try to update the version file
50 from synnefo.util import version
51 version.update_version('pithos_web_client', 'version', HERE)
55 from pithos_web_client.version import __version__
59 README = open(os.path.join(HERE, 'README')).read()
60 CHANGES = open(os.path.join(HERE, 'Changelog')).read()
61 SHORT_DESCRIPTION = 'Package short description'
64 PACKAGES = find_packages(PACKAGES_ROOT)
68 'Development Status :: 3 - Alpha',
69 'Operating System :: OS Independent',
70 'Programming Language :: Python',
72 'License :: OSI Approved :: BSD License',
75 # Package requirements
87 # Provided as an attribute, so you can append to these instead
88 # of replicating them:
89 standard_exclude = ["*.py", "*.pyc", "*$py.class", "*~", ".*", "*.bak"]
90 standard_exclude_directories = [
91 ".*", "CVS", "_darcs", "./build", "./dist", "EGG-INFO", "*.egg-info", "snf-0.7"
94 # (c) 2005 Ian Bicking and contributors; written for Paste (http://pythonpaste.org)
95 # Licensed under the MIT license: http://www.opensource.org/licenses/mit-license.php
96 # Note: you may want to copy this into your setup.py file verbatim, as
97 # you can't import this from another package, when you don't know if
98 # that package is installed yet.
99 def find_package_data(
102 exclude=standard_exclude,
103 exclude_directories=standard_exclude_directories,
104 only_in_packages=True,
107 Return a dictionary suitable for use in ``package_data``
108 in a distutils ``setup.py`` file.
110 The dictionary looks like::
114 Where ``files`` is a list of all the files in that package that
115 don"t match anything in ``exclude``.
117 If ``only_in_packages`` is true, then top-level directories that
118 are not packages won"t be included (but directories under packages
121 Directories matching any pattern in ``exclude_directories`` will
122 be ignored; by default directories with leading ``.``, ``CVS``,
123 and ``_darcs`` will be ignored.
125 If ``show_ignored`` is true, then all the files that aren"t
126 included in package data are shown on stderr (for debugging
129 Note patterns use wildcards, or can be exact paths (including
130 leading ``./``), and all searching is case-insensitive.
133 stack = [(convert_path(where), "", package, only_in_packages)]
135 where, prefix, package, only_in_packages = stack.pop(0)
136 for name in os.listdir(where):
137 fn = os.path.join(where, name)
138 if os.path.isdir(fn):
140 for pattern in exclude_directories:
141 if (fnmatchcase(name, pattern)
142 or fn.lower() == pattern.lower()):
145 print >> sys.stderr, (
146 "Directory %s ignored by pattern %s"
151 if (os.path.isfile(os.path.join(fn, "__init__.py"))
156 new_package = package + "." + name
157 stack.append((fn, "", new_package, False))
159 stack.append((fn, prefix + name + "/", package, only_in_packages))
160 elif package or not only_in_packages:
163 for pattern in exclude:
164 if (fnmatchcase(name, pattern)
165 or fn.lower() == pattern.lower()):
168 print >> sys.stderr, (
169 "File %s ignored by pattern %s"
174 out.setdefault(package, []).append(prefix+name)
179 Gwt clea/build helpers
181 import subprocess as sp
184 def clean_gwt(root="../", public_dir="bin/www/gr.grnet.pithos.web.Pithos/"):
185 # skip if no build.xml found (debian build process)
186 if not os.path.exists(os.path.join(root, "build.xml")):
191 rcode = sp.call(["ant", "clean"])
193 raise Exception("GWT clean failed")
195 pub_dir = os.path.abspath(os.path.join(root, public_dir))
196 static_dir = os.path.abspath(os.path.join("pithos_web_client", "static", \
197 "pithos_web_client"))
198 templates_dir = os.path.abspath(os.path.join("pithos_web_client", \
199 "templates", "pithos_web_client"))
200 clean_static = ["rm", "-r"] + glob.glob(os.path.join(static_dir, "*"))
201 clean_templates = ["rm", "-r"] + glob.glob(os.path.join(templates_dir, "*"))
204 if len(clean_static) > 2:
205 sp.call(clean_static)
206 if len(clean_static) > 2:
207 sp.call(clean_templates)
210 def build_gwt(root="../", public_dir="bin/www/gr.grnet.pithos.web.Pithos/"):
211 # skip if no build.xml found (debian build process)
212 if not os.path.exists(os.path.join(root, "build.xml")):
217 # run ant on root dir
218 rcode = sp.call(["ant"])
220 raise Exception("GWT build failed")
224 pub_dir = os.path.abspath(os.path.join(root, public_dir))
225 static_dir = os.path.abspath(os.path.join("pithos_web_client", "static", \
226 "pithos_web_client"))
227 templates_dir = os.path.abspath(os.path.join("pithos_web_client", \
228 "templates", "pithos_web_client"))
230 clean_static = ["rm", "-r"] + glob.glob(os.path.join(static_dir, "*"))
231 clean_templates = ["rm", "-r"] + glob.glob(os.path.join(templates_dir, "*"))
234 if len(clean_static) > 2:
235 sp.call(clean_static)
236 if len(clean_static) > 2:
237 sp.call(clean_templates)
239 copy_static = ["cp", "-r"] + glob.glob(os.path.join(pub_dir, "*")) + [static_dir]
240 copy_index = ["cp", os.path.join(pub_dir, "index.html"), templates_dir]
244 index = os.path.join(templates_dir, "index.html")
245 index_data = file(index).read()
246 index_data = index_data.replace('href="', 'href="{{ MEDIA_URL }}pithos_web_client/')
247 index_data = index_data.replace('" src="', '" src="{{ MEDIA_URL }}pithos_web_client/')
248 index_data = index_data.replace('\' src=\'', '\' src=\'{{ MEDIA_URL }}pithos_web_client/')
249 index_data = index_data.replace('url(', 'url({{ MEDIA_URL }}pithos_web_client/')
251 ifile = file(index, "w+")
252 ifile.write(index_data)
256 # do we need to run ant ???
257 if any(x in ''.join(sys.argv) for x in ["sdist", "build", "develop", "install"]):
260 if any(x in ''.join(sys.argv) for x in ["clean"]):
265 name='snf-pithos-web-client',
268 url='http://code.grnet.gr/projects/pithos-web-client',
269 description = SHORT_DESCRIPTION,
270 long_description=README + '\n\n' + CHANGES,
271 classifiers = CLASSIFIERS,
273 author_email='pithos@grnet.gr',
275 packages=find_packages(),
276 include_package_data=True,
277 package_data=find_package_data('.'),
280 install_requires = INSTALL_REQUIRES,
282 dependency_links = ['http://docs.dev.grnet.gr/pypi'],
286 'web_apps = pithos_web_client.synnefo_settings:installed_apps',
287 'urls = pithos_web_client.synnefo_settings:urlpatterns',
288 'web_static = pithos_web_client.synnefo_settings:static_files',
289 'web_context_processors = pithos_web_client.synnefo_settings:context_processors'