registry: Rebase registry to use the server config file of protocol names.
This commit is contained in:
parent
9b0e72c8d9
commit
decd5a7c60
|
@ -60,6 +60,7 @@ SOFTWARE.
|
|||
#include "scrnintstr.h"
|
||||
#include "dispatch.h"
|
||||
#include "privates.h"
|
||||
#include "registry.h"
|
||||
#include "xace.h"
|
||||
|
||||
#define EXTENSION_BASE 128
|
||||
|
@ -143,6 +144,7 @@ AddExtension(char *name, int NumEvents, int NumErrors,
|
|||
ext->errorLast = 0;
|
||||
}
|
||||
|
||||
RegisterExtensionNames(ext);
|
||||
return(ext);
|
||||
}
|
||||
|
||||
|
|
323
dix/registry.c
323
dix/registry.c
|
@ -23,17 +23,30 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|||
|
||||
#ifdef XREGISTRY
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <X11/X.h>
|
||||
#include <X11/Xproto.h>
|
||||
#include "resource.h"
|
||||
#include "registry.h"
|
||||
|
||||
#define BASE_SIZE 16
|
||||
#define CORE "X11:"
|
||||
#define CORE "X11"
|
||||
#define FILENAME SERVER_MISC_CONFIG_PATH "/protocol.txt"
|
||||
|
||||
static const char ***requests, **events, **errors, **resources;
|
||||
#define PROT_COMMENT '#'
|
||||
#define PROT_REQUEST 'R'
|
||||
#define PROT_EVENT 'V'
|
||||
#define PROT_ERROR 'E'
|
||||
|
||||
static FILE *fh;
|
||||
|
||||
static char ***requests, **events, **errors, **resources;
|
||||
static unsigned nmajor, *nminor, nevent, nerror, nresource;
|
||||
|
||||
/*
|
||||
* File parsing routines
|
||||
*/
|
||||
static int double_size(void *p, unsigned n, unsigned size)
|
||||
{
|
||||
char **ptr = (char **)p;
|
||||
|
@ -57,58 +70,131 @@ static int double_size(void *p, unsigned n, unsigned size)
|
|||
return TRUE;
|
||||
}
|
||||
|
||||
/*
|
||||
* Registration functions
|
||||
*/
|
||||
|
||||
void
|
||||
RegisterRequestName(unsigned major, unsigned minor, const char *name)
|
||||
static void
|
||||
RegisterRequestName(unsigned major, unsigned minor, char *name)
|
||||
{
|
||||
while (major >= nmajor) {
|
||||
if (!double_size(&requests, nmajor, sizeof(const char **)))
|
||||
if (!double_size(&requests, nmajor, sizeof(char **)))
|
||||
return;
|
||||
if (!double_size(&nminor, nmajor, sizeof(unsigned)))
|
||||
return;
|
||||
nmajor = nmajor ? nmajor * 2 : BASE_SIZE;
|
||||
}
|
||||
while (minor >= nminor[major]) {
|
||||
if (!double_size(requests+major, nminor[major], sizeof(const char *)))
|
||||
if (!double_size(requests+major, nminor[major], sizeof(char *)))
|
||||
return;
|
||||
nminor[major] = nminor[major] ? nminor[major] * 2 : BASE_SIZE;
|
||||
}
|
||||
|
||||
free(requests[major][minor]);
|
||||
requests[major][minor] = name;
|
||||
}
|
||||
|
||||
void
|
||||
RegisterEventName(unsigned event, const char *name) {
|
||||
static void
|
||||
RegisterEventName(unsigned event, char *name) {
|
||||
while (event >= nevent) {
|
||||
if (!double_size(&events, nevent, sizeof(const char *)))
|
||||
if (!double_size(&events, nevent, sizeof(char *)))
|
||||
return;
|
||||
nevent = nevent ? nevent * 2 : BASE_SIZE;
|
||||
}
|
||||
|
||||
free(events[event]);
|
||||
events[event] = name;
|
||||
}
|
||||
|
||||
void
|
||||
RegisterErrorName(unsigned error, const char *name) {
|
||||
static void
|
||||
RegisterErrorName(unsigned error, char *name) {
|
||||
while (error >= nerror) {
|
||||
if (!double_size(&errors, nerror, sizeof(const char *)))
|
||||
if (!double_size(&errors, nerror, sizeof(char *)))
|
||||
return;
|
||||
nerror = nerror ? nerror * 2 : BASE_SIZE;
|
||||
}
|
||||
|
||||
free(errors[error]);
|
||||
errors[error] = name;
|
||||
}
|
||||
|
||||
void
|
||||
RegisterResourceName(RESTYPE resource, const char *name)
|
||||
RegisterExtensionNames(ExtensionEntry *extEntry)
|
||||
{
|
||||
char buf[256], *lineobj, *ptr;
|
||||
unsigned offset;
|
||||
|
||||
if (fh == NULL)
|
||||
return;
|
||||
|
||||
rewind(fh);
|
||||
|
||||
while (fgets(buf, sizeof(buf), fh)) {
|
||||
ptr = strchr(buf, '\n');
|
||||
if (ptr)
|
||||
*ptr = 0;
|
||||
|
||||
switch (buf[0]) {
|
||||
case PROT_REQUEST:
|
||||
case PROT_EVENT:
|
||||
case PROT_ERROR:
|
||||
break;
|
||||
case PROT_COMMENT:
|
||||
case '\0':
|
||||
continue;
|
||||
default:
|
||||
continue;
|
||||
}
|
||||
|
||||
ptr = strchr(buf, ' ');
|
||||
if (!ptr || ptr != buf + 4) {
|
||||
LogMessage(X_WARNING, "Invalid line in " FILENAME ", skipping\n");
|
||||
continue;
|
||||
}
|
||||
lineobj = strdup(ptr + 1);
|
||||
if (!lineobj)
|
||||
continue;
|
||||
|
||||
ptr = strchr(buf, ':');
|
||||
if (!ptr) {
|
||||
LogMessage(X_WARNING, "Invalid line in " FILENAME ", skipping\n");
|
||||
continue;
|
||||
}
|
||||
*ptr = 0;
|
||||
|
||||
if (strcmp(buf + 5, extEntry->name))
|
||||
continue;
|
||||
|
||||
offset = strtol(buf + 1, &ptr, 10);
|
||||
if (offset == 0 && ptr == buf + 1) {
|
||||
LogMessage(X_WARNING, "Invalid line in " FILENAME ", skipping\n");
|
||||
continue;
|
||||
}
|
||||
|
||||
switch(buf[0]) {
|
||||
case PROT_REQUEST:
|
||||
if (extEntry->base)
|
||||
RegisterRequestName(extEntry->base, offset, lineobj);
|
||||
else
|
||||
RegisterRequestName(offset, 0, lineobj);
|
||||
break;
|
||||
case PROT_EVENT:
|
||||
RegisterEventName(extEntry->eventBase + offset, lineobj);
|
||||
break;
|
||||
case PROT_ERROR:
|
||||
RegisterErrorName(extEntry->errorBase + offset, lineobj);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Registration functions
|
||||
*/
|
||||
|
||||
void
|
||||
RegisterResourceName(RESTYPE resource, char *name)
|
||||
{
|
||||
resource &= TypeMask;
|
||||
|
||||
while (resource >= nresource) {
|
||||
if (!double_size(&resources, nresource, sizeof(const char *)))
|
||||
if (!double_size(&resources, nresource, sizeof(char *)))
|
||||
return;
|
||||
nresource = nresource ? nresource * 2 : BASE_SIZE;
|
||||
}
|
||||
|
@ -166,13 +252,25 @@ LookupResourceName(RESTYPE resource)
|
|||
void
|
||||
dixResetRegistry(void)
|
||||
{
|
||||
ExtensionEntry extEntry;
|
||||
|
||||
/* Free all memory */
|
||||
while (nmajor)
|
||||
xfree(requests[--nmajor]);
|
||||
while (nmajor--) {
|
||||
while (nminor[nmajor])
|
||||
free(requests[nmajor][--nminor[nmajor]]);
|
||||
xfree(requests[nmajor]);
|
||||
}
|
||||
xfree(requests);
|
||||
xfree(nminor);
|
||||
|
||||
while (nevent--)
|
||||
free(events[nevent]);
|
||||
xfree(events);
|
||||
|
||||
while (nerror--)
|
||||
free(errors[nerror]);
|
||||
xfree(errors);
|
||||
|
||||
xfree(resources);
|
||||
|
||||
requests = NULL;
|
||||
|
@ -183,6 +281,13 @@ dixResetRegistry(void)
|
|||
|
||||
nmajor = nevent = nerror = nresource = 0;
|
||||
|
||||
/* Open the protocol file */
|
||||
if (fh)
|
||||
fclose(fh);
|
||||
fh = fopen(FILENAME, "r");
|
||||
if (!fh)
|
||||
LogMessage(X_WARNING, "Failed to open protocol names file " FILENAME);
|
||||
|
||||
/* Add built-in resources */
|
||||
RegisterResourceName(RT_NONE, "NONE");
|
||||
RegisterResourceName(RT_WINDOW, "WINDOW");
|
||||
|
@ -196,181 +301,9 @@ dixResetRegistry(void)
|
|||
RegisterResourceName(RT_PASSIVEGRAB, "PASSIVE GRAB");
|
||||
|
||||
/* Add the core protocol */
|
||||
RegisterRequestName(X_CreateWindow, 0, CORE "CreateWindow");
|
||||
RegisterRequestName(X_ChangeWindowAttributes, 0, CORE "ChangeWindowAttributes");
|
||||
RegisterRequestName(X_GetWindowAttributes, 0, CORE "GetWindowAttributes");
|
||||
RegisterRequestName(X_DestroyWindow, 0, CORE "DestroyWindow");
|
||||
RegisterRequestName(X_DestroySubwindows, 0, CORE "DestroySubwindows");
|
||||
RegisterRequestName(X_ChangeSaveSet, 0, CORE "ChangeSaveSet");
|
||||
RegisterRequestName(X_ReparentWindow, 0, CORE "ReparentWindow");
|
||||
RegisterRequestName(X_MapWindow, 0, CORE "MapWindow");
|
||||
RegisterRequestName(X_MapSubwindows, 0, CORE "MapSubwindows");
|
||||
RegisterRequestName(X_UnmapWindow, 0, CORE "UnmapWindow");
|
||||
RegisterRequestName(X_UnmapSubwindows, 0, CORE "UnmapSubwindows");
|
||||
RegisterRequestName(X_ConfigureWindow, 0, CORE "ConfigureWindow");
|
||||
RegisterRequestName(X_CirculateWindow, 0, CORE "CirculateWindow");
|
||||
RegisterRequestName(X_GetGeometry, 0, CORE "GetGeometry");
|
||||
RegisterRequestName(X_QueryTree, 0, CORE "QueryTree");
|
||||
RegisterRequestName(X_InternAtom, 0, CORE "InternAtom");
|
||||
RegisterRequestName(X_GetAtomName, 0, CORE "GetAtomName");
|
||||
RegisterRequestName(X_ChangeProperty, 0, CORE "ChangeProperty");
|
||||
RegisterRequestName(X_DeleteProperty, 0, CORE "DeleteProperty");
|
||||
RegisterRequestName(X_GetProperty, 0, CORE "GetProperty");
|
||||
RegisterRequestName(X_ListProperties, 0, CORE "ListProperties");
|
||||
RegisterRequestName(X_SetSelectionOwner, 0, CORE "SetSelectionOwner");
|
||||
RegisterRequestName(X_GetSelectionOwner, 0, CORE "GetSelectionOwner");
|
||||
RegisterRequestName(X_ConvertSelection, 0, CORE "ConvertSelection");
|
||||
RegisterRequestName(X_SendEvent, 0, CORE "SendEvent");
|
||||
RegisterRequestName(X_GrabPointer, 0, CORE "GrabPointer");
|
||||
RegisterRequestName(X_UngrabPointer, 0, CORE "UngrabPointer");
|
||||
RegisterRequestName(X_GrabButton, 0, CORE "GrabButton");
|
||||
RegisterRequestName(X_UngrabButton, 0, CORE "UngrabButton");
|
||||
RegisterRequestName(X_ChangeActivePointerGrab, 0, CORE "ChangeActivePointerGrab");
|
||||
RegisterRequestName(X_GrabKeyboard, 0, CORE "GrabKeyboard");
|
||||
RegisterRequestName(X_UngrabKeyboard, 0, CORE "UngrabKeyboard");
|
||||
RegisterRequestName(X_GrabKey, 0, CORE "GrabKey");
|
||||
RegisterRequestName(X_UngrabKey, 0, CORE "UngrabKey");
|
||||
RegisterRequestName(X_AllowEvents, 0, CORE "AllowEvents");
|
||||
RegisterRequestName(X_GrabServer, 0, CORE "GrabServer");
|
||||
RegisterRequestName(X_UngrabServer, 0, CORE "UngrabServer");
|
||||
RegisterRequestName(X_QueryPointer, 0, CORE "QueryPointer");
|
||||
RegisterRequestName(X_GetMotionEvents, 0, CORE "GetMotionEvents");
|
||||
RegisterRequestName(X_TranslateCoords, 0, CORE "TranslateCoords");
|
||||
RegisterRequestName(X_WarpPointer, 0, CORE "WarpPointer");
|
||||
RegisterRequestName(X_SetInputFocus, 0, CORE "SetInputFocus");
|
||||
RegisterRequestName(X_GetInputFocus, 0, CORE "GetInputFocus");
|
||||
RegisterRequestName(X_QueryKeymap, 0, CORE "QueryKeymap");
|
||||
RegisterRequestName(X_OpenFont, 0, CORE "OpenFont");
|
||||
RegisterRequestName(X_CloseFont, 0, CORE "CloseFont");
|
||||
RegisterRequestName(X_QueryFont, 0, CORE "QueryFont");
|
||||
RegisterRequestName(X_QueryTextExtents, 0, CORE "QueryTextExtents");
|
||||
RegisterRequestName(X_ListFonts, 0, CORE "ListFonts");
|
||||
RegisterRequestName(X_ListFontsWithInfo, 0, CORE "ListFontsWithInfo");
|
||||
RegisterRequestName(X_SetFontPath, 0, CORE "SetFontPath");
|
||||
RegisterRequestName(X_GetFontPath, 0, CORE "GetFontPath");
|
||||
RegisterRequestName(X_CreatePixmap, 0, CORE "CreatePixmap");
|
||||
RegisterRequestName(X_FreePixmap, 0, CORE "FreePixmap");
|
||||
RegisterRequestName(X_CreateGC, 0, CORE "CreateGC");
|
||||
RegisterRequestName(X_ChangeGC, 0, CORE "ChangeGC");
|
||||
RegisterRequestName(X_CopyGC, 0, CORE "CopyGC");
|
||||
RegisterRequestName(X_SetDashes, 0, CORE "SetDashes");
|
||||
RegisterRequestName(X_SetClipRectangles, 0, CORE "SetClipRectangles");
|
||||
RegisterRequestName(X_FreeGC, 0, CORE "FreeGC");
|
||||
RegisterRequestName(X_ClearArea, 0, CORE "ClearArea");
|
||||
RegisterRequestName(X_CopyArea, 0, CORE "CopyArea");
|
||||
RegisterRequestName(X_CopyPlane, 0, CORE "CopyPlane");
|
||||
RegisterRequestName(X_PolyPoint, 0, CORE "PolyPoint");
|
||||
RegisterRequestName(X_PolyLine, 0, CORE "PolyLine");
|
||||
RegisterRequestName(X_PolySegment, 0, CORE "PolySegment");
|
||||
RegisterRequestName(X_PolyRectangle, 0, CORE "PolyRectangle");
|
||||
RegisterRequestName(X_PolyArc, 0, CORE "PolyArc");
|
||||
RegisterRequestName(X_FillPoly, 0, CORE "FillPoly");
|
||||
RegisterRequestName(X_PolyFillRectangle, 0, CORE "PolyFillRectangle");
|
||||
RegisterRequestName(X_PolyFillArc, 0, CORE "PolyFillArc");
|
||||
RegisterRequestName(X_PutImage, 0, CORE "PutImage");
|
||||
RegisterRequestName(X_GetImage, 0, CORE "GetImage");
|
||||
RegisterRequestName(X_PolyText8, 0, CORE "PolyText8");
|
||||
RegisterRequestName(X_PolyText16, 0, CORE "PolyText16");
|
||||
RegisterRequestName(X_ImageText8, 0, CORE "ImageText8");
|
||||
RegisterRequestName(X_ImageText16, 0, CORE "ImageText16");
|
||||
RegisterRequestName(X_CreateColormap, 0, CORE "CreateColormap");
|
||||
RegisterRequestName(X_FreeColormap, 0, CORE "FreeColormap");
|
||||
RegisterRequestName(X_CopyColormapAndFree, 0, CORE "CopyColormapAndFree");
|
||||
RegisterRequestName(X_InstallColormap, 0, CORE "InstallColormap");
|
||||
RegisterRequestName(X_UninstallColormap, 0, CORE "UninstallColormap");
|
||||
RegisterRequestName(X_ListInstalledColormaps, 0, CORE "ListInstalledColormaps");
|
||||
RegisterRequestName(X_AllocColor, 0, CORE "AllocColor");
|
||||
RegisterRequestName(X_AllocNamedColor, 0, CORE "AllocNamedColor");
|
||||
RegisterRequestName(X_AllocColorCells, 0, CORE "AllocColorCells");
|
||||
RegisterRequestName(X_AllocColorPlanes, 0, CORE "AllocColorPlanes");
|
||||
RegisterRequestName(X_FreeColors, 0, CORE "FreeColors");
|
||||
RegisterRequestName(X_StoreColors, 0, CORE "StoreColors");
|
||||
RegisterRequestName(X_StoreNamedColor, 0, CORE "StoreNamedColor");
|
||||
RegisterRequestName(X_QueryColors, 0, CORE "QueryColors");
|
||||
RegisterRequestName(X_LookupColor, 0, CORE "LookupColor");
|
||||
RegisterRequestName(X_CreateCursor, 0, CORE "CreateCursor");
|
||||
RegisterRequestName(X_CreateGlyphCursor, 0, CORE "CreateGlyphCursor");
|
||||
RegisterRequestName(X_FreeCursor, 0, CORE "FreeCursor");
|
||||
RegisterRequestName(X_RecolorCursor, 0, CORE "RecolorCursor");
|
||||
RegisterRequestName(X_QueryBestSize, 0, CORE "QueryBestSize");
|
||||
RegisterRequestName(X_QueryExtension, 0, CORE "QueryExtension");
|
||||
RegisterRequestName(X_ListExtensions, 0, CORE "ListExtensions");
|
||||
RegisterRequestName(X_ChangeKeyboardMapping, 0, CORE "ChangeKeyboardMapping");
|
||||
RegisterRequestName(X_GetKeyboardMapping, 0, CORE "GetKeyboardMapping");
|
||||
RegisterRequestName(X_ChangeKeyboardControl, 0, CORE "ChangeKeyboardControl");
|
||||
RegisterRequestName(X_GetKeyboardControl, 0, CORE "GetKeyboardControl");
|
||||
RegisterRequestName(X_Bell, 0, CORE "Bell");
|
||||
RegisterRequestName(X_ChangePointerControl, 0, CORE "ChangePointerControl");
|
||||
RegisterRequestName(X_GetPointerControl, 0, CORE "GetPointerControl");
|
||||
RegisterRequestName(X_SetScreenSaver, 0, CORE "SetScreenSaver");
|
||||
RegisterRequestName(X_GetScreenSaver, 0, CORE "GetScreenSaver");
|
||||
RegisterRequestName(X_ChangeHosts, 0, CORE "ChangeHosts");
|
||||
RegisterRequestName(X_ListHosts, 0, CORE "ListHosts");
|
||||
RegisterRequestName(X_SetAccessControl, 0, CORE "SetAccessControl");
|
||||
RegisterRequestName(X_SetCloseDownMode, 0, CORE "SetCloseDownMode");
|
||||
RegisterRequestName(X_KillClient, 0, CORE "KillClient");
|
||||
RegisterRequestName(X_RotateProperties, 0, CORE "RotateProperties");
|
||||
RegisterRequestName(X_ForceScreenSaver, 0, CORE "ForceScreenSaver");
|
||||
RegisterRequestName(X_SetPointerMapping, 0, CORE "SetPointerMapping");
|
||||
RegisterRequestName(X_GetPointerMapping, 0, CORE "GetPointerMapping");
|
||||
RegisterRequestName(X_SetModifierMapping, 0, CORE "SetModifierMapping");
|
||||
RegisterRequestName(X_GetModifierMapping, 0, CORE "GetModifierMapping");
|
||||
RegisterRequestName(X_NoOperation, 0, CORE "NoOperation");
|
||||
|
||||
RegisterErrorName(Success, CORE "Success");
|
||||
RegisterErrorName(BadRequest, CORE "BadRequest");
|
||||
RegisterErrorName(BadValue, CORE "BadValue");
|
||||
RegisterErrorName(BadWindow, CORE "BadWindow");
|
||||
RegisterErrorName(BadPixmap, CORE "BadPixmap");
|
||||
RegisterErrorName(BadAtom, CORE "BadAtom");
|
||||
RegisterErrorName(BadCursor, CORE "BadCursor");
|
||||
RegisterErrorName(BadFont, CORE "BadFont");
|
||||
RegisterErrorName(BadMatch, CORE "BadMatch");
|
||||
RegisterErrorName(BadDrawable, CORE "BadDrawable");
|
||||
RegisterErrorName(BadAccess, CORE "BadAccess");
|
||||
RegisterErrorName(BadAlloc, CORE "BadAlloc");
|
||||
RegisterErrorName(BadColor, CORE "BadColor");
|
||||
RegisterErrorName(BadGC, CORE "BadGC");
|
||||
RegisterErrorName(BadIDChoice, CORE "BadIDChoice");
|
||||
RegisterErrorName(BadName, CORE "BadName");
|
||||
RegisterErrorName(BadLength, CORE "BadLength");
|
||||
RegisterErrorName(BadImplementation, CORE "BadImplementation");
|
||||
|
||||
RegisterEventName(X_Error, CORE "Error");
|
||||
RegisterEventName(X_Reply, CORE "Reply");
|
||||
RegisterEventName(KeyPress, CORE "KeyPress");
|
||||
RegisterEventName(KeyRelease, CORE "KeyRelease");
|
||||
RegisterEventName(ButtonPress, CORE "ButtonPress");
|
||||
RegisterEventName(ButtonRelease, CORE "ButtonRelease");
|
||||
RegisterEventName(MotionNotify, CORE "MotionNotify");
|
||||
RegisterEventName(EnterNotify, CORE "EnterNotify");
|
||||
RegisterEventName(LeaveNotify, CORE "LeaveNotify");
|
||||
RegisterEventName(FocusIn, CORE "FocusIn");
|
||||
RegisterEventName(FocusOut, CORE "FocusOut");
|
||||
RegisterEventName(KeymapNotify, CORE "KeymapNotify");
|
||||
RegisterEventName(Expose, CORE "Expose");
|
||||
RegisterEventName(GraphicsExpose, CORE "GraphicsExpose");
|
||||
RegisterEventName(NoExpose, CORE "NoExpose");
|
||||
RegisterEventName(VisibilityNotify, CORE "VisibilityNotify");
|
||||
RegisterEventName(CreateNotify, CORE "CreateNotify");
|
||||
RegisterEventName(DestroyNotify, CORE "DestroyNotify");
|
||||
RegisterEventName(UnmapNotify, CORE "UnmapNotify");
|
||||
RegisterEventName(MapNotify, CORE "MapNotify");
|
||||
RegisterEventName(MapRequest, CORE "MapRequest");
|
||||
RegisterEventName(ReparentNotify, CORE "ReparentNotify");
|
||||
RegisterEventName(ConfigureNotify, CORE "ConfigureNotify");
|
||||
RegisterEventName(ConfigureRequest, CORE "ConfigureRequest");
|
||||
RegisterEventName(GravityNotify, CORE "GravityNotify");
|
||||
RegisterEventName(ResizeRequest, CORE "ResizeRequest");
|
||||
RegisterEventName(CirculateNotify, CORE "CirculateNotify");
|
||||
RegisterEventName(CirculateRequest, CORE "CirculateRequest");
|
||||
RegisterEventName(PropertyNotify, CORE "PropertyNotify");
|
||||
RegisterEventName(SelectionClear, CORE "SelectionClear");
|
||||
RegisterEventName(SelectionRequest, CORE "SelectionRequest");
|
||||
RegisterEventName(SelectionNotify, CORE "SelectionNotify");
|
||||
RegisterEventName(ColormapNotify, CORE "ColormapNotify");
|
||||
RegisterEventName(ClientMessage, CORE "ClientMessage");
|
||||
RegisterEventName(MappingNotify, CORE "MappingNotify");
|
||||
memset(&extEntry, 0, sizeof(extEntry));
|
||||
extEntry.name = CORE;
|
||||
RegisterExtensionNames(&extEntry);
|
||||
}
|
||||
|
||||
#endif /* XREGISTRY */
|
||||
|
|
|
@ -288,9 +288,6 @@ _X_HIDDEN void *dixLookupTab[] = {
|
|||
SYMVAR(ResourceStateCallback)
|
||||
/* registry.c */
|
||||
#ifdef XREGISTRY
|
||||
SYMFUNC(RegisterRequestName)
|
||||
SYMFUNC(RegisterEventName)
|
||||
SYMFUNC(RegisterErrorName)
|
||||
SYMFUNC(RegisterResourceName)
|
||||
#endif
|
||||
/* swaprep.c */
|
||||
|
|
|
@ -15,6 +15,7 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|||
#ifdef XREGISTRY
|
||||
|
||||
#include "resource.h"
|
||||
#include "extnsionst.h"
|
||||
|
||||
/* Internal string registry - for auditing, debugging, security, etc. */
|
||||
|
||||
|
@ -22,13 +23,11 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|||
* Registration functions. The name string is not copied, so it must
|
||||
* not be a stack variable.
|
||||
*/
|
||||
void RegisterRequestName(unsigned major, unsigned minor, const char *name);
|
||||
void RegisterEventName(unsigned event, const char *name);
|
||||
void RegisterErrorName(unsigned error, const char *name);
|
||||
void RegisterResourceName(RESTYPE type, const char *name);
|
||||
void RegisterResourceName(RESTYPE type, char *name);
|
||||
void RegisterExtensionNames(ExtensionEntry *ext);
|
||||
|
||||
/*
|
||||
* Lookup functions. The returned string must not be modified.
|
||||
* Lookup functions. The returned string must not be modified or freed.
|
||||
*/
|
||||
const char *LookupRequestName(int major, int minor);
|
||||
const char *LookupEventName(int event);
|
||||
|
@ -49,10 +48,8 @@ void dixResetRegistry(void);
|
|||
|
||||
/* Define calls away when the registry is not being built. */
|
||||
|
||||
#define RegisterRequestName(a, b, c) { ; }
|
||||
#define RegisterEventName(a, b) { ; }
|
||||
#define RegisterErrorName(a, b) { ; }
|
||||
#define RegisterResourceName(a, b) { ; }
|
||||
#define RegisterExtensionNames(a) { ; }
|
||||
|
||||
#define LookupRequestName(a, b) XREGISTRY_UNKNOWN
|
||||
#define LookupEventName(a) XREGISTRY_UNKNOWN
|
||||
|
|
Loading…
Reference in New Issue
Block a user