Deprecated: Creation of dynamic property c2c_AddAdminCSS::$admin_options_name is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$config is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$disable_contextual_help is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$disable_update_check is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$hook_prefix is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$form_name is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$menu_name is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$name is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$nonce_field is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$settings_page is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$show_admin is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$textdomain is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$textdomain_subdir is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 106 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$author_prefix is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 109 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$id_base is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 110 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$options_page is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 111 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$plugin_basename is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 112 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$plugin_file is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 113 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$plugin_path is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 114 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$u_id_base is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 115 Deprecated: Creation of dynamic property c2c_AddAdminCSS::$version is deprecated in /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php on line 116 Warning: Cannot modify header information - headers already sent by (output started at /var/www/html/wp-content/plugins/add-admin-css/c2c-plugin.php:106) in /var/www/html/wp-includes/rest-api/class-wp-rest-server.php on line 1768 {"id":57,"date":"2021-09-24T17:44:13","date_gmt":"2021-09-24T10:44:13","guid":{"rendered":"https:\/\/erwin.co\/?p=57"},"modified":"2022-07-05T18:29:03","modified_gmt":"2022-07-05T11:29:03","slug":"what-are-_gtk_frame_extents-and-how-does-gnome-window-sizing-work","status":"publish","type":"post","link":"https:\/\/erwin.co\/what-are-_gtk_frame_extents-and-how-does-gnome-window-sizing-work\/","title":{"rendered":"What are _GTK_FRAME_EXTENTS and how does Gnome Window Sizing work?"},"content":{"rendered":"\n

Gnome is a trailblazer. Desktop icons? Using the Win\/Cmd\/Super key as a shortcut key? Getting rid of backwards compatibility? The Gnome developers are always eager to try new things...<\/p>\n\n\n\n

There was once a time when the KDE (kwin) folks and the GNOME (mutter) folks appeared to get along quite well, and jointly created several versions of the wm-spec<\/a><\/code> of the FreeDesktop.org Specifications. Collectively, the FreeDesktop specifications are why application developers can create apps that work across various types of Linux desktops.<\/p>\n\n\n\n

Many parts of the spec are frequently updated, but sadly the wm-spec<\/code> portion of the FreeDesktop.org specifications hasn't gotten gotten an update since November, 29th 2011.<\/p>\n\n\n\n

The wm-spec<\/code> defines \"Extended Window Manager Hints\". Messages that applications, window managers, pagers (navigation aids like virtual desktop selectors), and automation applications such as xdotool<\/a> and wmctrl<\/a>.<\/p>\n\n\n\n

The wl-roots<\/a> project that provides the foundation for SwayWM<\/a>, basically the Wayland port of the i3<\/a> tiling window manager, may eventually become a sort of successor to wm-spec<\/code>, giving other desktops a common platform to build for Wayland on top of, however, I don't think GNOME or KDE are building on top of wl-roots. The future best case scenario may be code that works for wl-roots, KDE and GNOME... So for anyone that thought using xcb<\/a><\/code>, the C interface directly to the X11 protocol, was difficult, there's not even a consistent layer to write to once everything moves to Wayland. Hopefully Arcan<\/a> or something else comes out and surprises us, as I think Wayland could be a significant step backwards for the most sophisticated users. That said, the WL-ROOTS author seems to be optimistic<\/a> on Wayland...<\/p>\n\n\n\n


\n\n\n\n

X11 has been updated periodically since it's initial release in 1987. Lots of things change over the years... The MOTIF_ related proprieties aren't used very often any more.<\/p>\n\n\n\n

You can read all of the properties for any window you're interested in with xprop<\/code>. For example:<\/p>\n\n\n\n

# use -len 80 to drop X11's archaic icon info\nxprop -len 80<\/code><\/pre>\n\n\n\n

Prior to _GTK_FRAME_EXTENTS<\/code>, the next most recent window sizing method was to check _NET_FRAME_EXTENTS<\/code>.<\/p>\n\n\n\n

_NET_FRAME_EXTENTS, <\/p>

left, right, top, bottom, CARDINAL[4]\/32<\/p>

The Window Manager MUST set _NET_FRAME_EXTENTS to the extents of the window's frame. left, right, top and bottom are widths of the respective borders added by the Window Manager<\/p> EWMH (Extended Window Manager Hints) spec<\/a><\/cite><\/blockquote>\n\n\n\n

GNOME released a new property called _GTK_FRAME_EXTENTS<\/code> that usually have a value close to 25, 25, 25, 25<\/code>... In 20202, KDE's KWin window manager was updated to automatically handle _GTK_FRAME_EXTENTS<\/a>, so if you're a user or developer who's trying to understand how this property works on Kwin, it's even more confusing, because Kwin takes these values into account, and then gets them out of your way. This is the ideal behavior. Congratulations to the Kwin team. However, don't expect to understand this property if you're using a version of Kwin that already effectively hides it.<\/p>\n\n\n\n


\n\n\n\n

I had been searching for documentation on how exactly `_GTK_FRAME_EXTENTS` worked for a few weeks, but on KDE I just couldn't make any sense of it. I even found this video and though \"isn't that just doing what it was supposed to do? what did it look like before?\"<\/em><\/p>\n\n\n\n

\n