diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..ae4cc42 --- /dev/null +++ b/Makefile @@ -0,0 +1,23 @@ +.PHONY: clean clean-build clean-pyc release + +dist: clean + python -m build + +release: clean + ./scripts/release.sh + +publish: dist release + python -m twine upload dist/* + +clean: clean-build clean-pyc + +clean-build: + rm -rf build + rm -rf dist + rm -rf *.egg-info + +clean-pyc: + find . -name '*.pyc' -exec rm -f {} + + find . -name '*.pyo' -exec rm -f {} + + find . -name '*~' -exec rm -f {} + + find . -name '__pycache__' -exec rm -fr {} + diff --git a/README.md b/README.md index 21bdbee..2ff46d5 100644 --- a/README.md +++ b/README.md @@ -2,6 +2,8 @@ > Tool to download FC2 live streams +[![PyPI](https://img.shields.io/pypi/v/fc2-live-dl)](https://pypi.org/project/fc2-live-dl/ 'PyPI') + ## Requirements - Python 3.8 diff --git a/cliff.toml b/cliff.toml new file mode 100644 index 0000000..847c5ea --- /dev/null +++ b/cliff.toml @@ -0,0 +1,59 @@ +# configuration file for git-cliff (0.1.0) + +[changelog] +# changelog header +header = """ +# Changelog\n +""" +# template for the changelog body +# https://tera.netlify.app/docs/#introduction +body = """ +{% if version %}\ + ## [{{ version | trim_start_matches(pat="v") }}] - {{ timestamp | date(format="%Y-%m-%d") }} +{% else %}\ + ## [unreleased] +{% endif %}\ +{% for group, commits in commits | group_by(attribute="group") %} + ### {{ group | upper_first }} + {% for commit in commits %} + - {% if commit.breaking %}[**breaking**] {% endif %}{{ commit.message | upper_first }}\ + {% endfor %} +{% endfor %}\n +""" +# remove the leading and trailing whitespaces from the template +trim = true +# changelog footer +footer = """ + +""" + +[git] +# parse the commits based on https://www.conventionalcommits.org +conventional_commits = true +# filter out the commits that are not conventional +filter_unconventional = true +# regex for parsing and grouping commits +commit_parsers = [ + { message = "^feat", group = "Features"}, + { message = "^fix", group = "Bug Fixes"}, + { message = "^doc", group = "Documentation"}, + { message = "^perf", group = "Performance"}, + { message = "^refactor", group = "Refactor"}, + { message = "^style", group = "Styling"}, + { message = "^test", group = "Testing"}, + { message = "^chore\\(release\\): prepare for", skip = true}, + { message = "^chore", group = "Miscellaneous Tasks"}, + { body = ".*security", group = "Security"}, +] +# filter out the commits that are not matched by commit parsers +filter_commits = false +# glob pattern for matching git tags +tag_pattern = "v[0-9]*" +# regex for skipping tags +skip_tags = "v0.1.0-beta.1" +# regex for ignoring tags +ignore_tags = "" +# sort the tags topologically +topo_order = false +# sort the commits inside sections by oldest/newest order +sort_commits = "oldest" diff --git a/scripts/release.sh b/scripts/release.sh new file mode 100755 index 0000000..7c90ff8 --- /dev/null +++ b/scripts/release.sh @@ -0,0 +1,29 @@ +#!/bin/bash + +# Exit on error +set -e + +# Get versions +py_version=$(grep 'version' setup.cfg | sed 's/version = //') +latest_tag=$(git tag --sort=-v:refname | head -n 1 | sed 's/v//') + +# Skip if latest tag is the same as current version +if [ "$py_version" == "$latest_tag" ]; then + echo "Latest version is already tagged." + exit 0 +fi + +# Make sure we're in the right branch +if [ "$(git rev-parse --abbrev-ref HEAD)" != "main" ]; then + echo "You must be in the main branch to run this script" + exit 1 +fi + +# Make sure working tree is clean +if [ -n "$(git status --porcelain)" ]; then + echo "Working tree is not clean. Please commit or stash changes before running this script." + exit 1 +fi + +# Create a new tag +git tag -a "v$py_version" -em "$(git-cliff -ut $py_version -s all)" diff --git a/setup.cfg b/setup.cfg index b625ceb..e4adbc7 100644 --- a/setup.cfg +++ b/setup.cfg @@ -1,6 +1,6 @@ [metadata] name = fc2-live-dl -version = 2.0.0 +version = 2.0.1 author = Hizkia Felix author_email = felix@hizkifw.me description = Download live streams from FC2