mirror of
https://github.com/TECHNOFAB11/bump2version.git
synced 2025-12-11 23:50:08 +01:00
Compare commits
3 commits
| Author | SHA1 | Date | |
|---|---|---|---|
| f6a50bbda0 | |||
| 2136a99b31 | |||
| a576cb735f |
7 changed files with 48 additions and 28 deletions
|
|
@ -1,4 +1,4 @@
|
|||
current_version = "1.0.2"
|
||||
current_version = "1.1.1"
|
||||
commit = true
|
||||
tag = true
|
||||
message = "chore: bump {current_version} → {new_version}"
|
||||
|
|
@ -11,8 +11,8 @@ type = "string"
|
|||
values = ["alpha", "beta", "stable"]
|
||||
|
||||
[file."Cargo.toml"]
|
||||
format = 'version = "{version}"'
|
||||
formats = ['version = "{version}"']
|
||||
|
||||
[file."Cargo.lock"]
|
||||
format = """name = "bump2version"
|
||||
version = "{version}""""
|
||||
formats = ["""name = "bump2version"
|
||||
version = "{version}""""]
|
||||
|
|
|
|||
2
Cargo.lock
generated
2
Cargo.lock
generated
|
|
@ -61,7 +61,7 @@ dependencies = [
|
|||
|
||||
[[package]]
|
||||
name = "bump2version"
|
||||
version = "1.0.2"
|
||||
version = "1.1.1"
|
||||
dependencies = [
|
||||
"clap",
|
||||
"regex",
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
[package]
|
||||
name = "bump2version"
|
||||
version = "1.0.2"
|
||||
version = "1.1.1"
|
||||
edition = "2021"
|
||||
description = "⬆️ Easily manage version numbers in your projects."
|
||||
license = "MIT"
|
||||
|
|
|
|||
|
|
@ -24,6 +24,10 @@ pub(crate) struct Cli {
|
|||
#[arg(short = 'n', long = "dry-run", default_value_t = false)]
|
||||
pub(crate) dry_run: bool,
|
||||
|
||||
/// Current version
|
||||
#[arg(long = "current-version", value_name = "VERSION")]
|
||||
pub(crate) current_version: Option<String>,
|
||||
|
||||
/// New version that should be in the files.
|
||||
#[arg(long = "new-version", value_name = "VERSION")]
|
||||
pub(crate) new_version: Option<String>,
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@ use serde_derive::Deserialize;
|
|||
|
||||
#[derive(Debug, Clone, Deserialize)]
|
||||
pub(crate) struct Config {
|
||||
pub(crate) current_version: String,
|
||||
pub(crate) current_version: Option<String>,
|
||||
pub(crate) message: Option<String>,
|
||||
pub(crate) commit: bool,
|
||||
pub(crate) tag: bool,
|
||||
|
|
@ -35,8 +35,8 @@ pub(crate) struct Part {
|
|||
|
||||
#[derive(Debug, Clone, Deserialize)]
|
||||
pub(crate) struct File {
|
||||
/// Format to replace, eg. `current_version = "{version}"`
|
||||
pub(crate) format: String,
|
||||
/// Formats to replace, eg. `current_version = "{version}"`
|
||||
pub(crate) formats: Vec<String>,
|
||||
}
|
||||
|
||||
fn default_parse() -> String {
|
||||
|
|
|
|||
47
src/main.rs
47
src/main.rs
|
|
@ -38,12 +38,23 @@ fn main() -> Result<(), Box<dyn std::error::Error>> {
|
|||
}
|
||||
};
|
||||
|
||||
let current_version = config.current_version.clone();
|
||||
|
||||
let attempted_new_version = args
|
||||
.new_version
|
||||
let current_version = args
|
||||
.current_version
|
||||
.clone()
|
||||
.or(attempt_version_bump(args.clone(), config.clone()));
|
||||
.or(config.current_version.clone());
|
||||
|
||||
if current_version.is_none() {
|
||||
error!("No current version could be determined, either set in config or pass as arg");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
let current_version = current_version.unwrap();
|
||||
|
||||
let attempted_new_version = args.new_version.clone().or(attempt_version_bump(
|
||||
args.clone(),
|
||||
config.clone(),
|
||||
current_version.clone(),
|
||||
));
|
||||
|
||||
if attempted_new_version.is_some() {
|
||||
let new_version = attempted_new_version.clone().unwrap();
|
||||
|
|
@ -84,22 +95,24 @@ fn main() -> Result<(), Box<dyn std::error::Error>> {
|
|||
// Update version in specified files
|
||||
info!(amount = &files.len(), "Updating version in files");
|
||||
for path in files.clone() {
|
||||
let content = fs::read_to_string(path)?;
|
||||
let format = &config_files.get(path).unwrap().format.clone();
|
||||
let mut content = fs::read_to_string(path)?;
|
||||
let formats = &config_files.get(path).unwrap().formats.clone();
|
||||
|
||||
let old_line = format.replace("{version}", ¤t_version);
|
||||
if !content.contains(&old_line) {
|
||||
warn!(
|
||||
current_version,
|
||||
path, "Did not find current version in file"
|
||||
);
|
||||
for format in formats {
|
||||
let old_line = format.replace("{version}", ¤t_version);
|
||||
if !content.contains(&old_line) {
|
||||
warn!(
|
||||
current_version,
|
||||
path, "Did not find current version in file"
|
||||
);
|
||||
}
|
||||
|
||||
let new_line = format.replace("{version}", &new_version);
|
||||
content = content.replace(&old_line, &new_line);
|
||||
}
|
||||
|
||||
let new_line = format.replace("{version}", &new_version);
|
||||
let updated_content = content.replace(&old_line, &new_line);
|
||||
|
||||
if !dry_run {
|
||||
fs::write(path, updated_content)?;
|
||||
fs::write(path, content)?;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -6,7 +6,11 @@ use std::collections::HashMap;
|
|||
use std::ops::Index;
|
||||
use tracing::{error, trace};
|
||||
|
||||
pub(crate) fn attempt_version_bump(args: Cli, config: Config) -> Option<String> {
|
||||
pub(crate) fn attempt_version_bump(
|
||||
args: Cli,
|
||||
config: Config,
|
||||
current_version: String,
|
||||
) -> Option<String> {
|
||||
let parse_regex = config.parse;
|
||||
let regex = match Regex::new(&parse_regex) {
|
||||
Ok(r) => r,
|
||||
|
|
@ -16,7 +20,6 @@ pub(crate) fn attempt_version_bump(args: Cli, config: Config) -> Option<String>
|
|||
}
|
||||
};
|
||||
|
||||
let current_version = config.current_version;
|
||||
let mut parsed: HashMap<String, String> = HashMap::new();
|
||||
|
||||
if let Some(captures) = regex.captures(¤t_version) {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue