NAME

XkbFreeGeometry - Free an entire geometry

SYNOPSIS

void XkbFreeGeometry (XkbGeometryPtr geom, unsigned int which, Bool free_all);

ARGUMENTS

geom
geometry to be freed
which
mask of geometry components to be freed
free_all
True => the entire geometry is freed

DESCRIPTION

Xkb provides a number of functions to allocate and free subcomponents of a keyboard geometry. Use these functions to create or modify keyboard geometries. Note that these functions merely allocate space for the new element(s), and it is up to you to fill in the values explicitly in your code. These allocation functions increase sz_* but never touch num_* (unless there is an allocation failure, in which case they reset both sz_* and num_* to zero). These functions return Success if they succeed, BadAlloc if they are not able to allocate space, or BadValue if a parameter is not as expected.
 
The values of which and free_all determine how much of the specified geometry is freed. The valid values for which are:
 
    #define   XkbGeomPropertiesMask      (1<<0)
    #define   XkbGeomColorsMask          (1<<1)
    #define   XkbGeomShapesMask          (1<<2)
    #define   XkbGeomSectionsMask        (1<<3)
    #define   XkbGeomDoodadsMask         (1<<4)
    #define   XkbGeomKeyAliasesMask      (1<<5)
    #define   XkbGeomAllMask             (0x3f)
    
If free_all is True, the entire geometry is freed regardless of the value of which. Otherwise, the portions of the geometry specified by which are freed.

DIAGNOSTICS

BadAlloc
Unable to allocate storage
BadValue
An argument is out of range

Questions & Answers

Helpful answers and articles about XkbFreeGeometry you may found on these sites:
Stack Overflow Server Fault Super User Unix & Linux Ask Ubuntu Network Engineering DevOps Raspberry Pi Webmasters Google Search