Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/canta2899/logo-ls
Modern ls command with vscode like File Icon and Git Integrations. Written in Golang
https://github.com/canta2899/logo-ls
Last synced: 6 days ago
JSON representation
Modern ls command with vscode like File Icon and Git Integrations. Written in Golang
- Host: GitHub
- URL: https://github.com/canta2899/logo-ls
- Owner: canta2899
- License: mit
- Created: 2022-03-22T19:04:01.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-07-17T08:00:28.000Z (6 months ago)
- Last Synced: 2024-07-17T10:02:28.799Z (6 months ago)
- Language: Go
- Homepage:
- Size: 3.81 MB
- Stars: 16
- Watchers: 3
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# logo-ls
This is a fork of [logo-ls](https://github.com/Yash-Handa/logo-ls) which I ended up maintaining since the original repository went unmaintained some years ago.
My primary goals have been:
- Correct output (I should see all the files /bin/ls would show me)
- Informative output (I should see at least what /bin/ls would show me)
- MacOS / Linux / Windows compatibility (I mainly develop on OSX but I want to use logo-ls everywhere)The modifications I made involved:
- Removing case sensitive paths in order to avoid issues on OSX/Windows machines
- Changing UTF-8 space character in order to properly render the output on every terminal
- Fixing a bug on path separators that caused issues with the git status flag on Windows machines
- Implementing a symlink resolution that behaves like the one of the original [ls(coreutils)](https://www.gnu.org/software/coreutils/manual/html_node/ls-invocation.html#ls-invocation).
- Restructuring the code base to make it easier to apply changes and introduce features (still in progress)
- Nerd Fonts Version 3 migration (this breaks compatibility with codepoints of previous versions)Feel free to contribute and I'll be more than happy to merge your changes. In case you want to add some new icons, please make a PR so that we can all benefit from that. The following sections explains how to do it.
## Adding Icons
In order to add new icons you need to:
1. Fork the repository
2. Add an entry in the map `IconSet` in `icons/icons_map.go`. The key should be the **name of the icon** and **not** its extension (i.e. `markdown` for markdown files). The value should be of type `IconInfo`, a struct indicating the unicode character and its color.
3. Add one or more entries in the map `IconExt` in `icons/icon_ext.go`, mapping the entry defined in `IconSet` to each one of the desired extensionsYou can map an icon to a specific file name (i.e. `tsconfig.json`) by editing `icons/icons_files.go`. You can also override an icon for a specific file name (i.e. use a different icon for `gitlab-ci.yml` rather than the standard YML one) by editing `icons/icons_sub_ext.go`.
## Installation
Since no binary is available, you should compile yours by yourself (for now). You have to [install go](https://go.dev/doc/install), then run:
```bash
git clone https://github.com/canta2899/logo-ls
```And install using
```bash
cd logo-ls
go install ./cmd/logo-ls
```If you want to build the binary only you can, instead, run
```bash
cd logo-ls
go build -o logo-ls ./cmd/logo-ls
```