wineps.drv: Pass a generic PHYSDEV to all graphics functions.

This commit is contained in:
Alexandre Julliard 2011-07-07 13:29:17 +02:00
parent ba2a6ee983
commit 10dcba499f
17 changed files with 610 additions and 558 deletions

View File

@ -28,7 +28,7 @@ WINE_DEFAULT_DEBUG_CHANNEL(psdrv);
* *
* PSDRV_PatBlt * PSDRV_PatBlt
*/ */
BOOL CDECL PSDRV_PatBlt(PSDRV_PDEVICE *physDev, INT x, INT y, INT width, INT height, DWORD dwRop) BOOL CDECL PSDRV_PatBlt(PHYSDEV dev, INT x, INT y, INT width, INT height, DWORD dwRop)
{ {
POINT pt[2]; POINT pt[2];
@ -36,16 +36,16 @@ BOOL CDECL PSDRV_PatBlt(PSDRV_PDEVICE *physDev, INT x, INT y, INT width, INT hei
pt[0].y = y; pt[0].y = y;
pt[1].x = x + width; pt[1].x = x + width;
pt[1].y = y + height; pt[1].y = y + height;
LPtoDP( physDev->hdc, pt, 2 ); LPtoDP( dev->hdc, pt, 2 );
switch(dwRop) { switch(dwRop) {
case PATCOPY: case PATCOPY:
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteRectangle(physDev, pt[0].x, pt[0].y, pt[1].x - pt[0].x, pt[1].y - pt[0].y ); PSDRV_WriteRectangle(dev, pt[0].x, pt[0].y, pt[1].x - pt[0].x, pt[1].y - pt[0].y );
PSDRV_Brush(physDev, FALSE); PSDRV_Brush(dev, FALSE);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return TRUE; return TRUE;
case BLACKNESS: case BLACKNESS:
@ -53,15 +53,14 @@ BOOL CDECL PSDRV_PatBlt(PSDRV_PDEVICE *physDev, INT x, INT y, INT width, INT hei
{ {
PSCOLOR pscol; PSCOLOR pscol;
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteRectangle(physDev, pt[0].x, pt[0].y, pt[1].x - pt[0].x, pt[1].y - pt[0].y ); PSDRV_WriteRectangle(dev, pt[0].x, pt[0].y, pt[1].x - pt[0].x, pt[1].y - pt[0].y );
PSDRV_CreateColor( physDev, &pscol, (dwRop == BLACKNESS) ? PSDRV_CreateColor( dev, &pscol, (dwRop == BLACKNESS) ? RGB(0,0,0) : RGB(0xff,0xff,0xff) );
RGB(0,0,0) : RGB(0xff,0xff,0xff) ); PSDRV_WriteSetColor(dev, &pscol);
PSDRV_WriteSetColor(physDev, &pscol); PSDRV_WriteFill(dev);
PSDRV_WriteFill(physDev); PSDRV_WriteGRestore(dev);
PSDRV_WriteGRestore(physDev); PSDRV_ResetClip(dev);
PSDRV_ResetClip(physDev);
return TRUE; return TRUE;
} }
default: default:

View File

@ -90,7 +90,7 @@ static BOOL get_bitmap_info( const void *ptr, LONG *width, LONG *height, WORD *b
* Uses level 2 PostScript * Uses level 2 PostScript
*/ */
static BOOL PSDRV_WriteImageHeader(PSDRV_PDEVICE *physDev, const BITMAPINFO *info, INT xDst, static BOOL PSDRV_WriteImageHeader(PHYSDEV dev, const BITMAPINFO *info, INT xDst,
INT yDst, INT widthDst, INT heightDst, INT yDst, INT widthDst, INT heightDst,
INT widthSrc, INT heightSrc) INT widthSrc, INT heightSrc)
{ {
@ -99,36 +99,36 @@ static BOOL PSDRV_WriteImageHeader(PSDRV_PDEVICE *physDev, const BITMAPINFO *inf
switch(info->bmiHeader.biBitCount) { switch(info->bmiHeader.biBitCount) {
case 8: case 8:
PSDRV_WriteIndexColorSpaceBegin(physDev, 255); PSDRV_WriteIndexColorSpaceBegin(dev, 255);
for(i = 0; i < 256; i++) { for(i = 0; i < 256; i++) {
map[i] = info->bmiColors[i].rgbRed | map[i] = info->bmiColors[i].rgbRed |
info->bmiColors[i].rgbGreen << 8 | info->bmiColors[i].rgbGreen << 8 |
info->bmiColors[i].rgbBlue << 16; info->bmiColors[i].rgbBlue << 16;
} }
PSDRV_WriteRGB(physDev, map, 256); PSDRV_WriteRGB(dev, map, 256);
PSDRV_WriteIndexColorSpaceEnd(physDev); PSDRV_WriteIndexColorSpaceEnd(dev);
break; break;
case 4: case 4:
PSDRV_WriteIndexColorSpaceBegin(physDev, 15); PSDRV_WriteIndexColorSpaceBegin(dev, 15);
for(i = 0; i < 16; i++) { for(i = 0; i < 16; i++) {
map[i] = info->bmiColors[i].rgbRed | map[i] = info->bmiColors[i].rgbRed |
info->bmiColors[i].rgbGreen << 8 | info->bmiColors[i].rgbGreen << 8 |
info->bmiColors[i].rgbBlue << 16; info->bmiColors[i].rgbBlue << 16;
} }
PSDRV_WriteRGB(physDev, map, 16); PSDRV_WriteRGB(dev, map, 16);
PSDRV_WriteIndexColorSpaceEnd(physDev); PSDRV_WriteIndexColorSpaceEnd(dev);
break; break;
case 1: case 1:
PSDRV_WriteIndexColorSpaceBegin(physDev, 1); PSDRV_WriteIndexColorSpaceBegin(dev, 1);
for(i = 0; i < 2; i++) { for(i = 0; i < 2; i++) {
map[i] = info->bmiColors[i].rgbRed | map[i] = info->bmiColors[i].rgbRed |
info->bmiColors[i].rgbGreen << 8 | info->bmiColors[i].rgbGreen << 8 |
info->bmiColors[i].rgbBlue << 16; info->bmiColors[i].rgbBlue << 16;
} }
PSDRV_WriteRGB(physDev, map, 2); PSDRV_WriteRGB(dev, map, 2);
PSDRV_WriteIndexColorSpaceEnd(physDev); PSDRV_WriteIndexColorSpaceEnd(dev);
break; break;
case 15: case 15:
@ -139,7 +139,7 @@ static BOOL PSDRV_WriteImageHeader(PSDRV_PDEVICE *physDev, const BITMAPINFO *inf
PSCOLOR pscol; PSCOLOR pscol;
pscol.type = PSCOLOR_RGB; pscol.type = PSCOLOR_RGB;
pscol.value.rgb.r = pscol.value.rgb.g = pscol.value.rgb.b = 0.0; pscol.value.rgb.r = pscol.value.rgb.g = pscol.value.rgb.b = 0.0;
PSDRV_WriteSetColor(physDev, &pscol); PSDRV_WriteSetColor(dev, &pscol);
break; break;
} }
@ -148,7 +148,7 @@ static BOOL PSDRV_WriteImageHeader(PSDRV_PDEVICE *physDev, const BITMAPINFO *inf
return FALSE; return FALSE;
} }
PSDRV_WriteImage(physDev, info->bmiHeader.biBitCount, xDst, yDst, PSDRV_WriteImage(dev, info->bmiHeader.biBitCount, xDst, yDst,
widthDst, heightDst, widthSrc, heightSrc, FALSE); widthDst, heightDst, widthSrc, heightSrc, FALSE);
return TRUE; return TRUE;
} }
@ -166,7 +166,7 @@ static BOOL PSDRV_WriteImageHeader(PSDRV_PDEVICE *physDev, const BITMAPINFO *inf
* Uses level 2 PostScript * Uses level 2 PostScript
*/ */
static BOOL PSDRV_WriteImageMaskHeader(PSDRV_PDEVICE *physDev, const BITMAPINFO *info, INT xDst, static BOOL PSDRV_WriteImageMaskHeader(PHYSDEV dev, const BITMAPINFO *info, INT xDst,
INT yDst, INT widthDst, INT heightDst, INT yDst, INT widthDst, INT heightDst,
INT widthSrc, INT heightSrc) INT widthSrc, INT heightSrc)
{ {
@ -186,18 +186,18 @@ static BOOL PSDRV_WriteImageMaskHeader(PSDRV_PDEVICE *physDev, const BITMAPINFO
the foregnd color corresponds to a bit equal to the foregnd color corresponds to a bit equal to
0 in the bitmap. 0 in the bitmap.
*/ */
PSDRV_CreateColor(physDev, &foregnd, map[0]); PSDRV_CreateColor(dev, &foregnd, map[0]);
PSDRV_CreateColor(physDev, &bkgnd, map[1]); PSDRV_CreateColor(dev, &bkgnd, map[1]);
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteNewPath(physDev); PSDRV_WriteNewPath(dev);
PSDRV_WriteRectangle(physDev, xDst, yDst, widthDst, heightDst); PSDRV_WriteRectangle(dev, xDst, yDst, widthDst, heightDst);
PSDRV_WriteSetColor(physDev, &bkgnd); PSDRV_WriteSetColor(dev, &bkgnd);
PSDRV_WriteFill(physDev); PSDRV_WriteFill(dev);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
PSDRV_WriteSetColor(physDev, &foregnd); PSDRV_WriteSetColor(dev, &foregnd);
PSDRV_WriteImage(physDev, 1, xDst, yDst, widthDst, heightDst, PSDRV_WriteImage(dev, 1, xDst, yDst, widthDst, heightDst,
widthSrc, heightSrc, TRUE); widthSrc, heightSrc, TRUE);
return TRUE; return TRUE;
@ -222,7 +222,7 @@ static inline DWORD max_ascii85_size(DWORD size)
* bit depths. * bit depths.
* Compression not implemented. * Compression not implemented.
*/ */
INT CDECL PSDRV_StretchDIBits( PSDRV_PDEVICE *physDev, INT xDst, INT yDst, INT widthDst, INT CDECL PSDRV_StretchDIBits( PHYSDEV dev, INT xDst, INT yDst, INT widthDst,
INT heightDst, INT xSrc, INT ySrc, INT heightDst, INT xSrc, INT ySrc,
INT widthSrc, INT heightSrc, const void *bits, INT widthSrc, INT heightSrc, const void *bits,
const BITMAPINFO *info, UINT wUsage, DWORD dwRop ) const BITMAPINFO *info, UINT wUsage, DWORD dwRop )
@ -236,7 +236,7 @@ INT CDECL PSDRV_StretchDIBits( PSDRV_PDEVICE *physDev, INT xDst, INT yDst, INT w
BYTE *dst_ptr, *bitmap, *rle, *ascii85; BYTE *dst_ptr, *bitmap, *rle, *ascii85;
DWORD rle_len, ascii85_len, bitmap_size; DWORD rle_len, ascii85_len, bitmap_size;
TRACE("%p (%d,%d %dx%d) -> (%d,%d %dx%d)\n", physDev->hdc, TRACE("%p (%d,%d %dx%d) -> (%d,%d %dx%d)\n", dev->hdc,
xSrc, ySrc, widthSrc, heightSrc, xDst, yDst, widthDst, heightDst); xSrc, ySrc, widthSrc, heightSrc, xDst, yDst, widthDst, heightDst);
if (!get_bitmap_info( info, &fullSrcWidth, &fullSrcHeight, &bpp, &compression )) return FALSE; if (!get_bitmap_info( info, &fullSrcWidth, &fullSrcHeight, &bpp, &compression )) return FALSE;
@ -257,7 +257,7 @@ INT CDECL PSDRV_StretchDIBits( PSDRV_PDEVICE *physDev, INT xDst, INT yDst, INT w
pt[0].y = yDst; pt[0].y = yDst;
pt[1].x = xDst + widthDst; pt[1].x = xDst + widthDst;
pt[1].y = yDst + heightDst; pt[1].y = yDst + heightDst;
LPtoDP( physDev->hdc, pt, 2 ); LPtoDP( dev->hdc, pt, 2 );
xDst = pt[0].x; xDst = pt[0].x;
yDst = pt[0].y; yDst = pt[0].y;
widthDst = pt[1].x - pt[0].x; widthDst = pt[1].x - pt[0].x;
@ -266,11 +266,11 @@ INT CDECL PSDRV_StretchDIBits( PSDRV_PDEVICE *physDev, INT xDst, INT yDst, INT w
switch(bpp) { switch(bpp) {
case 1: case 1:
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
/* Use imagemask rather than image */ /* Use imagemask rather than image */
PSDRV_WriteImageMaskHeader(physDev, info, xDst, yDst, widthDst, heightDst, PSDRV_WriteImageMaskHeader(dev, info, xDst, yDst, widthDst, heightDst,
widthSrc, heightSrc); widthSrc, heightSrc);
src_ptr = bits; src_ptr = bits;
if(stride < 0) src_ptr += (fullSrcHeight + 1) * stride; if(stride < 0) src_ptr += (fullSrcHeight + 1) * stride;
@ -284,9 +284,9 @@ INT CDECL PSDRV_StretchDIBits( PSDRV_PDEVICE *physDev, INT xDst, INT yDst, INT w
break; break;
case 4: case 4:
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteImageHeader(physDev, info, xDst, yDst, widthDst, heightDst, PSDRV_WriteImageHeader(dev, info, xDst, yDst, widthDst, heightDst,
widthSrc, heightSrc); widthSrc, heightSrc);
src_ptr = bits; src_ptr = bits;
if(stride < 0) src_ptr += (fullSrcHeight + 1) * stride; if(stride < 0) src_ptr += (fullSrcHeight + 1) * stride;
@ -300,9 +300,9 @@ INT CDECL PSDRV_StretchDIBits( PSDRV_PDEVICE *physDev, INT xDst, INT yDst, INT w
break; break;
case 8: case 8:
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteImageHeader(physDev, info, xDst, yDst, widthDst, heightDst, PSDRV_WriteImageHeader(dev, info, xDst, yDst, widthDst, heightDst,
widthSrc, heightSrc); widthSrc, heightSrc);
src_ptr = bits; src_ptr = bits;
if(stride < 0) src_ptr += (fullSrcHeight + 1) * stride; if(stride < 0) src_ptr += (fullSrcHeight + 1) * stride;
@ -315,9 +315,9 @@ INT CDECL PSDRV_StretchDIBits( PSDRV_PDEVICE *physDev, INT xDst, INT yDst, INT w
case 15: case 15:
case 16: case 16:
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteImageHeader(physDev, info, xDst, yDst, widthDst, heightDst, PSDRV_WriteImageHeader(dev, info, xDst, yDst, widthDst, heightDst,
widthSrc, heightSrc); widthSrc, heightSrc);
@ -349,9 +349,9 @@ INT CDECL PSDRV_StretchDIBits( PSDRV_PDEVICE *physDev, INT xDst, INT yDst, INT w
break; break;
case 24: case 24:
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteImageHeader(physDev, info, xDst, yDst, widthDst, heightDst, PSDRV_WriteImageHeader(dev, info, xDst, yDst, widthDst, heightDst,
widthSrc, heightSrc); widthSrc, heightSrc);
src_ptr = bits; src_ptr = bits;
@ -372,9 +372,9 @@ INT CDECL PSDRV_StretchDIBits( PSDRV_PDEVICE *physDev, INT xDst, INT yDst, INT w
break; break;
case 32: case 32:
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteImageHeader(physDev, info, xDst, yDst, widthDst, heightDst, PSDRV_WriteImageHeader(dev, info, xDst, yDst, widthDst, heightDst,
widthSrc, heightSrc); widthSrc, heightSrc);
src_ptr = bits; src_ptr = bits;
@ -406,10 +406,10 @@ INT CDECL PSDRV_StretchDIBits( PSDRV_PDEVICE *physDev, INT xDst, INT yDst, INT w
ascii85 = HeapAlloc(GetProcessHeap(), 0, max_ascii85_size(rle_len)); ascii85 = HeapAlloc(GetProcessHeap(), 0, max_ascii85_size(rle_len));
ascii85_len = ASCII85_encode(rle, rle_len, ascii85); ascii85_len = ASCII85_encode(rle, rle_len, ascii85);
HeapFree(GetProcessHeap(), 0, rle); HeapFree(GetProcessHeap(), 0, rle);
PSDRV_WriteData(physDev, ascii85, ascii85_len); PSDRV_WriteData(dev, ascii85, ascii85_len);
HeapFree(GetProcessHeap(), 0, ascii85); HeapFree(GetProcessHeap(), 0, ascii85);
PSDRV_WriteSpool(physDev, "~>\n", 3); PSDRV_WriteSpool(dev, "~>\n", 3);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return abs(heightSrc); return abs(heightSrc);
} }

View File

@ -27,8 +27,9 @@ WINE_DEFAULT_DEBUG_CHANNEL(psdrv);
/*********************************************************************** /***********************************************************************
* SelectBrush (WINEPS.@) * SelectBrush (WINEPS.@)
*/ */
HBRUSH CDECL PSDRV_SelectBrush( PSDRV_PDEVICE *physDev, HBRUSH hbrush ) HBRUSH CDECL PSDRV_SelectBrush( PHYSDEV dev, HBRUSH hbrush )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
LOGBRUSH logbrush; LOGBRUSH logbrush;
if (!GetObjectA( hbrush, sizeof(logbrush), &logbrush )) return 0; if (!GetObjectA( hbrush, sizeof(logbrush), &logbrush )) return 0;
@ -41,14 +42,14 @@ HBRUSH CDECL PSDRV_SelectBrush( PSDRV_PDEVICE *physDev, HBRUSH hbrush )
switch(logbrush.lbStyle) { switch(logbrush.lbStyle) {
case BS_SOLID: case BS_SOLID:
PSDRV_CreateColor(physDev, &physDev->brush.color, logbrush.lbColor); PSDRV_CreateColor(dev, &physDev->brush.color, logbrush.lbColor);
break; break;
case BS_NULL: case BS_NULL:
break; break;
case BS_HATCHED: case BS_HATCHED:
PSDRV_CreateColor(physDev, &physDev->brush.color, logbrush.lbColor); PSDRV_CreateColor(dev, &physDev->brush.color, logbrush.lbColor);
break; break;
case BS_PATTERN: case BS_PATTERN:
@ -68,11 +69,13 @@ HBRUSH CDECL PSDRV_SelectBrush( PSDRV_PDEVICE *physDev, HBRUSH hbrush )
/*********************************************************************** /***********************************************************************
* SetDCBrushColor (WINEPS.@) * SetDCBrushColor (WINEPS.@)
*/ */
COLORREF CDECL PSDRV_SetDCBrushColor( PSDRV_PDEVICE *physDev, COLORREF color ) COLORREF CDECL PSDRV_SetDCBrushColor( PHYSDEV dev, COLORREF color )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
if (GetCurrentObject( physDev->hdc, OBJ_BRUSH ) == GetStockObject( DC_BRUSH )) if (GetCurrentObject( physDev->hdc, OBJ_BRUSH ) == GetStockObject( DC_BRUSH ))
{ {
PSDRV_CreateColor( physDev, &physDev->brush.color, color ); PSDRV_CreateColor( dev, &physDev->brush.color, color );
physDev->brush.set = FALSE; physDev->brush.set = FALSE;
} }
return color; return color;
@ -84,8 +87,9 @@ COLORREF CDECL PSDRV_SetDCBrushColor( PSDRV_PDEVICE *physDev, COLORREF color )
* PSDRV_SetBrush * PSDRV_SetBrush
* *
*/ */
static BOOL PSDRV_SetBrush(PSDRV_PDEVICE *physDev) static BOOL PSDRV_SetBrush( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
LOGBRUSH logbrush; LOGBRUSH logbrush;
BOOL ret = TRUE; BOOL ret = TRUE;
@ -98,7 +102,7 @@ static BOOL PSDRV_SetBrush(PSDRV_PDEVICE *physDev)
switch (logbrush.lbStyle) { switch (logbrush.lbStyle) {
case BS_SOLID: case BS_SOLID:
case BS_HATCHED: case BS_HATCHED:
PSDRV_WriteSetColor(physDev, &physDev->brush.color); PSDRV_WriteSetColor(dev, &physDev->brush.color);
break; break;
case BS_NULL: case BS_NULL:
@ -119,12 +123,12 @@ static BOOL PSDRV_SetBrush(PSDRV_PDEVICE *physDev)
* PSDRV_Fill * PSDRV_Fill
* *
*/ */
static BOOL PSDRV_Fill(PSDRV_PDEVICE *physDev, BOOL EO) static BOOL PSDRV_Fill(PHYSDEV dev, BOOL EO)
{ {
if(!EO) if(!EO)
return PSDRV_WriteFill(physDev); return PSDRV_WriteFill(dev);
else else
return PSDRV_WriteEOFill(physDev); return PSDRV_WriteEOFill(dev);
} }
@ -133,12 +137,12 @@ static BOOL PSDRV_Fill(PSDRV_PDEVICE *physDev, BOOL EO)
* PSDRV_Clip * PSDRV_Clip
* *
*/ */
static BOOL PSDRV_Clip(PSDRV_PDEVICE *physDev, BOOL EO) static BOOL PSDRV_Clip(PHYSDEV dev, BOOL EO)
{ {
if(!EO) if(!EO)
return PSDRV_WriteClip(physDev); return PSDRV_WriteClip(dev);
else else
return PSDRV_WriteEOClip(physDev); return PSDRV_WriteEOClip(dev);
} }
/********************************************************************** /**********************************************************************
@ -146,8 +150,9 @@ static BOOL PSDRV_Clip(PSDRV_PDEVICE *physDev, BOOL EO)
* PSDRV_Brush * PSDRV_Brush
* *
*/ */
BOOL PSDRV_Brush(PSDRV_PDEVICE *physDev, BOOL EO) BOOL PSDRV_Brush(PHYSDEV dev, BOOL EO)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
LOGBRUSH logbrush; LOGBRUSH logbrush;
BOOL ret = TRUE; BOOL ret = TRUE;
@ -162,56 +167,56 @@ BOOL PSDRV_Brush(PSDRV_PDEVICE *physDev, BOOL EO)
switch (logbrush.lbStyle) { switch (logbrush.lbStyle) {
case BS_SOLID: case BS_SOLID:
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_SetBrush(physDev); PSDRV_SetBrush(dev);
PSDRV_Fill(physDev, EO); PSDRV_Fill(dev, EO);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
break; break;
case BS_HATCHED: case BS_HATCHED:
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_SetBrush(physDev); PSDRV_SetBrush(dev);
switch(logbrush.lbHatch) { switch(logbrush.lbHatch) {
case HS_VERTICAL: case HS_VERTICAL:
case HS_CROSS: case HS_CROSS:
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_Clip(physDev, EO); PSDRV_Clip(dev, EO);
PSDRV_WriteHatch(physDev); PSDRV_WriteHatch(dev);
PSDRV_WriteStroke(physDev); PSDRV_WriteStroke(dev);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
if(logbrush.lbHatch == HS_VERTICAL) if(logbrush.lbHatch == HS_VERTICAL)
break; break;
/* else fallthrough for HS_CROSS */ /* else fallthrough for HS_CROSS */
case HS_HORIZONTAL: case HS_HORIZONTAL:
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_Clip(physDev, EO); PSDRV_Clip(dev, EO);
PSDRV_WriteRotate(physDev, 90.0); PSDRV_WriteRotate(dev, 90.0);
PSDRV_WriteHatch(physDev); PSDRV_WriteHatch(dev);
PSDRV_WriteStroke(physDev); PSDRV_WriteStroke(dev);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
break; break;
case HS_FDIAGONAL: case HS_FDIAGONAL:
case HS_DIAGCROSS: case HS_DIAGCROSS:
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_Clip(physDev, EO); PSDRV_Clip(dev, EO);
PSDRV_WriteRotate(physDev, -45.0); PSDRV_WriteRotate(dev, -45.0);
PSDRV_WriteHatch(physDev); PSDRV_WriteHatch(dev);
PSDRV_WriteStroke(physDev); PSDRV_WriteStroke(dev);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
if(logbrush.lbHatch == HS_FDIAGONAL) if(logbrush.lbHatch == HS_FDIAGONAL)
break; break;
/* else fallthrough for HS_DIAGCROSS */ /* else fallthrough for HS_DIAGCROSS */
case HS_BDIAGONAL: case HS_BDIAGONAL:
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_Clip(physDev, EO); PSDRV_Clip(dev, EO);
PSDRV_WriteRotate(physDev, 45.0); PSDRV_WriteRotate(dev, 45.0);
PSDRV_WriteHatch(physDev); PSDRV_WriteHatch(dev);
PSDRV_WriteStroke(physDev); PSDRV_WriteStroke(dev);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
break; break;
default: default:
@ -219,7 +224,7 @@ BOOL PSDRV_Brush(PSDRV_PDEVICE *physDev, BOOL EO)
ret = FALSE; ret = FALSE;
break; break;
} }
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
break; break;
case BS_NULL: case BS_NULL:
@ -236,10 +241,10 @@ BOOL PSDRV_Brush(PSDRV_PDEVICE *physDev, BOOL EO)
GetBitmapBits( (HBITMAP)logbrush.lbHatch, bm.bmWidthBytes * bm.bmHeight, bits); GetBitmapBits( (HBITMAP)logbrush.lbHatch, bm.bmWidthBytes * bm.bmHeight, bits);
if(physDev->pi->ppd->LanguageLevel > 1) { if(physDev->pi->ppd->LanguageLevel > 1) {
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WritePatternDict(physDev, &bm, bits); PSDRV_WritePatternDict(dev, &bm, bits);
PSDRV_Fill(physDev, EO); PSDRV_Fill(dev, EO);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
} else { } else {
FIXME("Trying to set a pattern brush on a level 1 printer\n"); FIXME("Trying to set a pattern brush on a level 1 printer\n");
ret = FALSE; ret = FALSE;
@ -255,10 +260,10 @@ BOOL PSDRV_Brush(PSDRV_PDEVICE *physDev, BOOL EO)
TRACE("size %dx%dx%d\n", bmi->bmiHeader.biWidth, TRACE("size %dx%dx%d\n", bmi->bmiHeader.biWidth,
bmi->bmiHeader.biHeight, bmi->bmiHeader.biBitCount); bmi->bmiHeader.biHeight, bmi->bmiHeader.biBitCount);
if(physDev->pi->ppd->LanguageLevel > 1) { if(physDev->pi->ppd->LanguageLevel > 1) {
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
ret = PSDRV_WriteDIBPatternDict(physDev, bmi, usage); ret = PSDRV_WriteDIBPatternDict(dev, bmi, usage);
PSDRV_Fill(physDev, EO); PSDRV_Fill(dev, EO);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
} else { } else {
FIXME("Trying to set a pattern brush on a level 1 printer\n"); FIXME("Trying to set a pattern brush on a level 1 printer\n");
ret = FALSE; ret = FALSE;

View File

@ -155,9 +155,10 @@ static VOID ScaleFont(const AFM *afm, LONG lfHeight, PSFONT *font,
* Set up physDev->font for a builtin font * Set up physDev->font for a builtin font
* *
*/ */
BOOL PSDRV_SelectBuiltinFont(PSDRV_PDEVICE *physDev, HFONT hfont, BOOL PSDRV_SelectBuiltinFont(PHYSDEV dev, HFONT hfont,
LOGFONTW *plf, LPSTR FaceName) LOGFONTW *plf, LPSTR FaceName)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
AFMLISTENTRY *afmle; AFMLISTENTRY *afmle;
FONTFAMILY *family; FONTFAMILY *family;
BOOL bd = FALSE, it = FALSE; BOOL bd = FALSE, it = FALSE;
@ -232,15 +233,17 @@ BOOL PSDRV_SelectBuiltinFont(PSDRV_PDEVICE *physDev, HFONT hfont,
return TRUE; return TRUE;
} }
BOOL PSDRV_WriteSetBuiltinFont(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteSetBuiltinFont(PHYSDEV dev)
{ {
return PSDRV_WriteSetFont(physDev, PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
physDev->font.fontinfo.Builtin.afm->FontName,
return PSDRV_WriteSetFont(dev, physDev->font.fontinfo.Builtin.afm->FontName,
physDev->font.size, physDev->font.escapement); physDev->font.size, physDev->font.escapement);
} }
BOOL PSDRV_WriteBuiltinGlyphShow(PSDRV_PDEVICE *physDev, LPCWSTR str, INT count) BOOL PSDRV_WriteBuiltinGlyphShow(PHYSDEV dev, LPCWSTR str, INT count)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
int i; int i;
LPCSTR name; LPCSTR name;
@ -248,7 +251,7 @@ BOOL PSDRV_WriteBuiltinGlyphShow(PSDRV_PDEVICE *physDev, LPCWSTR str, INT count)
{ {
name = PSDRV_UVMetrics(str[i], physDev->font.fontinfo.Builtin.afm)->N->sz; name = PSDRV_UVMetrics(str[i], physDev->font.fontinfo.Builtin.afm)->N->sz;
PSDRV_WriteGlyphShow(physDev, name); PSDRV_WriteGlyphShow(dev, name);
} }
return TRUE; return TRUE;
@ -257,8 +260,10 @@ BOOL PSDRV_WriteBuiltinGlyphShow(PSDRV_PDEVICE *physDev, LPCWSTR str, INT count)
/*********************************************************************** /***********************************************************************
* PSDRV_GetTextMetrics * PSDRV_GetTextMetrics
*/ */
BOOL CDECL PSDRV_GetTextMetrics(PSDRV_PDEVICE *physDev, TEXTMETRICW *metrics) BOOL CDECL PSDRV_GetTextMetrics(PHYSDEV dev, TEXTMETRICW *metrics)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
assert(physDev->font.fontloc == Builtin); assert(physDev->font.fontloc == Builtin);
memcpy(metrics, &(physDev->font.fontinfo.Builtin.tm), memcpy(metrics, &(physDev->font.fontinfo.Builtin.tm),
@ -308,9 +313,10 @@ const AFMMETRICS *PSDRV_UVMetrics(LONG UV, const AFM *afm)
/*********************************************************************** /***********************************************************************
* PSDRV_GetTextExtentExPoint * PSDRV_GetTextExtentExPoint
*/ */
BOOL CDECL PSDRV_GetTextExtentExPoint(PSDRV_PDEVICE *physDev, LPCWSTR str, INT count, BOOL CDECL PSDRV_GetTextExtentExPoint(PHYSDEV dev, LPCWSTR str, INT count,
INT maxExt, LPINT lpnFit, LPINT alpDx, LPSIZE size) INT maxExt, LPINT lpnFit, LPINT alpDx, LPSIZE size)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
int nfit = 0; int nfit = 0;
int i; int i;
float width = 0.0; float width = 0.0;
@ -346,8 +352,9 @@ BOOL CDECL PSDRV_GetTextExtentExPoint(PSDRV_PDEVICE *physDev, LPCWSTR str, INT c
/*********************************************************************** /***********************************************************************
* PSDRV_GetCharWidth * PSDRV_GetCharWidth
*/ */
BOOL CDECL PSDRV_GetCharWidth(PSDRV_PDEVICE *physDev, UINT firstChar, UINT lastChar, LPINT buffer) BOOL CDECL PSDRV_GetCharWidth(PHYSDEV dev, UINT firstChar, UINT lastChar, LPINT buffer)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
UINT i; UINT i;
assert(physDev->font.fontloc == Builtin); assert(physDev->font.fontloc == Builtin);
@ -406,9 +413,9 @@ static UINT PSDRV_GetFontMetric(HDC hdc, const AFM *afm,
/*********************************************************************** /***********************************************************************
* PSDRV_EnumDeviceFonts * PSDRV_EnumDeviceFonts
*/ */
BOOL CDECL PSDRV_EnumDeviceFonts( PSDRV_PDEVICE *physDev, LPLOGFONTW plf, BOOL CDECL PSDRV_EnumDeviceFonts( PHYSDEV dev, LPLOGFONTW plf, FONTENUMPROCW proc, LPARAM lp )
FONTENUMPROCW proc, LPARAM lp )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
ENUMLOGFONTEXW lf; ENUMLOGFONTEXW lf;
NEWTEXTMETRICEXW tm; NEWTEXTMETRICEXW tm;
BOOL b, bRet = 0; BOOL b, bRet = 0;

View File

@ -35,8 +35,9 @@ WINE_DEFAULT_DEBUG_CHANNEL(psdrv);
* small clip area in the printer dc that it can still write raw * small clip area in the printer dc that it can still write raw
* PostScript to the driver and expect this code not to be clipped. * PostScript to the driver and expect this code not to be clipped.
*/ */
void PSDRV_SetClip( PSDRV_PDEVICE *physDev ) void PSDRV_SetClip( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
CHAR szArrayName[] = "clippath"; CHAR szArrayName[] = "clippath";
DWORD size; DWORD size;
RGNDATA *rgndata = NULL; RGNDATA *rgndata = NULL;
@ -67,20 +68,20 @@ void PSDRV_SetClip( PSDRV_PDEVICE *physDev )
GetRegionData(hrgn, size, rgndata); GetRegionData(hrgn, size, rgndata);
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
/* check for NULL region */ /* check for NULL region */
if (rgndata->rdh.nCount == 0) if (rgndata->rdh.nCount == 0)
{ {
/* set an empty clip path. */ /* set an empty clip path. */
PSDRV_WriteRectClip(physDev, 0, 0, 0, 0); PSDRV_WriteRectClip(dev, 0, 0, 0, 0);
} }
/* optimize when it is a simple region */ /* optimize when it is a simple region */
else if (rgndata->rdh.nCount == 1) else if (rgndata->rdh.nCount == 1)
{ {
RECT *pRect = (RECT *)rgndata->Buffer; RECT *pRect = (RECT *)rgndata->Buffer;
PSDRV_WriteRectClip(physDev, pRect->left, pRect->top, PSDRV_WriteRectClip(dev, pRect->left, pRect->top,
pRect->right - pRect->left, pRect->right - pRect->left,
pRect->bottom - pRect->top); pRect->bottom - pRect->top);
} }
@ -89,20 +90,20 @@ void PSDRV_SetClip( PSDRV_PDEVICE *physDev )
UINT i; UINT i;
RECT *pRect = (RECT *)rgndata->Buffer; RECT *pRect = (RECT *)rgndata->Buffer;
PSDRV_WriteArrayDef(physDev, szArrayName, rgndata->rdh.nCount * 4); PSDRV_WriteArrayDef(dev, szArrayName, rgndata->rdh.nCount * 4);
for (i = 0; i < rgndata->rdh.nCount; i++, pRect++) for (i = 0; i < rgndata->rdh.nCount; i++, pRect++)
{ {
PSDRV_WriteArrayPut(physDev, szArrayName, i * 4, PSDRV_WriteArrayPut(dev, szArrayName, i * 4,
pRect->left); pRect->left);
PSDRV_WriteArrayPut(physDev, szArrayName, i * 4 + 1, PSDRV_WriteArrayPut(dev, szArrayName, i * 4 + 1,
pRect->top); pRect->top);
PSDRV_WriteArrayPut(physDev, szArrayName, i * 4 + 2, PSDRV_WriteArrayPut(dev, szArrayName, i * 4 + 2,
pRect->right - pRect->left); pRect->right - pRect->left);
PSDRV_WriteArrayPut(physDev, szArrayName, i * 4 + 3, PSDRV_WriteArrayPut(dev, szArrayName, i * 4 + 3,
pRect->bottom - pRect->top); pRect->bottom - pRect->top);
} }
PSDRV_WriteRectClip2(physDev, szArrayName); PSDRV_WriteRectClip2(dev, szArrayName);
} }
} }
end: end:
@ -114,13 +115,14 @@ end:
/*********************************************************************** /***********************************************************************
* PSDRV_ResetClip * PSDRV_ResetClip
*/ */
void PSDRV_ResetClip( PSDRV_PDEVICE *physDev ) void PSDRV_ResetClip( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
HRGN hrgn = CreateRectRgn(0,0,0,0); HRGN hrgn = CreateRectRgn(0,0,0,0);
BOOL empty; BOOL empty;
empty = !GetClipRgn(physDev->hdc, hrgn); empty = !GetClipRgn(physDev->hdc, hrgn);
if(!empty && !physDev->pathdepth) if(!empty && !physDev->pathdepth)
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
DeleteObject(hrgn); DeleteObject(hrgn);
} }

View File

@ -60,9 +60,9 @@ BOOL PSDRV_CopyColor(PSCOLOR *col1, PSCOLOR *col2)
* Result is grey scale if ColorDevice field of ppd is CD_False else an * Result is grey scale if ColorDevice field of ppd is CD_False else an
* rgb colour is produced. * rgb colour is produced.
*/ */
void PSDRV_CreateColor( PSDRV_PDEVICE *physDev, PSCOLOR *pscolor, void PSDRV_CreateColor( PHYSDEV dev, PSCOLOR *pscolor, COLORREF wincolor )
COLORREF wincolor )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
int ctype = wincolor >> 24; int ctype = wincolor >> 24;
float r, g, b; float r, g, b;
@ -90,9 +90,10 @@ void PSDRV_CreateColor( PSDRV_PDEVICE *physDev, PSCOLOR *pscolor,
/*********************************************************************** /***********************************************************************
* PSDRV_SetBkColor * PSDRV_SetBkColor
*/ */
COLORREF CDECL PSDRV_SetBkColor( PSDRV_PDEVICE *physDev, COLORREF color ) COLORREF CDECL PSDRV_SetBkColor( PHYSDEV dev, COLORREF color )
{ {
PSDRV_CreateColor(physDev, &physDev->bkColor, color); PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
PSDRV_CreateColor(dev, &physDev->bkColor, color);
return color; return color;
} }
@ -100,9 +101,10 @@ COLORREF CDECL PSDRV_SetBkColor( PSDRV_PDEVICE *physDev, COLORREF color )
/*********************************************************************** /***********************************************************************
* PSDRV_SetTextColor * PSDRV_SetTextColor
*/ */
COLORREF CDECL PSDRV_SetTextColor( PSDRV_PDEVICE *physDev, COLORREF color ) COLORREF CDECL PSDRV_SetTextColor( PHYSDEV dev, COLORREF color )
{ {
PSDRV_CreateColor(physDev, &physDev->font.color, color); PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
PSDRV_CreateColor(dev, &physDev->font.color, color);
physDev->font.set = FALSE; physDev->font.set = FALSE;
return color; return color;
} }

View File

@ -49,14 +49,13 @@ BOOL WINAPI GetTransform( HDC hdc, DWORD which, XFORM *xform );
/**************************************************************************** /****************************************************************************
* get_download_name * get_download_name
*/ */
static void get_download_name(PSDRV_PDEVICE *physDev, LPOUTLINETEXTMETRICA static void get_download_name(PHYSDEV dev, LPOUTLINETEXTMETRICA potm, char **str)
potm, char **str)
{ {
int len; int len;
char *p; char *p;
DWORD size; DWORD size;
size = GetFontData(physDev->hdc, MS_MAKE_TAG('n','a','m','e'), 0, NULL, 0); size = GetFontData(dev->hdc, MS_MAKE_TAG('n','a','m','e'), 0, NULL, 0);
if(size != 0 && size != GDI_ERROR) if(size != 0 && size != GDI_ERROR)
{ {
BYTE *name = HeapAlloc(GetProcessHeap(), 0, size); BYTE *name = HeapAlloc(GetProcessHeap(), 0, size);
@ -74,7 +73,7 @@ static void get_download_name(PSDRV_PDEVICE *physDev, LPOUTLINETEXTMETRICA
USHORT offset; USHORT offset;
} *name_record; } *name_record;
GetFontData(physDev->hdc, MS_MAKE_TAG('n','a','m','e'), 0, name, size); GetFontData(dev->hdc, MS_MAKE_TAG('n','a','m','e'), 0, name, size);
count = GET_BE_WORD(name + 2); count = GET_BE_WORD(name + 2);
strings = name + GET_BE_WORD(name + 4); strings = name + GET_BE_WORD(name + 4);
name_record = (typeof(name_record))(name + 6); name_record = (typeof(name_record))(name + 6);
@ -197,8 +196,10 @@ static BOOL get_bbox(HDC hdc, RECT *rc, UINT *emsize)
* Set up physDev->font for a downloadable font * Set up physDev->font for a downloadable font
* *
*/ */
BOOL PSDRV_SelectDownloadFont(PSDRV_PDEVICE *physDev) BOOL PSDRV_SelectDownloadFont(PHYSDEV dev)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
physDev->font.fontloc = Download; physDev->font.fontloc = Download;
physDev->font.fontinfo.Download = NULL; physDev->font.fontinfo.Download = NULL;
@ -246,8 +247,9 @@ static inline float ps_round(float f)
* Write setfont for download font. * Write setfont for download font.
* *
*/ */
BOOL PSDRV_WriteSetDownloadFont(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteSetDownloadFont(PHYSDEV dev)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
char *ps_name; char *ps_name;
LPOUTLINETEXTMETRICA potm; LPOUTLINETEXTMETRICA potm;
DWORD len = GetOutlineTextMetricsA(physDev->hdc, 0, NULL); DWORD len = GetOutlineTextMetricsA(physDev->hdc, 0, NULL);
@ -261,7 +263,7 @@ BOOL PSDRV_WriteSetDownloadFont(PSDRV_PDEVICE *physDev)
potm = HeapAlloc(GetProcessHeap(), 0, len); potm = HeapAlloc(GetProcessHeap(), 0, len);
GetOutlineTextMetricsA(physDev->hdc, len, potm); GetOutlineTextMetricsA(physDev->hdc, len, potm);
get_download_name(physDev, potm, &ps_name); get_download_name(dev, potm, &ps_name);
physDev->font.fontinfo.Download = is_font_downloaded(physDev, ps_name); physDev->font.fontinfo.Download = is_font_downloaded(physDev, ps_name);
if (!GetObjectW( GetCurrentObject(physDev->hdc, OBJ_FONT), sizeof(lf), &lf )) if (!GetObjectW( GetCurrentObject(physDev->hdc, OBJ_FONT), sizeof(lf), &lf ))
@ -297,7 +299,7 @@ BOOL PSDRV_WriteSetDownloadFont(PSDRV_PDEVICE *physDev)
return FALSE; return FALSE;
} }
if(!is_room_for_font(physDev)) if(!is_room_for_font(physDev))
PSDRV_EmptyDownloadList(physDev, TRUE); PSDRV_EmptyDownloadList(dev, TRUE);
pdl = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*pdl)); pdl = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*pdl));
pdl->ps_name = HeapAlloc(GetProcessHeap(), 0, strlen(ps_name)+1); pdl->ps_name = HeapAlloc(GetProcessHeap(), 0, strlen(ps_name)+1);
@ -305,11 +307,11 @@ BOOL PSDRV_WriteSetDownloadFont(PSDRV_PDEVICE *physDev)
pdl->next = NULL; pdl->next = NULL;
if(physDev->pi->ppd->TTRasterizer == RO_Type42) { if(physDev->pi->ppd->TTRasterizer == RO_Type42) {
pdl->typeinfo.Type42 = T42_download_header(physDev, ps_name, &bbox, emsize); pdl->typeinfo.Type42 = T42_download_header(dev, ps_name, &bbox, emsize);
pdl->type = Type42; pdl->type = Type42;
} }
if(pdl->typeinfo.Type42 == NULL) { if(pdl->typeinfo.Type42 == NULL) {
pdl->typeinfo.Type1 = T1_download_header(physDev, ps_name, &bbox, emsize); pdl->typeinfo.Type1 = T1_download_header(dev, ps_name, &bbox, emsize);
pdl->type = Type1; pdl->type = Type1;
} }
pdl->next = physDev->downloaded_fonts; pdl->next = physDev->downloaded_fonts;
@ -319,13 +321,12 @@ BOOL PSDRV_WriteSetDownloadFont(PSDRV_PDEVICE *physDev)
if(pdl->type == Type42) { if(pdl->type == Type42) {
char g_name[MAX_G_NAME + 1]; char g_name[MAX_G_NAME + 1];
get_glyph_name(physDev->hdc, 0, g_name); get_glyph_name(physDev->hdc, 0, g_name);
T42_download_glyph(physDev, pdl, 0, g_name); T42_download_glyph(dev, pdl, 0, g_name);
} }
} }
PSDRV_WriteSetFont(physDev, ps_name, physDev->font.size, PSDRV_WriteSetFont(dev, ps_name, physDev->font.size, physDev->font.escapement);
physDev->font.escapement);
HeapFree(GetProcessHeap(), 0, ps_name); HeapFree(GetProcessHeap(), 0, ps_name);
HeapFree(GetProcessHeap(), 0, potm); HeapFree(GetProcessHeap(), 0, potm);
@ -345,9 +346,10 @@ void get_glyph_name(HDC hdc, WORD index, char *name)
* Download and write out a number of glyphs * Download and write out a number of glyphs
* *
*/ */
BOOL PSDRV_WriteDownloadGlyphShow(PSDRV_PDEVICE *physDev, WORD *glyphs, BOOL PSDRV_WriteDownloadGlyphShow(PHYSDEV dev, WORD *glyphs,
UINT count) UINT count)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
UINT i; UINT i;
char g_name[MAX_G_NAME + 1]; char g_name[MAX_G_NAME + 1];
assert(physDev->font.fontloc == Download); assert(physDev->font.fontloc == Download);
@ -356,18 +358,16 @@ BOOL PSDRV_WriteDownloadGlyphShow(PSDRV_PDEVICE *physDev, WORD *glyphs,
case Type42: case Type42:
for(i = 0; i < count; i++) { for(i = 0; i < count; i++) {
get_glyph_name(physDev->hdc, glyphs[i], g_name); get_glyph_name(physDev->hdc, glyphs[i], g_name);
T42_download_glyph(physDev, physDev->font.fontinfo.Download, T42_download_glyph(dev, physDev->font.fontinfo.Download, glyphs[i], g_name);
glyphs[i], g_name); PSDRV_WriteGlyphShow(dev, g_name);
PSDRV_WriteGlyphShow(physDev, g_name);
} }
break; break;
case Type1: case Type1:
for(i = 0; i < count; i++) { for(i = 0; i < count; i++) {
get_glyph_name(physDev->hdc, glyphs[i], g_name); get_glyph_name(physDev->hdc, glyphs[i], g_name);
T1_download_glyph(physDev, physDev->font.fontinfo.Download, T1_download_glyph(dev, physDev->font.fontinfo.Download, glyphs[i], g_name);
glyphs[i], g_name); PSDRV_WriteGlyphShow(dev, g_name);
PSDRV_WriteGlyphShow(physDev, g_name);
} }
break; break;
@ -384,8 +384,9 @@ BOOL PSDRV_WriteDownloadGlyphShow(PSDRV_PDEVICE *physDev, WORD *glyphs,
* Clear the list of downloaded fonts * Clear the list of downloaded fonts
* *
*/ */
BOOL PSDRV_EmptyDownloadList(PSDRV_PDEVICE *physDev, BOOL write_undef) BOOL PSDRV_EmptyDownloadList(PHYSDEV dev, BOOL write_undef)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
DOWNLOAD *pdl, *old; DOWNLOAD *pdl, *old;
static const char undef[] = "/%s findfont 40 scalefont setfont /%s undefinefont\n"; static const char undef[] = "/%s findfont 40 scalefont setfont /%s undefinefont\n";
char buf[sizeof(undef) + 200]; char buf[sizeof(undef) + 200];
@ -402,7 +403,7 @@ BOOL PSDRV_EmptyDownloadList(PSDRV_PDEVICE *physDev, BOOL write_undef)
while(pdl) { while(pdl) {
if(write_undef) { if(write_undef) {
sprintf(buf, undef, default_font, pdl->ps_name); sprintf(buf, undef, default_font, pdl->ps_name);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
switch(pdl->type) { switch(pdl->type) {

View File

@ -47,9 +47,11 @@ static const char psbegindocument[] =
"%%BeginDocument: Wine passthrough\n"; "%%BeginDocument: Wine passthrough\n";
DWORD write_spool( PSDRV_PDEVICE *physDev, const void *data, DWORD num ) DWORD write_spool( PHYSDEV dev, const void *data, DWORD num )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
DWORD written; DWORD written;
if (!WritePrinter(physDev->job.hprinter, (LPBYTE) data, num, &written) || (written != num)) if (!WritePrinter(physDev->job.hprinter, (LPBYTE) data, num, &written) || (written != num))
return SP_OUTOFDISK; return SP_OUTOFDISK;
@ -59,9 +61,11 @@ DWORD write_spool( PSDRV_PDEVICE *physDev, const void *data, DWORD num )
/********************************************************************** /**********************************************************************
* ExtEscape (WINEPS.@) * ExtEscape (WINEPS.@)
*/ */
INT CDECL PSDRV_ExtEscape( PSDRV_PDEVICE *physDev, INT nEscape, INT cbInput, LPCVOID in_data, INT CDECL PSDRV_ExtEscape( PHYSDEV dev, INT nEscape, INT cbInput, LPCVOID in_data,
INT cbOutput, LPVOID out_data ) INT cbOutput, LPVOID out_data )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
switch(nEscape) switch(nEscape)
{ {
case QUERYESCSUPPORT: case QUERYESCSUPPORT:
@ -275,10 +279,10 @@ INT CDECL PSDRV_ExtEscape( PSDRV_PDEVICE *physDev, INT nEscape, INT cbInput, LPC
* in_data[0] instead. * in_data[0] instead.
*/ */
if(!physDev->job.in_passthrough) { if(!physDev->job.in_passthrough) {
write_spool(physDev, psbegindocument, sizeof(psbegindocument)-1); write_spool(dev, psbegindocument, sizeof(psbegindocument)-1);
physDev->job.in_passthrough = TRUE; physDev->job.in_passthrough = TRUE;
} }
return write_spool(physDev,((char*)in_data)+2,*(const WORD*)in_data); return write_spool(dev,((char*)in_data)+2,*(const WORD*)in_data);
} }
case POSTSCRIPT_IGNORE: case POSTSCRIPT_IGNORE:
@ -317,7 +321,7 @@ INT CDECL PSDRV_ExtEscape( PSDRV_PDEVICE *physDev, INT nEscape, INT cbInput, LPC
info->RenderMode, info->FillMode, info->BkMode); info->RenderMode, info->FillMode, info->BkMode);
switch(info->RenderMode) { switch(info->RenderMode) {
case RENDERMODE_NO_DISPLAY: case RENDERMODE_NO_DISPLAY:
PSDRV_WriteClosePath(physDev); /* not sure if this is necessary, but it can't hurt */ PSDRV_WriteClosePath(dev); /* not sure if this is necessary, but it can't hurt */
break; break;
case RENDERMODE_OPEN: case RENDERMODE_OPEN:
case RENDERMODE_CLOSED: case RENDERMODE_CLOSED:
@ -335,17 +339,17 @@ INT CDECL PSDRV_ExtEscape( PSDRV_PDEVICE *physDev, INT nEscape, INT cbInput, LPC
switch(mode) { switch(mode) {
case CLIP_SAVE: case CLIP_SAVE:
TRACE("CLIP_TO_PATH: CLIP_SAVE\n"); TRACE("CLIP_TO_PATH: CLIP_SAVE\n");
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
return 1; return 1;
case CLIP_RESTORE: case CLIP_RESTORE:
TRACE("CLIP_TO_PATH: CLIP_RESTORE\n"); TRACE("CLIP_TO_PATH: CLIP_RESTORE\n");
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
return 1; return 1;
case CLIP_INCLUSIVE: case CLIP_INCLUSIVE:
TRACE("CLIP_TO_PATH: CLIP_INCLUSIVE\n"); TRACE("CLIP_TO_PATH: CLIP_INCLUSIVE\n");
/* FIXME to clip or eoclip ? (see PATH_INFO.FillMode) */ /* FIXME to clip or eoclip ? (see PATH_INFO.FillMode) */
PSDRV_WriteClip(physDev); PSDRV_WriteClip(dev);
PSDRV_WriteNewPath(physDev); PSDRV_WriteNewPath(dev);
return 1; return 1;
case CLIP_EXCLUSIVE: case CLIP_EXCLUSIVE:
FIXME("CLIP_EXCLUSIVE: not implemented\n"); FIXME("CLIP_EXCLUSIVE: not implemented\n");
@ -364,19 +368,21 @@ INT CDECL PSDRV_ExtEscape( PSDRV_PDEVICE *physDev, INT nEscape, INT cbInput, LPC
/************************************************************************ /************************************************************************
* PSDRV_StartPage * PSDRV_StartPage
*/ */
INT CDECL PSDRV_StartPage( PSDRV_PDEVICE *physDev ) INT CDECL PSDRV_StartPage( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
if(!physDev->job.OutOfPage) { if(!physDev->job.OutOfPage) {
FIXME("Already started a page?\n"); FIXME("Already started a page?\n");
return 1; return 1;
} }
if(physDev->job.PageNo++ == 0) { if(physDev->job.PageNo++ == 0) {
if(!PSDRV_WriteHeader( physDev, physDev->job.DocName )) if(!PSDRV_WriteHeader( dev, physDev->job.DocName ))
return 0; return 0;
} }
if(!PSDRV_WriteNewPage( physDev )) if(!PSDRV_WriteNewPage( dev ))
return 0; return 0;
physDev->job.OutOfPage = FALSE; physDev->job.OutOfPage = FALSE;
return 1; return 1;
@ -386,15 +392,17 @@ INT CDECL PSDRV_StartPage( PSDRV_PDEVICE *physDev )
/************************************************************************ /************************************************************************
* PSDRV_EndPage * PSDRV_EndPage
*/ */
INT CDECL PSDRV_EndPage( PSDRV_PDEVICE *physDev ) INT CDECL PSDRV_EndPage( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
if(physDev->job.OutOfPage) { if(physDev->job.OutOfPage) {
FIXME("Already ended a page?\n"); FIXME("Already ended a page?\n");
return 1; return 1;
} }
if(!PSDRV_WriteEndPage( physDev )) if(!PSDRV_WriteEndPage( dev ))
return 0; return 0;
PSDRV_EmptyDownloadList(physDev, FALSE); PSDRV_EmptyDownloadList(dev, FALSE);
physDev->job.OutOfPage = TRUE; physDev->job.OutOfPage = TRUE;
return 1; return 1;
} }
@ -403,8 +411,9 @@ INT CDECL PSDRV_EndPage( PSDRV_PDEVICE *physDev )
/************************************************************************ /************************************************************************
* PSDRV_StartDocA * PSDRV_StartDocA
*/ */
static INT PSDRV_StartDocA( PSDRV_PDEVICE *physDev, const DOCINFOA *doc ) static INT PSDRV_StartDocA( PHYSDEV dev, const DOCINFOA *doc )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
DOC_INFO_1A di; DOC_INFO_1A di;
TRACE("(%p, %p) => %s, %s, %s\n", physDev, doc, debugstr_a(doc->lpszDocName), TRACE("(%p, %p) => %s, %s, %s\n", physDev, doc, debugstr_a(doc->lpszDocName),
@ -460,13 +469,13 @@ static INT PSDRV_StartDocA( PSDRV_PDEVICE *physDev, const DOCINFOA *doc )
/************************************************************************ /************************************************************************
* PSDRV_StartDoc * PSDRV_StartDoc
*/ */
INT CDECL PSDRV_StartDoc( PSDRV_PDEVICE *physDev, const DOCINFOW *doc ) INT CDECL PSDRV_StartDoc( PHYSDEV dev, const DOCINFOW *doc )
{ {
DOCINFOA docA; DOCINFOA docA;
INT ret, len; INT ret, len;
LPSTR docname = NULL, output = NULL, datatype = NULL; LPSTR docname = NULL, output = NULL, datatype = NULL;
TRACE("(%p, %p) => %d,%s,%s,%s\n", physDev, doc, doc->cbSize, debugstr_w(doc->lpszDocName), TRACE("(%p, %p) => %d,%s,%s,%s\n", dev, doc, doc->cbSize, debugstr_w(doc->lpszDocName),
debugstr_w(doc->lpszOutput), debugstr_w(doc->lpszDatatype)); debugstr_w(doc->lpszOutput), debugstr_w(doc->lpszDatatype));
docA.cbSize = doc->cbSize; docA.cbSize = doc->cbSize;
@ -493,7 +502,7 @@ INT CDECL PSDRV_StartDoc( PSDRV_PDEVICE *physDev, const DOCINFOW *doc )
docA.lpszDatatype = datatype; docA.lpszDatatype = datatype;
docA.fwType = doc->fwType; docA.fwType = doc->fwType;
ret = PSDRV_StartDocA(physDev, &docA); ret = PSDRV_StartDocA(dev, &docA);
HeapFree( GetProcessHeap(), 0, docname ); HeapFree( GetProcessHeap(), 0, docname );
HeapFree( GetProcessHeap(), 0, output ); HeapFree( GetProcessHeap(), 0, output );
@ -505,9 +514,11 @@ INT CDECL PSDRV_StartDoc( PSDRV_PDEVICE *physDev, const DOCINFOW *doc )
/************************************************************************ /************************************************************************
* PSDRV_EndDoc * PSDRV_EndDoc
*/ */
INT CDECL PSDRV_EndDoc( PSDRV_PDEVICE *physDev ) INT CDECL PSDRV_EndDoc( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
INT ret = 1; INT ret = 1;
if(!physDev->job.id) { if(!physDev->job.id) {
FIXME("hJob == 0. Now what?\n"); FIXME("hJob == 0. Now what?\n");
return 0; return 0;
@ -515,9 +526,9 @@ INT CDECL PSDRV_EndDoc( PSDRV_PDEVICE *physDev )
if(!physDev->job.OutOfPage) { if(!physDev->job.OutOfPage) {
WARN("Somebody forgot an EndPage\n"); WARN("Somebody forgot an EndPage\n");
PSDRV_EndPage( physDev ); PSDRV_EndPage( dev );
} }
PSDRV_WriteFooter( physDev ); PSDRV_WriteFooter( dev );
ret = EndDocPrinter(physDev->job.hprinter); ret = EndDocPrinter(physDev->job.hprinter);
ClosePrinter(physDev->job.hprinter); ClosePrinter(physDev->job.hprinter);

View File

@ -36,8 +36,9 @@ WINE_DEFAULT_DEBUG_CHANNEL(psdrv);
/*********************************************************************** /***********************************************************************
* SelectFont (WINEPS.@) * SelectFont (WINEPS.@)
*/ */
HFONT CDECL PSDRV_SelectFont( PSDRV_PDEVICE *physDev, HFONT hfont, HANDLE gdiFont ) HFONT CDECL PSDRV_SelectFont( PHYSDEV dev, HFONT hfont, HANDLE gdiFont )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
LOGFONTW lf; LOGFONTW lf;
BOOL subst = FALSE; BOOL subst = FALSE;
char FaceName[LF_FACESIZE]; char FaceName[LF_FACESIZE];
@ -112,28 +113,30 @@ HFONT CDECL PSDRV_SelectFont( PSDRV_PDEVICE *physDev, HFONT hfont, HANDLE gdiFon
physDev->font.set = FALSE; physDev->font.set = FALSE;
if(gdiFont && !subst) { if(gdiFont && !subst) {
if(PSDRV_SelectDownloadFont(physDev)) if(PSDRV_SelectDownloadFont(dev))
return 0; /* use gdi font */ return 0; /* use gdi font */
} }
PSDRV_SelectBuiltinFont(physDev, hfont, &lf, FaceName); PSDRV_SelectBuiltinFont(dev, hfont, &lf, FaceName);
return (HFONT)1; /* use device font */ return (HFONT)1; /* use device font */
} }
/*********************************************************************** /***********************************************************************
* PSDRV_SetFont * PSDRV_SetFont
*/ */
BOOL PSDRV_SetFont( PSDRV_PDEVICE *physDev ) BOOL PSDRV_SetFont( PHYSDEV dev )
{ {
PSDRV_WriteSetColor(physDev, &physDev->font.color); PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
PSDRV_WriteSetColor(dev, &physDev->font.color);
if(physDev->font.set) return TRUE; if(physDev->font.set) return TRUE;
switch(physDev->font.fontloc) { switch(physDev->font.fontloc) {
case Builtin: case Builtin:
PSDRV_WriteSetBuiltinFont(physDev); PSDRV_WriteSetBuiltinFont(dev);
break; break;
case Download: case Download:
PSDRV_WriteSetDownloadFont(physDev); PSDRV_WriteSetDownloadFont(dev);
break; break;
default: default:
ERR("fontloc = %d\n", physDev->font.fontloc); ERR("fontloc = %d\n", physDev->font.fontloc);

View File

@ -39,7 +39,7 @@ WINE_DEFAULT_DEBUG_CHANNEL(psdrv);
* *
* Performs a world-to-viewport transformation on the specified width. * Performs a world-to-viewport transformation on the specified width.
*/ */
INT PSDRV_XWStoDS( PSDRV_PDEVICE *physDev, INT width ) INT PSDRV_XWStoDS( PHYSDEV dev, INT width )
{ {
POINT pt[2]; POINT pt[2];
@ -47,45 +47,47 @@ INT PSDRV_XWStoDS( PSDRV_PDEVICE *physDev, INT width )
pt[0].y = 0; pt[0].y = 0;
pt[1].x = width; pt[1].x = width;
pt[1].y = 0; pt[1].y = 0;
LPtoDP( physDev->hdc, pt, 2 ); LPtoDP( dev->hdc, pt, 2 );
return pt[1].x - pt[0].x; return pt[1].x - pt[0].x;
} }
/*********************************************************************** /***********************************************************************
* PSDRV_DrawLine * PSDRV_DrawLine
*/ */
static void PSDRV_DrawLine( PSDRV_PDEVICE *physDev ) static void PSDRV_DrawLine( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
if(physDev->pathdepth) if(physDev->pathdepth)
return; return;
if (physDev->pen.style == PS_NULL) if (physDev->pen.style == PS_NULL)
PSDRV_WriteNewPath(physDev); PSDRV_WriteNewPath(dev);
else else
PSDRV_WriteStroke(physDev); PSDRV_WriteStroke(dev);
} }
/*********************************************************************** /***********************************************************************
* PSDRV_LineTo * PSDRV_LineTo
*/ */
BOOL CDECL PSDRV_LineTo(PSDRV_PDEVICE *physDev, INT x, INT y) BOOL CDECL PSDRV_LineTo(PHYSDEV dev, INT x, INT y)
{ {
POINT pt[2]; POINT pt[2];
TRACE("%d %d\n", x, y); TRACE("%d %d\n", x, y);
GetCurrentPositionEx( physDev->hdc, pt ); GetCurrentPositionEx( dev->hdc, pt );
pt[1].x = x; pt[1].x = x;
pt[1].y = y; pt[1].y = y;
LPtoDP( physDev->hdc, pt, 2 ); LPtoDP( dev->hdc, pt, 2 );
PSDRV_SetPen(physDev); PSDRV_SetPen(dev);
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteMoveTo(physDev, pt[0].x, pt[0].y ); PSDRV_WriteMoveTo(dev, pt[0].x, pt[0].y );
PSDRV_WriteLineTo(physDev, pt[1].x, pt[1].y ); PSDRV_WriteLineTo(dev, pt[1].x, pt[1].y );
PSDRV_DrawLine(physDev); PSDRV_DrawLine(dev);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return TRUE; return TRUE;
} }
@ -94,8 +96,9 @@ BOOL CDECL PSDRV_LineTo(PSDRV_PDEVICE *physDev, INT x, INT y)
/*********************************************************************** /***********************************************************************
* PSDRV_Rectangle * PSDRV_Rectangle
*/ */
BOOL CDECL PSDRV_Rectangle( PSDRV_PDEVICE *physDev, INT left, INT top, INT right, INT bottom ) BOOL CDECL PSDRV_Rectangle( PHYSDEV dev, INT left, INT top, INT right, INT bottom )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
RECT rect; RECT rect;
TRACE("%d %d - %d %d\n", left, top, right, bottom); TRACE("%d %d - %d %d\n", left, top, right, bottom);
@ -112,19 +115,19 @@ BOOL CDECL PSDRV_Rectangle( PSDRV_PDEVICE *physDev, INT left, INT top, INT right
if(physDev->job.in_passthrough && !physDev->job.had_passthrough_rect && GetROP2(physDev->hdc) == R2_NOP) { if(physDev->job.in_passthrough && !physDev->job.had_passthrough_rect && GetROP2(physDev->hdc) == R2_NOP) {
char buf[256]; char buf[256];
sprintf(buf, "N %d %d %d %d B\n", rect.right - rect.left, rect.bottom - rect.top, rect.left, rect.top); sprintf(buf, "N %d %d %d %d B\n", rect.right - rect.left, rect.bottom - rect.top, rect.left, rect.top);
write_spool(physDev, buf, strlen(buf)); write_spool(dev, buf, strlen(buf));
physDev->job.had_passthrough_rect = TRUE; physDev->job.had_passthrough_rect = TRUE;
return TRUE; return TRUE;
} }
PSDRV_SetPen(physDev); PSDRV_SetPen(dev);
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteRectangle(physDev, rect.left, rect.top, rect.right - rect.left, PSDRV_WriteRectangle(dev, rect.left, rect.top, rect.right - rect.left,
rect.bottom - rect.top ); rect.bottom - rect.top );
PSDRV_Brush(physDev,0); PSDRV_Brush(dev,0);
PSDRV_DrawLine(physDev); PSDRV_DrawLine(dev);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return TRUE; return TRUE;
} }
@ -132,7 +135,7 @@ BOOL CDECL PSDRV_Rectangle( PSDRV_PDEVICE *physDev, INT left, INT top, INT right
/*********************************************************************** /***********************************************************************
* PSDRV_RoundRect * PSDRV_RoundRect
*/ */
BOOL CDECL PSDRV_RoundRect( PSDRV_PDEVICE *physDev, INT left, INT top, INT right, BOOL CDECL PSDRV_RoundRect( PHYSDEV dev, INT left, INT top, INT right,
INT bottom, INT ell_width, INT ell_height ) INT bottom, INT ell_width, INT ell_height )
{ {
RECT rect[2]; RECT rect[2];
@ -145,7 +148,7 @@ BOOL CDECL PSDRV_RoundRect( PSDRV_PDEVICE *physDev, INT left, INT top, INT right
rect[1].top = 0; rect[1].top = 0;
rect[1].right = ell_width; rect[1].right = ell_width;
rect[1].bottom = ell_height; rect[1].bottom = ell_height;
LPtoDP( physDev->hdc, (POINT *)rect, 4 ); LPtoDP( dev->hdc, (POINT *)rect, 4 );
left = rect[0].left; left = rect[0].left;
top = rect[0].top; top = rect[0].top;
@ -159,27 +162,27 @@ BOOL CDECL PSDRV_RoundRect( PSDRV_PDEVICE *physDev, INT left, INT top, INT right
if (ell_width > right - left) ell_width = right - left; if (ell_width > right - left) ell_width = right - left;
if (ell_height > bottom - top) ell_height = bottom - top; if (ell_height > bottom - top) ell_height = bottom - top;
PSDRV_WriteSpool(physDev, "%RoundRect\n",11); PSDRV_WriteSpool(dev, "%RoundRect\n",11);
PSDRV_SetPen(physDev); PSDRV_SetPen(dev);
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteMoveTo( physDev, left, top + ell_height/2 ); PSDRV_WriteMoveTo( dev, left, top + ell_height/2 );
PSDRV_WriteArc( physDev, left + ell_width/2, top + ell_height/2, ell_width, PSDRV_WriteArc( dev, left + ell_width/2, top + ell_height/2, ell_width,
ell_height, 90.0, 180.0); ell_height, 90.0, 180.0);
PSDRV_WriteLineTo( physDev, right - ell_width/2, top ); PSDRV_WriteLineTo( dev, right - ell_width/2, top );
PSDRV_WriteArc( physDev, right - ell_width/2, top + ell_height/2, ell_width, PSDRV_WriteArc( dev, right - ell_width/2, top + ell_height/2, ell_width,
ell_height, 0.0, 90.0); ell_height, 0.0, 90.0);
PSDRV_WriteLineTo( physDev, right, bottom - ell_height/2 ); PSDRV_WriteLineTo( dev, right, bottom - ell_height/2 );
PSDRV_WriteArc( physDev, right - ell_width/2, bottom - ell_height/2, ell_width, PSDRV_WriteArc( dev, right - ell_width/2, bottom - ell_height/2, ell_width,
ell_height, -90.0, 0.0); ell_height, -90.0, 0.0);
PSDRV_WriteLineTo( physDev, right - ell_width/2, bottom); PSDRV_WriteLineTo( dev, right - ell_width/2, bottom);
PSDRV_WriteArc( physDev, left + ell_width/2, bottom - ell_height/2, ell_width, PSDRV_WriteArc( dev, left + ell_width/2, bottom - ell_height/2, ell_width,
ell_height, 180.0, -90.0); ell_height, 180.0, -90.0);
PSDRV_WriteClosePath( physDev ); PSDRV_WriteClosePath( dev );
PSDRV_Brush(physDev,0); PSDRV_Brush(dev,0);
PSDRV_DrawLine(physDev); PSDRV_DrawLine(dev);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return TRUE; return TRUE;
} }
@ -188,7 +191,7 @@ BOOL CDECL PSDRV_RoundRect( PSDRV_PDEVICE *physDev, INT left, INT top, INT right
* *
* Does the work of Arc, Chord and Pie. lines is 0, 1 or 2 respectively. * Does the work of Arc, Chord and Pie. lines is 0, 1 or 2 respectively.
*/ */
static BOOL PSDRV_DrawArc( PSDRV_PDEVICE *physDev, INT left, INT top, static BOOL PSDRV_DrawArc( PHYSDEV dev, INT left, INT top,
INT right, INT bottom, INT xstart, INT ystart, INT right, INT bottom, INT xstart, INT ystart,
INT xend, INT yend, int lines ) INT xend, INT yend, int lines )
{ {
@ -201,13 +204,13 @@ static BOOL PSDRV_DrawArc( PSDRV_PDEVICE *physDev, INT left, INT top,
rect.top = top; rect.top = top;
rect.right = right; rect.right = right;
rect.bottom = bottom; rect.bottom = bottom;
LPtoDP( physDev->hdc, (POINT *)&rect, 2 ); LPtoDP( dev->hdc, (POINT *)&rect, 2 );
start.x = xstart; start.x = xstart;
start.y = ystart; start.y = ystart;
end.x = xend; end.x = xend;
end.y = yend; end.y = yend;
LPtoDP( physDev->hdc, &start, 1 ); LPtoDP( dev->hdc, &start, 1 );
LPtoDP( physDev->hdc, &end, 1 ); LPtoDP( dev->hdc, &end, 1 );
x = (rect.left + rect.right) / 2; x = (rect.left + rect.right) / 2;
y = (rect.top + rect.bottom) / 2; y = (rect.top + rect.bottom) / 2;
@ -227,22 +230,22 @@ static BOOL PSDRV_DrawArc( PSDRV_PDEVICE *physDev, INT left, INT top,
start_angle *= 180.0 / PI; start_angle *= 180.0 / PI;
end_angle *= 180.0 / PI; end_angle *= 180.0 / PI;
PSDRV_WriteSpool(physDev,"%DrawArc\n", 9); PSDRV_WriteSpool(dev,"%DrawArc\n", 9);
PSDRV_SetPen(physDev); PSDRV_SetPen(dev);
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
if(lines == 2) /* pie */ if(lines == 2) /* pie */
PSDRV_WriteMoveTo(physDev, x, y); PSDRV_WriteMoveTo(dev, x, y);
else else
PSDRV_WriteNewPath( physDev ); PSDRV_WriteNewPath( dev );
PSDRV_WriteArc(physDev, x, y, w, h, start_angle, end_angle); PSDRV_WriteArc(dev, x, y, w, h, start_angle, end_angle);
if(lines == 1 || lines == 2) { /* chord or pie */ if(lines == 1 || lines == 2) { /* chord or pie */
PSDRV_WriteClosePath(physDev); PSDRV_WriteClosePath(dev);
PSDRV_Brush(physDev,0); PSDRV_Brush(dev,0);
} }
PSDRV_DrawLine(physDev); PSDRV_DrawLine(dev);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return TRUE; return TRUE;
} }
@ -251,36 +254,36 @@ static BOOL PSDRV_DrawArc( PSDRV_PDEVICE *physDev, INT left, INT top,
/*********************************************************************** /***********************************************************************
* PSDRV_Arc * PSDRV_Arc
*/ */
BOOL CDECL PSDRV_Arc( PSDRV_PDEVICE *physDev, INT left, INT top, INT right, INT bottom, BOOL CDECL PSDRV_Arc( PHYSDEV dev, INT left, INT top, INT right, INT bottom,
INT xstart, INT ystart, INT xend, INT yend ) INT xstart, INT ystart, INT xend, INT yend )
{ {
return PSDRV_DrawArc( physDev, left, top, right, bottom, xstart, ystart, xend, yend, 0 ); return PSDRV_DrawArc( dev, left, top, right, bottom, xstart, ystart, xend, yend, 0 );
} }
/*********************************************************************** /***********************************************************************
* PSDRV_Chord * PSDRV_Chord
*/ */
BOOL CDECL PSDRV_Chord( PSDRV_PDEVICE *physDev, INT left, INT top, INT right, INT bottom, BOOL CDECL PSDRV_Chord( PHYSDEV dev, INT left, INT top, INT right, INT bottom,
INT xstart, INT ystart, INT xend, INT yend ) INT xstart, INT ystart, INT xend, INT yend )
{ {
return PSDRV_DrawArc( physDev, left, top, right, bottom, xstart, ystart, xend, yend, 1 ); return PSDRV_DrawArc( dev, left, top, right, bottom, xstart, ystart, xend, yend, 1 );
} }
/*********************************************************************** /***********************************************************************
* PSDRV_Pie * PSDRV_Pie
*/ */
BOOL CDECL PSDRV_Pie( PSDRV_PDEVICE *physDev, INT left, INT top, INT right, INT bottom, BOOL CDECL PSDRV_Pie( PHYSDEV dev, INT left, INT top, INT right, INT bottom,
INT xstart, INT ystart, INT xend, INT yend ) INT xstart, INT ystart, INT xend, INT yend )
{ {
return PSDRV_DrawArc( physDev, left, top, right, bottom, xstart, ystart, xend, yend, 2 ); return PSDRV_DrawArc( dev, left, top, right, bottom, xstart, ystart, xend, yend, 2 );
} }
/*********************************************************************** /***********************************************************************
* PSDRV_Ellipse * PSDRV_Ellipse
*/ */
BOOL CDECL PSDRV_Ellipse( PSDRV_PDEVICE *physDev, INT left, INT top, INT right, INT bottom) BOOL CDECL PSDRV_Ellipse( PHYSDEV dev, INT left, INT top, INT right, INT bottom)
{ {
INT x, y, w, h; INT x, y, w, h;
RECT rect; RECT rect;
@ -291,23 +294,23 @@ BOOL CDECL PSDRV_Ellipse( PSDRV_PDEVICE *physDev, INT left, INT top, INT right,
rect.top = top; rect.top = top;
rect.right = right; rect.right = right;
rect.bottom = bottom; rect.bottom = bottom;
LPtoDP( physDev->hdc, (POINT *)&rect, 2 ); LPtoDP( dev->hdc, (POINT *)&rect, 2 );
x = (rect.left + rect.right) / 2; x = (rect.left + rect.right) / 2;
y = (rect.top + rect.bottom) / 2; y = (rect.top + rect.bottom) / 2;
w = rect.right - rect.left; w = rect.right - rect.left;
h = rect.bottom - rect.top; h = rect.bottom - rect.top;
PSDRV_WriteSpool(physDev, "%Ellipse\n", 9); PSDRV_WriteSpool(dev, "%Ellipse\n", 9);
PSDRV_SetPen(physDev); PSDRV_SetPen(dev);
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteNewPath(physDev); PSDRV_WriteNewPath(dev);
PSDRV_WriteArc(physDev, x, y, w, h, 0.0, 360.0); PSDRV_WriteArc(dev, x, y, w, h, 0.0, 360.0);
PSDRV_WriteClosePath(physDev); PSDRV_WriteClosePath(dev);
PSDRV_Brush(physDev,0); PSDRV_Brush(dev,0);
PSDRV_DrawLine(physDev); PSDRV_DrawLine(dev);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return TRUE; return TRUE;
} }
@ -315,7 +318,7 @@ BOOL CDECL PSDRV_Ellipse( PSDRV_PDEVICE *physDev, INT left, INT top, INT right,
/*********************************************************************** /***********************************************************************
* PSDRV_PolyPolyline * PSDRV_PolyPolyline
*/ */
BOOL CDECL PSDRV_PolyPolyline( PSDRV_PDEVICE *physDev, const POINT* pts, const DWORD* counts, BOOL CDECL PSDRV_PolyPolyline( PHYSDEV dev, const POINT* pts, const DWORD* counts,
DWORD polylines ) DWORD polylines )
{ {
DWORD polyline, line, total; DWORD polyline, line, total;
@ -326,24 +329,24 @@ BOOL CDECL PSDRV_PolyPolyline( PSDRV_PDEVICE *physDev, const POINT* pts, const D
for (polyline = total = 0; polyline < polylines; polyline++) total += counts[polyline]; for (polyline = total = 0; polyline < polylines; polyline++) total += counts[polyline];
if (!(dev_pts = HeapAlloc( GetProcessHeap(), 0, total * sizeof(*dev_pts) ))) return FALSE; if (!(dev_pts = HeapAlloc( GetProcessHeap(), 0, total * sizeof(*dev_pts) ))) return FALSE;
memcpy( dev_pts, pts, total * sizeof(*dev_pts) ); memcpy( dev_pts, pts, total * sizeof(*dev_pts) );
LPtoDP( physDev->hdc, dev_pts, total ); LPtoDP( dev->hdc, dev_pts, total );
pt = dev_pts; pt = dev_pts;
PSDRV_WriteSpool(physDev, "%PolyPolyline\n",14); PSDRV_WriteSpool(dev, "%PolyPolyline\n",14);
PSDRV_SetPen(physDev); PSDRV_SetPen(dev);
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
for(polyline = 0; polyline < polylines; polyline++) { for(polyline = 0; polyline < polylines; polyline++) {
PSDRV_WriteMoveTo(physDev, pt->x, pt->y); PSDRV_WriteMoveTo(dev, pt->x, pt->y);
pt++; pt++;
for(line = 1; line < counts[polyline]; line++, pt++) for(line = 1; line < counts[polyline]; line++, pt++)
PSDRV_WriteLineTo(physDev, pt->x, pt->y); PSDRV_WriteLineTo(dev, pt->x, pt->y);
} }
HeapFree( GetProcessHeap(), 0, dev_pts ); HeapFree( GetProcessHeap(), 0, dev_pts );
PSDRV_DrawLine(physDev); PSDRV_DrawLine(dev);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return TRUE; return TRUE;
} }
@ -351,16 +354,16 @@ BOOL CDECL PSDRV_PolyPolyline( PSDRV_PDEVICE *physDev, const POINT* pts, const D
/*********************************************************************** /***********************************************************************
* PSDRV_Polyline * PSDRV_Polyline
*/ */
BOOL CDECL PSDRV_Polyline( PSDRV_PDEVICE *physDev, const POINT* pt, INT count ) BOOL CDECL PSDRV_Polyline( PHYSDEV dev, const POINT* pt, INT count )
{ {
return PSDRV_PolyPolyline( physDev, pt, (LPDWORD) &count, 1 ); return PSDRV_PolyPolyline( dev, pt, (LPDWORD) &count, 1 );
} }
/*********************************************************************** /***********************************************************************
* PSDRV_PolyPolygon * PSDRV_PolyPolygon
*/ */
BOOL CDECL PSDRV_PolyPolygon( PSDRV_PDEVICE *physDev, const POINT* pts, const INT* counts, BOOL CDECL PSDRV_PolyPolygon( PHYSDEV dev, const POINT* pts, const INT* counts,
UINT polygons ) UINT polygons )
{ {
DWORD polygon, total; DWORD polygon, total;
@ -372,31 +375,31 @@ BOOL CDECL PSDRV_PolyPolygon( PSDRV_PDEVICE *physDev, const POINT* pts, const IN
for (polygon = total = 0; polygon < polygons; polygon++) total += counts[polygon]; for (polygon = total = 0; polygon < polygons; polygon++) total += counts[polygon];
if (!(dev_pts = HeapAlloc( GetProcessHeap(), 0, total * sizeof(*dev_pts) ))) return FALSE; if (!(dev_pts = HeapAlloc( GetProcessHeap(), 0, total * sizeof(*dev_pts) ))) return FALSE;
memcpy( dev_pts, pts, total * sizeof(*dev_pts) ); memcpy( dev_pts, pts, total * sizeof(*dev_pts) );
LPtoDP( physDev->hdc, dev_pts, total ); LPtoDP( dev->hdc, dev_pts, total );
pt = dev_pts; pt = dev_pts;
PSDRV_WriteSpool(physDev, "%PolyPolygon\n",13); PSDRV_WriteSpool(dev, "%PolyPolygon\n",13);
PSDRV_SetPen(physDev); PSDRV_SetPen(dev);
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteNewPath(physDev); PSDRV_WriteNewPath(dev);
for(polygon = 0; polygon < polygons; polygon++) { for(polygon = 0; polygon < polygons; polygon++) {
PSDRV_WriteMoveTo(physDev, pt->x, pt->y); PSDRV_WriteMoveTo(dev, pt->x, pt->y);
pt++; pt++;
for(line = 1; line < counts[polygon]; line++, pt++) for(line = 1; line < counts[polygon]; line++, pt++)
PSDRV_WriteLineTo(physDev, pt->x, pt->y); PSDRV_WriteLineTo(dev, pt->x, pt->y);
PSDRV_WriteClosePath(physDev); PSDRV_WriteClosePath(dev);
} }
HeapFree( GetProcessHeap(), 0, dev_pts ); HeapFree( GetProcessHeap(), 0, dev_pts );
if(GetPolyFillMode( physDev->hdc ) == ALTERNATE) if(GetPolyFillMode( dev->hdc ) == ALTERNATE)
PSDRV_Brush(physDev, 1); PSDRV_Brush(dev, 1);
else /* WINDING */ else /* WINDING */
PSDRV_Brush(physDev, 0); PSDRV_Brush(dev, 0);
PSDRV_DrawLine(physDev); PSDRV_DrawLine(dev);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return TRUE; return TRUE;
} }
@ -404,48 +407,47 @@ BOOL CDECL PSDRV_PolyPolygon( PSDRV_PDEVICE *physDev, const POINT* pts, const IN
/*********************************************************************** /***********************************************************************
* PSDRV_Polygon * PSDRV_Polygon
*/ */
BOOL CDECL PSDRV_Polygon( PSDRV_PDEVICE *physDev, const POINT* pt, INT count ) BOOL CDECL PSDRV_Polygon( PHYSDEV dev, const POINT* pt, INT count )
{ {
return PSDRV_PolyPolygon( physDev, pt, &count, 1 ); return PSDRV_PolyPolygon( dev, pt, &count, 1 );
} }
/*********************************************************************** /***********************************************************************
* PSDRV_SetPixel * PSDRV_SetPixel
*/ */
COLORREF CDECL PSDRV_SetPixel( PSDRV_PDEVICE *physDev, INT x, INT y, COLORREF color ) COLORREF CDECL PSDRV_SetPixel( PHYSDEV dev, INT x, INT y, COLORREF color )
{ {
PSCOLOR pscolor; PSCOLOR pscolor;
POINT pt; POINT pt;
pt.x = x; pt.x = x;
pt.y = y; pt.y = y;
LPtoDP( physDev->hdc, &pt, 1 ); LPtoDP( dev->hdc, &pt, 1 );
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
/* we bracket the setcolor in gsave/grestore so that we don't trash /* we bracket the setcolor in gsave/grestore so that we don't trash
the current pen colour */ the current pen colour */
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteRectangle( physDev, pt.x, pt.y, 0, 0 ); PSDRV_WriteRectangle( dev, pt.x, pt.y, 0, 0 );
PSDRV_CreateColor( physDev, &pscolor, color ); PSDRV_CreateColor( dev, &pscolor, color );
PSDRV_WriteSetColor( physDev, &pscolor ); PSDRV_WriteSetColor( dev, &pscolor );
PSDRV_WriteFill( physDev ); PSDRV_WriteFill( dev );
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return color; return color;
} }
/*********************************************************************** /***********************************************************************
* PSDRV_PaintRgn * PSDRV_PaintRgn
*/ */
BOOL CDECL PSDRV_PaintRgn( PSDRV_PDEVICE *physDev, HRGN hrgn ) BOOL CDECL PSDRV_PaintRgn( PHYSDEV dev, HRGN hrgn )
{ {
RGNDATA *rgndata = NULL; RGNDATA *rgndata = NULL;
RECT *pRect; RECT *pRect;
DWORD size, i; DWORD size, i;
TRACE("hdc=%p\n", physDev->hdc); TRACE("hdc=%p\n", dev->hdc);
size = GetRegionData(hrgn, 0, NULL); size = GetRegionData(hrgn, 0, NULL);
rgndata = HeapAlloc( GetProcessHeap(), 0, size ); rgndata = HeapAlloc( GetProcessHeap(), 0, size );
@ -458,15 +460,15 @@ BOOL CDECL PSDRV_PaintRgn( PSDRV_PDEVICE *physDev, HRGN hrgn )
if (rgndata->rdh.nCount == 0) if (rgndata->rdh.nCount == 0)
goto end; goto end;
LPtoDP(physDev->hdc, (POINT*)rgndata->Buffer, rgndata->rdh.nCount * 2); LPtoDP(dev->hdc, (POINT*)rgndata->Buffer, rgndata->rdh.nCount * 2);
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
PSDRV_WriteNewPath(physDev); PSDRV_WriteNewPath(dev);
for(i = 0, pRect = (RECT*)rgndata->Buffer; i < rgndata->rdh.nCount; i++, pRect++) for(i = 0, pRect = (RECT*)rgndata->Buffer; i < rgndata->rdh.nCount; i++, pRect++)
PSDRV_WriteRectangle(physDev, pRect->left, pRect->top, pRect->right - pRect->left, pRect->bottom - pRect->top); PSDRV_WriteRectangle(dev, pRect->left, pRect->top, pRect->right - pRect->left, pRect->bottom - pRect->top);
PSDRV_Brush(physDev, 0); PSDRV_Brush(dev, 0);
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
end: end:
HeapFree(GetProcessHeap(), 0, rgndata); HeapFree(GetProcessHeap(), 0, rgndata);

View File

@ -381,8 +381,10 @@ BOOL CDECL PSDRV_CreateDC( HDC hdc, PSDRV_PDEVICE **pdev, LPCWSTR driver, LPCWST
/********************************************************************** /**********************************************************************
* PSDRV_DeleteDC * PSDRV_DeleteDC
*/ */
BOOL CDECL PSDRV_DeleteDC( PSDRV_PDEVICE *physDev ) BOOL CDECL PSDRV_DeleteDC( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
TRACE("\n"); TRACE("\n");
HeapFree( PSDRV_Heap, 0, physDev->Devmode ); HeapFree( PSDRV_Heap, 0, physDev->Devmode );
@ -396,8 +398,10 @@ BOOL CDECL PSDRV_DeleteDC( PSDRV_PDEVICE *physDev )
/********************************************************************** /**********************************************************************
* ResetDC (WINEPS.@) * ResetDC (WINEPS.@)
*/ */
HDC CDECL PSDRV_ResetDC( PSDRV_PDEVICE *physDev, const DEVMODEW *lpInitData ) HDC CDECL PSDRV_ResetDC( PHYSDEV dev, const DEVMODEW *lpInitData )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
if(lpInitData) { if(lpInitData) {
DEVMODEA *devmodeA = DEVMODEdupWtoA(PSDRV_Heap, lpInitData); DEVMODEA *devmodeA = DEVMODEdupWtoA(PSDRV_Heap, lpInitData);
PSDRV_MergeDevmodes(physDev->Devmode, (PSDRV_DEVMODEA *)devmodeA, physDev->pi); PSDRV_MergeDevmodes(physDev->Devmode, (PSDRV_DEVMODEA *)devmodeA, physDev->pi);
@ -410,8 +414,10 @@ HDC CDECL PSDRV_ResetDC( PSDRV_PDEVICE *physDev, const DEVMODEW *lpInitData )
/*********************************************************************** /***********************************************************************
* GetDeviceCaps (WINEPS.@) * GetDeviceCaps (WINEPS.@)
*/ */
INT CDECL PSDRV_GetDeviceCaps( PSDRV_PDEVICE *physDev, INT cap ) INT CDECL PSDRV_GetDeviceCaps( PHYSDEV dev, INT cap )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
switch(cap) switch(cap)
{ {
case DRIVERVERSION: case DRIVERVERSION:

View File

@ -37,8 +37,9 @@ static const char PEN_alternate[] = "1";
/*********************************************************************** /***********************************************************************
* SelectPen (WINEPS.@) * SelectPen (WINEPS.@)
*/ */
HPEN CDECL PSDRV_SelectPen( PSDRV_PDEVICE *physDev, HPEN hpen ) HPEN CDECL PSDRV_SelectPen( PHYSDEV dev, HPEN hpen )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
LOGPEN logpen; LOGPEN logpen;
if (!GetObjectW( hpen, sizeof(logpen), &logpen )) if (!GetObjectW( hpen, sizeof(logpen), &logpen ))
@ -66,7 +67,7 @@ HPEN CDECL PSDRV_SelectPen( PSDRV_PDEVICE *physDev, HPEN hpen )
physDev->pen.width = logpen.lopnWidth.x; physDev->pen.width = logpen.lopnWidth.x;
if ((logpen.lopnStyle & PS_GEOMETRIC) || (physDev->pen.width > 1)) if ((logpen.lopnStyle & PS_GEOMETRIC) || (physDev->pen.width > 1))
{ {
physDev->pen.width = PSDRV_XWStoDS( physDev, physDev->pen.width ); physDev->pen.width = PSDRV_XWStoDS( dev, physDev->pen.width );
if(physDev->pen.width < 0) physDev->pen.width = -physDev->pen.width; if(physDev->pen.width < 0) physDev->pen.width = -physDev->pen.width;
} }
if (hpen == GetStockObject( DC_PEN )) if (hpen == GetStockObject( DC_PEN ))
@ -88,7 +89,7 @@ HPEN CDECL PSDRV_SelectPen( PSDRV_PDEVICE *physDev, HPEN hpen )
case PS_ENDCAP_FLAT: physDev->pen.endcap = 0; break; case PS_ENDCAP_FLAT: physDev->pen.endcap = 0; break;
} }
PSDRV_CreateColor(physDev, &physDev->pen.color, logpen.lopnColor); PSDRV_CreateColor(dev, &physDev->pen.color, logpen.lopnColor);
physDev->pen.style = logpen.lopnStyle & PS_STYLE_MASK; physDev->pen.style = logpen.lopnStyle & PS_STYLE_MASK;
switch(physDev->pen.style) { switch(physDev->pen.style) {
@ -129,10 +130,12 @@ HPEN CDECL PSDRV_SelectPen( PSDRV_PDEVICE *physDev, HPEN hpen )
/*********************************************************************** /***********************************************************************
* SetDCPenColor (WINEPS.@) * SetDCPenColor (WINEPS.@)
*/ */
COLORREF CDECL PSDRV_SetDCPenColor( PSDRV_PDEVICE *physDev, COLORREF color ) COLORREF CDECL PSDRV_SetDCPenColor( PHYSDEV dev, COLORREF color )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
if (GetCurrentObject( physDev->hdc, OBJ_PEN ) == GetStockObject( DC_PEN )) if (GetCurrentObject( physDev->hdc, OBJ_PEN ) == GetStockObject( DC_PEN ))
PSDRV_CreateColor( physDev, &physDev->pen.color, color ); PSDRV_CreateColor( dev, &physDev->pen.color, color );
return color; return color;
} }
@ -142,13 +145,15 @@ COLORREF CDECL PSDRV_SetDCPenColor( PSDRV_PDEVICE *physDev, COLORREF color )
* PSDRV_SetPen * PSDRV_SetPen
* *
*/ */
BOOL PSDRV_SetPen(PSDRV_PDEVICE *physDev) BOOL PSDRV_SetPen( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
if (physDev->pen.style != PS_NULL) { if (physDev->pen.style != PS_NULL) {
PSDRV_WriteSetColor(physDev, &physDev->pen.color); PSDRV_WriteSetColor(dev, &physDev->pen.color);
if(!physDev->pen.set) { if(!physDev->pen.set) {
PSDRV_WriteSetPen(physDev); PSDRV_WriteSetPen(dev);
physDev->pen.set = TRUE; physDev->pen.set = TRUE;
} }
} }

View File

@ -186,8 +186,9 @@ static const char psarraydef[] =
static const char psenddocument[] = static const char psenddocument[] =
"\n%%EndDocument\n"; "\n%%EndDocument\n";
DWORD PSDRV_WriteSpool(PSDRV_PDEVICE *physDev, LPCSTR lpData, DWORD cch) DWORD PSDRV_WriteSpool(PHYSDEV dev, LPCSTR lpData, DWORD cch)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
int num, num_left = cch; int num, num_left = cch;
if(physDev->job.quiet) { if(physDev->job.quiet) {
@ -196,18 +197,18 @@ DWORD PSDRV_WriteSpool(PSDRV_PDEVICE *physDev, LPCSTR lpData, DWORD cch)
} }
if(physDev->job.in_passthrough) { /* Was in PASSTHROUGH mode */ if(physDev->job.in_passthrough) { /* Was in PASSTHROUGH mode */
write_spool( physDev, psenddocument, sizeof(psenddocument)-1 ); write_spool( dev, psenddocument, sizeof(psenddocument)-1 );
physDev->job.in_passthrough = physDev->job.had_passthrough_rect = FALSE; physDev->job.in_passthrough = physDev->job.had_passthrough_rect = FALSE;
} }
if(physDev->job.OutOfPage) { /* Will get here after NEWFRAME Escape */ if(physDev->job.OutOfPage) { /* Will get here after NEWFRAME Escape */
if( !PSDRV_StartPage(physDev) ) if( !PSDRV_StartPage(dev) )
return 0; return 0;
} }
do { do {
num = min(num_left, 0x8000); num = min(num_left, 0x8000);
if(write_spool( physDev, lpData, num ) != num) if(write_spool( dev, lpData, num ) != num)
return 0; return 0;
lpData += num; lpData += num;
num_left -= num; num_left -= num;
@ -217,16 +218,16 @@ DWORD PSDRV_WriteSpool(PSDRV_PDEVICE *physDev, LPCSTR lpData, DWORD cch)
} }
static INT PSDRV_WriteFeature(PSDRV_PDEVICE *physDev, LPCSTR feature, LPCSTR value, LPCSTR invocation) static INT PSDRV_WriteFeature(PHYSDEV dev, LPCSTR feature, LPCSTR value, LPCSTR invocation)
{ {
char *buf = HeapAlloc( PSDRV_Heap, 0, sizeof(psbeginfeature) + char *buf = HeapAlloc( PSDRV_Heap, 0, sizeof(psbeginfeature) +
strlen(feature) + strlen(value)); strlen(feature) + strlen(value));
sprintf(buf, psbeginfeature, feature, value); sprintf(buf, psbeginfeature, feature, value);
write_spool( physDev, buf, strlen(buf) ); write_spool( dev, buf, strlen(buf) );
write_spool( physDev, invocation, strlen(invocation) ); write_spool( dev, invocation, strlen(invocation) );
write_spool( physDev, psendfeature, strlen(psendfeature) ); write_spool( dev, psendfeature, strlen(psendfeature) );
HeapFree( PSDRV_Heap, 0, buf ); HeapFree( PSDRV_Heap, 0, buf );
return 1; return 1;
@ -288,8 +289,9 @@ static char *escape_title(LPCSTR str)
} }
INT PSDRV_WriteHeader( PSDRV_PDEVICE *physDev, LPCSTR title ) INT PSDRV_WriteHeader( PHYSDEV dev, LPCSTR title )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
char *buf, *escaped_title; char *buf, *escaped_title;
INPUTSLOT *slot; INPUTSLOT *slot;
PAGESIZE *page; PAGESIZE *page;
@ -318,28 +320,28 @@ INT PSDRV_WriteHeader( PSDRV_PDEVICE *physDev, LPCSTR title )
sprintf(buf, psheader, escaped_title, llx, lly, urx, ury); sprintf(buf, psheader, escaped_title, llx, lly, urx, ury);
HeapFree(GetProcessHeap(), 0, escaped_title); HeapFree(GetProcessHeap(), 0, escaped_title);
if( write_spool( physDev, buf, strlen(buf) ) != strlen(buf) ) { if( write_spool( dev, buf, strlen(buf) ) != strlen(buf) ) {
WARN("WriteSpool error\n"); WARN("WriteSpool error\n");
HeapFree( PSDRV_Heap, 0, buf ); HeapFree( PSDRV_Heap, 0, buf );
return 0; return 0;
} }
HeapFree( PSDRV_Heap, 0, buf ); HeapFree( PSDRV_Heap, 0, buf );
write_spool( physDev, psbeginprolog, strlen(psbeginprolog) ); write_spool( dev, psbeginprolog, strlen(psbeginprolog) );
write_spool( physDev, psprolog, strlen(psprolog) ); write_spool( dev, psprolog, strlen(psprolog) );
write_spool( physDev, psendprolog, strlen(psendprolog) ); write_spool( dev, psendprolog, strlen(psendprolog) );
write_spool( physDev, psbeginsetup, strlen(psbeginsetup) ); write_spool( dev, psbeginsetup, strlen(psbeginsetup) );
if(physDev->Devmode->dmPublic.u1.s1.dmCopies > 1) { if(physDev->Devmode->dmPublic.u1.s1.dmCopies > 1) {
char copies_buf[100]; char copies_buf[100];
sprintf(copies_buf, "mark {\n << /NumCopies %d >> setpagedevice\n} stopped cleartomark\n", physDev->Devmode->dmPublic.u1.s1.dmCopies); sprintf(copies_buf, "mark {\n << /NumCopies %d >> setpagedevice\n} stopped cleartomark\n", physDev->Devmode->dmPublic.u1.s1.dmCopies);
write_spool(physDev, copies_buf, strlen(copies_buf)); write_spool(dev, copies_buf, strlen(copies_buf));
} }
for(slot = physDev->pi->ppd->InputSlots; slot; slot = slot->next) { for(slot = physDev->pi->ppd->InputSlots; slot; slot = slot->next) {
if(slot->WinBin == physDev->Devmode->dmPublic.u1.s1.dmDefaultSource) { if(slot->WinBin == physDev->Devmode->dmPublic.u1.s1.dmDefaultSource) {
if(slot->InvocationString) { if(slot->InvocationString) {
PSDRV_WriteFeature(physDev, "*InputSlot", slot->Name, PSDRV_WriteFeature(dev, "*InputSlot", slot->Name,
slot->InvocationString); slot->InvocationString);
break; break;
} }
@ -349,7 +351,7 @@ INT PSDRV_WriteHeader( PSDRV_PDEVICE *physDev, LPCSTR title )
LIST_FOR_EACH_ENTRY(page, &physDev->pi->ppd->PageSizes, PAGESIZE, entry) { LIST_FOR_EACH_ENTRY(page, &physDev->pi->ppd->PageSizes, PAGESIZE, entry) {
if(page->WinPage == physDev->Devmode->dmPublic.u1.s1.dmPaperSize) { if(page->WinPage == physDev->Devmode->dmPublic.u1.s1.dmPaperSize) {
if(page->InvocationString) { if(page->InvocationString) {
PSDRV_WriteFeature(physDev, "*PageSize", page->Name, PSDRV_WriteFeature(dev, "*PageSize", page->Name,
page->InvocationString); page->InvocationString);
break; break;
} }
@ -361,22 +363,23 @@ INT PSDRV_WriteHeader( PSDRV_PDEVICE *physDev, LPCSTR title )
for(duplex = physDev->pi->ppd->Duplexes; duplex; duplex = duplex->next) { for(duplex = physDev->pi->ppd->Duplexes; duplex; duplex = duplex->next) {
if(duplex->WinDuplex == win_duplex) { if(duplex->WinDuplex == win_duplex) {
if(duplex->InvocationString) { if(duplex->InvocationString) {
PSDRV_WriteFeature(physDev, "*Duplex", duplex->Name, PSDRV_WriteFeature(dev, "*Duplex", duplex->Name,
duplex->InvocationString); duplex->InvocationString);
break; break;
} }
} }
} }
write_spool( physDev, psendsetup, strlen(psendsetup) ); write_spool( dev, psendsetup, strlen(psendsetup) );
return 1; return 1;
} }
INT PSDRV_WriteFooter( PSDRV_PDEVICE *physDev ) INT PSDRV_WriteFooter( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
char *buf; char *buf;
buf = HeapAlloc( PSDRV_Heap, 0, sizeof(psfooter) + 100 ); buf = HeapAlloc( PSDRV_Heap, 0, sizeof(psfooter) + 100 );
@ -387,7 +390,7 @@ INT PSDRV_WriteFooter( PSDRV_PDEVICE *physDev )
sprintf(buf, psfooter, physDev->job.PageNo); sprintf(buf, psfooter, physDev->job.PageNo);
if( write_spool( physDev, buf, strlen(buf) ) != strlen(buf) ) { if( write_spool( dev, buf, strlen(buf) ) != strlen(buf) ) {
WARN("WriteSpool error\n"); WARN("WriteSpool error\n");
HeapFree( PSDRV_Heap, 0, buf ); HeapFree( PSDRV_Heap, 0, buf );
return 0; return 0;
@ -398,9 +401,9 @@ INT PSDRV_WriteFooter( PSDRV_PDEVICE *physDev )
INT PSDRV_WriteEndPage( PSDRV_PDEVICE *physDev ) INT PSDRV_WriteEndPage( PHYSDEV dev )
{ {
if( write_spool( physDev, psendpage, sizeof(psendpage)-1 ) != sizeof(psendpage)-1 ) { if( write_spool( dev, psendpage, sizeof(psendpage)-1 ) != sizeof(psendpage)-1 ) {
WARN("WriteSpool error\n"); WARN("WriteSpool error\n");
return 0; return 0;
} }
@ -410,8 +413,9 @@ INT PSDRV_WriteEndPage( PSDRV_PDEVICE *physDev )
INT PSDRV_WriteNewPage( PSDRV_PDEVICE *physDev ) INT PSDRV_WriteNewPage( PHYSDEV dev )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
char *buf; char *buf;
char name[100]; char name[100];
signed int xtrans, ytrans, rotation; signed int xtrans, ytrans, rotation;
@ -444,7 +448,7 @@ INT PSDRV_WriteNewPage( PSDRV_PDEVICE *physDev )
physDev->logPixelsX, physDev->logPixelsY, physDev->logPixelsX, physDev->logPixelsY,
xtrans, ytrans, rotation); xtrans, ytrans, rotation);
if( write_spool( physDev, buf, strlen(buf) ) != strlen(buf) ) { if( write_spool( dev, buf, strlen(buf) ) != strlen(buf) ) {
WARN("WriteSpool error\n"); WARN("WriteSpool error\n");
HeapFree( PSDRV_Heap, 0, buf ); HeapFree( PSDRV_Heap, 0, buf );
return 0; return 0;
@ -454,40 +458,40 @@ INT PSDRV_WriteNewPage( PSDRV_PDEVICE *physDev )
} }
BOOL PSDRV_WriteMoveTo(PSDRV_PDEVICE *physDev, INT x, INT y) BOOL PSDRV_WriteMoveTo(PHYSDEV dev, INT x, INT y)
{ {
char buf[100]; char buf[100];
sprintf(buf, psmoveto, x, y); sprintf(buf, psmoveto, x, y);
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
BOOL PSDRV_WriteLineTo(PSDRV_PDEVICE *physDev, INT x, INT y) BOOL PSDRV_WriteLineTo(PHYSDEV dev, INT x, INT y)
{ {
char buf[100]; char buf[100];
sprintf(buf, pslineto, x, y); sprintf(buf, pslineto, x, y);
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
BOOL PSDRV_WriteStroke(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteStroke(PHYSDEV dev)
{ {
return PSDRV_WriteSpool(physDev, psstroke, sizeof(psstroke)-1); return PSDRV_WriteSpool(dev, psstroke, sizeof(psstroke)-1);
} }
BOOL PSDRV_WriteRectangle(PSDRV_PDEVICE *physDev, INT x, INT y, INT width, BOOL PSDRV_WriteRectangle(PHYSDEV dev, INT x, INT y, INT width,
INT height) INT height)
{ {
char buf[100]; char buf[100];
sprintf(buf, psrectangle, x, y, width, height, -width); sprintf(buf, psrectangle, x, y, width, height, -width);
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
BOOL PSDRV_WriteArc(PSDRV_PDEVICE *physDev, INT x, INT y, INT w, INT h, double ang1, BOOL PSDRV_WriteArc(PHYSDEV dev, INT x, INT y, INT w, INT h, double ang1,
double ang2) double ang2)
{ {
char buf[256]; char buf[256];
@ -497,11 +501,11 @@ BOOL PSDRV_WriteArc(PSDRV_PDEVICE *physDev, INT x, INT y, INT w, INT h, double a
push_lc_numeric("C"); push_lc_numeric("C");
sprintf(buf, psarc, x, y, w, h, -ang2, -ang1); sprintf(buf, psarc, x, y, w, h, -ang2, -ang1);
pop_lc_numeric(); pop_lc_numeric();
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
BOOL PSDRV_WriteSetFont(PSDRV_PDEVICE *physDev, const char *name, matrix size, INT escapement) BOOL PSDRV_WriteSetFont(PHYSDEV dev, const char *name, matrix size, INT escapement)
{ {
char *buf; char *buf;
@ -515,13 +519,14 @@ BOOL PSDRV_WriteSetFont(PSDRV_PDEVICE *physDev, const char *name, matrix size, I
sprintf(buf, pssetfont, name, size.xx, size.xy, size.yx, size.yy, -escapement); sprintf(buf, pssetfont, name, size.xx, size.xy, size.yx, size.yy, -escapement);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
HeapFree(PSDRV_Heap, 0, buf); HeapFree(PSDRV_Heap, 0, buf);
return TRUE; return TRUE;
} }
BOOL PSDRV_WriteSetColor(PSDRV_PDEVICE *physDev, PSCOLOR *color) BOOL PSDRV_WriteSetColor(PHYSDEV dev, PSCOLOR *color)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
char buf[256]; char buf[256];
PSDRV_CopyColor(&physDev->inkColor, color); PSDRV_CopyColor(&physDev->inkColor, color);
@ -531,13 +536,13 @@ BOOL PSDRV_WriteSetColor(PSDRV_PDEVICE *physDev, PSCOLOR *color)
sprintf(buf, pssetrgbcolor, color->value.rgb.r, color->value.rgb.g, sprintf(buf, pssetrgbcolor, color->value.rgb.r, color->value.rgb.g,
color->value.rgb.b); color->value.rgb.b);
pop_lc_numeric(); pop_lc_numeric();
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
case PSCOLOR_GRAY: case PSCOLOR_GRAY:
push_lc_numeric("C"); push_lc_numeric("C");
sprintf(buf, pssetgray, color->value.gray.i); sprintf(buf, pssetgray, color->value.gray.i);
pop_lc_numeric(); pop_lc_numeric();
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
default: default:
ERR("Unkonwn colour type %d\n", color->type); ERR("Unkonwn colour type %d\n", color->type);
@ -547,12 +552,13 @@ BOOL PSDRV_WriteSetColor(PSDRV_PDEVICE *physDev, PSCOLOR *color)
return FALSE; return FALSE;
} }
BOOL PSDRV_WriteSetPen(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteSetPen(PHYSDEV dev)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
char buf[256]; char buf[256];
sprintf(buf, pssetline, physDev->pen.width, physDev->pen.join, physDev->pen.endcap); sprintf(buf, pssetline, physDev->pen.width, physDev->pen.join, physDev->pen.endcap);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
if(physDev->pen.dash) { if(physDev->pen.dash) {
sprintf(buf, pssetdash, physDev->pen.dash, 0); sprintf(buf, pssetdash, physDev->pen.dash, 0);
@ -560,12 +566,12 @@ BOOL PSDRV_WriteSetPen(PSDRV_PDEVICE *physDev)
else else
sprintf(buf, pssetdash, "", 0); sprintf(buf, pssetdash, "", 0);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
return TRUE; return TRUE;
} }
BOOL PSDRV_WriteGlyphShow(PSDRV_PDEVICE *physDev, LPCSTR g_name) BOOL PSDRV_WriteGlyphShow(PHYSDEV dev, LPCSTR g_name)
{ {
char buf[128]; char buf[128];
int l; int l;
@ -577,79 +583,79 @@ BOOL PSDRV_WriteGlyphShow(PSDRV_PDEVICE *physDev, LPCSTR g_name)
return FALSE; return FALSE;
} }
PSDRV_WriteSpool(physDev, buf, l); PSDRV_WriteSpool(dev, buf, l);
return TRUE; return TRUE;
} }
BOOL PSDRV_WriteFill(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteFill(PHYSDEV dev)
{ {
return PSDRV_WriteSpool(physDev, psfill, sizeof(psfill)-1); return PSDRV_WriteSpool(dev, psfill, sizeof(psfill)-1);
} }
BOOL PSDRV_WriteEOFill(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteEOFill(PHYSDEV dev)
{ {
return PSDRV_WriteSpool(physDev, pseofill, sizeof(pseofill)-1); return PSDRV_WriteSpool(dev, pseofill, sizeof(pseofill)-1);
} }
BOOL PSDRV_WriteGSave(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteGSave(PHYSDEV dev)
{ {
return PSDRV_WriteSpool(physDev, psgsave, sizeof(psgsave)-1); return PSDRV_WriteSpool(dev, psgsave, sizeof(psgsave)-1);
} }
BOOL PSDRV_WriteGRestore(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteGRestore(PHYSDEV dev)
{ {
return PSDRV_WriteSpool(physDev, psgrestore, sizeof(psgrestore)-1); return PSDRV_WriteSpool(dev, psgrestore, sizeof(psgrestore)-1);
} }
BOOL PSDRV_WriteNewPath(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteNewPath(PHYSDEV dev)
{ {
return PSDRV_WriteSpool(physDev, psnewpath, sizeof(psnewpath)-1); return PSDRV_WriteSpool(dev, psnewpath, sizeof(psnewpath)-1);
} }
BOOL PSDRV_WriteClosePath(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteClosePath(PHYSDEV dev)
{ {
return PSDRV_WriteSpool(physDev, psclosepath, sizeof(psclosepath)-1); return PSDRV_WriteSpool(dev, psclosepath, sizeof(psclosepath)-1);
} }
BOOL PSDRV_WriteClip(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteClip(PHYSDEV dev)
{ {
return PSDRV_WriteSpool(physDev, psclip, sizeof(psclip)-1); return PSDRV_WriteSpool(dev, psclip, sizeof(psclip)-1);
} }
BOOL PSDRV_WriteEOClip(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteEOClip(PHYSDEV dev)
{ {
return PSDRV_WriteSpool(physDev, pseoclip, sizeof(pseoclip)-1); return PSDRV_WriteSpool(dev, pseoclip, sizeof(pseoclip)-1);
} }
BOOL PSDRV_WriteHatch(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteHatch(PHYSDEV dev)
{ {
return PSDRV_WriteSpool(physDev, pshatch, sizeof(pshatch)-1); return PSDRV_WriteSpool(dev, pshatch, sizeof(pshatch)-1);
} }
BOOL PSDRV_WriteRotate(PSDRV_PDEVICE *physDev, float ang) BOOL PSDRV_WriteRotate(PHYSDEV dev, float ang)
{ {
char buf[256]; char buf[256];
push_lc_numeric("C"); push_lc_numeric("C");
sprintf(buf, psrotate, ang); sprintf(buf, psrotate, ang);
pop_lc_numeric(); pop_lc_numeric();
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
BOOL PSDRV_WriteIndexColorSpaceBegin(PSDRV_PDEVICE *physDev, int size) BOOL PSDRV_WriteIndexColorSpaceBegin(PHYSDEV dev, int size)
{ {
char buf[256]; char buf[256];
sprintf(buf, "[/Indexed /DeviceRGB %d\n<\n", size); sprintf(buf, "[/Indexed /DeviceRGB %d\n<\n", size);
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
BOOL PSDRV_WriteIndexColorSpaceEnd(PSDRV_PDEVICE *physDev) BOOL PSDRV_WriteIndexColorSpaceEnd(PHYSDEV dev)
{ {
static const char buf[] = ">\n] setcolorspace\n"; static const char buf[] = ">\n] setcolorspace\n";
return PSDRV_WriteSpool(physDev, buf, sizeof(buf) - 1); return PSDRV_WriteSpool(dev, buf, sizeof(buf) - 1);
} }
BOOL PSDRV_WriteRGB(PSDRV_PDEVICE *physDev, COLORREF *map, int number) BOOL PSDRV_WriteRGB(PHYSDEV dev, COLORREF *map, int number)
{ {
char *buf = HeapAlloc(PSDRV_Heap, 0, number * 7 + 1), *ptr; char *buf = HeapAlloc(PSDRV_Heap, 0, number * 7 + 1), *ptr;
int i; int i;
@ -661,12 +667,12 @@ BOOL PSDRV_WriteRGB(PSDRV_PDEVICE *physDev, COLORREF *map, int number)
((i & 0x7) == 0x7) || (i == number - 1) ? '\n' : ' '); ((i & 0x7) == 0x7) || (i == number - 1) ? '\n' : ' ');
ptr += 7; ptr += 7;
} }
PSDRV_WriteSpool(physDev, buf, number * 7); PSDRV_WriteSpool(dev, buf, number * 7);
HeapFree(PSDRV_Heap, 0, buf); HeapFree(PSDRV_Heap, 0, buf);
return TRUE; return TRUE;
} }
static BOOL PSDRV_WriteImageDict(PSDRV_PDEVICE *physDev, WORD depth, static BOOL PSDRV_WriteImageDict(PHYSDEV dev, WORD depth,
INT widthSrc, INT heightSrc, char *bits) INT widthSrc, INT heightSrc, char *bits)
{ {
static const char start[] = "<<\n" static const char start[] = "<<\n"
@ -684,7 +690,7 @@ static BOOL PSDRV_WriteImageDict(PSDRV_PDEVICE *physDev, WORD depth,
sprintf(buf, start, widthSrc, heightSrc, sprintf(buf, start, widthSrc, heightSrc,
(depth < 8) ? depth : 8, widthSrc, -heightSrc, heightSrc); (depth < 8) ? depth : 8, widthSrc, -heightSrc, heightSrc);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
switch(depth) { switch(depth) {
case 8: case 8:
@ -704,20 +710,20 @@ static BOOL PSDRV_WriteImageDict(PSDRV_PDEVICE *physDev, WORD depth,
break; break;
} }
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
if(!bits) { if(!bits) {
PSDRV_WriteSpool(physDev, end, sizeof(end) - 1); PSDRV_WriteSpool(dev, end, sizeof(end) - 1);
} else { } else {
sprintf(buf, endbits, bits); sprintf(buf, endbits, bits);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
HeapFree(PSDRV_Heap, 0, buf); HeapFree(PSDRV_Heap, 0, buf);
return TRUE; return TRUE;
} }
BOOL PSDRV_WriteImage(PSDRV_PDEVICE *physDev, WORD depth, INT xDst, INT yDst, BOOL PSDRV_WriteImage(PHYSDEV dev, WORD depth, INT xDst, INT yDst,
INT widthDst, INT heightDst, INT widthSrc, INT widthDst, INT heightDst, INT widthSrc,
INT heightSrc, BOOL mask) INT heightSrc, BOOL mask)
{ {
@ -727,17 +733,17 @@ BOOL PSDRV_WriteImage(PSDRV_PDEVICE *physDev, WORD depth, INT xDst, INT yDst,
char buf[100]; char buf[100];
sprintf(buf, start, xDst, yDst, widthDst, heightDst); sprintf(buf, start, xDst, yDst, widthDst, heightDst);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
PSDRV_WriteImageDict(physDev, depth, widthSrc, heightSrc, NULL); PSDRV_WriteImageDict(dev, depth, widthSrc, heightSrc, NULL);
if(mask) if(mask)
PSDRV_WriteSpool(physDev, imagemask, sizeof(imagemask) - 1); PSDRV_WriteSpool(dev, imagemask, sizeof(imagemask) - 1);
else else
PSDRV_WriteSpool(physDev, image, sizeof(image) - 1); PSDRV_WriteSpool(dev, image, sizeof(image) - 1);
return TRUE; return TRUE;
} }
BOOL PSDRV_WriteBytes(PSDRV_PDEVICE *physDev, const BYTE *bytes, DWORD number) BOOL PSDRV_WriteBytes(PHYSDEV dev, const BYTE *bytes, DWORD number)
{ {
char *buf = HeapAlloc(PSDRV_Heap, 0, number * 3 + 1); char *buf = HeapAlloc(PSDRV_Heap, 0, number * 3 + 1);
char *ptr; char *ptr;
@ -753,19 +759,19 @@ BOOL PSDRV_WriteBytes(PSDRV_PDEVICE *physDev, const BYTE *bytes, DWORD number)
ptr++; ptr++;
} }
} }
PSDRV_WriteSpool(physDev, buf, ptr - buf); PSDRV_WriteSpool(dev, buf, ptr - buf);
HeapFree(PSDRV_Heap, 0, buf); HeapFree(PSDRV_Heap, 0, buf);
return TRUE; return TRUE;
} }
BOOL PSDRV_WriteData(PSDRV_PDEVICE *physDev, const BYTE *data, DWORD number) BOOL PSDRV_WriteData(PHYSDEV dev, const BYTE *data, DWORD number)
{ {
int num, num_left = number; int num, num_left = number;
do { do {
num = min(num_left, 60); num = min(num_left, 60);
PSDRV_WriteSpool(physDev, (LPCSTR)data, num); PSDRV_WriteSpool(dev, (LPCSTR)data, num);
PSDRV_WriteSpool(physDev, "\n", 1); PSDRV_WriteSpool(dev, "\n", 1);
data += num; data += num;
num_left -= num; num_left -= num;
} while(num_left); } while(num_left);
@ -773,45 +779,46 @@ BOOL PSDRV_WriteData(PSDRV_PDEVICE *physDev, const BYTE *data, DWORD number)
return TRUE; return TRUE;
} }
BOOL PSDRV_WriteArrayPut(PSDRV_PDEVICE *physDev, CHAR *pszArrayName, INT nIndex, LONG lObject) BOOL PSDRV_WriteArrayPut(PHYSDEV dev, CHAR *pszArrayName, INT nIndex, LONG lObject)
{ {
char buf[100]; char buf[100];
sprintf(buf, psarrayput, pszArrayName, nIndex, lObject); sprintf(buf, psarrayput, pszArrayName, nIndex, lObject);
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
BOOL PSDRV_WriteArrayDef(PSDRV_PDEVICE *physDev, CHAR *pszArrayName, INT nSize) BOOL PSDRV_WriteArrayDef(PHYSDEV dev, CHAR *pszArrayName, INT nSize)
{ {
char buf[100]; char buf[100];
sprintf(buf, psarraydef, pszArrayName, nSize); sprintf(buf, psarraydef, pszArrayName, nSize);
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
BOOL PSDRV_WriteRectClip(PSDRV_PDEVICE *physDev, INT x, INT y, INT w, INT h) BOOL PSDRV_WriteRectClip(PHYSDEV dev, INT x, INT y, INT w, INT h)
{ {
char buf[100]; char buf[100];
sprintf(buf, psrectclip, x, y, w, h); sprintf(buf, psrectclip, x, y, w, h);
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
BOOL PSDRV_WriteRectClip2(PSDRV_PDEVICE *physDev, CHAR *pszArrayName) BOOL PSDRV_WriteRectClip2(PHYSDEV dev, CHAR *pszArrayName)
{ {
char buf[100]; char buf[100];
sprintf(buf, psrectclip2, pszArrayName); sprintf(buf, psrectclip2, pszArrayName);
return PSDRV_WriteSpool(physDev, buf, strlen(buf)); return PSDRV_WriteSpool(dev, buf, strlen(buf));
} }
BOOL PSDRV_WritePatternDict(PSDRV_PDEVICE *physDev, BITMAP *bm, BYTE *bits) BOOL PSDRV_WritePatternDict(PHYSDEV dev, BITMAP *bm, BYTE *bits)
{ {
static const char mypat[] = "/mypat\n"; static const char mypat[] = "/mypat\n";
static const char do_pattern[] = "<<\n /PaintType 1\n /PatternType 1\n /TilingType 1\n " static const char do_pattern[] = "<<\n /PaintType 1\n /PatternType 1\n /TilingType 1\n "
"/BBox [0 0 %d %d]\n /XStep %d\n /YStep %d\n /PaintProc {\n begin\n 0 0 translate\n" "/BBox [0 0 %d %d]\n /XStep %d\n /YStep %d\n /PaintProc {\n begin\n 0 0 translate\n"
" %d %d scale\n mypat image\n end\n }\n>>\n matrix makepattern setpattern\n"; " %d %d scale\n mypat image\n end\n }\n>>\n matrix makepattern setpattern\n";
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
char *buf, *ptr; char *buf, *ptr;
INT w, h, x, y, w_mult, h_mult; INT w, h, x, y, w_mult, h_mult;
COLORREF map[2]; COLORREF map[2];
@ -827,32 +834,33 @@ BOOL PSDRV_WritePatternDict(PSDRV_PDEVICE *physDev, BITMAP *bm, BYTE *bits)
ptr += 2; ptr += 2;
} }
} }
PSDRV_WriteSpool(physDev, mypat, sizeof(mypat) - 1); PSDRV_WriteSpool(dev, mypat, sizeof(mypat) - 1);
PSDRV_WriteImageDict(physDev, 1, 8, 8, buf); PSDRV_WriteImageDict(dev, 1, 8, 8, buf);
PSDRV_WriteSpool(physDev, "def\n", 4); PSDRV_WriteSpool(dev, "def\n", 4);
PSDRV_WriteIndexColorSpaceBegin(physDev, 1); PSDRV_WriteIndexColorSpaceBegin(dev, 1);
map[0] = GetTextColor( physDev->hdc ); map[0] = GetTextColor( physDev->hdc );
map[1] = GetBkColor( physDev->hdc ); map[1] = GetBkColor( physDev->hdc );
PSDRV_WriteRGB(physDev, map, 2); PSDRV_WriteRGB(dev, map, 2);
PSDRV_WriteIndexColorSpaceEnd(physDev); PSDRV_WriteIndexColorSpaceEnd(dev);
/* Windows seems to scale patterns so that a one pixel corresponds to 1/300" */ /* Windows seems to scale patterns so that a one pixel corresponds to 1/300" */
w_mult = (physDev->logPixelsX + 150) / 300; w_mult = (physDev->logPixelsX + 150) / 300;
h_mult = (physDev->logPixelsY + 150) / 300; h_mult = (physDev->logPixelsY + 150) / 300;
sprintf(buf, do_pattern, w * w_mult, h * h_mult, w * w_mult, h * h_mult, w * w_mult, h * h_mult); sprintf(buf, do_pattern, w * w_mult, h * h_mult, w * w_mult, h * h_mult, w * w_mult, h * h_mult);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
HeapFree(PSDRV_Heap, 0, buf); HeapFree(PSDRV_Heap, 0, buf);
return TRUE; return TRUE;
} }
BOOL PSDRV_WriteDIBPatternDict(PSDRV_PDEVICE *physDev, BITMAPINFO *bmi, UINT usage) BOOL PSDRV_WriteDIBPatternDict(PHYSDEV dev, BITMAPINFO *bmi, UINT usage)
{ {
static const char mypat[] = "/mypat\n"; static const char mypat[] = "/mypat\n";
static const char do_pattern[] = "<<\n /PaintType 1\n /PatternType 1\n /TilingType 1\n " static const char do_pattern[] = "<<\n /PaintType 1\n /PatternType 1\n /TilingType 1\n "
"/BBox [0 0 %d %d]\n /XStep %d\n /YStep %d\n /PaintProc {\n begin\n 0 0 translate\n" "/BBox [0 0 %d %d]\n /XStep %d\n /YStep %d\n /PaintProc {\n begin\n 0 0 translate\n"
" %d %d scale\n mypat image\n end\n }\n>>\n matrix makepattern setpattern\n"; " %d %d scale\n mypat image\n end\n }\n>>\n matrix makepattern setpattern\n";
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
char *buf, *ptr; char *buf, *ptr;
BYTE *bits; BYTE *bits;
INT w, h, x, y, colours, w_mult, h_mult; INT w, h, x, y, colours, w_mult, h_mult;
@ -883,21 +891,21 @@ BOOL PSDRV_WriteDIBPatternDict(PSDRV_PDEVICE *physDev, BITMAPINFO *bmi, UINT usa
ptr += 2; ptr += 2;
} }
} }
PSDRV_WriteSpool(physDev, mypat, sizeof(mypat) - 1); PSDRV_WriteSpool(dev, mypat, sizeof(mypat) - 1);
PSDRV_WriteImageDict(physDev, 1, 8, 8, buf); PSDRV_WriteImageDict(dev, 1, 8, 8, buf);
PSDRV_WriteSpool(physDev, "def\n", 4); PSDRV_WriteSpool(dev, "def\n", 4);
PSDRV_WriteIndexColorSpaceBegin(physDev, 1); PSDRV_WriteIndexColorSpaceBegin(dev, 1);
map[0] = GetTextColor( physDev->hdc ); map[0] = GetTextColor( dev->hdc );
map[1] = GetBkColor( physDev->hdc ); map[1] = GetBkColor( dev->hdc );
PSDRV_WriteRGB(physDev, map, 2); PSDRV_WriteRGB(dev, map, 2);
PSDRV_WriteIndexColorSpaceEnd(physDev); PSDRV_WriteIndexColorSpaceEnd(dev);
/* Windows seems to scale patterns so that a one pixel corresponds to 1/300" */ /* Windows seems to scale patterns so that a one pixel corresponds to 1/300" */
w_mult = (physDev->logPixelsX + 150) / 300; w_mult = (physDev->logPixelsX + 150) / 300;
h_mult = (physDev->logPixelsY + 150) / 300; h_mult = (physDev->logPixelsY + 150) / 300;
sprintf(buf, do_pattern, w * w_mult, h * h_mult, w * w_mult, h * h_mult, w * w_mult, h * h_mult); sprintf(buf, do_pattern, w * w_mult, h * h_mult, w * w_mult, h * h_mult, w * w_mult, h * h_mult);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
HeapFree(PSDRV_Heap, 0, buf); HeapFree(PSDRV_Heap, 0, buf);
return TRUE; return TRUE;
} }

View File

@ -386,6 +386,10 @@ typedef struct {
PSDRV_DEVMODEA *dlgdm; PSDRV_DEVMODEA *dlgdm;
} PSDRV_DLGINFO; } PSDRV_DLGINFO;
static inline PSDRV_PDEVICE *get_psdrv_dev( PHYSDEV dev )
{
return (PSDRV_PDEVICE *)dev;
}
/* /*
* Every glyph name in the Adobe Glyph List and the 35 core PostScript fonts * Every glyph name in the Adobe Glyph List and the 35 core PostScript fonts
@ -419,66 +423,63 @@ extern BOOL PSDRV_AddAFMtoList(FONTFAMILY **head, const AFM *afm,
BOOL *p_added) DECLSPEC_HIDDEN; BOOL *p_added) DECLSPEC_HIDDEN;
extern void PSDRV_FreeAFMList( FONTFAMILY *head ) DECLSPEC_HIDDEN; extern void PSDRV_FreeAFMList( FONTFAMILY *head ) DECLSPEC_HIDDEN;
extern INT PSDRV_XWStoDS( PSDRV_PDEVICE *physDev, INT width ) DECLSPEC_HIDDEN; extern INT PSDRV_XWStoDS( PHYSDEV dev, INT width ) DECLSPEC_HIDDEN;
extern BOOL PSDRV_Brush(PSDRV_PDEVICE *physDev, BOOL EO) DECLSPEC_HIDDEN; extern BOOL PSDRV_Brush(PHYSDEV dev, BOOL EO) DECLSPEC_HIDDEN;
extern BOOL PSDRV_SetFont( PSDRV_PDEVICE *physDev ) DECLSPEC_HIDDEN; extern BOOL PSDRV_SetFont( PHYSDEV dev ) DECLSPEC_HIDDEN;
extern BOOL PSDRV_SetPen( PSDRV_PDEVICE *physDev ) DECLSPEC_HIDDEN; extern BOOL PSDRV_SetPen( PHYSDEV dev ) DECLSPEC_HIDDEN;
extern void PSDRV_SetClip(PSDRV_PDEVICE* phyDev) DECLSPEC_HIDDEN; extern void PSDRV_SetClip( PHYSDEV dev ) DECLSPEC_HIDDEN;
extern void PSDRV_ResetClip(PSDRV_PDEVICE* phyDev) DECLSPEC_HIDDEN; extern void PSDRV_ResetClip( PHYSDEV dev ) DECLSPEC_HIDDEN;
extern BOOL PSDRV_CopyColor(PSCOLOR *col1, PSCOLOR *col2) DECLSPEC_HIDDEN; extern BOOL PSDRV_CopyColor(PSCOLOR *col1, PSCOLOR *col2) DECLSPEC_HIDDEN;
extern void PSDRV_CreateColor( PSDRV_PDEVICE *physDev, PSCOLOR *pscolor, extern void PSDRV_CreateColor( PHYSDEV dev, PSCOLOR *pscolor,
COLORREF wincolor ) DECLSPEC_HIDDEN; COLORREF wincolor ) DECLSPEC_HIDDEN;
extern char PSDRV_UnicodeToANSI(int u) DECLSPEC_HIDDEN; extern char PSDRV_UnicodeToANSI(int u) DECLSPEC_HIDDEN;
extern INT PSDRV_WriteHeader( PSDRV_PDEVICE *physDev, LPCSTR title ) DECLSPEC_HIDDEN; extern INT PSDRV_WriteHeader( PHYSDEV dev, LPCSTR title ) DECLSPEC_HIDDEN;
extern INT PSDRV_WriteFooter( PSDRV_PDEVICE *physDev ) DECLSPEC_HIDDEN; extern INT PSDRV_WriteFooter( PHYSDEV dev ) DECLSPEC_HIDDEN;
extern INT PSDRV_WriteNewPage( PSDRV_PDEVICE *physDev ) DECLSPEC_HIDDEN; extern INT PSDRV_WriteNewPage( PHYSDEV dev ) DECLSPEC_HIDDEN;
extern INT PSDRV_WriteEndPage( PSDRV_PDEVICE *physDev ) DECLSPEC_HIDDEN; extern INT PSDRV_WriteEndPage( PHYSDEV dev ) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteMoveTo(PSDRV_PDEVICE *physDev, INT x, INT y) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteMoveTo(PHYSDEV dev, INT x, INT y) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteLineTo(PSDRV_PDEVICE *physDev, INT x, INT y) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteLineTo(PHYSDEV dev, INT x, INT y) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteStroke(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteStroke(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteRectangle(PSDRV_PDEVICE *physDev, INT x, INT y, INT width, extern BOOL PSDRV_WriteRectangle(PHYSDEV dev, INT x, INT y, INT width, INT height) DECLSPEC_HIDDEN;
INT height) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteRRectangle(PHYSDEV dev, INT x, INT y, INT width, INT height) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteRRectangle(PSDRV_PDEVICE *physDev, INT x, INT y, INT width, extern BOOL PSDRV_WriteSetFont(PHYSDEV dev, const char *name, matrix size, INT escapement) DECLSPEC_HIDDEN;
INT height) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteGlyphShow(PHYSDEV dev, LPCSTR g_name) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteSetFont(PSDRV_PDEVICE *physDev, const char *name, matrix size, extern BOOL PSDRV_WriteSetPen(PHYSDEV dev) DECLSPEC_HIDDEN;
INT escapement) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteArc(PHYSDEV dev, INT x, INT y, INT w, INT h,
extern BOOL PSDRV_WriteGlyphShow(PSDRV_PDEVICE *physDev, LPCSTR g_name) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteSetPen(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteArc(PSDRV_PDEVICE *physDev, INT x, INT y, INT w, INT h,
double ang1, double ang2) DECLSPEC_HIDDEN; double ang1, double ang2) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteSetColor(PSDRV_PDEVICE *physDev, PSCOLOR *color) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteSetColor(PHYSDEV dev, PSCOLOR *color) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteSetBrush(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteSetBrush(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteFill(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteFill(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteEOFill(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteEOFill(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteGSave(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteGSave(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteGRestore(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteGRestore(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteNewPath(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteNewPath(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteClosePath(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteClosePath(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteClip(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteClip(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteRectClip(PSDRV_PDEVICE *physDev, INT x, INT y, INT w, INT h) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteRectClip(PHYSDEV dev, INT x, INT y, INT w, INT h) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteRectClip2(PSDRV_PDEVICE *physDev, CHAR *pszArrayName) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteRectClip2(PHYSDEV dev, CHAR *pszArrayName) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteEOClip(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteEOClip(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteHatch(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteHatch(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteRotate(PSDRV_PDEVICE *physDev, float ang) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteRotate(PHYSDEV dev, float ang) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteIndexColorSpaceBegin(PSDRV_PDEVICE *physDev, int size) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteIndexColorSpaceBegin(PHYSDEV dev, int size) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteIndexColorSpaceEnd(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteIndexColorSpaceEnd(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteRGB(PSDRV_PDEVICE *physDev, COLORREF *map, int number) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteRGB(PHYSDEV dev, COLORREF *map, int number) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteImage(PSDRV_PDEVICE *physDev, WORD depth, INT xDst, INT yDst, extern BOOL PSDRV_WriteImage(PHYSDEV dev, WORD depth, INT xDst, INT yDst,
INT widthDst, INT heightDst, INT widthSrc, INT widthDst, INT heightDst, INT widthSrc,
INT heightSrc, BOOL mask) DECLSPEC_HIDDEN; INT heightSrc, BOOL mask) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteBytes(PSDRV_PDEVICE *physDev, const BYTE *bytes, DWORD number) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteBytes(PHYSDEV dev, const BYTE *bytes, DWORD number) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteData(PSDRV_PDEVICE *physDev, const BYTE *byte, DWORD number) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteData(PHYSDEV dev, const BYTE *byte, DWORD number) DECLSPEC_HIDDEN;
extern DWORD PSDRV_WriteSpool(PSDRV_PDEVICE *physDev, LPCSTR lpData, DWORD cch) DECLSPEC_HIDDEN; extern DWORD PSDRV_WriteSpool(PHYSDEV dev, LPCSTR lpData, DWORD cch) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WritePatternDict(PSDRV_PDEVICE *physDev, BITMAP *bm, BYTE *bits) DECLSPEC_HIDDEN; extern BOOL PSDRV_WritePatternDict(PHYSDEV dev, BITMAP *bm, BYTE *bits) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteDIBPatternDict(PSDRV_PDEVICE *physDev, BITMAPINFO *bmi, UINT usage) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteDIBPatternDict(PHYSDEV dev, BITMAPINFO *bmi, UINT usage) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteArrayPut(PSDRV_PDEVICE *physDev, CHAR *pszArrayName, INT nIndex, LONG lCoord) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteArrayPut(PHYSDEV dev, CHAR *pszArrayName, INT nIndex, LONG lCoord) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteArrayDef(PSDRV_PDEVICE *physDev, CHAR *pszArrayName, INT nSize) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteArrayDef(PHYSDEV dev, CHAR *pszArrayName, INT nSize) DECLSPEC_HIDDEN;
extern INT CDECL PSDRV_StartPage( PSDRV_PDEVICE *physDev ) DECLSPEC_HIDDEN; extern INT CDECL PSDRV_StartPage( PHYSDEV dev ) DECLSPEC_HIDDEN;
INT PSDRV_GlyphListInit(void) DECLSPEC_HIDDEN; INT PSDRV_GlyphListInit(void) DECLSPEC_HIDDEN;
const GLYPHNAME *PSDRV_GlyphName(LPCSTR szName) DECLSPEC_HIDDEN; const GLYPHNAME *PSDRV_GlyphName(LPCSTR szName) DECLSPEC_HIDDEN;
@ -488,31 +489,30 @@ BOOL PSDRV_GetType1Metrics(void) DECLSPEC_HIDDEN;
const AFMMETRICS *PSDRV_UVMetrics(LONG UV, const AFM *afm) DECLSPEC_HIDDEN; const AFMMETRICS *PSDRV_UVMetrics(LONG UV, const AFM *afm) DECLSPEC_HIDDEN;
SHORT PSDRV_CalcAvgCharWidth(const AFM *afm) DECLSPEC_HIDDEN; SHORT PSDRV_CalcAvgCharWidth(const AFM *afm) DECLSPEC_HIDDEN;
extern BOOL PSDRV_SelectBuiltinFont(PSDRV_PDEVICE *physDev, HFONT hfont, extern BOOL PSDRV_SelectBuiltinFont(PHYSDEV dev, HFONT hfont,
LOGFONTW *plf, LPSTR FaceName) DECLSPEC_HIDDEN; LOGFONTW *plf, LPSTR FaceName) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteSetBuiltinFont(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteSetBuiltinFont(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteBuiltinGlyphShow(PSDRV_PDEVICE *physDev, LPCWSTR str, INT count) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteBuiltinGlyphShow(PHYSDEV dev, LPCWSTR str, INT count) DECLSPEC_HIDDEN;
extern BOOL PSDRV_SelectDownloadFont(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_SelectDownloadFont(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteSetDownloadFont(PSDRV_PDEVICE *physDev) DECLSPEC_HIDDEN; extern BOOL PSDRV_WriteSetDownloadFont(PHYSDEV dev) DECLSPEC_HIDDEN;
extern BOOL PSDRV_WriteDownloadGlyphShow(PSDRV_PDEVICE *physDev, WORD *glpyhs, extern BOOL PSDRV_WriteDownloadGlyphShow(PHYSDEV dev, WORD *glpyhs, UINT count) DECLSPEC_HIDDEN;
UINT count) DECLSPEC_HIDDEN; extern BOOL PSDRV_EmptyDownloadList(PHYSDEV dev, BOOL write_undef) DECLSPEC_HIDDEN;
extern BOOL PSDRV_EmptyDownloadList(PSDRV_PDEVICE *physDev, BOOL write_undef) DECLSPEC_HIDDEN;
extern DWORD write_spool( PSDRV_PDEVICE *physDev, const void *data, DWORD num ) DECLSPEC_HIDDEN; extern DWORD write_spool( PHYSDEV dev, const void *data, DWORD num ) DECLSPEC_HIDDEN;
#define MAX_G_NAME 31 /* max length of PS glyph name */ #define MAX_G_NAME 31 /* max length of PS glyph name */
extern void get_glyph_name(HDC hdc, WORD index, char *name) DECLSPEC_HIDDEN; extern void get_glyph_name(HDC hdc, WORD index, char *name) DECLSPEC_HIDDEN;
extern TYPE1 *T1_download_header(PSDRV_PDEVICE *physDev, char *ps_name, extern TYPE1 *T1_download_header(PHYSDEV dev, char *ps_name,
RECT *bbox, UINT emsize) DECLSPEC_HIDDEN; RECT *bbox, UINT emsize) DECLSPEC_HIDDEN;
extern BOOL T1_download_glyph(PSDRV_PDEVICE *physDev, DOWNLOAD *pdl, extern BOOL T1_download_glyph(PHYSDEV dev, DOWNLOAD *pdl,
DWORD index, char *glyph_name) DECLSPEC_HIDDEN; DWORD index, char *glyph_name) DECLSPEC_HIDDEN;
extern void T1_free(TYPE1 *t1) DECLSPEC_HIDDEN; extern void T1_free(TYPE1 *t1) DECLSPEC_HIDDEN;
extern TYPE42 *T42_download_header(PSDRV_PDEVICE *physDev, char *ps_name, extern TYPE42 *T42_download_header(PHYSDEV dev, char *ps_name,
RECT *bbox, UINT emsize) DECLSPEC_HIDDEN; RECT *bbox, UINT emsize) DECLSPEC_HIDDEN;
extern BOOL T42_download_glyph(PSDRV_PDEVICE *physDev, DOWNLOAD *pdl, extern BOOL T42_download_glyph(PHYSDEV dev, DOWNLOAD *pdl,
DWORD index, char *glyph_name) DECLSPEC_HIDDEN; DWORD index, char *glyph_name) DECLSPEC_HIDDEN;
extern void T42_free(TYPE42 *t42) DECLSPEC_HIDDEN; extern void T42_free(TYPE42 *t42) DECLSPEC_HIDDEN;

View File

@ -29,17 +29,18 @@
WINE_DEFAULT_DEBUG_CHANNEL(psdrv); WINE_DEFAULT_DEBUG_CHANNEL(psdrv);
static BOOL PSDRV_Text(PSDRV_PDEVICE *physDev, INT x, INT y, UINT flags, static BOOL PSDRV_Text(PHYSDEV dev, INT x, INT y, UINT flags,
LPCWSTR str, UINT count, LPCWSTR str, UINT count,
BOOL bDrawBackground, const INT *lpDx); BOOL bDrawBackground, const INT *lpDx);
/*********************************************************************** /***********************************************************************
* PSDRV_ExtTextOut * PSDRV_ExtTextOut
*/ */
BOOL CDECL PSDRV_ExtTextOut( PSDRV_PDEVICE *physDev, INT x, INT y, UINT flags, BOOL CDECL PSDRV_ExtTextOut( PHYSDEV dev, INT x, INT y, UINT flags,
const RECT *lprect, LPCWSTR str, UINT count, const RECT *lprect, LPCWSTR str, UINT count,
const INT *lpDx ) const INT *lpDx )
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
BOOL bResult = TRUE; BOOL bResult = TRUE;
BOOL bClipped = FALSE; BOOL bClipped = FALSE;
BOOL bOpaque = FALSE; BOOL bOpaque = FALSE;
@ -50,50 +51,51 @@ BOOL CDECL PSDRV_ExtTextOut( PSDRV_PDEVICE *physDev, INT x, INT y, UINT flags,
if(physDev->job.id == 0) return FALSE; if(physDev->job.id == 0) return FALSE;
/* write font if not already written */ /* write font if not already written */
PSDRV_SetFont(physDev); PSDRV_SetFont(dev);
PSDRV_SetClip(physDev); PSDRV_SetClip(dev);
/* set clipping and/or draw background */ /* set clipping and/or draw background */
if ((flags & (ETO_CLIPPED | ETO_OPAQUE)) && (lprect != NULL)) if ((flags & (ETO_CLIPPED | ETO_OPAQUE)) && (lprect != NULL))
{ {
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteRectangle(physDev, lprect->left, lprect->top, lprect->right - lprect->left, PSDRV_WriteRectangle(dev, lprect->left, lprect->top, lprect->right - lprect->left,
lprect->bottom - lprect->top); lprect->bottom - lprect->top);
if (flags & ETO_OPAQUE) if (flags & ETO_OPAQUE)
{ {
bOpaque = TRUE; bOpaque = TRUE;
PSDRV_WriteGSave(physDev); PSDRV_WriteGSave(dev);
PSDRV_WriteSetColor(physDev, &physDev->bkColor); PSDRV_WriteSetColor(dev, &physDev->bkColor);
PSDRV_WriteFill(physDev); PSDRV_WriteFill(dev);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
} }
if (flags & ETO_CLIPPED) if (flags & ETO_CLIPPED)
{ {
bClipped = TRUE; bClipped = TRUE;
PSDRV_WriteClip(physDev); PSDRV_WriteClip(dev);
} }
bResult = PSDRV_Text(physDev, x, y, flags, str, count, !(bClipped && bOpaque), lpDx); bResult = PSDRV_Text(dev, x, y, flags, str, count, !(bClipped && bOpaque), lpDx);
PSDRV_WriteGRestore(physDev); PSDRV_WriteGRestore(dev);
} }
else else
{ {
bResult = PSDRV_Text(physDev, x, y, flags, str, count, TRUE, lpDx); bResult = PSDRV_Text(dev, x, y, flags, str, count, TRUE, lpDx);
} }
PSDRV_ResetClip(physDev); PSDRV_ResetClip(dev);
return bResult; return bResult;
} }
/*********************************************************************** /***********************************************************************
* PSDRV_Text * PSDRV_Text
*/ */
static BOOL PSDRV_Text(PSDRV_PDEVICE *physDev, INT x, INT y, UINT flags, LPCWSTR str, static BOOL PSDRV_Text(PHYSDEV dev, INT x, INT y, UINT flags, LPCWSTR str,
UINT count, BOOL bDrawBackground, const INT *lpDx) UINT count, BOOL bDrawBackground, const INT *lpDx)
{ {
PSDRV_PDEVICE *physDev = get_psdrv_dev( dev );
WORD *glyphs = NULL; WORD *glyphs = NULL;
if (!count) if (!count)
@ -102,13 +104,13 @@ static BOOL PSDRV_Text(PSDRV_PDEVICE *physDev, INT x, INT y, UINT flags, LPCWSTR
if(physDev->font.fontloc == Download) if(physDev->font.fontloc == Download)
glyphs = (LPWORD)str; glyphs = (LPWORD)str;
PSDRV_WriteMoveTo(physDev, x, y); PSDRV_WriteMoveTo(dev, x, y);
if(!lpDx) { if(!lpDx) {
if(physDev->font.fontloc == Download) if(physDev->font.fontloc == Download)
PSDRV_WriteDownloadGlyphShow(physDev, glyphs, count); PSDRV_WriteDownloadGlyphShow(dev, glyphs, count);
else else
PSDRV_WriteBuiltinGlyphShow(physDev, str, count); PSDRV_WriteBuiltinGlyphShow(dev, str, count);
} }
else { else {
UINT i; UINT i;
@ -116,9 +118,9 @@ static BOOL PSDRV_Text(PSDRV_PDEVICE *physDev, INT x, INT y, UINT flags, LPCWSTR
for(i = 0; i < count-1; i++) { for(i = 0; i < count-1; i++) {
if(physDev->font.fontloc == Download) if(physDev->font.fontloc == Download)
PSDRV_WriteDownloadGlyphShow(physDev, glyphs + i, 1); PSDRV_WriteDownloadGlyphShow(dev, glyphs + i, 1);
else else
PSDRV_WriteBuiltinGlyphShow(physDev, str + i, 1); PSDRV_WriteBuiltinGlyphShow(dev, str + i, 1);
if(flags & ETO_PDY) if(flags & ETO_PDY)
{ {
offset.x += lpDx[i * 2]; offset.x += lpDx[i * 2];
@ -126,12 +128,12 @@ static BOOL PSDRV_Text(PSDRV_PDEVICE *physDev, INT x, INT y, UINT flags, LPCWSTR
} }
else else
offset.x += lpDx[i]; offset.x += lpDx[i];
PSDRV_WriteMoveTo(physDev, x + offset.x, y + offset.y); PSDRV_WriteMoveTo(dev, x + offset.x, y + offset.y);
} }
if(physDev->font.fontloc == Download) if(physDev->font.fontloc == Download)
PSDRV_WriteDownloadGlyphShow(physDev, glyphs + i, 1); PSDRV_WriteDownloadGlyphShow(dev, glyphs + i, 1);
else else
PSDRV_WriteBuiltinGlyphShow(physDev, str + i, 1); PSDRV_WriteBuiltinGlyphShow(dev, str + i, 1);
} }
return TRUE; return TRUE;

View File

@ -70,7 +70,7 @@ static inline WORD get_be_word(const void *p) { return RtlUshortByteSwap(*(WOR
static inline DWORD get_be_dword(const void *p) { return RtlUlongByteSwap(*(DWORD*)p); } static inline DWORD get_be_dword(const void *p) { return RtlUlongByteSwap(*(DWORD*)p); }
#endif #endif
TYPE1 *T1_download_header(PSDRV_PDEVICE *physDev, char *ps_name, RECT *bbox, UINT emsize) TYPE1 *T1_download_header(PHYSDEV dev, char *ps_name, RECT *bbox, UINT emsize)
{ {
char *buf; char *buf;
TYPE1 *t1; TYPE1 *t1;
@ -113,7 +113,7 @@ TYPE1 *T1_download_header(PSDRV_PDEVICE *physDev, char *ps_name, RECT *bbox, UIN
sprintf(buf, dict, ps_name, t1->emsize, t1->emsize, sprintf(buf, dict, ps_name, t1->emsize, t1->emsize,
bbox->left, bbox->bottom, bbox->right, bbox->top); bbox->left, bbox->bottom, bbox->right, bbox->top);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
HeapFree(GetProcessHeap(), 0, buf); HeapFree(GetProcessHeap(), 0, buf);
return t1; return t1;
@ -512,8 +512,7 @@ static inline BOOL on_point(const glyph_outline *outline, WORD pt)
return outline->flags[pt] & 1; return outline->flags[pt] & 1;
} }
BOOL T1_download_glyph(PSDRV_PDEVICE *physDev, DOWNLOAD *pdl, DWORD index, BOOL T1_download_glyph(PHYSDEV dev, DOWNLOAD *pdl, DWORD index, char *glyph_name)
char *glyph_name)
{ {
DWORD len; DWORD len;
WORD cur_pt, cont; WORD cur_pt, cont;
@ -551,9 +550,9 @@ BOOL T1_download_glyph(PSDRV_PDEVICE *physDev, DOWNLOAD *pdl, DWORD index,
outline.flags = NULL; outline.flags = NULL;
outline.end_pts = NULL; outline.end_pts = NULL;
outline.pts = NULL; outline.pts = NULL;
get_hmetrics(physDev->hdc, index, &outline.lsb, &outline.advance); get_hmetrics(dev->hdc, index, &outline.lsb, &outline.advance);
if(!append_glyph_outline(physDev->hdc, index, &outline)) return FALSE; if(!append_glyph_outline(dev->hdc, index, &outline)) return FALSE;
charstring = str_init(100); charstring = str_init(100);
curpos.x = outline.lsb; curpos.x = outline.lsb;
@ -633,14 +632,14 @@ BOOL T1_download_glyph(PSDRV_PDEVICE *physDev, DOWNLOAD *pdl, DWORD index,
strlen(pdl->ps_name) + strlen(glyph_name) + 100); strlen(pdl->ps_name) + strlen(glyph_name) + 100);
sprintf(buf, "%%%%glyph %04x\n", index); sprintf(buf, "%%%%glyph %04x\n", index);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
len = str_get_bytes(charstring, &bytes); len = str_get_bytes(charstring, &bytes);
sprintf(buf, glyph_def_begin, pdl->ps_name, glyph_name, len); sprintf(buf, glyph_def_begin, pdl->ps_name, glyph_name, len);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
PSDRV_WriteBytes(physDev, bytes, len); PSDRV_WriteBytes(dev, bytes, len);
sprintf(buf, glyph_def_end); sprintf(buf, glyph_def_end);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
str_free(charstring); str_free(charstring);
t1->glyph_sent[index] = TRUE; t1->glyph_sent[index] = TRUE;

View File

@ -134,7 +134,7 @@ static BOOL get_glyf_pos(TYPE42 *t42, DWORD index, DWORD *start, DWORD *end)
return TRUE; return TRUE;
} }
TYPE42 *T42_download_header(PSDRV_PDEVICE *physDev, char *ps_name, TYPE42 *T42_download_header(PHYSDEV dev, char *ps_name,
RECT *bbox, UINT emsize) RECT *bbox, UINT emsize)
{ {
DWORD i, j, tablepos, nb_blocks, glyf_off = 0, loca_off = 0, cur_off; DWORD i, j, tablepos, nb_blocks, glyf_off = 0, loca_off = 0, cur_off;
@ -173,7 +173,7 @@ TYPE42 *T42_download_header(PSDRV_PDEVICE *physDev, char *ps_name,
t42->num_of_written_tables = 0; t42->num_of_written_tables = 0;
for(i = 0; i < num_of_tables; i++) { for(i = 0; i < num_of_tables; i++) {
LoadTable(physDev->hdc, t42->tables + i); LoadTable(dev->hdc, t42->tables + i);
if(t42->tables[i].len > 0xffff && t42->tables[i].write) break; if(t42->tables[i].len > 0xffff && t42->tables[i].write) break;
if(t42->tables[i].write) t42->num_of_written_tables++; if(t42->tables[i].write) t42->num_of_written_tables++;
if(t42->tables[i].MS_tag == MS_MAKE_TAG('l','o','c','a')) if(t42->tables[i].MS_tag == MS_MAKE_TAG('l','o','c','a'))
@ -207,13 +207,13 @@ TYPE42 *T42_download_header(PSDRV_PDEVICE *physDev, char *ps_name,
(float)bbox->right / emsize, (float)bbox->top / emsize); (float)bbox->right / emsize, (float)bbox->top / emsize);
pop_lc_numeric(); pop_lc_numeric();
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
t42->num_of_written_tables++; /* explicitly add glyf */ t42->num_of_written_tables++; /* explicitly add glyf */
sprintf(buf, TT_offset_table, t42->num_of_written_tables, sprintf(buf, TT_offset_table, t42->num_of_written_tables,
t42->num_of_written_tables, t42->num_of_written_tables, t42->num_of_written_tables); t42->num_of_written_tables, t42->num_of_written_tables, t42->num_of_written_tables);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
tablepos = 12 + t42->num_of_written_tables * 16; tablepos = 12 + t42->num_of_written_tables * 16;
cur_off = 12; cur_off = 12;
@ -222,7 +222,7 @@ TYPE42 *T42_download_header(PSDRV_PDEVICE *physDev, char *ps_name,
sprintf(buf, TT_table_dir_entry, FLIP_ORDER(t42->tables[i].MS_tag), sprintf(buf, TT_table_dir_entry, FLIP_ORDER(t42->tables[i].MS_tag),
t42->tables[i].check, t42->tables[i].len ? tablepos : 0, t42->tables[i].check, t42->tables[i].len ? tablepos : 0,
t42->tables[i].len); t42->tables[i].len);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
tablepos += ((t42->tables[i].len + 3) & ~3); tablepos += ((t42->tables[i].len + 3) & ~3);
if(t42->tables[i].MS_tag == MS_MAKE_TAG('l','o','c','a')) if(t42->tables[i].MS_tag == MS_MAKE_TAG('l','o','c','a'))
loca_off = cur_off; loca_off = cur_off;
@ -230,19 +230,19 @@ TYPE42 *T42_download_header(PSDRV_PDEVICE *physDev, char *ps_name,
} }
sprintf(buf, TT_table_dir_entry, FLIP_ORDER(t42->tables[t42->glyf_tab].MS_tag), sprintf(buf, TT_table_dir_entry, FLIP_ORDER(t42->tables[t42->glyf_tab].MS_tag),
t42->tables[t42->glyf_tab].check, tablepos, t42->tables[t42->glyf_tab].len); t42->tables[t42->glyf_tab].check, tablepos, t42->tables[t42->glyf_tab].len);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
PSDRV_WriteSpool(physDev, "00>\n", 4); /* add an extra byte for old PostScript rips */ PSDRV_WriteSpool(dev, "00>\n", 4); /* add an extra byte for old PostScript rips */
glyf_off = cur_off; glyf_off = cur_off;
for(i = 0; i < num_of_tables; i++) { for(i = 0; i < num_of_tables; i++) {
if(t42->tables[i].len == 0 || !t42->tables[i].write) continue; if(t42->tables[i].len == 0 || !t42->tables[i].write) continue;
PSDRV_WriteSpool(physDev, "<", 1); PSDRV_WriteSpool(dev, "<", 1);
for(j = 0; j < ((t42->tables[i].len + 3) & ~3); j++) { for(j = 0; j < ((t42->tables[i].len + 3) & ~3); j++) {
sprintf(buf, "%02x", t42->tables[i].data[j]); sprintf(buf, "%02x", t42->tables[i].data[j]);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
if(j % 16 == 15) PSDRV_WriteSpool(physDev, "\n", 1); if(j % 16 == 15) PSDRV_WriteSpool(dev, "\n", 1);
} }
PSDRV_WriteSpool(physDev, "00>\n", 4); /* add an extra byte for old PostScript rips */ PSDRV_WriteSpool(dev, "00>\n", 4); /* add an extra byte for old PostScript rips */
} }
/* glyf_blocks is a 0 terminated list, holding the start offset of each block. For simplicity /* glyf_blocks is a 0 terminated list, holding the start offset of each block. For simplicity
@ -261,17 +261,17 @@ TYPE42 *T42_download_header(PSDRV_PDEVICE *physDev, char *ps_name,
t42->glyf_blocks[nb_blocks-1] = end; t42->glyf_blocks[nb_blocks-1] = end;
} }
PSDRV_WriteSpool(physDev, "[ ", 2); PSDRV_WriteSpool(dev, "[ ", 2);
for(i = 1; t42->glyf_blocks[i]; i++) { for(i = 1; t42->glyf_blocks[i]; i++) {
sprintf(buf,"%d ", t42->glyf_blocks[i] - t42->glyf_blocks[i-1] + 1); sprintf(buf,"%d ", t42->glyf_blocks[i] - t42->glyf_blocks[i-1] + 1);
/* again add one byte for old PostScript rips */ /* again add one byte for old PostScript rips */
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
if(i % 8 == 0) if(i % 8 == 0)
PSDRV_WriteSpool(physDev, "\n", 1); PSDRV_WriteSpool(dev, "\n", 1);
} }
PSDRV_WriteSpool(physDev, storage, sizeof(storage) - 1); PSDRV_WriteSpool(dev, storage, sizeof(storage) - 1);
sprintf(buf, end, loca_off, glyf_off); sprintf(buf, end, loca_off, glyf_off);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
HeapFree(GetProcessHeap(), 0, buf); HeapFree(GetProcessHeap(), 0, buf);
return t42; return t42;
} }
@ -279,7 +279,7 @@ TYPE42 *T42_download_header(PSDRV_PDEVICE *physDev, char *ps_name,
BOOL T42_download_glyph(PSDRV_PDEVICE *physDev, DOWNLOAD *pdl, DWORD index, BOOL T42_download_glyph(PHYSDEV dev, DOWNLOAD *pdl, DWORD index,
char *glyph_name) char *glyph_name)
{ {
DWORD start, end, i; DWORD start, end, i;
@ -326,8 +326,8 @@ BOOL T42_download_glyph(PSDRV_PDEVICE *physDev, DOWNLOAD *pdl, DWORD index,
sg_index = GET_BE_WORD(sg_start + 2); sg_index = GET_BE_WORD(sg_start + 2);
TRACE("Sending subglyph %04x for glyph %04x\n", sg_index, index); TRACE("Sending subglyph %04x for glyph %04x\n", sg_index, index);
get_glyph_name(physDev->hdc, sg_index, sg_name); get_glyph_name(dev->hdc, sg_index, sg_name);
T42_download_glyph(physDev, pdl, sg_index, sg_name); T42_download_glyph(dev, pdl, sg_index, sg_name);
sg_start += 4; sg_start += 4;
if(sg_flags & ARG_1_AND_2_ARE_WORDS) if(sg_flags & ARG_1_AND_2_ARE_WORDS)
sg_start += 4; sg_start += 4;
@ -351,18 +351,18 @@ BOOL T42_download_glyph(PSDRV_PDEVICE *physDev, DOWNLOAD *pdl, DWORD index,
/* we don't have a string for the gdir and glyf tables, but we do have a /* we don't have a string for the gdir and glyf tables, but we do have a
string for the TT header. So the offset we need is tables - 2 */ string for the TT header. So the offset we need is tables - 2 */
sprintf(buf, "%d %d\n", t42->num_of_written_tables - 2 + i, start - t42->glyf_blocks[i-1]); sprintf(buf, "%d %d\n", t42->num_of_written_tables - 2 + i, start - t42->glyf_blocks[i-1]);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
PSDRV_WriteSpool(physDev, "<", 1); PSDRV_WriteSpool(dev, "<", 1);
for(i = start; i < end; i++) { for(i = start; i < end; i++) {
sprintf(buf, "%02x", *(t42->tables[t42->glyf_tab].data + i)); sprintf(buf, "%02x", *(t42->tables[t42->glyf_tab].data + i));
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
if((i - start) % 16 == 15) if((i - start) % 16 == 15)
PSDRV_WriteSpool(physDev, "\n", 1); PSDRV_WriteSpool(dev, "\n", 1);
} }
PSDRV_WriteSpool(physDev, ">\n", 2); PSDRV_WriteSpool(dev, ">\n", 2);
sprintf(buf, glyph_def, pdl->ps_name, index, glyph_name, index); sprintf(buf, glyph_def, pdl->ps_name, index, glyph_name, index);
PSDRV_WriteSpool(physDev, buf, strlen(buf)); PSDRV_WriteSpool(dev, buf, strlen(buf));
t42->glyph_sent[index] = TRUE; t42->glyph_sent[index] = TRUE;
HeapFree(GetProcessHeap(), 0, buf); HeapFree(GetProcessHeap(), 0, buf);