mirror of
https://github.com/drewcassidy/yaclog.git
synced 2024-09-01 14:58:58 +00:00
Implement commit functionality
This commit is contained in:
parent
a82e455267
commit
74b6448ee1
@ -12,6 +12,7 @@ All notable changes to this project will be documented in this file
|
|||||||
- `show` command to show changes from the changelog
|
- `show` command to show changes from the changelog
|
||||||
- `entry` command for manipulating entries in the changelog
|
- `entry` command for manipulating entries in the changelog
|
||||||
- `tag` command for manipulating tags in the changelog
|
- `tag` command for manipulating tags in the changelog
|
||||||
|
- `release` command for creating releases
|
||||||
|
|
||||||
## 0.2.0 - 2021-04-19
|
## 0.2.0 - 2021-04-19
|
||||||
|
|
||||||
|
@ -264,19 +264,18 @@ class Changelog:
|
|||||||
v_links = {}
|
v_links = {}
|
||||||
v_links.update(self.links)
|
v_links.update(self.links)
|
||||||
|
|
||||||
with open(path, 'w') as fp:
|
segments = [self.header]
|
||||||
fp.write(self.header)
|
|
||||||
fp.write('\n\n')
|
|
||||||
|
|
||||||
for version in self.versions:
|
for version in self.versions:
|
||||||
if version.link:
|
if version.link:
|
||||||
v_links[version.name] = version.link
|
v_links[version.name] = version.link
|
||||||
|
|
||||||
fp.write(version.text())
|
segments.append(version.text())
|
||||||
fp.write('\n')
|
|
||||||
|
|
||||||
if version != self.versions[-1] or len(v_links) > 0:
|
|
||||||
fp.write('\n')
|
|
||||||
|
|
||||||
for link_id, link in v_links.items():
|
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)
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
import click
|
import click
|
||||||
import os.path
|
import os.path
|
||||||
import datetime
|
import datetime
|
||||||
|
import git
|
||||||
import yaclog.cli.version_util
|
import yaclog.cli.version_util
|
||||||
from yaclog import Changelog
|
from yaclog import Changelog
|
||||||
|
|
||||||
@ -167,19 +168,22 @@ def entry(obj: Changelog, bullets, paragraphs, section_name, version_name):
|
|||||||
|
|
||||||
|
|
||||||
@cli.command()
|
@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', '--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('-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('-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('-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('-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('-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
|
@click.pass_obj
|
||||||
def release(obj: Changelog, v_flag, commit):
|
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]
|
version = [v for v in obj.versions if v.name.lower() != 'unreleased'][0]
|
||||||
cur_version = obj.versions[0]
|
cur_version = obj.versions[0]
|
||||||
|
old_name = cur_version.name
|
||||||
|
|
||||||
|
if v_flag:
|
||||||
if v_flag[0] == '+':
|
if v_flag[0] == '+':
|
||||||
new_name = yaclog.cli.version_util.increment_version(version.name, v_flag)
|
new_name = yaclog.cli.version_util.increment_version(version.name, v_flag)
|
||||||
else:
|
else:
|
||||||
@ -188,9 +192,34 @@ def release(obj: Changelog, v_flag, commit):
|
|||||||
if yaclog.cli.version_util.is_release(cur_version.name):
|
if yaclog.cli.version_util.is_release(cur_version.name):
|
||||||
click.confirm(f'Rename release version "{cur_version.name}" to "{new_name}"?', abort=True)
|
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()
|
cur_version.date = datetime.datetime.utcnow().date()
|
||||||
|
|
||||||
obj.write()
|
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__':
|
if __name__ == '__main__':
|
||||||
|
@ -14,17 +14,19 @@
|
|||||||
# You should have received a copy of the GNU Affero General Public License
|
# 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/>.
|
# 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:
|
def is_release(version: str) -> bool:
|
||||||
v = parse(version)
|
try:
|
||||||
|
v = Version(version)
|
||||||
return not (v.is_devrelease or v.is_prerelease)
|
return not (v.is_devrelease or v.is_prerelease)
|
||||||
|
except InvalidVersion:
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
def increment_version(version: str, mode: str) -> str:
|
def increment_version(version: str, mode: str) -> str:
|
||||||
v = parse(version)
|
v = Version(version)
|
||||||
epoch = v.epoch
|
epoch = v.epoch
|
||||||
release = v.release
|
release = v.release
|
||||||
pre = v.pre
|
pre = v.pre
|
||||||
|
Loading…
Reference in New Issue
Block a user