Skip to content

Commit

Permalink
feature(config): add migrate-config subcommand
Browse files Browse the repository at this point in the history
Added a subcommand migrate-config to migrate from the old to the new configuration format.
  • Loading branch information
Cyclonit committed Mar 24, 2024
1 parent 18c8077 commit 4cd3f3c
Show file tree
Hide file tree
Showing 5 changed files with 225 additions and 37 deletions.
78 changes: 78 additions & 0 deletions __TODO.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
>>> [changelog]
>>> # A static header for the changelog.
>>> header Option<String> // changelog.header
>>>
>>> # A Tera template to be rendered for each release in the changelog (see https://keats.github.io/tera/docs/#introduction).
>>> body_template Option<String> // changelog.body
>>>
>>> # A Tera template to be rendered as the changelog's footer (see https://keats.github.io/tera/docs/#introduction).
>>> footer_template Option<String> // changelog.footer
>>>
>>> # Whether to remove leading and trailing whitespaces from all lines of the changelog's body.
>>> trim_body_whitespace Option<String> // changelog.trim

>>> # A list of postprocessors using regex to modify the changelog.
>>> postprocessors Option<Vec<TextProcessor>>
>>>
>>> # Whether to exclude changes that do not belong to any group from the changelog.
>>> exclude_ungrouped_changes Option<bool> // git.filter_commits


>>> [release]
>>> # Regex to select git tags that represent releases.
>>> # Example: "v[0-9].*"
>>> tags_pattern String // git.tag_pattern
>>>
>>> # Regex to select git tags that do not represent proper releases. Takes precedence over `release.tags_pattern`.
>>> # Changes belonging to these releases will be included in the next non-skipped release.
>>> # Example: "rc"
>>> skip_tags_pattern String // git.ignore_tags
>>>
>>> # Whether to order releases chronologically or topologically.
>>> # Must be either `time` or `topology`.
>>> order_by Enum: "time" / "topology" // git.topo_order


>>> [commit]
>>> # Whether to order commits newest to oldest or oldest to newest in their group.
>>> # Must be either `newest` or `oldest`.
>>> sort_order Enum: "newest" / "oldest" // git.sort_commits
>>>
>>> # Whether to limit the total number of commits to be included in the changelog.
>>> max_commit_count Option<usize> // git.limit_commits
>>>
>>> # Whether to split commits on newlines, treating each line as an individual commit.
>>> split_by_newline Option<bool> // git.split_commits
>>>
>>> # Regex to select git tags that should be excluded from the changelog.
>>> exclude_tags_pattern String // git.skip_tags
>>>
>>> # A list of preprocessors to modify commit messages using regex prior to further processing.
>>> message_preprocessors Option<Vec<TextProcessor>> // git.commit_preprocessors
>>>
>>> # A list of parsers using regex for extracting external references found in commit messages, and turning them into links. The gemerated links can be used in the body template as `commit.links`.
>>> # Example: "RFC(\\d+)" -> "https://datatracker.ietf.org/doc/html/rfc$1"
>>> link_parsers Option<Vec<LinkParser>> // git.link_parsers
>>>
>>> # Whether to parse commits according to the conventional commits specification.
>>> # Sets the commits' `group` (= `type`), `scope`, `message` (= `description`), `body`, `breaking`, `breaking_description` and `footers`.
>>> parse_conventional_commits Option<bool> // git.conventional_commits

# Whether to fail generating the changelog if the history contains commits that do not match the conventional commits specification.
require_conventional_commits Option<bool>

>>> # Whether to exclude commits that do not match the conventional commits specification from the changelog.
>>> exclude_unconventional_commits Option<bool> // git.filter_unconventional
>>>
>>> # A list of parsers using regex for extracting data from the commit message.
>>> # Sets the commits' `group` and `scope` and can decide to exclude commits from further processing.
>>> commit_parsers Option<Vec<CommitParser>> // git.commit_parsers
>>>
>>> # Whether to prevent breaking changes from being excluded by commit parsers.
>>> retain_breaking_changes Option<bool> // git.protect_breaking_commits


[remote.github]
owner String
repo String
token Option<Secretstring>
52 changes: 52 additions & 0 deletions git-cliff-core/src/config/migrate.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
use crate::error::{
Error,
Result,
};
use clap::Args;
use std::{
fs,
io::Write,
path::PathBuf,
};

/// Migrates configuration files from the old to the new schema.
#[derive(Args, Debug)]
pub struct MigrateArgs {
/// The file to read the original configuration from.
#[arg(long = "in")]
pub in_path: PathBuf,

/// The file to write the migrated configuration to.
#[arg(long = "out")]
pub out_path: PathBuf,
}

/// Migrates configuration files from the old to the new schema.
pub fn run(args: &MigrateArgs) -> Result<()> {
// load the old configuration
if !args.in_path.exists() {
return Err(Error::ArgumentError(format!(
"File {0} does not exist.",
&args.in_path.to_str().unwrap()
)));
}

let old_config =
super::parsing::parse::<super::models_v1::Config>(&args.in_path)?;

// convert to the new config format
let new_config = super::models_v2::Config::from(old_config);
let new_toml = toml::to_string(&new_config).unwrap();

// write the new config file
let mut new_config_file = fs::OpenOptions::new()
.create(true)
.write(true)
.truncate(true)
.open(&args.out_path)?;

new_config_file.write_all(new_toml.as_bytes())?;
new_config_file.flush()?;

Ok(())
}
2 changes: 2 additions & 0 deletions git-cliff-core/src/config/mod.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
/// Provide a command to migrate from old to new configuration.
pub mod migrate;
/// Deprecated Config models for git-cliff.
pub mod models_v1;
/// Current Config models for git-cliff.
Expand Down
Loading

0 comments on commit 4cd3f3c

Please sign in to comment.