160 lines
5.5 KiB
Markdown
160 lines
5.5 KiB
Markdown
# LSD (LSDeluxe)
|
|
|
|
[data:image/s3,"s3://crabby-images/b5dd2/b5dd2299677cb5d33741b1904cdab5c1688ef637" alt="license"](https://raw.githubusercontent.com/Peltoche/ical-rs/master/LICENSE)
|
|
[data:image/s3,"s3://crabby-images/81b99/81b9917870ee6fd7cd71b788394943d996d54fc0" alt="Build Status"](https://travis-ci.org/Peltoche/lsd)
|
|
[data:image/s3,"s3://crabby-images/2c9a7/2c9a7ffce5b152fe6d0c0906d52d801785a538fc" alt="Latest version"](https://crates.io/crates/lsd)
|
|
[data:image/s3,"s3://crabby-images/3ec9b/3ec9bf3c1f3df888ea3f10b560486996b9ef52e7" alt="Snap Status"](https://build.snapcraft.io/user/Peltoche/lsd)
|
|
|
|
# Table of Contents
|
|
|
|
- [Description](#description)
|
|
- [Screenshot](#screenshot)
|
|
- [Installation](#installation)
|
|
- [Configurations](#configurations)
|
|
* [Required](#required)
|
|
* [Optional](#optional)
|
|
- [Benchmark](#benchmark)
|
|
- [F.A.Q.](#faq)
|
|
- [Contributors](#contributors)
|
|
- [Credits](#credits)
|
|
|
|
## Description
|
|
|
|
This project is heavily inspired by the super [colorls](https://github.com/athityakumar/colorls)
|
|
project but with some little differences. For example it is written in rust and not in ruby which makes it much faster ([see the benchmarks](#benchmark)).
|
|
|
|
## Screenshot
|
|
|
|
data:image/s3,"s3://crabby-images/816c5/816c59319ade369977cedeb12cbd0c3518996bce" alt="image"
|
|
|
|
## Installation
|
|
|
|
### Prerequisites
|
|
|
|
Install the patched fonts of powerline nerd-font and/or font-awesome. Have a look at the [Nerd Font README](https://github.com/ryanoasis/nerd-fonts/blob/master/readme.md) for more installation instructions. Don't forget to setup your terminal in order to use the correct font.
|
|
|
|
See [this issue comment](https://github.com/Peltoche/lsd/issues/199#issuecomment-494218334) for detailed instructions on how to configure iTerm2 font settings correctly.
|
|
|
|
### On Archlinux
|
|
|
|
```sh
|
|
pacman -S lsd
|
|
```
|
|
|
|
### On Fedora
|
|
|
|
```sh
|
|
dnf install lsd
|
|
```
|
|
|
|
### On Ubuntu
|
|
|
|
_... and other Debian-based Linux distributions_
|
|
|
|
Download the latest .deb package from the [release page](https://github.com/Peltoche/lsd/releases) and install it via:
|
|
|
|
```sh
|
|
sudo dpkg -i lsd_7.2.0_amd64.deb # adapt version number and architecture
|
|
```
|
|
|
|
### On Gentoo
|
|
```sh
|
|
sudo emerge sys-apps/lsd
|
|
```
|
|
(Ebuild maintained by Georgy Yakovlev)
|
|
|
|
### From Snap
|
|
|
|
```sh
|
|
sudo snap install lsd
|
|
```
|
|
|
|
### On macOS
|
|
|
|
via [Homebrew](https://brew.sh/):
|
|
|
|
```sh
|
|
brew install lsd
|
|
```
|
|
|
|
### From Sources
|
|
|
|
With Rust's package manager cargo, you can install lsd via:
|
|
|
|
```sh
|
|
cargo install lsd
|
|
```
|
|
|
|
### From Binaries
|
|
|
|
The [release page](https://github.com/Peltoche/lsd/releases) includes precompiled binaries for Linux and macOS.
|
|
|
|
|
|
## Configurations
|
|
|
|
### Required
|
|
|
|
In order to use lsd instead of the default ls you need to add this to you shell
|
|
configuration file (~/.bashrc, ~/.zshrc, etc.) :
|
|
|
|
```sh
|
|
alias ls='lsd'
|
|
```
|
|
|
|
### Optional
|
|
|
|
Some examples of useful aliases. You can add this to you shell configuration
|
|
file (~/.bashrc, ~/.zshrc, etc.) just under the alias above :
|
|
|
|
```sh
|
|
alias l='ls -l'
|
|
alias la='ls -a'
|
|
alias lla='ls -la'
|
|
alias lt='ls --tree'
|
|
```
|
|
|
|
|
|
## Benchmark
|
|
|
|
Result from `hyperfine --warmup 10 'lsd -la /etc/*' 'colorls -la /etc/*' 'exa -la /etc/*' --export-markdown out.md`:
|
|
|
|
| Command | Mean [ms] | Min…Max [ms] |
|
|
|:---|---:|---:|
|
|
| `lsd -la /etc/*` | 9.8 ± 0.7 | 8.6…11.9 |
|
|
| `colorls -la /etc/*` | 387.3 ± 4.1 | 379.8…393.6 |
|
|
| `exa -la /etc/*` | 15.4 ± 1.8 | 14.0…24.0 |
|
|
|
|
## F.A.Q.
|
|
|
|
### Default Colors
|
|
|
|
In the future the possibility to customize the colors might be implemented.
|
|
For now, the default colors are:
|
|
|
|
| User/Group | Permissions | File Types | Last time Modified | File Size |
|
|
|:---|:---|:---|:---|:---|
|
|
|data:image/s3,"s3://crabby-images/6d69e/6d69e61f2d86e671e6de5508aa8d33e3e5b8dfcf" alt="#ffffd7" User|data:image/s3,"s3://crabby-images/09809/098097fad136309a2f4e168398da2d112f15f553" alt="#00d700" Read |data:image/s3,"s3://crabby-images/ff2c2/ff2c26b25a166ec731bf022248b9ce88795b37e8" alt="#0087ff" Directory|data:image/s3,"s3://crabby-images/09809/098097fad136309a2f4e168398da2d112f15f553" alt="#00d700" within the last hour|data:image/s3,"s3://crabby-images/dc759/dc759fd9e7a924bcfd095267f90348225276eb2e" alt="#ffffaf" Small File|
|
|
|data:image/s3,"s3://crabby-images/3bf82/3bf820b7a2ac2032d4ca767e44e66d3a8bc397d7" alt="#d7d7af" Group|data:image/s3,"s3://crabby-images/c8dbd/c8dbd8398de0ee18f85711e582ff0dca49882fce" alt="#d7ff87" Write|data:image/s3,"s3://crabby-images/09809/098097fad136309a2f4e168398da2d112f15f553" alt="#00d700" Executable File|data:image/s3,"s3://crabby-images/9637b/9637b06c9d68f85fbfa7ceb8239f091d2a3a43e8" alt="#00d787" within the last day|data:image/s3,"s3://crabby-images/e3d4e/e3d4e78906fd9bb99a1e9af8fb3d04e6ebeb2af0" alt="#ffaf87" Medium File|
|
|
||data:image/s3,"s3://crabby-images/e6250/e6250b7d68dab48afc797d5d9996d2ab2e509119" alt="#af0000" Execute|data:image/s3,"s3://crabby-images/4bda0/4bda07bdeab5ddefcf573b34e671c75917feaa23" alt="#d7d700" Non-Executable File|data:image/s3,"s3://crabby-images/7d949/7d9499daa139d06c1d41f7defeead331804cf4a3" alt="#00af87" older|data:image/s3,"s3://crabby-images/0c10e/0c10eece40137e753c5ec888d0d1a68378860a32" alt="#d78700" Large File|
|
|
||data:image/s3,"s3://crabby-images/81d53/81d534dc1904c4b31569aa70e2bfbf28669dc71c" alt="#ff00ff" Execute with Stickybit|data:image/s3,"s3://crabby-images/e6250/e6250b7d68dab48afc797d5d9996d2ab2e509119" alt="#af0000" Broken Symlink||data:image/s3,"s3://crabby-images/334f3/334f318c683c3344ed8de27670defac0ec5f75d7" alt="#ffffff" Non File|
|
|
||data:image/s3,"s3://crabby-images/37fa5/37fa55489f5f9a4b4cab69905d4eef0e8f892342" alt="#d75f87" No Access|data:image/s3,"s3://crabby-images/468c1/468c1f85684d675fcd221d4905e333597c178b1f" alt="#00d7d7" Pipe/Symlink/Blockdevice/Socket/Special|||
|
|
|||data:image/s3,"s3://crabby-images/0c10e/0c10eece40137e753c5ec888d0d1a68378860a32" alt="#d78700" CharDevice|||
|
|
|
|
|
|
|
|
## Contributors
|
|
|
|
Everyone can contribute to this project, improving the code or adding functions. If anyone wants something to be added we will try to do it.
|
|
|
|
As this is being updated regularly, don't forget to rebase your fork before creating a pull-request.
|
|
|
|
## Credits
|
|
|
|
Special thanks to:
|
|
|
|
- [meain](https://github.com/meain) for all his contributions and reviews
|
|
- [danieldulaney](https://github.com/danieldulaney) for the Windows integration
|
|
- [sharkdp](https://github.com/sharkdp) and his superb [fd](https://github.com/sharkdp/fd) from which I have stolen a lot of CI stuff.
|
|
- [athityakumar](https://github.com/athityakumar) for the project [colorls](https://github.com/athityakumar/colorls)
|
|
- All the other contributors
|