2013-07-13 07:56:15 +08:00
|
|
|
/*
|
2014-01-18 09:37:09 +08:00
|
|
|
Copyright 2005-2014 Jay Sorg
|
2013-07-13 07:56:15 +08:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
2013-07-24 11:57:38 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
/* this should be before all X11 .h files */
|
|
|
|
#include <xorg-server.h>
|
|
|
|
|
|
|
|
/* all driver need this */
|
|
|
|
#include <xf86.h>
|
|
|
|
#include <xf86_OSproc.h>
|
|
|
|
|
2013-07-13 13:36:16 +08:00
|
|
|
#include "rdp.h"
|
|
|
|
#include "rdpDraw.h"
|
2014-01-26 03:30:45 +08:00
|
|
|
#include "rdpClientCon.h"
|
|
|
|
#include "rdpReg.h"
|
2013-07-13 13:36:16 +08:00
|
|
|
|
|
|
|
#define LOG_LEVEL 1
|
|
|
|
#define LLOGLN(_level, _args) \
|
|
|
|
do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0)
|
|
|
|
|
2014-01-26 03:30:45 +08:00
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
rdpPolylinesPre(rdpPtr dev, rdpClientCon *clientCon,
|
|
|
|
int cd, RegionPtr clip_reg,
|
|
|
|
DrawablePtr pDrawable, GCPtr pGC, int mode,
|
|
|
|
int npt, DDXPointPtr pptInit, RegionPtr reg)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2013-07-13 13:36:16 +08:00
|
|
|
/******************************************************************************/
|
|
|
|
static void
|
|
|
|
rdpPolylinesOrg(DrawablePtr pDrawable, GCPtr pGC, int mode,
|
|
|
|
int npt, DDXPointPtr pptInit)
|
|
|
|
{
|
2013-07-31 15:41:44 +08:00
|
|
|
GC_OP_VARS;
|
2013-07-13 13:36:16 +08:00
|
|
|
|
|
|
|
GC_OP_PROLOGUE(pGC);
|
|
|
|
pGC->ops->Polylines(pDrawable, pGC, mode, npt, pptInit);
|
|
|
|
GC_OP_EPILOGUE(pGC);
|
|
|
|
}
|
|
|
|
|
2014-01-26 03:30:45 +08:00
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
rdpPolylinesPost(rdpPtr dev, rdpClientCon *clientCon,
|
|
|
|
int cd, RegionPtr clip_reg,
|
|
|
|
DrawablePtr pDrawable, GCPtr pGC, int mode,
|
|
|
|
int npt, DDXPointPtr pptInit, RegionPtr reg)
|
|
|
|
{
|
|
|
|
RegionRec lreg;
|
|
|
|
|
|
|
|
if (cd == XRDP_CD_NODRAW)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (!XRDP_DRAWABLE_IS_VISIBLE(dev, pDrawable))
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
rdpRegionInit(&lreg, NullBox, 0);
|
|
|
|
if (cd == XRDP_CD_CLIP)
|
|
|
|
{
|
|
|
|
rdpRegionIntersect(&lreg, clip_reg, reg);
|
|
|
|
}
|
|
|
|
rdpClientConAddDirtyScreenReg(dev, clientCon, &lreg);
|
|
|
|
rdpRegionUninit(&lreg);
|
|
|
|
}
|
|
|
|
|
2013-07-13 13:36:16 +08:00
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
rdpPolylines(DrawablePtr pDrawable, GCPtr pGC, int mode,
|
|
|
|
int npt, DDXPointPtr pptInit)
|
|
|
|
{
|
2014-01-26 03:30:45 +08:00
|
|
|
rdpPtr dev;
|
|
|
|
rdpClientCon *clientCon;
|
|
|
|
RegionRec clip_reg;
|
|
|
|
RegionRec reg;
|
|
|
|
int cd;
|
|
|
|
int index;
|
|
|
|
int x1;
|
|
|
|
int y1;
|
|
|
|
int x2;
|
|
|
|
int y2;
|
|
|
|
BoxRec box;
|
|
|
|
|
|
|
|
LLOGLN(10, ("rdpPolylines:"));
|
|
|
|
dev = rdpGetDevFromScreen(pGC->pScreen);
|
|
|
|
dev->counts.rdpPolylinesCallCount++;
|
|
|
|
rdpRegionInit(®, NullBox, 0);
|
|
|
|
for (index = 1; index < npt; index++)
|
|
|
|
{
|
|
|
|
x1 = pptInit[index - 1].x + pDrawable->x;
|
|
|
|
y1 = pptInit[index - 1].y + pDrawable->y;
|
|
|
|
x2 = pptInit[index].x + pDrawable->x;
|
|
|
|
y2 = pptInit[index].y + pDrawable->y;
|
|
|
|
box.x1 = RDPMIN(x1, x2);
|
|
|
|
box.y1 = RDPMIN(y1, y2);
|
|
|
|
box.x2 = RDPMAX(x1, x2) + 1;
|
|
|
|
box.y2 = RDPMAX(y1, y2) + 1;
|
|
|
|
rdpRegionUnionRect(®, &box);
|
|
|
|
}
|
|
|
|
rdpRegionInit(&clip_reg, NullBox, 0);
|
|
|
|
cd = rdpDrawGetClip(dev, &clip_reg, pDrawable, pGC);
|
|
|
|
LLOGLN(10, ("rdpPolylines: cd %d", cd));
|
|
|
|
clientCon = dev->clientConHead;
|
|
|
|
while (clientCon != NULL)
|
|
|
|
{
|
|
|
|
rdpPolylinesPre(dev, clientCon, cd, &clip_reg, pDrawable,
|
|
|
|
pGC, mode, npt, pptInit, ®);
|
|
|
|
clientCon = clientCon->next;
|
|
|
|
}
|
2013-07-13 13:36:16 +08:00
|
|
|
/* do original call */
|
|
|
|
rdpPolylinesOrg(pDrawable, pGC, mode, npt, pptInit);
|
2014-01-26 03:30:45 +08:00
|
|
|
clientCon = dev->clientConHead;
|
|
|
|
while (clientCon != NULL)
|
|
|
|
{
|
|
|
|
rdpPolylinesPost(dev, clientCon, cd, &clip_reg, pDrawable,
|
|
|
|
pGC, mode, npt, pptInit, ®);
|
|
|
|
clientCon = clientCon->next;
|
|
|
|
}
|
|
|
|
rdpRegionUninit(&clip_reg);
|
|
|
|
rdpRegionUninit(®);
|
2013-07-13 13:36:16 +08:00
|
|
|
}
|