/hyfetch

🖼️ 🏳️‍⚧️ Neofetch with LGBTQ pride flags!

Primary LanguageShellMIT LicenseMIT

HyFetch

neofetch with pride flags <3

screenshot

Running Updated Original Neofetch

This repo also serves as an updated version of the original neofetch since the upstream dylanaraps/neofetch doesn't seem to be maintained anymore (as of Jul 30, 2022, the original repo hasn't merged a pull request for 6 months). If you only want to use the updated neofetch without pride flags, you can use the neofetch script from this repo. To prevent command name conflict, I call it neowofetch :)

  • Method 1: pip install hyfetch then run neowofetch
  • Method 2: npx neowofetch
  • Method 3: P="$HOME/.local/bin/neowofetch" curl -L nf.hydev.org -o $P && chmod +x $P
  • Method 4: Run without install bash <(curl -sL nf.hydev.org)

Installation

Method 1: Install using Python pip (Recommended)

Install Python >= 3.7 first. Then, just do:

pip install hyfetch

Method 2: Install using system package manager

Currently, these distributions have existing packages for HyFetch:

  • Arch Linux: paru -S hyfetch or yay -S hyfetch (Thanks to @Aleksana)
  • Nix: nix-env -i hyfetch (Thanks to @YisuiDenghua)
  • Guix: guix install hyfetch (Thanks to @WammKD)

Method 3: Install the latest developmental version using git

Install Python >= 3.7 first. Then run the following commands:

git clone https://github.com/hykilpikonna/hyfetch.git
cd hyfetch
pip install .

Usage

When you run hyfetch for the first time, it will prompt you to choose a color system and a preset. Just follow the prompt, and everything should work (hopefully). If something doesn't work, feel free to submit an issue!

If you want to use the updated neofetch without LGBTQ flags, check out this section

Questions and answers

Q: How do I change my config?

A: Use hyfetch -c

Q: What do I do if the color is too dark/light for my theme?

A: You can try setting the colors' "lightness" in the configuration menu. The value should be between 0 and 1. For example, if you are using dark theme and the rainbow flag is too dark to display, you can set lightness to 0.7.

Feel free to experiment with it!

image

Contributing

To make changes to our codebase, you first need to create a fork by clicking the "Fork" button on the top right. Then, you can clone your fork of the source code using git clone https://github.com/{your username}/hyfetch.git.

After making changes to the source code, you can run python -m hyfetch in the root directory of your repo to test out your changes.

If they work correctly, you can commit and push these changes using git command or Github Desktop. Then, you can create a pull request on Github so that it can go into our next release!

You can also install your version locally by running pip install . in the repo root.

Change Log

About Notation

Updates to HyFetch begins with the emoji 🌈
Updates to neowofetch begins with the emoji 🖼️

TODO

  • (Important!) Refactor flag storage & coloring to support non-stride patterns
  • Config menu: Allow left-right arrow keys for pagination
  • Neofetch argument pass through

Unpublished 1.4.5

Note: You can install the latest nightly version by using:

pip install git+https://github.com/hykilpikonna/hyfetch.git@master

1.4.4

  • 🌈 Fix Python 3.11 compatibility (#35)
  • 🌈 Fix many overflow problems when screen is too small
  • 🖼️ Distro - Add Enso (dylanaraps#2233)
  • 🖼️ Memory - Optimize and fix memory unit conversion (dylanaraps#2225)
  • 🖼️ DE - Add dwl window manager (dylanaraps#2234)
  • 🖼️ DE - Fix XDG session detection for X11 (dylanaraps#2232)
  • 🖼️ CPU - Fix model detection for loongson (#34)

1.4.3

  • 🌈 Auto detect terminal background color & rgb support
  • 🌈 Optimize experience on light-themed terminals
  • 🌈 Fix bugs with lightness and light-mode config not applying
  • 🌈 Fix color alignment for distros with first color ≠ ${c1} (e.g. Ubuntu Budgie)
  • 🌈 Add unlabeled flags (#25)
  • 🌈 Add gender nonconforming & femboy & tomboy flags (#32)
  • 🌈 Fix jailbreak iOS shell killed: 9 issue caused by ld signature check.
  • 🖼️ Distro - Add garuda_small (dylanaraps#2215)
  • 🖼️ Distro - Add Cobalt Linux (dylanaraps#2213)
  • 🖼️ Distro - Add VanillaOS (dylanaraps#2222)
  • 🖼️ Distro - Surround macOS build number in parentheses (#28)
  • 🖼️ Misc - Auto select stdout mode based on tty detection (#31)
  • 🖼️ Bug Fix - Fix cols coloring reset for bash 3.2 (#24)

1.4.2

  • 🌈 Detailed runnning/contributing instructions in README.md (#21)
  • 🖼️ Distro - Add Stock Linux (#23)
  • 🖼️ Distro - Add DietPi (dylanaraps#1706)
  • 🖼️ Distro - Add OmniOS illumos (dylanaraps#2196)
  • 🖼️ Distro - Add Droidian (dylanaraps#2201)
  • 🖼️ Distro - Add HamoniKR (dylanaraps#2210)
  • 🖼️ Song - Add support for TIDAL HiFi (#22)
  • 🖼️ CPU - Detect multiple CPU models for ARM
  • 🖼️ Misc - Better defaults: Show RAM in GiB, RAM percentage, CPU speed rounding, refresh rate
  • 🖼️ Bug Fix - Fix bash 5.2 column cut off issue (#24)

1.4.1

  • 🌈 Paginate flags (#14)
  • 🌈 Add release workflow (#15)
  • 🌈 Create automatic release script
  • 🌈 Config page - Give warning when terminal size is too small
  • 🌈 Config page - Optimize color arrangement selection on small screens
  • 🌈 Add experimental Windows support (very unstable at the moment)
  • 🖼️ Distro - Add ravynOS (dylanaraps#2182)
  • 🖼️ Distro - Add ChonkySealOS (dylanaraps#2180)
  • 🖼️ Distro - Add GhostBSD (TheSudoer#18)
  • 🖼️ Distro - Add NekOS (dylanaraps#2186)
  • 🖼️ Distro - Add astOS (dylanaraps#2185)
  • 🖼️ Distro - Fix ChromeOS identification (dylanaraps#1949)
  • 🖼️ WM - Add Hyprland to the list of wayland wms (dylanaraps#2190)
  • 🖼️ Env - Add Java, Python, Node version detection (can be enabled in config)
  • 🖼️ Bug Fix - Fix hostname detection when inetutils is not installed
  • 🖼️ Bug Fix - Fix empty brackets displayed when no theme is found (dylanaraps#1713)
  • 🖼️ Bug Fix - Fix $ escape bug in strip_escape_codes() (dylanaraps#1543)
  • 🖼️ Bug Fix - Fix backslash escape bug in strip_escape_codes() (dylanaraps#1543)
  • 🖼️ Bug Fix - Fix CPU detection on ARM QEMU

1.4.0

  • 🌈 Add finsexual flag (#12)
  • 🚀 Addressed a total of 128 currently open pull requests from neofetch
🖼️ Meta Changes
  • Meta - Fixed shellcheck warnings in neowofetch
  • Meta - Moved shellcheck from travis to GitHub Actions
  • Meta - Created a script to automatically generate distro list
  • Colors - Allow RGB colors in neofetch --ascii_colors argument (dylanaraps#1726)
🖼️ Distro/OS Support Changes
🖼️ Device Support Changes
🖼️ Bug Fixes

1.3.0

🖼️ Ascii Art Changes
🖼️ Distro/OS Support Changes
🖼️ Device Support Changes
🖼️ Bug Fixes

1.2.0

  • 🚀 Take over neofetch with neowofetch
🖼️ Ascii Art Changes
  • Ascii - Add uwuntu (#9) (use it with hyfetch --test-distro uwuntu or neowofetch --ascii_distro uwuntu)
  • Ascii - Better Void ascii art (#10)
  • Ascii - Update old NixOS logo for compatibility (dylanaraps#2114)
🖼️ Distro/OS Support Changes
🖼️ Device/Program Support Changes
🖼️ Bug Fixes

1.1.3rc1

  • 🌈 Add foreground-background color arrangement to make Fedora and Ubuntu look nicer
  • 🌈 Allow typing abbreviations in flag selection
  • 🌈 Fix: Duplicate random color arrangements are appearing in selection screen
  • 🌈 Fix: Inconsistant color arrangement when saved to config file

1.1.2

  • Add more flags (#5)
  • Removed numpy dependency that was used in 1.1.0

1.1.0

  • Refactored a lot of things
  • Added Beiyang flag xD
  • Added interactive configurator for brightness adjustment
  • Added dark/light mode selection
  • Added color bar preview for RGB/8bit mode selection
  • Added random color arrangement feature (for NixOS)

1.0.7

  • Fix: Make config path not on init but when it's actually needed.

1.0.6

  • Remove hypy_utils dependency to make packaging easier.

1.0.5

  • Fix terminal emulator detection (PR #2)

1.0.4

1.0.3

  • Fix missing dependency for setuptools

1.0.2

  • Implement RGB to 8bit conversion
  • Add support for Python 3.7 and 3.8

1.0.1

  • Included 11 flag presets
  • Ability to lighten colors with --c-set-l <lightness>
  • Command-line flag chooser
  • Supports Python >= 3.9

More Screenshots

image image

Original Readme from Neofetch Below

logo

A command-line system information tool written in bash 3.2+

Packaging status

neofetch

Neofetch is a command-line system information tool written in bash 3.2+. Neofetch displays information about your operating system, software and hardware in an aesthetic and visually pleasing way.

The overall purpose of Neofetch is to be used in screen-shots of your system. Neofetch shows the information other people want to see. There are other tools available for proper system statistic/diagnostics.

The information by default is displayed alongside your operating system's logo. You can further configure Neofetch to instead use an image, a custom ASCII file, your wallpaper or nothing at all.

neofetch

You can further configure Neofetch to display exactly what you want it to. Through the use of command-line flags and the configuration file you can change existing information outputs or add your own custom ones.

Neofetch supports almost 150 different operating systems. From Linux to Windows, all the way to more obscure operating systems like Minix, AIX and Haiku. If your favourite operating system is unsupported: Open up an issue and support will be added.