From 5e1140a68bedc0704bab3df5eea687f45819e833 Mon Sep 17 00:00:00 2001 From: Ask Solem Date: Mon, 26 Sep 2011 21:02:11 +0100 Subject: [PATCH] Improves version bumper --- contrib/release/bump_version.py | 27 ++++++++++++++------------- pavement.py | 2 +- 2 files changed, 15 insertions(+), 14 deletions(-) mode change 100755 => 100644 contrib/release/bump_version.py diff --git a/contrib/release/bump_version.py b/contrib/release/bump_version.py old mode 100755 new mode 100644 index e49225c2..ebad4d3e --- a/contrib/release/bump_version.py +++ b/contrib/release/bump_version.py @@ -111,15 +111,21 @@ class SphinxVersion(VersionFile): self.filename = filename -def bump(dist, docfile="README.rst", custom=None): - distfile = os.path.join(dist, "__init__.py") - files = [PyVersion(distfile), SphinxVersion(docfile)] +_filetype_to_type = {"py": PyVersion, "rst": SphinxVersion} +def filetype_to_type(filename): + _, _, suffix = filename.rpartition(".") + return _filetype_to_type[suffix](filename) + + +def bump(*files, **kwargs): + version = kwargs.get("version") + files = [filetype_to_type(f) for f in files] versions = [v.parse() for v in files] current = list(reversed(sorted(versions)))[0] # find highest - if custom: - next = from_str(custom) + if version: + next = from_str(version) else: major, minor, release, text = current if text: @@ -137,20 +143,15 @@ def bump(dist, docfile="README.rst", custom=None): print(cmd("git", "tag", "v%s" % (to_str(next), ))) -def main(argv=sys.argv, docfile="README.rst", custom=None): +def main(argv=sys.argv, version=None): if not len(argv) > 1: print("Usage: distdir [docfile] -- ") sys.exit(0) - dist = argv[1] if "--" in argv: c = argv.index('--') - custom = argv[c + 1] + version = argv[c + 1] argv = argv[:c] - try: - docfile = argv[2] - except IndexError: - pass - bump(dist, docfile, custom) + bump(*argv, version=version) if __name__ == "__main__": main() diff --git a/pavement.py b/pavement.py index be5808e6..31e9532e 100644 --- a/pavement.py +++ b/pavement.py @@ -83,7 +83,7 @@ def readme(options): @task def bump(options): - sh("contrib/release/bump_version.py kombu") + sh("contrib/release/bump_version.py kombu/__init__.py README.rst") @task