[pacman-dev,v2] Convert download packages logic to multiplexed API

Message ID 20200507011930.56584-1-anatol.pomozov@gmail.com
State Superseded, archived
Headers show
Series [pacman-dev,v2] Convert download packages logic to multiplexed API | expand

Commit Message

Anatol Pomozov May 7, 2020, 1:19 a.m. UTC
Create a list of dload_payloads and pass it to the new _alpm_multi_*
interface.

Signed-off-by: Anatol Pomozov <anatol.pomozov@gmail.com>
---
 README                | 11 +++++++
 lib/libalpm/alpm.h    |  9 ------
 lib/libalpm/sync.c    | 73 +++++++++++++++----------------------------
 src/pacman/callback.c |  4 ---
 4 files changed, 36 insertions(+), 61 deletions(-)

Comments

Allan McRae May 7, 2020, 8:02 a.m. UTC | #1
On 7/5/20 11:19 am, Anatol Pomozov wrote:
> Create a list of dload_payloads and pass it to the new _alpm_multi_*
> interface.
> 
> Signed-off-by: Anatol Pomozov <anatol.pomozov@gmail.com>
> ---


Sorry - the error I sent for the "Swap alpm_db_update() implementation
to multiplexed version" actually occurred here:

../src/pacman/util.c: In function ‘sync_syncdbs’:
../src/pacman/util.c:156:2: error: ‘multibar_move_completed_up’
undeclared (first use in this function)
  156 |  multibar_move_completed_up = 0;
      |  ^~~~~~~~~~~~~~~~~~~~~~~~~~
../src/pacman/util.c:156:2: note: each undeclared identifier is reported
only once for each function it appears in


>  README                | 11 +++++++
>  lib/libalpm/alpm.h    |  9 ------
>  lib/libalpm/sync.c    | 73 +++++++++++++++----------------------------
>  src/pacman/callback.c |  4 ---
>  4 files changed, 36 insertions(+), 61 deletions(-)
> 
> diff --git a/README b/README
> index 6818ef70..f5bbaf02 100644
> --- a/README
> +++ b/README
> @@ -655,3 +655,14 @@ API CHANGES BETWEEN 5.1 AND 5.2
>  - alpm_errno_t - added member ALPM_ERR_MISSING_CAPABILITY_SIGNATURES
>  - alpm_sync_newversion() replaced with alpm_sync_get_new_version() which
>    does not filter on any ALPM_DB_USAGE_*.
> +
> +
> +API CHANGES BETWEEN 5.2 AND 6.0
> +===============================
> +
> +[REMOVED]
> +- ALPM_EVENT_PKGDOWNLOAD_START, ALPM_EVENT_PKGDOWNLOAD_DONE, ALPM_EVENT_PKGDOWNLOAD_FAILED
> +
> +[CHANGED]
> +
> +[ADDED]
> diff --git a/lib/libalpm/alpm.h b/lib/libalpm/alpm.h
> index 534a8189..903e2fbc 100644
> --- a/lib/libalpm/alpm.h
> +++ b/lib/libalpm/alpm.h
> @@ -414,15 +414,6 @@ typedef enum _alpm_event_type_t {
>  	ALPM_EVENT_PKG_RETRIEVE_DONE,
>  	/** Not all package files were successfully downloaded from a repository. */
>  	ALPM_EVENT_PKG_RETRIEVE_FAILED,
> -	/** A file will be downloaded from a repository; See alpm_event_pkgdownload_t
> -	 * for arguments */
> -	ALPM_EVENT_PKGDOWNLOAD_START,
> -	/** A file was downloaded from a repository; See alpm_event_pkgdownload_t
> -	 * for arguments */
> -	ALPM_EVENT_PKGDOWNLOAD_DONE,
> -	/** A file failed to be downloaded from a repository; See
> -	 * alpm_event_pkgdownload_t for arguments */
> -	ALPM_EVENT_PKGDOWNLOAD_FAILED,
>  	/** Disk space usage will be computed for a package. */
>  	ALPM_EVENT_DISKSPACE_START,
>  	/** Disk space usage was computed for a package. */
> diff --git a/lib/libalpm/sync.c b/lib/libalpm/sync.c
> index 855ca69c..f329de10 100644
> --- a/lib/libalpm/sync.c
> +++ b/lib/libalpm/sync.c
> @@ -726,47 +726,13 @@ static int find_dl_candidates(alpm_handle_t *handle, alpm_list_t **files)
>  	return 0;
>  }
>  
> -static int download_single_file(alpm_handle_t *handle, struct dload_payload *payload,
> -		const char *cachedir)
> -{
> -	alpm_event_pkgdownload_t event = {
> -		.type = ALPM_EVENT_PKGDOWNLOAD_START,
> -		.file = payload->remote_name
> -	};
> -	const alpm_list_t *server;
> -
> -	payload->handle = handle;
> -	payload->allow_resume = 1;
> -
> -	EVENT(handle, &event);
> -	for(server = payload->servers; server; server = server->next) {
> -		const char *server_url = server->data;
> -		size_t len;
> -
> -		/* print server + filename into a buffer */
> -		len = strlen(server_url) + strlen(payload->remote_name) + 2;
> -		MALLOC(payload->fileurl, len, RET_ERR(handle, ALPM_ERR_MEMORY, -1));
> -		snprintf(payload->fileurl, len, "%s/%s", server_url, payload->remote_name);
> -
> -		if(_alpm_download(payload, cachedir, NULL, NULL) != -1) {
> -			event.type = ALPM_EVENT_PKGDOWNLOAD_DONE;
> -			EVENT(handle, &event);
> -			return 0;
> -		}
> -		_alpm_dload_payload_reset_for_retry(payload);
> -	}
> -
> -	event.type = ALPM_EVENT_PKGDOWNLOAD_FAILED;
> -	EVENT(handle, &event);
> -	return -1;
> -}
> -
>  static int download_files(alpm_handle_t *handle)
>  {
>  	const char *cachedir;
>  	alpm_list_t *i, *files = NULL;
>  	int errors = 0;
>  	alpm_event_t event;
> +	alpm_list_t *payloads = NULL;
>  
>  	cachedir = _alpm_filecache_setup(handle);
>  	handle->trans->state = STATE_DOWNLOADING;
> @@ -814,26 +780,37 @@ static int download_files(alpm_handle_t *handle)
>  
>  		event.type = ALPM_EVENT_PKG_RETRIEVE_START;
>  		EVENT(handle, &event);
> -		event.type = ALPM_EVENT_PKG_RETRIEVE_DONE;
>  		for(i = files; i; i = i->next) {
>  			const alpm_pkg_t *pkg = i->data;
> -			struct dload_payload payload = {0};
> -
> -			STRDUP(payload.remote_name, pkg->filename, GOTO_ERR(handle, ALPM_ERR_MEMORY, finish));
> -			payload.servers = pkg->origin_data.db->servers;
> -			payload.max_size = pkg->size;
> -
> -			if(download_single_file(handle, &payload, cachedir) == -1) {
> -				errors++;
> -				event.type = ALPM_EVENT_PKG_RETRIEVE_FAILED;
> -				_alpm_log(handle, ALPM_LOG_WARNING, _("failed to retrieve some files\n"));
> -			}
> -			_alpm_dload_payload_reset(&payload);
> +			struct dload_payload *payload = NULL;
> +
> +			CALLOC(payload, 1, sizeof(*payload), GOTO_ERR(handle, ALPM_ERR_MEMORY, finish));
> +			STRDUP(payload->remote_name, pkg->filename, FREE(payload); GOTO_ERR(handle, ALPM_ERR_MEMORY, finish));
> +			STRDUP(payload->filepath, pkg->filename,
> +				FREE(payload->remote_name); FREE(payload);
> +				GOTO_ERR(handle, ALPM_ERR_MEMORY, finish));
> +			payload->max_size = pkg->size;
> +			payload->servers = pkg->origin_data.db->servers;
> +			payload->handle = handle;
> +			payload->allow_resume = 1;
> +
> +			payloads = alpm_list_add(payloads, payload);
> +		}
> +		event.type = ALPM_EVENT_PKG_RETRIEVE_DONE;
> +		if(_alpm_multi_download(handle, payloads, cachedir) == -1) {
> +			errors++;
> +			event.type = ALPM_EVENT_PKG_RETRIEVE_FAILED;
> +			_alpm_log(handle, ALPM_LOG_WARNING, _("failed to retrieve some files\n"));
>  		}
>  		EVENT(handle, &event);
>  	}
>  
>  finish:
> +	if(payloads) {
> +		alpm_list_free_inner(payloads, (alpm_list_fn_free)_alpm_dload_payload_reset);
> +		FREELIST(payloads);
> +	}
> +
>  	if(files) {
>  		alpm_list_free(files);
>  	}
> diff --git a/src/pacman/callback.c b/src/pacman/callback.c
> index 14dcaeb0..e7fce6b3 100644
> --- a/src/pacman/callback.c
> +++ b/src/pacman/callback.c
> @@ -363,10 +363,6 @@ void cb_event(alpm_event_t *event)
>  		case ALPM_EVENT_DISKSPACE_DONE:
>  		case ALPM_EVENT_HOOK_DONE:
>  		case ALPM_EVENT_HOOK_RUN_DONE:
> -		/* we can safely ignore those as well */
> -		case ALPM_EVENT_PKGDOWNLOAD_START:
> -		case ALPM_EVENT_PKGDOWNLOAD_DONE:
> -		case ALPM_EVENT_PKGDOWNLOAD_FAILED:
>  			/* nothing */
>  			break;
>  	}
>
Allan McRae May 7, 2020, 8:26 a.m. UTC | #2
On 7/5/20 6:02 pm, Allan McRae wrote:
> On 7/5/20 11:19 am, Anatol Pomozov wrote:
>> Create a list of dload_payloads and pass it to the new _alpm_multi_*
>> interface.
>>
>> Signed-off-by: Anatol Pomozov <anatol.pomozov@gmail.com>
>> ---
> 
> 
> Sorry - the error I sent for the "Swap alpm_db_update() implementation
> to multiplexed version" actually occurred here:
> 
> ../src/pacman/util.c: In function ‘sync_syncdbs’:
> ../src/pacman/util.c:156:2: error: ‘multibar_move_completed_up’
> undeclared (first use in this function)
>   156 |  multibar_move_completed_up = 0;
>       |  ^~~~~~~~~~~~~~~~~~~~~~~~~~
> ../src/pacman/util.c:156:2: note: each undeclared identifier is reported
> only once for each function it appears in
> 

And replying to myself again...

This is because I have not got an updated Multibar UI patch yet.  All
will be good when I apply that before this patch.

Carry on...

Patch

diff --git a/README b/README
index 6818ef70..f5bbaf02 100644
--- a/README
+++ b/README
@@ -655,3 +655,14 @@  API CHANGES BETWEEN 5.1 AND 5.2
 - alpm_errno_t - added member ALPM_ERR_MISSING_CAPABILITY_SIGNATURES
 - alpm_sync_newversion() replaced with alpm_sync_get_new_version() which
   does not filter on any ALPM_DB_USAGE_*.
+
+
+API CHANGES BETWEEN 5.2 AND 6.0
+===============================
+
+[REMOVED]
+- ALPM_EVENT_PKGDOWNLOAD_START, ALPM_EVENT_PKGDOWNLOAD_DONE, ALPM_EVENT_PKGDOWNLOAD_FAILED
+
+[CHANGED]
+
+[ADDED]
diff --git a/lib/libalpm/alpm.h b/lib/libalpm/alpm.h
index 534a8189..903e2fbc 100644
--- a/lib/libalpm/alpm.h
+++ b/lib/libalpm/alpm.h
@@ -414,15 +414,6 @@  typedef enum _alpm_event_type_t {
 	ALPM_EVENT_PKG_RETRIEVE_DONE,
 	/** Not all package files were successfully downloaded from a repository. */
 	ALPM_EVENT_PKG_RETRIEVE_FAILED,
-	/** A file will be downloaded from a repository; See alpm_event_pkgdownload_t
-	 * for arguments */
-	ALPM_EVENT_PKGDOWNLOAD_START,
-	/** A file was downloaded from a repository; See alpm_event_pkgdownload_t
-	 * for arguments */
-	ALPM_EVENT_PKGDOWNLOAD_DONE,
-	/** A file failed to be downloaded from a repository; See
-	 * alpm_event_pkgdownload_t for arguments */
-	ALPM_EVENT_PKGDOWNLOAD_FAILED,
 	/** Disk space usage will be computed for a package. */
 	ALPM_EVENT_DISKSPACE_START,
 	/** Disk space usage was computed for a package. */
diff --git a/lib/libalpm/sync.c b/lib/libalpm/sync.c
index 855ca69c..f329de10 100644
--- a/lib/libalpm/sync.c
+++ b/lib/libalpm/sync.c
@@ -726,47 +726,13 @@  static int find_dl_candidates(alpm_handle_t *handle, alpm_list_t **files)
 	return 0;
 }
 
-static int download_single_file(alpm_handle_t *handle, struct dload_payload *payload,
-		const char *cachedir)
-{
-	alpm_event_pkgdownload_t event = {
-		.type = ALPM_EVENT_PKGDOWNLOAD_START,
-		.file = payload->remote_name
-	};
-	const alpm_list_t *server;
-
-	payload->handle = handle;
-	payload->allow_resume = 1;
-
-	EVENT(handle, &event);
-	for(server = payload->servers; server; server = server->next) {
-		const char *server_url = server->data;
-		size_t len;
-
-		/* print server + filename into a buffer */
-		len = strlen(server_url) + strlen(payload->remote_name) + 2;
-		MALLOC(payload->fileurl, len, RET_ERR(handle, ALPM_ERR_MEMORY, -1));
-		snprintf(payload->fileurl, len, "%s/%s", server_url, payload->remote_name);
-
-		if(_alpm_download(payload, cachedir, NULL, NULL) != -1) {
-			event.type = ALPM_EVENT_PKGDOWNLOAD_DONE;
-			EVENT(handle, &event);
-			return 0;
-		}
-		_alpm_dload_payload_reset_for_retry(payload);
-	}
-
-	event.type = ALPM_EVENT_PKGDOWNLOAD_FAILED;
-	EVENT(handle, &event);
-	return -1;
-}
-
 static int download_files(alpm_handle_t *handle)
 {
 	const char *cachedir;
 	alpm_list_t *i, *files = NULL;
 	int errors = 0;
 	alpm_event_t event;
+	alpm_list_t *payloads = NULL;
 
 	cachedir = _alpm_filecache_setup(handle);
 	handle->trans->state = STATE_DOWNLOADING;
@@ -814,26 +780,37 @@  static int download_files(alpm_handle_t *handle)
 
 		event.type = ALPM_EVENT_PKG_RETRIEVE_START;
 		EVENT(handle, &event);
-		event.type = ALPM_EVENT_PKG_RETRIEVE_DONE;
 		for(i = files; i; i = i->next) {
 			const alpm_pkg_t *pkg = i->data;
-			struct dload_payload payload = {0};
-
-			STRDUP(payload.remote_name, pkg->filename, GOTO_ERR(handle, ALPM_ERR_MEMORY, finish));
-			payload.servers = pkg->origin_data.db->servers;
-			payload.max_size = pkg->size;
-
-			if(download_single_file(handle, &payload, cachedir) == -1) {
-				errors++;
-				event.type = ALPM_EVENT_PKG_RETRIEVE_FAILED;
-				_alpm_log(handle, ALPM_LOG_WARNING, _("failed to retrieve some files\n"));
-			}
-			_alpm_dload_payload_reset(&payload);
+			struct dload_payload *payload = NULL;
+
+			CALLOC(payload, 1, sizeof(*payload), GOTO_ERR(handle, ALPM_ERR_MEMORY, finish));
+			STRDUP(payload->remote_name, pkg->filename, FREE(payload); GOTO_ERR(handle, ALPM_ERR_MEMORY, finish));
+			STRDUP(payload->filepath, pkg->filename,
+				FREE(payload->remote_name); FREE(payload);
+				GOTO_ERR(handle, ALPM_ERR_MEMORY, finish));
+			payload->max_size = pkg->size;
+			payload->servers = pkg->origin_data.db->servers;
+			payload->handle = handle;
+			payload->allow_resume = 1;
+
+			payloads = alpm_list_add(payloads, payload);
+		}
+		event.type = ALPM_EVENT_PKG_RETRIEVE_DONE;
+		if(_alpm_multi_download(handle, payloads, cachedir) == -1) {
+			errors++;
+			event.type = ALPM_EVENT_PKG_RETRIEVE_FAILED;
+			_alpm_log(handle, ALPM_LOG_WARNING, _("failed to retrieve some files\n"));
 		}
 		EVENT(handle, &event);
 	}
 
 finish:
+	if(payloads) {
+		alpm_list_free_inner(payloads, (alpm_list_fn_free)_alpm_dload_payload_reset);
+		FREELIST(payloads);
+	}
+
 	if(files) {
 		alpm_list_free(files);
 	}
diff --git a/src/pacman/callback.c b/src/pacman/callback.c
index 14dcaeb0..e7fce6b3 100644
--- a/src/pacman/callback.c
+++ b/src/pacman/callback.c
@@ -363,10 +363,6 @@  void cb_event(alpm_event_t *event)
 		case ALPM_EVENT_DISKSPACE_DONE:
 		case ALPM_EVENT_HOOK_DONE:
 		case ALPM_EVENT_HOOK_RUN_DONE:
-		/* we can safely ignore those as well */
-		case ALPM_EVENT_PKGDOWNLOAD_START:
-		case ALPM_EVENT_PKGDOWNLOAD_DONE:
-		case ALPM_EVENT_PKGDOWNLOAD_FAILED:
 			/* nothing */
 			break;
 	}