-
-
Notifications
You must be signed in to change notification settings - Fork 592
Xorg Rants
yshui edited this page Apr 26, 2019
·
27 revisions
- There are wiki pages on fd.o that guarantee you xcb and xlib works together. NO THEY DO NOT!
- If you for example let xcb manage the event queue, everything will break down.
- Xlib will kill your program on any error reply from X server.
- If you use DRI2, OpenGL won't work without an ugly hack
- If you for example let xcb manage the event queue, everything will break down.
- In the shape extension, you can specify the shape of a window using a bitmap, but you can't get that bitmap back! You can only get rectangles! Meaning you will get thousands of rectangles of a circle shaped window. (10x the amount of data sent).
- Lots of the X protocol shows how limited the machines were back when X11 is designed. But there are also things like this.
- On 64-bit systems, Xlib will padded 32-bit property values to 64-bit when returning them. Presumably a short-sighted hack made during the 64-bit transition.
- If there are 10 ways to do something, X will do all 10, poorly, then add in some extras.
- And all 10 ways will be missing bits and pieces so you can't just use one of them, you have to use all of them.
- Examples: the input system, the event system.
- XFixes is an extension that "implements a collection of unrelated additions to the protocol." ... which include not just addition to the Core X protocol, but also to a bunch of other extensions too
- Why add functionalities to the relevant extension, when I can just create an entire new extension for that purpose? /s
- XRender
- Defines a
graphics-exposures
flags for Picture, then say "this flag is ignored. GraphicsExposure events are never generated by this extension."
- Defines a
- XRandR
- RRGetScreenInfo returns a refresh rate... for which monitor?
- Some information is only available in events!
- What window a window is on top of is only available in the ConfigureNotify event, otherwise you need to get the entire window stack to figure that out.
- This means sometimes the application has to re-implement part of X server to keep track of certain states.
- This is an exact quote from the XRes spec:
-
The protocol description of X Resource Extension version 1.1 has been either lost or has never been written. This specification documents version 1.0 based on reverse engineered library and server code. Version 1.1 has been accidentally released from the version control and while it doesn't have differences to version 1.0, this version is labeled 1.2 in order to remove the risk of confusion. In addition to the 1.0 description, this document introduces a new 1.2 version of the extension.
-
- Inconsistent coordinate systems. The origin can be inside or outside of the window border.
- XShape choose to use the top left corner inside the border as the origin. But the border is part of a window's bounding shape! It has to use negative coordinates to describe the border.
- There's no way to stay up-to-date with the X server
- New notification could arrive while you are doing something to make your state stale. Therefore there is no way to know if what you get from a request is actually what you think you get.
- Sometimes, this makes XGrabServer necessary.
- And before you make any requests, you have to process all relevant events already in queue, so those events won't cause unnecessary invalidation later.
- Or, you can discard events in queue that are older than your requests. Except some information is only efficiently obtainable via events.
- Documentation is a joke.
- Open any xcb man page, and you will see long lists of
TODO: NOT YET DOCUMENTED.
- The description is often as vague as possible, with important details left out.
- Open any xcb man page, and you will see long lists of
- Bugs
- Race conditions in event handling cause screen freeze when using compton (fixed)
Everything in this wiki is published under the CC BY-SA 4.0 license. You can find the license text here