windows-nt/Source/XPSP1/NT/printscan/print/drivers/usermode/driverui/driverui.h

1059 lines
25 KiB
C
Raw Permalink Normal View History

2020-09-26 03:20:57 -05:00
/*++
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_