diff options
-rw-r--r-- | .github/workflows/release.yml | 2 | ||||
-rw-r--r-- | CHANGELOG.md | 13 | ||||
-rw-r--r-- | Cargo.lock | 84 | ||||
-rw-r--r-- | README.md | 313 | ||||
-rw-r--r-- | src/driver.rs | 10 | ||||
-rw-r--r-- | src/lib.rs | 34 | ||||
-rw-r--r-- | src/main.rs | 13 | ||||
-rw-r--r-- | src/util.rs | 27 |
8 files changed, 253 insertions, 243 deletions
diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 73a5969..2fc4bdb 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -17,7 +17,7 @@ jobs: asset_name: gfold-windows-amd64 - os: macos-latest artifact_name: gfold - asset_name: gfold-macos-amd64 + asset_name: gfold-darwin-amd64 steps: - uses: actions/checkout@v2 - name: Build diff --git a/CHANGELOG.md b/CHANGELOG.md index ccb74c9..65d33c7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,8 +6,19 @@ All changes are from [@nickgerace](https://github.com/nickgerace) unless otherwi The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). ## [Unreleased] +<!-- The latest version contains all changes. --> -The latest version contains all changes. +### Added + +- Dependencies section to CHANGELOG +- `paru` to suggested AUR helpers in README + +### Changed + +- Condense tests into loops where possible +- Label `unpush_check` as an experimental feature +- `macos-amd64` to `darwin-amd64` +- `unpush_check` from `disable` to `enable` ## [0.8.3] - 2020-12-15 @@ -84,9 +84,9 @@ dependencies = [ [[package]] name = "byteorder" -version = "1.3.4" +version = "1.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "08c48aae112d48ed9f069b33538ea9e3e90aa263cfa3d1c24309612b1f7472de" +checksum = "ae44d1a3d5a19df61dd0c8beb138458ac2a53a7ac09eba97d55592540004306b" [[package]] name = "cc" @@ -195,9 +195,9 @@ dependencies = [ [[package]] name = "eyre" -version = "0.6.3" +version = "0.6.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5f29abf4740a4778632fe27a4f681ef5b7a6f659aeba3330ac66f48e20cfa3b7" +checksum = "221239d1d5ea86bf5d6f91c9d6bc3646ffe471b08ff9b0f91c44f115ac969d2b" dependencies = [ "indenter", "once_cell", @@ -215,11 +215,11 @@ dependencies = [ [[package]] name = "getrandom" -version = "0.1.15" +version = "0.1.16" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fc587bc0ec293155d5bfa6b9891ec18a1e330c234f896ea47fbada4cadbe47e6" +checksum = "8fc3cb4d91f53b50155bdcfd23f6a4c39ae1969c2ae85982b135750cccaf5fce" dependencies = [ - "cfg-if 0.1.10", + "cfg-if 1.0.0", "libc", "wasi", ] @@ -238,9 +238,9 @@ dependencies = [ [[package]] name = "git2" -version = "0.13.12" +version = "0.13.17" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca6f1a0238d7f8f8fd5ee642f4ebac4dbc03e03d1f78fbe7a3ede35dcf7e2224" +checksum = "1d250f5f82326884bd39c2853577e70a121775db76818ffa452ed1e80de12986" dependencies = [ "bitflags", "libc", @@ -253,27 +253,27 @@ dependencies = [ [[package]] name = "heck" -version = "0.3.1" +version = "0.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "20564e78d53d2bb135c343b3f47714a56af2061f1c928fdb541dc7b9fdd94205" +checksum = "87cbf45460356b7deeb5e3415b5563308c0a9b057c85e12b06ad551f98d0a6ac" dependencies = [ "unicode-segmentation", ] [[package]] name = "hermit-abi" -version = "0.1.17" +version = "0.1.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5aca5565f760fb5b220e499d72710ed156fdb74e631659e99377d9ebfbd13ae8" +checksum = "322f4de77956e22ed0e5032c359a0f1273f1f7f0d79bfa3b8ffbc730d7fbcc5c" dependencies = [ "libc", ] [[package]] name = "humantime" -version = "2.0.1" +version = "2.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c1ad908cc71012b7bea4d0c53ba96a8cba9962f048fa68d143376143d863b7a" +checksum = "9a3a5bfb195931eeb336b2a7b4d761daec841b97f947d34394601737a7bba5e4" [[package]] name = "idna" @@ -288,15 +288,15 @@ dependencies = [ [[package]] name = "indenter" -version = "0.3.0" +version = "0.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e0bd112d44d9d870a6819eb505d04dd92b5e4d94bb8c304924a0872ae7016fb5" +checksum = "f4d5eb2e114fec2b7fe0fadc22888ad2658789bb7acac4dbee9cf8389f971ec8" [[package]] name = "itoa" -version = "0.4.6" +version = "0.4.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dc6f3ad7b9d11a0c00842ff8de1b60ee58661048eb8049ed33c73594f359d7e6" +checksum = "dd25036021b0de88a0aff6b850051563c6516d0bf53f8638938edbb9de732736" [[package]] name = "jobserver" @@ -315,15 +315,15 @@ checksum = "e2abad23fbc42b3700f2f279844dc832adb2b2eb069b2df918f455c4e18cc646" [[package]] name = "libc" -version = "0.2.81" +version = "0.2.82" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1482821306169ec4d07f6aca392a4681f66c75c9918aa49641a2595db64053cb" +checksum = "89203f3fba0a3795506acaad8ebce3c80c0af93f994d5a1d7a0b1eeb23271929" [[package]] name = "libgit2-sys" -version = "0.12.14+1.1.0" +version = "0.12.18+1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8f25af58e6495f7caf2919d08f212de550cfa3ed2f5e744988938ea292b9f549" +checksum = "3da6a42da88fc37ee1ecda212ffa254c25713532980005d5f7c0b0fbe7e6e885" dependencies = [ "cc", "libc", @@ -361,9 +361,9 @@ dependencies = [ [[package]] name = "log" -version = "0.4.11" +version = "0.4.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4fabed175da42fed1fa0746b0ea71f412aa9d35e76e95e59b192c64b9dc2bf8b" +checksum = "fcf3805d4480bb5b86070dcfeb9e2cb2ebc148adb753c5cca5f884d1d65a42b2" dependencies = [ "cfg-if 0.1.10", ] @@ -394,9 +394,9 @@ checksum = "77af24da69f9d9341038eba93a073b1fdaaa1b788221b00a69bce9e762cb32de" [[package]] name = "openssl-sys" -version = "0.9.59" +version = "0.9.60" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "de52d8eabd217311538a39bba130d7dea1f1e118010fee7a033d966845e7d5fe" +checksum = "921fc71883267538946025deffb622905ecad223c28efbfdef9bb59a0175f3e6" dependencies = [ "autocfg", "cc", @@ -466,9 +466,9 @@ dependencies = [ [[package]] name = "quote" -version = "1.0.7" +version = "1.0.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "aa563d17ecb180e500da1cfd2b028310ac758de548efdd203e18f283af693f37" +checksum = "991431c3519a3f36861882da93630ce66b52918dcf1b8e2fd66b397fc96f28df" dependencies = [ "proc-macro2", ] @@ -492,9 +492,9 @@ dependencies = [ [[package]] name = "regex" -version = "1.4.2" +version = "1.4.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "38cf2c13ed4745de91a5eb834e11c00bcc3709e773173b2ce4c56c9fbde04b9c" +checksum = "d9251239e129e16308e70d853559389de218ac275b515068abc96829d05b948a" dependencies = [ "aho-corasick", "memchr", @@ -513,9 +513,9 @@ dependencies = [ [[package]] name = "regex-syntax" -version = "0.6.21" +version = "0.6.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3b181ba2dcf07aaccad5448e8ead58db5b742cf85dfe035e2227f137a539a189" +checksum = "b5eb417147ba9860a96cfe72a0b93bf88fee1744b5636ec99ab20c1aa9376581" [[package]] name = "rust-argon2" @@ -537,9 +537,9 @@ checksum = "71d301d4193d031abdd79ff7e3dd721168a9572ef3fe51a1517aba235bd8f86e" [[package]] name = "serde" -version = "1.0.118" +version = "1.0.123" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "06c64263859d87aa2eb554587e2d23183398d617427327cf2b3d0ed8c69e4800" +checksum = "92d5161132722baa40d802cc70b15262b98258453e85e5d1d365c757c73869ae" [[package]] name = "strsim" @@ -573,9 +573,9 @@ dependencies = [ [[package]] name = "syn" -version = "1.0.54" +version = "1.0.60" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9a2af957a63d6bd42255c359c93d9bfdb97076bd3b820897ce55ffbfbf107f44" +checksum = "c700597eca8a5a762beb35753ef6b94df201c81cca676604f547495a0d7f0081" dependencies = [ "proc-macro2", "quote", @@ -613,18 +613,18 @@ dependencies = [ [[package]] name = "thread_local" -version = "1.0.1" +version = "1.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d40c6d1b69745a6ec6fb1ca717914848da4b44ae29d9b3080cbee91d72a69b14" +checksum = "d8208a331e1cb318dd5bd76951d2b8fc48ca38a69f5f4e4af1b6a9f8c6236915" dependencies = [ - "lazy_static", + "once_cell", ] [[package]] name = "tinyvec" -version = "1.1.0" +version = "1.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ccf8dbc19eb42fba10e8feaaec282fb50e2c14b2726d6301dbfeed0f73306a6f" +checksum = "317cca572a0e89c3ce0ca1f1bdc9369547fe318a683418e42ac8f59d14701023" dependencies = [ "tinyvec_macros", ] @@ -1,154 +1,159 @@ -# gfold
-
-[![GitHub](https://img.shields.io/github/license/nickgerace/gfold?style=flat-square)](./LICENSE)
-[![Latest SemVer GitHub Tag](https://img.shields.io/github/v/tag/nickgerace/gfold?label=version&style=flat-square)](https://github.com/nickgerace/gfold/releases/latest)
-[![Crates.io](https://img.shields.io/crates/v/gfold?style=flat-square)](https://crates.io/crates/gfold)
-[![Build Status](https://img.shields.io/github/workflow/status/nickgerace/gfold/merge/main?style=flat-square)](https://github.com/nickgerace/gfold/actions?query=workflow%3Amerge+branch%3Amain)
-
-`gfold` is a CLI application that helps you keep track of multiple Git repositories.
-
-```bash
-user at hostname in ~/git
-% gfold
-great-journey unclean main git@github.com:truth/great-journey.git
-installation-zero bare main https://github.com/the-ark/installation-zero.git
-sierra unpushed dev https://github.com/forward-unto-dawn/sierra.git
-spark clean issue343 git@github.com:guilty/spark.git
-tartarus unclean delta git@github.com:covenant/tartarus.git
-voi clean main https://github.com/earth/voi.git
-```
-
-## Description and Motivation
-
-This app displays relevant information for multiple Git repositories in one, or multiple, directories.
-While this tool might seem limited in scope and purpose, that is by design.
-
-It prints each repository in alphabetical order, and pads each result based on the longest directory, branch, and status string.
-By default, `gfold` looks at every Git repository in the current working directory.
-However, if you would like to target another directory, you can pass that path (relative or absolute) as the first argument.
-
-## Installation
-
-There are multiple ways to install `gfold`, but here are some recommended methods...
-
-Installation Methods | `linux-gnu-amd64` | `macos-amd64` | `windows-amd64`
---- | --- | --- | --
-Homebrew | x | x | -
-Arch User Repository (AUR) | x | - | -
-Cargo Install | x | x | x
-GitHub Release Binary | x | x | x
-
-### Homebrew
-
-You can use [Homebrew](https://brew.sh) to install the [tap](https://github.com/nickgerace/homebrew-gfold) for `gfold`.
-
-```bash
-brew install nickgerace/gfold/gfold
-```
-
-Alternatively, you can do...
-
-```bash
-brew tap nickgerace/gfold
-brew install gfold
-```
-
-Running `brew help` or `man brew` can help you use `brew` locally.
-You can check out [Homebrew's documentation](https://docs.brew.sh) as well.
-
-### Arch User Repository (AUR)
-
-This application is available for all Linux distributions that support installing packages from the AUR.
-
-- [gfold](https://aur.archlinux.org/packages/gfold/) (builds from source)
-- [gfold-bin](https://aur.archlinux.org/packages/gfold-bin/) (uses the GitHub release binary)
-- [gfold-git](https://aur.archlinux.org/packages/gfold-git/) (VCS/development package)
-
-Many people choose to use an [AUR helper](https://wiki.archlinux.org/index.php/AUR_helpers), such as [yay](https://github.com/Jguer/yay) (example: `yay -S gfold`), in order to install their AUR packages.
-
-### Cargo Install
-
-You can install from [crates.io](https://crates.io/crates/gfold) by executing...
-
-```bash
-cargo install gfold
-```
-
-### GitHub Release Binary
-
-You can obtain `gfold` via the [latest GitHub release](https://github.com/nickgerace/gfold/releases/latest).
-Once you have it downloaded, you can add it to your `PATH`.
-Here is an example on how to do that on macOS and Linux...
-
-```bash
-chmod +x gfold
-mv gfold /usr/local/bin/
-```
-
-You may have to reload your shell in order to see `gfold` in your `PATH`.
-
-#### Advanced Management
-
-You can use symbolic links to swap between versions, and manage multiple at a time.
-Here is a full install workflow example...
-
-```bash
-wget https://github.com/nickgerace/gfold/releases/download/$VERSION/gfold-$PLATFORM
-mv gfold-$PLATFORM gfold-$VERSION
-chmod +x gfold-$VERSION
-
-mkdir /usr/local/gfold/
-mv gfold-$VERSION /usr/local/gfold/
-ln -s /usr/local/gfold/gfold-$VERSION /usr/local/bin/gfold
-```
-
-Now, you can add/remove versions of the binary from `/usr/local/gfold/`, and change the symbolic link as needed.
-
-## Usage
-
-For all the ways on how to use this application, pass in the `-h`, or `--help`, flag.
-
-```bash
-gfold --help
-```
-
-Here are some example invocations...
-
-```bash
-gfold
-gfold ..
-gfold $HOME
-gfold /this/is/an/absolute/path
-gfold ../../this/is/a/relative/path
-gfold ~/path/to/multiple/repositories/ -r
-gfold -r $HOME/path/to/multiple/repositories
-```
-
-## Compatibility
-
-`gfold`, and its external crates, support all three major desktop platforms.
-It is tested for the latest versions of the following systems, but may work on more...
-
-- **Linux**: `linux-gnu-amd64`
-- **macOS**: `macos-amd64`
-- **Windows 10**: `windows-amd64`
-
-## Changelog
-
-Please check out [CHANGELOG.md](./CHANGELOG.md) for more information.
-It follows the [Keep a Changelog](https://keepachangelog.com/) format.
-
-## Code of Conduct
-
-This repository follows and enforces the Rust programming language's [Code of Conduct](https://www.rust-lang.org/policies/code-of-conduct).
-
-## Additional Information
-
-- Author: [Nick Gerace](https://nickgerace.dev)
-- License: [Apache 2.0](./LICENSE)
-
-## Special Thanks To...
-
-- [@jrcichra](https://github.com/jrcichra) for adding multi-OS support to the original CI pipeline
-- [@orhun](https://github.com/orhun) for maintaining [all three AUR packages](https://github.com/orhun/PKGBUILDs)
-- [@yaahc](https://github.com/yaahc) for mentoring
+# gfold + +[![GitHub](https://img.shields.io/github/license/nickgerace/gfold?style=flat-square)](./LICENSE) +[![Latest SemVer GitHub Tag](https://img.shields.io/github/v/tag/nickgerace/gfold?label=version&style=flat-square)](https://github.com/nickgerace/gfold/releases/latest) +[![Crates.io](https://img.shields.io/crates/v/gfold?style=flat-square)](https://crates.io/crates/gfold) +[![Build Status](https://img.shields.io/github/workflow/status/nickgerace/gfold/merge/main?style=flat-square)](https://github.com/nickgerace/gfold/actions?query=workflow%3Amerge+branch%3Amain) + +`gfold` is a CLI application that helps you keep track of multiple Git repositories. + +```bash +user at hostname in ~/git +% gfold +great-journey unclean main git@github.com:truth/great-journey.git +installation-zero bare main https://github.com/the-ark/installation-zero.git +sierra unpushed dev https://github.com/forward-unto-dawn/sierra.git +spark clean issue343 git@github.com:guilty/spark.git +tartarus unclean delta git@github.com:covenant/tartarus.git +voi clean main https://github.com/earth/voi.git +``` + +## Description and Motivation + +This app displays relevant information for multiple Git repositories in one, or multiple, directories. +While this tool might seem limited in scope and purpose, that is by design. + +It prints each repository in alphabetical order, and pads each result based on the longest directory, branch, and status string. +By default, `gfold` looks at every Git repository in the current working directory. +However, if you would like to target another directory, you can pass that path (relative or absolute) as the first argument. + +## Installation + +There are multiple ways to install `gfold`, but here are some recommended methods... + +Installation Methods | `linux-gnu-amd64` | `darwin-amd64` | `windows-amd64` +--- | --- | --- | -- +Homebrew | x | x | - +Arch User Repository (AUR) | x | - | - +Cargo Install | x | x | x +GitHub Release Binary | x | x | x + +### Homebrew + +You can use [Homebrew](https://brew.sh) to install the [tap](https://github.com/nickgerace/homebrew-gfold) for `gfold`. + +```bash +brew install nickgerace/gfold/gfold +``` + +Alternatively, you can do... + +```bash +brew tap nickgerace/gfold +brew install gfold +``` + +Running `brew help` or `man brew` can help you use `brew` locally. +You can check out [Homebrew's documentation](https://docs.brew.sh) as well. + +### Arch User Repository (AUR) + +This application is available for all Linux distributions that support installing packages from the AUR. + +- [gfold](https://aur.archlinux.org/packages/gfold/) (builds from source) +- [gfold-bin](https://aur.archlinux.org/packages/gfold-bin/) (uses the GitHub release binary) +- [gfold-git](https://aur.archlinux.org/packages/gfold-git/) (VCS/development package) + +Many people choose to use an [AUR helper](https://wiki.archlinux.org/index.php/AUR_helpers), such as [yay](https://github.com/Jguer/yay) or [paru](https://github.com/Morganamilo/paru), in order to install their AUR packages. + +```bash +yay -S gfold +paru -S gfold +``` + +### Cargo Install + +You can install from [crates.io](https://crates.io/crates/gfold) by executing... + +```bash +cargo install gfold +``` + +### GitHub Release Binary + +You can obtain `gfold` via the [latest GitHub release](https://github.com/nickgerace/gfold/releases/latest). +Once you have it downloaded, you can add it to your `PATH`. +Here is an example on how to do that on macOS and Linux... + +```bash +chmod +x gfold +mv gfold /usr/local/bin/ +``` + +You may have to reload your shell in order to see `gfold` in your `PATH`. + +#### Advanced Management + +You can use symbolic links to swap between versions, and manage multiple at a time. +Here is a full install workflow example... + +```bash +wget https://github.com/nickgerace/gfold/releases/download/$VERSION/gfold-$PLATFORM +mv gfold-$PLATFORM gfold-$VERSION +chmod +x gfold-$VERSION + +mkdir /usr/local/gfold/ +mv gfold-$VERSION /usr/local/gfold/ +ln -s /usr/local/gfold/gfold-$VERSION /usr/local/bin/gfold +``` + +Now, you can add/remove versions of the binary from `/usr/local/gfold/`, and change the symbolic link as needed. + +## Usage + +For all the ways on how to use this application, pass in the `-h`, or `--help`, flag. + +```bash +gfold --help +``` + +Here are some example invocations... + +```bash +gfold +gfold .. +gfold $HOME +gfold /this/is/an/absolute/path +gfold ../../this/is/a/relative/path +gfold ~/path/to/multiple/repositories/ -r +gfold -r $HOME/path/to/multiple/repositories +``` + +## Compatibility + +`gfold`, and its external crates, support all three major desktop platforms. +It is tested for the latest versions of the following systems, but may work on more... + +- **Linux**: `linux-gnu-amd64` +- **macOS**: `darwin-amd64` +- **Windows 10**: `windows-amd64` + +## Changelog + +Please check out [CHANGELOG.md](./CHANGELOG.md) for more information. +It follows the [Keep a Changelog](https://keepachangelog.com/) format. + +## Code of Conduct + +This repository follows and enforces the Rust programming language's [Code of Conduct](https://www.rust-lang.org/policies/code-of-conduct). + +## Additional Information + +- Author: [Nick Gerace](https://nickgerace.dev) +- License: [Apache 2.0](./LICENSE) + +## Special Thanks To... + +- [@jrcichra](https://github.com/jrcichra) for adding multi-OS support to the original CI pipeline +- [@orhun](https://github.com/orhun) for maintaining [all three AUR packages](https://github.com/orhun/PKGBUILDs) +- [@yaahc](https://github.com/yaahc) for mentoring diff --git a/src/driver.rs b/src/driver.rs index 4830500..d27affb 100644 --- a/src/driver.rs +++ b/src/driver.rs @@ -6,17 +6,15 @@ */ use crate::util; - +use eyre::Result; +use log::debug; use std::cmp::Ordering; use std::fs; use std::path::Path; -use eyre::Result; -use log::debug; - #[derive(Debug)] pub struct Config { - pub disable_unpushed_check: bool, + pub enable_unpushed_check: bool, pub no_color: bool, pub recursive: bool, pub skip_sort: bool, @@ -82,7 +80,7 @@ impl Results { if let Some(table_wrapper) = util::create_table_from_paths( repos, &dir, - &config.disable_unpushed_check, + &config.enable_unpushed_check, &config.no_color, ) { self.0.push(table_wrapper); @@ -7,33 +7,33 @@ //! This is a CLI tool to help keep track of your Git repositories. -mod driver; -mod util; - #[macro_use] extern crate prettytable; -use std::path::Path; +mod driver; +mod util; use eyre::Result; +use std::path::Path; /// This function is the primary, backend driver for `gfold`. /// -/// - `path`: the target path to find and parse Git repositories +/// - `enable_unpushed_check`: enable checking for unpushed commits (experimental) /// - `no_color`: disables color, bolding, etc. +/// - `path`: the target path to find and parse Git repositories /// - `recursive`: recursively searches directories for Git repositories /// - `skip_sort`: skips sorting the repositories for output /// /// When executed, results will be printed to STDOUT. pub fn run( path: &Path, - disable_unpushed_check: bool, + enable_unpushed_check: bool, no_color: bool, recursive: bool, skip_sort: bool, ) -> Result<()> { let config = driver::Config { - disable_unpushed_check, + enable_unpushed_check, no_color, recursive, skip_sort, @@ -65,15 +65,15 @@ mod tests { fn parent_directory_all_options() { let mut current_dir = env::current_dir().expect("failed to get CWD"); current_dir.pop(); - - assert_ne!(run(¤t_dir, false, true, false, false).is_err(), true); - assert_ne!(run(¤t_dir, false, true, false, true).is_err(), true); - assert_ne!(run(¤t_dir, false, true, true, false).is_err(), true); - - assert_ne!(run(¤t_dir, false, false, true, false).is_err(), true); - assert_ne!(run(¤t_dir, false, false, true, true).is_err(), true); - assert_ne!(run(¤t_dir, false, false, false, true).is_err(), true); - - assert_ne!(run(¤t_dir, false, true, true, true).is_err(), true); + for skip_sort in vec![true, false] { + for recursive in vec![true, false] { + for no_color in vec![true, false] { + assert_ne!( + run(¤t_dir, false, no_color, recursive, skip_sort).is_err(), + true + ); + } + } + } } } diff --git a/src/main.rs b/src/main.rs index 8c233f8..c3fd418 100644 --- a/src/main.rs +++ b/src/main.rs @@ -5,10 +5,9 @@ * License: Apache 2.0 */ +use eyre::Result; use std::env; use std::path::PathBuf; - -use eyre::Result; use structopt::StructOpt; #[derive(StructOpt, Debug)] @@ -22,8 +21,12 @@ working directory." struct Opt { #[structopt(short, long, help = "Set to debug mode")] debug: bool, - #[structopt(short, long, help = "Toggle to disable checking for unpushed commits")] - disable_unpushed_check: bool, + #[structopt( + short, + long, + help = "Toggle to enable checking for unpushed commits (experimental)" + )] + enable_unpushed_check: bool, #[structopt(long = "nc", help = "Disable color output")] no_color: bool, #[structopt(parse(from_os_str), help = "Target a different directory")] @@ -50,7 +53,7 @@ fn main() -> Result<()> { gfold::run( &path, - opt.disable_unpushed_check, + opt.enable_unpushed_check, opt.no_color, opt.recursive, opt.skip_sort, diff --git a/src/util.rs b/src/util.rs index 6dda677..86a09d5 100644 --- a/src/util.rs +++ b/src/util.rs @@ -6,10 +6,8 @@ */ use crate::driver; - -use std::path::{Path, PathBuf}; - use log::debug; +use std::path::{Path, PathBuf}; #[derive(Debug)] enum Condition { @@ -23,7 +21,7 @@ enum Condition { pub fn create_table_from_paths( repos: Vec<PathBuf>, path: &Path, - disable_unpushed_check: &bool, + enable_unpushed_check: &bool, no_color: &bool, ) -> Option<driver::TableWrapper> { let mut table = prettytable::Table::new(); @@ -54,30 +52,25 @@ pub fn create_table_from_paths( continue; } }; - let url = match origin.url() { - Some(url) => url, - None => "none", - }; + let url = origin.url().unwrap_or("none"); debug!("[+] url: {:#?}", url); let head = repo_obj.head().ok()?; - let branch = match head.shorthand() { - Some(branch) => branch, - None => "none", - }; + let branch = head.shorthand().unwrap_or("none"); debug!("[+] branch: {:#?}", branch); - let name = match Path::new(&repo).strip_prefix(path).ok()?.to_str() { - Some(name) => name, - None => "none", - }; + let name = Path::new(&repo) + .strip_prefix(path) + .ok()? + .to_str() + .unwrap_or("none"); debug!("[+] name: {:#?}", name); // FIXME: test using the "is_bare()" method for a repository object. let mut opts = git2::StatusOptions::new(); let condition = match repo_obj.statuses(Some(&mut opts)) { Ok(statuses) if statuses.is_empty() => { - if !disable_unpushed_check && is_unpushed(&repo_obj, &head) { + if *enable_unpushed_check && is_unpushed(&repo_obj, &head) { Condition::Unpushed } else { Condition::Clean |