mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1058 lines
25 KiB
1058 lines
25 KiB
/*++
|
|
|
|
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_
|
|
|