]>
Commit | Line | Data |
---|---|---|
9e691f46 VZ |
1 | /////////////////////////////////////////////////////////////////////////////// |
2 | // Name: wx/gtk/private.h | |
3 | // Purpose: wxGTK private macros, functions &c | |
4 | // Author: Vadim Zeitlin | |
5 | // Modified by: | |
6 | // Created: 12.03.02 | |
7 | // RCS-ID: $Id$ | |
77ffb593 | 8 | // Copyright: (c) 2002 Vadim Zeitlin <vadim@wxwidgets.org> |
65571936 | 9 | // Licence: wxWindows licence |
9e691f46 VZ |
10 | /////////////////////////////////////////////////////////////////////////////// |
11 | ||
12 | #ifndef _WX_GTK_PRIVATE_H_ | |
13 | #define _WX_GTK_PRIVATE_H_ | |
14 | ||
9e691f46 VZ |
15 | #include <gtk/gtk.h> |
16 | ||
17 | #include "wx/event.h" | |
18 | ||
19 | // fail all version tests if the GTK+ version is so ancient that it doesn't | |
20 | // even have GTK_CHECK_VERSION | |
21 | #ifndef GTK_CHECK_VERSION | |
22 | #define GTK_CHECK_VERSION(a, b, c) 0 | |
23 | #endif | |
24 | ||
dd398cd0 RR |
25 | #if wxUSE_UNICODE |
26 | #define wxGTK_CONV(s) wxConvUTF8.cWX2MB(s) | |
27 | #define wxGTK_CONV_BACK(s) wxConvUTF8.cMB2WX(s) | |
28 | #else | |
29 | #define wxGTK_CONV(s) wxConvUTF8.cWC2MB( wxConvLocal.cWX2WC(s) ) | |
30 | #define wxGTK_CONV_BACK(s) wxConvLocal.cWC2WX( (wxConvUTF8.cMB2WC( s ) ) ) | |
31 | #endif | |
dd398cd0 | 32 | |
1efb5db8 MR |
33 | // Some deprecated GTK+ prototypes we still use often |
34 | // FIXME: Don't use them if possible. | |
35 | G_BEGIN_DECLS | |
36 | ||
37 | // Should use gtk_image_new, but the mask seems to be handled different, | |
38 | // and we need to migrate | |
39 | GtkWidget* gtk_pixmap_new (GdkPixmap *pixmap, | |
40 | GdkBitmap *mask); | |
41 | ||
42 | // Deprecated since GTK+-1.3.7: | |
43 | // Trivial wrapper around gtk_window_move, with some side effects we seem to rely on | |
44 | void gtk_widget_set_uposition (GtkWidget *widget, | |
45 | gint x, | |
46 | gint y); | |
47 | ||
48 | // We rely on the allow_shrink parameter in one place | |
49 | void gtk_window_set_policy (GtkWindow *window, | |
50 | gint allow_shrink, | |
51 | gint allow_grow, | |
52 | gint auto_shrink); | |
53 | ||
54 | G_END_DECLS | |
55 | ||
84833214 VZ |
56 | //----------------------------------------------------------------------------- |
57 | // idle system | |
58 | //----------------------------------------------------------------------------- | |
59 | ||
60 | extern void wxapp_install_idle_handler(); | |
61 | extern bool g_isIdle; | |
62 | ||
63 | //----------------------------------------------------------------------------- | |
64 | // GTK+ scroll types -> wxEventType | |
65 | //----------------------------------------------------------------------------- | |
66 | ||
9e691f46 VZ |
67 | // translate a GTK+ scroll type to a wxEventType |
68 | inline wxEventType GtkScrollTypeToWx(guint scrollType) | |
69 | { | |
70 | wxEventType command; | |
71 | switch ( scrollType ) | |
72 | { | |
73 | case GTK_SCROLL_STEP_BACKWARD: | |
74 | command = wxEVT_SCROLL_LINEUP; | |
75 | break; | |
76 | ||
77 | case GTK_SCROLL_STEP_FORWARD: | |
78 | command = wxEVT_SCROLL_LINEDOWN; | |
79 | break; | |
80 | ||
81 | case GTK_SCROLL_PAGE_BACKWARD: | |
82 | command = wxEVT_SCROLL_PAGEUP; | |
83 | break; | |
84 | ||
85 | case GTK_SCROLL_PAGE_FORWARD: | |
86 | command = wxEVT_SCROLL_PAGEDOWN; | |
87 | break; | |
88 | ||
89 | default: | |
90 | command = wxEVT_SCROLL_THUMBTRACK; | |
91 | } | |
92 | ||
93 | return command; | |
94 | } | |
95 | ||
96 | inline wxEventType GtkScrollWinTypeToWx(guint scrollType) | |
97 | { | |
98 | // GtkScrollTypeToWx() returns SCROLL_XXX, not SCROLLWIN_XXX as we need | |
99 | return GtkScrollTypeToWx(scrollType) + | |
100 | wxEVT_SCROLLWIN_TOP - wxEVT_SCROLL_TOP; | |
101 | } | |
102 | ||
84833214 VZ |
103 | |
104 | //----------------------------------------------------------------------------- | |
105 | // Misc. functions | |
106 | //----------------------------------------------------------------------------- | |
107 | ||
224016a8 JS |
108 | // Needed for implementing e.g. combobox on wxGTK within a modal dialog. |
109 | void wxAddGrab(wxWindow* window); | |
110 | void wxRemoveGrab(wxWindow* window); | |
111 | ||
66bd83b4 | 112 | // Escapes string so that it is valid Pango markup XML string: |
20123d49 | 113 | WXDLLIMPEXP_CORE wxString wxEscapeStringForPangoMarkup(const wxString& str); |
66bd83b4 | 114 | |
abc736fd MW |
115 | // The declaration for gtk_icon_size_lookup was accidentally ifdefed out in |
116 | // GTK+ 2.1.0 which Sun seem to have shipped with some versions of JDS | |
117 | // for Solaris 9 x86. | |
18720210 | 118 | #ifdef NEED_GTK_ICON_SIZE_LOOKUP |
abc736fd MW |
119 | extern "C" gboolean gtk_icon_size_lookup (GtkIconSize size, |
120 | gint *width, | |
121 | gint *height); | |
122 | #endif | |
123 | ||
9e691f46 VZ |
124 | #endif // _WX_GTK_PRIVATE_H_ |
125 |