/*
* This file is part of DisOrder.
- * Copyright (C) 2006 Richard Kettlewell
+ * Copyright (C) 2006, 2007 Richard Kettlewell
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
* USA
*/
+/** @file disobedience/disobedience.h
+ * @brief Header file for Disobedience, the DisOrder GTK+ client
+ */
#ifndef DISOBEDIENCE_H
#define DISOBEDIENCE_H
struct queuelike;
struct choosenode;
+struct progress_window;
+/** @brief Callback data structure
+ *
+ * This program is extremely heavily callback-driven. Rather than have
+ * numerous different callback structures we have a single one which can be
+ * interpreted adequately both by success and error handlers.
+ */
struct callbackdata {
void (*onerror)(struct callbackdata *cbd,
int code,
} u;
};
+/** @brief Per-tab callbacks
+ *
+ * Some of the options in the main menu depend on which tab is displayed, so we
+ * have some callbacks to set them appropriately.
+ */
struct tabtype {
int (*properties_sensitive)(GtkWidget *tab);
int (*selectall_sensitive)(GtkWidget *tab);
void (*selectall_activate)(GtkWidget *tab);
};
+/** @brief Button definitions */
+struct button {
+ const gchar *stock;
+ void (*clicked)(GtkButton *button, gpointer userdata);
+ const char *tip;
+};
+
/* Variables --------------------------------------------------------------- */
extern GMainLoop *mainloop;
extern int volume_l, volume_r; /* current volume */
extern double goesupto; /* volume upper bound */
extern int choosealpha; /* break up choose by letter */
+extern GtkTooltips *tips;
+extern int rtp_supported;
+extern int rtp_is_running;
+extern GtkItemFactory *mainmenufactory;
extern const disorder_eclient_log_callbacks log_callbacks;
+typedef void monitor_callback(void *u);
+
/* Functions --------------------------------------------------------------- */
disorder_eclient *gtkclient(void);
const char *msg);
/* Report an error */
-void properties(int ntracks, char **tracks);
+void properties(int ntracks, const char **tracks);
/* Pop up a properties window for a list of tracks */
-GtkWidget *scroll_widget(GtkWidget *child, const char *name);
+void properties_reset(void);
+
+GtkWidget *scroll_widget(GtkWidget *child);
/* Wrap a widget up for scrolling */
GdkPixbuf *find_image(const char *name);
/* Get the pixbuf for an image. Returns a null pointer if it cannot be
* found. */
-void popup_error(const char *msg);
-/* Pop up an error message */
+void popup_msg(GtkMessageType mt, const char *msg);
+/* Pop up a message */
+
+void fpopup_msg(GtkMessageType mt, const char *fmt, ...);
+
+struct progress_window *progress_window_new(const char *title);
+/* Pop up a progress window */
+
+void progress_window_progress(struct progress_window *pw,
+ int progress,
+ int limit);
+/* Report current progress */
+
+GtkWidget *iconbutton(const char *path, const char *tip);
+
+GtkWidget *create_buttons(const struct button *buttons,
+ size_t nbuttons);
+
+void register_monitor(monitor_callback *callback,
+ void *u,
+ unsigned long mask);
+/* Register a state monitor */
+
+/** @brief Type signature for a reset callback */
+typedef void reset_callback(void);
+
+void register_reset(reset_callback *callback);
+/* Register a reset callback */
+
+void reset(void);
void all_update(void);
/* Update everything */
GtkWidget *control_widget(void);
/* Make the controls widget */
-void control_update(void);
-/* Called whenever we think the control widget needs changing */
+void volume_update(void);
+/* Called whenever we think the volume control has changed */
+
+void control_monitor(void *u);
+extern int suppress_actions;
-/* Queue/Recent */
+/* Queue/Recent/Added */
GtkWidget *queue_widget(void);
GtkWidget *recent_widget(void);
-/* Create widgets for displaying the queue and the recently played list */
+GtkWidget *added_widget(void);
+/* Create widgets for displaying the queue, the recently played list and the
+ * newly added tracks list */
void queue_update(void);
void recent_update(void);
-/* Called whenever we think the queue or recent list might have chanegd */
+void added_update(void);
+/* Called whenever we think the queue, recent or newly-added list might have
+ * changed */
void queue_select_all(struct queuelike *ql);
/* Select all on some queue */
void queue_properties(struct queuelike *ql);
/* Pop up properties of selected items in some queue */
-void playing_update(void);
-/* Called whenever we think the currently playing track might have changed */
-
int queued(const char *track);
/* Return nonzero iff TRACK is queued or playing */
void choose_update(void);
/* Called when we think the choose tree might need updating */
+/* Login details */
+
+void login_box(void);
+
+/* Help */
+
+void popup_help(void);
+
+/* RTP */
+
+int rtp_running(void);
+void start_rtp(void);
+void stop_rtp(void);
+
+/* Settings */
+
+void init_styles(void);
+extern GtkStyle *layout_style;
+extern GtkStyle *title_style;
+extern GtkStyle *even_style;
+extern GtkStyle *odd_style;
+extern GtkStyle *active_style;
+extern GtkStyle *tool_style;
+extern GtkStyle *search_style;
+extern GtkStyle *drag_style;
+
+extern const char *browser;
+
+void save_settings(void);
+void load_settings(void);
+void set_tool_colors(GtkWidget *w);
+
/* Widget leakage debugging rubbish ---------------------------------------- */
#if MDEBUG