Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kattouf/progressline
⏳Track commands progress in a compact one-line format
https://github.com/kattouf/progressline
activity activity-indicator bash cli command-line command-line-tool developer-tools linux macos progress progress-bar progress-tracker progressbar script spinner swift swift-cli terminal utilities zsh
Last synced: 7 days ago
JSON representation
⏳Track commands progress in a compact one-line format
- Host: GitHub
- URL: https://github.com/kattouf/progressline
- Owner: kattouf
- License: mit
- Created: 2024-07-02T11:43:36.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-11-17T05:33:15.000Z (2 months ago)
- Last Synced: 2025-01-08T16:15:03.369Z (14 days ago)
- Topics: activity, activity-indicator, bash, cli, command-line, command-line-tool, developer-tools, linux, macos, progress, progress-bar, progress-tracker, progressbar, script, spinner, swift, swift-cli, terminal, utilities, zsh
- Language: Swift
- Homepage:
- Size: 2.18 MB
- Stars: 175
- Watchers: 2
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## ProgressLine
![](https://img.shields.io/badge/Platform-macOS-6464aa)
![](https://img.shields.io/badge/Platform-Linux-6464aa)
[![Latest Release](https://img.shields.io/github/release/kattouf/ProgressLine.svg)](https://github.com/kattouf/ProgressLine/releases/latest)
![](https://github.com/kattouf/ProgressLine/actions/workflows/checks.yml/badge.svg?branch=main)Track commands progress in a compact one-line format.
| ⏳ `progressline` output |
|:--:|
| ![](./.github/progressline_output.gif) || 📝 standard output |
|:--:|
| ![](./.github/standard_output.gif) |[Usage](#usage) • [Features](#features) • [Installation](#installation)
## Usage
Simply pipe your command output into `progressline` to start tracking:
```sh
long-running-command | progressline
```If the command you are executing also writes data to `stderr`, then you should probably use ["redirection"](https://www.gnu.org/software/bash/manual/html_node/Redirections.html) and send `stderr` messages to `stdout` so that they also go through the `progressline`:
``` sh
long-running-command 2>&1 | progressline
```## Features
### Change activity indicator styles
ProgressLine offers different styles to represent activity, they can be changed using `-s, --activity-style` option:
``` sh
long-running-command | progressline --activity-style snake
```Available styles:
| dots (Default) | snake | [kitt](https://en.wikipedia.org/wiki/KITT) | spinner |
|:--:|:--:|:--:|:--:|
| ![](./.github/activity_style_dots.gif) | ![](./.github/activity_style_snake.gif) | ![](./.github/activity_style_kitt.gif) | ![](./.github/activity_style_spinner.gif) |### Replace log output with custom text
If you don't need to see the log output during execution, even in a single line, you can replace it with your own text using the `-t, --static-text` option.
``` sh
long-running-command | progressline --static-text "Updating sources..."
```### Highlight important lines
Log specific stdin lines above the progress line using the `-m, --log-matches` option:
``` sh
long-running-command | progressline --log-matches "regex-1" --log-matches "regex-2"
```### Use progress line as an addition to standard output
Log all stdin data above the progress line using the `-a, --log-all` option:
```sh
long-running-command | progressline --log-all
```### Save original log
You have two options for saving the full original log:
1. Using [tee](https://en.wikipedia.org/wiki/Tee_(command))
``` sh
long-running-command | tee original-log.txt | progressline
```2. Using `-l, --original-log-path` option:
``` sh
long-running-command | progressline --original-log-path original-log.txt
```## Installation
### [Homebrew](https://brew.sh) (macOS / Linux)
``` sh
brew install progressline
```### [Mint](https://github.com/yonaskolb/Mint) (macOS)
``` sh
mint install kattouf/ProgressLine
```### [Mise](https://mise.jdx.dev) (macOS)
``` sh
mise use -g spm:kattouf/ProgressLine
```### Manual Installation (macOS / Linux)
Download the binary for your platform from the [releases page](https://github.com/kattouf/ProgressLine/releases), and place it in your executable path.
## Contributing
Feel free to open a pull request or a discussion.