setup.py: use get_version

This commit is contained in:
Benjamin Dauvergne 2013-05-13 16:40:25 +02:00
parent 8ae613f0ca
commit 88d7555bc8
2 changed files with 34 additions and 1 deletions

View File

@ -1,6 +1,8 @@
import os.path
import sys
__version__ = '0.1'
apps_dir = os.path.join(os.path.dirname(__file__), 'apps')
if apps_dir not in sys.path:
sys.path.append(apps_dir)

View File

@ -44,8 +44,39 @@ class install_lib(_install_lib):
self.run_command('compile_translations')
_install_lib.run(self)
def get_version():
import glob
import re
import os
version = None
for d in glob.glob('*'):
if not os.path.isdir(d):
continue
module_file = os.path.join(d, '__init__.py')
if not os.path.exists(module_file):
continue
for v in re.findall("""__version__ *= *['"](.*)['"]""",
open(module_file).read()):
assert version is None
version = v
if version:
break
assert version is not None
if os.path.exists('.git'):
import subprocess
p = subprocess.Popen(['git','describe'],
stdout=subprocess.PIPE)
result = p.communicate()[0]
assert p.returncode == 0, 'git returned non-zero'
new_version = result.split()[0]
assert new_version.split('-')[0] == version, '__version__ must match the last git annotated tag'
version = new_version.replace('-', '.')
return version
setup(name="portail_citoyen",
version=0.1,
version=get_version(),
license="AGPLv3 or later",
description="Portail citoyen",
url="http://dev.entrouvert.org/projects/portail-citoyen/",