built,working DAMAGE/XFIXES in mono tree

This commit is contained in:
Stuart Kreitman 2004-03-25 03:45:49 +00:00
parent 3c2e2d9ae0
commit f0336f18ee
12 changed files with 193 additions and 64 deletions

View File

@ -61,7 +61,7 @@ static int ShapeFreeEvents(
pointer /* data */, pointer /* data */,
XID /* id */ XID /* id */
); );
static void SendShapeNotify( void SendShapeNotify(
WindowPtr /* pWin */, WindowPtr /* pWin */,
int /* which */ int /* which */
); );
@ -87,8 +87,8 @@ RegionOperate (
#define CREATE_PROC(func) RegionPtr func(WindowPtr /* pWin */) #define CREATE_PROC(func) RegionPtr func(WindowPtr /* pWin */)
static CREATE_PROC(CreateBoundingShape); CREATE_PROC(CreateBoundingShape);
static CREATE_PROC(CreateClipShape); CREATE_PROC(CreateClipShape);
#undef CREATE_PROC #undef CREATE_PROC
@ -261,7 +261,7 @@ RegionOperate (client, pWin, kind, destRgnp, srcRgn, op, xoff, yoff, create)
return Success; return Success;
} }
static RegionPtr RegionPtr
CreateBoundingShape (pWin) CreateBoundingShape (pWin)
WindowPtr pWin; WindowPtr pWin;
{ {
@ -274,7 +274,7 @@ CreateBoundingShape (pWin)
return REGION_CREATE(pWin->drawable.pScreen, &extents, 1); return REGION_CREATE(pWin->drawable.pScreen, &extents, 1);
} }
static RegionPtr RegionPtr
CreateClipShape (pWin) CreateClipShape (pWin)
WindowPtr pWin; WindowPtr pWin;
{ {
@ -880,7 +880,7 @@ ProcShapeSelectInput (client)
* deliver the event * deliver the event
*/ */
static void void
SendShapeNotify (pWin, which) SendShapeNotify (pWin, which)
WindowPtr pWin; WindowPtr pWin;
int which; int which;

View File

@ -627,7 +627,7 @@ ProcChangeSaveSet(client)
return BadMatch; return BadMatch;
if ((stuff->mode == SetModeInsert) || (stuff->mode == SetModeDelete)) if ((stuff->mode == SetModeInsert) || (stuff->mode == SetModeDelete))
{ {
result = AlterSaveSetForClient(client, pWin, stuff->mode); result = AlterSaveSetForClient(client, pWin, stuff->mode, FALSE, TRUE);
if (client->noClientException != Success) if (client->noClientException != Success)
return(client->noClientException); return(client->noClientException);
else else

View File

@ -152,6 +152,21 @@ ClientTimeToServerTime(c)
* beware of too-small buffers * beware of too-small buffers
*/ */
static unsigned char
ISOLatin1ToLower (unsigned char source)
{
unsigned char dest;
if ((source >= XK_A) && (source <= XK_Z))
dest = source + (XK_a - XK_A);
else if ((source >= XK_Agrave) && (source <= XK_Odiaeresis))
dest = source + (XK_agrave - XK_Agrave);
else if ((source >= XK_Ooblique) && (source <= XK_Thorn))
dest = source + (XK_oslash - XK_Ooblique);
else
dest = source;
return dest;
}
void void
CopyISOLatin1Lowered(dest, source, length) CopyISOLatin1Lowered(dest, source, length)
register unsigned char *dest, *source; register unsigned char *dest, *source;
@ -160,19 +175,29 @@ CopyISOLatin1Lowered(dest, source, length)
register int i; register int i;
for (i = 0; i < length; i++, source++, dest++) for (i = 0; i < length; i++, source++, dest++)
{ *dest = ISOLatin1ToLower (*source);
if ((*source >= XK_A) && (*source <= XK_Z))
*dest = *source + (XK_a - XK_A);
else if ((*source >= XK_Agrave) && (*source <= XK_Odiaeresis))
*dest = *source + (XK_agrave - XK_Agrave);
else if ((*source >= XK_Ooblique) && (*source <= XK_Thorn))
*dest = *source + (XK_oslash - XK_Ooblique);
else
*dest = *source;
}
*dest = '\0'; *dest = '\0';
} }
int
CompareISOLatin1Lowered(unsigned char *s1, int s1len,
unsigned char *s2, int s2len)
{
unsigned char c1, c2;
for (;;)
{
/* note -- compare against zero so that -1 ignores len */
c1 = s1len-- ? *s1++ : '\0';
c2 = s2len-- ? *s2++ : '\0';
if (!c1 ||
(c1 != c2 &&
(c1 = ISOLatin1ToLower (c1)) != (c2 = ISOLatin1ToLower (c2))))
break;
}
return (int) c1 - (int) c2;
}
#ifdef XCSECURITY #ifdef XCSECURITY
/* SecurityLookupWindow and SecurityLookupDrawable: /* SecurityLookupWindow and SecurityLookupDrawable:
@ -321,10 +346,11 @@ LookupClient(rid, client)
int int
AlterSaveSetForClient(client, pWin, mode) AlterSaveSetForClient(ClientPtr client,
ClientPtr client; WindowPtr pWin,
WindowPtr pWin; unsigned mode,
unsigned mode; Bool toRoot,
Bool remap)
{ {
int numnow; int numnow;
pointer *pTmp = NULL; pointer *pTmp = NULL;
@ -348,7 +374,9 @@ AlterSaveSetForClient(client, pWin, mode)
return(BadAlloc); return(BadAlloc);
client->saveSet = pTmp; client->saveSet = pTmp;
client->numSaved = numnow; client->numSaved = numnow;
client->saveSet[numnow - 1] = (pointer)pWin; SaveSetAssignWindow(client->saveSet[numnow - 1], pWin);
SaveSetAssignToRoot(client->saveSet[numnow - 1], toRoot);
SaveSetAssignRemap(client->saveSet[numnow - 1], remap);
return(Success); return(Success);
} }
else if ((mode == SetModeDelete) && (j < numnow)) else if ((mode == SetModeDelete) && (j < numnow))
@ -388,7 +416,7 @@ DeleteWindowFromAnySaveSet(pWin)
{ {
client = clients[i]; client = clients[i];
if (client && client->numSaved) if (client && client->numSaved)
(void)AlterSaveSetForClient(client, pWin, SetModeDelete); (void)AlterSaveSetForClient(client, pWin, SetModeDelete, FALSE, TRUE);
} }
} }

View File

@ -181,11 +181,6 @@ static WindowPtr *spriteTrace = (WindowPtr *)NULL;
static int spriteTraceSize = 0; static int spriteTraceSize = 0;
static int spriteTraceGood; static int spriteTraceGood;
typedef struct {
int x, y;
ScreenPtr pScreen;
} HotSpot;
static struct { static struct {
CursorPtr current; CursorPtr current;
BoxRec hotLimits; /* logical constraints of hot spot */ BoxRec hotLimits; /* logical constraints of hot spot */

View File

@ -3152,10 +3152,17 @@ HandleSaveSet(client)
for (j=0; j<client->numSaved; j++) for (j=0; j<client->numSaved; j++)
{ {
pWin = (WindowPtr)client->saveSet[j]; pWin = SaveSetWindow(client->saveSet[j]);
pParent = pWin->parent; #ifdef XFIXES
while (pParent && (wClient (pParent) == client)) if (SaveSetToRoot(client->saveSet[j]))
pParent = pParent->parent; pParent = WindowTable[pWin->drawable.pScreen->myNum];
else
#endif
{
pParent = pWin->parent;
while (pParent && (wClient (pParent) == client))
pParent = pParent->parent;
}
if (pParent) if (pParent)
{ {
if (pParent != pWin->parent) if (pParent != pWin->parent)
@ -3172,7 +3179,7 @@ HandleSaveSet(client)
} }
xfree(client->saveSet); xfree(client->saveSet);
client->numSaved = 0; client->numSaved = 0;
client->saveSet = (pointer *)NULL; client->saveSet = (SaveSetElt *)NULL;
} }
Bool Bool

View File

@ -77,10 +77,18 @@ typedef struct _Cursor {
unsigned short backRed, backGreen, backBlue; /* device-independent color */ unsigned short backRed, backGreen, backBlue; /* device-independent color */
int refcnt; int refcnt;
pointer devPriv[MAXSCREENS]; /* set by pScr->RealizeCursor*/ pointer devPriv[MAXSCREENS]; /* set by pScr->RealizeCursor*/
#ifdef XFIXES
CARD32 serialNumber;
Atom name;
#endif
} CursorRec; } CursorRec;
typedef struct _CursorMetric { typedef struct _CursorMetric {
unsigned short width, height, xhot, yhot; unsigned short width, height, xhot, yhot;
} CursorMetricRec; } CursorMetricRec;
typedef struct {
int x, y;
ScreenPtr pScreen;
} HotSpot;
#endif /* CURSORSTRUCT_H */ #endif /* CURSORSTRUCT_H */

View File

@ -379,6 +379,12 @@ extern void CopyISOLatin1Lowered(
unsigned char * /*source*/, unsigned char * /*source*/,
int /*length*/); int /*length*/);
extern int CompareISOLatin1Lowered(
unsigned char * /*a*/,
int alen,
unsigned char * /*b*/,
int blen);
#ifdef XCSECURITY #ifdef XCSECURITY
extern WindowPtr SecurityLookupWindow( extern WindowPtr SecurityLookupWindow(
@ -423,12 +429,14 @@ extern ClientPtr LookupClient(
extern void NoopDDA(void); extern void NoopDDA(void);
extern int AlterSaveSetForClient( int AlterSaveSetForClient(
ClientPtr /*client*/, ClientPtr /*client*/,
WindowPtr /*pWin*/, WindowPtr /*pWin*/,
unsigned /*mode*/); unsigned /*mode*/,
Bool /*toRoot*/,
extern void DeleteWindowFromAnySaveSet( Bool /*remap*/);
void DeleteWindowFromAnySaveSet(
WindowPtr /*pWin*/); WindowPtr /*pWin*/);
extern void BlockHandler( extern void BlockHandler(
@ -785,4 +793,21 @@ typedef struct {
int count; int count;
} DeviceEventInfoRec; } DeviceEventInfoRec;
/*
* SelectionCallback stuff
*/
extern CallbackListPtr SelectionCallback;
typedef enum {
SelectionSetOwner,
SelectionWindowDestroy,
SelectionClientClose
} SelectionCallbackKind;
typedef struct {
struct _Selection *selection;
SelectionCallbackKind kind;
} SelectionInfoRec;
#endif /* DIX_H */ #endif /* DIX_H */

View File

@ -68,6 +68,28 @@ typedef enum {ClientStateInitial,
ClientStateCheckingSecurity, ClientStateCheckingSecurity,
ClientStateCheckedSecurity} ClientState; ClientStateCheckedSecurity} ClientState;
#ifdef XFIXES
typedef struct _saveSet {
struct _Window *windowPtr;
Bool toRoot;
Bool remap;
} SaveSetElt;
#define SaveSetWindow(ss) ((ss).windowPtr)
#define SaveSetToRoot(ss) ((ss).toRoot)
#define SaveSetRemap(ss) ((ss).remap)
#define SaveSetAssignWindow(ss,w) ((ss).windowPtr = (w))
#define SaveSetAssignToRoot(ss,tr) ((ss).toRoot = (tr))
#define SaveSetAssignRemap(ss,rm) ((ss).remap = (rm))
#else
typedef struct _Window *SaveSetElt;
#define SaveSetWindow(ss) (ss)
#define SaveSetToRoot(ss) FALSE
#define SaveSetRemap(ss) TRUE
#define SaveSetAssignWindow(ss,w) ((ss) = (w))
#define SaveSetAssignToRoot(ss,tr)
#define SaveSetAssignRemap(ss,rm)
#endif
typedef struct _Client { typedef struct _Client {
int index; int index;
Mask clientAsMask; Mask clientAsMask;
@ -85,7 +107,7 @@ typedef struct _Client {
Drawable lastDrawableID; Drawable lastDrawableID;
GCPtr lastGC; GCPtr lastGC;
GContext lastGCID; GContext lastGCID;
pointer *saveSet; SaveSetElt *saveSet;
int numSaved; int numSaved;
pointer screenPrivate[MAXSCREENS]; pointer screenPrivate[MAXSCREENS];
int (**requestVector) ( int (**requestVector) (
@ -148,8 +170,8 @@ extern Bool SmartScheduleDisable;
extern Bool SmartScheduleIdle; extern Bool SmartScheduleIdle;
extern Bool SmartScheduleTimerStopped; extern Bool SmartScheduleTimerStopped;
extern Bool SmartScheduleStartTimer(void); extern Bool SmartScheduleStartTimer(void);
#define SMART_MAX_PRIORITY (20) #define SMART_MAX_PRIORITY 20
#define SMART_MIN_PRIORITY (-20) #define SMART_MIN_PRIORITY -20
extern Bool SmartScheduleInit(void); extern Bool SmartScheduleInit(void);

View File

@ -92,6 +92,17 @@ typedef void (*ProcessInputProc)(
DeviceIntPtr /*device*/, DeviceIntPtr /*device*/,
int /*count*/); int /*count*/);
typedef Bool (*DeviceHandleProc)(
DeviceIntPtr /*device*/,
void* /*data*/
);
typedef void (*DeviceUnwrapProc)(
DeviceIntPtr /*device*/,
DeviceHandleProc /*proc*/,
void* /*data*/
);
typedef struct _DeviceRec { typedef struct _DeviceRec {
pointer devicePrivate; pointer devicePrivate;
ProcessInputProc processInputProc; /* current */ ProcessInputProc processInputProc; /* current */
@ -145,6 +156,10 @@ typedef struct {
unsigned char id; unsigned char id;
} LedCtrl; } LedCtrl;
extern int AllocateDevicePrivateIndex(void);
extern Bool AllocateDevicePrivate(DeviceIntPtr device, int index);
extern void ResetDevicePrivateIndex(void);
extern KeybdCtrl defaultKeyboardControl; extern KeybdCtrl defaultKeyboardControl;
extern PtrCtrl defaultPointerControl; extern PtrCtrl defaultPointerControl;

View File

@ -95,81 +95,84 @@ extern RegDataRec miBrokenData;
#define REGION_END(reg) REGION_BOX(reg, (reg)->data->numRects - 1) #define REGION_END(reg) REGION_BOX(reg, (reg)->data->numRects - 1)
#define REGION_SZOF(n) (sizeof(RegDataRec) + ((n) * sizeof(BoxRec))) #define REGION_SZOF(n) (sizeof(RegDataRec) + ((n) * sizeof(BoxRec)))
/* Keith recommends weaning the region code of pScreen argument */
#define REG_pScreen screenInfo.screens[0]
#ifdef NEED_SCREEN_REGIONS #ifdef NEED_SCREEN_REGIONS
#define REGION_CREATE(_pScreen, _rect, _size) \ #define REGION_CREATE(_pScreen, _rect, _size) \
(*(_pScreen)->RegionCreate)(_rect, _size) (*(REG_pScreen)->RegionCreate)(_rect, _size)
#define REGION_INIT(_pScreen, _pReg, _rect, _size) \ #define REGION_INIT(_pScreen, _pReg, _rect, _size) \
(*(_pScreen)->RegionInit)(_pReg, _rect, _size) (*(REG_pScreen)->RegionInit)(_pReg, _rect, _size)
#define REGION_COPY(_pScreen, dst, src) \ #define REGION_COPY(_pScreen, dst, src) \
(*(_pScreen)->RegionCopy)(dst, src) (*(REG_pScreen)->RegionCopy)(dst, src)
#define REGION_DESTROY(_pScreen, _pReg) \ #define REGION_DESTROY(_pScreen, _pReg) \
(*(_pScreen)->RegionDestroy)(_pReg) (*(REG_pScreen)->RegionDestroy)(_pReg)
#define REGION_UNINIT(_pScreen, _pReg) \ #define REGION_UNINIT(_pScreen, _pReg) \
(*(_pScreen)->RegionUninit)(_pReg) (*(REG_pScreen)->RegionUninit)(_pReg)
#define REGION_INTERSECT(_pScreen, newReg, reg1, reg2) \ #define REGION_INTERSECT(_pScreen, newReg, reg1, reg2) \
(*(_pScreen)->Intersect)(newReg, reg1, reg2) (*(REG_pScreen)->Intersect)(newReg, reg1, reg2)
#define REGION_UNION(_pScreen, newReg, reg1, reg2) \ #define REGION_UNION(_pScreen, newReg, reg1, reg2) \
(*(_pScreen)->Union)(newReg, reg1, reg2) (*(REG_pScreen)->Union)(newReg, reg1, reg2)
#define REGION_SUBTRACT(_pScreen, newReg, reg1, reg2) \ #define REGION_SUBTRACT(_pScreen, newReg, reg1, reg2) \
(*(_pScreen)->Subtract)(newReg, reg1, reg2) (*(REG_pScreen)->Subtract)(newReg, reg1, reg2)
#define REGION_INVERSE(_pScreen, newReg, reg1, invRect) \ #define REGION_INVERSE(_pScreen, newReg, reg1, invRect) \
(*(_pScreen)->Inverse)(newReg, reg1, invRect) (*(REG_pScreen)->Inverse)(newReg, reg1, invRect)
#define REGION_RESET(_pScreen, _pReg, _pBox) \ #define REGION_RESET(_pScreen, _pReg, _pBox) \
(*(_pScreen)->RegionReset)(_pReg, _pBox) (*(REG_pScreen)->RegionReset)(_pReg, _pBox)
#define REGION_TRANSLATE(_pScreen, _pReg, _x, _y) \ #define REGION_TRANSLATE(_pScreen, _pReg, _x, _y) \
(*(_pScreen)->TranslateRegion)(_pReg, _x, _y) (*(REG_pScreen)->TranslateRegion)(_pReg, _x, _y)
#define RECT_IN_REGION(_pScreen, _pReg, prect) \ #define RECT_IN_REGION(_pScreen, _pReg, prect) \
(*(_pScreen)->RectIn)(_pReg, prect) (*(REG_pScreen)->RectIn)(_pReg, prect)
#define POINT_IN_REGION(_pScreen, _pReg, _x, _y, prect) \ #define POINT_IN_REGION(_pScreen, _pReg, _x, _y, prect) \
(*(_pScreen)->PointInRegion)(_pReg, _x, _y, prect) (*(REG_pScreen)->PointInRegion)(_pReg, _x, _y, prect)
#define REGION_NOTEMPTY(_pScreen, _pReg) \ #define REGION_NOTEMPTY(_pScreen, _pReg) \
(*(_pScreen)->RegionNotEmpty)(_pReg) (*(REG_pScreen)->RegionNotEmpty)(_pReg)
#define REGION_EQUAL(_pScreen, _pReg1, _pReg2) \ #define REGION_EQUAL(_pScreen, _pReg1, _pReg2) \
(*(_pScreen)->RegionEqual)(_pReg1, _pReg2) (*(REG_pScreen)->RegionEqual)(_pReg1, _pReg2)
#define REGION_BROKEN(_pScreen, _pReg) \ #define REGION_BROKEN(_pScreen, _pReg) \
(*(_pScreen)->RegionBroken)(_pReg) (*(REG_pScreen)->RegionBroken)(_pReg)
#define REGION_BREAK(_pScreen, _pReg) \ #define REGION_BREAK(_pScreen, _pReg) \
(*(_pScreen)->RegionBreak)(_pReg) (*(REG_pScreen)->RegionBreak)(_pReg)
#define REGION_EMPTY(_pScreen, _pReg) \ #define REGION_EMPTY(_pScreen, _pReg) \
(*(_pScreen)->RegionEmpty)(_pReg) (*(REG_pScreen)->RegionEmpty)(_pReg)
#define REGION_EXTENTS(_pScreen, _pReg) \ #define REGION_EXTENTS(_pScreen, _pReg) \
(*(_pScreen)->RegionExtents)(_pReg) (*(REG_pScreen)->RegionExtents)(_pReg)
#define REGION_APPEND(_pScreen, dstrgn, rgn) \ #define REGION_APPEND(_pScreen, dstrgn, rgn) \
(*(_pScreen)->RegionAppend)(dstrgn, rgn) (*(REG_pScreen)->RegionAppend)(dstrgn, rgn)
#define REGION_VALIDATE(_pScreen, badreg, pOverlap) \ #define REGION_VALIDATE(_pScreen, badreg, pOverlap) \
(*(_pScreen)->RegionValidate)(badreg, pOverlap) (*(REG_pScreen)->RegionValidate)(badreg, pOverlap)
#define BITMAP_TO_REGION(_pScreen, pPix) \ #define BITMAP_TO_REGION(_pScreen, pPix) \
(*(_pScreen)->BitmapToRegion)(pPix) (*(REG_pScreen)->BitmapToRegion)(pPix)
#define RECTS_TO_REGION(_pScreen, nrects, prect, ctype) \ #define RECTS_TO_REGION(_pScreen, nrects, prect, ctype) \
(*(_pScreen)->RectsToRegion)(nrects, prect, ctype) (*(REG_pScreen)->RectsToRegion)(nrects, prect, ctype)
#else /* !NEED_SCREEN_REGIONS */ #else /* !NEED_SCREEN_REGIONS */
/* Reference _pScreen macro argument and check its type */ /* Reference _pScreen macro argument and check its type */
#define REGION_SCREEN(_pScreen_) (void)((_pScreen_)->myNum) #define REGION_SCREEN(_pScreen) (void)((REG_pScreen)->myNum)
#define REGION_CREATE(_pScreen, _rect, _size) \ #define REGION_CREATE(_pScreen, _rect, _size) \
(REGION_SCREEN(_pScreen), miRegionCreate(_rect, _size)) (REGION_SCREEN(_pScreen), miRegionCreate(_rect, _size))

View File

@ -252,4 +252,10 @@ void ResizeChildrenWinSize(
int /*dw*/, int /*dw*/,
int /*dh*/); int /*dh*/);
RegionPtr
CreateBoundingShape (WindowPtr pWin);
RegionPtr
CreateClipShape (WindowPtr pWin);
#endif /* WINDOW_H */ #endif /* WINDOW_H */

View File

@ -238,6 +238,12 @@ extern void RRExtensionInit(INITARGS);
#ifdef RES #ifdef RES
extern void ResExtensionInit(INITARGS); extern void ResExtensionInit(INITARGS);
#endif #endif
#ifdef DAMAGE
extern void DamageExtensionInit(INITARGS);
#endif
#ifdef XFIXES
extern void XFixesExtensionInit(INITARGS);
#endif
#ifndef XFree86LOADER #ifndef XFree86LOADER
@ -377,6 +383,12 @@ InitExtensions(argc, argv)
#ifdef RES #ifdef RES
ResExtensionInit(); ResExtensionInit();
#endif #endif
#ifdef DAMAGE
DamageExtensionInit();
#endif
#ifdef XFIXES
XFixesExtensionInit();
#endif
} }
void void
@ -448,7 +460,15 @@ ExtensionModule extension[] =
{ NULL, "FontCache", NULL, NULL }, { NULL, "FontCache", NULL, NULL },
{ NULL, "RENDER", NULL, NULL }, { NULL, "RENDER", NULL, NULL },
{ NULL, "RANDR", NULL, NULL }, { NULL, "RANDR", NULL, NULL },
#ifdef RES
{ NULL, "X-Resource", NULL, NULL }, { NULL, "X-Resource", NULL, NULL },
#endif
#ifdef DAMAGE
{ NULL, "DAMAGE", NULL, NULL },
#endif
#ifdef XFIXES
{ NULL, "XFIXES", NULL, NULL },
#endif
{ NULL, NULL, NULL, NULL } { NULL, NULL, NULL, NULL }
}; };
#endif #endif