mirror of
https://github.com/drewcassidy/yaclog.git
synced 2024-09-01 14:58:58 +00:00
show
command now uses color
This commit is contained in:
parent
000228a836
commit
7747d8a328
@ -15,6 +15,10 @@ All notable changes to this project will be documented in this file
|
|||||||
|
|
||||||
- `entry` with multiple `-b` options no longer add sub bullet points, instead adding each bullet as its own line.
|
- `entry` with multiple `-b` options no longer add sub bullet points, instead adding each bullet as its own line.
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
- Terminal output has color to distinguish version names/headers, sections, and git information
|
||||||
|
|
||||||
## 0.3.3 - 2021-04-27
|
## 0.3.3 - 2021-04-27
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
@ -21,6 +21,8 @@ import os
|
|||||||
import re
|
import re
|
||||||
from typing import List, Optional, Dict
|
from typing import List, Optional, Dict
|
||||||
|
|
||||||
|
import click # only for styling
|
||||||
|
|
||||||
import yaclog.markdown as markdown
|
import yaclog.markdown as markdown
|
||||||
import yaclog.version
|
import yaclog.version
|
||||||
|
|
||||||
@ -114,11 +116,12 @@ class VersionEntry:
|
|||||||
|
|
||||||
self.sections[section].append(contents)
|
self.sections[section].append(contents)
|
||||||
|
|
||||||
def body(self, md: bool = True) -> str:
|
def body(self, md: bool = True, color: bool = False) -> str:
|
||||||
"""
|
"""
|
||||||
Get the version's body as a string
|
Get the version's body as a string
|
||||||
|
|
||||||
:param md: Whether or not to use markdown syntax in headings
|
:param md: Format headings as markdown
|
||||||
|
:param color: Add color codes to the string for display in a terminal
|
||||||
:return: The formatted version body, without the version header
|
:return: The formatted version body, without the version header
|
||||||
"""
|
"""
|
||||||
|
|
||||||
@ -127,27 +130,38 @@ class VersionEntry:
|
|||||||
for section, entries in self.sections.items():
|
for section, entries in self.sections.items():
|
||||||
if section:
|
if section:
|
||||||
if md:
|
if md:
|
||||||
segments.append(f'### {section.title()}')
|
prefix = '### '
|
||||||
|
title = section.title()
|
||||||
else:
|
else:
|
||||||
segments.append(f'{section.upper()}:')
|
prefix = ''
|
||||||
|
title = section.upper()
|
||||||
|
|
||||||
|
if color:
|
||||||
|
prefix = click.style(prefix, fg='bright_black')
|
||||||
|
title = click.style(title, fg='cyan', bold=True)
|
||||||
|
|
||||||
|
segments.append(prefix + title)
|
||||||
|
|
||||||
if len(entries) > 0:
|
if len(entries) > 0:
|
||||||
segments += entries
|
segments += entries
|
||||||
|
|
||||||
return markdown.join(segments)
|
return markdown.join(segments)
|
||||||
|
|
||||||
def header(self, md: bool = True) -> str:
|
def header(self, md: bool = True, color: bool = False) -> str:
|
||||||
"""
|
"""
|
||||||
Get the version's header as a string
|
Get the version's header as a string
|
||||||
|
|
||||||
:param md: Whether or not to use markdown syntax in headings
|
:param md: Format headings as markdown
|
||||||
|
:param color: Add color codes to the string for display in a terminal
|
||||||
:return: The formatted version header
|
:return: The formatted version header
|
||||||
"""
|
"""
|
||||||
|
|
||||||
segments = []
|
|
||||||
|
|
||||||
if md:
|
if md:
|
||||||
segments.append('##')
|
prefix = '## '
|
||||||
|
else:
|
||||||
|
prefix = ''
|
||||||
|
|
||||||
|
segments = []
|
||||||
|
|
||||||
if self.link and md:
|
if self.link and md:
|
||||||
segments.append(f'[{self.name}]')
|
segments.append(f'[{self.name}]')
|
||||||
@ -162,18 +176,25 @@ class VersionEntry:
|
|||||||
|
|
||||||
segments += [f'[{t.upper()}]' for t in self.tags]
|
segments += [f'[{t.upper()}]' for t in self.tags]
|
||||||
|
|
||||||
return ' '.join(segments)
|
title = ' '.join(segments)
|
||||||
|
|
||||||
def text(self, md: bool = True) -> str:
|
if color:
|
||||||
|
prefix = click.style(prefix, fg='bright_black')
|
||||||
|
title = click.style(title, fg='blue', bold=True)
|
||||||
|
|
||||||
|
return prefix + title
|
||||||
|
|
||||||
|
def text(self, md: bool = True, color: bool = False) -> str:
|
||||||
"""
|
"""
|
||||||
Get the version's contents as a string
|
Get the version's contents as a string
|
||||||
|
|
||||||
:param md: Whether or not to use markdown syntax in headings
|
:param md: Format headings as markdown
|
||||||
|
:param color: Add color codes to the string for display in a terminal
|
||||||
:return: The formatted version header and body
|
:return: The formatted version header and body
|
||||||
"""
|
"""
|
||||||
|
|
||||||
contents = self.header(md)
|
contents = self.header(md, color)
|
||||||
body = self.body(md)
|
body = self.body(md, color)
|
||||||
if body:
|
if body:
|
||||||
contents += '\n\n' + body
|
contents += '\n\n' + body
|
||||||
return contents
|
return contents
|
||||||
|
@ -87,7 +87,7 @@ def show(obj: Changelog, all_versions, markdown, str_func, version_names):
|
|||||||
except ValueError as v:
|
except ValueError as v:
|
||||||
raise click.ClickException(v)
|
raise click.ClickException(v)
|
||||||
|
|
||||||
kwargs = {'md': markdown}
|
kwargs = {'md': markdown, 'color': True}
|
||||||
|
|
||||||
for v in versions:
|
for v in versions:
|
||||||
text = str_func(v, kwargs)
|
text = str_func(v, kwargs)
|
||||||
@ -122,17 +122,14 @@ def tag(obj: Changelog, add, tag_name: str, version_name: str):
|
|||||||
try:
|
try:
|
||||||
version.tags.remove(tag_name)
|
version.tags.remove(tag_name)
|
||||||
except ValueError:
|
except ValueError:
|
||||||
raise click.BadArgumentUsage(f'Tag {tag_name} not found in version {version.name}.')
|
raise click.BadArgumentUsage(f"Tag {tag_name} not found in version {version.name}.")
|
||||||
|
|
||||||
obj.write()
|
obj.write()
|
||||||
|
|
||||||
|
|
||||||
@cli.command(short_help='Add entries to the changelog.')
|
@cli.command(short_help='Add entries to the changelog.')
|
||||||
@click.option('--bullet', '-b', 'bullets', multiple=True, type=str,
|
@click.option('--bullet', '-b', 'bullets', multiple=True, type=str, help='Add a bullet point.')
|
||||||
help='Bullet points to add. '
|
@click.option('--paragraph', '-p', 'paragraphs', multiple=True, type=str, help='Add a paragraph')
|
||||||
'When multiple bullet points are provided, additional points are added as sub-points.')
|
|
||||||
@click.option('--paragraph', '-p', 'paragraphs', multiple=True, type=str,
|
|
||||||
help='Paragraphs to add')
|
|
||||||
@click.argument('section_name', metavar='SECTION', type=str, default='', required=False)
|
@click.argument('section_name', metavar='SECTION', type=str, default='', required=False)
|
||||||
@click.argument('version_name', metavar='VERSION', type=str, default=None, required=False)
|
@click.argument('version_name', metavar='VERSION', type=str, default=None, required=False)
|
||||||
@click.pass_obj
|
@click.pass_obj
|
||||||
@ -161,6 +158,13 @@ def entry(obj: Changelog, bullets, paragraphs, section_name, version_name):
|
|||||||
version.add_entry('- ' + b, section_name)
|
version.add_entry('- ' + b, section_name)
|
||||||
|
|
||||||
obj.write()
|
obj.write()
|
||||||
|
count = len(paragraphs) + len(bullets)
|
||||||
|
message = f"Created {count} {['entry', 'entries'][min(count - 1, 1)]}"
|
||||||
|
if section_name:
|
||||||
|
message += f" in section {click.style(section_name, fg='yellow')}"
|
||||||
|
if version.name.lower() != 'unreleased':
|
||||||
|
message += f" in version {click.style(version.name, fg='blue')}"
|
||||||
|
print(message)
|
||||||
|
|
||||||
|
|
||||||
@cli.command(short_help='Release versions.')
|
@cli.command(short_help='Release versions.')
|
||||||
@ -179,6 +183,9 @@ def entry(obj: Changelog, bullets, paragraphs, section_name, version_name):
|
|||||||
def release(obj: Changelog, version_name, rel_seg, pre_seg, commit):
|
def release(obj: Changelog, version_name, rel_seg, pre_seg, commit):
|
||||||
"""Release versions in the changelog and increment their version numbers"""
|
"""Release versions in the changelog and increment their version numbers"""
|
||||||
|
|
||||||
|
if not (rel_seg or pre_seg or version_name or commit):
|
||||||
|
rel_seg = 2 # default to incrementing patch number I guess
|
||||||
|
|
||||||
cur_version = obj.current_version()
|
cur_version = obj.current_version()
|
||||||
old_name = cur_version.name
|
old_name = cur_version.name
|
||||||
|
|
||||||
@ -197,47 +204,50 @@ def release(obj: Changelog, version_name, rel_seg, pre_seg, commit):
|
|||||||
|
|
||||||
if new_name != old_name:
|
if new_name != old_name:
|
||||||
if yaclog.version.is_release(old_name):
|
if yaclog.version.is_release(old_name):
|
||||||
click.confirm(f'Rename release version "{cur_version.name}" to "{new_name}"?', abort=True)
|
click.confirm(
|
||||||
|
f"Rename release version {click.style(old_name, fg='blue')} "
|
||||||
|
f"to {click.style(new_name, fg='blue')}?",
|
||||||
|
abort=True)
|
||||||
|
|
||||||
cur_version.name = new_name
|
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}".')
|
print(f"Renamed {click.style(old_name, fg='blue')} to {click.style(new_name, fg='blue')}")
|
||||||
|
|
||||||
if commit:
|
if commit:
|
||||||
repo = git.Repo(os.curdir)
|
repo = git.Repo(os.curdir)
|
||||||
|
|
||||||
if repo.bare:
|
if repo.bare:
|
||||||
raise click.BadOptionUsage('commit', f'Directory {os.path.abspath(os.curdir)} is not a git repo.')
|
raise click.BadOptionUsage('commit', f'Directory {os.path.abspath(os.curdir)} is not a git repo')
|
||||||
|
|
||||||
repo.index.add(obj.path)
|
repo.index.add(obj.path)
|
||||||
|
|
||||||
version_type = '' if yaclog.version.is_release(cur_version.name) else 'non-release '
|
|
||||||
tracked = len(repo.index.diff(repo.head.commit))
|
tracked = len(repo.index.diff(repo.head.commit))
|
||||||
tracked_warning = 'Create tag'
|
|
||||||
untracked = len(repo.index.diff(None))
|
untracked = len(repo.index.diff(None))
|
||||||
untracked_warning = ''
|
|
||||||
untracked_plural = 's' if untracked > 1 else ''
|
message = [['Commit and create tag', 'Create tag'][min(tracked, 1)], 'for']
|
||||||
|
|
||||||
|
if not cur_version.released:
|
||||||
|
message.append('non-release')
|
||||||
|
|
||||||
|
message.append(f"version {click.style(new_name, fg='blue')}?")
|
||||||
|
|
||||||
if untracked > 0:
|
if untracked > 0:
|
||||||
untracked_warning = click.style(
|
message.append(click.style(
|
||||||
f' You have {untracked} untracked file{untracked_plural} that will not be included.',
|
f"You have {untracked} untracked file{'s'[:untracked]} that will not be included!",
|
||||||
fg='red', bold=True)
|
fg='red', bold=True))
|
||||||
|
|
||||||
if tracked > 0:
|
click.confirm(' '.join(message), abort=True)
|
||||||
tracked_warning = 'Commit and create tag'
|
|
||||||
|
|
||||||
click.confirm(f'{tracked_warning} for {version_type}version {cur_version.name}?{untracked_warning}',
|
|
||||||
abort=True)
|
|
||||||
|
|
||||||
if tracked > 0:
|
if tracked > 0:
|
||||||
commit = repo.index.commit(f'Version {cur_version.name}\n\n{cur_version.body()}')
|
commit = repo.index.commit(f'Version {cur_version.name}\n\n{cur_version.body()}')
|
||||||
print(f'Created commit {repo.head.commit.hexsha[0:7]}')
|
print(f"Created commit {click.style(repo.head.commit.hexsha[0:7], fg='green')}")
|
||||||
else:
|
else:
|
||||||
commit = repo.head.commit
|
commit = repo.head.commit
|
||||||
|
|
||||||
repo_tag = repo.create_tag(cur_version.name, ref=commit, message=cur_version.body(False))
|
repo_tag = repo.create_tag(cur_version.name, ref=commit, message=cur_version.body(False))
|
||||||
print(f'Created tag "{repo_tag.name}".')
|
print(f"Created tag {click.style(repo_tag.name, fg='green')}.")
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
Loading…
Reference in New Issue
Block a user