]> git.ipfire.org Git - thirdparty/util-linux.git/commitdiff
lib/fileutils: add stripoff_last_component() from libmount
authorKarel Zak <kzak@redhat.com>
Mon, 9 Jun 2014 09:54:32 +0000 (11:54 +0200)
committerKarel Zak <kzak@redhat.com>
Mon, 9 Jun 2014 09:54:32 +0000 (11:54 +0200)
Signed-off-by: Karel Zak <kzak@redhat.com>
include/fileutils.h
lib/fileutils.c
lib/sysfs.c
libmount/src/mountP.h
libmount/src/tab.c
libmount/src/utils.c

index 99a71edbcd45fcfc7db5eacf2732bfe8f575a9f6..2144e5e5df1fdb2b88389212277f483b281330c4 100644 (file)
@@ -21,5 +21,6 @@ static inline FILE *xfmkstemp(char **tmpname, char *dir)
 extern int get_fd_tabsize(void);
 
 extern int mkdir_p(const char *path, mode_t mode);
+extern char *stripoff_last_component(char *path);
 
 #endif /* UTIL_LINUX_FILEUTILS */
index 3d45531792e158e915e1d46a1b537c8b262c583f..a1b47575783fb979cac629dd3da18303930afe31 100644 (file)
@@ -117,3 +117,15 @@ int mkdir_p(const char *path, mode_t mode)
        free(dir);
        return rc;
 }
+
+/* returns basename and keeps dirname in the @path, if @path is "/" (root)
+ * then returns empty string */
+char *stripoff_last_component(char *path)
+{
+       char *p = path ? strrchr(path, '/') : NULL;
+
+       if (!p)
+               return NULL;
+       *p = '\0';
+       return p + 1;
+}
index eee08275396dc4270ef08827ecb42b89df2724e4..b51a4ff26db6de6a11fb03bd34f99791b4237ace 100644 (file)
@@ -10,6 +10,7 @@
 #include "at.h"
 #include "pathnames.h"
 #include "sysfs.h"
+#include "fileutils.h"
 
 char *sysfs_devno_attribute_path(dev_t devno, char *buf,
                                 size_t bufsiz, const char *attr)
@@ -510,17 +511,6 @@ char *sysfs_get_devname(struct sysfs_cxt *cxt, char *buf, size_t bufsiz)
        return buf;
 }
 
-/* returns basename and keeps dirname in the @path */
-static char *stripoff_last_component(char *path)
-{
-    char *p = strrchr(path, '/');
-
-    if (!p)
-        return NULL;
-    *p = '\0';
-    return ++p;
-}
-
 static int get_dm_wholedisk(struct sysfs_cxt *cxt, char *diskname,
                 size_t len, dev_t *diskdevno)
 {
index eaaffa281806cf2218d9b34baaefab7fdf83a3f1..d85a078defbed0caf2248a86ea7778cc214ce134 100644 (file)
@@ -79,16 +79,12 @@ extern int mnt_run_test(struct libmnt_test *tests, int argc, char *argv[]);
 #endif
 
 /* utils.c */
-extern char *stripoff_last_component(char *path);
-
 extern int mnt_valid_tagname(const char *tagname);
 extern int append_string(char **a, const char *b);
 
 extern const char *mnt_statfs_get_fstype(struct statfs *vfs);
 extern int is_file_empty(const char *name);
 
-extern int mkdir_p(const char *path, mode_t mode);
-
 extern int mnt_is_readonly(const char *path)
                        __attribute__((nonnull));
 
index 86d682a0feb055a6fb36543a77ff8537dde5e9c0..77260ab96c35327aa61f172eeb8b4c90358125ef 100644 (file)
@@ -46,6 +46,7 @@
 #include "mountP.h"
 #include "strutils.h"
 #include "loopdev.h"
+#include "fileutils.h"
 
 static int is_mountinfo(struct libmnt_table *tb)
 {
index 7700d805a5e662b805b6ec1867a8f2f79a9d8a3f..d97390e941d232c763b378419285f123c419ed1d 100644 (file)
@@ -117,18 +117,6 @@ static int fstype_cmp(const void *v1, const void *v2)
        return strcmp(s1, s2);
 }
 
-/* returns basename and keeps dirname in the @path, if @path is "/" (root)
- * then returns empty string */
-char *stripoff_last_component(char *path)
-{
-       char *p = path ? strrchr(path, '/') : NULL;
-
-       if (!p)
-               return NULL;
-       *p = '\0';
-       return p + 1;
-}
-
 /*
  * Note that the @target has to be an absolute path (so at least "/").  The
  * @filename returns an allocated buffer with the last path component, for example: