X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/disorder/blobdiff_plain/73f1b9f30c98dc525a5b6a540f6f135855d640a0..54156c626b7377cd012b1de85679801d59da8a09:/disobedience/disobedience.h diff --git a/disobedience/disobedience.h b/disobedience/disobedience.h index 37bdda4..21f3bf6 100644 --- a/disobedience/disobedience.h +++ b/disobedience/disobedience.h @@ -1,6 +1,6 @@ /* * This file is part of DisOrder. - * Copyright (C) 2006, 2007 Richard Kettlewell + * Copyright (C) 2006-2008 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 @@ -24,13 +24,9 @@ #ifndef DISOBEDIENCE_H #define DISOBEDIENCE_H -#include -#include "types.h" +#include "common.h" -#include #include -#include -#include #include #include #include @@ -49,6 +45,9 @@ #include "configuration.h" #include "hash.h" #include "selection.h" +#include "kvp.h" +#include "eventdist.h" +#include "split.h" #include #include @@ -75,6 +74,10 @@ struct callbackdata { struct choosenode *choosenode; /* gtkchoose.c got_files/got_dirs */ struct queuelike *ql; /* gtkqueue.c queuelike_completed */ struct prefdata *f; /* properties.c */ + const char *user; /* users.c */ + struct { + const char *user, *email; /* users.c */ + } edituser; } u; }; @@ -84,10 +87,14 @@ struct callbackdata { * have some callbacks to set them appropriately. */ struct tabtype { - int (*properties_sensitive)(GtkWidget *tab); - int (*selectall_sensitive)(GtkWidget *tab); - void (*properties_activate)(GtkWidget *tab); - void (*selectall_activate)(GtkWidget *tab); + int (*properties_sensitive)(void *extra); + int (*selectall_sensitive)(void *extra); + int (*selectnone_sensitive)(void *extra); + void (*properties_activate)(void *extra); + void (*selectall_activate)(void *extra); + void (*selectnone_activate)(void *extra); + void (*selected)(void); + void *extra; }; /** @brief Button definitions */ @@ -95,6 +102,7 @@ struct button { const gchar *stock; void (*clicked)(GtkButton *button, gpointer userdata); const char *tip; + GtkWidget *widget; }; /* Variables --------------------------------------------------------------- */ @@ -106,16 +114,18 @@ extern GtkWidget *tabs; /* main tabs */ extern disorder_eclient *client; /* main client */ extern unsigned long last_state; /* last reported state */ +extern rights_type last_rights; /* last reported rights bitmap */ extern int playing; /* true if playing some track */ 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); @@ -128,19 +138,19 @@ void popup_protocol_error(int code, void properties(int ntracks, const char **tracks); /* Pop up a properties window for a list of tracks */ -void properties_reset(void); - -GtkWidget *scroll_widget(GtkWidget *child, const char *name); +GtkWidget *scroll_widget(GtkWidget *child); /* Wrap a widget up for scrolling */ +GtkWidget *frame_widget(GtkWidget *w, const char *title); + 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); +void popup_submsg(GtkWidget *parent, GtkMessageType mt, const char *msg); -void fpopup_error(const char *fmt, ...); +void fpopup_msg(GtkMessageType mt, const char *fmt, ...); struct progress_window *progress_window_new(const char *title); /* Pop up a progress window */ @@ -152,21 +162,13 @@ void progress_window_progress(struct progress_window *pw, GtkWidget *iconbutton(const char *path, const char *tip); -GtkWidget *create_buttons(const struct button *buttons, +GtkWidget *create_buttons(struct button *buttons, size_t nbuttons); +GtkWidget *create_buttons_box(struct button *buttons, + size_t nbuttons, + GtkWidget *box); -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 logged_in(void); void all_update(void); /* Update everything */ @@ -180,14 +182,14 @@ void menu_update(int page); /* Called whenever the main menu might need to change. PAGE is the current * page if known or -1 otherwise. */ +void users_set_sensitive(int sensitive); /* Controls */ GtkWidget *control_widget(void); /* Make the controls widget */ -void volume_update(void); -/* Called whenever we think the volume control has changed */ +extern int suppress_actions; /* Queue/Recent/Added */ @@ -197,14 +199,9 @@ 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); -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_select_none(struct queuelike *ql); +/* Select all/none on some queue */ void queue_properties(struct queuelike *ql); /* Pop up properties of selected items in some queue */ @@ -217,6 +214,7 @@ void namepart_update(const char *track, const char *part); /* Called when a namepart might have changed */ +extern struct queue_entry *playing_track; /* Choose */ @@ -226,36 +224,47 @@ GtkWidget *choose_widget(void); void choose_update(void); /* Called when we think the choose tree might need updating */ +void play_completed(void *v, + const char *error); + +/* Login details */ + void login_box(void); -/* Widget leakage debugging rubbish ---------------------------------------- */ - -#if MDEBUG -#define NW(what) do { \ - if(++current##what % 100 > max##what) { \ - fprintf(stderr, "%s:%d: %d %s\n", \ - __FILE__, __LINE__, current##what, #what); \ - max##what = current##what; \ - } \ -} while(0) -#define WT(what) static int current##what, max##what -#define DW(what) (--current##what) -#else -#define NW(what) do { } while(0) -#define DW(what) do { } while(0) -#define WT(what) struct neverused -#endif - -#if MTRACK -extern const char *mtag; -#define MTAG(x) do { mtag = x; } while(0) -#define MTAG_PUSH(x) do { const char *save_mtag = mtag; mtag = x; (void)0 -#define MTAG_POP() mtag = save_mtag; } while(0) -#else -#define MTAG(x) do { } while(0) -#define MTAG_PUSH(x) do {} while(0) -#define MTAG_POP() do {} while(0) -#endif +GtkWidget *login_window; + +/* User management */ + +void manage_users(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); +void popup_settings(void); #endif /* DISOBEDIENCE_H */