mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-11 09:31:34 +11:00
Start the release script rewrite
This commit is contained in:
parent
74207835fa
commit
57772af416
|
@ -2,12 +2,14 @@
|
||||||
use clap::Command;
|
use clap::Command;
|
||||||
|
|
||||||
mod publish;
|
mod publish;
|
||||||
|
mod release;
|
||||||
|
|
||||||
fn cli() -> Command {
|
fn cli() -> Command {
|
||||||
Command::new("Agb tools")
|
Command::new("Agb tools")
|
||||||
.subcommand_required(true)
|
.subcommand_required(true)
|
||||||
.arg_required_else_help(true)
|
.arg_required_else_help(true)
|
||||||
.subcommand(publish::command())
|
.subcommand(publish::command())
|
||||||
|
.subcommand(release::command())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
@ -15,6 +17,7 @@ fn main() {
|
||||||
|
|
||||||
let result = match matches.subcommand() {
|
let result = match matches.subcommand() {
|
||||||
Some(("publish", arg_matches)) => publish::publish(arg_matches),
|
Some(("publish", arg_matches)) => publish::publish(arg_matches),
|
||||||
|
Some(("release", arg_matches)) => todo!(),
|
||||||
_ => unreachable!("Exhausted list of subcommands and subcommand_required prevents `None`"),
|
_ => unreachable!("Exhausted list of subcommands and subcommand_required prevents `None`"),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
82
tools/src/release.rs
Normal file
82
tools/src/release.rs
Normal file
|
@ -0,0 +1,82 @@
|
||||||
|
pub fn command() -> clap::Command {
|
||||||
|
clap::Command::new("release")
|
||||||
|
.about("Prepares and commits the changes required to release agb")
|
||||||
|
.arg(
|
||||||
|
clap::Arg::new("version")
|
||||||
|
.help("New version to release")
|
||||||
|
.value_parser(version_parser),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq)]
|
||||||
|
struct Version {
|
||||||
|
major: u32,
|
||||||
|
minor: u32,
|
||||||
|
patch: u32,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Version {
|
||||||
|
#[cfg(test)]
|
||||||
|
pub fn new(major: u32, minor: u32, patch: u32) -> Self {
|
||||||
|
Self {
|
||||||
|
major,
|
||||||
|
minor,
|
||||||
|
patch,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, PartialEq, Eq)]
|
||||||
|
struct ParseVersionError;
|
||||||
|
|
||||||
|
impl std::str::FromStr for Version {
|
||||||
|
type Err = ParseVersionError;
|
||||||
|
|
||||||
|
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
||||||
|
let version_array: Vec<_> = s
|
||||||
|
.split('.')
|
||||||
|
.map(|v| v.parse())
|
||||||
|
.collect::<Result<Vec<_>, _>>()
|
||||||
|
.map_err(|_| ParseVersionError)?;
|
||||||
|
|
||||||
|
if version_array.len() > 3 || version_array.is_empty() {
|
||||||
|
return Err(ParseVersionError);
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(Version {
|
||||||
|
major: version_array[0],
|
||||||
|
minor: *version_array.get(1).unwrap_or(&0),
|
||||||
|
patch: *version_array.get(2).unwrap_or(&0),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn version_parser(maybe_version: &str) -> Result<Version, &'static str> {
|
||||||
|
maybe_version.parse().map_err(|_| "Failed to parse version")
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
use std::str::FromStr;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn verify_cli() {
|
||||||
|
command().debug_assert();
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn can_parse_versions() {
|
||||||
|
assert_eq!(Version::from_str("0.1.2").unwrap(), Version::new(0, 1, 2));
|
||||||
|
assert_eq!(Version::from_str("0.1").unwrap(), Version::new(0, 1, 0));
|
||||||
|
assert_eq!(
|
||||||
|
Version::from_str("33.23.4000").unwrap(),
|
||||||
|
Version::new(33, 23, 4000)
|
||||||
|
);
|
||||||
|
|
||||||
|
assert_eq!(Version::from_str("abc").unwrap_err(), ParseVersionError);
|
||||||
|
assert_eq!(Version::from_str("").unwrap_err(), ParseVersionError);
|
||||||
|
assert_eq!(Version::from_str("0.2.4.5").unwrap_err(), ParseVersionError);
|
||||||
|
assert_eq!(Version::from_str("0.2.4a").unwrap_err(), ParseVersionError);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue