/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2006 Hiroyuki Yamamoto and the Sylpheed-Claws team
+ * Copyright (C) 1999-2007 Hiroyuki Yamamoto and the Claws Mail team
*
* 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
}
}
+void gtkut_stock_with_text_button_set_create(GtkWidget **bbox,
+ GtkWidget **button1, const gchar *label1, const gchar *text1,
+ GtkWidget **button2, const gchar *label2, const gchar *text2,
+ GtkWidget **button3, const gchar *label3, const gchar *text3)
+{
+ g_return_if_fail(bbox != NULL);
+ g_return_if_fail(button1 != NULL);
+
+ *bbox = gtk_hbutton_box_new();
+ gtk_button_box_set_layout(GTK_BUTTON_BOX(*bbox), GTK_BUTTONBOX_END);
+ gtk_box_set_spacing(GTK_BOX(*bbox), 5);
+
+ *button1 = gtk_button_new_with_mnemonic(text1);
+ gtk_button_set_image(GTK_BUTTON(*button1),
+ gtk_image_new_from_stock(label1, GTK_ICON_SIZE_BUTTON));
+ GTK_WIDGET_SET_FLAGS(*button1, GTK_CAN_DEFAULT);
+ gtk_box_pack_start(GTK_BOX(*bbox), *button1, TRUE, TRUE, 0);
+ gtk_widget_show(*button1);
+
+ if (button2) {
+ *button2 = gtk_button_new_with_mnemonic(text2);
+ gtk_button_set_image(GTK_BUTTON(*button2),
+ gtk_image_new_from_stock(label2, GTK_ICON_SIZE_BUTTON));
+ gtk_box_pack_start(GTK_BOX(*bbox), *button2, TRUE, TRUE, 0);
+ gtk_widget_show(*button2);
+ }
+
+ if (button3) {
+ *button3 = gtk_button_new_with_mnemonic(text3);
+ gtk_button_set_image(GTK_BUTTON(*button3),
+ gtk_image_new_from_stock(label3, GTK_ICON_SIZE_BUTTON));
+ gtk_box_pack_start(GTK_BOX(*bbox), *button3, TRUE, TRUE, 0);
+ gtk_widget_show(*button3);
+ }
+}
+
static void combo_button_size_request(GtkWidget *widget,
GtkRequisition *requisition,
gpointer data)
GtkWidget *clist;
clist = gtk_clist_new(1);
- g_object_ref(G_OBJECT(clist));
+ gtk_object_ref(GTK_OBJECT(clist));
gtk_object_sink(GTK_OBJECT(clist));
gtkut_clist_bindings_add(clist);
- g_object_unref(G_OBJECT(clist));
+ gtk_object_unref(GTK_OBJECT(clist));
clist = gtk_ctree_new(1, 0);
- g_object_ref(G_OBJECT(clist));
+ gtk_object_ref(GTK_OBJECT(clist));
gtk_object_sink(GTK_OBJECT(clist));
gtkut_clist_bindings_add(clist);
- g_object_unref(G_OBJECT(clist));
+ gtk_object_unref(GTK_OBJECT(clist));
clist = gtk_sctree_new_with_titles(1, 0, NULL);
- g_object_ref(G_OBJECT(clist));
+ gtk_object_ref(GTK_OBJECT(clist));
gtk_object_sink(GTK_OBJECT(clist));
gtkut_clist_bindings_add(clist);
- g_object_unref(G_OBJECT(clist));
+ gtk_object_unref(GTK_OBJECT(clist));
}
void gtkut_widget_set_app_icon(GtkWidget *widget)
{
-#include "pixmaps/sylpheed-claws.xpm"
+#include "pixmaps/claws-mail.xpm"
static GdkPixmap *sylpheedclawsxpm;
static GdkBitmap *sylpheedclawsxpmmask;
g_return_if_fail(widget->window != NULL);
if (!sylpheedclawsxpm) {
PIXMAP_CREATE(widget, sylpheedclawsxpm, sylpheedclawsxpmmask,
- sylpheed_claws_xpm);
+ claws_mail_xpm);
}
gdk_window_set_icon(widget->window, NULL, sylpheedclawsxpm, sylpheedclawsxpmmask);
}
return button;
}
+GtkWidget *gtkut_get_options_frame(GtkWidget *box, GtkWidget **frame,
+ const gchar *frame_label)
+{
+ GtkWidget *vbox;
+
+ *frame = gtk_frame_new(frame_label);
+ gtk_widget_show(*frame);
+ gtk_box_pack_start(GTK_BOX(box), *frame, FALSE, TRUE, 0);
+ gtk_frame_set_label_align(GTK_FRAME(*frame), 0.01, 0.5);
+
+ vbox = gtk_vbox_new (FALSE, 4);
+ gtk_widget_show(vbox);
+ gtk_container_add(GTK_CONTAINER (*frame), vbox);
+ gtk_container_set_border_width (GTK_CONTAINER (vbox), 8);
+
+ return vbox;
+}
+
#if HAVE_LIBCOMPFACE
gint create_xpm_from_xface(gchar *xpm[], const gchar *xface)
{
gchar xface[2048];
strncpy(xface, o_xface, sizeof(xface));
+ if (!window) {
+ g_warning("no window\n");
+ return NULL;
+ }
if (uncompface(xface) < 0) {
g_warning("uncompface failed\n");
return NULL;
}
}
}
+
+gboolean gtkut_tree_model_text_iter_prev(GtkTreeModel *model,
+ GtkTreeIter *iter,
+ const gchar* text)
+/* do the same as gtk_tree_model_iter_next, but _prev instead.
+ to use with widgets with one text column (gtk_combo_box_new_text()
+ and with GtkComboBoxEntry's for instance),
+*/
+{
+ GtkTreeIter cur_iter;
+ gchar *cur_value;
+ gboolean valid;
+ gint count;
+
+ g_return_val_if_fail(model != NULL, FALSE);
+ g_return_val_if_fail(iter != NULL, FALSE);
+
+ if (text == NULL || *text == '\0')
+ return FALSE;
+
+ valid = gtk_tree_model_get_iter_first(model, &cur_iter);
+ count = 0;
+ while (valid) {
+ gtk_tree_model_get(model, &cur_iter, 0, &cur_value, -1);
+
+ if (strcmp(text, cur_value) == 0) {
+ if (count <= 0)
+ return FALSE;
+
+ return gtk_tree_model_iter_nth_child(model, iter, NULL, count - 1);
+ }
+
+ valid = gtk_tree_model_iter_next(model, &cur_iter);
+ count++;
+ }
+ return FALSE;
+}
+
+gboolean gtkut_tree_model_get_iter_last(GtkTreeModel *model,
+ GtkTreeIter *iter)
+/* do the same as gtk_tree_model_get_iter_first, but _last instead.
+*/
+{
+ gint count;
+
+ g_return_val_if_fail(model != NULL, FALSE);
+ g_return_val_if_fail(iter != NULL, FALSE);
+
+ count = gtk_tree_model_iter_n_children(model, NULL);
+
+ if (count <= 0)
+ return FALSE;
+
+ return gtk_tree_model_iter_nth_child(model, iter, NULL, count - 1);
+}