Comments (5)
I've had a bit of time to play around and I quite like @NobodyXu's suggestion.
What I've come up with is a type-driven approach in order to have compile-time guarantees about what methods can be called, rather than just having read_to_*_checked
error or panic if it doesn't have an associated entry.
Readers now implement two entry reader methods:
rs-async-zip/src/base/read/seek.rs
Line 84 in 846ec13
rs-async-zip/src/base/read/seek.rs
Line 98 in 846ec13
This still needs a bit of polish but the documentation page would essentially look like this: https://imgur.com/a/HRQkGvr
Where the read_to_*_checked()
methods are only defined on the WithEntry variant and no longer require it as a parameter.
I'm happy to settle on this unless anyone else has any other suggestions.
from rs-async-zip.
I've just pushed V0.0.15 which has the above changes - I'll go ahead and close this as a result. 👍
from rs-async-zip.
Yep, this wasn't something I ran into until after I had already switched over the API so didn't realise the implications at the time. That's why, unfortunately, the README example currently clones the ZipEntry to make it at least somewhat usable.
Whilst I wasn't a big fan of the old API (where a ZipEntryReader holds a reference to the ZipEntry itself), it worked well since there was a disjoint/split borrow on the ZipFileReader's fields.
Will hopefully tackle switching it back soon but feel free to do so if you happen to have the time.
from rs-async-zip.
Whilst I wasn't a big fan of the old API (where a ZipEntryReader holds a reference to the ZipEntry itself), it worked well since there was a disjoint/split borrow on the ZipFileReader's fields.
I have another idea of fixing this, by adding a new API to ZipFileReader:
pub fn entry_and_reader(&mut self) -> (&ZipEntry, &mut ZipEntryReader<...>);
from rs-async-zip.
Please make this clear in the documentation. something as simple as creating an iterator over the entries and checking if the filename is in a list and then decompressing doesn't work because of the issue highlighted in the first comment.
from rs-async-zip.
Related Issues (20)
- How to construct ZipDateTime without chrono dependency? HOT 3
- Unable To Locate EOCDR HOT 8
- `tokio::io::AsyncRead`(`Ext`) doesn't seem to be implemented for `async_zip::tokio::read::ZipEntryReader` HOT 2
- OwnedEntryStreamWriter HOT 2
- deflate64 support
- Support to read Info-ZIP Unicode Path Extra Field HOT 1
- Incorrect Zip64 Header Implementation HOT 8
- Tokio file doesn't satisfy `tokio::fs::File: futures_lite::AsyncWrite` HOT 1
- Incorrect parsing of zip64 extended information field HOT 1
- New Release? HOT 3
- Offset and size of entry in archive HOT 1
- Parallel Zip Stream support HOT 2
- Async ZIP Streaming?... HOT 13
- Test failures on 32-bit arches HOT 2
- data descriptor not supported error HOT 11
- Broken pipe occurs. HOT 4
- Streaming - Write file in chunks HOT 2
- Option to compress externally and just store input compressed byte stream.
- a computed CRC32 value did not match the expected value - when CRC is in data_descriptor HOT 2
- Can't properly use the stream method
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from rs-async-zip.