aboutsummaryrefslogtreecommitdiff
path: root/nx-X11/lib/dmx
diff options
context:
space:
mode:
Diffstat (limited to 'nx-X11/lib/dmx')
-rw-r--r--nx-X11/lib/dmx/Imakefile26
-rw-r--r--nx-X11/lib/dmx/dmx.c802
2 files changed, 0 insertions, 828 deletions
diff --git a/nx-X11/lib/dmx/Imakefile b/nx-X11/lib/dmx/Imakefile
deleted file mode 100644
index c4296de6f..000000000
--- a/nx-X11/lib/dmx/Imakefile
+++ /dev/null
@@ -1,26 +0,0 @@
-XCOMM $XFree86$
-
-#define DoNormalLib NormalLibDmx
-#define DoSharedLib SharedLibDmx
-#define DoDebugLib DebugLibDmx
-#define DoProfileLib ProfileLibDmx
-
-#define LibName dmx
-#define SoRev SODMXREV
-#define LibHeaders NO
-
-#include <Threads.tmpl>
-
-#if Malloc0ReturnsNull
-ALLOC_DEFINES = -DMALLOC_0_RETURNS_NULL
-#endif
-
- DEFINES = $(ALLOC_DEFINES)
- INCLUDES = -I$(XLIBSRC) -I$(EXTINCSRC)
- SRCS = dmx.c
- OBJS = dmx.o
- LINTLIBS = $(LINTXLIB)
-
-#include <Library.tmpl>
-
-DependTarget()
diff --git a/nx-X11/lib/dmx/dmx.c b/nx-X11/lib/dmx/dmx.c
deleted file mode 100644
index 1df28e690..000000000
--- a/nx-X11/lib/dmx/dmx.c
+++ /dev/null
@@ -1,802 +0,0 @@
-/* $XFree86$ */
-/*
- * Copyright 2002-2004 Red Hat Inc., Durham, North Carolina.
- *
- * All Rights Reserved.
- *
- * Permission is hereby granted, free of charge, to any person obtaining
- * a copy of this software and associated documentation files (the
- * "Software"), to deal in the Software without restriction, including
- * without limitation on the rights to use, copy, modify, merge,
- * publish, distribute, sublicense, and/or sell copies of the Software,
- * and to permit persons to whom the Software is furnished to do so,
- * subject to the following conditions:
- *
- * The above copyright notice and this permission notice (including the
- * next paragraph) shall be included in all copies or substantial
- * portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- * NON-INFRINGEMENT. IN NO EVENT SHALL RED HAT AND/OR THEIR SUPPLIERS
- * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
- * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
- * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- */
-
-/*
- * Authors:
- * Rickard E. (Rik) Faith <faith@redhat.com>
- *
- */
-
-/* THIS IS NOT AN X CONSORTIUM STANDARD */
-
-/** \file
- * This file implements the client-side part of the DMX protocol. It
- * can be included in client applications by linking with the libdmx.a
- * library. */
-
-#define NEED_REPLIES
-#include <X11/Xlibint.h>
-#include <X11/extensions/Xext.h>
-#define EXTENSION_PROC_ARGS void *
-#include <X11/extensions/extutil.h>
-#include <X11/extensions/dmxproto.h>
-#include <X11/extensions/dmxext.h>
-
-static XExtensionInfo dmx_extension_info_data;
-static XExtensionInfo *dmx_extension_info = &dmx_extension_info_data;
-static const char *dmx_extension_name = DMX_EXTENSION_NAME;
-
-#define DMXCheckExtension(dpy,i,val) \
- XextCheckExtension(dpy, i, dmx_extension_name, val)
-#define DMXSimpleCheckExtension(dpy,i) \
- XextSimpleCheckExtension(dpy, i, dmx_extension_name)
-
-/*****************************************************************************
- * *
- * private utility routines *
- * *
- *****************************************************************************/
-
-static int close_display(Display *dpy, XExtCodes *extCodes);
-static /* const */ XExtensionHooks dmx_extension_hooks = {
- NULL, /* create_gc */
- NULL, /* copy_gc */
- NULL, /* flush_gc */
- NULL, /* free_gc */
- NULL, /* create_font */
- NULL, /* free_font */
- close_display, /* close_display */
- NULL, /* wire_to_event */
- NULL, /* event_to_wire */
- NULL, /* error */
- NULL, /* error_string */
-};
-
-static XEXT_GENERATE_FIND_DISPLAY(find_display, dmx_extension_info,
- (char *)dmx_extension_name,
- &dmx_extension_hooks,
- 0, NULL)
-
-static XEXT_GENERATE_CLOSE_DISPLAY(close_display, dmx_extension_info)
-
-
-/*****************************************************************************
- * *
- * public DMX Extension routines *
- * *
- *****************************************************************************/
-
-/** If the server has the DMX extension, the event and error bases will
- * be placed in \a event_basep and \a error_basep, and True will be
- * returned. Otherwise, False will be returned.
- *
- * Available in DMX Protocol Version 1.0 */
-Bool DMXQueryExtension(Display *dpy, int *event_basep, int *error_basep)
-{
- XExtDisplayInfo *info = find_display(dpy);
-
- if (XextHasExtension(info)) {
- *event_basep = info->codes->first_event;
- *error_basep = info->codes->first_error;
- return True;
- } else {
- return False;
- }
-}
-
-/** If the DMXQueryVersion protocol request returns version information
- * from the server, \a majorVersion, \a minorVersion, and \a
- * patchVersion are filled in with the appropriate information and True
- * is returned. Otherwise, False will be returned.
- *
- * Available in DMX Protocol Version 1.0 */
-Bool DMXQueryVersion(Display *dpy,
- int *majorVersion, int *minorVersion, int *patchVersion)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXQueryVersionReply rep;
- xDMXQueryVersionReq *req;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXQueryVersion, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXQueryVersion;
- if (!_XReply(dpy, (xReply *)&rep, 0, xTrue)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
- *majorVersion = rep.majorVersion;
- *minorVersion = rep.minorVersion;
- *patchVersion = rep.patchVersion;
- UnlockDisplay(dpy);
- SyncHandle();
- return True;
-}
-
-/** Flush all pending dmxSync requests in DMX server.
- *
- * Available in DMX Protocol Version 1.5 */
-Bool DMXSync(Display *dpy)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXSyncReply rep;
- xDMXSyncReq *req;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXSync, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXSync;
- if (!_XReply(dpy, (xReply *)&rep, 0, xTrue)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
-
- UnlockDisplay(dpy);
- SyncHandle();
- return rep.status == Success ? True : False;
-}
-
-/** The creation of the specified \a window will be forced.
- *
- * Available in DMX Protocol Version 1.2
- * Reply added in DMX Protocol Version 2.0 */
-Bool DMXForceWindowCreation(Display *dpy, Window window)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXForceWindowCreationReq *req;
- xDMXForceWindowCreationReply rep;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXForceWindowCreation, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXForceWindowCreation;
- req->window = window;
- if (!_XReply(dpy, (xReply *)&rep, 0, xTrue)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
-
- UnlockDisplay(dpy);
- SyncHandle();
- return rep.status == Success ? True : False;
-}
-
-/** If the DMXGetScreenCount protocol request returns the screen count,
- * the value will be placed in \a screen_count, and True will be
- * returned. Otherwise, False will be returned.
- *
- * Available in DMX Protocol Version 1.0 */
-Bool DMXGetScreenCount(Display *dpy, int *screen_count)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXGetScreenCountReply rep;
- xDMXGetScreenCountReq *req;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXGetScreenCount, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXGetScreenCount;
- if (!_XReply(dpy, (xReply *)&rep, 0, xTrue)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
- *screen_count = rep.screenCount;
- UnlockDisplay(dpy);
- SyncHandle();
- return True;
-}
-
-/** If the DMXGetScreenAttributes protocol request returns information
- * for the specified \a physical_screen, information about the screen
- * will be placed in \a attr, and True will be returned. Otherwise,
- * False will be returned.
- *
- * Available in DMX Protocol Version 1.0; Modified in Version 2.0 */
-Bool DMXGetScreenAttributes(Display *dpy, int physical_screen,
- DMXScreenAttributes *attr)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXGetScreenAttributesReply rep;
- xDMXGetScreenAttributesReq *req;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXGetScreenAttributes, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXGetScreenAttributes;
- req->physicalScreen = physical_screen;
- if (!_XReply(dpy, (xReply *)&rep,
- (SIZEOF(xDMXGetScreenAttributesReply) - 32) >> 2, xFalse)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
- attr->displayName = Xmalloc(rep.displayNameLength + 1 + 4 /* for pad */);
- _XReadPad(dpy, attr->displayName, rep.displayNameLength);
- attr->displayName[rep.displayNameLength] = '\0';
- attr->logicalScreen = rep.logicalScreen;
-
- attr->screenWindowWidth = rep.screenWindowWidth;
- attr->screenWindowHeight = rep.screenWindowHeight;
- attr->screenWindowXoffset = rep.screenWindowXoffset;
- attr->screenWindowYoffset = rep.screenWindowYoffset;
-
- attr->rootWindowWidth = rep.rootWindowWidth;
- attr->rootWindowHeight = rep.rootWindowHeight;
- attr->rootWindowXoffset = rep.rootWindowXoffset;
- attr->rootWindowYoffset = rep.rootWindowYoffset;
- attr->rootWindowXorigin = rep.rootWindowXorigin;
- attr->rootWindowYorigin = rep.rootWindowYorigin;
- UnlockDisplay(dpy);
- SyncHandle();
- return True;
-}
-
-static CARD32 _DMXGetScreenAttribute(int bit, DMXScreenAttributes *attr)
-{
- switch (1 << bit) {
- case DMXScreenWindowWidth: return attr->screenWindowWidth;
- case DMXScreenWindowHeight: return attr->screenWindowHeight;
- case DMXScreenWindowXoffset: return attr->screenWindowXoffset;
- case DMXScreenWindowYoffset: return attr->screenWindowYoffset;
- case DMXRootWindowWidth: return attr->rootWindowWidth;
- case DMXRootWindowHeight: return attr->rootWindowHeight;
- case DMXRootWindowXoffset: return attr->rootWindowXoffset;
- case DMXRootWindowYoffset: return attr->rootWindowYoffset;
- case DMXRootWindowXorigin: return attr->rootWindowXorigin;
- case DMXRootWindowYorigin: return attr->rootWindowYorigin;
- default: return 0;
- }
-}
-
-static int _DMXDumpScreenAttributes(Display *dpy,
- unsigned long mask,
- DMXScreenAttributes *attr)
-{
- int i;
- unsigned long value_list[32];
- unsigned long *value = value_list;
- int count = 0;
-
- for (i = 0; i < 32; i++) {
- if (mask & (1 << i)) {
- *value++ = _DMXGetScreenAttribute(i, attr);
- ++count;
- }
- }
- Data32(dpy, value_list, count * sizeof(CARD32));
- return count;
-}
-
-static CARD32 _DMXGetInputAttribute(int bit, DMXInputAttributes *attr)
-{
- switch (1 << bit) {
- case DMXInputType:
- switch (attr->inputType) {
- case DMXLocalInputType: return 0;
- case DMXConsoleInputType: return 1;
- case DMXBackendInputType: return 2;
- }
- return attr->inputType;
- case DMXInputPhysicalScreen: return attr->physicalScreen;
- case DMXInputSendsCore: return attr->sendsCore;
- default: return 0;
- }
-}
-
-static int _DMXDumpInputAttributes(Display *dpy,
- unsigned long mask,
- DMXInputAttributes *attr)
-{
- int i;
- unsigned long value_list[32];
- unsigned long *value = value_list;
- int count = 0;
-
- for (i = 0; i < 32; i++) {
- if (mask & (1 << i)) {
- *value++ = _DMXGetInputAttribute(i, attr);
- ++count;
- }
- }
- Data32(dpy, value_list, count * sizeof(CARD32));
- return count;
-}
-
-/** Change geometries and positions of the DMX screen and root windows
- * on the back-end X server. */
-int DMXChangeScreensAttributes(Display *dpy,
- int screen_count,
- int *screens,
- int mask_count,
- unsigned int *masks,
- DMXScreenAttributes *attrs, /* vector */
- int *error_screen)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXChangeScreensAttributesReply rep;
- xDMXChangeScreensAttributesReq *req;
- int i;
- unsigned int mask = 0;
- CARD32 *screen_list;
- CARD32 *mask_list;
-
- DMXCheckExtension(dpy, info, False);
-
- if (screen_count < 1 || mask_count < 1) return DmxBadValue;
-
- LockDisplay(dpy);
- GetReq(DMXChangeScreensAttributes, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXChangeScreensAttributes;
- req->screenCount = screen_count;
- req->maskCount = mask_count;
- req->length += screen_count + mask_count;
-
- screen_list = (CARD32 *)Xmalloc(sizeof(*screen_list) * screen_count);
- for (i = 0; i < screen_count; i++) screen_list[i] = screens[i];
- Data32(dpy, screen_list, screen_count * sizeof(CARD32));
- Xfree(screen_list);
-
- mask_list = (CARD32 *)Xmalloc(sizeof(*mask_list) * mask_count);
- for (i = 0; i < mask_count; i++) mask_list[i] = masks[i];
- Data32(dpy, mask_list, mask_count * sizeof(CARD32));
- Xfree(mask_list);
-
- for (i = 0; i < screen_count; i++) {
- if (i < mask_count) mask = masks[i];
- req->length += _DMXDumpScreenAttributes(dpy, mask, attrs + i);
- }
-
- if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return DmxBadReply;
- }
- if (error_screen) *error_screen = rep.errorScreen;
- UnlockDisplay(dpy);
- SyncHandle();
- return rep.status;
-}
-
-/** Add a screen. */
-Bool DMXAddScreen(Display *dpy, const char *displayName, unsigned int mask,
- DMXScreenAttributes *attr, int *screen)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXAddScreenReply rep;
- xDMXAddScreenReq *req;
- int length;
- int paddedLength;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXAddScreen, req);
- length = displayName ? strlen(displayName) : 0;
- paddedLength = (length + 3) & ~3;
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXAddScreen;
- req->displayNameLength = length;
- req->physicalScreen = *screen;
- req->valueMask = mask;
- req->length += paddedLength/4;
- req->length += _DMXDumpScreenAttributes(dpy, mask, attr);
-
- if (length) {
- char *buffer = Xmalloc(paddedLength);
- memset(buffer, 0, paddedLength);
- memcpy(buffer, displayName, length);
- Data32(dpy, buffer, paddedLength);
- Xfree(buffer);
- }
-
- if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
- if (screen) *screen = rep.physicalScreen;
- UnlockDisplay(dpy);
- SyncHandle();
- return rep.status == Success ? True : False;
-}
-
-/** Remove a screen. */
-Bool DMXRemoveScreen(Display *dpy, int screen)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXRemoveScreenReply rep;
- xDMXRemoveScreenReq *req;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXRemoveScreen, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXRemoveScreen;
- req->physicalScreen = screen;
-
- if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
- UnlockDisplay(dpy);
- SyncHandle();
- return rep.status == Success ? True : False;
-}
-
-/** If the DMXGetWindowAttributes protocol request returns information
- * about the specified \a window, the number of screens for which
- * information is available will be returned in \a screen_count and
- * information about the first \a available_count of those screens will
- * be placed in \a inf. Because this call transports a great deal of
- * information over the wire, please call #DMXGetScreenCount first, and
- * make sure \a inf is that large.
- *
- * Note that if the specified \a window has not yet been mapped when
- * #DMXGetWindowAttributes is called, then a subsequent XMapWindow call
- * might be buffered in xlib while requests directly to the back-end X
- * servers are processed. This race condition can be solved by calling
- * #DMXSync before talking directly to the back-end X servers.
- *
- * Available in DMX Protocol Version 1.0, but not working correctly
- * until DMX Protocol Version 1.4 */
-Bool DMXGetWindowAttributes(Display *dpy, Window window,
- int *screen_count, int available_count,
- DMXWindowAttributes *inf)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXGetWindowAttributesReply rep;
- xDMXGetWindowAttributesReq *req;
- unsigned long current;
- CARD32 *screens; /* Must match protocol size */
- CARD32 *windows; /* Must match protocol size */
- XRectangle *pos; /* Must match protocol size */
- XRectangle *vis; /* Must match protocol size */
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXGetWindowAttributes, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXGetWindowAttributes;
- req->window = window;
- if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
-
- /* FIXME: check for NULL? */
- screens = Xmalloc(rep.screenCount * sizeof(*screens));
- windows = Xmalloc(rep.screenCount * sizeof(*windows));
- pos = Xmalloc(rep.screenCount * sizeof(*pos));
- vis = Xmalloc(rep.screenCount * sizeof(*vis));
-
- _XRead(dpy, (char *)screens, rep.screenCount * sizeof(*screens));
- _XRead(dpy, (char *)windows, rep.screenCount * sizeof(*windows));
- _XRead(dpy, (char *)pos, rep.screenCount * sizeof(*pos));
- _XRead(dpy, (char *)vis, rep.screenCount * sizeof(*vis));
-
- *screen_count = rep.screenCount;
- for (current = 0;
- current < rep.screenCount && current < (unsigned)available_count;
- current++, inf++) {
- inf->screen = screens[current];
- inf->window = windows[current];
- inf->pos = pos[current];
- inf->vis = vis[current];
- }
-
- Xfree(vis);
- Xfree(pos);
- Xfree(windows);
- Xfree(screens);
-
- UnlockDisplay(dpy);
- SyncHandle();
- return True;
-}
-
-/** If the DMXGetDesktopAttributes protocol request returns information
- * correctly, the information will be placed in \a attr, and True will
- * be returned. Otherwise, False will be returned.
- *
- * Available in DMX Protocol Version 2.0 */
-Bool DMXGetDesktopAttributes(Display *dpy, DMXDesktopAttributes *attr)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXGetDesktopAttributesReply rep;
- xDMXGetDesktopAttributesReq *req;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXGetDesktopAttributes, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXGetDesktopAttributes;
- if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
- attr->width = rep.width;
- attr->height = rep.height;
- attr->shiftX = rep.shiftX;
- attr->shiftY = rep.shiftY;
-
- UnlockDisplay(dpy);
- SyncHandle();
- return True;
-}
-
-static CARD32 _DMXGetDesktopAttribute(int bit, DMXDesktopAttributes *attr)
-{
- switch (1 << bit) {
- case DMXDesktopWidth: return attr->width;
- case DMXDesktopHeight: return attr->height;
- case DMXDesktopShiftX: return attr->shiftX;
- case DMXDesktopShiftY: return attr->shiftY;
- default: return 0;
- }
-}
-
-static int _DMXDumpDesktopAttributes(Display *dpy,
- unsigned long mask,
- DMXDesktopAttributes *attr)
-{
- int i;
- unsigned long value_list[32];
- unsigned long *value = value_list;
- int count = 0;
-
- for (i = 0; i < 32; i++) {
- if (mask & (1 << i)) {
- *value++ = _DMXGetDesktopAttribute(i, attr);
- ++count;
- }
- }
- Data32(dpy, value_list, count * sizeof(CARD32));
- return count;
-}
-
-/** Change the global bounding box and origin offset.
- *
- * Available in DMX Protocol Version 2.0 */
-int DMXChangeDesktopAttributes(Display *dpy,
- unsigned int mask,
- DMXDesktopAttributes *attr)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXChangeDesktopAttributesReply rep;
- xDMXChangeDesktopAttributesReq *req;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXChangeDesktopAttributes, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXChangeDesktopAttributes;
- req->valueMask = mask;
- req->length +=_DMXDumpDesktopAttributes(dpy, mask, attr);
-
- if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return DmxBadReply;
- }
- UnlockDisplay(dpy);
- SyncHandle();
- return rep.status;
-}
-
-/** If the DMXGetInputCount protocol request returns the input count,
- * the value will be placed in \a input_count, and True will be
- * returned. Otherwise, False will be returned.
- *
- * Available in DMX Protocol Version 1.1 */
-Bool DMXGetInputCount(Display *dpy, int *input_count)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXGetInputCountReply rep;
- xDMXGetInputCountReq *req;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXGetInputCount, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXGetInputCount;
- if (!_XReply(dpy, (xReply *)&rep, 0, xTrue)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
- *input_count = rep.inputCount;
- UnlockDisplay(dpy);
- SyncHandle();
- return True;
-}
-
-/** If the DMXGetInputAttributes protocol request returns information
- * about the input device with the specified \a id, information about
- * the input device will be placed in \a inf, and True will be returned.
- * Otherwise, False will be returned.
- *
- * Available in DMX Protocol Version 1.1 */
-Bool DMXGetInputAttributes(Display *dpy, int id, DMXInputAttributes *inf)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXGetInputAttributesReply rep;
- xDMXGetInputAttributesReq *req;
- char *buffer;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXGetInputAttributes, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXGetInputAttributes;
- req->deviceId = id;
- if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
-
- switch (rep.inputType) {
- case 0: inf->inputType = DMXLocalInputType; break;
- case 1: inf->inputType = DMXConsoleInputType; break;
- case 2: inf->inputType = DMXBackendInputType; break;
- }
-
- inf->physicalScreen = rep.physicalScreen;
- inf->physicalId = rep.physicalId;
- inf->isCore = rep.isCore;
- inf->sendsCore = rep.sendsCore;
- inf->detached = rep.detached;
- buffer = Xmalloc(rep.nameLength + 1 + 4 /* for pad */);
- _XReadPad(dpy, buffer, rep.nameLength);
- buffer[rep.nameLength] = '\0';
- inf->name = buffer;
- UnlockDisplay(dpy);
- SyncHandle();
- return True;
-}
-
-/** Add input. */
-Bool DMXAddInput(Display *dpy, unsigned int mask, DMXInputAttributes *attr,
- int *id)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXAddInputReply rep;
- xDMXAddInputReq *req;
- int length;
- int paddedLength;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXAddInput, req);
- length = attr->name ? strlen(attr->name) : 0;
- paddedLength = (length + 3) & ~3;
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXAddInput;
- req->displayNameLength = length;
- req->valueMask = mask;
- req->length += paddedLength/4;
- req->length += _DMXDumpInputAttributes(dpy, mask, attr);
-
- if (length) {
- char *buffer = Xmalloc(paddedLength);
- memset(buffer, 0, paddedLength);
- memcpy(buffer, attr->name, paddedLength);
- Data32(dpy, buffer, paddedLength);
- Xfree(buffer);
- }
-
- if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
- if (id) *id = rep.physicalId;
- UnlockDisplay(dpy);
- SyncHandle();
- return rep.status == Success ? True : False;
-}
-
-/** Add backend input (a helper function that calls #DMXAddInput). */
-Bool DMXAddBackendInput(Display *dpy, int screen, int sendsCore, int *newId)
-{
- DMXInputAttributes attr;
- unsigned int mask = (DMXInputType
- | DMXInputPhysicalScreen
- | DMXInputSendsCore);
-
- attr.inputType = DMXBackendInputType;
- attr.physicalScreen = screen;
- attr.sendsCore = sendsCore;
- attr.name = NULL;
- return DMXAddInput(dpy, mask, &attr, newId);
-}
-
-/** Add console input (a helper function that calls #DMXAddInput). */
-Bool DMXAddConsoleInput(Display *dpy, const char *name, int sendsCore,
- int *newId)
-{
- DMXInputAttributes attr;
- unsigned int mask = (DMXInputType
- | DMXInputSendsCore);
-
- attr.inputType = DMXConsoleInputType;
- attr.physicalScreen = 0;
- attr.sendsCore = sendsCore;
- attr.name = name;
- return DMXAddInput(dpy, mask, &attr, newId);
-}
-
-/** Remove an input. */
-Bool DMXRemoveInput(Display *dpy, int id)
-{
- XExtDisplayInfo *info = find_display(dpy);
- xDMXRemoveInputReply rep;
- xDMXRemoveInputReq *req;
-
- DMXCheckExtension(dpy, info, False);
-
- LockDisplay(dpy);
- GetReq(DMXRemoveInput, req);
- req->reqType = info->codes->major_opcode;
- req->dmxReqType = X_DMXRemoveInput;
- req->physicalId = id;
-
- if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) {
- UnlockDisplay(dpy);
- SyncHandle();
- return False;
- }
- UnlockDisplay(dpy);
- SyncHandle();
- return rep.status == Success ? True : False;
-}