]> git.saurik.com Git - wxWidgets.git/blame - include/wx/gtk/private.h
added static Apply(GtkWidget, tip) method
[wxWidgets.git] / include / wx / gtk / private.h
CommitLineData
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 25#if wxUSE_UNICODE
1a6c768b
VZ
26 #define wxGTK_CONV(s) wxConvUTF8.cWX2MB((s))
27 #define wxGTK_CONV_ENC(s, enc) wxGTK_CONV((s))
28 #define wxGTK_CONV_FONT(s, font) wxGTK_CONV((s))
29 #define wxGTK_CONV_SYS(s) wxGTK_CONV((s))
30 #define wxGTK_CONV_BACK(s) wxConvUTF8.cMB2WX((s))
dd398cd0 31#else
5851053a
VZ
32 #include "wx/font.h"
33
5f11fef5
VZ
34 // convert the text in given encoding to UTF-8 used by wxGTK
35 extern wxCharBuffer
36 wxConvertToGTK(const wxString& s,
37 wxFontEncoding enc = wxFONTENCODING_SYSTEM);
38
39 // helper: use the encoding of the given font if it's valid
40 inline wxCharBuffer wxConvertToGTK(const wxString& s, const wxFont& font)
41 {
42 return wxConvertToGTK(s, font.Ok() ? font.GetEncoding()
43 : wxFONTENCODING_SYSTEM);
44 }
45
1a6c768b
VZ
46 #define wxGTK_CONV_ENC(s, enc) wxConvertToGTK((s), (enc))
47 #define wxGTK_CONV_FONT(s, font) wxConvertToGTK((s), (font))
48 #define wxGTK_CONV(s) wxGTK_CONV_FONT((s), m_font)
49 #define wxGTK_CONV_SYS(s) wxConvertToGTK((s))
50 #define wxGTK_CONV_BACK(s) wxConvLocal.cWC2WX(wxConvUTF8.cMB2WC((s)))
dd398cd0 51#endif
dd398cd0 52
1efb5db8
MR
53// Some deprecated GTK+ prototypes we still use often
54// FIXME: Don't use them if possible.
55G_BEGIN_DECLS
56
57// Should use gtk_image_new, but the mask seems to be handled different,
58// and we need to migrate
59GtkWidget* gtk_pixmap_new (GdkPixmap *pixmap,
60 GdkBitmap *mask);
61
62// Deprecated since GTK+-1.3.7:
63// Trivial wrapper around gtk_window_move, with some side effects we seem to rely on
64void gtk_widget_set_uposition (GtkWidget *widget,
65 gint x,
66 gint y);
67
68// We rely on the allow_shrink parameter in one place
69void gtk_window_set_policy (GtkWindow *window,
70 gint allow_shrink,
71 gint allow_grow,
72 gint auto_shrink);
73
74G_END_DECLS
75
84833214
VZ
76//-----------------------------------------------------------------------------
77// idle system
78//-----------------------------------------------------------------------------
79
80extern void wxapp_install_idle_handler();
81extern bool g_isIdle;
82
35a489dd
MR
83//-----------------------------------------------------------------------------
84// Convenience class for g_freeing a gchar* on scope exit automatically
85//-----------------------------------------------------------------------------
86
87class wxGtkString
88{
89public:
90 explicit wxGtkString(gchar *s) : m_str(s) { }
91 ~wxGtkString() { g_free(m_str); }
92
46cb4b3f
VZ
93 const gchar *c_str() const { return m_str; }
94
35a489dd
MR
95 operator gchar *() const { return m_str; }
96
97private:
98 gchar *m_str;
99
100 DECLARE_NO_COPY_CLASS(wxGtkString)
101};
102
84833214
VZ
103//-----------------------------------------------------------------------------
104// GTK+ scroll types -> wxEventType
105//-----------------------------------------------------------------------------
106
9e691f46
VZ
107// translate a GTK+ scroll type to a wxEventType
108inline wxEventType GtkScrollTypeToWx(guint scrollType)
109{
110 wxEventType command;
111 switch ( scrollType )
112 {
113 case GTK_SCROLL_STEP_BACKWARD:
114 command = wxEVT_SCROLL_LINEUP;
115 break;
116
117 case GTK_SCROLL_STEP_FORWARD:
118 command = wxEVT_SCROLL_LINEDOWN;
119 break;
120
121 case GTK_SCROLL_PAGE_BACKWARD:
122 command = wxEVT_SCROLL_PAGEUP;
123 break;
124
125 case GTK_SCROLL_PAGE_FORWARD:
126 command = wxEVT_SCROLL_PAGEDOWN;
127 break;
128
129 default:
130 command = wxEVT_SCROLL_THUMBTRACK;
131 }
132
133 return command;
134}
135
136inline wxEventType GtkScrollWinTypeToWx(guint scrollType)
137{
138 // GtkScrollTypeToWx() returns SCROLL_XXX, not SCROLLWIN_XXX as we need
139 return GtkScrollTypeToWx(scrollType) +
140 wxEVT_SCROLLWIN_TOP - wxEVT_SCROLL_TOP;
141}
142
84833214
VZ
143
144//-----------------------------------------------------------------------------
145// Misc. functions
146//-----------------------------------------------------------------------------
147
224016a8
JS
148// Needed for implementing e.g. combobox on wxGTK within a modal dialog.
149void wxAddGrab(wxWindow* window);
150void wxRemoveGrab(wxWindow* window);
151
66bd83b4 152// Escapes string so that it is valid Pango markup XML string:
20123d49 153WXDLLIMPEXP_CORE wxString wxEscapeStringForPangoMarkup(const wxString& str);
66bd83b4 154
abc736fd
MW
155// The declaration for gtk_icon_size_lookup was accidentally ifdefed out in
156// GTK+ 2.1.0 which Sun seem to have shipped with some versions of JDS
157// for Solaris 9 x86.
18720210 158#ifdef NEED_GTK_ICON_SIZE_LOOKUP
abc736fd
MW
159extern "C" gboolean gtk_icon_size_lookup (GtkIconSize size,
160 gint *width,
161 gint *height);
162#endif
163
9e691f46
VZ
164#endif // _WX_GTK_PRIVATE_H_
165