summaryrefslogtreecommitdiff
path: root/app/xwd/wsutils.h
diff options
context:
space:
mode:
Diffstat (limited to 'app/xwd/wsutils.h')
-rw-r--r--app/xwd/wsutils.h340
1 files changed, 340 insertions, 0 deletions
diff --git a/app/xwd/wsutils.h b/app/xwd/wsutils.h
new file mode 100644
index 000000000..4d84ad0fb
--- /dev/null
+++ b/app/xwd/wsutils.h
@@ -0,0 +1,340 @@
+/* $Xorg: wsutils.h,v 1.4 2001/02/09 02:06:03 xorgcvs Exp $ */
+/** ------------------------------------------------------------------------
+ This file contains routines for manipulating generic lists.
+ Lists are implemented with a "harness". In other words, each
+ node in the list consists of two pointers, one to the data item
+ and one to the next node in the list. The head of the list is
+ the same struct as each node, but the "item" ptr is used to point
+ to the current member of the list (used by the first_in_list and
+ next_in_list functions).
+
+Copyright 1994 Hewlett-Packard Co.
+Copyright 1996, 1998 The Open Group
+
+Permission to use, copy, modify, distribute, and sell this software and its
+documentation for any purpose is hereby granted without fee, provided that
+the above copyright notice appear in all copies and that both that
+copyright notice and this permission notice appear in supporting
+documentation.
+
+The above copyright notice and this permission notice 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 NONINFRINGEMENT.
+IN NO EVENT SHALL THE OPEN GROUP 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.
+
+Except as contained in this notice, the name of The Open Group shall
+not be used in advertising or otherwise to promote the sale, use or
+other dealings in this Software without prior written authorization
+from The Open Group.
+
+ ------------------------------------------------------------------------ **/
+/* $XFree86$ */
+
+/******************************************************************************
+ *
+ * This file contains various typedef's, macros and procedure declarations for
+ * a set of example utility procedures contained in the file "wsutils.c".
+ *
+ ******************************************************************************/
+
+/* This is the actual structure returned by the X server describing the
+ * SERVER_OVERLAY_VISUAL property.
+ */
+typedef struct
+{
+ VisualID visualID; /* The VisualID of the overlay visual */
+ int transparentType; /* Can be None, TransparentPixel or
+ * TransparentMask */
+ int value; /* Pixel value */
+ int layer; /* Overlay planes will always be in
+ * layer 1 */
+} OverlayVisualPropertyRec;
+
+
+/* This is structure also describes the SERVER_OVERLAY_VISUAL property, but
+ * should be more useful than the one actually returned by the X server
+ * because it actually points to the visual's XVisualInfo struct rather than
+ * refering to the visual's ID.
+ */
+typedef struct
+{
+ XVisualInfo *pOverlayVisualInfo; /* Pointer to the XVisualInfo struct */
+ int transparentType; /* Can be None, TransparentPixel or
+ * TransparentMask */
+ int value; /* Pixel value */
+ int layer; /* Overlay planes will always be in
+ * layer 1 */
+} OverlayInfo;
+
+
+/* These macros are the values of the "transparentType" above: */
+#ifndef None
+#define None 0
+#endif
+#ifndef TransparentPixel
+#define TransparentPixel 1
+#endif
+
+
+/* These macros define how flexible a program is when it requests a window's
+ * creation with either the CreateImagePlanesWindow() or
+ * CreateOverlayPlanesWindow():
+ */
+#ifndef NOT_FLEXIBLE
+#define NOT_FLEXIBLE 0
+#define FLEXIBLE 1
+#endif
+
+
+/* These macros define the values of the "sbCmapHint" parameter of the
+ * CreateImagePlanesWindow():
+ */
+#ifndef SB_CMAP_TYPE_NORMAL
+#define SB_CMAP_TYPE_NORMAL 1
+#endif
+
+#ifndef SB_CMAP_TYPE_MONOTONIC
+#define SB_CMAP_TYPE_MONOTONIC 2
+#endif
+
+#ifndef SB_CMAP_TYPE_FULL
+#define SB_CMAP_TYPE_FULL 4
+#endif
+
+
+/******************************************************************************
+ *
+ * GetXVisualInfo()
+ *
+ * This routine takes an X11 Display, screen number, and returns whether the
+ * screen supports transparent overlays and three arrays:
+ *
+ * 1) All of the XVisualInfo struct's for the screen.
+ * 2) All of the OverlayInfo struct's for the screen.
+ * 3) An array of pointers to the screen's image plane XVisualInfo
+ * structs.
+ *
+ * The code below obtains the array of all the screen's visuals, and obtains
+ * the array of all the screen's overlay visual information. It then processes
+ * the array of the screen's visuals, determining whether the visual is an
+ * overlay or image visual.
+ *
+ * If the routine sucessfully obtained the visual information, it returns zero.
+ * If the routine didn't obtain the visual information, it returns non-zero.
+ *
+ ******************************************************************************/
+
+extern int GetXVisualInfo(
+ Display *display, /* Which X server (aka "display"). */
+ int screen, /* Which screen of the "display". */
+ int *transparentOverlays, /* Non-zero if there's at least one
+ * overlay visual and if at least one
+ * of those supports a transparent
+ * pixel. */
+ int *numVisuals, /* Number of XVisualInfo struct's
+ * pointed to to by pVisuals. */
+ XVisualInfo **pVisuals, /* All of the device's visuals. */
+ int *numOverlayVisuals, /* Number of OverlayInfo's pointed
+ * to by pOverlayVisuals. If this
+ * number is zero, the device does
+ * not have overlay planes. */
+ OverlayInfo **pOverlayVisuals, /* The device's overlay plane visual
+ * information. */
+ int *numImageVisuals, /* Number of XVisualInfo's pointed
+ * to by pImageVisuals. */
+ XVisualInfo ***pImageVisuals /* The device's image visuals. */
+ );
+
+
+/******************************************************************************
+ *
+ * FreeXVisualInfo()
+ *
+ * This routine frees the data that was allocated by GetXVisualInfo().
+ *
+ ******************************************************************************/
+
+extern void FreeXVisualInfo(
+ XVisualInfo *pVisuals,
+ OverlayInfo *pOverlayVisuals,
+ XVisualInfo **pImageVisuals
+ );
+
+
+/******************************************************************************
+ *
+ * FindImagePlanesVisual()
+ *
+ * This routine attempts to find a visual to use to create an image planes
+ * window based upon the information passed in.
+ *
+ * The "Hint" values give guides to the routine as to what the program wants.
+ * The "depthFlexibility" value tells the routine how much the program wants
+ * the actual "depthHint" specified. If the program can't live with the
+ * screen's image planes visuals, the routine returns non-zero, and the
+ * "depthObtained" and "pImageVisualToUse" return parameters are NOT valid.
+ * Otherwise, the "depthObtained" and "pImageVisualToUse" return parameters
+ * are valid and the routine returns zero.
+ *
+ * NOTE: This is just an example of what can be done. It may or may not be
+ * useful for any specific application.
+ *
+ ******************************************************************************/
+
+extern int FindImagePlanesVisual(
+ Display *display, /* Which X server (aka "display"). */
+ int screen, /* Which screen of the "display". */
+ int numImageVisuals, /* Number of XVisualInfo's pointed
+ * to by pImageVisuals. */
+ XVisualInfo **pImageVisuals, /* The device's image visuals. */
+ int sbCmapHint, /* What Starbase cmap modes will be
+ * used with the visual. NOTE: This
+ * is a mask of the possible values. */
+ int depthHint, /* Desired depth. */
+ int depthFlexibility, /* How much the actual value in
+ * "depthHint" is desired. */
+ Visual **pImageVisualToUse, /* The screen's image visual to use. */
+ int *depthObtained /* Actual depth of the visual. */
+ );
+
+
+/******************************************************************************
+ *
+ * FindOverlayPlanesVisual()
+ *
+ * This routine attempts to find a visual to use to create an overlay planes
+ * window based upon the information passed in.
+ *
+ * While the CreateImagePlanesWindow() routine took a sbCmapHint, this
+ * routine doesn't. Starbase's CMAP_FULL shouldn't be used in overlay planes
+ * windows. This is partially because this functionality is better suited in
+ * the image planes where there are generally more planes, and partially
+ * because the overlay planes generally have PseudoColor visuals with one
+ * color being transparent (the transparent normally being the "white" color
+ * for CMAP_FULL).
+ *
+ * The "depthHint" values give guides to the routine as to what depth the
+ * program wants the window to be. The "depthFlexibility" value tells the
+ * routine how much the program wants the actual "depthHint" specified. If
+ * the program can't live with the screen's overlay planes visuals, the
+ * routine returns non-zero, and the "depthObtained" and "pOverlayVisualToUse"
+ * return parameters are NOT valid. Otherwise, the "depthObtained" and
+ * "pOverlayVisualToUse" return parameters are valid and the routine returns
+ * zero.
+ *
+ * NOTE: This is just an example of what can be done. It may or may not be
+ * useful for any specific application.
+ *
+ ******************************************************************************/
+
+extern int FindOverlayPlanesVisual(
+ Display *display, /* Which X server (aka "display"). */
+ int screen, /* Which screen of the "display". */
+ int numOverlayVisuals, /* Number of OverlayInfo's pointed
+ * to by pOverlayVisuals. */
+ OverlayInfo *pOverlayVisuals, /* The device's overlay plane visual
+ * information. */
+ int depthHint, /* Desired depth. */
+ int depthFlexibility, /* How much the actual value in
+ * "depthHint" is desired. */
+ int transparentBackground, /* Non-zero if the visual must have
+ * a transparent color. */
+ Visual **pOverlayVisualToUse, /* The screen's overlay visual to
+ * use. */
+ int *depthObtained, /* Actual depth of the visual. */
+ int *transparentColor /* The transparent color the program
+ * can use with the visual. */
+ );
+
+
+/******************************************************************************
+ *
+ * CreateImagePlanesWindow()
+ *
+ * This routine creates an image planes window, potentially creates a colormap
+ * for the window to use, and sets the window's standard properties, based
+ * upon the information passed in to the routine. While "created," the window
+ * has not been mapped.
+ *
+ * If the routine suceeds, it returns zero and the return parameters
+ * "imageWindow", "imageColormap" and "mustFreeImageColormap" are valid.
+ * Otherwise, the routine returns non-zero and the return parameters are
+ * NOT valid.
+ *
+ * NOTE: This is just an example of what can be done. It may or may not be
+ * useful for any specific application.
+ *
+ ******************************************************************************/
+
+extern int CreateImagePlanesWindow(
+ Display *display, /* Which X server (aka "display"). */
+ int screen, /* Which screen of the "display". */
+ Window parentWindow, /* Window ID of the parent window for
+ * the created window. */
+ int windowX, /* Desired X coord. of the window. */
+ int windowY, /* Desired Y coord of the window. */
+ int windowWidth, /* Desired width of the window. */
+ int windowHeight, /* Desired height of the window. */
+ int windowDepth, /* Desired depth of the window. */
+ Visual *pImageVisualToUse, /* The window's image planes visual. */
+ int argc, /* Program's argc parameter. */
+ char *argv[], /* Program's argv parameter. */
+ char *windowName, /* Name to put on window's border. */
+ char *iconName, /* Name to put on window's icon. */
+ Window *imageWindow, /* Window ID of the created window. */
+ Colormap *imageColormap, /* The window's colormap. */
+ int *mustFreeImageColormap /* Non-zero if the program must call
+ * XFreeColormap() for imageColormap. */
+ );
+
+
+/******************************************************************************
+ *
+ * CreateOverlayPlanesWindow()
+ *
+ * This routine creates an overlay planes window, potentially creates a colormap
+ * for the window to use, and sets the window's standard properties, based
+ * upon the information passed in to the routine. While "created," the window
+ * has not been mapped.
+ *
+ * If the routine suceeds, it returns zero and the return parameters
+ * "overlayWindow", "overlayColormap" and "mustFreeOverlayColormap" are valid.
+ * Otherwise, the routine returns non-zero and the return parameters are
+ * NOT valid.
+ *
+ * NOTE: This is just an example of what can be done. It may or may not be
+ * useful for any specific application.
+ *
+ ******************************************************************************/
+
+int CreateOverlayPlanesWindow(
+ Display *display, /* Which X server (aka "display"). */
+ int screen, /* Which screen of the "display". */
+ Window parentWindow, /* Window ID of the parent window for
+ * the created window. */
+ int windowX, /* Desired X coord. of the window. */
+ int windowY, /* Desired Y coord of the window. */
+ int windowWidth, /* Desired width of the window. */
+ int windowHeight, /* Desired height of the window. */
+ int windowDepth, /* Desired depth of the window. */
+ Visual *pOverlayVisualToUse, /* The window's overlay planes visual.*/
+ int argc, /* Program's argc parameter. */
+ char *argv[], /* Program's argv parameter. */
+ char *windowName, /* Name to put on window's border. */
+ char *iconName, /* Name to put on window's icon. */
+ int transparentBackground, /* Non-zero if the window's background
+ * should be a transparent color. */
+ int *transparentColor, /* The transparent color to use as the
+ * window's background. */
+ Window *overlayWindow, /* Window ID of the created window. */
+ Colormap *overlayColormap, /* The window's colormap. */
+ int *mustFreeOverlayColormap/* Non-zero if the program must call
+ * XFreeColormap() for
+ * overlayColormap. */
+ );