X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fsysv-generator%2Fsysv-generator.c;h=6e39b449eb7902e7de97da8d94beec2ef9f06f89;hp=1e4d54888cfd74c516875f1036d79ef207c1dd61;hb=f806f64c7460632d6b6c27865e1554cb6c934320;hpb=4e4885553447f6f4c014bfa3e5b5837a76a0e612 diff --git a/src/sysv-generator/sysv-generator.c b/src/sysv-generator/sysv-generator.c index 1e4d54888..6e39b449e 100644 --- a/src/sysv-generator/sysv-generator.c +++ b/src/sysv-generator/sysv-generator.c @@ -119,11 +119,6 @@ static int add_alias(const char *service, const char *alias) { assert(service); assert(alias); - if (streq(service, alias)) { - log_error("Ignoring creation of an alias %s for itself", service); - return 0; - } - link = strjoin(arg_dest, "/", alias, NULL); if (!link) return log_oom(); @@ -147,7 +142,6 @@ static int generate_unit_file(SysvStub *s) { _cleanup_free_ char *wants = NULL; _cleanup_free_ char *conflicts = NULL; int r; - struct stat st; before = strv_join(s->before, " "); if (!before) @@ -172,9 +166,9 @@ static int generate_unit_file(SysvStub *s) { /* We might already have a symlink with the same name from a Provides:, * or from backup files like /etc/init.d/foo.bak. Real scripts always win, * so remove an existing link */ - if (lstat(unit, &st) == 0 && S_ISLNK(st.st_mode)) { + if (is_symlink(unit)) { log_warning("Overwriting existing symlink %s with real service", unit); - unlink(unit); + (void) unlink(unit); } f = fopen(unit, "wxe"); @@ -300,7 +294,7 @@ static int sysv_translate_facility(const char *name, const char *filename, char /* strip ".sh" suffix from file name for comparison */ filename_no_sh = strdupa(filename); - e = endswith(filename, ".sh"); + e = endswith(filename_no_sh, ".sh"); if (e) { *e = '\0'; filename = filename_no_sh; @@ -315,13 +309,12 @@ static int sysv_translate_facility(const char *name, const char *filename, char /* Facilities starting with $ are most likely targets */ r = unit_name_build(n, NULL, ".target"); - } else if (filename && streq(name, filename)) + } else if (streq_ptr(n, filename)) /* Names equaling the file name of the services are redundant */ return 0; else /* Everything else we assume to be normal service names */ r = sysv_translate_name(n); - if (!r) return -ENOMEM; @@ -750,12 +743,10 @@ static int enumerate_sysv(LookupPaths lp, Hashmap *all_services) { struct stat st; int r; - dirent_ensure_type(d, de); - - if (!dirent_is_file(de)) - continue; + if (hidden_file(de->d_name)) + continue; - if (fstatat(dirfd(d), de->d_name, &st, 0) < 0) { + if (fstatat(dirfd(d), de->d_name, &st, AT_SYMLINK_NOFOLLOW) < 0) { log_warning_errno(errno, "stat() failed on %s/%s: %m", *path, de->d_name); continue; } @@ -770,12 +761,17 @@ static int enumerate_sysv(LookupPaths lp, Hashmap *all_services) { if (!name) return log_oom(); + if (hashmap_contains(all_services, name)) + continue; + fpath = strjoin(*path, "/", de->d_name, NULL); if (!fpath) return log_oom(); - if (hashmap_contains(all_services, name)) + if (unit_file_get_state(UNIT_FILE_SYSTEM, NULL, name) >= 0) { + log_debug("Native unit for %s already exists, skipping", name); continue; + } service = new0(SysvStub, 1); if (!service) @@ -861,7 +857,8 @@ static int set_dependencies_from_rcnd(LookupPaths lp, Hashmap *all_services) { service = hashmap_get(all_services, name); if (!service){ - log_warning("Could not find init script for %s", name); + log_debug("Ignoring %s symlink in %s, not generating %s.", + de->d_name, rcnd_table[i].path, name); continue; }