You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Describe the problem or limitation you are having in your project
Godot doesn't support this compression format/algorithm. I would like to have it supported in order to use it with the convenient utility functions Godot offers PackedByteArray.compress and PackedByteArray.decompress.
Describe the feature / enhancement and how it helps to overcome the problem or limitation
I wouldn't be able to parse LZ4-compressed maps.
Describe how your proposal will work, with code, pseudo-code, mock-ups, and/or diagrams
If this enhancement will not be used often, can it be worked around with a few lines of script?
No, although if we ignore usage with builtin utility functions PackedByteArray.compress, PackedByteArray.decompress and FileAccess.open_compressed, it can probably be implemented as a GDExtension.
Is there a reason why this should be core and not an add-on in the asset library?
LZ4 does have its niche in achieving very fast (de)compression at the cost of compression ratio, to the point where even a tuned Zstandard is outmatched. As you can see in the Zstandard benchmarks, LZ4 can decompress more than twice as fast as Zstandard, at the cost of having a significantly worse compression ratio.
However, as the comments on the PR say, there really needs to be a strong use case for it for it to be integrated in core. As far as I know, the engine itself doesn't have a need for very fast (de)compression – Zstandard is good enough here (significantly better than e.g. zlib).
Describe the project you are working on
I'm working on making a Minecraft client, I'm currently parsing the region files.
In order to do that I need to decompress LZ4-compressed bytes.
Describe the problem or limitation you are having in your project
Godot doesn't support this compression format/algorithm. I would like to have it supported in order to use it with the convenient utility functions Godot offers
PackedByteArray.compress
andPackedByteArray.decompress
.Describe the feature / enhancement and how it helps to overcome the problem or limitation
I wouldn't be able to parse LZ4-compressed maps.
Describe how your proposal will work, with code, pseudo-code, mock-ups, and/or diagrams
godotengine/godot#100866
If this enhancement will not be used often, can it be worked around with a few lines of script?
No, although if we ignore usage with builtin utility functions
PackedByteArray.compress
,PackedByteArray.decompress
andFileAccess.open_compressed
, it can probably be implemented as a GDExtension.Is there a reason why this should be core and not an add-on in the asset library?
In the gaming industry, it's used in Nintendo Switch, Unity, Hitman 3, Death Stranding, Battlefield 4, Guild Wars 2, Crytek, Black Ops 3, Black Ops Cold War, FIFA, Sine Mora and 1000 Tiny Claws. (source: https://lz4.org/#lz4usedby).
Also,
PackedByteArray.compress
,PackedByteArray.decompress
andFileAccess.open_compressed
couldn't be used.The text was updated successfully, but these errors were encountered: