discover/parser: Add new parser_is_unique
authorGeoff Levand <geoff@infradead.org>
Thu, 2 Aug 2018 17:29:34 +0000 (17:29 +0000)
committerSamuel Mendoza-Jonas <sam@mendozajonas.com>
Tue, 7 Aug 2018 01:30:36 +0000 (11:30 +1000)
Add a new routine parser_is_unique that tests a file's inode
against a list of known file inodes.  Useful when searching
case-insensitive filesystems.

Signed-off-by: Geoff Levand <geoff@infradead.org>
Signed-off-by: Samuel Mendoza-Jonas <sam@mendozajonas.com>
discover/parser.c
discover/parser.h

index 9fe1925d94c44a283f0065f89f550401373b8347..54787201553010d808297eaf8cc8c1730540d0db 100644 (file)
@@ -73,6 +73,36 @@ out:
        return rc;
 }
 
+bool parser_is_unique(struct discover_context *ctx, struct discover_device *dev,
+       const char *filename, struct list *found_list)
+{
+       struct stat stat;
+       struct parser_found_file *found_file;
+       const struct parser_found_file *entry;
+
+       if (parser_stat_path(ctx, dev, filename, &stat)) {
+               pb_debug("%s: Not found: '%s'\n", __func__, filename);
+               return false;
+       }
+
+       list_for_each_entry(found_list, entry, list) {
+               if (entry->ino == stat.st_ino) {
+                       pb_log("%s: Duplicate: '%s' = '%s'\n",
+                               __func__, filename, entry->filename);
+                       return false;
+               }
+       }
+
+       pb_debug("%s: Found:     '%s'\n", __func__, filename);
+
+       found_file = talloc_zero(found_list, struct parser_found_file);
+       found_file->filename = talloc_strdup(found_file, filename);
+       found_file->ino = stat.st_ino;
+       list_add(found_list, &found_file->list);
+
+       return true;
+}
+
 int parser_replace_file(struct discover_context *ctx,
                struct discover_device *dev, const char *filename,
                char *buf, int len)
index bff52e30d09fbfda86620664b2a4d61108ac8439..e7d52fe5d2ae671e96e78c6ec6270396e4bb82a3 100644 (file)
@@ -45,6 +45,12 @@ enum generic_icon_type {
        ICON_TYPE_UNKNOWN
 };
 
+struct parser_found_file {
+       const char *filename;
+       unsigned ino;
+       struct list_item list;
+};
+
 #define streq(a,b) (!strcasecmp((a),(b)))
 
 void parser_init(void);
@@ -85,4 +91,12 @@ int parser_scandir(struct discover_context *ctx, const char *dirname,
                   struct dirent ***files, int (*filter)(const struct dirent *),
                   int (*comp)(const struct dirent **, const struct dirent **));
 
+/* parser_is_unique - Test a file against a list of known files.
+ * If the file @filename exists and the file is not in @found_list add the
+ * file to @found_list and return true.  Use when searching case-insensitive
+ * filesystems.
+ */
+bool parser_is_unique(struct discover_context *ctx, struct discover_device *dev, const char *filename,
+               struct list *found_list);
+
 #endif /* _PARSER_H */