All notable changes to this project will be documented in this file, in reverse chronological order by release.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Fixed php-scoper configuration to allow phar build to complete successfully.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Fixed the workflow for generating the Phar distribution.
- Adds support for PHP 8.4.
-
Bumps the laminas/laminas-diactoros minimum supported version to 3.3.0.
-
#121 updates the symfony/console dependency to allow version 7 releases. (Contributed by fezfez)
- Nothing.
-
Removes support for PHP versions older than 8.1.0.
-
Removes support for PHP versions prior to PHP 8.1.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Fixes an issue with the version:release command whereby GitHub/GitLab tokens were not correctly consumed, leading to exceptions.
- Adds support for symfony/console v6 releases (thanks to @ramsey).
- The utility now uses the composer-runtime-api for purposes of reporting its version.
- Nothing.
- This release removes support for Composer version 1 releases.
- Nothing.
- #97 adds support for PHP 8.0.
- #97 updates to use the v3 release of knplabs/github-api.
- Nothing.
- #97 removes support for PHP versions < 7.4.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- #94 fixes parsing of the
Location
header when determining redirects for theGitLab
provider. GitLab will sometimes provide multiple values for the header, versus the expected single value. The provider now pulls the first one from a list if multiple are present.
- Nothing.
- #92 modifies the
version:tag
andversion:release
commands. In each, theversion
argument is now optional; when not provided, the tooling will discover the first releasable version in the changelog (essentially, the first with a release date associated), and prompt the user to confirm using that version.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
-
#91 differentiates the various reasons why version:tag fails, and adds more help information both when requested and when running the command.
-
#90 modifies the various events that communicate with the configured Git provider to indicate when invalid credentials were used, versus providing a generic failure message.
-
#89 fixes the
config:create
command to emit an error message and return a non-zero status when neither the--local|-l
nor the--global|-g
options have been provided. -
#88 fixes an issue where using the phly/keep-a-changelog PHAR with configuration would lead to errors about the inability to locate provider classes. These are now resolved correctly by the PHAR.
-
#88 fixes an issue whereby calling
config:create -l
with a phly/keep-a-changelog PHAR file would result in unusable local configuration due to a string injected in the config template during PHAR creation.
- #80 adds support for more verbose changelog headings. The heading no longer must be exactly
# Changelog
. Rather, it can be# My Project's Changelog
or# The changelog for all the things
. The word "changelog" must still be somewhere in the heading.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- #79 fixes a case where the
bump
command (and its subcommands) would result in a fatal error if unable to detect any changelog entries.
- #78 adds accessor methods with return types to the
Phly\KeepAChangelog\Common\ChangelogEntry
class. This change only affects code consumers of the package, and has no effect on end-user consumers of the tooling.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- #77 updates the php-http/guzzle6-adapter dependency to also allow 2.0 versions, allowing the tool to coexist with other tools depending on that later version. Functionally, there are no changes.
- Nothing.
- Nothing.
- Nothing.
-
#76 adds "milestone" commands for listing, creating, and closing milestones:
milestone:list
will list milestones.milestone:create
will create a milestone, optionally with a description.milestone:close
will close a milestone.
-
#76 adds
--create-milestone
and--create-milestone-with-name
options to thebump:*
andunreleased:promote
commands, allowing them to optionally create a milestone on completion. -
#76 adds a new provider interface,
MilestoneAwareProviderInterface
, for indicating that a provider is capable of manipulating project milestones.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
-
#75 adds the ability to correctly parse, show, and manipulate a changelog marked Unreleased in your changelog file, per the 1.0.0 version of the Keep-A-Changelog spec.
-
#75 adds the command
unreleased:create
, allowing you to create an Unreleased release in your changelog. -
#75 adds the command
unreleased:promote <version> [--date|-d]
, allowing you to rename an Unreleased release to the given version, and set the release date (defaulting to the current date).
-
#73 adds a new listener to the
version:tag
command,VerifyVersionHasReleaseDateListener
. This listener ensures that you cannot tag a release that has not had its release date set in the changelog yet, aborting if the date is not present. -
#74 changes the behavior of
version:tag
slightly, by adding a check to see if we have a clean checkout currently. If not, it will abort the operation. Users can pass a new--force
option to force the operation to continue.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
-
#72 expands the regexp used to validate a version string to allow including a hyphen (
-
) between the version and stability, as well as a period (.
) between the stability and revision identifier. As an example, the version "1.2.3-rc.1" will now be considered valid by the keep-a-changelog tool. -
#71 changes the values of the constants
BumpCommand::BUMP_BUGFIX
and::BUMP_PATCH
to be "patch" instead of "bugfix", making them better align with the verbiage in version 2.0 of the Keep A Changelog specification. Usage of the tool does not change, however.
- Nothing.
- Nothing.
- Nothing.
- #67 adds self-contained PHAR files to new releases.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Adds PHP 7.4 support.
- #63 adds support for symfony/console v5 releases.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- #62 fixes how the command handles the return value when prompting for a remote to use. Previously, it was using the index, instead of looking up the remote name by the index, which would lead to errors.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- #61 fixes an issue that presented when the tag name associated with a release differs from the version.
-
#56 adds a new command,
changelog:edit-links
, to allow editing reference links in the changelog file. -
#57 [DEVELOPERS] This patch adds two traits for listeners that use the
Editor
orChangelogEditor
; these traits facilitate testing.
- Nothing.
- Nothing.
- Nothing.
- #56 / #38 fixes parsing of the changelog file to ensure it recognizes versions using the reference link format.
-
Configuration is now a first-class citizen within the tooling, and is merged (in order of ascending priority) from each of package defaults,
$XDG_CONFIG_HOME/keep-a-changelog.ini
(usually$HOME/.config/keep-a-changelog.ini
),$PWD/.keep-a-changelog.ini
(the directory in which you run the command), and command options. Configuration has the following format:[defaults] changelog_file = CHANGELOG.md provider = github remote = origin package = some/package ; local ($PWD) config only [providers] github[class] = Phly\KeepAChangelog\Provider\GitHub github[token] = authorization-token ; global config only github[url] = https://some-custom-install.github.com gitlab[class] = Phly\KeepAChangelog\Provider\GitLab gitlab[token] = authorization-token ; global config only gitlab[url] = https://some-custom-install.gitlab.com
Full details can be found in the README.md file.
-
Adds the command
config:edit
, which allows editing a global or local configuration file within your specified editor (either$EDITOR
or the value of the--editor
option). -
Adds the command
config:remove
, which allows removing either a global or local configuration file. -
Adds the command
config:show
, which allows showing the contents of either a global or local configuration file, or the merged values of the two. -
The
version:edit
command now allows you to specify the specific changelog version you wish to edit. If you do not specify a version, it assumes the most recent listed. -
The various
entry:*
commands now allow you to specify the specific changelog version (via--version
) to which to add the new entry, instead of only allowing adding to the most recent.
-
The tooling now requires PHP 7.2, as it consumes and implements PSR-14 (Event Dispatcher) internally.
-
Configuration has changed, including where it is stored. If you were using configuration previously, generate new configuration using
keep-a-changelog config:create --global
, and then copy relevant details from your$HOME/.keep-a-changelog/config.ini
to the new configuration file (you can usekeep-a-changelog config:edit --global
to edit the new file). -
When calling
version:release
or the variousentry:*
commands, package names can now be autodiscovered via one of:- The local configuration file.
- A Composer
composer.json
file (via thename
key). - An NPM
package.json
file (via thename
key).
This means you likely no longer need to specify the package name when pushing a release via the tooling.
-
When calling
version:tag
, git remote names can now be specified via one of:- The global configuration file.
- The local configuration file.
- Command-line option.
- Autodiscovery via
.git/config
, using the configured provider and package name.
-
The
--file|-f
global option for specifying a changelog file is now--changelog|-c
. -
The
version:release
command now makes the<package>
argument a--package
option. -
The
version:release
command now allows releasing any version; this can be useful when creating historical releases. -
The internals were completely rewritten. If you were extending or consuming any classes previously, they are likely either removed, renamed, or rewritten at this time. In particular, all commands are now under sub-namespaces, and dispatch events instead of performing logic internally. This approach should make understanding the workflow of individual commands simpler.
- Nothing.
-
Removes the
config
command; useconfig:create
instead. -
Removes the
edit
command; useversion:edit
instead. -
Removes the
new
command; usechangelog:new
instead. -
Removes the
ready
command; useversion:ready
instead. -
Removes the
release
command; useversion:release
instead. -
Removes the
tag
command; useversion:tag
instead.
- Nothing.
- Nothing.
- #48 adds the string
:
to then end of all question prompts to make them more readable.
- Nothing.
- Nothing.
-
#52 removes the
Throwable $e
argument toMissingTagException::forUnverifiedTagOnGithub()
as noThrowable
was available in the context in which it was called. -
#47 fixes a bug during global configuration file creation that occurs when the configuration directory does not exist.
-
#46 adds the
--provider-domain
option to each of theentry:*
andrelease
commands, and the correspondingdomain
key in.keep-a-changelog.ini
files. The option can be used to specify a custom domain for your chosen provider; it will be used to determine which git remote to push tags to, to generate links for changelog entries, and to make API calls to the provider. -
#44 adds the command
bump:patch
as an alias tobump
/bump:bugfix
. -
#33 adds support for usage with the symfony/console 3.4 series.
-
#41 adds the command
version:list
, which will list all versions and associated release dates from the changelog file. -
#41 adds the command
version:remove <version>
, which will remove the changelog entry for the provided version, if it exists. -
#41 adds the command
version:show <version>
, which will show the full release entry in the changelog for the provided version, along with its release date.
-
#41 aliases the
edit
command toversion:edit
. -
#41 adds an optional
<version>
argument to theversion:edit
command, allowing users to edit a specific release version entry.
- #41 deprecates the
edit
command in favor ofversion:edit
.
- Nothing.
-
#45 updates the
GitHub
provider such that it now verifies that a signed commit matching the release has been pushed before attempting to create a release. -
#45 updates the
release
command to no longer hard-code using "origin" as the remote, and to instead lookup the remote based on the provider and package. When multiple remotes match (which should not happen), it will prompt the user to choose one, or abort. -
#43 fixes the markup used to generate a link to a merge request when using GitLab as your provider. In that scenario, the markup
[!{merge number}]
will now be used instead of[#{merge number}]
.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
-
#32 fixes the order of arguments to the
getToken()
method invoked withinReleaseCommand
, resolving a syntax error. -
#31 fixes a syntax error in the
release
command. -
#30 fixes the
EntryCommand
, adding a missingglobal
(-g
) option.
-
#24 adds a GitLab repository provider. You can specify the new provider via a new
--provider gitlab
option to either thetag
orrelease
commands. -
#27 adds the ability to create either a local or global config file containing both the preferred/default provider to use, and its associated token. Usage is
keep-a-changelog config
, optionally with a--global
or-g
flag. The command will then prompt you for the provider and token.
- #27 modifies each of the
release
andentry:*
commands to use the appropriate global or local configuration file, if found, to determine the provider and/or token to use; if either of the--token
or--provider
options are provided during invocation, those will override the values from configuration.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- #22 modifies how PR links are generated in several ways:
- If the provided package name does not result in a valid PR link, it raises an excepion.
- If the package name discovered in the
composer.json
does not result in a valid PR link, it then - Probes the git remotes to find the first that results in a valid package link.
In each case, it performs a
HEAD
request on the generated link to determine if it is valid, following redirects as encountered.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- #21 fixes an issue with releasing that occurs when the token file contains any additional whitespace (such as a trailing EOL character), resolving problems with creating a release via the GitHub API.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
-
Fixes the exception message emitted when
new
is called and a changelog file already exists to properly mention the--overwrite
, not the--override
, option. -
#20 fixes detection of a changelog when only one changelog entry is present in the file.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- #19 fixes the
new
command to correctly detect the--overwrite
option instead of the--override
option.
- #16 adds functionality to prevent an existing changelog
from being overwritten by the
new
command, and adds an--overwrite
option to allow overwriting the file.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
-
#14 adds a new global option,
--file
(or-f
), to allow specifying an alternate changelog file to create or modify. -
#12 adds a new command, "bump:to-version". This command will add a new changelog entry for the version specified on the command line at the top of the changelog file.
-
#11 Adds a new command, "new", for creating a new changelog file. The file will be created in CHANGELOG.md in the current directory unless a --file option is provided. The initial version will be 0.1.0 unless an --initial-version option is provided.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
-
Fixes a problem with the edit command successful message template, switching from
<success>
(which does not exist) to<info>
. -
#10 adds a dependency on ocramius/package-versions in order to ensure that the script version is auto-updated for each tag.
-
Adds a new command, "edit", which will open the most recent changelog entry in an editor. By default, it uses
$EDITOR
, unless an alternate editor is provided via the--editor
option. It will edit the fileCHANGELOG.md
unless an alternate file is provided via the--file
option. -
Adds a new command, "ready", which will set the date for the first un-dated changelog entry in the CHANGELOG.md. You may also pass the --date or -d option to specify an alternate date, or to use a date formate other than YYYY-MM-DD.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Sets the release version for the tool, bumping it to 1.1.2 from 1.0.3dev1.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Fixes the dev-master branch alias in the package definition to ensure the package validates.
-
Adds the command "entry:fixed", for adding an entry to the Fixed section of the current changelog.
-
Adds the command "entry:removed", for adding an entry to the Removed section of the current changelog.
-
Adds the command "entry:deprecated", for adding an entry to the Deprecated section of the current changelog.
-
Adds the command "entry:changed", for adding an entry to the Changed section of the current changelog.
-
Adds the command "entry:added", for adding an entry to the Added section of the current changelog.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Fixes an autoloading issue when running globally.
- Nothing.
- Nothing.
- Nothing.
- Removes dependency on ocramius/package-versions.
- Fixes error that occurs when running globally, due to a dependency that only works when running in a local package.
Initial release.
- Nothing.
- Nothing.
- Nothing.
- Nothing.
- Nothing.