/* * COMMDLG - Print Dialog * * Copyright 1994 Martin Ayotte * Copyright 1996 Albrecht Kleine * Copyright 1999 Klaas van Gend */ #include #include #include #include "winbase.h" #include "wine/winbase16.h" #include "wine/winuser16.h" #include "ldt.h" #include "commdlg.h" #include "resource.h" #include "dialog.h" #include "dlgs.h" #include "module.h" #include "debugtools.h" #include "winproc.h" #include "cderr.h" #include "winspool.h" #include "winerror.h" DEFAULT_DEBUG_CHANNEL(commdlg) #include "cdlg.h" /* This PRINTDLGA internal structure stores * pointers to several throughout useful structures. * */ typedef struct { LPPRINTER_INFO_2A lpPrinterInfo; UINT CurrentPrinter; /* used as lpPrinterInfo[CurrentPrinter] */ UINT DefaultPrinter; /* used as lpPrinterInfo[DefaultPrinter] */ DWORD NrOfPrinterInfoEntries; LPPRINTDLGA lpPrintDlg; UINT HelpMessageID; HICON hCollateIcon; HICON hNoCollateIcon; } PRINT_PTRA; /* prototypes */ static BOOL PRINTDLG_ValidateAndDuplicateSettings(HWND hDlg, PRINT_PTRA* PrintStructures); /*********************************************************************** * PrintDlg16 (COMMDLG.20) */ BOOL16 WINAPI PrintDlg16( SEGPTR printdlg ) { HANDLE16 hInst; BOOL16 bRet = FALSE; LPCVOID template; HWND hwndDialog; HANDLE hResInfo, hDlgTmpl; LPSTR rscname; LPPRINTDLG16 lpPrint = (LPPRINTDLG16)PTR_SEG_TO_LIN(printdlg); TRACE("(%p) -- Flags=%08lX\n", lpPrint, lpPrint->Flags ); if (lpPrint->Flags & PD_RETURNDEFAULT) /* FIXME: should fill lpPrint->hDevMode and lpPrint->hDevNames here */ return TRUE; if (lpPrint->Flags & PD_PRINTSETUP) rscname = "PRINT_SETUP"; else rscname = "PRINT"; if (!(hResInfo = FindResourceA(COMMDLG_hInstance32, rscname, RT_DIALOGA))) { COMDLG32_SetCommDlgExtendedError(CDERR_FINDRESFAILURE); return FALSE; } if (!(hDlgTmpl = LoadResource(COMMDLG_hInstance32, hResInfo )) || !(template = LockResource( hDlgTmpl ))) { COMDLG32_SetCommDlgExtendedError(CDERR_LOADRESFAILURE); return FALSE; } hInst = GetWindowLongA( lpPrint->hwndOwner, GWL_HINSTANCE ); hwndDialog = DIALOG_CreateIndirect( hInst, template, TRUE, lpPrint->hwndOwner, (DLGPROC16)((lpPrint->Flags & PD_PRINTSETUP) ? /* FIXME: PrintSetupDlgProc */ PrintDlgProcA : PrintDlgProcA ), printdlg, WIN_PROC_32A ); if (hwndDialog) bRet = DIALOG_DoDialogBox( hwndDialog, lpPrint->hwndOwner); return bRet; } /*********************************************************************** * PrintDlgA (COMDLG32.17) * * Displays the the PRINT dialog box, which enables the user to specify * specific properties of the print job. * * (Note: according to the MS Platform SDK, this call was in the past * also used to display some PRINT SETUP dialog. As this is superseded * by PageSetupDlg, this now results in an error!) * * RETURNS * nonzero if the user pressed the OK button * zero if the user cancelled the window or an error occurred * * BUGS * The Collate Icons do not display, even though they are in the code. */ BOOL WINAPI PrintDlgA( LPPRINTDLGA lppd /* ptr to PRINTDLG32 struct */ ) { /* My implementing strategy: * * step 1: display the dialog and implement the layout-flags * step 2: enter valid information in the fields (e.g. real printers) * step 3: fix the RETURN-TRUE-ALWAYS Fixme by checking lppd->Flags for * PD_RETURNDEFAULT * step 4: implement all other specs * step 5: allow customisation of the dialog box * * current implementation is in step 3. */ HWND hwndDialog; BOOL bRet = FALSE; LPCVOID ptr; HANDLE hResInfo, hDlgTmpl; HINSTANCE hInst = GetWindowLongA( lppd->hwndOwner, GWL_HINSTANCE ); DWORD EnumBytesNeeded; DWORD CopyOfEnumBytesNeeded; PRINT_PTRA PrintStructures; FIXME("KVG (%p): stub\n", lppd); PrintStructures.lpPrintDlg = lppd; /* load Dialog */ if (!(hResInfo = FindResourceA(COMDLG32_hInstance, "PRINT32", RT_DIALOGA))) { COMDLG32_SetCommDlgExtendedError(CDERR_FINDRESFAILURE); return FALSE; } if (!(hDlgTmpl = LoadResource(COMDLG32_hInstance, hResInfo )) || !(ptr = LockResource( hDlgTmpl ))) { COMDLG32_SetCommDlgExtendedError(CDERR_LOADRESFAILURE); return FALSE; } /* load Collate ICON */ PrintStructures.hCollateIcon = LoadIconA(COMDLG32_hInstance, "PD32_COLLATE"); PrintStructures.hNoCollateIcon = LoadIconA(COMDLG32_hInstance, "PD32_NOCOLLATE"); if (PrintStructures.hCollateIcon==0 || PrintStructures.hNoCollateIcon==0) { ERR("no icon in resourcefile???"); COMDLG32_SetCommDlgExtendedError(CDERR_LOADRESFAILURE); return FALSE; } /* * if lppd->Flags PD_SHOWHELP is specified, a HELPMESGSTRING message * must be registered and the Help button must be shown. */ if (lppd->Flags & PD_SHOWHELP) { if((PrintStructures.HelpMessageID = RegisterWindowMessageA(HELPMSGSTRING)) == 0) { COMDLG32_SetCommDlgExtendedError(CDERR_REGISTERMSGFAIL); return FALSE; } } else PrintStructures.HelpMessageID=0; if (lppd->Flags & PD_PRINTSETUP) { FIXME(": PrintDlg was requested to display PrintSetup box.\n"); COMDLG32_SetCommDlgExtendedError(PDERR_INITFAILURE); return(FALSE); } /* Use EnumPrinters to obtain a list of PRINTER_INFO_2A's * and store a pointer to this list in our "global structure" * as reference for the rest of the PrintDlg routines */ EnumPrintersA(PRINTER_ENUM_LOCAL, NULL, 2, NULL, 0, &EnumBytesNeeded, &PrintStructures.NrOfPrinterInfoEntries); CopyOfEnumBytesNeeded=EnumBytesNeeded+16; PrintStructures.lpPrinterInfo = malloc(CopyOfEnumBytesNeeded*sizeof(char)); EnumPrintersA(PRINTER_ENUM_LOCAL, NULL, 2, (LPBYTE)PrintStructures.lpPrinterInfo, CopyOfEnumBytesNeeded, &EnumBytesNeeded, &PrintStructures.NrOfPrinterInfoEntries); /* Find the default printer. * If not: display a warning message (unless PD_NOWARNING specified) * and return PDERR_NODEFAULTPRN */ /* FIXME: not implemented yet!!! */ if (!PrintStructures.NrOfPrinterInfoEntries) { COMDLG32_SetCommDlgExtendedError(PDERR_NODEFAULTPRN); return FALSE; } PrintStructures.CurrentPrinter=0; PrintStructures.DefaultPrinter=0; /* FIXME: Currently Unimplemented */ if (lppd->Flags & PD_NOWARNING) { COMDLG32_SetCommDlgExtendedError(PDERR_INITFAILURE); WARN(": PD_NOWARNING Flag is not yet implemented.\n"); } /* * FIXME : Should respond to TEMPLATE and HOOK flags here * For now, only the standard dialog works. */ if (lppd->Flags & (PD_ENABLEPRINTHOOK | PD_ENABLEPRINTTEMPLATE | PD_ENABLEPRINTTEMPLATEHANDLE | PD_ENABLESETUPHOOK | PD_ENABLESETUPTEMPLATE|PD_ENABLESETUPTEMPLATEHANDLE)) FIXME(": unimplemented flag (ignored)\n"); /* * if lppd->Flags PD_RETURNDEFAULT is specified, the PrintDlg function * does not display the dialog box, but returns with valid entries * for hDevMode and hDevNames . * * According to MSDN, it is required that hDevMode and hDevNames equal * zero if this flag is set. */ if (lppd->Flags & PD_RETURNDEFAULT) { TRACE(" PD_RETURNDEFAULT: was requested to return printer info only.\n"); if (lppd->hDevMode!=0 || lppd->hDevNames !=0) { COMDLG32_SetCommDlgExtendedError(PDERR_INITFAILURE); return(FALSE); } return(PRINTDLG_ValidateAndDuplicateSettings(0, &PrintStructures)); } /* and create & process the dialog */ hwndDialog= DIALOG_CreateIndirect(hInst, ptr, TRUE, lppd->hwndOwner, (DLGPROC16)PrintDlgProcA, (LPARAM)&PrintStructures, WIN_PROC_32A ); if (hwndDialog) bRet = DIALOG_DoDialogBox(hwndDialog, lppd->hwndOwner); /* free memory & resources */ free(PrintStructures.lpPrinterInfo); DeleteObject(PrintStructures.hCollateIcon); DeleteObject(PrintStructures.hNoCollateIcon); TRACE(" exit! (%d)", bRet); return bRet; } /*********************************************************************** * PrintDlg32W (COMDLG32.18) */ BOOL WINAPI PrintDlgW( LPPRINTDLGW printdlg ) { FIXME("A really empty stub\n" ); return FALSE; } /*********************************************************************** * PRINTDLG_UpdatePrinterInfoTexts [internal] */ static void PRINTDLG_UpdatePrinterInfoTexts(HWND hDlg, PRINT_PTRA* PrintStructures) { char StatusMsg[256]; char ResourceString[256]; int i; LPPRINTER_INFO_2A lpPi = &(PrintStructures->lpPrinterInfo [PrintStructures->CurrentPrinter]); /* Status Message */ StatusMsg[0]='\0'; for (i=0; i< 25; i++) { if (lpPi->Status & (1<pDriverName); if (lpPi->pLocation != NULL && lpPi->pLocation[0]!='\0') SendDlgItemMessageA(hDlg, stc14, WM_SETTEXT, 0,(LPARAM)lpPi->pLocation); else SendDlgItemMessageA(hDlg, stc14, WM_SETTEXT, 0, (LPARAM)lpPi->pPortName); SendDlgItemMessageA(hDlg, stc13, WM_SETTEXT, 0, (LPARAM)lpPi->pComment); } /*********************************************************************** * PRINTDLG_WMInitDialog [internal] */ static LRESULT PRINTDLG_WMInitDialog(HWND hDlg, WPARAM wParam, LPARAM lParam, PRINT_PTRA* PrintStructures) { int i; LPPRINTDLGA lppd = PrintStructures->lpPrintDlg; LPPRINTER_INFO_2A lppi = PrintStructures->lpPrinterInfo; PDEVMODEA pDevMode = lppi[PrintStructures->CurrentPrinter].pDevMode; SetWindowLongA(hDlg, DWL_USER, lParam); TRACE("WM_INITDIALOG lParam=%08lX\n", lParam); if (lppd->lStructSize != sizeof(PRINTDLGA)) { FIXME("structure size failure !!!\n"); /* EndDialog (hDlg, 0); return FALSE; */ } /* Fill Combobox according to info from PRINTER_INFO2A * structure inside PrintStructures, * select the default printer and generate an * update-message to have the rest of the dialog box updated. */ for (i=0; i < PrintStructures->NrOfPrinterInfoEntries; i++) SendDlgItemMessageA(hDlg, cmb4, CB_ADDSTRING, 0, (LPARAM)lppi[i].pPrinterName ); i=SendDlgItemMessageA(hDlg, cmb4, CB_SELECTSTRING, (WPARAM) -1, (LPARAM) lppi[PrintStructures->CurrentPrinter].pPrinterName); SendDlgItemMessageA(hDlg, cmb4, CB_SETCURSEL, (WPARAM)i, (LPARAM)0); PRINTDLG_UpdatePrinterInfoTexts(hDlg, PrintStructures); /* Flag processing to set the according buttons on/off and * Initialise the various values */ /* Print range (All/Range/Selection) */ /* FIXME: I allow more freedom than either Win95 or WinNT, * which do not agree to what errors should be thrown or not * in case nToPage or nFromPage is out-of-range. */ if (lppd->nMaxPage < lppd->nMinPage) lppd->nMaxPage = lppd->nMinPage; if (lppd->nMinPage == lppd->nMaxPage) lppd->Flags |= PD_NOPAGENUMS; if (lppd->nToPage < lppd->nMinPage) lppd->nToPage = lppd->nMinPage; if (lppd->nToPage > lppd->nMaxPage) lppd->nToPage = lppd->nMaxPage; if (lppd->nFromPage < lppd->nMinPage) lppd->nFromPage = lppd->nMinPage; if (lppd->nFromPage > lppd->nMaxPage) lppd->nFromPage = lppd->nMaxPage; SetDlgItemInt(hDlg, edt1, lppd->nFromPage, FALSE); SetDlgItemInt(hDlg, edt2, lppd->nToPage, FALSE); CheckRadioButton(hDlg, rad1, rad3, rad1); /* default */ if (lppd->Flags & PD_NOSELECTION) EnableWindow(GetDlgItem(hDlg, rad2), FALSE); else if (lppd->Flags & PD_SELECTION) CheckRadioButton(hDlg, rad1, rad3, rad2); if (lppd->Flags & PD_NOPAGENUMS) { EnableWindow(GetDlgItem(hDlg, rad3), FALSE); EnableWindow(GetDlgItem(hDlg, stc2),FALSE); EnableWindow(GetDlgItem(hDlg, edt1), FALSE); EnableWindow(GetDlgItem(hDlg, stc3),FALSE); EnableWindow(GetDlgItem(hDlg, edt2), FALSE); } else { if (lppd->Flags & PD_PAGENUMS) CheckRadioButton(hDlg, rad1, rad3, rad3); } /* "All xxx pages"... */ { char resourcestr[64]; char result[64]; LoadStringA(COMDLG32_hInstance, PD32_PRINT_ALL_X_PAGES, resourcestr, 49); sprintf(result,resourcestr,lppd->nMaxPage - lppd->nMinPage + 1); SendDlgItemMessageA(hDlg, rad1, WM_SETTEXT, 0, (LPARAM) result); } /* Collate pages * * FIXME: The ico3 is not displayed for some reason. I don't know why. */ if (lppd->Flags & PD_COLLATE) { SendDlgItemMessageA(hDlg, ico3, STM_SETIMAGE, (WPARAM) IMAGE_ICON, (LPARAM)PrintStructures->hCollateIcon); CheckDlgButton(hDlg, chx2, 1); } else { SendDlgItemMessageA(hDlg, ico3, STM_SETIMAGE, (WPARAM) IMAGE_ICON, (LPARAM)PrintStructures->hNoCollateIcon); CheckDlgButton(hDlg, chx2, 0); } if (lppd->Flags & PD_USEDEVMODECOPIESANDCOLLATE || lppd->Flags & PD_USEDEVMODECOPIES) { /* if printer doesn't support it: no Collate */ if (!(pDevMode->dmFields & DM_COLLATE)) { EnableWindow(GetDlgItem(hDlg, chx2), FALSE); EnableWindow(GetDlgItem(hDlg, ico3), FALSE); } } /* nCopies */ if (lppd->hDevMode == 0) { SetDlgItemInt(hDlg, edt3, lppd->nCopies, FALSE); } else { SetDlgItemInt(hDlg, edt1, pDevMode->dmCopies, FALSE); } if (lppd->Flags & PD_USEDEVMODECOPIESANDCOLLATE || lppd->Flags & PD_USEDEVMODECOPIES) { /* if printer doesn't support it: no nCopies */ if (!(pDevMode->dmFields & DM_COPIES)) { EnableWindow(GetDlgItem(hDlg, edt3), FALSE); EnableWindow(GetDlgItem(hDlg, stc5), FALSE); } } /* print to file */ CheckDlgButton(hDlg, chx1, (lppd->Flags & PD_PRINTTOFILE) ? 1 : 0); if (lppd->Flags & PD_DISABLEPRINTTOFILE) EnableWindow(GetDlgItem(hDlg, chx1), FALSE); if (lppd->Flags & PD_HIDEPRINTTOFILE) ShowWindow(GetDlgItem(hDlg, chx1), SW_HIDE); /* help button */ if ((lppd->Flags & PD_SHOWHELP)==0) { /* hide if PD_SHOWHELP not specified */ ShowWindow(GetDlgItem(hDlg, pshHelp), SW_HIDE); } GlobalUnlock(lppd->hDevMode); return TRUE; } /*********************************************************************** * PRINTDLG_CreateDevNames [internal] * * * creates a DevNames structure. * RETURNS * HGLOBAL to DevNames memory object on success or * zero on faillure */ HGLOBAL PRINTDLG_CreateDevNames( char* DeviceDriverName, char* DeviceName, char* OutputPort, WORD Flags) { long size; HGLOBAL hDevNames; void* pDevNamesSpace; void* pTempPtr; LPDEVNAMES lpDevNames; size = strlen(DeviceDriverName) +1 + strlen(DeviceName) + 1 + strlen(OutputPort) + 1 + sizeof(DEVNAMES); hDevNames = GlobalAlloc(GMEM_MOVEABLE, size*sizeof(char)); if (hDevNames != 0) { pDevNamesSpace = GlobalLock(hDevNames); lpDevNames = (LPDEVNAMES) pDevNamesSpace; pTempPtr = pDevNamesSpace + sizeof(DEVNAMES); strcpy(pTempPtr, DeviceDriverName); lpDevNames->wDriverOffset = pTempPtr - pDevNamesSpace; pTempPtr += strlen(DeviceDriverName) + 1; strcpy(pTempPtr, DeviceName); lpDevNames->wDeviceOffset = pTempPtr - pDevNamesSpace; pTempPtr += strlen(DeviceName) + 1; strcpy(pTempPtr, OutputPort); lpDevNames->wOutputOffset = pTempPtr - pDevNamesSpace; lpDevNames->wDefault = Flags; GlobalUnlock(hDevNames); } return(hDevNames); } /*********************************************************************** * PRINTDLG_ValidateAndDuplicateSettings [internal] * * * updates the PrintDlg structure for returnvalues. * (yep, the name was chosen a bit stupid...) * * if hDlg equals zero, only hDevModes and hDevNames are adapted. * * RETURNS * FALSE if user is not allowed to close (i.e. wrong nTo or nFrom values) * TRUE if succesful. */ static BOOL PRINTDLG_ValidateAndDuplicateSettings(HWND hDlg, PRINT_PTRA* PrintStructures) { LPPRINTER_INFO_2A lpPi = &(PrintStructures->lpPrinterInfo [PrintStructures->CurrentPrinter]); LPPRINTDLGA lppd = PrintStructures->lpPrintDlg; PDEVMODEA pDevMode; if (hDlg!=0) { /* check whether nFromPage and nToPage are within range defined by * nMinPage and nMaxPage */ if (IsDlgButtonChecked(hDlg, rad3) == BST_CHECKED) { WORD nToPage; WORD nFromPage; nFromPage = GetDlgItemInt(hDlg, edt1, NULL, FALSE); nToPage = GetDlgItemInt(hDlg, edt2, NULL, FALSE); if (nFromPage < lppd->nMinPage || nFromPage > lppd->nMaxPage || nToPage < lppd->nMinPage || nToPage > lppd->nMaxPage) { char resourcestr[256]; char resultstr[256]; LoadStringA(COMDLG32_hInstance, PD32_INVALID_PAGE_RANGE, resourcestr, 255); sprintf(resultstr,resourcestr, lppd->nMinPage, lppd->nMaxPage); LoadStringA(COMDLG32_hInstance, PD32_PRINT_TITLE, resourcestr, 255); MessageBoxA(hDlg, resultstr, resourcestr, MB_OK | MB_ICONWARNING); return(FALSE); } lppd->nFromPage = nFromPage; lppd->nToPage = nToPage; } if (IsDlgButtonChecked(hDlg, chx1) == BST_CHECKED) { lppd->Flags |= PD_PRINTTOFILE; lpPi->pPortName = "FILE:"; } if (IsDlgButtonChecked(hDlg, chx2) == BST_CHECKED) { FIXME("Collate lppd not yet implemented as output\n"); } } /* end-of-if(hDlg!=0) */ /* * create or modify hDevMode */ if (lppd->hDevMode == 0) { TRACE(" No hDevMode yet... Need to create my own\n"); /* FIXME: possible memory leak? Memory never freed again! */ lppd->hDevMode = GlobalAlloc(GMEM_MOVEABLE, lpPi->pDevMode->dmSize); pDevMode = GlobalLock(lppd->hDevMode); memcpy(pDevMode, lpPi->pDevMode, lpPi->pDevMode->dmSize); } else { FIXME(" already hDevMode... must adjust it... Not implemented yet\n"); pDevMode = GlobalLock(lppd->hDevMode); } /* If hDevNames already exists, trash it. * But create a new one anyway */ if (lppd->hDevNames != 0) { if ( (GlobalFlags(lppd->hDevNames)&0xFF) != 0) ERR(" Tried to free hDevNames, but your application still has a" " lock on hDevNames. Possible program crash..."); GlobalFree(lppd->hDevNames); } /* FIXME: The first entry of DevNames is fixed to "winspool", * because I don't know of any printerdriver which doesn't return * winspool there. But I guess they do exist... */ lppd->hDevNames = PRINTDLG_CreateDevNames("winspool", lpPi->pDriverName, lpPi->pPortName, (PrintStructures->DefaultPrinter == PrintStructures->CurrentPrinter)?1:0); /* set PD_Collate and nCopies */ if (lppd->Flags & PD_USEDEVMODECOPIESANDCOLLATE || lppd->Flags & PD_USEDEVMODECOPIES) { /* if one of the above flags was set, the application doesn't * (want to) support multiple copies or collate... */ lppd->Flags &= ~PD_COLLATE; lppd->nCopies = 1; /* if the printer driver supports it... store info there * otherwise no collate & multiple copies ! */ if (pDevMode->dmFields & DM_COLLATE) { if (IsDlgButtonChecked(hDlg, chx2) == BST_CHECKED) pDevMode->dmCollate = 1; else pDevMode->dmCollate = 0; } if (pDevMode->dmFields & DM_COPIES) { WORD nCopies = GetDlgItemInt(hDlg, edt3, NULL, FALSE); pDevMode->dmCopies = nCopies; } } else { /* set Collate & nCopies according to dialog */ if (IsDlgButtonChecked(hDlg, chx2) == BST_CHECKED) lppd->Flags |= PD_COLLATE; else lppd->Flags &= ~PD_COLLATE; lppd->nCopies = GetDlgItemInt(hDlg, edt3, NULL, FALSE); } GlobalUnlock(lppd->hDevMode); return(TRUE); } /*********************************************************************** * PRINTDLG_WMCommand [internal] */ static LRESULT PRINTDLG_WMCommand(HWND hDlg, WPARAM wParam, LPARAM lParam, PRINT_PTRA* PrintStructures) { LPPRINTDLGA lppd = PrintStructures->lpPrintDlg; LPPRINTER_INFO_2A lppi = &(PrintStructures->lpPrinterInfo [PrintStructures->CurrentPrinter]); switch (LOWORD(wParam)) { case IDOK: TRACE(" OK button was hit\n"); if (PRINTDLG_ValidateAndDuplicateSettings(hDlg, PrintStructures) != TRUE) return(FALSE); DestroyWindow(hDlg); return(TRUE); case IDCANCEL: TRACE(" CANCEL button was hit\n"); EndDialog(hDlg, FALSE); return(FALSE); case pshHelp: TRACE(" HELP button was hit\n"); SendMessageA(lppd->hwndOwner, PrintStructures->HelpMessageID, (WPARAM) hDlg, (LPARAM) lppd); break; case chx2: /* collate pages checkbox */ if (IsDlgButtonChecked(hDlg, chx2) == BST_CHECKED) SendDlgItemMessageA(hDlg, ico3, STM_SETIMAGE, (WPARAM) IMAGE_ICON, (LPARAM)PrintStructures->hCollateIcon); else SendDlgItemMessageA(hDlg, ico3, STM_SETIMAGE, (WPARAM) IMAGE_ICON, (LPARAM)PrintStructures->hNoCollateIcon); break; case edt1: /* from page nr editbox */ case edt2: /* to page nr editbox */ if (HIWORD(wParam)==EN_CHANGE) { WORD nToPage; WORD nFromPage; nFromPage = GetDlgItemInt(hDlg, edt1, NULL, FALSE); nToPage = GetDlgItemInt(hDlg, edt2, NULL, FALSE); if (nFromPage != lppd->nFromPage || nToPage != lppd->nToPage) CheckRadioButton(hDlg, rad1, rad3, rad3); } break; case psh2: /* Properties button */ { HANDLE hPrinter; char PrinterName[256]; GetDlgItemTextA(hDlg, cmb4, PrinterName, 255); if (OpenPrinterA(PrinterName, &hPrinter, NULL)) { PrinterProperties(hDlg, hPrinter); ClosePrinter(hPrinter); } else WARN(" Call to OpenPrinter did not succeed!\n"); break; } case cmb4: /* Printer combobox */ if (HIWORD(wParam)==CBN_SELCHANGE) { int i; char PrinterName[256]; /* look the newly selected Printer up in * our array Printer_Info2As */ GetDlgItemTextA(hDlg, cmb4, PrinterName, 255); for (i=0; i < PrintStructures->NrOfPrinterInfoEntries; i++) { if (strcmp(PrintStructures->lpPrinterInfo[i].pPrinterName, PrinterName)==0) break; } PrintStructures->CurrentPrinter = i; PRINTDLG_UpdatePrinterInfoTexts(hDlg, PrintStructures); lppi = &(PrintStructures->lpPrinterInfo [PrintStructures->CurrentPrinter]); if (lppd->Flags & PD_USEDEVMODECOPIESANDCOLLATE || lppd->Flags & PD_USEDEVMODECOPIES) { /* if printer doesn't support it: no nCopies */ if (!(lppi->pDevMode->dmFields & DM_COPIES)) { EnableWindow(GetDlgItem(hDlg, edt3), FALSE); EnableWindow(GetDlgItem(hDlg, stc5), FALSE); } else { EnableWindow(GetDlgItem(hDlg, edt3), TRUE); EnableWindow(GetDlgItem(hDlg, stc5), TRUE); } /* if printer doesn't support it: no Collate */ if (!(lppi->pDevMode->dmFields & DM_COPIES)) { EnableWindow(GetDlgItem(hDlg, ico3), FALSE); EnableWindow(GetDlgItem(hDlg, chx2), FALSE); } else { EnableWindow(GetDlgItem(hDlg, ico3), TRUE); EnableWindow(GetDlgItem(hDlg, chx2), TRUE); } } } break; } return FALSE; } /*********************************************************************** * PrintDlgProcA [internal] */ LRESULT WINAPI PrintDlgProcA(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) { PRINT_PTRA* PrintStructures; LRESULT res=FALSE; if (uMsg!=WM_INITDIALOG) { PrintStructures = (PRINT_PTRA*) GetWindowLongA(hDlg, DWL_USER); if (!PrintStructures) return FALSE; } else { PrintStructures=(PRINT_PTRA*) lParam; if (!PRINTDLG_WMInitDialog(hDlg, wParam, lParam, PrintStructures)) { TRACE("PRINTDLG_WMInitDialog returned FALSE\n"); return FALSE; } } switch (uMsg) { case WM_COMMAND: return PRINTDLG_WMCommand(hDlg, wParam, lParam, PrintStructures); case WM_DESTROY: return FALSE; } return res; } /*********************************************************************** * PrintDlgProc16 (COMMDLG.21) */ LRESULT WINAPI PrintDlgProc16(HWND16 hWnd, UINT16 wMsg, WPARAM16 wParam, LPARAM lParam) { switch (wMsg) { case WM_INITDIALOG: TRACE("WM_INITDIALOG lParam=%08lX\n", lParam); ShowWindow16(hWnd, SW_SHOWNORMAL); return (TRUE); case WM_COMMAND: switch (wParam) { case IDOK: EndDialog(hWnd, TRUE); return(TRUE); case IDCANCEL: EndDialog(hWnd, FALSE); return(TRUE); } return(FALSE); } return FALSE; } /*********************************************************************** * PrintSetupDlgProc (COMMDLG.22) */ LRESULT WINAPI PrintSetupDlgProc16(HWND16 hWnd, UINT16 wMsg, WPARAM16 wParam, LPARAM lParam) { switch (wMsg) { case WM_INITDIALOG: TRACE("WM_INITDIALOG lParam=%08lX\n", lParam); ShowWindow16(hWnd, SW_SHOWNORMAL); return (TRUE); case WM_COMMAND: switch (wParam) { case IDOK: EndDialog(hWnd, TRUE); return(TRUE); case IDCANCEL: EndDialog(hWnd, FALSE); return(TRUE); } return(FALSE); } return FALSE; } /*********************************************************************** * PageSetupDlgA (COMDLG32.15) */ BOOL WINAPI PageSetupDlgA(LPPAGESETUPDLGA setupdlg) { FIXME("(%p), stub!\n",setupdlg); return FALSE; }