mirror of
https://github.com/mirror/wget.git
synced 2025-01-24 11:20:13 +08:00
[svn] Concatenate strings using concat_strings.
This commit is contained in:
parent
5fca43a4c0
commit
c36e9a5272
@ -1,3 +1,15 @@
|
||||
2005-03-18 Hrvoje Niksic <hniksic@xemacs.org>
|
||||
|
||||
* init.c (cmd_file): Use concat_strings.
|
||||
|
||||
* http.c (basic_authentication_encode): Use concat_strings.
|
||||
|
||||
* ftp-ls.c (ftp_index): Use concat_strings.
|
||||
|
||||
* ftp-basic.c (ftp_request): Use concat_strings.
|
||||
|
||||
* utils.c (concat_strings): New function.
|
||||
|
||||
2005-03-12 Hrvoje Niksic <hniksic@xemacs.org>
|
||||
|
||||
* init.c (simple_atof): Handle negative numbers; skip whitespace
|
||||
|
@ -93,10 +93,11 @@ ftp_response (int fd, char **ret_line)
|
||||
static char *
|
||||
ftp_request (const char *command, const char *value)
|
||||
{
|
||||
char *res = (char *)xmalloc (strlen (command)
|
||||
+ (value ? (1 + strlen (value)) : 0)
|
||||
+ 2 + 1);
|
||||
sprintf (res, "%s%s%s\r\n", command, value ? " " : "", value ? value : "");
|
||||
char *res;
|
||||
if (value)
|
||||
res = concat_strings (command, " ", value, "\r\n", (char *) 0);
|
||||
else
|
||||
res = concat_strings (command, "\r\n", (char *) 0);
|
||||
if (opt.server_response)
|
||||
{
|
||||
/* Hack: don't print out password. */
|
||||
|
@ -872,9 +872,10 @@ ftp_index (const char *file, struct url *u, struct fileinfo *f)
|
||||
|
||||
tmpu = url_escape (u->user);
|
||||
tmpp = u->passwd ? url_escape (u->passwd) : NULL;
|
||||
upwd = (char *)xmalloc (strlen (tmpu)
|
||||
+ (tmpp ? (1 + strlen (tmpp)) : 0) + 2);
|
||||
sprintf (upwd, "%s%s%s@", tmpu, tmpp ? ":" : "", tmpp ? tmpp : "");
|
||||
if (tmpp)
|
||||
upwd = concat_strings (tmpu, ":", tmpp, "@", (char *) 0);
|
||||
else
|
||||
upwd = concat_strings (tmpu, "@", (char *) 0);
|
||||
xfree (tmpu);
|
||||
xfree_null (tmpp);
|
||||
}
|
||||
|
@ -271,8 +271,7 @@ getftp (struct url *u, wgint *len, wgint restval, ccon *con)
|
||||
if (con->proxy)
|
||||
{
|
||||
/* If proxy is in use, log in as username@target-site. */
|
||||
logname = xmalloc (strlen (user) + 1 + strlen (u->host) + 1);
|
||||
sprintf (logname, "%s@%s", user, u->host);
|
||||
logname = concat_strings (user, "@", u->host, (char *) 0);
|
||||
}
|
||||
|
||||
/* Login to the server: */
|
||||
|
@ -2583,7 +2583,7 @@ base64_encode (const char *s, char *store, int length)
|
||||
static char *
|
||||
basic_authentication_encode (const char *user, const char *passwd)
|
||||
{
|
||||
char *t1, *t2, *res;
|
||||
char *t1, *t2;
|
||||
int len1 = strlen (user) + 1 + strlen (passwd);
|
||||
int len2 = BASE64_LENGTH (len1);
|
||||
|
||||
@ -2593,10 +2593,7 @@ basic_authentication_encode (const char *user, const char *passwd)
|
||||
t2 = (char *)alloca (len2 + 1);
|
||||
base64_encode (t1, t2, len1);
|
||||
|
||||
res = (char *)xmalloc (6 + len2 + 1);
|
||||
sprintf (res, "Basic %s", t2);
|
||||
|
||||
return res;
|
||||
return concat_strings ("Basic ", t2, (char *) 0);
|
||||
}
|
||||
|
||||
#define SKIP_WS(x) do { \
|
||||
|
@ -748,7 +748,6 @@ cmd_file (const char *com, const char *val, void *closure)
|
||||
}
|
||||
else
|
||||
{
|
||||
char *result;
|
||||
int homelen;
|
||||
char *home = home_dir ();
|
||||
if (!home)
|
||||
@ -762,12 +761,7 @@ cmd_file (const char *com, const char *val, void *closure)
|
||||
for (++val; ISSEP (*val); val++)
|
||||
;
|
||||
|
||||
result = xmalloc (homelen + 1 + strlen (val) + 1);
|
||||
memcpy (result, home, homelen);
|
||||
result[homelen] = '/';
|
||||
strcpy (result + homelen + 1, val);
|
||||
|
||||
*pstring = result;
|
||||
*pstring = concat_strings (home, "/", val, (char *) 0);
|
||||
}
|
||||
|
||||
#ifdef WINDOWS
|
||||
|
@ -1009,7 +1009,7 @@ char *
|
||||
url_full_path (const struct url *url)
|
||||
{
|
||||
int length = full_path_length (url);
|
||||
char *full_path = (char *)xmalloc(length + 1);
|
||||
char *full_path = (char *) xmalloc (length + 1);
|
||||
|
||||
full_path_write (url, full_path);
|
||||
full_path[length] = '\0';
|
||||
|
48
src/utils.c
48
src/utils.c
@ -226,6 +226,54 @@ aprintf (const char *fmt, ...)
|
||||
}
|
||||
return NULL; /* unreached */
|
||||
}
|
||||
|
||||
/* Concatenate the NULL-terminated list of string arguments into
|
||||
freshly allocated space. */
|
||||
|
||||
char *
|
||||
concat_strings (const char *str0, ...)
|
||||
{
|
||||
va_list args;
|
||||
int saved_lengths[5]; /* inspired by Apache's apr_pstrcat */
|
||||
char *ret, *p;
|
||||
|
||||
const char *next_str;
|
||||
int total_length = 0;
|
||||
int argcount;
|
||||
|
||||
/* Calculate the length of and allocate the resulting string. */
|
||||
|
||||
argcount = 0;
|
||||
VA_START (args, str0);
|
||||
for (next_str = str0; next_str != NULL; next_str = va_arg (args, char *))
|
||||
{
|
||||
int len = strlen (next_str);
|
||||
if (argcount < countof (saved_lengths))
|
||||
saved_lengths[argcount++] = len;
|
||||
total_length += len;
|
||||
}
|
||||
va_end (args);
|
||||
p = ret = xmalloc (total_length + 1);
|
||||
|
||||
/* Copy the strings into the allocated space. */
|
||||
|
||||
argcount = 0;
|
||||
VA_START (args, str0);
|
||||
for (next_str = str0; next_str != NULL; next_str = va_arg (args, char *))
|
||||
{
|
||||
int len;
|
||||
if (argcount < countof (saved_lengths))
|
||||
len = saved_lengths[argcount++];
|
||||
else
|
||||
len = strlen (next_str);
|
||||
memcpy (p, next_str, len);
|
||||
p += len;
|
||||
}
|
||||
va_end (args);
|
||||
*p = '\0';
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* Return pointer to a static char[] buffer in which zero-terminated
|
||||
string-representation of TM (in form hh:mm:ss) is printed.
|
||||
|
@ -68,12 +68,14 @@ char **sepstring PARAMS ((const char *));
|
||||
int frontcmp PARAMS ((const char *, const char *));
|
||||
void fork_to_background PARAMS ((void));
|
||||
|
||||
#ifdef HAVE_STDARG_H
|
||||
#ifdef WGET_USE_STDARG
|
||||
char *aprintf PARAMS ((const char *, ...))
|
||||
GCC_FORMAT_ATTR (1, 2);
|
||||
#else /* not HAVE_STDARG_H */
|
||||
char *concat_strings PARAMS ((const char *, ...));
|
||||
#else /* not WGET_USE_STDARG */
|
||||
char *aprintf ();
|
||||
#endif /* not HAVE_STDARG_H */
|
||||
char *concat_strings ();
|
||||
#endif /* not WGET_USE_STDARG */
|
||||
|
||||
void touch PARAMS ((const char *, time_t));
|
||||
int remove_link PARAMS ((const char *));
|
||||
|
Loading…
Reference in New Issue
Block a user