]> git.tuebingen.mpg.de Git - paraslash.git/blobdiff - afs.h
mood.c: Switch to fnmatch() in mood method name_like.
[paraslash.git] / afs.h
diff --git a/afs.h b/afs.h
index 6b5afcc4630d769b8ed0e182ef7572fd72b9dcb3..72081ab6163fbc7748a1332e4e1701cde8433184 100644 (file)
--- a/afs.h
+++ b/afs.h
@@ -12,7 +12,7 @@
 struct afs_info {
        /** Seconds since the epoch. */
        uint64_t last_played;
-       /** Bitfield of set attributes. */
+       /** Bit field of set attributes. */
        uint64_t attributes;
        /** Counts how many times the file was selected. */
        uint32_t num_played;
@@ -42,6 +42,23 @@ struct audio_file_data {
        struct osl_object map;
 };
 
+enum pattern_match_flags {
+       PM_REVERSE_LOOP = 1,
+       PM_NO_PATTERN_MATCHES_EVERYTHING = 2,
+       PM_SKIP_EMPTY_NAME = 4,
+};
+
+struct pattern_match_data {
+       struct osl_table *table;
+       unsigned loop_col_num;
+       unsigned match_col_num;
+       unsigned pm_flags;
+       int fnmatch_flags;
+       struct osl_object patterns;
+       void *data;
+       int (*action)(struct osl_table *table, struct osl_row *row, const char *name, void *data);
+};
+
 /* afs */
 typedef int callback_function(const struct osl_object *, struct osl_object *);
 __noreturn int afs_init(uint32_t cookie, int socket_fd);
@@ -55,9 +72,9 @@ int send_option_arg_callback_request(struct osl_object *options,
 int stdin_command(int fd, struct osl_object *arg_obj, callback_function *f,
                unsigned max_len, struct osl_object *result);
 int string_compare(const struct osl_object *obj1, const struct osl_object *obj2);
-int para_atol(const char *str, long *result);
 int open_next_audio_file(struct audio_file_data *afd);
 int close_audio_file(struct audio_file_data *afd);
+int for_each_matching_row(struct pattern_match_data *pmd);
 
 /* score */
 int score_init(struct table_info *ti, const char *db);