#filetype #icons #glyph #file-format #nerd-fonts #rust

devicons

A Rust library that provides filetype glyphs (icons) for a wide range of common file formats

14 releases (4 breaking)

0.6.12 Dec 28, 2024
0.6.11 Oct 15, 2024
0.5.4 Sep 29, 2024
0.4.4 Sep 29, 2024
0.1.0 Sep 9, 2024

#144 in Filesystem

Download history 10/week @ 2024-09-21 405/week @ 2024-09-28 303/week @ 2024-10-05 488/week @ 2024-10-12 98/week @ 2024-10-19 43/week @ 2024-10-26 91/week @ 2024-11-02 323/week @ 2024-11-09 341/week @ 2024-11-16 303/week @ 2024-11-23 252/week @ 2024-11-30 121/week @ 2024-12-07 253/week @ 2024-12-14 38/week @ 2024-12-21 637/week @ 2024-12-28 327/week @ 2025-01-04

1,272 downloads per month
Used in 8 crates (7 directly)

Apache-2.0

205KB
9K SLoC

GitHub branch check runs docs.rs Crates.io Total Downloads GitHub License Crates.io Version Crates.io Size

πŸ¦€ rust-devicons

A Rust library inspired by vim-devicons, that provides filetype glyphs (icons) for a wide range of common file formats.

rust-devicons

Features

  • 🦞 Icon Retrieval: Get file or directory icons based on file name/extension.
  • 🦞 Icon Color: Retrieve the color associated with the icon depending on the specified theme.
  • 🦞 Filetype Support: Supports a wide range of filetypes and filename conventions (dockerfile, makefile, etc.).
  • 🦞 Customizable Themes: Supports both light and dark themes.
Screenshot 2024-09-21 at 16 54 16

Installation

cargo add devicons

NOTE: you'll need to use a NerdFont to properly display the icons.

Usage

Here’s a simple example of how to use devicons to retrieve a file icon with the dark theme:

use std::path::Path;
use devicons::{File, Theme, icon_for_file, FileIcon};

fn main() {
    // getting the icon from a path with a specified theme
    let path = Path::new("Cargo.toml");
    let icon = icon_for_file(path, Some(Theme::Dark));

    // getting the icon from a string with a specified theme
    let icon = icon_for_file("Cargo.toml", Some(Theme::Dark));

    // getting the icon from a path with the default theme
    let icon = FileIcon::from(path);

    // directly getting an icon from a filename
    let icon = FileIcon::from("Cargo.toml");

    println!("File: {}", path.to_string_lossy());
    println!("Icon: {}", icon.icon);
    println!("Color: {}", icon.color);
}

Running the Examples

You can find more usage examples in the examples directory. To run them, use:

cargo run --example <example_name>

License

This project is licensed under the Apache 2.0 License.

Dependencies