Fix bug #3526 ‘autoconfiguration: get more detailed error message’
[claws.git] / src / gtk / gtkutils.h
index f63ca06c4bc98762639246d38630bf27c18544ea..7510387b158e706c55f1245cb9c58e75915f6ee5 100644 (file)
@@ -1,6 +1,6 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2007 Hiroyuki Yamamoto and the Claws Mail team
+ * Copyright (C) 1999-2013 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
@@ -21,7 +21,7 @@
 #define __GTKUTILS_H__
 
 #ifdef HAVE_CONFIG_H
-#  include "config.h"
+#include "claws-features.h"
 #endif
 
 #include <glib.h>
 #  include <wchar.h>
 #endif
 
-#ifdef MAEMO
-#ifdef CHINOOK
-#include <hildon/hildon-program.h>
-#else
-#include <hildon-widgets/hildon-program.h>
-#include <hildon-widgets/hildon-window.h>
-#endif
-#include "main.h"
-#include <gtk/gtkmain.h>
-#endif
-
-typedef struct _ComboButton    ComboButton;
+#include "gtkcmctree.h"
 
-struct _ComboButton
-{
-       GtkWidget *arrow;
-       GtkWidget *button;
-       GtkWidget *menu;
-       GtkItemFactory *factory;
-       gpointer data;
-};
+#ifndef GDK_KEY_Escape
+#include "gdkkeysyms-new.h"
+#endif
 
 #define GTK_EVENTS_FLUSH() \
 { \
@@ -60,38 +44,18 @@ struct _ComboButton
                gtk_main_iteration(); \
 }
 
-#define PIXMAP_CREATE(widget, pixmap, mask, xpm_d) \
-{ \
-       if (!pixmap) { \
-               GtkStyle *style = gtk_widget_get_style(widget); \
-               pixmap = gdk_pixmap_create_from_xpm_d \
-                       (widget->window, &mask, \
-                        &style->bg[GTK_STATE_NORMAL], xpm_d); \
-       } \
-}
-
-#define PIXMAP_CREATE_FROM_FILE(widget, pixmap, mask, filename) \
-{ \
-       if (!pixmap) { \
-               GtkStyle *style = gtk_widget_get_style(widget); \
-               pixmap = gdk_pixmap_create_from_xpm \
-                       (widget->window, &mask, \
-                        &style->bg[GTK_STATE_NORMAL], filename); \
-       } \
-}
-
 #define GTK_WIDGET_PTR(wid)    (*(GtkWidget **)wid)
 
 #define GTKUT_CTREE_NODE_SET_ROW_DATA(node, d) \
 { \
-       GTK_CTREE_ROW(node)->row.data = d; \
+       GTK_CMCTREE_ROW(node)->row.data = d; \
 }
 
 #define GTKUT_CTREE_NODE_GET_ROW_DATA(node) \
-       (GTK_CTREE_ROW(node)->row.data)
+       (GTK_CMCTREE_ROW(node)->row.data)
 
 #define GTKUT_CTREE_REFRESH(clist) \
-       GTK_CLIST_GET_CLASS(clist)->refresh(clist)
+       GTK_CMCLIST_GET_CLASS(clist)->refresh(clist)
 
 gboolean gtkut_get_font_size           (GtkWidget      *widget,
                                         gint           *width,
@@ -99,6 +63,7 @@ gboolean gtkut_get_font_size          (GtkWidget      *widget,
 
 void gtkut_convert_int_to_gdk_color    (gint            rgbvalue,
                                         GdkColor       *color);
+gint gtkut_convert_gdk_color_to_int    (GdkColor       *color);
 
 void gtkut_stock_button_add_help(GtkWidget *bbox, GtkWidget **help_btn);
 
@@ -122,28 +87,28 @@ void gtkut_stock_with_text_button_set_create(GtkWidget **bbox,
                                   GtkWidget **button3, const gchar *label3, const gchar *text3);
 
 void gtkut_ctree_node_move_if_on_the_edge
-                                       (GtkCTree       *ctree,
-                                        GtkCTreeNode   *node,
+                                       (GtkCMCTree     *ctree,
+                                        GtkCMCTreeNode *node,
                                         gint            _row);
-gint gtkut_ctree_get_nth_from_node     (GtkCTree       *ctree,
-                                        GtkCTreeNode   *node);
-GtkCTreeNode *gtkut_ctree_node_next    (GtkCTree       *ctree,
-                                        GtkCTreeNode   *node);
-GtkCTreeNode *gtkut_ctree_node_prev    (GtkCTree       *ctree,
-                                        GtkCTreeNode   *node);
-gboolean gtkut_ctree_node_is_selected  (GtkCTree       *ctree,
-                                        GtkCTreeNode   *node);
-GtkCTreeNode *gtkut_ctree_find_collapsed_parent
-                                       (GtkCTree       *ctree,
-                                        GtkCTreeNode   *node);
-void gtkut_ctree_expand_parent_all     (GtkCTree       *ctree,
-                                        GtkCTreeNode   *node);
-gboolean gtkut_ctree_node_is_parent    (GtkCTreeNode   *parent, 
-                                        GtkCTreeNode   *node);
-void gtkut_ctree_set_focus_row         (GtkCTree       *ctree,
-                                        GtkCTreeNode   *node);
-
-void gtkut_clist_set_focus_row         (GtkCList       *clist,
+gint gtkut_ctree_get_nth_from_node     (GtkCMCTree     *ctree,
+                                        GtkCMCTreeNode *node);
+GtkCMCTreeNode *gtkut_ctree_node_next  (GtkCMCTree     *ctree,
+                                        GtkCMCTreeNode *node);
+GtkCMCTreeNode *gtkut_ctree_node_prev  (GtkCMCTree     *ctree,
+                                        GtkCMCTreeNode *node);
+gboolean gtkut_ctree_node_is_selected  (GtkCMCTree     *ctree,
+                                        GtkCMCTreeNode *node);
+GtkCMCTreeNode *gtkut_ctree_find_collapsed_parent
+                                       (GtkCMCTree     *ctree,
+                                        GtkCMCTreeNode *node);
+void gtkut_ctree_expand_parent_all     (GtkCMCTree     *ctree,
+                                        GtkCMCTreeNode *node);
+gboolean gtkut_ctree_node_is_parent    (GtkCMCTreeNode         *parent, 
+                                        GtkCMCTreeNode         *node);
+void gtkut_ctree_set_focus_row         (GtkCMCTree     *ctree,
+                                        GtkCMCTreeNode *node);
+
+void gtkut_clist_set_focus_row         (GtkCMCList     *clist,
                                         gint            row);
 
 void gtkut_container_remove            (GtkContainer   *container,
@@ -173,6 +138,14 @@ void gtkut_widget_init                     (void);
 void gtkut_widget_set_app_icon         (GtkWidget      *widget);
 void gtkut_widget_set_composer_icon    (GtkWidget      *widget);
 
+void gtkut_widget_set_mapped            (GtkWidget *widget, gboolean mapped);
+void gtkut_widget_set_realized          (GtkWidget *widget, gboolean realized);
+void gtkut_widget_set_can_default       (GtkWidget *widget, gboolean can_default);
+void gtkut_widget_set_receives_default  (GtkWidget *widget, gboolean receives_default);
+void gtkut_widget_set_can_focus         (GtkWidget *widget, gboolean can_focus);
+void gtkut_widget_set_has_window        (GtkWidget *widget, gboolean has_window);
+
+
 GtkWidget *gtkut_account_menu_new      (GList                  *ac_list,
                                         GCallback               callback,
                                         gpointer                data);
@@ -188,8 +161,7 @@ GtkWidget *gtkut_get_browse_directory_btn(const gchar *label);
 GtkWidget *gtkut_get_replace_btn(const gchar *label);
 GtkWidget *gtkut_get_options_frame(GtkWidget *box, GtkWidget **frame, const gchar *frame_label);
 #if HAVE_LIBCOMPFACE
-GtkWidget *xface_get_from_header(const gchar *o_xface, GdkColor *background,
-                                GdkWindow *window);
+GtkWidget *xface_get_from_header(const gchar *o_xface);
 #endif
 gboolean get_tag_range(GtkTextIter *iter,
                                       GtkTextTag *tag,
@@ -216,8 +188,20 @@ gboolean gtkut_tree_model_get_iter_last(GtkTreeModel *model,
 gint gtkut_list_view_get_selected_row(GtkWidget *list_view);
 gboolean gtkut_list_view_select_row(GtkWidget *list, gint row);
 
-#if GTK_CHECK_VERSION(2,12,0)
-#define CLAWS_TIP_DECL() {}
+GtkUIManager *gtkut_create_ui_manager(void);
+GtkUIManager *gtkut_ui_manager(void);
+
+GdkPixbuf *claws_load_pixbuf_fitting(GdkPixbuf *pixbuf, int box_width,
+                                    int box_height);
+
+typedef void (*ClawsIOFunc)(gpointer data, gint source, GIOCondition condition);
+gint
+claws_input_add    (gint             source,
+                   GIOCondition      condition,
+                   ClawsIOFunc       function,
+                   gpointer          data,
+                   gboolean          is_sock);
+
 #define CLAWS_SET_TIP(widget,tip) {                                    \
        if (tip != NULL)                                                \
                gtk_widget_set_tooltip_text(GTK_WIDGET(widget), tip);   \
@@ -225,14 +209,85 @@ gboolean gtkut_list_view_select_row(GtkWidget *list, gint row);
                gtk_widget_set_has_tooltip(GTK_WIDGET(widget), FALSE);  \
 }
 
-#else
-#define CLAWS_TIP_DECL() \
-       GtkTooltips *tips = gtk_tooltips_new();
+#if (defined USE_GNUTLS && GLIB_CHECK_VERSION(2,22,0))
+typedef struct _AutoConfigureData {
+       const gchar *ssl_service;
+       const gchar *tls_service;
+       gchar *address;
+       gint resolver_error;
+
+       GtkEntry *hostname_entry;
+       GtkToggleButton *set_port;
+       GtkSpinButton *port;
+       gint default_port;
+       gint default_ssl_port;
+       GtkToggleButton *tls_checkbtn;
+       GtkToggleButton *ssl_checkbtn;
+       GtkToggleButton *auth_checkbtn;
+       GtkEntry *uid_entry;
+       GtkLabel *info_label;
+       GtkButton *configure_button;
+       GtkButton *cancel_button;
+       GCancellable *cancel;
+       GMainLoop *main_loop;
+} AutoConfigureData;
+
+void auto_configure_service(AutoConfigureData *data);
+gboolean auto_configure_service_sync(const gchar *service, const gchar *domain, gchar **srvhost, guint16 *srvport);
+#endif
+
 
-#define CLAWS_SET_TIP(widget,tip) {                            \
-       gtk_tooltips_set_tip(GTK_TOOLTIPS(tips), widget,        \
-                           tip, NULL);                         \
+#if GTK_CHECK_VERSION (3, 2, 0)
+#define GTK_TYPE_VBOX GTK_TYPE_BOX
+#define GtkVBox GtkBox
+#define GtkVBoxClass GtkBoxClass
+#define gtk_vbox_new(hmg,spc) g_object_new (GTK_TYPE_BOX, \
+    "homogeneous", hmg, "spacing", spc, \
+    "orientation", GTK_ORIENTATION_VERTICAL, NULL)
+#define GTK_TYPE_HBOX GTK_TYPE_BOX
+#define GtkHBox GtkBox
+#define GtkHBoxClass GtkBoxClass
+#define gtk_hbox_new(hmg,spc) g_object_new (GTK_TYPE_BOX, \
+    "homogeneous", hmg, "spacing", spc, \
+    "orientation", GTK_ORIENTATION_HORIZONTAL, NULL)
+#define gtk_hseparator_new() g_object_new (GTK_TYPE_SEPARATOR, NULL)
+#define gtk_hpaned_new() g_object_new (GTK_TYPE_PANED, NULL)
+#define gtk_vpaned_new() g_object_new (GTK_TYPE_PANED, \
+    "orientation", GTK_ORIENTATION_VERTICAL, NULL)
+#endif
+#if !GTK_CHECK_VERSION(2,22,0)
+#define gdk_drag_context_get_selected_action(x) ((x)->action)
+#define gdk_drag_context_get_actions(x) ((x)->actions)
+#define gtk_text_view_get_vadjustment(x) ((x)->vadjustment)
+#define gdk_drag_context_get_suggested_action(x) ((x)->suggested_action)
+#define gtk_button_get_event_window(x) ((x)->event_window)
+#endif
+#if !GTK_CHECK_VERSION(2,20,0)
+#define gtk_widget_get_requisition(x,r) (*(r) = (x)->requisition)
+#define gtk_statusbar_get_message_area(x) ((x)->label)
+#define gtk_widget_get_realized(x) (GTK_WIDGET_REALIZED(x))
+#define gtk_widget_get_mapped(x) (GTK_WIDGET_MAPPED(x))
+#endif
+#if !GTK_CHECK_VERSION(2,18,0)
+#define gtk_widget_get_allocation(x,a) (*(a) = (x)->allocation)
+#define gtk_widget_set_allocation(x,a) ((x)->allocation = *(a))
+#define gtk_widget_has_focus(x) (GTK_WIDGET_HAS_FOCUS(x))
+#define gtk_widget_get_can_focus(x) (GTK_WIDGET_CAN_FOCUS(x))
+#define gtk_widget_has_grab(x) (GTK_WIDGET_HAS_GRAB(x))
+#define gtk_widget_get_visible(x) (GTK_WIDGET_VISIBLE(x))
+#define gtk_widget_get_realized(x) (GTK_WIDGET_REALIZED(x))
+#define gtk_widget_is_sensitive(x) (GTK_WIDGET_IS_SENSITIVE(x))
+#define gtk_widget_get_sensitive(x) (GTK_WIDGET_SENSITIVE(x))
+#define gtk_widget_is_drawable(x) (GTK_WIDGET_DRAWABLE(x))
+#define gtk_widget_get_state(x) (GTK_WIDGET_STATE(x))
+#define gtk_widget_get_mapped(x) (GTK_WIDGET_MAPPED(x))
+#define gtk_widget_get_has_window(x) (!(GTK_WIDGET_NO_WINDOW(x)))
+#define gtk_widget_get_app_paintable(x) (GTK_WIDGET_APP_PAINTABLE(x))
+#define gtk_widget_set_window(x,w) {                   \
+       if ((x)->window != w) {                         \
+               (x)->window = w;                        \
+               g_object_notify (G_OBJECT(x), "window");\
+       }                                               \
 }
-
 #endif
 #endif /* __GTKUTILS_H__ */