diff options
author | marha <marha@users.sourceforge.net> | 2010-12-25 14:33:36 +0000 |
---|---|---|
committer | marha <marha@users.sourceforge.net> | 2010-12-25 14:33:36 +0000 |
commit | 311ab924cacb3353066bf25f23208a315ac06b9d (patch) | |
tree | 4562209dc2dba361da4eb3bb7bea923d892f1a48 /libxcb/doc/xkb_internals | |
parent | 0412ee015982ea1ab7cbe353f20b24530d2d8048 (diff) | |
parent | c6539c9f45372fb6518bff17a781effd654bd3f0 (diff) | |
download | vcxsrv-311ab924cacb3353066bf25f23208a315ac06b9d.tar.gz vcxsrv-311ab924cacb3353066bf25f23208a315ac06b9d.tar.bz2 vcxsrv-311ab924cacb3353066bf25f23208a315ac06b9d.zip |
svn merge ^/branches/released .
Diffstat (limited to 'libxcb/doc/xkb_internals')
-rw-r--r-- | libxcb/doc/xkb_internals | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/libxcb/doc/xkb_internals b/libxcb/doc/xkb_internals new file mode 100644 index 000000000..3e103910c --- /dev/null +++ b/libxcb/doc/xkb_internals @@ -0,0 +1,49 @@ +
+XKB introduces several uncommon data structures:
+ - switch allows conditional inclusion of fields
+ - several complex objects intermix variable and fixed size fields
+ - lists with a variable number of variable size objects
+
+To handle these objects, a number of new functions is generated:
+ - _serialize() turns a structured object into a byte stream,
+ (re)ordering or including fields according to the protocol
+ - _unserialize() rewrites data from a buffer into a structured object
+ - _unpack() expands a buffer representing a switch object into
+ a special structured type, all flags needed to resolve the switch
+ expression have to given as parameters
+ - _sizeof() calculates the size of a serialized object, often by calling
+ _unserialize()/_unpack() internally
+
+The new structured data type for switch is special as it contains fixed
+and variable size fields. Variable size fields can be accessed via pointers.
+
+If switch appears in a request, an additional set of request helpers is
+generated with the suffix _aux or _aux_(un)checked. While the 'common'
+request functions require that switch has been serialized before, the _aux
+variants take the structured data type. They are especially designed to
+replace certain functions in xcb-util/aux.
+
+Accessors for switch members need two parameters, where the first is usually
+a pointer to the respective request or reply structure, while the second
+is a pointer to the unpacked switch data structure.
+
+Functions from the serialize family that take a double pointer can allocate
+memory on their own, which is useful if the size of a buffer has to be
+calculated depending on the data within. These functions call malloc() when
+the double pointer is given as the address of a pointer that has been
+initialized to 0. It is the responsibility of the user to free any allocated
+memory.
+
+Intermixed variable and fixed size fields are an important special case in XKB.
+The current implementation resolves the issue by reordering the fields before
+sending them on the wire as well as before returning a reply. That means that
+these objects look like 'common' XCB data types and they can be accessed as such
+(i.e. fixed size fields directly via the structured type and variable size fields
+via accessors/iterators).
+
+In case a list with variable size elements needs to be accessed, it is necessary
+to use iterators. The iterator functions take care of determining the actual
+object size for each element automatically.
+
+A small and preliminary set of auxiliary functions is available in xkb_util.c
+in the check_xkb module.
|