Compare commits

..

No commits in common. "64ac7a6ef3a903959ffe4c9d621ec5451104de29" and "3bb2a0bd10f871aa1f5732c87619f183820426a2" have entirely different histories.

2 changed files with 16 additions and 52 deletions

View file

@ -41,15 +41,16 @@ than welcome to use it on your system: it's pretty [fast...](#benchmarks)
- Shell Colors - Shell Colors
- Did I mention fast? - Did I mention fast?
## Motivation ## Installation
Fastfetch, as its name indicates, a very fast fetch tool written in C, however, Microfetch is packaged in [nixpkgs](https://github.com/nixos/nixpkgs). You can
I am not interested in any of its additional features and I very much dislike get it through the unstable channel for the time being. The Nix flake can also
the defaults. Microfetch is a fetch tool that you would normally write in Bash be used for bleeding-edge builds.
and put in your `~/.bashrc` but actually _really_ fast because it opts-out of
all customization options provided by Fastfetch. Why? Because I can.
I cannot re-iterate it enough, Microfetch is annoyingly fast. Non-Nix users will have to build Microfetch with `cargo`.
Microfetch is _currently_ not available anywhere else. Though, does it _really_
have to be?
## Benchmarks ## Benchmarks
@ -60,9 +61,9 @@ benchmarks with Hyperfine on my desktop system.
| Command | Mean [ms] | Min [ms] | Max [ms] | Relative | Written by raf? | | Command | Mean [ms] | Min [ms] | Max [ms] | Relative | Written by raf? |
| :----------- | ----------: | -------: | -------: | -------------: | --------------: | | :----------- | ----------: | -------: | -------: | -------------: | --------------: |
| `microfetch` | 1.3 ± 0.0 | 1.3 | 1.4 | 1.00 | yes | | `microfetch` | 1.3 ± 0.0 | 1.3 | 1.4 | 1.00 | yes |
| `fastfetch` | 31.9 ± 0.8 | 30.8 | 33.8 | 24.08 ± 0.98 | no |
| `pfetch` | 254.2 ± 4.8 | 246.7 | 264.9 | 191.97 ± 7.10 | no | | `pfetch` | 254.2 ± 4.8 | 246.7 | 264.9 | 191.97 ± 7.10 | no |
| `neofetch` | 735.4 ± 9.5 | 721.1 | 752.8 | 555.48 ± 19.08 | no | | `neofetch` | 735.4 ± 9.5 | 721.1 | 752.8 | 555.48 ± 19.08 | no |
| `fastfetch` | 31.9 ± 0.8 | 30.8 | 33.8 | 24.08 ± 0.98 | no |
_As far as I'm concerned, Microfetch is faster than almost every fetch tool _As far as I'm concerned, Microfetch is faster than almost every fetch tool
there is. The only downside of using Rust is introducing more "bloated" there is. The only downside of using Rust is introducing more "bloated"
@ -73,29 +74,11 @@ Nix's binary cache, though._
[Getting Started Guide]: https://bheisler.github.io/criterion.rs/book/getting_started.html [Getting Started Guide]: https://bheisler.github.io/criterion.rs/book/getting_started.html
To benchmark individual functions, [Criterion.rs] is used. See Criterion's To benchmark individual functions, [Criterion.rs] is used. See Criterion's
[Getting Started Guide] for details or just run `cargo bench` to benchmark all [Getting Started Guide] for details or just run `cargo bench` to benchmark
features of Microfetch. all features of Microfetch
## Installation
Microfetch is packaged in [nixpkgs](https://github.com/nixos/nixpkgs). You can
get it through the unstable channel for the time being. The Nix flake can also
be used for bleeding-edge builds.
Non-Nix users will have to build Microfetch with `cargo`. It is not published
anywhere but I imagine you can use `cargo install --git` to install it from
source.
```bash
cargo install --git https://github.com/notashelf/microfetch.git
```
Microfetch is _currently_ not available anywhere else. Though, does it _really_
have to be?
## Customizing ## Customizing
You can't. You can't\*.
### Why? ### Why?
@ -105,12 +88,9 @@ those increment execution time and resource consumption by a lot.
### Really? ### Really?
To be fair, you _can_ customize Microfetch by, well, patching it. It's not the To be fair, you _can_ customize Microfetch by... Well, patching it. It's not the
best way per se, but it will be the only way that does not compromise on speed. best way per se, but it will be the only way that does not compromise on speed.
The Nix package allows passing patches in a streamlined manner by passing
`.overrideAttrs` to the derivation.
## Contributing ## Contributing
I will, mostly, reject feature additions. This is not to say you should avoid I will, mostly, reject feature additions. This is not to say you should avoid
@ -118,8 +98,7 @@ them altogether, as you might have a really good idea worth discussing but as a
general rule of thumb consider talking to me before creating a feature PR. general rule of thumb consider talking to me before creating a feature PR.
Contributions that help improve performance in specific areas of Microfetch are Contributions that help improve performance in specific areas of Microfetch are
welcome. Though, prepare to be bombarded with questions if your changes are welcome. Though, prepare to be bombarded with questions.
large.
## Hacking ## Hacking
@ -132,21 +111,7 @@ Non-nix users will need `cargo` and `gcc` installed on their system, see
## Thanks ## Thanks
Huge thanks to everyone who took the time to make pull requests or nag me in Huge thanks to everyone who took the time to make pull requests or nag me in
person about current issues. To list a few, special thanks to: person about current issues.
- [@Nydragon](https://github.com/Nydragon) - For packaging Microfetch in Nixpkgs
- [@ErrorNoInternet](https://github.com/ErrorNoInternet) - Performance
improvements and code assistance
- [@SoraTenshi](https://github.com/SoraTenshi) - General tips and code
improvements
- [@bloxx12](https://github.com/bloxx12) - Performance improvements and
benchmarking plots
- [@sioodmy](https://github.com/sioodmy) - Being cute
- [@mewoocat](https://github.com/mewoocat) - The awesome NixOS logo ASCII used
in Microfetch
Additionally a big thank you to everyone who used, talked about or criticized
Microfetch. I might have missed your name here, but you have my thanks.
## License ## License

View file

@ -11,8 +11,7 @@
pkgsForEach = nixpkgs.legacyPackages; pkgsForEach = nixpkgs.legacyPackages;
in { in {
packages = forEachSystem (system: { packages = forEachSystem (system: {
default = self.packages.${system}.microfetch; default = pkgsForEach.${system}.callPackage ./nix/package.nix {};
microfetch = pkgsForEach.${system}.callPackage ./nix/package.nix {};
}); });
devShells = forEachSystem (system: { devShells = forEachSystem (system: {