mirror of
https://github.com/mirror/wget.git
synced 2025-01-09 11:50:15 +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>
|
2005-03-12 Hrvoje Niksic <hniksic@xemacs.org>
|
||||||
|
|
||||||
* init.c (simple_atof): Handle negative numbers; skip whitespace
|
* init.c (simple_atof): Handle negative numbers; skip whitespace
|
||||||
|
@ -93,10 +93,11 @@ ftp_response (int fd, char **ret_line)
|
|||||||
static char *
|
static char *
|
||||||
ftp_request (const char *command, const char *value)
|
ftp_request (const char *command, const char *value)
|
||||||
{
|
{
|
||||||
char *res = (char *)xmalloc (strlen (command)
|
char *res;
|
||||||
+ (value ? (1 + strlen (value)) : 0)
|
if (value)
|
||||||
+ 2 + 1);
|
res = concat_strings (command, " ", value, "\r\n", (char *) 0);
|
||||||
sprintf (res, "%s%s%s\r\n", command, value ? " " : "", value ? value : "");
|
else
|
||||||
|
res = concat_strings (command, "\r\n", (char *) 0);
|
||||||
if (opt.server_response)
|
if (opt.server_response)
|
||||||
{
|
{
|
||||||
/* Hack: don't print out password. */
|
/* 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);
|
tmpu = url_escape (u->user);
|
||||||
tmpp = u->passwd ? url_escape (u->passwd) : NULL;
|
tmpp = u->passwd ? url_escape (u->passwd) : NULL;
|
||||||
upwd = (char *)xmalloc (strlen (tmpu)
|
if (tmpp)
|
||||||
+ (tmpp ? (1 + strlen (tmpp)) : 0) + 2);
|
upwd = concat_strings (tmpu, ":", tmpp, "@", (char *) 0);
|
||||||
sprintf (upwd, "%s%s%s@", tmpu, tmpp ? ":" : "", tmpp ? tmpp : "");
|
else
|
||||||
|
upwd = concat_strings (tmpu, "@", (char *) 0);
|
||||||
xfree (tmpu);
|
xfree (tmpu);
|
||||||
xfree_null (tmpp);
|
xfree_null (tmpp);
|
||||||
}
|
}
|
||||||
|
@ -271,8 +271,7 @@ getftp (struct url *u, wgint *len, wgint restval, ccon *con)
|
|||||||
if (con->proxy)
|
if (con->proxy)
|
||||||
{
|
{
|
||||||
/* If proxy is in use, log in as username@target-site. */
|
/* If proxy is in use, log in as username@target-site. */
|
||||||
logname = xmalloc (strlen (user) + 1 + strlen (u->host) + 1);
|
logname = concat_strings (user, "@", u->host, (char *) 0);
|
||||||
sprintf (logname, "%s@%s", user, u->host);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Login to the server: */
|
/* Login to the server: */
|
||||||
|
@ -2583,7 +2583,7 @@ base64_encode (const char *s, char *store, int length)
|
|||||||
static char *
|
static char *
|
||||||
basic_authentication_encode (const char *user, const char *passwd)
|
basic_authentication_encode (const char *user, const char *passwd)
|
||||||
{
|
{
|
||||||
char *t1, *t2, *res;
|
char *t1, *t2;
|
||||||
int len1 = strlen (user) + 1 + strlen (passwd);
|
int len1 = strlen (user) + 1 + strlen (passwd);
|
||||||
int len2 = BASE64_LENGTH (len1);
|
int len2 = BASE64_LENGTH (len1);
|
||||||
|
|
||||||
@ -2593,10 +2593,7 @@ basic_authentication_encode (const char *user, const char *passwd)
|
|||||||
t2 = (char *)alloca (len2 + 1);
|
t2 = (char *)alloca (len2 + 1);
|
||||||
base64_encode (t1, t2, len1);
|
base64_encode (t1, t2, len1);
|
||||||
|
|
||||||
res = (char *)xmalloc (6 + len2 + 1);
|
return concat_strings ("Basic ", t2, (char *) 0);
|
||||||
sprintf (res, "Basic %s", t2);
|
|
||||||
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define SKIP_WS(x) do { \
|
#define SKIP_WS(x) do { \
|
||||||
|
@ -748,7 +748,6 @@ cmd_file (const char *com, const char *val, void *closure)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
char *result;
|
|
||||||
int homelen;
|
int homelen;
|
||||||
char *home = home_dir ();
|
char *home = home_dir ();
|
||||||
if (!home)
|
if (!home)
|
||||||
@ -762,12 +761,7 @@ cmd_file (const char *com, const char *val, void *closure)
|
|||||||
for (++val; ISSEP (*val); val++)
|
for (++val; ISSEP (*val); val++)
|
||||||
;
|
;
|
||||||
|
|
||||||
result = xmalloc (homelen + 1 + strlen (val) + 1);
|
*pstring = concat_strings (home, "/", val, (char *) 0);
|
||||||
memcpy (result, home, homelen);
|
|
||||||
result[homelen] = '/';
|
|
||||||
strcpy (result + homelen + 1, val);
|
|
||||||
|
|
||||||
*pstring = result;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WINDOWS
|
#ifdef WINDOWS
|
||||||
|
@ -1009,7 +1009,7 @@ char *
|
|||||||
url_full_path (const struct url *url)
|
url_full_path (const struct url *url)
|
||||||
{
|
{
|
||||||
int length = full_path_length (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_write (url, full_path);
|
||||||
full_path[length] = '\0';
|
full_path[length] = '\0';
|
||||||
|
48
src/utils.c
48
src/utils.c
@ -226,6 +226,54 @@ aprintf (const char *fmt, ...)
|
|||||||
}
|
}
|
||||||
return NULL; /* unreached */
|
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
|
/* Return pointer to a static char[] buffer in which zero-terminated
|
||||||
string-representation of TM (in form hh:mm:ss) is printed.
|
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 *));
|
int frontcmp PARAMS ((const char *, const char *));
|
||||||
void fork_to_background PARAMS ((void));
|
void fork_to_background PARAMS ((void));
|
||||||
|
|
||||||
#ifdef HAVE_STDARG_H
|
#ifdef WGET_USE_STDARG
|
||||||
char *aprintf PARAMS ((const char *, ...))
|
char *aprintf PARAMS ((const char *, ...))
|
||||||
GCC_FORMAT_ATTR (1, 2);
|
GCC_FORMAT_ATTR (1, 2);
|
||||||
#else /* not HAVE_STDARG_H */
|
char *concat_strings PARAMS ((const char *, ...));
|
||||||
|
#else /* not WGET_USE_STDARG */
|
||||||
char *aprintf ();
|
char *aprintf ();
|
||||||
#endif /* not HAVE_STDARG_H */
|
char *concat_strings ();
|
||||||
|
#endif /* not WGET_USE_STDARG */
|
||||||
|
|
||||||
void touch PARAMS ((const char *, time_t));
|
void touch PARAMS ((const char *, time_t));
|
||||||
int remove_link PARAMS ((const char *));
|
int remove_link PARAMS ((const char *));
|
||||||
|
Loading…
Reference in New Issue
Block a user