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.
|
||||
|
||||
### Added
|
||||
|
||||
- Terminal output has color to distinguish version names/headers, sections, and git information
|
||||
|
||||
## 0.3.3 - 2021-04-27
|
||||
|
||||
### Added
|
||||
|
@ -21,6 +21,8 @@ import os
|
||||
import re
|
||||
from typing import List, Optional, Dict
|
||||
|
||||
import click # only for styling
|
||||
|
||||
import yaclog.markdown as markdown
|
||||
import yaclog.version
|
||||
|
||||
@ -114,11 +116,12 @@ class VersionEntry:
|
||||
|
||||
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
|
||||
|
||||
: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
|
||||
"""
|
||||
|
||||
@ -127,27 +130,38 @@ class VersionEntry:
|
||||
for section, entries in self.sections.items():
|
||||
if section:
|
||||
if md:
|
||||
segments.append(f'### {section.title()}')
|
||||
prefix = '### '
|
||||
title = section.title()
|
||||
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:
|
||||
segments += entries
|
||||
|
||||
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
|
||||
|
||||
: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
|
||||
"""
|
||||
|
||||
segments = []
|
||||
|
||||
if md:
|
||||
segments.append('##')
|
||||
prefix = '## '
|
||||
else:
|
||||
prefix = ''
|
||||
|
||||
segments = []
|
||||
|
||||
if self.link and md:
|
||||
segments.append(f'[{self.name}]')
|
||||
@ -162,18 +176,25 @@ class VersionEntry:
|
||||
|
||||
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
|
||||
|
||||
: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
|
||||
"""
|
||||
|
||||
contents = self.header(md)
|
||||
body = self.body(md)
|
||||
contents = self.header(md, color)
|
||||
body = self.body(md, color)
|
||||
if body:
|
||||
contents += '\n\n' + body
|
||||
return contents
|
||||
|
@ -87,7 +87,7 @@ def show(obj: Changelog, all_versions, markdown, str_func, version_names):
|
||||
except ValueError as v:
|
||||
raise click.ClickException(v)
|
||||
|
||||
kwargs = {'md': markdown}
|
||||
kwargs = {'md': markdown, 'color': True}
|
||||
|
||||
for v in versions:
|
||||
text = str_func(v, kwargs)
|
||||
@ -122,17 +122,14 @@ def tag(obj: Changelog, add, tag_name: str, version_name: str):
|
||||
try:
|
||||
version.tags.remove(tag_name)
|
||||
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()
|
||||
|
||||
|
||||
@cli.command(short_help='Add entries to the changelog.')
|
||||
@click.option('--bullet', '-b', 'bullets', multiple=True, type=str,
|
||||
help='Bullet points to add. '
|
||||
'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.option('--bullet', '-b', 'bullets', multiple=True, type=str, help='Add a bullet point.')
|
||||
@click.option('--paragraph', '-p', 'paragraphs', multiple=True, type=str, help='Add a paragraph')
|
||||
@click.argument('section_name', metavar='SECTION', type=str, default='', required=False)
|
||||
@click.argument('version_name', metavar='VERSION', type=str, default=None, required=False)
|
||||
@click.pass_obj
|
||||
@ -161,6 +158,13 @@ def entry(obj: Changelog, bullets, paragraphs, section_name, version_name):
|
||||
version.add_entry('- ' + b, section_name)
|
||||
|
||||
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.')
|
||||
@ -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):
|
||||
"""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()
|
||||
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 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.date = datetime.datetime.utcnow().date()
|
||||
|
||||
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:
|
||||
repo = git.Repo(os.curdir)
|
||||
|
||||
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)
|
||||
|
||||
version_type = '' if yaclog.version.is_release(cur_version.name) else 'non-release '
|
||||
tracked = len(repo.index.diff(repo.head.commit))
|
||||
tracked_warning = 'Create tag'
|
||||
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:
|
||||
untracked_warning = click.style(
|
||||
f' You have {untracked} untracked file{untracked_plural} that will not be included.',
|
||||
fg='red', bold=True)
|
||||
message.append(click.style(
|
||||
f"You have {untracked} untracked file{'s'[:untracked]} that will not be included!",
|
||||
fg='red', bold=True))
|
||||
|
||||
if tracked > 0:
|
||||
tracked_warning = 'Commit and create tag'
|
||||
|
||||
click.confirm(f'{tracked_warning} for {version_type}version {cur_version.name}?{untracked_warning}',
|
||||
abort=True)
|
||||
click.confirm(' '.join(message), abort=True)
|
||||
|
||||
if tracked > 0:
|
||||
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:
|
||||
commit = repo.head.commit
|
||||
|
||||
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__':
|
||||
|
Loading…
Reference in New Issue
Block a user