/*
* 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
#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
-
#include "gtkcmctree.h"
+#ifndef GDK_KEY_Escape
+#include "gdkkeysyms-new.h"
+#endif
+
#define GTK_EVENTS_FLUSH() \
{ \
while (gtk_events_pending()) \
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) \
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);
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);
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,
GtkUIManager *gtkut_create_ui_manager(void);
GtkUIManager *gtkut_ui_manager(void);
-#if GTK_CHECK_VERSION(2,12,0)
-#define CLAWS_TIP_DECL() {}
+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); \
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 *domain;
+
+ GtkEntry *hostname_entry;
+ GtkToggleButton *set_port;
+ GtkSpinButton *port;
+ gint default_port;
+ gint default_ssl_port;
+ GtkToggleButton *tls_checkbtn;
+ GtkToggleButton *ssl_checkbtn;
+ GtkToggleButton *auth_checkbtn;
+ GtkLabel *info_label;
+ GtkButton *configure_button;
+ GtkButton *cancel_button;
+ GCancellable *cancel;
+ GMainLoop *main_loop;
+} AutoConfigureData;
+
+void auto_configure_service(AutoConfigureData *data);
+#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__ */