-
-
Notifications
You must be signed in to change notification settings - Fork 57
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
Smarter Downloader::startDownload() #1066
Conversation
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #1066 +/- ##
==========================================
- Coverage 41.07% 40.93% -0.14%
==========================================
Files 58 58
Lines 4190 4204 +14
Branches 2304 2307 +3
==========================================
Hits 1721 1721
- Misses 1001 1015 +14
Partials 1468 1468 ☔ View full report in Codecov by Sentry. |
It is a technical approval. Maybe we need a extra step of discussion if this is a better solution than #1052 (or not) |
@veloman-yunkan Do we agree to merge this solution ? |
I think that it may be the best way to proceed. Although my intuition tells me that we may eventually run into other (more subtle) issues connected with this approach, I don't see why we should try to absolutely avoid them, since we can easily switch to the dumb solution at any time. |
The dubious logic of when an existing download can be reused by Downloader::startDownload() is preserved.
cc566c3
to
3733e50
Compare
Let's go with this solution then. If we face some bug with this, we will see then what to do. |
Fixes kiwix/kiwix-desktop#1022 |
This PR is an alternative to #1052. Similar to the latter it addresses the user-observable problems behind #1050 without fixing that issue the way it was formulated.
The shared property of #1052 and this PR is that they try to solve the bugs without enhancing the libkiwix API. The difference is that this PR tries to make
Downloader::startDownload()
smarter, whereas #1052 deprived it of the slightest smartness that it tried to exercise.Now having tried both approaches I think that we better follow the dumb path. Although we can close the seemingly small gap in
downloadCanBeReused()
(marked with anXXX
comment) my feeling is that trying to optimize for a theoretical situation that can hardly happen in practice is not justified.