diff options
Diffstat (limited to 'xorg-server/miext')
| -rw-r--r-- | xorg-server/miext/damage/damage.c | 6 | ||||
| -rw-r--r-- | xorg-server/miext/damage/makefile | 7 | ||||
| -rw-r--r-- | xorg-server/miext/rootless/makefile | 10 | ||||
| -rw-r--r-- | xorg-server/miext/rootless/rootlessGC.c | 3 | ||||
| -rw-r--r-- | xorg-server/miext/rootless/rootlessWindow.c | 14 | ||||
| -rw-r--r-- | xorg-server/miext/rootless/xplugin.h | 592 | ||||
| -rw-r--r-- | xorg-server/miext/shadow/makefile | 25 | ||||
| -rw-r--r-- | xorg-server/miext/sync/makefile | 6 | 
8 files changed, 656 insertions, 7 deletions
| diff --git a/xorg-server/miext/damage/damage.c b/xorg-server/miext/damage/damage.c index 9bd9c84e7..f303249e2 100644 --- a/xorg-server/miext/damage/damage.c +++ b/xorg-server/miext/damage/damage.c @@ -1170,9 +1170,9 @@ damagePolyFillRect(DrawablePtr pDrawable,          int nRectsTmp = nRects;          box.x1 = pRectsTmp->x; -        box.x2 = box.x1 + pRectsTmp->width; +        box.x2 = box.x1 + (short)pRectsTmp->width;          box.y1 = pRectsTmp->y; -        box.y2 = box.y1 + pRectsTmp->height; +        box.y2 = box.y1 + (short)pRectsTmp->height;          while (--nRectsTmp) {              pRectsTmp++; @@ -1875,7 +1875,7 @@ DamageRegionProcessPending(DrawablePtr pDrawable)  /* This call is very odd, i'm leaving it intact for API sake, but please don't use it. */  void -DamageDamageRegion(DrawablePtr pDrawable, RegionPtr pRegion) +DamageDamageRegion(DrawablePtr pDrawable, const RegionPtr pRegion)  {      damageRegionAppend(pDrawable, pRegion, FALSE, -1); diff --git a/xorg-server/miext/damage/makefile b/xorg-server/miext/damage/makefile new file mode 100644 index 000000000..e58f4a883 --- /dev/null +++ b/xorg-server/miext/damage/makefile @@ -0,0 +1,7 @@ +LIBRARY = libdamage + +#INCLUDES = -I$(srcdir)/../cw -I$(top_srcdir)/hw/xfree86/os-support + +CSRCS =damage.c + + diff --git a/xorg-server/miext/rootless/makefile b/xorg-server/miext/rootless/makefile new file mode 100644 index 000000000..d49e810a2 --- /dev/null +++ b/xorg-server/miext/rootless/makefile @@ -0,0 +1,10 @@ +LIBRARY=librootless + +librootless_la_SOURCES = \ +	rootlessCommon.c \ +	rootlessGC.c \ +	rootlessScreen.c \ +	rootlessValTree.c \ +	rootlessWindow.c + +CSRCS = $(filter %.c,$(librootless_la_SOURCES)) diff --git a/xorg-server/miext/rootless/rootlessGC.c b/xorg-server/miext/rootless/rootlessGC.c index 23ff3934e..71eaa11d1 100644 --- a/xorg-server/miext/rootless/rootlessGC.c +++ b/xorg-server/miext/rootless/rootlessGC.c @@ -49,6 +49,9 @@  #include "rootlessCommon.h" +#ifdef _MSC_VER +#define inline __inline +#endif  // GC functions  static void RootlessValidateGC(GCPtr pGC, unsigned long changes,                                 DrawablePtr pDrawable); diff --git a/xorg-server/miext/rootless/rootlessWindow.c b/xorg-server/miext/rootless/rootlessWindow.c index 3dbd5886a..7b9be2cfe 100644 --- a/xorg-server/miext/rootless/rootlessWindow.c +++ b/xorg-server/miext/rootless/rootlessWindow.c @@ -51,6 +51,12 @@ extern Bool no_configure_window;  #include "rootlessCommon.h"  #include "rootlessWindow.h" +#ifdef _MSC_VER +#define inline __inline +#include "xplugin.h" +extern int darwinMainScreenX, darwinMainScreenY; +#endif +  #define SCREEN_TO_GLOBAL_X \      (pScreen->x + rootlessGlobalOffsetX)  #define SCREEN_TO_GLOBAL_Y \ @@ -995,6 +1001,7 @@ StartFrameResize(WindowPtr pWin, Bool gravity,      }      else if (gravity) {          /* The general case. Just copy everything. */ +        BoxRec tmpBoxRec={oldX, oldY, oldX2, oldY2};          RootlessStartDrawing(pWin); @@ -1003,8 +1010,7 @@ StartFrameResize(WindowPtr pWin, Bool gravity,          memcpy(gResizeDeathBits, winRec->pixelData,                 winRec->bytesPerRow * winRec->height); -        gResizeDeathBounds[0] = (BoxRec) { -        oldX, oldY, oldX2, oldY2}; +        gResizeDeathBounds[0] = tmpBoxRec;          gResizeDeathPix[0]              = GetScratchPixmapHeader(pScreen, winRec->width,                                       winRec->height, @@ -1041,8 +1047,8 @@ StartFrameResize(WindowPtr pWin, Bool gravity,         window bits. */      if (need_window_source) { -        gResizeDeathBounds[0] = (BoxRec) { -        oldX, oldY, oldX2, oldY2}; +        BoxRec tmpBoxRec={oldX, oldY, oldX2, oldY2}; +        gResizeDeathBounds[0] = tmpBoxRec;          gResizeDeathPix[0]              = GetScratchPixmapHeader(pScreen, oldW, oldH,                                       winRec->win->drawable.depth, diff --git a/xorg-server/miext/rootless/xplugin.h b/xorg-server/miext/rootless/xplugin.h new file mode 100644 index 000000000..7fdf6006e --- /dev/null +++ b/xorg-server/miext/rootless/xplugin.h @@ -0,0 +1,592 @@ +/* Xplugin.h -- windowing API for rootless X11 server +   $Id$ + +   Copyright (c) 2002 Apple Computer, Inc. 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 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 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 ABOVE LISTED COPYRIGHT +   HOLDER(S) 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(s) of the above +   copyright holders shall not be used in advertising or otherwise to +   promote the sale, use or other dealings in this Software without +   prior written authorization. + +   Note that these interfaces are provided solely for the use of the +   X11 server. Any other uses are unsupported and strongly discouraged. */ +/* $XFree86: xc/programs/Xserver/hw/darwin/quartz/xpr/Xplugin.h,v 1.2 2003/05/02 00:08:49 torrey Exp $ */ + +#ifndef XPLUGIN_H +#define XPLUGIN_H 1 + +#include <stdint.h> + +/* By default we use the X server definition of BoxRec to define xp_box, +   so that the compiler can silently convert between the two. But if +   XP_NO_X_HEADERS is defined, we'll define it ourselves. */ + +#ifndef XP_NO_X_HEADERS +# include "miscstruct.h" +  typedef BoxRec xp_box; +#else +  struct xp_box_struct { +      short x1, y1, x2, y2; +  }; +  typedef struct xp_box_struct xp_box; +#endif + +typedef unsigned int xp_resource_id; +typedef xp_resource_id xp_window_id; +typedef xp_resource_id xp_surface_id; +typedef unsigned int xp_client_id; +typedef unsigned int xp_request_type; +typedef int xp_error; +typedef int xp_bool; + + +/* Error codes that the functions declared here may return. They all +   numerically match their X equivalents, i.e. the XP_ can be dropped +   if <X11/X.h> has been included. */ + +enum xp_error_enum { +    XP_Success			= 0, +    XP_BadRequest		= 1, +    XP_BadValue			= 2, +    XP_BadWindow		= 3, +    XP_BadMatch			= 8, +    XP_BadAccess		= 10, +    XP_BadImplementation	= 17, +};     + + +/* Event types generated by the plugin. */ + +enum xp_event_type_enum { +    /* The global display configuration changed somehow. */ +    XP_EVENT_DISPLAY_CHANGED	= 1 << 0, + +    /* A window changed state. Argument is xp_window_state_event */ +    XP_EVENT_WINDOW_STATE_CHANGED = 1 << 1, + +    /* An async request encountered an error. Argument is of type +       xp_async_error_event */ +    XP_EVENT_ASYNC_ERROR	= 1 << 2, + +    /* Sent when a surface is destroyed as a side effect of destroying +       a window. Arg is of type xp_surface_id. */ +    XP_EVENT_SURFACE_DESTROYED	= 1 << 3, + +    /* Sent when any GL contexts pointing at the given surface need to +       call xp_update_gl_context () to refresh their state (because the +       window moved or was resized. Arg is of type xp_surface_id. */ +    XP_EVENT_SURFACE_CHANGED	= 1 << 4, + +    /* Sent when a window has been moved. Arg is of type xp_window_id. */ +    XP_EVENT_WINDOW_MOVED	= 1 << 5, +}; + +/* Function type used to receive events. */ + +typedef void (xp_event_fun) (unsigned int type, const void *arg, +			     unsigned int arg_size, void *user_data); + + +/* Operation types. Used when reporting errors asynchronously. */ + +enum xp_request_type_enum { +    XP_REQUEST_NIL = 0, +    XP_REQUEST_DESTROY_WINDOW = 1, +    XP_REQUEST_CONFIGURE_WINDOW = 2, +    XP_REQUEST_FLUSH_WINDOW = 3, +    XP_REQUEST_COPY_WINDOW = 4, +    XP_REQUEST_UNLOCK_WINDOW = 5, +    XP_REQUEST_DISABLE_UPDATE = 6, +    XP_REQUEST_REENABLE_UPDATE = 7, +    XP_REQUEST_HIDE_CURSOR = 8, +    XP_REQUEST_SHOW_CURSOR = 9, +    XP_REQUEST_FRAME_DRAW = 10, +}; + +/* Structure used to report an error asynchronously. Passed as the "arg" +   of an XP_EVENT_ASYNC_ERROR event. */ + +struct xp_async_error_event_struct { +    xp_request_type request_type; +    xp_resource_id id; +    xp_error error; +}; + +typedef struct xp_async_error_event_struct xp_async_error_event; + + +/* Possible window states. */ + +enum xp_window_state_enum { +    /* The window is not in the global list of possibly-visible windows. */ +    XP_WINDOW_STATE_OFFSCREEN	= 1 << 0, + +    /* Parts of the window may be obscured by other windows. */ +    XP_WINDOW_STATE_OBSCURED	= 1 << 1, +}; + +/* Structure passed as argument of an XP_EVENT_WINDOW_STATE_CHANGED event. */ + +struct xp_window_state_event_struct { +    xp_window_id id; +    unsigned int state; +}; + +typedef struct xp_window_state_event_struct xp_window_state_event; + + +/* Function type used to supply a colormap for indexed drawables. */ + +typedef xp_error (xp_colormap_fun) (void *data, int first_color, +				    int n_colors, uint32_t *colors); + + +/* Window attributes structure. Used when creating and configuring windows. +   Also used when configuring surfaces attached to windows. Functions that +   take one of these structures also take a bit mask defining which +   fields are set to meaningful values. */ + +enum xp_window_changes_enum { +    XP_ORIGIN			= 1 << 0, +    XP_SIZE			= 1 << 1, +    XP_BOUNDS			= XP_ORIGIN | XP_SIZE, +    XP_SHAPE			= 1 << 2, +    XP_STACKING			= 1 << 3, +    XP_DEPTH			= 1 << 4, +    XP_COLORMAP			= 1 << 5, +    XP_WINDOW_LEVEL		= 1 << 6, +}; + +struct xp_window_changes_struct { +    /* XP_ORIGIN */ +    int x, y; + +    /* XP_SIZE */ +    unsigned int width, height; +    int bit_gravity;			/* how to resize the backing store */ + +    /* XP_SHAPE */ +    int shape_nrects;			/* -1 = remove shape */ +    xp_box *shape_rects; +    int shape_tx, shape_ty;		/* translation for shape */ + +    /* XP_STACKING */ +    int stack_mode; +    xp_window_id sibling;		/* may be zero; in ABOVE/BELOW modes +					   it may specify a relative window */ +    /* XP_DEPTH, window-only */ +    unsigned int depth; + +    /* XP_COLORMAP, window-only */ +    xp_colormap_fun *colormap; +    void *colormap_data; + +    /* XP_WINDOW_LEVEL, window-only */ +    int window_level; +}; + +typedef struct xp_window_changes_struct xp_window_changes; + +/* Values for bit_gravity field */ + +enum xp_bit_gravity_enum { +    XP_GRAVITY_NONE		= 0,	/* no gravity, fill everything */ +    XP_GRAVITY_NORTH_WEST	= 1,	/* anchor to top-left corner */ +    XP_GRAVITY_NORTH_EAST	= 2,	/* anchor to top-right corner */ +    XP_GRAVITY_SOUTH_EAST	= 3,	/* anchor to bottom-right corner */ +    XP_GRAVITY_SOUTH_WEST	= 4,	/* anchor to bottom-left corner */ +}; + +/* Values for stack_mode field */ + +enum xp_window_stack_mode_enum { +    XP_UNMAPPED			= 0,	/* remove the window */ +    XP_MAPPED_ABOVE		= 1,	/* display the window on top */ +    XP_MAPPED_BELOW		= 2,	/* display the window at bottom */ +}; + +/* Data formats for depth field and composite functions */ + +enum xp_depth_enum { +    XP_DEPTH_NIL = 0,			/* null source when compositing */ +    XP_DEPTH_ARGB8888, +    XP_DEPTH_RGB555, +    XP_DEPTH_A8,			/* for masks when compositing */ +    XP_DEPTH_INDEX8, +}; + +/* Options that may be passed to the xp_init () function. */ + +enum xp_init_options_enum { +    /* Don't mark that this process can be in the foreground. */ +    XP_IN_BACKGROUND		= 1 << 0, + +    /* Deliver background pointer events to this process. */ +    XP_BACKGROUND_EVENTS	= 1 << 1, +}; + + + +/* Miscellaneous functions */ + +/* Initialize the plugin library. Only the copy/fill/composite functions +   may be called without having previously called xp_init () */ + +extern xp_error xp_init (unsigned int options); + +/* Sets the current set of requested notifications to MASK. When any of +   these arrive, CALLBACK will be invoked with CALLBACK-DATA. Note that +   calling this function cancels any previously requested notifications +   that aren't set in MASK. */ + +extern xp_error xp_select_events (unsigned int mask, +				  xp_event_fun *callback, +				  void *callback_data); + +/* Waits for all initiated operations to complete. */ + +extern xp_error xp_synchronize (void); + +/* Causes any display update initiated through the plugin libary to be +   queued until update is reenabled. Note that calls to these functions +   nest. */ +   +extern xp_error xp_disable_update (void); +extern xp_error xp_reenable_update (void); + + + +/* Cursor functions. */ + +/* Installs the specified cursor. ARGB-DATA should point to 32-bit +   premultiplied big-endian ARGB data. The HOT-X,HOT-Y parameters +   specify the offset to the cursor's hot spot from its top-left +   corner. */ + +extern xp_error xp_set_cursor (unsigned int width, unsigned int height, +			       unsigned int hot_x, unsigned int hot_y, +			       const uint32_t *argb_data, +			       unsigned int rowbytes); + +/* Hide and show the cursor if it's owned by the current process. Calls +   to these functions nest. */ + +extern xp_error xp_hide_cursor (void); +extern xp_error xp_show_cursor (void); + + + +/* Window functions. */ + +/* Create a new window as defined by MASK and VALUES. MASK must contain +   XP_BOUNDS or an error is raised. The id of the newly created window +   is stored in *RET-ID if this function returns XP_Success. */ + +extern xp_error xp_create_window (unsigned int mask, +				  const xp_window_changes *values, +				  xp_window_id *ret_id); + +/* Destroys the window identified by ID. */ + +extern xp_error xp_destroy_window (xp_window_id id); + +/* Reconfigures the given window according to MASK and VALUES. */ + +extern xp_error xp_configure_window (xp_window_id id, unsigned int mask, +				     const xp_window_changes *values); + + +/* Returns true if NATIVE-ID is a window created by the plugin library. +   If so and RET-ID is non-null, stores the id of the window in *RET-ID. */ + +extern xp_bool xp_lookup_native_window (unsigned int native_id, +					xp_window_id *ret_id); + +/* If ID names a window created by the plugin library, stores it's native +   window id in *RET-NATIVE-ID. */ + +extern xp_error xp_get_native_window (xp_window_id id, +				      unsigned int *ret_native_id); + + +/* Locks the rectangle IN-RECT (or, if null, the entire window) of the +   given window's backing store. Any other non-null parameters are filled +   in as follows: + +   DEPTH = format of returned data. Currently either XP_DEPTH_ARGB8888 +   or XP_DEPTH_RGB565 (possibly with 8 bit planar alpha). Data is +   always stored in native byte order. + +   BITS[0] = pointer to top-left pixel of locked color data +   BITS[1] = pointer to top-left of locked alpha data, or null if window +   has no alpha. If the alpha data is meshed, then BITS[1] = BITS[0]. + +   ROWBYTES[0,1] = size in bytes of each row of color,alpha data + +   OUT-RECT = rectangle specifying the current position and size of the +   locked region relative to the window origin. + +   Note that an error is raised when trying to lock an already locked +   window. While the window is locked, the only operations that may +   be performed on it are to modify, access or flush its marked region. */ + +extern xp_error xp_lock_window (xp_window_id id, +				const xp_box *in_rect, +				unsigned int *depth, +				void *bits[2], +				unsigned int rowbytes[2], +				xp_box *out_rect); + +/* Mark that the region specified by SHAPE-NRECTS, SHAPE-RECTS, +   SHAPE-TX, and SHAPE-TY in the specified window has been updated, and +   will need to subsequently be redisplayed. */ + +extern xp_error xp_mark_window (xp_window_id id, int shape_nrects, +				const xp_box *shape_rects, +				int shape_tx, int shape_ty); + +/* Unlocks the specified window. If FLUSH is true, then any marked +   regions are immediately redisplayed. Note that it's an error to +   unlock an already unlocked window. */ + +extern xp_error xp_unlock_window (xp_window_id id, xp_bool flush); + +/* If anything is marked in the given window for redisplay, do it now. */ + +extern xp_error xp_flush_window (xp_window_id id); + +/* Moves the contents of the region DX,DY pixels away from that specified +   by DST_RECTS and DST_NRECTS in the window with SRC-ID to the +   destination region in the window DST-ID. Note that currently source +   and destination windows must be the same. */ + +extern xp_error xp_copy_window (xp_window_id src_id, xp_window_id dst_id, +				int dst_nrects, const xp_box *dst_rects, +				int dx, int dy); + +/* Returns true if the given window has any regions marked for +   redisplay. */ + +extern xp_bool xp_is_window_marked (xp_window_id id); + +/* If successful returns a superset of the region marked for update in +   the given window. Use xp_free_region () to release the returned data. */ + +extern xp_error xp_get_marked_shape (xp_window_id id, +				     int *ret_nrects, xp_box **ret_rects); + +extern void xp_free_shape (int nrects, xp_box *rects); + +/* Searches for the first window below ABOVE-ID containing the point X,Y, +   and returns it's window id in *RET-ID. If no window is found, *RET-ID +   is set to zero. If ABOVE-ID is zero, finds the topmost window +   containing the given point. */ + +extern xp_error xp_find_window (int x, int y, xp_window_id above_id, +				xp_window_id *ret_id); + +/* Returns the current origin and size of the window ID in *BOUNDS-RET if +   successful. */ +extern xp_error xp_get_window_bounds (xp_window_id id, xp_box *bounds_ret); + + + +/* Window surface functions. */ + +/* Create a new VRAM surface on the specified window. If successful, +   returns the identifier of the new surface in *RET-SID. */ + +extern xp_error xp_create_surface (xp_window_id id, xp_surface_id *ret_sid); + +/* Destroys the specified surface. */ + +extern xp_error xp_destroy_surface (xp_surface_id sid); + +/* Reconfigures the specified surface as defined by MASK and VALUES. +   Note that specifying XP_DEPTH is an error. */ + +extern xp_error xp_configure_surface (xp_surface_id sid, unsigned int mask, +				      const xp_window_changes *values); + +/* If successful, places the client identifier of the current process +   in *RET-CLIENT. */ + +extern xp_error xp_get_client_id (xp_client_id *ret_client); + +/* Given a valid window,surface combination created by the current +   process, attempts to allow the specified external client access +   to that surface. If successful, returns two integers in RET-KEY +   which the client can use to import the surface into their process. */ + +extern xp_error xp_export_surface (xp_window_id wid, xp_surface_id sid, +				   xp_client_id client, +				   unsigned int ret_key[2]); + +/* Given a two integer key returned from xp_export_surface (), tries +   to import the surface into the current process. If successful the +   local surface identifier is stored in *SID-RET. */ + +extern xp_error xp_import_surface (const unsigned int key[2], +				   xp_surface_id *sid_ret); + +/* If successful, stores the number of surfaces attached to the +   specified window in *RET. */ + +extern xp_error xp_get_window_surface_count (xp_window_id id, +					     unsigned int *ret); + +/* Attaches the CGLContextObj CGL-CTX to the specified surface. */ + +extern xp_error xp_attach_gl_context (void *cgl_ctx, xp_surface_id sid); + +/* Updates the CGLContextObj CGL-CTX to reflect any recent changes to +   the surface it's attached to. */ + +extern xp_error xp_update_gl_context (void *cgl_ctx); + + + +/* Window frame functions. */ + +/* Possible arguments to xp_frame_get_rect (). */ + +enum xp_frame_rect_enum { +    XP_FRAME_RECT_TITLEBAR		= 1, +    XP_FRAME_RECT_TRACKING		= 2, +    XP_FRAME_RECT_GROWBOX		= 3, +}; + +/* Classes of window frame. */ + +enum xp_frame_class_enum { +    XP_FRAME_CLASS_DOCUMENT		= 1 << 0, +    XP_FRAME_CLASS_DIALOG		= 1 << 1, +    XP_FRAME_CLASS_MODAL_DIALOG		= 1 << 2, +    XP_FRAME_CLASS_SYSTEM_MODAL_DIALOG	= 1 << 3, +    XP_FRAME_CLASS_UTILITY		= 1 << 4, +    XP_FRAME_CLASS_TOOLBAR		= 1 << 5, +    XP_FRAME_CLASS_MENU			= 1 << 6, +    XP_FRAME_CLASS_SPLASH		= 1 << 7, +    XP_FRAME_CLASS_BORDERLESS		= 1 << 8, +}; + +/* Attributes of window frames. */ + +enum xp_frame_attr_enum { +    XP_FRAME_ACTIVE			= 0x0001, +    XP_FRAME_URGENT			= 0x0002, +    XP_FRAME_TITLE			= 0x0004, +    XP_FRAME_PRELIGHT			= 0x0008, +    XP_FRAME_SHADED			= 0x0010, +    XP_FRAME_CLOSE_BOX			= 0x0100, +    XP_FRAME_COLLAPSE			= 0x0200, +    XP_FRAME_ZOOM			= 0x0400, +    XP_FRAME_ANY_BUTTON			= 0x0700, +    XP_FRAME_CLOSE_BOX_CLICKED		= 0x0800, +    XP_FRAME_COLLAPSE_BOX_CLICKED	= 0x1000, +    XP_FRAME_ZOOM_BOX_CLICKED		= 0x2000, +    XP_FRAME_ANY_CLICKED		= 0x3800, +    XP_FRAME_GROW_BOX			= 0x4000, +}; + +#define XP_FRAME_ATTR_IS_SET(a,b)	(((a) & (b)) == (b)) +#define XP_FRAME_ATTR_IS_CLICKED(a,m)	((a) & ((m) << 3)) +#define XP_FRAME_ATTR_SET_CLICKED(a,m)	((a) |= ((m) << 3)) +#define XP_FRAME_ATTR_UNSET_CLICKED(a,m) ((a) &= ~((m) << 3)) + +#define XP_FRAME_POINTER_ATTRS		(XP_FRAME_PRELIGHT		\ +					 | XP_FRAME_ANY_BUTTON		\ +					 | XP_FRAME_ANY_CLICKED) + +extern xp_error xp_frame_get_rect (int type, int class, const xp_box *outer, +				   const xp_box *inner, xp_box *ret); +extern xp_error xp_frame_hit_test (int class, int x, int y, +				   const xp_box *outer, +				   const xp_box *inner, int *ret); +extern xp_error xp_frame_draw (xp_window_id wid, int class, unsigned int attr, +			       const xp_box *outer, const xp_box *inner, +			       unsigned int title_len, +			       const unsigned char *title_bytes); + + + +/* Memory manipulation functions. */ + +enum xp_composite_op_enum { +    XP_COMPOSITE_SRC = 0, +    XP_COMPOSITE_OVER, +}; + +#define XP_COMPOSITE_FUNCTION(op, src_depth, mask_depth, dest_depth) \ +    (((op) << 24) | ((src_depth) << 16) \ +     | ((mask_depth) << 8) | ((dest_depth) << 0)) + +#define XP_COMPOSITE_FUNCTION_OP(f)         (((f) >> 24) & 255) +#define XP_COMPOSITE_FUNCTION_SRC_DEPTH(f)  (((f) >> 16) & 255) +#define XP_COMPOSITE_FUNCTION_MASK_DEPTH(f) (((f) >>  8) & 255) +#define XP_COMPOSITE_FUNCTION_DEST_DEPTH(f) (((f) >>  0) & 255) + +/* Composite WIDTH by HEIGHT pixels from source and mask to destination +   using a specified function (if source and destination overlap, +   undefined behavior results). + +   For SRC and DEST, the first element of the array is the color data. If +   the second element is non-null it implies that there is alpha data +   (which may be meshed or planar). Data without alpha is assumed to be +   opaque. + +   Passing a null SRC-ROWBYTES pointer implies that the data SRC points +   to is a single element. + +   Operations that are not supported will return XP_BadImplementation. */ + +extern xp_error xp_composite_pixels (unsigned int width, unsigned int height, +				     unsigned int function, +				     void *src[2], unsigned int src_rowbytes[2], +				     void *mask, unsigned int mask_rowbytes, +				     void *dest[2], unsigned int dest_rowbytes[2]); + +/* Fill HEIGHT rows of data starting at DST. Each row will have WIDTH +   bytes filled with the 32-bit pattern VALUE. Each row is DST-ROWBYTES +   wide in total. */ + +extern void xp_fill_bytes (unsigned int width, +			   unsigned int height, uint32_t value, +			   void *dst, unsigned int dst_rowbytes); + +/* Copy HEIGHT rows of bytes from SRC to DST. Each row will have WIDTH +   bytes copied. SRC and DST may overlap, and the right thing will happen. */ + +extern void xp_copy_bytes (unsigned int width, unsigned int height, +			   const void *src, unsigned int src_rowbytes, +			   void *dst, unsigned int dst_rowbytes); + +/* Suggestions for the minimum number of bytes or pixels for which it +   makes sense to use some of the xp_ functions */ + +extern unsigned int xp_fill_bytes_threshold, xp_copy_bytes_threshold, +    xp_composite_area_threshold, xp_scroll_area_threshold; + + +#endif /* XPLUGIN_H */ + diff --git a/xorg-server/miext/shadow/makefile b/xorg-server/miext/shadow/makefile new file mode 100644 index 000000000..0a84b506c --- /dev/null +++ b/xorg-server/miext/shadow/makefile @@ -0,0 +1,25 @@ +LIBRARY = libshadow + +#INCLUDES = -I$(top_srcdir)/hw/xfree86/os-support + +CSRCS =	shadow.c		\ +	shalloc.c		\ +	shpacked.c		\ +	shplanar8.c		\ +	shplanar.c		\ +	shrot16pack_180.c	\ +	shrot16pack_270.c	\ +	shrot16pack_270YX.c	\ +	shrot16pack_90.c	\ +	shrot16pack_90YX.c	\ +	shrot16pack.c		\ +	shrot32pack_180.c	\ +	shrot32pack_270.c	\ +	shrot32pack_90.c	\ +	shrot32pack.c		\ +	shrot8pack_180.c	\ +	shrot8pack_270.c	\ +	shrot8pack_90.c		\ +	shrot8pack.c		\ +	shrotate.c + diff --git a/xorg-server/miext/sync/makefile b/xorg-server/miext/sync/makefile new file mode 100644 index 000000000..295fdb250 --- /dev/null +++ b/xorg-server/miext/sync/makefile @@ -0,0 +1,6 @@ +LIBRARY = libsync
 +
 +CSRCS =	\
 +	misync.c	\
 +	misyncfd.c	\
 +
 | 
