chiark / gitweb /
Disobedience login window now has a 'remote' switch. When off it will
[disorder] / disobedience / choose.h
index 16414a8c02299efba2b9c3dcc76fa9d293b2361c..c101e6bcf303aaeacddda06ff53bca691eee7897 100644 (file)
@@ -30,14 +30,31 @@ enum {
   ISFILE_COLUMN,                /* TRUE for a track, FALSE for a directory */
   TRACK_COLUMN,                 /* Full track name, "" for placeholder */
   SORT_COLUMN,                  /* Sort key */
+  BG_COLUMN,                    /* Background color */
+  FG_COLUMN,                    /* Foreground color */
+  AUTOCOLLAPSE_COLUMN,          /* TRUE if row should be auto-collapsed */
 
   CHOOSE_COLUMNS                /* column count */
 };
 
+#ifndef SEARCH_RESULT_BG
+/** @brief Background color for search results */
+# define SEARCH_RESULT_BG "#ffffc0"
+/** @brief Foreground color for search results */
+# define SEARCH_RESULT_FG "black"
+#endif
+
+#ifndef SEARCH_DELAY_MS
+/** @brief Delay between last keypress in search entry and start of search */
+# define SEARCH_DELAY_MS 500            /* milliseconds */
+#endif
+
 extern GtkTreeStore *choose_store;
 extern GtkWidget *choose_view;
 extern GtkTreeSelection *choose_selection;
 extern const struct tabtype choose_tabtype;
+extern int choose_auto_expanding;
+extern GtkWidget *choose_search_entry;
 
 struct choosedata *choose_iter_to_data(GtkTreeIter *iter);
 struct choosedata *choose_path_to_data(GtkTreePath *path);
@@ -45,12 +62,22 @@ gboolean choose_button_event(GtkWidget *widget,
                              GdkEventButton *event,
                              gpointer user_data);
 void choose_play_completed(void attribute((unused)) *v,
-                           const char *error);
+                           const char *err);
 char *choose_get_track(GtkTreeIter *iter);
 char *choose_get_sort(GtkTreeIter *iter);
+char *choose_get_display(GtkTreeIter *iter);
 int choose_is_file(GtkTreeIter *iter);
 int choose_is_dir(GtkTreeIter *iter);
 int choose_is_placeholder(GtkTreeIter *iter);
+int choose_can_autocollapse(GtkTreeIter *iter);
+GtkWidget *choose_search_widget(void);
+int choose_is_search_result(const char *track);
+void choose_auto_collapse(void);
+void choose_next_clicked(GtkButton *button,
+                         gpointer userdata);
+void choose_prev_clicked(GtkButton *button,
+                         gpointer userdata);
+void choose_search_new(void);
 
 #endif /* CHOOSE_H */