下载手机最新版tp|xcb

作者: 下载手机最新版tp
2024-03-07 22:06:04

【星辰变】官网——2D次世代动作网游

【星辰变】官网——2D次世代动作网游

进入官网

这里是副标题

这里是副标题

领取礼包

礼遇2022礼盒

兑换方法

前往炎京城车侯辕(313,325)处领取

这里是副标题

3分钟极速下载

DOWNLOAD

完整客户端

DOWNLOAD

赤阳

血魔

蓝央

清虚

阴月

炎魔

原掌门的突然飞升让紫阳门陷入动荡,危难之际,赤阳真人横空出世,以通天手段扭转乾坤,兼容并蓄,重建门墙。重建后的紫阳门正式改名为赤阳门。

血魔门修炼的正是魔道三大秘法之一的血魔魔道。能够传承此秘法的人相当稀少。不过真正的血魔战士都是敌人的梦魇,他们的出现就是死亡的宣告。

蓝央门的创始人是一对出生在腾龙大陆的孪生兄弟:哥哥天生驭火、弟弟点物成石。两兄弟在飞升时留下两座神塔,借助双塔神力修行的人们创立了蓝央门。

这些最早迎来天劫的道人们,便是清虚观的创立之祖。到现在,没人知道清虚观究竟有多久的历史,但无论时代如何变迁,清虚观的强大从来没有改变过。

第一次修真者大战,致使仙魔之间长期压抑的积怨集中爆发。大战过后,修魔者重新划分形成了众多的新势力,而这些势力之中又以阴月宫最为独特。

为了将血脉延续,炎魔与凡人女子通婚,以减轻血液中的“天罚之力”。渐渐地,炎魔的子孙恢复了常人的样子,获得重生的炎魔后裔也知感恩。

您已获得礼包激活码

复制

※ 请至游戏内炎京城车侯辕(313,325)处领取

关于qt缺少xcb问题终极解决办法_qt xcb-CSDN博客

>

关于qt缺少xcb问题终极解决办法_qt xcb-CSDN博客

关于qt缺少xcb问题终极解决办法

最新推荐文章于 2024-01-29 14:56:40 发布

我爱下午茶

最新推荐文章于 2024-01-29 14:56:40 发布

阅读量7.9w

收藏

191

点赞数

45

分类专栏:

学习工作

文章标签:

qt

qt移植

xcb

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/sinat_26106275/article/details/82778951

版权

学习工作

专栏收录该内容

12 篇文章

0 订阅

订阅专栏

关于qt缺少xcb问题终极解决办法

问题背景系统环境qt版本问题描述

解决过程走的弯路解决问题的关键

总结

问题背景

系统环境

中标麒麟,龙芯平台

qt版本

qt5.6

问题描述

原来的Qt程序是qt5.3.2版本,但是由于各种原因,升级成了qt5.6版本。 编译完成后放在其他机器上报错缺少xcb,报错如下:

This application failed to start because it could not find or load the Qt platform plugin "xcb"

in "".

Available platform plugins are: eglfs, linuxfb, minimal, minimalegl, offscreen, xcb, xcb.

Reinstalling the application may fix this problem.

解决过程

走的弯路

几乎尝试百度到的各种方式,无非就这么几种。 1、运行目录下添加platform文件夹,文件夹里放上libqxcb.so。 2、指定环境变量,具体什么变量记不清楚了。 3、在运行目录下,添加 libQt5Core.so libQt5Gui.so libQt5Network.so libQt5Widgets.so libQt5DBus.so libicuuc.so libicudata.so libicui18n.so

最终结果还是不行。

解决问题的关键

设置环境变量 export QT_DEBUG_PLUGINS=1 加了这个环境变量,让我看到了QT程序加载的过程,看到了详细的报错信息。 最后一部分是这样的:

Found metadata in lib /usr/lib64/qt5/plugins/platforms/libqxcb.so, metadata=

{

"IID": "org.qt-project.Qt.QPA.QPlatformIntegrationFactoryInterface.5.3",

"MetaData": {

"Keys": [

"xcb"

]

},

"className": "QXcbIntegrationPlugin",

"debug": false,

"version": 329218

}

Found metadata in lib /opt/dky/SASClient/bin/platforms/libqxcb.so, metadata=

{

"IID": "org.qt-project.Qt.QPA.QPlatformIntegrationFactoryInterface.5.3",

"MetaData": {

"Keys": [

"xcb"

]

},

"className": "QXcbIntegrationPlugin",

"debug": false,

"version": 329216

}

QLibraryPrivate::loadPlugin failed on "/usr/lib64/qt5/plugins/platforms/libqxcb.so" : "Cannot load library /usr/lib64/qt5/plugins/platforms/libqxcb.so: (/lib64/libQt5XcbQpa.so.5: symbol _ZNK11QFontEngine6handleEv, version Qt_5_PRIVATE_API not defined in file libQt5Gui.so.5 with link time reference)"

This application failed to start because it could not find or load the Qt platform plugin "xcb"

in "".

Available platform plugins are: eglfs, linuxfb, minimal, minimalegl, offscreen, xcb, xcb.

Reinstalling the application may fix this problem.

看到问题没? /lib64/libQt5XcbQpa.so.5 这个库有问题。 于是我把libQt5XcbQpa.so,也放在运行目录下。 奇迹发生了,一切OK了!!!

总结

网上大部分搜到的解决办法,可能都是基于qt5.6之前的,但是qt5.6之后新加了几个库,所以网上的解决办法搜不到,所以才困扰了我这么久。 这次解决问题的关键在于,添加环境变量:export QT_DEBUG_PLUGINS=1 相信遇到此问题,利用这个方法,都可以很快的定位并解决问题了。 最后,祝大家好运!!!

优惠劵

我爱下午茶

关注

关注

45

点赞

191

收藏

觉得还不错?

一键收藏

知道了

49

评论

关于qt缺少xcb问题终极解决办法

关于qt缺少xcb问题终极解决办法问题背景系统环境qt版本问题描述解决过程走的弯路解决问题的关键总结问题背景系统环境中标麒麟,龙芯平台qt版本qt5.6问题描述原来的Qt程序是qt5.3.2版本,但是由于各种原因,升级成了qt5.6版本。编译完成后放在其他机器上报错缺少xcb,报错如下:This application failed to start because it cou...

复制链接

扫一扫

专栏目录

Ubuntu18.04下解决Qt出现qt.qpa.plugin:Could not load the Qt platform plugin “xcb“问题

09-14

主要介绍了Ubuntu18.04下解决Qt出现qt.qpa.plugin:Could not load the Qt platform plugin “xcb“问题,本文给大家分享解决方案,需要的朋友可以参考下

QT 安装libX11-xcb.so.1

07-01

安装Qt时候,显示缺少libX11-xcb.so.1,这个是安装源码文件

49 条评论

您还未登录,请先

登录

后发表或查看评论

Python qt.qpa.xcb: could not connect to display解决办法

smile_5me的博客

01-29

445

遇到问题:qt.qpa.xcb: could not connect to display。然后重新跑python程序,解决!

Linux关于qt缺少xcb问题解决办法

LEGENDA的博客

07-20

1960

Linux关于qt缺少xcb问题解决办法 , 包解决

ubuntu, debain, uos, deepin qt安装后打不开

07-10

解决下面报错

qt.qpa.plugin: Could not load the Qt platform plugin "xcb" in "" even though it was found.

This application failed to start because no Qt platform plugin could be initialized. Reinstalling the application may fix this problem.

Available platform plugins are: eglfs, linuxfb, minimal, minimalegl, offscreen, vnc, xcb.

关于Qt 缺少xcb 解决办法

子非鱼的博客

11-15

9381

最近在ARM上编译Qt5.13 编译完之后出现这个错误

This application failed to start because it could not find or load the Qt platform plugin "xcb"

in "".

Available platform plugins are: eglfs, linuxfb, minimal, minimalegl, offscreen, xcb, xcb.

Reinstalling the application may

【ARM开发】交叉编译Qt源码之(4)添加xcb支持

console_log的博客

02-16

5163

Debian 9

1、依赖

Qt源码添加xcb支持,依赖xcb-util-wm、xcb-util、xcb-util-image、xcb-util-keysyms、xcb-util-renderutil、libxkbcommon,其中libxkbcommon依赖libxml。

1.1、xcb-util-wm

下载地址:Index of /releases/individual/xcbhttps://www.x.org/releases/individual/xcb/

#解压

tar -zxvf x

qt 打包程序到别的电脑上 缺少xcb错误 两个大坑

qq_45988470的博客

02-25

2619

This application failed to start because it could not find or load the

Qt platform plugin “xcb” in “”.

一般我们都知道,打包的时候要添加添加platform文件夹,文件夹里放上libqxcb.so。我这里遇到了两个另外的问题,

需添加libQt5XcbQpa.so.5,注意是就是我下面选中的文件,不要去复制快捷方式,具体的做法应该是把那个文件复制到你的程序所在目录去,并将libQt5XcbQpa.s.

kylin aarch-64位下编译qt-xcb 。

malihong1的专栏

01-05

1409

为了再kylin 64位下编译qt源码, 先编译xcb, 可以先参考一位博主的文章CentOS7 环境下交叉编译(银河麒麟)_lijing_sun的博客-CSDN博客_银河麒麟交叉编译

,按照步骤来,前面其他的还好编译,就是在编译xproto的时候一直有问题,提示类似无法猜测编译类型啥的, 后来使用如下命令,成功编译:

sudo ./configure --enable-static --build=arm-linux

sudo make

sudo make install

.

...

在Ubuntu上运行Qt发布的应用程序时遇到xcb问题,可以尝试以下几个步骤:

ylfdragon2005的博客

09-11

1263

可以尝试设置QT_QPA_PLATFORM_PLUGIN_PATH环境变量。如果以上步骤都无法解决xcb问题,则可能需要升级Qt库或重新安装Qt Creator。尝试安装libqt5xcbqpa插件。或者将其添加到~/.bashrc文件中(如果它不存在,请创建)。重新启动应用程序或系统,并尝试再次运行Qt应用程序。// 或者使用一下命令再尝试一下。

Qt+x11+xcb的例子

03-08

Qt+x11+xcb的例子, 详见http://blog.csdn.net/xgbing/article/details/79479380

解决安装QT时报的libX11-xcb.so.1 缺包问题

02-21

解决安装QT时报的libX11-xcb.so.1 缺包问题解决安装QT时报的libX11-xcb.so.1 缺包问题解决安装QT时报的libX11-xcb.so.1 缺包问题解决安装QT时报的libX11-xcb.so.1 缺包问题解决安装QT时报的libX11-xcb.so.1 缺包问题...

qt-5.9.9-gcc485-libc217-static-qt-xcb.tar.gz

04-09

./configure -confirm-license -opensource -debug-and-release -static -prefix ../build -no-opengl -nomake tests -no-compile-examples -nomake examples -qt-xcb ———————————————— 原文链接:...

x86上交叉编译的arm xcb插件,配合qt源码编译使用

最新发布

02-21

内含源码包、编译包、安装完成的库. ...如遇到qt程序在客户机报xcb错误,可以先交叉编译此文件夹的包,再在qt源码配置中启用xcb,并指定依赖库位置。请注意:交叉编译qt时,不能引用系统的库,指令集不一致

xcb-proto-1.13.tar.gz

09-30

xcb-proto-1.13.tar.gz的源码,交叉编译通过,亲测可用

Qt5.9.9 编译需要的 fontconfig、x11、xcb相关库

04-14

Qt5.9.9 编译需要的 fontconfig、x11、xcb相关库

qt-5.15.2-jetson-nano

05-09

jetson-nano,jetpack 是4.6.1版本。编译的qt5.15.2,带xcb, 带opengl, qml可用。 在板子上编译大概需要6小时,还会碰到各种问题,试错成本比较高。有需要的小伙伴可以省去大家编译的烦恼,节约时间。

银河麒麟V10系统+飞腾CPU交叉编译Qt5.15

09-29

一、准备工作 1、下载qt源码包 下载网址:...sudo apt-get install '^libxcb.*-dev' libx11-xcb-dev libglu1-mesa-dev libxrender-dev libxi-dev libxkbcommon-dev libxkbcommon-x11-d

麒麟v10 qt 缺少xcb

07-28

您好!对于麒麟v10 qt缺少xcb的问题,您可以尝试通过以下步骤解决:

1. 确认系统是否已经安装了xcb库。您可以打开终端,并输入以下命令进行检查:

```

dpkg -l | grep libxcb

```

2. 如果系统中没有安装xcb库,您可以通过以下命令进行安装:

```

sudo apt-get install libxcb1-dev

```

3. 安装完成后,重新编译和运行您的程序,看是否仍然缺少xcb库。

希望以上步骤能够帮助您解决问题!如果还有其他疑问,请随时提问。

“相关推荐”对你有帮助么?

非常没帮助

没帮助

一般

有帮助

非常有帮助

提交

我爱下午茶

CSDN认证博客专家

CSDN认证企业博客

码龄9年

暂无认证

18

原创

13万+

周排名

43万+

总排名

12万+

访问

等级

813

积分

57

粉丝

91

获赞

82

评论

357

收藏

私信

关注

热门文章

关于qt缺少xcb问题终极解决办法

79674

基于Huffman树的文件压缩原理及C语言实现(一)

8800

基于Huffman树的文件压缩原理及C语言实现(二)

7295

BeyondCompare之忽略换行符(pc/mac/unix)比较文件

5741

各版本的QT源码下载地址

4774

分类专栏

数据结构

9篇

学习工作

12篇

最新评论

基于Huffman树的文件压缩原理及C语言实现(二)

m0_74947800:

可以压缩中英文混合的txt文本嘛

关于qt缺少xcb问题终极解决办法

西伯利亚猹:

那该怎么解决呢 我搜了好几天了

求解决阿大神

关于qt缺少xcb问题终极解决办法

weixin_39179052:

有用,成功解决了问题。

顺便题一下, 运行路径可以通过 readelf -ld ***.so 来查看

关于qt缺少xcb问题终极解决办法

Pom Pom Purin:

我也是这样的,你解决了吗

关于qt缺少xcb问题终极解决办法

我爱下午茶:

QObject::moveToThread: Current thread (0x5638f5ffdf40) is not the object's thread (0x5638fadd59b0).

Cannot move to target thread (0x5638f5ffdf40)

你这个线程不对,好像遇到过。记得是,界面加载动作不要放在自己启动的线程中。

大家在看

String类,StringBuilder类,StringBuffer类

159

【开源物联网平台】使用MQTT.fx模拟设备接入FastBee物联网平台

73

差分--算法思路解析

微软输入法无法输出中文的解决方案

Anthropic 发布最智能模型 Claude 3,超越 ChatGPT 4 !!!

315

最新文章

数据结构—图解排序算法+github代码实现(希尔、冒泡、快排、堆排序、归并排序等)

KMP算法与优化(串的模式匹配)

表达式的二叉树表示

2020年3篇

2019年1篇

2018年3篇

2017年2篇

2016年1篇

2015年11篇

目录

目录

分类专栏

数据结构

9篇

学习工作

12篇

目录

评论 49

被折叠的  条评论

为什么被折叠?

到【灌水乐园】发言

查看更多评论

添加红包

祝福语

请填写红包祝福语或标题

红包数量

红包个数最小为10个

红包总金额

红包金额最低5元

余额支付

当前余额3.43元

前往充值 >

需支付:10.00元

取消

确定

下一步

知道了

成就一亿技术人!

领取后你会自动成为博主和红包主的粉丝

规则

hope_wisdom 发出的红包

实付元

使用余额支付

点击重新获取

扫码支付

钱包余额

0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。 2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

xcb

xcb

xcb

Edit

Page History

Repo Info

Introduction

The X protocol C-language Binding (XCB) is a replacement for Xlib featuring a small footprint, latency hiding, direct access to the protocol, improved threading support, and extensibility.

News

August 2023: xcb-proto 1.16 and libxcb 1.16 were released. In addition to fixing bugs, this adds support for DPMS 1.2 & Present 1.3.

May 2022: xcb-proto 1.15 and libxcb 1.15 were released. In addition to fixing bugs, this adds support for XInput 2.4.

February 2020: xcb-proto 1.14 and libxcb 1.14 were released. In addition to fixing bugs, this brings compatibility with check >= 0.13 and adds xcb_total_read() and xcb_total_written() APIs.

March 2018: xcb-proto 1.13 and libxcb 1.13 were released. In addition to fixing bugs, this enables new and completed versions of some protocols.

May 2016: xcb-proto 1.12 and libxcb 1.12 were released.

September 2015: libxcb 1.11.1 was released. This fixes some thread-related issues and adds 64-bit versions of some APIs.

August 2014: xcb-proto 1.11 and libxcb 1.11 were released. This is again mostly a bug-fix release.

December 2013: xcb-proto 1.10 and libxcb 1.10 were released, this time mainly fixing some API and ABI issues introduced with libxcb 1.9.2. See the linked announcements for more details.

May 2013: libxcb 1.9.1 was released, fixing the python code to work with Python 3, and fixing an integer overflow in the read_packet() function (CVE-2013-2064)

October 2012: New releases of the XCB packages have been published, including autogenerated man pages for XCB API's - see the linked announcements for full details of what's changed in each one:

xcb-proto 1.8

libxcb 1.9

Download

You can obtain released versions of XCB from http://xcb.freedesktop.org/dist.

Follow the instructions from the developer's guide to build, except that you can use released versions of the dependencies, and you don't need git, automake, autoconf, or libtool.

Development

If you wish to work on XCB, please read the developer's guide.

Mailing list: Discussion of XCB and Xlib/XCB is through the XCB mailing list.

IRC: XCB developers also hang out on IRC, and have occasional meetings.

Of course, there's still a lot to do .

Documentation

The XCB API is documented. There is also a tutorial and some random notes.

People wanting to implement higher level applications can use xcb-util.

XCB is built atop an XML description of the X core protocol and common extension protocols called XML/XCB. This protocol can be used in other interesting ways. Documentation of the X Window System protocol is also available at X.org's website, and can be used in combination with XCB documentation as XCB functions largely reflect the protocol.

To aid in porting applications, you can configure Xlib to use XCB for the transport layer. We call this Xlib/XCB.

There is automatically-generated documentation for the XCB protocol bindings.

The Windows (32 bit) port of XCB will be merged into the main code base soon. You can read more on that here.

Miscellaneous

The XCB logo

The XCB project has a long history, during which it has produced many academic publications. Various projects have adopted XCB.

Links:

XCBDevelopmentPlan

XCBToDo

XcbApi

XmlXcb

usingxcb

Last edited Sat Mar 2 22:47:09 2024

XCB - 维基百科,自由的百科全书

XCB - 维基百科,自由的百科全书

跳转到内容

主菜单

主菜单

移至侧栏

隐藏

导航

首页分类索引特色内容新闻动态最近更改随机条目资助维基百科

帮助

帮助维基社群方针与指引互助客栈知识问答字词转换IRC即时聊天联络我们关于维基百科

语言

语言链接位于页面顶部,标题的另一侧。

搜索

搜索

创建账号

登录

个人工具

创建账号 登录

未登录编辑者的页面 了解详情

贡献讨论

目录

移至侧栏

隐藏

序言

1理念

2示例

3注释

4外部链接

开关目录

XCB

7种语言

DeutschEnglishEspañolFrançais日本語한국어Русский

编辑链接

条目讨论

大陆简体

不转换简体繁體大陆简体香港繁體澳門繁體大马简体新加坡简体臺灣正體

阅读编辑查看历史

工具

工具

移至侧栏

隐藏

操作

阅读编辑查看历史

常规

链入页面相关更改上传文件特殊页面固定链接页面信息引用本页获取短URL下载二维码维基数据项目

打印/导出

下载为PDF可打印版

在其他项目中

维基共享资源

维基百科,自由的百科全书

XCB开发者Jamey Sharp、Josh Triplett、Bart Massey当前版本1.16.1 (2024年3月2日;稳定版本)[1]

源代码库gitlab.freedesktop.org/xorg/lib/libxcb

操作系统POSIX类型X Window核心协议开发函式库许可协议MIT许可证网站xcb.freedesktop.org

XCB(X C Binding)是一套以 C语言撰写,并用于绑定(Binding) X Window System之上。XCB是一套免费的软件,目标在于取代 Xlib。这个计划开始于2001年,作者是Bart Massey.

理念[编辑]

XCB 主要目标是:

减轻函式库的大小与复杂度;

可直接访问 X Window核心协议。

示例[编辑]

/* Simple XCB application drawing a box in a window */

#include

#include

#include

int main()

{

xcb_connection_t *c;

xcb_screen_t *s;

xcb_window_t w;

xcb_gcontext_t g;

xcb_generic_event_t *e;

uint32_t mask;

uint32_t values[2];

int done = 0;

xcb_rectangle_t r = { 20, 20, 60, 60 };

/* open connection with the server */

c = xcb_connect(NULL,NULL);

if (xcb_connection_has_error(c)) {

printf("Cannot open display\n");

exit(1);

}

/* get the first screen */

s = xcb_setup_roots_iterator( xcb_get_setup(c) ).data;

/* create black graphics context */

g = xcb_generate_id(c);

w = s->root;

mask = XCB_GC_FOREGROUND | XCB_GC_GRAPHICS_EXPOSURES;

values[0] = s->black_pixel;

values[1] = 0;

xcb_create_gc(c, g, w, mask, values);

/* create window */

w = xcb_generate_id(c);

mask = XCB_CW_BACK_PIXEL | XCB_CW_EVENT_MASK;

values[0] = s->white_pixel;

values[1] = XCB_EVENT_MASK_EXPOSURE | XCB_EVENT_MASK_KEY_PRESS;

xcb_create_window(c, s->root_depth, w, s->root,

10, 10, 100, 100, 1,

XCB_WINDOW_CLASS_INPUT_OUTPUT, s->root_visual,

mask, values);

/* map (show) the window */

xcb_map_window(c, w);

xcb_flush(c);

/* event loop */

while (!done && (e = xcb_wait_for_event(c))) {

switch (e->response_type & ~0x80) {

case XCB_EXPOSE: /* draw or redraw the window */

xcb_poly_fill_rectangle(c, w, g, 1, &r);

xcb_flush(c);

break;

case XCB_KEY_PRESS: /* exit on key press */

done = 1;

break;

}

free(e);

}

/* close connection to server */

xcb_disconnect(c);

return 0;

}

注释[编辑]

^ libxcb-1.16.1. 

^ [ANNOUNCE] libxcb 1.14. xcb (邮件列表). 2020-02-22 [2020-02-22]. (原始内容存档于2021-02-26). 

外部链接[编辑]

XCB wiki (页面存档备份,存于互联网档案馆) (freedesktop.org)

XCB API reference (页面存档备份,存于互联网档案馆)

Further publications (页面存档备份,存于互联网档案馆)

查论编Freedesktop.org托管的自由及开放源代码软件项目操作系统组件音频

PulseAudio

PipeWire

图形

Compiz

DRI(英语:Direct Rendering Infrastructure)

Enchant(英语:Enchant (software))

nouveau

Plymouth

Wayland

X.Org Server

Glamor

Xephyr(英语:Xephyr)

其它

Avahi(英语:Avahi (software))

D-Bus

Flatpak

kmscon(英语:kmscon)

luit(英语:luit)

PackageKit

pkg-config

Systemd

函式库

AppStream

cairo

Fontconfig

GStreamer

Mesa 3D

fprint(英语:fprint)

HarfBuzz

Pango

Poppler

Swfdec(英语:Swfdec)

Video Acceleration API(英语:Video Acceleration API)

XCB

Xft(英语:Xft)

软件框架

CppUnit(英语:CppUnit)

Galago(英语:Galago (software))

GeoClue(英语:GeoClue)

Open Collaboration Services(英语:Open Collaboration Services)

Telepathy

会议

Create Project(英语:Create Project)

波特兰计划

查论编X窗口系统架构

核心协议

X Window选择(英语:X Window selection)

X Toolkit Intrinsics

X窗口授权(英语:X Window authorization)

X11颜色名称(英语:X11 color names)

X输入法

Wayland

扩展

X图像扩展(英语:X Image Extension)

X键盘扩展(英语:X keyboard extension)

RandR

X渲染扩展(英语:X Rendering Extension)

形状扩展(英语:Shape extension)

共享内存扩展(英语:MIT-SHM)

X显示管理器控制协议(英语:XDM (display manager))

X视频扩展(英语:X video extension)

X视频运动补偿(英语:X-Video Motion Compensation)

AIGLX(英语:AIGLX)

GLX(英语:GLX)

多指针X(英语:Multi-Pointer X)

Display PostScript

合成(英语:Composite (graphics))

Xinerama(英语:Xinerama)

组件和值得注意的实现显示服务器(英语:display server)

X.Org Server

Cygwin/X

X-Win32(英语:X-Win32)

X386(英语:X386)

XFree86

XGGI(英语:XGGI)

XDarwin(英语:XDarwin)

Xming

Xsgi(英语:Xsgi)

Xsun(英语:Xsun)

Xgl

Xnest(英语:Xnest)

Xephyr(英语:Xephyr)

XQuartz

XWayland

客户端库

Xlib

XCB

显示管理器会话管理器

GNOME显示管理器

KDM

SDDM(英语:Simple Desktop Display Manager)

XDM(英语:XDM (display manager))

LightDM

LXDM

SLiM(英语:SLiM)

Entrance(英语:Entrance (display manager))

WDM

X视窗管理器合成(英语:compositing window manager)

Compiz

KWin

Metacity

Mutter

Xfwm

平铺(英语:tiling window manager)

awesome

dwm

i3

Ion(英语:Ion (window manager))

PWM(英语:PWM (window manager))

ratpoison

wmii(英语:wmii)

xmonad

堆叠(英语:stacking window manager)

AfterStep(英语:AfterStep)

amiwm(英语:amiwm)

Blackbox

cwm(英语:cwm (window manager))

Enlightenment

Fluxbox

FVWM

IceWM

JWM

Matchbox(英语:Matchbox (window manager))

MWM

Openbox

Sawfish

twm

Window Maker

标准

ICCCM

EWMH

XDS

freedesktop.org

应用程序

xcalc

xclock

xedit

xload

xterm

xeyes

桌面环境(英语:Comparison of X Window System desktop environments)

取自“https://zh.wikipedia.org/w/index.php?title=XCB&oldid=71704018”

分类:​X Window系统隐藏分类:​使用未知软件信息框参数的页面

本页面最后修订于2022年5月19日 (星期四) 01:16。

本站的全部文字在知识共享 署名-相同方式共享 4.0协议之条款下提供,附加条款亦可能应用。(请参阅使用条款)

Wikipedia®和维基百科标志是维基媒体基金会的注册商标;维基™是维基媒体基金会的商标。

维基媒体基金会是按美国国内税收法501(c)(3)登记的非营利慈善机构。

隐私政策

关于维基百科

免责声明

行为准则

开发者

统计

Cookie声明

手机版视图

开关有限宽度模式

tutorial

tutorial

xcb/

tutorial

Edit

Page History

Repo Info

Tutorial based off original here, which in turn was based off an Xlib tutorial by Guy Keren.

After reading this page, read these pages (in this order):

Basic Windows and Drawing

Events

Text and Fonts

Window Context and Manipulation

Colors and PixMaps

Mouse Cursors

Xlib to XCB Translation Guide

Introduction

This tutorial is intended for people who want to program with the XCB library. Keep in mind that XCB, like the Xlib library, isn't what most programmers wanting to write X applications are looking for. Rather, most application developers will want to use a much higher-level GUI toolkit, like Motif, LessTiff, GTK, Qt, EWL, or ETK or perhaps use the higher-level drawing library Cairo. However, the basics of XCB are not all that complicated, and knowing about the layers those other libraries are built on top of is not a bad idea.

After reading this tutorial, one should be able to write very simple graphical programs but not write programs with decent user interfaces (at least easily). For real applications, the previously mentioned libraries are much more appropriate.

What is XCB and why does it exist?

XCB ("X C Binding") is an low-level API for the X window server. XCB is an alternative to Xlib, which has been the standard C binding for the X Window System protocol for many years now. Xlib is an excellent piece of work, but there are applications for which it is not ideal, for example:

Small platforms: Xlib is a large piece of code, and it's difficult to make it smaller

Latency hiding: Xlib requests requiring a reply are effectively synchronous: they block until the reply appears, whether the result is needed immediately or not.

Direct access to the protocol: Xlib does quite a bit of caching, layering, and similar optimizations. While this is normally a feature, it makes it difficult to simply emit specified X protocol requests and process specific responses.

Threaded applications: While Xlib does attempt to support multithreading, the API makes this difficult and error-prone.

New extensions: The Xlib infrastructure provides limited support for the new creation of X extension client side code.

XCB has been designed to solve the above problems and thus provide a base for:

Toolkit implementation.

Direct protocol-level programming.

Lightweight emulation of commonly used portions of the Xlib API.

The client and server model of the X window system

The X Window System was developed with one major goal: flexibility. The idea was that the way things look is one thing, but the way things work is another matter. Thus, the lower levels provide the tools required to draw windows, handle user input, allow drawing graphics using colors (or black and white screens), etc. To this point, a decision was made to separate the system into two parts. A client that decides what to do, and a server that actually draws on the screen and reads user input in order to send it to the client for processing.

This model is the complete opposite of what is used to when dealing with clients and servers. In our case, the user sits near the machine controlled by the server, while the client might be running on a remote machine. The server controls the screens, mouse and keyboard. A client may connect to the server, request that it draws a window (or several windows), and ask the server to send it any input the user sends to these windows. Thus, several clients may connect to a single X server (one might be running mail software, one running a WWW browser, etc). When input is sent by the user to some window, the server sends a message to the client controlling this window for processing. The client decides what to do with this input, and sends the server requests for drawing in the window.

The whole session is carried out using the X message protocol. This protocol was originally carried over the TCP/IP protocol suite, allowing the client to run on any machine connected to the same network that the server is. Later on, the X servers were extended to allow clients running on the local machine with more optimized access to the server (note that an X protocol message may be several hundreds of KB in size), such as using shared memory, or using Unix domain sockets (a method for creating a logical channel on a Unix system between two processes).

GUI programming: the asynchronous model

Unlike conventional computer programs, that carry some serial nature, a GUI program usually uses an asynchronous programming model, also known as "event-driven programming". This means that that program mostly sits idle, waiting for events sent by the X server, and then acts upon these events. An event may say "The user pressed the 1st button mouse in spot (x,y)", or "The window you control needs to be redrawn". In order for the program to be responsive to the user input, as well as to refresh requests, it needs to handle each event in a rather short period of time (e.g. less that 200 milliseconds, as a rule of thumb).

This also implies that the program may not perform operations that might take a long time while handling an event (such as opening a network connection to some remote server, or connecting to a database server, or even performing a long file copy operation). Instead, it needs to perform all these operations in an asynchronous manner. This may be done by using various asynchronous models to perform the longish operations, or by performing them in a different process or thread.

So the way a GUI program looks is something like that:

Perform initialization routines.

Connect to the X server.

Perform X-related initialization.

While not finished:

Receive the next event from the X server.

Handle the event, possibly sending various drawing requests to the X server.

If the event was a quit message, exit the loop.

Close down the connection to the X server.

Perform cleanup operations.

Basic XCB notions

XCB has been created to eliminate the need for programs to actually implement the X protocol layer. This library gives a program a very low-level access to any X server. Since the protocol is standardized, a client using any implementation of XCB may talk with any X server (the same occurs for Xlib, of course). We now give a brief description of the basic XCB notions. They will be detailed later.

1. The X Connection

The major notion of using XCB is the X Connection. This is a structure representing the connection we have open with a given X server. It hides a queue of messages coming from the server, and a queue of pending requests that our client intends to send to the server. In XCB, this structure is named 'xcb_connection_t'. It is analogous to the Xlib Display. When we open a connection to an X server, the library returns a pointer to such a structure. Later, we supply this pointer to any XCB function that should send messages to the X server or receive messages from this server.

2. Requests and replies: the Xlib killers

To ask for information from the X server, we have to make a request and ask for a reply. With Xlib, these two tasks are automatically done: Xlib locks the system, sends a request, waits for a reply from the X server and unlocks. This is annoying, especially if one makes a lot of requests to the X server. Indeed, Xlib has to wait for the end of a reply before asking for the next request (because of the locks that Xlib sends). For example, here is a time-line of N=4 requests/replies with Xlib, with a round-trip latency T_round_trip that is 5 times long as the time required to write or read a request/reply (T_write/T_read):

W-----RW-----RW-----RW-----R

* W: Writing request

* -: Stalled, waiting for data

* R: Reading reply

The total time is N * (T_write + T_round_trip + T_read).

With XCB, we can suppress most of the round-trips as the requests and the replies are not locked. We usually send a request, then XCB returns to us a cookie, which is an identifier. Then, later, we ask for a reply using this cookie and XCB returns a pointer to that reply. Hence, with XCB, we can send a lot of requests, and later in the program, ask for all the replies when we need them. Here is the time-line for 4 requests/replies when we use this property of XCB:

WWWW--RRRR

The total time is N * T_write + max (0, T_round_trip - (N-1) * T_write) + N * T_read. Which can be considerably faster than all those Xlib round-trips.

Here is a program that computes the time to create 500 atoms with Xlib and XCB. It shows the Xlib way, the bad XCB way (which is similar to Xlib) and the good XCB way. On my computer, XCB is 25 times faster than Xlib. On another random machine XCB has been observed to be up to 117 times faster than Xlib, on rare occasions.

To further compare Xlib to XCB, there's a XInternAtoms routine. It's the Xlib method to request all the atoms in an array at one time to help hide the latency. Mostly the good Xlib time takes twice the time as the good XCB time. It also highlights the complexity of using XCB, 3 simple statements for Xlib vs 9 statements including two loops for XCB. If this simple test was expanded beyond requesting Atoms, XCB would allow submitting all the various requests at one time, Xlib wouldn't.

/* It's a good idea to paste this and other long code examples

into a text editor for easier reading */

#include

#include

#include

#include

#include

#include

#define NUM_NAMES 500

/*

NOTE: For concision, we're going to be cheesy and use arrays where real code

would use points and memory allocation.s

*/

#ifndef __GNUC__

char* strdup(const char* s) {

int n = strlen(s) + 1;

char *dup = malloc(n);

if(dup)

strcpy(dup, s);

return dup;

}

#endif

/*

return interval of time (uses time.h)

*/

double

get_time (void) {

struct timeval timev;

gettimeofday(&timev, NULL);

return (double)timev.tv_sec + (((double)timev.tv_usec) / 1000000);

}

/*

*/

void

useXlib (char **names,

Display *display ) {

Atom atoms[NUM_NAMES];

for (int i = 0; i < NUM_NAMES; ++i) {

atoms[i] = XInternAtom(display, names[i], 0);

}

}

/*

Request all atoms at once.

*/

void

useXlibProperly (char **names,

Display *display ) {

Atom atoms[NUM_NAMES];

if(!XInternAtoms(display, names, NUM_NAMES, 0, atoms))

fprintf(stderr, "XInternAtoms failed\n");

}

/*

*/

void

useXCBPoorly (char **names,

xcb_connection_t *connection ) {

xcb_atom_t atoms[NUM_NAMES];

// in this bad use of xcb, we use the cookie immediately after posting the request with xcb_intern_atom

for (int i = 0; i < NUM_NAMES; ++i) {

/* make request */

xcb_intern_atom_cookie_t cookie = xcb_intern_atom (connection,

0,

strlen(names[i]),

names[i] );

/* get response */

xcb_intern_atom_reply_t *reply = xcb_intern_atom_reply (connection,

cookie,

NULL ); // normally a pointer to receive error, but we'll just ignore error handling

if (reply) {

atoms[i] = reply->atom;

free (reply);

}

}

// now we have our atoms (replies), but this is just a demo, so we do nothing with them

}

/*

*/

void

useXCBProperly (char **names,

xcb_connection_t *connection ) {

xcb_atom_t atoms[NUM_NAMES];

xcb_intern_atom_cookie_t cookies[NUM_NAMES];

// in this good example, we make all our requests before checking for

// replies because it's best to queue requests when we have many at once

/* make requests */

for (int i = 0; i < NUM_NAMES; ++i) {

cookies[i] = xcb_intern_atom (connection,

0,

strlen (names[i]),

names[i] );

}

/* get responses */

for (int i = 0; i < NUM_NAMES; ++i) {

xcb_intern_atom_reply_t *reply = xcb_intern_atom_reply (connection,

cookies[i],

NULL ); // normally a pointer to receive errors, but we'll just ignore error handling

if (reply) {

atoms[i] = reply->atom;

free (reply);

}

}

// now we have our atoms (replies), but this is just a demo, so we do nothing with them

}

int

main () {

/* setup names for tests */

char (**names) = malloc(NUM_NAMES*sizeof(*names));

// init names to "NAME0", "NAME1", "NAME2" ... and so on

for (int i = 0; i < NUM_NAMES; ++i) {

char buf[100];

sprintf (buf, "NAME%d", i);

names[i] = strdup (buf);

}

/* do tests */

double start, XlibTime, XlibGoodTime, XCBBadTime, XCBGoodTime;

/* test Xlib */

Display *display = XOpenDisplay (NULL);

start = get_time ();

useXlib (names, display);

XlibTime = get_time () - start;

start = get_time ();

useXlibProperly (names, display);

XlibGoodTime = get_time () - start;

XCloseDisplay (display);

/* test XCB */

xcb_connection_t *connection = xcb_connect (NULL, NULL);

start = get_time ();

useXCBPoorly (names, connection);

XCBBadTime = get_time () - start;

start = get_time ();

useXCBProperly (names, connection);

XCBGoodTime = get_time () - start;

xcb_disconnect (connection);

/* report times */

printf ("Bad Xlib time : %f\n", XlibTime);

printf ("Good Xlib time : %f\n", XlibGoodTime);

printf ("Bad xcb time : %f\n", XCBBadTime);

printf ("Good xcb time : %f\n", XCBGoodTime);

printf ("ratio of good xcb time to bad xcb time: %f\n", XCBGoodTime / XCBBadTime);

printf ("ratio of Xlib time to good xcb time: %f\n", XlibTime / XCBGoodTime);

printf ("ratio of good Xlib time to bad Xlib time: %f\n", XlibGoodTime / XlibTime);

return 0;

}

3. The Graphics Context

When we perform various drawing operations (graphics, text, etc), we may specify various options for controlling how the data will be drawn (what foreground and background colors to use, how line edges will be connected, what font to use when drawing some text, etc). In order to avoid the need to supply hundreds of parameters to each drawing function, a graphical context structure is used. We set the various drawing options in this structure, and then we pass a pointer to this structure to any drawing routines. This is rather handy, as we often need to perform several drawing requests with the same options. Thus, we would initialize a graphical context, set the desired options, and pass this structure to all drawing functions.

Note that graphic contexts have no client-side structure in XCB, they're just XIDs. Xlib has a client-side structure because it caches the GC contents so it can avoid making redundant requests, but of course XCB doesn't do that.

4. Events

A structure is used to pass events received from the X server. XCB supports exactly the events specified in the protocol (33 events). This structure contains the type of event received (including a bit for whether it came from the server or another client), as well as the data associated with the event (e.g. position on the screen where the event was generated, mouse button associated with the event, region of the screen associated with a "redraw" event, etc). The way to read the event's data depends on the event type.

Using XCB-based programs

1. Installing XCB

TODO: These instructions are out of date. Just reference the main XCB page so we don't have to maintain these instructions in more than one place.

To build XCB from source, you need to have installed at least:

pkgconfig 0.15.0

automake 1.7

autoconf 2.50

check

xsltproc

gperf 3.0.1

You have to checkout in the git repository the following modules:

Xau from xlibs

xcb-proto

xcb

Note that xcb-proto exists only to install header files, so typing 'make' or 'make all' will produce the message "Nothing to be done for 'all'". That's normal.

2. Compiling XCB-based programs

Compiling XCB-based programs requires linking them with the XCB library. This is easily done thanks to pkgconfig:

gcc -Wall prog.c -o prog `pkg-config --cflags --libs xcb`

or simply :

gcc -Wall prog.c -lxcb

Opening and closing the connection to an X server

An X program first needs to open the connection to the X server, using xcb_connect():

xcb_connection_t *xcb_connect (const char *displayname, // if NULL, uses the DISPLAY environment variable

int *screenp ); // returns the screen number of the connection; can provide NULL if you don't care

To close a connection, it suffices to use:

void xcb_disconnect (xcb_connection_t *c);

So for example:

#include

...

xcb_connection_t *connection = xcb_connect (NULL, NULL);

xcb_disconnect (connection);

Comparison Xlib/XCB:

XOpenDisplay () => xcb_connect ()

XCloseDisplay () => xcb_disconnect ()

Checking basic information about a connection

Once we have opened a connection to an X server, we should check some basic information about it: what screens it has, what is the size (width and height) of the screen, how many colors it supports (black and white ? grey scale ?, 256 colors ? more ?), and so on. We get such information from the xcbscreent structure:

typedef struct {

xcb_window_t root;

xcb_colormap_t default_colormap;

uint32_t white_pixel;

uint32_t black_pixel;

uint32_t current_input_masks;

uint16_t width_in_pixels;

uint16_t height_in_pixels;

uint16_t width_in_millimeters;

uint16_t height_in_millimeters;

uint16_t min_installed_maps;

uint16_t max_installed_maps;

xcb_visualid_t root_visual;

uint8_t backing_stores;

uint8_t save_unders;

uint8_t root_depth;

uint8_t allowed_depths_len;

} xcb_screen_t;

We could retrieve the first screen of the connection by using the following function:

xcb_screen_iterator_t xcb_setup_roots_iterator (xcb_setup_t *R);

Here is a small program that shows how to use this function:

#include

#include

#include

int

main ()

{

/* Open the connection to the X server. Use the DISPLAY environment variable */

int i, screenNum;

xcb_connection_t *connection = xcb_connect (NULL, &screenNum);

/* Get the screen whose number is screenNum */

const xcb_setup_t *setup = xcb_get_setup (connection);

xcb_screen_iterator_t iter = xcb_setup_roots_iterator (setup);

// we want the screen at index screenNum of the iterator

for (i = 0; i < screenNum; ++i) {

xcb_screen_next (&iter);

}

xcb_screen_t *screen = iter.data;

/* report */

printf ("\n");

printf ("Informations of screen %"PRIu32":\n", screen->root);

printf (" width.........: %"PRIu16"\n", screen->width_in_pixels);

printf (" height........: %"PRIu16"\n", screen->height_in_pixels);

printf (" white pixel...: %"PRIu32"\n", screen->white_pixel);

printf (" black pixel...: %"PRIu32"\n", screen->black_pixel);

printf ("\n");

return 0;

}

The window hierarchy

TODO

Links:

index

Last edited Sat 29 Mar 2014 03:59:04 PM UTC

XCB - Wikipedia

XCB - Wikipedia

Jump to content

Main menu

Main menu

move to sidebar

hide

Navigation

Main pageContentsCurrent eventsRandom articleAbout WikipediaContact usDonate

Contribute

HelpLearn to editCommunity portalRecent changesUpload file

Languages

Language links are at the top of the page.

Search

Search

Create account

Log in

Personal tools

Create account Log in

Pages for logged out editors learn more

ContributionsTalk

Contents

move to sidebar

hide

(Top)

1Overview

Toggle Overview subsection

1.1Xlib compatibility

2Example

3Protocol description

4Logo

5Other language bindings

6Notes

7References

8External links

Toggle the table of contents

XCB

7 languages

DeutschEspañolFrançais한국어日本語Русский中文

Edit links

ArticleTalk

English

ReadEditView history

Tools

Tools

move to sidebar

hide

Actions

ReadEditView history

General

What links hereRelated changesUpload fileSpecial pagesPermanent linkPage informationCite this pageGet shortened URLDownload QR codeWikidata item

Print/export

Download as PDFPrintable version

In other projects

Wikimedia Commons

From Wikipedia, the free encyclopedia

X protocol C language binding library

This article relies excessively on references to primary sources. Please improve this article by adding secondary or tertiary sources. Find sources: "XCB" – news · newspapers · books · scholar · JSTOR (November 2009) (Learn how and when to remove this template message)

Original author(s)Bart MasseyDeveloper(s)Jamey Sharp, Josh Triplett, Bart MasseyInitial release2001; 23 years ago (2001)Stable release1.16.1[1] 

/ 2 March 2024; 3 days ago (2 March 2024)

Repositorygitlab.freedesktop.org/xorg/lib/libxcb

Written inCOperating systemPOSIXTypeX11 client libraryLicenseMIT LicenseWebsitexcb.freedesktop.org

X11-clients use XCB to communicate with the X server.

A more complete view of the Linux graphics stack

Programs often use GTK or FLTK or Qt for their GUI widgets.

A more complete view of the components of an operating system for home computers.

XCB (X protocol C-language Binding) is a library implementing the client-side of the X11 display server protocol. XCB is written in the C programming language and distributed under the MIT License. The project was started in 2001 by Bart Massey and aims to replace Xlib.

Overview[edit]

XCB was designed as a smaller, modernized replacement for Xlib, previously the primary C library for communicating with the X window system, coinciding with a more complete overhaul of the X implementation that took place during the early 2000s.[2] The main goals of XCB are to:

reduce library size and complexity

provide direct access to the X11 protocol

The required size reduction is achieved primarily by restricting XCB's scope to handling the X protocol and omitting Xlib functionality such as its extensive utility library, much of which saw little use by applications. This results in a factor thirty reduction of the compiled library size (as of 2004).[3]

Secondary goals include making the C interface asynchronous, facilitating better multithreading and making it easier to implement extensions (via XML protocol descriptions).

The core and extension protocol descriptions are in XML, with a program written in Python creating the C bindings. (Previous versions used XSLT and M4.)

A further goal is to be able to use these protocol descriptions to create protocol documentation, more language bindings, and server-side stubs.

Massey and others have worked to prove key portions of XCB formally correct using Z notation.[4] (Xlib has long been known to contain errors.[5])

Xlib compatibility[edit]

Xlib/XCB provides application binary interface compatibility with both Xlib and XCB, providing an incremental porting path.[6] Xlib/XCB uses the protocol layer of Xlib, but replaces the Xlib transport layer with XCB, and provides access to the underlying XCB connection for direct use of XCB. Xlib/XCB allows an application to open a single connection to the X display server and use both XCB and Xlib, possibly through a mixture of libraries designed for one or the other.[7][8]

Example[edit]

// Simple XCB application for opening a window and drawing a box in it

// To compile it using GNU, use:

// gcc x.c -lxcb

#include

#include

#include

int main(void)

{

xcb_connection_t *c;

xcb_screen_t *s;

xcb_window_t w;

xcb_gcontext_t g;

xcb_generic_event_t *e;

uint32_t mask;

uint32_t values[2];

int done = 0;

xcb_rectangle_t r = { 20, 20, 60, 60 };

// open connection to the server

c = xcb_connect(NULL,NULL);

if (xcb_connection_has_error(c)) {

printf("Cannot open display\n");

exit(EXIT_FAILURE);

}

// get the first screen

s = xcb_setup_roots_iterator( xcb_get_setup(c) ).data;

// create black graphics context

g = xcb_generate_id(c);

w = s->root;

mask = XCB_GC_FOREGROUND | XCB_GC_GRAPHICS_EXPOSURES;

values[0] = s->black_pixel;

values[1] = 0;

xcb_create_gc(c, g, w, mask, values);

// create window

w = xcb_generate_id(c);

mask = XCB_CW_BACK_PIXEL | XCB_CW_EVENT_MASK;

values[0] = s->white_pixel;

values[1] = XCB_EVENT_MASK_EXPOSURE | XCB_EVENT_MASK_KEY_PRESS;

xcb_create_window(c, s->root_depth, w, s->root,

10, 10, 100, 100, 1,

XCB_WINDOW_CLASS_INPUT_OUTPUT, s->root_visual,

mask, values);

// map (show) the window

xcb_map_window(c, w);

xcb_flush(c);

// event loop

while (!done && (e = xcb_wait_for_event(c))) {

switch (e->response_type & ~0x80) {

case XCB_EXPOSE: // draw or redraw the window

xcb_poly_fill_rectangle(c, w, g, 1, &r);

xcb_flush(c);

break;

case XCB_KEY_PRESS: // exit on key press

done = 1;

break;

}

free(e);

}

// close connection to server

xcb_disconnect(c);

exit(EXIT_SUCCESS);

}

XCB has a comparable, but slightly lower-level API than Xlib,[9] as can be seen with this example.

Protocol description[edit]

Creators of XCB have invented a specialized interface description language to model X11 protocol in language-neutral way and facilitate generation of bindings to other programming languages. libxcb itself is implemented as a code generator and a tiny C stub of utility functions.

An example:

extension-name="BigRequests" extension-multiword="true"

major-version="0" minor-version="0">

Logo[edit]

The XCB logo was produced by Gearóid Molloy, author of the web comic Neko the Kitty, and donated to the project.[10]

Other language bindings[edit]

XCB.pm - Perl module implementing bindings to XCB.

xpyb - The Python binding to the X Window System using XCB. As of June 2013, it does not support Python 3. Provided by freedesktop.org.

xcffib - Another Python binding which supports Python 2 & 3 as well as several more X extensions than xpyb.

Notes[edit]

^ "libxcb-1.16.1".

^ Gettys, James; Packard, Keith (2004). The (Re) Architecture of the X Window System (PDF). Proc. Linux Symposium. Vol. 1.

^ Sharp, Jamey (2004). How Xlib is Implemented (And What We're Doing About It) (PDF). Proc. Usenix Annual Techn. Conf., Freenix Track.

^ Massey and Bauer, 2002.

^ Sharp and Massey, 2002, §2.4. "While Xlib was designed to support threaded applications, and while that support is not unusable, there are known race conditions that cannot be eliminated without changing the Xlib interface."

^ Maloney, Ross J. (31 March 2018). Low Level X Window Programming: An Introduction by Examples. Springer. pp. 225–244. ISBN 978-3-319-74250-2. Retrieved 17 May 2022.

^ "Xlib/XCB: Xlib with XCB transport". 2008-01-11. Retrieved 2009-09-11.

^ Jamey Sharp and Josh Triplett (2006-11-26). "libx11 with Xlib/XCB now in experimental; please test with your packages". debian-devel-announce (Mailing list). Retrieved 2009-09-11.

^ Jamey Sharp; Bart Massey (2002), XCL : An Xlib Compatibility Layer For XCB, USENIX 2002 Annual Technical Conference, Freenix Track

^ KittyLogo (xcb.freedesktop.org)

References[edit]

Massey, Bart; Sharp, Jamey (2001-09-19). "XCB: An X Protocol C Binding" (PDF). Proceedings of the XFree86 Technical Conference. Oakland, California: USENIX. Retrieved 2012-03-12.

Massey, Bart; Bauer, Robert (2002). "X Meets Z: Verifying Correctness In The Presence Of POSIX Threads". Proceedings of the FREENIX Track: 2002 USENIX Annual Technical Conference. Monterey, California: USENIX. pp. 221–234. Retrieved 2008-11-07.

Sharp, Jamey; Massey, Bart (2002). "XCL: A Compatibility Layer For XCB". Proceedings of the FREENIX Track: 2002 USENIX Annual Technical Conference. Monterey, California: USENIX. pp. 71–83. Retrieved 2008-11-07.

External links[edit]

Free Software portal

XCB wiki (freedesktop.org)

XCB API reference, tutorial

libxcb tutorial

Further publications

The X New Developer’s Guide: Xlib and XCB

vteFree and open-source software projects hosted by freedesktop.orgOS componentsSound

PulseAudio

PipeWire

Graphics

Compiz

DRI

Enchant

nouveau

Plymouth

Wayland

X.Org Server

Glamor

Xephyr

Other

Avahi

D-Bus

Flatpak

Kmscon

luit

PackageKit

pkg-config

Systemd

Libraries

AppStream

Cairo

FreeType

Fontconfig

GStreamer

libinput

Mesa 3D

HarfBuzz

Pango

Poppler

Swfdec

Video Acceleration API

XCB

Xft

Frameworks

CppUnit

Open Collaboration Services (OCS)

Telepathy

Meetings

Create Project

Portland Project

vteX Window SystemArchitecture

Core protocol

X Window selection

X Window authorization

X11 color names

X Input Method

Wayland

Extensions

X Image Extension

X keyboard extension

RandR

X Rendering Extension

Shape extension

Shared memory extension

X Display Manager Control Protocol

X video extension

X-Video Motion Compensation

AIGLX

GLX

Multi-Pointer X

Display PostScript

Composite Extension

Xinerama

Componentsand notableimplementationsDisplay servers

X.Org Server

Cygwin/X

X-Win32

X386

XFree86

XDarwin

Xming

Xsgi

Xsun

Xgl

Xephyr

XQuartz

XWayland

Client libraries

Xlib

XCB

X Toolkit Intrinsics

Display managersSession managers

GDM

KDM

SDDM

XDM

LightDM

LXDM

Entrance

WDM

Window managers(comparison)Compositing

Compiz

KWin

Metacity

Mutter

Xfwm

Enlightenment

Stacking

4Dwm

9wm

AfterStep

amiwm

Blackbox

CTWM

cwm

Fluxbox

FLWM

FVWM

IceWM

JWM

Matchbox

mwm

olwm

Openbox

Qvwm

Sawfish

swm

tvtwm

twm

vtwm

WindowLab

Window Maker

wm2

Tiling

awesome

dwm

i3

Ion

ratpoison

wmii

xmonad

StumpWM

larswm

Standards

ICCCM

EWMH

XDS

freedesktop.org

Applications

xcalc

xclock

xedit

xload

xterm

xeyes

Desktop environments (comparison)

vteList of widget toolkitsLow-levelOn AmigaOS

Intuition

On Classic Mac OS, macOS

Macintosh Toolbox

Carbon

On Windows

Windows API

UWP

WinRT

On Unix,under X11

Xlib

XCB

X Toolkit Intrinsics

On BeOS, Haiku

BeOS API

Cross-platformCLI

OpenTK

C

GDK

Simple DirectMedia Layer

Java

JOGL

LWJGL

On AndroidCLI

Xamarin.Android

High-level, platform-specificOn AmigaOS

BOOPSI

MUI

ReAction GUI

Zune

On Classic Mac OS, macOSObject Pascal

MacApp

Objective-C, Swift

Cocoa

Cocoa Touch

C++

MacApp

PowerPlant

THINK C

CLI

Xamarin.Mac

Xamarin.iOS

On WindowsCLI

Windows Forms

XAML

Windows Presentation Foundation

Windows UI Library

Silverlight

Microsoft XNA

C++

MFC

Active Template Library

Windows Template Library

Object Windows Library

Object Pascal

Visual Component Library

On Unix,under X11

Athena (Xaw)

LessTif

Motif

OLIT

XForms

On Android

Qt for Android

High-level, cross-platformC

Enlightenment Foundation Libraries

GTK

IUP

XForms

XVT

C++

Bedrock

CEGUI

Component Library for Cross Platform

FLTK

FOX toolkit

OpenGL User Interface Library

gtkmm

JUCE

Qt

Rogue Wave Views

TnFOX

U++

Wt

wxWidgets

Simple and Fast Multimedia Library

Objective-C

GNUstep

CLI

Gtk#

Tao Framework

OpenTK

UIML

MonoGame

Moonlight

Xamarin.Forms

XWT[1][2]

.NET MAUI

Adobe Flash

Apache Flex

MXML

Go

Fyne

Haskell

wxHaskell

Java

Abstract Window Toolkit

FXML

JavaFX

Qt Jambi

Swing

Standard Widget Toolkit

Google Web Toolkit

Lightweight User Interface Toolkit

JavaScript

Dojo Toolkit

Echo

Ext JS

Google Closure Tools

jQuery UI

OpenUI5

Qooxdoo

YUI

Common Lisp

CAPI

CLIM

Common Graphics

Lua

IUP

Pascal

Lazarus Component Library

Object Pascal

Component Library for Cross Platform

fpGUI

IP Pascal

FireMonkey

Perl

Perl/Tk

wxPerl

PHP

PHP-GTK

wxPHP

Python

Tkinter

Kivy

PySide

PyQt

PyGTK

wxPython

Pyjs

Ruby

Shoes

QtRuby

Tcl

Tcl/Tk

XML

GladeXML

Lively Kernel

Extensible Application Markup Language

XUL

Wt

shell

Newt

CDK

Dialog

Dart

Flutter

Retrieved from "https://en.wikipedia.org/w/index.php?title=XCB&oldid=1211644569"

Categories: C (programming language) librariesFreedesktop.orgFreedesktop.org librariesSoftware using the MIT licenseX Window SystemHidden categories: Articles with short descriptionShort description is different from WikidataArticles lacking reliable references from November 2009All articles lacking reliable references

This page was last edited on 3 March 2024, at 17:28 (UTC).

Text is available under the Creative Commons Attribution-ShareAlike License 4.0;

additional terms may apply. By using this site, you agree to the Terms of Use and Privacy Policy. Wikipedia® is a registered trademark of the Wikimedia Foundation, Inc., a non-profit organization.

Privacy policy

About Wikipedia

Disclaimers

Contact Wikipedia

Code of Conduct

Developers

Statistics

Cookie statement

Mobile view

Toggle limited content width

Basic Graphics Programming With The XCB Library

Basic Graphics Programming With The XCB Library

Basic Graphics Programming With The XCB Library

Introduction

The client and server model of the X window system

GUI programming: the asynchronous model

Basic XCB notions

The X Connection

Requests and replies: the Xlib killers

The Graphics Context

Object handles

Memory allocation for XCB structures

Events

Using XCB-based programs

Installation of XCB

Compiling XCB-based programs

Opening and closing the connection to an X server

Checking basic information about a connection

Creating a basic window - the "hello world" program

Drawing in a window

Allocating a Graphics Context

Changing the attributes of a Graphics Context

Drawing primitives: point, line, box, circle,...

X Events

Registering for event types using event masks

Receiving events: writing the events loop

Expose events

Getting user input

Mouse button press and release events

Mouse movement events

Mouse pointer enter and leave events

The keyboard focus

Keyboard press and release events

X events: a complete example

Handling text and fonts

The Font structure

Opening a Font

Assigning a Font to a Graphic Context

Drawing text in a drawable

Complete example

Windows hierarchy

Root, parent and child windows

Events propagation

Interacting with the window manager

Window properties

Setting the window name and icon name

Setting preferred window size(s)

Setting miscellaneous window manager hints

Setting an application's icon

Obeying the delete-window protocol

Simple window operations

Mapping and unmapping a window

Configuring a window

Moving a window around the screen

Resizing a window

Changing windows stacking order: raise and lower

Iconifying and de-iconifying a window

Getting informations about a window

Using colors to paint the rainbow

Color maps

Allocating and freeing Color Maps

Allocating and freeing a color entry

Drawing with a color

X Bitmaps and Pixmaps

What is a X Bitmap ? An X Pixmap ?

Loading a bitmap from a file

Drawing a bitmap in a window

Creating a pixmap

Drawing a pixmap in a window

Freeing a pixmap

Messing with the mouse cursor

Creating and destroying a mouse cursor

Setting a window's mouse cursor

Complete example

Translation of basic Xlib functions and macros

Members of the Display structure

ConnectionNumber

DefaultScreen

QLength

ScreenCount

ServerVendor

ProtocolVersion

ProtocolRevision

VendorRelease

DisplayString

BitmapUnit

BitmapBitOrder

BitmapPad

ImageByteOrder

ScreenOfDisplay related functions

ScreenOfDisplay

DefaultScreenOfDisplay

RootWindow / RootWindowOfScreen

DefaultRootWindow

DefaultVisual / DefaultVisualOfScreen

DefaultGC / DefaultGCOfScreen

BlackPixel / BlackPixelOfScreen

WhitePixel / WhitePixelOfScreen

DisplayWidth / WidthOfScreen

DisplayHeight / HeightOfScreen

DisplayWidthMM / WidthMMOfScreen

DisplayHeightMM / HeightMMOfScreen

DisplayPlanes / DefaultDepth / DefaultDepthOfScreen / PlanesOfScreen

DefaultColormap / DefaultColormapOfScreen

MinCmapsOfScreen

MaxCmapsOfScreen

DoesSaveUnders

DoesBackingStore

EventMaskOfScreen

Miscellaneaous macros

DisplayOfScreen

DisplayCells / CellsOfScreen

Introduction

This tutorial is based on the

Xlib Tutorial

written by Guy Keren. The

author allowed me to take some parts of his text, mainly the text which

deals with the X Windows generality.

This tutorial is intended for people who want to start to program

with the XCB

library. keep in mind that XCB, like the

Xlib

library, isn't what most programmers wanting to write X

applications are looking for. They should use a much higher

level GUI toolkit like Motif,

LessTiff,

GTK,

QT,

EWL,

ETK, or use

Cairo.

However,

we need to start somewhere. More than this, knowing how things

work down below is never a bad idea.

After reading this tutorial, one should be able to write very

simple graphical programs, but not programs with decent user

interfaces. For such programs, one of the previously mentioned

libraries should be used.

But what is XCB? Xlib has been

the standard C binding for the X

Window System protocol for many years now. It is an

excellent piece of work, but there are applications for which it

is not ideal, for example:

Small platforms: Xlib is a large piece of code, and

it's difficult to make it smaller

Latency hiding: Xlib requests requiring a reply are

effectively synchronous: they block until the reply appears,

whether the result is needed immediately or not.

Direct access to the protocol: Xlib does quite a

bit of caching, layering, and similar optimizations. While this

is normally a feature, it makes it difficult to simply emit

specified X protocol requests and process specific

responses.

Threaded applications: While Xlib does attempt to

support multithreading, the API makes this difficult and

error-prone.

New extensions: The Xlib infrastructure provides

limited support for the new creation of X extension client side

code.

For these reasons, among others, XCB, an X C binding, has been

designed to solve the above problems and thus provide a base for

Toolkit implementation.

Direct protocol-level programming.

Lightweight emulation of commonly used portions of the

Xlib API.

The client and server model of the X window system

The X Window System was developed with one major goal:

flexibility. The idea was that the way things look is one thing,

but the way things work is another matter. Thus, the lower

levels provide the tools required to draw windows, handle user

input, allow drawing graphics using colors (or black and white

screens), etc. To this point, a decision was made to separate

the system into two parts. A client that decides what to do, and

a server that actually draws on the screen and reads user input

in order to send it to the client for processing.

This model is the complete opposite of what is used to when

dealing with clients and servers. In our case, the user sits

near the machine controlled by the server, while the client

might be running on a remote machine. The server controls the

screens, mouse and keyboard. A client may connect to the server,

request that it draws a window (or several windows), and ask the

server to send it any input the user sends to these

windows. Thus, several clients may connect to a single X server

(one might be running mail software, one running a WWW

browser, etc). When input is sent by the user to some window,

the server sends a message to the client controlling this window

for processing. The client decides what to do with this input,

and sends the server requests for drawing in the window.

The whole session is carried out using the X message

protocol. This protocol was originally carried over the TCP/IP

protocol suite, allowing the client to run on any machine

connected to the same network that the server is. Later on, the

X servers were extended to allow clients running on the local

machine with more optimized access to the server (note that an X

protocol message may be several hundreds of KB in size), such as

using shared memory, or using Unix domain sockets (a method for

creating a logical channel on a Unix system between two processes).

GUI programming: the asynchronous model

Unlike conventional computer programs, that carry some serial

nature, a GUI program usually uses an asynchronous programming

model, also known as "event-driven programming". This means that

that program mostly sits idle, waiting for events sent by the X

server, and then acts upon these events. An event may say "The

user pressed the 1st button mouse in spot (x,y)", or "The window

you control needs to be redrawn". In order for the program to be

responsive to the user input, as well as to refresh requests, it

needs to handle each event in a rather short period of time

(e.g. less that 200 milliseconds, as a rule of thumb).

This also implies that the program may not perform operations

that might take a long time while handling an event (such as

opening a network connection to some remote server, or

connecting to a database server, or even performing a long file

copy operation). Instead, it needs to perform all these

operations in an asynchronous manner. This may be done by using

various asynchronous models to perform the longish operations,

or by performing them in a different process or thread.

So the way a GUI program looks is something like that:

Perform initialization routines.

Connect to the X server.

Perform X-related initialization.

While not finished:

Receive the next event from the X server.

Handle the event, possibly sending various drawing

requests to the X server.

If the event was a quit message, exit the loop.

Close down the connection to the X server.

Perform cleanup operations.

Basic XCB notions

XCB has been created to eliminate the need for

programs to actually implement the X protocol layer. This

library gives a program a very low-level access to any X

server. Since the protocol is standardized, a client using any

implementation of XCB may talk with any X server (the same

occurs for Xlib, of course). We now give a brief description of

the basic XCB notions. They will be detailed later.

The X Connection

The major notion of using XCB is the X Connection. This is a

structure representing the connection we have open with a

given X server. It hides a queue of messages coming from the

server, and a queue of pending requests that our client

intends to send to the server. In XCB, this structure is named

'xcb_connection_t'. It is analogous to the Xlib Display.

When we open a connection to an X server, the

library returns a pointer to such a structure. Later, we

supply this pointer to any XCB function that should send

messages to the X server or receive messages from this server.

Requests and

replies: the Xlib killers

To ask for information from the X server, we have to make a request

and ask for a reply. With Xlib, these two tasks are

automatically done: Xlib locks the system, sends a request,

waits for a reply from the X server and unlocks. This is

annoying, especially if one makes a lot of requests to the X

server. Indeed, Xlib has to wait for the end of a reply

before asking for the next request (because of the locks that

Xlib sends). For example, here is a time-line of N=4

requests/replies with Xlib, with a round-trip latency

T_round_trip that is 5 times long as the time required

to write or read a request/reply (T_write/T_read):

W-----RW-----RW-----RW-----R

W: Writing request

-: Stalled, waiting for data

R: Reading reply

The total time is N * (T_write + T_round_trip + T_read).

With XCB, we can suppress most of the round-trips as the

requests and the replies are not locked. We usually send a

request, then XCB returns to us a cookie, which is an

identifier. Then, later, we ask for a reply using this

cookie and XCB returns a

pointer to that reply. Hence, with XCB, we can send a lot of

requests, and later in the program, ask for all the replies

when we need them. Here is the time-line for 4

requests/replies when we use this property of XCB:

WWWW--RRRR

The total time is N * T_write + max (0, T_round_trip - (N-1) *

T_write) + N * T_read. Which can be considerably faster than

all those Xlib round-trips.

Here is a program that computes the time to create 500 atoms

with Xlib and XCB. It shows the Xlib way, the bad XCB way

(which is similar to Xlib) and the good XCB way. On my

computer, XCB is 25 times faster than Xlib.

#include

#include

#include

#include

#include

#include

double

get_time(void)

{

struct timeval timev;

gettimeofday(&timev, NULL);

return (double)timev.tv_sec + (((double)timev.tv_usec) / 1000000);

}

int

main ()

{

xcb_connection_t *c;

xcb_atom_t *atoms;

xcb_intern_atom_cookie_t *cs;

char **names;

int count;

int i;

double start;

double end;

double diff;

/* Xlib */

Display *disp;

Atom *atoms_x;

double diff_x;

c = xcb_connect (NULL, NULL);

count = 500;

atoms = (xcb_atom_t *)malloc (count * sizeof (atoms));

names = (char **)malloc (count * sizeof (char *));

/* init names */

for (i = 0; i < count; ++i) {

char buf[100];

sprintf (buf, "NAME%d", i);

names[i] = strdup (buf);

}

/* bad use */

start = get_time ();

for (i = 0; i < count; ++i)

atoms[i] = xcb_intern_atom_reply (c,

xcb_intern_atom (c,

0,

strlen(names[i]),

names[i]),

NULL)->atom;

end = get_time ();

diff = end - start;

printf ("bad use time : %f\n", diff);

/* good use */

start = get_time ();

cs = (xcb_intern_atom_cookie_t *) malloc (count * sizeof(xcb_intern_atom_cookie_t));

for(i = 0; i < count; ++i)

cs[i] = xcb_intern_atom (c, 0, strlen(names[i]), names[i]);

for(i = 0; i < count; ++i) {

xcb_intern_atom_reply_t *r;

r = xcb_intern_atom_reply(c, cs[i], 0);

if(r)

atoms[i] = r->atom;

free(r);

}

end = get_time ();

printf ("good use time : %f\n", end - start);

printf ("ratio : %f\n", diff / (end - start));

diff = end - start;

/* free var */

free (atoms);

free (cs);

xcb_disconnect (c);

/* Xlib */

disp = XOpenDisplay (getenv("DISPLAY"));

atoms_x = (Atom *)malloc (count * sizeof (atoms_x));

start = get_time ();

for (i = 0; i < count; ++i)

atoms_x[i] = XInternAtom(disp, names[i], 0);

end = get_time ();

diff_x = end - start;

printf ("Xlib use time : %f\n", diff_x);

printf ("ratio : %f\n", diff_x / diff);

free (atoms_x);

for (i = 0; i < count; ++i)

free (names[i]);

free (names);

XCloseDisplay (disp);

return 0;

}

The Graphic Context

When we perform various drawing operations (graphics, text,

etc), we may specify various options for controlling how the

data will be drawn (what foreground and background colors to

use, how line edges will be connected, what font to use when

drawing some text, etc). In order to avoid the need to supply

hundreds of parameters to each drawing function, a graphical

context structure is used. We set the various drawing options

in this structure, and then we pass a pointer to this

structure to any drawing routines. This is rather handy, as we

often need to perform several drawing requests with the same

options. Thus, we would initialize a graphical context, set

the desired options, and pass this structure to all drawing

functions.

Note that graphic contexts have no client-side structure in

XCB, they're just XIDs. Xlib has a client-side structure

because it caches the GC contents so it can avoid making

redundant requests, but of course XCB doesn't do that.

Events

A structure is used to pass events received from the X

server. XCB supports exactly the events specified in the

protocol (33 events). This structure contains the type

of event received (including a bit for whether it came

from the server or another client), as well as the data associated with the

event (e.g. position on the screen where the event was

generated, mouse button associated with the event, region of

the screen associated with a "redraw" event, etc). The way to

read the event's data depends on the event type.

Using XCB-based programs

Installation of XCB

TODO: These instructions are out of date.

Just reference the main XCB page

so we don't have to maintain these instructions in more than

one place.

To build XCB from source, you need to have installed at

least:

pkgconfig 0.15.0

automake 1.7

autoconf 2.50

check

xsltproc

gperf 3.0.1

You have to checkout in the git repository the following modules:

Xau from xlibs

xcb-proto

xcb

Note that xcb-proto exists only to install header

files, so typing 'make' or 'make all' will produce the message

"Nothing to be done for 'all'". That's normal.

Compiling XCB-based programs

Compiling XCB-based programs requires linking them with the XCB

library. This is easily done thanks to pkgconfig:

gcc -Wall prog.c -o prog `pkg-config --cflags --libs xcb`

Opening and closing the connection to an X server

An X program first needs to open the connection to the X

server. There is a function that opens a connection. It requires

the display name, or NULL. In the latter case, the display name

will be the one in the environment variable DISPLAY.

xcb_connection_t *xcb_connect (const char *displayname,

int *screenp);

The second parameter returns the screen number used for the

connection. The returned structure describes an XCB connection

and is opaque. Here is how the connection can be opened:

#include

int

main ()

{

xcb_connection_t *c;

/* Open the connection to the X server. Use the DISPLAY environment variable as the default display name */

c = xcb_connect (NULL, NULL);

return 0;

}

To close a connection, it suffices to use:

void xcb_disconnect (xcb_connection_t *c);

Comparison Xlib/XCB

XOpenDisplay ()

xcb_connect ()

XCloseDisplay ()

xcb_disconnect ()

Checking basic information about a connection

Once we have opened a connection to an X server, we should check some

basic information about it: what screens it has, what is the

size (width and height) of the screen, how many colors it

supports (black and white ? grey scale ?, 256 colors ? more ?),

and so on. We get such information from the xcb_screen_t

structure:

typedef struct {

xcb_window_t root;

xcb_colormap_t default_colormap;

uint32_t white_pixel;

uint32_t black_pixel;

uint32_t current_input_masks;

uint16_t width_in_pixels;

uint16_t height_in_pixels;

uint16_t width_in_millimeters;

uint16_t height_in_millimeters;

uint16_t min_installed_maps;

uint16_t max_installed_maps;

xcb_visualid_t root_visual;

uint8_t backing_stores;

uint8_t save_unders;

uint8_t root_depth;

uint8_t allowed_depths_len;

} xcb_screen_t;

We could retrieve the first screen of the connection by using the

following function:

xcb_screen_iterator_t xcb_setup_roots_iterator (xcb_setup_t *R);

Here is a small program that shows how to use this function:

#include

#include

int

main ()

{

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

xcb_screen_iterator_t iter;

/* Open the connection to the X server. Use the DISPLAY environment variable */

c = xcb_connect (NULL, &screen_nbr);

/* Get the screen #screen_nbr */

iter = xcb_setup_roots_iterator (xcb_get_setup (c));

for (; iter.rem; --screen_nbr, xcb_screen_next (&iter))

if (screen_nbr == 0) {

screen = iter.data;

break;

}

printf ("\n");

printf ("Informations of screen %ld:\n", screen->root);

printf (" width.........: %d\n", screen->width_in_pixels);

printf (" height........: %d\n", screen->height_in_pixels);

printf (" white pixel...: %ld\n", screen->white_pixel);

printf (" black pixel...: %ld\n", screen->black_pixel);

printf ("\n");

return 0;

}

Creating a basic window - the "hello world" program

After we got some basic information about our screen, we can

create our first window. In the X Window System, a window is

characterized by an Id. So, in XCB, a window is of type:

typedef uint32_t xcb_window_t;

We first ask for a new Id for our window, with this function:

xcb_window_t xcb_generate_id(xcb_connection_t *c);

Then, XCB supplies the following function to create new windows:

xcb_void_cookie_t xcb_create_window (xcb_connection_t *c, /* Pointer to the xcb_connection_t structure */

uint8_t depth, /* Depth of the screen */

xcb_window_t wid, /* Id of the window */

xcb_window_t parent, /* Id of an existing window that should be the parent of the new window */

int16_t x, /* X position of the top-left corner of the window (in pixels) */

int16_t y, /* Y position of the top-left corner of the window (in pixels) */

uint16_t width, /* Width of the window (in pixels) */

uint16_t height, /* Height of the window (in pixels) */

uint16_t border_width, /* Width of the window's border (in pixels) */

uint16_t _class,

xcb_visualid_t visual,

uint32_t value_mask,

const uint32_t *value_list);

The fact that we created the window does not mean that it will

be drawn on screen. By default, newly created windows are not

mapped on the screen (they are invisible). In order to make our

window visible, we use the function xcb_map_window(), whose

prototype is

xcb_void_cookie_t xcb_map_window (xcb_connection_t *c,

xcb_window_t window);

Finally, here is a small program to create a window of size

150x150 pixels, positioned at the top-left corner of the screen:

#include /* pause() */

#include

int

main ()

{

xcb_connection_t *c;

xcb_screen_t *screen;

xcb_window_t win;

/* Open the connection to the X server */

c = xcb_connect (NULL, NULL);

/* Get the first screen */

screen = xcb_setup_roots_iterator (xcb_get_setup (c)).data;

/* Ask for our window's Id */

win = xcb_generate_id(c);

/* Create the window */

xcb_create_window (c, /* Connection */

XCB_COPY_FROM_PARENT, /* depth (same as root)*/

win, /* window Id */

screen->root, /* parent window */

0, 0, /* x, y */

150, 150, /* width, height */

10, /* border_width */

XCB_WINDOW_CLASS_INPUT_OUTPUT, /* class */

screen->root_visual, /* visual */

0, NULL); /* masks, not used yet */

/* Map the window on the screen */

xcb_map_window (c, win);

/* Make sure commands are sent before we pause, so window is shown */

xcb_flush (c);

pause (); /* hold client until Ctrl-C */

return 0;

}

In this code, you see one more function - xcb_flush(), not explained

yet. It is used to flush all the pending requests. More

precisely, there are 2 functions that do such things. The first

one is xcb_flush():

int xcb_flush (xcb_connection_t *c);

This function flushes all pending requests to the X server (much

like the fflush() function is used to

flush standard output). The second function is

xcb_aux_sync():

int xcb_aux_sync (xcb_connection_t *c);

This functions also flushes all pending requests to the X

server, and then waits until the X server finishing processing

these requests. In a normal program, this will not be necessary

(we'll see why when we get to write a normal X program), but for

now, we put it there.

The window that is created by the above code has a non defined

background. This one can be set to a specific color,

thanks to the two last parameters of

xcb_create_window(), which are not

described yet. See the subsections

Configuring a window or

Registering for event types using event masks

for examples on how to use these parameters. In addition, as no

events are handled, you have to make a Ctrl-C to interrupt the

program.

TODO: one should tell what these functions return and

about the generic error

Comparison Xlib/XCB

XCreateWindow ()

xcb_generate_id ()

xcb_create_window ()

Drawing in a window

Drawing in a window can be done using various graphical

functions (drawing pixels, lines, rectangles, etc). In order to

draw in a window, we first need to define various general

drawing parameters (what line width to use, which color to draw

with, etc). This is done using a graphical context.

Allocating a Graphics Context

As we said, a graphical context defines several attributes to

be used with the various drawing functions. For this, we

define a graphical context. We can use more than one graphical

context with a single window, in order to draw in multiple

styles (different colors, different line widths, etc). In XCB,

a Graphics Context is, as a window, characterized by an Id:

typedef uint32_t xcb_gcontext_t;

We first ask the X server to attribute an Id to our graphic

context with this function:

xcb_gcontext_t xcb_generate_id (xcb_connection_t *c);

Then, we set the attributes of the graphic context with this function:

xcb_void_cookie_t xcb_create_gc (xcb_connection_t *c,

xcb_gcontext_t cid,

xcb_drawable_t drawable,

uint32_t value_mask,

const uint32_t *value_list);

We give now an example on how to allocate a graphic context

that specifies that each drawing function that uses it will

draw in foreground with a black color.

#include

int

main ()

{

xcb_connection_t *c;

xcb_screen_t *screen;

xcb_drawable_t win;

xcb_gcontext_t black;

uint32_t mask;

uint32_t value[1];

/* Open the connection to the X server and get the first screen */

c = xcb_connect (NULL, NULL);

screen = xcb_setup_roots_iterator (xcb_get_setup (c)).data;

/* Create a black graphic context for drawing in the foreground */

win = screen->root;

black = xcb_generate_id (c);

mask = XCB_GC_FOREGROUND;

value[0] = screen->black_pixel;

xcb_create_gc (c, black, win, mask, value);

return 0;

}

Note should be taken regarding the role of "value_mask" and

"value_list" in the prototype of xcb_create_gc(). Since a

graphic context has many attributes, and since we often just

want to define a few of them, we need to be able to tell the

xcb_create_gc() which attributes we

want to set. This is what the "value_mask" parameter is

for. We then use the "value_list" parameter to specify actual

values for the attribute we defined in "value_mask". Thus, for

each constant used in "value_list", we will use the matching

constant in "value_mask". In this case, we define a graphic

context with one attribute: when drawing (a point, a line,

etc), the foreground color will be black. The rest of the

attributes of this graphic context will be set to their

default values.

See the next Subsection for more details.

Comparison Xlib/XCB

XCreateGC ()

xcb_generate_id ()

xcb_create_gc ()

Changing the attributes of a Graphics Context

Once we have allocated a Graphic Context, we may need to

change its attributes (for example, changing the foreground

color we use to draw a line, or changing the attributes of the

font we use to display strings. See Subsections Drawing with a

color and

Assigning a Font to a Graphic Context).

This is done by using this function:

xcb_void_cookie_t xcb_change_gc (xcb_connection_t *c, /* The XCB Connection */

xcb_gcontext_t gc, /* The Graphic Context */

uint32_t value_mask, /* Components of the Graphic Context that have to be set */

const uint32_t *value_list); /* Value as specified by value_mask */

The value_mask parameter could take

any combination of these masks from the xcb_gc_t enumeration:

XCB_GC_FUNCTION

XCB_GC_PLANE_MASK

XCB_GC_FOREGROUND

XCB_GC_BACKGROUND

XCB_GC_LINE_WIDTH

XCB_GC_LINE_STYLE

XCB_GC_CAP_STYLE

XCB_GC_JOIN_STYLE

XCB_GC_FILL_STYLE

XCB_GC_FILL_RULE

XCB_GC_TILE

XCB_GC_STIPPLE

XCB_GC_TILE_STIPPLE_ORIGIN_X

XCB_GC_TILE_STIPPLE_ORIGIN_Y

XCB_GC_FONT

XCB_GC_SUBWINDOW_MODE

XCB_GC_GRAPHICS_EXPOSURES

XCB_GC_CLIP_ORIGIN_X

XCB_GC_CLIP_ORIGIN_Y

XCB_GC_CLIP_MASK

XCB_GC_DASH_OFFSET

XCB_GC_DASH_LIST

XCB_GC_ARC_MODE

It is possible to set several attributes at the same

time (for example setting the attributes of a font and the

color which will be used to display a string), by OR'ing these

values in value_mask. Then

value_list has to be an array which

lists the value for the respective attributes. These values

must be in the same order as masks listed above. See Subsection

Drawing with a color to have an example.

TODO: set the links of the 3 subsections, once they will

be written :)

TODO: give an example which sets several attributes.

Drawing primitives: point, line, box, circle,...

After we have created a Graphic Context, we can draw on a

window using this Graphic Context, with a set of XCB

functions, collectively called "drawing primitives". Let see

how they are used.

To draw a point, or several points, we use

xcb_void_cookie_t xcb_poly_point (xcb_connection_t *c, /* The connection to the X server */

uint8_t coordinate_mode, /* Coordinate mode, usually set to XCB_COORD_MODE_ORIGIN */

xcb_drawable_t drawable, /* The drawable on which we want to draw the point(s) */

xcb_gcontext_t gc, /* The Graphic Context we use to draw the point(s) */

uint32_t points_len, /* The number of points */

const xcb_point_t *points); /* An array of points */

The coordinate_mode parameter

specifies the coordinate mode. Available values are

XCB_COORD_MODE_ORIGIN

XCB_COORD_MODE_PREVIOUS

If XCB_COORD_MODE_PREVIOUS is used, then all points but the first one

are relative to the immediately previous point.

The xcb_point_t type is just a

structure with two fields (the coordinates of the point):

typedef struct {

int16_t x;

int16_t y;

} xcb_point_t;

You could see an example in xpoints.c. TODO Set the link.

To draw a line, or a polygonal line, we use

xcb_void_cookie_t xcb_poly_line (xcb_connection_t *c, /* The connection to the X server */

uint8_t coordinate_mode, /* Coordinate mode, usually set to XCB_COORD_MODE_ORIGIN */

xcb_drawable_t drawable, /* The drawable on which we want to draw the line(s) */

xcb_gcontext_t gc, /* The Graphic Context we use to draw the line(s) */

uint32_t points_len, /* The number of points in the polygonal line */

const xcb_point_t *points); /* An array of points */

This function will draw the line between the first and the

second points, then the line between the second and the third

points, and so on.

To draw a segment, or several segments, we use

xcb_void_cookie_t xcb_poly_segment (xcb_connection_t *c, /* The connection to the X server */

xcb_drawable_t drawable, /* The drawable on which we want to draw the segment(s) */

xcb_gcontext_t gc, /* The Graphic Context we use to draw the segment(s) */

uint32_t segments_len, /* The number of segments */

const xcb_segment_t *segments); /* An array of segments */

The xcb_segment_t type is just a

structure with four fields (the coordinates of the two points

that define the segment):

typedef struct {

int16_t x1;

int16_t y1;

int16_t x2;

int16_t y2;

} xcb_segment_t;

To draw a rectangle, or several rectangles, we use

xcb_void_cookie_t xcb_poly_rectangle (xcb_connection_t *c, /* The connection to the X server */

xcb_drawable_t drawable, /* The drawable on which we want to draw the rectangle(s) */

xcb_gcontext_t gc, /* The Graphic Context we use to draw the rectangle(s) */

uint32_t rectangles_len, /* The number of rectangles */

const xcb_rectangle_t *rectangles); /* An array of rectangles */

The xcb_rectangle_t type is just a

structure with four fields (the coordinates of the top-left

corner of the rectangle, and its width and height):

typedef struct {

int16_t x;

int16_t y;

uint16_t width;

uint16_t height;

} xcb_rectangle_t;

To draw an elliptical arc, or several elliptical arcs, we use

xcb_void_cookie_t xcb_poly_arc (xcb_connection_t *c, /* The connection to the X server */

xcb_drawable_t drawable, /* The drawable on which we want to draw the arc(s) */

xcb_gcontext_t gc, /* The Graphic Context we use to draw the arc(s) */

uint32_t arcs_len, /* The number of arcs */

const xcb_arc_t *arcs); /* An array of arcs */

The xcb_arc_t type is a structure with

six fields:

typedef struct {

int16_t x; /* Top left x coordinate of the rectangle surrounding the ellipse */

int16_t y; /* Top left y coordinate of the rectangle surrounding the ellipse */

uint16_t width; /* Width of the rectangle surrounding the ellipse */

uint16_t height; /* Height of the rectangle surrounding the ellipse */

int16_t angle1; /* Angle at which the arc begins */

int16_t angle2; /* Angle at which the arc ends */

} xcb_arc_t;

Note: the angles are expressed in units of 1/64 of a degree,

so to have an angle of 90 degrees, starting at 0,

angle1 = 0 and

angle2 = 90 << 6. Positive angles

indicate counterclockwise motion, while negative angles

indicate clockwise motion.

The corresponding function which fill inside the geometrical

object are listed below, without further explanation, as they

are used as the above functions.

To Fill a polygon defined by the points given as arguments ,

we use

xcb_void_cookie_t xcb_fill_poly (xcb_connection_t *c,

xcb_drawable_t drawable,

xcb_gcontext_t gc,

uint8_t shape,

uint8_t coordinate_mode,

uint32_t points_len,

const xcb_point_t *points);

The shape parameter specifies a

shape that helps the server to improve performance. Available

values are

XCB_POLY_SHAPE_COMPLEX

XCB_POLY_SHAPE_NONCONVEX

XCB_POLY_SHAPE_CONVEX

To fill one or several rectangles, we use

xcb_void_cookie_t xcb_poly_fill_rectangle (xcb_connection_t *c,

xcb_drawable_t drawable,

xcb_gcontext_t gc,

uint32_t rectangles_len,

const xcb_rectangle_t *rectangles);

To fill one or several arcs, we use

xcb_void_cookie_t xcb_poly_fill_arc (xcb_connection_t *c,

xcb_drawable_t drawable,

xcb_gcontext_t gc,

uint32_t arcs_len,

const xcb_arc_t *arcs);

To illustrate these functions, here is an example that draws

four points, a polygonal line, two segments, two rectangles

and two arcs. Remark that we use events for the first time, as

an introduction to the next section.

TODO: Use screen->root_depth for depth parameter.

#include

#include

#include

int

main ()

{

xcb_connection_t *c;

xcb_screen_t *screen;

xcb_drawable_t win;

xcb_gcontext_t foreground;

xcb_generic_event_t *e;

uint32_t mask = 0;

uint32_t values[2];

/* geometric objects */

xcb_point_t points[] = {

{10, 10},

{10, 20},

{20, 10},

{20, 20}};

xcb_point_t polyline[] = {

{50, 10},

{ 5, 20}, /* rest of points are relative */

{25,-20},

{10, 10}};

xcb_segment_t segments[] = {

{100, 10, 140, 30},

{110, 25, 130, 60}};

xcb_rectangle_t rectangles[] = {

{ 10, 50, 40, 20},

{ 80, 50, 10, 40}};

xcb_arc_t arcs[] = {

{10, 100, 60, 40, 0, 90 << 6},

{90, 100, 55, 40, 0, 270 << 6}};

/* Open the connection to the X server */

c = xcb_connect (NULL, NULL);

/* Get the first screen */

screen = xcb_setup_roots_iterator (xcb_get_setup (c)).data;

/* Create black (foreground) graphic context */

win = screen->root;

foreground = xcb_generate_id (c);

mask = XCB_GC_FOREGROUND | XCB_GC_GRAPHICS_EXPOSURES;

values[0] = screen->black_pixel;

values[1] = 0;

xcb_create_gc (c, foreground, win, mask, values);

/* Ask for our window's Id */

win = xcb_generate_id(c);

/* Create the window */

mask = XCB_CW_BACK_PIXEL | XCB_CW_EVENT_MASK;

values[0] = screen->white_pixel;

values[1] = XCB_EVENT_MASK_EXPOSURE;

xcb_create_window (c, /* Connection */

XCB_COPY_FROM_PARENT, /* depth */

win, /* window Id */

screen->root, /* parent window */

0, 0, /* x, y */

150, 150, /* width, height */

10, /* border_width */

XCB_WINDOW_CLASS_INPUT_OUTPUT, /* class */

screen->root_visual, /* visual */

mask, values); /* masks */

/* Map the window on the screen */

xcb_map_window (c, win);

/* We flush the request */

xcb_flush (c);

while ((e = xcb_wait_for_event (c))) {

switch (e->response_type & ~0x80) {

case XCB_EXPOSE: {

/* We draw the points */

xcb_poly_point (c, XCB_COORD_MODE_ORIGIN, win, foreground, 4, points);

/* We draw the polygonal line */

xcb_poly_line (c, XCB_COORD_MODE_PREVIOUS, win, foreground, 4, polyline);

/* We draw the segements */

xcb_poly_segment (c, win, foreground, 2, segments);

/* We draw the rectangles */

xcb_poly_rectangle (c, win, foreground, 2, rectangles);

/* We draw the arcs */

xcb_poly_arc (c, win, foreground, 2, arcs);

/* We flush the request */

xcb_flush (c);

break;

}

default: {

/* Unknown event type, ignore it */

break;

}

}

/* Free the Generic Event */

free (e);

}

return 0;

}

X Events

In an X program, everything is driven by events. Event painting

on the screen is sometimes done as a response to an event (an

Expose event). If part of a program's

window that was hidden, gets exposed (e.g. the window was raised

above other widows), the X server will send an "expose" event to

let the program know it should repaint that part of the

window. User input (key presses, mouse movement, etc) is also

received as a set of events.

Registering for event types using event masks

During the creation of a window, you should give it what kind

of events it wishes to receive. Thus, you may register for

various mouse (also called pointer) events, keyboard events,

expose events, and so on. This is done for optimizing the

server-to-client connection (i.e. why send a program (that

might even be running at the other side of the globe) an event

it is not interested in ?)

In XCB, you use the "value_mask" and "value_list" data in the

xcb_create_window() function to

register for events. Here is how we register for

Expose event when creating a window:

mask = XCB_CW_EVENT_MASK;

valwin[0] = XCB_EVENT_MASK_EXPOSURE;

win = xcb_generate_id (c);

xcb_create_window (c, depth, win, root->root,

0, 0, 150, 150, 10,

XCB_WINDOW_CLASS_INPUT_OUTPUT, root->root_visual,

mask, valwin);

XCB_EVENT_MASK_EXPOSURE is a constant defined

in the xcb_event_mask_t enumeration in the "xproto.h" header file. If we wanted to register for several

event types, we can logically "or" them, as follows:

mask = XCB_CW_EVENT_MASK;

valwin[0] = XCB_EVENT_MASK_EXPOSURE | XCB_EVENT_MASK_BUTTON_PRESS;

win = xcb_generate_id (c);

xcb_create_window (c, depth, win, root->root,

0, 0, 150, 150, 10,

XCB_WINDOW_CLASS_INPUT_OUTPUT, root->root_visual,

mask, valwin);

This registers for Expose events as

well as for mouse button presses inside the created

window. You should note that a mask may represent several

event sub-types.

The values that a mask could take are given

by the xcb_cw_t enumeration:

typedef enum {

XCB_CW_BACK_PIXMAP = 1L<<0,

XCB_CW_BACK_PIXEL = 1L<<1,

XCB_CW_BORDER_PIXMAP = 1L<<2,

XCB_CW_BORDER_PIXEL = 1L<<3,

XCB_CW_BIT_GRAVITY = 1L<<4,

XCB_CW_WIN_GRAVITY = 1L<<5,

XCB_CW_BACKING_STORE = 1L<<6,

XCB_CW_BACKING_PLANES = 1L<<7,

XCB_CW_BACKING_PIXEL = 1L<<8,

XCB_CW_OVERRIDE_REDIRECT = 1L<<9,

XCB_CW_SAVE_UNDER = 1L<<10,

XCB_CW_EVENT_MASK = 1L<<11,

XCB_CW_DONT_PROPAGATE = 1L<<12,

XCB_CW_COLORMAP = 1L<<13,

XCB_CW_CURSOR = 1L<<14

} xcb_cw_t;

Note: we must be careful when setting the values of the valwin

parameter, as they have to follow the order the

xcb_cw_t enumeration. Here is an

example:

mask = XCB_CW_EVENT_MASK | XCB_CW_BACK_PIXMAP;

valwin[0] = XCB_NONE; /* for XCB_CW_BACK_PIXMAP (whose value is 1) */

valwin[1] = XCB_EVENT_MASK_EXPOSURE | XCB_EVENT_MASK_BUTTON_PRESS; /* for XCB_CW_EVENT_MASK, whose value (2048) */

/* is greater than the one of XCB_CW_BACK_PIXMAP */

If the window has already been created, we can use the

xcb_change_window_attributes() function to set

the events that the window will receive. The subsection

Configuring a window shows its

prototype. As an example, here is a piece of code that

configures the window to receive the

Expose and

ButtonPress events:

const static uint32_t values[] = { XCB_EVENT_MASK_EXPOSURE | XCB_EVENT_MASK_BUTTON_PRESS };

/* The connection c and the window win are supposed to be defined */

xcb_change_window_attributes (c, win, XCB_CW_EVENT_MASK, values);

Note: A common bug programmers do is adding code to handle new

event types in their program, while forgetting to add the

masks for these events in the creation of the window. Such a

programmer then should sit down for hours debugging his

program, wondering "Why doesn't my program notice that I

released the button?", only to find that they registered for

button press events but not for button release events.

Receiving events: writing the events loop

After we have registered for the event types we are interested

in, we need to enter a loop of receiving events and handling

them. There are two ways to receive events: a blocking way and

a non-blocking way:

xcb_wait_for_event (xcb_connection_t *c)

is the blocking way. It waits (so blocks...) until an event is

queued in the X server. Then it retrieves it into a newly

allocated structure (it dequeues it from the queue) and returns

it. This structure has to be freed. The function returns

NULL if an error occurs.

xcb_poll_for_event (xcb_connection_t *c, int

*error) is the non-blocking way. It looks at the event

queue and returns (and dequeues too) an existing event into

a newly allocated structure. This structure has to be

freed. It returns NULL if there is

no event. If an error occurs, the parameter error will be filled with the error

status.

There are various ways to write such a loop. We present two

ways to write such a loop, with the two functions above. The

first one uses xcb_wait_for_event_t, which

is similar to an event Xlib loop using only XNextEvent:

xcb_generic_event_t *e;

while ((e = xcb_wait_for_event (c))) {

switch (e->response_type & ~0x80) {

case XCB_EXPOSE: {

/* Handle the Expose event type */

xcb_expose_event_t *ev = (xcb_expose_event_t *)e;

/* ... */

break;

}

case XCB_BUTTON_PRESS: {

/* Handle the ButtonPress event type */

xcb_button_press_event_t *ev = (xcb_button_press_event_t *)e;

/* ... */

break;

}

default: {

/* Unknown event type, ignore it */

break;

}

}

/* Free the Generic Event */

free (e);

}

You will certainly want to use xcb_poll_for_event(xcb_connection_t *c, int

*error) if, in Xlib, you use XPending or

XCheckMaskEvent:

while (XPending (display)) {

XEvent ev;

XNextEvent(d, &ev);

/* Manage your event */

}

Such a loop in XCB looks like:

xcb_generic_event_t *ev;

while ((ev = xcb_poll_for_event (conn, 0))) {

/* Manage your event */

}

The events are managed in the same way as with xcb_wait_for_event_t.

Obviously, we will need to give the user some way of

terminating the program. This is usually done by handling a

special "quit" event, as we will soon see.

Comparison Xlib/XCB

XNextEvent ()

xcb_wait_for_event ()

XPending ()

XCheckMaskEvent ()

xcb_poll_for_event ()

Expose events

The Expose event is one of the most

basic (and most used) events an application may receive. It

will be sent to us in one of several cases:

A window that covered part of our window has moved

away, exposing part (or all) of our window.

Our window was raised above other windows.

Our window mapped for the first time.

Our window was de-iconified.

You should note the implicit assumption hidden here: the

contents of our window is lost when it is being obscured

(covered) by either windows. One may wonder why the X server

does not save this contents. The answer is: to save

memory. After all, the number of windows on a display at a

given time may be very large, and storing the contents of all

of them might require a lot of memory. Actually, there is a

way to tell the X server to store the contents of a window in

special cases, as we will see later.

When we get an Expose event, we

should take the event's data from the members of the following

structure:

typedef struct {

uint8_t response_type; /* The type of the event, here it is XCB_EXPOSE */

uint8_t pad0;

uint16_t sequence;

xcb_window_t window; /* The Id of the window that receives the event (in case */

/* our application registered for events on several windows */

uint16_t x; /* The x coordinate of the top-left part of the window that needs to be redrawn */

uint16_t y; /* The y coordinate of the top-left part of the window that needs to be redrawn */

uint16_t width; /* The width of the part of the window that needs to be redrawn */

uint16_t height; /* The height of the part of the window that needs to be redrawn */

uint16_t count;

} xcb_expose_event_t;

Getting user input

User input traditionally comes from two sources: the mouse

and the keyboard. Various event types exist to notify us of

user input (a key being presses on the keyboard, a key being

released on the keyboard, the mouse moving over our window,

the mouse entering (or leaving) our window, and so on.

Mouse button press and release events

The first event type we will deal with is a mouse

button-press (or button-release) event in our window. In

order to register to such an event type, we should add one

(or more) of the following masks when we create our window:

XCB_EVENT_MASK_BUTTON_PRESS: notify us

of any button that was pressed in one of our windows.

XCB_EVENT_MASK_BUTTON_RELEASE: notify us

of any button that was released in one of our windows.

The structure to be checked for in our events loop is the

same for these two events, and is the following:

typedef struct {

uint8_t response_type; /* The type of the event, here it is xcb_button_press_event_t or xcb_button_release_event_t */

xcb_button_t detail;

uint16_t sequence;

xcb_timestamp_t time; /* Time, in milliseconds the event took place in */

xcb_window_t root;

xcb_window_t event;

xcb_window_t child;

int16_t root_x;

int16_t root_y;

int16_t event_x; /* The x coordinate where the mouse has been pressed in the window */

int16_t event_y; /* The y coordinate where the mouse has been pressed in the window */

uint16_t state; /* A mask of the buttons (or keys) during the event */

uint8_t same_screen;

} xcb_button_press_event_t;

typedef xcb_button_press_event_t xcb_button_release_event_t;

The time field may be used to calculate "double-click"

situations by an application (e.g. if the mouse button was

clicked two times in a duration shorter than a given amount

of time, assume this was a double click).

The state field is a mask of the buttons held down during

the event. It is a bitwise OR of any of the following (from the xcb_button_mask_t and

xcb_mod_mask_t enumerations):

XCB_BUTTON_MASK_1

XCB_BUTTON_MASK_2

XCB_BUTTON_MASK_3

XCB_BUTTON_MASK_4

XCB_BUTTON_MASK_5

XCB_MOD_MASK_SHIFT

XCB_MOD_MASK_LOCK

XCB_MOD_MASK_CONTROL

XCB_MOD_MASK_1

XCB_MOD_MASK_2

XCB_MOD_MASK_3

XCB_MOD_MASK_4

XCB_MOD_MASK_5

Their names are self explanatory, where the first 5 refer to

the mouse buttons that are being pressed, while the rest

refer to various "special keys" that are being pressed (Mod1

is usually the 'Alt' key or the 'Meta' key).

TODO: Problem: it seems that the state does not

change when clicking with various buttons.

Mouse movement events

Similar to mouse button press and release events, we also

can be notified of various mouse movement events. These can

be split into two families. One is of mouse pointer

movement while no buttons are pressed, and the second is a

mouse pointer motion while one (or more) of the buttons are

pressed (this is sometimes called "a mouse drag operation",

or just "dragging"). The following event masks may be added

during the creation of our window:

XCB_EVENT_MASK_POINTER_MOTION: events of

the pointer moving in one of the windows controlled by our

application, while no mouse button is held pressed.

XCB_EVENT_MASK_BUTTON_MOTION: Events of

the pointer moving while one or more of the mouse buttons

is held pressed.

XCB_EVENT_MASK_BUTTON_1_MOTION: same as

XCB_EVENT_MASK_BUTTON_MOTION, but only when

the 1st mouse button is held pressed.

XCB_EVENT_MASK_BUTTON_2_MOTION,

XCB_EVENT_MASK_BUTTON_3_MOTION,

XCB_EVENT_MASK_BUTTON_4_MOTION,

XCB_EVENT_MASK_BUTTON_5_MOTION: same as

XCB_EVENT_MASK_BUTTON_1_MOTION, but

respectively for 2nd, 3rd, 4th and 5th mouse button.

The structure to be checked for in our events loop is the

same for these events, and is the following:

typedef struct {

uint8_t response_type; /* The type of the event */

uint8_t detail;

uint16_t sequence;

xcb_timestamp_t time; /* Time, in milliseconds the event took place in */

xcb_window_t root;

xcb_window_t event;

xcb_window_t child;

int16_t root_x;

int16_t root_y;

int16_t event_x; /* The x coordinate of the mouse when the event was generated */

int16_t event_y; /* The y coordinate of the mouse when the event was generated */

uint16_t state; /* A mask of the buttons (or keys) during the event */

uint8_t same_screen;

} xcb_motion_notify_event_t;

Mouse pointer enter and leave events

Another type of event that applications might be interested

in, is a mouse pointer entering a window the program

controls, or leaving such a window. Some programs use these

events to show the user that the application is now in

focus. In order to register for such an event type, we

should add one (or more) of the following masks when we

create our window:

xcb_event_enter_window_t: notify us

when the mouse pointer enters any of our controlled

windows.

xcb_event_leave_window_t: notify us

when the mouse pointer leaves any of our controlled

windows.

The structure to be checked for in our events loop is the

same for these two events, and is the following:

typedef struct {

uint8_t response_type; /* The type of the event */

uint8_t detail;

uint16_t sequence;

xcb_timestamp_t time; /* Time, in milliseconds the event took place in */

xcb_window_t root;

xcb_window_t event;

xcb_window_t child;

int16_t root_x;

int16_t root_y;

int16_t event_x; /* The x coordinate of the mouse when the event was generated */

int16_t event_y; /* The y coordinate of the mouse when the event was generated */

uint16_t state; /* A mask of the buttons (or keys) during the event */

uint8_t mode; /* The number of mouse button that was clicked */

uint8_t same_screen_focus;

} xcb_enter_notify_event_t;

typedef xcb_enter_notify_event_t xcb_leave_notify_event_t;

The keyboard focus

There may be many windows on a screen, but only a single

keyboard attached to them. How does the X server then know

which window should be sent a given keyboard input ? This is

done using the keyboard focus. Only a single window on the

screen may have the keyboard focus at a given time. There

is a XCB function that allows a program to set the keyboard

focus to a given window. The user can usually set the

keyboard focus using the window manager (often by clicking

on the title bar of the desired window). Once our window

has the keyboard focus, every key press or key release will

cause an event to be sent to our program (if it regsitered

for these event types...).

Keyboard press and release events

If a window controlled by our program currently holds the

keyboard focus, it can receive key press and key release

events. So, we should add one (or more) of the following

masks when we create our window:

XCB_EVENT_MASK_KEY_PRESS: notify us when

a key was pressed while any of our controlled windows had

the keyboard focus.

XCB_EVENT_MASK_KEY_RELEASE: notify us

when a key was released while any of our controlled

windows had the keyboard focus.

The structure to be checked for in our events loop is the

same for these two events, and is the following:

typedef struct {

uint8_t response_type; /* The type of the event */

xcb_keycode_t detail;

uint16_t sequence;

xcb_timestamp_t time; /* Time, in milliseconds the event took place in */

xcb_window_t root;

xcb_window_t event;

xcb_window_t child;

int16_t root_x;

int16_t root_y;

int16_t event_x;

int16_t event_y;

uint16_t state;

uint8_t same_screen;

} xcb_key_press_event_t;

typedef xcb_key_press_event_t xcb_key_release_event_t;

The detail field refers to the

physical key on the keyboard.

TODO: Talk about getting the ASCII code from the key code.

X events: a complete example

As an example for handling events, we show a program that

creates a window, enters an events loop and checks for all the

events described above, and writes on the terminal the relevant

characteristics of the event. With this code, it should be

easy to add drawing operations, like those which have been

described above.

#include

#include

#include

void

print_modifiers (uint32_t mask)

{

const char **mod, *mods[] = {

"Shift", "Lock", "Ctrl", "Alt",

"Mod2", "Mod3", "Mod4", "Mod5",

"Button1", "Button2", "Button3", "Button4", "Button5"

};

printf ("Modifier mask: ");

for (mod = mods ; mask; mask >>= 1, mod++)

if (mask & 1)

printf(*mod);

putchar ('\n');

}

int

main ()

{

xcb_connection_t *c;

xcb_screen_t *screen;

xcb_window_t win;

xcb_generic_event_t *e;

uint32_t mask = 0;

uint32_t values[2];

/* Open the connection to the X server */

c = xcb_connect (NULL, NULL);

/* Get the first screen */

screen = xcb_setup_roots_iterator (xcb_get_setup (c)).data;

/* Ask for our window's Id */

win = xcb_generate_id (c);

/* Create the window */

mask = XCB_CW_BACK_PIXEL | XCB_CW_EVENT_MASK;

values[0] = screen->white_pixel;

values[1] = XCB_EVENT_MASK_EXPOSURE | XCB_EVENT_MASK_BUTTON_PRESS |

XCB_EVENT_MASK_BUTTON_RELEASE | XCB_EVENT_MASK_POINTER_MOTION |

XCB_EVENT_MASK_ENTER_WINDOW | XCB_EVENT_MASK_LEAVE_WINDOW |

XCB_EVENT_MASK_KEY_PRESS | XCB_EVENT_MASK_KEY_RELEASE;

xcb_create_window (c, /* Connection */

0, /* depth */

win, /* window Id */

screen->root, /* parent window */

0, 0, /* x, y */

150, 150, /* width, height */

10, /* border_width */

XCB_WINDOW_CLASS_INPUT_OUTPUT, /* class */

screen->root_visual, /* visual */

mask, values); /* masks */

/* Map the window on the screen */

xcb_map_window (c, win);

xcb_flush (c);

while ((e = xcb_wait_for_event (c))) {

switch (e->response_type & ~0x80) {

case XCB_EXPOSE: {

xcb_expose_event_t *ev = (xcb_expose_event_t *)e;

printf ("Window %ld exposed. Region to be redrawn at location (%d,%d), with dimension (%d,%d)\n",

ev->window, ev->x, ev->y, ev->width, ev->height);

break;

}

case XCB_BUTTON_PRESS: {

xcb_button_press_event_t *ev = (xcb_button_press_event_t *)e;

print_modifiers(ev->state);

switch (ev->detail) {

case 4:

printf ("Wheel Button up in window %ld, at coordinates (%d,%d)\n",

ev->event, ev->event_x, ev->event_y);

break;

case 5:

printf ("Wheel Button down in window %ld, at coordinates (%d,%d)\n",

ev->event, ev->event_x, ev->event_y);

break;

default:

printf ("Button %d pressed in window %ld, at coordinates (%d,%d)\n",

ev->detail, ev->event, ev->event_x, ev->event_y);

}

break;

}

case XCB_BUTTON_RELEASE: {

xcb_button_release_event_t *ev = (xcb_button_release_event_t *)e;

print_modifiers(ev->state);

printf ("Button %d released in window %ld, at coordinates (%d,%d)\n",

ev->detail, ev->event, ev->event_x, ev->event_y);

break;

}

case XCB_MOTION_NOTIFY: {

xcb_motion_notify_event_t *ev = (xcb_motion_notify_event_t *)e;

printf ("Mouse moved in window %ld, at coordinates (%d,%d)\n",

ev->event, ev->event_x, ev->event_y);

break;

}

case XCB_ENTER_NOTIFY: {

xcb_enter_notify_event_t *ev = (xcb_enter_notify_event_t *)e;

printf ("Mouse entered window %ld, at coordinates (%d,%d)\n",

ev->event, ev->event_x, ev->event_y);

break;

}

case XCB_LEAVE_NOTIFY: {

xcb_leave_notify_event_t *ev = (xcb_leave_notify_event_t *)e;

printf ("Mouse left window %ld, at coordinates (%d,%d)\n",

ev->event, ev->event_x, ev->event_y);

break;

}

case XCB_KEY_PRESS: {

xcb_key_press_event_t *ev = (xcb_key_press_event_t *)e;

print_modifiers(ev->state);

printf ("Key pressed in window %ld\n",

ev->event);

break;

}

case XCB_KEY_RELEASE: {

xcb_key_release_event_t *ev = (xcb_key_release_event_t *)e;

print_modifiers(ev->state);

printf ("Key released in window %ld\n",

ev->event);

break;

}

default:

/* Unknown event type, ignore it */

printf("Unknown event: %d\n", e->response_type);

break;

}

/* Free the Generic Event */

free (e);

}

return 0;

}

Handling text and fonts

Besides drawing graphics on a window, we often want to draw

text. Text strings have two major properties: the characters to

be drawn and the font with which they are drawn. In order to

draw text, we need to first request the X server to load a

font. We then assign a font to a Graphic Context, and finally, we

draw the text in a window, using the Graphic Context.

The Font structure

In order to support flexible fonts, a font type is

defined. You know what ? It's an Id:

typedef uint32_t xcb_font_t;

It is used to contain information about a font, and is passed

to several functions that handle fonts selection and text drawing.

We ask the X server to attribute an Id to our font with the

function:

xcb_font_t xcb_generate_id (xcb_connection_t *c);

Opening a Font

To open a font, we use the following function:

xcb_void_cookie_t xcb_open_font (xcb_connection_t *c,

xcb_font_t fid,

uint16_t name_len,

const char *name);

The fid parameter is the font Id

defined by xcb_generate_id() (see

above). The name parameter is the

name of the font you want to open. Use the command

xlsfonts in a terminal to know which

are the fonts available on your computer. The parameter

name_len is the length of the name

of the font (given by strlen()).

Assigning a Font to a Graphic Context

Once a font is opened, you have to create a Graphic Context

that will contain the informations about the color of the

foreground and the background used when you draw a text in a

Drawable. Here is an exemple of a Graphic Context that will

allow us to draw an opened font with a black foreground and a

white background:

/*

* c is the connection

* screen is the screen where the window is displayed

* window is the window in which we will draw the text

* font is the opened font

*/

uint32_t value_list[3];

xcb_gcontext_t gc;

uint32_t mask;

gc = xcb_generate_id (c);

mask = XCB_GC_FOREGROUND | XCB_GC_BACKGROUND | XCB_GC_FONT;

value_list[0] = screen->black_pixel;

value_list[1] = screen->white_pixel;

value_list[2] = font;

xcb_create_gc (c, gc, window, mask, value_list);

/* The font is not needed anymore, so we close it */

xcb_close_font (c, font);

Drawing text in a drawable

To draw a text in a drawable, we use the following function:

xcb_void_cookie_t xcb_image_text_8 (xcb_connection_t *c,

uint8_t string_len,

xcb_drawable_t drawable,

xcb_gcontext_t gc,

int16_t x,

int16_t y,

const char *string);

The string parameter is the text to

draw. The location of the drawing is given by the parameters

x and y.

The base line of the text is exactly the parameter

y.

Complete example

This example draw a text at 10 pixels (for the base line) of

the bottom of a window. Pressing the Esc key exits the program.

#include

#include

#include

#include

#define WIDTH 300

#define HEIGHT 100

static xcb_gc_t gc_font_get (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

const char *font_name);

static void text_draw (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

int16_t x1,

int16_t y1,

const char *label);

static void

text_draw (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

int16_t x1,

int16_t y1,

const char *label)

{

xcb_void_cookie_t cookie_gc;

xcb_void_cookie_t cookie_text;

xcb_generic_error_t *error;

xcb_gcontext_t gc;

uint8_t length;

length = strlen (label);

gc = gc_font_get(c, screen, window, "7x13");

cookie_text = xcb_image_text_8_checked (c, length, window, gc,

x1,

y1, label);

error = xcb_request_check (c, cookie_text);

if (error) {

fprintf (stderr, "ERROR: can't paste text : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

cookie_gc = xcb_free_gc (c, gc);

error = xcb_request_check (c, cookie_gc);

if (error) {

fprintf (stderr, "ERROR: can't free gc : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

}

static xcb_gc_t

gc_font_get (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

const char *font_name)

{

uint32_t value_list[3];

xcb_void_cookie_t cookie_font;

xcb_void_cookie_t cookie_gc;

xcb_generic_error_t *error;

xcb_font_t font;

xcb_gcontext_t gc;

uint32_t mask;

font = xcb_generate_id (c);

cookie_font = xcb_open_font_checked (c, font,

strlen (font_name),

font_name);

error = xcb_request_check (c, cookie_font);

if (error) {

fprintf (stderr, "ERROR: can't open font : %d\n", error->error_code);

xcb_disconnect (c);

return -1;

}

gc = xcb_generate_id (c);

mask = XCB_GC_FOREGROUND | XCB_GC_BACKGROUND | XCB_GC_FONT;

value_list[0] = screen->black_pixel;

value_list[1] = screen->white_pixel;

value_list[2] = font;

cookie_gc = xcb_create_gc_checked (c, gc, window, mask, value_list);

error = xcb_request_check (c, cookie_gc);

if (error) {

fprintf (stderr, "ERROR: can't create gc : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

cookie_font = xcb_close_font_checked (c, font);

error = xcb_request_check (c, cookie_font);

if (error) {

fprintf (stderr, "ERROR: can't close font : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

return gc;

}

int main ()

{

xcb_screen_iterator_t screen_iter;

xcb_connection_t *c;

const xcb_setup_t *setup;

xcb_screen_t *screen;

xcb_generic_event_t *e;

xcb_generic_error_t *error;

xcb_void_cookie_t cookie_window;

xcb_void_cookie_t cookie_map;

xcb_window_t window;

uint32_t mask;

uint32_t values[2];

int screen_number;

/* getting the connection */

c = xcb_connect (NULL, &screen_number);

if (!c) {

fprintf (stderr, "ERROR: can't connect to an X server\n");

return -1;

}

/* getting the current screen */

setup = xcb_get_setup (c);

screen = NULL;

screen_iter = xcb_setup_roots_iterator (setup);

for (; screen_iter.rem != 0; --screen_number, xcb_screen_next (&screen_iter))

if (screen_number == 0)

{

screen = screen_iter.data;

break;

}

if (!screen) {

fprintf (stderr, "ERROR: can't get the current screen\n");

xcb_disconnect (c);

return -1;

}

/* creating the window */

window = xcb_generate_id (c);

mask = XCB_CW_BACK_PIXEL | XCB_CW_EVENT_MASK;

values[0] = screen->white_pixel;

values[1] =

XCB_EVENT_MASK_KEY_RELEASE |

XCB_EVENT_MASK_BUTTON_PRESS |

XCB_EVENT_MASK_EXPOSURE |

XCB_EVENT_MASK_POINTER_MOTION;

cookie_window = xcb_create_window_checked (c,

screen->root_depth,

window, screen->root,

20, 200, WIDTH, HEIGHT,

0, XCB_WINDOW_CLASS_INPUT_OUTPUT,

screen->root_visual,

mask, values);

cookie_map = xcb_map_window_checked (c, window);

/* error managing */

error = xcb_request_check (c, cookie_window);

if (error) {

fprintf (stderr, "ERROR: can't create window : %d\n", error->error_code);

xcb_disconnect (c);

return -1;

}

error = xcb_request_check (c, cookie_map);

if (error) {

fprintf (stderr, "ERROR: can't map window : %d\n", error->error_code);

xcb_disconnect (c);

return -1;

}

xcb_flush(c);

while (1) {

e = xcb_poll_for_event(c);

if (e) {

switch (e->response_type & ~0x80) {

case XCB_EXPOSE: {

char *text;

text = "Press ESC key to exit...";

text_draw (c, screen, window, 10, HEIGHT - 10, text);

break;

}

case XCB_KEY_RELEASE: {

xcb_key_release_event_t *ev;

ev = (xcb_key_release_event_t *)e;

switch (ev->detail) {

/* ESC */

case 9:

free (e);

xcb_disconnect (c);

return 0;

}

}

}

free (e);

}

}

return 0;

}

Interacting with the window manager

After we have seen how to create windows and draw on them, we

take one step back, and look at how our windows are interacting

with their environment (the full screen and the other

windows). First of all, our application needs to interact with

the window manager. The window manager is responsible to

decorating drawn windows (i.e. adding a frame, an iconify

button, a system menu, a title bar, etc), as well as handling

icons shown when windows are being iconified. It also handles

ordering of windows on the screen, and other administrative

tasks. We need to give it various hints as to how we want it to

treat our application's windows.

Window properties

Many of the parameters communicated to the window manager are

passed using data called "properties". These properties are

attached by the X server to different windows, and are stored

in a format that makes it possible to read them from different

machines that may use different architectures (remember that

an X client program may run on a remote machine).

The property and its type (a string, an integer, etc) are

Id. Their type are xcb_atom_t:

typedef uint32_t xcb_atom_t;

To change the property of a window, we use the following

function:

xcb_void_cookie_t xcb_change_property (xcb_connection_t *c, /* Connection to the X server */

uint8_t mode, /* Property mode */

xcb_window_t window, /* Window */

xcb_atom_t property, /* Property to change */

xcb_atom_t type, /* Type of the property */

uint8_t format, /* Format of the property (8, 16, 32) */

uint32_t data_len, /* Length of the data parameter */

const void *data); /* Data */

The mode parameter coud be one of

the following values (defined in enumeration xcb_prop_mode_t in

the xproto.h header file):

XCB_PROP_MODE_REPLACE

XCB_PROP_MODE_PREPEND

XCB_PROP_MODE_APPEND

Setting the window name and icon name

The first thing we want to do would be to set the name for our

window. This is done using the

xcb_change_property() function. This

name may be used by the window manager as the title of the

window (in the title bar), in a task list, etc. The property

atom to use to set the name of a window is

WM_NAME (and

WM_ICON_NAME for the iconified

window) and its type is STRING. Here

is an example of utilization:

#include

#include

#include

int

main ()

{

xcb_connection_t *c;

xcb_screen_t *screen;

xcb_window_t win;

char *title = "Hello World !";

char *title_icon = "Hello World ! (iconified)";

/* Open the connection to the X server */

c = xcb_connect (NULL, NULL);

/* Get the first screen */

screen = xcb_setup_roots_iterator (xcb_get_setup (c)).data;

/* Ask for our window's Id */

win = xcb_generate_id (c);

/* Create the window */

xcb_create_window (c, /* Connection */

0, /* depth */

win, /* window Id */

screen->root, /* parent window */

0, 0, /* x, y */

250, 150, /* width, height */

10, /* border_width */

XCB_WINDOW_CLASS_INPUT_OUTPUT, /* class */

screen->root_visual, /* visual */

0, NULL); /* masks, not used */

/* Set the title of the window */

xcb_change_property (c, XCB_PROP_MODE_REPLACE, win,

WM_NAME, STRING, 8,

strlen (title), title);

/* Set the title of the window icon */

xcb_change_property (c, XCB_PROP_MODE_REPLACE, win,

WM_ICON_NAME, STRING, 8,

strlen(title_icon), title_icon);

/* Map the window on the screen */

xcb_map_window (c, win);

xcb_flush (c);

while (1) {}

return 0;

}

Note: the use of the atoms needs our program to be compiled

and linked against xcb_atom, so that we have to use

gcc prog.c -o prog `pkg-config --cflags --libs xcb_atom`

for the program to compile fine.

Simple window operations

One more thing we can do to our window is manipulate them on the

screen (resize them, move them, raise or lower them, iconify

them, and so on). Some window operations functions are supplied

by XCB for this purpose.

Mapping and un-mapping a window

The first pair of operations we can apply on a window is

mapping it, or un-mapping it. Mapping a window causes the

window to appear on the screen, as we have seen in our simple

window program example. Un-mapping it causes it to be removed

from the screen (although the window as a logical entity still

exists). This gives the effect of making a window hidden

(unmapped) and shown again (mapped). For example, if we have a

dialog box window in our program, instead of creating it every

time the user asks to open it, we can create the window once,

in an un-mapped mode, and when the user asks to open it, we

simply map the window on the screen. When the user clicked the

'OK' or 'Cancel' button, we simply un-map the window. This is

much faster than creating and destroying the window, however,

the cost is wasted resources, both on the client side, and on

the X server side.

To map a window, you use the following function:

xcb_void_cookie_t xcb_map_window (xcb_connection_t *c,

xcb_window_t window);

To have a simple example, see the example

above. The mapping operation will cause an

Expose event to be sent to our

application, unless the window is completely covered by other

windows.

Un-mapping a window is also simple. You use the function

xcb_void_cookie_t xcb_unmap_window (xcb_connection_t *c,

xcb_window_t window);

The utilization of this function is the same as

xcb_map_window().

Configuring a window

As we have seen when we have created our first window, in the

X Events subsection, we can set some attributes for the window

(that is, the position, the size, the events the window will

receive, etc). If we want to modify them, but the window is

already created, we can change them by using the following

function:

xcb_void_cookie_t xcb_configure_window (xcb_connection_t *c, /* The connection to the X server*/

xcb_window_t window, /* The window to configure */

uint16_t value_mask, /* The mask */

const uint32_t *value_list); /* The values to set */

We set the value_mask to one or

several mask values that are in the xcb_config_window_t enumeration in the xproto.h header:

XCB_CONFIG_WINDOW_X: new x coordinate of the window's top left corner

XCB_CONFIG_WINDOW_Y: new y coordinate of the window's top left corner

XCB_CONFIG_WINDOW_WIDTH: new width of the window

XCB_CONFIG_WINDOW_HEIGHT: new height of the window

XCB_CONFIG_WINDOW_BORDER_WIDTH: new width of the border of the window

XCB_CONFIG_WINDOW_SIBLING

XCB_CONFIG_WINDOW_STACK_MODE: the new stacking order

We then give to value_mask the new

value. We now describe how to use

xcb_configure_window_t in some useful

situations.

Moving a window around the screen

An operation we might want to do with windows is to move them

to a different location. This can be done like this:

const static uint32_t values[] = { 10, 20 };

/* The connection c and the window win are supposed to be defined */

/* Move the window to coordinates x = 10 and y = 20 */

xcb_configure_window (c, win, XCB_CONFIG_WINDOW_X | XCB_CONFIG_WINDOW_Y, values);

Note that when the window is moved, it might get partially

exposed or partially hidden by other windows, and thus we

might get Expose events due to this

operation.

Resizing a window

Yet another operation we can do is to change the size of a

window. This is done using the following code:

const static uint32_t values[] = { 200, 300 };

/* The connection c and the window win are supposed to be defined */

/* Resize the window to width = 10 and height = 20 */

xcb_configure_window (c, win, XCB_CONFIG_WINDOW_WIDTH | XCB_CONFIG_WINDOW_HEIGHT, values);

We can also combine the move and resize operations using one

single call to xcb_configure_window_t:

const static uint32_t values[] = { 10, 20, 200, 300 };

/* The connection c and the window win are supposed to be defined */

/* Move the window to coordinates x = 10 and y = 20 */

/* and resize the window to width = 10 and height = 20 */

xcb_configure_window (c, win, XCB_CONFIG_WINDOW_X | XCB_CONFIG_WINDOW_Y | XCB_CONFIG_WINDOW_WIDTH | XCB_CONFIG_WINDOW_HEIGHT, values);

Changing windows stacking order: raise and lower

Until now, we changed properties of a single window. We'll see

that there are properties that relate to the window and other

windows. One of them is the stacking order. That is, the order

in which the windows are layered on top of each other. The

front-most window is said to be on the top of the stack, while

the back-most window is at the bottom of the stack. Here is

how to manipulate our windows stack order:

const static uint32_t values[] = { XCB_STACK_MODE_ABOVE };

/* The connection c and the window win are supposed to be defined */

/* Move the window on the top of the stack */

xcb_configure_window (c, win, XCB_CONFIG_WINDOW_STACK_MODE, values);

const static uint32_t values[] = { XCB_STACK_MODE_BELOW };

/* The connection c and the window win are supposed to be defined */

/* Move the window on the bottom of the stack */

xcb_configure_window (c, win, XCB_CONFIG_WINDOW_STACK_MODE, values);

Getting information about a window

Just like we can set various attributes of our windows, we can

also ask the X server supply the current values of these

attributes. For example, we can check where a window is

located on the screen, what is its current size, whether it is

mapped or not, etc. The structure that contains some of this

information is

typedef struct {

uint8_t response_type;

uint8_t depth; /* depth of the window */

uint16_t sequence;

uint32_t length;

xcb_window_t root; /* Id of the root window *>

int16_t x; /* X coordinate of the window's location */

int16_t y; /* Y coordinate of the window's location */

uint16_t width; /* Width of the window */

uint16_t height; /* Height of the window */

uint16_t border_width; /* Width of the window's border */

} xcb_get_geometry_reply_t;

XCB fill this structure with two functions:

xcb_get_geometry_cookie_t xcb_get_geometry (xcb_connection_t *c,

xcb_drawable_t drawable);

xcb_get_geometry_reply_t *xcb_get_geometry_reply (xcb_connection_t *c,

xcb_get_geometry_cookie_t cookie,

xcb_generic_error_t **e);

You use them as follows:

xcb_connection_t *c;

xcb_drawable_t win;

xcb_get_geometry_reply_t *geom;

/* You initialize c and win */

geom = xcb_get_geometry_reply (c, xcb_get_geometry (c, win), NULL);

/* Do something with the fields of geom */

free (geom);

Remark that you have to free the structure, as

xcb_get_geometry_reply_t allocates a

newly one.

One problem is that the returned location of the window is

relative to its parent window. This makes these coordinates

rather useless for any window manipulation functions, like

moving it on the screen. In order to overcome this problem, we

need to take a two-step operation. First, we find out the Id

of the parent window of our window. We then translate the

above relative coordinates to the screen coordinates.

To get the Id of the parent window, we need this structure:

typedef struct {

uint8_t response_type;

uint8_t pad0;

uint16_t sequence;

uint32_t length;

xcb_window_t root;

xcb_window_t parent; /* Id of the parent window */

uint16_t children_len;

uint8_t pad1[14];

} xcb_query_tree_reply_t;

To fill this structure, we use these two functions:

xcb_query_tree_cookie_t xcb_query_tree (xcb_connection_t *c,

xcb_window_t window);

xcb_query_tree_reply_t *xcb_query_tree_reply (xcb_connection_t *c,

xcb_query_tree_cookie_t cookie,

xcb_generic_error_t **e);

The translated coordinates will be found in this structure:

typedef struct {

uint8_t response_type;

uint8_t same_screen;

uint16_t sequence;

uint32_t length;

xcb_window_t child;

uint16_t dst_x; /* Translated x coordinate */

uint16_t dst_y; /* Translated y coordinate */

} xcb_translate_coordinates_reply_t;

As usual, we need two functions to fill this structure:

xcb_translate_coordinates_cookie_t xcb_translate_coordinates (xcb_connection_t *c,

xcb_window_t src_window,

xcb_window_t dst_window,

int16_t src_x,

int16_t src_y);

xcb_translate_coordinates_reply_t *xcb_translate_coordinates_reply (xcb_connection_t *c,

xcb_translate_coordinates_cookie_t cookie,

xcb_generic_error_t **e);

We use them as follows:

xcb_connection_t *c;

xcb_drawable_t win;

xcb_get_geometry_reply_t *geom;

xcb_query_tree_reply_t *tree;

xcb_translate_coordinates_reply_t *trans;

/* You initialize c and win */

geom = xcb_get_geometry_reply (c, xcb_get_geometry (c, win), NULL);

if (!geom)

return 0;

tree = xcb_query_tree_reply (c, xcb_query_tree (c, win), NULL);

if (!tree)

return 0;

trans = xcb_translate_coordinates_reply (c,

xcb_translate_coordinates (c,

win,

tree->parent,

geom->x, geom->y),

NULL);

if (!trans)

return 0;

/* the translated coordinates are in trans->dst_x and trans->dst_y */

free (trans);

free (tree);

free (geom);

Of course, as for geom,

tree and

trans have to be freed.

The work is a bit hard, but XCB is a very low-level library.

TODO: the utilization of these functions should be a

prog, which displays the coordinates of the window.

There is another structure that gives informations about our window:

typedef struct {

uint8_t response_type;

uint8_t backing_store;

uint16_t sequence;

uint32_t length;

xcb_visualid_t visual; /* Visual of the window */

uint16_t _class;

uint8_t bit_gravity;

uint8_t win_gravity;

uint32_t backing_planes;

uint32_t backing_pixel;

uint8_t save_under;

uint8_t map_is_installed;

uint8_t map_state; /* Map state of the window */

uint8_t override_redirect;

xcb_colormap_t colormap; /* Colormap of the window */

uint32_t all_event_masks;

uint32_t your_event_mask;

uint16_t do_not_propagate_mask;

} xcb_get_window_attributes_reply_t;

XCB supplies these two functions to fill it:

xcb_get_window_attributes_cookie_t xcb_get_window_attributes (xcb_connection_t *c,

xcb_window_t window);

xcb_get_window_attributes_reply_t *xcb_get_window_attributes_reply (xcb_connection_t *c,

xcb_get_window_attributes_cookie_t cookie,

xcb_generic_error_t **e);

You use them as follows:

xcb_connection_t *c;

xcb_drawable_t win;

xcb_get_window_attributes_reply_t *attr;

/* You initialize c and win */

attr = xcb_get_window_attributes_reply (c, xcb_get_window_attributes (c, win), NULL);

if (!attr)

return 0;

/* Do something with the fields of attr */

free (attr);

As for geom,

attr has to be freed.

Using colors to paint the rainbow

Up until now, all our painting operation were done using black

and white. We will (finally) see now how to draw using colors.

Color maps

In the beginning, there were not enough colors. Screen

controllers could only support a limited number of colors

simultaneously (initially 2, then 4, 16 and 256). Because of

this, an application could not just ask to draw in a "light

purple-red" color, and expect that color to be available. Each

application allocated the colors it needed, and when all the

color entries (4, 16, 256 colors) were in use, the next color

allocation would fail.

Thus, the notion of "a color map" was introduced. A color map

is a table whose size is the same as the number of

simultaneous colors a given screen controller. Each entry

contained the RGB (Red, Green and Blue) values of a different

color (all colors can be drawn using some combination of red,

green and blue). When an application wants to draw on the

screen, it does not specify which color to use. Rather, it

specifies which color entry of some color map to be used

during this drawing. Change the value in this color map entry

and the drawing will use a different color.

In order to be able to draw using colors that got something to

do with what the programmer intended, color map allocation

functions are supplied. You could ask to allocate entry for a

color with a set of RGB values. If one already existed, you

would get its index in the table. If none existed, and the

table was not full, a new cell would be allocated to contain

the given RGB values, and its index returned. If the table was

full, the procedure would fail. You could then ask to get a

color map entry with a color that is closest to the one you

were asking for. This would mean that the actual drawing on

the screen would be done using colors similar to what you

wanted, but not the same.

On today's more modern screens where one runs an X server with

support for 16 million colors, this limitation looks a little

silly, but remember that there are still older computers with

older graphics cards out there. Using color map, support for

these screen becomes transparent to you. On a display

supporting 16 million colors, any color entry allocation

request would succeed. On a display supporting a limited

number of colors, some color allocation requests would return

similar colors. It won't look as good, but your application

would still work.

Allocating and freeing Color Maps

When you draw using XCB, you can choose to use the standard

color map of the screen your window is displayed on, or you

can allocate a new color map and apply it to a window. In the

latter case, each time the mouse moves onto your window, the

screen color map will be replaced by your window's color map,

and you'll see all the other windows on screen change their

colors into something quite bizzare. In fact, this is the

effect you get with X applications that use the "-install"

command line option.

In XCB, a color map is (as often in X) an Id:

typedef uint32_t xcb_colormap_t;

In order to access the screen's default color map, you just

have to retrieve the default_colormap

field of the xcb_screen_t structure

(see Section

Checking basic information about a connection):

#include

#include

int

main ()

{

xcb_connection_t *c;

xcb_screen_t *screen;

xcb_colormap_t colormap;

/* Open the connection to the X server and get the first screen */

c = xcb_connect (NULL, NULL);

screen = xcb_setup_roots_iterator (xcb_get_setup (c)).data;

colormap = screen->default_colormap;

return 0;

}

This will return the color map used by default on the first

screen (again, remember that an X server may support several

different screens, each of which might have its own resources).

The other option, that of allocating a new colormap, works as

follows. We first ask the X server to give an Id to our color

map, with this function:

xcb_colormap_t xcb_generate_id (xcb_connection_t *c);

Then, we create the color map with

xcb_void_cookie_t xcb_create_colormap (xcb_connection_t *c, /* Pointer to the xcb_connection_t structure */

uint8_t alloc, /* Colormap entries to be allocated (AllocNone or AllocAll) */

xcb_colormap_t mid, /* Id of the color map */

xcb_window_t window, /* Window on whose screen the colormap will be created */

xcb_visualid_t visual); /* Id of the visual supported by the screen */

Here is an example of creation of a new color map:

#include

int

main ()

{

xcb_connection_t *c;

xcb_screen_t *screen;

xcb_window_t win;

xcb_colormap_t cmap

/* Open the connection to the X server and get the first screen */

c = xcb_connect (NULL, NULL);

screen = xcb_setup_roots_iterator (xcb_get_setup (c)).data;

/* We create the window win here*/

cmap = xcb_generate_id (c);

xcb_create_colormap (c, XCB_COLORMAP_ALLOC_NONE, cmap, win, screen->root_visual);

return 0;

}

Note that the window parameter is only used to allow the X

server to create the color map for the given screen. We can

then use this color map for any window drawn on the same screen.

To free a color map, it suffices to use this function:

xcb_void_cookie_t xcb_free_colormap (xcb_connection_t *c, /* The connection */

xcb_colormap_t cmap); /* The color map */

Comparison Xlib/XCB

XCreateColormap ()

xcb_generate_id ()

xcb_create_colormap ()

XFreeColormap ()

xcb_free_colormap ()

Allocating and freeing a color entry

Once we got access to some color map, we can start allocating

colors. The informations related to a color are stored in the

following structure:

typedef struct {

uint8_t response_type;

uint8_t pad0;

uint16_t sequence;

uint32_t length;

uint16_t red; /* The red component */

uint16_t green; /* The green component */

uint16_t blue; /* The blue component */

uint8_t pad1[2];

uint32_t pixel; /* The entry in the color map, supplied by the X server */

} xcb_alloc_color_reply_t;

XCB supplies these two functions to fill it:

xcb_alloc_color_cookie_t xcb_alloc_color (xcb_connection_t *c,

xcb_colormap_t cmap,

uint16_t red,

uint16_t green,

uint16_t blue);

xcb_alloc_color_reply_t *xcb_alloc_color_reply (xcb_connection_t *c,

xcb_alloc_color_cookie_t cookie,

xcb_generic_error_t **e);

The fuction xcb_alloc_color() takes the

3 RGB components as parameters (red, green and blue). Here is an

example of using these functions:

#include

#include

int

main ()

{

xcb_connection_t *c;

xcb_screen_t *screen;

xcb_window_t win;

xcb_colormap_t cmap;

xcb_alloc_color_reply_t *rep;

/* Open the connection to the X server and get the first screen */

c = xcb_connect (NULL, NULL);

screen = xcb_setup_roots_iterator (xcb_get_setup (c)).data;

/* We create the window win here*/

cmap = xcb_generate_id (c);

xcb_create_colormap (c, XCB_COLORMAP_ALLOC_NONE, cmap, win, screen->root_visual);

rep = xcb_alloc_color_reply (c, xcb_alloc_color (c, cmap, 65535, 0, 0), NULL);

if (!rep)

return 0;

/* Do something with r->pixel or the components */

free (rep);

return 0;

}

As xcb_alloc_color_reply() allocates

memory, you have to free rep.

TODO: Talk about freeing colors.

X Bitmaps and Pixmaps

One thing many so-called "Multi-Media" applications need to do,

is display images. In the X world, this is done using bitmaps

and pixmaps. We have already seen some usage of them when

setting an icon for our application. Lets study them further,

and see how to draw these images inside a window, along side the

simple graphics and text we have seen so far.

One thing to note before delving further, is that XCB (nor Xlib)

supplies no means of manipulating popular image formats, such as

gif, png, jpeg or tiff. It is up to the programmer (or to higher

level graphics libraries) to translate these image formats into

formats that the X server is familiar with (x bitmaps and x

pixmaps).

What is a X Bitmap? An X Pixmap?

An X bitmap is a two-color image stored in a format specific

to the X window system. When stored in a file, the bitmap data

looks like a C source file. It contains variables defining the

width and the height of the bitmap, an array containing the

bit values of the bitmap (the size of the array is

(width+7)/8*height and the bit and byte order are LSB), and

an optional hot-spot location (that will

be explained later, when discussing mouse cursors).

An X pixmap is a format used to stored images in the memory of

an X server. This format can store both black and white images

(such as x bitmaps) as well as color images. It is the only

image format supported by the X protocol, and any image to be

drawn on screen, should be first translated into this format.

In actuality, an X pixmap can be thought of as a window that

does not appear on the screen. Many graphics operations that

work on windows, will also work on pixmaps. Indeed, the type

of X pixmap in XCB is an Id like a window:

typedef uint32_t xcb_pixmap_t;

Like Xlib, there is no difference between a Drawable, a Window

or a Pixmap:

typedef uint32_t xcb_drawable_t;

in order to avoid confusion between a window and a pixmap. The

operations that will work the same on a window or a pixmap

will require a xcb_drawable_t

Remark: In Xlib, there is no specific difference between a

Drawable, a

Pixmap or a

Window: all are 32 bit long

integer. XCB wraps all these different IDs in structures to

provide some measure of type-safety.

Creating a pixmap

Sometimes we want to create an un-initialized pixmap, so we

can later draw into it. This is useful for image drawing

programs (creating a new empty canvas will cause the creation

of a new pixmap on which the drawing can be stored). It is

also useful when reading various image formats: we load the

image data into memory, create a pixmap on the server, and

then draw the decoded image data onto that pixmap.

To create a new pixmap, we first ask the X server to give an

Id to our pixmap, with this function:

xcb_pixmap_t xcb_generate_id (xcb_connection_t *c);

Then, XCB supplies the following function to create new pixmaps:

xcb_void_cookie_t xcb_create_pixmap (xcb_connection_t *c, /* Pointer to the xcb_connection_t structure */

uint8_t depth, /* Depth of the screen */

xcb_pixmap_t pid, /* Id of the pixmap */

xcb_drawable_t drawable,

uint16_t width, /* Width of the window (in pixels) */

uint16_t height); /* Height of the window (in pixels) */

TODO: Explain the drawable parameter, and give an

example (like xpoints.c)

Drawing a pixmap in a window

Once we got a handle to a pixmap, we can draw it on some

window, using the following function:

xcb_void_cookie_t xcb_copy_area (xcb_connection_t *c, /* Pointer to the xcb_connection_t structure */

xcb_drawable_t src_drawable, /* The Drawable we want to paste */

xcb_drawable_t dst_drawable, /* The Drawable on which we copy the previous Drawable */

xcb_gcontext_t gc, /* A Graphic Context */

int16_t src_x, /* Top left x coordinate of the region we want to copy */

int16_t src_y, /* Top left y coordinate of the region we want to copy */

int16_t dst_x, /* Top left x coordinate of the region where we want to copy */

int16_t dst_y, /* Top left y coordinate of the region where we want to copy */

uint16_t width, /* Width of the region we want to copy */

uint16_t height); /* Height of the region we want to copy */

As you can see, we could copy the whole pixmap, as well as

only a given rectangle of the pixmap. This is useful to

optimize the drawing speed: we could copy only what we have

modified in the pixmap.

One important note should be made: it is possible to

create pixmaps with different depths on the same screen. When

we perform copy operations (a pixmap onto a window, etc), we

should make sure that both source and target have the same

depth. If they have a different depth, the operation would

fail. The exception to this is if we copy a specific bit plane

of the source pixmap using the

xcb_copy_plane_t function. In such an

event, we can copy a specific plane to the target window (in

actuality, setting a specific bit in the color of each pixel

copied). This can be used to generate strange graphic effects

in a window, but that is beyond the scope of this tutorial.

Freeing a pixmap

Finally, when we are done using a given pixmap, we should free

it, in order to free resources of the X server. This is done

using this function:

xcb_void_cookie_t xcb_free_pixmap (xcb_connection_t *c, /* Pointer to the xcb_connection_t structure */

xcb_pixmap_t pixmap); /* A given pixmap */

Of course, after having freed it, we must not try accessing

the pixmap again.

TODO: Give an example, or a link to xpoints.c

Messing with the mouse cursor

It it possible to modify the shape of the mouse pointer (also

called the X pointer) when in certain states, as we otfen see in

programs. For example, a busy application would often display

the sand clock over its main window, to give the user a visual

hint that he should wait. Let's see how we can change the mouse

cursor of our windows.

Creating and destroying a mouse cursor

There are two methods for creating cursors. One of them is by

using a set of predefined cursors, that are supplied by the X

server, the other is by using a user-supplied bitmap.

In the first method, we use a special font named "cursor", and

the function xcb_create_glyph_cursor:

xcb_void_cookie_t xcb_create_glyph_cursor (xcb_connection_t *c,

xcb_cursor_t cid,

xcb_font_t source_font, /* font for the source glyph */

xcb_font_t mask_font, /* font for the mask glyph or XCB_NONE */

uint16_t source_char, /* character glyph for the source */

uint16_t mask_char, /* character glyph for the mask */

uint16_t fore_red, /* red value for the foreground of the source */

uint16_t fore_green, /* green value for the foreground of the source */

uint16_t fore_blue, /* blue value for the foreground of the source */

uint16_t back_red, /* red value for the background of the source */

uint16_t back_green, /* green value for the background of the source */

uint16_t back_blue) /* blue value for the background of the source */

TODO: Describe source_char

and mask_char, for example by giving

an example on how to get the values. There is a list there:

X Font Cursors

So we first open that font (see Loading a Font)

and create the new cursor. As for every X ressource, we have to

ask for an X id with xcb_generate_id

first:

xcb_font_t font;

xcb_cursor_t cursor;

/* The connection is set */

font = xcb_generate_id (conn);

xcb_open_font (conn, font, strlen ("cursor"), "cursor");

cursor = xcb_generate_id (conn);

xcb_create_glyph_cursor (conn, cursor, font, font,

58, 58 + 1,

0, 0, 0,

0, 0, 0);

We have created the cursor "right hand" by specifying 58 to

the source_font argument and 58 + 1

to the mask_font.

The cursor is destroyed by using the function

xcb_void_cookie_t xcb_free_cursor (xcb_connection_t *c,

xcb_cursor_t cursor);

In the second method, we create a new cursor by using a pair

of pixmaps, with depth of one (that is, two colors

pixmaps). One pixmap defines the shape of the cursor, while

the other works as a mask, specifying which pixels of the

cursor will be actually drawn. The rest of the pixels will be

transparent.

TODO: give an example.

Setting a window's mouse cursor

Once the cursor is created, we can modify the cursor of our

window by using xcb_change_window_attributes

and using the XCB_CWCURSOR attribute:

uint32_t mask;

uint32_t value_list;

/* The connection and window are set */

/* The cursor is already created */

mask = XCB_CWCURSOR;

value_list = cursor;

xcb_change_window_attributes (conn, window, mask, &value_list);

Of course, the cursor and the font must be freed.

Complete example

The following example displays a window with a

button. When entering the window, the window cursor is changed

to an arrow. When clicking once on the button, the cursor is

changed to a hand. When clicking again on the button, the

cursor window gets back to the arrow. The Esc key exits the

application.

#include

#include

#include

#include

#define WIDTH 300

#define HEIGHT 150

static xcb_gc_t gc_font_get (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

const char *font_name);

static void button_draw (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

int16_t x1,

int16_t y1,

const char *label);

static void text_draw (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

int16_t x1,

int16_t y1,

const char *label);

static void cursor_set (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

int cursor_id);

static void

button_draw (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

int16_t x1,

int16_t y1,

const char *label)

{

xcb_point_t points[5];

xcb_void_cookie_t cookie_gc;

xcb_void_cookie_t cookie_line;

xcb_void_cookie_t cookie_text;

xcb_generic_error_t *error;

xcb_gcontext_t gc;

int16_t width;

int16_t height;

uint8_t length;

int16_t inset;

length = strlen (label);

inset = 2;

gc = gc_font_get(c, screen, window, "7x13");

width = 7 * length + 2 * (inset + 1);

height = 13 + 2 * (inset + 1);

points[0].x = x1;

points[0].y = y1;

points[1].x = x1 + width;

points[1].y = y1;

points[2].x = x1 + width;

points[2].y = y1 - height;

points[3].x = x1;

points[3].y = y1 - height;

points[4].x = x1;

points[4].y = y1;

cookie_line = xcb_poly_line_checked (c, XCB_COORD_MODE_ORIGIN,

window, gc, 5, points);

error = xcb_request_check (c, cookie_line);

if (error) {

fprintf (stderr, "ERROR: can't draw lines : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

cookie_text = xcb_image_text_8_checked (c, length, window, gc,

x1 + inset + 1,

y1 - inset - 1, label);

error = xcb_request_check (c, cookie_text);

if (error) {

fprintf (stderr, "ERROR: can't paste text : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

cookie_gc = xcb_free_gc (c, gc);

error = xcb_request_check (c, cookie_gc);

if (error) {

fprintf (stderr, "ERROR: can't free gc : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

}

static void

text_draw (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

int16_t x1,

int16_t y1,

const char *label)

{

xcb_void_cookie_t cookie_gc;

xcb_void_cookie_t cookie_text;

xcb_generic_error_t *error;

xcb_gcontext_t gc;

uint8_t length;

length = strlen (label);

gc = gc_font_get(c, screen, window, "7x13");

cookie_text = xcb_image_text_8_checked (c, length, window, gc,

x1,

y1, label);

error = xcb_request_check (c, cookie_text);

if (error) {

fprintf (stderr, "ERROR: can't paste text : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

cookie_gc = xcb_free_gc (c, gc);

error = xcb_request_check (c, cookie_gc);

if (error) {

fprintf (stderr, "ERROR: can't free gc : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

}

static xcb_gc_t

gc_font_get (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

const char *font_name)

{

uint32_t value_list[3];

xcb_void_cookie_t cookie_font;

xcb_void_cookie_t cookie_gc;

xcb_generic_error_t *error;

xcb_font_t font;

xcb_gcontext_t gc;

uint32_t mask;

font = xcb_generate_id (c);

cookie_font = xcb_open_font_checked (c, font,

strlen (font_name),

font_name);

error = xcb_request_check (c, cookie_font);

if (error) {

fprintf (stderr, "ERROR: can't open font : %d\n", error->error_code);

xcb_disconnect (c);

return -1;

}

gc = xcb_generate_id (c);

mask = XCB_GC_FOREGROUND | XCB_GC_BACKGROUND | XCB_GC_FONT;

value_list[0] = screen->black_pixel;

value_list[1] = screen->white_pixel;

value_list[2] = font;

cookie_gc = xcb_create_gc_checked (c, gc, window, mask, value_list);

error = xcb_request_check (c, cookie_gc);

if (error) {

fprintf (stderr, "ERROR: can't create gc : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

cookie_font = xcb_close_font_checked (c, font);

error = xcb_request_check (c, cookie_font);

if (error) {

fprintf (stderr, "ERROR: can't close font : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

return gc;

}

static void

cursor_set (xcb_connection_t *c,

xcb_screen_t *screen,

xcb_window_t window,

int cursor_id)

{

uint32_t values_list[3];

xcb_void_cookie_t cookie_font;

xcb_void_cookie_t cookie_gc;

xcb_generic_error_t *error;

xcb_font_t font;

xcb_cursor_t cursor;

xcb_gcontext_t gc;

uint32_t mask;

uint32_t value_list;

font = xcb_generate_id (c);

cookie_font = xcb_open_font_checked (c, font,

strlen ("cursor"),

"cursor");

error = xcb_request_check (c, cookie_font);

if (error) {

fprintf (stderr, "ERROR: can't open font : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

cursor = xcb_generate_id (c);

xcb_create_glyph_cursor (c, cursor, font, font,

cursor_id, cursor_id + 1,

0, 0, 0,

0, 0, 0);

gc = xcb_generate_id (c);

mask = XCB_GC_FOREGROUND | XCB_GC_BACKGROUND | XCB_GC_FONT;

values_list[0] = screen->black_pixel;

values_list[1] = screen->white_pixel;

values_list[2] = font;

cookie_gc = xcb_create_gc_checked (c, gc, window, mask, values_list);

error = xcb_request_check (c, cookie_gc);

if (error) {

fprintf (stderr, "ERROR: can't create gc : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

mask = XCB_CW_CURSOR;

value_list = cursor;

xcb_change_window_attributes (c, window, mask, &value_list);

xcb_free_cursor (c, cursor);

cookie_font = xcb_close_font_checked (c, font);

error = xcb_request_check (c, cookie_font);

if (error) {

fprintf (stderr, "ERROR: can't close font : %d\n", error->error_code);

xcb_disconnect (c);

exit (-1);

}

}

int main ()

{

xcb_screen_iterator_t screen_iter;

xcb_connection_t *c;

const xcb_setup_t *setup;

xcb_screen_t *screen;

xcb_generic_event_t *e;

xcb_generic_error_t *error;

xcb_void_cookie_t cookie_window;

xcb_void_cookie_t cookie_map;

xcb_window_t window;

uint32_t mask;

uint32_t values[2];

int screen_number;

uint8_t is_hand = 0;

/* getting the connection */

c = xcb_connect (NULL, &screen_number);

if (!c) {

fprintf (stderr, "ERROR: can't connect to an X server\n");

return -1;

}

/* getting the current screen */

setup = xcb_get_setup (c);

screen = NULL;

screen_iter = xcb_setup_roots_iterator (setup);

for (; screen_iter.rem != 0; --screen_number, xcb_screen_next (&screen_iter))

if (screen_number == 0)

{

screen = screen_iter.data;

break;

}

if (!screen) {

fprintf (stderr, "ERROR: can't get the current screen\n");

xcb_disconnect (c);

return -1;

}

/* creating the window */

window = xcb_generate_id (c);

mask = XCB_CW_BACK_PIXEL | XCB_CW_EVENT_MASK;

values[0] = screen->white_pixel;

values[1] =

XCB_EVENT_MASK_KEY_RELEASE |

XCB_EVENT_MASK_BUTTON_PRESS |

XCB_EVENT_MASK_EXPOSURE |

XCB_EVENT_MASK_POINTER_MOTION;

cookie_window = xcb_create_window_checked (c,

screen->root_depth,

window, screen->root,

20, 200, WIDTH, HEIGHT,

0, XCB_WINDOW_CLASS_INPUT_OUTPUT,

screen->root_visual,

mask, values);

cookie_map = xcb_map_window_checked (c, window);

/* error managing */

error = xcb_request_check (c, cookie_window);

if (error) {

fprintf (stderr, "ERROR: can't create window : %d\n", error->error_code);

xcb_disconnect (c);

return -1;

}

error = xcb_request_check (c, cookie_map);

if (error) {

fprintf (stderr, "ERROR: can't map window : %d\n", error->error_code);

xcb_disconnect (c);

return -1;

}

cursor_set (c, screen, window, 68);

xcb_flush(c);

while (1) {

e = xcb_poll_for_event(c);

if (e) {

switch (e->response_type & ~0x80) {

case XCB_EXPOSE: {

char *text;

text = "click here to change cursor";

button_draw (c, screen, window,

(WIDTH - 7 * strlen(text)) / 2,

(HEIGHT - 16) / 2, text);

text = "Press ESC key to exit...";

text_draw (c, screen, window, 10, HEIGHT - 10, text);

break;

}

case XCB_BUTTON_PRESS: {

xcb_button_press_event_t *ev;

int length;

ev = (xcb_button_press_event_t *)e;

length = strlen ("click here to change cursor");

if ((ev->event_x >= (WIDTH - 7 * length) / 2) &&

(ev->event_x <= ((WIDTH - 7 * length) / 2 + 7 * length + 6)) &&

(ev->event_y >= (HEIGHT - 16) / 2 - 19) &&

(ev->event_y <= ((HEIGHT - 16) / 2)))

is_hand = 1 - is_hand;

is_hand ? cursor_set (c, screen, window, 58) : cursor_set (c, screen, window, 68);

}

case XCB_KEY_RELEASE: {

xcb_key_release_event_t *ev;

ev = (xcb_key_release_event_t *)e;

switch (ev->detail) {

/* ESC */

case 9:

free (e);

xcb_disconnect (c);

return 0;

}

}

}

free (e);

}

}

return 0;

}

Translation of basic Xlib functions and macros

The problem when you want to port an Xlib program to XCB is that

you don't know if the Xlib function that you want to "translate"

is a X Window one or an Xlib macro. In that section, we describe

a way to translate the usual functions or macros that Xlib

provides. It's usually just a member of a structure.

Members of the Display structure

In this section, we look at how to translate the macros that

return some members of the Display

structure. They are obtained by using a function that requires a

xcb_connection_t * or a member of the

xcb_setup_t structure

(via the function xcb_get_setup), or

a function that requires that structure.

ConnectionNumber

This number is the file descriptor that connects the client

to the server. You just have to use that function:

int xcb_get_file_descriptor (xcb_connection_t *c);

DefaultScreen

That number is not stored by XCB. It is returned in the

second parameter of the function xcb_connect.

Hence, you have to store it yourself if you want to use

it. Then, to get the xcb_screen_t

structure, you have to iterate on the screens.

The equivalent function of the Xlib's

ScreenOfDisplay function can be

found below. This is also provided in the

xcb_aux_t library as xcb_aux_get_screen(). OK, here is the

small piece of code to get that number:

xcb_connection_t *c;

int screen_default_nbr;

/* you pass the name of the display you want to xcb_connect_t */

c = xcb_connect (display_name, &screen_default_nbr);

/* screen_default_nbr contains now the number of the default screen */

QLength

Not documented yet.

However, this points out a basic difference in philosophy between

Xlib and XCB. Xlib has several functions for filtering and

manipulating the incoming and outgoing X message queues. XCB

wishes to hide this as much as possible from the user, which

allows for more freedom in implementation strategies.

ScreenCount

You get the count of screens with the functions

xcb_get_setup

and

xcb_setup_roots_iterator

(if you need to iterate):

xcb_connection_t *c;

int screen_count;

/* you init the connection */

screen_count = xcb_setup_roots_iterator (xcb_get_setup (c)).rem;

/* screen_count contains now the count of screens */

If you don't want to iterate over the screens, a better way

to get that number is to use

xcb_setup_roots_length_t:

xcb_connection_t *c;

int screen_count;

/* you init the connection */

screen_count = xcb_setup_roots_length (xcb_get_setup (c));

/* screen_count contains now the count of screens */

ServerVendor

You get the name of the vendor of the server hardware with

the functions xcb_get_setup

and

xcb_setup_vendor. Beware

that, unlike Xlib, the string returned by XCB is not

necessarily null-terminaled:

xcb_connection_t *c;

char *vendor = NULL;

int length;

/* you init the connection */

length = xcb_setup_vendor_length (xcb_get_setup (c));

vendor = (char *)malloc (length + 1);

if (vendor)

memcpy (vendor, xcb_setup_vendor (xcb_get_setup (c)), length);

vendor[length] = '\0';

/* vendor contains now the name of the vendor. Must be freed when not used anymore */

ProtocolVersion

You get the major version of the protocol in the

xcb_setup_t

structure, with the function xcb_get_setup:

xcb_connection_t *c;

uint16_t protocol_major_version;

/* you init the connection */

protocol_major_version = xcb_get_setup (c)->protocol_major_version;

/* protocol_major_version contains now the major version of the protocol */

ProtocolRevision

You get the minor version of the protocol in the

xcb_setup_t

structure, with the function xcb_get_setup:

xcb_connection_t *c;

uint16_t protocol_minor_version;

/* you init the connection */

protocol_minor_version = xcb_get_setup (c)->protocol_minor_version;

/* protocol_minor_version contains now the minor version of the protocol */

VendorRelease

You get the number of the release of the server hardware in the

xcb_setup_t

structure, with the function xcb_get_setup:

xcb_connection_t *c;

uint32_t release_number;

/* you init the connection */

release_number = xcb_get_setup (c)->release_number;

/* release_number contains now the number of the release of the server hardware */

DisplayString

The name of the display is not stored in XCB. You have to

store it by yourself.

BitmapUnit

You get the bitmap scanline unit in the

xcb_setup_t

structure, with the function xcb_get_setup:

xcb_connection_t *c;

uint8_t bitmap_format_scanline_unit;

/* you init the connection */

bitmap_format_scanline_unit = xcb_get_setup (c)->bitmap_format_scanline_unit;

/* bitmap_format_scanline_unit contains now the bitmap scanline unit */

BitmapBitOrder

You get the bitmap bit order in the

xcb_setup_t

structure, with the function xcb_get_setup:

xcb_connection_t *c;

uint8_t bitmap_format_bit_order;

/* you init the connection */

bitmap_format_bit_order = xcb_get_setup (c)->bitmap_format_bit_order;

/* bitmap_format_bit_order contains now the bitmap bit order */

BitmapPad

You get the bitmap scanline pad in the

xcb_setup_t

structure, with the function xcb_get_setup:

xcb_connection_t *c;

uint8_t bitmap_format_scanline_pad;

/* you init the connection */

bitmap_format_scanline_pad = xcb_get_setup (c)->bitmap_format_scanline_pad;

/* bitmap_format_scanline_pad contains now the bitmap scanline pad */

ImageByteOrder

You get the image byte order in the

xcb_setup_t

structure, with the function xcb_get_setup:

xcb_connection_t *c;

uint8_t image_byte_order;

/* you init the connection */

image_byte_order = xcb_get_setup (c)->image_byte_order;

/* image_byte_order contains now the image byte order */

ScreenOfDisplay related functions

in Xlib, ScreenOfDisplay returns a

Screen structure that contains

several characteristics of your screen. XCB has a similar

structure (xcb_screen_t),

but the way to obtain it is a bit different. With

Xlib, you just provide the number of the screen and you grab it

from an array. With XCB, you iterate over all the screens to

obtain the one you want. The complexity of this operation is

O(n). So the best is to store this structure if you use

it often. See screen_of_display just below.

Xlib provides generally two functions to obtain the characteristics

related to the screen. One with the display and the number of

the screen, which calls ScreenOfDisplay,

and the other that uses the Screen structure.

This might be a bit confusing. As mentioned above, with XCB, it

is better to store the xcb_screen_t

structure. Then, you have to read the members of this

structure. That's why the Xlib functions are put by pairs (or

more) as, with XCB, you will use the same code.

ScreenOfDisplay

This function returns the Xlib Screen

structure. With XCB, you iterate over all the screens and

once you get the one you want, you return it:

xcb_screen_t *screen_of_display (xcb_connection_t *c,

int screen)

{

xcb_screen_iterator_t iter;

iter = xcb_setup_roots_iterator (xcb_get_setup (c));

for (; iter.rem; --screen, xcb_screen_next (&iter))

if (screen == 0)

return iter.data;

return NULL;

}

As mentioned above, you might want to store the value

returned by this function.

All the functions below will use the result of that

function, as they just grab a specific member of the

xcb_screen_t structure.

DefaultScreenOfDisplay

It is the default screen that you obtain when you connect to

the X server. It suffices to call the screen_of_display

function above with the connection and the number of the

default screen.

xcb_connection_t *c;

int screen_default_nbr;

xcb_screen_t *default_screen; /* the returned default screen */

/* you pass the name of the display you want to xcb_connect_t */

c = xcb_connect (display_name, &screen_default_nbr);

default_screen = screen_of_display (c, screen_default_nbr);

/* default_screen contains now the default root window, or a NULL window if no screen is found */

RootWindow / RootWindowOfScreen

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

xcb_window_t root_window = { 0 }; /* the returned window */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

root_window = screen->root;

/* root_window contains now the root window, or a NULL window if no screen is found */

DefaultRootWindow

It is the root window of the default screen. So, you call

ScreenOfDisplay with the

default screen number and you get the

root window as above:

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_default_nbr;

xcb_window_t root_window = { 0 }; /* the returned root window */

/* you pass the name of the display you want to xcb_connect_t */

c = xcb_connect (display_name, &screen_default_nbr);

screen = screen_of_display (c, screen_default_nbr);

if (screen)

root_window = screen->root;

/* root_window contains now the default root window, or a NULL window if no screen is found */

DefaultVisual / DefaultVisualOfScreen

While a Visual is, in Xlib, a structure, in XCB, there are

two types: xcb_visualid_t, which is

the Id of the visual, and xcb_visualtype_t,

which corresponds to the Xlib Visual. To get the Id of the

visual of a screen, just get the

root_visual

member of a xcb_screen_t:

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

xcb_visualid_t root_visual = { 0 }; /* the returned visual Id */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

root_visual = screen->root_visual;

/* root_visual contains now the value of the Id of the visual, or a NULL visual if no screen is found */

To get the xcb_visualtype_t

structure, it's a bit less easy. You have to get the

xcb_screen_t structure that you want,

get its root_visual member,

then iterate over the xcb_depth_ts

and the xcb_visualtype_ts, and compare

the xcb_visualid_t of these xcb_visualtype_ts:

with root_visual:

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

xcb_visualid_t root_visual = { 0 };

xcb_visualtype_t *visual_type = NULL; /* the returned visual type */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen) {

xcb_depth_iterator_t depth_iter;

depth_iter = xcb_screen_allowed_depths_iterator (screen);

for (; depth_iter.rem; xcb_depth_next (&depth_iter)) {

xcb_visualtype_iterator_t visual_iter;

visual_iter = xcb_depth_visuals_iterator (depth_iter.data);

for (; visual_iter.rem; xcb_visualtype_next (&visual_iter)) {

if (screen->root_visual == visual_iter.data->visual_id) {

visual_type = visual_iter.data;

break;

}

}

}

}

/* visual_type contains now the visual structure, or a NULL visual structure if no screen is found */

DefaultGC / DefaultGCOfScreen

This default Graphic Context is just a newly created Graphic

Context, associated to the root window of a

xcb_screen_t,

using the black white pixels of that screen:

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

xcb_gcontext_t gc = { 0 }; /* the returned default graphic context */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen) {

xcb_drawable_t draw;

uint32_t mask;

uint32_t values[2];

gc = xcb_generate_id (c);

draw = screen->root;

mask = XCB_GC_FOREGROUND | XCB_GC_BACKGROUND;

values[0] = screen->black_pixel;

values[1] = screen->white_pixel;

xcb_create_gc (c, gc, draw, mask, values);

}

/* gc contains now the default graphic context */

BlackPixel / BlackPixelOfScreen

It is the Id of the black pixel, which is in the structure

of an xcb_screen_t.

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint32_t black_pixel = 0; /* the returned black pixel */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

black_pixel = screen->black_pixel;

/* black_pixel contains now the value of the black pixel, or 0 if no screen is found */

WhitePixel / WhitePixelOfScreen

It is the Id of the white pixel, which is in the structure

of an xcb_screen_t.

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint32_t white_pixel = 0; /* the returned white pixel */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

white_pixel = screen->white_pixel;

/* white_pixel contains now the value of the white pixel, or 0 if no screen is found */

DisplayWidth / WidthOfScreen

It is the width in pixels of the screen that you want, and

which is in the structure of the corresponding

xcb_screen_t.

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint32_t width_in_pixels = 0; /* the returned width in pixels */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

width_in_pixels = screen->width_in_pixels;

/* width_in_pixels contains now the width in pixels, or 0 if no screen is found */

DisplayHeight / HeightOfScreen

It is the height in pixels of the screen that you want, and

which is in the structure of the corresponding

xcb_screen_t.

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint32_t height_in_pixels = 0; /* the returned height in pixels */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

height_in_pixels = screen->height_in_pixels;

/* height_in_pixels contains now the height in pixels, or 0 if no screen is found */

DisplayWidthMM / WidthMMOfScreen

It is the width in millimeters of the screen that you want, and

which is in the structure of the corresponding

xcb_screen_t.

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint32_t width_in_millimeters = 0; /* the returned width in millimeters */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

width_in_millimeters = screen->width_in_millimeters;

/* width_in_millimeters contains now the width in millimeters, or 0 if no screen is found */

DisplayHeightMM / HeightMMOfScreen

It is the height in millimeters of the screen that you want, and

which is in the structure of the corresponding

xcb_screen_t.

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint32_t height_in_millimeters = 0; /* the returned height in millimeters */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

height_in_millimeters = screen->height_in_millimeters;

/* height_in_millimeters contains now the height in millimeters, or 0 if no screen is found */

DisplayPlanes / DefaultDepth / DefaultDepthOfScreen / PlanesOfScreen

It is the depth (in bits) of the root window of the

screen. You get it from the xcb_screen_t structure.

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint8_t root_depth = 0; /* the returned depth of the root window */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

root_depth = screen->root_depth;

/* root_depth contains now the depth of the root window, or 0 if no screen is found */

DefaultColormap / DefaultColormapOfScreen

This is the default colormap of the screen (and not the

(default) colormap of the default screen !). As usual, you

get it from the xcb_screen_t structure:

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

xcb_colormap_t default_colormap = { 0 }; /* the returned default colormap */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

default_colormap = screen->default_colormap;

/* default_colormap contains now the default colormap, or a NULL colormap if no screen is found */

MinCmapsOfScreen

You get the minimum installed colormaps in the xcb_screen_t structure:

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint16_t min_installed_maps = 0; /* the returned minimum installed colormaps */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

min_installed_maps = screen->min_installed_maps;

/* min_installed_maps contains now the minimum installed colormaps, or 0 if no screen is found */

MaxCmapsOfScreen

You get the maximum installed colormaps in the xcb_screen_t structure:

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint16_t max_installed_maps = 0; /* the returned maximum installed colormaps */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

max_installed_maps = screen->max_installed_maps;

/* max_installed_maps contains now the maximum installed colormaps, or 0 if no screen is found */

DoesSaveUnders

You know if save_unders is set,

by looking in the xcb_screen_t structure:

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint8_t save_unders = 0; /* the returned value of save_unders */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

save_unders = screen->save_unders;

/* save_unders contains now the value of save_unders, or FALSE if no screen is found */

DoesBackingStore

You know the value of backing_stores,

by looking in the xcb_screen_t structure:

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint8_t backing_stores = 0; /* the returned value of backing_stores */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

backing_stores = screen->backing_stores;

/* backing_stores contains now the value of backing_stores, or FALSE if no screen is found */

EventMaskOfScreen

To get the current input masks,

you look in the xcb_screen_t structure:

xcb_connection_t *c;

xcb_screen_t *screen;

int screen_nbr;

uint32_t current_input_masks = 0; /* the returned value of current input masks */

/* you init the connection and screen_nbr */

screen = screen_of_display (c, screen_nbr);

if (screen)

current_input_masks = screen->current_input_masks;

/* current_input_masks contains now the value of the current input masks, or FALSE if no screen is found */

Miscellaneous macros

DisplayOfScreen

in Xlib, the Screen structure

stores its associated Display

structure. This is not the case in the X Window protocol,

hence, it's also not the case in XCB. So you have to store

it by yourself.

DisplayCells / CellsOfScreen

To get the colormap entries,

you look in the xcb_visualtype_t

structure, that you grab like here:

xcb_connection_t *c;

xcb_visualtype_t *visual_type;

uint16_t colormap_entries = 0; /* the returned value of the colormap entries */

/* you init the connection and visual_type */

if (visual_type)

colormap_entries = visual_type->colormap_entries;

/* colormap_entries contains now the value of the colormap entries, or FALSE if no screen is found */

The X New Developer’s Guide: Xlib and XCB

The X New Developer’s Guide: Xlib and XCB

xorg/

guide/

The X New Developer’s Guide: Xlib and XCB

Edit

Page History

Repo Info

Xlib and XCB

Alan Coopersmith

Example: Converting xwininfo from Xlib to XCB

Mixing Xlib & XCB calls

Example: Converting xdpyinfo extension queries to XCB

Extension libraries

API documentation

The two most popular questions about Xlib and XCB may be

"What are they?" and "What's the difference?"

Most programming languages make it awkward for X

applications to spit raw X protocol down the network and

take apart the protocol coming back. Thus, X toolkits and

applications are a lot easier to write if some library

handles these jobs for them, providing an API that fits with

the programming language and environment for connecting to

the X server.

At the bottom level of the X client library stack are Xlib

and XCB, two helper libraries (really sets of libraries)

that provide API for talking to the X server. Xlib and XCB

have different design goals, and were developed in different

periods in the evolution of the X Window System.

Most application developers should call Xlib and XCB

sparingly. Higher level toolkits provide more efficient

programming models, and support features expected in modern

applications, including support for complex

internationalized input and output, accessibility, and

integration with desktop environments. However, sometimes

applications will find themselves needing to make calls to

the raw underlying X11 libraries for operations not

supported by toolkits. An application might need to make

calls to X extension API's not covered in the current

version of the toolkit's programming model. It is also

common for drawing not to be wrapped by toolkit API's. [Yes?

--po8]

The original C-language X11 API is libX11, often referred to

as "Xlib". It was designed to look like a traditional

library API, hiding the fact that calls result in protocol

requests to a server. Calls that don't require a response

from the X server are queued in a buffer to be sent as a

batch of requests to the server. Those that require a

response flush all the buffered requests and then block

until the response is received.

Xlib's mix of synchronous and asynchronous behaviors causes

some problems. Xlib's behaviour is often confusing to new

programmers. Calls appear to work sometimes and not others,

because it is not obvious which calls implicitly flush the

buffer. The asynchronous nature of many calls makes it

difficult to debug problems. When an error is reported, the

stack trace shows the call that was being made when the

error was received and processed, often many calls after the

one that caused the error. Finally, Xlib's synchronous calls

incur avoidable round-trip latency. This latency has a

notable effect on application performance; in particular,

startup times are often greatly increased.

After many years of experience with Xlib, and learning from

it and other protocol interface libraries, a second attempt

was made at defining a C language binding for X11: the "X11

C Binding" layer XCB. XCB makes the client-server nature of

the protocol explicit in its design. The client is in charge

of deciding when to flush the request buffer, when to read

results and when to wait for the server to respond.

For instance, to lookup a window property, the Xlib code is

a single function call:

XGetWindowProperty(dpy, win, atom, 0, 0, False, AnyPropertyType, &type_ret, &format_ret, &num_ret, &bytes_after, &prop_ret);

Xlib generates the request to the X server to retrieve the

property and appends it to its buffer of requests. Since

this is a request that requires a response, Xlib then

flushes the buffer, sending the contents to the X

server. Next, Xlib waits until the X server processes all

the requests preceding the property retrieve request, and

sends the property retrieve reply. Xlib then returns the

reply to the client.

Xlib also provides convenience functions that wrap a

property request. These convenience functions retrieve

specific properties, knowing the details of each property

and how to request and decode it. Examples include

XGetWMName and XGetWMHints. Some of these functions could be

written outside Xlib, but many use Xlib internals in

non-trivial ways and are thus inseparable. [Yes? --po8]

XCB on the other hand, provides functions generated directly

from the protocol descriptions in an "obvious" mechanistic

way. XCB functions map directly onto the protocol, with

separate functions to put requests into the outgoing buffer

and to read results back from the X server asynchronously

later. The XCB version of the above code is:

prop_cookie = xcb_get_property (dpy, False, win, atom, XCB_GET_PROPERTY_TYPE_ANY, 0, 0);

prop_reply = xcb_get_property_reply (dpy, prop_cookie, NULL);

The power of XCB is in allowing those two steps to have as

much code as you want between them. The programmer decides

when to wait for data, instead of being forced to wait for

the data returned by a request at the time the request is

issued.

Example: Converting xwininfo from Xlib to XCB

The program xwininfo is a command-line utility to print

information about windows on an X server. It knows in

advance, from the command line options, most of the data it

needs to request information for each window from the

server. Thus, xwininfo can make its requests all at once,

and then wait for the results to start coming in. When using

the -tree option to walk the window tree, xwininfo can

request the data for all the children of the current window

at once, batching even further. On a local connection on a

single CPU server, this means less context switches between

X client and server. On a multi-core/CPU server, the X

server can process requests on one core while the client is

handling the responses on another core as they become

available, improving performance. On remote connections, the

requests can be grouped into packets closer to the MTU size

of the connection, instead of just sending whatever requests

are in the buffer when a request is made that needs a

response.

Version 1.1 of xwininfo was converted from Xlib to XCB by

Alan Coopersmith. It was tested with a GNOME desktop session

with a few clients. xwininfo was run as "xwininfo -root

-all": this started xwininfo at the root of the window

hierarchy and asked it to traverse the tree, requesting all

the information available for each window along the way. In

this sample session it found 114 windows. (In X, a window is

simply a container for drawing output and receiving

events. X windows are often regions of, or borders around,

the "user windows"). When running locally on a four-core

Intel Nehalem CPU, both versions ran so fast (0.05 seconds

or less) that the difference in time was too small to

accurately measure. To measure remote performance, "ssh -X"

was used to tunnel an X11 connection from California to a

computer in China, and from there back to the workstation in

California, introducing a huge amount of latency. With this

setup, the difference was dramatic between the two:

Xlib: 0.03u 0.02s 8:19.12 0.0%

xcb: 0.00u 0.00s 0:45.26 0.0%

Of course, xwininfo is an unusual X application in a few ways:

xwininfo runs through the requests as fast as it can and

then exits, not waiting for user input (unless you use

the mode where you click on a window to choose it, after

which it runs through as normal). Once they are up and

running, most X applications spend most of their time

waiting for user input, so the overall runtime won't

decrease as much by reducing the time spent

communicating with the X server. However, application

startups are typically dominated by round-trip times,

and so proper use of XCB reduces the huge startup times

of X applications running over high-latency (and even

medium-latency) connections.

xwininfo uses only the core protocol and shape

extension. It does not use the more complex extensions,

such as Render or Xinput, that most modern applications

use. Xinput, XKB, and GLX are especially problematic, as

those have not yet been fully supported in an XCB

release, though support has been worked on through some

Google Summer of Code projects.

xwininfo is small enough that a complete reworking to

use XCB in one shot was feasible. Most applications are

much larger than this. XCB is aimed primarily at new

code and at toolkits: it is designed specifically to

interoperate with existing Xlib applications. Calls to

Xlib and XCB can be mixed, so Xlib applications can be

converted partially or incrementally if desired.

xwininfo used only raw Xlib, without any toolkit. Thus,

it did not have to worry about which X library the

toolkit used.

xwininfo uses only a few of the Xlib helper

functions. This makes it more directly mappable to

XCB. Applications that rely on Xlib's input method

framework, compose key handling or character set

conversion, for example, would be harder to

port. Fortunately, modern toolkits handle most of this

functionality in the toolkit layer anyway.

xwininfo did rely on Xlib helper functions for converting

the window name property from other character sets---the XCB

version currently only works for UTF-8 and Latin-1 window

names. Since most modern toolkits use UTF-8, no one is

likely to notice. Older applications with localized window

names will fail, but there are few of these in use.

Mixing Xlib & XCB calls

As mentioned above, XCB provides a method for incremental

conversion from Xlib to XCB. One can use libX11 to open the

display and pass the Display pointer it returns to existing

code, toolkits, and libraries. To call an XCB function, one

can convert the Display pointer to an xcb_connection_t

pointer for the same connection. This enables calling into

Xlib and XCB from the same application.

Xlib and XCB compatibility was achieved by rebuilding libX11

as a layer on top of libxcb. Xlib and XCB share the same X

server connection and pass control of it back and

forth. That option was introduced in libX11 1.2, and is now

always present (no longer optional) since the 2010 release

of libX11 1.4.

Example: Converting xdpyinfo extension queries to XCB

xdpyinfo is another command-line tool in the standard X

Window System toolset. Like xwininfo, xdpyinfo prints a lot

of information about the X server. xdpyinfo calls many

extensions, and few of its calls block waiting for a

response from the server. If you add the "-queryExt" option,

though, for every extension xdpyinfo calls XQueryExtension

to print which request, event, and error ids are assigned to

that extension in the currently running server. These ids

are dynamically assigned, and vary depending on the set of

extensions enabled in a given server

build/configuration. Thus, the list of extension ids is

critical information to have when debugging X error reports

that reference them. Using "xdpyinfo -queryExt" is

especially needed when reporting an X error message that

comes from a custom error handler like the one in the gtk

toolkit: such error handlers typically omit the extension

information found in the default Xlib error handler, so the

person reading the bug report will be unable to identify the

extension in which the error was encountered.

The Xlib call XQueryExtension takes one extension name at a

time, sends a request to the X server for the id codes for

that extension, and waits for a response so it can return

those ids to the caller. On the Xorg 1.7 server used as the

test system for this conversion, there were 30 active X

extensions, so that's 30 tiny packets sent to the X server,

30 times that the xdpyinfo client blocks in poll() waiting

for a response, and 30 times that the X server goes through

the client handling and request scheduling code before going

back to block again on its own select() loop.

Note: XListExtensions can be used to get a list of available

extensions that can be called with XQueryExtension.

A simple patch to xdpyinfo replaced just that loop of calls

to XQueryExtension with two loops. The first loop called

xcb_query_extension for each extension. When the entire

batch of queries had been issued, a second loop called

xcb_query_extension_reply to start collecting the batched

replies. Gathering system call counts with "truss -c" showed

the expected reduction in a number of system calls made by

the xdpyinfo client:

System call

Xlib

xcb

writev

40

11

poll

80

22

recv

117

29

total

237

62

Over a TCP connection, the switch to XCB for this

transaction reduced both the number of packets and (due to

tcp packet header overhead) the overall amount of data:

Xlib

xcb

TCP packets

93

35

TCP bytes

11554

7726

This sort of change is far more feasible than wholesale

conversion to XCB for most applications. Find the hotspots

where the application is waiting for data from the server

and convert those. There are almost always opportunities in

application startup code, when the application is gathering

the information about the X server and session. Converting

just those calls to more efficient sets of XCB calls can

have major performance benefits. Earlier work by X

developers reduced the latency of many applications by

converting repeated calls to XInternAtom with a single call

to fetch multiple atoms at once via XInternAtoms. XCB

permits a generalization of this principle.

Extension libraries

Each new extension to the X11 protocol adds requests that

clients can make to the X server. To allow client software

to utilize these requests, most extensions offer API's built

on top of Xlib or XCB. These API's use the library's

connection marshalling to include their requests in the

stream sent to the X server.

In the early X11 releases, many of the smaller and more

common extensions were grouped into a common library,

libXext. You will find several there today which are still

in use, such as the MIT-SHM Shared Memory extension, the

SHAPE extension for non-rectangular windows, and the SYNC

extension for event synchronization. However, libXext also

includes some API's for extensions no longer found in

current Xorg server releases, such as App-Group and

Low-Bandwidth X (LBX), as well as extensions many apps never

use, such as DPMS for display power management. Since these

extension API's cannot be removed from libXext without

breaking any existing application which may be using them,

the code is stuck in there.

Accordingly, new Xlib extension API's are no longer added to

libXext. Instead a new library utilizing libX11 is created

for each extension. Having a library per extension makes it

easier to evolve the API for that extension, to deprecate an

obsolete extension and to only link it into the clients that

actually need it. Almost all modern extensions have their

own Xlib API library---libXrender for the RENDER extension,

libXcomposite for the COMPOSITE extension, and so on. A

handful of extensions are so core to the protocol

interaction that they are supported directly in libX11

itself, such as BigRequests, XC-MISC, and XKB.

When XCB added its API style to the mix, it followed the

newer style and created a "libxcb"-prefixed library for each

extension---libxcb-composite, libxcb-render, etc. Since XCB

can generates the API code for an extension automatically

from an XML description of the extension protocol, new

extension API's are created by simply adding the extension

description to the xcb-proto package and rebuilding.

Unfortunately, some of the older extensions have complex

protocols that are not easily described in the XML

syntax. Work is ongoing to extend the syntax and code

generator to handle these. The XKB & GLX protocols are

current challenges.

API documentation

To write code using Xlib or XCB, you'll need to know the

details of the library API. Xlib includes man pages for

most functions, providing a good API reference. libXext

includes man pages for some of the extension API's it

includes, but not all of them. Man page coverage is even

more spotty in the individual Xlib-based extension

libraries.

There's also a more complete guide to the Xlib API, and

specifications for many extension API's, in the X.Org online

doc set at http://www.x.org/releases/current/doc/.

For extensions without Xlib-style API documentation, the

calls are usually simple mappings to the protocol

specifications provided in the above-linked doc set.

For XCB, the documentation relies even more heavily on the

protocol specifications. The generated API is an exact

mapping to the X protocol; it translates the C call data

into X protocol encoded packets as straightforwardly as

possible. The connection management and other functions in

the XCB API are documented at

http://xcb.freedesktop.org/XcbApi/. Work is in progress on

adding support to XCB to generate Unix style reference man

pages from the XML protocol descriptions as well, for

developer convenience.

There is also a XCB tutorial, "Basic Graphics Programming

With The XCB Library" at

http://www.x.org/releases/current/doc/libxcb/tutorial/index.html.

Helping us improve our API documentation for either library

stack is always appreciated. See the Documentation chapter

later in this guide for more information.

The X New Developer’s Guide

<< The X Client Ecosystem

|

Using Extensions >>

Links:

ProgrammingDocumentation

Last edited Sun 14 Jul 2013 05:33:55 PM UTC

XCB: XCB API

XCB: XCB API

XCB

 1.12

Main Page

Related Pages

Modules

Data Structures

Files

Data Structures |

Macros |

Typedefs |

Enumerations |

Functions

XCB API

XCB Protocol Implementation.

More...

Data Structures

struct  xcb_char2b_t

 xcb_char2b_t More...

 

struct  xcb_char2b_iterator_t

 xcb_char2b_iterator_t More...

 

struct  xcb_window_iterator_t

 xcb_window_iterator_t More...

 

struct  xcb_pixmap_iterator_t

 xcb_pixmap_iterator_t More...

 

struct  xcb_cursor_iterator_t

 xcb_cursor_iterator_t More...

 

struct  xcb_font_iterator_t

 xcb_font_iterator_t More...

 

struct  xcb_gcontext_iterator_t

 xcb_gcontext_iterator_t More...

 

struct  xcb_colormap_iterator_t

 xcb_colormap_iterator_t More...

 

struct  xcb_atom_iterator_t

 xcb_atom_iterator_t More...

 

struct  xcb_drawable_iterator_t

 xcb_drawable_iterator_t More...

 

struct  xcb_fontable_iterator_t

 xcb_fontable_iterator_t More...

 

struct  xcb_bool32_iterator_t

 xcb_bool32_iterator_t More...

 

struct  xcb_visualid_iterator_t

 xcb_visualid_iterator_t More...

 

struct  xcb_timestamp_iterator_t

 xcb_timestamp_iterator_t More...

 

struct  xcb_keysym_iterator_t

 xcb_keysym_iterator_t More...

 

struct  xcb_keycode_iterator_t

 xcb_keycode_iterator_t More...

 

struct  xcb_keycode32_iterator_t

 xcb_keycode32_iterator_t More...

 

struct  xcb_button_iterator_t

 xcb_button_iterator_t More...

 

struct  xcb_point_t

 xcb_point_t More...

 

struct  xcb_point_iterator_t

 xcb_point_iterator_t More...

 

struct  xcb_rectangle_t

 xcb_rectangle_t More...

 

struct  xcb_rectangle_iterator_t

 xcb_rectangle_iterator_t More...

 

struct  xcb_arc_t

 xcb_arc_t More...

 

struct  xcb_arc_iterator_t

 xcb_arc_iterator_t More...

 

struct  xcb_format_t

 xcb_format_t More...

 

struct  xcb_format_iterator_t

 xcb_format_iterator_t More...

 

struct  xcb_visualtype_t

 xcb_visualtype_t More...

 

struct  xcb_visualtype_iterator_t

 xcb_visualtype_iterator_t More...

 

struct  xcb_depth_t

 xcb_depth_t More...

 

struct  xcb_depth_iterator_t

 xcb_depth_iterator_t More...

 

struct  xcb_screen_t

 xcb_screen_t More...

 

struct  xcb_screen_iterator_t

 xcb_screen_iterator_t More...

 

struct  xcb_setup_request_t

 xcb_setup_request_t More...

 

struct  xcb_setup_request_iterator_t

 xcb_setup_request_iterator_t More...

 

struct  xcb_setup_failed_t

 xcb_setup_failed_t More...

 

struct  xcb_setup_failed_iterator_t

 xcb_setup_failed_iterator_t More...

 

struct  xcb_setup_authenticate_t

 xcb_setup_authenticate_t More...

 

struct  xcb_setup_authenticate_iterator_t

 xcb_setup_authenticate_iterator_t More...

 

struct  xcb_setup_t

 xcb_setup_t More...

 

struct  xcb_setup_iterator_t

 xcb_setup_iterator_t More...

 

struct  xcb_key_press_event_t

 xcb_key_press_event_t More...

 

struct  xcb_button_press_event_t

 xcb_button_press_event_t More...

 

struct  xcb_motion_notify_event_t

 xcb_motion_notify_event_t More...

 

struct  xcb_enter_notify_event_t

 xcb_enter_notify_event_t More...

 

struct  xcb_focus_in_event_t

 xcb_focus_in_event_t More...

 

struct  xcb_keymap_notify_event_t

 xcb_keymap_notify_event_t More...

 

struct  xcb_expose_event_t

 xcb_expose_event_t More...

 

struct  xcb_graphics_exposure_event_t

 xcb_graphics_exposure_event_t More...

 

struct  xcb_no_exposure_event_t

 xcb_no_exposure_event_t More...

 

struct  xcb_visibility_notify_event_t

 xcb_visibility_notify_event_t More...

 

struct  xcb_create_notify_event_t

 xcb_create_notify_event_t More...

 

struct  xcb_destroy_notify_event_t

 xcb_destroy_notify_event_t More...

 

struct  xcb_unmap_notify_event_t

 xcb_unmap_notify_event_t More...

 

struct  xcb_map_notify_event_t

 xcb_map_notify_event_t More...

 

struct  xcb_map_request_event_t

 xcb_map_request_event_t More...

 

struct  xcb_reparent_notify_event_t

 xcb_reparent_notify_event_t More...

 

struct  xcb_configure_notify_event_t

 xcb_configure_notify_event_t More...

 

struct  xcb_configure_request_event_t

 xcb_configure_request_event_t More...

 

struct  xcb_gravity_notify_event_t

 xcb_gravity_notify_event_t More...

 

struct  xcb_resize_request_event_t

 xcb_resize_request_event_t More...

 

struct  xcb_circulate_notify_event_t

 xcb_circulate_notify_event_t More...

 

struct  xcb_property_notify_event_t

 xcb_property_notify_event_t More...

 

struct  xcb_selection_clear_event_t

 xcb_selection_clear_event_t More...

 

struct  xcb_selection_request_event_t

 xcb_selection_request_event_t More...

 

struct  xcb_selection_notify_event_t

 xcb_selection_notify_event_t More...

 

struct  xcb_colormap_notify_event_t

 xcb_colormap_notify_event_t More...

 

union  xcb_client_message_data_t

 xcb_client_message_data_t More...

 

struct  xcb_client_message_data_iterator_t

 xcb_client_message_data_iterator_t More...

 

struct  xcb_client_message_event_t

 xcb_client_message_event_t More...

 

struct  xcb_mapping_notify_event_t

 xcb_mapping_notify_event_t More...

 

struct  xcb_ge_generic_event_t

 xcb_ge_generic_event_t More...

 

struct  xcb_request_error_t

 xcb_request_error_t More...

 

struct  xcb_value_error_t

 xcb_value_error_t More...

 

struct  xcb_create_window_value_list_t

 xcb_create_window_value_list_t More...

 

struct  xcb_create_window_request_t

 xcb_create_window_request_t More...

 

struct  xcb_change_window_attributes_value_list_t

 xcb_change_window_attributes_value_list_t More...

 

struct  xcb_change_window_attributes_request_t

 xcb_change_window_attributes_request_t More...

 

struct  xcb_get_window_attributes_cookie_t

 xcb_get_window_attributes_cookie_t More...

 

struct  xcb_get_window_attributes_request_t

 xcb_get_window_attributes_request_t More...

 

struct  xcb_get_window_attributes_reply_t

 xcb_get_window_attributes_reply_t More...

 

struct  xcb_destroy_window_request_t

 xcb_destroy_window_request_t More...

 

struct  xcb_destroy_subwindows_request_t

 xcb_destroy_subwindows_request_t More...

 

struct  xcb_change_save_set_request_t

 xcb_change_save_set_request_t More...

 

struct  xcb_reparent_window_request_t

 xcb_reparent_window_request_t More...

 

struct  xcb_map_window_request_t

 xcb_map_window_request_t More...

 

struct  xcb_map_subwindows_request_t

 xcb_map_subwindows_request_t More...

 

struct  xcb_unmap_window_request_t

 xcb_unmap_window_request_t More...

 

struct  xcb_unmap_subwindows_request_t

 xcb_unmap_subwindows_request_t More...

 

struct  xcb_configure_window_value_list_t

 xcb_configure_window_value_list_t More...

 

struct  xcb_configure_window_request_t

 xcb_configure_window_request_t More...

 

struct  xcb_circulate_window_request_t

 xcb_circulate_window_request_t More...

 

struct  xcb_get_geometry_cookie_t

 xcb_get_geometry_cookie_t More...

 

struct  xcb_get_geometry_request_t

 xcb_get_geometry_request_t More...

 

struct  xcb_get_geometry_reply_t

 xcb_get_geometry_reply_t More...

 

struct  xcb_query_tree_cookie_t

 xcb_query_tree_cookie_t More...

 

struct  xcb_query_tree_request_t

 xcb_query_tree_request_t More...

 

struct  xcb_query_tree_reply_t

 xcb_query_tree_reply_t More...

 

struct  xcb_intern_atom_cookie_t

 xcb_intern_atom_cookie_t More...

 

struct  xcb_intern_atom_request_t

 xcb_intern_atom_request_t More...

 

struct  xcb_intern_atom_reply_t

 xcb_intern_atom_reply_t More...

 

struct  xcb_get_atom_name_cookie_t

 xcb_get_atom_name_cookie_t More...

 

struct  xcb_get_atom_name_request_t

 xcb_get_atom_name_request_t More...

 

struct  xcb_get_atom_name_reply_t

 xcb_get_atom_name_reply_t More...

 

struct  xcb_change_property_request_t

 xcb_change_property_request_t More...

 

struct  xcb_delete_property_request_t

 xcb_delete_property_request_t More...

 

struct  xcb_get_property_cookie_t

 xcb_get_property_cookie_t More...

 

struct  xcb_get_property_request_t

 xcb_get_property_request_t More...

 

struct  xcb_get_property_reply_t

 xcb_get_property_reply_t More...

 

struct  xcb_list_properties_cookie_t

 xcb_list_properties_cookie_t More...

 

struct  xcb_list_properties_request_t

 xcb_list_properties_request_t More...

 

struct  xcb_list_properties_reply_t

 xcb_list_properties_reply_t More...

 

struct  xcb_set_selection_owner_request_t

 xcb_set_selection_owner_request_t More...

 

struct  xcb_get_selection_owner_cookie_t

 xcb_get_selection_owner_cookie_t More...

 

struct  xcb_get_selection_owner_request_t

 xcb_get_selection_owner_request_t More...

 

struct  xcb_get_selection_owner_reply_t

 xcb_get_selection_owner_reply_t More...

 

struct  xcb_convert_selection_request_t

 xcb_convert_selection_request_t More...

 

struct  xcb_send_event_request_t

 xcb_send_event_request_t More...

 

struct  xcb_grab_pointer_cookie_t

 xcb_grab_pointer_cookie_t More...

 

struct  xcb_grab_pointer_request_t

 xcb_grab_pointer_request_t More...

 

struct  xcb_grab_pointer_reply_t

 xcb_grab_pointer_reply_t More...

 

struct  xcb_ungrab_pointer_request_t

 xcb_ungrab_pointer_request_t More...

 

struct  xcb_grab_button_request_t

 xcb_grab_button_request_t More...

 

struct  xcb_ungrab_button_request_t

 xcb_ungrab_button_request_t More...

 

struct  xcb_change_active_pointer_grab_request_t

 xcb_change_active_pointer_grab_request_t More...

 

struct  xcb_grab_keyboard_cookie_t

 xcb_grab_keyboard_cookie_t More...

 

struct  xcb_grab_keyboard_request_t

 xcb_grab_keyboard_request_t More...

 

struct  xcb_grab_keyboard_reply_t

 xcb_grab_keyboard_reply_t More...

 

struct  xcb_ungrab_keyboard_request_t

 xcb_ungrab_keyboard_request_t More...

 

struct  xcb_grab_key_request_t

 xcb_grab_key_request_t More...

 

struct  xcb_ungrab_key_request_t

 xcb_ungrab_key_request_t More...

 

struct  xcb_allow_events_request_t

 xcb_allow_events_request_t More...

 

struct  xcb_grab_server_request_t

 xcb_grab_server_request_t More...

 

struct  xcb_ungrab_server_request_t

 xcb_ungrab_server_request_t More...

 

struct  xcb_query_pointer_cookie_t

 xcb_query_pointer_cookie_t More...

 

struct  xcb_query_pointer_request_t

 xcb_query_pointer_request_t More...

 

struct  xcb_query_pointer_reply_t

 xcb_query_pointer_reply_t More...

 

struct  xcb_timecoord_t

 xcb_timecoord_t More...

 

struct  xcb_timecoord_iterator_t

 xcb_timecoord_iterator_t More...

 

struct  xcb_get_motion_events_cookie_t

 xcb_get_motion_events_cookie_t More...

 

struct  xcb_get_motion_events_request_t

 xcb_get_motion_events_request_t More...

 

struct  xcb_get_motion_events_reply_t

 xcb_get_motion_events_reply_t More...

 

struct  xcb_translate_coordinates_cookie_t

 xcb_translate_coordinates_cookie_t More...

 

struct  xcb_translate_coordinates_request_t

 xcb_translate_coordinates_request_t More...

 

struct  xcb_translate_coordinates_reply_t

 xcb_translate_coordinates_reply_t More...

 

struct  xcb_warp_pointer_request_t

 xcb_warp_pointer_request_t More...

 

struct  xcb_set_input_focus_request_t

 xcb_set_input_focus_request_t More...

 

struct  xcb_get_input_focus_cookie_t

 xcb_get_input_focus_cookie_t More...

 

struct  xcb_get_input_focus_request_t

 xcb_get_input_focus_request_t More...

 

struct  xcb_get_input_focus_reply_t

 xcb_get_input_focus_reply_t More...

 

struct  xcb_query_keymap_cookie_t

 xcb_query_keymap_cookie_t More...

 

struct  xcb_query_keymap_request_t

 xcb_query_keymap_request_t More...

 

struct  xcb_query_keymap_reply_t

 xcb_query_keymap_reply_t More...

 

struct  xcb_open_font_request_t

 xcb_open_font_request_t More...

 

struct  xcb_close_font_request_t

 xcb_close_font_request_t More...

 

struct  xcb_fontprop_t

 xcb_fontprop_t More...

 

struct  xcb_fontprop_iterator_t

 xcb_fontprop_iterator_t More...

 

struct  xcb_charinfo_t

 xcb_charinfo_t More...

 

struct  xcb_charinfo_iterator_t

 xcb_charinfo_iterator_t More...

 

struct  xcb_query_font_cookie_t

 xcb_query_font_cookie_t More...

 

struct  xcb_query_font_request_t

 xcb_query_font_request_t More...

 

struct  xcb_query_font_reply_t

 xcb_query_font_reply_t More...

 

struct  xcb_query_text_extents_cookie_t

 xcb_query_text_extents_cookie_t More...

 

struct  xcb_query_text_extents_request_t

 xcb_query_text_extents_request_t More...

 

struct  xcb_query_text_extents_reply_t

 xcb_query_text_extents_reply_t More...

 

struct  xcb_str_t

 xcb_str_t More...

 

struct  xcb_str_iterator_t

 xcb_str_iterator_t More...

 

struct  xcb_list_fonts_cookie_t

 xcb_list_fonts_cookie_t More...

 

struct  xcb_list_fonts_request_t

 xcb_list_fonts_request_t More...

 

struct  xcb_list_fonts_reply_t

 xcb_list_fonts_reply_t More...

 

struct  xcb_list_fonts_with_info_cookie_t

 xcb_list_fonts_with_info_cookie_t More...

 

struct  xcb_list_fonts_with_info_request_t

 xcb_list_fonts_with_info_request_t More...

 

struct  xcb_list_fonts_with_info_reply_t

 xcb_list_fonts_with_info_reply_t More...

 

struct  xcb_set_font_path_request_t

 xcb_set_font_path_request_t More...

 

struct  xcb_get_font_path_cookie_t

 xcb_get_font_path_cookie_t More...

 

struct  xcb_get_font_path_request_t

 xcb_get_font_path_request_t More...

 

struct  xcb_get_font_path_reply_t

 xcb_get_font_path_reply_t More...

 

struct  xcb_create_pixmap_request_t

 xcb_create_pixmap_request_t More...

 

struct  xcb_free_pixmap_request_t

 xcb_free_pixmap_request_t More...

 

struct  xcb_create_gc_value_list_t

 xcb_create_gc_value_list_t More...

 

struct  xcb_create_gc_request_t

 xcb_create_gc_request_t More...

 

struct  xcb_change_gc_value_list_t

 xcb_change_gc_value_list_t More...

 

struct  xcb_change_gc_request_t

 xcb_change_gc_request_t More...

 

struct  xcb_copy_gc_request_t

 xcb_copy_gc_request_t More...

 

struct  xcb_set_dashes_request_t

 xcb_set_dashes_request_t More...

 

struct  xcb_set_clip_rectangles_request_t

 xcb_set_clip_rectangles_request_t More...

 

struct  xcb_free_gc_request_t

 xcb_free_gc_request_t More...

 

struct  xcb_clear_area_request_t

 xcb_clear_area_request_t More...

 

struct  xcb_copy_area_request_t

 xcb_copy_area_request_t More...

 

struct  xcb_copy_plane_request_t

 xcb_copy_plane_request_t More...

 

struct  xcb_poly_point_request_t

 xcb_poly_point_request_t More...

 

struct  xcb_poly_line_request_t

 xcb_poly_line_request_t More...

 

struct  xcb_segment_t

 xcb_segment_t More...

 

struct  xcb_segment_iterator_t

 xcb_segment_iterator_t More...

 

struct  xcb_poly_segment_request_t

 xcb_poly_segment_request_t More...

 

struct  xcb_poly_rectangle_request_t

 xcb_poly_rectangle_request_t More...

 

struct  xcb_poly_arc_request_t

 xcb_poly_arc_request_t More...

 

struct  xcb_fill_poly_request_t

 xcb_fill_poly_request_t More...

 

struct  xcb_poly_fill_rectangle_request_t

 xcb_poly_fill_rectangle_request_t More...

 

struct  xcb_poly_fill_arc_request_t

 xcb_poly_fill_arc_request_t More...

 

struct  xcb_put_image_request_t

 xcb_put_image_request_t More...

 

struct  xcb_get_image_cookie_t

 xcb_get_image_cookie_t More...

 

struct  xcb_get_image_request_t

 xcb_get_image_request_t More...

 

struct  xcb_get_image_reply_t

 xcb_get_image_reply_t More...

 

struct  xcb_poly_text_8_request_t

 xcb_poly_text_8_request_t More...

 

struct  xcb_poly_text_16_request_t

 xcb_poly_text_16_request_t More...

 

struct  xcb_image_text_8_request_t

 xcb_image_text_8_request_t More...

 

struct  xcb_image_text_16_request_t

 xcb_image_text_16_request_t More...

 

struct  xcb_create_colormap_request_t

 xcb_create_colormap_request_t More...

 

struct  xcb_free_colormap_request_t

 xcb_free_colormap_request_t More...

 

struct  xcb_copy_colormap_and_free_request_t

 xcb_copy_colormap_and_free_request_t More...

 

struct  xcb_install_colormap_request_t

 xcb_install_colormap_request_t More...

 

struct  xcb_uninstall_colormap_request_t

 xcb_uninstall_colormap_request_t More...

 

struct  xcb_list_installed_colormaps_cookie_t

 xcb_list_installed_colormaps_cookie_t More...

 

struct  xcb_list_installed_colormaps_request_t

 xcb_list_installed_colormaps_request_t More...

 

struct  xcb_list_installed_colormaps_reply_t

 xcb_list_installed_colormaps_reply_t More...

 

struct  xcb_alloc_color_cookie_t

 xcb_alloc_color_cookie_t More...

 

struct  xcb_alloc_color_request_t

 xcb_alloc_color_request_t More...

 

struct  xcb_alloc_color_reply_t

 xcb_alloc_color_reply_t More...

 

struct  xcb_alloc_named_color_cookie_t

 xcb_alloc_named_color_cookie_t More...

 

struct  xcb_alloc_named_color_request_t

 xcb_alloc_named_color_request_t More...

 

struct  xcb_alloc_named_color_reply_t

 xcb_alloc_named_color_reply_t More...

 

struct  xcb_alloc_color_cells_cookie_t

 xcb_alloc_color_cells_cookie_t More...

 

struct  xcb_alloc_color_cells_request_t

 xcb_alloc_color_cells_request_t More...

 

struct  xcb_alloc_color_cells_reply_t

 xcb_alloc_color_cells_reply_t More...

 

struct  xcb_alloc_color_planes_cookie_t

 xcb_alloc_color_planes_cookie_t More...

 

struct  xcb_alloc_color_planes_request_t

 xcb_alloc_color_planes_request_t More...

 

struct  xcb_alloc_color_planes_reply_t

 xcb_alloc_color_planes_reply_t More...

 

struct  xcb_free_colors_request_t

 xcb_free_colors_request_t More...

 

struct  xcb_coloritem_t

 xcb_coloritem_t More...

 

struct  xcb_coloritem_iterator_t

 xcb_coloritem_iterator_t More...

 

struct  xcb_store_colors_request_t

 xcb_store_colors_request_t More...

 

struct  xcb_store_named_color_request_t

 xcb_store_named_color_request_t More...

 

struct  xcb_rgb_t

 xcb_rgb_t More...

 

struct  xcb_rgb_iterator_t

 xcb_rgb_iterator_t More...

 

struct  xcb_query_colors_cookie_t

 xcb_query_colors_cookie_t More...

 

struct  xcb_query_colors_request_t

 xcb_query_colors_request_t More...

 

struct  xcb_query_colors_reply_t

 xcb_query_colors_reply_t More...

 

struct  xcb_lookup_color_cookie_t

 xcb_lookup_color_cookie_t More...

 

struct  xcb_lookup_color_request_t

 xcb_lookup_color_request_t More...

 

struct  xcb_lookup_color_reply_t

 xcb_lookup_color_reply_t More...

 

struct  xcb_create_cursor_request_t

 xcb_create_cursor_request_t More...

 

struct  xcb_create_glyph_cursor_request_t

 xcb_create_glyph_cursor_request_t More...

 

struct  xcb_free_cursor_request_t

 xcb_free_cursor_request_t More...

 

struct  xcb_recolor_cursor_request_t

 xcb_recolor_cursor_request_t More...

 

struct  xcb_query_best_size_cookie_t

 xcb_query_best_size_cookie_t More...

 

struct  xcb_query_best_size_request_t

 xcb_query_best_size_request_t More...

 

struct  xcb_query_best_size_reply_t

 xcb_query_best_size_reply_t More...

 

struct  xcb_query_extension_cookie_t

 xcb_query_extension_cookie_t More...

 

struct  xcb_query_extension_request_t

 xcb_query_extension_request_t More...

 

struct  xcb_query_extension_reply_t

 xcb_query_extension_reply_t More...

 

struct  xcb_list_extensions_cookie_t

 xcb_list_extensions_cookie_t More...

 

struct  xcb_list_extensions_request_t

 xcb_list_extensions_request_t More...

 

struct  xcb_list_extensions_reply_t

 xcb_list_extensions_reply_t More...

 

struct  xcb_change_keyboard_mapping_request_t

 xcb_change_keyboard_mapping_request_t More...

 

struct  xcb_get_keyboard_mapping_cookie_t

 xcb_get_keyboard_mapping_cookie_t More...

 

struct  xcb_get_keyboard_mapping_request_t

 xcb_get_keyboard_mapping_request_t More...

 

struct  xcb_get_keyboard_mapping_reply_t

 xcb_get_keyboard_mapping_reply_t More...

 

struct  xcb_change_keyboard_control_value_list_t

 xcb_change_keyboard_control_value_list_t More...

 

struct  xcb_change_keyboard_control_request_t

 xcb_change_keyboard_control_request_t More...

 

struct  xcb_get_keyboard_control_cookie_t

 xcb_get_keyboard_control_cookie_t More...

 

struct  xcb_get_keyboard_control_request_t

 xcb_get_keyboard_control_request_t More...

 

struct  xcb_get_keyboard_control_reply_t

 xcb_get_keyboard_control_reply_t More...

 

struct  xcb_bell_request_t

 xcb_bell_request_t More...

 

struct  xcb_change_pointer_control_request_t

 xcb_change_pointer_control_request_t More...

 

struct  xcb_get_pointer_control_cookie_t

 xcb_get_pointer_control_cookie_t More...

 

struct  xcb_get_pointer_control_request_t

 xcb_get_pointer_control_request_t More...

 

struct  xcb_get_pointer_control_reply_t

 xcb_get_pointer_control_reply_t More...

 

struct  xcb_set_screen_saver_request_t

 xcb_set_screen_saver_request_t More...

 

struct  xcb_get_screen_saver_cookie_t

 xcb_get_screen_saver_cookie_t More...

 

struct  xcb_get_screen_saver_request_t

 xcb_get_screen_saver_request_t More...

 

struct  xcb_get_screen_saver_reply_t

 xcb_get_screen_saver_reply_t More...

 

struct  xcb_change_hosts_request_t

 xcb_change_hosts_request_t More...

 

struct  xcb_host_t

 xcb_host_t More...

 

struct  xcb_host_iterator_t

 xcb_host_iterator_t More...

 

struct  xcb_list_hosts_cookie_t

 xcb_list_hosts_cookie_t More...

 

struct  xcb_list_hosts_request_t

 xcb_list_hosts_request_t More...

 

struct  xcb_list_hosts_reply_t

 xcb_list_hosts_reply_t More...

 

struct  xcb_set_access_control_request_t

 xcb_set_access_control_request_t More...

 

struct  xcb_set_close_down_mode_request_t

 xcb_set_close_down_mode_request_t More...

 

struct  xcb_kill_client_request_t

 xcb_kill_client_request_t More...

 

struct  xcb_rotate_properties_request_t

 xcb_rotate_properties_request_t More...

 

struct  xcb_force_screen_saver_request_t

 xcb_force_screen_saver_request_t More...

 

struct  xcb_set_pointer_mapping_cookie_t

 xcb_set_pointer_mapping_cookie_t More...

 

struct  xcb_set_pointer_mapping_request_t

 xcb_set_pointer_mapping_request_t More...

 

struct  xcb_set_pointer_mapping_reply_t

 xcb_set_pointer_mapping_reply_t More...

 

struct  xcb_get_pointer_mapping_cookie_t

 xcb_get_pointer_mapping_cookie_t More...

 

struct  xcb_get_pointer_mapping_request_t

 xcb_get_pointer_mapping_request_t More...

 

struct  xcb_get_pointer_mapping_reply_t

 xcb_get_pointer_mapping_reply_t More...

 

struct  xcb_set_modifier_mapping_cookie_t

 xcb_set_modifier_mapping_cookie_t More...

 

struct  xcb_set_modifier_mapping_request_t

 xcb_set_modifier_mapping_request_t More...

 

struct  xcb_set_modifier_mapping_reply_t

 xcb_set_modifier_mapping_reply_t More...

 

struct  xcb_get_modifier_mapping_cookie_t

 xcb_get_modifier_mapping_cookie_t More...

 

struct  xcb_get_modifier_mapping_request_t

 xcb_get_modifier_mapping_request_t More...

 

struct  xcb_get_modifier_mapping_reply_t

 xcb_get_modifier_mapping_reply_t More...

 

struct  xcb_no_operation_request_t

 xcb_no_operation_request_t More...

 

Macros

#define XCB_KEY_PRESS   2

 

#define XCB_KEY_RELEASE   3

 

#define XCB_BUTTON_PRESS   4

 

#define XCB_BUTTON_RELEASE   5

 

#define XCB_MOTION_NOTIFY   6

 

#define XCB_ENTER_NOTIFY   7

 

#define XCB_LEAVE_NOTIFY   8

 

#define XCB_FOCUS_IN   9

 

#define XCB_FOCUS_OUT   10

 

#define XCB_KEYMAP_NOTIFY   11

 

#define XCB_EXPOSE   12

 

#define XCB_GRAPHICS_EXPOSURE   13

 

#define XCB_NO_EXPOSURE   14

 

#define XCB_VISIBILITY_NOTIFY   15

 

#define XCB_CREATE_NOTIFY   16

 

#define XCB_DESTROY_NOTIFY   17

 

#define XCB_UNMAP_NOTIFY   18

 

#define XCB_MAP_NOTIFY   19

 

#define XCB_MAP_REQUEST   20

 

#define XCB_REPARENT_NOTIFY   21

 

#define XCB_CONFIGURE_NOTIFY   22

 

#define XCB_CONFIGURE_REQUEST   23

 

#define XCB_GRAVITY_NOTIFY   24

 

#define XCB_RESIZE_REQUEST   25

 

#define XCB_CIRCULATE_NOTIFY   26

 

#define XCB_CIRCULATE_REQUEST   27

 

#define XCB_PROPERTY_NOTIFY   28

 

#define XCB_SELECTION_CLEAR   29

 

#define XCB_SELECTION_REQUEST   30

 

#define XCB_SELECTION_NOTIFY   31

 

#define XCB_COLORMAP_NOTIFY   32

 

#define XCB_CLIENT_MESSAGE   33

 

#define XCB_MAPPING_NOTIFY   34

 

#define XCB_GE_GENERIC   35

 

#define XCB_REQUEST   1

 

#define XCB_VALUE   2

 

#define XCB_WINDOW   3

 

#define XCB_PIXMAP   4

 

#define XCB_ATOM   5

 

#define XCB_CURSOR   6

 

#define XCB_FONT   7

 

#define XCB_MATCH   8

 

#define XCB_DRAWABLE   9

 

#define XCB_ACCESS   10

 

#define XCB_ALLOC   11

 

#define XCB_COLORMAP   12

 

#define XCB_G_CONTEXT   13

 

#define XCB_ID_CHOICE   14

 

#define XCB_NAME   15

 

#define XCB_LENGTH   16

 

#define XCB_IMPLEMENTATION   17

 

#define XCB_CREATE_WINDOW   1

 

#define XCB_CHANGE_WINDOW_ATTRIBUTES   2

 

#define XCB_GET_WINDOW_ATTRIBUTES   3

 

#define XCB_DESTROY_WINDOW   4

 

#define XCB_DESTROY_SUBWINDOWS   5

 

#define XCB_CHANGE_SAVE_SET   6

 

#define XCB_REPARENT_WINDOW   7

 

#define XCB_MAP_WINDOW   8

 

#define XCB_MAP_SUBWINDOWS   9

 

#define XCB_UNMAP_WINDOW   10

 

#define XCB_UNMAP_SUBWINDOWS   11

 

#define XCB_CONFIGURE_WINDOW   12

 

#define XCB_CIRCULATE_WINDOW   13

 

#define XCB_GET_GEOMETRY   14

 

#define XCB_QUERY_TREE   15

 

#define XCB_INTERN_ATOM   16

 

#define XCB_GET_ATOM_NAME   17

 

#define XCB_CHANGE_PROPERTY   18

 

#define XCB_DELETE_PROPERTY   19

 

#define XCB_GET_PROPERTY   20

 

#define XCB_LIST_PROPERTIES   21

 

#define XCB_SET_SELECTION_OWNER   22

 

#define XCB_GET_SELECTION_OWNER   23

 

#define XCB_CONVERT_SELECTION   24

 

#define XCB_SEND_EVENT   25

 

#define XCB_GRAB_POINTER   26

 

#define XCB_UNGRAB_POINTER   27

 

#define XCB_GRAB_BUTTON   28

 

#define XCB_UNGRAB_BUTTON   29

 

#define XCB_CHANGE_ACTIVE_POINTER_GRAB   30

 

#define XCB_GRAB_KEYBOARD   31

 

#define XCB_UNGRAB_KEYBOARD   32

 

#define XCB_GRAB_KEY   33

 

#define XCB_UNGRAB_KEY   34

 

#define XCB_ALLOW_EVENTS   35

 

#define XCB_GRAB_SERVER   36

 

#define XCB_UNGRAB_SERVER   37

 

#define XCB_QUERY_POINTER   38

 

#define XCB_GET_MOTION_EVENTS   39

 

#define XCB_TRANSLATE_COORDINATES   40

 

#define XCB_WARP_POINTER   41

 

#define XCB_SET_INPUT_FOCUS   42

 

#define XCB_GET_INPUT_FOCUS   43

 

#define XCB_QUERY_KEYMAP   44

 

#define XCB_OPEN_FONT   45

 

#define XCB_CLOSE_FONT   46

 

#define XCB_QUERY_FONT   47

 

#define XCB_QUERY_TEXT_EXTENTS   48

 

#define XCB_LIST_FONTS   49

 

#define XCB_LIST_FONTS_WITH_INFO   50

 

#define XCB_SET_FONT_PATH   51

 

#define XCB_GET_FONT_PATH   52

 

#define XCB_CREATE_PIXMAP   53

 

#define XCB_FREE_PIXMAP   54

 

#define XCB_CREATE_GC   55

 

#define XCB_CHANGE_GC   56

 

#define XCB_COPY_GC   57

 

#define XCB_SET_DASHES   58

 

#define XCB_SET_CLIP_RECTANGLES   59

 

#define XCB_FREE_GC   60

 

#define XCB_CLEAR_AREA   61

 

#define XCB_COPY_AREA   62

 

#define XCB_COPY_PLANE   63

 

#define XCB_POLY_POINT   64

 

#define XCB_POLY_LINE   65

 

#define XCB_POLY_SEGMENT   66

 

#define XCB_POLY_RECTANGLE   67

 

#define XCB_POLY_ARC   68

 

#define XCB_FILL_POLY   69

 

#define XCB_POLY_FILL_RECTANGLE   70

 

#define XCB_POLY_FILL_ARC   71

 

#define XCB_PUT_IMAGE   72

 

#define XCB_GET_IMAGE   73

 

#define XCB_POLY_TEXT_8   74

 

#define XCB_POLY_TEXT_16   75

 

#define XCB_IMAGE_TEXT_8   76

 

#define XCB_IMAGE_TEXT_16   77

 

#define XCB_CREATE_COLORMAP   78

 

#define XCB_FREE_COLORMAP   79

 

#define XCB_COPY_COLORMAP_AND_FREE   80

 

#define XCB_INSTALL_COLORMAP   81

 

#define XCB_UNINSTALL_COLORMAP   82

 

#define XCB_LIST_INSTALLED_COLORMAPS   83

 

#define XCB_ALLOC_COLOR   84

 

#define XCB_ALLOC_NAMED_COLOR   85

 

#define XCB_ALLOC_COLOR_CELLS   86

 

#define XCB_ALLOC_COLOR_PLANES   87

 

#define XCB_FREE_COLORS   88

 

#define XCB_STORE_COLORS   89

 

#define XCB_STORE_NAMED_COLOR   90

 

#define XCB_QUERY_COLORS   91

 

#define XCB_LOOKUP_COLOR   92

 

#define XCB_CREATE_CURSOR   93

 

#define XCB_CREATE_GLYPH_CURSOR   94

 

#define XCB_FREE_CURSOR   95

 

#define XCB_RECOLOR_CURSOR   96

 

#define XCB_QUERY_BEST_SIZE   97

 

#define XCB_QUERY_EXTENSION   98

 

#define XCB_LIST_EXTENSIONS   99

 

#define XCB_CHANGE_KEYBOARD_MAPPING   100

 

#define XCB_GET_KEYBOARD_MAPPING   101

 

#define XCB_CHANGE_KEYBOARD_CONTROL   102

 

#define XCB_GET_KEYBOARD_CONTROL   103

 

#define XCB_BELL   104

 

#define XCB_CHANGE_POINTER_CONTROL   105

 

#define XCB_GET_POINTER_CONTROL   106

 

#define XCB_SET_SCREEN_SAVER   107

 

#define XCB_GET_SCREEN_SAVER   108

 

#define XCB_CHANGE_HOSTS   109

 

#define XCB_LIST_HOSTS   110

 

#define XCB_SET_ACCESS_CONTROL   111

 

#define XCB_SET_CLOSE_DOWN_MODE   112

 

#define XCB_KILL_CLIENT   113

 

#define XCB_ROTATE_PROPERTIES   114

 

#define XCB_FORCE_SCREEN_SAVER   115

 

#define XCB_SET_POINTER_MAPPING   116

 

#define XCB_GET_POINTER_MAPPING   117

 

#define XCB_SET_MODIFIER_MAPPING   118

 

#define XCB_GET_MODIFIER_MAPPING   119

 

#define XCB_NO_OPERATION   127

 

Typedefs

typedef struct xcb_char2b_t xcb_char2b_t

 xcb_char2b_t

 

typedef struct xcb_char2b_iterator_t xcb_char2b_iterator_t

 xcb_char2b_iterator_t

 

typedef uint32_t xcb_window_t

 

typedef struct xcb_window_iterator_t xcb_window_iterator_t

 xcb_window_iterator_t

 

typedef uint32_t xcb_pixmap_t

 

typedef struct xcb_pixmap_iterator_t xcb_pixmap_iterator_t

 xcb_pixmap_iterator_t

 

typedef uint32_t xcb_cursor_t

 

typedef struct xcb_cursor_iterator_t xcb_cursor_iterator_t

 xcb_cursor_iterator_t

 

typedef uint32_t xcb_font_t

 

typedef struct xcb_font_iterator_t xcb_font_iterator_t

 xcb_font_iterator_t

 

typedef uint32_t xcb_gcontext_t

 

typedef struct xcb_gcontext_iterator_t xcb_gcontext_iterator_t

 xcb_gcontext_iterator_t

 

typedef uint32_t xcb_colormap_t

 

typedef struct xcb_colormap_iterator_t xcb_colormap_iterator_t

 xcb_colormap_iterator_t

 

typedef uint32_t xcb_atom_t

 

typedef struct xcb_atom_iterator_t xcb_atom_iterator_t

 xcb_atom_iterator_t

 

typedef uint32_t xcb_drawable_t

 

typedef struct xcb_drawable_iterator_t xcb_drawable_iterator_t

 xcb_drawable_iterator_t

 

typedef uint32_t xcb_fontable_t

 

typedef struct xcb_fontable_iterator_t xcb_fontable_iterator_t

 xcb_fontable_iterator_t

 

typedef uint32_t xcb_bool32_t

 

typedef struct xcb_bool32_iterator_t xcb_bool32_iterator_t

 xcb_bool32_iterator_t

 

typedef uint32_t xcb_visualid_t

 

typedef struct xcb_visualid_iterator_t xcb_visualid_iterator_t

 xcb_visualid_iterator_t

 

typedef uint32_t xcb_timestamp_t

 

typedef struct xcb_timestamp_iterator_t xcb_timestamp_iterator_t

 xcb_timestamp_iterator_t

 

typedef uint32_t xcb_keysym_t

 

typedef struct xcb_keysym_iterator_t xcb_keysym_iterator_t

 xcb_keysym_iterator_t

 

typedef uint8_t xcb_keycode_t

 

typedef struct xcb_keycode_iterator_t xcb_keycode_iterator_t

 xcb_keycode_iterator_t

 

typedef uint32_t xcb_keycode32_t

 

typedef struct xcb_keycode32_iterator_t xcb_keycode32_iterator_t

 xcb_keycode32_iterator_t

 

typedef uint8_t xcb_button_t

 

typedef struct xcb_button_iterator_t xcb_button_iterator_t

 xcb_button_iterator_t

 

typedef struct xcb_point_t xcb_point_t

 xcb_point_t

 

typedef struct xcb_point_iterator_t xcb_point_iterator_t

 xcb_point_iterator_t

 

typedef struct xcb_rectangle_t xcb_rectangle_t

 xcb_rectangle_t

 

typedef struct xcb_rectangle_iterator_t xcb_rectangle_iterator_t

 xcb_rectangle_iterator_t

 

typedef struct xcb_arc_t xcb_arc_t

 xcb_arc_t

 

typedef struct xcb_arc_iterator_t xcb_arc_iterator_t

 xcb_arc_iterator_t

 

typedef struct xcb_format_t xcb_format_t

 xcb_format_t

 

typedef struct xcb_format_iterator_t xcb_format_iterator_t

 xcb_format_iterator_t

 

typedef enum xcb_visual_class_t xcb_visual_class_t

 

typedef struct xcb_visualtype_t xcb_visualtype_t

 xcb_visualtype_t

 

typedef struct xcb_visualtype_iterator_t xcb_visualtype_iterator_t

 xcb_visualtype_iterator_t

 

typedef struct xcb_depth_t xcb_depth_t

 xcb_depth_t

 

typedef struct xcb_depth_iterator_t xcb_depth_iterator_t

 xcb_depth_iterator_t

 

typedef enum xcb_event_mask_t xcb_event_mask_t

 

typedef enum xcb_backing_store_t xcb_backing_store_t

 

typedef struct xcb_screen_t xcb_screen_t

 xcb_screen_t

 

typedef struct xcb_screen_iterator_t xcb_screen_iterator_t

 xcb_screen_iterator_t

 

typedef struct xcb_setup_request_t xcb_setup_request_t

 xcb_setup_request_t

 

typedef struct xcb_setup_request_iterator_t xcb_setup_request_iterator_t

 xcb_setup_request_iterator_t

 

typedef struct xcb_setup_failed_t xcb_setup_failed_t

 xcb_setup_failed_t

 

typedef struct xcb_setup_failed_iterator_t xcb_setup_failed_iterator_t

 xcb_setup_failed_iterator_t

 

typedef struct xcb_setup_authenticate_t xcb_setup_authenticate_t

 xcb_setup_authenticate_t

 

typedef struct xcb_setup_authenticate_iterator_t xcb_setup_authenticate_iterator_t

 xcb_setup_authenticate_iterator_t

 

typedef enum xcb_image_order_t xcb_image_order_t

 

typedef struct xcb_setup_t xcb_setup_t

 xcb_setup_t

 

typedef struct xcb_setup_iterator_t xcb_setup_iterator_t

 xcb_setup_iterator_t

 

typedef enum xcb_mod_mask_t xcb_mod_mask_t

 

typedef enum xcb_key_but_mask_t xcb_key_but_mask_t

 

typedef enum xcb_window_enum_t xcb_window_enum_t

 

typedef struct xcb_key_press_event_t xcb_key_press_event_t

 xcb_key_press_event_t

 

typedef xcb_key_press_event_t xcb_key_release_event_t

 

typedef enum xcb_button_mask_t xcb_button_mask_t

 

typedef struct xcb_button_press_event_t xcb_button_press_event_t

 xcb_button_press_event_t

 

typedef xcb_button_press_event_t xcb_button_release_event_t

 

typedef enum xcb_motion_t xcb_motion_t

 

typedef struct xcb_motion_notify_event_t xcb_motion_notify_event_t

 xcb_motion_notify_event_t

 

typedef enum xcb_notify_detail_t xcb_notify_detail_t

 

typedef enum xcb_notify_mode_t xcb_notify_mode_t

 

typedef struct xcb_enter_notify_event_t xcb_enter_notify_event_t

 xcb_enter_notify_event_t

 

typedef xcb_enter_notify_event_t xcb_leave_notify_event_t

 

typedef struct xcb_focus_in_event_t xcb_focus_in_event_t

 xcb_focus_in_event_t

 

typedef xcb_focus_in_event_t xcb_focus_out_event_t

 

typedef struct xcb_keymap_notify_event_t xcb_keymap_notify_event_t

 xcb_keymap_notify_event_t

 

typedef struct xcb_expose_event_t xcb_expose_event_t

 xcb_expose_event_t

 

typedef struct xcb_graphics_exposure_event_t xcb_graphics_exposure_event_t

 xcb_graphics_exposure_event_t

 

typedef struct xcb_no_exposure_event_t xcb_no_exposure_event_t

 xcb_no_exposure_event_t

 

typedef enum xcb_visibility_t xcb_visibility_t

 

typedef struct xcb_visibility_notify_event_t xcb_visibility_notify_event_t

 xcb_visibility_notify_event_t

 

typedef struct xcb_create_notify_event_t xcb_create_notify_event_t

 xcb_create_notify_event_t

 

typedef struct xcb_destroy_notify_event_t xcb_destroy_notify_event_t

 xcb_destroy_notify_event_t

 

typedef struct xcb_unmap_notify_event_t xcb_unmap_notify_event_t

 xcb_unmap_notify_event_t

 

typedef struct xcb_map_notify_event_t xcb_map_notify_event_t

 xcb_map_notify_event_t

 

typedef struct xcb_map_request_event_t xcb_map_request_event_t

 xcb_map_request_event_t

 

typedef struct xcb_reparent_notify_event_t xcb_reparent_notify_event_t

 xcb_reparent_notify_event_t

 

typedef struct xcb_configure_notify_event_t xcb_configure_notify_event_t

 xcb_configure_notify_event_t

 

typedef struct xcb_configure_request_event_t xcb_configure_request_event_t

 xcb_configure_request_event_t

 

typedef struct xcb_gravity_notify_event_t xcb_gravity_notify_event_t

 xcb_gravity_notify_event_t

 

typedef struct xcb_resize_request_event_t xcb_resize_request_event_t

 xcb_resize_request_event_t

 

typedef enum xcb_place_t xcb_place_t

 

typedef struct xcb_circulate_notify_event_t xcb_circulate_notify_event_t

 xcb_circulate_notify_event_t

 

typedef xcb_circulate_notify_event_t xcb_circulate_request_event_t

 

typedef enum xcb_property_t xcb_property_t

 

typedef struct xcb_property_notify_event_t xcb_property_notify_event_t

 xcb_property_notify_event_t

 

typedef struct xcb_selection_clear_event_t xcb_selection_clear_event_t

 xcb_selection_clear_event_t

 

typedef enum xcb_time_t xcb_time_t

 

typedef enum xcb_atom_enum_t xcb_atom_enum_t

 

typedef struct xcb_selection_request_event_t xcb_selection_request_event_t

 xcb_selection_request_event_t

 

typedef struct xcb_selection_notify_event_t xcb_selection_notify_event_t

 xcb_selection_notify_event_t

 

typedef enum xcb_colormap_state_t xcb_colormap_state_t

 

typedef enum xcb_colormap_enum_t xcb_colormap_enum_t

 

typedef struct xcb_colormap_notify_event_t xcb_colormap_notify_event_t

 xcb_colormap_notify_event_t

 

typedef union xcb_client_message_data_t xcb_client_message_data_t

 xcb_client_message_data_t

 

typedef struct xcb_client_message_data_iterator_t xcb_client_message_data_iterator_t

 xcb_client_message_data_iterator_t

 

typedef struct xcb_client_message_event_t xcb_client_message_event_t

 xcb_client_message_event_t

 

typedef enum xcb_mapping_t xcb_mapping_t

 

typedef struct xcb_mapping_notify_event_t xcb_mapping_notify_event_t

 xcb_mapping_notify_event_t

 

typedef struct xcb_ge_generic_event_t xcb_ge_generic_event_t

 xcb_ge_generic_event_t

 

typedef struct xcb_request_error_t xcb_request_error_t

 xcb_request_error_t

 

typedef struct xcb_value_error_t xcb_value_error_t

 xcb_value_error_t

 

typedef xcb_value_error_t xcb_window_error_t

 

typedef xcb_value_error_t xcb_pixmap_error_t

 

typedef xcb_value_error_t xcb_atom_error_t

 

typedef xcb_value_error_t xcb_cursor_error_t

 

typedef xcb_value_error_t xcb_font_error_t

 

typedef xcb_request_error_t xcb_match_error_t

 

typedef xcb_value_error_t xcb_drawable_error_t

 

typedef xcb_request_error_t xcb_access_error_t

 

typedef xcb_request_error_t xcb_alloc_error_t

 

typedef xcb_value_error_t xcb_colormap_error_t

 

typedef xcb_value_error_t xcb_g_context_error_t

 

typedef xcb_value_error_t xcb_id_choice_error_t

 

typedef xcb_request_error_t xcb_name_error_t

 

typedef xcb_request_error_t xcb_length_error_t

 

typedef xcb_request_error_t xcb_implementation_error_t

 

typedef enum xcb_window_class_t xcb_window_class_t

 

typedef enum xcb_cw_t xcb_cw_t

 

typedef enum xcb_back_pixmap_t xcb_back_pixmap_t

 

typedef enum xcb_gravity_t xcb_gravity_t

 

typedef struct xcb_create_window_value_list_t xcb_create_window_value_list_t

 xcb_create_window_value_list_t

 

typedef struct xcb_create_window_request_t xcb_create_window_request_t

 xcb_create_window_request_t

 

typedef struct xcb_change_window_attributes_value_list_t xcb_change_window_attributes_value_list_t

 xcb_change_window_attributes_value_list_t

 

typedef struct xcb_change_window_attributes_request_t xcb_change_window_attributes_request_t

 xcb_change_window_attributes_request_t

 

typedef enum xcb_map_state_t xcb_map_state_t

 

typedef struct xcb_get_window_attributes_cookie_t xcb_get_window_attributes_cookie_t

 xcb_get_window_attributes_cookie_t

 

typedef struct xcb_get_window_attributes_request_t xcb_get_window_attributes_request_t

 xcb_get_window_attributes_request_t

 

typedef struct xcb_get_window_attributes_reply_t xcb_get_window_attributes_reply_t

 xcb_get_window_attributes_reply_t

 

typedef struct xcb_destroy_window_request_t xcb_destroy_window_request_t

 xcb_destroy_window_request_t

 

typedef struct xcb_destroy_subwindows_request_t xcb_destroy_subwindows_request_t

 xcb_destroy_subwindows_request_t

 

typedef enum xcb_set_mode_t xcb_set_mode_t

 

typedef struct xcb_change_save_set_request_t xcb_change_save_set_request_t

 xcb_change_save_set_request_t

 

typedef struct xcb_reparent_window_request_t xcb_reparent_window_request_t

 xcb_reparent_window_request_t

 

typedef struct xcb_map_window_request_t xcb_map_window_request_t

 xcb_map_window_request_t

 

typedef struct xcb_map_subwindows_request_t xcb_map_subwindows_request_t

 xcb_map_subwindows_request_t

 

typedef struct xcb_unmap_window_request_t xcb_unmap_window_request_t

 xcb_unmap_window_request_t

 

typedef struct xcb_unmap_subwindows_request_t xcb_unmap_subwindows_request_t

 xcb_unmap_subwindows_request_t

 

typedef enum xcb_config_window_t xcb_config_window_t

 

typedef enum xcb_stack_mode_t xcb_stack_mode_t

 

typedef struct xcb_configure_window_value_list_t xcb_configure_window_value_list_t

 xcb_configure_window_value_list_t

 

typedef struct xcb_configure_window_request_t xcb_configure_window_request_t

 xcb_configure_window_request_t

 

typedef enum xcb_circulate_t xcb_circulate_t

 

typedef struct xcb_circulate_window_request_t xcb_circulate_window_request_t

 xcb_circulate_window_request_t

 

typedef struct xcb_get_geometry_cookie_t xcb_get_geometry_cookie_t

 xcb_get_geometry_cookie_t

 

typedef struct xcb_get_geometry_request_t xcb_get_geometry_request_t

 xcb_get_geometry_request_t

 

typedef struct xcb_get_geometry_reply_t xcb_get_geometry_reply_t

 xcb_get_geometry_reply_t

 

typedef struct xcb_query_tree_cookie_t xcb_query_tree_cookie_t

 xcb_query_tree_cookie_t

 

typedef struct xcb_query_tree_request_t xcb_query_tree_request_t

 xcb_query_tree_request_t

 

typedef struct xcb_query_tree_reply_t xcb_query_tree_reply_t

 xcb_query_tree_reply_t

 

typedef struct xcb_intern_atom_cookie_t xcb_intern_atom_cookie_t

 xcb_intern_atom_cookie_t

 

typedef struct xcb_intern_atom_request_t xcb_intern_atom_request_t

 xcb_intern_atom_request_t

 

typedef struct xcb_intern_atom_reply_t xcb_intern_atom_reply_t

 xcb_intern_atom_reply_t

 

typedef struct xcb_get_atom_name_cookie_t xcb_get_atom_name_cookie_t

 xcb_get_atom_name_cookie_t

 

typedef struct xcb_get_atom_name_request_t xcb_get_atom_name_request_t

 xcb_get_atom_name_request_t

 

typedef struct xcb_get_atom_name_reply_t xcb_get_atom_name_reply_t

 xcb_get_atom_name_reply_t

 

typedef enum xcb_prop_mode_t xcb_prop_mode_t

 

typedef struct xcb_change_property_request_t xcb_change_property_request_t

 xcb_change_property_request_t

 

typedef struct xcb_delete_property_request_t xcb_delete_property_request_t

 xcb_delete_property_request_t

 

typedef enum xcb_get_property_type_t xcb_get_property_type_t

 

typedef struct xcb_get_property_cookie_t xcb_get_property_cookie_t

 xcb_get_property_cookie_t

 

typedef struct xcb_get_property_request_t xcb_get_property_request_t

 xcb_get_property_request_t

 

typedef struct xcb_get_property_reply_t xcb_get_property_reply_t

 xcb_get_property_reply_t

 

typedef struct xcb_list_properties_cookie_t xcb_list_properties_cookie_t

 xcb_list_properties_cookie_t

 

typedef struct xcb_list_properties_request_t xcb_list_properties_request_t

 xcb_list_properties_request_t

 

typedef struct xcb_list_properties_reply_t xcb_list_properties_reply_t

 xcb_list_properties_reply_t

 

typedef struct xcb_set_selection_owner_request_t xcb_set_selection_owner_request_t

 xcb_set_selection_owner_request_t

 

typedef struct xcb_get_selection_owner_cookie_t xcb_get_selection_owner_cookie_t

 xcb_get_selection_owner_cookie_t

 

typedef struct xcb_get_selection_owner_request_t xcb_get_selection_owner_request_t

 xcb_get_selection_owner_request_t

 

typedef struct xcb_get_selection_owner_reply_t xcb_get_selection_owner_reply_t

 xcb_get_selection_owner_reply_t

 

typedef struct xcb_convert_selection_request_t xcb_convert_selection_request_t

 xcb_convert_selection_request_t

 

typedef enum xcb_send_event_dest_t xcb_send_event_dest_t

 

typedef struct xcb_send_event_request_t xcb_send_event_request_t

 xcb_send_event_request_t

 

typedef enum xcb_grab_mode_t xcb_grab_mode_t

 

typedef enum xcb_grab_status_t xcb_grab_status_t

 

typedef enum xcb_cursor_enum_t xcb_cursor_enum_t

 

typedef struct xcb_grab_pointer_cookie_t xcb_grab_pointer_cookie_t

 xcb_grab_pointer_cookie_t

 

typedef struct xcb_grab_pointer_request_t xcb_grab_pointer_request_t

 xcb_grab_pointer_request_t

 

typedef struct xcb_grab_pointer_reply_t xcb_grab_pointer_reply_t

 xcb_grab_pointer_reply_t

 

typedef struct xcb_ungrab_pointer_request_t xcb_ungrab_pointer_request_t

 xcb_ungrab_pointer_request_t

 

typedef enum xcb_button_index_t xcb_button_index_t

 

typedef struct xcb_grab_button_request_t xcb_grab_button_request_t

 xcb_grab_button_request_t

 

typedef struct xcb_ungrab_button_request_t xcb_ungrab_button_request_t

 xcb_ungrab_button_request_t

 

typedef struct xcb_change_active_pointer_grab_request_t xcb_change_active_pointer_grab_request_t

 xcb_change_active_pointer_grab_request_t

 

typedef struct xcb_grab_keyboard_cookie_t xcb_grab_keyboard_cookie_t

 xcb_grab_keyboard_cookie_t

 

typedef struct xcb_grab_keyboard_request_t xcb_grab_keyboard_request_t

 xcb_grab_keyboard_request_t

 

typedef struct xcb_grab_keyboard_reply_t xcb_grab_keyboard_reply_t

 xcb_grab_keyboard_reply_t

 

typedef struct xcb_ungrab_keyboard_request_t xcb_ungrab_keyboard_request_t

 xcb_ungrab_keyboard_request_t

 

typedef enum xcb_grab_t xcb_grab_t

 

typedef struct xcb_grab_key_request_t xcb_grab_key_request_t

 xcb_grab_key_request_t

 

typedef struct xcb_ungrab_key_request_t xcb_ungrab_key_request_t

 xcb_ungrab_key_request_t

 

typedef enum xcb_allow_t xcb_allow_t

 

typedef struct xcb_allow_events_request_t xcb_allow_events_request_t

 xcb_allow_events_request_t

 

typedef struct xcb_grab_server_request_t xcb_grab_server_request_t

 xcb_grab_server_request_t

 

typedef struct xcb_ungrab_server_request_t xcb_ungrab_server_request_t

 xcb_ungrab_server_request_t

 

typedef struct xcb_query_pointer_cookie_t xcb_query_pointer_cookie_t

 xcb_query_pointer_cookie_t

 

typedef struct xcb_query_pointer_request_t xcb_query_pointer_request_t

 xcb_query_pointer_request_t

 

typedef struct xcb_query_pointer_reply_t xcb_query_pointer_reply_t

 xcb_query_pointer_reply_t

 

typedef struct xcb_timecoord_t xcb_timecoord_t

 xcb_timecoord_t

 

typedef struct xcb_timecoord_iterator_t xcb_timecoord_iterator_t

 xcb_timecoord_iterator_t

 

typedef struct xcb_get_motion_events_cookie_t xcb_get_motion_events_cookie_t

 xcb_get_motion_events_cookie_t

 

typedef struct xcb_get_motion_events_request_t xcb_get_motion_events_request_t

 xcb_get_motion_events_request_t

 

typedef struct xcb_get_motion_events_reply_t xcb_get_motion_events_reply_t

 xcb_get_motion_events_reply_t

 

typedef struct xcb_translate_coordinates_cookie_t xcb_translate_coordinates_cookie_t

 xcb_translate_coordinates_cookie_t

 

typedef struct xcb_translate_coordinates_request_t xcb_translate_coordinates_request_t

 xcb_translate_coordinates_request_t

 

typedef struct xcb_translate_coordinates_reply_t xcb_translate_coordinates_reply_t

 xcb_translate_coordinates_reply_t

 

typedef struct xcb_warp_pointer_request_t xcb_warp_pointer_request_t

 xcb_warp_pointer_request_t

 

typedef enum xcb_input_focus_t xcb_input_focus_t

 

typedef struct xcb_set_input_focus_request_t xcb_set_input_focus_request_t

 xcb_set_input_focus_request_t

 

typedef struct xcb_get_input_focus_cookie_t xcb_get_input_focus_cookie_t

 xcb_get_input_focus_cookie_t

 

typedef struct xcb_get_input_focus_request_t xcb_get_input_focus_request_t

 xcb_get_input_focus_request_t

 

typedef struct xcb_get_input_focus_reply_t xcb_get_input_focus_reply_t

 xcb_get_input_focus_reply_t

 

typedef struct xcb_query_keymap_cookie_t xcb_query_keymap_cookie_t

 xcb_query_keymap_cookie_t

 

typedef struct xcb_query_keymap_request_t xcb_query_keymap_request_t

 xcb_query_keymap_request_t

 

typedef struct xcb_query_keymap_reply_t xcb_query_keymap_reply_t

 xcb_query_keymap_reply_t

 

typedef struct xcb_open_font_request_t xcb_open_font_request_t

 xcb_open_font_request_t

 

typedef struct xcb_close_font_request_t xcb_close_font_request_t

 xcb_close_font_request_t

 

typedef enum xcb_font_draw_t xcb_font_draw_t

 

typedef struct xcb_fontprop_t xcb_fontprop_t

 xcb_fontprop_t

 

typedef struct xcb_fontprop_iterator_t xcb_fontprop_iterator_t

 xcb_fontprop_iterator_t

 

typedef struct xcb_charinfo_t xcb_charinfo_t

 xcb_charinfo_t

 

typedef struct xcb_charinfo_iterator_t xcb_charinfo_iterator_t

 xcb_charinfo_iterator_t

 

typedef struct xcb_query_font_cookie_t xcb_query_font_cookie_t

 xcb_query_font_cookie_t

 

typedef struct xcb_query_font_request_t xcb_query_font_request_t

 xcb_query_font_request_t

 

typedef struct xcb_query_font_reply_t xcb_query_font_reply_t

 xcb_query_font_reply_t

 

typedef struct xcb_query_text_extents_cookie_t xcb_query_text_extents_cookie_t

 xcb_query_text_extents_cookie_t

 

typedef struct xcb_query_text_extents_request_t xcb_query_text_extents_request_t

 xcb_query_text_extents_request_t

 

typedef struct xcb_query_text_extents_reply_t xcb_query_text_extents_reply_t

 xcb_query_text_extents_reply_t

 

typedef struct xcb_str_t xcb_str_t

 xcb_str_t

 

typedef struct xcb_str_iterator_t xcb_str_iterator_t

 xcb_str_iterator_t

 

typedef struct xcb_list_fonts_cookie_t xcb_list_fonts_cookie_t

 xcb_list_fonts_cookie_t

 

typedef struct xcb_list_fonts_request_t xcb_list_fonts_request_t

 xcb_list_fonts_request_t

 

typedef struct xcb_list_fonts_reply_t xcb_list_fonts_reply_t

 xcb_list_fonts_reply_t

 

typedef struct xcb_list_fonts_with_info_cookie_t xcb_list_fonts_with_info_cookie_t

 xcb_list_fonts_with_info_cookie_t

 

typedef struct xcb_list_fonts_with_info_request_t xcb_list_fonts_with_info_request_t

 xcb_list_fonts_with_info_request_t

 

typedef struct xcb_list_fonts_with_info_reply_t xcb_list_fonts_with_info_reply_t

 xcb_list_fonts_with_info_reply_t

 

typedef struct xcb_set_font_path_request_t xcb_set_font_path_request_t

 xcb_set_font_path_request_t

 

typedef struct xcb_get_font_path_cookie_t xcb_get_font_path_cookie_t

 xcb_get_font_path_cookie_t

 

typedef struct xcb_get_font_path_request_t xcb_get_font_path_request_t

 xcb_get_font_path_request_t

 

typedef struct xcb_get_font_path_reply_t xcb_get_font_path_reply_t

 xcb_get_font_path_reply_t

 

typedef struct xcb_create_pixmap_request_t xcb_create_pixmap_request_t

 xcb_create_pixmap_request_t

 

typedef struct xcb_free_pixmap_request_t xcb_free_pixmap_request_t

 xcb_free_pixmap_request_t

 

typedef enum xcb_gc_t xcb_gc_t

 

typedef enum xcb_gx_t xcb_gx_t

 

typedef enum xcb_line_style_t xcb_line_style_t

 

typedef enum xcb_cap_style_t xcb_cap_style_t

 

typedef enum xcb_join_style_t xcb_join_style_t

 

typedef enum xcb_fill_style_t xcb_fill_style_t

 

typedef enum xcb_fill_rule_t xcb_fill_rule_t

 

typedef enum xcb_subwindow_mode_t xcb_subwindow_mode_t

 

typedef enum xcb_arc_mode_t xcb_arc_mode_t

 

typedef struct xcb_create_gc_value_list_t xcb_create_gc_value_list_t

 xcb_create_gc_value_list_t

 

typedef struct xcb_create_gc_request_t xcb_create_gc_request_t

 xcb_create_gc_request_t

 

typedef struct xcb_change_gc_value_list_t xcb_change_gc_value_list_t

 xcb_change_gc_value_list_t

 

typedef struct xcb_change_gc_request_t xcb_change_gc_request_t

 xcb_change_gc_request_t

 

typedef struct xcb_copy_gc_request_t xcb_copy_gc_request_t

 xcb_copy_gc_request_t

 

typedef struct xcb_set_dashes_request_t xcb_set_dashes_request_t

 xcb_set_dashes_request_t

 

typedef enum xcb_clip_ordering_t xcb_clip_ordering_t

 

typedef struct xcb_set_clip_rectangles_request_t xcb_set_clip_rectangles_request_t

 xcb_set_clip_rectangles_request_t

 

typedef struct xcb_free_gc_request_t xcb_free_gc_request_t

 xcb_free_gc_request_t

 

typedef struct xcb_clear_area_request_t xcb_clear_area_request_t

 xcb_clear_area_request_t

 

typedef struct xcb_copy_area_request_t xcb_copy_area_request_t

 xcb_copy_area_request_t

 

typedef struct xcb_copy_plane_request_t xcb_copy_plane_request_t

 xcb_copy_plane_request_t

 

typedef enum xcb_coord_mode_t xcb_coord_mode_t

 

typedef struct xcb_poly_point_request_t xcb_poly_point_request_t

 xcb_poly_point_request_t

 

typedef struct xcb_poly_line_request_t xcb_poly_line_request_t

 xcb_poly_line_request_t

 

typedef struct xcb_segment_t xcb_segment_t

 xcb_segment_t

 

typedef struct xcb_segment_iterator_t xcb_segment_iterator_t

 xcb_segment_iterator_t

 

typedef struct xcb_poly_segment_request_t xcb_poly_segment_request_t

 xcb_poly_segment_request_t

 

typedef struct xcb_poly_rectangle_request_t xcb_poly_rectangle_request_t

 xcb_poly_rectangle_request_t

 

typedef struct xcb_poly_arc_request_t xcb_poly_arc_request_t

 xcb_poly_arc_request_t

 

typedef enum xcb_poly_shape_t xcb_poly_shape_t

 

typedef struct xcb_fill_poly_request_t xcb_fill_poly_request_t

 xcb_fill_poly_request_t

 

typedef struct xcb_poly_fill_rectangle_request_t xcb_poly_fill_rectangle_request_t

 xcb_poly_fill_rectangle_request_t

 

typedef struct xcb_poly_fill_arc_request_t xcb_poly_fill_arc_request_t

 xcb_poly_fill_arc_request_t

 

typedef enum xcb_image_format_t xcb_image_format_t

 

typedef struct xcb_put_image_request_t xcb_put_image_request_t

 xcb_put_image_request_t

 

typedef struct xcb_get_image_cookie_t xcb_get_image_cookie_t

 xcb_get_image_cookie_t

 

typedef struct xcb_get_image_request_t xcb_get_image_request_t

 xcb_get_image_request_t

 

typedef struct xcb_get_image_reply_t xcb_get_image_reply_t

 xcb_get_image_reply_t

 

typedef struct xcb_poly_text_8_request_t xcb_poly_text_8_request_t

 xcb_poly_text_8_request_t

 

typedef struct xcb_poly_text_16_request_t xcb_poly_text_16_request_t

 xcb_poly_text_16_request_t

 

typedef struct xcb_image_text_8_request_t xcb_image_text_8_request_t

 xcb_image_text_8_request_t

 

typedef struct xcb_image_text_16_request_t xcb_image_text_16_request_t

 xcb_image_text_16_request_t

 

typedef enum xcb_colormap_alloc_t xcb_colormap_alloc_t

 

typedef struct xcb_create_colormap_request_t xcb_create_colormap_request_t

 xcb_create_colormap_request_t

 

typedef struct xcb_free_colormap_request_t xcb_free_colormap_request_t

 xcb_free_colormap_request_t

 

typedef struct xcb_copy_colormap_and_free_request_t xcb_copy_colormap_and_free_request_t

 xcb_copy_colormap_and_free_request_t

 

typedef struct xcb_install_colormap_request_t xcb_install_colormap_request_t

 xcb_install_colormap_request_t

 

typedef struct xcb_uninstall_colormap_request_t xcb_uninstall_colormap_request_t

 xcb_uninstall_colormap_request_t

 

typedef struct xcb_list_installed_colormaps_cookie_t xcb_list_installed_colormaps_cookie_t

 xcb_list_installed_colormaps_cookie_t

 

typedef struct xcb_list_installed_colormaps_request_t xcb_list_installed_colormaps_request_t

 xcb_list_installed_colormaps_request_t

 

typedef struct xcb_list_installed_colormaps_reply_t xcb_list_installed_colormaps_reply_t

 xcb_list_installed_colormaps_reply_t

 

typedef struct xcb_alloc_color_cookie_t xcb_alloc_color_cookie_t

 xcb_alloc_color_cookie_t

 

typedef struct xcb_alloc_color_request_t xcb_alloc_color_request_t

 xcb_alloc_color_request_t

 

typedef struct xcb_alloc_color_reply_t xcb_alloc_color_reply_t

 xcb_alloc_color_reply_t

 

typedef struct xcb_alloc_named_color_cookie_t xcb_alloc_named_color_cookie_t

 xcb_alloc_named_color_cookie_t

 

typedef struct xcb_alloc_named_color_request_t xcb_alloc_named_color_request_t

 xcb_alloc_named_color_request_t

 

typedef struct xcb_alloc_named_color_reply_t xcb_alloc_named_color_reply_t

 xcb_alloc_named_color_reply_t

 

typedef struct xcb_alloc_color_cells_cookie_t xcb_alloc_color_cells_cookie_t

 xcb_alloc_color_cells_cookie_t

 

typedef struct xcb_alloc_color_cells_request_t xcb_alloc_color_cells_request_t

 xcb_alloc_color_cells_request_t

 

typedef struct xcb_alloc_color_cells_reply_t xcb_alloc_color_cells_reply_t

 xcb_alloc_color_cells_reply_t

 

typedef struct xcb_alloc_color_planes_cookie_t xcb_alloc_color_planes_cookie_t

 xcb_alloc_color_planes_cookie_t

 

typedef struct xcb_alloc_color_planes_request_t xcb_alloc_color_planes_request_t

 xcb_alloc_color_planes_request_t

 

typedef struct xcb_alloc_color_planes_reply_t xcb_alloc_color_planes_reply_t

 xcb_alloc_color_planes_reply_t

 

typedef struct xcb_free_colors_request_t xcb_free_colors_request_t

 xcb_free_colors_request_t

 

typedef enum xcb_color_flag_t xcb_color_flag_t

 

typedef struct xcb_coloritem_t xcb_coloritem_t

 xcb_coloritem_t

 

typedef struct xcb_coloritem_iterator_t xcb_coloritem_iterator_t

 xcb_coloritem_iterator_t

 

typedef struct xcb_store_colors_request_t xcb_store_colors_request_t

 xcb_store_colors_request_t

 

typedef struct xcb_store_named_color_request_t xcb_store_named_color_request_t

 xcb_store_named_color_request_t

 

typedef struct xcb_rgb_t xcb_rgb_t

 xcb_rgb_t

 

typedef struct xcb_rgb_iterator_t xcb_rgb_iterator_t

 xcb_rgb_iterator_t

 

typedef struct xcb_query_colors_cookie_t xcb_query_colors_cookie_t

 xcb_query_colors_cookie_t

 

typedef struct xcb_query_colors_request_t xcb_query_colors_request_t

 xcb_query_colors_request_t

 

typedef struct xcb_query_colors_reply_t xcb_query_colors_reply_t

 xcb_query_colors_reply_t

 

typedef struct xcb_lookup_color_cookie_t xcb_lookup_color_cookie_t

 xcb_lookup_color_cookie_t

 

typedef struct xcb_lookup_color_request_t xcb_lookup_color_request_t

 xcb_lookup_color_request_t

 

typedef struct xcb_lookup_color_reply_t xcb_lookup_color_reply_t

 xcb_lookup_color_reply_t

 

typedef enum xcb_pixmap_enum_t xcb_pixmap_enum_t

 

typedef struct xcb_create_cursor_request_t xcb_create_cursor_request_t

 xcb_create_cursor_request_t

 

typedef enum xcb_font_enum_t xcb_font_enum_t

 

typedef struct xcb_create_glyph_cursor_request_t xcb_create_glyph_cursor_request_t

 xcb_create_glyph_cursor_request_t

 

typedef struct xcb_free_cursor_request_t xcb_free_cursor_request_t

 xcb_free_cursor_request_t

 

typedef struct xcb_recolor_cursor_request_t xcb_recolor_cursor_request_t

 xcb_recolor_cursor_request_t

 

typedef enum xcb_query_shape_of_t xcb_query_shape_of_t

 

typedef struct xcb_query_best_size_cookie_t xcb_query_best_size_cookie_t

 xcb_query_best_size_cookie_t

 

typedef struct xcb_query_best_size_request_t xcb_query_best_size_request_t

 xcb_query_best_size_request_t

 

typedef struct xcb_query_best_size_reply_t xcb_query_best_size_reply_t

 xcb_query_best_size_reply_t

 

typedef struct xcb_query_extension_cookie_t xcb_query_extension_cookie_t

 xcb_query_extension_cookie_t

 

typedef struct xcb_query_extension_request_t xcb_query_extension_request_t

 xcb_query_extension_request_t

 

typedef struct xcb_query_extension_reply_t xcb_query_extension_reply_t

 xcb_query_extension_reply_t

 

typedef struct xcb_list_extensions_cookie_t xcb_list_extensions_cookie_t

 xcb_list_extensions_cookie_t

 

typedef struct xcb_list_extensions_request_t xcb_list_extensions_request_t

 xcb_list_extensions_request_t

 

typedef struct xcb_list_extensions_reply_t xcb_list_extensions_reply_t

 xcb_list_extensions_reply_t

 

typedef struct xcb_change_keyboard_mapping_request_t xcb_change_keyboard_mapping_request_t

 xcb_change_keyboard_mapping_request_t

 

typedef struct xcb_get_keyboard_mapping_cookie_t xcb_get_keyboard_mapping_cookie_t

 xcb_get_keyboard_mapping_cookie_t

 

typedef struct xcb_get_keyboard_mapping_request_t xcb_get_keyboard_mapping_request_t

 xcb_get_keyboard_mapping_request_t

 

typedef struct xcb_get_keyboard_mapping_reply_t xcb_get_keyboard_mapping_reply_t

 xcb_get_keyboard_mapping_reply_t

 

typedef enum xcb_kb_t xcb_kb_t

 

typedef enum xcb_led_mode_t xcb_led_mode_t

 

typedef enum xcb_auto_repeat_mode_t xcb_auto_repeat_mode_t

 

typedef struct xcb_change_keyboard_control_value_list_t xcb_change_keyboard_control_value_list_t

 xcb_change_keyboard_control_value_list_t

 

typedef struct xcb_change_keyboard_control_request_t xcb_change_keyboard_control_request_t

 xcb_change_keyboard_control_request_t

 

typedef struct xcb_get_keyboard_control_cookie_t xcb_get_keyboard_control_cookie_t

 xcb_get_keyboard_control_cookie_t

 

typedef struct xcb_get_keyboard_control_request_t xcb_get_keyboard_control_request_t

 xcb_get_keyboard_control_request_t

 

typedef struct xcb_get_keyboard_control_reply_t xcb_get_keyboard_control_reply_t

 xcb_get_keyboard_control_reply_t

 

typedef struct xcb_bell_request_t xcb_bell_request_t

 xcb_bell_request_t

 

typedef struct xcb_change_pointer_control_request_t xcb_change_pointer_control_request_t

 xcb_change_pointer_control_request_t

 

typedef struct xcb_get_pointer_control_cookie_t xcb_get_pointer_control_cookie_t

 xcb_get_pointer_control_cookie_t

 

typedef struct xcb_get_pointer_control_request_t xcb_get_pointer_control_request_t

 xcb_get_pointer_control_request_t

 

typedef struct xcb_get_pointer_control_reply_t xcb_get_pointer_control_reply_t

 xcb_get_pointer_control_reply_t

 

typedef enum xcb_blanking_t xcb_blanking_t

 

typedef enum xcb_exposures_t xcb_exposures_t

 

typedef struct xcb_set_screen_saver_request_t xcb_set_screen_saver_request_t

 xcb_set_screen_saver_request_t

 

typedef struct xcb_get_screen_saver_cookie_t xcb_get_screen_saver_cookie_t

 xcb_get_screen_saver_cookie_t

 

typedef struct xcb_get_screen_saver_request_t xcb_get_screen_saver_request_t

 xcb_get_screen_saver_request_t

 

typedef struct xcb_get_screen_saver_reply_t xcb_get_screen_saver_reply_t

 xcb_get_screen_saver_reply_t

 

typedef enum xcb_host_mode_t xcb_host_mode_t

 

typedef enum xcb_family_t xcb_family_t

 

typedef struct xcb_change_hosts_request_t xcb_change_hosts_request_t

 xcb_change_hosts_request_t

 

typedef struct xcb_host_t xcb_host_t

 xcb_host_t

 

typedef struct xcb_host_iterator_t xcb_host_iterator_t

 xcb_host_iterator_t

 

typedef struct xcb_list_hosts_cookie_t xcb_list_hosts_cookie_t

 xcb_list_hosts_cookie_t

 

typedef struct xcb_list_hosts_request_t xcb_list_hosts_request_t

 xcb_list_hosts_request_t

 

typedef struct xcb_list_hosts_reply_t xcb_list_hosts_reply_t

 xcb_list_hosts_reply_t

 

typedef enum xcb_access_control_t xcb_access_control_t

 

typedef struct xcb_set_access_control_request_t xcb_set_access_control_request_t

 xcb_set_access_control_request_t

 

typedef enum xcb_close_down_t xcb_close_down_t

 

typedef struct xcb_set_close_down_mode_request_t xcb_set_close_down_mode_request_t

 xcb_set_close_down_mode_request_t

 

typedef enum xcb_kill_t xcb_kill_t

 

typedef struct xcb_kill_client_request_t xcb_kill_client_request_t

 xcb_kill_client_request_t

 

typedef struct xcb_rotate_properties_request_t xcb_rotate_properties_request_t

 xcb_rotate_properties_request_t

 

typedef enum xcb_screen_saver_t xcb_screen_saver_t

 

typedef struct xcb_force_screen_saver_request_t xcb_force_screen_saver_request_t

 xcb_force_screen_saver_request_t

 

typedef enum xcb_mapping_status_t xcb_mapping_status_t

 

typedef struct xcb_set_pointer_mapping_cookie_t xcb_set_pointer_mapping_cookie_t

 xcb_set_pointer_mapping_cookie_t

 

typedef struct xcb_set_pointer_mapping_request_t xcb_set_pointer_mapping_request_t

 xcb_set_pointer_mapping_request_t

 

typedef struct xcb_set_pointer_mapping_reply_t xcb_set_pointer_mapping_reply_t

 xcb_set_pointer_mapping_reply_t

 

typedef struct xcb_get_pointer_mapping_cookie_t xcb_get_pointer_mapping_cookie_t

 xcb_get_pointer_mapping_cookie_t

 

typedef struct xcb_get_pointer_mapping_request_t xcb_get_pointer_mapping_request_t

 xcb_get_pointer_mapping_request_t

 

typedef struct xcb_get_pointer_mapping_reply_t xcb_get_pointer_mapping_reply_t

 xcb_get_pointer_mapping_reply_t

 

typedef enum xcb_map_index_t xcb_map_index_t

 

typedef struct xcb_set_modifier_mapping_cookie_t xcb_set_modifier_mapping_cookie_t

 xcb_set_modifier_mapping_cookie_t

 

typedef struct xcb_set_modifier_mapping_request_t xcb_set_modifier_mapping_request_t

 xcb_set_modifier_mapping_request_t

 

typedef struct xcb_set_modifier_mapping_reply_t xcb_set_modifier_mapping_reply_t

 xcb_set_modifier_mapping_reply_t

 

typedef struct xcb_get_modifier_mapping_cookie_t xcb_get_modifier_mapping_cookie_t

 xcb_get_modifier_mapping_cookie_t

 

typedef struct xcb_get_modifier_mapping_request_t xcb_get_modifier_mapping_request_t

 xcb_get_modifier_mapping_request_t

 

typedef struct xcb_get_modifier_mapping_reply_t xcb_get_modifier_mapping_reply_t

 xcb_get_modifier_mapping_reply_t

 

typedef struct xcb_no_operation_request_t xcb_no_operation_request_t

 xcb_no_operation_request_t

 

Enumerations

enum  xcb_visual_class_t {

  XCB_VISUAL_CLASS_STATIC_GRAY = 0,

XCB_VISUAL_CLASS_GRAY_SCALE = 1,

XCB_VISUAL_CLASS_STATIC_COLOR = 2,

XCB_VISUAL_CLASS_PSEUDO_COLOR = 3,

  XCB_VISUAL_CLASS_TRUE_COLOR = 4,

XCB_VISUAL_CLASS_DIRECT_COLOR = 5

}

 

enum  xcb_event_mask_t {

  XCB_EVENT_MASK_NO_EVENT = 0,

XCB_EVENT_MASK_KEY_PRESS = 1,

XCB_EVENT_MASK_KEY_RELEASE = 2,

XCB_EVENT_MASK_BUTTON_PRESS = 4,

  XCB_EVENT_MASK_BUTTON_RELEASE = 8,

XCB_EVENT_MASK_ENTER_WINDOW = 16,

XCB_EVENT_MASK_LEAVE_WINDOW = 32,

XCB_EVENT_MASK_POINTER_MOTION = 64,

  XCB_EVENT_MASK_POINTER_MOTION_HINT = 128,

XCB_EVENT_MASK_BUTTON_1_MOTION = 256,

XCB_EVENT_MASK_BUTTON_2_MOTION = 512,

XCB_EVENT_MASK_BUTTON_3_MOTION = 1024,

  XCB_EVENT_MASK_BUTTON_4_MOTION = 2048,

XCB_EVENT_MASK_BUTTON_5_MOTION = 4096,

XCB_EVENT_MASK_BUTTON_MOTION = 8192,

XCB_EVENT_MASK_KEYMAP_STATE = 16384,

  XCB_EVENT_MASK_EXPOSURE = 32768,

XCB_EVENT_MASK_VISIBILITY_CHANGE = 65536,

XCB_EVENT_MASK_STRUCTURE_NOTIFY = 131072,

XCB_EVENT_MASK_RESIZE_REDIRECT = 262144,

  XCB_EVENT_MASK_SUBSTRUCTURE_NOTIFY = 524288,

XCB_EVENT_MASK_SUBSTRUCTURE_REDIRECT = 1048576,

XCB_EVENT_MASK_FOCUS_CHANGE = 2097152,

XCB_EVENT_MASK_PROPERTY_CHANGE = 4194304,

  XCB_EVENT_MASK_COLOR_MAP_CHANGE = 8388608,

XCB_EVENT_MASK_OWNER_GRAB_BUTTON = 16777216

}

 

enum  xcb_backing_store_t { XCB_BACKING_STORE_NOT_USEFUL = 0,

XCB_BACKING_STORE_WHEN_MAPPED = 1,

XCB_BACKING_STORE_ALWAYS = 2

}

 

enum  xcb_image_order_t { XCB_IMAGE_ORDER_LSB_FIRST = 0,

XCB_IMAGE_ORDER_MSB_FIRST = 1

}

 

enum  xcb_mod_mask_t {

  XCB_MOD_MASK_SHIFT = 1,

XCB_MOD_MASK_LOCK = 2,

XCB_MOD_MASK_CONTROL = 4,

XCB_MOD_MASK_1 = 8,

  XCB_MOD_MASK_2 = 16,

XCB_MOD_MASK_3 = 32,

XCB_MOD_MASK_4 = 64,

XCB_MOD_MASK_5 = 128,

  XCB_MOD_MASK_ANY = 32768

}

 

enum  xcb_key_but_mask_t {

  XCB_KEY_BUT_MASK_SHIFT = 1,

XCB_KEY_BUT_MASK_LOCK = 2,

XCB_KEY_BUT_MASK_CONTROL = 4,

XCB_KEY_BUT_MASK_MOD_1 = 8,

  XCB_KEY_BUT_MASK_MOD_2 = 16,

XCB_KEY_BUT_MASK_MOD_3 = 32,

XCB_KEY_BUT_MASK_MOD_4 = 64,

XCB_KEY_BUT_MASK_MOD_5 = 128,

  XCB_KEY_BUT_MASK_BUTTON_1 = 256,

XCB_KEY_BUT_MASK_BUTTON_2 = 512,

XCB_KEY_BUT_MASK_BUTTON_3 = 1024,

XCB_KEY_BUT_MASK_BUTTON_4 = 2048,

  XCB_KEY_BUT_MASK_BUTTON_5 = 4096

}

 

enum  xcb_window_enum_t { XCB_WINDOW_NONE = 0

}

 

enum  xcb_button_mask_t {

  XCB_BUTTON_MASK_1 = 256,

XCB_BUTTON_MASK_2 = 512,

XCB_BUTTON_MASK_3 = 1024,

XCB_BUTTON_MASK_4 = 2048,

  XCB_BUTTON_MASK_5 = 4096,

XCB_BUTTON_MASK_ANY = 32768

}

 

enum  xcb_motion_t { XCB_MOTION_NORMAL = 0,

XCB_MOTION_HINT = 1

}

 

enum  xcb_notify_detail_t {

  XCB_NOTIFY_DETAIL_ANCESTOR = 0,

XCB_NOTIFY_DETAIL_VIRTUAL = 1,

XCB_NOTIFY_DETAIL_INFERIOR = 2,

XCB_NOTIFY_DETAIL_NONLINEAR = 3,

  XCB_NOTIFY_DETAIL_NONLINEAR_VIRTUAL = 4,

XCB_NOTIFY_DETAIL_POINTER = 5,

XCB_NOTIFY_DETAIL_POINTER_ROOT = 6,

XCB_NOTIFY_DETAIL_NONE = 7

}

 

enum  xcb_notify_mode_t { XCB_NOTIFY_MODE_NORMAL = 0,

XCB_NOTIFY_MODE_GRAB = 1,

XCB_NOTIFY_MODE_UNGRAB = 2,

XCB_NOTIFY_MODE_WHILE_GRABBED = 3

}

 

enum  xcb_visibility_t { XCB_VISIBILITY_UNOBSCURED = 0,

XCB_VISIBILITY_PARTIALLY_OBSCURED = 1,

XCB_VISIBILITY_FULLY_OBSCURED = 2

}

 

enum  xcb_place_t { XCB_PLACE_ON_TOP = 0,

XCB_PLACE_ON_BOTTOM = 1

}

 

enum  xcb_property_t { XCB_PROPERTY_NEW_VALUE = 0,

XCB_PROPERTY_DELETE = 1

}

 

enum  xcb_time_t { XCB_TIME_CURRENT_TIME = 0

}

 

enum  xcb_atom_enum_t {

  XCB_ATOM_NONE = 0,

XCB_ATOM_ANY = 0,

XCB_ATOM_PRIMARY = 1,

XCB_ATOM_SECONDARY = 2,

  XCB_ATOM_ARC = 3,

XCB_ATOM_ATOM = 4,

XCB_ATOM_BITMAP = 5,

XCB_ATOM_CARDINAL = 6,

  XCB_ATOM_COLORMAP = 7,

XCB_ATOM_CURSOR = 8,

XCB_ATOM_CUT_BUFFER0 = 9,

XCB_ATOM_CUT_BUFFER1 = 10,

  XCB_ATOM_CUT_BUFFER2 = 11,

XCB_ATOM_CUT_BUFFER3 = 12,

XCB_ATOM_CUT_BUFFER4 = 13,

XCB_ATOM_CUT_BUFFER5 = 14,

  XCB_ATOM_CUT_BUFFER6 = 15,

XCB_ATOM_CUT_BUFFER7 = 16,

XCB_ATOM_DRAWABLE = 17,

XCB_ATOM_FONT = 18,

  XCB_ATOM_INTEGER = 19,

XCB_ATOM_PIXMAP = 20,

XCB_ATOM_POINT = 21,

XCB_ATOM_RECTANGLE = 22,

  XCB_ATOM_RESOURCE_MANAGER = 23,

XCB_ATOM_RGB_COLOR_MAP = 24,

XCB_ATOM_RGB_BEST_MAP = 25,

XCB_ATOM_RGB_BLUE_MAP = 26,

  XCB_ATOM_RGB_DEFAULT_MAP = 27,

XCB_ATOM_RGB_GRAY_MAP = 28,

XCB_ATOM_RGB_GREEN_MAP = 29,

XCB_ATOM_RGB_RED_MAP = 30,

  XCB_ATOM_STRING = 31,

XCB_ATOM_VISUALID = 32,

XCB_ATOM_WINDOW = 33,

XCB_ATOM_WM_COMMAND = 34,

  XCB_ATOM_WM_HINTS = 35,

XCB_ATOM_WM_CLIENT_MACHINE = 36,

XCB_ATOM_WM_ICON_NAME = 37,

XCB_ATOM_WM_ICON_SIZE = 38,

  XCB_ATOM_WM_NAME = 39,

XCB_ATOM_WM_NORMAL_HINTS = 40,

XCB_ATOM_WM_SIZE_HINTS = 41,

XCB_ATOM_WM_ZOOM_HINTS = 42,

  XCB_ATOM_MIN_SPACE = 43,

XCB_ATOM_NORM_SPACE = 44,

XCB_ATOM_MAX_SPACE = 45,

XCB_ATOM_END_SPACE = 46,

  XCB_ATOM_SUPERSCRIPT_X = 47,

XCB_ATOM_SUPERSCRIPT_Y = 48,

XCB_ATOM_SUBSCRIPT_X = 49,

XCB_ATOM_SUBSCRIPT_Y = 50,

  XCB_ATOM_UNDERLINE_POSITION = 51,

XCB_ATOM_UNDERLINE_THICKNESS = 52,

XCB_ATOM_STRIKEOUT_ASCENT = 53,

XCB_ATOM_STRIKEOUT_DESCENT = 54,

  XCB_ATOM_ITALIC_ANGLE = 55,

XCB_ATOM_X_HEIGHT = 56,

XCB_ATOM_QUAD_WIDTH = 57,

XCB_ATOM_WEIGHT = 58,

  XCB_ATOM_POINT_SIZE = 59,

XCB_ATOM_RESOLUTION = 60,

XCB_ATOM_COPYRIGHT = 61,

XCB_ATOM_NOTICE = 62,

  XCB_ATOM_FONT_NAME = 63,

XCB_ATOM_FAMILY_NAME = 64,

XCB_ATOM_FULL_NAME = 65,

XCB_ATOM_CAP_HEIGHT = 66,

  XCB_ATOM_WM_CLASS = 67,

XCB_ATOM_WM_TRANSIENT_FOR = 68

}

 

enum  xcb_colormap_state_t { XCB_COLORMAP_STATE_UNINSTALLED = 0,

XCB_COLORMAP_STATE_INSTALLED = 1

}

 

enum  xcb_colormap_enum_t { XCB_COLORMAP_NONE = 0

}

 

enum  xcb_mapping_t { XCB_MAPPING_MODIFIER = 0,

XCB_MAPPING_KEYBOARD = 1,

XCB_MAPPING_POINTER = 2

}

 

enum  xcb_window_class_t { XCB_WINDOW_CLASS_COPY_FROM_PARENT = 0,

XCB_WINDOW_CLASS_INPUT_OUTPUT = 1,

XCB_WINDOW_CLASS_INPUT_ONLY = 2

}

 

enum  xcb_cw_t {

  XCB_CW_BACK_PIXMAP = 1,

XCB_CW_BACK_PIXEL = 2,

XCB_CW_BORDER_PIXMAP = 4,

XCB_CW_BORDER_PIXEL = 8,

  XCB_CW_BIT_GRAVITY = 16,

XCB_CW_WIN_GRAVITY = 32,

XCB_CW_BACKING_STORE = 64,

XCB_CW_BACKING_PLANES = 128,

  XCB_CW_BACKING_PIXEL = 256,

XCB_CW_OVERRIDE_REDIRECT = 512,

XCB_CW_SAVE_UNDER = 1024,

XCB_CW_EVENT_MASK = 2048,

  XCB_CW_DONT_PROPAGATE = 4096,

XCB_CW_COLORMAP = 8192,

XCB_CW_CURSOR = 16384

}

 

enum  xcb_back_pixmap_t { XCB_BACK_PIXMAP_NONE = 0,

XCB_BACK_PIXMAP_PARENT_RELATIVE = 1

}

 

enum  xcb_gravity_t {

  XCB_GRAVITY_BIT_FORGET = 0,

XCB_GRAVITY_WIN_UNMAP = 0,

XCB_GRAVITY_NORTH_WEST = 1,

XCB_GRAVITY_NORTH = 2,

  XCB_GRAVITY_NORTH_EAST = 3,

XCB_GRAVITY_WEST = 4,

XCB_GRAVITY_CENTER = 5,

XCB_GRAVITY_EAST = 6,

  XCB_GRAVITY_SOUTH_WEST = 7,

XCB_GRAVITY_SOUTH = 8,

XCB_GRAVITY_SOUTH_EAST = 9,

XCB_GRAVITY_STATIC = 10

}

 

enum  xcb_map_state_t { XCB_MAP_STATE_UNMAPPED = 0,

XCB_MAP_STATE_UNVIEWABLE = 1,

XCB_MAP_STATE_VIEWABLE = 2

}

 

enum  xcb_set_mode_t { XCB_SET_MODE_INSERT = 0,

XCB_SET_MODE_DELETE = 1

}

 

enum  xcb_config_window_t {

  XCB_CONFIG_WINDOW_X = 1,

XCB_CONFIG_WINDOW_Y = 2,

XCB_CONFIG_WINDOW_WIDTH = 4,

XCB_CONFIG_WINDOW_HEIGHT = 8,

  XCB_CONFIG_WINDOW_BORDER_WIDTH = 16,

XCB_CONFIG_WINDOW_SIBLING = 32,

XCB_CONFIG_WINDOW_STACK_MODE = 64

}

 

enum  xcb_stack_mode_t {

  XCB_STACK_MODE_ABOVE = 0,

XCB_STACK_MODE_BELOW = 1,

XCB_STACK_MODE_TOP_IF = 2,

XCB_STACK_MODE_BOTTOM_IF = 3,

  XCB_STACK_MODE_OPPOSITE = 4

}

 

enum  xcb_circulate_t { XCB_CIRCULATE_RAISE_LOWEST = 0,

XCB_CIRCULATE_LOWER_HIGHEST = 1

}

 

enum  xcb_prop_mode_t { XCB_PROP_MODE_REPLACE = 0,

XCB_PROP_MODE_PREPEND = 1,

XCB_PROP_MODE_APPEND = 2

}

 

enum  xcb_get_property_type_t { XCB_GET_PROPERTY_TYPE_ANY = 0

}

 

enum  xcb_send_event_dest_t { XCB_SEND_EVENT_DEST_POINTER_WINDOW = 0,

XCB_SEND_EVENT_DEST_ITEM_FOCUS = 1

}

 

enum  xcb_grab_mode_t { XCB_GRAB_MODE_SYNC = 0,

XCB_GRAB_MODE_ASYNC = 1

}

 

enum  xcb_grab_status_t {

  XCB_GRAB_STATUS_SUCCESS = 0,

XCB_GRAB_STATUS_ALREADY_GRABBED = 1,

XCB_GRAB_STATUS_INVALID_TIME = 2,

XCB_GRAB_STATUS_NOT_VIEWABLE = 3,

  XCB_GRAB_STATUS_FROZEN = 4

}

 

enum  xcb_cursor_enum_t { XCB_CURSOR_NONE = 0

}

 

enum  xcb_button_index_t {

  XCB_BUTTON_INDEX_ANY = 0,

XCB_BUTTON_INDEX_1 = 1,

XCB_BUTTON_INDEX_2 = 2,

XCB_BUTTON_INDEX_3 = 3,

  XCB_BUTTON_INDEX_4 = 4,

XCB_BUTTON_INDEX_5 = 5

}

 

enum  xcb_grab_t { XCB_GRAB_ANY = 0

}

 

enum  xcb_allow_t {

  XCB_ALLOW_ASYNC_POINTER = 0,

XCB_ALLOW_SYNC_POINTER = 1,

XCB_ALLOW_REPLAY_POINTER = 2,

XCB_ALLOW_ASYNC_KEYBOARD = 3,

  XCB_ALLOW_SYNC_KEYBOARD = 4,

XCB_ALLOW_REPLAY_KEYBOARD = 5,

XCB_ALLOW_ASYNC_BOTH = 6,

XCB_ALLOW_SYNC_BOTH = 7

}

 

enum  xcb_input_focus_t { XCB_INPUT_FOCUS_NONE = 0,

XCB_INPUT_FOCUS_POINTER_ROOT = 1,

XCB_INPUT_FOCUS_PARENT = 2,

XCB_INPUT_FOCUS_FOLLOW_KEYBOARD = 3

}

 

enum  xcb_font_draw_t { XCB_FONT_DRAW_LEFT_TO_RIGHT = 0,

XCB_FONT_DRAW_RIGHT_TO_LEFT = 1

}

 

enum  xcb_gc_t {

  XCB_GC_FUNCTION = 1,

XCB_GC_PLANE_MASK = 2,

XCB_GC_FOREGROUND = 4,

XCB_GC_BACKGROUND = 8,

  XCB_GC_LINE_WIDTH = 16,

XCB_GC_LINE_STYLE = 32,

XCB_GC_CAP_STYLE = 64,

XCB_GC_JOIN_STYLE = 128,

  XCB_GC_FILL_STYLE = 256,

XCB_GC_FILL_RULE = 512,

XCB_GC_TILE = 1024,

XCB_GC_STIPPLE = 2048,

  XCB_GC_TILE_STIPPLE_ORIGIN_X = 4096,

XCB_GC_TILE_STIPPLE_ORIGIN_Y = 8192,

XCB_GC_FONT = 16384,

XCB_GC_SUBWINDOW_MODE = 32768,

  XCB_GC_GRAPHICS_EXPOSURES = 65536,

XCB_GC_CLIP_ORIGIN_X = 131072,

XCB_GC_CLIP_ORIGIN_Y = 262144,

XCB_GC_CLIP_MASK = 524288,

  XCB_GC_DASH_OFFSET = 1048576,

XCB_GC_DASH_LIST = 2097152,

XCB_GC_ARC_MODE = 4194304

}

 

enum  xcb_gx_t {

  XCB_GX_CLEAR = 0,

XCB_GX_AND = 1,

XCB_GX_AND_REVERSE = 2,

XCB_GX_COPY = 3,

  XCB_GX_AND_INVERTED = 4,

XCB_GX_NOOP = 5,

XCB_GX_XOR = 6,

XCB_GX_OR = 7,

  XCB_GX_NOR = 8,

XCB_GX_EQUIV = 9,

XCB_GX_INVERT = 10,

XCB_GX_OR_REVERSE = 11,

  XCB_GX_COPY_INVERTED = 12,

XCB_GX_OR_INVERTED = 13,

XCB_GX_NAND = 14,

XCB_GX_SET = 15

}

 

enum  xcb_line_style_t { XCB_LINE_STYLE_SOLID = 0,

XCB_LINE_STYLE_ON_OFF_DASH = 1,

XCB_LINE_STYLE_DOUBLE_DASH = 2

}

 

enum  xcb_cap_style_t { XCB_CAP_STYLE_NOT_LAST = 0,

XCB_CAP_STYLE_BUTT = 1,

XCB_CAP_STYLE_ROUND = 2,

XCB_CAP_STYLE_PROJECTING = 3

}

 

enum  xcb_join_style_t { XCB_JOIN_STYLE_MITER = 0,

XCB_JOIN_STYLE_ROUND = 1,

XCB_JOIN_STYLE_BEVEL = 2

}

 

enum  xcb_fill_style_t { XCB_FILL_STYLE_SOLID = 0,

XCB_FILL_STYLE_TILED = 1,

XCB_FILL_STYLE_STIPPLED = 2,

XCB_FILL_STYLE_OPAQUE_STIPPLED = 3

}

 

enum  xcb_fill_rule_t { XCB_FILL_RULE_EVEN_ODD = 0,

XCB_FILL_RULE_WINDING = 1

}

 

enum  xcb_subwindow_mode_t { XCB_SUBWINDOW_MODE_CLIP_BY_CHILDREN = 0,

XCB_SUBWINDOW_MODE_INCLUDE_INFERIORS = 1

}

 

enum  xcb_arc_mode_t { XCB_ARC_MODE_CHORD = 0,

XCB_ARC_MODE_PIE_SLICE = 1

}

 

enum  xcb_clip_ordering_t { XCB_CLIP_ORDERING_UNSORTED = 0,

XCB_CLIP_ORDERING_Y_SORTED = 1,

XCB_CLIP_ORDERING_YX_SORTED = 2,

XCB_CLIP_ORDERING_YX_BANDED = 3

}

 

enum  xcb_coord_mode_t { XCB_COORD_MODE_ORIGIN = 0,

XCB_COORD_MODE_PREVIOUS = 1

}

 

enum  xcb_poly_shape_t { XCB_POLY_SHAPE_COMPLEX = 0,

XCB_POLY_SHAPE_NONCONVEX = 1,

XCB_POLY_SHAPE_CONVEX = 2

}

 

enum  xcb_image_format_t { XCB_IMAGE_FORMAT_XY_BITMAP = 0,

XCB_IMAGE_FORMAT_XY_PIXMAP = 1,

XCB_IMAGE_FORMAT_Z_PIXMAP = 2

}

 

enum  xcb_colormap_alloc_t { XCB_COLORMAP_ALLOC_NONE = 0,

XCB_COLORMAP_ALLOC_ALL = 1

}

 

enum  xcb_color_flag_t { XCB_COLOR_FLAG_RED = 1,

XCB_COLOR_FLAG_GREEN = 2,

XCB_COLOR_FLAG_BLUE = 4

}

 

enum  xcb_pixmap_enum_t { XCB_PIXMAP_NONE = 0

}

 

enum  xcb_font_enum_t { XCB_FONT_NONE = 0

}

 

enum  xcb_query_shape_of_t { XCB_QUERY_SHAPE_OF_LARGEST_CURSOR = 0,

XCB_QUERY_SHAPE_OF_FASTEST_TILE = 1,

XCB_QUERY_SHAPE_OF_FASTEST_STIPPLE = 2

}

 

enum  xcb_kb_t {

  XCB_KB_KEY_CLICK_PERCENT = 1,

XCB_KB_BELL_PERCENT = 2,

XCB_KB_BELL_PITCH = 4,

XCB_KB_BELL_DURATION = 8,

  XCB_KB_LED = 16,

XCB_KB_LED_MODE = 32,

XCB_KB_KEY = 64,

XCB_KB_AUTO_REPEAT_MODE = 128

}

 

enum  xcb_led_mode_t { XCB_LED_MODE_OFF = 0,

XCB_LED_MODE_ON = 1

}

 

enum  xcb_auto_repeat_mode_t { XCB_AUTO_REPEAT_MODE_OFF = 0,

XCB_AUTO_REPEAT_MODE_ON = 1,

XCB_AUTO_REPEAT_MODE_DEFAULT = 2

}

 

enum  xcb_blanking_t { XCB_BLANKING_NOT_PREFERRED = 0,

XCB_BLANKING_PREFERRED = 1,

XCB_BLANKING_DEFAULT = 2

}

 

enum  xcb_exposures_t { XCB_EXPOSURES_NOT_ALLOWED = 0,

XCB_EXPOSURES_ALLOWED = 1,

XCB_EXPOSURES_DEFAULT = 2

}

 

enum  xcb_host_mode_t { XCB_HOST_MODE_INSERT = 0,

XCB_HOST_MODE_DELETE = 1

}

 

enum  xcb_family_t {

  XCB_FAMILY_INTERNET = 0,

XCB_FAMILY_DECNET = 1,

XCB_FAMILY_CHAOS = 2,

XCB_FAMILY_SERVER_INTERPRETED = 5,

  XCB_FAMILY_INTERNET_6 = 6

}

 

enum  xcb_access_control_t { XCB_ACCESS_CONTROL_DISABLE = 0,

XCB_ACCESS_CONTROL_ENABLE = 1

}

 

enum  xcb_close_down_t { XCB_CLOSE_DOWN_DESTROY_ALL = 0,

XCB_CLOSE_DOWN_RETAIN_PERMANENT = 1,

XCB_CLOSE_DOWN_RETAIN_TEMPORARY = 2

}

 

enum  xcb_kill_t { XCB_KILL_ALL_TEMPORARY = 0

}

 

enum  xcb_screen_saver_t { XCB_SCREEN_SAVER_RESET = 0,

XCB_SCREEN_SAVER_ACTIVE = 1

}

 

enum  xcb_mapping_status_t { XCB_MAPPING_STATUS_SUCCESS = 0,

XCB_MAPPING_STATUS_BUSY = 1,

XCB_MAPPING_STATUS_FAILURE = 2

}

 

enum  xcb_map_index_t {

  XCB_MAP_INDEX_SHIFT = 0,

XCB_MAP_INDEX_LOCK = 1,

XCB_MAP_INDEX_CONTROL = 2,

XCB_MAP_INDEX_1 = 3,

  XCB_MAP_INDEX_2 = 4,

XCB_MAP_INDEX_3 = 5,

XCB_MAP_INDEX_4 = 6,

XCB_MAP_INDEX_5 = 7

}

 

Functions

void xcb_char2b_next (xcb_char2b_iterator_t *i)

 

xcb_generic_iterator_t xcb_char2b_end (xcb_char2b_iterator_t i)

 

void xcb_window_next (xcb_window_iterator_t *i)

 

xcb_generic_iterator_t xcb_window_end (xcb_window_iterator_t i)

 

void xcb_pixmap_next (xcb_pixmap_iterator_t *i)

 

xcb_generic_iterator_t xcb_pixmap_end (xcb_pixmap_iterator_t i)

 

void xcb_cursor_next (xcb_cursor_iterator_t *i)

 

xcb_generic_iterator_t xcb_cursor_end (xcb_cursor_iterator_t i)

 

void xcb_font_next (xcb_font_iterator_t *i)

 

xcb_generic_iterator_t xcb_font_end (xcb_font_iterator_t i)

 

void xcb_gcontext_next (xcb_gcontext_iterator_t *i)

 

xcb_generic_iterator_t xcb_gcontext_end (xcb_gcontext_iterator_t i)

 

void xcb_colormap_next (xcb_colormap_iterator_t *i)

 

xcb_generic_iterator_t xcb_colormap_end (xcb_colormap_iterator_t i)

 

void xcb_atom_next (xcb_atom_iterator_t *i)

 

xcb_generic_iterator_t xcb_atom_end (xcb_atom_iterator_t i)

 

void xcb_drawable_next (xcb_drawable_iterator_t *i)

 

xcb_generic_iterator_t xcb_drawable_end (xcb_drawable_iterator_t i)

 

void xcb_fontable_next (xcb_fontable_iterator_t *i)

 

xcb_generic_iterator_t xcb_fontable_end (xcb_fontable_iterator_t i)

 

void xcb_bool32_next (xcb_bool32_iterator_t *i)

 

xcb_generic_iterator_t xcb_bool32_end (xcb_bool32_iterator_t i)

 

void xcb_visualid_next (xcb_visualid_iterator_t *i)

 

xcb_generic_iterator_t xcb_visualid_end (xcb_visualid_iterator_t i)

 

void xcb_timestamp_next (xcb_timestamp_iterator_t *i)

 

xcb_generic_iterator_t xcb_timestamp_end (xcb_timestamp_iterator_t i)

 

void xcb_keysym_next (xcb_keysym_iterator_t *i)

 

xcb_generic_iterator_t xcb_keysym_end (xcb_keysym_iterator_t i)

 

void xcb_keycode_next (xcb_keycode_iterator_t *i)

 

xcb_generic_iterator_t xcb_keycode_end (xcb_keycode_iterator_t i)

 

void xcb_keycode32_next (xcb_keycode32_iterator_t *i)

 

xcb_generic_iterator_t xcb_keycode32_end (xcb_keycode32_iterator_t i)

 

void xcb_button_next (xcb_button_iterator_t *i)

 

xcb_generic_iterator_t xcb_button_end (xcb_button_iterator_t i)

 

void xcb_point_next (xcb_point_iterator_t *i)

 

xcb_generic_iterator_t xcb_point_end (xcb_point_iterator_t i)

 

void xcb_rectangle_next (xcb_rectangle_iterator_t *i)

 

xcb_generic_iterator_t xcb_rectangle_end (xcb_rectangle_iterator_t i)

 

void xcb_arc_next (xcb_arc_iterator_t *i)

 

xcb_generic_iterator_t xcb_arc_end (xcb_arc_iterator_t i)

 

void xcb_format_next (xcb_format_iterator_t *i)

 

xcb_generic_iterator_t xcb_format_end (xcb_format_iterator_t i)

 

void xcb_visualtype_next (xcb_visualtype_iterator_t *i)

 

xcb_generic_iterator_t xcb_visualtype_end (xcb_visualtype_iterator_t i)

 

int xcb_depth_sizeof (const void *_buffer)

 

xcb_visualtype_t * xcb_depth_visuals (const xcb_depth_t *R)

 

int xcb_depth_visuals_length (const xcb_depth_t *R)

 

xcb_visualtype_iterator_t xcb_depth_visuals_iterator (const xcb_depth_t *R)

 

void xcb_depth_next (xcb_depth_iterator_t *i)

 

xcb_generic_iterator_t xcb_depth_end (xcb_depth_iterator_t i)

 

int xcb_screen_sizeof (const void *_buffer)

 

int xcb_screen_allowed_depths_length (const xcb_screen_t *R)

 

xcb_depth_iterator_t xcb_screen_allowed_depths_iterator (const xcb_screen_t *R)

 

void xcb_screen_next (xcb_screen_iterator_t *i)

 

xcb_generic_iterator_t xcb_screen_end (xcb_screen_iterator_t i)

 

int xcb_setup_request_sizeof (const void *_buffer)

 

char * xcb_setup_request_authorization_protocol_name (const xcb_setup_request_t *R)

 

int xcb_setup_request_authorization_protocol_name_length (const xcb_setup_request_t *R)

 

xcb_generic_iterator_t xcb_setup_request_authorization_protocol_name_end (const xcb_setup_request_t *R)

 

char * xcb_setup_request_authorization_protocol_data (const xcb_setup_request_t *R)

 

int xcb_setup_request_authorization_protocol_data_length (const xcb_setup_request_t *R)

 

xcb_generic_iterator_t xcb_setup_request_authorization_protocol_data_end (const xcb_setup_request_t *R)

 

void xcb_setup_request_next (xcb_setup_request_iterator_t *i)

 

xcb_generic_iterator_t xcb_setup_request_end (xcb_setup_request_iterator_t i)

 

int xcb_setup_failed_sizeof (const void *_buffer)

 

char * xcb_setup_failed_reason (const xcb_setup_failed_t *R)

 

int xcb_setup_failed_reason_length (const xcb_setup_failed_t *R)

 

xcb_generic_iterator_t xcb_setup_failed_reason_end (const xcb_setup_failed_t *R)

 

void xcb_setup_failed_next (xcb_setup_failed_iterator_t *i)

 

xcb_generic_iterator_t xcb_setup_failed_end (xcb_setup_failed_iterator_t i)

 

int xcb_setup_authenticate_sizeof (const void *_buffer)

 

char * xcb_setup_authenticate_reason (const xcb_setup_authenticate_t *R)

 

int xcb_setup_authenticate_reason_length (const xcb_setup_authenticate_t *R)

 

xcb_generic_iterator_t xcb_setup_authenticate_reason_end (const xcb_setup_authenticate_t *R)

 

void xcb_setup_authenticate_next (xcb_setup_authenticate_iterator_t *i)

 

xcb_generic_iterator_t xcb_setup_authenticate_end (xcb_setup_authenticate_iterator_t i)

 

int xcb_setup_sizeof (const void *_buffer)

 

char * xcb_setup_vendor (const xcb_setup_t *R)

 

int xcb_setup_vendor_length (const xcb_setup_t *R)

 

xcb_generic_iterator_t xcb_setup_vendor_end (const xcb_setup_t *R)

 

xcb_format_t * xcb_setup_pixmap_formats (const xcb_setup_t *R)

 

int xcb_setup_pixmap_formats_length (const xcb_setup_t *R)

 

xcb_format_iterator_t xcb_setup_pixmap_formats_iterator (const xcb_setup_t *R)

 

int xcb_setup_roots_length (const xcb_setup_t *R)

 

xcb_screen_iterator_t xcb_setup_roots_iterator (const xcb_setup_t *R)

 

void xcb_setup_next (xcb_setup_iterator_t *i)

 

xcb_generic_iterator_t xcb_setup_end (xcb_setup_iterator_t i)

 

void xcb_client_message_data_next (xcb_client_message_data_iterator_t *i)

 

xcb_generic_iterator_t xcb_client_message_data_end (xcb_client_message_data_iterator_t i)

 

int xcb_create_window_value_list_serialize (void **_buffer, uint32_t value_mask, const xcb_create_window_value_list_t *_aux)

 

int xcb_create_window_value_list_unpack (const void *_buffer, uint32_t value_mask, xcb_create_window_value_list_t *_aux)

 

int xcb_create_window_value_list_sizeof (const void *_buffer, uint32_t value_mask)

 

int xcb_create_window_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_create_window_checked (xcb_connection_t *c, uint8_t depth, xcb_window_t wid, xcb_window_t parent, int16_t x, int16_t y, uint16_t width, uint16_t height, uint16_t border_width, uint16_t _class, xcb_visualid_t visual, uint32_t value_mask, const void *value_list)

 Creates a window. More...

 

xcb_void_cookie_t xcb_create_window (xcb_connection_t *c, uint8_t depth, xcb_window_t wid, xcb_window_t parent, int16_t x, int16_t y, uint16_t width, uint16_t height, uint16_t border_width, uint16_t _class, xcb_visualid_t visual, uint32_t value_mask, const void *value_list)

 Creates a window. More...

 

xcb_void_cookie_t xcb_create_window_aux_checked (xcb_connection_t *c, uint8_t depth, xcb_window_t wid, xcb_window_t parent, int16_t x, int16_t y, uint16_t width, uint16_t height, uint16_t border_width, uint16_t _class, xcb_visualid_t visual, uint32_t value_mask, const xcb_create_window_value_list_t *value_list)

 Creates a window. More...

 

xcb_void_cookie_t xcb_create_window_aux (xcb_connection_t *c, uint8_t depth, xcb_window_t wid, xcb_window_t parent, int16_t x, int16_t y, uint16_t width, uint16_t height, uint16_t border_width, uint16_t _class, xcb_visualid_t visual, uint32_t value_mask, const xcb_create_window_value_list_t *value_list)

 Creates a window. More...

 

void * xcb_create_window_value_list (const xcb_create_window_request_t *R)

 

int xcb_change_window_attributes_value_list_serialize (void **_buffer, uint32_t value_mask, const xcb_change_window_attributes_value_list_t *_aux)

 

int xcb_change_window_attributes_value_list_unpack (const void *_buffer, uint32_t value_mask, xcb_change_window_attributes_value_list_t *_aux)

 

int xcb_change_window_attributes_value_list_sizeof (const void *_buffer, uint32_t value_mask)

 

int xcb_change_window_attributes_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_change_window_attributes_checked (xcb_connection_t *c, xcb_window_t window, uint32_t value_mask, const void *value_list)

 change window attributes More...

 

xcb_void_cookie_t xcb_change_window_attributes (xcb_connection_t *c, xcb_window_t window, uint32_t value_mask, const void *value_list)

 change window attributes More...

 

xcb_void_cookie_t xcb_change_window_attributes_aux_checked (xcb_connection_t *c, xcb_window_t window, uint32_t value_mask, const xcb_change_window_attributes_value_list_t *value_list)

 change window attributes More...

 

xcb_void_cookie_t xcb_change_window_attributes_aux (xcb_connection_t *c, xcb_window_t window, uint32_t value_mask, const xcb_change_window_attributes_value_list_t *value_list)

 change window attributes More...

 

void * xcb_change_window_attributes_value_list (const xcb_change_window_attributes_request_t *R)

 

xcb_get_window_attributes_cookie_t xcb_get_window_attributes (xcb_connection_t *c, xcb_window_t window)

 Gets window attributes. More...

 

xcb_get_window_attributes_cookie_t xcb_get_window_attributes_unchecked (xcb_connection_t *c, xcb_window_t window)

 Gets window attributes. More...

 

xcb_get_window_attributes_reply_t * xcb_get_window_attributes_reply (xcb_connection_t *c, xcb_get_window_attributes_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_destroy_window_checked (xcb_connection_t *c, xcb_window_t window)

 Destroys a window. More...

 

xcb_void_cookie_t xcb_destroy_window (xcb_connection_t *c, xcb_window_t window)

 Destroys a window. More...

 

xcb_void_cookie_t xcb_destroy_subwindows_checked (xcb_connection_t *c, xcb_window_t window)

 

xcb_void_cookie_t xcb_destroy_subwindows (xcb_connection_t *c, xcb_window_t window)

 

xcb_void_cookie_t xcb_change_save_set_checked (xcb_connection_t *c, uint8_t mode, xcb_window_t window)

 Changes a client's save set. More...

 

xcb_void_cookie_t xcb_change_save_set (xcb_connection_t *c, uint8_t mode, xcb_window_t window)

 Changes a client's save set. More...

 

xcb_void_cookie_t xcb_reparent_window_checked (xcb_connection_t *c, xcb_window_t window, xcb_window_t parent, int16_t x, int16_t y)

 Reparents a window. More...

 

xcb_void_cookie_t xcb_reparent_window (xcb_connection_t *c, xcb_window_t window, xcb_window_t parent, int16_t x, int16_t y)

 Reparents a window. More...

 

xcb_void_cookie_t xcb_map_window_checked (xcb_connection_t *c, xcb_window_t window)

 Makes a window visible. More...

 

xcb_void_cookie_t xcb_map_window (xcb_connection_t *c, xcb_window_t window)

 Makes a window visible. More...

 

xcb_void_cookie_t xcb_map_subwindows_checked (xcb_connection_t *c, xcb_window_t window)

 

xcb_void_cookie_t xcb_map_subwindows (xcb_connection_t *c, xcb_window_t window)

 

xcb_void_cookie_t xcb_unmap_window_checked (xcb_connection_t *c, xcb_window_t window)

 Makes a window invisible. More...

 

xcb_void_cookie_t xcb_unmap_window (xcb_connection_t *c, xcb_window_t window)

 Makes a window invisible. More...

 

xcb_void_cookie_t xcb_unmap_subwindows_checked (xcb_connection_t *c, xcb_window_t window)

 

xcb_void_cookie_t xcb_unmap_subwindows (xcb_connection_t *c, xcb_window_t window)

 

int xcb_configure_window_value_list_serialize (void **_buffer, uint16_t value_mask, const xcb_configure_window_value_list_t *_aux)

 

int xcb_configure_window_value_list_unpack (const void *_buffer, uint16_t value_mask, xcb_configure_window_value_list_t *_aux)

 

int xcb_configure_window_value_list_sizeof (const void *_buffer, uint16_t value_mask)

 

int xcb_configure_window_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_configure_window_checked (xcb_connection_t *c, xcb_window_t window, uint16_t value_mask, const void *value_list)

 Configures window attributes. More...

 

xcb_void_cookie_t xcb_configure_window (xcb_connection_t *c, xcb_window_t window, uint16_t value_mask, const void *value_list)

 Configures window attributes. More...

 

xcb_void_cookie_t xcb_configure_window_aux_checked (xcb_connection_t *c, xcb_window_t window, uint16_t value_mask, const xcb_configure_window_value_list_t *value_list)

 Configures window attributes. More...

 

xcb_void_cookie_t xcb_configure_window_aux (xcb_connection_t *c, xcb_window_t window, uint16_t value_mask, const xcb_configure_window_value_list_t *value_list)

 Configures window attributes. More...

 

void * xcb_configure_window_value_list (const xcb_configure_window_request_t *R)

 

xcb_void_cookie_t xcb_circulate_window_checked (xcb_connection_t *c, uint8_t direction, xcb_window_t window)

 Change window stacking order. More...

 

xcb_void_cookie_t xcb_circulate_window (xcb_connection_t *c, uint8_t direction, xcb_window_t window)

 Change window stacking order. More...

 

xcb_get_geometry_cookie_t xcb_get_geometry (xcb_connection_t *c, xcb_drawable_t drawable)

 Get current window geometry. More...

 

xcb_get_geometry_cookie_t xcb_get_geometry_unchecked (xcb_connection_t *c, xcb_drawable_t drawable)

 Get current window geometry. More...

 

xcb_get_geometry_reply_t * xcb_get_geometry_reply (xcb_connection_t *c, xcb_get_geometry_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_query_tree_sizeof (const void *_buffer)

 

xcb_query_tree_cookie_t xcb_query_tree (xcb_connection_t *c, xcb_window_t window)

 query the window tree More...

 

xcb_query_tree_cookie_t xcb_query_tree_unchecked (xcb_connection_t *c, xcb_window_t window)

 query the window tree More...

 

xcb_window_t * xcb_query_tree_children (const xcb_query_tree_reply_t *R)

 

int xcb_query_tree_children_length (const xcb_query_tree_reply_t *R)

 

xcb_generic_iterator_t xcb_query_tree_children_end (const xcb_query_tree_reply_t *R)

 

xcb_query_tree_reply_t * xcb_query_tree_reply (xcb_connection_t *c, xcb_query_tree_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_intern_atom_sizeof (const void *_buffer)

 

xcb_intern_atom_cookie_t xcb_intern_atom (xcb_connection_t *c, uint8_t only_if_exists, uint16_t name_len, const char *name)

 Get atom identifier by name. More...

 

xcb_intern_atom_cookie_t xcb_intern_atom_unchecked (xcb_connection_t *c, uint8_t only_if_exists, uint16_t name_len, const char *name)

 Get atom identifier by name. More...

 

xcb_intern_atom_reply_t * xcb_intern_atom_reply (xcb_connection_t *c, xcb_intern_atom_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_get_atom_name_sizeof (const void *_buffer)

 

xcb_get_atom_name_cookie_t xcb_get_atom_name (xcb_connection_t *c, xcb_atom_t atom)

 

xcb_get_atom_name_cookie_t xcb_get_atom_name_unchecked (xcb_connection_t *c, xcb_atom_t atom)

 

char * xcb_get_atom_name_name (const xcb_get_atom_name_reply_t *R)

 

int xcb_get_atom_name_name_length (const xcb_get_atom_name_reply_t *R)

 

xcb_generic_iterator_t xcb_get_atom_name_name_end (const xcb_get_atom_name_reply_t *R)

 

xcb_get_atom_name_reply_t * xcb_get_atom_name_reply (xcb_connection_t *c, xcb_get_atom_name_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_change_property_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_change_property_checked (xcb_connection_t *c, uint8_t mode, xcb_window_t window, xcb_atom_t property, xcb_atom_t type, uint8_t format, uint32_t data_len, const void *data)

 Changes a window property. More...

 

xcb_void_cookie_t xcb_change_property (xcb_connection_t *c, uint8_t mode, xcb_window_t window, xcb_atom_t property, xcb_atom_t type, uint8_t format, uint32_t data_len, const void *data)

 Changes a window property. More...

 

void * xcb_change_property_data (const xcb_change_property_request_t *R)

 

int xcb_change_property_data_length (const xcb_change_property_request_t *R)

 

xcb_generic_iterator_t xcb_change_property_data_end (const xcb_change_property_request_t *R)

 

xcb_void_cookie_t xcb_delete_property_checked (xcb_connection_t *c, xcb_window_t window, xcb_atom_t property)

 

xcb_void_cookie_t xcb_delete_property (xcb_connection_t *c, xcb_window_t window, xcb_atom_t property)

 

int xcb_get_property_sizeof (const void *_buffer)

 

xcb_get_property_cookie_t xcb_get_property (xcb_connection_t *c, uint8_t _delete, xcb_window_t window, xcb_atom_t property, xcb_atom_t type, uint32_t long_offset, uint32_t long_length)

 Gets a window property. More...

 

xcb_get_property_cookie_t xcb_get_property_unchecked (xcb_connection_t *c, uint8_t _delete, xcb_window_t window, xcb_atom_t property, xcb_atom_t type, uint32_t long_offset, uint32_t long_length)

 Gets a window property. More...

 

void * xcb_get_property_value (const xcb_get_property_reply_t *R)

 

int xcb_get_property_value_length (const xcb_get_property_reply_t *R)

 

xcb_generic_iterator_t xcb_get_property_value_end (const xcb_get_property_reply_t *R)

 

xcb_get_property_reply_t * xcb_get_property_reply (xcb_connection_t *c, xcb_get_property_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_list_properties_sizeof (const void *_buffer)

 

xcb_list_properties_cookie_t xcb_list_properties (xcb_connection_t *c, xcb_window_t window)

 

xcb_list_properties_cookie_t xcb_list_properties_unchecked (xcb_connection_t *c, xcb_window_t window)

 

xcb_atom_t * xcb_list_properties_atoms (const xcb_list_properties_reply_t *R)

 

int xcb_list_properties_atoms_length (const xcb_list_properties_reply_t *R)

 

xcb_generic_iterator_t xcb_list_properties_atoms_end (const xcb_list_properties_reply_t *R)

 

xcb_list_properties_reply_t * xcb_list_properties_reply (xcb_connection_t *c, xcb_list_properties_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_set_selection_owner_checked (xcb_connection_t *c, xcb_window_t owner, xcb_atom_t selection, xcb_timestamp_t time)

 Sets the owner of a selection. More...

 

xcb_void_cookie_t xcb_set_selection_owner (xcb_connection_t *c, xcb_window_t owner, xcb_atom_t selection, xcb_timestamp_t time)

 Sets the owner of a selection. More...

 

xcb_get_selection_owner_cookie_t xcb_get_selection_owner (xcb_connection_t *c, xcb_atom_t selection)

 Gets the owner of a selection. More...

 

xcb_get_selection_owner_cookie_t xcb_get_selection_owner_unchecked (xcb_connection_t *c, xcb_atom_t selection)

 Gets the owner of a selection. More...

 

xcb_get_selection_owner_reply_t * xcb_get_selection_owner_reply (xcb_connection_t *c, xcb_get_selection_owner_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_convert_selection_checked (xcb_connection_t *c, xcb_window_t requestor, xcb_atom_t selection, xcb_atom_t target, xcb_atom_t property, xcb_timestamp_t time)

 

xcb_void_cookie_t xcb_convert_selection (xcb_connection_t *c, xcb_window_t requestor, xcb_atom_t selection, xcb_atom_t target, xcb_atom_t property, xcb_timestamp_t time)

 

xcb_void_cookie_t xcb_send_event_checked (xcb_connection_t *c, uint8_t propagate, xcb_window_t destination, uint32_t event_mask, const char *event)

 send an event More...

 

xcb_void_cookie_t xcb_send_event (xcb_connection_t *c, uint8_t propagate, xcb_window_t destination, uint32_t event_mask, const char *event)

 send an event More...

 

xcb_grab_pointer_cookie_t xcb_grab_pointer (xcb_connection_t *c, uint8_t owner_events, xcb_window_t grab_window, uint16_t event_mask, uint8_t pointer_mode, uint8_t keyboard_mode, xcb_window_t confine_to, xcb_cursor_t cursor, xcb_timestamp_t time)

 Grab the pointer. More...

 

xcb_grab_pointer_cookie_t xcb_grab_pointer_unchecked (xcb_connection_t *c, uint8_t owner_events, xcb_window_t grab_window, uint16_t event_mask, uint8_t pointer_mode, uint8_t keyboard_mode, xcb_window_t confine_to, xcb_cursor_t cursor, xcb_timestamp_t time)

 Grab the pointer. More...

 

xcb_grab_pointer_reply_t * xcb_grab_pointer_reply (xcb_connection_t *c, xcb_grab_pointer_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_ungrab_pointer_checked (xcb_connection_t *c, xcb_timestamp_t time)

 release the pointer More...

 

xcb_void_cookie_t xcb_ungrab_pointer (xcb_connection_t *c, xcb_timestamp_t time)

 release the pointer More...

 

xcb_void_cookie_t xcb_grab_button_checked (xcb_connection_t *c, uint8_t owner_events, xcb_window_t grab_window, uint16_t event_mask, uint8_t pointer_mode, uint8_t keyboard_mode, xcb_window_t confine_to, xcb_cursor_t cursor, uint8_t button, uint16_t modifiers)

 Grab pointer button(s) More...

 

xcb_void_cookie_t xcb_grab_button (xcb_connection_t *c, uint8_t owner_events, xcb_window_t grab_window, uint16_t event_mask, uint8_t pointer_mode, uint8_t keyboard_mode, xcb_window_t confine_to, xcb_cursor_t cursor, uint8_t button, uint16_t modifiers)

 Grab pointer button(s) More...

 

xcb_void_cookie_t xcb_ungrab_button_checked (xcb_connection_t *c, uint8_t button, xcb_window_t grab_window, uint16_t modifiers)

 

xcb_void_cookie_t xcb_ungrab_button (xcb_connection_t *c, uint8_t button, xcb_window_t grab_window, uint16_t modifiers)

 

xcb_void_cookie_t xcb_change_active_pointer_grab_checked (xcb_connection_t *c, xcb_cursor_t cursor, xcb_timestamp_t time, uint16_t event_mask)

 

xcb_void_cookie_t xcb_change_active_pointer_grab (xcb_connection_t *c, xcb_cursor_t cursor, xcb_timestamp_t time, uint16_t event_mask)

 

xcb_grab_keyboard_cookie_t xcb_grab_keyboard (xcb_connection_t *c, uint8_t owner_events, xcb_window_t grab_window, xcb_timestamp_t time, uint8_t pointer_mode, uint8_t keyboard_mode)

 Grab the keyboard. More...

 

xcb_grab_keyboard_cookie_t xcb_grab_keyboard_unchecked (xcb_connection_t *c, uint8_t owner_events, xcb_window_t grab_window, xcb_timestamp_t time, uint8_t pointer_mode, uint8_t keyboard_mode)

 Grab the keyboard. More...

 

xcb_grab_keyboard_reply_t * xcb_grab_keyboard_reply (xcb_connection_t *c, xcb_grab_keyboard_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_ungrab_keyboard_checked (xcb_connection_t *c, xcb_timestamp_t time)

 

xcb_void_cookie_t xcb_ungrab_keyboard (xcb_connection_t *c, xcb_timestamp_t time)

 

xcb_void_cookie_t xcb_grab_key_checked (xcb_connection_t *c, uint8_t owner_events, xcb_window_t grab_window, uint16_t modifiers, xcb_keycode_t key, uint8_t pointer_mode, uint8_t keyboard_mode)

 Grab keyboard key(s) More...

 

xcb_void_cookie_t xcb_grab_key (xcb_connection_t *c, uint8_t owner_events, xcb_window_t grab_window, uint16_t modifiers, xcb_keycode_t key, uint8_t pointer_mode, uint8_t keyboard_mode)

 Grab keyboard key(s) More...

 

xcb_void_cookie_t xcb_ungrab_key_checked (xcb_connection_t *c, xcb_keycode_t key, xcb_window_t grab_window, uint16_t modifiers)

 release a key combination More...

 

xcb_void_cookie_t xcb_ungrab_key (xcb_connection_t *c, xcb_keycode_t key, xcb_window_t grab_window, uint16_t modifiers)

 release a key combination More...

 

xcb_void_cookie_t xcb_allow_events_checked (xcb_connection_t *c, uint8_t mode, xcb_timestamp_t time)

 release queued events More...

 

xcb_void_cookie_t xcb_allow_events (xcb_connection_t *c, uint8_t mode, xcb_timestamp_t time)

 release queued events More...

 

xcb_void_cookie_t xcb_grab_server_checked (xcb_connection_t *c)

 

xcb_void_cookie_t xcb_grab_server (xcb_connection_t *c)

 

xcb_void_cookie_t xcb_ungrab_server_checked (xcb_connection_t *c)

 

xcb_void_cookie_t xcb_ungrab_server (xcb_connection_t *c)

 

xcb_query_pointer_cookie_t xcb_query_pointer (xcb_connection_t *c, xcb_window_t window)

 get pointer coordinates More...

 

xcb_query_pointer_cookie_t xcb_query_pointer_unchecked (xcb_connection_t *c, xcb_window_t window)

 get pointer coordinates More...

 

xcb_query_pointer_reply_t * xcb_query_pointer_reply (xcb_connection_t *c, xcb_query_pointer_cookie_t cookie, xcb_generic_error_t **e)

 

void xcb_timecoord_next (xcb_timecoord_iterator_t *i)

 

xcb_generic_iterator_t xcb_timecoord_end (xcb_timecoord_iterator_t i)

 

int xcb_get_motion_events_sizeof (const void *_buffer)

 

xcb_get_motion_events_cookie_t xcb_get_motion_events (xcb_connection_t *c, xcb_window_t window, xcb_timestamp_t start, xcb_timestamp_t stop)

 

xcb_get_motion_events_cookie_t xcb_get_motion_events_unchecked (xcb_connection_t *c, xcb_window_t window, xcb_timestamp_t start, xcb_timestamp_t stop)

 

xcb_timecoord_t * xcb_get_motion_events_events (const xcb_get_motion_events_reply_t *R)

 

int xcb_get_motion_events_events_length (const xcb_get_motion_events_reply_t *R)

 

xcb_timecoord_iterator_t xcb_get_motion_events_events_iterator (const xcb_get_motion_events_reply_t *R)

 

xcb_get_motion_events_reply_t * xcb_get_motion_events_reply (xcb_connection_t *c, xcb_get_motion_events_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_translate_coordinates_cookie_t xcb_translate_coordinates (xcb_connection_t *c, xcb_window_t src_window, xcb_window_t dst_window, int16_t src_x, int16_t src_y)

 

xcb_translate_coordinates_cookie_t xcb_translate_coordinates_unchecked (xcb_connection_t *c, xcb_window_t src_window, xcb_window_t dst_window, int16_t src_x, int16_t src_y)

 

xcb_translate_coordinates_reply_t * xcb_translate_coordinates_reply (xcb_connection_t *c, xcb_translate_coordinates_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_warp_pointer_checked (xcb_connection_t *c, xcb_window_t src_window, xcb_window_t dst_window, int16_t src_x, int16_t src_y, uint16_t src_width, uint16_t src_height, int16_t dst_x, int16_t dst_y)

 move mouse pointer More...

 

xcb_void_cookie_t xcb_warp_pointer (xcb_connection_t *c, xcb_window_t src_window, xcb_window_t dst_window, int16_t src_x, int16_t src_y, uint16_t src_width, uint16_t src_height, int16_t dst_x, int16_t dst_y)

 move mouse pointer More...

 

xcb_void_cookie_t xcb_set_input_focus_checked (xcb_connection_t *c, uint8_t revert_to, xcb_window_t focus, xcb_timestamp_t time)

 Sets input focus. More...

 

xcb_void_cookie_t xcb_set_input_focus (xcb_connection_t *c, uint8_t revert_to, xcb_window_t focus, xcb_timestamp_t time)

 Sets input focus. More...

 

xcb_get_input_focus_cookie_t xcb_get_input_focus (xcb_connection_t *c)

 

xcb_get_input_focus_cookie_t xcb_get_input_focus_unchecked (xcb_connection_t *c)

 

xcb_get_input_focus_reply_t * xcb_get_input_focus_reply (xcb_connection_t *c, xcb_get_input_focus_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_query_keymap_cookie_t xcb_query_keymap (xcb_connection_t *c)

 

xcb_query_keymap_cookie_t xcb_query_keymap_unchecked (xcb_connection_t *c)

 

xcb_query_keymap_reply_t * xcb_query_keymap_reply (xcb_connection_t *c, xcb_query_keymap_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_open_font_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_open_font_checked (xcb_connection_t *c, xcb_font_t fid, uint16_t name_len, const char *name)

 opens a font More...

 

xcb_void_cookie_t xcb_open_font (xcb_connection_t *c, xcb_font_t fid, uint16_t name_len, const char *name)

 opens a font More...

 

char * xcb_open_font_name (const xcb_open_font_request_t *R)

 

int xcb_open_font_name_length (const xcb_open_font_request_t *R)

 

xcb_generic_iterator_t xcb_open_font_name_end (const xcb_open_font_request_t *R)

 

xcb_void_cookie_t xcb_close_font_checked (xcb_connection_t *c, xcb_font_t font)

 

xcb_void_cookie_t xcb_close_font (xcb_connection_t *c, xcb_font_t font)

 

void xcb_fontprop_next (xcb_fontprop_iterator_t *i)

 

xcb_generic_iterator_t xcb_fontprop_end (xcb_fontprop_iterator_t i)

 

void xcb_charinfo_next (xcb_charinfo_iterator_t *i)

 

xcb_generic_iterator_t xcb_charinfo_end (xcb_charinfo_iterator_t i)

 

int xcb_query_font_sizeof (const void *_buffer)

 

xcb_query_font_cookie_t xcb_query_font (xcb_connection_t *c, xcb_fontable_t font)

 query font metrics More...

 

xcb_query_font_cookie_t xcb_query_font_unchecked (xcb_connection_t *c, xcb_fontable_t font)

 query font metrics More...

 

xcb_fontprop_t * xcb_query_font_properties (const xcb_query_font_reply_t *R)

 

int xcb_query_font_properties_length (const xcb_query_font_reply_t *R)

 

xcb_fontprop_iterator_t xcb_query_font_properties_iterator (const xcb_query_font_reply_t *R)

 

xcb_charinfo_t * xcb_query_font_char_infos (const xcb_query_font_reply_t *R)

 

int xcb_query_font_char_infos_length (const xcb_query_font_reply_t *R)

 

xcb_charinfo_iterator_t xcb_query_font_char_infos_iterator (const xcb_query_font_reply_t *R)

 

xcb_query_font_reply_t * xcb_query_font_reply (xcb_connection_t *c, xcb_query_font_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_query_text_extents_sizeof (const void *_buffer, uint32_t string_len)

 

xcb_query_text_extents_cookie_t xcb_query_text_extents (xcb_connection_t *c, xcb_fontable_t font, uint32_t string_len, const xcb_char2b_t *string)

 get text extents More...

 

xcb_query_text_extents_cookie_t xcb_query_text_extents_unchecked (xcb_connection_t *c, xcb_fontable_t font, uint32_t string_len, const xcb_char2b_t *string)

 get text extents More...

 

xcb_query_text_extents_reply_t * xcb_query_text_extents_reply (xcb_connection_t *c, xcb_query_text_extents_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_str_sizeof (const void *_buffer)

 

char * xcb_str_name (const xcb_str_t *R)

 

int xcb_str_name_length (const xcb_str_t *R)

 

xcb_generic_iterator_t xcb_str_name_end (const xcb_str_t *R)

 

void xcb_str_next (xcb_str_iterator_t *i)

 

xcb_generic_iterator_t xcb_str_end (xcb_str_iterator_t i)

 

int xcb_list_fonts_sizeof (const void *_buffer)

 

xcb_list_fonts_cookie_t xcb_list_fonts (xcb_connection_t *c, uint16_t max_names, uint16_t pattern_len, const char *pattern)

 get matching font names More...

 

xcb_list_fonts_cookie_t xcb_list_fonts_unchecked (xcb_connection_t *c, uint16_t max_names, uint16_t pattern_len, const char *pattern)

 get matching font names More...

 

int xcb_list_fonts_names_length (const xcb_list_fonts_reply_t *R)

 

xcb_str_iterator_t xcb_list_fonts_names_iterator (const xcb_list_fonts_reply_t *R)

 

xcb_list_fonts_reply_t * xcb_list_fonts_reply (xcb_connection_t *c, xcb_list_fonts_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_list_fonts_with_info_sizeof (const void *_buffer)

 

xcb_list_fonts_with_info_cookie_t xcb_list_fonts_with_info (xcb_connection_t *c, uint16_t max_names, uint16_t pattern_len, const char *pattern)

 get matching font names and information More...

 

xcb_list_fonts_with_info_cookie_t xcb_list_fonts_with_info_unchecked (xcb_connection_t *c, uint16_t max_names, uint16_t pattern_len, const char *pattern)

 get matching font names and information More...

 

xcb_fontprop_t * xcb_list_fonts_with_info_properties (const xcb_list_fonts_with_info_reply_t *R)

 

int xcb_list_fonts_with_info_properties_length (const xcb_list_fonts_with_info_reply_t *R)

 

xcb_fontprop_iterator_t xcb_list_fonts_with_info_properties_iterator (const xcb_list_fonts_with_info_reply_t *R)

 

char * xcb_list_fonts_with_info_name (const xcb_list_fonts_with_info_reply_t *R)

 

int xcb_list_fonts_with_info_name_length (const xcb_list_fonts_with_info_reply_t *R)

 

xcb_generic_iterator_t xcb_list_fonts_with_info_name_end (const xcb_list_fonts_with_info_reply_t *R)

 

xcb_list_fonts_with_info_reply_t * xcb_list_fonts_with_info_reply (xcb_connection_t *c, xcb_list_fonts_with_info_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_set_font_path_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_set_font_path_checked (xcb_connection_t *c, uint16_t font_qty, const xcb_str_t *font)

 

xcb_void_cookie_t xcb_set_font_path (xcb_connection_t *c, uint16_t font_qty, const xcb_str_t *font)

 

int xcb_set_font_path_font_length (const xcb_set_font_path_request_t *R)

 

xcb_str_iterator_t xcb_set_font_path_font_iterator (const xcb_set_font_path_request_t *R)

 

int xcb_get_font_path_sizeof (const void *_buffer)

 

xcb_get_font_path_cookie_t xcb_get_font_path (xcb_connection_t *c)

 

xcb_get_font_path_cookie_t xcb_get_font_path_unchecked (xcb_connection_t *c)

 

int xcb_get_font_path_path_length (const xcb_get_font_path_reply_t *R)

 

xcb_str_iterator_t xcb_get_font_path_path_iterator (const xcb_get_font_path_reply_t *R)

 

xcb_get_font_path_reply_t * xcb_get_font_path_reply (xcb_connection_t *c, xcb_get_font_path_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_create_pixmap_checked (xcb_connection_t *c, uint8_t depth, xcb_pixmap_t pid, xcb_drawable_t drawable, uint16_t width, uint16_t height)

 Creates a pixmap. More...

 

xcb_void_cookie_t xcb_create_pixmap (xcb_connection_t *c, uint8_t depth, xcb_pixmap_t pid, xcb_drawable_t drawable, uint16_t width, uint16_t height)

 Creates a pixmap. More...

 

xcb_void_cookie_t xcb_free_pixmap_checked (xcb_connection_t *c, xcb_pixmap_t pixmap)

 Destroys a pixmap. More...

 

xcb_void_cookie_t xcb_free_pixmap (xcb_connection_t *c, xcb_pixmap_t pixmap)

 Destroys a pixmap. More...

 

int xcb_create_gc_value_list_serialize (void **_buffer, uint32_t value_mask, const xcb_create_gc_value_list_t *_aux)

 

int xcb_create_gc_value_list_unpack (const void *_buffer, uint32_t value_mask, xcb_create_gc_value_list_t *_aux)

 

int xcb_create_gc_value_list_sizeof (const void *_buffer, uint32_t value_mask)

 

int xcb_create_gc_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_create_gc_checked (xcb_connection_t *c, xcb_gcontext_t cid, xcb_drawable_t drawable, uint32_t value_mask, const void *value_list)

 Creates a graphics context. More...

 

xcb_void_cookie_t xcb_create_gc (xcb_connection_t *c, xcb_gcontext_t cid, xcb_drawable_t drawable, uint32_t value_mask, const void *value_list)

 Creates a graphics context. More...

 

xcb_void_cookie_t xcb_create_gc_aux_checked (xcb_connection_t *c, xcb_gcontext_t cid, xcb_drawable_t drawable, uint32_t value_mask, const xcb_create_gc_value_list_t *value_list)

 Creates a graphics context. More...

 

xcb_void_cookie_t xcb_create_gc_aux (xcb_connection_t *c, xcb_gcontext_t cid, xcb_drawable_t drawable, uint32_t value_mask, const xcb_create_gc_value_list_t *value_list)

 Creates a graphics context. More...

 

void * xcb_create_gc_value_list (const xcb_create_gc_request_t *R)

 

int xcb_change_gc_value_list_serialize (void **_buffer, uint32_t value_mask, const xcb_change_gc_value_list_t *_aux)

 

int xcb_change_gc_value_list_unpack (const void *_buffer, uint32_t value_mask, xcb_change_gc_value_list_t *_aux)

 

int xcb_change_gc_value_list_sizeof (const void *_buffer, uint32_t value_mask)

 

int xcb_change_gc_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_change_gc_checked (xcb_connection_t *c, xcb_gcontext_t gc, uint32_t value_mask, const void *value_list)

 change graphics context components More...

 

xcb_void_cookie_t xcb_change_gc (xcb_connection_t *c, xcb_gcontext_t gc, uint32_t value_mask, const void *value_list)

 change graphics context components More...

 

xcb_void_cookie_t xcb_change_gc_aux_checked (xcb_connection_t *c, xcb_gcontext_t gc, uint32_t value_mask, const xcb_change_gc_value_list_t *value_list)

 change graphics context components More...

 

xcb_void_cookie_t xcb_change_gc_aux (xcb_connection_t *c, xcb_gcontext_t gc, uint32_t value_mask, const xcb_change_gc_value_list_t *value_list)

 change graphics context components More...

 

void * xcb_change_gc_value_list (const xcb_change_gc_request_t *R)

 

xcb_void_cookie_t xcb_copy_gc_checked (xcb_connection_t *c, xcb_gcontext_t src_gc, xcb_gcontext_t dst_gc, uint32_t value_mask)

 

xcb_void_cookie_t xcb_copy_gc (xcb_connection_t *c, xcb_gcontext_t src_gc, xcb_gcontext_t dst_gc, uint32_t value_mask)

 

int xcb_set_dashes_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_set_dashes_checked (xcb_connection_t *c, xcb_gcontext_t gc, uint16_t dash_offset, uint16_t dashes_len, const uint8_t *dashes)

 

xcb_void_cookie_t xcb_set_dashes (xcb_connection_t *c, xcb_gcontext_t gc, uint16_t dash_offset, uint16_t dashes_len, const uint8_t *dashes)

 

uint8_t * xcb_set_dashes_dashes (const xcb_set_dashes_request_t *R)

 

int xcb_set_dashes_dashes_length (const xcb_set_dashes_request_t *R)

 

xcb_generic_iterator_t xcb_set_dashes_dashes_end (const xcb_set_dashes_request_t *R)

 

int xcb_set_clip_rectangles_sizeof (const void *_buffer, uint32_t rectangles_len)

 

xcb_void_cookie_t xcb_set_clip_rectangles_checked (xcb_connection_t *c, uint8_t ordering, xcb_gcontext_t gc, int16_t clip_x_origin, int16_t clip_y_origin, uint32_t rectangles_len, const xcb_rectangle_t *rectangles)

 

xcb_void_cookie_t xcb_set_clip_rectangles (xcb_connection_t *c, uint8_t ordering, xcb_gcontext_t gc, int16_t clip_x_origin, int16_t clip_y_origin, uint32_t rectangles_len, const xcb_rectangle_t *rectangles)

 

xcb_rectangle_t * xcb_set_clip_rectangles_rectangles (const xcb_set_clip_rectangles_request_t *R)

 

int xcb_set_clip_rectangles_rectangles_length (const xcb_set_clip_rectangles_request_t *R)

 

xcb_rectangle_iterator_t xcb_set_clip_rectangles_rectangles_iterator (const xcb_set_clip_rectangles_request_t *R)

 

xcb_void_cookie_t xcb_free_gc_checked (xcb_connection_t *c, xcb_gcontext_t gc)

 Destroys a graphics context. More...

 

xcb_void_cookie_t xcb_free_gc (xcb_connection_t *c, xcb_gcontext_t gc)

 Destroys a graphics context. More...

 

xcb_void_cookie_t xcb_clear_area_checked (xcb_connection_t *c, uint8_t exposures, xcb_window_t window, int16_t x, int16_t y, uint16_t width, uint16_t height)

 

xcb_void_cookie_t xcb_clear_area (xcb_connection_t *c, uint8_t exposures, xcb_window_t window, int16_t x, int16_t y, uint16_t width, uint16_t height)

 

xcb_void_cookie_t xcb_copy_area_checked (xcb_connection_t *c, xcb_drawable_t src_drawable, xcb_drawable_t dst_drawable, xcb_gcontext_t gc, int16_t src_x, int16_t src_y, int16_t dst_x, int16_t dst_y, uint16_t width, uint16_t height)

 copy areas More...

 

xcb_void_cookie_t xcb_copy_area (xcb_connection_t *c, xcb_drawable_t src_drawable, xcb_drawable_t dst_drawable, xcb_gcontext_t gc, int16_t src_x, int16_t src_y, int16_t dst_x, int16_t dst_y, uint16_t width, uint16_t height)

 copy areas More...

 

xcb_void_cookie_t xcb_copy_plane_checked (xcb_connection_t *c, xcb_drawable_t src_drawable, xcb_drawable_t dst_drawable, xcb_gcontext_t gc, int16_t src_x, int16_t src_y, int16_t dst_x, int16_t dst_y, uint16_t width, uint16_t height, uint32_t bit_plane)

 

xcb_void_cookie_t xcb_copy_plane (xcb_connection_t *c, xcb_drawable_t src_drawable, xcb_drawable_t dst_drawable, xcb_gcontext_t gc, int16_t src_x, int16_t src_y, int16_t dst_x, int16_t dst_y, uint16_t width, uint16_t height, uint32_t bit_plane)

 

int xcb_poly_point_sizeof (const void *_buffer, uint32_t points_len)

 

xcb_void_cookie_t xcb_poly_point_checked (xcb_connection_t *c, uint8_t coordinate_mode, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t points_len, const xcb_point_t *points)

 

xcb_void_cookie_t xcb_poly_point (xcb_connection_t *c, uint8_t coordinate_mode, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t points_len, const xcb_point_t *points)

 

xcb_point_t * xcb_poly_point_points (const xcb_poly_point_request_t *R)

 

int xcb_poly_point_points_length (const xcb_poly_point_request_t *R)

 

xcb_point_iterator_t xcb_poly_point_points_iterator (const xcb_poly_point_request_t *R)

 

int xcb_poly_line_sizeof (const void *_buffer, uint32_t points_len)

 

xcb_void_cookie_t xcb_poly_line_checked (xcb_connection_t *c, uint8_t coordinate_mode, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t points_len, const xcb_point_t *points)

 draw lines More...

 

xcb_void_cookie_t xcb_poly_line (xcb_connection_t *c, uint8_t coordinate_mode, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t points_len, const xcb_point_t *points)

 draw lines More...

 

xcb_point_t * xcb_poly_line_points (const xcb_poly_line_request_t *R)

 

int xcb_poly_line_points_length (const xcb_poly_line_request_t *R)

 

xcb_point_iterator_t xcb_poly_line_points_iterator (const xcb_poly_line_request_t *R)

 

void xcb_segment_next (xcb_segment_iterator_t *i)

 

xcb_generic_iterator_t xcb_segment_end (xcb_segment_iterator_t i)

 

int xcb_poly_segment_sizeof (const void *_buffer, uint32_t segments_len)

 

xcb_void_cookie_t xcb_poly_segment_checked (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t segments_len, const xcb_segment_t *segments)

 draw lines More...

 

xcb_void_cookie_t xcb_poly_segment (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t segments_len, const xcb_segment_t *segments)

 draw lines More...

 

xcb_segment_t * xcb_poly_segment_segments (const xcb_poly_segment_request_t *R)

 

int xcb_poly_segment_segments_length (const xcb_poly_segment_request_t *R)

 

xcb_segment_iterator_t xcb_poly_segment_segments_iterator (const xcb_poly_segment_request_t *R)

 

int xcb_poly_rectangle_sizeof (const void *_buffer, uint32_t rectangles_len)

 

xcb_void_cookie_t xcb_poly_rectangle_checked (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t rectangles_len, const xcb_rectangle_t *rectangles)

 

xcb_void_cookie_t xcb_poly_rectangle (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t rectangles_len, const xcb_rectangle_t *rectangles)

 

xcb_rectangle_t * xcb_poly_rectangle_rectangles (const xcb_poly_rectangle_request_t *R)

 

int xcb_poly_rectangle_rectangles_length (const xcb_poly_rectangle_request_t *R)

 

xcb_rectangle_iterator_t xcb_poly_rectangle_rectangles_iterator (const xcb_poly_rectangle_request_t *R)

 

int xcb_poly_arc_sizeof (const void *_buffer, uint32_t arcs_len)

 

xcb_void_cookie_t xcb_poly_arc_checked (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t arcs_len, const xcb_arc_t *arcs)

 

xcb_void_cookie_t xcb_poly_arc (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t arcs_len, const xcb_arc_t *arcs)

 

xcb_arc_t * xcb_poly_arc_arcs (const xcb_poly_arc_request_t *R)

 

int xcb_poly_arc_arcs_length (const xcb_poly_arc_request_t *R)

 

xcb_arc_iterator_t xcb_poly_arc_arcs_iterator (const xcb_poly_arc_request_t *R)

 

int xcb_fill_poly_sizeof (const void *_buffer, uint32_t points_len)

 

xcb_void_cookie_t xcb_fill_poly_checked (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint8_t shape, uint8_t coordinate_mode, uint32_t points_len, const xcb_point_t *points)

 

xcb_void_cookie_t xcb_fill_poly (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint8_t shape, uint8_t coordinate_mode, uint32_t points_len, const xcb_point_t *points)

 

xcb_point_t * xcb_fill_poly_points (const xcb_fill_poly_request_t *R)

 

int xcb_fill_poly_points_length (const xcb_fill_poly_request_t *R)

 

xcb_point_iterator_t xcb_fill_poly_points_iterator (const xcb_fill_poly_request_t *R)

 

int xcb_poly_fill_rectangle_sizeof (const void *_buffer, uint32_t rectangles_len)

 

xcb_void_cookie_t xcb_poly_fill_rectangle_checked (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t rectangles_len, const xcb_rectangle_t *rectangles)

 Fills rectangles. More...

 

xcb_void_cookie_t xcb_poly_fill_rectangle (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t rectangles_len, const xcb_rectangle_t *rectangles)

 Fills rectangles. More...

 

xcb_rectangle_t * xcb_poly_fill_rectangle_rectangles (const xcb_poly_fill_rectangle_request_t *R)

 

int xcb_poly_fill_rectangle_rectangles_length (const xcb_poly_fill_rectangle_request_t *R)

 

xcb_rectangle_iterator_t xcb_poly_fill_rectangle_rectangles_iterator (const xcb_poly_fill_rectangle_request_t *R)

 

int xcb_poly_fill_arc_sizeof (const void *_buffer, uint32_t arcs_len)

 

xcb_void_cookie_t xcb_poly_fill_arc_checked (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t arcs_len, const xcb_arc_t *arcs)

 

xcb_void_cookie_t xcb_poly_fill_arc (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, uint32_t arcs_len, const xcb_arc_t *arcs)

 

xcb_arc_t * xcb_poly_fill_arc_arcs (const xcb_poly_fill_arc_request_t *R)

 

int xcb_poly_fill_arc_arcs_length (const xcb_poly_fill_arc_request_t *R)

 

xcb_arc_iterator_t xcb_poly_fill_arc_arcs_iterator (const xcb_poly_fill_arc_request_t *R)

 

int xcb_put_image_sizeof (const void *_buffer, uint32_t data_len)

 

xcb_void_cookie_t xcb_put_image_checked (xcb_connection_t *c, uint8_t format, xcb_drawable_t drawable, xcb_gcontext_t gc, uint16_t width, uint16_t height, int16_t dst_x, int16_t dst_y, uint8_t left_pad, uint8_t depth, uint32_t data_len, const uint8_t *data)

 

xcb_void_cookie_t xcb_put_image (xcb_connection_t *c, uint8_t format, xcb_drawable_t drawable, xcb_gcontext_t gc, uint16_t width, uint16_t height, int16_t dst_x, int16_t dst_y, uint8_t left_pad, uint8_t depth, uint32_t data_len, const uint8_t *data)

 

uint8_t * xcb_put_image_data (const xcb_put_image_request_t *R)

 

int xcb_put_image_data_length (const xcb_put_image_request_t *R)

 

xcb_generic_iterator_t xcb_put_image_data_end (const xcb_put_image_request_t *R)

 

int xcb_get_image_sizeof (const void *_buffer)

 

xcb_get_image_cookie_t xcb_get_image (xcb_connection_t *c, uint8_t format, xcb_drawable_t drawable, int16_t x, int16_t y, uint16_t width, uint16_t height, uint32_t plane_mask)

 

xcb_get_image_cookie_t xcb_get_image_unchecked (xcb_connection_t *c, uint8_t format, xcb_drawable_t drawable, int16_t x, int16_t y, uint16_t width, uint16_t height, uint32_t plane_mask)

 

uint8_t * xcb_get_image_data (const xcb_get_image_reply_t *R)

 

int xcb_get_image_data_length (const xcb_get_image_reply_t *R)

 

xcb_generic_iterator_t xcb_get_image_data_end (const xcb_get_image_reply_t *R)

 

xcb_get_image_reply_t * xcb_get_image_reply (xcb_connection_t *c, xcb_get_image_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_poly_text_8_sizeof (const void *_buffer, uint32_t items_len)

 

xcb_void_cookie_t xcb_poly_text_8_checked (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, int16_t x, int16_t y, uint32_t items_len, const uint8_t *items)

 

xcb_void_cookie_t xcb_poly_text_8 (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, int16_t x, int16_t y, uint32_t items_len, const uint8_t *items)

 

uint8_t * xcb_poly_text_8_items (const xcb_poly_text_8_request_t *R)

 

int xcb_poly_text_8_items_length (const xcb_poly_text_8_request_t *R)

 

xcb_generic_iterator_t xcb_poly_text_8_items_end (const xcb_poly_text_8_request_t *R)

 

int xcb_poly_text_16_sizeof (const void *_buffer, uint32_t items_len)

 

xcb_void_cookie_t xcb_poly_text_16_checked (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, int16_t x, int16_t y, uint32_t items_len, const uint8_t *items)

 

xcb_void_cookie_t xcb_poly_text_16 (xcb_connection_t *c, xcb_drawable_t drawable, xcb_gcontext_t gc, int16_t x, int16_t y, uint32_t items_len, const uint8_t *items)

 

uint8_t * xcb_poly_text_16_items (const xcb_poly_text_16_request_t *R)

 

int xcb_poly_text_16_items_length (const xcb_poly_text_16_request_t *R)

 

xcb_generic_iterator_t xcb_poly_text_16_items_end (const xcb_poly_text_16_request_t *R)

 

int xcb_image_text_8_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_image_text_8_checked (xcb_connection_t *c, uint8_t string_len, xcb_drawable_t drawable, xcb_gcontext_t gc, int16_t x, int16_t y, const char *string)

 Draws text. More...

 

xcb_void_cookie_t xcb_image_text_8 (xcb_connection_t *c, uint8_t string_len, xcb_drawable_t drawable, xcb_gcontext_t gc, int16_t x, int16_t y, const char *string)

 Draws text. More...

 

char * xcb_image_text_8_string (const xcb_image_text_8_request_t *R)

 

int xcb_image_text_8_string_length (const xcb_image_text_8_request_t *R)

 

xcb_generic_iterator_t xcb_image_text_8_string_end (const xcb_image_text_8_request_t *R)

 

int xcb_image_text_16_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_image_text_16_checked (xcb_connection_t *c, uint8_t string_len, xcb_drawable_t drawable, xcb_gcontext_t gc, int16_t x, int16_t y, const xcb_char2b_t *string)

 Draws text. More...

 

xcb_void_cookie_t xcb_image_text_16 (xcb_connection_t *c, uint8_t string_len, xcb_drawable_t drawable, xcb_gcontext_t gc, int16_t x, int16_t y, const xcb_char2b_t *string)

 Draws text. More...

 

xcb_char2b_t * xcb_image_text_16_string (const xcb_image_text_16_request_t *R)

 

int xcb_image_text_16_string_length (const xcb_image_text_16_request_t *R)

 

xcb_char2b_iterator_t xcb_image_text_16_string_iterator (const xcb_image_text_16_request_t *R)

 

xcb_void_cookie_t xcb_create_colormap_checked (xcb_connection_t *c, uint8_t alloc, xcb_colormap_t mid, xcb_window_t window, xcb_visualid_t visual)

 

xcb_void_cookie_t xcb_create_colormap (xcb_connection_t *c, uint8_t alloc, xcb_colormap_t mid, xcb_window_t window, xcb_visualid_t visual)

 

xcb_void_cookie_t xcb_free_colormap_checked (xcb_connection_t *c, xcb_colormap_t cmap)

 

xcb_void_cookie_t xcb_free_colormap (xcb_connection_t *c, xcb_colormap_t cmap)

 

xcb_void_cookie_t xcb_copy_colormap_and_free_checked (xcb_connection_t *c, xcb_colormap_t mid, xcb_colormap_t src_cmap)

 

xcb_void_cookie_t xcb_copy_colormap_and_free (xcb_connection_t *c, xcb_colormap_t mid, xcb_colormap_t src_cmap)

 

xcb_void_cookie_t xcb_install_colormap_checked (xcb_connection_t *c, xcb_colormap_t cmap)

 

xcb_void_cookie_t xcb_install_colormap (xcb_connection_t *c, xcb_colormap_t cmap)

 

xcb_void_cookie_t xcb_uninstall_colormap_checked (xcb_connection_t *c, xcb_colormap_t cmap)

 

xcb_void_cookie_t xcb_uninstall_colormap (xcb_connection_t *c, xcb_colormap_t cmap)

 

int xcb_list_installed_colormaps_sizeof (const void *_buffer)

 

xcb_list_installed_colormaps_cookie_t xcb_list_installed_colormaps (xcb_connection_t *c, xcb_window_t window)

 

xcb_list_installed_colormaps_cookie_t xcb_list_installed_colormaps_unchecked (xcb_connection_t *c, xcb_window_t window)

 

xcb_colormap_t * xcb_list_installed_colormaps_cmaps (const xcb_list_installed_colormaps_reply_t *R)

 

int xcb_list_installed_colormaps_cmaps_length (const xcb_list_installed_colormaps_reply_t *R)

 

xcb_generic_iterator_t xcb_list_installed_colormaps_cmaps_end (const xcb_list_installed_colormaps_reply_t *R)

 

xcb_list_installed_colormaps_reply_t * xcb_list_installed_colormaps_reply (xcb_connection_t *c, xcb_list_installed_colormaps_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_alloc_color_cookie_t xcb_alloc_color (xcb_connection_t *c, xcb_colormap_t cmap, uint16_t red, uint16_t green, uint16_t blue)

 Allocate a color. More...

 

xcb_alloc_color_cookie_t xcb_alloc_color_unchecked (xcb_connection_t *c, xcb_colormap_t cmap, uint16_t red, uint16_t green, uint16_t blue)

 Allocate a color. More...

 

xcb_alloc_color_reply_t * xcb_alloc_color_reply (xcb_connection_t *c, xcb_alloc_color_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_alloc_named_color_sizeof (const void *_buffer)

 

xcb_alloc_named_color_cookie_t xcb_alloc_named_color (xcb_connection_t *c, xcb_colormap_t cmap, uint16_t name_len, const char *name)

 

xcb_alloc_named_color_cookie_t xcb_alloc_named_color_unchecked (xcb_connection_t *c, xcb_colormap_t cmap, uint16_t name_len, const char *name)

 

xcb_alloc_named_color_reply_t * xcb_alloc_named_color_reply (xcb_connection_t *c, xcb_alloc_named_color_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_alloc_color_cells_sizeof (const void *_buffer)

 

xcb_alloc_color_cells_cookie_t xcb_alloc_color_cells (xcb_connection_t *c, uint8_t contiguous, xcb_colormap_t cmap, uint16_t colors, uint16_t planes)

 

xcb_alloc_color_cells_cookie_t xcb_alloc_color_cells_unchecked (xcb_connection_t *c, uint8_t contiguous, xcb_colormap_t cmap, uint16_t colors, uint16_t planes)

 

uint32_t * xcb_alloc_color_cells_pixels (const xcb_alloc_color_cells_reply_t *R)

 

int xcb_alloc_color_cells_pixels_length (const xcb_alloc_color_cells_reply_t *R)

 

xcb_generic_iterator_t xcb_alloc_color_cells_pixels_end (const xcb_alloc_color_cells_reply_t *R)

 

uint32_t * xcb_alloc_color_cells_masks (const xcb_alloc_color_cells_reply_t *R)

 

int xcb_alloc_color_cells_masks_length (const xcb_alloc_color_cells_reply_t *R)

 

xcb_generic_iterator_t xcb_alloc_color_cells_masks_end (const xcb_alloc_color_cells_reply_t *R)

 

xcb_alloc_color_cells_reply_t * xcb_alloc_color_cells_reply (xcb_connection_t *c, xcb_alloc_color_cells_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_alloc_color_planes_sizeof (const void *_buffer)

 

xcb_alloc_color_planes_cookie_t xcb_alloc_color_planes (xcb_connection_t *c, uint8_t contiguous, xcb_colormap_t cmap, uint16_t colors, uint16_t reds, uint16_t greens, uint16_t blues)

 

xcb_alloc_color_planes_cookie_t xcb_alloc_color_planes_unchecked (xcb_connection_t *c, uint8_t contiguous, xcb_colormap_t cmap, uint16_t colors, uint16_t reds, uint16_t greens, uint16_t blues)

 

uint32_t * xcb_alloc_color_planes_pixels (const xcb_alloc_color_planes_reply_t *R)

 

int xcb_alloc_color_planes_pixels_length (const xcb_alloc_color_planes_reply_t *R)

 

xcb_generic_iterator_t xcb_alloc_color_planes_pixels_end (const xcb_alloc_color_planes_reply_t *R)

 

xcb_alloc_color_planes_reply_t * xcb_alloc_color_planes_reply (xcb_connection_t *c, xcb_alloc_color_planes_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_free_colors_sizeof (const void *_buffer, uint32_t pixels_len)

 

xcb_void_cookie_t xcb_free_colors_checked (xcb_connection_t *c, xcb_colormap_t cmap, uint32_t plane_mask, uint32_t pixels_len, const uint32_t *pixels)

 

xcb_void_cookie_t xcb_free_colors (xcb_connection_t *c, xcb_colormap_t cmap, uint32_t plane_mask, uint32_t pixels_len, const uint32_t *pixels)

 

uint32_t * xcb_free_colors_pixels (const xcb_free_colors_request_t *R)

 

int xcb_free_colors_pixels_length (const xcb_free_colors_request_t *R)

 

xcb_generic_iterator_t xcb_free_colors_pixels_end (const xcb_free_colors_request_t *R)

 

void xcb_coloritem_next (xcb_coloritem_iterator_t *i)

 

xcb_generic_iterator_t xcb_coloritem_end (xcb_coloritem_iterator_t i)

 

int xcb_store_colors_sizeof (const void *_buffer, uint32_t items_len)

 

xcb_void_cookie_t xcb_store_colors_checked (xcb_connection_t *c, xcb_colormap_t cmap, uint32_t items_len, const xcb_coloritem_t *items)

 

xcb_void_cookie_t xcb_store_colors (xcb_connection_t *c, xcb_colormap_t cmap, uint32_t items_len, const xcb_coloritem_t *items)

 

xcb_coloritem_t * xcb_store_colors_items (const xcb_store_colors_request_t *R)

 

int xcb_store_colors_items_length (const xcb_store_colors_request_t *R)

 

xcb_coloritem_iterator_t xcb_store_colors_items_iterator (const xcb_store_colors_request_t *R)

 

int xcb_store_named_color_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_store_named_color_checked (xcb_connection_t *c, uint8_t flags, xcb_colormap_t cmap, uint32_t pixel, uint16_t name_len, const char *name)

 

xcb_void_cookie_t xcb_store_named_color (xcb_connection_t *c, uint8_t flags, xcb_colormap_t cmap, uint32_t pixel, uint16_t name_len, const char *name)

 

char * xcb_store_named_color_name (const xcb_store_named_color_request_t *R)

 

int xcb_store_named_color_name_length (const xcb_store_named_color_request_t *R)

 

xcb_generic_iterator_t xcb_store_named_color_name_end (const xcb_store_named_color_request_t *R)

 

void xcb_rgb_next (xcb_rgb_iterator_t *i)

 

xcb_generic_iterator_t xcb_rgb_end (xcb_rgb_iterator_t i)

 

int xcb_query_colors_sizeof (const void *_buffer, uint32_t pixels_len)

 

xcb_query_colors_cookie_t xcb_query_colors (xcb_connection_t *c, xcb_colormap_t cmap, uint32_t pixels_len, const uint32_t *pixels)

 

xcb_query_colors_cookie_t xcb_query_colors_unchecked (xcb_connection_t *c, xcb_colormap_t cmap, uint32_t pixels_len, const uint32_t *pixels)

 

xcb_rgb_t * xcb_query_colors_colors (const xcb_query_colors_reply_t *R)

 

int xcb_query_colors_colors_length (const xcb_query_colors_reply_t *R)

 

xcb_rgb_iterator_t xcb_query_colors_colors_iterator (const xcb_query_colors_reply_t *R)

 

xcb_query_colors_reply_t * xcb_query_colors_reply (xcb_connection_t *c, xcb_query_colors_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_lookup_color_sizeof (const void *_buffer)

 

xcb_lookup_color_cookie_t xcb_lookup_color (xcb_connection_t *c, xcb_colormap_t cmap, uint16_t name_len, const char *name)

 

xcb_lookup_color_cookie_t xcb_lookup_color_unchecked (xcb_connection_t *c, xcb_colormap_t cmap, uint16_t name_len, const char *name)

 

xcb_lookup_color_reply_t * xcb_lookup_color_reply (xcb_connection_t *c, xcb_lookup_color_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_create_cursor_checked (xcb_connection_t *c, xcb_cursor_t cid, xcb_pixmap_t source, xcb_pixmap_t mask, uint16_t fore_red, uint16_t fore_green, uint16_t fore_blue, uint16_t back_red, uint16_t back_green, uint16_t back_blue, uint16_t x, uint16_t y)

 

xcb_void_cookie_t xcb_create_cursor (xcb_connection_t *c, xcb_cursor_t cid, xcb_pixmap_t source, xcb_pixmap_t mask, uint16_t fore_red, uint16_t fore_green, uint16_t fore_blue, uint16_t back_red, uint16_t back_green, uint16_t back_blue, uint16_t x, uint16_t y)

 

xcb_void_cookie_t xcb_create_glyph_cursor_checked (xcb_connection_t *c, xcb_cursor_t cid, xcb_font_t source_font, xcb_font_t mask_font, uint16_t source_char, uint16_t mask_char, uint16_t fore_red, uint16_t fore_green, uint16_t fore_blue, uint16_t back_red, uint16_t back_green, uint16_t back_blue)

 create cursor More...

 

xcb_void_cookie_t xcb_create_glyph_cursor (xcb_connection_t *c, xcb_cursor_t cid, xcb_font_t source_font, xcb_font_t mask_font, uint16_t source_char, uint16_t mask_char, uint16_t fore_red, uint16_t fore_green, uint16_t fore_blue, uint16_t back_red, uint16_t back_green, uint16_t back_blue)

 create cursor More...

 

xcb_void_cookie_t xcb_free_cursor_checked (xcb_connection_t *c, xcb_cursor_t cursor)

 Deletes a cursor. More...

 

xcb_void_cookie_t xcb_free_cursor (xcb_connection_t *c, xcb_cursor_t cursor)

 Deletes a cursor. More...

 

xcb_void_cookie_t xcb_recolor_cursor_checked (xcb_connection_t *c, xcb_cursor_t cursor, uint16_t fore_red, uint16_t fore_green, uint16_t fore_blue, uint16_t back_red, uint16_t back_green, uint16_t back_blue)

 

xcb_void_cookie_t xcb_recolor_cursor (xcb_connection_t *c, xcb_cursor_t cursor, uint16_t fore_red, uint16_t fore_green, uint16_t fore_blue, uint16_t back_red, uint16_t back_green, uint16_t back_blue)

 

xcb_query_best_size_cookie_t xcb_query_best_size (xcb_connection_t *c, uint8_t _class, xcb_drawable_t drawable, uint16_t width, uint16_t height)

 

xcb_query_best_size_cookie_t xcb_query_best_size_unchecked (xcb_connection_t *c, uint8_t _class, xcb_drawable_t drawable, uint16_t width, uint16_t height)

 

xcb_query_best_size_reply_t * xcb_query_best_size_reply (xcb_connection_t *c, xcb_query_best_size_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_query_extension_sizeof (const void *_buffer)

 

xcb_query_extension_cookie_t xcb_query_extension (xcb_connection_t *c, uint16_t name_len, const char *name)

 check if extension is present More...

 

xcb_query_extension_cookie_t xcb_query_extension_unchecked (xcb_connection_t *c, uint16_t name_len, const char *name)

 check if extension is present More...

 

xcb_query_extension_reply_t * xcb_query_extension_reply (xcb_connection_t *c, xcb_query_extension_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_list_extensions_sizeof (const void *_buffer)

 

xcb_list_extensions_cookie_t xcb_list_extensions (xcb_connection_t *c)

 

xcb_list_extensions_cookie_t xcb_list_extensions_unchecked (xcb_connection_t *c)

 

int xcb_list_extensions_names_length (const xcb_list_extensions_reply_t *R)

 

xcb_str_iterator_t xcb_list_extensions_names_iterator (const xcb_list_extensions_reply_t *R)

 

xcb_list_extensions_reply_t * xcb_list_extensions_reply (xcb_connection_t *c, xcb_list_extensions_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_change_keyboard_mapping_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_change_keyboard_mapping_checked (xcb_connection_t *c, uint8_t keycode_count, xcb_keycode_t first_keycode, uint8_t keysyms_per_keycode, const xcb_keysym_t *keysyms)

 

xcb_void_cookie_t xcb_change_keyboard_mapping (xcb_connection_t *c, uint8_t keycode_count, xcb_keycode_t first_keycode, uint8_t keysyms_per_keycode, const xcb_keysym_t *keysyms)

 

xcb_keysym_t * xcb_change_keyboard_mapping_keysyms (const xcb_change_keyboard_mapping_request_t *R)

 

int xcb_change_keyboard_mapping_keysyms_length (const xcb_change_keyboard_mapping_request_t *R)

 

xcb_generic_iterator_t xcb_change_keyboard_mapping_keysyms_end (const xcb_change_keyboard_mapping_request_t *R)

 

int xcb_get_keyboard_mapping_sizeof (const void *_buffer)

 

xcb_get_keyboard_mapping_cookie_t xcb_get_keyboard_mapping (xcb_connection_t *c, xcb_keycode_t first_keycode, uint8_t count)

 

xcb_get_keyboard_mapping_cookie_t xcb_get_keyboard_mapping_unchecked (xcb_connection_t *c, xcb_keycode_t first_keycode, uint8_t count)

 

xcb_keysym_t * xcb_get_keyboard_mapping_keysyms (const xcb_get_keyboard_mapping_reply_t *R)

 

int xcb_get_keyboard_mapping_keysyms_length (const xcb_get_keyboard_mapping_reply_t *R)

 

xcb_generic_iterator_t xcb_get_keyboard_mapping_keysyms_end (const xcb_get_keyboard_mapping_reply_t *R)

 

xcb_get_keyboard_mapping_reply_t * xcb_get_keyboard_mapping_reply (xcb_connection_t *c, xcb_get_keyboard_mapping_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_change_keyboard_control_value_list_serialize (void **_buffer, uint32_t value_mask, const xcb_change_keyboard_control_value_list_t *_aux)

 

int xcb_change_keyboard_control_value_list_unpack (const void *_buffer, uint32_t value_mask, xcb_change_keyboard_control_value_list_t *_aux)

 

int xcb_change_keyboard_control_value_list_sizeof (const void *_buffer, uint32_t value_mask)

 

int xcb_change_keyboard_control_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_change_keyboard_control_checked (xcb_connection_t *c, uint32_t value_mask, const void *value_list)

 

xcb_void_cookie_t xcb_change_keyboard_control (xcb_connection_t *c, uint32_t value_mask, const void *value_list)

 

xcb_void_cookie_t xcb_change_keyboard_control_aux_checked (xcb_connection_t *c, uint32_t value_mask, const xcb_change_keyboard_control_value_list_t *value_list)

 

xcb_void_cookie_t xcb_change_keyboard_control_aux (xcb_connection_t *c, uint32_t value_mask, const xcb_change_keyboard_control_value_list_t *value_list)

 

void * xcb_change_keyboard_control_value_list (const xcb_change_keyboard_control_request_t *R)

 

xcb_get_keyboard_control_cookie_t xcb_get_keyboard_control (xcb_connection_t *c)

 

xcb_get_keyboard_control_cookie_t xcb_get_keyboard_control_unchecked (xcb_connection_t *c)

 

xcb_get_keyboard_control_reply_t * xcb_get_keyboard_control_reply (xcb_connection_t *c, xcb_get_keyboard_control_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_bell_checked (xcb_connection_t *c, int8_t percent)

 

xcb_void_cookie_t xcb_bell (xcb_connection_t *c, int8_t percent)

 

xcb_void_cookie_t xcb_change_pointer_control_checked (xcb_connection_t *c, int16_t acceleration_numerator, int16_t acceleration_denominator, int16_t threshold, uint8_t do_acceleration, uint8_t do_threshold)

 

xcb_void_cookie_t xcb_change_pointer_control (xcb_connection_t *c, int16_t acceleration_numerator, int16_t acceleration_denominator, int16_t threshold, uint8_t do_acceleration, uint8_t do_threshold)

 

xcb_get_pointer_control_cookie_t xcb_get_pointer_control (xcb_connection_t *c)

 

xcb_get_pointer_control_cookie_t xcb_get_pointer_control_unchecked (xcb_connection_t *c)

 

xcb_get_pointer_control_reply_t * xcb_get_pointer_control_reply (xcb_connection_t *c, xcb_get_pointer_control_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_set_screen_saver_checked (xcb_connection_t *c, int16_t timeout, int16_t interval, uint8_t prefer_blanking, uint8_t allow_exposures)

 

xcb_void_cookie_t xcb_set_screen_saver (xcb_connection_t *c, int16_t timeout, int16_t interval, uint8_t prefer_blanking, uint8_t allow_exposures)

 

xcb_get_screen_saver_cookie_t xcb_get_screen_saver (xcb_connection_t *c)

 

xcb_get_screen_saver_cookie_t xcb_get_screen_saver_unchecked (xcb_connection_t *c)

 

xcb_get_screen_saver_reply_t * xcb_get_screen_saver_reply (xcb_connection_t *c, xcb_get_screen_saver_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_change_hosts_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_change_hosts_checked (xcb_connection_t *c, uint8_t mode, uint8_t family, uint16_t address_len, const uint8_t *address)

 

xcb_void_cookie_t xcb_change_hosts (xcb_connection_t *c, uint8_t mode, uint8_t family, uint16_t address_len, const uint8_t *address)

 

uint8_t * xcb_change_hosts_address (const xcb_change_hosts_request_t *R)

 

int xcb_change_hosts_address_length (const xcb_change_hosts_request_t *R)

 

xcb_generic_iterator_t xcb_change_hosts_address_end (const xcb_change_hosts_request_t *R)

 

int xcb_host_sizeof (const void *_buffer)

 

uint8_t * xcb_host_address (const xcb_host_t *R)

 

int xcb_host_address_length (const xcb_host_t *R)

 

xcb_generic_iterator_t xcb_host_address_end (const xcb_host_t *R)

 

void xcb_host_next (xcb_host_iterator_t *i)

 

xcb_generic_iterator_t xcb_host_end (xcb_host_iterator_t i)

 

int xcb_list_hosts_sizeof (const void *_buffer)

 

xcb_list_hosts_cookie_t xcb_list_hosts (xcb_connection_t *c)

 

xcb_list_hosts_cookie_t xcb_list_hosts_unchecked (xcb_connection_t *c)

 

int xcb_list_hosts_hosts_length (const xcb_list_hosts_reply_t *R)

 

xcb_host_iterator_t xcb_list_hosts_hosts_iterator (const xcb_list_hosts_reply_t *R)

 

xcb_list_hosts_reply_t * xcb_list_hosts_reply (xcb_connection_t *c, xcb_list_hosts_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_set_access_control_checked (xcb_connection_t *c, uint8_t mode)

 

xcb_void_cookie_t xcb_set_access_control (xcb_connection_t *c, uint8_t mode)

 

xcb_void_cookie_t xcb_set_close_down_mode_checked (xcb_connection_t *c, uint8_t mode)

 

xcb_void_cookie_t xcb_set_close_down_mode (xcb_connection_t *c, uint8_t mode)

 

xcb_void_cookie_t xcb_kill_client_checked (xcb_connection_t *c, uint32_t resource)

 kills a client More...

 

xcb_void_cookie_t xcb_kill_client (xcb_connection_t *c, uint32_t resource)

 kills a client More...

 

int xcb_rotate_properties_sizeof (const void *_buffer)

 

xcb_void_cookie_t xcb_rotate_properties_checked (xcb_connection_t *c, xcb_window_t window, uint16_t atoms_len, int16_t delta, const xcb_atom_t *atoms)

 

xcb_void_cookie_t xcb_rotate_properties (xcb_connection_t *c, xcb_window_t window, uint16_t atoms_len, int16_t delta, const xcb_atom_t *atoms)

 

xcb_atom_t * xcb_rotate_properties_atoms (const xcb_rotate_properties_request_t *R)

 

int xcb_rotate_properties_atoms_length (const xcb_rotate_properties_request_t *R)

 

xcb_generic_iterator_t xcb_rotate_properties_atoms_end (const xcb_rotate_properties_request_t *R)

 

xcb_void_cookie_t xcb_force_screen_saver_checked (xcb_connection_t *c, uint8_t mode)

 

xcb_void_cookie_t xcb_force_screen_saver (xcb_connection_t *c, uint8_t mode)

 

int xcb_set_pointer_mapping_sizeof (const void *_buffer)

 

xcb_set_pointer_mapping_cookie_t xcb_set_pointer_mapping (xcb_connection_t *c, uint8_t map_len, const uint8_t *map)

 

xcb_set_pointer_mapping_cookie_t xcb_set_pointer_mapping_unchecked (xcb_connection_t *c, uint8_t map_len, const uint8_t *map)

 

xcb_set_pointer_mapping_reply_t * xcb_set_pointer_mapping_reply (xcb_connection_t *c, xcb_set_pointer_mapping_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_get_pointer_mapping_sizeof (const void *_buffer)

 

xcb_get_pointer_mapping_cookie_t xcb_get_pointer_mapping (xcb_connection_t *c)

 

xcb_get_pointer_mapping_cookie_t xcb_get_pointer_mapping_unchecked (xcb_connection_t *c)

 

uint8_t * xcb_get_pointer_mapping_map (const xcb_get_pointer_mapping_reply_t *R)

 

int xcb_get_pointer_mapping_map_length (const xcb_get_pointer_mapping_reply_t *R)

 

xcb_generic_iterator_t xcb_get_pointer_mapping_map_end (const xcb_get_pointer_mapping_reply_t *R)

 

xcb_get_pointer_mapping_reply_t * xcb_get_pointer_mapping_reply (xcb_connection_t *c, xcb_get_pointer_mapping_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_set_modifier_mapping_sizeof (const void *_buffer)

 

xcb_set_modifier_mapping_cookie_t xcb_set_modifier_mapping (xcb_connection_t *c, uint8_t keycodes_per_modifier, const xcb_keycode_t *keycodes)

 

xcb_set_modifier_mapping_cookie_t xcb_set_modifier_mapping_unchecked (xcb_connection_t *c, uint8_t keycodes_per_modifier, const xcb_keycode_t *keycodes)

 

xcb_set_modifier_mapping_reply_t * xcb_set_modifier_mapping_reply (xcb_connection_t *c, xcb_set_modifier_mapping_cookie_t cookie, xcb_generic_error_t **e)

 

int xcb_get_modifier_mapping_sizeof (const void *_buffer)

 

xcb_get_modifier_mapping_cookie_t xcb_get_modifier_mapping (xcb_connection_t *c)

 

xcb_get_modifier_mapping_cookie_t xcb_get_modifier_mapping_unchecked (xcb_connection_t *c)

 

xcb_keycode_t * xcb_get_modifier_mapping_keycodes (const xcb_get_modifier_mapping_reply_t *R)

 

int xcb_get_modifier_mapping_keycodes_length (const xcb_get_modifier_mapping_reply_t *R)

 

xcb_generic_iterator_t xcb_get_modifier_mapping_keycodes_end (const xcb_get_modifier_mapping_reply_t *R)

 

xcb_get_modifier_mapping_reply_t * xcb_get_modifier_mapping_reply (xcb_connection_t *c, xcb_get_modifier_mapping_cookie_t cookie, xcb_generic_error_t **e)

 

xcb_void_cookie_t xcb_no_operation_checked (xcb_connection_t *c)

 

xcb_void_cookie_t xcb_no_operation (xcb_connection_t *c)

 

Detailed Description

XCB Protocol Implementation.

Macro Definition Documentation

#define XCB_ACCESS   10

Opcode for xcb_access.

#define XCB_ALLOC   11

Opcode for xcb_alloc.

#define XCB_ALLOC_COLOR   84

Opcode for xcb_alloc_color.

Referenced by xcb_alloc_color(), and xcb_alloc_color_unchecked().

#define XCB_ALLOC_COLOR_CELLS   86

Opcode for xcb_alloc_color_cells.

Referenced by xcb_alloc_color_cells(), and xcb_alloc_color_cells_unchecked().

#define XCB_ALLOC_COLOR_PLANES   87

Opcode for xcb_alloc_color_planes.

Referenced by xcb_alloc_color_planes(), and xcb_alloc_color_planes_unchecked().

#define XCB_ALLOC_NAMED_COLOR   85

Opcode for xcb_alloc_named_color.

Referenced by xcb_alloc_named_color(), and xcb_alloc_named_color_unchecked().

#define XCB_ALLOW_EVENTS   35

Opcode for xcb_allow_events.

Referenced by xcb_allow_events(), and xcb_allow_events_checked().

#define XCB_ATOM   5

Opcode for xcb_atom.

#define XCB_BELL   104

Opcode for xcb_bell.

Referenced by xcb_bell(), and xcb_bell_checked().

#define XCB_BUTTON_PRESS   4

Opcode for xcb_button_press.

#define XCB_BUTTON_RELEASE   5

Opcode for xcb_button_release.

#define XCB_CHANGE_ACTIVE_POINTER_GRAB   30

Opcode for xcb_change_active_pointer_grab.

Referenced by xcb_change_active_pointer_grab(), and xcb_change_active_pointer_grab_checked().

#define XCB_CHANGE_GC   56

Opcode for xcb_change_gc.

Referenced by xcb_change_gc(), xcb_change_gc_aux(), xcb_change_gc_aux_checked(), and xcb_change_gc_checked().

#define XCB_CHANGE_HOSTS   109

Opcode for xcb_change_hosts.

Referenced by xcb_change_hosts(), and xcb_change_hosts_checked().

#define XCB_CHANGE_KEYBOARD_CONTROL   102

Opcode for xcb_change_keyboard_control.

Referenced by xcb_change_keyboard_control(), xcb_change_keyboard_control_aux(), xcb_change_keyboard_control_aux_checked(), and xcb_change_keyboard_control_checked().

#define XCB_CHANGE_KEYBOARD_MAPPING   100

Opcode for xcb_change_keyboard_mapping.

Referenced by xcb_change_keyboard_mapping(), and xcb_change_keyboard_mapping_checked().

#define XCB_CHANGE_POINTER_CONTROL   105

Opcode for xcb_change_pointer_control.

Referenced by xcb_change_pointer_control(), and xcb_change_pointer_control_checked().

#define XCB_CHANGE_PROPERTY   18

Opcode for xcb_change_property.

Referenced by xcb_change_property(), and xcb_change_property_checked().

#define XCB_CHANGE_SAVE_SET   6

Opcode for xcb_change_save_set.

Referenced by xcb_change_save_set(), and xcb_change_save_set_checked().

#define XCB_CHANGE_WINDOW_ATTRIBUTES   2

Opcode for xcb_change_window_attributes.

Referenced by xcb_change_window_attributes(), xcb_change_window_attributes_aux(), xcb_change_window_attributes_aux_checked(), and xcb_change_window_attributes_checked().

#define XCB_CIRCULATE_NOTIFY   26

Opcode for xcb_circulate_notify.

#define XCB_CIRCULATE_REQUEST   27

Opcode for xcb_circulate_request.

#define XCB_CIRCULATE_WINDOW   13

Opcode for xcb_circulate_window.

Referenced by xcb_circulate_window(), and xcb_circulate_window_checked().

#define XCB_CLEAR_AREA   61

Opcode for xcb_clear_area.

Referenced by xcb_clear_area(), and xcb_clear_area_checked().

#define XCB_CLIENT_MESSAGE   33

Opcode for xcb_client_message.

#define XCB_CLOSE_FONT   46

Opcode for xcb_close_font.

Referenced by xcb_close_font(), and xcb_close_font_checked().

#define XCB_COLORMAP   12

Opcode for xcb_colormap.

#define XCB_COLORMAP_NOTIFY   32

Opcode for xcb_colormap_notify.

#define XCB_CONFIGURE_NOTIFY   22

Opcode for xcb_configure_notify.

#define XCB_CONFIGURE_REQUEST   23

Opcode for xcb_configure_request.

#define XCB_CONFIGURE_WINDOW   12

Opcode for xcb_configure_window.

Referenced by xcb_configure_window(), xcb_configure_window_aux(), xcb_configure_window_aux_checked(), and xcb_configure_window_checked().

#define XCB_CONVERT_SELECTION   24

Opcode for xcb_convert_selection.

Referenced by xcb_convert_selection(), and xcb_convert_selection_checked().

#define XCB_COPY_AREA   62

Opcode for xcb_copy_area.

Referenced by xcb_copy_area(), and xcb_copy_area_checked().

#define XCB_COPY_COLORMAP_AND_FREE   80

Opcode for xcb_copy_colormap_and_free.

Referenced by xcb_copy_colormap_and_free(), and xcb_copy_colormap_and_free_checked().

#define XCB_COPY_GC   57

Opcode for xcb_copy_gc.

Referenced by xcb_copy_gc(), and xcb_copy_gc_checked().

#define XCB_COPY_PLANE   63

Opcode for xcb_copy_plane.

Referenced by xcb_copy_plane(), and xcb_copy_plane_checked().

#define XCB_CREATE_COLORMAP   78

Opcode for xcb_create_colormap.

Referenced by xcb_create_colormap(), and xcb_create_colormap_checked().

#define XCB_CREATE_CURSOR   93

Opcode for xcb_create_cursor.

Referenced by xcb_create_cursor(), and xcb_create_cursor_checked().

#define XCB_CREATE_GC   55

Opcode for xcb_create_gc.

Referenced by xcb_create_gc(), xcb_create_gc_aux(), xcb_create_gc_aux_checked(), and xcb_create_gc_checked().

#define XCB_CREATE_GLYPH_CURSOR   94

Opcode for xcb_create_glyph_cursor.

Referenced by xcb_create_glyph_cursor(), and xcb_create_glyph_cursor_checked().

#define XCB_CREATE_NOTIFY   16

Opcode for xcb_create_notify.

#define XCB_CREATE_PIXMAP   53

Opcode for xcb_create_pixmap.

Referenced by xcb_create_pixmap(), and xcb_create_pixmap_checked().

#define XCB_CREATE_WINDOW   1

Opcode for xcb_create_window.

Referenced by xcb_create_window(), xcb_create_window_aux(), xcb_create_window_aux_checked(), and xcb_create_window_checked().

#define XCB_CURSOR   6

Opcode for xcb_cursor.

#define XCB_DELETE_PROPERTY   19

Opcode for xcb_delete_property.

Referenced by xcb_delete_property(), and xcb_delete_property_checked().

#define XCB_DESTROY_NOTIFY   17

Opcode for xcb_destroy_notify.

#define XCB_DESTROY_SUBWINDOWS   5

Opcode for xcb_destroy_subwindows.

Referenced by xcb_destroy_subwindows(), and xcb_destroy_subwindows_checked().

#define XCB_DESTROY_WINDOW   4

Opcode for xcb_destroy_window.

Referenced by xcb_destroy_window(), and xcb_destroy_window_checked().

#define XCB_DRAWABLE   9

Opcode for xcb_drawable.

#define XCB_ENTER_NOTIFY   7

Opcode for xcb_enter_notify.

#define XCB_EXPOSE   12

Opcode for xcb_expose.

#define XCB_FILL_POLY   69

Opcode for xcb_fill_poly.

Referenced by xcb_fill_poly(), and xcb_fill_poly_checked().

#define XCB_FOCUS_IN   9

Opcode for xcb_focus_in.

#define XCB_FOCUS_OUT   10

Opcode for xcb_focus_out.

#define XCB_FONT   7

Opcode for xcb_font.

#define XCB_FORCE_SCREEN_SAVER   115

Opcode for xcb_force_screen_saver.

Referenced by xcb_force_screen_saver(), and xcb_force_screen_saver_checked().

#define XCB_FREE_COLORMAP   79

Opcode for xcb_free_colormap.

Referenced by xcb_free_colormap(), and xcb_free_colormap_checked().

#define XCB_FREE_COLORS   88

Opcode for xcb_free_colors.

Referenced by xcb_free_colors(), and xcb_free_colors_checked().

#define XCB_FREE_CURSOR   95

Opcode for xcb_free_cursor.

Referenced by xcb_free_cursor(), and xcb_free_cursor_checked().

#define XCB_FREE_GC   60

Opcode for xcb_free_gc.

Referenced by xcb_free_gc(), and xcb_free_gc_checked().

#define XCB_FREE_PIXMAP   54

Opcode for xcb_free_pixmap.

Referenced by xcb_free_pixmap(), and xcb_free_pixmap_checked().

#define XCB_G_CONTEXT   13

Opcode for xcb_g_context.

#define XCB_GE_GENERIC   35

Opcode for xcb_ge_generic.

#define XCB_GET_ATOM_NAME   17

Opcode for xcb_get_atom_name.

Referenced by xcb_get_atom_name(), and xcb_get_atom_name_unchecked().

#define XCB_GET_FONT_PATH   52

Opcode for xcb_get_font_path.

Referenced by xcb_get_font_path(), and xcb_get_font_path_unchecked().

#define XCB_GET_GEOMETRY   14

Opcode for xcb_get_geometry.

Referenced by xcb_get_geometry(), and xcb_get_geometry_unchecked().

#define XCB_GET_IMAGE   73

Opcode for xcb_get_image.

Referenced by xcb_get_image(), and xcb_get_image_unchecked().

#define XCB_GET_INPUT_FOCUS   43

Opcode for xcb_get_input_focus.

Referenced by xcb_get_input_focus(), and xcb_get_input_focus_unchecked().

#define XCB_GET_KEYBOARD_CONTROL   103

Opcode for xcb_get_keyboard_control.

Referenced by xcb_get_keyboard_control(), and xcb_get_keyboard_control_unchecked().

#define XCB_GET_KEYBOARD_MAPPING   101

Opcode for xcb_get_keyboard_mapping.

Referenced by xcb_get_keyboard_mapping(), and xcb_get_keyboard_mapping_unchecked().

#define XCB_GET_MODIFIER_MAPPING   119

Opcode for xcb_get_modifier_mapping.

Referenced by xcb_get_modifier_mapping(), and xcb_get_modifier_mapping_unchecked().

#define XCB_GET_MOTION_EVENTS   39

Opcode for xcb_get_motion_events.

Referenced by xcb_get_motion_events(), and xcb_get_motion_events_unchecked().

#define XCB_GET_POINTER_CONTROL   106

Opcode for xcb_get_pointer_control.

Referenced by xcb_get_pointer_control(), and xcb_get_pointer_control_unchecked().

#define XCB_GET_POINTER_MAPPING   117

Opcode for xcb_get_pointer_mapping.

Referenced by xcb_get_pointer_mapping(), and xcb_get_pointer_mapping_unchecked().

#define XCB_GET_PROPERTY   20

Opcode for xcb_get_property.

Referenced by xcb_get_property(), and xcb_get_property_unchecked().

#define XCB_GET_SCREEN_SAVER   108

Opcode for xcb_get_screen_saver.

Referenced by xcb_get_screen_saver(), and xcb_get_screen_saver_unchecked().

#define XCB_GET_SELECTION_OWNER   23

Opcode for xcb_get_selection_owner.

Referenced by xcb_get_selection_owner(), and xcb_get_selection_owner_unchecked().

#define XCB_GET_WINDOW_ATTRIBUTES   3

Opcode for xcb_get_window_attributes.

Referenced by xcb_get_window_attributes(), and xcb_get_window_attributes_unchecked().

#define XCB_GRAB_BUTTON   28

Opcode for xcb_grab_button.

Referenced by xcb_grab_button(), and xcb_grab_button_checked().

#define XCB_GRAB_KEY   33

Opcode for xcb_grab_key.

Referenced by xcb_grab_key(), and xcb_grab_key_checked().

#define XCB_GRAB_KEYBOARD   31

Opcode for xcb_grab_keyboard.

Referenced by xcb_grab_keyboard(), and xcb_grab_keyboard_unchecked().

#define XCB_GRAB_POINTER   26

Opcode for xcb_grab_pointer.

Referenced by xcb_grab_pointer(), and xcb_grab_pointer_unchecked().

#define XCB_GRAB_SERVER   36

Opcode for xcb_grab_server.

Referenced by xcb_grab_server(), and xcb_grab_server_checked().

#define XCB_GRAPHICS_EXPOSURE   13

Opcode for xcb_graphics_exposure.

#define XCB_GRAVITY_NOTIFY   24

Opcode for xcb_gravity_notify.

#define XCB_ID_CHOICE   14

Opcode for xcb_id_choice.

#define XCB_IMAGE_TEXT_16   77

Opcode for xcb_image_text_16.

Referenced by xcb_image_text_16(), and xcb_image_text_16_checked().

#define XCB_IMAGE_TEXT_8   76

Opcode for xcb_image_text_8.

Referenced by xcb_image_text_8(), and xcb_image_text_8_checked().

#define XCB_IMPLEMENTATION   17

Opcode for xcb_implementation.

#define XCB_INSTALL_COLORMAP   81

Opcode for xcb_install_colormap.

Referenced by xcb_install_colormap(), and xcb_install_colormap_checked().

#define XCB_INTERN_ATOM   16

Opcode for xcb_intern_atom.

Referenced by xcb_intern_atom(), and xcb_intern_atom_unchecked().

#define XCB_KEY_PRESS   2

Opcode for xcb_key_press.

#define XCB_KEY_RELEASE   3

Opcode for xcb_key_release.

#define XCB_KEYMAP_NOTIFY   11

Opcode for xcb_keymap_notify.

#define XCB_KILL_CLIENT   113

Opcode for xcb_kill_client.

Referenced by xcb_kill_client(), and xcb_kill_client_checked().

#define XCB_LEAVE_NOTIFY   8

Opcode for xcb_leave_notify.

#define XCB_LENGTH   16

Opcode for xcb_length.

#define XCB_LIST_EXTENSIONS   99

Opcode for xcb_list_extensions.

Referenced by xcb_list_extensions(), and xcb_list_extensions_unchecked().

#define XCB_LIST_FONTS   49

Opcode for xcb_list_fonts.

Referenced by xcb_list_fonts(), and xcb_list_fonts_unchecked().

#define XCB_LIST_FONTS_WITH_INFO   50

Opcode for xcb_list_fonts_with_info.

Referenced by xcb_list_fonts_with_info(), and xcb_list_fonts_with_info_unchecked().

#define XCB_LIST_HOSTS   110

Opcode for xcb_list_hosts.

Referenced by xcb_list_hosts(), and xcb_list_hosts_unchecked().

#define XCB_LIST_INSTALLED_COLORMAPS   83

Opcode for xcb_list_installed_colormaps.

Referenced by xcb_list_installed_colormaps(), and xcb_list_installed_colormaps_unchecked().

#define XCB_LIST_PROPERTIES   21

Opcode for xcb_list_properties.

Referenced by xcb_list_properties(), and xcb_list_properties_unchecked().

#define XCB_LOOKUP_COLOR   92

Opcode for xcb_lookup_color.

Referenced by xcb_lookup_color(), and xcb_lookup_color_unchecked().

#define XCB_MAP_NOTIFY   19

Opcode for xcb_map_notify.

#define XCB_MAP_REQUEST   20

Opcode for xcb_map_request.

#define XCB_MAP_SUBWINDOWS   9

Opcode for xcb_map_subwindows.

Referenced by xcb_map_subwindows(), and xcb_map_subwindows_checked().

#define XCB_MAP_WINDOW   8

Opcode for xcb_map_window.

Referenced by xcb_map_window(), and xcb_map_window_checked().

#define XCB_MAPPING_NOTIFY   34

Opcode for xcb_mapping_notify.

#define XCB_MATCH   8

Opcode for xcb_match.

#define XCB_MOTION_NOTIFY   6

Opcode for xcb_motion_notify.

#define XCB_NAME   15

Opcode for xcb_name.

#define XCB_NO_EXPOSURE   14

Opcode for xcb_no_exposure.

#define XCB_NO_OPERATION   127

Opcode for xcb_no_operation.

Referenced by xcb_no_operation(), and xcb_no_operation_checked().

#define XCB_OPEN_FONT   45

Opcode for xcb_open_font.

Referenced by xcb_open_font(), and xcb_open_font_checked().

#define XCB_PIXMAP   4

Opcode for xcb_pixmap.

#define XCB_POLY_ARC   68

Opcode for xcb_poly_arc.

Referenced by xcb_poly_arc(), and xcb_poly_arc_checked().

#define XCB_POLY_FILL_ARC   71

Opcode for xcb_poly_fill_arc.

Referenced by xcb_poly_fill_arc(), and xcb_poly_fill_arc_checked().

#define XCB_POLY_FILL_RECTANGLE   70

Opcode for xcb_poly_fill_rectangle.

Referenced by xcb_poly_fill_rectangle(), and xcb_poly_fill_rectangle_checked().

#define XCB_POLY_LINE   65

Opcode for xcb_poly_line.

Referenced by xcb_poly_line(), and xcb_poly_line_checked().

#define XCB_POLY_POINT   64

Opcode for xcb_poly_point.

Referenced by xcb_poly_point(), and xcb_poly_point_checked().

#define XCB_POLY_RECTANGLE   67

Opcode for xcb_poly_rectangle.

Referenced by xcb_poly_rectangle(), and xcb_poly_rectangle_checked().

#define XCB_POLY_SEGMENT   66

Opcode for xcb_poly_segment.

Referenced by xcb_poly_segment(), and xcb_poly_segment_checked().

#define XCB_POLY_TEXT_16   75

Opcode for xcb_poly_text_16.

Referenced by xcb_poly_text_16(), and xcb_poly_text_16_checked().

#define XCB_POLY_TEXT_8   74

Opcode for xcb_poly_text_8.

Referenced by xcb_poly_text_8(), and xcb_poly_text_8_checked().

#define XCB_PROPERTY_NOTIFY   28

Opcode for xcb_property_notify.

#define XCB_PUT_IMAGE   72

Opcode for xcb_put_image.

Referenced by xcb_put_image(), and xcb_put_image_checked().

#define XCB_QUERY_BEST_SIZE   97

Opcode for xcb_query_best_size.

Referenced by xcb_query_best_size(), and xcb_query_best_size_unchecked().

#define XCB_QUERY_COLORS   91

Opcode for xcb_query_colors.

Referenced by xcb_query_colors(), and xcb_query_colors_unchecked().

#define XCB_QUERY_EXTENSION   98

Opcode for xcb_query_extension.

Referenced by xcb_query_extension(), and xcb_query_extension_unchecked().

#define XCB_QUERY_FONT   47

Opcode for xcb_query_font.

Referenced by xcb_query_font(), and xcb_query_font_unchecked().

#define XCB_QUERY_KEYMAP   44

Opcode for xcb_query_keymap.

Referenced by xcb_query_keymap(), and xcb_query_keymap_unchecked().

#define XCB_QUERY_POINTER   38

Opcode for xcb_query_pointer.

Referenced by xcb_query_pointer(), and xcb_query_pointer_unchecked().

#define XCB_QUERY_TEXT_EXTENTS   48

Opcode for xcb_query_text_extents.

Referenced by xcb_query_text_extents(), and xcb_query_text_extents_unchecked().

#define XCB_QUERY_TREE   15

Opcode for xcb_query_tree.

Referenced by xcb_query_tree(), and xcb_query_tree_unchecked().

#define XCB_RECOLOR_CURSOR   96

Opcode for xcb_recolor_cursor.

Referenced by xcb_recolor_cursor(), and xcb_recolor_cursor_checked().

#define XCB_REPARENT_NOTIFY   21

Opcode for xcb_reparent_notify.

#define XCB_REPARENT_WINDOW   7

Opcode for xcb_reparent_window.

Referenced by xcb_reparent_window(), and xcb_reparent_window_checked().

#define XCB_REQUEST   1

Opcode for xcb_request.

#define XCB_RESIZE_REQUEST   25

Opcode for xcb_resize_request.

#define XCB_ROTATE_PROPERTIES   114

Opcode for xcb_rotate_properties.

Referenced by xcb_rotate_properties(), and xcb_rotate_properties_checked().

#define XCB_SELECTION_CLEAR   29

Opcode for xcb_selection_clear.

#define XCB_SELECTION_NOTIFY   31

Opcode for xcb_selection_notify.

#define XCB_SELECTION_REQUEST   30

Opcode for xcb_selection_request.

#define XCB_SEND_EVENT   25

Opcode for xcb_send_event.

Referenced by xcb_send_event(), and xcb_send_event_checked().

#define XCB_SET_ACCESS_CONTROL   111

Opcode for xcb_set_access_control.

Referenced by xcb_set_access_control(), and xcb_set_access_control_checked().

#define XCB_SET_CLIP_RECTANGLES   59

Opcode for xcb_set_clip_rectangles.

Referenced by xcb_set_clip_rectangles(), and xcb_set_clip_rectangles_checked().

#define XCB_SET_CLOSE_DOWN_MODE   112

Opcode for xcb_set_close_down_mode.

Referenced by xcb_set_close_down_mode(), and xcb_set_close_down_mode_checked().

#define XCB_SET_DASHES   58

Opcode for xcb_set_dashes.

Referenced by xcb_set_dashes(), and xcb_set_dashes_checked().

#define XCB_SET_FONT_PATH   51

Opcode for xcb_set_font_path.

Referenced by xcb_set_font_path(), and xcb_set_font_path_checked().

#define XCB_SET_INPUT_FOCUS   42

Opcode for xcb_set_input_focus.

Referenced by xcb_set_input_focus(), and xcb_set_input_focus_checked().

#define XCB_SET_MODIFIER_MAPPING   118

Opcode for xcb_set_modifier_mapping.

Referenced by xcb_set_modifier_mapping(), and xcb_set_modifier_mapping_unchecked().

#define XCB_SET_POINTER_MAPPING   116

Opcode for xcb_set_pointer_mapping.

Referenced by xcb_set_pointer_mapping(), and xcb_set_pointer_mapping_unchecked().

#define XCB_SET_SCREEN_SAVER   107

Opcode for xcb_set_screen_saver.

Referenced by xcb_set_screen_saver(), and xcb_set_screen_saver_checked().

#define XCB_SET_SELECTION_OWNER   22

Opcode for xcb_set_selection_owner.

Referenced by xcb_set_selection_owner(), and xcb_set_selection_owner_checked().

#define XCB_STORE_COLORS   89

Opcode for xcb_store_colors.

Referenced by xcb_store_colors(), and xcb_store_colors_checked().

#define XCB_STORE_NAMED_COLOR   90

Opcode for xcb_store_named_color.

Referenced by xcb_store_named_color(), and xcb_store_named_color_checked().

#define XCB_TRANSLATE_COORDINATES   40

Opcode for xcb_translate_coordinates.

Referenced by xcb_translate_coordinates(), and xcb_translate_coordinates_unchecked().

#define XCB_UNGRAB_BUTTON   29

Opcode for xcb_ungrab_button.

Referenced by xcb_ungrab_button(), and xcb_ungrab_button_checked().

#define XCB_UNGRAB_KEY   34

Opcode for xcb_ungrab_key.

Referenced by xcb_ungrab_key(), and xcb_ungrab_key_checked().

#define XCB_UNGRAB_KEYBOARD   32

Opcode for xcb_ungrab_keyboard.

Referenced by xcb_ungrab_keyboard(), and xcb_ungrab_keyboard_checked().

#define XCB_UNGRAB_POINTER   27

Opcode for xcb_ungrab_pointer.

Referenced by xcb_ungrab_pointer(), and xcb_ungrab_pointer_checked().

#define XCB_UNGRAB_SERVER   37

Opcode for xcb_ungrab_server.

Referenced by xcb_ungrab_server(), and xcb_ungrab_server_checked().

#define XCB_UNINSTALL_COLORMAP   82

Opcode for xcb_uninstall_colormap.

Referenced by xcb_uninstall_colormap(), and xcb_uninstall_colormap_checked().

#define XCB_UNMAP_NOTIFY   18

Opcode for xcb_unmap_notify.

#define XCB_UNMAP_SUBWINDOWS   11

Opcode for xcb_unmap_subwindows.

Referenced by xcb_unmap_subwindows(), and xcb_unmap_subwindows_checked().

#define XCB_UNMAP_WINDOW   10

Opcode for xcb_unmap_window.

Referenced by xcb_unmap_window(), and xcb_unmap_window_checked().

#define XCB_VALUE   2

Opcode for xcb_value.

#define XCB_VISIBILITY_NOTIFY   15

Opcode for xcb_visibility_notify.

#define XCB_WARP_POINTER   41

Opcode for xcb_warp_pointer.

Referenced by xcb_warp_pointer(), and xcb_warp_pointer_checked().

#define XCB_WINDOW   3

Opcode for xcb_window.

Enumeration Type Documentation

enum xcb_allow_t

EnumeratorXCB_ALLOW_ASYNC_POINTER 

For AsyncPointer, if the pointer is frozen by the client, pointer event processing continues normally. If the pointer is frozen twice by the client on behalf of two separate grabs, AsyncPointer thaws for both. AsyncPointer has no effect if the pointer is not frozen by the client, but the pointer need not be grabbed by the client.

TODO: rewrite this in more understandable terms.

XCB_ALLOW_SYNC_POINTER 

For SyncPointer, if the pointer is frozen and actively grabbed by the client, pointer event processing continues normally until the next ButtonPress or ButtonRelease event is reported to the client, at which time the pointer again appears to freeze. However, if the reported event causes the pointer grab to be released, then the pointer does not freeze. SyncPointer has no effect if the pointer is not frozen by the client or if the pointer is not grabbed by the client.

XCB_ALLOW_REPLAY_POINTER 

For ReplayPointer, if the pointer is actively grabbed by the client and is frozen as the result of an event having been sent to the client (either from the activation of a GrabButton or from a previous AllowEvents with mode SyncPointer but not from a GrabPointer), then the pointer grab is released and that event is completely reprocessed, this time ignoring any passive grabs at or above (towards the root) the grab-window of the grab just released. The request has no effect if the pointer is not grabbed by the client or if the pointer is not frozen as the result of an event.

XCB_ALLOW_ASYNC_KEYBOARD 

For AsyncKeyboard, if the keyboard is frozen by the client, keyboard event processing continues normally. If the keyboard is frozen twice by the client on behalf of two separate grabs, AsyncKeyboard thaws for both. AsyncKeyboard has no effect if the keyboard is not frozen by the client, but the keyboard need not be grabbed by the client.

XCB_ALLOW_SYNC_KEYBOARD 

For SyncKeyboard, if the keyboard is frozen and actively grabbed by the client, keyboard event processing continues normally until the next KeyPress or KeyRelease event is reported to the client, at which time the keyboard again appears to freeze. However, if the reported event causes the keyboard grab to be released, then the keyboard does not freeze. SyncKeyboard has no effect if the keyboard is not frozen by the client or if the keyboard is not grabbed by the client.

XCB_ALLOW_REPLAY_KEYBOARD 

For ReplayKeyboard, if the keyboard is actively grabbed by the client and is frozen as the result of an event having been sent to the client (either from the activation of a GrabKey or from a previous AllowEvents with mode SyncKeyboard but not from a GrabKeyboard), then the keyboard grab is released and that event is completely reprocessed, this time ignoring any passive grabs at or above (towards the root) the grab-window of the grab just released. The request has no effect if the keyboard is not grabbed by the client or if the keyboard is not frozen as the result of an event.

XCB_ALLOW_ASYNC_BOTH 

For AsyncBoth, if the pointer and the keyboard are frozen by the client, event processing for both devices continues normally. If a device is frozen twice by the client on behalf of two separate grabs, AsyncBoth thaws for both. AsyncBoth has no effect unless both pointer and keyboard are frozen by the client.

XCB_ALLOW_SYNC_BOTH 

For SyncBoth, if both pointer and keyboard are frozen by the client, event processing (for both devices) continues normally until the next ButtonPress, ButtonRelease, KeyPress, or KeyRelease event is reported to the client for a grabbed device (button event for the pointer, key event for the keyboard), at which time the devices again appear to freeze. However, if the reported event causes the grab to be released, then the devices do not freeze (but if the other device is still grabbed, then a subsequent event for it will still cause both devices to freeze). SyncBoth has no effect unless both pointer and keyboard are frozen by the client. If the pointer or keyboard is frozen twice by the client on behalf of two separate grabs, SyncBoth thaws for both (but a subsequent freeze for SyncBoth will only freeze each device once).

enum xcb_button_index_t

EnumeratorXCB_BUTTON_INDEX_ANY 

Any of the following (or none):

XCB_BUTTON_INDEX_1 

The left mouse button.

XCB_BUTTON_INDEX_2 

The right mouse button.

XCB_BUTTON_INDEX_3 

The middle mouse button.

XCB_BUTTON_INDEX_4 

Scroll wheel. TODO: direction?

XCB_BUTTON_INDEX_5 

Scroll wheel. TODO: direction?

enum xcb_colormap_state_t

EnumeratorXCB_COLORMAP_STATE_UNINSTALLED 

The colormap was uninstalled.

XCB_COLORMAP_STATE_INSTALLED 

The colormap was installed.

enum xcb_coord_mode_t

EnumeratorXCB_COORD_MODE_ORIGIN 

Treats all coordinates as relative to the origin.

XCB_COORD_MODE_PREVIOUS 

Treats all coordinates after the first as relative to the previous coordinate.

enum xcb_cw_t

EnumeratorXCB_CW_BACK_PIXMAP 

Overrides the default background-pixmap. The background pixmap and window must have the same root and same depth. Any size pixmap can be used, although some sizes may be faster than others.

If XCB_BACK_PIXMAP_NONE is specified, the window has no defined background. The server may fill the contents with the previous screen contents or with contents of its own choosing.

If XCB_BACK_PIXMAP_PARENT_RELATIVE is specified, the parent's background is used, but the window must have the same depth as the parent (or a Match error results). The parent's background is tracked, and the current version is used each time the window background is required.

XCB_CW_BACK_PIXEL 

Overrides BackPixmap. A pixmap of undefined size filled with the specified background pixel is used for the background. Range-checking is not performed, the background pixel is truncated to the appropriate number of bits.

XCB_CW_BORDER_PIXMAP 

Overrides the default border-pixmap. The border pixmap and window must have the same root and the same depth. Any size pixmap can be used, although some sizes may be faster than others.

The special value XCB_COPY_FROM_PARENT means the parent's border pixmap is copied (subsequent changes to the parent's border attribute do not affect the child), but the window must have the same depth as the parent.

XCB_CW_BORDER_PIXEL 

Overrides BorderPixmap. A pixmap of undefined size filled with the specified border pixel is used for the border. Range checking is not performed on the border-pixel value, it is truncated to the appropriate number of bits.

XCB_CW_BIT_GRAVITY 

Defines which region of the window should be retained if the window is resized.

XCB_CW_WIN_GRAVITY 

Defines how the window should be repositioned if the parent is resized (see ConfigureWindow).

XCB_CW_BACKING_STORE 

A backing-store of WhenMapped advises the server that maintaining contents of obscured regions when the window is mapped would be beneficial. A backing-store of Always advises the server that maintaining contents even when the window is unmapped would be beneficial. In this case, the server may generate an exposure event when the window is created. A value of NotUseful advises the server that maintaining contents is unnecessary, although a server may still choose to maintain contents while the window is mapped. Note that if the server maintains contents, then the server should maintain complete contents not just the region within the parent boundaries, even if the window is larger than its parent. While the server maintains contents, exposure events will not normally be generated, but the server may stop maintaining contents at any time.

XCB_CW_BACKING_PLANES 

The backing-planes indicates (with bits set to 1) which bit planes of the window hold dynamic data that must be preserved in backing-stores and during save-unders.

XCB_CW_BACKING_PIXEL 

The backing-pixel specifies what value to use in planes not covered by backing-planes. The server is free to save only the specified bit planes in the backing-store or save-under and regenerate the remaining planes with the specified pixel value. Any bits beyond the specified depth of the window in these values are simply ignored.

XCB_CW_OVERRIDE_REDIRECT 

The override-redirect specifies whether map and configure requests on this window should override a SubstructureRedirect on the parent, typically to inform a window manager not to tamper with the window.

XCB_CW_SAVE_UNDER 

If 1, the server is advised that when this window is mapped, saving the contents of windows it obscures would be beneficial.

XCB_CW_EVENT_MASK 

The event-mask defines which events the client is interested in for this window (or for some event types, inferiors of the window).

XCB_CW_DONT_PROPAGATE 

The do-not-propagate-mask defines which events should not be propagated to ancestor windows when no client has the event type selected in this window.

XCB_CW_COLORMAP 

The colormap specifies the colormap that best reflects the true colors of the window. Servers capable of supporting multiple hardware colormaps may use this information, and window man- agers may use it for InstallColormap requests. The colormap must have the same visual type and root as the window (or a Match error results). If CopyFromParent is specified, the parent's colormap is copied (subsequent changes to the parent's colormap attribute do not affect the child). However, the window must have the same visual type as the parent (or a Match error results), and the parent must not have a colormap of None (or a Match error results). For an explanation of None, see FreeColormap request. The colormap is copied by sharing the colormap object between the child and the parent, not by making a complete copy of the colormap contents.

XCB_CW_CURSOR 

If a cursor is specified, it will be used whenever the pointer is in the window. If None is speci- fied, the parent's cursor will be used when the pointer is in the window, and any change in the parent's cursor will cause an immediate change in the displayed cursor.

enum xcb_gc_t

EnumeratorXCB_GC_FUNCTION 

TODO: Refer to GX

XCB_GC_PLANE_MASK 

In graphics operations, given a source and destination pixel, the result is computed bitwise on corresponding bits of the pixels; that is, a Boolean operation is performed in each bit plane. The plane-mask restricts the operation to a subset of planes, so the result is: ((src FUNC dst) AND plane-mask) OR (dst AND (NOT plane-mask))

XCB_GC_FOREGROUND 

Foreground colorpixel.

XCB_GC_BACKGROUND 

Background colorpixel.

XCB_GC_LINE_WIDTH 

The line-width is measured in pixels and can be greater than or equal to one, a wide line, or the special value zero, a thin line.

XCB_GC_LINE_STYLE 

The line-style defines which sections of a line are drawn: Solid The full path of the line is drawn. DoubleDash The full path of the line is drawn, but the even dashes are filled differently than the odd dashes (see fill-style), with Butt cap-style used where even and odd dashes meet. OnOffDash Only the even dashes are drawn, and cap-style applies to all internal ends of the individual dashes (except NotLast is treated as Butt).

XCB_GC_CAP_STYLE 

The cap-style defines how the endpoints of a path are drawn: NotLast The result is equivalent to Butt, except that for a line-width of zero the final endpoint is not drawn. Butt The result is square at the endpoint (perpendicular to the slope of the line) with no projection beyond. Round The result is a circular arc with its diameter equal to the line-width, centered on the endpoint; it is equivalent to Butt for line-width zero. Projecting The result is square at the end, but the path continues beyond the endpoint for a distance equal to half the line-width; it is equivalent to Butt for line-width zero.

XCB_GC_JOIN_STYLE 

The join-style defines how corners are drawn for wide lines: Miter The outer edges of the two lines extend to meet at an angle. However, if the angle is less than 11 degrees, a Bevel join-style is used instead. Round The result is a circular arc with a diameter equal to the line-width, centered on the joinpoint. Bevel The result is Butt endpoint styles, and then the triangular notch is filled.

XCB_GC_FILL_STYLE 

The fill-style defines the contents of the source for line, text, and fill requests. For all text and fill requests (for example, PolyText8, PolyText16, PolyFillRectangle, FillPoly, and PolyFillArc) as well as for line requests with line-style Solid, (for example, PolyLine, PolySegment, PolyRectangle, PolyArc) and for the even dashes for line requests with line-style OnOffDash or DoubleDash: Solid Foreground Tiled Tile OpaqueStippled A tile with the same width and height as stipple but with background everywhere stipple has a zero and with foreground everywhere stipple has a one Stippled Foreground masked by stipple For the odd dashes for line requests with line-style DoubleDash: Solid Background Tiled Same as for even dashes OpaqueStippled Same as for even dashes Stippled Background masked by stipple

XCB_GC_TILE 

The tile/stipple represents an infinite two-dimensional plane with the tile/stipple replicated in all dimensions. When that plane is superimposed on the drawable for use in a graphics operation, the upper-left corner of some instance of the tile/stipple is at the coordinates within the drawable specified by the tile/stipple origin. The tile/stipple and clip origins are interpreted relative to the origin of whatever destination drawable is specified in a graphics request. The tile pixmap must have the same root and depth as the gcontext (or a Match error results). The stipple pixmap must have depth one and must have the same root as the gcontext (or a Match error results). For fill-style Stippled (but not fill-style OpaqueStippled), the stipple pattern is tiled in a single plane and acts as an additional clip mask to be ANDed with the clip-mask. Any size pixmap can be used for tiling or stippling, although some sizes may be faster to use than others.

XCB_GC_STIPPLE 

The tile/stipple represents an infinite two-dimensional plane with the tile/stipple replicated in all dimensions. When that plane is superimposed on the drawable for use in a graphics operation, the upper-left corner of some instance of the tile/stipple is at the coordinates within the drawable specified by the tile/stipple origin. The tile/stipple and clip origins are interpreted relative to the origin of whatever destination drawable is specified in a graphics request. The tile pixmap must have the same root and depth as the gcontext (or a Match error results). The stipple pixmap must have depth one and must have the same root as the gcontext (or a Match error results). For fill-style Stippled (but not fill-style OpaqueStippled), the stipple pattern is tiled in a single plane and acts as an additional clip mask to be ANDed with the clip-mask. Any size pixmap can be used for tiling or stippling, although some sizes may be faster to use than others.

XCB_GC_TILE_STIPPLE_ORIGIN_X 

TODO

XCB_GC_TILE_STIPPLE_ORIGIN_Y 

TODO

XCB_GC_FONT 

Which font to use for the ImageText8 and ImageText16 requests.

XCB_GC_SUBWINDOW_MODE 

For ClipByChildren, both source and destination windows are additionally clipped by all viewable InputOutput children. For IncludeInferiors, neither source nor destination window is clipped by inferiors. This will result in including subwindow contents in the source and drawing through subwindow boundaries of the destination. The use of IncludeInferiors with a source or destination window of one depth with mapped inferiors of differing depth is not illegal, but the semantics is undefined by the core protocol.

XCB_GC_GRAPHICS_EXPOSURES 

Whether ExposureEvents should be generated (1) or not (0).

The default is 1.

XCB_GC_CLIP_ORIGIN_X 

TODO

XCB_GC_CLIP_ORIGIN_Y 

TODO

XCB_GC_CLIP_MASK 

The clip-mask restricts writes to the destination drawable. Only pixels where the clip-mask has bits set to 1 are drawn. Pixels are not drawn outside the area covered by the clip-mask or where the clip-mask has bits set to 0. The clip-mask affects all graphics requests, but it does not clip sources. The clip-mask origin is interpreted relative to the origin of whatever destination drawable is specified in a graphics request. If a pixmap is specified as the clip-mask, it must have depth 1 and have the same root as the gcontext (or a Match error results). If clip-mask is None, then pixels are always drawn, regardless of the clip origin. The clip-mask can also be set with the SetClipRectangles request.

XCB_GC_DASH_OFFSET 

TODO

XCB_GC_DASH_LIST 

TODO

XCB_GC_ARC_MODE 

TODO

enum xcb_grab_mode_t

EnumeratorXCB_GRAB_MODE_SYNC 

The state of the keyboard appears to freeze: No further keyboard events are generated by the server until the grabbing client issues a releasing AllowEvents request or until the keyboard grab is released.

XCB_GRAB_MODE_ASYNC 

Keyboard event processing continues normally.

enum xcb_input_focus_t

EnumeratorXCB_INPUT_FOCUS_NONE 

The focus reverts to XCB_NONE, so no window will have the input focus.

XCB_INPUT_FOCUS_POINTER_ROOT 

The focus reverts to XCB_POINTER_ROOT respectively. When the focus reverts, FocusIn and FocusOut events are generated, but the last-focus-change time is not changed.

XCB_INPUT_FOCUS_PARENT 

The focus reverts to the parent (or closest viewable ancestor) and the new revert_to value is XCB_INPUT_FOCUS_NONE.

XCB_INPUT_FOCUS_FOLLOW_KEYBOARD 

NOT YET DOCUMENTED. Only relevant for the xinput extension.

enum xcb_place_t

EnumeratorXCB_PLACE_ON_TOP 

The window is now on top of all siblings.

XCB_PLACE_ON_BOTTOM 

The window is now below all siblings.

enum xcb_prop_mode_t

EnumeratorXCB_PROP_MODE_REPLACE 

Discard the previous property value and store the new data.

XCB_PROP_MODE_PREPEND 

Insert the new data before the beginning of existing data. The format must match existing property value. If the property is undefined, it is treated as defined with the correct type and format with zero-length data.

XCB_PROP_MODE_APPEND 

Insert the new data after the beginning of existing data. The format must match existing property value. If the property is undefined, it is treated as defined with the correct type and format with zero-length data.

Function Documentation

xcb_alloc_color_cookie_t xcb_alloc_color

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint16_t 

red,

uint16_t 

green,

uint16_t 

blue 

)

Allocate a color.

Parameters

cThe connection

cmapTODO

redThe red value of your color.

greenThe green value of your color.

blueThe blue value of your color.

ReturnsA cookie

Allocates a read-only colormap entry corresponding to the closest RGB value supported by the hardware. If you are using TrueColor, you can take a shortcut and directly calculate the color pixel value to avoid the round trip. But, for example, on 16-bit color setups (VNC), you can easily get the closest supported RGB value to the RGB value you are specifying.

References XCB_ALLOC_COLOR.

xcb_alloc_color_cells_cookie_t xcb_alloc_color_cells

(

xcb_connection_t * 

c,

uint8_t 

contiguous,

xcb_colormap_t 

cmap,

uint16_t 

colors,

uint16_t 

planes 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_ALLOC_COLOR_CELLS.

xcb_alloc_color_cells_reply_t* xcb_alloc_color_cells_reply

(

xcb_connection_t * 

c,

xcb_alloc_color_cells_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_alloc_color_cells_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_alloc_color_cells_cookie_t xcb_alloc_color_cells_unchecked

(

xcb_connection_t * 

c,

uint8_t 

contiguous,

xcb_colormap_t 

cmap,

uint16_t 

colors,

uint16_t 

planes 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_ALLOC_COLOR_CELLS.

xcb_alloc_color_planes_cookie_t xcb_alloc_color_planes

(

xcb_connection_t * 

c,

uint8_t 

contiguous,

xcb_colormap_t 

cmap,

uint16_t 

colors,

uint16_t 

reds,

uint16_t 

greens,

uint16_t 

blues 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_ALLOC_COLOR_PLANES.

xcb_alloc_color_planes_reply_t* xcb_alloc_color_planes_reply

(

xcb_connection_t * 

c,

xcb_alloc_color_planes_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_alloc_color_planes_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_alloc_color_planes_cookie_t xcb_alloc_color_planes_unchecked

(

xcb_connection_t * 

c,

uint8_t 

contiguous,

xcb_colormap_t 

cmap,

uint16_t 

colors,

uint16_t 

reds,

uint16_t 

greens,

uint16_t 

blues 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_ALLOC_COLOR_PLANES.

xcb_alloc_color_reply_t* xcb_alloc_color_reply

(

xcb_connection_t * 

c,

xcb_alloc_color_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_alloc_color_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_alloc_color_cookie_t xcb_alloc_color_unchecked

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint16_t 

red,

uint16_t 

green,

uint16_t 

blue 

)

Allocate a color.

Parameters

cThe connection

cmapTODO

redThe red value of your color.

greenThe green value of your color.

blueThe blue value of your color.

ReturnsA cookie

Allocates a read-only colormap entry corresponding to the closest RGB value supported by the hardware. If you are using TrueColor, you can take a shortcut and directly calculate the color pixel value to avoid the round trip. But, for example, on 16-bit color setups (VNC), you can easily get the closest supported RGB value to the RGB value you are specifying.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_ALLOC_COLOR.

xcb_alloc_named_color_cookie_t xcb_alloc_named_color

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint16_t 

name_len,

const char * 

name 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_ALLOC_NAMED_COLOR.

xcb_alloc_named_color_reply_t* xcb_alloc_named_color_reply

(

xcb_connection_t * 

c,

xcb_alloc_named_color_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_alloc_named_color_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_alloc_named_color_cookie_t xcb_alloc_named_color_unchecked

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint16_t 

name_len,

const char * 

name 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_ALLOC_NAMED_COLOR.

xcb_void_cookie_t xcb_allow_events

(

xcb_connection_t * 

c,

uint8_t 

mode,

xcb_timestamp_t 

time 

)

release queued events

Parameters

cThe connection

modeA bitmask of xcb_allow_t values.

mode

timeTimestamp to avoid race conditions when running X over the network.

The special value XCB_CURRENT_TIME will be replaced with the current server time.

ReturnsA cookie

Releases queued events if the client has caused a device (pointer/keyboard) to freeze due to grabbing it actively. This request has no effect if time is earlier than the last-grab time of the most recent active grab for this client or if time is later than the current X server time.

References XCB_ALLOW_EVENTS.

xcb_void_cookie_t xcb_allow_events_checked

(

xcb_connection_t * 

c,

uint8_t 

mode,

xcb_timestamp_t 

time 

)

release queued events

Parameters

cThe connection

modeA bitmask of xcb_allow_t values.

mode

timeTimestamp to avoid race conditions when running X over the network.

The special value XCB_CURRENT_TIME will be replaced with the current server time.

ReturnsA cookie

Releases queued events if the client has caused a device (pointer/keyboard) to freeze due to grabbing it actively. This request has no effect if time is earlier than the last-grab time of the most recent active grab for this client or if time is later than the current X server time.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_ALLOW_EVENTS.

xcb_generic_iterator_t xcb_arc_end

(

xcb_arc_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_arc_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_arc_next

(

xcb_arc_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_arc_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_arc_t)

xcb_generic_iterator_t xcb_atom_end

(

xcb_atom_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_atom_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_atom_next

(

xcb_atom_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_atom_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_atom_t)

xcb_void_cookie_t xcb_bell

(

xcb_connection_t * 

c,

int8_t 

percent 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_BELL.

xcb_void_cookie_t xcb_bell_checked

(

xcb_connection_t * 

c,

int8_t 

percent 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_BELL.

xcb_generic_iterator_t xcb_bool32_end

(

xcb_bool32_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_bool32_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_bool32_next

(

xcb_bool32_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_bool32_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_bool32_t)

xcb_generic_iterator_t xcb_button_end

(

xcb_button_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_button_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_button_next

(

xcb_button_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_button_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_button_t)

xcb_void_cookie_t xcb_change_active_pointer_grab

(

xcb_connection_t * 

c,

xcb_cursor_t 

cursor,

xcb_timestamp_t 

time,

uint16_t 

event_mask 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_CHANGE_ACTIVE_POINTER_GRAB.

xcb_void_cookie_t xcb_change_active_pointer_grab_checked

(

xcb_connection_t * 

c,

xcb_cursor_t 

cursor,

xcb_timestamp_t 

time,

uint16_t 

event_mask 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_ACTIVE_POINTER_GRAB.

xcb_void_cookie_t xcb_change_gc

(

xcb_connection_t * 

c,

xcb_gcontext_t 

gc,

uint32_t 

value_mask,

const void * 

value_list 

)

change graphics context components

Parameters

cThe connection

gcThe graphics context to change.

value_maskA bitmask of xcb_gc_t values.

value_mask

value_listValues for each of the components specified in the bitmask value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Changes the components specified by value_mask for the specified graphics context.

References XCB_CHANGE_GC.

xcb_void_cookie_t xcb_change_gc_aux

(

xcb_connection_t * 

c,

xcb_gcontext_t 

gc,

uint32_t 

value_mask,

const xcb_change_gc_value_list_t * 

value_list 

)

change graphics context components

Parameters

cThe connection

gcThe graphics context to change.

value_maskA bitmask of xcb_gc_t values.

value_mask

value_listValues for each of the components specified in the bitmask value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Changes the components specified by value_mask for the specified graphics context.

References XCB_CHANGE_GC.

xcb_void_cookie_t xcb_change_gc_aux_checked

(

xcb_connection_t * 

c,

xcb_gcontext_t 

gc,

uint32_t 

value_mask,

const xcb_change_gc_value_list_t * 

value_list 

)

change graphics context components

Parameters

cThe connection

gcThe graphics context to change.

value_maskA bitmask of xcb_gc_t values.

value_mask

value_listValues for each of the components specified in the bitmask value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Changes the components specified by value_mask for the specified graphics context.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_GC.

xcb_void_cookie_t xcb_change_gc_checked

(

xcb_connection_t * 

c,

xcb_gcontext_t 

gc,

uint32_t 

value_mask,

const void * 

value_list 

)

change graphics context components

Parameters

cThe connection

gcThe graphics context to change.

value_maskA bitmask of xcb_gc_t values.

value_mask

value_listValues for each of the components specified in the bitmask value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Changes the components specified by value_mask for the specified graphics context.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_GC.

xcb_void_cookie_t xcb_change_hosts

(

xcb_connection_t * 

c,

uint8_t 

mode,

uint8_t 

family,

uint16_t 

address_len,

const uint8_t * 

address 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_CHANGE_HOSTS.

xcb_void_cookie_t xcb_change_hosts_checked

(

xcb_connection_t * 

c,

uint8_t 

mode,

uint8_t 

family,

uint16_t 

address_len,

const uint8_t * 

address 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_HOSTS.

xcb_void_cookie_t xcb_change_keyboard_control

(

xcb_connection_t * 

c,

uint32_t 

value_mask,

const void * 

value_list 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_CHANGE_KEYBOARD_CONTROL.

xcb_void_cookie_t xcb_change_keyboard_control_aux

(

xcb_connection_t * 

c,

uint32_t 

value_mask,

const xcb_change_keyboard_control_value_list_t * 

value_list 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_CHANGE_KEYBOARD_CONTROL.

xcb_void_cookie_t xcb_change_keyboard_control_aux_checked

(

xcb_connection_t * 

c,

uint32_t 

value_mask,

const xcb_change_keyboard_control_value_list_t * 

value_list 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_KEYBOARD_CONTROL.

xcb_void_cookie_t xcb_change_keyboard_control_checked

(

xcb_connection_t * 

c,

uint32_t 

value_mask,

const void * 

value_list 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_KEYBOARD_CONTROL.

xcb_void_cookie_t xcb_change_keyboard_mapping

(

xcb_connection_t * 

c,

uint8_t 

keycode_count,

xcb_keycode_t 

first_keycode,

uint8_t 

keysyms_per_keycode,

const xcb_keysym_t * 

keysyms 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_CHANGE_KEYBOARD_MAPPING.

xcb_void_cookie_t xcb_change_keyboard_mapping_checked

(

xcb_connection_t * 

c,

uint8_t 

keycode_count,

xcb_keycode_t 

first_keycode,

uint8_t 

keysyms_per_keycode,

const xcb_keysym_t * 

keysyms 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_KEYBOARD_MAPPING.

xcb_void_cookie_t xcb_change_pointer_control

(

xcb_connection_t * 

c,

int16_t 

acceleration_numerator,

int16_t 

acceleration_denominator,

int16_t 

threshold,

uint8_t 

do_acceleration,

uint8_t 

do_threshold 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_CHANGE_POINTER_CONTROL.

xcb_void_cookie_t xcb_change_pointer_control_checked

(

xcb_connection_t * 

c,

int16_t 

acceleration_numerator,

int16_t 

acceleration_denominator,

int16_t 

threshold,

uint8_t 

do_acceleration,

uint8_t 

do_threshold 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_POINTER_CONTROL.

xcb_void_cookie_t xcb_change_property

(

xcb_connection_t * 

c,

uint8_t 

mode,

xcb_window_t 

window,

xcb_atom_t 

property,

xcb_atom_t 

type,

uint8_t 

format,

uint32_t 

data_len,

const void * 

data 

)

Changes a window property.

Parameters

cThe connection

modeA bitmask of xcb_prop_mode_t values.

mode

windowThe window whose property you want to change.

propertyThe property you want to change (an atom).

typeThe type of the property you want to change (an atom).

formatSpecifies whether the data should be viewed as a list of 8-bit, 16-bit or 32-bit quantities. Possible values are 8, 16 and 32. This information allows the X server to correctly perform byte-swap operations as necessary.

data_lenSpecifies the number of elements (see format).

dataThe property data.

ReturnsA cookie

Sets or updates a property on the specified window. Properties are for example the window title (WM_NAME) or its minimum size (WM_NORMAL_HINTS). Protocols such as EWMH also use properties - for example EWMH defines the window title, encoded as UTF-8 string, in the _NET_WM_NAME property.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_CHANGE_PROPERTY.

xcb_void_cookie_t xcb_change_property_checked

(

xcb_connection_t * 

c,

uint8_t 

mode,

xcb_window_t 

window,

xcb_atom_t 

property,

xcb_atom_t 

type,

uint8_t 

format,

uint32_t 

data_len,

const void * 

data 

)

Changes a window property.

Parameters

cThe connection

modeA bitmask of xcb_prop_mode_t values.

mode

windowThe window whose property you want to change.

propertyThe property you want to change (an atom).

typeThe type of the property you want to change (an atom).

formatSpecifies whether the data should be viewed as a list of 8-bit, 16-bit or 32-bit quantities. Possible values are 8, 16 and 32. This information allows the X server to correctly perform byte-swap operations as necessary.

data_lenSpecifies the number of elements (see format).

dataThe property data.

ReturnsA cookie

Sets or updates a property on the specified window. Properties are for example the window title (WM_NAME) or its minimum size (WM_NORMAL_HINTS). Protocols such as EWMH also use properties - for example EWMH defines the window title, encoded as UTF-8 string, in the _NET_WM_NAME property.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_PROPERTY.

xcb_void_cookie_t xcb_change_save_set

(

xcb_connection_t * 

c,

uint8_t 

mode,

xcb_window_t 

window 

)

Changes a client's save set.

Parameters

cThe connection

modeA bitmask of #xcb_set_mode_t values.

modeInsert to add the specified window to the save set or Delete to delete it from the save set.

windowThe window to add or delete to/from your save set.

ReturnsA cookie

TODO: explain what the save set is for.

This function either adds or removes the specified window to the client's (your application's) save set.

References XCB_CHANGE_SAVE_SET.

xcb_void_cookie_t xcb_change_save_set_checked

(

xcb_connection_t * 

c,

uint8_t 

mode,

xcb_window_t 

window 

)

Changes a client's save set.

Parameters

cThe connection

modeA bitmask of #xcb_set_mode_t values.

modeInsert to add the specified window to the save set or Delete to delete it from the save set.

windowThe window to add or delete to/from your save set.

ReturnsA cookie

TODO: explain what the save set is for.

This function either adds or removes the specified window to the client's (your application's) save set.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_SAVE_SET.

xcb_void_cookie_t xcb_change_window_attributes

(

xcb_connection_t * 

c,

xcb_window_t 

window,

uint32_t 

value_mask,

const void * 

value_list 

)

change window attributes

Parameters

cThe connection

windowThe window to change.

value_maskA bitmask of xcb_cw_t values.

value_mask

value_listValues for each of the attributes specified in the bitmask value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Changes the attributes specified by value_mask for the specified window.

References XCB_CHANGE_WINDOW_ATTRIBUTES.

xcb_void_cookie_t xcb_change_window_attributes_aux

(

xcb_connection_t * 

c,

xcb_window_t 

window,

uint32_t 

value_mask,

const xcb_change_window_attributes_value_list_t * 

value_list 

)

change window attributes

Parameters

cThe connection

windowThe window to change.

value_maskA bitmask of xcb_cw_t values.

value_mask

value_listValues for each of the attributes specified in the bitmask value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Changes the attributes specified by value_mask for the specified window.

References XCB_CHANGE_WINDOW_ATTRIBUTES.

xcb_void_cookie_t xcb_change_window_attributes_aux_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window,

uint32_t 

value_mask,

const xcb_change_window_attributes_value_list_t * 

value_list 

)

change window attributes

Parameters

cThe connection

windowThe window to change.

value_maskA bitmask of xcb_cw_t values.

value_mask

value_listValues for each of the attributes specified in the bitmask value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Changes the attributes specified by value_mask for the specified window.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_WINDOW_ATTRIBUTES.

xcb_void_cookie_t xcb_change_window_attributes_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window,

uint32_t 

value_mask,

const void * 

value_list 

)

change window attributes

Parameters

cThe connection

windowThe window to change.

value_maskA bitmask of xcb_cw_t values.

value_mask

value_listValues for each of the attributes specified in the bitmask value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Changes the attributes specified by value_mask for the specified window.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CHANGE_WINDOW_ATTRIBUTES.

xcb_generic_iterator_t xcb_char2b_end

(

xcb_char2b_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_char2b_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_char2b_next

(

xcb_char2b_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_char2b_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_char2b_t)

xcb_generic_iterator_t xcb_charinfo_end

(

xcb_charinfo_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_charinfo_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_charinfo_next

(

xcb_charinfo_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_charinfo_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_charinfo_t)

xcb_void_cookie_t xcb_circulate_window

(

xcb_connection_t * 

c,

uint8_t 

direction,

xcb_window_t 

window 

)

Change window stacking order.

Parameters

cThe connection

directionA bitmask of #xcb_circulate_t values.

direction

windowThe window to raise/lower (depending on direction).

ReturnsA cookie

If direction is XCB_CIRCULATE_RAISE_LOWEST, the lowest mapped child (if any) will be raised to the top of the stack.

If direction is XCB_CIRCULATE_LOWER_HIGHEST, the highest mapped child will be lowered to the bottom of the stack.

References XCB_CIRCULATE_WINDOW.

xcb_void_cookie_t xcb_circulate_window_checked

(

xcb_connection_t * 

c,

uint8_t 

direction,

xcb_window_t 

window 

)

Change window stacking order.

Parameters

cThe connection

directionA bitmask of #xcb_circulate_t values.

direction

windowThe window to raise/lower (depending on direction).

ReturnsA cookie

If direction is XCB_CIRCULATE_RAISE_LOWEST, the lowest mapped child (if any) will be raised to the top of the stack.

If direction is XCB_CIRCULATE_LOWER_HIGHEST, the highest mapped child will be lowered to the bottom of the stack.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CIRCULATE_WINDOW.

xcb_void_cookie_t xcb_clear_area

(

xcb_connection_t * 

c,

uint8_t 

exposures,

xcb_window_t 

window,

int16_t 

x,

int16_t 

y,

uint16_t 

width,

uint16_t 

height 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_CLEAR_AREA.

xcb_void_cookie_t xcb_clear_area_checked

(

xcb_connection_t * 

c,

uint8_t 

exposures,

xcb_window_t 

window,

int16_t 

x,

int16_t 

y,

uint16_t 

width,

uint16_t 

height 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CLEAR_AREA.

xcb_generic_iterator_t xcb_client_message_data_end

(

xcb_client_message_data_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_client_message_data_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, XCB_CW_BACK_PIXEL, XCB_CW_BACK_PIXMAP, XCB_CW_BACKING_PIXEL, XCB_CW_BACKING_PLANES, XCB_CW_BACKING_STORE, XCB_CW_BIT_GRAVITY, XCB_CW_BORDER_PIXEL, XCB_CW_BORDER_PIXMAP, XCB_CW_COLORMAP, XCB_CW_CURSOR, XCB_CW_DONT_PROPAGATE, XCB_CW_EVENT_MASK, XCB_CW_OVERRIDE_REDIRECT, XCB_CW_SAVE_UNDER, and XCB_CW_WIN_GRAVITY.

void xcb_client_message_data_next

(

xcb_client_message_data_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_client_message_data_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_client_message_data_t)

xcb_void_cookie_t xcb_close_font

(

xcb_connection_t * 

c,

xcb_font_t 

font 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_CLOSE_FONT.

xcb_void_cookie_t xcb_close_font_checked

(

xcb_connection_t * 

c,

xcb_font_t 

font 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CLOSE_FONT.

xcb_generic_iterator_t xcb_coloritem_end

(

xcb_coloritem_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_coloritem_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_coloritem_next

(

xcb_coloritem_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_coloritem_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_coloritem_t)

xcb_generic_iterator_t xcb_colormap_end

(

xcb_colormap_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_colormap_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_colormap_next

(

xcb_colormap_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_colormap_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_colormap_t)

xcb_void_cookie_t xcb_configure_window

(

xcb_connection_t * 

c,

xcb_window_t 

window,

uint16_t 

value_mask,

const void * 

value_list 

)

Configures window attributes.

Parameters

cThe connection

windowThe window to configure.

value_maskBitmask of attributes to change.

value_listNew values, corresponding to the attributes in value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Configures a window's size, position, border width and stacking order.

References XCB_CONFIGURE_WINDOW.

xcb_void_cookie_t xcb_configure_window_aux

(

xcb_connection_t * 

c,

xcb_window_t 

window,

uint16_t 

value_mask,

const xcb_configure_window_value_list_t * 

value_list 

)

Configures window attributes.

Parameters

cThe connection

windowThe window to configure.

value_maskBitmask of attributes to change.

value_listNew values, corresponding to the attributes in value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Configures a window's size, position, border width and stacking order.

References XCB_CONFIGURE_WINDOW.

xcb_void_cookie_t xcb_configure_window_aux_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window,

uint16_t 

value_mask,

const xcb_configure_window_value_list_t * 

value_list 

)

Configures window attributes.

Parameters

cThe connection

windowThe window to configure.

value_maskBitmask of attributes to change.

value_listNew values, corresponding to the attributes in value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Configures a window's size, position, border width and stacking order.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CONFIGURE_WINDOW.

xcb_void_cookie_t xcb_configure_window_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window,

uint16_t 

value_mask,

const void * 

value_list 

)

Configures window attributes.

Parameters

cThe connection

windowThe window to configure.

value_maskBitmask of attributes to change.

value_listNew values, corresponding to the attributes in value_mask. The order has to correspond to the order of possible value_mask bits. See the example.

ReturnsA cookie

Configures a window's size, position, border width and stacking order.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CONFIGURE_WINDOW.

xcb_void_cookie_t xcb_convert_selection

(

xcb_connection_t * 

c,

xcb_window_t 

requestor,

xcb_atom_t 

selection,

xcb_atom_t 

target,

xcb_atom_t 

property,

xcb_timestamp_t 

time 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_CONVERT_SELECTION.

xcb_void_cookie_t xcb_convert_selection_checked

(

xcb_connection_t * 

c,

xcb_window_t 

requestor,

xcb_atom_t 

selection,

xcb_atom_t 

target,

xcb_atom_t 

property,

xcb_timestamp_t 

time 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CONVERT_SELECTION.

xcb_void_cookie_t xcb_copy_area

(

xcb_connection_t * 

c,

xcb_drawable_t 

src_drawable,

xcb_drawable_t 

dst_drawable,

xcb_gcontext_t 

gc,

int16_t 

src_x,

int16_t 

src_y,

int16_t 

dst_x,

int16_t 

dst_y,

uint16_t 

width,

uint16_t 

height 

)

copy areas

Parameters

cThe connection

src_drawableThe source drawable (Window or Pixmap).

dst_drawableThe destination drawable (Window or Pixmap).

gcThe graphics context to use.

src_xThe source X coordinate.

src_yThe source Y coordinate.

dst_xThe destination X coordinate.

dst_yThe destination Y coordinate.

widthThe width of the area to copy (in pixels).

heightThe height of the area to copy (in pixels).

ReturnsA cookie

Copies the specified rectangle from src_drawable to dst_drawable.

References XCB_COPY_AREA.

xcb_void_cookie_t xcb_copy_area_checked

(

xcb_connection_t * 

c,

xcb_drawable_t 

src_drawable,

xcb_drawable_t 

dst_drawable,

xcb_gcontext_t 

gc,

int16_t 

src_x,

int16_t 

src_y,

int16_t 

dst_x,

int16_t 

dst_y,

uint16_t 

width,

uint16_t 

height 

)

copy areas

Parameters

cThe connection

src_drawableThe source drawable (Window or Pixmap).

dst_drawableThe destination drawable (Window or Pixmap).

gcThe graphics context to use.

src_xThe source X coordinate.

src_yThe source Y coordinate.

dst_xThe destination X coordinate.

dst_yThe destination Y coordinate.

widthThe width of the area to copy (in pixels).

heightThe height of the area to copy (in pixels).

ReturnsA cookie

Copies the specified rectangle from src_drawable to dst_drawable.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_COPY_AREA.

xcb_void_cookie_t xcb_copy_colormap_and_free

(

xcb_connection_t * 

c,

xcb_colormap_t 

mid,

xcb_colormap_t 

src_cmap 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_COPY_COLORMAP_AND_FREE.

xcb_void_cookie_t xcb_copy_colormap_and_free_checked

(

xcb_connection_t * 

c,

xcb_colormap_t 

mid,

xcb_colormap_t 

src_cmap 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_COPY_COLORMAP_AND_FREE.

xcb_void_cookie_t xcb_copy_gc

(

xcb_connection_t * 

c,

xcb_gcontext_t 

src_gc,

xcb_gcontext_t 

dst_gc,

uint32_t 

value_mask 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_COPY_GC.

xcb_void_cookie_t xcb_copy_gc_checked

(

xcb_connection_t * 

c,

xcb_gcontext_t 

src_gc,

xcb_gcontext_t 

dst_gc,

uint32_t 

value_mask 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_COPY_GC.

xcb_void_cookie_t xcb_copy_plane

(

xcb_connection_t * 

c,

xcb_drawable_t 

src_drawable,

xcb_drawable_t 

dst_drawable,

xcb_gcontext_t 

gc,

int16_t 

src_x,

int16_t 

src_y,

int16_t 

dst_x,

int16_t 

dst_y,

uint16_t 

width,

uint16_t 

height,

uint32_t 

bit_plane 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_COPY_PLANE.

xcb_void_cookie_t xcb_copy_plane_checked

(

xcb_connection_t * 

c,

xcb_drawable_t 

src_drawable,

xcb_drawable_t 

dst_drawable,

xcb_gcontext_t 

gc,

int16_t 

src_x,

int16_t 

src_y,

int16_t 

dst_x,

int16_t 

dst_y,

uint16_t 

width,

uint16_t 

height,

uint32_t 

bit_plane 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_COPY_PLANE.

xcb_void_cookie_t xcb_create_colormap

(

xcb_connection_t * 

c,

uint8_t 

alloc,

xcb_colormap_t 

mid,

xcb_window_t 

window,

xcb_visualid_t 

visual 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_CREATE_COLORMAP.

xcb_void_cookie_t xcb_create_colormap_checked

(

xcb_connection_t * 

c,

uint8_t 

alloc,

xcb_colormap_t 

mid,

xcb_window_t 

window,

xcb_visualid_t 

visual 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CREATE_COLORMAP.

xcb_void_cookie_t xcb_create_cursor

(

xcb_connection_t * 

c,

xcb_cursor_t 

cid,

xcb_pixmap_t 

source,

xcb_pixmap_t 

mask,

uint16_t 

fore_red,

uint16_t 

fore_green,

uint16_t 

fore_blue,

uint16_t 

back_red,

uint16_t 

back_green,

uint16_t 

back_blue,

uint16_t 

x,

uint16_t 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_CREATE_CURSOR.

xcb_void_cookie_t xcb_create_cursor_checked

(

xcb_connection_t * 

c,

xcb_cursor_t 

cid,

xcb_pixmap_t 

source,

xcb_pixmap_t 

mask,

uint16_t 

fore_red,

uint16_t 

fore_green,

uint16_t 

fore_blue,

uint16_t 

back_red,

uint16_t 

back_green,

uint16_t 

back_blue,

uint16_t 

x,

uint16_t 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CREATE_CURSOR.

xcb_void_cookie_t xcb_create_gc

(

xcb_connection_t * 

c,

xcb_gcontext_t 

cid,

xcb_drawable_t 

drawable,

uint32_t 

value_mask,

const void * 

value_list 

)

Creates a graphics context.

Parameters

cThe connection

cidThe ID with which you will refer to the graphics context, created by xcb_generate_id.

drawableDrawable to get the root/depth from.

ReturnsA cookie

Creates a graphics context. The graphics context can be used with any drawable that has the same root and depth as the specified drawable.

References XCB_CREATE_GC.

xcb_void_cookie_t xcb_create_gc_aux

(

xcb_connection_t * 

c,

xcb_gcontext_t 

cid,

xcb_drawable_t 

drawable,

uint32_t 

value_mask,

const xcb_create_gc_value_list_t * 

value_list 

)

Creates a graphics context.

Parameters

cThe connection

cidThe ID with which you will refer to the graphics context, created by xcb_generate_id.

drawableDrawable to get the root/depth from.

ReturnsA cookie

Creates a graphics context. The graphics context can be used with any drawable that has the same root and depth as the specified drawable.

References XCB_CREATE_GC, XCB_GC_ARC_MODE, XCB_GC_BACKGROUND, XCB_GC_CAP_STYLE, XCB_GC_CLIP_MASK, XCB_GC_CLIP_ORIGIN_X, XCB_GC_CLIP_ORIGIN_Y, XCB_GC_DASH_LIST, XCB_GC_DASH_OFFSET, XCB_GC_FILL_STYLE, XCB_GC_FONT, XCB_GC_FOREGROUND, XCB_GC_FUNCTION, XCB_GC_GRAPHICS_EXPOSURES, XCB_GC_JOIN_STYLE, XCB_GC_LINE_STYLE, XCB_GC_LINE_WIDTH, XCB_GC_PLANE_MASK, XCB_GC_STIPPLE, XCB_GC_SUBWINDOW_MODE, XCB_GC_TILE, XCB_GC_TILE_STIPPLE_ORIGIN_X, and XCB_GC_TILE_STIPPLE_ORIGIN_Y.

xcb_void_cookie_t xcb_create_gc_aux_checked

(

xcb_connection_t * 

c,

xcb_gcontext_t 

cid,

xcb_drawable_t 

drawable,

uint32_t 

value_mask,

const xcb_create_gc_value_list_t * 

value_list 

)

Creates a graphics context.

Parameters

cThe connection

cidThe ID with which you will refer to the graphics context, created by xcb_generate_id.

drawableDrawable to get the root/depth from.

ReturnsA cookie

Creates a graphics context. The graphics context can be used with any drawable that has the same root and depth as the specified drawable.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CREATE_GC.

xcb_void_cookie_t xcb_create_gc_checked

(

xcb_connection_t * 

c,

xcb_gcontext_t 

cid,

xcb_drawable_t 

drawable,

uint32_t 

value_mask,

const void * 

value_list 

)

Creates a graphics context.

Parameters

cThe connection

cidThe ID with which you will refer to the graphics context, created by xcb_generate_id.

drawableDrawable to get the root/depth from.

ReturnsA cookie

Creates a graphics context. The graphics context can be used with any drawable that has the same root and depth as the specified drawable.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CREATE_GC.

xcb_void_cookie_t xcb_create_glyph_cursor

(

xcb_connection_t * 

c,

xcb_cursor_t 

cid,

xcb_font_t 

source_font,

xcb_font_t 

mask_font,

uint16_t 

source_char,

uint16_t 

mask_char,

uint16_t 

fore_red,

uint16_t 

fore_green,

uint16_t 

fore_blue,

uint16_t 

back_red,

uint16_t 

back_green,

uint16_t 

back_blue 

)

create cursor

Parameters

cThe connection

cidThe ID with which you will refer to the cursor, created by xcb_generate_id.

source_fontIn which font to look for the cursor glyph.

mask_fontIn which font to look for the mask glyph.

source_charThe glyph of source_font to use.

mask_charThe glyph of mask_font to use as a mask: Pixels which are set to 1 define which source pixels are displayed. All pixels which are set to 0 are not displayed.

fore_redThe red value of the foreground color.

fore_greenThe green value of the foreground color.

fore_blueThe blue value of the foreground color.

back_redThe red value of the background color.

back_greenThe green value of the background color.

back_blueThe blue value of the background color.

ReturnsA cookie

Creates a cursor from a font glyph. X provides a set of standard cursor shapes in a special font named cursor. Applications are encouraged to use this interface for their cursors because the font can be customized for the individual display type.

All pixels which are set to 1 in the source will use the foreground color (as specified by fore_red, fore_green and fore_blue). All pixels set to 0 will use the background color (as specified by back_red, back_green and back_blue).

References XCB_CREATE_GLYPH_CURSOR.

xcb_void_cookie_t xcb_create_glyph_cursor_checked

(

xcb_connection_t * 

c,

xcb_cursor_t 

cid,

xcb_font_t 

source_font,

xcb_font_t 

mask_font,

uint16_t 

source_char,

uint16_t 

mask_char,

uint16_t 

fore_red,

uint16_t 

fore_green,

uint16_t 

fore_blue,

uint16_t 

back_red,

uint16_t 

back_green,

uint16_t 

back_blue 

)

create cursor

Parameters

cThe connection

cidThe ID with which you will refer to the cursor, created by xcb_generate_id.

source_fontIn which font to look for the cursor glyph.

mask_fontIn which font to look for the mask glyph.

source_charThe glyph of source_font to use.

mask_charThe glyph of mask_font to use as a mask: Pixels which are set to 1 define which source pixels are displayed. All pixels which are set to 0 are not displayed.

fore_redThe red value of the foreground color.

fore_greenThe green value of the foreground color.

fore_blueThe blue value of the foreground color.

back_redThe red value of the background color.

back_greenThe green value of the background color.

back_blueThe blue value of the background color.

ReturnsA cookie

Creates a cursor from a font glyph. X provides a set of standard cursor shapes in a special font named cursor. Applications are encouraged to use this interface for their cursors because the font can be customized for the individual display type.

All pixels which are set to 1 in the source will use the foreground color (as specified by fore_red, fore_green and fore_blue). All pixels set to 0 will use the background color (as specified by back_red, back_green and back_blue).

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CREATE_GLYPH_CURSOR.

xcb_void_cookie_t xcb_create_pixmap

(

xcb_connection_t * 

c,

uint8_t 

depth,

xcb_pixmap_t 

pid,

xcb_drawable_t 

drawable,

uint16_t 

width,

uint16_t 

height 

)

Creates a pixmap.

Parameters

cThe connection

depthTODO

pidThe ID with which you will refer to the new pixmap, created by xcb_generate_id.

drawableDrawable to get the screen from.

widthThe width of the new pixmap.

heightThe height of the new pixmap.

ReturnsA cookie

Creates a pixmap. The pixmap can only be used on the same screen as drawable is on and only with drawables of the same depth.

References XCB_CREATE_PIXMAP.

xcb_void_cookie_t xcb_create_pixmap_checked

(

xcb_connection_t * 

c,

uint8_t 

depth,

xcb_pixmap_t 

pid,

xcb_drawable_t 

drawable,

uint16_t 

width,

uint16_t 

height 

)

Creates a pixmap.

Parameters

cThe connection

depthTODO

pidThe ID with which you will refer to the new pixmap, created by xcb_generate_id.

drawableDrawable to get the screen from.

widthThe width of the new pixmap.

heightThe height of the new pixmap.

ReturnsA cookie

Creates a pixmap. The pixmap can only be used on the same screen as drawable is on and only with drawables of the same depth.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CREATE_PIXMAP.

xcb_void_cookie_t xcb_create_window

(

xcb_connection_t * 

c,

uint8_t 

depth,

xcb_window_t 

wid,

xcb_window_t 

parent,

int16_t 

x,

int16_t 

y,

uint16_t 

width,

uint16_t 

height,

uint16_t 

border_width,

uint16_t 

_class,

xcb_visualid_t 

visual,

uint32_t 

value_mask,

const void * 

value_list 

)

Creates a window.

Parameters

cThe connection

depthSpecifies the new window's depth (TODO: what unit?).

The special value XCB_COPY_FROM_PARENT means the depth is taken from the parent window.

widThe ID with which you will refer to the new window, created by xcb_generate_id.

parentThe parent window of the new window.

xThe X coordinate of the new window.

yThe Y coordinate of the new window.

widthThe width of the new window.

heightThe height of the new window.

border_widthTODO:

Must be zero if the class is InputOnly or a xcb_match_error_t occurs.

_classA bitmask of #xcb_window_class_t values.

_class

visualSpecifies the id for the new window's visual.

The special value XCB_COPY_FROM_PARENT means the visual is taken from the parent window.

value_maskA bitmask of xcb_cw_t values.

ReturnsA cookie

Creates an unmapped window as child of the specified parent window. A CreateNotify event will be generated. The new window is placed on top in the stacking order with respect to siblings.

The coordinate system has the X axis horizontal and the Y axis vertical with the origin [0, 0] at the upper-left corner. Coordinates are integral, in terms of pixels, and coincide with pixel centers. Each window and pixmap has its own coordinate system. For a window, the origin is inside the border at the inside, upper-left corner.

The created window is not yet displayed (mapped), call xcb_map_window to display it.

The created window will initially use the same cursor as its parent.

References XCB_CREATE_WINDOW.

xcb_void_cookie_t xcb_create_window_aux

(

xcb_connection_t * 

c,

uint8_t 

depth,

xcb_window_t 

wid,

xcb_window_t 

parent,

int16_t 

x,

int16_t 

y,

uint16_t 

width,

uint16_t 

height,

uint16_t 

border_width,

uint16_t 

_class,

xcb_visualid_t 

visual,

uint32_t 

value_mask,

const xcb_create_window_value_list_t * 

value_list 

)

Creates a window.

Parameters

cThe connection

depthSpecifies the new window's depth (TODO: what unit?).

The special value XCB_COPY_FROM_PARENT means the depth is taken from the parent window.

widThe ID with which you will refer to the new window, created by xcb_generate_id.

parentThe parent window of the new window.

xThe X coordinate of the new window.

yThe Y coordinate of the new window.

widthThe width of the new window.

heightThe height of the new window.

border_widthTODO:

Must be zero if the class is InputOnly or a xcb_match_error_t occurs.

_classA bitmask of #xcb_window_class_t values.

_class

visualSpecifies the id for the new window's visual.

The special value XCB_COPY_FROM_PARENT means the visual is taken from the parent window.

value_maskA bitmask of xcb_cw_t values.

ReturnsA cookie

Creates an unmapped window as child of the specified parent window. A CreateNotify event will be generated. The new window is placed on top in the stacking order with respect to siblings.

The coordinate system has the X axis horizontal and the Y axis vertical with the origin [0, 0] at the upper-left corner. Coordinates are integral, in terms of pixels, and coincide with pixel centers. Each window and pixmap has its own coordinate system. For a window, the origin is inside the border at the inside, upper-left corner.

The created window is not yet displayed (mapped), call xcb_map_window to display it.

The created window will initially use the same cursor as its parent.

References XCB_CREATE_WINDOW, XCB_CW_BACK_PIXEL, XCB_CW_BACK_PIXMAP, XCB_CW_BACKING_PIXEL, XCB_CW_BACKING_PLANES, XCB_CW_BACKING_STORE, XCB_CW_BIT_GRAVITY, XCB_CW_BORDER_PIXEL, XCB_CW_BORDER_PIXMAP, XCB_CW_COLORMAP, XCB_CW_CURSOR, XCB_CW_DONT_PROPAGATE, XCB_CW_EVENT_MASK, XCB_CW_OVERRIDE_REDIRECT, XCB_CW_SAVE_UNDER, and XCB_CW_WIN_GRAVITY.

xcb_void_cookie_t xcb_create_window_aux_checked

(

xcb_connection_t * 

c,

uint8_t 

depth,

xcb_window_t 

wid,

xcb_window_t 

parent,

int16_t 

x,

int16_t 

y,

uint16_t 

width,

uint16_t 

height,

uint16_t 

border_width,

uint16_t 

_class,

xcb_visualid_t 

visual,

uint32_t 

value_mask,

const xcb_create_window_value_list_t * 

value_list 

)

Creates a window.

Parameters

cThe connection

depthSpecifies the new window's depth (TODO: what unit?).

The special value XCB_COPY_FROM_PARENT means the depth is taken from the parent window.

widThe ID with which you will refer to the new window, created by xcb_generate_id.

parentThe parent window of the new window.

xThe X coordinate of the new window.

yThe Y coordinate of the new window.

widthThe width of the new window.

heightThe height of the new window.

border_widthTODO:

Must be zero if the class is InputOnly or a xcb_match_error_t occurs.

_classA bitmask of #xcb_window_class_t values.

_class

visualSpecifies the id for the new window's visual.

The special value XCB_COPY_FROM_PARENT means the visual is taken from the parent window.

value_maskA bitmask of xcb_cw_t values.

ReturnsA cookie

Creates an unmapped window as child of the specified parent window. A CreateNotify event will be generated. The new window is placed on top in the stacking order with respect to siblings.

The coordinate system has the X axis horizontal and the Y axis vertical with the origin [0, 0] at the upper-left corner. Coordinates are integral, in terms of pixels, and coincide with pixel centers. Each window and pixmap has its own coordinate system. For a window, the origin is inside the border at the inside, upper-left corner.

The created window is not yet displayed (mapped), call xcb_map_window to display it.

The created window will initially use the same cursor as its parent.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CREATE_WINDOW.

xcb_void_cookie_t xcb_create_window_checked

(

xcb_connection_t * 

c,

uint8_t 

depth,

xcb_window_t 

wid,

xcb_window_t 

parent,

int16_t 

x,

int16_t 

y,

uint16_t 

width,

uint16_t 

height,

uint16_t 

border_width,

uint16_t 

_class,

xcb_visualid_t 

visual,

uint32_t 

value_mask,

const void * 

value_list 

)

Creates a window.

Parameters

cThe connection

depthSpecifies the new window's depth (TODO: what unit?).

The special value XCB_COPY_FROM_PARENT means the depth is taken from the parent window.

widThe ID with which you will refer to the new window, created by xcb_generate_id.

parentThe parent window of the new window.

xThe X coordinate of the new window.

yThe Y coordinate of the new window.

widthThe width of the new window.

heightThe height of the new window.

border_widthTODO:

Must be zero if the class is InputOnly or a xcb_match_error_t occurs.

_classA bitmask of #xcb_window_class_t values.

_class

visualSpecifies the id for the new window's visual.

The special value XCB_COPY_FROM_PARENT means the visual is taken from the parent window.

value_maskA bitmask of xcb_cw_t values.

ReturnsA cookie

Creates an unmapped window as child of the specified parent window. A CreateNotify event will be generated. The new window is placed on top in the stacking order with respect to siblings.

The coordinate system has the X axis horizontal and the Y axis vertical with the origin [0, 0] at the upper-left corner. Coordinates are integral, in terms of pixels, and coincide with pixel centers. Each window and pixmap has its own coordinate system. For a window, the origin is inside the border at the inside, upper-left corner.

The created window is not yet displayed (mapped), call xcb_map_window to display it.

The created window will initially use the same cursor as its parent.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_CREATE_WINDOW.

xcb_generic_iterator_t xcb_cursor_end

(

xcb_cursor_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_cursor_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_cursor_next

(

xcb_cursor_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_cursor_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_cursor_t)

xcb_void_cookie_t xcb_delete_property

(

xcb_connection_t * 

c,

xcb_window_t 

window,

xcb_atom_t 

property 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_DELETE_PROPERTY.

xcb_void_cookie_t xcb_delete_property_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window,

xcb_atom_t 

property 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_DELETE_PROPERTY.

xcb_generic_iterator_t xcb_depth_end

(

xcb_depth_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_depth_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and xcb_depth_next().

void xcb_depth_next

(

xcb_depth_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_depth_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_depth_t)

References xcb_generic_iterator_t::data.

Referenced by xcb_depth_end().

xcb_void_cookie_t xcb_destroy_subwindows

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_DESTROY_SUBWINDOWS.

xcb_void_cookie_t xcb_destroy_subwindows_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_DESTROY_SUBWINDOWS.

xcb_void_cookie_t xcb_destroy_window

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Destroys a window.

Parameters

cThe connection

windowThe window to destroy.

ReturnsA cookie

Destroys the specified window and all of its subwindows. A DestroyNotify event is generated for each destroyed window (a DestroyNotify event is first generated for any given window's inferiors). If the window was mapped, it will be automatically unmapped before destroying.

Calling DestroyWindow on the root window will do nothing.

References XCB_DESTROY_WINDOW.

xcb_void_cookie_t xcb_destroy_window_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Destroys a window.

Parameters

cThe connection

windowThe window to destroy.

ReturnsA cookie

Destroys the specified window and all of its subwindows. A DestroyNotify event is generated for each destroyed window (a DestroyNotify event is first generated for any given window's inferiors). If the window was mapped, it will be automatically unmapped before destroying.

Calling DestroyWindow on the root window will do nothing.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_DESTROY_WINDOW.

xcb_generic_iterator_t xcb_drawable_end

(

xcb_drawable_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_drawable_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_drawable_next

(

xcb_drawable_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_drawable_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_drawable_t)

xcb_void_cookie_t xcb_fill_poly

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint8_t 

shape,

uint8_t 

coordinate_mode,

uint32_t 

points_len,

const xcb_point_t * 

points 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_FILL_POLY.

xcb_void_cookie_t xcb_fill_poly_checked

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint8_t 

shape,

uint8_t 

coordinate_mode,

uint32_t 

points_len,

const xcb_point_t * 

points 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_FILL_POLY.

xcb_generic_iterator_t xcb_font_end

(

xcb_font_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_font_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_font_next

(

xcb_font_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_font_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_font_t)

xcb_generic_iterator_t xcb_fontable_end

(

xcb_fontable_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_fontable_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_fontable_next

(

xcb_fontable_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_fontable_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_fontable_t)

xcb_generic_iterator_t xcb_fontprop_end

(

xcb_fontprop_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_fontprop_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

Referenced by xcb_list_fonts_with_info_unchecked(), and xcb_query_font_unchecked().

void xcb_fontprop_next

(

xcb_fontprop_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_fontprop_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_fontprop_t)

xcb_void_cookie_t xcb_force_screen_saver

(

xcb_connection_t * 

c,

uint8_t 

mode 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_FORCE_SCREEN_SAVER.

xcb_void_cookie_t xcb_force_screen_saver_checked

(

xcb_connection_t * 

c,

uint8_t 

mode 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_FORCE_SCREEN_SAVER.

xcb_generic_iterator_t xcb_format_end

(

xcb_format_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_format_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

Referenced by xcb_setup_authenticate_end().

void xcb_format_next

(

xcb_format_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_format_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_format_t)

xcb_void_cookie_t xcb_free_colormap

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_FREE_COLORMAP.

xcb_void_cookie_t xcb_free_colormap_checked

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_FREE_COLORMAP.

xcb_void_cookie_t xcb_free_colors

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint32_t 

plane_mask,

uint32_t 

pixels_len,

const uint32_t * 

pixels 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_FREE_COLORS.

xcb_void_cookie_t xcb_free_colors_checked

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint32_t 

plane_mask,

uint32_t 

pixels_len,

const uint32_t * 

pixels 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_FREE_COLORS.

xcb_void_cookie_t xcb_free_cursor

(

xcb_connection_t * 

c,

xcb_cursor_t 

cursor 

)

Deletes a cursor.

Parameters

cThe connection

cursorThe cursor to destroy.

ReturnsA cookie

Deletes the association between the cursor resource ID and the specified cursor. The cursor is freed when no other resource references it.

References XCB_FREE_CURSOR.

xcb_void_cookie_t xcb_free_cursor_checked

(

xcb_connection_t * 

c,

xcb_cursor_t 

cursor 

)

Deletes a cursor.

Parameters

cThe connection

cursorThe cursor to destroy.

ReturnsA cookie

Deletes the association between the cursor resource ID and the specified cursor. The cursor is freed when no other resource references it.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_FREE_CURSOR.

xcb_void_cookie_t xcb_free_gc

(

xcb_connection_t * 

c,

xcb_gcontext_t 

gc 

)

Destroys a graphics context.

Parameters

cThe connection

gcThe graphics context to destroy.

ReturnsA cookie

Destroys the specified gc and all associated storage.

References XCB_FREE_GC.

xcb_void_cookie_t xcb_free_gc_checked

(

xcb_connection_t * 

c,

xcb_gcontext_t 

gc 

)

Destroys a graphics context.

Parameters

cThe connection

gcThe graphics context to destroy.

ReturnsA cookie

Destroys the specified gc and all associated storage.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_FREE_GC.

xcb_void_cookie_t xcb_free_pixmap

(

xcb_connection_t * 

c,

xcb_pixmap_t 

pixmap 

)

Destroys a pixmap.

Parameters

cThe connection

pixmapThe pixmap to destroy.

ReturnsA cookie

Deletes the association between the pixmap ID and the pixmap. The pixmap storage will be freed when there are no more references to it.

References XCB_FREE_PIXMAP, XCB_GC_ARC_MODE, XCB_GC_BACKGROUND, XCB_GC_CAP_STYLE, XCB_GC_CLIP_MASK, XCB_GC_CLIP_ORIGIN_X, XCB_GC_CLIP_ORIGIN_Y, XCB_GC_DASH_LIST, XCB_GC_DASH_OFFSET, XCB_GC_FILL_STYLE, XCB_GC_FONT, XCB_GC_FOREGROUND, XCB_GC_FUNCTION, XCB_GC_GRAPHICS_EXPOSURES, XCB_GC_JOIN_STYLE, XCB_GC_LINE_STYLE, XCB_GC_LINE_WIDTH, XCB_GC_PLANE_MASK, XCB_GC_STIPPLE, XCB_GC_SUBWINDOW_MODE, XCB_GC_TILE, XCB_GC_TILE_STIPPLE_ORIGIN_X, and XCB_GC_TILE_STIPPLE_ORIGIN_Y.

xcb_void_cookie_t xcb_free_pixmap_checked

(

xcb_connection_t * 

c,

xcb_pixmap_t 

pixmap 

)

Destroys a pixmap.

Parameters

cThe connection

pixmapThe pixmap to destroy.

ReturnsA cookie

Deletes the association between the pixmap ID and the pixmap. The pixmap storage will be freed when there are no more references to it.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_FREE_PIXMAP.

xcb_generic_iterator_t xcb_gcontext_end

(

xcb_gcontext_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_gcontext_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_gcontext_next

(

xcb_gcontext_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_gcontext_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_gcontext_t)

xcb_get_atom_name_cookie_t xcb_get_atom_name

(

xcb_connection_t * 

c,

xcb_atom_t 

atom 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_ATOM_NAME.

xcb_get_atom_name_reply_t* xcb_get_atom_name_reply

(

xcb_connection_t * 

c,

xcb_get_atom_name_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_atom_name_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_atom_name_cookie_t xcb_get_atom_name_unchecked

(

xcb_connection_t * 

c,

xcb_atom_t 

atom 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_GET_ATOM_NAME.

xcb_get_font_path_cookie_t xcb_get_font_path

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_FONT_PATH.

xcb_get_font_path_reply_t* xcb_get_font_path_reply

(

xcb_connection_t * 

c,

xcb_get_font_path_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_font_path_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_font_path_cookie_t xcb_get_font_path_unchecked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GET_FONT_PATH.

xcb_get_geometry_cookie_t xcb_get_geometry

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable 

)

Get current window geometry.

Parameters

cThe connection

drawableThe drawable (Window or Pixmap) of which the geometry will be received.

ReturnsA cookie

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

References XCB_GET_GEOMETRY.

xcb_get_geometry_reply_t* xcb_get_geometry_reply

(

xcb_connection_t * 

c,

xcb_get_geometry_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_geometry_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_geometry_cookie_t xcb_get_geometry_unchecked

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable 

)

Get current window geometry.

Parameters

cThe connection

drawableThe drawable (Window or Pixmap) of which the geometry will be received.

ReturnsA cookie

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

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GET_GEOMETRY.

xcb_get_image_cookie_t xcb_get_image

(

xcb_connection_t * 

c,

uint8_t 

format,

xcb_drawable_t 

drawable,

int16_t 

x,

int16_t 

y,

uint16_t 

width,

uint16_t 

height,

uint32_t 

plane_mask 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_IMAGE.

xcb_get_image_reply_t* xcb_get_image_reply

(

xcb_connection_t * 

c,

xcb_get_image_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_image_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_image_cookie_t xcb_get_image_unchecked

(

xcb_connection_t * 

c,

uint8_t 

format,

xcb_drawable_t 

drawable,

int16_t 

x,

int16_t 

y,

uint16_t 

width,

uint16_t 

height,

uint32_t 

plane_mask 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_GET_IMAGE.

xcb_get_input_focus_cookie_t xcb_get_input_focus

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_INPUT_FOCUS.

xcb_get_input_focus_reply_t* xcb_get_input_focus_reply

(

xcb_connection_t * 

c,

xcb_get_input_focus_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_input_focus_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_input_focus_cookie_t xcb_get_input_focus_unchecked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GET_INPUT_FOCUS.

xcb_get_keyboard_control_cookie_t xcb_get_keyboard_control

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_KEYBOARD_CONTROL.

xcb_get_keyboard_control_reply_t* xcb_get_keyboard_control_reply

(

xcb_connection_t * 

c,

xcb_get_keyboard_control_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_keyboard_control_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_keyboard_control_cookie_t xcb_get_keyboard_control_unchecked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GET_KEYBOARD_CONTROL.

xcb_get_keyboard_mapping_cookie_t xcb_get_keyboard_mapping

(

xcb_connection_t * 

c,

xcb_keycode_t 

first_keycode,

uint8_t 

count 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_KEYBOARD_MAPPING.

xcb_get_keyboard_mapping_reply_t* xcb_get_keyboard_mapping_reply

(

xcb_connection_t * 

c,

xcb_get_keyboard_mapping_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_keyboard_mapping_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_keyboard_mapping_cookie_t xcb_get_keyboard_mapping_unchecked

(

xcb_connection_t * 

c,

xcb_keycode_t 

first_keycode,

uint8_t 

count 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_GET_KEYBOARD_MAPPING.

xcb_get_modifier_mapping_cookie_t xcb_get_modifier_mapping

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_MODIFIER_MAPPING.

xcb_get_modifier_mapping_reply_t* xcb_get_modifier_mapping_reply

(

xcb_connection_t * 

c,

xcb_get_modifier_mapping_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_modifier_mapping_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_modifier_mapping_cookie_t xcb_get_modifier_mapping_unchecked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_GET_MODIFIER_MAPPING.

xcb_get_motion_events_cookie_t xcb_get_motion_events

(

xcb_connection_t * 

c,

xcb_window_t 

window,

xcb_timestamp_t 

start,

xcb_timestamp_t 

stop 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_MOTION_EVENTS.

xcb_get_motion_events_reply_t* xcb_get_motion_events_reply

(

xcb_connection_t * 

c,

xcb_get_motion_events_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_motion_events_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_motion_events_cookie_t xcb_get_motion_events_unchecked

(

xcb_connection_t * 

c,

xcb_window_t 

window,

xcb_timestamp_t 

start,

xcb_timestamp_t 

stop 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GET_MOTION_EVENTS.

xcb_get_pointer_control_cookie_t xcb_get_pointer_control

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_POINTER_CONTROL.

xcb_get_pointer_control_reply_t* xcb_get_pointer_control_reply

(

xcb_connection_t * 

c,

xcb_get_pointer_control_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_pointer_control_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_pointer_control_cookie_t xcb_get_pointer_control_unchecked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GET_POINTER_CONTROL.

xcb_get_pointer_mapping_cookie_t xcb_get_pointer_mapping

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_POINTER_MAPPING.

xcb_get_pointer_mapping_reply_t* xcb_get_pointer_mapping_reply

(

xcb_connection_t * 

c,

xcb_get_pointer_mapping_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_pointer_mapping_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_pointer_mapping_cookie_t xcb_get_pointer_mapping_unchecked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_GET_POINTER_MAPPING.

xcb_get_property_cookie_t xcb_get_property

(

xcb_connection_t * 

c,

uint8_t 

_delete,

xcb_window_t 

window,

xcb_atom_t 

property,

xcb_atom_t 

type,

uint32_t 

long_offset,

uint32_t 

long_length 

)

Gets a window property.

Parameters

cThe connection

_deleteWhether the property should actually be deleted. For deleting a property, the specified type has to match the actual property type.

windowThe window whose property you want to get.

propertyThe property you want to get (an atom).

typeThe type of the property you want to get (an atom).

long_offsetSpecifies the offset (in 32-bit multiples) in the specified property where the data is to be retrieved.

long_lengthSpecifies how many 32-bit multiples of data should be retrieved (e.g. if you set long_length to 4, you will receive 16 bytes of data).

ReturnsA cookie

Gets the specified property from the specified window. Properties are for example the window title (WM_NAME) or its minimum size (WM_NORMAL_HINTS). Protocols such as EWMH also use properties - for example EWMH defines the window title, encoded as UTF-8 string, in the _NET_WM_NAME property.

TODO: talk about type

TODO: talk about delete

TODO: talk about the offset/length thing. what's a valid use case?

References XCB_GET_PROPERTY.

xcb_get_property_reply_t* xcb_get_property_reply

(

xcb_connection_t * 

c,

xcb_get_property_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_property_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_property_cookie_t xcb_get_property_unchecked

(

xcb_connection_t * 

c,

uint8_t 

_delete,

xcb_window_t 

window,

xcb_atom_t 

property,

xcb_atom_t 

type,

uint32_t 

long_offset,

uint32_t 

long_length 

)

Gets a window property.

Parameters

cThe connection

_deleteWhether the property should actually be deleted. For deleting a property, the specified type has to match the actual property type.

windowThe window whose property you want to get.

propertyThe property you want to get (an atom).

typeThe type of the property you want to get (an atom).

long_offsetSpecifies the offset (in 32-bit multiples) in the specified property where the data is to be retrieved.

long_lengthSpecifies how many 32-bit multiples of data should be retrieved (e.g. if you set long_length to 4, you will receive 16 bytes of data).

ReturnsA cookie

Gets the specified property from the specified window. Properties are for example the window title (WM_NAME) or its minimum size (WM_NORMAL_HINTS). Protocols such as EWMH also use properties - for example EWMH defines the window title, encoded as UTF-8 string, in the _NET_WM_NAME property.

TODO: talk about type

TODO: talk about delete

TODO: talk about the offset/length thing. what's a valid use case?

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_GET_PROPERTY.

xcb_get_screen_saver_cookie_t xcb_get_screen_saver

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GET_SCREEN_SAVER.

xcb_get_screen_saver_reply_t* xcb_get_screen_saver_reply

(

xcb_connection_t * 

c,

xcb_get_screen_saver_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_screen_saver_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_screen_saver_cookie_t xcb_get_screen_saver_unchecked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GET_SCREEN_SAVER.

xcb_get_selection_owner_cookie_t xcb_get_selection_owner

(

xcb_connection_t * 

c,

xcb_atom_t 

selection 

)

Gets the owner of a selection.

Parameters

cThe connection

selectionThe selection.

ReturnsA cookie

Gets the owner of the specified selection.

TODO: briefly explain what a selection is.

References XCB_GET_SELECTION_OWNER.

xcb_get_selection_owner_reply_t* xcb_get_selection_owner_reply

(

xcb_connection_t * 

c,

xcb_get_selection_owner_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_selection_owner_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_selection_owner_cookie_t xcb_get_selection_owner_unchecked

(

xcb_connection_t * 

c,

xcb_atom_t 

selection 

)

Gets the owner of a selection.

Parameters

cThe connection

selectionThe selection.

ReturnsA cookie

Gets the owner of the specified selection.

TODO: briefly explain what a selection is.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GET_SELECTION_OWNER.

xcb_get_window_attributes_cookie_t xcb_get_window_attributes

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Gets window attributes.

Parameters

cThe connection

windowThe window to get the attributes from.

ReturnsA cookie

Gets the current attributes for the specified window.

References XCB_GET_WINDOW_ATTRIBUTES.

xcb_get_window_attributes_reply_t* xcb_get_window_attributes_reply

(

xcb_connection_t * 

c,

xcb_get_window_attributes_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_get_window_attributes_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_get_window_attributes_cookie_t xcb_get_window_attributes_unchecked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Gets window attributes.

Parameters

cThe connection

windowThe window to get the attributes from.

ReturnsA cookie

Gets the current attributes for the specified window.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GET_WINDOW_ATTRIBUTES.

xcb_void_cookie_t xcb_grab_button

(

xcb_connection_t * 

c,

uint8_t 

owner_events,

xcb_window_t 

grab_window,

uint16_t 

event_mask,

uint8_t 

pointer_mode,

uint8_t 

keyboard_mode,

xcb_window_t 

confine_to,

xcb_cursor_t 

cursor,

uint8_t 

button,

uint16_t 

modifiers 

)

Grab pointer button(s)

Parameters

cThe connection

owner_eventsIf 1, the grab_window will still get the pointer events. If 0, events are not reported to the grab_window.

grab_windowSpecifies the window on which the pointer should be grabbed.

event_maskSpecifies which pointer events are reported to the client.

TODO: which values?

pointer_modeA bitmask of xcb_grab_mode_t values.

pointer_mode

keyboard_modeA bitmask of xcb_grab_mode_t values.

keyboard_mode

confine_toSpecifies the window to confine the pointer in (the user will not be able to move the pointer out of that window).

The special value XCB_NONE means don't confine the pointer.

cursorSpecifies the cursor that should be displayed or XCB_NONE to not change the cursor.

buttonA bitmask of xcb_button_index_t values.

button

modifiersThe modifiers to grab.

Using the special value XCB_MOD_MASK_ANY means grab the pointer with all possible modifier combinations.

ReturnsA cookie

This request establishes a passive grab. The pointer is actively grabbed as described in GrabPointer, the last-pointer-grab time is set to the time at which the button was pressed (as transmitted in the ButtonPress event), and the ButtonPress event is reported if all of the following conditions are true:

The pointer is not grabbed and the specified button is logically pressed when the specified modifier keys are logically down, and no other buttons or modifier keys are logically down.

The grab-window contains the pointer.

The confine-to window (if any) is viewable.

A passive grab on the same button/key combination does not exist on any ancestor of grab-window.

The interpretation of the remaining arguments is the same as for GrabPointer. The active grab is terminated automatically when the logical state of the pointer has all buttons released, independent of the logical state of modifier keys. Note that the logical state of a device (as seen by means of the protocol) may lag the physical state if device event processing is frozen. This request overrides all previous passive grabs by the same client on the same button/key combinations on the same window. A modifier of AnyModifier is equivalent to issuing the request for all possible modifier combinations (including the combination of no modifiers). It is not required that all specified modifiers have currently assigned keycodes. A button of AnyButton is equivalent to issuing the request for all possible buttons. Otherwise, it is not required that the button specified currently be assigned to a physical button.

An Access error is generated if some other client has already issued a GrabButton request with the same button/key combination on the same window. When using AnyModifier or AnyButton, the request fails completely (no grabs are established), and an Access error is generated if there is a conflicting grab for any combination. The request has no effect on an active grab.

References XCB_GRAB_BUTTON.

xcb_void_cookie_t xcb_grab_button_checked

(

xcb_connection_t * 

c,

uint8_t 

owner_events,

xcb_window_t 

grab_window,

uint16_t 

event_mask,

uint8_t 

pointer_mode,

uint8_t 

keyboard_mode,

xcb_window_t 

confine_to,

xcb_cursor_t 

cursor,

uint8_t 

button,

uint16_t 

modifiers 

)

Grab pointer button(s)

Parameters

cThe connection

owner_eventsIf 1, the grab_window will still get the pointer events. If 0, events are not reported to the grab_window.

grab_windowSpecifies the window on which the pointer should be grabbed.

event_maskSpecifies which pointer events are reported to the client.

TODO: which values?

pointer_modeA bitmask of xcb_grab_mode_t values.

pointer_mode

keyboard_modeA bitmask of xcb_grab_mode_t values.

keyboard_mode

confine_toSpecifies the window to confine the pointer in (the user will not be able to move the pointer out of that window).

The special value XCB_NONE means don't confine the pointer.

cursorSpecifies the cursor that should be displayed or XCB_NONE to not change the cursor.

buttonA bitmask of xcb_button_index_t values.

button

modifiersThe modifiers to grab.

Using the special value XCB_MOD_MASK_ANY means grab the pointer with all possible modifier combinations.

ReturnsA cookie

This request establishes a passive grab. The pointer is actively grabbed as described in GrabPointer, the last-pointer-grab time is set to the time at which the button was pressed (as transmitted in the ButtonPress event), and the ButtonPress event is reported if all of the following conditions are true:

The pointer is not grabbed and the specified button is logically pressed when the specified modifier keys are logically down, and no other buttons or modifier keys are logically down.

The grab-window contains the pointer.

The confine-to window (if any) is viewable.

A passive grab on the same button/key combination does not exist on any ancestor of grab-window.

The interpretation of the remaining arguments is the same as for GrabPointer. The active grab is terminated automatically when the logical state of the pointer has all buttons released, independent of the logical state of modifier keys. Note that the logical state of a device (as seen by means of the protocol) may lag the physical state if device event processing is frozen. This request overrides all previous passive grabs by the same client on the same button/key combinations on the same window. A modifier of AnyModifier is equivalent to issuing the request for all possible modifier combinations (including the combination of no modifiers). It is not required that all specified modifiers have currently assigned keycodes. A button of AnyButton is equivalent to issuing the request for all possible buttons. Otherwise, it is not required that the button specified currently be assigned to a physical button.

An Access error is generated if some other client has already issued a GrabButton request with the same button/key combination on the same window. When using AnyModifier or AnyButton, the request fails completely (no grabs are established), and an Access error is generated if there is a conflicting grab for any combination. The request has no effect on an active grab.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_GRAB_BUTTON.

xcb_void_cookie_t xcb_grab_key

(

xcb_connection_t * 

c,

uint8_t 

owner_events,

xcb_window_t 

grab_window,

uint16_t 

modifiers,

xcb_keycode_t 

key,

uint8_t 

pointer_mode,

uint8_t 

keyboard_mode 

)

Grab keyboard key(s)

Parameters

cThe connection

owner_eventsIf 1, the grab_window will still get the pointer events. If 0, events are not reported to the grab_window.

grab_windowSpecifies the window on which the pointer should be grabbed.

modifiersThe modifiers to grab.

Using the special value XCB_MOD_MASK_ANY means grab the pointer with all possible modifier combinations.

keyThe keycode of the key to grab.

The special value XCB_GRAB_ANY means grab any key.

pointer_modeA bitmask of xcb_grab_mode_t values.

pointer_mode

keyboard_modeA bitmask of xcb_grab_mode_t values.

keyboard_mode

ReturnsA cookie

Establishes a passive grab on the keyboard. In the future, the keyboard is actively grabbed (as for GrabKeyboard), the last-keyboard-grab time is set to the time at which the key was pressed (as transmitted in the KeyPress event), and the KeyPress event is reported if all of the following conditions are true:

The keyboard is not grabbed and the specified key (which can itself be a modifier key) is logically pressed when the specified modifier keys are logically down, and no other modifier keys are logically down.

Either the grab_window is an ancestor of (or is) the focus window, or the grab_window is a descendant of the focus window and contains the pointer.

A passive grab on the same key combination does not exist on any ancestor of grab_window.

The interpretation of the remaining arguments is as for XGrabKeyboard. The active grab is terminated automatically when the logical state of the keyboard has the specified key released (independent of the logical state of the modifier keys), at which point a KeyRelease event is reported to the grabbing window.

Note that the logical state of a device (as seen by client applications) may lag the physical state if device event processing is frozen.

A modifiers argument of AnyModifier is equivalent to issuing the request for all possible modifier combinations (including the combination of no modifiers). It is not required that all modifiers specified have currently assigned KeyCodes. A keycode argument of AnyKey is equivalent to issuing the request for all possible KeyCodes. Otherwise, the specified keycode must be in the range specified by min_keycode and max_keycode in the connection setup, or a BadValue error results.

If some other client has issued a XGrabKey with the same key combination on the same window, a BadAccess error results. When using AnyModifier or AnyKey, the request fails completely, and a BadAccess error results (no grabs are established) if there is a conflicting grab for any combination.

References XCB_GRAB_KEY.

xcb_void_cookie_t xcb_grab_key_checked

(

xcb_connection_t * 

c,

uint8_t 

owner_events,

xcb_window_t 

grab_window,

uint16_t 

modifiers,

xcb_keycode_t 

key,

uint8_t 

pointer_mode,

uint8_t 

keyboard_mode 

)

Grab keyboard key(s)

Parameters

cThe connection

owner_eventsIf 1, the grab_window will still get the pointer events. If 0, events are not reported to the grab_window.

grab_windowSpecifies the window on which the pointer should be grabbed.

modifiersThe modifiers to grab.

Using the special value XCB_MOD_MASK_ANY means grab the pointer with all possible modifier combinations.

keyThe keycode of the key to grab.

The special value XCB_GRAB_ANY means grab any key.

pointer_modeA bitmask of xcb_grab_mode_t values.

pointer_mode

keyboard_modeA bitmask of xcb_grab_mode_t values.

keyboard_mode

ReturnsA cookie

Establishes a passive grab on the keyboard. In the future, the keyboard is actively grabbed (as for GrabKeyboard), the last-keyboard-grab time is set to the time at which the key was pressed (as transmitted in the KeyPress event), and the KeyPress event is reported if all of the following conditions are true:

The keyboard is not grabbed and the specified key (which can itself be a modifier key) is logically pressed when the specified modifier keys are logically down, and no other modifier keys are logically down.

Either the grab_window is an ancestor of (or is) the focus window, or the grab_window is a descendant of the focus window and contains the pointer.

A passive grab on the same key combination does not exist on any ancestor of grab_window.

The interpretation of the remaining arguments is as for XGrabKeyboard. The active grab is terminated automatically when the logical state of the keyboard has the specified key released (independent of the logical state of the modifier keys), at which point a KeyRelease event is reported to the grabbing window.

Note that the logical state of a device (as seen by client applications) may lag the physical state if device event processing is frozen.

A modifiers argument of AnyModifier is equivalent to issuing the request for all possible modifier combinations (including the combination of no modifiers). It is not required that all modifiers specified have currently assigned KeyCodes. A keycode argument of AnyKey is equivalent to issuing the request for all possible KeyCodes. Otherwise, the specified keycode must be in the range specified by min_keycode and max_keycode in the connection setup, or a BadValue error results.

If some other client has issued a XGrabKey with the same key combination on the same window, a BadAccess error results. When using AnyModifier or AnyKey, the request fails completely, and a BadAccess error results (no grabs are established) if there is a conflicting grab for any combination.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_GRAB_KEY.

xcb_grab_keyboard_cookie_t xcb_grab_keyboard

(

xcb_connection_t * 

c,

uint8_t 

owner_events,

xcb_window_t 

grab_window,

xcb_timestamp_t 

time,

uint8_t 

pointer_mode,

uint8_t 

keyboard_mode 

)

Grab the keyboard.

Parameters

cThe connection

owner_eventsIf 1, the grab_window will still get the pointer events. If 0, events are not reported to the grab_window.

grab_windowSpecifies the window on which the pointer should be grabbed.

timeTimestamp to avoid race conditions when running X over the network.

The special value XCB_CURRENT_TIME will be replaced with the current server time.

pointer_modeA bitmask of xcb_grab_mode_t values.

pointer_mode

keyboard_modeA bitmask of xcb_grab_mode_t values.

keyboard_mode

ReturnsA cookie

Actively grabs control of the keyboard and generates FocusIn and FocusOut events. Further key events are reported only to the grabbing client.

Any active keyboard grab by this client is overridden. If the keyboard is actively grabbed by some other client, AlreadyGrabbed is returned. If grab_window is not viewable, GrabNotViewable is returned. If the keyboard is frozen by an active grab of another client, GrabFrozen is returned. If the specified time is earlier than the last-keyboard-grab time or later than the current X server time, GrabInvalidTime is returned. Otherwise, the last-keyboard-grab time is set to the specified time.

References XCB_GRAB_KEYBOARD.

xcb_grab_keyboard_reply_t* xcb_grab_keyboard_reply

(

xcb_connection_t * 

c,

xcb_grab_keyboard_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_grab_keyboard_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_grab_keyboard_cookie_t xcb_grab_keyboard_unchecked

(

xcb_connection_t * 

c,

uint8_t 

owner_events,

xcb_window_t 

grab_window,

xcb_timestamp_t 

time,

uint8_t 

pointer_mode,

uint8_t 

keyboard_mode 

)

Grab the keyboard.

Parameters

cThe connection

owner_eventsIf 1, the grab_window will still get the pointer events. If 0, events are not reported to the grab_window.

grab_windowSpecifies the window on which the pointer should be grabbed.

timeTimestamp to avoid race conditions when running X over the network.

The special value XCB_CURRENT_TIME will be replaced with the current server time.

pointer_modeA bitmask of xcb_grab_mode_t values.

pointer_mode

keyboard_modeA bitmask of xcb_grab_mode_t values.

keyboard_mode

ReturnsA cookie

Actively grabs control of the keyboard and generates FocusIn and FocusOut events. Further key events are reported only to the grabbing client.

Any active keyboard grab by this client is overridden. If the keyboard is actively grabbed by some other client, AlreadyGrabbed is returned. If grab_window is not viewable, GrabNotViewable is returned. If the keyboard is frozen by an active grab of another client, GrabFrozen is returned. If the specified time is earlier than the last-keyboard-grab time or later than the current X server time, GrabInvalidTime is returned. Otherwise, the last-keyboard-grab time is set to the specified time.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GRAB_KEYBOARD.

xcb_grab_pointer_cookie_t xcb_grab_pointer

(

xcb_connection_t * 

c,

uint8_t 

owner_events,

xcb_window_t 

grab_window,

uint16_t 

event_mask,

uint8_t 

pointer_mode,

uint8_t 

keyboard_mode,

xcb_window_t 

confine_to,

xcb_cursor_t 

cursor,

xcb_timestamp_t 

time 

)

Grab the pointer.

Parameters

cThe connection

owner_eventsIf 1, the grab_window will still get the pointer events. If 0, events are not reported to the grab_window.

grab_windowSpecifies the window on which the pointer should be grabbed.

event_maskSpecifies which pointer events are reported to the client.

TODO: which values?

pointer_modeA bitmask of xcb_grab_mode_t values.

pointer_mode

keyboard_modeA bitmask of xcb_grab_mode_t values.

keyboard_mode

confine_toSpecifies the window to confine the pointer in (the user will not be able to move the pointer out of that window).

The special value XCB_NONE means don't confine the pointer.

cursorSpecifies the cursor that should be displayed or XCB_NONE to not change the cursor.

timeThe time argument allows you to avoid certain circumstances that come up if applications take a long time to respond or if there are long network delays. Consider a situation where you have two applications, both of which normally grab the pointer when clicked on. If both applications specify the timestamp from the event, the second application may wake up faster and successfully grab the pointer before the first application. The first application then will get an indication that the other application grabbed the pointer before its request was processed.

The special value XCB_CURRENT_TIME will be replaced with the current server time.

ReturnsA cookie

Actively grabs control of the pointer. Further pointer events are reported only to the grabbing client. Overrides any active pointer grab by this client.

References XCB_GRAB_POINTER.

xcb_grab_pointer_reply_t* xcb_grab_pointer_reply

(

xcb_connection_t * 

c,

xcb_grab_pointer_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_grab_pointer_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_grab_pointer_cookie_t xcb_grab_pointer_unchecked

(

xcb_connection_t * 

c,

uint8_t 

owner_events,

xcb_window_t 

grab_window,

uint16_t 

event_mask,

uint8_t 

pointer_mode,

uint8_t 

keyboard_mode,

xcb_window_t 

confine_to,

xcb_cursor_t 

cursor,

xcb_timestamp_t 

time 

)

Grab the pointer.

Parameters

cThe connection

owner_eventsIf 1, the grab_window will still get the pointer events. If 0, events are not reported to the grab_window.

grab_windowSpecifies the window on which the pointer should be grabbed.

event_maskSpecifies which pointer events are reported to the client.

TODO: which values?

pointer_modeA bitmask of xcb_grab_mode_t values.

pointer_mode

keyboard_modeA bitmask of xcb_grab_mode_t values.

keyboard_mode

confine_toSpecifies the window to confine the pointer in (the user will not be able to move the pointer out of that window).

The special value XCB_NONE means don't confine the pointer.

cursorSpecifies the cursor that should be displayed or XCB_NONE to not change the cursor.

timeThe time argument allows you to avoid certain circumstances that come up if applications take a long time to respond or if there are long network delays. Consider a situation where you have two applications, both of which normally grab the pointer when clicked on. If both applications specify the timestamp from the event, the second application may wake up faster and successfully grab the pointer before the first application. The first application then will get an indication that the other application grabbed the pointer before its request was processed.

The special value XCB_CURRENT_TIME will be replaced with the current server time.

ReturnsA cookie

Actively grabs control of the pointer. Further pointer events are reported only to the grabbing client. Overrides any active pointer grab by this client.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_GRAB_POINTER.

xcb_void_cookie_t xcb_grab_server

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_GRAB_SERVER.

xcb_void_cookie_t xcb_grab_server_checked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_GRAB_SERVER.

xcb_generic_iterator_t xcb_host_end

(

xcb_host_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_host_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and xcb_host_next().

void xcb_host_next

(

xcb_host_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_host_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_host_t)

References xcb_generic_iterator_t::data.

Referenced by xcb_host_end().

xcb_void_cookie_t xcb_image_text_16

(

xcb_connection_t * 

c,

uint8_t 

string_len,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

int16_t 

x,

int16_t 

y,

const xcb_char2b_t * 

string 

)

Draws text.

Parameters

cThe connection

string_lenThe length of the string in characters. Note that this parameter limited by 255 due to using 8 bits!

drawableThe drawable (Window or Pixmap) to draw text on.

gcThe graphics context to use.

The following graphics context components are used: plane-mask, foreground, background, font, subwindow-mode, clip-x-origin, clip-y-origin, and clip-mask.

xThe x coordinate of the first character, relative to the origin of drawable.

yThe y coordinate of the first character, relative to the origin of drawable.

stringThe string to draw. Only the first 255 characters are relevant due to the data type of string_len. Every character uses 2 bytes (hence the 16 in this request's name).

ReturnsA cookie

Fills the destination rectangle with the background pixel from gc, then paints the text with the foreground pixel from gc. The upper-left corner of the filled rectangle is at [x, y - font-ascent]. The width is overall-width, the height is font-ascent + font-descent. The overall-width, font-ascent and font-descent are as returned by xcb_query_text_extents (TODO).

Note that using X core fonts is deprecated (but still supported) in favor of client-side rendering using Xft.

References XCB_IMAGE_TEXT_16.

xcb_void_cookie_t xcb_image_text_16_checked

(

xcb_connection_t * 

c,

uint8_t 

string_len,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

int16_t 

x,

int16_t 

y,

const xcb_char2b_t * 

string 

)

Draws text.

Parameters

cThe connection

string_lenThe length of the string in characters. Note that this parameter limited by 255 due to using 8 bits!

drawableThe drawable (Window or Pixmap) to draw text on.

gcThe graphics context to use.

The following graphics context components are used: plane-mask, foreground, background, font, subwindow-mode, clip-x-origin, clip-y-origin, and clip-mask.

xThe x coordinate of the first character, relative to the origin of drawable.

yThe y coordinate of the first character, relative to the origin of drawable.

stringThe string to draw. Only the first 255 characters are relevant due to the data type of string_len. Every character uses 2 bytes (hence the 16 in this request's name).

ReturnsA cookie

Fills the destination rectangle with the background pixel from gc, then paints the text with the foreground pixel from gc. The upper-left corner of the filled rectangle is at [x, y - font-ascent]. The width is overall-width, the height is font-ascent + font-descent. The overall-width, font-ascent and font-descent are as returned by xcb_query_text_extents (TODO).

Note that using X core fonts is deprecated (but still supported) in favor of client-side rendering using Xft.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_IMAGE_TEXT_16.

xcb_void_cookie_t xcb_image_text_8

(

xcb_connection_t * 

c,

uint8_t 

string_len,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

int16_t 

x,

int16_t 

y,

const char * 

string 

)

Draws text.

Parameters

cThe connection

string_lenThe length of the string. Note that this parameter limited by 255 due to using 8 bits!

drawableThe drawable (Window or Pixmap) to draw text on.

gcThe graphics context to use.

The following graphics context components are used: plane-mask, foreground, background, font, subwindow-mode, clip-x-origin, clip-y-origin, and clip-mask.

xThe x coordinate of the first character, relative to the origin of drawable.

yThe y coordinate of the first character, relative to the origin of drawable.

stringThe string to draw. Only the first 255 characters are relevant due to the data type of string_len.

ReturnsA cookie

Fills the destination rectangle with the background pixel from gc, then paints the text with the foreground pixel from gc. The upper-left corner of the filled rectangle is at [x, y - font-ascent]. The width is overall-width, the height is font-ascent + font-descent. The overall-width, font-ascent and font-descent are as returned by xcb_query_text_extents (TODO).

Note that using X core fonts is deprecated (but still supported) in favor of client-side rendering using Xft.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_IMAGE_TEXT_8.

xcb_void_cookie_t xcb_image_text_8_checked

(

xcb_connection_t * 

c,

uint8_t 

string_len,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

int16_t 

x,

int16_t 

y,

const char * 

string 

)

Draws text.

Parameters

cThe connection

string_lenThe length of the string. Note that this parameter limited by 255 due to using 8 bits!

drawableThe drawable (Window or Pixmap) to draw text on.

gcThe graphics context to use.

The following graphics context components are used: plane-mask, foreground, background, font, subwindow-mode, clip-x-origin, clip-y-origin, and clip-mask.

xThe x coordinate of the first character, relative to the origin of drawable.

yThe y coordinate of the first character, relative to the origin of drawable.

stringThe string to draw. Only the first 255 characters are relevant due to the data type of string_len.

ReturnsA cookie

Fills the destination rectangle with the background pixel from gc, then paints the text with the foreground pixel from gc. The upper-left corner of the filled rectangle is at [x, y - font-ascent]. The width is overall-width, the height is font-ascent + font-descent. The overall-width, font-ascent and font-descent are as returned by xcb_query_text_extents (TODO).

Note that using X core fonts is deprecated (but still supported) in favor of client-side rendering using Xft.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_IMAGE_TEXT_8.

xcb_void_cookie_t xcb_install_colormap

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_INSTALL_COLORMAP.

xcb_void_cookie_t xcb_install_colormap_checked

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_INSTALL_COLORMAP.

xcb_intern_atom_cookie_t xcb_intern_atom

(

xcb_connection_t * 

c,

uint8_t 

only_if_exists,

uint16_t 

name_len,

const char * 

name 

)

Get atom identifier by name.

Parameters

cThe connection

only_if_existsReturn a valid atom id only if the atom already exists.

name_lenThe length of the following name.

nameThe name of the atom.

ReturnsA cookie

Retrieves the identifier (xcb_atom_t TODO) for the atom with the specified name. Atoms are used in protocols like EWMH, for example to store window titles (_NET_WM_NAME atom) as property of a window.

If only_if_exists is 0, the atom will be created if it does not already exist. If only_if_exists is 1, XCB_ATOM_NONE will be returned if the atom does not yet exist.

References XCB_INTERN_ATOM.

xcb_intern_atom_reply_t* xcb_intern_atom_reply

(

xcb_connection_t * 

c,

xcb_intern_atom_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_intern_atom_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_intern_atom_cookie_t xcb_intern_atom_unchecked

(

xcb_connection_t * 

c,

uint8_t 

only_if_exists,

uint16_t 

name_len,

const char * 

name 

)

Get atom identifier by name.

Parameters

cThe connection

only_if_existsReturn a valid atom id only if the atom already exists.

name_lenThe length of the following name.

nameThe name of the atom.

ReturnsA cookie

Retrieves the identifier (xcb_atom_t TODO) for the atom with the specified name. Atoms are used in protocols like EWMH, for example to store window titles (_NET_WM_NAME atom) as property of a window.

If only_if_exists is 0, the atom will be created if it does not already exist. If only_if_exists is 1, XCB_ATOM_NONE will be returned if the atom does not yet exist.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_INTERN_ATOM.

xcb_generic_iterator_t xcb_keycode32_end

(

xcb_keycode32_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_keycode32_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_keycode32_next

(

xcb_keycode32_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_keycode32_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_keycode32_t)

xcb_generic_iterator_t xcb_keycode_end

(

xcb_keycode_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_keycode_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_keycode_next

(

xcb_keycode_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_keycode_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_keycode_t)

xcb_generic_iterator_t xcb_keysym_end

(

xcb_keysym_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_keysym_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_keysym_next

(

xcb_keysym_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_keysym_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_keysym_t)

xcb_void_cookie_t xcb_kill_client

(

xcb_connection_t * 

c,

uint32_t 

resource 

)

kills a client

Parameters

cThe connection

resourceAny resource belonging to the client (for example a Window), used to identify the client connection.

The special value of XCB_KILL_ALL_TEMPORARY, the resources of all clients that have terminated in RetainTemporary (TODO) are destroyed.

ReturnsA cookie

Forces a close down of the client that created the specified resource.

References XCB_KILL_CLIENT.

xcb_void_cookie_t xcb_kill_client_checked

(

xcb_connection_t * 

c,

uint32_t 

resource 

)

kills a client

Parameters

cThe connection

resourceAny resource belonging to the client (for example a Window), used to identify the client connection.

The special value of XCB_KILL_ALL_TEMPORARY, the resources of all clients that have terminated in RetainTemporary (TODO) are destroyed.

ReturnsA cookie

Forces a close down of the client that created the specified resource.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_KILL_CLIENT.

xcb_list_extensions_cookie_t xcb_list_extensions

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_LIST_EXTENSIONS.

xcb_list_extensions_reply_t* xcb_list_extensions_reply

(

xcb_connection_t * 

c,

xcb_list_extensions_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_list_extensions_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_list_extensions_cookie_t xcb_list_extensions_unchecked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_LIST_EXTENSIONS.

xcb_list_fonts_cookie_t xcb_list_fonts

(

xcb_connection_t * 

c,

uint16_t 

max_names,

uint16_t 

pattern_len,

const char * 

pattern 

)

get matching font names

Parameters

cThe connection

max_namesThe maximum number of fonts to be returned.

pattern_lenThe length (in bytes) of pattern.

patternA font pattern, for example "-misc-fixed-*".

The asterisk (*) is a wildcard for any number of characters. The question mark (?) is a wildcard for a single character. Use of uppercase or lowercase does not matter.

ReturnsA cookie

Gets a list of available font names which match the given pattern.

References XCB_LIST_FONTS.

xcb_list_fonts_reply_t* xcb_list_fonts_reply

(

xcb_connection_t * 

c,

xcb_list_fonts_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_list_fonts_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_list_fonts_cookie_t xcb_list_fonts_unchecked

(

xcb_connection_t * 

c,

uint16_t 

max_names,

uint16_t 

pattern_len,

const char * 

pattern 

)

get matching font names

Parameters

cThe connection

max_namesThe maximum number of fonts to be returned.

pattern_lenThe length (in bytes) of pattern.

patternA font pattern, for example "-misc-fixed-*".

The asterisk (*) is a wildcard for any number of characters. The question mark (?) is a wildcard for a single character. Use of uppercase or lowercase does not matter.

ReturnsA cookie

Gets a list of available font names which match the given pattern.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_LIST_FONTS.

xcb_list_fonts_with_info_cookie_t xcb_list_fonts_with_info

(

xcb_connection_t * 

c,

uint16_t 

max_names,

uint16_t 

pattern_len,

const char * 

pattern 

)

get matching font names and information

Parameters

cThe connection

max_namesThe maximum number of fonts to be returned.

pattern_lenThe length (in bytes) of pattern.

patternA font pattern, for example "-misc-fixed-*".

The asterisk (*) is a wildcard for any number of characters. The question mark (?) is a wildcard for a single character. Use of uppercase or lowercase does not matter.

ReturnsA cookie

Gets a list of available font names which match the given pattern.

References XCB_LIST_FONTS_WITH_INFO.

xcb_list_fonts_with_info_reply_t* xcb_list_fonts_with_info_reply

(

xcb_connection_t * 

c,

xcb_list_fonts_with_info_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_list_fonts_with_info_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_list_fonts_with_info_cookie_t xcb_list_fonts_with_info_unchecked

(

xcb_connection_t * 

c,

uint16_t 

max_names,

uint16_t 

pattern_len,

const char * 

pattern 

)

get matching font names and information

Parameters

cThe connection

max_namesThe maximum number of fonts to be returned.

pattern_lenThe length (in bytes) of pattern.

patternA font pattern, for example "-misc-fixed-*".

The asterisk (*) is a wildcard for any number of characters. The question mark (?) is a wildcard for a single character. Use of uppercase or lowercase does not matter.

ReturnsA cookie

Gets a list of available font names which match the given pattern.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, xcb_fontprop_end(), and XCB_LIST_FONTS_WITH_INFO.

xcb_list_hosts_cookie_t xcb_list_hosts

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_LIST_HOSTS.

xcb_list_hosts_reply_t* xcb_list_hosts_reply

(

xcb_connection_t * 

c,

xcb_list_hosts_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_list_hosts_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_list_hosts_cookie_t xcb_list_hosts_unchecked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_LIST_HOSTS.

xcb_list_installed_colormaps_cookie_t xcb_list_installed_colormaps

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_LIST_INSTALLED_COLORMAPS.

xcb_list_installed_colormaps_reply_t* xcb_list_installed_colormaps_reply

(

xcb_connection_t * 

c,

xcb_list_installed_colormaps_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_list_installed_colormaps_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_list_installed_colormaps_cookie_t xcb_list_installed_colormaps_unchecked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_LIST_INSTALLED_COLORMAPS.

xcb_list_properties_cookie_t xcb_list_properties

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_LIST_PROPERTIES.

xcb_list_properties_reply_t* xcb_list_properties_reply

(

xcb_connection_t * 

c,

xcb_list_properties_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_list_properties_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_list_properties_cookie_t xcb_list_properties_unchecked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_LIST_PROPERTIES.

xcb_lookup_color_cookie_t xcb_lookup_color

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint16_t 

name_len,

const char * 

name 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_LOOKUP_COLOR.

xcb_lookup_color_reply_t* xcb_lookup_color_reply

(

xcb_connection_t * 

c,

xcb_lookup_color_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_lookup_color_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_lookup_color_cookie_t xcb_lookup_color_unchecked

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint16_t 

name_len,

const char * 

name 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_LOOKUP_COLOR.

xcb_void_cookie_t xcb_map_subwindows

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_MAP_SUBWINDOWS.

xcb_void_cookie_t xcb_map_subwindows_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_MAP_SUBWINDOWS.

xcb_void_cookie_t xcb_map_window

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Makes a window visible.

Parameters

cThe connection

windowThe window to make visible.

ReturnsA cookie

Maps the specified window. This means making the window visible (as long as its parent is visible).

This MapWindow request will be translated to a MapRequest request if a window manager is running. The window manager then decides to either map the window or not. Set the override-redirect window attribute to true if you want to bypass this mechanism.

If the window manager decides to map the window (or if no window manager is running), a MapNotify event is generated.

If the window becomes viewable and no earlier contents for it are remembered, the X server tiles the window with its background. If the window's background is undefined, the existing screen contents are not altered, and the X server generates zero or more Expose events.

If the window type is InputOutput, an Expose event will be generated when the window becomes visible. The normal response to an Expose event should be to repaint the window.

References XCB_MAP_WINDOW.

xcb_void_cookie_t xcb_map_window_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Makes a window visible.

Parameters

cThe connection

windowThe window to make visible.

ReturnsA cookie

Maps the specified window. This means making the window visible (as long as its parent is visible).

This MapWindow request will be translated to a MapRequest request if a window manager is running. The window manager then decides to either map the window or not. Set the override-redirect window attribute to true if you want to bypass this mechanism.

If the window manager decides to map the window (or if no window manager is running), a MapNotify event is generated.

If the window becomes viewable and no earlier contents for it are remembered, the X server tiles the window with its background. If the window's background is undefined, the existing screen contents are not altered, and the X server generates zero or more Expose events.

If the window type is InputOutput, an Expose event will be generated when the window becomes visible. The normal response to an Expose event should be to repaint the window.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_MAP_WINDOW.

xcb_void_cookie_t xcb_no_operation

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_NO_OPERATION.

xcb_void_cookie_t xcb_no_operation_checked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_NO_OPERATION.

xcb_void_cookie_t xcb_open_font

(

xcb_connection_t * 

c,

xcb_font_t 

fid,

uint16_t 

name_len,

const char * 

name 

)

opens a font

Parameters

cThe connection

fidThe ID with which you will refer to the font, created by xcb_generate_id.

name_lenLength (in bytes) of name.

nameA pattern describing an X core font.

ReturnsA cookie

Opens any X core font matching the given name (for example "-misc-fixed-*").

Note that X core fonts are deprecated (but still supported) in favor of client-side rendering using Xft.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_OPEN_FONT.

xcb_void_cookie_t xcb_open_font_checked

(

xcb_connection_t * 

c,

xcb_font_t 

fid,

uint16_t 

name_len,

const char * 

name 

)

opens a font

Parameters

cThe connection

fidThe ID with which you will refer to the font, created by xcb_generate_id.

name_lenLength (in bytes) of name.

nameA pattern describing an X core font.

ReturnsA cookie

Opens any X core font matching the given name (for example "-misc-fixed-*").

Note that X core fonts are deprecated (but still supported) in favor of client-side rendering using Xft.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_OPEN_FONT.

xcb_generic_iterator_t xcb_pixmap_end

(

xcb_pixmap_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_pixmap_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_pixmap_next

(

xcb_pixmap_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_pixmap_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_pixmap_t)

xcb_generic_iterator_t xcb_point_end

(

xcb_point_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_point_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_point_next

(

xcb_point_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_point_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_point_t)

xcb_void_cookie_t xcb_poly_arc

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

arcs_len,

const xcb_arc_t * 

arcs 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_POLY_ARC.

xcb_void_cookie_t xcb_poly_arc_checked

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

arcs_len,

const xcb_arc_t * 

arcs 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_POLY_ARC.

xcb_void_cookie_t xcb_poly_fill_arc

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

arcs_len,

const xcb_arc_t * 

arcs 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_POLY_FILL_ARC.

xcb_void_cookie_t xcb_poly_fill_arc_checked

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

arcs_len,

const xcb_arc_t * 

arcs 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_POLY_FILL_ARC.

xcb_void_cookie_t xcb_poly_fill_rectangle

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

rectangles_len,

const xcb_rectangle_t * 

rectangles 

)

Fills rectangles.

Parameters

cThe connection

drawableThe drawable (Window or Pixmap) to draw on.

gcThe graphics context to use.

The following graphics context components are used: function, plane-mask, fill-style, subwindow-mode, clip-x-origin, clip-y-origin, and clip-mask.

The following graphics context mode-dependent components are used: foreground, background, tile, stipple, tile-stipple-x-origin, and tile-stipple-y-origin.

rectangles_lenThe number of xcb_rectangle_t structures in rectangles.

rectanglesThe rectangles to fill.

ReturnsA cookie

Fills the specified rectangle(s) in the order listed in the array. For any given rectangle, each pixel is not drawn more than once. If rectangles intersect, the intersecting pixels are drawn multiple times.

References XCB_POLY_FILL_RECTANGLE.

xcb_void_cookie_t xcb_poly_fill_rectangle_checked

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

rectangles_len,

const xcb_rectangle_t * 

rectangles 

)

Fills rectangles.

Parameters

cThe connection

drawableThe drawable (Window or Pixmap) to draw on.

gcThe graphics context to use.

The following graphics context components are used: function, plane-mask, fill-style, subwindow-mode, clip-x-origin, clip-y-origin, and clip-mask.

The following graphics context mode-dependent components are used: foreground, background, tile, stipple, tile-stipple-x-origin, and tile-stipple-y-origin.

rectangles_lenThe number of xcb_rectangle_t structures in rectangles.

rectanglesThe rectangles to fill.

ReturnsA cookie

Fills the specified rectangle(s) in the order listed in the array. For any given rectangle, each pixel is not drawn more than once. If rectangles intersect, the intersecting pixels are drawn multiple times.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_POLY_FILL_RECTANGLE.

xcb_void_cookie_t xcb_poly_line

(

xcb_connection_t * 

c,

uint8_t 

coordinate_mode,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

points_len,

const xcb_point_t * 

points 

)

draw lines

Parameters

cThe connection

coordinate_modeA bitmask of xcb_coord_mode_t values.

coordinate_mode

drawableThe drawable to draw the line(s) on.

gcThe graphics context to use.

points_lenThe number of xcb_point_t structures in points.

pointsAn array of points.

ReturnsA cookie

Draws points_len-1 lines between each pair of points (point[i], point[i+1]) in the points array. The lines are drawn in the order listed in the array. They join correctly at all intermediate points, and if the first and last points coincide, the first and last lines also join correctly. For any given line, a pixel is not drawn more than once. If thin (zero line-width) lines intersect, the intersecting pixels are drawn multiple times. If wide lines intersect, the intersecting pixels are drawn only once, as though the entire request were a single, filled shape.

References XCB_POLY_LINE.

xcb_void_cookie_t xcb_poly_line_checked

(

xcb_connection_t * 

c,

uint8_t 

coordinate_mode,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

points_len,

const xcb_point_t * 

points 

)

draw lines

Parameters

cThe connection

coordinate_modeA bitmask of xcb_coord_mode_t values.

coordinate_mode

drawableThe drawable to draw the line(s) on.

gcThe graphics context to use.

points_lenThe number of xcb_point_t structures in points.

pointsAn array of points.

ReturnsA cookie

Draws points_len-1 lines between each pair of points (point[i], point[i+1]) in the points array. The lines are drawn in the order listed in the array. They join correctly at all intermediate points, and if the first and last points coincide, the first and last lines also join correctly. For any given line, a pixel is not drawn more than once. If thin (zero line-width) lines intersect, the intersecting pixels are drawn multiple times. If wide lines intersect, the intersecting pixels are drawn only once, as though the entire request were a single, filled shape.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_POLY_LINE.

xcb_void_cookie_t xcb_poly_point

(

xcb_connection_t * 

c,

uint8_t 

coordinate_mode,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

points_len,

const xcb_point_t * 

points 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_POLY_POINT.

xcb_void_cookie_t xcb_poly_point_checked

(

xcb_connection_t * 

c,

uint8_t 

coordinate_mode,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

points_len,

const xcb_point_t * 

points 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_POLY_POINT.

xcb_void_cookie_t xcb_poly_rectangle

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

rectangles_len,

const xcb_rectangle_t * 

rectangles 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_POLY_RECTANGLE.

xcb_void_cookie_t xcb_poly_rectangle_checked

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

rectangles_len,

const xcb_rectangle_t * 

rectangles 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_POLY_RECTANGLE.

xcb_void_cookie_t xcb_poly_segment

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

segments_len,

const xcb_segment_t * 

segments 

)

draw lines

Parameters

cThe connection

drawableA drawable (Window or Pixmap) to draw on.

gcThe graphics context to use.

TODO: document which attributes of a gc are used

segments_lenThe number of xcb_segment_t structures in segments.

segmentsAn array of xcb_segment_t structures.

ReturnsA cookie

Draws multiple, unconnected lines. For each segment, a line is drawn between (x1, y1) and (x2, y2). The lines are drawn in the order listed in the array of xcb_segment_t structures and does not perform joining at coincident endpoints. For any given line, a pixel is not drawn more than once. If lines intersect, the intersecting pixels are drawn multiple times.

TODO: include the xcb_segment_t data structure

TODO: an example

References XCB_POLY_SEGMENT.

xcb_void_cookie_t xcb_poly_segment_checked

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint32_t 

segments_len,

const xcb_segment_t * 

segments 

)

draw lines

Parameters

cThe connection

drawableA drawable (Window or Pixmap) to draw on.

gcThe graphics context to use.

TODO: document which attributes of a gc are used

segments_lenThe number of xcb_segment_t structures in segments.

segmentsAn array of xcb_segment_t structures.

ReturnsA cookie

Draws multiple, unconnected lines. For each segment, a line is drawn between (x1, y1) and (x2, y2). The lines are drawn in the order listed in the array of xcb_segment_t structures and does not perform joining at coincident endpoints. For any given line, a pixel is not drawn more than once. If lines intersect, the intersecting pixels are drawn multiple times.

TODO: include the xcb_segment_t data structure

TODO: an example

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_POLY_SEGMENT.

xcb_void_cookie_t xcb_poly_text_16

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

int16_t 

x,

int16_t 

y,

uint32_t 

items_len,

const uint8_t * 

items 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_POLY_TEXT_16.

xcb_void_cookie_t xcb_poly_text_16_checked

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

int16_t 

x,

int16_t 

y,

uint32_t 

items_len,

const uint8_t * 

items 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_POLY_TEXT_16.

xcb_void_cookie_t xcb_poly_text_8

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

int16_t 

x,

int16_t 

y,

uint32_t 

items_len,

const uint8_t * 

items 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_POLY_TEXT_8.

xcb_void_cookie_t xcb_poly_text_8_checked

(

xcb_connection_t * 

c,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

int16_t 

x,

int16_t 

y,

uint32_t 

items_len,

const uint8_t * 

items 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_POLY_TEXT_8.

xcb_void_cookie_t xcb_put_image

(

xcb_connection_t * 

c,

uint8_t 

format,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint16_t 

width,

uint16_t 

height,

int16_t 

dst_x,

int16_t 

dst_y,

uint8_t 

left_pad,

uint8_t 

depth,

uint32_t 

data_len,

const uint8_t * 

data 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_PUT_IMAGE.

xcb_void_cookie_t xcb_put_image_checked

(

xcb_connection_t * 

c,

uint8_t 

format,

xcb_drawable_t 

drawable,

xcb_gcontext_t 

gc,

uint16_t 

width,

uint16_t 

height,

int16_t 

dst_x,

int16_t 

dst_y,

uint8_t 

left_pad,

uint8_t 

depth,

uint32_t 

data_len,

const uint8_t * 

data 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_PUT_IMAGE.

xcb_query_best_size_cookie_t xcb_query_best_size

(

xcb_connection_t * 

c,

uint8_t 

_class,

xcb_drawable_t 

drawable,

uint16_t 

width,

uint16_t 

height 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_QUERY_BEST_SIZE.

xcb_query_best_size_reply_t* xcb_query_best_size_reply

(

xcb_connection_t * 

c,

xcb_query_best_size_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_query_best_size_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_query_best_size_cookie_t xcb_query_best_size_unchecked

(

xcb_connection_t * 

c,

uint8_t 

_class,

xcb_drawable_t 

drawable,

uint16_t 

width,

uint16_t 

height 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_QUERY_BEST_SIZE.

xcb_query_colors_cookie_t xcb_query_colors

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint32_t 

pixels_len,

const uint32_t * 

pixels 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_QUERY_COLORS.

xcb_query_colors_reply_t* xcb_query_colors_reply

(

xcb_connection_t * 

c,

xcb_query_colors_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_query_colors_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_query_colors_cookie_t xcb_query_colors_unchecked

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint32_t 

pixels_len,

const uint32_t * 

pixels 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_QUERY_COLORS.

xcb_query_extension_cookie_t xcb_query_extension

(

xcb_connection_t * 

c,

uint16_t 

name_len,

const char * 

name 

)

check if extension is present

Parameters

cThe connection

name_lenThe length of name in bytes.

nameThe name of the extension to query, for example "RANDR". This is case sensitive!

ReturnsA cookie

Determines if the specified extension is present on this X11 server.

Every extension has a unique major_opcode to identify requests, the minor opcodes and request formats are extension-specific. If the extension provides events and errors, the first_event and first_error fields in the reply are set accordingly.

There should rarely be a need to use this request directly, XCB provides the xcb_get_extension_data function instead.

References XCB_QUERY_EXTENSION.

xcb_query_extension_reply_t* xcb_query_extension_reply

(

xcb_connection_t * 

c,

xcb_query_extension_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_query_extension_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

Referenced by xcb_get_extension_data().

xcb_query_extension_cookie_t xcb_query_extension_unchecked

(

xcb_connection_t * 

c,

uint16_t 

name_len,

const char * 

name 

)

check if extension is present

Parameters

cThe connection

name_lenThe length of name in bytes.

nameThe name of the extension to query, for example "RANDR". This is case sensitive!

ReturnsA cookie

Determines if the specified extension is present on this X11 server.

Every extension has a unique major_opcode to identify requests, the minor opcodes and request formats are extension-specific. If the extension provides events and errors, the first_event and first_error fields in the reply are set accordingly.

There should rarely be a need to use this request directly, XCB provides the xcb_get_extension_data function instead.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_QUERY_EXTENSION.

xcb_query_font_cookie_t xcb_query_font

(

xcb_connection_t * 

c,

xcb_fontable_t 

font 

)

query font metrics

Parameters

cThe connection

fontThe fontable (Font or Graphics Context) to query.

ReturnsA cookie

Queries information associated with the font.

References XCB_QUERY_FONT.

xcb_query_font_reply_t* xcb_query_font_reply

(

xcb_connection_t * 

c,

xcb_query_font_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_query_font_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_query_font_cookie_t xcb_query_font_unchecked

(

xcb_connection_t * 

c,

xcb_fontable_t 

font 

)

query font metrics

Parameters

cThe connection

fontThe fontable (Font or Graphics Context) to query.

ReturnsA cookie

Queries information associated with the font.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_fontprop_end(), and XCB_QUERY_FONT.

xcb_query_keymap_cookie_t xcb_query_keymap

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_QUERY_KEYMAP.

xcb_query_keymap_reply_t* xcb_query_keymap_reply

(

xcb_connection_t * 

c,

xcb_query_keymap_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_query_keymap_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_query_keymap_cookie_t xcb_query_keymap_unchecked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_QUERY_KEYMAP.

xcb_query_pointer_cookie_t xcb_query_pointer

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

get pointer coordinates

Parameters

cThe connection

windowA window to check if the pointer is on the same screen as window (see the same_screen field in the reply).

ReturnsA cookie

Gets the root window the pointer is logically on and the pointer coordinates relative to the root window's origin.

References XCB_QUERY_POINTER.

xcb_query_pointer_reply_t* xcb_query_pointer_reply

(

xcb_connection_t * 

c,

xcb_query_pointer_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_query_pointer_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_query_pointer_cookie_t xcb_query_pointer_unchecked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

get pointer coordinates

Parameters

cThe connection

windowA window to check if the pointer is on the same screen as window (see the same_screen field in the reply).

ReturnsA cookie

Gets the root window the pointer is logically on and the pointer coordinates relative to the root window's origin.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_QUERY_POINTER.

xcb_query_text_extents_cookie_t xcb_query_text_extents

(

xcb_connection_t * 

c,

xcb_fontable_t 

font,

uint32_t 

string_len,

const xcb_char2b_t * 

string 

)

get text extents

Parameters

cThe connection

fontThe font to calculate text extents in. You can also pass a graphics context.

string_lenThe number of characters in string.

stringThe text to get text extents for.

ReturnsA cookie

Query text extents from the X11 server. This request returns the bounding box of the specified 16-bit character string in the specified font or the font contained in the specified graphics context.

font_ascent is set to the maximum of the ascent metrics of all characters in the string. font_descent is set to the maximum of the descent metrics. overall_width is set to the sum of the character-width metrics of all characters in the string. For each character in the string, let W be the sum of the character-width metrics of all characters preceding it in the string. Let L be the left-side-bearing metric of the character plus W. Let R be the right-side-bearing metric of the character plus W. The lbearing member is set to the minimum L of all characters in the string. The rbearing member is set to the maximum R.

For fonts defined with linear indexing rather than 2-byte matrix indexing, each xcb_char2b_t structure is interpreted as a 16-bit number with byte1 as the most significant byte. If the font has no defined default character, undefined characters in the string are taken to have all zero metrics.

Characters with all zero metrics are ignored. If the font has no defined default_char, the undefined characters in the string are also ignored.

References XCB_QUERY_TEXT_EXTENTS.

xcb_query_text_extents_reply_t* xcb_query_text_extents_reply

(

xcb_connection_t * 

c,

xcb_query_text_extents_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_query_text_extents_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

xcb_query_text_extents_cookie_t xcb_query_text_extents_unchecked

(

xcb_connection_t * 

c,

xcb_fontable_t 

font,

uint32_t 

string_len,

const xcb_char2b_t * 

string 

)

get text extents

Parameters

cThe connection

fontThe font to calculate text extents in. You can also pass a graphics context.

string_lenThe number of characters in string.

stringThe text to get text extents for.

ReturnsA cookie

Query text extents from the X11 server. This request returns the bounding box of the specified 16-bit character string in the specified font or the font contained in the specified graphics context.

font_ascent is set to the maximum of the ascent metrics of all characters in the string. font_descent is set to the maximum of the descent metrics. overall_width is set to the sum of the character-width metrics of all characters in the string. For each character in the string, let W be the sum of the character-width metrics of all characters preceding it in the string. Let L be the left-side-bearing metric of the character plus W. Let R be the right-side-bearing metric of the character plus W. The lbearing member is set to the minimum L of all characters in the string. The rbearing member is set to the maximum R.

For fonts defined with linear indexing rather than 2-byte matrix indexing, each xcb_char2b_t structure is interpreted as a 16-bit number with byte1 as the most significant byte. If the font has no defined default character, undefined characters in the string are taken to have all zero metrics.

Characters with all zero metrics are ignored. If the font has no defined default_char, the undefined characters in the string are also ignored.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_QUERY_TEXT_EXTENTS.

xcb_query_tree_cookie_t xcb_query_tree

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

query the window tree

Parameters

cThe connection

windowThe window to query.

ReturnsA cookie

Gets the root window ID, parent window ID and list of children windows for the specified window. The children are listed in bottom-to-top stacking order.

References XCB_QUERY_TREE.

xcb_query_tree_reply_t* xcb_query_tree_reply

(

xcb_connection_t * 

c,

xcb_query_tree_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_query_tree_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_query_tree_cookie_t xcb_query_tree_unchecked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

query the window tree

Parameters

cThe connection

windowThe window to query.

ReturnsA cookie

Gets the root window ID, parent window ID and list of children windows for the specified window. The children are listed in bottom-to-top stacking order.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_QUERY_TREE.

xcb_void_cookie_t xcb_recolor_cursor

(

xcb_connection_t * 

c,

xcb_cursor_t 

cursor,

uint16_t 

fore_red,

uint16_t 

fore_green,

uint16_t 

fore_blue,

uint16_t 

back_red,

uint16_t 

back_green,

uint16_t 

back_blue 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_RECOLOR_CURSOR.

xcb_void_cookie_t xcb_recolor_cursor_checked

(

xcb_connection_t * 

c,

xcb_cursor_t 

cursor,

uint16_t 

fore_red,

uint16_t 

fore_green,

uint16_t 

fore_blue,

uint16_t 

back_red,

uint16_t 

back_green,

uint16_t 

back_blue 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_RECOLOR_CURSOR.

xcb_generic_iterator_t xcb_rectangle_end

(

xcb_rectangle_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_rectangle_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_rectangle_next

(

xcb_rectangle_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_rectangle_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_rectangle_t)

xcb_void_cookie_t xcb_reparent_window

(

xcb_connection_t * 

c,

xcb_window_t 

window,

xcb_window_t 

parent,

int16_t 

x,

int16_t 

)

Reparents a window.

Parameters

cThe connection

windowThe window to reparent.

parentThe new parent of the window.

xThe X position of the window within its new parent.

yThe Y position of the window within its new parent.

ReturnsA cookie

Makes the specified window a child of the specified parent window. If the window is mapped, it will automatically be unmapped before reparenting and re-mapped after reparenting. The window is placed in the stacking order on top with respect to sibling windows.

After reparenting, a ReparentNotify event is generated.

References XCB_REPARENT_WINDOW.

xcb_void_cookie_t xcb_reparent_window_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window,

xcb_window_t 

parent,

int16_t 

x,

int16_t 

)

Reparents a window.

Parameters

cThe connection

windowThe window to reparent.

parentThe new parent of the window.

xThe X position of the window within its new parent.

yThe Y position of the window within its new parent.

ReturnsA cookie

Makes the specified window a child of the specified parent window. If the window is mapped, it will automatically be unmapped before reparenting and re-mapped after reparenting. The window is placed in the stacking order on top with respect to sibling windows.

After reparenting, a ReparentNotify event is generated.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_REPARENT_WINDOW.

xcb_generic_iterator_t xcb_rgb_end

(

xcb_rgb_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_rgb_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_rgb_next

(

xcb_rgb_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_rgb_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_rgb_t)

xcb_void_cookie_t xcb_rotate_properties

(

xcb_connection_t * 

c,

xcb_window_t 

window,

uint16_t 

atoms_len,

int16_t 

delta,

const xcb_atom_t * 

atoms 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_ROTATE_PROPERTIES.

xcb_void_cookie_t xcb_rotate_properties_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window,

uint16_t 

atoms_len,

int16_t 

delta,

const xcb_atom_t * 

atoms 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_ROTATE_PROPERTIES.

xcb_generic_iterator_t xcb_screen_end

(

xcb_screen_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_screen_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and xcb_screen_next().

void xcb_screen_next

(

xcb_screen_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_screen_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_screen_t)

References xcb_generic_iterator_t::data.

Referenced by xcb_screen_end().

xcb_generic_iterator_t xcb_segment_end

(

xcb_segment_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_segment_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_segment_next

(

xcb_segment_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_segment_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_segment_t)

xcb_void_cookie_t xcb_send_event

(

xcb_connection_t * 

c,

uint8_t 

propagate,

xcb_window_t 

destination,

uint32_t 

event_mask,

const char * 

event 

)

send an event

Parameters

cThe connection

propagateIf propagate is true and no clients have selected any event on destination, the destination is replaced with the closest ancestor of destination for which some client has selected a type in event_mask and for which no intervening window has that type in its do-not-propagate-mask. If no such window exists or if the window is an ancestor of the focus window and InputFocus was originally specified as the destination, the event is not sent to any clients. Otherwise, the event is reported to every client selecting on the final destination any of the types specified in event_mask.

destinationThe window to send this event to. Every client which selects any event within event_mask on destination will get the event.

The special value XCB_SEND_EVENT_DEST_POINTER_WINDOW refers to the window that contains the mouse pointer.

The special value XCB_SEND_EVENT_DEST_ITEM_FOCUS refers to the window which has the keyboard focus.

event_maskEvent_mask for determining which clients should receive the specified event. See destination and propagate.

eventThe event to send to the specified destination.

ReturnsA cookie

Identifies the destination window, determines which clients should receive the specified event and ignores any active grabs.

The event must be one of the core events or an event defined by an extension, so that the X server can correctly byte-swap the contents as necessary. The contents of event are otherwise unaltered and unchecked except for the send_event field which is forced to 'true'.

References XCB_SEND_EVENT.

xcb_void_cookie_t xcb_send_event_checked

(

xcb_connection_t * 

c,

uint8_t 

propagate,

xcb_window_t 

destination,

uint32_t 

event_mask,

const char * 

event 

)

send an event

Parameters

cThe connection

propagateIf propagate is true and no clients have selected any event on destination, the destination is replaced with the closest ancestor of destination for which some client has selected a type in event_mask and for which no intervening window has that type in its do-not-propagate-mask. If no such window exists or if the window is an ancestor of the focus window and InputFocus was originally specified as the destination, the event is not sent to any clients. Otherwise, the event is reported to every client selecting on the final destination any of the types specified in event_mask.

destinationThe window to send this event to. Every client which selects any event within event_mask on destination will get the event.

The special value XCB_SEND_EVENT_DEST_POINTER_WINDOW refers to the window that contains the mouse pointer.

The special value XCB_SEND_EVENT_DEST_ITEM_FOCUS refers to the window which has the keyboard focus.

event_maskEvent_mask for determining which clients should receive the specified event. See destination and propagate.

eventThe event to send to the specified destination.

ReturnsA cookie

Identifies the destination window, determines which clients should receive the specified event and ignores any active grabs.

The event must be one of the core events or an event defined by an extension, so that the X server can correctly byte-swap the contents as necessary. The contents of event are otherwise unaltered and unchecked except for the send_event field which is forced to 'true'.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_SEND_EVENT.

xcb_void_cookie_t xcb_set_access_control

(

xcb_connection_t * 

c,

uint8_t 

mode 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_SET_ACCESS_CONTROL.

xcb_void_cookie_t xcb_set_access_control_checked

(

xcb_connection_t * 

c,

uint8_t 

mode 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_SET_ACCESS_CONTROL.

xcb_void_cookie_t xcb_set_clip_rectangles

(

xcb_connection_t * 

c,

uint8_t 

ordering,

xcb_gcontext_t 

gc,

int16_t 

clip_x_origin,

int16_t 

clip_y_origin,

uint32_t 

rectangles_len,

const xcb_rectangle_t * 

rectangles 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_SET_CLIP_RECTANGLES.

xcb_void_cookie_t xcb_set_clip_rectangles_checked

(

xcb_connection_t * 

c,

uint8_t 

ordering,

xcb_gcontext_t 

gc,

int16_t 

clip_x_origin,

int16_t 

clip_y_origin,

uint32_t 

rectangles_len,

const xcb_rectangle_t * 

rectangles 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_SET_CLIP_RECTANGLES.

xcb_void_cookie_t xcb_set_close_down_mode

(

xcb_connection_t * 

c,

uint8_t 

mode 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_SET_CLOSE_DOWN_MODE.

xcb_void_cookie_t xcb_set_close_down_mode_checked

(

xcb_connection_t * 

c,

uint8_t 

mode 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_SET_CLOSE_DOWN_MODE.

xcb_void_cookie_t xcb_set_dashes

(

xcb_connection_t * 

c,

xcb_gcontext_t 

gc,

uint16_t 

dash_offset,

uint16_t 

dashes_len,

const uint8_t * 

dashes 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_SET_DASHES.

xcb_void_cookie_t xcb_set_dashes_checked

(

xcb_connection_t * 

c,

xcb_gcontext_t 

gc,

uint16_t 

dash_offset,

uint16_t 

dashes_len,

const uint8_t * 

dashes 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_SET_DASHES.

xcb_void_cookie_t xcb_set_font_path

(

xcb_connection_t * 

c,

uint16_t 

font_qty,

const xcb_str_t * 

font 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_SET_FONT_PATH.

xcb_void_cookie_t xcb_set_font_path_checked

(

xcb_connection_t * 

c,

uint16_t 

font_qty,

const xcb_str_t * 

font 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_SET_FONT_PATH.

xcb_void_cookie_t xcb_set_input_focus

(

xcb_connection_t * 

c,

uint8_t 

revert_to,

xcb_window_t 

focus,

xcb_timestamp_t 

time 

)

Sets input focus.

Parameters

cThe connection

revert_toA bitmask of xcb_input_focus_t values.

revert_toSpecifies what happens when the focus window becomes unviewable (if focus is neither XCB_NONE nor XCB_POINTER_ROOT).

focusThe window to focus. All keyboard events will be reported to this window. The window must be viewable (TODO), or a xcb_match_error_t occurs (TODO).

If focus is XCB_NONE (TODO), all keyboard events are discarded until a new focus window is set.

If focus is XCB_POINTER_ROOT (TODO), focus is on the root window of the screen on which the pointer is on currently.

timeTimestamp to avoid race conditions when running X over the network.

The special value XCB_CURRENT_TIME will be replaced with the current server time.

ReturnsA cookie

Changes the input focus and the last-focus-change time. If the specified time is earlier than the current last-focus-change time, the request is ignored (to avoid race conditions when running X over the network).

A FocusIn and FocusOut event is generated when focus is changed.

References XCB_SET_INPUT_FOCUS.

xcb_void_cookie_t xcb_set_input_focus_checked

(

xcb_connection_t * 

c,

uint8_t 

revert_to,

xcb_window_t 

focus,

xcb_timestamp_t 

time 

)

Sets input focus.

Parameters

cThe connection

revert_toA bitmask of xcb_input_focus_t values.

revert_toSpecifies what happens when the focus window becomes unviewable (if focus is neither XCB_NONE nor XCB_POINTER_ROOT).

focusThe window to focus. All keyboard events will be reported to this window. The window must be viewable (TODO), or a xcb_match_error_t occurs (TODO).

If focus is XCB_NONE (TODO), all keyboard events are discarded until a new focus window is set.

If focus is XCB_POINTER_ROOT (TODO), focus is on the root window of the screen on which the pointer is on currently.

timeTimestamp to avoid race conditions when running X over the network.

The special value XCB_CURRENT_TIME will be replaced with the current server time.

ReturnsA cookie

Changes the input focus and the last-focus-change time. If the specified time is earlier than the current last-focus-change time, the request is ignored (to avoid race conditions when running X over the network).

A FocusIn and FocusOut event is generated when focus is changed.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_SET_INPUT_FOCUS.

xcb_set_modifier_mapping_cookie_t xcb_set_modifier_mapping

(

xcb_connection_t * 

c,

uint8_t 

keycodes_per_modifier,

const xcb_keycode_t * 

keycodes 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_SET_MODIFIER_MAPPING.

xcb_set_modifier_mapping_reply_t* xcb_set_modifier_mapping_reply

(

xcb_connection_t * 

c,

xcb_set_modifier_mapping_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_set_modifier_mapping_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_set_modifier_mapping_cookie_t xcb_set_modifier_mapping_unchecked

(

xcb_connection_t * 

c,

uint8_t 

keycodes_per_modifier,

const xcb_keycode_t * 

keycodes 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_SET_MODIFIER_MAPPING.

xcb_set_pointer_mapping_cookie_t xcb_set_pointer_mapping

(

xcb_connection_t * 

c,

uint8_t 

map_len,

const uint8_t * 

map 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_SET_POINTER_MAPPING.

xcb_set_pointer_mapping_reply_t* xcb_set_pointer_mapping_reply

(

xcb_connection_t * 

c,

xcb_set_pointer_mapping_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_set_pointer_mapping_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_set_pointer_mapping_cookie_t xcb_set_pointer_mapping_unchecked

(

xcb_connection_t * 

c,

uint8_t 

map_len,

const uint8_t * 

map 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_SET_POINTER_MAPPING.

xcb_void_cookie_t xcb_set_screen_saver

(

xcb_connection_t * 

c,

int16_t 

timeout,

int16_t 

interval,

uint8_t 

prefer_blanking,

uint8_t 

allow_exposures 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_SET_SCREEN_SAVER.

xcb_void_cookie_t xcb_set_screen_saver_checked

(

xcb_connection_t * 

c,

int16_t 

timeout,

int16_t 

interval,

uint8_t 

prefer_blanking,

uint8_t 

allow_exposures 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_SET_SCREEN_SAVER.

xcb_void_cookie_t xcb_set_selection_owner

(

xcb_connection_t * 

c,

xcb_window_t 

owner,

xcb_atom_t 

selection,

xcb_timestamp_t 

time 

)

Sets the owner of a selection.

Parameters

cThe connection

ownerThe new owner of the selection.

The special value XCB_NONE means that the selection will have no owner.

selectionThe selection.

timeTimestamp to avoid race conditions when running X over the network.

The selection will not be changed if time is earlier than the current last-change time of the selection or is later than the current X server time. Otherwise, the last-change time is set to the specified time.

The special value XCB_CURRENT_TIME will be replaced with the current server time.

ReturnsA cookie

Makes window the owner of the selection selection and updates the last-change time of the specified selection.

TODO: briefly explain what a selection is.

References XCB_SET_SELECTION_OWNER.

xcb_void_cookie_t xcb_set_selection_owner_checked

(

xcb_connection_t * 

c,

xcb_window_t 

owner,

xcb_atom_t 

selection,

xcb_timestamp_t 

time 

)

Sets the owner of a selection.

Parameters

cThe connection

ownerThe new owner of the selection.

The special value XCB_NONE means that the selection will have no owner.

selectionThe selection.

timeTimestamp to avoid race conditions when running X over the network.

The selection will not be changed if time is earlier than the current last-change time of the selection or is later than the current X server time. Otherwise, the last-change time is set to the specified time.

The special value XCB_CURRENT_TIME will be replaced with the current server time.

ReturnsA cookie

Makes window the owner of the selection selection and updates the last-change time of the specified selection.

TODO: briefly explain what a selection is.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_SET_SELECTION_OWNER.

xcb_generic_iterator_t xcb_setup_authenticate_end

(

xcb_setup_authenticate_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_setup_authenticate_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, xcb_format_end(), and xcb_setup_authenticate_next().

void xcb_setup_authenticate_next

(

xcb_setup_authenticate_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_setup_authenticate_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_setup_authenticate_t)

References xcb_generic_iterator_t::data.

Referenced by xcb_setup_authenticate_end().

xcb_generic_iterator_t xcb_setup_end

(

xcb_setup_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_setup_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and xcb_setup_next().

xcb_generic_iterator_t xcb_setup_failed_end

(

xcb_setup_failed_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_setup_failed_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and xcb_setup_failed_next().

void xcb_setup_failed_next

(

xcb_setup_failed_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_setup_failed_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_setup_failed_t)

References xcb_generic_iterator_t::data.

Referenced by xcb_setup_failed_end().

void xcb_setup_next

(

xcb_setup_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_setup_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_setup_t)

References xcb_generic_iterator_t::data.

Referenced by xcb_setup_end().

xcb_generic_iterator_t xcb_setup_request_end

(

xcb_setup_request_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_setup_request_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and xcb_setup_request_next().

void xcb_setup_request_next

(

xcb_setup_request_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_setup_request_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_setup_request_t)

References xcb_generic_iterator_t::data.

Referenced by xcb_setup_request_end().

xcb_void_cookie_t xcb_store_colors

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint32_t 

items_len,

const xcb_coloritem_t * 

items 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_STORE_COLORS.

xcb_void_cookie_t xcb_store_colors_checked

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap,

uint32_t 

items_len,

const xcb_coloritem_t * 

items 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_STORE_COLORS.

xcb_void_cookie_t xcb_store_named_color

(

xcb_connection_t * 

c,

uint8_t 

flags,

xcb_colormap_t 

cmap,

uint32_t 

pixel,

uint16_t 

name_len,

const char * 

name 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and XCB_STORE_NAMED_COLOR.

xcb_void_cookie_t xcb_store_named_color_checked

(

xcb_connection_t * 

c,

uint8_t 

flags,

xcb_colormap_t 

cmap,

uint32_t 

pixel,

uint16_t 

name_len,

const char * 

name 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_STORE_NAMED_COLOR.

xcb_generic_iterator_t xcb_str_end

(

xcb_str_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_str_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, xcb_generic_iterator_t::rem, and xcb_str_next().

void xcb_str_next

(

xcb_str_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_str_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_str_t)

References xcb_generic_iterator_t::data.

Referenced by xcb_str_end().

xcb_generic_iterator_t xcb_timecoord_end

(

xcb_timecoord_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_timecoord_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_timecoord_next

(

xcb_timecoord_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_timecoord_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_timecoord_t)

xcb_generic_iterator_t xcb_timestamp_end

(

xcb_timestamp_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_timestamp_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_timestamp_next

(

xcb_timestamp_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_timestamp_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_timestamp_t)

xcb_translate_coordinates_cookie_t xcb_translate_coordinates

(

xcb_connection_t * 

c,

xcb_window_t 

src_window,

xcb_window_t 

dst_window,

int16_t 

src_x,

int16_t 

src_y 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_TRANSLATE_COORDINATES.

xcb_translate_coordinates_reply_t* xcb_translate_coordinates_reply

(

xcb_connection_t * 

c,

xcb_translate_coordinates_cookie_t 

cookie,

xcb_generic_error_t ** 

)

Return the reply Parameters

cThe connection

cookieThe cookie

eThe xcb_generic_error_t supplied

Returns the reply of the request asked by

The parameter e supplied to this function must be NULL if xcb_translate_coordinates_unchecked(). is used. Otherwise, it stores the error if any.

The returned value must be freed by the caller using free().

xcb_translate_coordinates_cookie_t xcb_translate_coordinates_unchecked

(

xcb_connection_t * 

c,

xcb_window_t 

src_window,

xcb_window_t 

dst_window,

int16_t 

src_x,

int16_t 

src_y 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will cause a reply to be generated. Any returned error will be placed in the event queue.

References XCB_TRANSLATE_COORDINATES.

xcb_void_cookie_t xcb_ungrab_button

(

xcb_connection_t * 

c,

uint8_t 

button,

xcb_window_t 

grab_window,

uint16_t 

modifiers 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_UNGRAB_BUTTON.

xcb_void_cookie_t xcb_ungrab_button_checked

(

xcb_connection_t * 

c,

uint8_t 

button,

xcb_window_t 

grab_window,

uint16_t 

modifiers 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_UNGRAB_BUTTON.

xcb_void_cookie_t xcb_ungrab_key

(

xcb_connection_t * 

c,

xcb_keycode_t 

key,

xcb_window_t 

grab_window,

uint16_t 

modifiers 

)

release a key combination

Parameters

cThe connection

keyThe keycode of the specified key combination.

Using the special value XCB_GRAB_ANY means releasing all possible key codes.

grab_windowThe window on which the grabbed key combination will be released.

modifiersThe modifiers of the specified key combination.

Using the special value XCB_MOD_MASK_ANY means releasing the key combination with every possible modifier combination.

ReturnsA cookie

Releases the key combination on grab_window if you grabbed it using xcb_grab_key before.

References XCB_UNGRAB_KEY.

xcb_void_cookie_t xcb_ungrab_key_checked

(

xcb_connection_t * 

c,

xcb_keycode_t 

key,

xcb_window_t 

grab_window,

uint16_t 

modifiers 

)

release a key combination

Parameters

cThe connection

keyThe keycode of the specified key combination.

Using the special value XCB_GRAB_ANY means releasing all possible key codes.

grab_windowThe window on which the grabbed key combination will be released.

modifiersThe modifiers of the specified key combination.

Using the special value XCB_MOD_MASK_ANY means releasing the key combination with every possible modifier combination.

ReturnsA cookie

Releases the key combination on grab_window if you grabbed it using xcb_grab_key before.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_UNGRAB_KEY.

xcb_void_cookie_t xcb_ungrab_keyboard

(

xcb_connection_t * 

c,

xcb_timestamp_t 

time 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_UNGRAB_KEYBOARD.

xcb_void_cookie_t xcb_ungrab_keyboard_checked

(

xcb_connection_t * 

c,

xcb_timestamp_t 

time 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_UNGRAB_KEYBOARD.

xcb_void_cookie_t xcb_ungrab_pointer

(

xcb_connection_t * 

c,

xcb_timestamp_t 

time 

)

release the pointer

Parameters

cThe connection

timeTimestamp to avoid race conditions when running X over the network.

The pointer will not be released if time is earlier than the last-pointer-grab time or later than the current X server time.

ReturnsA cookie

Releases the pointer and any queued events if you actively grabbed the pointer before using xcb_grab_pointer, xcb_grab_button or within a normal button press.

EnterNotify and LeaveNotify events are generated.

References XCB_UNGRAB_POINTER.

xcb_void_cookie_t xcb_ungrab_pointer_checked

(

xcb_connection_t * 

c,

xcb_timestamp_t 

time 

)

release the pointer

Parameters

cThe connection

timeTimestamp to avoid race conditions when running X over the network.

The pointer will not be released if time is earlier than the last-pointer-grab time or later than the current X server time.

ReturnsA cookie

Releases the pointer and any queued events if you actively grabbed the pointer before using xcb_grab_pointer, xcb_grab_button or within a normal button press.

EnterNotify and LeaveNotify events are generated.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_UNGRAB_POINTER.

xcb_void_cookie_t xcb_ungrab_server

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_UNGRAB_SERVER.

xcb_void_cookie_t xcb_ungrab_server_checked

(

xcb_connection_t * 

c)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_UNGRAB_SERVER.

xcb_void_cookie_t xcb_uninstall_colormap

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_UNINSTALL_COLORMAP.

xcb_void_cookie_t xcb_uninstall_colormap_checked

(

xcb_connection_t * 

c,

xcb_colormap_t 

cmap 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_UNINSTALL_COLORMAP.

xcb_void_cookie_t xcb_unmap_subwindows

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

References XCB_UNMAP_SUBWINDOWS.

xcb_void_cookie_t xcb_unmap_subwindows_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Parameters

cThe connection

ReturnsA cookie

Delivers a request to the X server.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_UNMAP_SUBWINDOWS.

xcb_void_cookie_t xcb_unmap_window

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Makes a window invisible.

Parameters

cThe connection

windowThe window to make invisible.

ReturnsA cookie

Unmaps the specified window. This means making the window invisible (and all its child windows).

Unmapping a window leads to the UnmapNotify event being generated. Also, Expose events are generated for formerly obscured windows.

References XCB_UNMAP_WINDOW.

xcb_void_cookie_t xcb_unmap_window_checked

(

xcb_connection_t * 

c,

xcb_window_t 

window 

)

Makes a window invisible.

Parameters

cThe connection

windowThe window to make invisible.

ReturnsA cookie

Unmaps the specified window. This means making the window invisible (and all its child windows).

Unmapping a window leads to the UnmapNotify event being generated. Also, Expose events are generated for formerly obscured windows.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_UNMAP_WINDOW.

xcb_generic_iterator_t xcb_visualid_end

(

xcb_visualid_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_visualid_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_visualid_next

(

xcb_visualid_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_visualid_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_visualid_t)

xcb_generic_iterator_t xcb_visualtype_end

(

xcb_visualtype_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_visualtype_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_visualtype_next

(

xcb_visualtype_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_visualtype_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_visualtype_t)

xcb_void_cookie_t xcb_warp_pointer

(

xcb_connection_t * 

c,

xcb_window_t 

src_window,

xcb_window_t 

dst_window,

int16_t 

src_x,

int16_t 

src_y,

uint16_t 

src_width,

uint16_t 

src_height,

int16_t 

dst_x,

int16_t 

dst_y 

)

move mouse pointer

Parameters

cThe connection

src_windowIf src_window is not XCB_NONE (TODO), the move will only take place if the pointer is inside src_window and within the rectangle specified by (src_x, src_y, src_width, src_height). The rectangle coordinates are relative to src_window.

dst_windowIf dst_window is not XCB_NONE (TODO), the pointer will be moved to the offsets (dst_x, dst_y) relative to dst_window. If dst_window is XCB_NONE (TODO), the pointer will be moved by the offsets (dst_x, dst_y) relative to the current position of the pointer.

ReturnsA cookie

Moves the mouse pointer to the specified position.

If src_window is not XCB_NONE (TODO), the move will only take place if the pointer is inside src_window and within the rectangle specified by (src_x, src_y, src_width, src_height). The rectangle coordinates are relative to src_window.

If dst_window is not XCB_NONE (TODO), the pointer will be moved to the offsets (dst_x, dst_y) relative to dst_window. If dst_window is XCB_NONE (TODO), the pointer will be moved by the offsets (dst_x, dst_y) relative to the current position of the pointer.

References XCB_WARP_POINTER.

xcb_void_cookie_t xcb_warp_pointer_checked

(

xcb_connection_t * 

c,

xcb_window_t 

src_window,

xcb_window_t 

dst_window,

int16_t 

src_x,

int16_t 

src_y,

uint16_t 

src_width,

uint16_t 

src_height,

int16_t 

dst_x,

int16_t 

dst_y 

)

move mouse pointer

Parameters

cThe connection

src_windowIf src_window is not XCB_NONE (TODO), the move will only take place if the pointer is inside src_window and within the rectangle specified by (src_x, src_y, src_width, src_height). The rectangle coordinates are relative to src_window.

dst_windowIf dst_window is not XCB_NONE (TODO), the pointer will be moved to the offsets (dst_x, dst_y) relative to dst_window. If dst_window is XCB_NONE (TODO), the pointer will be moved by the offsets (dst_x, dst_y) relative to the current position of the pointer.

ReturnsA cookie

Moves the mouse pointer to the specified position.

If src_window is not XCB_NONE (TODO), the move will only take place if the pointer is inside src_window and within the rectangle specified by (src_x, src_y, src_width, src_height). The rectangle coordinates are relative to src_window.

If dst_window is not XCB_NONE (TODO), the pointer will be moved to the offsets (dst_x, dst_y) relative to dst_window. If dst_window is XCB_NONE (TODO), the pointer will be moved by the offsets (dst_x, dst_y) relative to the current position of the pointer.

This form can be used only if the request will not cause a reply to be generated. Any returned error will be saved for handling by xcb_request_check().

References XCB_WARP_POINTER.

xcb_generic_iterator_t xcb_window_end

(

xcb_window_iterator_t 

i)

Return the iterator pointing to the last element Parameters

iAn xcb_window_iterator_t

ReturnsThe iterator pointing to the last element

Set the current element in the iterator to the last element. The member rem is set to 0. The member data points to the last element.

References xcb_generic_iterator_t::data, xcb_generic_iterator_t::index, and xcb_generic_iterator_t::rem.

void xcb_window_next

(

xcb_window_iterator_t * 

i)

Get the next element of the iterator Parameters

iPointer to a xcb_window_iterator_t

Get the next element in the iterator. The member rem is decreased by one. The member data points to the next element. The member index is increased by sizeof(xcb_window_t)

Generated by  

1.8.11

Linux XCB_xcb gtk qt-CSDN博客

>

Linux XCB_xcb gtk qt-CSDN博客

Linux XCB

最新推荐文章于 2024-03-06 15:27:44 发布

顺其自然~

最新推荐文章于 2024-03-06 15:27:44 发布

阅读量1.7k

收藏

5

点赞数

文章标签:

linux

运维

服务器

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/fuhanghang/article/details/130129691

版权

X协议的c语言绑定(XCB: The X protocol C-language Binding) 是一种替代Xlib具有占用空间小,延迟隐藏,直接访问协议,提高线程的支持,和可扩展性。

基本的窗口和绘制(basicwindowsanddrawing)事件(events)文本和字体(fonts)窗口的内容和操作(windowcontextandmanipulation)颜色和像素地图(https://xcb.freedesktop.org/colorsandpixmaps/)鼠标光标(mousecursors)Xlib 到XCB的翻译引导(xlibtoxcbtranslationguide)

介绍

这个手册是用来介绍给想用XCB library进行编程需要的人们。 像使用Xlib library来使用XCB,因为不是大多数的编程人员都想要写X的应用程序。而更多的开发者是想使用更高级的GUI 开发工具,如Motif,LessTiff,GTK,Qt,EWL,or ETK 或者更高级的使用library Cairo来进行绘制。虽然, 不是所有的XCB的基础都很复杂,了其他一些库的上层的东西也不是坏事。

在读完这个手册之后,一个人可以写简单图形程序而不是好看的图形界面(至少是相对简单的)。在写应用程序之前,这个先前的关于上面库的了解是更有必要的。

什么是XCB,为什么它为存在?

XCB("X C Bing")是一个低级的api给X window server。 XCB是Xlib的一个替代产物,Xlib曾是多年以来标准的C绑定的给X Window System 协议的库。Xlib表现得很优秀,但是对于应用程序来说也有很多不理想的地方,例如:

小平台: Xlib包含在大段的代码,精简起来十分困难延迟隐藏:Xlib需要有效的同步回复:他们会一直阻塞直到获取到结果,不管这个结果是否立即需要直接访问协议:Xlib需要大量的缓存,层和相似的优化。由于这个通性,它很难简单的发出特定的X 协议请求和处理特定的响应线程化应用程序:Xlib尽量会支持多线程,它的api的容错性较差新的扩展:Xlib的底部架构提供了有限的支持给新的X的扩展客户端代码。

XCB被设计用来解决上述的问题,目前已经解决的有:

工具包的实现直接进行协议级的编程轻量级的调用常用的Xlib api.

Xcb 的全称是 X 协议 C 库,它是一种让在 X Window 活动图形框架中的 Linux 中的程序更易于使用。Xcb 是一种为原生 X 协议提供一个高级接口的库。它允许用户使用函数调用,而不是手动构造消息来访问 X 协议。Xcb 的特点是它是轻量级的,低维护,运行速度快。Xcb 使用在链接器中编译的函数库来缩短天生 X 协议消息的小编程意味,它让用户可以不必担心包装 X 协议消息的技术细节。

在开始使用 Xcb 之前,我们需要一种方法来安装它。如果你使用的是 Ubuntu,你可以使用下面的命令来安装:

“`bash

sudo apt-get install libxcb1-dev

安装之后,我们就可以开始使用 Xcb。要想创建图形界面,我们首先需要做的就是创建 xcb 的连接:

```C

xcb_connection_t *conn = xcb_connect(NULL, NULL);

 连接建立之后,我们还需要获取窗口:

“`C

xcb_window_t window = xcb_generate_id(conn);

uint32_t value_list[] = {600, 400};

xcb_create_window(conn,

XCB_COPY_FROM_PARENT,

window,

screen->root,

0, 0,

value_list[0], value_list[1],

0,

XCB_WINDOW_CLASS_INPUT_OUTPUT,

screen->root_visual,

0, NULL );

在窗口创建之后,我们需要把它显示在屏幕上:

```C

xcb_map_window(conn, window);

xcb_flush(conn);

经过以上操作,我们就创建了一个空白窗口。现在,如果我们想要把它绘制成我们想要的样子,我们可以使用 Xcb 的一些其他功能。

另一种在 Linux 中开发图形界面的方法是使用 Qt。Qt 是一个开源的 C++ 框架,它的优势在于它的易用性,以及它的强大的图形功能。此外,它还支持跨平台开发,因此也被用作在 Linux 下开发图形界面的工具。

优惠劵

顺其自然~

关注

关注

0

点赞

5

收藏

觉得还不错?

一键收藏

打赏

知道了

0

评论

Linux XCB

而更多的开发者是想使用更高级的GUI 开发工具,如Motif,LessTiff,GTK,Qt,EWL,or ETK 或者更高级的使用library Cairo来进行绘制。Qt 是一个开源的 C++ 框架,它的优势在于它的易用性,以及它的强大的图形功能。XCB是Xlib的一个替代产物,Xlib曾是多年以来标准的C绑定的给X Window System 协议的库。Xcb 的全称是 X 协议 C 库,它是一种让在 X Window 活动图形框架中的 Linux 中的程序更易于使用。什么是XCB,为什么它为存在?

复制链接

扫一扫

xcb-util-0.4.0-2.el7.x86_64.rpm

11-30

离线安装包,亲测可用

x11 gtk qt gnome kde 之间的区别和联系

weixin_55163060的博客

08-12

1195

x11 gtk qt gnome kde 之间的区别和联系

x11 gtk qt gnome kde 之间的区别和联系

x11 gtk qt gnome kde 之间的区别和联系

参与评论

您还未登录,请先

登录

后发表或查看评论

【ARM开发】交叉编译Qt源码之(4)添加xcb支持

console_log的博客

02-16

5163

Debian 9

1、依赖

Qt源码添加xcb支持,依赖xcb-util-wm、xcb-util、xcb-util-image、xcb-util-keysyms、xcb-util-renderutil、libxkbcommon,其中libxkbcommon依赖libxml。

1.1、xcb-util-wm

下载地址:Index of /releases/individual/xcbhttps://www.x.org/releases/individual/xcb/

#解压

tar -zxvf x

XCB tutorial

热门推荐

01-18

5万+

tutorial (xcb.freedesktop.org)

Introduction

Most application developers will want to use a much higher-level GUI toolkit, like Motif, LessTiff, GTK, Qt, EWL, or ETK or perhaps use the higher-level drawing library Cairo. However, knowing about the layers

linux 原生迅雷

10-21

运行环境要求

硬件:

x86或x64 CPU

下载文件夹所在卷容量大于4G

软件:

Linux 32位或64位x86系列CPU

Python3 >= 3.4

Py3.PyQt5 >= 5.2

详细的软件依赖参见发行版的打包文件。

其它:

拥有迅雷账户(会员/非会员均可)

许可证

GPLv3 -- Xware Desktop部分

迅雷协议 -- Xware部分

新增64位版本(迅雷下载核心1.0.31):

附件:

xware-desktop_0.13.20141115_amd64.deb [1.71 MiB]

被下载 2099 次

Xware Desktop已打包,64位打包系统是kubuntu15.04,凡是64位的ubuntu15.04系,应该都能用.

迅雷版本是1.0.31,包含数个linux原生二进制程序,建议双击安装包进行安装,它还要额外的pyQt5图形库,会自动从ubuntu仓库下载.

第一次先不要登陆,先要设置.启动迅雷软件->菜单栏->文件->设置

->挂载->添加下载目录,比如我的是/home/name/download.

->启动与登陆->xwared托管->我们选systemd托管,ETM选随xwared启动

至此设置告一段落.重启PC后,如下图会有两个迅雷的原生进程:

附件:

thunder.png

thunder.png [ 23.98 KiB | 被浏览 52484 次 ]

在我的kubuntu开始菜单的因特网子菜单里会有个xwared Desktop的迅雷图标,点击它就能启动迅雷了.

第一次登陆后会有激活码,点一下即可成功.

就能跟windows里的迅雷7一样用啦,速度嘛,跟windows完全一样,免费用户同样没有高速通道,要vip才能用.

32位迅雷下载核心更新至1.0.25

附件:

xware-desktop_0.10.20140702_i386.deb [1.61 MiB]

被下载 7829 次

当然,有能力的同学可以自行编译,在Ubuntu上编译安装说明如下 :

编译环境:

安装必备的软件。

sudo apt-get install git build-essential devscripts

下载源代码。

git clone git://github.com/Xinkai/XwareDesktop.git

这会在当前目录下生成一个名为XwareDesktop的子目录。

切换到源代码目录XwareDesktop。

cd XwareDesktop

打包

你需要切换到XwareDesktop的源代码目录。

列出缺失的编译依赖。

dpkg-checkbuilddeps。

如果没有列出任何东西,跳过步骤2。

安装缺失的编译依赖。

sudo apt-get install

制作安装包。

dpkg-buildpackage

执行这条命令后会在你当前目录下生成数个包,其中包括xware-desktop_??????.deb安装包。

安装

回到图形化界面,在XwareDesktop的源代码目录的上级目录,你应该能找到名为xware-desktop_??????.deb的安装包文件, 双击它,按提示安装。

浏览器扩展整合

Xware Desktop接受来自命令行的参数作为新任务的网址,格式为

xware-desktop http://www.website.com/file1 ftp://www.website.com/file2 ...

以Firefox上的Flashgot为例,打开其选项。添加一个新的下载器,程序设置为xware-desktop,参数设置为[URL]。

来自命令行的参数支持http,https,ftp,ed2k,magnet,flashget,qqdl,thunder等多种协议, 也同样支持本地的torrent文件。

注:本软件同linux版115网盘存在冲突,出现如下提示:

This application failed to start because it could not find or load the Qt platform plugin "xcb".

Reinstalling the application may fix this problem.

Linux系统中,安装软件时候遇到错误提示xcb问题解决方案

veryhappy1979的专栏

05-05

1929

(3)、debian系linux系统中缺少:libxcb-xinerama.so.0,使用命令安装:sudo apt-get install libxcb-xinerama0。cenntos系统中缺少:libxkbcommon-x11.so.0,使用命令安装:yum -y install libxkbcommon-x11-devel。出现xcb问题,主要是因为安装pyqt5后,缺少一些链接库,通过一下方法定位到缺少的链接库,安装上就可以了。两种方案都可以解决问题。

什么是XCB

Alex Xu's blog

01-27

1万+



简单看了下XCB的功能,作用,大致总结如下,不知道是否正确。暂时如此理解吧。


XCB

是用来替代Xlib。当期Xlib实际是调用XCB。
XCB最大的特征是可以自动生成X协议的c语言绑定。
XLIB/XCB

就是用XML文件描述的x协议,并生成x协议的c语言绑定

x程序 Linux,使用XCB编写X Window程序(01):快速起步

weixin_35715402的博客

05-03

3453

估计现在已经没有谁使用XCB这么底层的库写应用程序了,要用也是用经过精心封装的Motif, LessTiff, GTK, Qt, EWL, ETK或者Cairo等高层次的库。我之所以这么费心地去折腾XCB,其实主要也是为了学习。毕竟,使用最接近底层的UI库写代码是学习X协议及GUI编程原理的最好方法。XCB的主要教程可以参考这里:http://xcb.freedesktop.org/tutori...

Linux系统关于Qt platform plugin “xcb“缺失的解决

weixin_39284111的博客

08-07

2万+

之前在Debian10.0系统中安装图形库(如QT)相关时出现xcb缺失、xinerama缺失的问题。

qt.qpa.plugin: Could not load the Qt platform plugin "xcb" in "" even though it was found.

libxcb-xinerama.so.0: cannot open shared object file: No such file or directory

在~/.bashrc中添加QT_DEBUG_PLUGINS在编译

Linux下源码编译安装新版libxcb

luoyayun361的专栏

07-05

8382

前言

上一篇文章提到,linux 下编译Qt源码如果要用到Quick的话,那么运行时会依赖qxcb库,而编译生成qxcb库就需要先安装libxcb,并且最低要求 版本大于1.9.1

Requires libxcb >= 1.9.1.

所以,本篇中主要介绍如何通过源码编译安装最新版的xcb库。

为啥一定要用源码编译安装呢,其实在命令行通过apt-get install 同样可以安装xcb,而且方便快捷,这样确实可以安装,但是不能保证是最新版。

下载源码

首先在这里下载源码:https://xcb.fr

BMenu:基于xcb的linux简单单机菜单

07-01

菜单

一个基于 xcb 的简单、灵活、独立的 linux 饼图菜单。

安装

构建二进制文件。

make

创建配置文件

.config/BMenu/BMenurc

用法

映射到要运行的热键并将文件输出通过管道传输到。 例子:

BMenu | bmenu_out

然后,您可以使用这些命令(使用 bash 脚本)来运行程序,或者做一些奇特的事情。

句法

调试

只需在终端中运行BMenu并查看输出。

选项

请参阅样本配置文件BMenurc和样本bash脚本BMenubash在config/BMenu 。

去做

让它发挥作用。

错误

它目前不起作用。

libxcb-1.14.tar.gz

11-26

X 协议 C 语言绑定 (XCB) 是 Xlib 的替代品,具有占用空间小、隐藏延迟、直接访问协议、改进的线程支持和可扩展性等特点。

xcb-proto-1.13.tar.gz

09-30

xcb-proto-1.13.tar.gz的源码,交叉编译通过,亲测可用

xcb-util-wm-0.4.1-5.el7.x86_64.rpm

11-30

离线安装包,亲测可用

qt程序在linux下发布

08-21

qt程序在linux下发布,特别是QT5的程序发布,解决这个错误,Failed to load platform plugin “xcb”. Available platforms are: Aborted(core dumped)

Linux下mysql添加用户并授权数据库权限

beautifulmemory的博客

03-06

196

在 Linux 下,你可以使用 MySQL 的 root 用户登录到 MySQL 数据库,然后通过 SQL 命令来添加新用户并授予数据库权限。

【Linux】Linux的管道与重定向

AliceNo的博客

03-02

951

在Linux系统中,管道和重定向是使命令行操作更为灵活和高效的关键工具。通过管道,我们可以将一个命令的输出作为另一个命令的输入,实现命令之间的连接和协作。而重定向则允许我们将命令的输入和输出从默认位置进行定向,使得我们能够轻松地将结果保存到文件中或者从文件中读取输入。本文将详细探讨这两个重要概念,并演示它们在日常Linux命令行操作中的应用。管道和重定向是Linux命令行中的两个强大而灵活的工具,它们为用户提供了处理和操作命令输入输出的便利方式。

linux-rpm命令

最新发布

weixin_44654338的博客

03-06

154

rpm命令管理程序包:安装、升级、卸载、查询和校验。1、忽略依赖关系安装/卸载包。2、安装相关默认路径。6、查询已安装过的包。

《Linux C编程实战》笔记:共享内存

ouliten的博客

03-02

849

由于本人要考研了,播客可能不会再长更。这本《Linux C编程实战》其实也差不多完结了,还剩网络编程章节没有讲,我肯定是没时间讲了,可能考研失败了会回来继续。《Primer C++》的课后题还有第八章的存货,后续章节只能随缘更新。Qt部分真烂尾了,写Qt项目的注释实在太累了。最有可能更新的部分是力扣题讲解,因为写来准备复试上机。最后祝大家,也祝我一切顺利。

linux python qt.qpa.xcb: could not connect to display

08-22

引用和中的错误信息是关于Qt平台插件的问题,显示了"qt.qpa.xcb could not connect to display"和"qt.qpa.plugin: Could not load the Qt platform plugin "xcb""的错误信息。这些错误通常会在使用Qt库或相关应用程序时出现。这些错误表明在加载Qt平台插件时遇到了问题。

通常,这些错误是由于缺少Qt平台插件或环境配置不正确导致的。解决这个问题的一种方法是重新安装应用程序或Qt库。您可以尝试重新安装相关软件,以确保所有的依赖项都正确安装并配置。此外,您也可以检查系统环境变量和路径设置,确保它们正确指向Qt库和插件所在的位置。

引用提供了针对Ubuntu 18.04下解决类似问题的解决方案,您可以参考该文档进行操作。既然这个问题出现在Linux Python环境中,您可能还需要考虑检查您的Python环境和依赖项是否正确安装,并确保与Qt版本兼容。

总结来说,qt.qpa.xcb: could not connect to display错误通常是由于Qt平台插件的加载问题引起的。您可以尝试重新安装应用程序或Qt库,并确保环境变量和路径设置正确。如果问题仍然存在,您可以参考适用于您的操作系统和Python环境的特定解决方案。123

#### 引用[.reference_title]

- *1* [mmcv包在linux下无法使用inshow展示报错:qt.qpa.xcb: could not connect to display](https://blog.csdn.net/weixin_44635198/article/details/127616135)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"]

- *2* [解决qt.qpa.xcb: could not connect to display问题](https://blog.csdn.net/zimojiang/article/details/127383943)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"]

- *3* [Ubuntu18.04下解决Qt出现qt.qpa.plugin:Could not load the Qt platform plugin “xcb“问题](https://download.csdn.net/download/weixin_38695061/12841039)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"]

[ .reference_list ]

“相关推荐”对你有帮助么?

非常没帮助

没帮助

一般

有帮助

非常有帮助

提交

顺其自然~

CSDN认证博客专家

CSDN认证企业博客

码龄16年

暂无认证

434

原创

8907

周排名

332

总排名

755万+

访问

等级

3万+

积分

2400

粉丝

6454

获赞

678

评论

3万+

收藏

私信

关注

热门文章

什么是汇编语言

125638

4款最好用的虚拟机软件简介及对比

120110

Java Bean详解

99915

接入层、汇聚层、核心层交换机三者之间的功能详解

91679

netstat查看端口状态

84848

最新评论

堆溢出崩溃分析Critical error detected c0000374

黑白灰12345:

VS2017、VS2019版本,测试只有在释放堆内存时存在检查,申请无检查也不会抛出异常

使用ChatGTP4的Coze AI

CSDN-Ada助手:

Python入门 技能树或许可以帮到你:https://edu.csdn.net/skill/python?utm_source=AI_act_python

服务器硬件基础知识

全球服务器运营:

需要服务器的可以联系

Windows消息机制

x暮落:

受益匪浅,时常回来复习都有新的收获,感谢梳理

声卡是什么

yangzuhao2020:

写的太棒了

您愿意向朋友推荐“博客详情页”吗?

强烈不推荐

不推荐

一般般

推荐

强烈推荐

提交

最新文章

统一身份管理平台IAM单点登录流程及第三方接口设计方案

MaxKey单点登录认证系统

ajax之HttpOnly cookie 如何与 AJAX 请求配合使用

2024

03月

14篇

02月

12篇

01月

74篇

2023年1005篇

2022年501篇

2021年317篇

2020年328篇

2019年101篇

2018年164篇

目录

目录

最新文章

统一身份管理平台IAM单点登录流程及第三方接口设计方案

MaxKey单点登录认证系统

ajax之HttpOnly cookie 如何与 AJAX 请求配合使用

2024

03月

14篇

02月

12篇

01月

74篇

2023年1005篇

2022年501篇

2021年317篇

2020年328篇

2019年101篇

2018年164篇

目录

评论

被折叠的  条评论

为什么被折叠?

到【灌水乐园】发言

查看更多评论

添加红包

祝福语

请填写红包祝福语或标题

红包数量

红包个数最小为10个

红包总金额

红包金额最低5元

余额支付

当前余额3.43元

前往充值 >

需支付:10.00元

取消

确定

下一步

知道了

成就一亿技术人!

领取后你会自动成为博主和红包主的粉丝

规则

hope_wisdom 发出的红包

打赏作者

顺其自然~

你的鼓励将是我创作的最大动力

¥1

¥2

¥4

¥6

¥10

¥20

扫码支付:¥1

获取中

扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付元

使用余额支付

点击重新获取

扫码支付

钱包余额

0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。 2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值