mirror of
https://github.com/Garmelon/PFERD.git
synced 2023-12-21 10:23:01 +01:00
Add script for releasing new versions
This commit is contained in:
parent
85f89a7ff3
commit
c33de233dc
@ -5,7 +5,7 @@ All notable changes to this project will be documented in this file.
|
||||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
||||
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||
|
||||
## [Unreleased]
|
||||
## Unreleased
|
||||
|
||||
### Added
|
||||
- Support for concurrent downloads
|
||||
|
4
DEV.md
4
DEV.md
@ -56,6 +56,10 @@ In your first PR, please add your name to the `LICENSE` file.
|
||||
|
||||
## Releasing a new version
|
||||
|
||||
This section describes the steps required to release a new version of PFERD.
|
||||
Usually, they don't need to performed manually and `scripts/bump-version` can be
|
||||
used instead.
|
||||
|
||||
1. Update the version number in `PFERD/version.py`
|
||||
2. Update `CHANGELOG.md`
|
||||
3. Commit changes to `master` with message `Bump version to <version>` (e. g. `Bump version to 3.2.5`)
|
||||
|
111
scripts/bump-version
Executable file
111
scripts/bump-version
Executable file
@ -0,0 +1,111 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
import argparse
|
||||
import time
|
||||
import re
|
||||
from subprocess import run
|
||||
|
||||
|
||||
def load_changelog():
|
||||
with open("CHANGELOG.md") as f:
|
||||
return list(f)
|
||||
|
||||
|
||||
def extract_changes(lines):
|
||||
lines = iter(lines)
|
||||
changes = []
|
||||
|
||||
# Find "Unreleased" section
|
||||
for line in lines:
|
||||
if line.strip() == "## Unreleased":
|
||||
break
|
||||
next(lines)
|
||||
|
||||
# Read all lines from that section
|
||||
for line in lines:
|
||||
if line.startswith("## "):
|
||||
# Found the beginning of the next section
|
||||
break
|
||||
elif line.startswith("### "):
|
||||
# Found a heading in the current section
|
||||
# Remove "#" symbols so git doesn't interpret the line as a comment later
|
||||
changes.append(line[4:])
|
||||
else:
|
||||
changes.append(line)
|
||||
|
||||
# Remove trailing empty lines
|
||||
while changes and not changes[-1].strip():
|
||||
changes.pop()
|
||||
|
||||
return changes
|
||||
|
||||
|
||||
def update_version(version):
|
||||
with open("PFERD/version.py") as f:
|
||||
text = f.read()
|
||||
|
||||
text = re.sub(r'VERSION = ".*"', f'VERSION = "{version}"', text)
|
||||
|
||||
with open("PFERD/version.py", "w") as f:
|
||||
f.write(text)
|
||||
|
||||
|
||||
def update_changelog(lines, version, date):
|
||||
lines = iter(lines)
|
||||
new_lines = []
|
||||
|
||||
# Find "Unreleased" section
|
||||
for line in lines:
|
||||
new_lines.append(line)
|
||||
if line.strip() == "## Unreleased":
|
||||
break
|
||||
|
||||
# Add new heading below that
|
||||
new_lines.append("\n")
|
||||
new_lines.append(f"## {version} - {date}\n")
|
||||
|
||||
# Add remaining lines
|
||||
for line in lines:
|
||||
new_lines.append(line)
|
||||
|
||||
with open("CHANGELOG.md", "w") as f:
|
||||
f.write("".join(new_lines))
|
||||
|
||||
|
||||
def commit_changes(version):
|
||||
run(["git", "add", "CHANGELOG.md", "PFERD/version.py"])
|
||||
run(["git", "commit", "-m", f"Bump version to {version}"])
|
||||
|
||||
|
||||
def create_tag(version, annotation):
|
||||
run(["git", "tag", "-am", annotation, f"v{version}"])
|
||||
|
||||
|
||||
def fastforward_latest():
|
||||
run(["git", "branch", "-f", "latest", "HEAD"])
|
||||
|
||||
|
||||
def main():
|
||||
parser = argparse.ArgumentParser()
|
||||
parser.add_argument("version")
|
||||
args = parser.parse_args()
|
||||
|
||||
version = args.version
|
||||
date = time.strftime("%Y-%m-%d")
|
||||
changelog = load_changelog()
|
||||
changes = extract_changes(changelog)
|
||||
annotation = f"Version {version} - {date}\n\n{''.join(changes)}"
|
||||
|
||||
update_version(version)
|
||||
update_changelog(changelog, version, date)
|
||||
commit_changes(version)
|
||||
create_tag(version, annotation)
|
||||
fastforward_latest()
|
||||
|
||||
print()
|
||||
print("Now the only thing left is to publish the changes:")
|
||||
print(f" $ git push origin master latest v{version}")
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
Loading…
Reference in New Issue
Block a user