mirror of
https://github.com/reactos/wine.git
synced 2025-04-03 08:31:55 +00:00

Sun Jun 15 10:30:35 1998 Andreas Mohr <100.30936@germany.net> * [files/dos_fs.c] [files/file.c] [if1632/wprocs.spec] [misc/aspi.c] Added support for scanners that need Adaptec's ASPI2DOS. * [graphics/env.c] [misc/printerdrv.c] [graphics/win16drv/init.c] [if1632/gdi.spec] [include/gdi.h] Enhanced printer support (especially Win95): Drv[GS]etPrinterData, [GS]etEnvironment; added AbortProc handling. * [misc/tapi32.c] [relay32/tapi32.spec] Added some stubs. * [configure.in] [graphics/fontengine.c] [include/windows.h] [misc/comm.c] [misc/w32skrnl.c] [misc/win32s16.c] Made Wine compile on HP-UX (just for fun ;) * [controls/menu.c] [include/windows.h] Complete rewrite of EnableMenuItem32. Free Agent 32 still doesn't work :( * [misc/version.c] [if1632/kernel.spec] [include/winbase.h] Implemented GetVersionEx16. * [misc/network.c] [if1632/user.spec] Fixed arguments of WNetGetPropertyText. * [misc/version.c] [relay32/comctl32.spec] [relay32/oleaut32.spec] Implemented COMCTL32_DllGetVersion, OaBuildVersion. * [win32/file.c] Fixed UNC handling of CreateFile32. Sat Jun 13 22:35:12 1998 Douglas Ridgway <ridgway@winehq.com> * [Makefile.in] [Make.rules.in] Added pattern for CVS merge files to 'make clean' * [ole/olecli.c] [windows/scroll.c] [windows/grahics.c] Add some DC handle unlocking. (When hdc's are always unlocked, they can be made moveable.) * [documentation/wine.texinfo] Started a Wine Design chapter with discussion of graphics driver model. Sat Jun 13 11:19:25 1998 David Luyer <luyer@ucs.uwa.edu.au> * [misc/main.c] [relay32/relay386.c] Added new option -debugmsg +relay=.... or -debugmsg -relay=... Fri Jun 12 22:56:09 1998 Marcus Meissner <marcus@jet.franken.de> * [relay32/snoop.c][relay32/builtin.c][loader/pe_image.c] Added inter win32 dll snooping. Use -debugmsg +snoop. Number of arguments and string references are autodetected. Some small bugfixes in the PE loader. * [misc/system.c] Disabled SystemTimers. They do not work with the current %fs handling in the 32->16 relaycode. (helps labview) * [msdos/dpmi.c][msdos/int2f.c][files/drive.c] Added a monoton linear increasing memory allocator for DPMI (required for LabView, HAFAS, ...) mscdex handling in emulated realmode interrupts (for mcicda.drv) allocate logical drives only once. (helps Myst) * [files/profile.c] Handle ^Z as space. Found on CDROMS (helps Myst Installer). * [multimedia/mmio.c] mmio* partially updated to win32. No funny additions. * [windows/driver.c] Added win32 driver handling (will be used for win32 multimedia/ msvideo drivers). * [win32/device.c] Added device handling (K32OBJ_DEVICE_IOCTL). Implemented VTDAPI.5 (used by win95' WINMM.timeGetTime()) Fri Jun 12 18:01:18 1998 Rein Klazes <rklazes@casema.net> * [ole/compobj.c relay32/ole32.spec] Add a stub for CoLockObjectExternal32. * [objects/clipping.c] Fix in IntersectClipRect(), when there is no initial clipping region. * [graphics/x11drv/graphics.c] Corrected several "one-off" errors for the Ellipse, Rectangle and RoundRectangle (especially small ones) draw routines. Arc and friends still have to be done. Fri Jun 12 06:23:19 1998 Matthew Becker <mbecker@glasscity.net> * [misc/ntdll.c] Fixed some of the parameter counts. * [misc/registry.c] General cleanup, documentation. Standard keys are allowed to be 'closed' and succeed. * [misc/shell.c] Check for correct return values from Reg* functions. * [win32/newfns.c] Added stubs for OpenDesktopA, SetThreadDesktop, and SetUserObjectInformationA. Wed Jun 10 20:28:08 1998 James Juran <jrj120@psu.edu> * [debugger/break.c] Fixed bug introduced in 980503 that broke the -debug command line option for PE executable files. * [configure.in] [include/acconfig.h] [include/debugtools.h] [documentation/debug-msgs] Added 'configure' options to compile out debugging messages. Use --disable-debug to disable all debugging messages, and --disable-trace to just disable TRACE messages. This results in a stripped executable that is 15-20% smaller. This option is very much untested--don't expect it to work. * [documentation/debug-msgs] [documentation/debugging] Minor updates. * [*/*.c] Fixed some compile warnings. This also includes the compile_warnings_trivial patch from WineHQ. Tue Jun 10 22:00:18 1998 Eric Kohl <ekohl@abo.rhein-zeitung.de> * [windows/sysmetrics.c][include/sysmetrics.h] Fixed some Win95 values. * [windows/nonclient.c][include/windows.h] Fixed some Win95 drawing bugs. Added extended window style flags (WS_EX_xxx). * [misc/printdrv.c][relay32/winspool.spec] Added stubs for DeletePrinterDriver32A, DeleteMonitor32A and DeletePort32A. * [windows/mdi.c][include/windows.h][relay32/user32.spec] Added stubs for CascadeWindows and TileWindows. * [controls/toolbar.c][include/toolbar.h] Fixed a few bugs and implemented new features. * [misc/shellord.c][relay32/shell32.spec] Added stubs for SHELL32_60, SHELL32_61 and SHELL32_184. * [controls/comctl32undoc.c][relay32/comctl32.spec] New file comctl32undoc.c. Contains undocumented functions of COMCTL32.DLL. These functions are needed to run EXPLORER.EXE IEXPLORE.EXE and TASKMAN.EXE. * [controls/status.c] Added text alignment. Tue Jun 8 22:00:00 1998 Bertho Stultiens <bertho@akhphd.au.dk> * [programs/*/Makefile.in] Changed the rules to use wrc as resource compiler but passing the source through gcc first for macro expansion. * [programs/*/*.rc] Added #include "windows.h" for the resource compiler in the appropriate files. * [tools/wrc/wrc.[ch]] [tools/wrc/writeres.c] Added commandline option -A for autoregister code. Corrected the underscore problem by checking the proper define from config.h. Sun Jun 7 22:09:29 1998 Pascal Cuoq <pcuoq@ens-lyon.fr> * [ole/ole2nls.c] [memory/string.c] Improved LCMapString32A, and changed CompareString32A, lstrcmp, lstrcmpi to use it. Sat Jun 6 19:00:50 1998 Martin Strömberg <ams@ludd.luth.se> * [include/winnt.h] Added typedefs for security and tokens. Sat Jun 6 12:26:31 1998 Morten Welinder <terra@diku.dk> * [objects/text.c] Use debugstr_an in DrawText16. * [loader/resource.c] Use debugres_w in FindResourceEx32W. Avoid crashing during debug when wm is NULL. * [if1632/relay.c] In RELAY_DebugCallTo16, send output to the right place and avoid side effects in macro arguments. Wed Jun 3 20:56:03 1998 Huw D M Davies <daviesh@abacus.physics.ox.ac.uk> * [controls/scroll.c] [windows/nonclient.c] Fix several off by one errors in scrollbar painting. Tue Jun 2 23:58:59 1998 Insomnia (Stea Greene) <insomnia@core.binghamton.edu> * [graphics/dsound.c] Rewrote mixer code to handle panning and volume for 16->16, 16->8, 8->16, and 8->8 bit mixes. Conforms to DirectX's "logarithmic hearing scale" as specified in M$VC docs. Still does not handle mixing of different frequencies (I am still working on that). Tested 16->16 extensively with StarCraft. Other mixing combinations untested but should work fine. Still kind of a work in progress, so be warned. Tue Jun 2 03:31:33 1998 Alexander V. Lukyanov <lav@long.yar.ru> * [tools/wrc/utils.c] dup_basename: fix to strip directory. Mon Jun 1 20:00:00 1998 Juergen Schmied <juergen.schmied@metronet.de> * [include/windows.h] [objects/cursoricon.c] [relay32/user32.spec] Added stubs LoadCursorFromFileW and LoadCursorFromFileA.
697 lines
20 KiB
C
697 lines
20 KiB
C
/*
|
|
* Windows Device Context initialisation functions
|
|
*
|
|
* Copyright 1996 John Harvey
|
|
* 1998 Huw Davies
|
|
*/
|
|
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <sys/types.h>
|
|
#include <ctype.h>
|
|
#include <fcntl.h>
|
|
#include <unistd.h>
|
|
#include <errno.h>
|
|
#include "windows.h"
|
|
#include "win16drv.h"
|
|
#include "gdi.h"
|
|
#include "bitmap.h"
|
|
#include "heap.h"
|
|
#include "color.h"
|
|
#include "font.h"
|
|
#include "callback.h"
|
|
#include "options.h"
|
|
#include "debug.h"
|
|
#include "dc.h"
|
|
|
|
#define SUPPORT_REALIZED_FONTS 1
|
|
#pragma pack(1)
|
|
typedef struct
|
|
{
|
|
SHORT nSize;
|
|
SEGPTR lpindata;
|
|
SEGPTR lpFont;
|
|
SEGPTR lpXForm;
|
|
SEGPTR lpDrawMode;
|
|
} EXTTEXTDATA, *LPEXTTEXTDATA;
|
|
#pragma pack(4)
|
|
|
|
SEGPTR win16drv_SegPtr_TextXForm;
|
|
LPTEXTXFORM16 win16drv_TextXFormP;
|
|
SEGPTR win16drv_SegPtr_DrawMode;
|
|
LPDRAWMODE win16drv_DrawModeP;
|
|
|
|
|
|
static BOOL32 WIN16DRV_CreateDC( DC *dc, LPCSTR driver, LPCSTR device,
|
|
LPCSTR output, const DEVMODE16* initData );
|
|
static INT32 WIN16DRV_Escape( DC *dc, INT32 nEscape, INT32 cbInput,
|
|
SEGPTR lpInData, SEGPTR lpOutData );
|
|
|
|
static const DC_FUNCTIONS WIN16DRV_Funcs =
|
|
{
|
|
NULL, /* pArc */
|
|
NULL, /* pBitBlt */
|
|
NULL, /* pChord */
|
|
WIN16DRV_CreateDC, /* pCreateDC */
|
|
NULL, /* pDeleteDC */
|
|
NULL, /* pDeleteObject */
|
|
WIN16DRV_Ellipse, /* pEllipse */
|
|
WIN16DRV_EnumDeviceFonts, /* pEnumDeviceFonts */
|
|
WIN16DRV_Escape, /* pEscape */
|
|
NULL, /* pExcludeClipRect */
|
|
NULL, /* pExcludeVisRect */
|
|
NULL, /* pExtFloodFill */
|
|
WIN16DRV_ExtTextOut, /* pExtTextOut */
|
|
WIN16DRV_GetCharWidth, /* pGetCharWidth */
|
|
NULL, /* pGetPixel */
|
|
WIN16DRV_GetTextExtentPoint, /* pGetTextExtentPoint */
|
|
WIN16DRV_GetTextMetrics, /* pGetTextMetrics */
|
|
NULL, /* pIntersectClipRect */
|
|
NULL, /* pIntersectVisRect */
|
|
WIN16DRV_LineTo, /* pLineTo */
|
|
WIN16DRV_MoveToEx, /* pMoveToEx */
|
|
NULL, /* pOffsetClipRgn */
|
|
NULL, /* pOffsetViewportOrgEx */
|
|
NULL, /* pOffsetWindowOrgEx */
|
|
NULL, /* pPaintRgn */
|
|
WIN16DRV_PatBlt, /* pPatBlt */
|
|
NULL, /* pPie */
|
|
NULL, /* pPolyPolygon */
|
|
NULL, /* pPolyPolyline */
|
|
WIN16DRV_Polygon, /* pPolygon */
|
|
WIN16DRV_Polyline, /* pPolyline */
|
|
NULL, /* pRealizePalette */
|
|
WIN16DRV_Rectangle, /* pRectangle */
|
|
NULL, /* pRestoreDC */
|
|
NULL, /* pRoundRect */
|
|
NULL, /* pSaveDC */
|
|
NULL, /* pScaleViewportExtEx */
|
|
NULL, /* pScaleWindowExtEx */
|
|
NULL, /* pSelectClipRgn */
|
|
WIN16DRV_SelectObject, /* pSelectObject */
|
|
NULL, /* pSelectPalette */
|
|
NULL, /* pSetBkColor */
|
|
NULL, /* pSetBkMode */
|
|
NULL, /* pSetDeviceClipping */
|
|
NULL, /* pSetDIBitsToDevice */
|
|
NULL, /* pSetMapMode */
|
|
NULL, /* pSetMapperFlags */
|
|
NULL, /* pSetPixel */
|
|
NULL, /* pSetPolyFillMode */
|
|
NULL, /* pSetROP2 */
|
|
NULL, /* pSetRelAbs */
|
|
NULL, /* pSetStretchBltMode */
|
|
NULL, /* pSetTextAlign */
|
|
NULL, /* pSetTextCharacterExtra */
|
|
NULL, /* pSetTextColor */
|
|
NULL, /* pSetTextJustification */
|
|
NULL, /* pSetViewportExtEx */
|
|
NULL, /* pSetViewportOrgEx */
|
|
NULL, /* pSetWindowExtEx */
|
|
NULL, /* pSetWindowOrgEx */
|
|
NULL, /* pStretchBlt */
|
|
NULL /* pStretchDIBits */
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
* WIN16DRV_Init
|
|
*/
|
|
BOOL32 WIN16DRV_Init(void)
|
|
{
|
|
return DRIVER_RegisterDriver( NULL /* generic driver */, &WIN16DRV_Funcs );
|
|
|
|
}
|
|
|
|
/* Tempory functions, for initialising structures */
|
|
/* These values should be calculated, not hardcoded */
|
|
void InitTextXForm(LPTEXTXFORM16 lpTextXForm)
|
|
{
|
|
lpTextXForm->txfHeight = 0x0001;
|
|
lpTextXForm->txfWidth = 0x000c;
|
|
lpTextXForm->txfEscapement = 0x0000;
|
|
lpTextXForm->txfOrientation = 0x0000;
|
|
lpTextXForm->txfWeight = 0x0190;
|
|
lpTextXForm->txfItalic = 0x00;
|
|
lpTextXForm->txfUnderline = 0x00;
|
|
lpTextXForm->txfStrikeOut = 0x00;
|
|
lpTextXForm->txfOutPrecision = 0x02;
|
|
lpTextXForm->txfClipPrecision = 0x01;
|
|
lpTextXForm->txfAccelerator = 0x0001;
|
|
lpTextXForm->txfOverhang = 0x0000;
|
|
}
|
|
|
|
|
|
void InitDrawMode(LPDRAWMODE lpDrawMode)
|
|
{
|
|
lpDrawMode->Rop2 = 0x000d;
|
|
lpDrawMode->bkMode = 0x0001;
|
|
lpDrawMode->bkColor = 0x3fffffff;
|
|
lpDrawMode->TextColor = 0x20000000;
|
|
lpDrawMode->TBreakExtra = 0x0000;
|
|
lpDrawMode->BreakExtra = 0x0000;
|
|
lpDrawMode->BreakErr = 0x0000;
|
|
lpDrawMode->BreakRem = 0x0000;
|
|
lpDrawMode->BreakCount = 0x0000;
|
|
lpDrawMode->CharExtra = 0x0000;
|
|
lpDrawMode->LbkColor = 0x00ffffff;
|
|
lpDrawMode->LTextColor = 0x00000000;
|
|
}
|
|
|
|
BOOL32 WIN16DRV_CreateDC( DC *dc, LPCSTR driver, LPCSTR device, LPCSTR output,
|
|
const DEVMODE16* initData )
|
|
{
|
|
LOADED_PRINTER_DRIVER *pLPD;
|
|
WORD wRet;
|
|
DeviceCaps *printerDevCaps;
|
|
int nPDEVICEsize;
|
|
PDEVICE_HEADER *pPDH;
|
|
WIN16DRV_PDEVICE *physDev;
|
|
char printerEnabled[20];
|
|
PROFILE_GetWineIniString( "wine", "printer", "off",
|
|
printerEnabled, sizeof(printerEnabled) );
|
|
if (lstrcmpi32A(printerEnabled,"on"))
|
|
{
|
|
MSG("WIN16DRV_CreateDC disabled in wine.conf file\n");
|
|
MSG("Enable printing with \"printer=on\"");
|
|
return FALSE;
|
|
}
|
|
|
|
TRACE(win16drv, "In creatdc for (%s,%s,%s) initData 0x%p\n",
|
|
driver, device, output, initData);
|
|
|
|
physDev = (WIN16DRV_PDEVICE *)HeapAlloc( SystemHeap, 0, sizeof(*physDev) );
|
|
if (!physDev) return FALSE;
|
|
dc->physDev = physDev;
|
|
|
|
pLPD = LoadPrinterDriver(driver);
|
|
if (pLPD == NULL)
|
|
{
|
|
WARN(win16drv, "Failed to find printer driver\n");
|
|
HeapFree( SystemHeap, 0, physDev );
|
|
return FALSE;
|
|
}
|
|
TRACE(win16drv, "windevCreateDC pLPD 0x%p\n", pLPD);
|
|
|
|
/* Now Get the device capabilities from the printer driver */
|
|
|
|
printerDevCaps = (DeviceCaps *) malloc(sizeof(DeviceCaps));
|
|
memset(printerDevCaps, 0, sizeof(DeviceCaps));
|
|
|
|
/* Get GDIINFO which is the same as a DeviceCaps structure */
|
|
wRet = PRTDRV_Enable(printerDevCaps, GETGDIINFO, device, driver, output,NULL);
|
|
|
|
/* Add this to the DC */
|
|
dc->w.devCaps = printerDevCaps;
|
|
dc->w.hVisRgn = CreateRectRgn32(0, 0, dc->w.devCaps->horzRes, dc->w.devCaps->vertRes);
|
|
dc->w.bitsPerPixel = dc->w.devCaps->bitsPixel;
|
|
|
|
TRACE(win16drv, "Got devcaps width %d height %d bits %d planes %d\n",
|
|
dc->w.devCaps->horzRes, dc->w.devCaps->vertRes,
|
|
dc->w.devCaps->bitsPixel, dc->w.devCaps->planes);
|
|
|
|
/* Now we allocate enough memory for the PDEVICE structure */
|
|
/* The size of this varies between printer drivers */
|
|
/* This PDEVICE is used by the printer DRIVER not by the GDI so must */
|
|
/* be accessable from 16 bit code */
|
|
nPDEVICEsize = dc->w.devCaps->pdeviceSize + sizeof(PDEVICE_HEADER);
|
|
|
|
/* TTD Shouldn't really do pointer arithmetic on segment points */
|
|
physDev->segptrPDEVICE = WIN16_GlobalLock16(GlobalAlloc16(GHND, nPDEVICEsize))+sizeof(PDEVICE_HEADER);
|
|
*((BYTE *)PTR_SEG_TO_LIN(physDev->segptrPDEVICE)+0) = 'N';
|
|
*((BYTE *)PTR_SEG_TO_LIN(physDev->segptrPDEVICE)+1) = 'B';
|
|
|
|
/* Set up the header */
|
|
pPDH = (PDEVICE_HEADER *)((BYTE*)PTR_SEG_TO_LIN(physDev->segptrPDEVICE) - sizeof(PDEVICE_HEADER));
|
|
pPDH->pLPD = pLPD;
|
|
|
|
TRACE(win16drv, "PDEVICE allocated %08lx\n",(DWORD)(physDev->segptrPDEVICE));
|
|
|
|
/* Now get the printer driver to initialise this data */
|
|
wRet = PRTDRV_Enable((LPVOID)physDev->segptrPDEVICE, INITPDEVICE, device, driver, output, NULL);
|
|
|
|
physDev->FontInfo = NULL;
|
|
physDev->BrushInfo = NULL;
|
|
physDev->PenInfo = NULL;
|
|
win16drv_SegPtr_TextXForm = WIN16_GlobalLock16(GlobalAlloc16(GHND, sizeof(TEXTXFORM16)));
|
|
win16drv_TextXFormP = PTR_SEG_TO_LIN(win16drv_SegPtr_TextXForm);
|
|
|
|
InitTextXForm(win16drv_TextXFormP);
|
|
|
|
/* TTD Lots more to do here */
|
|
win16drv_SegPtr_DrawMode = WIN16_GlobalLock16(GlobalAlloc16(GHND, sizeof(DRAWMODE)));
|
|
win16drv_DrawModeP = PTR_SEG_TO_LIN(win16drv_SegPtr_DrawMode);
|
|
|
|
InitDrawMode(win16drv_DrawModeP);
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
BOOL32 WIN16DRV_PatBlt( struct tagDC *dc, INT32 left, INT32 top,
|
|
INT32 width, INT32 height, DWORD rop )
|
|
{
|
|
|
|
WIN16DRV_PDEVICE *physDev = (WIN16DRV_PDEVICE *)dc->physDev;
|
|
BOOL32 bRet = 0;
|
|
|
|
bRet = PRTDRV_StretchBlt( physDev->segptrPDEVICE, left, top, width, height, (SEGPTR)NULL, 0, 0, width, height,
|
|
PATCOPY, physDev->BrushInfo, win16drv_SegPtr_DrawMode, NULL);
|
|
|
|
return bRet;
|
|
}
|
|
/*
|
|
* Escape (GDI.38)
|
|
*/
|
|
static INT32 WIN16DRV_Escape( DC *dc, INT32 nEscape, INT32 cbInput,
|
|
SEGPTR lpInData, SEGPTR lpOutData )
|
|
{
|
|
WIN16DRV_PDEVICE *physDev = (WIN16DRV_PDEVICE *)dc->physDev;
|
|
int nRet = 0;
|
|
|
|
/* We should really process the nEscape parameter, but for now just
|
|
pass it all to the driver */
|
|
if (dc != NULL && physDev->segptrPDEVICE != 0)
|
|
{
|
|
switch(nEscape)
|
|
{
|
|
case ENABLEPAIRKERNING:
|
|
FIXME(win16drv,"Escape: ENABLEPAIRKERNING ignored.\n");
|
|
nRet = 1;
|
|
break;
|
|
case GETPAIRKERNTABLE:
|
|
FIXME(win16drv,"Escape: GETPAIRKERNTABLE ignored.\n");
|
|
nRet = 0;
|
|
break;
|
|
case SETABORTPROC:
|
|
/* FIXME: The AbortProc should be called:
|
|
- After every write to printer port or spool file
|
|
- Several times when no more disk space
|
|
- Before every metafile record when GDI does banding
|
|
*/
|
|
/* dc->w.lpfnPrint = (FARPROC16)lpInData; FIXME! */
|
|
nRet = 1;
|
|
break;
|
|
|
|
case NEXTBAND:
|
|
{
|
|
LPPOINT16 newInData = SEGPTR_NEW(POINT16);
|
|
|
|
nRet = PRTDRV_Control(physDev->segptrPDEVICE, nEscape,
|
|
SEGPTR_GET(newInData), lpOutData);
|
|
SEGPTR_FREE(newInData);
|
|
break;
|
|
}
|
|
|
|
case GETEXTENDEDTEXTMETRICS:
|
|
{
|
|
EXTTEXTDATA *textData = SEGPTR_NEW(EXTTEXTDATA);
|
|
|
|
textData->nSize = cbInput;
|
|
textData->lpindata = lpInData;
|
|
textData->lpFont = SEGPTR_GET( physDev->FontInfo );
|
|
textData->lpXForm = win16drv_SegPtr_TextXForm;
|
|
textData->lpDrawMode = win16drv_SegPtr_DrawMode;
|
|
nRet = PRTDRV_Control(physDev->segptrPDEVICE, nEscape,
|
|
SEGPTR_GET(textData), lpOutData);
|
|
SEGPTR_FREE(textData);
|
|
}
|
|
break;
|
|
case STARTDOC:
|
|
nRet = PRTDRV_Control(physDev->segptrPDEVICE, nEscape,
|
|
lpInData, lpOutData);
|
|
if (nRet != -1)
|
|
{
|
|
HDC32 *tmpHdc = SEGPTR_NEW(HDC32);
|
|
|
|
#define SETPRINTERDC SETABORTPROC
|
|
|
|
*tmpHdc = dc->hSelf;
|
|
PRTDRV_Control(physDev->segptrPDEVICE, SETPRINTERDC,
|
|
SEGPTR_GET(tmpHdc), (SEGPTR)NULL);
|
|
SEGPTR_FREE(tmpHdc);
|
|
}
|
|
break;
|
|
default:
|
|
nRet = PRTDRV_Control(physDev->segptrPDEVICE, nEscape,
|
|
lpInData, lpOutData);
|
|
break;
|
|
}
|
|
}
|
|
else
|
|
WARN(win16drv, "Escape(nEscape = %04x) - ???\n", nEscape);
|
|
return nRet;
|
|
}
|
|
|
|
|
|
/**********************************************************************
|
|
* QueryAbort (GDI.155)
|
|
*
|
|
* Calls the app's AbortProc function if avail.
|
|
*
|
|
* RETURNS
|
|
* TRUE if no AbortProc avail or AbortProc wants to continue printing.
|
|
* FALSE if AbortProc wants to abort printing.
|
|
*/
|
|
BOOL16 WINAPI QueryAbort(HDC16 hdc, INT16 reserved)
|
|
{
|
|
DC *dc = DC_GetDCPtr( hdc );
|
|
|
|
if ((!dc) || (!dc->w.lpfnPrint))
|
|
return TRUE;
|
|
return dc->w.lpfnPrint(hdc, 0);
|
|
}
|
|
|
|
/**********************************************************************
|
|
* SetAbortProc (GDI.381)
|
|
*
|
|
*/
|
|
INT16 WINAPI SetAbortProc(HDC16 hdc, FARPROC16 abrtprc)
|
|
{
|
|
DC *dc = DC_GetDCPtr( hdc );
|
|
|
|
if (dc) {
|
|
dc->w.lpfnPrint = abrtprc;
|
|
return 1;
|
|
}
|
|
return -1;
|
|
}
|
|
|
|
/****************** misc. printer related functions */
|
|
|
|
/*
|
|
* The following function should implement a queing system
|
|
*/
|
|
#ifndef HPQ
|
|
#define HPQ WORD
|
|
#endif
|
|
struct hpq
|
|
{
|
|
struct hpq *next;
|
|
int tag;
|
|
int key;
|
|
};
|
|
|
|
static struct hpq *hpqueue;
|
|
|
|
HPQ WINAPI CreatePQ(int size)
|
|
{
|
|
FIXME(win16drv, "(%d): stub\n",size);
|
|
return 1;
|
|
}
|
|
int WINAPI DeletePQ(HPQ hPQ)
|
|
{
|
|
FIXME(win16drv, "(%x): stub\n", hPQ);
|
|
return 0;
|
|
}
|
|
int WINAPI ExtractPQ(HPQ hPQ)
|
|
{
|
|
struct hpq *queue, *prev, *current, *currentPrev;
|
|
int key = 0, tag = -1;
|
|
currentPrev = prev = NULL;
|
|
queue = current = hpqueue;
|
|
if (current)
|
|
key = current->key;
|
|
|
|
while (current)
|
|
{
|
|
currentPrev = current;
|
|
current = current->next;
|
|
if (current)
|
|
{
|
|
if (current->key < key)
|
|
{
|
|
queue = current;
|
|
prev = currentPrev;
|
|
}
|
|
}
|
|
}
|
|
if (queue)
|
|
{
|
|
tag = queue->tag;
|
|
|
|
if (prev)
|
|
prev->next = queue->next;
|
|
else
|
|
hpqueue = queue->next;
|
|
free(queue);
|
|
}
|
|
|
|
TRACE(win16drv, "%x got tag %d key %d\n", hPQ, tag, key);
|
|
|
|
return tag;
|
|
}
|
|
|
|
int WINAPI InsertPQ(HPQ hPQ, int tag, int key)
|
|
{
|
|
struct hpq *queueItem = malloc(sizeof(struct hpq));
|
|
queueItem->next = hpqueue;
|
|
hpqueue = queueItem;
|
|
queueItem->key = key;
|
|
queueItem->tag = tag;
|
|
|
|
FIXME(win16drv, "(%x %d %d): stub???\n", hPQ, tag, key);
|
|
return TRUE;
|
|
}
|
|
int WINAPI MinPQ(HPQ hPQ)
|
|
{
|
|
FIXME(win16drv, "(%x): stub\n", hPQ);
|
|
return 0;
|
|
}
|
|
int WINAPI SizePQ(HPQ hPQ, int sizechange)
|
|
{
|
|
FIXME(win16drv, "(%x %d): stub\n", hPQ, sizechange);
|
|
return -1;
|
|
}
|
|
|
|
/*
|
|
* The following functions implement part of the spooling process to
|
|
* print manager. I would like to see wine have a version of print managers
|
|
* that used LPR/LPD. For simplicity print jobs will be sent to a file for
|
|
* now.
|
|
*/
|
|
typedef struct PRINTJOB
|
|
{
|
|
char *pszOutput;
|
|
char *pszTitle;
|
|
HDC16 hDC;
|
|
HANDLE16 hHandle;
|
|
int nIndex;
|
|
int fd;
|
|
} PRINTJOB, *PPRINTJOB;
|
|
|
|
#define MAX_PRINT_JOBS 1
|
|
#define SP_OK 1
|
|
|
|
PPRINTJOB gPrintJobsTable[MAX_PRINT_JOBS];
|
|
|
|
|
|
static PPRINTJOB FindPrintJobFromHandle(HANDLE16 hHandle)
|
|
{
|
|
return gPrintJobsTable[0];
|
|
}
|
|
|
|
/* TTD Need to do some DOS->UNIX file conversion here */
|
|
static int CreateSpoolFile(LPSTR pszOutput)
|
|
{
|
|
int fd=-1;
|
|
char psCmd[1024];
|
|
char *psCmdP = psCmd;
|
|
|
|
/* TTD convert the 'output device' into a spool file name */
|
|
|
|
if (pszOutput == NULL || *pszOutput == '\0')
|
|
return -1;
|
|
|
|
PROFILE_GetWineIniString( "spooler", pszOutput, "", psCmd, sizeof(psCmd) );
|
|
TRACE(win16drv, "Got printerSpoolCommand '%s' for output device '%s'\n",
|
|
psCmd, pszOutput);
|
|
if (!*psCmd)
|
|
psCmdP = pszOutput;
|
|
else
|
|
{
|
|
while (*psCmdP && isspace(*psCmdP))
|
|
{
|
|
psCmdP++;
|
|
};
|
|
if (!*psCmdP)
|
|
return -1;
|
|
}
|
|
if (*psCmdP == '|')
|
|
{
|
|
int fds[2];
|
|
if (pipe(fds))
|
|
return -1;
|
|
if (fork() == 0)
|
|
{
|
|
psCmdP++;
|
|
|
|
TRACE(win16drv, "In child need to exec %s\n",psCmdP);
|
|
close(0);
|
|
dup2(fds[0],0);
|
|
close (fds[1]);
|
|
system(psCmdP);
|
|
exit(0);
|
|
|
|
}
|
|
close (fds[0]);
|
|
fd = fds[1];
|
|
TRACE(win16drv,"Need to execute a cmnd and pipe the output to it\n");
|
|
}
|
|
else
|
|
{
|
|
TRACE(win16drv, "Just assume its a file\n");
|
|
|
|
if ((fd = open(psCmdP, O_CREAT | O_TRUNC | O_WRONLY , 0600)) < 0)
|
|
{
|
|
ERR(win16drv, "Failed to create spool file %s, errno = %d\n",
|
|
psCmdP, errno);
|
|
}
|
|
}
|
|
return fd;
|
|
}
|
|
|
|
static int FreePrintJob(HANDLE16 hJob)
|
|
{
|
|
int nRet = SP_ERROR;
|
|
PPRINTJOB pPrintJob;
|
|
|
|
pPrintJob = FindPrintJobFromHandle(hJob);
|
|
if (pPrintJob != NULL)
|
|
{
|
|
gPrintJobsTable[pPrintJob->nIndex] = NULL;
|
|
free(pPrintJob->pszOutput);
|
|
free(pPrintJob->pszTitle);
|
|
if (pPrintJob->fd >= 0) close(pPrintJob->fd);
|
|
free(pPrintJob);
|
|
nRet = SP_OK;
|
|
}
|
|
return nRet;
|
|
}
|
|
|
|
HANDLE16 WINAPI OpenJob(LPSTR lpOutput, LPSTR lpTitle, HDC16 hDC)
|
|
{
|
|
HANDLE16 hHandle = (HANDLE16)SP_ERROR;
|
|
PPRINTJOB pPrintJob;
|
|
|
|
TRACE(win16drv, "'%s' '%s' %04x\n", lpOutput, lpTitle, hDC);
|
|
|
|
pPrintJob = gPrintJobsTable[0];
|
|
if (pPrintJob == NULL)
|
|
{
|
|
int fd;
|
|
|
|
/* Try an create a spool file */
|
|
fd = CreateSpoolFile(lpOutput);
|
|
if (fd >= 0)
|
|
{
|
|
hHandle = 1;
|
|
|
|
pPrintJob = malloc(sizeof(PRINTJOB));
|
|
memset(pPrintJob, 0, sizeof(PRINTJOB));
|
|
|
|
pPrintJob->pszOutput = strdup(lpOutput);
|
|
pPrintJob->pszTitle = strdup(lpTitle);
|
|
pPrintJob->hDC = hDC;
|
|
pPrintJob->fd = fd;
|
|
pPrintJob->nIndex = 0;
|
|
pPrintJob->hHandle = hHandle;
|
|
gPrintJobsTable[pPrintJob->nIndex] = pPrintJob;
|
|
}
|
|
}
|
|
TRACE(win16drv, "return %04x\n", hHandle);
|
|
return hHandle;
|
|
}
|
|
|
|
int WINAPI CloseJob(HANDLE16 hJob)
|
|
{
|
|
int nRet = SP_ERROR;
|
|
PPRINTJOB pPrintJob = NULL;
|
|
|
|
TRACE(win16drv, "%04x\n", hJob);
|
|
|
|
pPrintJob = FindPrintJobFromHandle(hJob);
|
|
if (pPrintJob != NULL)
|
|
{
|
|
/* Close the spool file */
|
|
close(pPrintJob->fd);
|
|
FreePrintJob(hJob);
|
|
nRet = 1;
|
|
}
|
|
return nRet;
|
|
}
|
|
|
|
int WINAPI WriteSpool(HANDLE16 hJob, LPSTR lpData, WORD cch)
|
|
{
|
|
int nRet = SP_ERROR;
|
|
PPRINTJOB pPrintJob = NULL;
|
|
|
|
TRACE(win16drv, "%04x %08lx %04x\n", hJob, (DWORD)lpData, cch);
|
|
|
|
pPrintJob = FindPrintJobFromHandle(hJob);
|
|
if (pPrintJob != NULL && pPrintJob->fd >= 0 && cch)
|
|
{
|
|
if (write(pPrintJob->fd, lpData, cch) != cch)
|
|
nRet = SP_OUTOFDISK;
|
|
else
|
|
nRet = cch;
|
|
if (pPrintJob->hDC == 0) {
|
|
ERR(print, "hDC == 0 !\n");
|
|
return SP_ERROR;
|
|
}
|
|
if (!(QueryAbort(pPrintJob->hDC, (nRet == SP_OUTOFDISK) ? nRet : 0 )))
|
|
{
|
|
CloseJob(hJob); /* printing aborted */
|
|
nRet = SP_APPABORT;
|
|
}
|
|
}
|
|
return nRet;
|
|
}
|
|
|
|
int WINAPI WriteDialog(HANDLE16 hJob, LPSTR lpMsg, WORD cchMsg)
|
|
{
|
|
int nRet = 0;
|
|
|
|
TRACE(win16drv, "%04x %04x '%s'\n", hJob, cchMsg, lpMsg);
|
|
|
|
nRet = MessageBox16(0, lpMsg, "Printing Error", MB_OKCANCEL);
|
|
return nRet;
|
|
}
|
|
|
|
int WINAPI DeleteJob(HANDLE16 hJob, WORD wNotUsed)
|
|
{
|
|
int nRet;
|
|
|
|
TRACE(win16drv, "%04x\n", hJob);
|
|
|
|
nRet = FreePrintJob(hJob);
|
|
return nRet;
|
|
}
|
|
|
|
/*
|
|
* The following two function would allow a page to be sent to the printer
|
|
* when it has been processed. For simplicity they havn't been implemented.
|
|
* This means a whole job has to be processed before it is sent to the printer.
|
|
*/
|
|
int WINAPI StartSpoolPage(HANDLE16 hJob)
|
|
{
|
|
FIXME(win16drv, "StartSpoolPage GDI.246 unimplemented\n");
|
|
return 1;
|
|
|
|
}
|
|
int WINAPI EndSpoolPage(HANDLE16 hJob)
|
|
{
|
|
FIXME(win16drv, "EndSpoolPage GDI.247 unimplemented\n");
|
|
return 1;
|
|
}
|
|
|
|
|
|
DWORD WINAPI GetSpoolJob(int nOption, LONG param)
|
|
{
|
|
DWORD retval = 0;
|
|
TRACE(win16drv, "In GetSpoolJob param 0x%lx noption %d\n",param, nOption);
|
|
return retval;
|
|
}
|