-
Notifications
You must be signed in to change notification settings - Fork 20
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for the Nix package manager #172
Conversation
This looks very interesting. From my experience, invoking Just out of curiosity, what is your P.S. What are the runtime differences when you compile |
I have done a bit of testing in a NixOS Live ISO environment with about 1100 packages installed, and this method is still very slow, with the package count taking about So as much as I would like Nix support to be added, this method just is not fast enough for If you are interested, you could try to get the package count in other ways, as I tried in #150, but this probably requires deeper knowledge of the nix source code. I also had a look at what |
I think that command is the standard for getting the amount of packages. It's also whats used in fastfetch (which is which is what I compared it to), as well as most stack overflow answers. (all packages built with
I think my previous test were wrong (I'm not even sure how I got the original results). These numbers seem to be more realistic. In reply to your latest comment, as well as the more realistic results, it is probably best to cache the result somewhere. I'll look into it later tomorrow to see if that's the best way to go. |
(I just changed it to a draft until I find a faster, but still reliable method) |
Hi, thanks for the contribution. I personally want to see more progress in #150 due to the performance penalty of dishing out to a command-line program. To respond to @Gobidev on the caching proposal, I believe it shouldn't be libmacchina's responsibility to cache things. I'd rather keep the library as stateless as possible (despite the obvious oxymoron), downstream programs should implement this if they so wish. |
Quick update: Hopefully this method works and can give good speeds! (well, as good as you'll get with an sqlite database) |
Nice, that sounds really promising, thank you for putting in the work! I will close #150 in favor of this PR. |
I think the best sqlite query is Here are the results of hyperfine:
This lookup is grabbing a slightly different metric which gives 739 on my system (nix store giving 1306). So I think nix store is including extra things that don't count as packages (as the Also, I've updated sqlite from 0.31.1 to 0.36.0. |
Big thanks for the contribution (TIL about breaking out of loops with labels, thanks for that too!). |
Thanks again for your work. I didn't have much time to test this, yet, but at least in a NixOS live CD environment, it doesn't really seem to work right now. Your method returns
If the lower count is more accurate than the one returned by I will check your method on a system with NixOS actually installed and on a different distro with Nix installed to see if that gives different results, maybe there is just something weird about the NixOS live CD. |
It only lists the main installed packages. I've uploaded a video of me adding cargo (to a Mint system that I freshly installed Nix onto), and despite it having several dependencies, it only recognizes it as a single one. example_of_method_text.mp4(I haven't tested it on the NixOS live env, but my guess is that it only shows 3 as it is registering basically everything under a single meta package) |
The other option for an sqlite search is doing |
How does that count compare to the other methods? |
Wrote my thought process, as well as some notes. Hopefully you'd agree that the current method in the pr is the best one (well, at least that I could find):
If I remove the
Getting the overlap by doing the following: nix-store -q --requisites /run/current-system/sw > /tmp/pkgs_system.txt
nix-store -q --requisites ~/.nix-profile > /tmp/pkgs_profile.txt
awk 'FNR==NR {a[$0]++; next} !($0 in a)' /tmp/pkgs_profile.txt /tmp/pkgs_system.txt | wc -l # Gets the count of different lines between the 2 files (on my system being 651) |
Thanks a lot for the extensive comparison :) Based on your numbers, your current method seems to be the one to go with. If there was a way to include dependencies in the count, that would be preferable, but that might not be possible with this approach. I tested your method on a stock NixOS system, and it returns Thanks again for the amount of work you put into this, it is nice to finally see Nix support being added to libmacchina^^ |
I tested this PR on a single- and multi-user Nix installation on Arch Linux and on both it returns the package count without dependencies as expected. @grtcdr what is your opinion on the dependency count not being included? AFAIK it is included for all other package managers, but the count without it is not inherently wrong. |
I'd include the dependencies to avoid the inevitable, unwanted reports we'd undoubtedly receive from users. I'm familiar with the basic concepts of Nix, but the intricacies of it escape me, so if the majority agrees that including just the base packages is a better index then I'm all for it. |
How about something like On a fresh install of nix on another distro, it outputs 0. Then once I install cargo (which has 63 dependacies, that it says at the top of the output when its downloading), it outputs 64 as expected. Sorry, not sure how I didnt notice that before. I guess doing my tests on a non-nix system is easier to read as there isn't soo many packages installed. |
Yeah, this is wayy better! This slightly larger number is understandable as the new sqlite lookup includes every generation (which won't add any on my system due to me cleaning old generations recently), as well as packages on your system but not on the current generation (ie from |
I have tested this new method and found the following: On an Arch installation with Nix installed in multi-user mode, I get On an Arch installation with Nix installed in single-user mode, I get On a NixOS installation, i get This method is still not perfect but imo the best we've had so far. |
Remember to clear your cache ( |
I'm happy with what we've got - thank you so much for the quality work - shall we get this merged? |
Yeah, sounds good! |
* Fix Armv7 build (#158) * Add armv7 build target * Fix mismatched types for pointer width 32 * Use `sh` instead of `python` for `which` assertion * Replace mach with mach2 (#157) * feat: add support for RPM `ndb` databases (#159) * feat: add support for RPM `ndb` databases * chore: always try sqlite before librpm * chore: remove `rpm` feature * fix: librpm call not lazily evaluated * Add `librpm` dependency note to README (#160) * Update the changelog * Bump version to 7.1.0 * Fix i686 build (#162) closes #161 * Add Sonoma to macos_version_to_name (#163) * BREAKING CHANGE: Change BatteryReadout::health return value to u8 There's no particular reason why one should allocate 64 bits for a value that can only be <= 100. As a bonus, ceil() the return value before finally casting to u8. * Update BatteryReadout::health function signature for other operating systems besides Linux. * Added general detection for wayland compositors (#164) * Upgrade dependencies to their latest versions * Update changelog Make some formatting changes as well. * Add missing generic argument sqlite's changed a bit between releases. * Bump version to 7.2.0 * Add missing second generic argument to sqlite read() call * Remove unneeded argument to unistd::gethostname function call * Remove unused variable * Refactor obsolete find_ifa function * Bump version to 7.2.1 * Bump vergen version * Use gitcl feature of vergen This depends on the git binary, more ubiquituous than the libgit2 bindings, so it should technically work on every platform we support. * Refactor the old vergen interface * Add new entry to the changelog * Update version to 7.2.2 * Replace flatten() calls with map_while(Result::ok) * Fix Readouts struct's network field type Closes: #168 * Improve CI workflow (#169) * Replace discontinued actions-rs * Split cargo fmt and clippy into their own CI job * Faster package count on Alpine Linux (#170) * Bump version to 7.2.3 * added macos 15 version name (#171) https://www.apple.com/newsroom/2024/06/macos-sequoia-takes-productivity-and-intelligence-on-mac-to-new-heights/ * Removed panic if local gpu db is not able to be read (#173) * Add support for the Nix package manager (#172) Added support for the Nix package manager using Nix' SQLite database. * Bump version and update changelog * linux: Safely exit when homebrew is not installed * Improve linuxbrew keepme safeguard * Remove unused import * Bump version to 7.3.1 * Allow disk_space function to accept a path argument (#156) BREAKING CHANGE: allow disk_space function to accept a path argument - Bump version and update changelog - Change disk_space path argument to be of type &Path and check path exists in shared::disk_space - Add missing import for openwrt --------- Co-authored-by: Adrian Groh <50576978+Gobidev@users.noreply.github.com> Co-authored-by: Silas Groh <silas.groh@t-online.de> Co-authored-by: grtcdr <tahaaziz.benali@esprit.tn> Co-authored-by: Rex Ng <rex.ky.ng@gmail.com> Co-authored-by: Absolpega <106615943+Absolpega@users.noreply.github.com> Co-authored-by: grtcdr <ba.tahaaziz@gmail.com> Co-authored-by: Matthias Baer <matthiasbaer@bluewin.ch> Co-authored-by: Rex Ng <timescam@duck.com> Co-authored-by: coolGi <57488297+coolGi2007@users.noreply.github.com>
Similar to #150 except updated to the latest version of libmacchina. (closes #120)
Unlike that commit which attempts to estimate the total amount of nix pkgs by counting the files in
/nix/store
, this uses nix's sqlite database (/nix/var/nix/db/db.sqlite
).The sqlite library has also been updated (0.31.1 -> 0.36.0) due to it having the ability to read the path as a uri (so that I can tell sqlite that the database is immutable).
This queries the database using
SELECT COUNT(path) FROM ValidPaths WHERE ultimate=1
(which is equivalent tonix path-info --all --sigs | grep ultimate | wc -l
) which gives a time of around 10ms, while the equivalent nix command gives around 40ms.This lookup is grabbing a slightly different metric which gives 739 on my system (nix store giving 1306). So I think nix store is including extra things that don't count as packages (as the
/nix/store
folder stores everything from fetches, sources, man pages, binaries, etc).(all packages built with
cargo build --release
, and tested withhyperfine -w 4 -m 500 -N
)