summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAarni Koskela <akx@iki.fi>2022-06-16 08:33:00 +0300
committerAarni Koskela <akx@iki.fi>2022-06-16 08:49:30 +0300
commit6c7a772e1a24b0e023c170fe25134357fe4fe9fa (patch)
tree0e2e776bd754b2508615a55aadc7813021ebe252
parent0ab05bc61a8f2064b0ae2a57656b258e641ed192 (diff)
downloadbabel-6c7a772e1a24b0e023c170fe25134357fe4fe9fa.tar.gz
Delete legacy release scripts
-rw-r--r--Makefile5
-rwxr-xr-xscripts/make-release.py155
-rw-r--r--setup.cfg3
3 files changed, 1 insertions, 162 deletions
diff --git a/Makefile b/Makefile
index 8db9891..114f0c7 100644
--- a/Makefile
+++ b/Makefile
@@ -31,7 +31,4 @@ develop:
tox-test: import-cldr
tox
-release: import-cldr
- python scripts/make-release.py
-
-.PHONY: test develop tox-test clean-pyc clean-cldr import-cldr clean release clean-test-env standalone-test
+.PHONY: test develop tox-test clean-pyc clean-cldr import-cldr clean clean-test-env standalone-test
diff --git a/scripts/make-release.py b/scripts/make-release.py
deleted file mode 100755
index d8963f2..0000000
--- a/scripts/make-release.py
+++ /dev/null
@@ -1,155 +0,0 @@
-#!/usr/bin/env python
-"""
- make-release
- ~~~~~~~~~~~~
-
- Helper script that performs a release. Does pretty much everything
- automatically for us.
-
- :copyright: (c) 2013 by Armin Ronacher.
- :license: BSD, see LICENSE for more details.
-"""
-import sys
-import os
-import re
-from datetime import datetime, date
-from subprocess import Popen, PIPE
-
-_date_clean_re = re.compile(r'(\d+)(st|nd|rd|th)')
-
-
-def parse_changelog():
- with open('CHANGES.rst') as f:
- lineiter = iter(f)
- for line in lineiter:
- match = re.search(r'^Version\s+(.*)', line.strip())
- if match is None:
- continue
- version = match.group(1).strip()
- if lineiter.next().count('-') != len(match.group(0)):
- continue
- while 1:
- change_info = lineiter.next().strip()
- if change_info:
- break
-
- match = re.search(r'released on (\w+\s+\d+\w+\s+\d+)'
- r'(?:, codename (.*))?', change_info,
- flags=re.IGNORECASE)
- if match is None:
- continue
-
- datestr, codename = match.groups()
- return version, parse_date(datestr), codename
-
-
-def bump_version(version):
- try:
- parts = map(int, version.split('.'))
- except ValueError:
- fail('Current version is not numeric')
- if parts[-1] != 0:
- parts[-1] += 1
- else:
- parts[0] += 1
- return '.'.join(map(str, parts))
-
-
-def parse_date(string):
- string = _date_clean_re.sub(r'\1', string)
- return datetime.strptime(string, '%B %d %Y')
-
-
-def set_filename_version(filename, version_number, pattern):
- changed = []
-
- def inject_version(match):
- before, old, after = match.groups()
- changed.append(True)
- return before + version_number + after
- with open(filename) as f:
- contents = re.sub(r"^(\s*%s\s*=\s*')(.+?)(')" % pattern,
- inject_version, f.read(),
- flags=re.DOTALL | re.MULTILINE)
-
- if not changed:
- fail('Could not find %s in %s', pattern, filename)
-
- with open(filename, 'w') as f:
- f.write(contents)
-
-
-def set_init_version(version):
- info('Setting __init__.py version to %s', version)
- set_filename_version('babel/__init__.py', version, '__version__')
-
-
-def set_setup_version(version):
- info('Setting setup.py version to %s', version)
- set_filename_version('setup.py', version, 'version')
-
-
-def build_and_upload():
- Popen([sys.executable, 'setup.py', 'release', 'sdist', 'upload']).wait()
-
-
-def fail(message, *args):
- print >> sys.stderr, 'Error:', message % args
- sys.exit(1)
-
-
-def info(message, *args):
- print >> sys.stderr, message % args
-
-
-def get_git_tags():
- return set(Popen(['git', 'tag'], stdout=PIPE).communicate()[0].splitlines())
-
-
-def git_is_clean():
- return Popen(['git', 'diff', '--quiet']).wait() == 0
-
-
-def make_git_commit(message, *args):
- message = message % args
- Popen(['git', 'commit', '-am', message]).wait()
-
-
-def make_git_tag(tag):
- info('Tagging "%s"', tag)
- Popen(['git', 'tag', tag]).wait()
-
-
-def main():
- os.chdir(os.path.join(os.path.dirname(__file__), '..'))
-
- rv = parse_changelog()
- if rv is None:
- fail('Could not parse changelog')
-
- version, release_date, codename = rv
- dev_version = bump_version(version) + '-dev'
-
- info('Releasing %s (codename %s, release date %s)',
- version, codename, release_date.strftime('%d/%m/%Y'))
- tags = get_git_tags()
-
- if version in tags:
- fail('Version "%s" is already tagged', version)
- if release_date.date() != date.today():
- fail('Release date is not today (%s != %s)')
-
- if not git_is_clean():
- fail('You have uncommitted changes in git')
-
- set_init_version(version)
- set_setup_version(version)
- make_git_commit('Bump version number to %s', version)
- make_git_tag(version)
- build_and_upload()
- set_init_version(dev_version)
- set_setup_version(dev_version)
-
-
-if __name__ == '__main__':
- main()
diff --git a/setup.cfg b/setup.cfg
index aed9471..ac49ca5 100644
--- a/setup.cfg
+++ b/setup.cfg
@@ -1,6 +1,3 @@
-[aliases]
-release = sdist bdist_wheel
-
[tool:pytest]
norecursedirs = venv* .* _* scripts {args}
doctest_optionflags = ELLIPSIS NORMALIZE_WHITESPACE ALLOW_UNICODE IGNORE_EXCEPTION_DETAIL