Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nitwof/izer
Command-line tool for adding icons to filenames
https://github.com/nitwof/izer
cli fzf go izer unix vim
Last synced: 2 months ago
JSON representation
Command-line tool for adding icons to filenames
- Host: GitHub
- URL: https://github.com/nitwof/izer
- Owner: nitwof
- License: mit
- Created: 2019-09-10T17:24:38.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2020-05-27T22:22:36.000Z (over 4 years ago)
- Last Synced: 2024-06-12T08:20:02.846Z (8 months ago)
- Topics: cli, fzf, go, izer, unix, vim
- Language: Go
- Homepage:
- Size: 120 KB
- Stars: 7
- Watchers: 1
- Forks: 1
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# izer
[![Build Status](https://github.com/NightWolf007/izer/workflows/build/badge.svg)](https://github.com/NightWolf007/izer)
[![codecov](https://codecov.io/gh/NightWolf007/izer/branch/master/graph/badge.svg)](https://codecov.io/gh/NightWolf007/izer)izer is a command-line tool for adding icons to filenames.
izer is heavily inspired by [VimDevIcons](https://github.com/ryanoasis/vim-devicons).
## Pros
- Portable, no dependencies
- Fast
- Icon sets for different fonts
- Colored icons
- Deiconize feature for removing icons from filenames
- Smooth integration with [fzf](https://github.com/junegunn/fzf)## Benchmark
```shell
BenchmarkDeiconize-8 10 1118691512 ns/op
--- BENCH: BenchmarkDeiconize-8
deiconize_bench_test.go:28: Input size: 44148 KB - 1356000 lines
BenchmarkIconize/Nerd-8 10 1301644333 ns/op
BenchmarkIconize/NerdColor-8 10 1567274214 ns/op
BenchmarkIconize/NerdDir-8 10 1829822057 ns/op
BenchmarkIconize/NerdDirColor-8 10 2202257278 ns/op
--- BENCH: BenchmarkIconize
iconize_bench_test.go:32: Input size: 19472 KB - 1356000 lines
```## Installation
### From binaries
The [release page](https://github.com/NightWolf007/izer/releases) includes
precompiled binaries for Linux, FreeBSD, macOS and Windows.### Using Go
```shell
go get -u github.com/NightWolf007/izer
```## Usage
### Iconize
`iconize` command adds icons to filenames.
You can pass filenames to command through stdin or as arguments.#### Command-line options
```shell
Usage:
izer iconize [flags]Flags:
-c, --color Enable colorful output
-d, --dir Enable icons for directories (Slows down the process due checking files)
-f, --font string Font to be used. See: izer fonts
-h, --help help for iconize
```#### Simple usage
```shell
# Using arguments
izer iconize -f=nerd somefile.go somefile2.py# Using stdin
find . | izer iconize -f=nerd
```#### Directory icons
Checking that filename is directory or not slows down the iconization process.
Thus, by default izer handles directories as a simple files.To enable directory icons use `-d` opton.
```shell
# Using arguments
izer iconize -f=nerd -d somedir somefile.go# Using stdin
find . | izer iconize -f=nerd -d
```#### Colored icons
`-c` option prints icons in ANSI colors
```shell
# Using arguments
izer iconize -f=nerd -c somefile.go somefile2.py# Using stdin
find . | izer iconize -f=nerd -c
```### Deiconize
`deiconize` command removes icons from filenames (undoing iconize command).
You can pass filenames to command through stdin or as arguments.```shell
# Using arguments
izer deiconize " somefile.go" " somefile.py"# Using stdin
find . | izer iconize -f=nerd | izer deiconize
```### Supported fonts
To show list of all supported fonts use `fonts` command.
```shell
izer fonts
```### Using izer with [fzf](https://github.com/junegunn/fzf)
You can use izer to iconize files in fzf.
```shell
# Set default preview command
export FZF_DEFAULT_PREVIEW="fd --type file | izer iconize -f=nerd -c"# Run fzf
fzf | izer deiconize# Run fzf with preview
fzf --preview 'bat $(izer deiconize {})' | izer deiconize
```More info about fzf usage [here](https://github.com/junegunn/fzf#usage).
## Development
### Prerequisites
- Go 1.13
- [gomplate](https://github.com/hairyhenderson/gomplate)
- [golangci-lint](https://github.com/golangci/golangci-lint)### Building
```shell
# Build izer binary
make# Generate font files and test inputs from mappings
make generate
```### Linting
```shell
# Using make
make lint# Alternatively, you can run golangci-lint directly
golangci-lint run
```### Testing
```shell
# Run all tests
make test# Run integration tests
make itest# Update test golden files
make goldens
```### Benchmarking
```shell
# Run integration benchmarks
make bench# Also, you can pass benchtime through variable
BENCHTIME=10x make bench
```