|author||Denis Vlasenko <firstname.lastname@example.org>||2008-02-25 23:24:32 +0000|
|committer||Denis Vlasenko <email@example.com>||2008-02-25 23:24:32 +0000|
actually add libbb/safe_gethostname.c
Diffstat (limited to 'libbb/safe_gethostname.c')
1 files changed, 53 insertions, 0 deletions
diff --git a/libbb/safe_gethostname.c b/libbb/safe_gethostname.c
new file mode 100644
@@ -0,0 +1,53 @@
+/* vi: set sw=4 ts=4: */
+ * Safe gethostname implementation for busybox
+ * Copyright (C) 2008 Tito Ragusa <firstname.lastname@example.org>
+ * Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
+ * SUSv2 guarantees that "Host names are limited to 255 bytes"
+ * POSIX.1-2001 guarantees that "Host names (not including the terminating
+ * null byte) are limited to HOST_NAME_MAX bytes" (64 bytes on my box).
+ * RFC1123 says:
+ * The syntax of a legal Internet host name was specified in RFC-952
+ * [DNS:4]. One aspect of host name syntax is hereby changed: the
+ * restriction on the first character is relaxed to allow either a
+ * letter or a digit. Host software MUST support this more liberal
+ * syntax.
+ * Host software MUST handle host names of up to 63 characters and
+ * SHOULD handle host names of up to 255 characters.
+ * On success return the current malloced and NUL terminated hostname.
+ * On error return malloced and NUL terminated string "?".
+ * This is an illegal first character for a hostname.
+ * The returned malloced string must be freed by the caller.
+ struct utsname uts;
+ /* The length of the arrays in a struct utsname is unspecified;
+ * the fields are terminated by a null byte.
+ * Note that there is no standard that says that the hostname
+ * set by sethostname(2) is the same string as the nodename field of the
+ * struct returned by uname (indeed, some systems allow a 256-byte host-
+ * name and an 8-byte nodename), but this is true on Linux. The same holds
+ * for setdomainname(2) and the domainname field.
+ /* Uname can fail only if you pass a bad pointer to it. */
+ return xstrndup(!*(uts.nodename) ? "?" : uts.nodename, sizeof(uts.nodename));