mirror of
https://github.com/drewcassidy/yaclog.git
synced 2024-09-01 14:58:58 +00:00
Compare commits
No commits in common. "7a8b3c716073a8273c5ec5f945fedb6fd861880b" and "76d2d55af85d41b8036c60322da5bec7e473e74f" have entirely different histories.
7a8b3c7160
...
76d2d55af8
13
.github/workflows/python-publish.yml
vendored
13
.github/workflows/python-publish.yml
vendored
@ -77,11 +77,10 @@ jobs:
|
|||||||
password: ${{ secrets.PYPI_API_TOKEN }}
|
password: ${{ secrets.PYPI_API_TOKEN }}
|
||||||
|
|
||||||
- name: Publish to Github
|
- name: Publish to Github
|
||||||
run: |
|
uses: softprops/action-gh-release@v2
|
||||||
gh release create ${{ github.ref_name }} \
|
with:
|
||||||
--notes-file "${{ steps.yaclog-show.outputs.body_file }}" \
|
files: dist/*
|
||||||
--title "${{ steps.yaclog-show.outputs.name }}"
|
name: ${{ steps.yaclog-show.outputs.name }}
|
||||||
|
body_path: ${{ steps.yaclog-show.outputs.body_file }}
|
||||||
gh release upload ${{ github.ref_name }} dist/*
|
|
||||||
env:
|
env:
|
||||||
GH_TOKEN: ${{ github.token }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
30
CHANGELOG.md
30
CHANGELOG.md
@ -2,49 +2,31 @@
|
|||||||
|
|
||||||
All notable changes to this project will be documented in this file
|
All notable changes to this project will be documented in this file
|
||||||
|
|
||||||
## Version 1.4.1 - 2024-08-25
|
|
||||||
|
|
||||||
### Fixed
|
|
||||||
|
|
||||||
- Fixed escape characters being included in github actions body file
|
|
||||||
|
|
||||||
### Added
|
|
||||||
|
|
||||||
- Added pypi tags for python 3.11 and 3.12
|
|
||||||
|
|
||||||
|
|
||||||
## Version 1.4.0 - 2024-08-25
|
|
||||||
|
|
||||||
### Added
|
|
||||||
|
|
||||||
- Added a github action to the repository. The action can create new releases and fetch version information. For more information see the "Github Actions" page in the handbook
|
|
||||||
|
|
||||||
|
|
||||||
## Version 1.3.0 - 2024-08-08
|
## Version 1.3.0 - 2024-08-08
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
|
||||||
- Added a `--version` option to `yaclog show` that prints just the version number
|
- added a `--version` option to `yaclog show` that prints just the version number
|
||||||
|
|
||||||
### Changed
|
### Changed
|
||||||
|
|
||||||
- Removed support for Click 7 as a dependency
|
- removed support for Click 7 as a dependency
|
||||||
|
|
||||||
|
|
||||||
## Version 1.2.0 - 2024-04-16
|
## Version 1.2.0 - 2024-04-16
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
|
||||||
- Added the `-s` option to `yaclog release` to increment arbitrary version segments
|
- added the `-s` option to `yaclog release` to increment arbitrary version segments
|
||||||
- Added the `-n` option to `yaclog release` to create a new release instead of releasing a new one
|
- added the `-n` option to `yaclog release` to create a new release instead of releasing a new one
|
||||||
- Added the `-y` option to `yaclog release` to answer "yes" to all confirmation dialogs. Use with caution!
|
- added the `-y` option to `yaclog release` to answer "yes" to all confirmation dialogs. Use with caution!
|
||||||
|
|
||||||
|
|
||||||
## Version 1.1.2 - 2022-12-29
|
## Version 1.1.2 - 2022-12-29
|
||||||
|
|
||||||
### Changed
|
### Changed
|
||||||
|
|
||||||
- Yaclog now only tries to use git when invoked with a command that needs it, meaning most sub commands can now be used on systems without git
|
- yaclog now only tries to use git when invoked with a command that needs it, meaning most sub commands can now be used on systems without git
|
||||||
|
|
||||||
|
|
||||||
## Version 1.1.1 - 2022-08-15
|
## Version 1.1.1 - 2022-08-15
|
||||||
|
21
action.yaml
21
action.yaml
@ -15,7 +15,13 @@ inputs:
|
|||||||
description: >
|
description: >
|
||||||
Creates a new release and commits it if set. Directly passed to the arguments of `yaclog release`.
|
Creates a new release and commits it if set. Directly passed to the arguments of `yaclog release`.
|
||||||
Can be a version number or an increment tag like `--major`, `--minor`, or `--patch`.
|
Can be a version number or an increment tag like `--major`, `--minor`, or `--patch`.
|
||||||
The resulting commit and tag will NOT be pushed back to the repo. You must add a step to do this yourself
|
The resulting commit and tag will be pushed back to the repo, but the workflow must have write permissions.
|
||||||
|
Add
|
||||||
|
```yaml
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
```
|
||||||
|
to your workflow to allow this.
|
||||||
|
|
||||||
outputs:
|
outputs:
|
||||||
name:
|
name:
|
||||||
@ -62,4 +68,15 @@ runs:
|
|||||||
# header=Version 1.3.0 - 2024-08-08
|
# header=Version 1.3.0 - 2024-08-08
|
||||||
# version=1.3.0
|
# version=1.3.0
|
||||||
# body_file={path to file containing version body}
|
# body_file={path to file containing version body}
|
||||||
# changelog={path to changelog}
|
# changelog={path to changelog}
|
||||||
|
|
||||||
|
- name: Push Changes
|
||||||
|
if: ${{ inputs.release }}
|
||||||
|
shell: bash
|
||||||
|
env:
|
||||||
|
GH_TOKEN: ${{ github.token }}
|
||||||
|
run: |
|
||||||
|
git config --global user.name "github-actions"
|
||||||
|
git config --global user.email "github-actions@github.com"
|
||||||
|
git push
|
||||||
|
git push --tags
|
||||||
|
17
docs/conf.py
17
docs/conf.py
@ -4,7 +4,7 @@
|
|||||||
# list see the documentation:
|
# list see the documentation:
|
||||||
# https://www.sphinx-doc.org/en/master/usage/configuration.html
|
# https://www.sphinx-doc.org/en/master/usage/configuration.html
|
||||||
|
|
||||||
from importlib.metadata import version
|
from pkg_resources import get_distribution
|
||||||
|
|
||||||
# -- Path setup --------------------------------------------------------------
|
# -- Path setup --------------------------------------------------------------
|
||||||
|
|
||||||
@ -22,9 +22,8 @@ sys.path.insert(0, os.path.abspath('..'))
|
|||||||
project = 'Yaclog'
|
project = 'Yaclog'
|
||||||
copyright = '2021, Andrew Cassidy'
|
copyright = '2021, Andrew Cassidy'
|
||||||
author = 'Andrew Cassidy'
|
author = 'Andrew Cassidy'
|
||||||
release = version('yaclog')
|
release = get_distribution('yaclog').version
|
||||||
version = '.'.join(release.split('.')[:3])
|
version = '.'.join(release.split('.')[:3])
|
||||||
ref = version if len(release.split('.')) == 3 else 'main'
|
|
||||||
|
|
||||||
# -- General configuration ---------------------------------------------------
|
# -- General configuration ---------------------------------------------------
|
||||||
|
|
||||||
@ -37,13 +36,9 @@ extensions = [
|
|||||||
'sphinx_rtd_theme',
|
'sphinx_rtd_theme',
|
||||||
'sphinx.ext.autodoc',
|
'sphinx.ext.autodoc',
|
||||||
'sphinx.ext.intersphinx',
|
'sphinx.ext.intersphinx',
|
||||||
'sphinx_jinja'
|
|
||||||
]
|
]
|
||||||
|
|
||||||
myst_heading_anchors = 2
|
myst_heading_anchors = 2
|
||||||
myst_enable_extensions = [
|
|
||||||
"colon_fence"
|
|
||||||
]
|
|
||||||
|
|
||||||
# Add any paths that contain templates here, relative to this directory.
|
# Add any paths that contain templates here, relative to this directory.
|
||||||
templates_path = ['_templates']
|
templates_path = ['_templates']
|
||||||
@ -81,8 +76,6 @@ autodoc_default_options = {
|
|||||||
'undoc-members': True,
|
'undoc-members': True,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# -- Options for Intersphinx -------------------------------------------------
|
# -- Options for Intersphinx -------------------------------------------------
|
||||||
|
|
||||||
# This config value contains the locations and names of other projects that
|
# This config value contains the locations and names of other projects that
|
||||||
@ -92,9 +85,3 @@ intersphinx_mapping = {
|
|||||||
'python': ('https://docs.python.org/3', None),
|
'python': ('https://docs.python.org/3', None),
|
||||||
'packaging': ('https://packaging.pypa.io/en/latest/', None),
|
'packaging': ('https://packaging.pypa.io/en/latest/', None),
|
||||||
}
|
}
|
||||||
|
|
||||||
jinja_globals = {
|
|
||||||
'version': version,
|
|
||||||
'release': release,
|
|
||||||
'ref': ref,
|
|
||||||
}
|
|
@ -1,141 +0,0 @@
|
|||||||
# Github Actions
|
|
||||||
|
|
||||||
Yaclog makes an action available for Github Actions and compatible CI systems.
|
|
||||||
|
|
||||||
## The Yaclog Action
|
|
||||||
|
|
||||||
To use the Yaclog action add the following to your workflow steps
|
|
||||||
|
|
||||||
````{jinja}
|
|
||||||
```yaml
|
|
||||||
- name: Get version info
|
|
||||||
uses: drewcassidy/yaclog@{{ ref }}
|
|
||||||
id: yaclog
|
|
||||||
```
|
|
||||||
````
|
|
||||||
|
|
||||||
### Inputs
|
|
||||||
|
|
||||||
```{confval} release
|
|
||||||
:type: string
|
|
||||||
|
|
||||||
When set, creates a new release and commits it. Directly passed to the arguments of `yaclog release --yes --commit`.
|
|
||||||
|
|
||||||
Can be a version number or an increment tag like `--major`, `--minor`, or `--patch`.
|
|
||||||
The resulting commit and tag will NOT be pushed back to the repo. You must add a step to do this yourself
|
|
||||||
```
|
|
||||||
|
|
||||||
```{confval} markdown
|
|
||||||
:type: boolean
|
|
||||||
:default: true
|
|
||||||
|
|
||||||
If the output should be in markdown format or not. Equivalent to the `--markdown` flag
|
|
||||||
```
|
|
||||||
|
|
||||||
### Outputs
|
|
||||||
|
|
||||||
```{confval} version
|
|
||||||
The current version number, equivalent to the output of `yaclog show --version`. For example, `1.3.1`
|
|
||||||
```
|
|
||||||
|
|
||||||
```{confval} name
|
|
||||||
The most recent version name, equivalent to the output of `yaclog show --name`. For example, `Version 1.3.0`
|
|
||||||
```
|
|
||||||
|
|
||||||
```{confval} header
|
|
||||||
The entire header for the most recent version, equivalent to the output of `yaclog show --header`. For example, `Version 1.3.0 - 2024-08-08`
|
|
||||||
```
|
|
||||||
|
|
||||||
```{confval} body_file
|
|
||||||
The path to a temporary file containing the body of the most recent version. Contents equivalent to `yaclog show --body`
|
|
||||||
```
|
|
||||||
|
|
||||||
```{confval} changelog
|
|
||||||
The path to the changelog file. Usually `CHANGELOG.md` in the current directory.
|
|
||||||
```
|
|
||||||
|
|
||||||
## Example Usage
|
|
||||||
|
|
||||||
### Get changelog information in your Build workflow
|
|
||||||
|
|
||||||
````{jinja}
|
|
||||||
```yaml
|
|
||||||
name: Build
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
pull_request:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout Mod Repo
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- uses: drewcassidy/yaclog@{{ ref }}
|
|
||||||
id: yaclog
|
|
||||||
|
|
||||||
# Your build and test actions go here
|
|
||||||
|
|
||||||
- name: Publish to Github
|
|
||||||
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags')
|
|
||||||
run: |
|
|
||||||
gh release create {{ '${{ github.ref_name }}' }} \
|
|
||||||
--notes-file "{{ '${{ steps.yaclog.outputs.body_file }}' }}" \
|
|
||||||
--title "{{ '${{ steps.yaclog.outputs.name }}' }}"
|
|
||||||
env:
|
|
||||||
GH_TOKEN: {{ '${{ github.token }}' }}
|
|
||||||
|
|
||||||
```
|
|
||||||
````
|
|
||||||
|
|
||||||
### Workflow to make a new release
|
|
||||||
|
|
||||||
If you want to be able to create a new release for your project directly from the Github UI, you can make a new workflow
|
|
||||||
you can dispatch directly.
|
|
||||||
|
|
||||||
Please note that this workflow does NOT create any releases in Github or any package managers. Instead, your normal build workflow should do this when it detects a push to a tag.
|
|
||||||
|
|
||||||
````{jinja}
|
|
||||||
```yaml
|
|
||||||
name: Release
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
inputs:
|
|
||||||
release:
|
|
||||||
description: 'type of release to use'
|
|
||||||
required: true
|
|
||||||
default: 'patch'
|
|
||||||
type: choice
|
|
||||||
options:
|
|
||||||
- major
|
|
||||||
- minor
|
|
||||||
- patch
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: write
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
yaclog-release:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout Mod Repo
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Yaclog Release
|
|
||||||
uses: drewcassidy/yaclog@{{ ref }}
|
|
||||||
with:
|
|
||||||
release: '--{{ '${{ inputs.release }}' }}'
|
|
||||||
|
|
||||||
- name: Push Changes
|
|
||||||
run: |
|
|
||||||
git config --global user.name "github-actions"
|
|
||||||
git config --global user.email "github-actions@github.com"
|
|
||||||
git push
|
|
||||||
git push --tags
|
|
||||||
env:
|
|
||||||
GH_TOKEN: {{ '${{ github.token }}' }}
|
|
||||||
```
|
|
||||||
````
|
|
@ -8,5 +8,4 @@ maxdepth: 3
|
|||||||
getting_started
|
getting_started
|
||||||
changelog_files
|
changelog_files
|
||||||
commands
|
commands
|
||||||
github_actions
|
|
||||||
```
|
```
|
@ -22,8 +22,6 @@ classifiers = [
|
|||||||
"Programming Language :: Python :: 3.8",
|
"Programming Language :: Python :: 3.8",
|
||||||
"Programming Language :: Python :: 3.9",
|
"Programming Language :: Python :: 3.9",
|
||||||
"Programming Language :: Python :: 3.10",
|
"Programming Language :: Python :: 3.10",
|
||||||
"Programming Language :: Python :: 3.11",
|
|
||||||
"Programming Language :: Python :: 3.12",
|
|
||||||
"Topic :: Text Processing :: Markup :: Markdown",
|
"Topic :: Text Processing :: Markup :: Markdown",
|
||||||
"Topic :: Software Development :: Version Control :: Git",
|
"Topic :: Software Development :: Version Control :: Git",
|
||||||
"Topic :: Utilities"
|
"Topic :: Utilities"
|
||||||
@ -45,7 +43,6 @@ docs = [
|
|||||||
"sphinx-click >= 2.7",
|
"sphinx-click >= 2.7",
|
||||||
"sphinx-rtd-theme",
|
"sphinx-rtd-theme",
|
||||||
"myst-parser >= 0.14",
|
"myst-parser >= 0.14",
|
||||||
"sphinx-jinja >=1.2.1",
|
|
||||||
]
|
]
|
||||||
|
|
||||||
[project.scripts]
|
[project.scripts]
|
||||||
|
@ -16,7 +16,6 @@
|
|||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
import os.path
|
import os.path
|
||||||
from sys import stdout
|
|
||||||
|
|
||||||
import click
|
import click
|
||||||
|
|
||||||
@ -92,7 +91,7 @@ def show(obj: Changelog, all_versions, markdown, mode, version_names, gh_actions
|
|||||||
}
|
}
|
||||||
|
|
||||||
str_func = functions[mode]
|
str_func = functions[mode]
|
||||||
kwargs = {'md': markdown, 'color': stdout.isatty()}
|
kwargs = {'md': markdown, 'color': True}
|
||||||
|
|
||||||
try:
|
try:
|
||||||
if all_versions:
|
if all_versions:
|
||||||
@ -116,7 +115,6 @@ def show(obj: Changelog, all_versions, markdown, mode, version_names, gh_actions
|
|||||||
if gh_actions:
|
if gh_actions:
|
||||||
import tempfile
|
import tempfile
|
||||||
|
|
||||||
kwargs['color'] = False
|
|
||||||
all_modes = [ 'name', 'header', 'version' ]
|
all_modes = [ 'name', 'header', 'version' ]
|
||||||
outputs = [f'{mode}={sep.join([functions[mode](v, kwargs) for v in versions])}' for mode in all_modes]
|
outputs = [f'{mode}={sep.join([functions[mode](v, kwargs) for v in versions])}' for mode in all_modes]
|
||||||
click.echo('\n'.join(outputs))
|
click.echo('\n'.join(outputs))
|
||||||
|
Loading…
Reference in New Issue
Block a user