Compare commits

..

No commits in common. "7a8b3c716073a8273c5ec5f945fedb6fd861880b" and "76d2d55af85d41b8036c60322da5bec7e473e74f" have entirely different histories.

8 changed files with 34 additions and 196 deletions

View File

@ -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 }}

View File

@ -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

View File

@ -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:
@ -63,3 +69,14 @@ runs:
# 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

View File

@ -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,
}

View File

@ -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 }}' }}
```
````

View File

@ -8,5 +8,4 @@ maxdepth: 3
getting_started getting_started
changelog_files changelog_files
commands commands
github_actions
``` ```

View File

@ -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]

View File

@ -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))