mirror of
https://github.com/drewcassidy/yaclog.git
synced 2024-09-01 14:58:58 +00:00
yaclog init
command
This commit is contained in:
parent
e9a8e63c27
commit
6e75e15526
@ -29,6 +29,8 @@ under2_regex = re.compile(r'^-+\s*$')
|
||||
bullet_regex = re.compile(r'^[-+*]')
|
||||
linkid_regex = re.compile(r'^\[(?P<link_id>\S*)]:\s*(?P<link>.*)')
|
||||
|
||||
default_header = '# Changelog\n\nAll notable changes to this project will be documented in this file'
|
||||
|
||||
|
||||
def _strip_link(token):
|
||||
if link_literal := re.fullmatch(r'\[(.*?)]\((.*?)\)', token):
|
||||
@ -112,26 +114,28 @@ class VersionEntry:
|
||||
|
||||
|
||||
class Changelog:
|
||||
def __init__(self, path: os.PathLike):
|
||||
def __init__(self, path: os.PathLike = None):
|
||||
self.path = path
|
||||
self.header = ''
|
||||
self.versions = []
|
||||
self.links = {}
|
||||
|
||||
if not os.path.exists(path):
|
||||
self.header = default_header
|
||||
return
|
||||
|
||||
# Read file
|
||||
with open(path, 'r') as fp:
|
||||
self.lines = fp.readlines()
|
||||
lines = fp.readlines()
|
||||
|
||||
section = ''
|
||||
in_block = False
|
||||
in_code = False
|
||||
|
||||
self.links = {}
|
||||
|
||||
links = {}
|
||||
segments: List[Tuple[int, List[str], str]] = []
|
||||
header_segments = []
|
||||
|
||||
for line_no, line in enumerate(self.lines):
|
||||
for line_no, line in enumerate(lines):
|
||||
if in_code:
|
||||
# this is the contents of a code block
|
||||
segments[-1][1].append(line)
|
||||
@ -168,7 +172,7 @@ class Changelog:
|
||||
|
||||
elif match := linkid_regex.match(line):
|
||||
# this is a link definition in the form '[id]: link', so add it to the link table
|
||||
links[match['link_id'].lower()] = match['link']
|
||||
self.links[match['link_id'].lower()] = match['link']
|
||||
|
||||
elif line.isspace():
|
||||
# skip empty lines
|
||||
@ -241,18 +245,18 @@ class Changelog:
|
||||
if match := re.fullmatch(r'\[(.*)]', version.name):
|
||||
# ref-matched link
|
||||
link_id = match[1].lower()
|
||||
if link_id in links:
|
||||
version.link = links.pop(link_id)
|
||||
if link_id in self.links:
|
||||
version.link = self.links.pop(link_id)
|
||||
version.link_id = None
|
||||
version.name = match[1]
|
||||
|
||||
elif version.link_id in links:
|
||||
elif version.link_id in self.links:
|
||||
# id-matched link
|
||||
version.link = links.pop(version.link_id)
|
||||
version.link = self.links.pop(version.link_id)
|
||||
|
||||
# strip whitespace from header
|
||||
self.header = _join_markdown(header_segments)
|
||||
self.links = links
|
||||
self.links = self.links
|
||||
|
||||
def write(self, path: os.PathLike = None):
|
||||
if path is None:
|
||||
|
0
yaclog/cli/__init__.py
Normal file
0
yaclog/cli/__init__.py
Normal file
52
yaclog/cli/__main__.py
Normal file
52
yaclog/cli/__main__.py
Normal file
@ -0,0 +1,52 @@
|
||||
# yaclog: yet another changelog tool
|
||||
# Copyright (c) 2021. Andrew Cassidy
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU Affero General Public License as
|
||||
# published by the Free Software Foundation, either version 3 of the
|
||||
# License, or (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU Affero General Public License for more details.
|
||||
#
|
||||
# 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/>.
|
||||
|
||||
import click
|
||||
import yaclog
|
||||
import os.path
|
||||
|
||||
|
||||
@click.group()
|
||||
@click.option('--path', envvar='YACLOG_PATH', default='CHANGELOG.md',
|
||||
type=click.Path(dir_okay=False, writable=True, readable=True))
|
||||
@click.version_option()
|
||||
@click.pass_context
|
||||
def cli(ctx, path):
|
||||
ctx.obj = path
|
||||
|
||||
if not (ctx.invoked_subcommand == 'init' or os.path.exists(path)):
|
||||
# if the path doesnt exist, then ask if we can create it
|
||||
if click.confirm(f'Changelog file {path} does not exist. Would you like to create it?'):
|
||||
ctx.invoke('init')
|
||||
else:
|
||||
return
|
||||
|
||||
|
||||
@cli.command('init')
|
||||
@click.pass_context
|
||||
def init(ctx):
|
||||
path = ctx.parent.params['path']
|
||||
|
||||
if os.path.exists(path) and not click.confirm(
|
||||
f'Changelog file {path} already exists. Would you like to overwrite it?'):
|
||||
return
|
||||
|
||||
yaclog.Changelog(path).write()
|
||||
print(f'Created new changelog file at {path}')
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
cli()
|
Loading…
Reference in New Issue
Block a user