From b6fbffe3d4a9435cc8560ee0271c7e6e763e89c1 Mon Sep 17 00:00:00 2001 From: Harald Hoyer Date: Thu, 6 Mar 2014 09:12:57 +0100 Subject: [PATCH] util: add files_same() helper function files_same() returns 1, if the files are the same 0, if the files have different inode/dev numbers errno, for any stat error (cherry picked from commit 9d9951a460a90ef0e1e0384742cefdcf85193f8c) Related: #1111199 --- src/shared/util.c | 24 ++++++++++++++++-------- src/shared/util.h | 2 ++ 2 files changed, 18 insertions(+), 8 deletions(-) diff --git a/src/shared/util.c b/src/shared/util.c index 2974c2a..fb1e6d1 100644 --- a/src/shared/util.c +++ b/src/shared/util.c @@ -3311,19 +3311,27 @@ bool on_tty(void) { return cached_on_tty; } -int running_in_chroot(void) { - struct stat a = {}, b = {}; +int files_same(const char *filea, const char *fileb) { + struct stat a, b; - /* Only works as root */ - if (stat("/proc/1/root", &a) < 0) + if (stat(filea, &a) < 0) return -errno; - if (stat("/", &b) < 0) + if (stat(fileb, &b) < 0) return -errno; - return - a.st_dev != b.st_dev || - a.st_ino != b.st_ino; + return a.st_dev == b.st_dev && + a.st_ino == b.st_ino; +} + +int running_in_chroot(void) { + int ret; + + ret = files_same("/proc/1/root", "/"); + if (ret < 0) + return ret; + + return ret == 0; } char *ellipsize_mem(const char *s, size_t old_length, size_t new_length, unsigned percent) { diff --git a/src/shared/util.h b/src/shared/util.h index e577ef0..631a385 100644 --- a/src/shared/util.h +++ b/src/shared/util.h @@ -403,6 +403,8 @@ static inline const char *ansi_highlight_off(void) { return on_tty() ? ANSI_HIGHLIGHT_OFF : ""; } +int files_same(const char *filea, const char *fileb); + int running_in_chroot(void); char *ellipsize(const char *s, size_t length, unsigned percent);