chrono/setup.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

184 lines
5.6 KiB
Python
Raw Permalink Normal View History

2016-02-13 09:56:55 +01:00
#! /usr/bin/env python
import glob
import os
import re
import subprocess
import sys
from distutils.cmd import Command
from distutils.command.build import build as _build
from distutils.command.sdist import sdist
from distutils.errors import CompileError
from distutils.spawn import find_executable
2021-04-08 11:25:34 +02:00
2016-02-13 09:56:55 +01:00
from setuptools import find_packages, setup
from setuptools.command.install_lib import install_lib as _install_lib
2016-02-13 09:56:55 +01:00
class eo_sdist(sdist):
def run(self):
if os.path.exists('VERSION'):
os.remove('VERSION')
version = get_version()
version_file = open('VERSION', 'w')
version_file.write(version)
version_file.close()
sdist.run(self)
if os.path.exists('VERSION'):
os.remove('VERSION')
2016-02-13 09:56:55 +01:00
def get_version():
"""Use the VERSION, if absent generates a version with git describe, if not
tag exists, take 0.0- and add the length of the commit log.
2020-12-29 10:42:33 +01:00
"""
2016-02-13 09:56:55 +01:00
if os.path.exists('VERSION'):
with open('VERSION') as v:
return v.read()
2016-02-13 09:56:55 +01:00
if os.path.exists('.git'):
p = subprocess.Popen(
['git', 'describe', '--dirty=.dirty', '--match=v*'],
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
)
2016-02-13 09:56:55 +01:00
result = p.communicate()[0]
if p.returncode == 0:
result = result.decode('ascii').strip()[1:] # strip spaces/newlines and initial v
if '-' in result: # not a tagged version
real_number, commit_count, commit_hash = result.split('-', 2)
version = '%s.post%s+%s' % (real_number, commit_count, commit_hash)
else:
version = result.replace('.dirty', '+dirty')
2016-02-13 09:56:55 +01:00
return version
else:
return '0.0.post%s' % len(subprocess.check_output(['git', 'rev-list', 'HEAD']).splitlines())
return '0.0'
2016-02-13 09:56:55 +01:00
2016-02-13 09:56:55 +01:00
def data_tree(destdir, sourcedir):
extensions = ['.css', '.png', '.jpeg', '.jpg', '.gif', '.xml', '.html', '.js']
r = []
for root, dirs, files in os.walk(sourcedir):
l = [os.path.join(root, x) for x in files if os.path.splitext(x)[1] in extensions]
r.append((root.replace(sourcedir, destdir, 1), l))
return r
2016-02-13 09:56:55 +01:00
class compile_translations(Command):
description = 'compile message catalogs to MO files via django compilemessages'
user_options = []
def initialize_options(self):
pass
def finalize_options(self):
pass
def run(self):
curdir = os.getcwd()
2016-02-13 09:56:55 +01:00
try:
from django.core.management import call_command
2016-02-13 09:56:55 +01:00
for path, dirs, files in os.walk('chrono'):
if 'locale' not in dirs:
continue
os.chdir(os.path.realpath(path))
call_command('compilemessages')
except ImportError:
sys.stderr.write('!!! Please install Django >= 1.4 to build translations\n')
finally:
os.chdir(curdir)
2016-02-13 09:56:55 +01:00
class compile_scss(Command):
description = 'compile scss files into css files'
user_options = []
def initialize_options(self):
pass
def finalize_options(self):
pass
def run(self):
sass_bin = None
for program in ('sassc', 'sass'):
sass_bin = find_executable(program)
if sass_bin:
break
if not sass_bin:
raise CompileError(
'A sass compiler is required but none was found. See sass-lang.com for choices.'
)
for package in self.distribution.packages:
for package_path in __import__(package).__path__:
for path, dirnames, filenames in os.walk(package_path):
for filename in filenames:
if not filename.endswith('.scss'):
continue
if filename.startswith('_'):
continue
subprocess.check_call(
[
sass_bin,
'%s/%s' % (path, filename),
'%s/%s' % (path, filename.replace('.scss', '.css')),
]
)
2016-02-13 09:56:55 +01:00
class build(_build):
sub_commands = [('compile_translations', None), ('compile_scss', None)] + _build.sub_commands
2016-02-13 09:56:55 +01:00
class install_lib(_install_lib):
def run(self):
self.run_command('compile_translations')
_install_lib.run(self)
setup(
name='chrono',
version=get_version(),
description='Agendas System',
author='Frederic Peters',
author_email='fpeters@entrouvert.com',
packages=find_packages(),
include_package_data=True,
scripts=('manage.py',),
url='https://dev.entrouvert.org/projects/chrono/',
classifiers=[
'Development Status :: 4 - Beta',
2016-02-13 09:56:55 +01:00
'Environment :: Web Environment',
'Framework :: Django',
'Intended Audience :: Developers',
'License :: OSI Approved :: GNU Affero General Public License v3 or later (AGPLv3+)',
'Operating System :: OS Independent',
'Programming Language :: Python',
'Programming Language :: Python :: 3',
2016-02-13 09:56:55 +01:00
],
install_requires=[
2023-03-15 14:13:30 +01:00
'django>=3.2, <3.3',
2016-02-13 09:56:55 +01:00
'gadjo',
'djangorestframework>=3.4,<3.15',
'django-filter<23.2',
'vobject',
'python-dateutil',
'pyquery',
'requests',
'workalendar',
'weasyprint',
2024-01-29 14:52:38 +01:00
'sorl-thumbnail',
2024-03-07 16:42:55 +01:00
'lxml',
2016-02-13 09:56:55 +01:00
],
zip_safe=False,
cmdclass={
'build': build,
'compile_scss': compile_scss,
2016-02-13 09:56:55 +01:00
'compile_translations': compile_translations,
'install_lib': install_lib,
'sdist': eo_sdist,
},
)