From e59077036bcf5a041e336f04cb0d2f7d18d489a1 Mon Sep 17 00:00:00 2001 From: Lennart Poettering Date: Thu, 19 Aug 2010 03:02:22 +0200 Subject: [PATCH] hostname: on all distros make the name configured in /etc/hostname take precedence over distro-specific configuration In order to unify configuration across distributions we pick the simple-most option by default (Debian's /etc/hostname) and then fall back to distro-specific hacks if that doesn't exist. --- .gitignore | 1 + Makefile.am | 8 ++++++++ fixme | 2 -- src/hostname-setup.c | 42 ++++++++++++++++++++++++++++++++++++------ src/test-hostname.c | 37 +++++++++++++++++++++++++++++++++++++ 5 files changed, 82 insertions(+), 8 deletions(-) create mode 100644 src/test-hostname.c diff --git a/.gitignore b/.gitignore index 7e7b62600..99b533854 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ +test-hostname systemd-modules-load systemd-auto-console-getty systemd-shutdownd diff --git a/Makefile.am b/Makefile.am index a2f7e1725..bf329e508 100644 --- a/Makefile.am +++ b/Makefile.am @@ -81,6 +81,7 @@ noinst_PROGRAMS = \ test-job-type \ test-ns \ test-loopback \ + test-hostname \ test-daemon \ test-cgroup \ test-env-replace @@ -473,6 +474,13 @@ test_loopback_SOURCES = \ test_loopback_LDADD = \ libsystemd-basic.la +test_hostname_SOURCES = \ + src/test-hostname.c \ + src/hostname-setup.c + +test_hostname_LDADD = \ + libsystemd-basic.la + test_daemon_SOURCES = \ src/test-daemon.c \ src/sd-daemon.c diff --git a/fixme b/fixme index 48fc3c8f7..76267c3f2 100644 --- a/fixme +++ b/fixme @@ -63,8 +63,6 @@ * X-Interactive is kaputt -* universal fallback for hostname - * bash completion a la gdbus External: diff --git a/src/hostname-setup.c b/src/hostname-setup.c index f52e38aef..d8fa56790 100644 --- a/src/hostname-setup.c +++ b/src/hostname-setup.c @@ -34,8 +34,6 @@ #define FILENAME "/etc/sysconfig/network" #elif defined(TARGET_SUSE) || defined(TARGET_SLACKWARE) #define FILENAME "/etc/HOSTNAME" -#elif defined(TARGET_DEBIAN) -#define FILENAME "/etc/hostname" #elif defined(TARGET_ARCH) #define FILENAME "/etc/rc.conf" #elif defined(TARGET_GENTOO) @@ -59,7 +57,7 @@ static char* strip_bad_chars(char *s) { return s; } -static int read_hostname(char **hn) { +static int read_distro_hostname(char **hn) { #if defined(TARGET_FEDORA) || defined(TARGET_ARCH) || defined(TARGET_GENTOO) int r; @@ -111,7 +109,7 @@ finish: fclose(f); return r; -#elif defined(TARGET_SUSE) || defined(TARGET_DEBIAN) || defined(TARGET_SLACKWARE) +#elif defined(TARGET_SUSE) || defined(TARGET_SLACKWARE) int r; char *s, *k; @@ -134,12 +132,44 @@ finish: } *hn = k; + return 0; #else -#warning "Don't know how to read the hostname" - return -ENOENT; #endif +} + +static int read_hostname(char **hn) { + int r; + char *s, *k; + + assert(hn); + + /* First, try to load the generic hostname configuration file, + * that we support on all distributions */ + + if ((r = read_one_line_file("/etc/hostname", &s)) < 0) { + + if (r == -ENOENT) + return read_distro_hostname(hn); + + return r; + } + + k = strdup(strstrip(s)); + free(s); + + if (!k) + return -ENOMEM; + + strip_bad_chars(k); + + if (k[0] == 0) { + free(k); + return -ENOENT; + } + + *hn = k; return 0; } diff --git a/src/test-hostname.c b/src/test-hostname.c new file mode 100644 index 000000000..0a08416a1 --- /dev/null +++ b/src/test-hostname.c @@ -0,0 +1,37 @@ +/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ + +/*** + This file is part of systemd. + + Copyright 2010 Lennart Poettering + + systemd is free software; you can redistribute it and/or modify it + under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + systemd is distributed in the hope that it will be useful, but + WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + General Public License for more details. + + You should have received a copy of the GNU General Public License + along with systemd; If not, see . +***/ + +#include +#include +#include +#include + +#include "hostname-setup.h" +#include "util.h" + +int main(int argc, char* argv[]) { + int r; + + if ((r = hostname_setup()) < 0) + fprintf(stderr, "hostname: %s\n", strerror(-r)); + + return 0; +} -- 2.30.2