- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 394
Switch to zlib-rs by default and drop other zlib backends #1963
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
Conversation
e4ccc1c    to
    cc3a6da      
    Compare
  
    As of zlib-rs 0.5.0 (depended on by flate2 1.1.1), zlib-rs no longer exports C symbols by default, so it doesn't conflict with any other zlib that might be loaded into the address space. This removed the primary issue that made zlib selection a challenge that needed to be exposed to users: users may already have some other particular preference on zlib implementations, or want to use a system library, or want to ensure C dependencies use a particular zlib. Since zlib-rs 0.5.0 no longer conflicts with other zlib implementations, gix can make this choice independently and not create issues for the user. Given that, use zlib-rs by default, for performance out of the box with no C compiler requirement, and deprecate all the feature flags for other variations. A future major version bump can drop all of these features. This also means that (for instance) max-performance becomes the same as max-performance-safe, so such features are deprecated as well. Depend on flate2 with `default-features = false`, which brings us closer to eliminating the `miniz_oxide` dependency, which will improve build time for everyone. Currently, the `gix-archive` dependency on `zip` still activates the `zip/deflate` feature which enables `flate2/rust_backend`; this can be fixed to use `deflate-flate2` as soon as zip-rs/zip2#340 is fixed upstream. Fixes: GitoxideLabs#1961
cc3a6da    to
    96164c5      
    Compare
  
    | OK, CI is passing now. | 
…itoxideLabs#1962) The module is still hidden from the documentation, and those who discover it anyway will be informed that it's not for general use.
| Thanks a lot for this wonderful PR! I am very much looking forward to massively simplify the features configuration in a follow-up step. It also feels like  It's also great to see that  It's a bit unfortunate that it recently became more than 2x slower (#1915), but this probably means the 1% is even more of an accomplishment now. | 
| @Byron Thanks for merging this! Regarding the test fix for  | 
| I am thanking you! 
 That didn't work, unfortunately, as integration tests don't build the crate under test with  | 
| On Mon, Apr 21, 2025 at 05:06:08AM -0700, Sebastian Thiel wrote:
 > Regarding the test fix for `cargo test -r`, I _think_ it'd be fine to use `cfg(test)` to make the API not exist when not testing. `cfg(test)` should work any time you're doing `cargo test`, whether you're using `-r` or not.
 That didn't work, unfortunately, as integration tests don't build the crate under test with `test`, just the test-binary itself if built with `test`. I tried that first and settled with leaving it in, but making it hard to discover while discouraging its usage. Oh, right: that does work for unit tests *in* the crate, but not for
*integration* tests in `tests/`. So, if you want to keep that API
private, you could move the tests you have into the crate as integration
tests. | 
| Indeed, that would work and it's nothing I even considered, admittedly. Moving tests from integration to unit-level can still happen, of course, but I think it's fine to do it once there is a trigger, like code in the wild that somehow abuses the presence of this test-trait. | 
The issue was introduced in GitoxideLabs#1963, and incorrectly assumed that the `max-performance-safe` feature flag was only used to enable other feature flags. But this feature flag is itself used in various places, so failing to enable it leads to worse codegen. This issue was discussed/found in GitoxideLabs#2148
The issue was introduced in GitoxideLabs#1963, and incorrectly assumed that the `max-performance-safe` feature flag was only used to enable other feature flags. But this feature flag is itself used in various places, so failing to enable it leads to worse codegen. This issue was discussed/found in GitoxideLabs#2148
As of zlib-rs 0.5.0 (depended on by flate2 1.1.1), zlib-rs no longer
exports C symbols by default, so it doesn't conflict with any other zlib
that might be loaded into the address space.
This removed the primary issue that made zlib selection a challenge
that needed to be exposed to users: users may already have some other
particular preference on zlib implementations, or want to use a system
library, or want to ensure C dependencies use a particular zlib. Since
zlib-rs 0.5.0 no longer conflicts with other zlib implementations, gix
can make this choice independently and not create issues for the user.
Given that, use zlib-rs by default, for performance out of the box with
no C compiler requirement, and deprecate all the feature flags for other
variations. A future major version bump can drop all of these features.
This also means that (for instance) max-performance becomes the same as
max-performance-safe, so such features are deprecated as well.
Depend on flate2 with
default-features = false, which brings us closerto eliminating the
miniz_oxidedependency, which will improve buildtime for everyone. Currently, the
gix-archivedependency onzipstill activates the
zip/deflatefeature which enablesflate2/rust_backend; this can be fixed to usedeflate-flate2as soonas zip-rs/zip2#340 is fixed upstream.
Fixes: #1961