Replace struct table_info by struct afs_table.
[paraslash.git] / afs.h
diff --git a/afs.h b/afs.h
index ab2db3a..1399b2a 100644 (file)
--- a/afs.h
+++ b/afs.h
@@ -26,11 +26,31 @@ struct afs_info {
        uint8_t audio_format_id;
 };
 
-enum afs_table_flags {TBLFLAG_SKIP_CREATE};
+enum afs_events {
+       AFSI_CHANGE,
+       AFHI_CHANGE,
+       AUDIO_FILE_RENAME,
+       AUDIO_FILE_ADD,
+       AUDIO_FILE_REMOVE,
+       AUDIO_FILE_STREAMED,
+       ATTRIBUTE_ADD,
+       ATTRIBUTE_RENAME,
+       ATTRIBUTE_DELETE,
+       LYRICS_DELETE,
+       IMAGE_DELETE,
+       LYRICS_RENAME,
+       IMAGE_RENAME,
 
-struct table_info {
-       const struct osl_table_description *desc;
-       enum afs_table_flags flags;
+};
+
+struct afs_table {
+       void (*init)(struct afs_table *t);
+       const char *name;
+       int (*open)(const char *base_dir);
+       void (*close)(void);
+       int (*create)(const char *);
+       int (*event_handler)(enum afs_events event, struct para_buffer *pb,  void *data);
+       /* int *(check)() */
 };
 
 enum play_mode {PLAY_MODE_MOOD, PLAY_MODE_PLAYLIST};
@@ -92,8 +112,7 @@ 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);
-void score_shutdown(enum osl_close_flags flags);
+void score_init(struct afs_table *t);
 int admissible_file_loop(void *data, osl_rbtree_loop_func *func);
 int admissible_file_loop_reverse(void *data, osl_rbtree_loop_func *func);
 int score_get_best(struct osl_row **aft_row, long *score);
@@ -105,15 +124,13 @@ int score_delete(const struct osl_row *aft_row);
 int row_belongs_to_score_table(const struct osl_row *aft_row);
 
 /* attribute */
-int attribute_init(struct table_info *ti, const char *db);
-void attribute_shutdown(enum osl_close_flags flags);
+void attribute_init(struct afs_table *t);
 void get_attribute_bitmap(const uint64_t *atts, char *buf); /* needed by com_ls() */
 int get_attribute_bitnum_by_name(const char *att_name, unsigned char *bitnum);
 int get_attribute_text(uint64_t *atts, const char *delim, char **text);
 
 /* aft */
-int aft_init(struct table_info *ti, const char *db);
-void aft_shutdown(enum osl_close_flags flags);
+void aft_init(struct afs_table *t);
 int aft_get_row_of_path(const char *path, struct osl_row **row);
 int open_and_update_audio_file(struct osl_row *aft_row, struct audio_file_data *afd);
 int load_afsi(struct afs_info *afsi, struct osl_object *obj);
@@ -128,7 +145,6 @@ int aft_check_callback(const struct osl_object *query, struct osl_object *result
 
 /* mood */
 int change_current_mood(char *mood_name);
-void close_current_mood(void);
 int mood_update_audio_file(const struct osl_row *aft_row, struct afs_info *old_afsi);
 int reload_current_mood(void);
 int mood_delete_audio_file(const struct osl_row *aft_row);
@@ -138,7 +154,6 @@ int mood_check_callback(__a_unused const struct osl_object *query,
 
 /* playlist */
 int playlist_open(char *name);
-void playlist_close(void);
 int playlist_update_audio_file(struct osl_row *aft_row);
 int playlist_check_callback(__a_unused const struct osl_object *query,
        struct osl_object *result);
@@ -148,8 +163,7 @@ int playlist_check_callback(__a_unused const struct osl_object *query,
 
 
 #define DECLARE_BLOB_SYMBOLS(table_name, cmd_prefix) \
-       int table_name ## _init(struct table_info *ti, const char *db); \
-       void table_name ## _shutdown(enum osl_close_flags flags); \
+       void table_name ## _init(struct afs_table *t); \
        int cmd_prefix ## _get_name_by_id(uint32_t id, char **name); \
        int cmd_prefix ## _get_def_by_id(uint32_t id, struct osl_object *def); \
        int cmd_prefix ## _get_name_and_def_by_row(const struct osl_row *row, \