Scroll to navigation

xcb_get_geometry(3) XCB Requests xcb_get_geometry(3)

NAME

xcb_get_geometry - Get current window geometry

SYNOPSIS

#include <xcb/xproto.h>

Request function

xcb_get_geometry_cookie_t xcb_get_geometry(xcb_connection_t *conn, xcb_drawable_t drawable);

Reply datastructure

typedef struct xcb_get_geometry_reply_t {

uint8_t response_type;
uint8_t depth;
uint16_t sequence;
uint32_t length;
xcb_window_t root;
int16_t x;
int16_t y;
uint16_t width;
uint16_t height;
uint16_t border_width;
uint8_t pad0[2]; } xcb_get_geometry_reply_t;

Reply function

xcb_get_geometry_reply_t *xcb_get_geometry_reply(xcb_connection_t *conn, xcb_get_geometry_cookie_t cookie, xcb_generic_error_t **e);

REQUEST ARGUMENTS

The XCB connection to X11.
The drawable (Window or Pixmap) of which the geometry will be received.

REPLY FIELDS

The type of this reply, in this case XCB_GET_GEOMETRY. This field is also present in the xcb_generic_reply_t and can be used to tell replies apart from each other.
The sequence number of the last request processed by the X11 server.
The length of the reply, in words (a word is 4 bytes).
The depth of the drawable (bits per pixel for the object).
Root window of the screen containing drawable.
The X coordinate of drawable. If drawable is a window, the coordinate specifies the upper-left outer corner relative to its parent's origin. If drawable is a pixmap, the X coordinate is always 0.
The Y coordinate of drawable. If drawable is a window, the coordinate specifies the upper-left outer corner relative to its parent's origin. If drawable is a pixmap, the Y coordinate is always 0.
The width of drawable.
The height of drawable.
The border width (in pixels).

DESCRIPTION

Gets the current geometry of the specified drawable (either Window or Pixmap).

RETURN VALUE

Returns an xcb_get_geometry_cookie_t. Errors have to be handled when calling the reply function xcb_get_geometry_reply.

If you want to handle errors in the event loop instead, use xcb_get_geometry_unchecked. See xcb-requests(3) for details.

ERRORS

TODO: reasons?
TODO: reasons?

EXAMPLE

/*

* Displays the x and y position of the given window.
*
*/ void my_example(xcb_connection_t *c, xcb_window_t window) {
xcb_get_geometry_cookie_t cookie;
xcb_get_geometry_reply_t *reply;
cookie = xcb_get_geometry(c, window);
/* ... do other work here if possible ... */
if ((reply = xcb_get_geometry_reply(c, cookie, NULL))) {
printf("This window is at %d, %d\n", reply->x, reply->y);
}
free(reply); }

SEE ALSO

xcb-requests(3), xcb-examples(3), xwininfo(1)

AUTHOR

Generated from xproto.xml. Contact xcb@lists.freedesktop.org for corrections and improvements.

libxcb 1.15 X Version 11