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 from pithos_webclient.version import __version__
53 README = open(os.path.join(HERE, 'README')).read()
54 CHANGES = open(os.path.join(HERE, 'Changelog')).read()
55 SHORT_DESCRIPTION = 'Package short description'
58 PACKAGES = find_packages(PACKAGES_ROOT)
62 'Development Status :: 3 - Alpha',
63 'Operating System :: OS Independent',
64 'Programming Language :: Python',
66 'License :: OSI Approved :: BSD License',
69 # Package requirements
82 # Provided as an attribute, so you can append to these instead
83 # of replicating them:
84 standard_exclude = ["*.py", "*.pyc", "*$py.class", "*~", ".*", "*.bak"]
85 standard_exclude_directories = [
86 ".*", "CVS", "_darcs", "./build", "./dist", "EGG-INFO", "*.egg-info", "snf-0.7"
89 # (c) 2005 Ian Bicking and contributors; written for Paste (http://pythonpaste.org)
90 # Licensed under the MIT license: http://www.opensource.org/licenses/mit-license.php
91 # Note: you may want to copy this into your setup.py file verbatim, as
92 # you can't import this from another package, when you don't know if
93 # that package is installed yet.
94 def find_package_data(
97 exclude=standard_exclude,
98 exclude_directories=standard_exclude_directories,
99 only_in_packages=True,
102 Return a dictionary suitable for use in ``package_data``
103 in a distutils ``setup.py`` file.
105 The dictionary looks like::
109 Where ``files`` is a list of all the files in that package that
110 don"t match anything in ``exclude``.
112 If ``only_in_packages`` is true, then top-level directories that
113 are not packages won"t be included (but directories under packages
116 Directories matching any pattern in ``exclude_directories`` will
117 be ignored; by default directories with leading ``.``, ``CVS``,
118 and ``_darcs`` will be ignored.
120 If ``show_ignored`` is true, then all the files that aren"t
121 included in package data are shown on stderr (for debugging
124 Note patterns use wildcards, or can be exact paths (including
125 leading ``./``), and all searching is case-insensitive.
128 stack = [(convert_path(where), "", package, only_in_packages)]
130 where, prefix, package, only_in_packages = stack.pop(0)
131 for name in os.listdir(where):
132 fn = os.path.join(where, name)
133 if os.path.isdir(fn):
135 for pattern in exclude_directories:
136 if (fnmatchcase(name, pattern)
137 or fn.lower() == pattern.lower()):
140 print >> sys.stderr, (
141 "Directory %s ignored by pattern %s"
146 if (os.path.isfile(os.path.join(fn, "__init__.py"))
151 new_package = package + "." + name
152 stack.append((fn, "", new_package, False))
154 stack.append((fn, prefix + name + "/", package, only_in_packages))
155 elif package or not only_in_packages:
158 for pattern in exclude:
159 if (fnmatchcase(name, pattern)
160 or fn.lower() == pattern.lower()):
163 print >> sys.stderr, (
164 "File %s ignored by pattern %s"
169 out.setdefault(package, []).append(prefix+name)
174 Gwt clea/build helpers
176 import subprocess as sp
179 def clean_gwt(root="../", public_dir="bin/www/gr.grnet.pithos.web.Pithos/"):
180 # skip if no build.xml found (debian build process)
181 if not os.path.exists(os.path.join(root, "build.xml")):
186 rcode = sp.call(["ant", "clean"])
188 raise Exception("GWT clean failed")
190 pub_dir = os.path.abspath(os.path.join(root, public_dir))
191 static_dir = os.path.abspath(os.path.join("pithos_webclient", "static", \
193 templates_dir = os.path.abspath(os.path.join("pithos_webclient", \
194 "templates", "pithos_webclient"))
195 clean_static = ["rm", "-r"] + glob.glob(os.path.join(static_dir, "*"))
196 clean_templates = ["rm", "-r"] + glob.glob(os.path.join(templates_dir, "*"))
199 if len(clean_static) > 2:
200 sp.call(clean_static)
201 if len(clean_static) > 2:
202 sp.call(clean_templates)
205 def build_gwt(root="../", public_dir="bin/www/gr.grnet.pithos.web.Pithos/"):
206 # skip if no build.xml found (debian build process)
207 if not os.path.exists(os.path.join(root, "build.xml")):
212 # run ant on root dir
213 rcode = sp.call(["ant"])
215 raise Exception("GWT build failed")
219 pub_dir = os.path.abspath(os.path.join(root, public_dir))
220 static_dir = os.path.abspath(os.path.join("pithos_webclient", "static", \
222 templates_dir = os.path.abspath(os.path.join("pithos_webclient", \
223 "templates", "pithos_webclient"))
225 clean_static = ["rm", "-r"] + glob.glob(os.path.join(static_dir, "*"))
226 clean_templates = ["rm", "-r"] + glob.glob(os.path.join(templates_dir, "*"))
229 if len(clean_static) > 2:
230 sp.call(clean_static)
231 if len(clean_static) > 2:
232 sp.call(clean_templates)
234 copy_static = ["cp", "-r"] + glob.glob(os.path.join(pub_dir, "*")) + [static_dir]
235 copy_index = ["cp", os.path.join(pub_dir, "index.html"), templates_dir]
239 index = os.path.join(templates_dir, "index.html")
240 index_data = file(index).read()
241 index_data = index_data.replace('href="', 'href="{{ MEDIA_URL }}pithos_webclient/')
242 index_data = index_data.replace('" src="', '" src="{{ MEDIA_URL }}pithos_webclient/')
243 index_data = index_data.replace('\' src=\'', '\' src=\'{{ MEDIA_URL }}pithos_webclient/')
244 index_data = index_data.replace('url(', 'url({{ MEDIA_URL }}pithos_webclient/')
246 index_data = index_data.replace("{{ CLOUDBAR_CODE }}", """
249 var CLOUDBAR_ACTIVE_SERVICE = "{{ PITHOS_UI_CLOUDBAR_ACTIVE_SERVICE }}"
253 index_data = index_data.replace("{{ EXTEND_OTHER_PROPERTIES }}", """
254 {% for key, value in branding_settings.items %}
255 otherProperties.{{ key }} = "{{ value }}";
259 ifile = file(index, "w+")
260 ifile.write(index_data)
264 # do we need to run ant ???
265 if any(x in ''.join(sys.argv) for x in ["sdist", "build", "develop", "install"]):
268 if any(x in ''.join(sys.argv) for x in ["clean"]):
273 name='snf-pithos-webclient',
276 url='http://code.grnet.gr/projects/pithos-web-client',
277 description = SHORT_DESCRIPTION,
278 long_description=README + '\n\n' + CHANGES,
279 classifiers = CLASSIFIERS,
281 author_email='pithos@grnet.gr',
283 packages=find_packages(),
284 include_package_data=True,
285 package_data=find_package_data('.'),
288 install_requires = INSTALL_REQUIRES,
290 dependency_links = ['http://docs.dev.grnet.gr/pypi'],
294 'web_apps = pithos_webclient.synnefo_settings:installed_apps',
295 'urls = pithos_webclient.synnefo_settings:urlpatterns',
296 'web_static = pithos_webclient.synnefo_settings:static_files',
297 'web_context_processors = pithos_webclient.synnefo_settings:context_processors'