X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4f167b46b42b81f8f646e594057535f05b05027f..937013e0fd914d4c42f9f5ec98da665986b93dfa:/src/gtk/taskbar.cpp diff --git a/src/gtk/taskbar.cpp b/src/gtk/taskbar.cpp index bfd2341e2d..4bb7f2dcf2 100644 --- a/src/gtk/taskbar.cpp +++ b/src/gtk/taskbar.cpp @@ -14,6 +14,9 @@ #if wxUSE_TASKBARICON +#include +#if GTK_CHECK_VERSION(2, 1, 0) + #include "wx/gtk/taskbarpriv.h" #ifndef WX_PRECOMP @@ -22,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() @@ -60,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); @@ -72,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 //----------------------------------------------------------------------------- @@ -142,9 +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