Implement commit functionality

This commit is contained in:
Andrew Cassidy 2021-04-23 23:57:53 -07:00
parent a82e455267
commit 74b6448ee1
4 changed files with 61 additions and 30 deletions

View File

@ -12,6 +12,7 @@ All notable changes to this project will be documented in this file
- `show` command to show changes from the changelog
- `entry` command for manipulating entries in the changelog
- `tag` command for manipulating tags in the changelog
- `release` command for creating releases
## 0.2.0 - 2021-04-19

View File

@ -264,19 +264,18 @@ class Changelog:
v_links = {}
v_links.update(self.links)
with open(path, 'w') as fp:
fp.write(self.header)
fp.write('\n\n')
segments = [self.header]
for version in self.versions:
if version.link:
v_links[version.name] = version.link
fp.write(version.text())
fp.write('\n')
if version != self.versions[-1] or len(v_links) > 0:
fp.write('\n')
segments.append(version.text())
for link_id, link in v_links.items():
fp.write(f'[{link_id.lower()}]: {link}\n')
segments.append(f'[{link_id.lower()}]: {link}')
text = _join_markdown(segments)
with open(path, 'w') as fp:
fp.write(text)

View File

@ -17,6 +17,7 @@
import click
import os.path
import datetime
import git
import yaclog.cli.version_util
from yaclog import Changelog
@ -167,19 +168,22 @@ def entry(obj: Changelog, bullets, paragraphs, section_name, version_name):
@cli.command()
@click.option('-v', '--version', 'v_flag', type=str, help='The full version string to release.')
@click.option('-v', '--version', 'v_flag', type=str, default=None, help='The new version number to use.')
@click.option('-M', '--major', 'v_flag', flag_value='+M', help='Increment major version number.')
@click.option('-m', '--minor', 'v_flag', flag_value='+m', help='Increment minor version number.')
@click.option('-p', '--patch', 'v_flag', flag_value='+p', help='Increment patch number.')
@click.option('-a', '--alpha', 'v_flag', flag_value='+a', help='Increment alpha version number.')
@click.option('-b', '--beta', 'v_flag', flag_value='+b', help='Increment beta version number.')
@click.option('-r', '--rc', 'v_flag', flag_value='+rc', help='Increment release candidate version number.')
@click.option('-c', '--commit', help='Create a git commit tagged with the new version number.')
@click.option('-c', '--commit', is_flag=True, help='Create a git commit tagged with the new version number.')
@click.pass_obj
def release(obj: Changelog, v_flag, commit):
"""Release versions in the changelog and increment their version numbers"""
version = [v for v in obj.versions if v.name.lower() != 'unreleased'][0]
cur_version = obj.versions[0]
old_name = cur_version.name
if v_flag:
if v_flag[0] == '+':
new_name = yaclog.cli.version_util.increment_version(version.name, v_flag)
else:
@ -188,9 +192,34 @@ def release(obj: Changelog, v_flag, commit):
if yaclog.cli.version_util.is_release(cur_version.name):
click.confirm(f'Rename release version "{cur_version.name}" to "{new_name}"?', abort=True)
cur_version.name = new_name
cur_version.date = datetime.datetime.utcnow().date()
obj.write()
print(f'Renamed version "{old_name}" to "{cur_version.name}".')
if commit:
repo = git.Repo(os.curdir)
if repo.bare:
raise click.BadOptionUsage('commit', f'Directory {os.path.abspath(os.curdir)} is not a git repo.')
version_type = '' if yaclog.cli.version_util.is_release(cur_version.name) else 'non-release '
untracked = len(repo.index.diff(None))
untracked_warning = ''
if untracked > 0:
untracked_warning = click.style(f' You have {untracked} untracked files that will not be committed.',
fg='red', bold=True)
click.confirm(f'Commit and create tag for {version_type}version {cur_version.name}?{untracked_warning}',
abort=True)
repo.index.add(obj.path)
repo.index.commit(f'Version {cur_version.name}\n\n{cur_version.body()}')
repo.create_tag(cur_version.name, message=cur_version.body(False))
print(f'Created tag "{cur_version.name}".')
if __name__ == '__main__':

View File

@ -14,17 +14,19 @@
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
from packaging.version import Version, parse
from packaging.version import Version, InvalidVersion
def is_release(version: str) -> bool:
v = parse(version)
try:
v = Version(version)
return not (v.is_devrelease or v.is_prerelease)
except InvalidVersion:
return False
def increment_version(version: str, mode: str) -> str:
v = parse(version)
v = Version(version)
epoch = v.epoch
release = v.release
pre = v.pre