changelog remove
Remove changelog YAML files from a directory.
You can use either profile-based or command-option-based removal:
- Profile-based:
docs-builder changelog remove <profile> <version|promotion-report>— uses the samebundle.profilesconfiguration aschangelog bundleto determine which changelogs to remove. - Option-based:
docs-builder changelog remove --products "..."(or--prs,--issues,--all,--release-version,--report) — specify the filter directly.
These modes are mutually exclusive. You can't combine a profile argument with the command filter options.
Before deleting anything, the command checks whether any of the matching files are referenced by unresolved bundles, to prevent silently breaking the {changelog} directive.
For more context, go to Create and bundle changelogs > Remove changelog files.
docs-builder changelog remove [arguments...] [options...] [-h|--help]
These arguments apply to profile-based removal:
[0] <string?>- Profile name from
bundle.profilesin the changelog configuration file. - For example, "elasticsearch-release".
- When specified, the second argument is the version, promotion report URL, or URL list file.
[1] <string?>- Version number, promotion report URL/path, or URL list file.
- For example,
9.2.0,https://buildkite.../promotion-report.html, or/path/to/prs.txt. - See Profile argument types for details on accepted formats.
[2] <string?>- Optional: Promotion report URL/path or URL list file when the second argument is a version string.
- When provided,
[1]must be a version string and[2]is the PR/issue filter source. - For example,
docs-builder changelog remove serverless-release 2026-02 ./promotion-report.html.
For command-option-based removal, only one filter option can be specified: --all, --products, --prs, --issues, --release-version, or --report.
--all- Remove all changelog files in the directory.
- Cannot be combined with a profile argument.
--bundles-dir <string?>- Optional: Override the directory scanned for bundles during the dependency check.
- When not specified, the directory is resolved in order:
bundle.output_directoryfrom the changelog configuration, then{changelog-dir}/bundles, then{changelog-dir}/../bundles. - Not allowed with a profile argument. In profile mode, the same automatic discovery applies.
--config <string?>- Optional: Path to the changelog configuration file.
- Defaults to
docs/changelog.yml. - Not allowed with a profile argument. In profile mode, the configuration is discovered automatically.
--directory <string?>- Optional: The directory that contains the changelog YAML files.
- When not specified, falls back to
bundle.directoryfrom the changelog configuration, then the current working directory. - Not allowed with a profile argument. In profile mode, the same fallback applies (starting from
bundle.directory). --dry-run- Print the files that would be removed and any bundle dependency conflicts, without deleting anything.
- Valid in both profile and command-option-based mode.
--force- Proceed with removal even when files are referenced by unresolved bundles.
- Emits a warning per dependency instead of blocking.
- Valid in both profile and command-option-based mode.
--issues <string[]?>- Filter by issue URLs (comma-separated), or a path to a newline-delimited file.
- Can be specified multiple times.
- When using a file, every line must be a fully-qualified GitHub issue URL. Bare numbers and short forms are not allowed in files.
- Cannot be combined with a profile argument.
--owner <string?>- Optional: The GitHub repository owner, which is used when pull requests or issues are specified as numbers.
- Precedence:
--ownerflag >bundle.ownerinchangelog.yml>elastic. - Cannot be combined with a profile argument.
--products <List<ProductInfo>?>- Filter by products in format
"product target lifecycle, ..." - Cannot be combined with a profile argument.
- All three parts (product, target, lifecycle) are required but can be wildcards (
*). Multiple comma-separated values are combined with OR: a changelog is removed if it matches any of the specified product/target/lifecycle combinations. For example:
"elasticsearch 9.3.0 ga"— exact match"cloud-serverless 2025-12-02 ga, cloud-serverless 2025-12-06 beta"— remove changelogs for either cloud-serverless 2025-12-02 ga or cloud-serverless 2025-12-06 beta"elasticsearch * *"— all elasticsearch changelogs"* 9.3.* *"— any product with a target starting with9.3."* * *"— all changelogs (equivalent to--all)
--prs <string[]?>- Filter by pull request URLs (comma-separated), or a path to a newline-delimited file.
- Can be specified multiple times.
- When using a file, every line must be a fully-qualified GitHub PR URL. Bare numbers and short forms are not allowed in files.
- Cannot be combined with a profile argument.
--release-version <string?>- GitHub release tag to use as a source of pull requests (for example,
"v9.2.0"or"latest"). - When specified, the command fetches the release from GitHub, parses PR references from the release notes, and use it as the removal filter. Only automated GitHub release notes (the default format or Release Drafter format) are supported at this time.
- Requires repo (
--repoorbundle.repoinchangelog.yml) and owner (--ownerflag >bundle.ownerinchangelog.yml>elastic) details. - Requires a
GITHUB_TOKENorGH_TOKENenvironment variable (or an activeghlogin). --repo <string?>- The GitHub repository name, which is required when pull requests or issues are specified as numbers or when using
--release-version. - Precedence:
--repoflag >bundle.repoinchangelog.yml. - Cannot be comined with a profile argument.
--report <string?>- Filter by pull requests extracted from a promotion report. Accepts a URL or a local file path.
- Exactly one filter option must be specified:
--all,--products,--prs,--issues, or--report. - Not allowed with a profile argument.
Both modes use the same ordered fallback to locate changelog YAML files and existing bundles.
Changelog files directory (where changelog YAML files are read from):
| Priority | Profile-based | Option-based |
|---|---|---|
| 1 | bundle.directory in changelog.yml |
--directory CLI option |
| 2 | Current working directory | bundle.directory in changelog.yml |
| 3 | — | Current working directory |
Bundles directory (scanned for existing bundles during the dependency check):
| Priority | Both modes |
|---|---|
| 1 | --bundles-dir CLI option (command-option-based only) |
| 2 | bundle.output_directory in changelog.yml |
| 3 | {changelog-dir}/bundles |
| 4 | {changelog-dir}/../bundles |
"Current working directory" means the directory you are in when you run the command (pwd).
Setting bundle.directory and bundle.output_directory in changelog.yml is recommended so you don't need to rely on running the command from a specific directory.
When a changelog.yml configuration file defines bundle.profiles, you can use those same profiles with changelog remove to remove exactly the changelogs that would be included in a matching bundle.
Profile-based commands discover the changelog configuration automatically (no --config flag): they look for changelog.yml in the current directory, then docs/changelog.yml. If neither file is found, the command returns an error with instructions to run docs-builder changelog init or to re-run from the folder where the file exists.
For example, if your configuration file defines:
bundle:
profiles:
elasticsearch-release:
products: "elasticsearch {version} {lifecycle}"
output: "elasticsearch-{version}.yaml"
You can remove the matching changelogs with:
docs-builder changelog remove elasticsearch-release 9.2.0 --dry-run
This removes changelogs for elasticsearch 9.2.0 ga — the same set that docs-builder changelog bundle elasticsearch-release 9.2.0 would include.
The output_products, repo, owner, and hide_features fields are not relevant to changelog removal and are ignored.
You can also pass a promotion report URL or file path, in which case the command removes changelogs that have prs that match the report.
The following commands perform the same task with and without a profile:
docs-builder changelog remove serverless-report ./promotion-report.html
docs-builder changelog remove \
--report ./promotion-report.html
Alternatively, use a newline delimited text file that lists pull request or issue URLs:
docs-builder changelog remove serverless-report ./prs.txt
You can use --release-version to fetch pull request references directly from GitHub release notes and use them as the removal filter.
This mirrors the equivalent --release-version option on changelog bundle and is useful when cleaning up after a release-based bundle.
docs-builder changelog remove \
--release-version v1.34.0 \
--repo apm-agent-dotnet --owner elastic
The repo and owner used to fetch the release follow the same precedence as changelog bundle:
- Repo:
--repoflag >bundle.repoinchangelog.yml(one source is required) - Owner:
--ownerflag >bundle.ownerinchangelog.yml>elastic
Use --dry-run to preview which files would be deleted before committing:
docs-builder changelog remove \
--release-version v1.34.0 \
--dry-run
Pass latest to target the most recent release:
docs-builder changelog remove \
--release-version latest \
--dry-run
--release-version requires a GITHUB_TOKEN or GH_TOKEN environment variable (or an active gh login) to fetch release details from the GitHub API.