|
|
/*++
Copyright (c) 1996 Microsoft Corporation
Module Name:
driverui.h
Abstract:
Header file for driverui.c
Environment:
Win32 subsystem, DriverUI module, user mode
Revision History:
02/09/97 -davidx- Consistent handling of common printer info (COMMONINFO)
02/04/97 -davidx- Reorganize driver UI to separate ps and uni DLLs.
07/17/96 -amandan- Created it.
--*/
#ifndef _DRIVERUI_H_
#define _DRIVERUI_H_
//
// Global critical section used when accessing shared data
//
extern CRITICAL_SECTION gCriticalSection;
#define ENTER_CRITICAL_SECTION() EnterCriticalSection(&gCriticalSection)
#define LEAVE_CRITICAL_SECTION() LeaveCriticalSection(&gCriticalSection)
//
// Allocate zero-filled memory from a heap
//
#define HEAPALLOC(hheap,size) HeapAlloc(hheap, HEAP_ZERO_MEMORY, size)
#define HEAPREALLOC(hheap, pOrig, size) HeapReAlloc(hheap, HEAP_ZERO_MEMORY, pOrig, size)
//
// Various hardcoded limits
//
#define CCHBINNAME 24 // max length for bin names
#define CCHPAPERNAME 64 // max length for form names
#define CCHMEDIATYPENAME 64 // max length for mediatype names
#define CCHLANGNAME 32 // max length for language strings
#define MIN_OPTIONS_ALLOWED 2
#define UNUSED_PARAM 0xFFFFFFFF
//
// PostScript and UniDriver driver private devmode
//
#ifdef PSCRIPT
#define PDRIVEREXTRA PPSDRVEXTRA
#endif
#ifdef UNIDRV
#define PDRIVEREXTRA PUNIDRVEXTRA
typedef struct _WINRESDATA WINRESDATA; #endif
#define PGetDevmodeOptionsArray(pdm) \
(((PDRIVEREXTRA) GET_DRIVER_PRIVATE_DEVMODE(pdm))->aOptions)
#define GETUSERDATASIZE(UserData) \
( ((PUSERDATA)(UserData))->dwSize )
#define GETUSERDATAITEM(UserData) \
( ((PUSERDATA)(UserData))->dwItemID )
#define GETUSERDATAKEYWORDNAME(UserData) \
( ((PUSERDATA)(UserData))->pKeyWordName )
#define SETUSERDATAID(pOptItem, dwID) \
( ((PUSERDATA)((pOptItem)->UserData))->dwItemID = dwID)
#define SETUSERDATA_SIZE(pOptItem, dwSize) \
( ((PUSERDATA)((pOptItem)->UserData))->dwSize = dwSize)
#define SETUSERDATA_KEYWORDNAME(ci, pOptItem, pFeature) \
((PUSERDATA)((pOptItem)->UserData))->pKeyWordName = \ OFFSET_TO_POINTER(ci.pUIInfo->pubResourceData, pFeature->loKeywordName)
//
// Common data structure which is needed whether UI comes up or not
//
typedef struct _COMMONINFO {
OEMUIOBJ oemuiobj; // support info for OEM plugins
PVOID pvStartSign; // signature
PTSTR pPrinterName; // current printer name
HANDLE hPrinter; // handle to current printer
DWORD dwFlags; // miscellaneous flag bits
PDRIVER_INFO_3 pDriverInfo3; // driver info level 3
PRAWBINARYDATA pRawData; // raw printer description data
PINFOHEADER pInfoHeader; // current printer description data instance
PUIINFO pUIInfo; // UIINFO structure inside above instance
POEM_PLUGINS pOemPlugins; // OEM plugin information
PDEVMODE pdm; // devmode information
PDRIVEREXTRA pdmPrivate; // driver private devmode fields
PPRINTERDATA pPrinterData; // printer-sticky property data
POPTSELECT pCombinedOptions; // combined options array
PFORM_INFO_1 pSplForms; // spooler forms
DWORD dwSplForms; // number of spooler forms
HANDLE hHeap; // heap used to display UI
#ifdef UNIDRV
WINRESDATA *pWinResData;
#endif
} COMMONINFO, *PCOMMONINFO;
//
// Flag constants for COMMONINFO.dwFlags field
//
#define FLAG_OPENPRINTER_NORMAL 0x0001
#define FLAG_OPEN_CONDITIONAL 0x0002
#define FLAG_OPENPRINTER_ADMIN 0x0004
#define FLAG_INIT_PRINTER 0x0008
#define FLAG_ALLOCATE_UIDATA 0x0010
#define FLAG_PROCESS_INIFILE 0x0020
#define FLAG_REFRESH_PARSED_DATA 0x0040
#define FLAG_WITHIN_PLUGINCALL 0x0080
#define FLAG_APPLYNOW_CALLED 0x0100
#define FLAG_PLUGIN_CHANGED_OPTITEM 0x0200
#define FLAG_USER_CHANGED_FREEMEM 0x0400
#define FLAG_PROPSHEET_SESSION 0x0800
#define FLAG_UPGRADE_PRINTER 0x1000
#define IS_WITHIN_PROPSHEET_SESSION(pci) ((pci)->dwFlags & FLAG_PROPSHEET_SESSION)
//
// Special entry point for getting around EnumForm bug in spooler
//
DWORD DrvSplDeviceCaps( HANDLE hPrinter, PWSTR pDeviceName, WORD wCapability, PVOID pOutput, DWORD dwOutputSize, PDEVMODE pdmSrc );
//
// Load basic information needed by the driver UI
//
PCOMMONINFO PLoadCommonInfo( IN HANDLE hPrinter, IN PTSTR ptstrPrinterName, IN DWORD dwFlags );
//
// Release common information used by the driver UI
//
VOID VFreeCommonInfo( IN PCOMMONINFO pci );
//
// Populate the devmode fields in the COMMONINFO structure
//
BOOL BFillCommonInfoDevmode( IN OUT PCOMMONINFO pci, IN PDEVMODE pdmPrinter, IN PDEVMODE pdmInput );
//
// Populate the printer-sticky property data field
//
BOOL BFillCommonInfoPrinterData( IN OUT PCOMMONINFO pci );
//
// Combined document-sticky feature selections and printer-sticky
// feature selection into a single options array
//
BOOL BCombineCommonInfoOptionsArray( IN OUT PCOMMONINFO pci );
//
// Get an updated printer description data instance
// using the combined options array
//
BOOL BUpdateUIInfo( IN OUT PCOMMONINFO pci );
//
// Fix up combined options array with information from public devmode fields
//
VOID VFixOptionsArrayWithDevmode( IN OUT PCOMMONINFO pci );
//
// Convert option array setting into public devmode fields
//
VOID VOptionsToDevmodeFields( IN OUT PCOMMONINFO pci, IN BOOL bUpdateFormFields );
#ifndef WINNT_40
//
// Notify DS of update
//
VOID VNotifyDSOfUpdate( IN HANDLE hPrinter ); #endif
//
// Get a read-only copy of a display name:
// 1) if the display name is in the binary printer description data,
// then we simply return a pointer to that data.
// 2) otherwise, the display name is in the resource DLL.
// we allocate memory out of the driver's heap and
// load the string.
//
// Caller should NOT free the returned pointer. The memory
// will go away when the binary printer description data is unloaded
// or when the driver's heap is destroyed.
//
// Since PSCRIPT currently doesn't have any resource DLL,
// we define this as a macro to save a function call.
//
#ifdef PSCRIPT
#define PGetReadOnlyDisplayName(pci, loOffset) \
OFFSET_TO_POINTER((pci)->pUIInfo->pubResourceData, (loOffset))
#else
PWSTR PGetReadOnlyDisplayName( PCOMMONINFO pci, PTRREF loOffset );
#endif
//
// This macro is defined as a convenience to get a read-only
// copy of the display name for an option.
//
#define GET_OPTION_DISPLAY_NAME(pci, pOption) \
PGetReadOnlyDisplayName(pci, ((POPTION) (pOption))->loDisplayName)
//
// This function is similar to PGetReadOnlyDisplayName
// but the caller must provide the buffer for loading the string.
//
BOOL BLoadDisplayNameString( PCOMMONINFO pci, PTRREF loOffset, PWSTR pwstrBuf, INT iMaxChars );
BOOL BLoadPageSizeNameString( PCOMMONINFO pci, PTRREF loOffset, PWSTR pwstrBuf, INT iMaxChars, INT iStdID );
//
// Convenience macro for loading the display name of an option
// into a caller-provided buffer.
//
#define LOAD_STRING_OPTION_NAME(pci, pOption, pwch, maxsize) \
BLoadDisplayNameString(pci, ((POPTION) (pOption))->loDisplayName, pwch, maxsize)
#define LOAD_STRING_PAGESIZE_NAME(pci, pPageSize, pwch, maxsize) \
BLoadPageSizeNameString(pci, (pPageSize)->GenericOption.loDisplayName, pwch, maxsize, (pPageSize)->dwPaperSizeID)
//
// Load icon resource from the resource DLL
//
ULONG_PTR HLoadIconFromResourceDLL( PCOMMONINFO pci, DWORD dwIconID );
//
// Data structure which is used only when UI is displayed
// IMPORTANT: The first field must be a COMMONINFO structure.
//
typedef struct _UIDATA {
COMMONINFO ci; INT iMode; HWND hDlg; BOOL bPermission; BOOL bIgnoreConflict; BOOL bEMFSpooling; PFNCOMPROPSHEET pfnComPropSheet; HANDLE hComPropSheet; PCOMPROPSHEETUI pCompstui;
//
// These fields are valid only when a dialog is presented
//
DWORD dwFormNames; PWSTR pFormNames; PWORD pwPapers; PWORD pwPaperFeatures; DWORD dwBinNames; PWSTR pBinNames;
//
// Used for helper functions
//
BOOL abEnabledOptions[MAX_PRINTER_OPTIONS];
//
// Fields for keeping track of various option items
//
DWORD dwDrvOptItem; POPTITEM pDrvOptItem;
DWORD dwFormTrayItem; POPTITEM pFormTrayItems;
DWORD dwTTFontItem; POPTITEM pTTFontItems;
DWORD dwFeatureItem; POPTITEM pFeatureItems; POPTITEM pFeatureHdrItem;
//
// These fields are used for packing option items
//
DWORD dwOptItem; POPTITEM pOptItem; DWORD dwOptType; POPTTYPE pOptType;
//
// UniDriver specific fields
//
#ifdef UNIDRV
//
// Font Cart Table
//
DWORD dwFontCart; POPTITEM pFontCart;
//
// Device halftone setup info
//
PDEVHTINFO pDevHTInfo;
#endif // UNIDRV
DWORD dwHideFlags; PVOID pvEndSign;
} UIDATA, *PUIDATA;
//
// Flag constants for UIDATA.dwHideFlags field
//
#define HIDEFLAG_HIDE_STD_DOCPROP 0x0001
#define HIDEFLAG_HIDE_STD_PRNPROP 0x0002
#define IS_HIDING_STD_UI(pUiData) \
((((pUiData)->iMode == MODE_DOCUMENT_STICKY) && \ ((pUiData)->dwHideFlags & HIDEFLAG_HIDE_STD_DOCPROP)) || \ (((pUiData)->iMode == MODE_PRINTER_STICKY) && \ ((pUiData)->dwHideFlags & HIDEFLAG_HIDE_STD_PRNPROP)))
#define VALIDUIDATA(pUiData) ((pUiData) && \
(pUiData) == (pUiData)->ci.pvStartSign && \ (pUiData) == (pUiData)->pvEndSign)
#define HASPERMISSION(pUiData) ((pUiData)->bPermission)
//
// This function is called by DrvDocumentPropertySheets and
// DrvPrinterPropertySheets. It allocates and initializes
// a UIDATA structure that's used to display property pages.
//
PUIDATA PFillUiData( IN HANDLE hPrinter, IN PTSTR pPrinterName, IN PDEVMODE pdmInput, IN INT iMode );
//
// Dispose of a UIDATA structure -
// Just disposed of the embedded COMMONINFO structure
//
#define VFreeUiData(pUiData) VFreeCommonInfo((PCOMMONINFO) (pUiData))
//
// Data structure used to pass parameters to "Conflicts" dialog
//
typedef struct _DLGPARAM {
PFNCOMPROPSHEET pfnComPropSheet; HANDLE hComPropSheet; PUIDATA pUiData; BOOL bFinal; POPTITEM pOptItem; DWORD dwResult;
} DLGPARAM, *PDLGPARAM;
#define CONFLICT_NONE IDOK
#define CONFLICT_RESOLVE IDC_RESOLVE
#define CONFLICT_CANCEL IDC_CANCEL
#define CONFLICT_IGNORE IDC_IGNORE
//
// Functions used to implement DeviceCapabilities:
// calculate minimum or maximum paper size extent
// get list of supported paper size names, indices, and dimensions
// get list of supported paper bin names and indices
// get list of supported resolutions
//
DWORD DwCalcMinMaxExtent( IN PCOMMONINFO pci, OUT PPOINT pptOutput, IN WORD wCapability );
DWORD DwEnumPaperSizes( IN OUT PCOMMONINFO pci, OUT PWSTR pPaperNames, OUT PWORD pPapers, OUT PPOINT pPaperSizes, IN PWORD pPaperFeatures, IN DWORD dwPaperNamesBufSize );
DWORD DwEnumBinNames( IN PCOMMONINFO pci, OUT PWSTR pBinNames );
DWORD DwEnumBins( IN PCOMMONINFO pci, OUT PWORD pBins );
DWORD DwEnumResolutions( IN PCOMMONINFO pci, OUT PLONG pResolutions );
DWORD DwEnumNupOptions( PCOMMONINFO pci, PDWORD pdwOutput );
DWORD DwGetAvailablePrinterMem( IN PCOMMONINFO pci );
DWORD DwEnumMediaReady( IN OUT FORM_TRAY_TABLE pFormTrayTable, OUT PDWORD pdwResultSize );
#ifndef WINNT_40
//
// DC_MEDIATYPENAMES and DC_MEDIATYPES are added in Whistler.
// We need to do following so the driver can also be built with
// Win2K SDK/DDK.
//
#ifndef DC_MEDIATYPENAMES
#define DC_MEDIATYPENAMES 34
#endif
#ifndef DC_MEDIATYPES
#define DC_MEDIATYPES 35
#endif
#endif // !WINNT_40
DWORD DwEnumMediaTypes( IN PCOMMONINFO pci, OUT PTSTR pMediaTypeNames, OUT PDWORD pMediaTypes );
//
// Functions for dealing with forms
//
BOOL BFormSupportedOnPrinter( IN PCOMMONINFO pci, IN PFORM_INFO_1 pFormInfo, OUT PDWORD pdwOptionIndex );
BOOL BPackItemFormTrayTable( IN OUT PUIDATA pUiData );
BOOL BUnpackItemFormTrayTable( IN OUT PUIDATA pUiData );
VOID VSetupFormTrayAssignments( IN PUIDATA pUiData );
DWORD DwFindFormNameIndex( IN PUIDATA pUiData, IN PWSTR pFormName, OUT PBOOL pbSupported );
ULONG_PTR HLoadFormIconResource( PUIDATA pUiData, DWORD dwIndex );
DWORD DwGuessFormIconID( PWSTR pFormName );
//
// Functions prototypes for commonui related items.
//
PCOMPROPSHEETUI PPrepareDataForCommonUI( IN OUT PUIDATA pUiData, IN PDLGPAGE pDlgPage );
BOOL BPackPrinterPropertyItems( IN OUT PUIDATA pUiData );
BOOL BPackDocumentPropertyItems( IN OUT PUIDATA pUiData );
VOID VPackOptItemGroupHeader( IN OUT PUIDATA pUiData, IN DWORD dwTitleId, IN DWORD dwIconId, IN DWORD dwHelpIndex );
BOOL BPackOptItemTemplate( IN OUT PUIDATA pUiData, IN CONST WORD pwItemInfo[], IN DWORD dwSelection, IN PFEATURE pFeature );
#define ITEM_INFO_SIGNATURE 0xCAFE
BOOL BPackUDArrowItemTemplate( IN OUT PUIDATA pUiData, IN CONST WORD pwItemInfo[], IN DWORD dwSelection, IN DWORD dwMaxVal, IN PFEATURE pFeature );
POPTPARAM PFillOutOptType( OUT POPTTYPE pOptType, IN DWORD dwType, IN DWORD dwParams, IN HANDLE hHeap );
PFEATURE PGetFeatureFromItem( IN PUIINFO pUIInfo, IN OUT POPTITEM pOptItem, OUT PDWORD pdwFeatureIndex );
BOOL BPackItemGenericOptions( IN OUT PUIDATA pUiData );
BOOL BPackItemPrinterFeature( IN OUT PUIDATA pUiData, IN PFEATURE pFeature, IN DWORD dwLevel, IN DWORD dwPub, IN ULONG_PTR dwUserData, IN DWORD dwHelpIndex );
DWORD DwCountDisplayableGenericFeature( IN PUIDATA pUiData, BOOL bPrinterSticky );
BOOL BShouldDisplayGenericFeature( IN PFEATURE pFeature, IN BOOL bPrinterSticky );
BOOL BOptItemSelectionsChanged( IN OUT POPTITEM pItems, IN DWORD dwItems );
POPTITEM PFindOptItem( IN PUIDATA pUiData, IN DWORD dwItemId );
BOOL BPackItemFontSubstTable( IN PUIDATA pUiData );
BOOL BUnpackItemFontSubstTable( IN PUIDATA pUiData );
PTSTR PtstrDuplicateStringFromHeap( IN PTSTR ptstrSrc, IN HANDLE hHeap );
VOID VUpdateOptionsArrayWithSelection( IN OUT PUIDATA pUiData, IN POPTITEM pOptItem );
VOID VUnpackDocumentPropertiesItems( IN OUT PUIDATA pUiData, IN OUT POPTITEM pOptItem, IN DWORD dwCound);
BOOL BGetPageOrderFlag( IN PCOMMONINFO pci );
VOID VPropShowConstraints( IN PUIDATA pUiData, IN INT iMode );
INT ICheckConstraintsDlg( IN OUT PUIDATA pUiData, IN OUT POPTITEM pOptItem, IN DWORD dwOptItem, IN BOOL bFinal );
#define CONSTRAINED_FLAG OPTPF_OVERLAY_WARNING_ICON
#define IS_CONSTRAINED(pitem, sel) ((pitem)->pOptType->pOptParam[sel].Flags & CONSTRAINED_FLAG)
//
// This function copy a source devmode to an output devmode buffer.
// It should be called by the driver just before the driver returns
// to the caller of DrvDocumentPropertySheets.
//
BOOL BConvertDevmodeOut( IN PDEVMODE pdmSrc, IN PDEVMODE pdmIn, OUT PDEVMODE pdmOut );
//
// Find the OPTITEM with UserData's pKeywordName matching given keyword name
//
POPTITEM PFindOptItemWithKeyword( IN PUIDATA pUiData, IN PCSTR pKeywordName );
//
// Find the OPTITEM containing the specified UserData value
//
POPTITEM PFindOptItemWithUserData( IN PUIDATA pUiData, IN DWORD UserData );
//
// Sync up OPTITEM list with the updated options array
//
VOID VUpdateOptItemList( IN OUT PUIDATA pUiData, IN POPTSELECT pOldCombinedOptions, IN POPTSELECT pNewCombinedOptions );
//
// Display an error message box
//
INT IDisplayErrorMessageBox( HWND hwndParent, UINT uType, INT iTitleStrId, INT iFormatStrId, ... );
BOOL BPrepareForLoadingResource( PCOMMONINFO pci, BOOL bNeedHeap );
//
// Fill out an OPTITEM structure
//
#define FILLOPTITEM(poptitem,popttype,name,sel,level,dmpub,userdata,help) \
(poptitem)->cbSize = sizeof(OPTITEM); \ (poptitem)->Flags |= OPTIF_CALLBACK; \ (poptitem)->pOptType = (popttype); \ (poptitem)->pName = (PWSTR) (name); \ (poptitem)->pSel = (PVOID) (sel); \ (poptitem)->Level = (BYTE) (level); \ (poptitem)->DMPubID = (BYTE) (dmpub); \ SETUSERDATAID(poptitem, userdata); \ (poptitem)->HelpIndex = (help)
//
// Tree view item level
//
#define TVITEM_LEVEL1 1
#define TVITEM_LEVEL2 2
#define TVITEM_LEVEL3 3
enum { UNKNOWN_ITEM,
FONT_SUBST_ITEM, FONTSLOT_ITEM, PRINTER_VM_ITEM, HALFTONE_SETUP_ITEM, IGNORE_DEVFONT_ITEM, PSPROTOCOL_ITEM, JOB_TIMEOUT_ITEM, WAIT_TIMEOUT_ITEM,
COPIES_COLLATE_ITEM, SCALE_ITEM, COLOR_ITEM, ICMMETHOD_ITEM, ICMINTENT_ITEM, TTOPTION_ITEM, METASPOOL_ITEM, NUP_ITEM, REVPRINT_ITEM, MIRROR_ITEM, NEGATIVE_ITEM, COMPRESSBMP_ITEM, CTRLD_BEFORE_ITEM, CTRLD_AFTER_ITEM, TEXT_ASGRX_ITEM, PAGE_PROTECT_ITEM, PSOUTPUT_OPTION_ITEM, PSTT_DLFORMAT_ITEM, PSLEVEL_ITEM, PSERROR_HANDLER_ITEM, PSMINOUTLINE_ITEM, PSMAXBITMAP_ITEM, PSHALFTONE_FREQ_ITEM, PSHALFTONE_ANGLE_ITEM, QUALITY_SETTINGS_ITEM, SOFTFONT_SETTINGS_ITEM,
TRUE_GRAY_TEXT_ITEM, TRUE_GRAY_GRAPH_ITEM,
ADD_EURO_ITEM,
//
// !!! Only items whose UserData value is larger than
// CONSTRAINABLE_ITEM can have constraints.
//
CONSTRAINABLE_ITEM = 0x8000, ORIENTATION_ITEM = CONSTRAINABLE_ITEM, DUPLEX_ITEM, RESOLUTION_ITEM, INPUTSLOT_ITEM, FORMNAME_ITEM, MEDIATYPE_ITEM, COLORMODE_ITEM, HALFTONING_ITEM, FORM_TRAY_ITEM, };
//
// Interpretation of OPTITEM.UserData: If it's less than 0x10000
// then it's one of the constants defined above. Otherwise, it's
// a pointer to a FEATURE object.
//
#define DRIVERUI_MAX_ITEM 0x10000
#define ISPRINTERFEATUREITEM(userData) (GETUSERDATAITEM(userData) >= DRIVERUI_MAX_ITEM)
#define ISCONSTRAINABLEITEM(userData) (GETUSERDATAITEM(userData) >= CONSTRAINABLE_ITEM)
#define ISFORMTRAYITEM(userData) (GETUSERDATAITEM(userData) == FORM_TRAY_ITEM)
#define ISFONTSUBSTITEM(userData) (GETUSERDATAITEM(userData) == FONT_SUBST_ITEM)
//
// Determine whether certain features are supported on the printer
//
#ifdef UNIDRV
#define SUPPORTS_DUPLEX(pci) \
((!_BFeatureDisabled(pci, 0xFFFFFFFF, GID_DUPLEX)) && \ (GET_PREDEFINED_FEATURE((pci)->pUIInfo, GID_DUPLEX) != NULL)) #else
#define SUPPORTS_DUPLEX(pci) \
((_BSupportFeature(pci, GID_DUPLEX, NULL)) && \ (GET_PREDEFINED_FEATURE(pci->pUIInfo, GID_DUPLEX) != NULL)) #endif // UNIDRV
#define SUPPORTS_PAGE_PROTECT(pUIInfo) \
(GET_PREDEFINED_FEATURE(pUIInfo, GID_PAGEPROTECTION) != NULL)
#ifdef UNIDRV
#define PRINTER_SUPPORTS_COLLATE(pci) \
((!_BFeatureDisabled(pci, 0xFFFFFFFF, GID_COLLATE)) && \ (GET_PREDEFINED_FEATURE((pci)->pUIInfo, GID_COLLATE) != NULL)) #else
#define PRINTER_SUPPORTS_COLLATE(pci) \
((_BSupportFeature(pci, GID_COLLATE, NULL)) && \ (GET_PREDEFINED_FEATURE(pci->pUIInfo, GID_COLLATE) != NULL)) #endif // UNIDRV
#ifdef WINNT_40
#define DRIVER_SUPPORTS_COLLATE(pci) PRINTER_SUPPORTS_COLLATE(pci)
#else
#define DRIVER_SUPPORTS_COLLATE(pci) TRUE
#endif
//
// Data structure containing information about cached driver files
//
typedef struct _CACHEDFILE {
HANDLE hRemoteFile; // open handle to remote file on the server
PWSTR pRemoteDir; // remote directory on the server
PWSTR pLocalDir; // local directory
PWSTR pFilename; // name of the cached file
} CACHEDFILE, *PCACHEDFILE;
//
// Functions for copying files over during point and print
//
BOOL _BPrepareToCopyCachedFile(HANDLE, PCACHEDFILE, PWSTR); BOOL _BCopyCachedFile(PCOMMONINFO, PCACHEDFILE); VOID _VDisposeCachedFileInfo(PCACHEDFILE);
//
// Driver specific functions (implemented in ps and uni subdirectories)
//
DWORD _DwEnumPersonalities(PCOMMONINFO, PWSTR); DWORD _DwGetOrientationAngle(PUIINFO, PDEVMODE); BOOL _BPackDocumentOptions(PUIDATA); VOID _VUnpackDocumentOptions(POPTITEM, PDEVMODE); BOOL _BPackPrinterOptions(PUIDATA); BOOL _BPackOrientationItem(PUIDATA); INT _IListDevFontNames(HDC, PWSTR, INT); INT_PTR CALLBACK _AboutDlgProc(HWND, UINT, WPARAM, LPARAM); #define FREE_DEFAULT_FONTSUB_TABLE(pTTSubstTable) MemFree(pTTSubstTable)
#ifdef PSCRIPT
#define _PwstrGetCallerName() ((PWSTR) IDS_POSTSCRIPT)
#define _DwGetFontCap(pUIInfo) (DCTT_DOWNLOAD | DCTT_SUBDEV)
#define _DwGetDefaultResolution() DEFAULT_RESOLUTION
#define _DwGetPrinterIconID() IDI_CPSUI_POSTSCRIPT
#define _BUnpackPrinterOptions(pUiData) TRUE
BOOL _BSupportStapling(PCOMMONINFO); VOID _VUnpackDriverPrnPropItem(PUIDATA, POPTITEM); BOOL _BPackItemScale(PUIDATA); BOOL _BPackFontSubstItems(PUIDATA); BOOL _BSupportFeature(PCOMMONINFO, DWORD, PFEATURE); BOOL BDisplayPSCustomPageSizeDialog(PUIDATA); BOOL BUpdateModelNtfFilename(PCOMMONINFO); VOID VSyncRevPrintAndOutputOrder(PUIDATA, POPTITEM);
#ifdef WINNT_40
BOOL BUpdateVMErrorMessageID(PCOMMONINFO); #endif // WINNT_40
#define ISSET_MFSPOOL_FLAG(pdmExtra) ((pdmExtra)->dwFlags & PSDEVMODE_METAFILE_SPOOL)
#define SET_MFSPOOL_FLAG(pdmExtra) ((pdmExtra)->dwFlags |= PSDEVMODE_METAFILE_SPOOL)
#define CLEAR_MFSPOOL_FLAG(pdmExtra) ((pdmExtra)->dwFlags &= ~PSDEVMODE_METAFILE_SPOOL)
#define NUPOPTION(pdmExtra) ((pdmExtra)->iLayout)
#define REVPRINTOPTION(pdmExtra) ((pdmExtra)->bReversePrint)
#define GET_DEFAULT_FONTSUB_TABLE(pci, pUIInfo) PtstrGetDefaultTTSubstTable(pUIInfo)
#define NOT_UNUSED_ITEM(bOrderReversed) TRUE
#define ILOADSTRING(pci, id, wchbuf, size) 0
#endif // PSCRIPT
#ifdef UNIDRV
#define _PwstrGetCallerName() ((PWSTR) IDS_UNIDRV)
#define _DwGetDefaultResolution() 300
#define _BPackItemScale(pUiData) TRUE
#define _BPackFontSubstItems(pUiData) BPackItemFontSubstTable(pUiData)
#define _DwGetPrinterIconID() IDI_CPSUI_PRINTER2
#define BValidateDevmodeCustomPageSizeFields(pRawData, pUIInfo, pdm, prclImageArea) FALSE
#define _VUnpackDriverPrnPropItem(pUiData, pOptItem)
DWORD _DwGetFontCap(PUIINFO); BOOL _BUnpackPrinterOptions(PUIDATA); BOOL _BSupportStapling(PCOMMONINFO); BOOL _BFeatureDisabled(PCOMMONINFO, DWORD, WORD); VOID VSyncColorInformation(PUIDATA, POPTITEM); VOID VMakeMacroSelections(PUIDATA, POPTITEM); VOID VUpdateMacroSelection(PUIDATA, POPTITEM); PTSTR PtstrUniGetDefaultTTSubstTable(PCOMMONINFO, PUIINFO); BOOL BOkToChangeColorToMono(PCOMMONINFO, PDEVMODE, SHORT * , SHORT *);
#define ISSET_MFSPOOL_FLAG(pdmExtra) (((pdmExtra)->dwFlags & DXF_NOEMFSPOOL) == 0)
#define SET_MFSPOOL_FLAG(pdmExtra) ((pdmExtra)->dwFlags &= ~DXF_NOEMFSPOOL)
#define CLEAR_MFSPOOL_FLAG(pdmExtra) ((pdmExtra)->dwFlags |= DXF_NOEMFSPOOL)
#define NUPOPTION(pdmExtra) ((pdmExtra)->iLayout)
#define REVPRINTOPTION(pdmExtra) ((pdmExtra)->bReversePrint)
#define GET_DEFAULT_FONTSUB_TABLE(pci, pUIInfo) PtstrUniGetDefaultTTSubstTable(pci, pUIInfo)
#define NOT_UNUSED_ITEM(bOrderReversed) (bOrderReversed != UNUSED_ITEM)
#define ILOADSTRING(pci, id, wchbuf, size) \
ILoadStringW(((pci)->pWinResData), id, wchbuf, size)
#endif // UNIDRV
#endif //!_DRIVERUI_H_
|