~ubuntu-branches/ubuntu/gutsy/vnc4/gutsy

« back to all changes in this revision

Viewing changes to unix/xc/programs/Xserver/ilbm/ilbmpolypnt.c

  • Committer: Bazaar Package Importer
  • Author(s): Ola Lundqvist
  • Date: 2006-05-15 20:35:17 UTC
  • mfrom: (1.1.2 upstream)
  • Revision ID: james.westby@ubuntu.com-20060515203517-l4lre1ku942mn26k
Tags: 4.1.1+X4.3.0-10
* Correction of critical security issue. Thanks to Martin Kogler
  <e9925248@student.tuwien.ac.at> that informed me about the issue,
  and provided the patch.
  This flaw was originally found by Steve Wiseman of intelliadmin.com.
* Applied patch from Javier Kohen <jkohen@users.sourceforge.net> that
  inform the user that only 8 first characters of the password will
  actually be used when typing more than 8 characters, closes:
  #355619.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* $XFree86: xc/programs/Xserver/ilbm/ilbmpolypnt.c,v 3.1 1998/03/20 21:08:03 hohndel Exp $ */
 
2
/* Combined Purdue/PurduePlus patches, level 2.0, 1/17/89 */
 
3
/***********************************************************
 
4
 
 
5
Copyright (c) 1987  X Consortium
 
6
 
 
7
Permission is hereby granted, free of charge, to any person obtaining a copy
 
8
of this software and associated documentation files (the "Software"), to deal
 
9
in the Software without restriction, including without limitation the rights
 
10
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 
11
copies of the Software, and to permit persons to whom the Software is
 
12
furnished to do so, subject to the following conditions:
 
13
 
 
14
The above copyright notice and this permission notice shall be included in
 
15
all copies or substantial portions of the Software.
 
16
 
 
17
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 
18
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 
19
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
 
20
X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
 
21
AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
 
22
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 
23
 
 
24
Except as contained in this notice, the name of the X Consortium shall not be
 
25
used in advertising or otherwise to promote the sale, use or other dealings
 
26
in this Software without prior written authorization from the X Consortium.
 
27
 
 
28
 
 
29
Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts.
 
30
 
 
31
                        All Rights Reserved
 
32
 
 
33
Permission to use, copy, modify, and distribute this software and its
 
34
documentation for any purpose and without fee is hereby granted,
 
35
provided that the above copyright notice appear in all copies and that
 
36
both that copyright notice and this permission notice appear in
 
37
supporting documentation, and that the name of Digital not be
 
38
used in advertising or publicity pertaining to distribution of the
 
39
software without specific, written prior permission.
 
40
 
 
41
DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
 
42
ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
 
43
DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
 
44
ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
 
45
WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
 
46
ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
 
47
SOFTWARE.
 
48
 
 
49
******************************************************************/
 
50
/* $XConsortium: ilbmpolypnt.c,v 5.6 94/04/17 20:28:30 dpw Exp $ */
 
51
 
 
52
/* Modified jun 95 by Geert Uytterhoeven (Geert.Uytterhoeven@cs.kuleuven.ac.be)
 
53
   to use interleaved bitplanes instead of normal bitplanes */
 
54
 
 
55
#include "X.h"
 
56
#include "Xprotostr.h"
 
57
#include "pixmapstr.h"
 
58
#include "gcstruct.h"
 
59
#include "windowstr.h"
 
60
#include "miscstruct.h"
 
61
#include "regionstr.h"
 
62
#include "scrnintstr.h"
 
63
 
 
64
#include "ilbm.h"
 
65
#include "maskbits.h"
 
66
 
 
67
void
 
68
ilbmPolyPoint(pDrawable, pGC, mode, npt, pptInit)
 
69
        register DrawablePtr pDrawable;
 
70
        GCPtr pGC;
 
71
        int mode;                               /* Origin or Previous */
 
72
        int npt;
 
73
        xPoint *pptInit;
 
74
{
 
75
 
 
76
        register BoxPtr pbox;
 
77
        register int nbox;
 
78
        register int d;
 
79
 
 
80
        register PixelType *addrl;
 
81
        PixelType *pBase;
 
82
        PixelType *pBaseSave;
 
83
        int nlwidth;
 
84
        int auxDst;
 
85
        int depthDst;
 
86
 
 
87
        int nptTmp;
 
88
        register xPoint *ppt;
 
89
 
 
90
        register int x;
 
91
        register int y;
 
92
        register unsigned char *rrops;
 
93
        ilbmPrivGC *pGCPriv;
 
94
 
 
95
        pGCPriv = (ilbmPrivGC *) pGC->devPrivates[ilbmGCPrivateIndex].ptr;
 
96
 
 
97
        ilbmGetPixelWidthAuxDepthAndPointer(pDrawable, nlwidth, auxDst, depthDst,
 
98
                                                                                                        pBaseSave);
 
99
 
 
100
        rrops = pGCPriv->rrops;
 
101
        if ((mode == CoordModePrevious) && (npt > 1))
 
102
                for (ppt = pptInit + 1, nptTmp = npt - 1; --nptTmp >= 0; ppt++) {
 
103
                        ppt->x += (ppt-1)->x;
 
104
                        ppt->y += (ppt-1)->y;
 
105
                }
 
106
 
 
107
        nbox = REGION_NUM_RECTS(pGC->pCompositeClip);
 
108
        pbox = REGION_RECTS(pGC->pCompositeClip);
 
109
        for (; --nbox >= 0; pbox++)
 
110
                for (d = 0, pBase = pBaseSave; d < depthDst; d++, pBase += nlwidth) {   /* @@@ NEXT PLANE @@@ */
 
111
                        addrl = pBase;
 
112
 
 
113
                        switch (rrops[d]) {
 
114
                                case RROP_BLACK:
 
115
                                        for (ppt = pptInit, nptTmp = npt; --nptTmp >= 0; ppt++) {
 
116
                                                x = ppt->x + pDrawable->x;
 
117
                                                y = ppt->y + pDrawable->y;
 
118
                                                if ((x >= pbox->x1) && (x < pbox->x2) &&
 
119
                                                        (y >= pbox->y1) && (y < pbox->y2))
 
120
                                                        *ilbmScanline(addrl, x, y, auxDst) &= rmask[x & PIM];
 
121
                                        }
 
122
                                        break;
 
123
 
 
124
                                case RROP_WHITE:
 
125
                                        for (ppt = pptInit, nptTmp = npt; --nptTmp >= 0; ppt++) {
 
126
                                                x = ppt->x + pDrawable->x;
 
127
                                                y = ppt->y + pDrawable->y;
 
128
                                                if ((x >= pbox->x1) && (x < pbox->x2) &&
 
129
                                                        (y >= pbox->y1) && (y < pbox->y2))
 
130
                                                        *ilbmScanline(addrl, x, y, auxDst) |= mask[x & PIM];
 
131
                                        }
 
132
                                        break;
 
133
 
 
134
                                case RROP_INVERT:
 
135
                                        for (ppt = pptInit, nptTmp = npt; --nptTmp >= 0; ppt++) {
 
136
                                                x = ppt->x + pDrawable->x;
 
137
                                                y = ppt->y + pDrawable->y;
 
138
                                                if ((x >= pbox->x1) && (x < pbox->x2) &&
 
139
                                                        (y >= pbox->y1) && (y < pbox->y2))
 
140
                                                        *ilbmScanline(addrl, x, y, auxDst) ^= mask[x & PIM];
 
141
                                        }
 
142
                                        break;
 
143
 
 
144
                                case RROP_NOP:
 
145
                                        break;
 
146
                        } /* switch */
 
147
                } /* for (d = ...) */
 
148
}