1
0
mirror of https://github.com/moparisthebest/pacman synced 2025-01-10 21:38:19 -05:00

* Fix the double package name URL when using XferCommand

* Fixed valgrind yelling about the sprintfs in md5/sha1 routines
This commit is contained in:
Aaron Griffin 2007-03-06 04:22:03 +00:00
parent 5baba84397
commit 90b75a0435
3 changed files with 12 additions and 10 deletions

View File

@ -47,6 +47,7 @@ char* _alpm_MDFile(char *filename)
FILE *file; FILE *file;
MD_CTX context; MD_CTX context;
int len; int len;
char hex[3];
unsigned char buffer[1024], digest[16]; unsigned char buffer[1024], digest[16];
ALPM_LOG_FUNC; ALPM_LOG_FUNC;
@ -66,10 +67,11 @@ char* _alpm_MDFile(char *filename)
ret = calloc(33, sizeof(char)); ret = calloc(33, sizeof(char));
for(i = 0; i < 16; i++) { for(i = 0; i < 16; i++) {
sprintf(ret+(i*2), "%02x", digest[i]); snprintf(hex, 3, "%02x", digest[i]);
strncat(ret, hex, 2);
} }
_alpm_log(PM_LOG_DEBUG, _("sha1(%s) = %s"), filename, ret); _alpm_log(PM_LOG_DEBUG, _("md5(%s) = %s"), filename, ret);
return(ret); return(ret);
} }
return(NULL); return(NULL);

View File

@ -319,8 +319,10 @@ int _alpm_downloadfiles_forreal(alpm_list_t *servers, const char *localpath,
char parsedCmd[PATH_MAX] = ""; char parsedCmd[PATH_MAX] = "";
char url[PATH_MAX]; char url[PATH_MAX];
char cwd[PATH_MAX]; char cwd[PATH_MAX];
/* build the full download url */ /* build the full download url */
snprintf(url, PATH_MAX, "%s://%s%s/%s", fileurl->scheme, fileurl->host, fileurl->doc, fn); snprintf(url, PATH_MAX, "%s://%s%s", fileurl->scheme, fileurl->host, fileurl->doc);
/* replace all occurrences of %o with fn.part */ /* replace all occurrences of %o with fn.part */
strncpy(origCmd, handle->xfercommand, sizeof(origCmd)); strncpy(origCmd, handle->xfercommand, sizeof(origCmd));
ptr1 = origCmd; ptr1 = origCmd;
@ -328,8 +330,7 @@ int _alpm_downloadfiles_forreal(alpm_list_t *servers, const char *localpath,
usepart = 1; usepart = 1;
ptr2[0] = '\0'; ptr2[0] = '\0';
strcat(parsedCmd, ptr1); strcat(parsedCmd, ptr1);
strcat(parsedCmd, fn); strcat(parsedCmd, output);
strcat(parsedCmd, ".part");
ptr1 = ptr2 + 2; ptr1 = ptr2 + 2;
} }
strcat(parsedCmd, ptr1); strcat(parsedCmd, ptr1);
@ -363,10 +364,7 @@ int _alpm_downloadfiles_forreal(alpm_list_t *servers, const char *localpath,
/* download was successful */ /* download was successful */
complete = alpm_list_add(complete, fn); complete = alpm_list_add(complete, fn);
if(usepart) { if(usepart) {
char fnpart[PATH_MAX]; rename(output, realfile);
/* rename "output.part" file to "output" file */
snprintf(fnpart, PATH_MAX, "%s.part", fn);
rename(fnpart, fn);
} }
} }
chdir(cwd); chdir(cwd);

View File

@ -387,6 +387,7 @@ char* _alpm_SHAFile(char *filename) {
FILE *file; FILE *file;
struct sha_ctx context; struct sha_ctx context;
int len, i; int len, i;
char hex[3];
unsigned char buffer[1024], digest[20]; unsigned char buffer[1024], digest[20];
char *ret; char *ret;
@ -405,7 +406,8 @@ char* _alpm_SHAFile(char *filename) {
ret = (char*)malloc(41); ret = (char*)malloc(41);
ret[0] = '\0'; ret[0] = '\0';
for(i = 0; i < 20; i++) { for(i = 0; i < 20; i++) {
sprintf(ret+(i*2), "%02x", digest[i]); snprintf(hex, 3, "%02x", digest[i]);
strncat(ret, hex, 2);
} }
_alpm_log(PM_LOG_DEBUG, _("sha1(%s) = %s"), filename, ret); _alpm_log(PM_LOG_DEBUG, _("sha1(%s) = %s"), filename, ret);
return(ret); return(ret);