[pacman-dev] Duplicated lines of "downloading foo.db..." with --noprogressbar

David Macek david.macek.0 at gmail.com
Tue May 5 22:32:02 UTC 2015


On 4. 5. 2015 14:55, Andrew Gregory wrote:
> I don't think this is the right solution.  The comments in
> dload_progress_cb suggest that the callback is not intended to be
> called until we have actually downloaded something. So, file_xfered
> should always equal 0 exactly once per downloaded file.  I think it
> makes more sense to fix dload_progress_cb.  We might also consider
> using the event callback rather than the download callback when
> noprogressbar is set.

Okay. I was thinking and came up with another idea, along the lines of this incomplete patch:

--- a/lib/libalpm/dload.c
+++ b/lib/libalpm/dload.c
@@ -127,15 +127,17 @@ static int dload_progress_cb(void *file, double dltotal, double dlnow,
 
 	/* initialize the progress bar here to avoid displaying it when
 	 * a repo is up to date and nothing gets downloaded */
-	if(payload->prevprogress == 0) {
+	if(payload->prevprogress == -1) {
 		payload->handle->dlcb(payload->remote_name, 0, (off_t)dltotal);
+		payload->prevprogress = payload->initial_size;
 	}
 
 	/* do NOT include initial_size since it wasn't part of the package's
 	 * download_size (nor included in the total download size callback) */
-	payload->handle->dlcb(payload->remote_name, (off_t)dlnow, (off_t)dltotal);
-
-	payload->prevprogress = current_size;
+	if(payload->prevprogress != current_size) {
+		payload->handle->dlcb(payload->remote_name, (off_t)dlnow, (off_t)dltotal);
+		payload->prevprogress = current_size;
+	}
 
 	return 0;
 }

If putting -1 into prevprogress is undesirable, can we introduce a new field into the dload_payload type? (If introducing a new field is a big deal for libalpm clients, maybe we can future-proof the struct by adding a `struct dload_payload_internal *_alpm_internal` field instead and keeping `struct dload_payload_internal` unexported.)

-- 
David Macek

-------------- next part --------------
A non-text attachment was scrubbed...
Name: smime.p7s
Type: application/pkcs7-signature
Size: 4234 bytes
Desc: S/MIME Cryptographic Signature
URL: <https://lists.archlinux.org/pipermail/pacman-dev/attachments/20150506/de86dba6/attachment.p7s>


More information about the pacman-dev mailing list