X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fcore%2Fhostname-setup.c;h=8aa1cff1d30f23ad1a42826a487a7e8540a11beb;hp=550d3c2113e4b191dfe5c35cbda3ed7a8b7eef5f;hb=4d8ddba9d71e51356cc9488f906b8fef89c60c23;hpb=4d8961391719a1dd7a20f15e3f7d4df47988fbcf diff --git a/src/core/hostname-setup.c b/src/core/hostname-setup.c index 550d3c211..8aa1cff1d 100644 --- a/src/core/hostname-setup.c +++ b/src/core/hostname-setup.c @@ -29,16 +29,7 @@ #include "macro.h" #include "util.h" #include "log.h" - -#if defined(TARGET_FEDORA) || defined(TARGET_ALTLINUX) || defined(TARGET_MANDRIVA) || defined(TARGET_MEEGO) || defined(TARGET_MAGEIA) -#define FILENAME "/etc/sysconfig/network" -#elif defined(TARGET_SUSE) || defined(TARGET_SLACKWARE) -#define FILENAME "/etc/HOSTNAME" -#elif defined(TARGET_ARCH) -#define FILENAME "/etc/rc.conf" -#elif defined(TARGET_GENTOO) -#define FILENAME "/etc/conf.d/hostname" -#endif +#include "fileio.h" static int read_and_strip_hostname(const char *path, char **hn) { char *s; @@ -47,10 +38,11 @@ static int read_and_strip_hostname(const char *path, char **hn) { assert(path); assert(hn); - if ((r = read_one_line_file(path, &s)) < 0) + r = read_one_line_file(path, &s); + if (r < 0) return r; - hostname_cleanup(s); + hostname_cleanup(s, false); if (isempty(s)) { free(s); @@ -58,96 +50,19 @@ static int read_and_strip_hostname(const char *path, char **hn) { } *hn = s; - - return 0; -} - -static int read_distro_hostname(char **hn) { - -#if defined(TARGET_FEDORA) || defined(TARGET_ARCH) || defined(TARGET_GENTOO) || defined(TARGET_ALTLINUX) || defined(TARGET_MANDRIVA) || defined(TARGET_MEEGO) || defined(TARGET_MAGEIA) - int r; - FILE *f; - - assert(hn); - - if (!(f = fopen(FILENAME, "re"))) - return -errno; - - for (;;) { - char line[LINE_MAX]; - char *s, *k; - - if (!fgets(line, sizeof(line), f)) { - if (feof(f)) - break; - - r = -errno; - goto finish; - } - - s = strstrip(line); - - if (!startswith_no_case(s, "HOSTNAME=")) - continue; - - if (!(k = strdup(s+9))) { - r = -ENOMEM; - goto finish; - } - - hostname_cleanup(k); - - if (isempty(k)) { - free(k); - r = -ENOENT; - goto finish; - } - - *hn = k; - r = 0; - goto finish; - } - - r = -ENOENT; - -finish: - fclose(f); - return r; - -#elif defined(TARGET_SUSE) || defined(TARGET_SLACKWARE) - return read_and_strip_hostname(FILENAME, hn); -#else - return -ENOENT; -#endif -} - -static int read_hostname(char **hn) { - int r; - - assert(hn); - - /* First, try to load the generic hostname configuration file, - * that we support on all distributions */ - - if ((r = read_and_strip_hostname("/etc/hostname", hn)) < 0) { - - if (r == -ENOENT) - return read_distro_hostname(hn); - - return r; - } - return 0; } int hostname_setup(void) { int r; - char *b = NULL; - const char *hn = NULL; + _cleanup_free_ char *b = NULL; + const char *hn; + bool enoent = false; - if ((r = read_hostname(&b)) < 0) { + r = read_and_strip_hostname("/etc/hostname", &b); + if (r < 0) { if (r == -ENOENT) - log_info("No hostname configured."); + enoent = true; else log_warning("Failed to read configured hostname: %s", strerror(-r)); @@ -155,33 +70,23 @@ int hostname_setup(void) { } else hn = b; - if (!hn) { - /* Don't override the hostname if it is unset and not - * explicitly configured */ - - char *old_hostname = NULL; + if (isempty(hn)) { + /* Don't override the hostname if it is already set + * and not explicitly configured */ + if (hostname_is_set()) + return 0; - if ((old_hostname = gethostname_malloc())) { - bool already_set; - - already_set = old_hostname[0] != 0; - free(old_hostname); - - if (already_set) - goto finish; - } + if (enoent) + log_info("No hostname configured."); hn = "localhost"; } if (sethostname(hn, strlen(hn)) < 0) { log_warning("Failed to set hostname to <%s>: %m", hn); - r = -errno; - } else - log_info("Set hostname to <%s>.", hn); - -finish: - free(b); + return -errno; + } - return r; + log_info("Set hostname to <%s>.", hn); + return 0; }