Statistics
| Branch: | Tag: | Revision:

root / snf-pithos-webclient / setup.py @ 6157de5b

History | View | Annotate | Download (10 kB)

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
import distribute_setup
37
distribute_setup.use_setuptools()
38

    
39
import os
40
import sys
41

    
42
from fnmatch import fnmatchcase
43
from distutils.util import convert_path
44

    
45
from setuptools import setup, find_packages
46

    
47

    
48
HERE = os.path.abspath(os.path.normpath(os.path.dirname(__file__)))
49

    
50
from pithos_webclient.version import __version__
51

    
52
# Package info
53
VERSION = __version__
54
README = open(os.path.join(HERE, 'README')).read()
55
CHANGES = open(os.path.join(HERE, 'Changelog')).read()
56
SHORT_DESCRIPTION = 'Package short description'
57

    
58
PACKAGES_ROOT = '.'
59
PACKAGES = find_packages(PACKAGES_ROOT)
60

    
61
# Package meta
62
CLASSIFIERS = [
63
    'Development Status :: 3 - Alpha',
64
    'Operating System :: OS Independent',
65
    'Programming Language :: Python',
66
    'Topic :: Utilities',
67
    'License :: OSI Approved :: BSD License',
68
]
69

    
70
# Package requirements
71
INSTALL_REQUIRES = [
72
    'Django>=1.2, <1.3',
73
    'snf-branding',
74
    'snf-common>=0.9.0rc'
75
]
76

    
77
EXTRAS_REQUIRES = {
78
}
79

    
80
TESTS_REQUIRES = [
81
]
82

    
83
# Provided as an attribute, so you can append to these instead
84
# of replicating them:
85
standard_exclude = ["*.py", "*.pyc", "*$py.class", "*~", ".*", "*.bak"]
86
standard_exclude_directories = [
87
    ".*", "CVS", "_darcs", "./build", "./dist", "EGG-INFO", "*.egg-info",
88
    "snf-0.7"
89
]
90

    
91

    
92
# (c) 2005 Ian Bicking and contributors; written for Paste
93
# (http://pythonpaste.org) Licensed under the MIT license:
94
# http://www.opensource.org/licenses/mit-license.php Note: you may want to
95
# copy this into your setup.py file verbatim, as you can't import this from
96
# another package, when you don't know if that package is installed yet.
97
def find_package_data(
98
    where=".",
99
    package="",
100
    exclude=standard_exclude,
101
    exclude_directories=standard_exclude_directories,
102
    only_in_packages=True,
103
    show_ignored=False
104
):
105
    """
106
    Return a dictionary suitable for use in ``package_data``
107
    in a distutils ``setup.py`` file.
108

109
    The dictionary looks like::
110

111
        {"package": [files]}
112

113
    Where ``files`` is a list of all the files in that package that
114
    don"t match anything in ``exclude``.
115

116
    If ``only_in_packages`` is true, then top-level directories that
117
    are not packages won"t be included (but directories under packages
118
    will).
119

120
    Directories matching any pattern in ``exclude_directories`` will
121
    be ignored; by default directories with leading ``.``, ``CVS``,
122
    and ``_darcs`` will be ignored.
123

124
    If ``show_ignored`` is true, then all the files that aren"t
125
    included in package data are shown on stderr (for debugging
126
    purposes).
127

128
    Note patterns use wildcards, or can be exact paths (including
129
    leading ``./``), and all searching is case-insensitive.
130
    """
131
    out = {}
132
    stack = [(convert_path(where), "", package, only_in_packages)]
133
    while stack:
134
        where, prefix, package, only_in_packages = stack.pop(0)
135
        for name in os.listdir(where):
136
            fn = os.path.join(where, name)
137
            if os.path.isdir(fn):
138
                bad_name = False
139
                for pattern in exclude_directories:
140
                    if (fnmatchcase(name, pattern)
141
                            or fn.lower() == pattern.lower()):
142
                        bad_name = True
143
                        if show_ignored:
144
                            print >> sys.stderr, (
145
                                "Directory %s ignored by pattern %s"
146
                                % (fn, pattern))
147
                        break
148
                if bad_name:
149
                    continue
150
                if (os.path.isfile(os.path.join(fn, "__init__.py"))
151
                        and not prefix):
152
                    if not package:
153
                        new_package = name
154
                    else:
155
                        new_package = package + "." + name
156
                    stack.append((fn, "", new_package, False))
157
                else:
158
                    stack.append((fn, prefix + name + "/", package,
159
                                  only_in_packages))
160
            elif package or not only_in_packages:
161
                # is a file
162
                bad_name = False
163
                for pattern in exclude:
164
                    if (fnmatchcase(name, pattern) or
165
                            fn.lower() == pattern.lower()):
166
                        bad_name = True
167
                        if show_ignored:
168
                            print >> sys.stderr, (
169
                                "File %s ignored by pattern %s"
170
                                % (fn, pattern))
171
                        break
172
                if bad_name:
173
                    continue
174
                out.setdefault(package, []).append(prefix + name)
175
    return out
176

    
177

    
178
"""
179
Gwt clea/build helpers
180
"""
181
import subprocess as sp
182
import glob
183

    
184

    
185
def clean_gwt(root="../", public_dir="bin/www/gr.grnet.pithos.web.Pithos/"):
186
    # skip if no build.xml found (debian build process)
187
    if not os.path.exists(os.path.join(root, "build.xml")):
188
        return
189

    
190
    curdir = os.getcwd()
191
    os.chdir(root)
192
    rcode = sp.call(["ant", "clean"])
193
    if rcode == 1:
194
        raise Exception("GWT clean failed")
195
    os.chdir(curdir)
196
    #pub_dir = os.path.abspath(os.path.join(root, public_dir))
197
    static_dir = os.path.abspath(os.path.join("pithos_webclient", "static",
198
                                              "pithos_webclient"))
199
    #templates_dir = os.path.abspath(os.path.join("pithos_webclient",
200
                                                 #"templates",
201
                                                 #"pithos_webclient"))
202
    clean_static = ["rm", "-r"] + glob.glob(os.path.join(static_dir, "*"))
203

    
204
    # clean dirs
205
    if len(clean_static) > 2:
206
        sp.call(clean_static)
207

    
208

    
209
def build_gwt(root="../", public_dir="bin/www/gr.grnet.pithos.web.Pithos/"):
210
    # skip if no build.xml found (debian build process)
211
    if not os.path.exists(os.path.join(root, "build.xml")):
212
        return
213

    
214
    curdir = os.getcwd()
215
    os.chdir(root)
216
    # run ant on root dir
217
    rcode = sp.call(["ant"])
218
    if rcode == 1:
219
        raise Exception("GWT build failed")
220
    os.chdir(curdir)
221

    
222
    pub_dir = os.path.abspath(os.path.join(root, public_dir))
223
    static_dir = os.path.abspath(os.path.join("pithos_webclient", "static",
224
                                              "pithos_webclient"))
225
    templates_dir = os.path.abspath(os.path.join("pithos_webclient",
226
                                                 "templates",
227
                                                 "pithos_webclient"))
228

    
229
    clean_static = ["rm", "-r"] + glob.glob(os.path.join(static_dir, "*"))
230

    
231
    # clean dirs
232
    if len(clean_static) > 2:
233
        sp.call(clean_static)
234

    
235
    copy_static = ["cp", "-r"] + glob.glob(os.path.join(pub_dir, "*")) + \
236
                  [static_dir]
237
    copy_index = ["cp", os.path.join(pub_dir, "index.html"), templates_dir]
238
    sp.call(copy_static)
239
    sp.call(copy_index)
240

    
241
    index = os.path.join(templates_dir, "index.html")
242
    index_data = file(index).read()
243
    # fix locations of static files
244
    index_data = index_data.replace('href="',
245
                                    'href="{{ MEDIA_URL }}pithos_webclient/')
246
    index_data = index_data.replace('" src="',
247
                                    '" src="{{ MEDIA_URL }}pithos_webclient/')
248
    index_data = index_data.replace(
249
        '\' src=\'',
250
        '\' src=\'{{ MEDIA_URL }}pithos_webclient/')
251
    index_data = index_data.replace('url(',
252
                                    'url({{ MEDIA_URL }}pithos_webclient/')
253

    
254
    ifile = file(index, "w+")
255
    ifile.write(index_data)
256
    ifile.close()
257

    
258

    
259
# do we need to run ant ???
260
if any(x in ''.join(sys.argv) for x in ["sdist", "build", "develop",
261
                                        "install"]):
262
    build_gwt()
263

    
264
if any(x in ''.join(sys.argv) for x in ["clean"]):
265
    clean_gwt()
266

    
267

    
268
setup(
269
    name='snf-pithos-webclient',
270
    version=VERSION,
271
    license='BSD',
272
    url='http://code.grnet.gr/projects/pithos-web-client',
273
    description=SHORT_DESCRIPTION,
274
    long_description=README + '\n\n' + CHANGES,
275
    classifiers=CLASSIFIERS,
276
    author='GRNET',
277
    author_email='pithos@grnet.gr',
278

    
279
    packages=find_packages(),
280
    include_package_data=True,
281
    package_data=find_package_data('.'),
282
    zip_safe=False,
283

    
284
    install_requires=INSTALL_REQUIRES,
285

    
286
    dependency_links=['http://docs.dev.grnet.gr/pypi'],
287

    
288
    entry_points={
289
        'synnefo': [
290
            'web_apps = pithos_webclient.synnefo_settings:installed_apps',
291
            'urls = pithos_webclient.synnefo_settings:urlpatterns',
292
            'web_static = pithos_webclient.synnefo_settings:static_files',
293
            'web_context_processors = '
294
            'pithos_webclient.synnefo_settings:context_processors'
295
        ]
296
    }
297
)