aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--toys/lsb/hostname.c36
1 files changed, 24 insertions, 12 deletions
diff --git a/toys/lsb/hostname.c b/toys/lsb/hostname.c
index 0a1f9b18..4b9347dd 100644
--- a/toys/lsb/hostname.c
+++ b/toys/lsb/hostname.c
@@ -4,48 +4,60 @@
*
* http://refspecs.linuxfoundation.org/LSB_4.1.0/LSB-Core-generic/LSB-Core-generic/hostname.html
-USE_HOSTNAME(NEWTOY(hostname, "bF:", TOYFLAG_BIN))
+USE_HOSTNAME(NEWTOY(hostname, ">1bdsfF:[!bdsf]", TOYFLAG_BIN))
config HOSTNAME
bool "hostname"
default y
help
- usage: hostname [-b] [-F FILENAME] [newname]
+ usage: hostname [-bsf] [-F FILENAME] [newname]
- Get/Set the current hostname
+ Get/set the current hostname.
- -b Set hostname to 'localhost' if otherwise unset
- -F Set hostname to contents of FILENAME
+ -b set hostname to 'localhost' if otherwise unset
+ -d show DNS domain name (no host)
+ -f show fully-qualified name (host+domain, FQDN)
+ -F set hostname to contents of FILENAME
+ -s show short host name (no domain)
*/
#define FOR_hostname
#include "toys.h"
GLOBALS(
- char *fname;
+ char *F;
)
void hostname_main(void)
{
- char *hostname = *toys.optargs;
+ char *hostname = *toys.optargs, *dot;
+ struct hostent *h;
- if (TT.fname && (hostname = xreadfile(TT.fname, 0, 0))) {
+ if (TT.F && (hostname = xreadfile(TT.F, 0, 0))) {
if (!*chomp(hostname)) {
if (CFG_TOYBOX_FREE) free(hostname);
- if (!(toys.optflags&FLAG_b)) error_exit("empty '%s'", TT.fname);
+ if (!(toys.optflags&FLAG_b)) error_exit("empty '%s'", TT.F);
hostname = 0;
}
}
+ // Implement -b.
if (!hostname && (toys.optflags&FLAG_b))
if (gethostname(toybuf, sizeof(toybuf)-1) || !*toybuf)
hostname = "localhost";
+ // Setting?
if (hostname) {
if (sethostname(hostname, strlen(hostname)))
perror_exit("set '%s'", hostname);
- } else {
- if (gethostname(toybuf, sizeof(toybuf)-1)) perror_exit("gethostname");
- xputs(toybuf);
+ return;
}
+
+ // Get the hostname.
+ if (gethostname(toybuf, sizeof(toybuf)-1)) perror_exit("gethostname");
+ if (!(h = gethostbyname(toybuf))) perror_exit("gethostbyname");
+ snprintf(toybuf, sizeof(toybuf), "%s", h->h_name);
+ dot = strchr(toybuf, '.');
+ if (toys.optflags&FLAG_s) *dot = '\0';
+ xputs(toys.optflags&FLAG_d ? dot+1 : toybuf);
}