2 * Exported functions from the PostScript driver.
4 * [Ext]DeviceMode, DeviceCapabilities, AdvancedSetupDialog.
6 * Will need ExtTextOut for winword6 (urgh!)
8 * Copyright 1998 Huw D M Davies
20 static LONG Resolutions[][2] = { {600,600} };
23 /************************************************************************
27 * Updates dm1 with some fields from dm2
30 void PSDRV_MergeDevmodes(PSDRV_DEVMODE16 *dm1, PSDRV_DEVMODE16 *dm2,
33 /* some sanity checks here on dm2 */
34 if(dm2->dmPublic.dmFields & DM_ORIENTATION)
35 dm1->dmPublic.dmOrientation = dm2->dmPublic.dmOrientation;
36 /* NB PaperWidth is always < PaperLength */
38 if(dm2->dmPublic.dmFields & DM_PAPERSIZE) {
41 for(page = pi->ppd->PageSizes; page; page = page->next) {
42 if(page->WinPage == dm2->dmPublic.dmPaperSize)
46 dm1->dmPublic.dmPaperSize = dm2->dmPublic.dmPaperSize;
47 dm1->dmPublic.dmPaperWidth = page->PaperDimension->x * 25.4 / 72.0;
48 dm1->dmPublic.dmPaperLength = page->PaperDimension->y * 25.4 / 72.0;
49 TRACE(psdrv, "Changing page to %s %d x %d\n", page->FullName,
50 dm1->dmPublic.dmPaperWidth, dm1->dmPublic.dmPaperLength );
52 TRACE(psdrv, "Trying to change to unsupported pagesize %d\n",
53 dm2->dmPublic.dmPaperSize);
57 if(dm2->dmPublic.dmFields & DM_DEFAULTSOURCE) {
60 for(slot = pi->ppd->InputSlots; slot; slot = slot->next) {
61 if(slot->WinBin == dm2->dmPublic.dmDefaultSource)
65 dm1->dmPublic.dmDefaultSource = dm2->dmPublic.dmDefaultSource;
66 TRACE(psdrv, "Changing bin to '%s'\n", slot->FullName);
68 TRACE(psdrv, "Trying to change to unsupported bin %d\n",
69 dm2->dmPublic.dmDefaultSource);
80 /*******************************************************************
82 * PSDRV_NewPrinterDlgProc32
86 LRESULT WINAPI PSDRV_NewPrinterDlgProc32(HWND32 hWnd, UINT32 wMsg,
87 WPARAM32 wParam, LPARAM lParam)
91 TRACE(psdrv,"WM_INITDIALOG lParam=%08lX\n", lParam);
92 ShowWindow32(hWnd, SW_SHOWNORMAL);
96 switch (LOWORD(wParam)) {
98 EndDialog32(hWnd, TRUE);
102 EndDialog32(hWnd, FALSE);
114 LRESULT WINAPI PSDRV_AdvancedSetupDlgProc32(HWND32 hWnd, UINT32 wMsg,
115 WPARAM32 wParam, LPARAM lParam)
119 TRACE(psdrv,"WM_INITDIALOG lParam=%08lX\n", lParam);
120 SendDlgItemMessage32A(hWnd, 99, CB_ADDSTRING32, 0,
121 (LPARAM)"Default Tray");
122 ShowWindow32(hWnd, SW_SHOWNORMAL);
126 switch (LOWORD(wParam)) {
128 EndDialog32(hWnd, TRUE);
132 EndDialog32(hWnd, FALSE);
136 DialogBoxIndirectParam32A( WIN_GetWindowInstance( hWnd ),
137 SYSRES_GetResPtr( SYSRES_DIALOG_PSDRV_NEWPRINTER ),
138 hWnd, PSDRV_NewPrinterDlgProc32, (LPARAM) NULL );
151 /**************************************************************
153 * PSDRV_AdvancedSetupDialog16 [WINEPS.93]
155 * Presumably dev1 and dev2 are in and out, don't know which is which yet.
156 * Not sure about return value either. (I haven't got any docs on this at all)
159 INT16 WINAPI PSDRV_AdvancedSetupDialog16(HWND16 hwnd, HANDLE16 hDriver,
160 LPDEVMODE16 dev1, LPDEVMODE16 dev2 )
163 TRACE(psdrv, "hwnd = %04x, hDriver = %04x dev1=%p dev2=%p\n", hwnd,
164 hDriver, dev1, dev2);
169 return DialogBoxIndirectParam32A( WIN_GetWindowInstance( hwnd ),
170 SYSRES_GetResPtr( SYSRES_DIALOG_PSDRV_ADVANCEDSETUP ),
171 hwnd, PSDRV_AdvancedSetupDlgProc32, (LPARAM) NULL );
177 /***************************************************************
179 * PSDRV_ExtDeviceMode16 [WINEPS.90]
181 * Just returns default devmode at the moment
183 INT16 WINAPI PSDRV_ExtDeviceMode16(HWND16 hwnd, HANDLE16 hDriver,
184 LPDEVMODE16 lpdmOutput, LPSTR lpszDevice, LPSTR lpszPort,
185 LPDEVMODE16 lpdmInput, LPSTR lpszProfile, WORD fwMode)
187 PRINTERINFO *pi = PSDRV_FindPrinterInfo(lpszDevice);
190 "(hwnd=%04x, hDriver=%04x, devOut=%p, Device='%s', Port='%s', devIn=%p, Profile='%s', Mode=%04x)\n",
191 hwnd, hDriver, lpdmOutput, lpszDevice, lpszPort, lpdmInput, lpszProfile,
195 return sizeof(DEVMODE16); /* Just copy dmPublic bit of PSDRV_DEVMODE */
197 if((fwMode & DM_PROMPT) || (fwMode & DM_UPDATE))
198 FIXME(psdrv, "Mode %d not implemented\n", fwMode);
200 if(fwMode & DM_MODIFY) {
201 TRACE(psdrv, "DM_MODIFY set. devIn->dmFields = %08lx\n", lpdmInput->dmFields);
202 PSDRV_MergeDevmodes(pi->Devmode, (PSDRV_DEVMODE16 *)lpdmInput, pi);
205 if(fwMode & DM_COPY) {
206 memcpy(lpdmOutput, pi->Devmode, sizeof(DEVMODE16));
212 /***************************************************************
214 * PSDRV_DeviceCapabilities16 [WINEPS.91]
217 DWORD WINAPI PSDRV_DeviceCapabilities16(LPSTR lpszDevice, LPSTR lpszPort,
218 WORD fwCapability, LPSTR lpszOutput, LPDEVMODE16 lpdm)
222 pi = PSDRV_FindPrinterInfo(lpszDevice);
223 TRACE(psdrv, "Cap=%d. Got PrinterInfo = %p\n", fwCapability, pi);
225 switch(fwCapability) {
230 WORD *wp = (WORD *)lpszOutput;
233 for(ps = pi->ppd->PageSizes; ps; ps = ps->next, i++)
234 if(lpszOutput != NULL)
242 POINT16 *pt = (POINT16 *)lpszOutput;
245 for(ps = pi->ppd->PageSizes; ps; ps = ps->next, i++)
246 if(lpszOutput != NULL) {
247 pt->x = ps->PaperDimension->x * 254.0 / 72.0;
248 pt->y = ps->PaperDimension->y * 254.0 / 72.0;
257 char *cp = lpszOutput;
260 for(ps = pi->ppd->PageSizes; ps; ps = ps->next, i++)
261 if(lpszOutput != NULL) {
262 strncpy(cp, ps->FullName, 64);
270 return pi->ppd->LandscapeOrientation ? pi->ppd->LandscapeOrientation : 90;
275 WORD *wp = (WORD *)lpszOutput;
278 for(slot = pi->ppd->InputSlots; slot; slot = slot->next, i++)
279 if(lpszOutput != NULL)
280 *wp++ = slot->WinBin;
287 char *cp = lpszOutput;
290 for(slot = pi->ppd->InputSlots; slot; slot = slot->next, i++)
291 if(lpszOutput != NULL) {
292 strncpy(cp, slot->FullName, 24);
299 case DC_ENUMRESOLUTIONS:
300 if(lpszOutput != NULL)
301 memcpy(lpszOutput, Resolutions, sizeof(Resolutions));
302 return sizeof(Resolutions) / sizeof(Resolutions[0]);
306 FIXME(psdrv, "Unsupported capability %d\n", fwCapability);
311 /***************************************************************
313 * PSDRV_DeviceMode16 [WINEPS.13]
316 void WINAPI PSDRV_DeviceMode16(HWND16 hwnd, HANDLE16 hDriver,
317 LPSTR lpszDevice, LPSTR lpszPort)
319 PSDRV_ExtDeviceMode16( hwnd, hDriver, NULL, lpszDevice, lpszPort, NULL,