X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fshared%2Fdev-setup.c;h=cb15da8a5d0bb5f415866c60ef6a130680b9e4c7;hb=17384d7f95169dad5f769431374fc2c08101206d;hp=50a187fda914c764a0493bbee9ff5c2ee27805f8;hpb=696fee7d95194948f7f6a17eab93213b925a846d;p=elogind.git diff --git a/src/shared/dev-setup.c b/src/shared/dev-setup.c index 50a187fda..cb15da8a5 100644 --- a/src/shared/dev-setup.c +++ b/src/shared/dev-setup.c @@ -20,37 +20,14 @@ ***/ #include -#include #include -#include -#include #include #include "dev-setup.h" -#include "log.h" -#include "macro.h" #include "util.h" #include "label.h" -static int symlink_and_label(const char *old_path, const char *new_path) { - int r; - - assert(old_path); - assert(new_path); - - r = label_context_set(new_path, S_IFLNK); - if (r < 0) - return r; - - if (symlink(old_path, new_path) < 0) - r = -errno; - - label_context_clear(); - - return r; -} - -void dev_setup(const char *prefix) { +int dev_setup(const char *prefix) { const char *j, *k; static const char symlinks[] = @@ -64,21 +41,21 @@ void dev_setup(const char *prefix) { if (j[0] == '-') { j++; - if (access(j, F_OK)) + if (access(j, F_OK) < 0) continue; } if (prefix) { - char *linkname; + _cleanup_free_ char *link_name = NULL; - if (asprintf(&linkname, "%s/%s", prefix, k) < 0) { - log_oom(); - break; - } + link_name = strjoin(prefix, "/", k, NULL); + if (!link_name) + return -ENOMEM; - symlink_and_label(j, linkname); - free(linkname); + symlink_label(j, link_name); } else - symlink_and_label(j, k); + symlink_label(j, k); } + + return 0; }