Go to file
Athitya Kumar 24e402c153
Merge pull request #585 from Flimm/patch-1
Fix README.md to use latest flags
2023-10-29 21:45:30 +05:30
.github Explicitly use bash (for Windows) 2022-04-29 16:08:35 +02:00
exe Set exit status code when specified path doesn't exist 2020-10-07 09:58:01 +02:00
lib Update file_aliases.yaml 2023-10-23 09:59:19 +02:00
man Remove man page and zsh completion file 2022-03-21 09:03:21 +01:00
spec relevant feature spec 2023-04-30 02:45:55 +05:30
test add check for the new flag 2023-04-26 18:32:52 +05:30
.gitignore Gitignores gem files 2017-07-05 22:45:17 +05:30
.rubocop.yml Fix rubocop offenses 2022-03-20 02:18:02 +03:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2017-07-07 23:01:53 +05:30
colorls.gemspec Update rubocop-rspec requirement from ~> 2.19.0 to ~> 2.20.0 2023-04-18 23:57:17 +00:00
CONTRIBUTING.md Updates CONTRIBUTING.md (#148) 2017-10-31 01:28:39 +05:30
CONTRIBUTORS.md Add one contributor name 2021-10-30 09:08:08 +09:00
COVERAGES.md Update COVERAGES.md 2017-10-08 14:02:15 +05:30
Gemfile Use rubocop's default include configuration and fix all offenses 2020-12-23 22:32:36 +01:00
ISSUE_TEMPLATE.md Adds few templates and release policy 2017-10-21 02:24:11 +05:30
LICENSE.md Adds some more markdown files 2017-07-06 22:05:43 +05:30
PULL_REQUEST_TEMPLATE.md Adds few templates and release policy 2017-10-21 02:24:11 +05:30
Rakefile CI: Publish to RubyGems 2022-03-21 09:09:01 +01:00
README.md Merge pull request #585 from Flimm/patch-1 2023-10-29 21:45:30 +05:30
RELEASE_POLICY.md Adds few templates and release policy 2017-10-21 02:24:11 +05:30

Color LS

forthebadge forthebadge

Gem Version CI PRs Welcome

A Ruby script that colorizes the ls output with color and icons. Here are the screenshots of working example on an iTerm2 terminal (Mac OS), oh-my-zsh with powerlevel9k theme and powerline nerd-font + awesome-config font with the Solarized Dark color theme.


If you're interested in knowing the powerlevel9k configuration to get this prompt, have a look at this gist.

Table of contents


(Back to top)

Man pages have been added. Checkout man colorls.


  • With -1 : Lists one entry per line


  • With -a (or) --all : Does not ignore entries starting with '.'


  • With -A (or) --almost-all : Does not ignore entries starting with '.', except ./ and ../


  • With -d (or) --dirs : Shows only directories


  • With -f (or) --files : Shows only files


  • With --help : Prints a very helpful help menu


  • With -l (or) --long : Shows in long listing format


  • With --report : Shows brief report about number of files and folders shown


  • With --tree (or) --tree=[DEPTH] : Shows tree view of the directory with the specified depth (default 3)


  • With --gs (or) --git-status : Shows git status for each entry


  • With --sd (or) --sort-dirs or --group-directories-first : Shows directories first, followed by files


  • With --sf (or) --sort-files : Shows files first, followed by directories


  • With -t : Sort by modification time, newest first (NEED TO ADD IMAGE)

  • With color options : --light or --dark can be passed as a flag, to choose the appropriate color scheme. By default, the dark color scheme is chosen. In order to tweak any color, read Custom configurations.

Combination of flags

  • Using --gs with -t :


  • Using --gs with -l :


  • Using --sd with -l and -A :


  • Using --non-human-readable with -l :

    • This will print the file sizes in bytes (non-human readable format)



(Back to top)

  1. Install Ruby (preferably, version >= 2.6)

  2. Download and install a Nerd Font. Have a look at the Nerd Font README for installation instructions.

    Note for iTerm2 users - Please enable the Nerd Font at iTerm2 > Preferences > Profiles > Text > Non-ASCII font > Hack Regular Nerd Font Complete.

    Note for HyperJS users - Please add "Hack Nerd Font" Font as an option to fontFamily in your ~/.hyper.js file.

  3. Install the colorls ruby gem with gem install colorls

    Note for rbenv users - In case of load error when using lc, please try the below patch.

    rbenv rehash
  4. Enable tab completion for flags by entering following line to your shell configuration file (~/.bashrc or ~/.zshrc) :

    source $(dirname $(gem which colorls))/tab_complete.sh
  5. Start using colorls 🎉

  6. Have a look at Recommended configurations and Custom configurations.

Recommended configurations

(Back to top)

  1. To add some short command (say, lc) with some flag options (say, -l, -A, --sd) by default, add this to your shell configuration file (~/.bashrc, ~/.zshrc, etc.) :

    alias lc='colorls -lA --sd'
  2. For changing the icon(s) to other unicode icons of choice (select icons from here), change the YAML files in a text editor of your choice (say, subl)

    subl $(dirname $(gem which colorls))/yaml

Custom configurations

(Back to top)

You can overwrite the existing icons and colors mapping by copying the yaml files from $(dirname $(gem which colorls))/yaml into ~/.config/colorls, and changing them.

  • To overwrite color mapping :

    Please have a look at the list of supported color names. You may also use a color hex code as long as it is quoted within the YAML file and prefaced with a # symbol.

    Let's say that you're using the dark color scheme and would like to change the color of untracked file (??) in the --git-status flag to yellow. Copy the defaut dark_colors.yaml and change it.

    Check if the ~/.config/colorls directory exists. If it doesn't exist, create it using the following command:

    mkdir -p ~/.config/colorls

    And then

    cp $(dirname $(gem which colorls))/yaml/dark_colors.yaml ~/.config/colorls/dark_colors.yaml

    In the ~/.config/colorls/dark_colors.yaml file, change the color set for untracked from darkorange to yellow, and save the change.

    untracked: yellow

    Or, using hex color codes:

    untracked: '#FFFF00'
  • To overwrite icon mapping :

    Please have a look at the list of supported icons. Let's say you want to add an icon for swift files. Copy the default files.yaml and change it.

    cp $(dirname $(gem which colorls))/yaml/files.yaml ~/.config/colorls/files.yaml`

    In the ~/.config/colorls/files.yaml file, add a new icon / change an existing icon, and save the change.

    swift: "\uF179"
  • User contributed alias configurations :


(Back to top)

Want to update to the latest version of colorls?

gem update colorls


(Back to top)

Want to uninstall and revert back to the old style? No issues (sob). Please feel free to open an issue regarding how we can enhance colorls.

gem uninstall colorls


(Back to top)

Your contributions are always welcome! Please have a look at the contribution guidelines first. 🎉


(Back to top)

The MIT License (MIT) 2017 - Athitya Kumar. Please have a look at the LICENSE.md for more details.