105b261ecSmrg/*********************************************************** 205b261ecSmrg 305b261ecSmrgCopyright 1987, 1998 The Open Group 405b261ecSmrg 505b261ecSmrgPermission to use, copy, modify, distribute, and sell this software and its 605b261ecSmrgdocumentation for any purpose is hereby granted without fee, provided that 705b261ecSmrgthe above copyright notice appear in all copies and that both that 805b261ecSmrgcopyright notice and this permission notice appear in supporting 905b261ecSmrgdocumentation. 1005b261ecSmrg 1105b261ecSmrgThe above copyright notice and this permission notice shall be included in 1205b261ecSmrgall copies or substantial portions of the Software. 1305b261ecSmrg 1405b261ecSmrgTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 1505b261ecSmrgIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 1605b261ecSmrgFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 1705b261ecSmrgOPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN 1805b261ecSmrgAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 1905b261ecSmrgCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 2005b261ecSmrg 2105b261ecSmrgExcept as contained in this notice, the name of The Open Group shall not be 2205b261ecSmrgused in advertising or otherwise to promote the sale, use or other dealings 2305b261ecSmrgin this Software without prior written authorization from The Open Group. 2405b261ecSmrg 2505b261ecSmrgCopyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts. 2605b261ecSmrg 2705b261ecSmrg All Rights Reserved 2805b261ecSmrg 2935c4bbdfSmrgPermission to use, copy, modify, and distribute this software and its 3035c4bbdfSmrgdocumentation for any purpose and without fee is hereby granted, 3105b261ecSmrgprovided that the above copyright notice appear in all copies and that 3235c4bbdfSmrgboth that copyright notice and this permission notice appear in 3305b261ecSmrgsupporting documentation, and that the name of Digital not be 3405b261ecSmrgused in advertising or publicity pertaining to distribution of the 3535c4bbdfSmrgsoftware without specific, written prior permission. 3605b261ecSmrg 3705b261ecSmrgDIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING 3805b261ecSmrgALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL 3905b261ecSmrgDIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR 4005b261ecSmrgANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, 4105b261ecSmrgWHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, 4205b261ecSmrgARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS 4305b261ecSmrgSOFTWARE. 4405b261ecSmrg 4505b261ecSmrg******************************************************************/ 4605b261ecSmrg#ifdef HAVE_DIX_CONFIG_H 4705b261ecSmrg#include <dix-config.h> 4805b261ecSmrg#endif 4905b261ecSmrg 5005b261ecSmrg#include <X11/X.h> 5105b261ecSmrg#include <X11/Xprotostr.h> 5205b261ecSmrg#include "regionstr.h" 5305b261ecSmrg#include "gcstruct.h" 5405b261ecSmrg#include "pixmap.h" 5505b261ecSmrg#include "mi.h" 5605b261ecSmrg 576747b715Smrgvoid 584642e01fSmrgmiPolyRectangle(DrawablePtr pDraw, GCPtr pGC, int nrects, xRectangle *pRects) 5905b261ecSmrg{ 6005b261ecSmrg int i; 6105b261ecSmrg xRectangle *pR = pRects; 6205b261ecSmrg DDXPointRec rect[5]; 6335c4bbdfSmrg int bound_tmp; 6405b261ecSmrg 6505b261ecSmrg#define MINBOUND(dst,eqn) bound_tmp = eqn; \ 6605b261ecSmrg if (bound_tmp < -32768) \ 6705b261ecSmrg bound_tmp = -32768; \ 6805b261ecSmrg dst = bound_tmp; 6905b261ecSmrg 7005b261ecSmrg#define MAXBOUND(dst,eqn) bound_tmp = eqn; \ 7105b261ecSmrg if (bound_tmp > 32767) \ 7205b261ecSmrg bound_tmp = 32767; \ 7305b261ecSmrg dst = bound_tmp; 7405b261ecSmrg 7505b261ecSmrg#define MAXUBOUND(dst,eqn) bound_tmp = eqn; \ 7605b261ecSmrg if (bound_tmp > 65535) \ 7705b261ecSmrg bound_tmp = 65535; \ 7805b261ecSmrg dst = bound_tmp; 7905b261ecSmrg 8005b261ecSmrg if (pGC->lineStyle == LineSolid && pGC->joinStyle == JoinMiter && 8135c4bbdfSmrg pGC->lineWidth != 0) { 8235c4bbdfSmrg xRectangle *tmp, *t; 8335c4bbdfSmrg int ntmp; 8435c4bbdfSmrg int offset1, offset2, offset3; 8535c4bbdfSmrg int x, y, width, height; 8635c4bbdfSmrg 8735c4bbdfSmrg ntmp = (nrects << 2); 8835c4bbdfSmrg offset2 = pGC->lineWidth; 8935c4bbdfSmrg offset1 = offset2 >> 1; 9035c4bbdfSmrg offset3 = offset2 - offset1; 9135c4bbdfSmrg tmp = xallocarray(ntmp, sizeof(xRectangle)); 9235c4bbdfSmrg if (!tmp) 9335c4bbdfSmrg return; 9435c4bbdfSmrg t = tmp; 9535c4bbdfSmrg for (i = 0; i < nrects; i++) { 9635c4bbdfSmrg x = pR->x; 9735c4bbdfSmrg y = pR->y; 9835c4bbdfSmrg width = pR->width; 9935c4bbdfSmrg height = pR->height; 10035c4bbdfSmrg pR++; 10135c4bbdfSmrg if (width == 0 && height == 0) { 10235c4bbdfSmrg rect[0].x = x; 10335c4bbdfSmrg rect[0].y = y; 10435c4bbdfSmrg rect[1].x = x; 10535c4bbdfSmrg rect[1].y = y; 10635c4bbdfSmrg (*pGC->ops->Polylines) (pDraw, pGC, CoordModeOrigin, 2, rect); 10735c4bbdfSmrg } 10835c4bbdfSmrg else if (height < offset2 || width < offset1) { 10935c4bbdfSmrg if (height == 0) { 11035c4bbdfSmrg t->x = x; 11135c4bbdfSmrg t->width = width; 11235c4bbdfSmrg } 11335c4bbdfSmrg else { 11435c4bbdfSmrg MINBOUND(t->x, x - offset1) 11535c4bbdfSmrg MAXUBOUND(t->width, width + offset2) 11635c4bbdfSmrg } 11735c4bbdfSmrg if (width == 0) { 11835c4bbdfSmrg t->y = y; 11935c4bbdfSmrg t->height = height; 12035c4bbdfSmrg } 12135c4bbdfSmrg else { 12235c4bbdfSmrg MINBOUND(t->y, y - offset1) 12335c4bbdfSmrg MAXUBOUND(t->height, height + offset2) 12435c4bbdfSmrg } 12535c4bbdfSmrg t++; 12635c4bbdfSmrg } 12735c4bbdfSmrg else { 12835c4bbdfSmrg MINBOUND(t->x, x - offset1) 12935c4bbdfSmrg MINBOUND(t->y, y - offset1) 13035c4bbdfSmrg MAXUBOUND(t->width, width + offset2) 13135c4bbdfSmrg t->height = offset2; 13235c4bbdfSmrg t++; 13335c4bbdfSmrg MINBOUND(t->x, x - offset1) 13435c4bbdfSmrg MAXBOUND(t->y, y + offset3); 13535c4bbdfSmrg t->width = offset2; 13635c4bbdfSmrg t->height = height - offset2; 13735c4bbdfSmrg t++; 13835c4bbdfSmrg MAXBOUND(t->x, x + width - offset1); 13935c4bbdfSmrg MAXBOUND(t->y, y + offset3) 14035c4bbdfSmrg t->width = offset2; 14135c4bbdfSmrg t->height = height - offset2; 14235c4bbdfSmrg t++; 14335c4bbdfSmrg MINBOUND(t->x, x - offset1) 14435c4bbdfSmrg MAXBOUND(t->y, y + height - offset1) 14535c4bbdfSmrg MAXUBOUND(t->width, width + offset2) 14635c4bbdfSmrg t->height = offset2; 14735c4bbdfSmrg t++; 14835c4bbdfSmrg } 14935c4bbdfSmrg } 15035c4bbdfSmrg (*pGC->ops->PolyFillRect) (pDraw, pGC, t - tmp, tmp); 15135c4bbdfSmrg free((void *) tmp); 15205b261ecSmrg } 15335c4bbdfSmrg else { 15435c4bbdfSmrg 15535c4bbdfSmrg for (i = 0; i < nrects; i++) { 15635c4bbdfSmrg rect[0].x = pR->x; 15735c4bbdfSmrg rect[0].y = pR->y; 15835c4bbdfSmrg 15935c4bbdfSmrg MAXBOUND(rect[1].x, pR->x + (int) pR->width) 16035c4bbdfSmrg rect[1].y = rect[0].y; 16135c4bbdfSmrg 16235c4bbdfSmrg rect[2].x = rect[1].x; 16335c4bbdfSmrg MAXBOUND(rect[2].y, pR->y + (int) pR->height); 16435c4bbdfSmrg 16535c4bbdfSmrg rect[3].x = rect[0].x; 16635c4bbdfSmrg rect[3].y = rect[2].y; 16735c4bbdfSmrg 16835c4bbdfSmrg rect[4].x = rect[0].x; 16935c4bbdfSmrg rect[4].y = rect[0].y; 17035c4bbdfSmrg 17135c4bbdfSmrg (*pGC->ops->Polylines) (pDraw, pGC, CoordModeOrigin, 5, rect); 17235c4bbdfSmrg pR++; 17335c4bbdfSmrg } 17405b261ecSmrg } 17505b261ecSmrg} 176