* mug: fix header clearing + code reindentation
This commit is contained in:
@ -34,7 +34,6 @@ enum {
|
|||||||
LAST_SIGNAL
|
LAST_SIGNAL
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
MUG_COL_DATESTR,
|
MUG_COL_DATESTR,
|
||||||
MUG_COL_MAILDIR,
|
MUG_COL_MAILDIR,
|
||||||
@ -66,9 +65,7 @@ static guint signals[LAST_SIGNAL] = {0};
|
|||||||
|
|
||||||
G_DEFINE_TYPE(MugMsgListView, mug_msg_list_view, GTK_TYPE_TREE_VIEW);
|
G_DEFINE_TYPE(MugMsgListView, mug_msg_list_view, GTK_TYPE_TREE_VIEW);
|
||||||
|
|
||||||
|
static void mug_msg_list_view_class_init(MugMsgListViewClass * klass)
|
||||||
static void
|
|
||||||
mug_msg_list_view_class_init (MugMsgListViewClass *klass)
|
|
||||||
{
|
{
|
||||||
GObjectClass *gobject_class;
|
GObjectClass *gobject_class;
|
||||||
gobject_class = (GObjectClass *) klass;
|
gobject_class = (GObjectClass *) klass;
|
||||||
@ -76,8 +73,7 @@ mug_msg_list_view_class_init (MugMsgListViewClass *klass)
|
|||||||
parent_class = g_type_class_peek_parent(klass);
|
parent_class = g_type_class_peek_parent(klass);
|
||||||
gobject_class->finalize = mug_msg_list_view_finalize;
|
gobject_class->finalize = mug_msg_list_view_finalize;
|
||||||
|
|
||||||
g_type_class_add_private (gobject_class,
|
g_type_class_add_private(gobject_class, sizeof(MugMsgListViewPrivate));
|
||||||
sizeof(MugMsgListViewPrivate));
|
|
||||||
|
|
||||||
signals[MUG_MSG_SELECTED] =
|
signals[MUG_MSG_SELECTED] =
|
||||||
g_signal_new("msg-selected",
|
g_signal_new("msg-selected",
|
||||||
@ -99,9 +95,7 @@ mug_msg_list_view_class_init (MugMsgListViewClass *klass)
|
|||||||
G_TYPE_NONE, 1, G_TYPE_UINT);
|
G_TYPE_NONE, 1, G_TYPE_UINT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void on_cursor_changed(GtkTreeView * tview, MugMsgListView * lst)
|
||||||
static void
|
|
||||||
on_cursor_changed (GtkTreeView *tview, MugMsgListView *lst)
|
|
||||||
{
|
{
|
||||||
GtkTreeSelection *sel;
|
GtkTreeSelection *sel;
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
@ -117,13 +111,11 @@ on_cursor_changed (GtkTreeView *tview, MugMsgListView *lst)
|
|||||||
gtk_tree_model_get(GTK_TREE_MODEL(priv->_store), &iter,
|
gtk_tree_model_get(GTK_TREE_MODEL(priv->_store), &iter,
|
||||||
MUG_COL_PATH, &path, -1);
|
MUG_COL_PATH, &path, -1);
|
||||||
g_signal_emit(G_OBJECT(lst),
|
g_signal_emit(G_OBJECT(lst),
|
||||||
signals[MUG_MSG_SELECTED], 0,
|
signals[MUG_MSG_SELECTED], 0, path);
|
||||||
path);
|
|
||||||
g_free(path);
|
g_free(path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
treecell_func(GtkTreeViewColumn * tree_column, GtkCellRenderer * renderer,
|
treecell_func(GtkTreeViewColumn * tree_column, GtkCellRenderer * renderer,
|
||||||
GtkTreeModel * tree_model, GtkTreeIter * iter, gpointer data)
|
GtkTreeModel * tree_model, GtkTreeIter * iter, gpointer data)
|
||||||
@ -132,9 +124,7 @@ treecell_func (GtkTreeViewColumn *tree_column, GtkCellRenderer *renderer,
|
|||||||
MuMsgPrio prio;
|
MuMsgPrio prio;
|
||||||
|
|
||||||
gtk_tree_model_get(tree_model, iter,
|
gtk_tree_model_get(tree_model, iter,
|
||||||
MUG_COL_FLAGS, &flags,
|
MUG_COL_FLAGS, &flags, MUG_COL_PRIO, &prio, -1);
|
||||||
MUG_COL_PRIO, &prio,
|
|
||||||
-1);
|
|
||||||
|
|
||||||
g_object_set(G_OBJECT(renderer),
|
g_object_set(G_OBJECT(renderer),
|
||||||
"weight", (flags & MU_MSG_FLAG_NEW) ? 800 : 400,
|
"weight", (flags & MU_MSG_FLAG_NEW) ? 800 : 400,
|
||||||
@ -143,17 +133,17 @@ treecell_func (GtkTreeViewColumn *tree_column, GtkCellRenderer *renderer,
|
|||||||
NULL);
|
NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* sortcolidx == -1 means 'sortcolidx = colidx' */
|
/* sortcolidx == -1 means 'sortcolidx = colidx' */
|
||||||
static void
|
static void
|
||||||
append_col (GtkTreeView *treeview, const char* label, int colidx, int sortcolidx,
|
append_col(GtkTreeView * treeview, const char *label, int colidx,
|
||||||
gint maxwidth)
|
int sortcolidx, gint maxwidth)
|
||||||
{
|
{
|
||||||
GtkTreeViewColumn *col;
|
GtkTreeViewColumn *col;
|
||||||
GtkCellRenderer *renderer;
|
GtkCellRenderer *renderer;
|
||||||
|
|
||||||
renderer = gtk_cell_renderer_text_new();
|
renderer = gtk_cell_renderer_text_new();
|
||||||
g_object_set (G_OBJECT(renderer),"ellipsize", PANGO_ELLIPSIZE_END, NULL);
|
g_object_set(G_OBJECT(renderer), "ellipsize", PANGO_ELLIPSIZE_END,
|
||||||
|
NULL);
|
||||||
|
|
||||||
col = gtk_tree_view_column_new_with_attributes(label, renderer, "text",
|
col = gtk_tree_view_column_new_with_attributes(label, renderer, "text",
|
||||||
colidx, NULL);
|
colidx, NULL);
|
||||||
@ -166,23 +156,21 @@ append_col (GtkTreeView *treeview, const char* label, int colidx, int sortcolidx
|
|||||||
gtk_tree_view_column_set_sort_column_id(col, sortcolidx);
|
gtk_tree_view_column_set_sort_column_id(col, sortcolidx);
|
||||||
|
|
||||||
if (maxwidth) {
|
if (maxwidth) {
|
||||||
gtk_tree_view_column_set_sizing (col, GTK_TREE_VIEW_COLUMN_FIXED);
|
gtk_tree_view_column_set_sizing(col,
|
||||||
|
GTK_TREE_VIEW_COLUMN_FIXED);
|
||||||
gtk_tree_view_column_set_fixed_width(col, maxwidth);
|
gtk_tree_view_column_set_fixed_width(col, maxwidth);
|
||||||
gtk_tree_view_column_set_expand(col, FALSE);
|
gtk_tree_view_column_set_expand(col, FALSE);
|
||||||
} else {
|
} else
|
||||||
//gtk_tree_view_column_set_sizing (col, GTK_TREE_VIEW_COLUMN_GROW_ONLY);
|
|
||||||
gtk_tree_view_column_set_expand(col, TRUE);
|
gtk_tree_view_column_set_expand(col, TRUE);
|
||||||
}
|
|
||||||
|
|
||||||
gtk_tree_view_column_set_cell_data_func(col, renderer,
|
gtk_tree_view_column_set_cell_data_func(col, renderer,
|
||||||
(GtkTreeCellDataFunc) treecell_func,
|
(GtkTreeCellDataFunc)
|
||||||
NULL, NULL);
|
treecell_func, NULL, NULL);
|
||||||
|
|
||||||
gtk_tree_view_append_column(treeview, col);
|
gtk_tree_view_append_column(treeview, col);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void mug_msg_list_view_init(MugMsgListView * obj)
|
||||||
mug_msg_list_view_init (MugMsgListView *obj)
|
|
||||||
{
|
{
|
||||||
MugMsgListViewPrivate *priv;
|
MugMsgListViewPrivate *priv;
|
||||||
GtkTreeView *tview;
|
GtkTreeView *tview;
|
||||||
@ -190,8 +178,7 @@ mug_msg_list_view_init (MugMsgListView *obj)
|
|||||||
priv = MUG_MSG_LIST_VIEW_GET_PRIVATE(obj);
|
priv = MUG_MSG_LIST_VIEW_GET_PRIVATE(obj);
|
||||||
|
|
||||||
priv->_xpath = priv->_query = NULL;
|
priv->_xpath = priv->_query = NULL;
|
||||||
priv->_store = gtk_list_store_new (MUG_N_COLS,
|
priv->_store = gtk_list_store_new(MUG_N_COLS, G_TYPE_STRING, /* date */
|
||||||
G_TYPE_STRING, /* date */
|
|
||||||
G_TYPE_STRING, /* folder */
|
G_TYPE_STRING, /* folder */
|
||||||
G_TYPE_STRING, /* flagstr */
|
G_TYPE_STRING, /* flagstr */
|
||||||
G_TYPE_STRING, /* from */
|
G_TYPE_STRING, /* from */
|
||||||
@ -220,8 +207,7 @@ mug_msg_list_view_init (MugMsgListView *obj)
|
|||||||
G_CALLBACK(on_cursor_changed), obj);
|
G_CALLBACK(on_cursor_changed), obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void mug_msg_list_view_finalize(GObject * obj)
|
||||||
mug_msg_list_view_finalize (GObject *obj)
|
|
||||||
{
|
{
|
||||||
MugMsgListViewPrivate *priv;
|
MugMsgListViewPrivate *priv;
|
||||||
priv = MUG_MSG_LIST_VIEW_GET_PRIVATE(obj);
|
priv = MUG_MSG_LIST_VIEW_GET_PRIVATE(obj);
|
||||||
@ -235,23 +221,19 @@ mug_msg_list_view_finalize (GObject *obj)
|
|||||||
G_OBJECT_CLASS(parent_class)->finalize(obj);
|
G_OBJECT_CLASS(parent_class)->finalize(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void mug_msg_list_view_move_first(MugMsgListView * self)
|
||||||
mug_msg_list_view_move_first (MugMsgListView *self)
|
|
||||||
{
|
{
|
||||||
GtkTreePath *path;
|
GtkTreePath *path;
|
||||||
|
|
||||||
g_return_if_fail(MUG_IS_MSG_LIST_VIEW(self));
|
g_return_if_fail(MUG_IS_MSG_LIST_VIEW(self));
|
||||||
|
|
||||||
path = gtk_tree_path_new_first();
|
path = gtk_tree_path_new_first();
|
||||||
gtk_tree_view_set_cursor (GTK_TREE_VIEW(self), path,
|
gtk_tree_view_set_cursor(GTK_TREE_VIEW(self), path, NULL, FALSE);
|
||||||
NULL, FALSE);
|
|
||||||
|
|
||||||
gtk_tree_path_free(path);
|
gtk_tree_path_free(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean msg_list_view_move(MugMsgListView * self, gboolean next)
|
||||||
static gboolean
|
|
||||||
msg_list_view_move (MugMsgListView *self, gboolean next)
|
|
||||||
{
|
{
|
||||||
GtkTreePath *path;
|
GtkTreePath *path;
|
||||||
|
|
||||||
@ -264,33 +246,27 @@ msg_list_view_move (MugMsgListView *self, gboolean next)
|
|||||||
else
|
else
|
||||||
gtk_tree_path_prev(path);
|
gtk_tree_path_prev(path);
|
||||||
|
|
||||||
gtk_tree_view_set_cursor (GTK_TREE_VIEW(self), path,
|
gtk_tree_view_set_cursor(GTK_TREE_VIEW(self), path, NULL, FALSE);
|
||||||
NULL, FALSE);
|
|
||||||
gtk_tree_path_free(path);
|
gtk_tree_path_free(path);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gboolean mug_msg_list_view_move_next(MugMsgListView * self)
|
||||||
gboolean
|
|
||||||
mug_msg_list_view_move_next (MugMsgListView *self)
|
|
||||||
{
|
{
|
||||||
g_return_val_if_fail(MUG_IS_MSG_LIST_VIEW(self), FALSE);
|
g_return_val_if_fail(MUG_IS_MSG_LIST_VIEW(self), FALSE);
|
||||||
|
|
||||||
return msg_list_view_move(self, TRUE);
|
return msg_list_view_move(self, TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gboolean mug_msg_list_view_move_prev(MugMsgListView * self)
|
||||||
gboolean
|
|
||||||
mug_msg_list_view_move_prev (MugMsgListView *self)
|
|
||||||
{
|
{
|
||||||
g_return_val_if_fail(MUG_IS_MSG_LIST_VIEW(self), FALSE);
|
g_return_val_if_fail(MUG_IS_MSG_LIST_VIEW(self), FALSE);
|
||||||
|
|
||||||
return msg_list_view_move(self, FALSE);
|
return msg_list_view_move(self, FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkWidget*
|
GtkWidget *mug_msg_list_view_new(const char *xpath)
|
||||||
mug_msg_list_view_new (const char *xpath)
|
|
||||||
{
|
{
|
||||||
GtkWidget *w;
|
GtkWidget *w;
|
||||||
MugMsgListViewPrivate *priv;
|
MugMsgListViewPrivate *priv;
|
||||||
@ -305,9 +281,7 @@ mug_msg_list_view_new (const char *xpath)
|
|||||||
return w;
|
return w;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gchar *empty_or_display_contact(const gchar * str)
|
||||||
static gchar*
|
|
||||||
empty_or_display_contact (const gchar* str)
|
|
||||||
{
|
{
|
||||||
if (!str || *str == '\0')
|
if (!str || *str == '\0')
|
||||||
return g_strdup("-");
|
return g_strdup("-");
|
||||||
@ -316,8 +290,7 @@ empty_or_display_contact (const gchar* str)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static MugError
|
static MugError mu_result_to_mug_error(MuResult r)
|
||||||
mu_result_to_mug_error (MuResult r)
|
|
||||||
{
|
{
|
||||||
switch (r) {
|
switch (r) {
|
||||||
case MU_ERROR_XAPIAN_DIR:
|
case MU_ERROR_XAPIAN_DIR:
|
||||||
@ -331,9 +304,7 @@ mu_result_to_mug_error (MuResult r)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static MuMsgIter *run_query(const char *xpath, const char *query,
|
||||||
static MuMsgIter *
|
|
||||||
run_query (const char *xpath, const char *query,
|
|
||||||
MugMsgListView * self)
|
MugMsgListView * self)
|
||||||
{
|
{
|
||||||
GError *err;
|
GError *err;
|
||||||
@ -351,9 +322,7 @@ run_query (const char *xpath, const char *query,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
iter = mu_query_run (xapian, query,
|
iter = mu_query_run(xapian, query, MU_MSG_FIELD_ID_DATE, TRUE, 0, &err);
|
||||||
MU_MSG_FIELD_ID_DATE,
|
|
||||||
TRUE, 0, &err);
|
|
||||||
mu_query_destroy(xapian);
|
mu_query_destroy(xapian);
|
||||||
if (!iter) {
|
if (!iter) {
|
||||||
g_warning("Error: %s", err->message);
|
g_warning("Error: %s", err->message);
|
||||||
@ -367,8 +336,7 @@ run_query (const char *xpath, const char *query,
|
|||||||
return iter;
|
return iter;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void add_row(GtkListStore * store, MuMsgIter * iter)
|
||||||
add_row (GtkListStore *store, MuMsgIter *iter)
|
|
||||||
{
|
{
|
||||||
GtkTreeIter treeiter;
|
GtkTreeIter treeiter;
|
||||||
const gchar *datestr, *flagstr;
|
const gchar *datestr, *flagstr;
|
||||||
@ -392,13 +360,11 @@ add_row (GtkListStore *store, MuMsgIter *iter)
|
|||||||
MUG_COL_PATH, mu_msg_iter_get_path(iter),
|
MUG_COL_PATH, mu_msg_iter_get_path(iter),
|
||||||
MUG_COL_PRIO, mu_msg_iter_get_prio(iter),
|
MUG_COL_PRIO, mu_msg_iter_get_prio(iter),
|
||||||
MUG_COL_FLAGS, mu_msg_iter_get_flags(iter),
|
MUG_COL_FLAGS, mu_msg_iter_get_flags(iter),
|
||||||
MUG_COL_TIME, timeval,
|
MUG_COL_TIME, timeval, -1);
|
||||||
-1);
|
|
||||||
g_free(from);
|
g_free(from);
|
||||||
g_free(to);
|
g_free(to);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
update_model(GtkListStore * store, const char *xpath, const char *query,
|
update_model(GtkListStore * store, const char *xpath, const char *query,
|
||||||
MugMsgListView * self)
|
MugMsgListView * self)
|
||||||
@ -421,9 +387,7 @@ update_model (GtkListStore *store, const char *xpath, const char *query,
|
|||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int mug_msg_list_view_query(MugMsgListView * self, const char *query)
|
||||||
int
|
|
||||||
mug_msg_list_view_query (MugMsgListView *self, const char *query)
|
|
||||||
{
|
{
|
||||||
MugMsgListViewPrivate *priv;
|
MugMsgListViewPrivate *priv;
|
||||||
gboolean rv;
|
gboolean rv;
|
||||||
@ -439,17 +403,14 @@ mug_msg_list_view_query (MugMsgListView *self, const char *query)
|
|||||||
if (!query)
|
if (!query)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
rv = update_model (priv->_store, priv->_xpath, query,
|
rv = update_model(priv->_store, priv->_xpath, query, self);
|
||||||
self);
|
|
||||||
|
|
||||||
gtk_tree_view_columns_autosize(GTK_TREE_VIEW(self));
|
gtk_tree_view_columns_autosize(GTK_TREE_VIEW(self));
|
||||||
|
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const gchar *mug_msg_list_view_get_query(MugMsgListView * self)
|
||||||
const gchar*
|
|
||||||
mug_msg_list_view_get_query (MugMsgListView *self)
|
|
||||||
{
|
{
|
||||||
g_return_val_if_fail(MUG_IS_MSG_LIST_VIEW(self), NULL);
|
g_return_val_if_fail(MUG_IS_MSG_LIST_VIEW(self), NULL);
|
||||||
|
|
||||||
|
|||||||
@ -24,7 +24,6 @@
|
|||||||
#include <mu-result.h>
|
#include <mu-result.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
/* convenience macros */
|
/* convenience macros */
|
||||||
#define MUG_TYPE_MSG_LIST_VIEW (mug_msg_list_view_get_type())
|
#define MUG_TYPE_MSG_LIST_VIEW (mug_msg_list_view_get_type())
|
||||||
#define MUG_MSG_LIST_VIEW(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),MUG_TYPE_MSG_LIST_VIEW,MugMsgListView))
|
#define MUG_MSG_LIST_VIEW(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),MUG_TYPE_MSG_LIST_VIEW,MugMsgListView))
|
||||||
@ -32,7 +31,6 @@ G_BEGIN_DECLS
|
|||||||
#define MUG_IS_MSG_LIST_VIEW(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),MUG_TYPE_MSG_LIST_VIEW))
|
#define MUG_IS_MSG_LIST_VIEW(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),MUG_TYPE_MSG_LIST_VIEW))
|
||||||
#define MUG_IS_MSG_LIST_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),MUG_TYPE_MSG_LIST_VIEW))
|
#define MUG_IS_MSG_LIST_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),MUG_TYPE_MSG_LIST_VIEW))
|
||||||
#define MUG_MSG_LIST_VIEW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj),MUG_TYPE_MSG_LIST_VIEW,MugMsgListViewClass))
|
#define MUG_MSG_LIST_VIEW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj),MUG_TYPE_MSG_LIST_VIEW,MugMsgListViewClass))
|
||||||
|
|
||||||
typedef struct _MugMsgListView MugMsgListView;
|
typedef struct _MugMsgListView MugMsgListView;
|
||||||
typedef struct _MugMsgListViewClass MugMsgListViewClass;
|
typedef struct _MugMsgListViewClass MugMsgListViewClass;
|
||||||
|
|
||||||
@ -49,7 +47,6 @@ enum _MugError {
|
|||||||
};
|
};
|
||||||
typedef enum _MugError MugError;
|
typedef enum _MugError MugError;
|
||||||
|
|
||||||
|
|
||||||
struct _MugMsgListViewClass {
|
struct _MugMsgListViewClass {
|
||||||
GtkTreeViewClass parent_class;
|
GtkTreeViewClass parent_class;
|
||||||
/* insert signal callback declarations, e.g. */
|
/* insert signal callback declarations, e.g. */
|
||||||
@ -66,7 +63,6 @@ GtkWidget* mug_msg_list_view_new (const char *xpath);
|
|||||||
|
|
||||||
int mug_msg_list_view_query(MugMsgListView * self, const char *query);
|
int mug_msg_list_view_query(MugMsgListView * self, const char *query);
|
||||||
|
|
||||||
|
|
||||||
void mug_msg_list_view_move_first(MugMsgListView * self);
|
void mug_msg_list_view_move_first(MugMsgListView * self);
|
||||||
|
|
||||||
gboolean mug_msg_list_view_move_prev(MugMsgListView * self);
|
gboolean mug_msg_list_view_move_prev(MugMsgListView * self);
|
||||||
@ -75,6 +71,4 @@ gboolean mug_msg_list_view_move_next (MugMsgListView *self);
|
|||||||
const gchar *mug_msg_list_view_get_query(MugMsgListView * self);
|
const gchar *mug_msg_list_view_get_query(MugMsgListView * self);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
#endif /* __MUG_MSG_LIST_VIEW_H__ */
|
#endif /* __MUG_MSG_LIST_VIEW_H__ */
|
||||||
|
|
||||||
|
|||||||
@ -17,7 +17,6 @@
|
|||||||
**
|
**
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include "mug-msg-view.h"
|
#include "mug-msg-view.h"
|
||||||
#include "mu-msg.h"
|
#include "mu-msg.h"
|
||||||
#include "mu-str.h"
|
#include "mu-str.h"
|
||||||
@ -77,19 +76,16 @@ struct _MugMsgViewPrivate {
|
|||||||
GtkWidget *_expander_header, *_expander;
|
GtkWidget *_expander_header, *_expander;
|
||||||
GtkWidget *_view;
|
GtkWidget *_view;
|
||||||
};
|
};
|
||||||
#define MUG_MSG_VIEW_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE((o), \
|
#define MUG_MSG_VIEW_GET_PRIVATE(o)(G_TYPE_INSTANCE_GET_PRIVATE((o),MUG_TYPE_MSG_VIEW, MugMsgViewPrivate))
|
||||||
MUG_TYPE_MSG_VIEW, MugMsgViewPrivate))
|
|
||||||
/* globals */
|
/* globals */
|
||||||
static GtkVBoxClass *parent_class = NULL;
|
static GtkVBoxClass *parent_class = NULL;
|
||||||
|
|
||||||
/* uncomment the following if you have defined any signals */
|
/* uncomment the following if you have defined any signals */
|
||||||
/* static guint signals[LAST_SIGNAL] = {0}; */
|
/* static guint signals[LAST_SIGNAL] = {0}; */
|
||||||
|
|
||||||
|
|
||||||
G_DEFINE_TYPE(MugMsgView, mug_msg_view, GTK_TYPE_VBOX);
|
G_DEFINE_TYPE(MugMsgView, mug_msg_view, GTK_TYPE_VBOX);
|
||||||
|
|
||||||
static void
|
static void mug_msg_view_class_init(MugMsgViewClass * klass)
|
||||||
mug_msg_view_class_init (MugMsgViewClass *klass)
|
|
||||||
{
|
{
|
||||||
GObjectClass *gobject_class;
|
GObjectClass *gobject_class;
|
||||||
gobject_class = (GObjectClass *) klass;
|
gobject_class = (GObjectClass *) klass;
|
||||||
@ -107,9 +103,8 @@ mug_msg_view_class_init (MugMsgViewClass *klass)
|
|||||||
/* etc. */
|
/* etc. */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GtkWidget *create_table(MugMsgViewPrivate * priv,
|
||||||
static GtkWidget*
|
const HeaderInfo * hinfo, guint num)
|
||||||
create_table (MugMsgViewPrivate *priv, const HeaderInfo *hinfo, guint num)
|
|
||||||
{
|
{
|
||||||
guint i;
|
guint i;
|
||||||
GtkWidget *table;
|
GtkWidget *table;
|
||||||
@ -141,29 +136,26 @@ create_table (MugMsgViewPrivate *priv, const HeaderInfo *hinfo, guint num)
|
|||||||
|
|
||||||
gtk_container_add(GTK_CONTAINER(al), l);
|
gtk_container_add(GTK_CONTAINER(al), l);
|
||||||
gtk_label_set_justify(GTK_LABEL(l), GTK_JUSTIFY_LEFT);
|
gtk_label_set_justify(GTK_LABEL(l), GTK_JUSTIFY_LEFT);
|
||||||
gtk_label_set_line_wrap_mode (GTK_LABEL(l), PANGO_WRAP_WORD_CHAR);
|
gtk_label_set_line_wrap_mode(GTK_LABEL(l),
|
||||||
|
PANGO_WRAP_WORD_CHAR);
|
||||||
gtk_label_set_line_wrap(GTK_LABEL(l), FALSE);
|
gtk_label_set_line_wrap(GTK_LABEL(l), FALSE);
|
||||||
gtk_table_attach(GTK_TABLE(table), al,
|
gtk_table_attach(GTK_TABLE(table), al,
|
||||||
1, 2, i, i+1,
|
1, 2, i, i + 1, GTK_FILL, 0, 0, 0);
|
||||||
GTK_FILL,
|
|
||||||
0, 0, 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return table;
|
return table;
|
||||||
}
|
}
|
||||||
|
|
||||||
static GtkWidget*
|
static GtkWidget *headers_area(MugMsgViewPrivate * priv)
|
||||||
headers_area (MugMsgViewPrivate *priv)
|
|
||||||
{
|
{
|
||||||
GtkWidget *scrolled, *vbox;
|
GtkWidget *scrolled, *vbox;
|
||||||
|
|
||||||
priv->_tablemain = create_table(priv, HEADER_INFO,
|
priv->_tablemain = create_table(priv, HEADER_INFO,
|
||||||
G_N_ELEMENTS(HEADER_INFO));
|
G_N_ELEMENTS(HEADER_INFO));
|
||||||
priv->_tableexpander = create_table (priv, HEADER_INFO_EXPANDER,
|
priv->_tableexpander = create_table
|
||||||
G_N_ELEMENTS(HEADER_INFO_EXPANDER));
|
(priv, HEADER_INFO_EXPANDER, G_N_ELEMENTS(HEADER_INFO_EXPANDER));
|
||||||
priv->_expander = gtk_expander_new("Details");
|
priv->_expander = gtk_expander_new("Details");
|
||||||
gtk_container_add (GTK_CONTAINER(priv->_expander),
|
gtk_container_add(GTK_CONTAINER(priv->_expander), priv->_tableexpander);
|
||||||
priv->_tableexpander);
|
|
||||||
|
|
||||||
vbox = gtk_vbox_new(FALSE, FALSE);
|
vbox = gtk_vbox_new(FALSE, FALSE);
|
||||||
gtk_box_pack_start(GTK_BOX(vbox), priv->_tablemain, FALSE, FALSE, 0);
|
gtk_box_pack_start(GTK_BOX(vbox), priv->_tablemain, FALSE, FALSE, 0);
|
||||||
@ -171,15 +163,15 @@ headers_area (MugMsgViewPrivate *priv)
|
|||||||
|
|
||||||
scrolled = gtk_scrolled_window_new(NULL, NULL);
|
scrolled = gtk_scrolled_window_new(NULL, NULL);
|
||||||
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled),
|
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled),
|
||||||
GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
|
GTK_POLICY_AUTOMATIC,
|
||||||
gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW(scrolled), vbox);
|
GTK_POLICY_AUTOMATIC);
|
||||||
|
gtk_scrolled_window_add_with_viewport(GTK_SCROLLED_WINDOW(scrolled),
|
||||||
|
vbox);
|
||||||
|
|
||||||
return priv->_headers_area = scrolled;
|
return priv->_headers_area = scrolled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void mug_msg_view_init(MugMsgView * obj)
|
||||||
static void
|
|
||||||
mug_msg_view_init (MugMsgView *obj)
|
|
||||||
{
|
{
|
||||||
MugMsgViewPrivate *priv;
|
MugMsgViewPrivate *priv;
|
||||||
GtkWidget *scrolled;
|
GtkWidget *scrolled;
|
||||||
@ -193,32 +185,41 @@ mug_msg_view_init (MugMsgView *obj)
|
|||||||
|
|
||||||
scrolled = gtk_scrolled_window_new(NULL, NULL);
|
scrolled = gtk_scrolled_window_new(NULL, NULL);
|
||||||
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled),
|
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled),
|
||||||
GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
|
GTK_POLICY_AUTOMATIC,
|
||||||
|
GTK_POLICY_AUTOMATIC);
|
||||||
gtk_container_add(GTK_CONTAINER(scrolled), priv->_view);
|
gtk_container_add(GTK_CONTAINER(scrolled), priv->_view);
|
||||||
|
|
||||||
gtk_box_pack_start(GTK_BOX(obj), headers_area(priv), FALSE, FALSE, 0);
|
gtk_box_pack_start(GTK_BOX(obj), headers_area(priv), FALSE, FALSE, 0);
|
||||||
gtk_box_pack_start(GTK_BOX(obj), scrolled, TRUE, TRUE, 0);
|
gtk_box_pack_start(GTK_BOX(obj), scrolled, TRUE, TRUE, 0);
|
||||||
|
|
||||||
gtk_widget_hide (priv->_headers_area);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void mug_msg_view_finalize(GObject * obj)
|
||||||
mug_msg_view_finalize (GObject *obj)
|
|
||||||
{
|
{
|
||||||
/* free/unref instance resources here */
|
/* free/unref instance resources here */
|
||||||
G_OBJECT_CLASS(parent_class)->finalize(obj);
|
G_OBJECT_CLASS(parent_class)->finalize(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkWidget*
|
GtkWidget *mug_msg_view_new(void)
|
||||||
mug_msg_view_new (void)
|
|
||||||
{
|
{
|
||||||
return GTK_WIDGET(g_object_new(MUG_TYPE_MSG_VIEW, NULL));
|
return GTK_WIDGET(g_object_new(MUG_TYPE_MSG_VIEW, NULL));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void empty_message(MugMsgView * self)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
MugMsgViewPrivate *priv;
|
||||||
|
GtkTextBuffer *buf;
|
||||||
|
|
||||||
|
priv = MUG_MSG_VIEW_GET_PRIVATE(self);
|
||||||
|
|
||||||
gboolean
|
for (i = 0; i != HEADER_ROW_NUM; ++i)
|
||||||
mug_msg_view_set_text (MugMsgView *self, const char* txt)
|
gtk_label_set_markup(GTK_LABEL(priv->_headervals[i]), "");
|
||||||
|
|
||||||
|
buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(priv->_view));
|
||||||
|
gtk_text_buffer_set_text(buf, "", -1);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean set_text(MugMsgView * self, const char *txt)
|
||||||
{
|
{
|
||||||
MugMsgViewPrivate *priv;
|
MugMsgViewPrivate *priv;
|
||||||
GtkTextBuffer *buf;
|
GtkTextBuffer *buf;
|
||||||
@ -232,43 +233,52 @@ mug_msg_view_set_text (MugMsgView *self, const char* txt)
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void fill_header(MugMsgViewPrivate * priv, MuMsg * msg)
|
||||||
static void
|
|
||||||
fill_header (MugMsgViewPrivate *priv, MuMsg* msg)
|
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i != HEADER_ROW_NUM; ++i) {
|
for (i = 0; i != HEADER_ROW_NUM; ++i) {
|
||||||
const gchar *val;
|
const gchar *val;
|
||||||
switch (i) {
|
switch (i) {
|
||||||
case HEADER_ROW_FROM: val = mu_msg_get_from(msg); break;
|
case HEADER_ROW_FROM:
|
||||||
case HEADER_ROW_TO: val = mu_msg_get_to(msg); break;
|
val = mu_msg_get_from(msg);
|
||||||
case HEADER_ROW_SUBJECT: val = mu_msg_get_subject(msg); break;
|
|
||||||
case HEADER_ROW_MSGID: val = mu_msg_get_msgid(msg); break;
|
|
||||||
case HEADER_ROW_CC: val = mu_msg_get_cc (msg); break;
|
|
||||||
case HEADER_ROW_PATH: val = mu_msg_get_path (msg); break;
|
|
||||||
case HEADER_ROW_DATE: val = mu_str_date_s(
|
|
||||||
"%c", mu_msg_get_date (msg));
|
|
||||||
break;
|
break;
|
||||||
case HEADER_ROW_SIZE: val = mu_str_size_s (mu_msg_get_size(msg));
|
case HEADER_ROW_TO:
|
||||||
|
val = mu_msg_get_to(msg);
|
||||||
break;
|
break;
|
||||||
default: val = NULL;
|
case HEADER_ROW_SUBJECT:
|
||||||
|
val = mu_msg_get_subject(msg);
|
||||||
|
break;
|
||||||
|
case HEADER_ROW_MSGID:
|
||||||
|
val = mu_msg_get_msgid(msg);
|
||||||
|
break;
|
||||||
|
case HEADER_ROW_CC:
|
||||||
|
val = mu_msg_get_cc(msg);
|
||||||
|
break;
|
||||||
|
case HEADER_ROW_PATH:
|
||||||
|
val = mu_msg_get_path(msg);
|
||||||
|
break;
|
||||||
|
case HEADER_ROW_DATE:
|
||||||
|
val = mu_str_date_s("%c", mu_msg_get_date(msg));
|
||||||
|
break;
|
||||||
|
case HEADER_ROW_SIZE:
|
||||||
|
val = mu_str_size_s(mu_msg_get_size(msg));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
val = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
gchar *str;
|
gchar *str;
|
||||||
str = g_markup_escape_text(val ? val : "", -1);
|
str = g_markup_escape_text(val ? val : "", -1);
|
||||||
gtk_label_set_markup (GTK_LABEL(priv->_headervals[i]), str);
|
gtk_label_set_markup
|
||||||
|
(GTK_LABEL(priv->_headervals[i]), str);
|
||||||
g_free(str);
|
g_free(str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
gtk_widget_show (priv->_tablemain);
|
|
||||||
gtk_widget_show (priv->_expander);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gboolean mug_msg_view_set_msg(MugMsgView * self, const char *msgpath)
|
||||||
gboolean
|
|
||||||
mug_msg_view_set_msg (MugMsgView *self, const char* msgpath)
|
|
||||||
{
|
{
|
||||||
MugMsgViewPrivate *priv;
|
MugMsgViewPrivate *priv;
|
||||||
MuMsg *msg;
|
MuMsg *msg;
|
||||||
@ -279,24 +289,19 @@ mug_msg_view_set_msg (MugMsgView *self, const char* msgpath)
|
|||||||
priv = MUG_MSG_VIEW_GET_PRIVATE(self);
|
priv = MUG_MSG_VIEW_GET_PRIVATE(self);
|
||||||
|
|
||||||
if (!msgpath) {
|
if (!msgpath) {
|
||||||
mug_msg_view_set_text (self, "");
|
empty_message(self);
|
||||||
gtk_widget_hide (priv->_headers_area);
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
msg = mu_msg_new(msgpath, NULL, NULL);
|
msg = mu_msg_new(msgpath, NULL, NULL);
|
||||||
if (!msg) {
|
if (!msg) {
|
||||||
gtk_widget_hide (priv->_tablemain);
|
empty_message(self);
|
||||||
gtk_widget_hide (priv->_expander);
|
set_text(self, "Message not found; " "please run 'mu index'");
|
||||||
mug_msg_view_set_text (self,
|
|
||||||
"Message not found; "
|
|
||||||
"please run 'mu index'");
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
rv = mug_msg_view_set_text (self, mu_msg_get_body_text(msg));
|
rv = set_text(self, mu_msg_get_body_text(msg));
|
||||||
fill_header(priv, msg);
|
fill_header(priv, msg);
|
||||||
gtk_widget_show (priv->_headers_area);
|
|
||||||
|
|
||||||
mu_msg_destroy(msg);
|
mu_msg_destroy(msg);
|
||||||
|
|
||||||
|
|||||||
@ -17,7 +17,6 @@
|
|||||||
**
|
**
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifndef __MUG_MSG_VIEW_H__
|
#ifndef __MUG_MSG_VIEW_H__
|
||||||
#define __MUG_MSG_VIEW_H__
|
#define __MUG_MSG_VIEW_H__
|
||||||
|
|
||||||
@ -25,7 +24,6 @@
|
|||||||
/* other include files */
|
/* other include files */
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
/* convenience macros */
|
/* convenience macros */
|
||||||
#define MUG_TYPE_MSG_VIEW (mug_msg_view_get_type())
|
#define MUG_TYPE_MSG_VIEW (mug_msg_view_get_type())
|
||||||
#define MUG_MSG_VIEW(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),MUG_TYPE_MSG_VIEW,MugMsgView))
|
#define MUG_MSG_VIEW(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),MUG_TYPE_MSG_VIEW,MugMsgView))
|
||||||
@ -33,7 +31,6 @@ G_BEGIN_DECLS
|
|||||||
#define MUG_IS_MSG_VIEW(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),MUG_TYPE_MSG_VIEW))
|
#define MUG_IS_MSG_VIEW(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),MUG_TYPE_MSG_VIEW))
|
||||||
#define MUG_IS_MSG_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),MUG_TYPE_MSG_VIEW))
|
#define MUG_IS_MSG_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),MUG_TYPE_MSG_VIEW))
|
||||||
#define MUG_MSG_VIEW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj),MUG_TYPE_MSG_VIEW,MugMsgViewClass))
|
#define MUG_MSG_VIEW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj),MUG_TYPE_MSG_VIEW,MugMsgViewClass))
|
||||||
|
|
||||||
typedef struct _MugMsgView MugMsgView;
|
typedef struct _MugMsgView MugMsgView;
|
||||||
typedef struct _MugMsgViewClass MugMsgViewClass;
|
typedef struct _MugMsgViewClass MugMsgViewClass;
|
||||||
|
|
||||||
@ -55,9 +52,6 @@ GType mug_msg_view_get_type (void) G_GNUC_CONST;
|
|||||||
/* if this is a kind of GtkWidget, it should probably return at GtkWidget* */
|
/* if this is a kind of GtkWidget, it should probably return at GtkWidget* */
|
||||||
GtkWidget *mug_msg_view_new(void);
|
GtkWidget *mug_msg_view_new(void);
|
||||||
gboolean mug_msg_view_set_msg(MugMsgView * self, const char *msgpath);
|
gboolean mug_msg_view_set_msg(MugMsgView * self, const char *msgpath);
|
||||||
gboolean mug_msg_view_set_text (MugMsgView *self, const char* txt);
|
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
#endif /* __MUG_MSG_VIEW_H__ */
|
#endif /* __MUG_MSG_VIEW_H__ */
|
||||||
|
|
||||||
|
|||||||
@ -28,8 +28,7 @@ static GtkContainerClass *parent_class = NULL;
|
|||||||
|
|
||||||
static guint signals[LAST_SIGNAL] = { 0 };
|
static guint signals[LAST_SIGNAL] = { 0 };
|
||||||
|
|
||||||
GType
|
GType mug_query_bar_get_type(void)
|
||||||
mug_query_bar_get_type (void)
|
|
||||||
{
|
{
|
||||||
static GType my_type = 0;
|
static GType my_type = 0;
|
||||||
if (!my_type) {
|
if (!my_type) {
|
||||||
@ -46,14 +45,12 @@ mug_query_bar_get_type (void)
|
|||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
my_type = g_type_register_static(GTK_TYPE_HBOX,
|
my_type = g_type_register_static(GTK_TYPE_HBOX,
|
||||||
"MugQueryBar",
|
"MugQueryBar", &my_info, 0);
|
||||||
&my_info, 0);
|
|
||||||
}
|
}
|
||||||
return my_type;
|
return my_type;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void mug_query_bar_class_init(MugQueryBarClass * klass)
|
||||||
mug_query_bar_class_init (MugQueryBarClass *klass)
|
|
||||||
{
|
{
|
||||||
GObjectClass *gobject_class;
|
GObjectClass *gobject_class;
|
||||||
gobject_class = (GObjectClass *) klass;
|
gobject_class = (GObjectClass *) klass;
|
||||||
@ -74,9 +71,7 @@ mug_query_bar_class_init (MugQueryBarClass *klass)
|
|||||||
G_TYPE_NONE, 1, G_TYPE_STRING);
|
G_TYPE_NONE, 1, G_TYPE_STRING);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void on_entry_activated(GtkWidget * w, MugQueryBar * bar)
|
||||||
static void
|
|
||||||
on_entry_activated (GtkWidget *w, MugQueryBar *bar)
|
|
||||||
{
|
{
|
||||||
MugQueryBarPrivate *priv;
|
MugQueryBarPrivate *priv;
|
||||||
|
|
||||||
@ -86,8 +81,7 @@ on_entry_activated (GtkWidget *w, MugQueryBar *bar)
|
|||||||
gtk_entry_get_text(GTK_ENTRY(w)));
|
gtk_entry_get_text(GTK_ENTRY(w)));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void mug_query_bar_init(MugQueryBar * obj)
|
||||||
mug_query_bar_init (MugQueryBar *obj)
|
|
||||||
{
|
{
|
||||||
MugQueryBarPrivate *priv;
|
MugQueryBarPrivate *priv;
|
||||||
|
|
||||||
@ -95,26 +89,23 @@ mug_query_bar_init (MugQueryBar *obj)
|
|||||||
|
|
||||||
priv->_entry = gtk_entry_new();
|
priv->_entry = gtk_entry_new();
|
||||||
|
|
||||||
g_signal_connect (priv->_entry, "activate", G_CALLBACK(on_entry_activated),
|
g_signal_connect(priv->_entry, "activate",
|
||||||
obj);
|
G_CALLBACK(on_entry_activated), obj);
|
||||||
|
|
||||||
gtk_box_pack_start(GTK_BOX(obj), priv->_entry, TRUE, TRUE, 0);
|
gtk_box_pack_start(GTK_BOX(obj), priv->_entry, TRUE, TRUE, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void mug_query_bar_finalize(GObject * obj)
|
||||||
mug_query_bar_finalize (GObject *obj)
|
|
||||||
{
|
{
|
||||||
/* free/unref instance resources here */
|
/* free/unref instance resources here */
|
||||||
G_OBJECT_CLASS(parent_class)->finalize(obj);
|
G_OBJECT_CLASS(parent_class)->finalize(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkWidget*
|
GtkWidget *mug_query_bar_new(void)
|
||||||
mug_query_bar_new (void)
|
|
||||||
{
|
{
|
||||||
return GTK_WIDGET(g_object_new(MUG_TYPE_QUERY_BAR, NULL));
|
return GTK_WIDGET(g_object_new(MUG_TYPE_QUERY_BAR, NULL));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
mug_query_bar_set_query(MugQueryBar * self, const char *query, gboolean run)
|
mug_query_bar_set_query(MugQueryBar * self, const char *query, gboolean run)
|
||||||
{
|
{
|
||||||
@ -129,13 +120,10 @@ mug_query_bar_set_query (MugQueryBar *self, const char *query, gboolean run)
|
|||||||
on_entry_activated(priv->_entry, self);
|
on_entry_activated(priv->_entry, self);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void mug_query_bar_grab_focus(MugQueryBar * self)
|
||||||
void
|
|
||||||
mug_query_bar_grab_focus (MugQueryBar *self)
|
|
||||||
{
|
{
|
||||||
g_return_if_fail(MUG_IS_QUERY_BAR(self));
|
g_return_if_fail(MUG_IS_QUERY_BAR(self));
|
||||||
|
|
||||||
gtk_widget_grab_focus
|
gtk_widget_grab_focus
|
||||||
(GTK_WIDGET(MUG_QUERY_BAR_GET_PRIVATE(self)->_entry));
|
(GTK_WIDGET(MUG_QUERY_BAR_GET_PRIVATE(self)->_entry));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -8,7 +8,6 @@
|
|||||||
/* other include files */
|
/* other include files */
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
/* convenience macros */
|
/* convenience macros */
|
||||||
#define MUG_TYPE_QUERY_BAR (mug_query_bar_get_type())
|
#define MUG_TYPE_QUERY_BAR (mug_query_bar_get_type())
|
||||||
#define MUG_QUERY_BAR(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),MUG_TYPE_QUERY_BAR,MugQueryBar))
|
#define MUG_QUERY_BAR(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),MUG_TYPE_QUERY_BAR,MugQueryBar))
|
||||||
@ -16,7 +15,6 @@ G_BEGIN_DECLS
|
|||||||
#define MUG_IS_QUERY_BAR(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),MUG_TYPE_QUERY_BAR))
|
#define MUG_IS_QUERY_BAR(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),MUG_TYPE_QUERY_BAR))
|
||||||
#define MUG_IS_QUERY_BAR_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),MUG_TYPE_QUERY_BAR))
|
#define MUG_IS_QUERY_BAR_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),MUG_TYPE_QUERY_BAR))
|
||||||
#define MUG_QUERY_BAR_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj),MUG_TYPE_QUERY_BAR,MugQueryBarClass))
|
#define MUG_QUERY_BAR_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj),MUG_TYPE_QUERY_BAR,MugQueryBarClass))
|
||||||
|
|
||||||
typedef struct _MugQueryBar MugQueryBar;
|
typedef struct _MugQueryBar MugQueryBar;
|
||||||
typedef struct _MugQueryBarClass MugQueryBarClass;
|
typedef struct _MugQueryBarClass MugQueryBarClass;
|
||||||
|
|
||||||
@ -40,9 +38,8 @@ GtkWidget* mug_query_bar_new (void);
|
|||||||
|
|
||||||
void mug_query_bar_grab_focus(MugQueryBar * self);
|
void mug_query_bar_grab_focus(MugQueryBar * self);
|
||||||
|
|
||||||
void mug_query_bar_set_query (MugQueryBar *self, const char *query, gboolean run);
|
void mug_query_bar_set_query(MugQueryBar * self, const char *query,
|
||||||
|
gboolean run);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
#endif /* __MUG_QUERY_BAR_H__ */
|
#endif /* __MUG_QUERY_BAR_H__ */
|
||||||
|
|
||||||
|
|||||||
@ -51,8 +51,7 @@ static guint signals[LAST_SIGNAL] = {0};
|
|||||||
|
|
||||||
G_DEFINE_TYPE(MugShortcuts, mug_shortcuts, GTK_TYPE_VBOX);
|
G_DEFINE_TYPE(MugShortcuts, mug_shortcuts, GTK_TYPE_VBOX);
|
||||||
|
|
||||||
static void
|
static void mug_shortcuts_class_init(MugShortcutsClass * klass)
|
||||||
mug_shortcuts_class_init (MugShortcutsClass *klass)
|
|
||||||
{
|
{
|
||||||
GObjectClass *gobject_class;
|
GObjectClass *gobject_class;
|
||||||
gobject_class = (GObjectClass *) klass;
|
gobject_class = (GObjectClass *) klass;
|
||||||
@ -72,14 +71,12 @@ mug_shortcuts_class_init (MugShortcutsClass *klass)
|
|||||||
g_cclosure_marshal_VOID__STRING,
|
g_cclosure_marshal_VOID__STRING,
|
||||||
G_TYPE_NONE, 1, G_TYPE_STRING);
|
G_TYPE_NONE, 1, G_TYPE_STRING);
|
||||||
|
|
||||||
|
|
||||||
/* signals[MY_SIGNAL_2] = */
|
/* signals[MY_SIGNAL_2] = */
|
||||||
/* g_signal_new ("my_signal_2",....); */
|
/* g_signal_new ("my_signal_2",....); */
|
||||||
/* etc. */
|
/* etc. */
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void mug_shortcuts_init(MugShortcuts * obj)
|
||||||
mug_shortcuts_init (MugShortcuts *obj)
|
|
||||||
{
|
{
|
||||||
obj->_priv = MUG_SHORTCUTS_GET_PRIVATE(obj);
|
obj->_priv = MUG_SHORTCUTS_GET_PRIVATE(obj);
|
||||||
|
|
||||||
@ -89,15 +86,13 @@ mug_shortcuts_init (MugShortcuts *obj)
|
|||||||
gtk_box_pack_start(GTK_BOX(obj), obj->_priv->_bbox, TRUE, TRUE, 0);
|
gtk_box_pack_start(GTK_BOX(obj), obj->_priv->_bbox, TRUE, TRUE, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void mug_shortcuts_finalize(GObject * obj)
|
||||||
mug_shortcuts_finalize (GObject *obj)
|
|
||||||
{
|
{
|
||||||
/* free/unref instance resources here */
|
/* free/unref instance resources here */
|
||||||
G_OBJECT_CLASS(parent_class)->finalize(obj);
|
G_OBJECT_CLASS(parent_class)->finalize(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void on_button_clicked(GtkWidget * button, MugShortcuts * self)
|
||||||
on_button_clicked (GtkWidget *button, MugShortcuts *self)
|
|
||||||
{
|
{
|
||||||
g_signal_emit(G_OBJECT(self),
|
g_signal_emit(G_OBJECT(self),
|
||||||
signals[SHORTCUT_CLICKED], 0,
|
signals[SHORTCUT_CLICKED], 0,
|
||||||
@ -105,23 +100,20 @@ on_button_clicked (GtkWidget *button, MugShortcuts *self)
|
|||||||
MUG_SHORTCUT_BOOKMARK));
|
MUG_SHORTCUT_BOOKMARK));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void each_bookmark(const char *key, const char *val, MugShortcuts * self)
|
||||||
static void
|
|
||||||
each_bookmark (const char* key, const char* val, MugShortcuts *self)
|
|
||||||
{
|
{
|
||||||
GtkWidget *button;
|
GtkWidget *button;
|
||||||
|
|
||||||
button = gtk_button_new_with_label(key);
|
button = gtk_button_new_with_label(key);
|
||||||
g_object_set_data_full(G_OBJECT(button), MUG_SHORTCUT_BOOKMARK,
|
g_object_set_data_full(G_OBJECT(button), MUG_SHORTCUT_BOOKMARK,
|
||||||
g_strdup(val), g_free);
|
g_strdup(val), g_free);
|
||||||
g_signal_connect (G_OBJECT(button), "clicked", G_CALLBACK(on_button_clicked),
|
g_signal_connect(G_OBJECT(button), "clicked",
|
||||||
self);
|
G_CALLBACK(on_button_clicked), self);
|
||||||
|
|
||||||
gtk_container_add(GTK_CONTAINER(self->_priv->_bbox), button);
|
gtk_container_add(GTK_CONTAINER(self->_priv->_bbox), button);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean init_shortcuts(MugShortcuts * self, const char *bmpath)
|
||||||
init_shortcuts (MugShortcuts *self, const char* bmpath)
|
|
||||||
{
|
{
|
||||||
MuBookmarks *bookmarks;
|
MuBookmarks *bookmarks;
|
||||||
|
|
||||||
@ -136,8 +128,7 @@ init_shortcuts (MugShortcuts *self, const char* bmpath)
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkWidget*
|
GtkWidget *mug_shortcuts_new(const char *bmpath)
|
||||||
mug_shortcuts_new (const char *bmpath)
|
|
||||||
{
|
{
|
||||||
MugShortcuts *self;
|
MugShortcuts *self;
|
||||||
|
|
||||||
@ -152,4 +143,3 @@ mug_shortcuts_new (const char *bmpath)
|
|||||||
|
|
||||||
/* following: other function implementations */
|
/* following: other function implementations */
|
||||||
/* such as mug_shortcuts_do_something, or mug_shortcuts_has_foo */
|
/* such as mug_shortcuts_do_something, or mug_shortcuts_has_foo */
|
||||||
|
|
||||||
|
|||||||
@ -17,7 +17,6 @@
|
|||||||
**
|
**
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifndef __MUG_SHORTCUTS_H__
|
#ifndef __MUG_SHORTCUTS_H__
|
||||||
#define __MUG_SHORTCUTS_H__
|
#define __MUG_SHORTCUTS_H__
|
||||||
|
|
||||||
@ -25,7 +24,6 @@
|
|||||||
/* other include files */
|
/* other include files */
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
/* convenience macros */
|
/* convenience macros */
|
||||||
#define MUG_TYPE_SHORTCUTS (mug_shortcuts_get_type())
|
#define MUG_TYPE_SHORTCUTS (mug_shortcuts_get_type())
|
||||||
#define MUG_SHORTCUTS(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),MUG_TYPE_SHORTCUTS,MugShortcuts))
|
#define MUG_SHORTCUTS(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),MUG_TYPE_SHORTCUTS,MugShortcuts))
|
||||||
@ -33,7 +31,6 @@ G_BEGIN_DECLS
|
|||||||
#define MUG_IS_SHORTCUTS(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),MUG_TYPE_SHORTCUTS))
|
#define MUG_IS_SHORTCUTS(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),MUG_TYPE_SHORTCUTS))
|
||||||
#define MUG_IS_SHORTCUTS_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),MUG_TYPE_SHORTCUTS))
|
#define MUG_IS_SHORTCUTS_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),MUG_TYPE_SHORTCUTS))
|
||||||
#define MUG_SHORTCUTS_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj),MUG_TYPE_SHORTCUTS,MugShortcutsClass))
|
#define MUG_SHORTCUTS_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj),MUG_TYPE_SHORTCUTS,MugShortcutsClass))
|
||||||
|
|
||||||
typedef struct _MugShortcuts MugShortcuts;
|
typedef struct _MugShortcuts MugShortcuts;
|
||||||
typedef struct _MugShortcutsClass MugShortcutsClass;
|
typedef struct _MugShortcutsClass MugShortcutsClass;
|
||||||
typedef struct _MugShortcutsPrivate MugShortcutsPrivate;
|
typedef struct _MugShortcutsPrivate MugShortcutsPrivate;
|
||||||
@ -62,8 +59,5 @@ GtkWidget* mug_shortcuts_new (const char *bmpath);
|
|||||||
/* void mug_shortcuts_do_something (MugShortcuts *self, const gchar* param); */
|
/* void mug_shortcuts_do_something (MugShortcuts *self, const gchar* param); */
|
||||||
/* gboolean mug_shortcuts_has_foo (MugShortcuts *self, gint value); */
|
/* gboolean mug_shortcuts_has_foo (MugShortcuts *self, gint value); */
|
||||||
|
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
#endif /* __MUG_SHORTCUTS_H__ */
|
#endif /* __MUG_SHORTCUTS_H__ */
|
||||||
|
|
||||||
|
|||||||
135
toys/mug/mug.cc
135
toys/mug/mug.cc
@ -44,9 +44,7 @@ struct _MugData {
|
|||||||
};
|
};
|
||||||
typedef struct _MugData MugData;
|
typedef struct _MugData MugData;
|
||||||
|
|
||||||
|
static void about_mug(MugData * mugdata)
|
||||||
static void
|
|
||||||
about_mug (MugData *mugdata)
|
|
||||||
{
|
{
|
||||||
GtkWidget *about;
|
GtkWidget *about;
|
||||||
about = gtk_message_dialog_new
|
about = gtk_message_dialog_new
|
||||||
@ -70,24 +68,22 @@ enum _ToolAction {
|
|||||||
};
|
};
|
||||||
typedef enum _ToolAction ToolAction;
|
typedef enum _ToolAction ToolAction;
|
||||||
|
|
||||||
static void
|
static void on_tool_button_clicked(GtkToolButton * btn, MugData * mugdata)
|
||||||
on_tool_button_clicked (GtkToolButton *btn, MugData *mugdata)
|
|
||||||
{
|
{
|
||||||
ToolAction action;
|
ToolAction action;
|
||||||
action = (ToolAction)GPOINTER_TO_UINT(
|
action =
|
||||||
g_object_get_data(G_OBJECT(btn),"action"));
|
(ToolAction)
|
||||||
|
GPOINTER_TO_UINT(g_object_get_data(G_OBJECT(btn), "action"));
|
||||||
switch (action) {
|
switch (action) {
|
||||||
|
|
||||||
case ACTION_DO_QUIT:
|
case ACTION_DO_QUIT:
|
||||||
gtk_main_quit();
|
gtk_main_quit();
|
||||||
break;
|
break;
|
||||||
case ACTION_NEXT_MSG:
|
case ACTION_NEXT_MSG:
|
||||||
mug_msg_list_view_move_next
|
mug_msg_list_view_move_next(MUG_MSG_LIST_VIEW(mugdata->mlist));
|
||||||
(MUG_MSG_LIST_VIEW(mugdata->mlist));
|
|
||||||
break;
|
break;
|
||||||
case ACTION_PREV_MSG:
|
case ACTION_PREV_MSG:
|
||||||
mug_msg_list_view_move_prev
|
mug_msg_list_view_move_prev(MUG_MSG_LIST_VIEW(mugdata->mlist));
|
||||||
(MUG_MSG_LIST_VIEW(mugdata->mlist));
|
|
||||||
break;
|
break;
|
||||||
case ACTION_ABOUT:
|
case ACTION_ABOUT:
|
||||||
about_mug(mugdata);
|
about_mug(mugdata);
|
||||||
@ -97,8 +93,7 @@ on_tool_button_clicked (GtkToolButton *btn, MugData *mugdata)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static GtkWidget*
|
static GtkWidget *mug_toolbar(MugData * mugdata)
|
||||||
mug_toolbar (MugData *mugdata)
|
|
||||||
{
|
{
|
||||||
GtkWidget *toolbar;
|
GtkWidget *toolbar;
|
||||||
int i;
|
int i;
|
||||||
@ -106,19 +101,18 @@ mug_toolbar (MugData *mugdata)
|
|||||||
const char *stock_id;
|
const char *stock_id;
|
||||||
ToolAction action;
|
ToolAction action;
|
||||||
} tools[] = {
|
} tools[] = {
|
||||||
{ GTK_STOCK_GO_UP, ACTION_PREV_MSG },
|
{
|
||||||
{ GTK_STOCK_GO_DOWN, ACTION_NEXT_MSG },
|
GTK_STOCK_GO_UP, ACTION_PREV_MSG}, {
|
||||||
{ NULL, ACTION_SEPARATOR },
|
GTK_STOCK_GO_DOWN, ACTION_NEXT_MSG}, {
|
||||||
{ GTK_STOCK_ABOUT, ACTION_ABOUT },
|
NULL, ACTION_SEPARATOR}, {
|
||||||
{ NULL, ACTION_SEPARATOR },
|
GTK_STOCK_ABOUT, ACTION_ABOUT}, {
|
||||||
{ GTK_STOCK_QUIT, ACTION_DO_QUIT },
|
NULL, ACTION_SEPARATOR}, {
|
||||||
};
|
GTK_STOCK_QUIT, ACTION_DO_QUIT},};
|
||||||
|
|
||||||
for (toolbar = gtk_toolbar_new(), i = 0; i != G_N_ELEMENTS(tools); ++i) {
|
toolbar = gtk_toolbar_new();
|
||||||
|
for (i = 0; i != G_N_ELEMENTS(tools); ++i) {
|
||||||
GtkToolItem *btn;
|
GtkToolItem *btn;
|
||||||
|
if (tools[i].action == ACTION_SEPARATOR) { /* separator */
|
||||||
/* separator item ? */
|
|
||||||
if (tools[i].action == ACTION_SEPARATOR) {
|
|
||||||
gtk_toolbar_insert(GTK_TOOLBAR(toolbar),
|
gtk_toolbar_insert(GTK_TOOLBAR(toolbar),
|
||||||
gtk_separator_tool_item_new(), i);
|
gtk_separator_tool_item_new(), i);
|
||||||
continue;
|
continue;
|
||||||
@ -129,9 +123,9 @@ mug_toolbar (MugData *mugdata)
|
|||||||
g_object_set_data(G_OBJECT(btn), "action",
|
g_object_set_data(G_OBJECT(btn), "action",
|
||||||
GUINT_TO_POINTER(tools[i].action));
|
GUINT_TO_POINTER(tools[i].action));
|
||||||
g_signal_connect(G_OBJECT(btn), "clicked",
|
g_signal_connect(G_OBJECT(btn), "clicked",
|
||||||
G_CALLBACK(on_tool_button_clicked),
|
G_CALLBACK(on_tool_button_clicked), mugdata);
|
||||||
mugdata);
|
|
||||||
gtk_toolbar_insert(GTK_TOOLBAR(toolbar), btn, i);
|
gtk_toolbar_insert(GTK_TOOLBAR(toolbar), btn, i);
|
||||||
|
gtk_widget_show(GTK_WIDGET(btn));
|
||||||
}
|
}
|
||||||
|
|
||||||
return toolbar;
|
return toolbar;
|
||||||
@ -140,13 +134,10 @@ mug_toolbar (MugData *mugdata)
|
|||||||
static void
|
static void
|
||||||
on_shortcut_clicked(GtkWidget * w, const gchar * query, MugData * mdata)
|
on_shortcut_clicked(GtkWidget * w, const gchar * query, MugData * mdata)
|
||||||
{
|
{
|
||||||
mug_query_bar_set_query (MUG_QUERY_BAR(mdata->querybar),
|
mug_query_bar_set_query(MUG_QUERY_BAR(mdata->querybar), query, TRUE);
|
||||||
query, TRUE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GtkWidget *mug_shortcuts_bar(MugData * data)
|
||||||
static GtkWidget*
|
|
||||||
mug_shortcuts_bar (MugData *data)
|
|
||||||
{
|
{
|
||||||
data->shortcuts = mug_shortcuts_new(mu_runtime_bookmarks_file());
|
data->shortcuts = mug_shortcuts_new(mu_runtime_bookmarks_file());
|
||||||
|
|
||||||
@ -156,9 +147,7 @@ mug_shortcuts_bar (MugData *data)
|
|||||||
return data->shortcuts;
|
return data->shortcuts;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GtkWidget *mug_statusbar(void)
|
||||||
static GtkWidget*
|
|
||||||
mug_statusbar (void)
|
|
||||||
{
|
{
|
||||||
GtkWidget *statusbar;
|
GtkWidget *statusbar;
|
||||||
|
|
||||||
@ -173,25 +162,28 @@ on_query_changed (MugQueryBar *bar, const char* query, MugData *mugdata)
|
|||||||
int count;
|
int count;
|
||||||
|
|
||||||
/* clear the old message */
|
/* clear the old message */
|
||||||
mug_msg_view_set_text (MUG_MSG_VIEW(mugdata->msgview), NULL);
|
//mug_msg_view_set_text (MUG_MSG_VIEW(mugdata->msgview), NULL);
|
||||||
|
mug_msg_view_set_msg(MUG_MSG_VIEW(mugdata->msgview), NULL);
|
||||||
|
|
||||||
count = mug_msg_list_view_query(MUG_MSG_LIST_VIEW(mugdata->mlist),
|
count = mug_msg_list_view_query(MUG_MSG_LIST_VIEW(mugdata->mlist),
|
||||||
query);
|
query);
|
||||||
if (count >= 0) {
|
if (count >= 0) {
|
||||||
gchar *msg =
|
gchar *msg = g_strdup_printf("%d message%s found matching '%s'",
|
||||||
g_strdup_printf ("%d message%s found matching '%s'",
|
|
||||||
count,
|
count,
|
||||||
count > 1 ? "s" : "",
|
count > 1 ? "s" : "",
|
||||||
mug_msg_list_view_get_query
|
mug_msg_list_view_get_query
|
||||||
(MUG_MSG_LIST_VIEW(mugdata->mlist)));
|
(MUG_MSG_LIST_VIEW
|
||||||
|
(mugdata->mlist)));
|
||||||
gtk_statusbar_push(GTK_STATUSBAR(mugdata->statusbar), 0, msg);
|
gtk_statusbar_push(GTK_STATUSBAR(mugdata->statusbar), 0, msg);
|
||||||
g_free(msg);
|
g_free(msg);
|
||||||
|
|
||||||
mug_msg_list_view_move_first(MUG_MSG_LIST_VIEW(mugdata->mlist));
|
mug_msg_list_view_move_first(MUG_MSG_LIST_VIEW(mugdata->mlist));
|
||||||
gtk_widget_grab_focus(GTK_WIDGET(mugdata->mlist));
|
gtk_widget_grab_focus(GTK_WIDGET(mugdata->mlist));
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
if (count == 0) /* nothing found */
|
||||||
|
mug_query_bar_grab_focus(MUG_QUERY_BAR(bar));
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
on_msg_selected(MugMsgListView * mlist, const char *mpath, MugData * mugdata)
|
on_msg_selected(MugMsgListView * mlist, const char *mpath, MugData * mugdata)
|
||||||
@ -200,10 +192,8 @@ on_msg_selected (MugMsgListView *mlist, const char* mpath, MugData *mugdata)
|
|||||||
mug_msg_view_set_msg(MUG_MSG_VIEW(mugdata->msgview), mpath);
|
mug_msg_view_set_msg(MUG_MSG_VIEW(mugdata->msgview), mpath);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
on_list_view_error (MugMsgListView *mlist, MugError err,
|
on_list_view_error(MugMsgListView * mlist, MugError err, MugData * mugdata)
|
||||||
MugData *mugdata)
|
|
||||||
{
|
{
|
||||||
GtkWidget *errdialog;
|
GtkWidget *errdialog;
|
||||||
const char *msg;
|
const char *msg;
|
||||||
@ -211,15 +201,19 @@ on_list_view_error (MugMsgListView *mlist, MugError err,
|
|||||||
switch (err) {
|
switch (err) {
|
||||||
case MUG_ERROR_XAPIAN_NOT_UPTODATE:
|
case MUG_ERROR_XAPIAN_NOT_UPTODATE:
|
||||||
msg = "The Xapian Database has the wrong version\n"
|
msg = "The Xapian Database has the wrong version\n"
|
||||||
"Please run 'mu index --rebuild'"; break;
|
"Please run 'mu index --rebuild'";
|
||||||
|
break;
|
||||||
case MUG_ERROR_XAPIAN_DIR:
|
case MUG_ERROR_XAPIAN_DIR:
|
||||||
msg = "Cannot find the Xapian database dir\n"
|
msg = "Cannot find the Xapian database dir\n"
|
||||||
"Please restart mug with --muhome=... pointing\n"
|
"Please restart mug with --muhome=... pointing\n"
|
||||||
"to your mu home directory"; break;
|
"to your mu home directory";
|
||||||
|
break;
|
||||||
case MUG_ERROR_QUERY:
|
case MUG_ERROR_QUERY:
|
||||||
msg = "Error in query"; break;
|
msg = "Error in query";
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
msg = "Some error occured"; break;
|
msg = "Some error occured";
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
errdialog = gtk_message_dialog_new
|
errdialog = gtk_message_dialog_new
|
||||||
@ -230,15 +224,11 @@ on_list_view_error (MugMsgListView *mlist, MugError err,
|
|||||||
gtk_widget_destroy(errdialog);
|
gtk_widget_destroy(errdialog);
|
||||||
|
|
||||||
if (err == MUG_ERROR_QUERY) {
|
if (err == MUG_ERROR_QUERY) {
|
||||||
mug_query_bar_grab_focus
|
mug_query_bar_grab_focus(MUG_QUERY_BAR(mugdata->querybar));
|
||||||
(MUG_QUERY_BAR(mugdata->querybar));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GtkWidget *mug_querybar(void)
|
||||||
|
|
||||||
static GtkWidget*
|
|
||||||
mug_querybar (void)
|
|
||||||
{
|
{
|
||||||
GtkWidget *querybar;
|
GtkWidget *querybar;
|
||||||
|
|
||||||
@ -247,9 +237,7 @@ mug_querybar (void)
|
|||||||
return querybar;
|
return querybar;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GtkWidget *mug_query_area(MugData * mugdata)
|
||||||
static GtkWidget*
|
|
||||||
mug_query_area (MugData *mugdata)
|
|
||||||
{
|
{
|
||||||
GtkWidget *queryarea;
|
GtkWidget *queryarea;
|
||||||
GtkWidget *paned;
|
GtkWidget *paned;
|
||||||
@ -259,7 +247,6 @@ mug_query_area (MugData *mugdata)
|
|||||||
paned = gtk_vpaned_new();
|
paned = gtk_vpaned_new();
|
||||||
|
|
||||||
mugdata->mlist = mug_msg_list_view_new(mu_runtime_xapian_dir());
|
mugdata->mlist = mug_msg_list_view_new(mu_runtime_xapian_dir());
|
||||||
|
|
||||||
scrolled = gtk_scrolled_window_new(NULL, NULL);
|
scrolled = gtk_scrolled_window_new(NULL, NULL);
|
||||||
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled),
|
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled),
|
||||||
GTK_POLICY_AUTOMATIC,
|
GTK_POLICY_AUTOMATIC,
|
||||||
@ -269,6 +256,7 @@ mug_query_area (MugData *mugdata)
|
|||||||
gtk_paned_add1(GTK_PANED(paned), scrolled);
|
gtk_paned_add1(GTK_PANED(paned), scrolled);
|
||||||
|
|
||||||
mugdata->msgview = mug_msg_view_new();
|
mugdata->msgview = mug_msg_view_new();
|
||||||
|
|
||||||
mug_msg_view_set_msg(MUG_MSG_VIEW(mugdata->msgview), NULL);
|
mug_msg_view_set_msg(MUG_MSG_VIEW(mugdata->msgview), NULL);
|
||||||
g_signal_connect(G_OBJECT(mugdata->mlist), "msg-selected",
|
g_signal_connect(G_OBJECT(mugdata->mlist), "msg-selected",
|
||||||
G_CALLBACK(on_msg_selected), mugdata);
|
G_CALLBACK(on_msg_selected), mugdata);
|
||||||
@ -278,36 +266,33 @@ mug_query_area (MugData *mugdata)
|
|||||||
|
|
||||||
mugdata->querybar = mug_querybar();
|
mugdata->querybar = mug_querybar();
|
||||||
g_signal_connect(G_OBJECT(mugdata->querybar), "query-changed",
|
g_signal_connect(G_OBJECT(mugdata->querybar), "query-changed",
|
||||||
G_CALLBACK(on_query_changed),
|
G_CALLBACK(on_query_changed), mugdata);
|
||||||
mugdata);
|
|
||||||
|
|
||||||
gtk_box_pack_start(GTK_BOX(queryarea),
|
gtk_box_pack_start(GTK_BOX(queryarea),
|
||||||
mugdata->querybar, FALSE, FALSE, 2);
|
mugdata->querybar, FALSE, FALSE, 2);
|
||||||
gtk_box_pack_start (GTK_BOX(queryarea),
|
gtk_box_pack_start(GTK_BOX(queryarea), paned, TRUE, TRUE, 2);
|
||||||
paned, TRUE, TRUE, 2);
|
|
||||||
|
|
||||||
|
gtk_widget_show_all(queryarea);
|
||||||
return queryarea;
|
return queryarea;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GtkWidget *mug_main_area(MugData * mugdata)
|
||||||
static GtkWidget*
|
|
||||||
mug_main_area (MugData *mugdata)
|
|
||||||
{
|
{
|
||||||
GtkWidget *mainarea;
|
GtkWidget *mainarea, *w;
|
||||||
|
|
||||||
mainarea = gtk_hbox_new(FALSE, 5);
|
mainarea = gtk_hbox_new(FALSE, 5);
|
||||||
|
|
||||||
gtk_box_pack_start (GTK_BOX(mainarea), mug_shortcuts_bar(mugdata),
|
w = mug_shortcuts_bar(mugdata);
|
||||||
FALSE, FALSE, 0);
|
gtk_box_pack_start(GTK_BOX(mainarea), w, FALSE, FALSE, 0);
|
||||||
gtk_box_pack_start (GTK_BOX(mainarea), mug_query_area(mugdata),
|
gtk_widget_show(w);
|
||||||
TRUE, TRUE, 0);
|
|
||||||
|
w = mug_query_area(mugdata);
|
||||||
|
gtk_box_pack_start(GTK_BOX(mainarea), w, TRUE, TRUE, 0);
|
||||||
|
gtk_widget_show(w);
|
||||||
|
|
||||||
return mainarea;
|
return mainarea;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GtkWidget *mug_shell(MugData * mugdata)
|
||||||
GtkWidget*
|
|
||||||
mug_shell (MugData *mugdata)
|
|
||||||
{
|
{
|
||||||
GtkWidget *vbox;
|
GtkWidget *vbox;
|
||||||
gchar *icon;
|
gchar *icon;
|
||||||
@ -318,7 +303,8 @@ mug_shell (MugData *mugdata)
|
|||||||
vbox = gtk_vbox_new(FALSE, 2);
|
vbox = gtk_vbox_new(FALSE, 2);
|
||||||
mugdata->toolbar = mug_toolbar(mugdata);
|
mugdata->toolbar = mug_toolbar(mugdata);
|
||||||
gtk_box_pack_start(GTK_BOX(vbox), mugdata->toolbar, FALSE, FALSE, 2);
|
gtk_box_pack_start(GTK_BOX(vbox), mugdata->toolbar, FALSE, FALSE, 2);
|
||||||
gtk_box_pack_start (GTK_BOX(vbox), mug_main_area(mugdata), TRUE, TRUE, 2);
|
gtk_box_pack_start(GTK_BOX(vbox), mug_main_area(mugdata), TRUE,
|
||||||
|
TRUE, 2);
|
||||||
|
|
||||||
mugdata->statusbar = mug_statusbar();
|
mugdata->statusbar = mug_statusbar();
|
||||||
gtk_box_pack_start(GTK_BOX(vbox), mugdata->statusbar, FALSE, FALSE, 2);
|
gtk_box_pack_start(GTK_BOX(vbox), mugdata->statusbar, FALSE, FALSE, 2);
|
||||||
@ -336,8 +322,7 @@ mug_shell (MugData *mugdata)
|
|||||||
return mugdata->win;
|
return mugdata->win;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int main(int argc, char *argv[])
|
||||||
main (int argc, char *argv[])
|
|
||||||
{
|
{
|
||||||
MugData mugdata;
|
MugData mugdata;
|
||||||
GtkWidget *mugshell;
|
GtkWidget *mugshell;
|
||||||
|
|||||||
Reference in New Issue
Block a user