xgethostname: handle long hostnames
If the full hostname doesn't fit in the buffer supplied to gethostname, POSIX does not specify whether the buffer will be null-terminated, so to be safe, we should do it ourselves. Introduce new function, xgethostname, which ensures that there is always a \0 at the end of the buffer. Signed-off-by: David Turner <dturner@twosigma.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
da25bdb776
commit
5781a9a270
@ -232,7 +232,7 @@ static const char *lock_repo_for_gc(int force, pid_t* ret_pid)
|
|||||||
/* already locked */
|
/* already locked */
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (gethostname(my_host, sizeof(my_host)))
|
if (xgethostname(my_host, sizeof(my_host)))
|
||||||
xsnprintf(my_host, sizeof(my_host), "unknown");
|
xsnprintf(my_host, sizeof(my_host), "unknown");
|
||||||
|
|
||||||
pidfile_path = git_pathdup("gc.pid");
|
pidfile_path = git_pathdup("gc.pid");
|
||||||
|
@ -1660,7 +1660,7 @@ static const char *unpack(int err_fd, struct shallow_info *si)
|
|||||||
argv_array_pushl(&child.args, "index-pack",
|
argv_array_pushl(&child.args, "index-pack",
|
||||||
"--stdin", hdr_arg, NULL);
|
"--stdin", hdr_arg, NULL);
|
||||||
|
|
||||||
if (gethostname(hostname, sizeof(hostname)))
|
if (xgethostname(hostname, sizeof(hostname)))
|
||||||
xsnprintf(hostname, sizeof(hostname), "localhost");
|
xsnprintf(hostname, sizeof(hostname), "localhost");
|
||||||
argv_array_pushf(&child.args,
|
argv_array_pushf(&child.args,
|
||||||
"--keep=receive-pack %"PRIuMAX" on %s",
|
"--keep=receive-pack %"PRIuMAX" on %s",
|
||||||
|
@ -746,7 +746,7 @@ static int get_pack(struct fetch_pack_args *args,
|
|||||||
argv_array_push(&cmd.args, "--fix-thin");
|
argv_array_push(&cmd.args, "--fix-thin");
|
||||||
if (args->lock_pack || unpack_limit) {
|
if (args->lock_pack || unpack_limit) {
|
||||||
char hostname[HOST_NAME_MAX + 1];
|
char hostname[HOST_NAME_MAX + 1];
|
||||||
if (gethostname(hostname, sizeof(hostname)))
|
if (xgethostname(hostname, sizeof(hostname)))
|
||||||
xsnprintf(hostname, sizeof(hostname), "localhost");
|
xsnprintf(hostname, sizeof(hostname), "localhost");
|
||||||
argv_array_pushf(&cmd.args,
|
argv_array_pushf(&cmd.args,
|
||||||
"--keep=fetch-pack %"PRIuMAX " on %s",
|
"--keep=fetch-pack %"PRIuMAX " on %s",
|
||||||
|
@ -882,6 +882,8 @@ extern int xsnprintf(char *dst, size_t max, const char *fmt, ...);
|
|||||||
#define HOST_NAME_MAX 256
|
#define HOST_NAME_MAX 256
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
extern int xgethostname(char *buf, size_t len);
|
||||||
|
|
||||||
/* in ctype.c, for kwset users */
|
/* in ctype.c, for kwset users */
|
||||||
extern const unsigned char tolower_trans_tbl[256];
|
extern const unsigned char tolower_trans_tbl[256];
|
||||||
|
|
||||||
|
2
ident.c
2
ident.c
@ -122,7 +122,7 @@ static void add_domainname(struct strbuf *out, int *is_bogus)
|
|||||||
{
|
{
|
||||||
char buf[HOST_NAME_MAX + 1];
|
char buf[HOST_NAME_MAX + 1];
|
||||||
|
|
||||||
if (gethostname(buf, sizeof(buf))) {
|
if (xgethostname(buf, sizeof(buf))) {
|
||||||
warning_errno("cannot get host name");
|
warning_errno("cannot get host name");
|
||||||
strbuf_addstr(out, "(none)");
|
strbuf_addstr(out, "(none)");
|
||||||
*is_bogus = 1;
|
*is_bogus = 1;
|
||||||
|
13
wrapper.c
13
wrapper.c
@ -679,3 +679,16 @@ void sleep_millisec(int millisec)
|
|||||||
{
|
{
|
||||||
poll(NULL, 0, millisec);
|
poll(NULL, 0, millisec);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int xgethostname(char *buf, size_t len)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* If the full hostname doesn't fit in buf, POSIX does not
|
||||||
|
* specify whether the buffer will be null-terminated, so to
|
||||||
|
* be safe, do it ourselves.
|
||||||
|
*/
|
||||||
|
int ret = gethostname(buf, len);
|
||||||
|
if (!ret)
|
||||||
|
buf[len - 1] = 0;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user