From 03a99351648173aa12def1a8f9b9d9ddfe45bbc9 Mon Sep 17 00:00:00 2001 From: Casey Rodarmor Date: Tue, 7 Apr 2020 22:21:59 -0700 Subject: [PATCH] Skip fixup commits in changelog This change Makes the changelog generator ignore fixup commits. `git commit --fixup` can be used to mark that a commit should be squashed before merging, which can be done automatically with `git rebase --autosquash`. Fixup commits have a summary that starts with `fixup!` type: development --- .github/workflows/build.yaml | 10 +++++----- CHANGELOG.md | 5 ++++- Cargo.lock | 28 ++++++++++++++-------------- bin/changelog/src/changelog.rs | 34 +++++++++++++++++++++------------- bin/changelog/src/common.rs | 5 +++-- bin/changelog/src/entry.rs | 2 +- bin/changelog/src/kind.rs | 32 +++++++++++++++++++++++++++++++- bin/changelog/src/metadata.rs | 15 --------------- bin/changelog/src/opt.rs | 6 ++++++ justfile | 10 ++++++++-- 10 files changed, 93 insertions(+), 54 deletions(-) diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index 4594789..42e7877 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -90,20 +90,20 @@ jobs: profile: minimal components: rustfmt - - name: Format + - name: Check Formatting run: cargo +nightly fmt --all -- --check - - name: Completion Scripts + - name: Check Completion Scripts if: matrix.os != 'windows-latest' run: | ./bin/generate-completions - git diff --no-ext-diff --quiet --exit-code + git diff --no-ext-diff --exit-code - - name: Readme + - name: Check Readme Table of Contents if: matrix.os != 'windows-latest' run: | cargo run --package update-readme toc - git diff --no-ext-diff --quiet --exit-code + git diff --no-ext-diff --exit-code - name: Install `mdbook` uses: peaceiris/actions-mdbook@v1 diff --git a/CHANGELOG.md b/CHANGELOG.md index 9428e5d..8dc2c2b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,7 +4,10 @@ Changelog UNRELEASED - 2020-04-08 ----------------------- -- :zap: [`xxxxxxxxxxxx`](https://github.com/casey/intermodal/commits/master) Make changelog generator strict ([#341](https://github.com/casey/intermodal/pull/341)) - _Casey Rodarmor _ +- :wrench: [`xxxxxxxxxxxx`](https://github.com/casey/intermodal/commits/master) Skip fixup commits in changelog - _Casey Rodarmor _ +- :art: [`a395052f7c22`](https://github.com/casey/intermodal/commit/a395052f7c226a934cf1b0d75294b1a3146cbeae) Deduplicate progress style string - _Casey Rodarmor _ +- :wrench: [`db2a2ac4f556`](https://github.com/casey/intermodal/commit/db2a2ac4f556e7a1a450f9a18d212f082d18fb9d) Refactor demo recipe in justfile into multiple recipes - _Casey Rodarmor _ +- :zap: [`92748f9fd4e6`](https://github.com/casey/intermodal/commit/92748f9fd4e6e65c25e82f2a6e41a0b9b82cf4dd) Make changelog generator strict ([#341](https://github.com/casey/intermodal/pull/341)) - _Casey Rodarmor _ - :wrench: [`c33446b48135`](https://github.com/casey/intermodal/commit/c33446b481351009fc16335cbcd66ff2c2b7985e) Generate changelog from git history ([#337](https://github.com/casey/intermodal/pull/337)) - Fixes [#336](https://github.com/casey/intermodal/issues/336) - _Casey Rodarmor _ - :art: [`6edab1fa3fa8`](https://github.com/casey/intermodal/commit/6edab1fa3fa8461ac4ca02466a04b0f14e42dfc0) Use `TestEnv::assert_ok` everywhere - Fixes [#330](https://github.com/casey/intermodal/issues/330) - _Casey Rodarmor _ - :zap: [`8e3f5516aff8`](https://github.com/casey/intermodal/commit/8e3f5516aff8c89289203a2bc1b46505410c5f1f) Use attractive paths in user-facing messages - Fixes [#252](https://github.com/casey/intermodal/issues/252), [#332](https://github.com/casey/intermodal/issues/332) - _Casey Rodarmor _ diff --git a/Cargo.lock b/Cargo.lock index 0e8868d..a7b03db 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -369,9 +369,9 @@ dependencies = [ [[package]] name = "hermit-abi" -version = "0.1.8" +version = "0.1.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1010591b26bbfe835e9faeabeb11866061cc7dcebffd56ad7d0942d0e61aefd8" +checksum = "725cf19794cf90aa94e65050cb4191ff5d8fa87a498383774c47b332e3af952e" dependencies = [ "libc", ] @@ -604,9 +604,9 @@ checksum = "77af24da69f9d9341038eba93a073b1fdaaa1b788221b00a69bce9e762cb32de" [[package]] name = "openssl-sys" -version = "0.9.54" +version = "0.9.55" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1024c0a59774200a555087a6da3f253a9095a5f344e353b212ac4c8b8e450986" +checksum = "7717097d810a0f2e2323f9e5d11e71608355e24828410b55b9d4f18aa5f9a5d8" dependencies = [ "autocfg", "cc", @@ -692,9 +692,9 @@ dependencies = [ [[package]] name = "proc-macro2" -version = "1.0.9" +version = "1.0.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6c09721c6781493a2a492a96b5a5bf19b65917fe6728884e7c44dd0c60ca3435" +checksum = "df246d292ff63439fea9bc8c0a270bed0e390d5ebd4db4ba15aba81111b5abe3" dependencies = [ "unicode-xid", ] @@ -899,9 +899,9 @@ checksum = "5c2fb2ec9bcd216a5b0d0ccf31ab17b5ed1d627960edff65bbe95d3ce221cefc" [[package]] name = "snafu" -version = "0.6.3" +version = "0.6.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "48492e4f51c6e679217e80c11290edfdedf3133e358f4f432a6296f4c820f95b" +checksum = "b1ec0ae2ed980f26e1ad62e717feb01df90731df56887b5391a2c79f9f6805be" dependencies = [ "doc-comment", "snafu-derive", @@ -909,9 +909,9 @@ dependencies = [ [[package]] name = "snafu-derive" -version = "0.6.3" +version = "0.6.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b5d1c41856cbfa99befda5034c72539dd9d7dd6f3e61058bdb804ac40715bc2a" +checksum = "0ec32ba84a7a86aeb0bc32fd0c46d31b0285599f68ea72e87eff6127889d99e1" dependencies = [ "proc-macro2", "quote", @@ -1051,9 +1051,9 @@ dependencies = [ [[package]] name = "termios" -version = "0.3.1" +version = "0.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "72b620c5ea021d75a735c943269bb07d30c9b77d6ac6b236bc8b5c496ef05625" +checksum = "6f0fcee7b24a25675de40d5bb4de6e41b0df07bc9856295e7e2b3a3600c400c2" dependencies = [ "libc", ] @@ -1219,9 +1219,9 @@ checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6" [[package]] name = "winapi-util" -version = "0.1.3" +version = "0.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4ccfbf554c6ad11084fb7517daca16cfdcaccbdadba4fc336f032a8b12c2ad80" +checksum = "fa515c5163a99cc82bab70fd3bfdd36d827be85de63737b40fcef2ce084a436e" dependencies = [ "winapi 0.3.8", ] diff --git a/bin/changelog/src/changelog.rs b/bin/changelog/src/changelog.rs index 5cf842d..c61ecf5 100644 --- a/bin/changelog/src/changelog.rs +++ b/bin/changelog/src/changelog.rs @@ -14,27 +14,35 @@ impl Changelog { let mut head = true; loop { - let manifest_bytes = current - .tree()? - .get_path("Cargo.toml".as_ref())? - .to_object(&repo)? - .as_blob() - .unwrap() - .content() - .to_vec(); + let summary_bytes = current + .summary_bytes() + .ok_or_else(|| anyhow!("Commit had no summary"))?; - let manifest = Manifest::from_slice(&manifest_bytes)?; + let summary = String::from_utf8_lossy(summary_bytes); - let entry = Entry::new(¤t, manifest.package.unwrap().version.as_ref(), head)?; + if !summary.starts_with("fixup!") { + let manifest_bytes = current + .tree()? + .get_path("Cargo.toml".as_ref())? + .to_object(&repo)? + .as_blob() + .unwrap() + .content() + .to_vec(); + + let manifest = Manifest::from_slice(&manifest_bytes)?; + + let entry = Entry::new(¤t, manifest.package.unwrap().version.as_ref(), head)?; + + entries.push(entry); + } head = false; - entries.push(entry); - match current.parent_count() { 0 => break, 1 => current = current.parent(0)?, - count => panic!("Commit has {} parents", count), + _ => throw!(anyhow!("Commit had multiple parents!")), } } diff --git a/bin/changelog/src/common.rs b/bin/changelog/src/common.rs index f9cd3ce..e9ceb1b 100644 --- a/bin/changelog/src/common.rs +++ b/bin/changelog/src/common.rs @@ -8,11 +8,12 @@ pub(crate) use std::{ pub(crate) use anyhow::{anyhow, Error}; pub(crate) use cargo_toml::Manifest; pub(crate) use chrono::{DateTime, NaiveDateTime, Utc}; -pub(crate) use fehler::throws; +pub(crate) use fehler::{throw, throws}; pub(crate) use git2::{Commit, Repository}; pub(crate) use serde::{Deserialize, Serialize}; pub(crate) use structopt::StructOpt; -pub(crate) use strum_macros::IntoStaticStr; +pub(crate) use strum::VariantNames; +pub(crate) use strum_macros::{EnumVariantNames, IntoStaticStr}; pub(crate) use url::Url; pub(crate) use crate::{ diff --git a/bin/changelog/src/entry.rs b/bin/changelog/src/entry.rs index bc4906f..dd8b548 100644 --- a/bin/changelog/src/entry.rs +++ b/bin/changelog/src/entry.rs @@ -58,7 +58,7 @@ impl Display for Entry { write!( f, "{} [`{}`]({}) {}", - self.metadata.emoji(), + self.metadata.kind.emoji(), shorthash, url, self.summary diff --git a/bin/changelog/src/kind.rs b/bin/changelog/src/kind.rs index 579b15c..f299fc2 100644 --- a/bin/changelog/src/kind.rs +++ b/bin/changelog/src/kind.rs @@ -1,13 +1,25 @@ use crate::common::*; #[derive( - Deserialize, Serialize, Debug, Clone, Copy, Eq, PartialEq, Ord, PartialOrd, IntoStaticStr, + Deserialize, + Serialize, + Debug, + Clone, + Copy, + Eq, + PartialEq, + Ord, + PartialOrd, + IntoStaticStr, + EnumVariantNames, )] #[serde(rename_all = "kebab-case")] +#[strum(serialize_all = "kebab-case")] pub(crate) enum Kind { Added, Breaking, Changed, + Dependencies, Development, Distribution, Documentation, @@ -16,3 +28,21 @@ pub(crate) enum Kind { Release, Testing, } + +impl Kind { + pub(crate) fn emoji(self) -> &'static str { + match self { + Self::Added => ":sparkles:", + Self::Breaking => ":boom:", + Self::Changed => ":zap:", + Self::Dependencies => ":arrow_up:", + Self::Development => ":wrench:", + Self::Distribution => ":package:", + Self::Documentation => ":books:", + Self::Fixed => ":bug:", + Self::Reform => ":art:", + Self::Release => ":bookmark:", + Self::Testing => ":white_check_mark:", + } + } +} diff --git a/bin/changelog/src/metadata.rs b/bin/changelog/src/metadata.rs index 57e7714..16b6e08 100644 --- a/bin/changelog/src/metadata.rs +++ b/bin/changelog/src/metadata.rs @@ -27,21 +27,6 @@ impl Metadata { metadata } - - pub(crate) fn emoji(&self) -> &'static str { - match self.kind { - Kind::Added => ":sparkles:", - Kind::Breaking => ":boom:", - Kind::Changed => ":zap:", - Kind::Development => ":wrench:", - Kind::Distribution => ":package:", - Kind::Documentation => ":books:", - Kind::Fixed => ":bug:", - Kind::Reform => ":art:", - Kind::Release => ":bookmark:", - Kind::Testing => ":white_check_mark:", - } - } } impl Default for Metadata { diff --git a/bin/changelog/src/opt.rs b/bin/changelog/src/opt.rs index 82949ce..bbe36ca 100644 --- a/bin/changelog/src/opt.rs +++ b/bin/changelog/src/opt.rs @@ -3,6 +3,7 @@ use crate::common::*; #[derive(StructOpt)] pub(crate) enum Opt { IssueTemplate, + Types, Update, } @@ -10,6 +11,11 @@ impl Opt { #[throws] pub(crate) fn run(self) { match self { + Self::Types => { + for kind in Kind::VARIANTS { + println!("{}", kind) + } + } Self::IssueTemplate => { println!("{}", Metadata::default().to_string()); } diff --git a/justfile b/justfile index e681748..780bdb7 100644 --- a/justfile +++ b/justfile @@ -86,7 +86,7 @@ check-man: man check-minimal-versions: ./bin/check-minimal-versions -check: test clippy lint check-minimal-versions changelog +check: test clippy lint check-minimal-versions changelog-update git diff --no-ext-diff --quiet --exit-code cargo +nightly fmt --all -- --check cargo run --package update-readme toc @@ -116,9 +116,15 @@ publish: publish-check git push github {{version}} cargo publish -changelog: +changelog-update: cargo run --package changelog update +changelog-types: + cargo run --package changelog types + +changelog-issue-template: + cargo run --package changelog issue-template + # record, upload, and render demo animation demo: demo-record demo-upload demo-render