X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/3b3dc8019a520ce5e166c8ae9098ba020f8b3f94..8fd7108e7cfd6d3564a71ab5f49c391613e27798:/src/gtk/taskbar.cpp diff --git a/src/gtk/taskbar.cpp b/src/gtk/taskbar.cpp index 70f600372d..4bb7f2dcf2 100644 --- a/src/gtk/taskbar.cpp +++ b/src/gtk/taskbar.cpp @@ -12,6 +12,11 @@ // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" +#if wxUSE_TASKBARICON + +#include +#if GTK_CHECK_VERSION(2, 1, 0) + #include "wx/gtk/taskbarpriv.h" #ifndef WX_PRECOMP @@ -20,14 +25,9 @@ #include "wx/menu.h" #endif +#include #include -#ifdef __WXGTK20__ -#include -#if GTK_CHECK_VERSION(2, 1, 0) - -#include "gtk/gtk.h" - #include "eggtrayicon.h" wxTaskBarIconAreaBase::wxTaskBarIconAreaBase() @@ -58,9 +58,10 @@ bool wxTaskBarIconAreaBase::IsProtocolSupported() Display *display = GDK_DISPLAY(); Screen *screen = DefaultScreenOfDisplay(display); - wxString name; - name.Printf(_T("_NET_SYSTEM_TRAY_S%d"), XScreenNumberOfScreen(screen)); - Atom atom = XInternAtom(display, name.ToAscii(), False); + char name[32]; + g_snprintf(name, sizeof(name), "_NET_SYSTEM_TRAY_S%d", + XScreenNumberOfScreen(screen)); + Atom atom = XInternAtom(display, name, False); Window manager = XGetSelectionOwner(display, atom); @@ -70,6 +71,13 @@ bool wxTaskBarIconAreaBase::IsProtocolSupported() return (bool)s_supported; } +bool wxTaskBarIconAreaBase::IsDecorCacheable() const +{ + // Apparently, WM frame extents extend to full width of screen when window + // is in the tray. Don't cache, it's not useful for other windows. + return false; +} + //----------------------------------------------------------------------------- // Pop-up menu stuff //----------------------------------------------------------------------------- @@ -140,7 +148,7 @@ bool wxTaskBarIconAreaBase::DoPopupMenu( wxMenu *menu, int x, int y ) return true; } -#endif // wxUSE_MENUS_NATIVE -#endif // __WXGTK20__ +#endif // wxUSE_MENUS_NATIVE #endif // GTK_CHECK_VERSION(2, 1, 0) +#endif // wxUSE_TASKBARICON