Le lun. 4 nov. 2024 à 09:27, Emmanuel Bourg <ebo...@apache.org> a écrit :
>
> Le 02/11/2024 à 13:19, Gilles Sadowski a écrit :
>
> > My question was and still is:  Can modularization help?
>
> Modularization is very much needed for Commons Compress, I think we
> should at least split the compression part from the archive part, and
> then further split by file format (commons-compression-* and
> commons-archive-*).
>
> This would greatly improve the situation with the optional dependencies.
> Let's say I want to extract xz files, I would simply declare a
> dependency on commons-compression-xz in my pom.xml, which would pull the
> org.tukaani:xz dependency transitively, instead of having to declare two
> dependencies on commons-compress and org.tukaani:xz.
>
> Unfortunately modularization will hardly help with the dependencies on
> commons-codec, commons-lang and commons-io, because as of
> commons-compress 1.26 they are used almost everywhere in the code. Only
> commons-codec is restricted to a couple of formats (LZ4 and Snappy), but
> commons-io is now part of the core *public* API [1], which is really bad
> because we can no longer remove the dependency without breaking the
> binary compatibility (and I think we should do it as soon as possible
> before this new public method gets widely used).
>
> Emmanuel Bourg
>
> [1]
> https://github.com/apache/commons-compress/blob/863be804/src/main/java/org/apache/commons/compress/archivers/ArchiveInputStream.java#L224
>

Is it "bad" because "Commons IO" is too heavy as a dependency, or because
the "IOIterator" functionality is not actually used (and a plain
"Iterator" would
suffice)?
If it's the former, then the solution may again be to modularize "Commons IO".

Gilles

---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscr...@commons.apache.org
For additional commands, e-mail: dev-h...@commons.apache.org

Reply via email to