Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

633 lines
18 KiB

/*++
Copyright (c) 1994-1998 Microsoft Corporation
All rights reserved.
Module Name:
WinPrtP.h
Abstract:
Private PrintUI library public header.
Author:
Albert Ting (AlbertT) 27-Jun-95
Revision History:
--*/
DEFINE_GUID(CLSID_PrintUIShellExtension, 0x77597368, 0x7b15, 0x11d0, 0xa0, 0xc2, 0x08, 0x00, 0x36, 0xaf, 0x3f, 0x03 );
DEFINE_GUID(IID_IFindPrinter, 0xb4cd8efc, 0xd70b, 0x11d1, 0x99, 0xb1, 0x8, 0x0, 0x36, 0xaf, 0x3f, 0x3);
DEFINE_GUID(IID_IPrinterFolder, 0xef99abd4, 0x5b8d, 0x11d1, 0xa9, 0xc8, 0x8, 0x0, 0x36, 0xaf, 0x3f, 0x3);
DEFINE_GUID(IID_IFolderNotify, 0xff22d71, 0x5172, 0x11d1, 0xa9, 0xc6, 0x8, 0x0, 0x36, 0xaf, 0x3f, 0x3);
DEFINE_GUID(IID_IDsPrinterProperties,0x8a58bc16, 0x410e, 0x11d1, 0xa9, 0xc2, 0x8, 0x0, 0x36, 0xaf, 0x3f, 0x3);
DEFINE_GUID(IID_IPhysicalLocation, 0xdfe8c7eb, 0x651b, 0x11d2, 0x92, 0xce, 0x08, 0x00, 0x36, 0xaf, 0x3f, 0x03);
DEFINE_GUID(IID_IPrnStream, 0xa24c1d62, 0x75f5, 0x11d2, 0xb8, 0x99, 0x0, 0xc0, 0x4f, 0x86, 0xae, 0x55);
// {2E4599E1-BE2C-436a-B0AD-3D0E347F34B3}
DEFINE_GUID(IID_IPrintUIServices, 0x2e4599e1, 0xbe2c, 0x436a, 0xb0, 0xad, 0x3d, 0xe, 0x34, 0x7f, 0x34, 0xb3);
#ifndef _PRTLIB_H
#define _PRTLIB_H
#ifdef __cplusplus
extern "C" {
#endif
/********************************************************************
Prototypes
********************************************************************/
//
// Initialize the library.
//
BOOL
bPrintLibInit(
VOID
);
//
// Create a new print queue.
//
VOID
vQueueCreate(
HWND hwndOwner,
LPCTSTR pszPrinter,
INT nCmdShow,
LPARAM lParam
);
//
// Display document defaults for a print queue.
//
VOID
vDocumentDefaults(
HWND hwndOwner,
LPCTSTR pszPrinterName,
INT nCmdShow,
LPARAM lParam
);
#define PRINTER_SHARING_PAGE 1
//
// Display properties for a print queue.
//
VOID
vPrinterPropPages(
HWND hwndOwner,
LPCTSTR pszPrinterName,
INT nCmdShow,
LPARAM lParam
);
VOID
vServerPropPages(
HWND hwndOwner,
LPCTSTR pszServerName,
INT nCmdShow,
LPARAM lParam
);
//
// Run printer and drivers setup.
//
BOOL
bPrinterSetup(
HWND hwnd,
UINT uAction,
UINT cchPrinterName,
LPTSTR pszPrinterName,
UINT* pcchPrinterName,
LPCTSTR pszServerName
);
/********************************************************************
Print folder interfaces.
********************************************************************/
/********************************************************************
Printers Folder Extenstion Interface. This interface extends
the printers IShellFolder implementation.
********************************************************************/
#undef INTERFACE
#define INTERFACE IPrinterFolder
DECLARE_INTERFACE_(IPrinterFolder, IUnknown)
{
// *** IUnknown methods ***
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE;
STDMETHOD_(ULONG,AddRef)(THIS) PURE;
STDMETHOD_(ULONG,Release)(THIS) PURE;
// *** IPrintersFolder methods ***
STDMETHOD_(BOOL, IsPrinter)( THIS_ LPCITEMIDLIST pidl ) PURE;
};
/********************************************************************
Folder Notification interface.
********************************************************************/
//
// Folder notify type
//
typedef enum IFolderNotifyType
{
kFolderNone, // No item changed do not generate notification
kFolderUpdate, // Item changed
kFolderAttributes, // Item attribute changed
kFolderCreate, // Item created
kFolderDelete, // Item deleted
kFolderRename, // Item renamed
kFolderUpdateAll, // Update all items == 'F5'
} FOLDER_NOTIFY_TYPE, *PFOLDER_NOTIFY_TYPE;
//
// Folder notification callback interface definition.
//
#undef INTERFACE
#define INTERFACE IFolderNotify
DECLARE_INTERFACE_(IFolderNotify, IUnknown)
{
// *** IUnknown methods ***
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE;
STDMETHOD_(ULONG,AddRef)(THIS) PURE;
STDMETHOD_(ULONG,Release)(THIS) PURE;
// *** IFolderNotify methods ***
STDMETHOD_(BOOL, ProcessNotify)( THIS_ FOLDER_NOTIFY_TYPE NotifyType, LPCWSTR pszName, LPCWSTR pszNewName ) PURE;
};
typedef struct _FOLDER_PRINTER_DATA {
LPCTSTR pName;
LPCTSTR pComment;
DWORD Status;
DWORD Attributes;
DWORD cJobs;
DWORD cbSize;
LPCTSTR pLocation;
LPCTSTR pDriverName;
LPCTSTR pStatus; // Connection status i.e. <opening...>
LPCTSTR pPortName;
} FOLDER_PRINTER_DATA, *PFOLDER_PRINTER_DATA;
//
// Register folder watch. Currently this only works for print
// servers; connections aren't maintained.
//
HRESULT
RegisterPrintNotify(
IN LPCTSTR pszDataSource,
IN IFolderNotify *pClientNotify,
OUT LPHANDLE phFolder,
OUT PBOOL pbAdministrator OPTIONAL
);
//
// Unregister folder watch. Currently this only works for print
// servers; connections aren't maintained.
//
HRESULT
UnregisterPrintNotify(
IN LPCTSTR pszDataSource,
IN IFolderNotify *pClientNotify,
OUT LPHANDLE phFolder
);
BOOL
bFolderEnumPrinters(
IN HANDLE hFolder,
OUT PFOLDER_PRINTER_DATA pData,
IN DWORD cbData,
OUT PDWORD pcbNeeded,
OUT PDWORD pcbReturned
);
BOOL
bFolderRefresh(
IN HANDLE hFolder,
OUT PBOOL pbAdministrator
);
BOOL
bFolderGetPrinter(
IN HANDLE hFolder,
IN LPCTSTR pszPrinter,
OUT PFOLDER_PRINTER_DATA pData,
IN DWORD cbData,
OUT PDWORD pcbNeeded
);
/********************************************************************
PrintUI error support (exposed to shell)
********************************************************************/
HRESULT
ShowErrorMessageSC(
OUT INT *piResult,
IN HINSTANCE hModule,
IN HWND hwnd,
IN LPCTSTR pszTitle,
IN LPCTSTR pszMessage,
IN UINT uType,
IN DWORD dwCode
);
HRESULT
ShowErrorMessageHR(
OUT INT *piResult,
IN HINSTANCE hModule,
IN HWND hwnd,
IN LPCTSTR pszTitle,
IN LPCTSTR pszMessage,
IN UINT uType,
IN HRESULT hr
);
/********************************************************************
IPhysicalLocation
********************************************************************/
#undef INTERFACE
#define INTERFACE IPhysicalLocation
DECLARE_INTERFACE_(IPhysicalLocation, IUnknown)
{
// *** IUnknown methods ***
STDMETHOD(QueryInterface) (THIS_ REFIID riid, LPVOID * ppvObj) PURE;
STDMETHOD_(ULONG,AddRef) (THIS) PURE;
STDMETHOD_(ULONG,Release) (THIS) PURE;
// IPhysicalLocation methods
STDMETHOD(DiscoverPhysicalLocation)(THIS) PURE;
STDMETHOD(GetExactPhysicalLocation)(THIS_ BSTR *pbsLocation) PURE;
STDMETHOD(GetSearchPhysicalLocation)(THIS_ BSTR *pbsLocation) PURE;
// IPhysicalLocation methods for fetching individual physical locations
STDMETHOD(GetUserPhysicalLocation)(THIS_ BSTR *pbsLocation) PURE;
STDMETHOD(GetMachinePhysicalLocation)(THIS_ BSTR *pbsLocation) PURE;
STDMETHOD(GetSubnetPhysicalLocation)(THIS_ BSTR *pbsLocation) PURE;
STDMETHOD(GetSitePhysicalLocation)(THIS_ BSTR *pbsLocation) PURE;
STDMETHOD(BrowseForLocation)(THIS_ HWND hParent, BSTR bsDefault, BSTR *pbsLocation) PURE;
STDMETHOD(ShowPhysicalLocationUI)(THIS) PURE;
};
/********************************************************************
IDsPrinterProperties
This is a private interface used to launch printer properties
from the DS MMC snapin.
********************************************************************/
#undef INTERFACE
#define INTERFACE IDsPrinterProperties
DECLARE_INTERFACE_(IDsPrinterProperties, IUnknown)
{
// *** IUnknown methods ***
STDMETHOD(QueryInterface) (THIS_ REFIID riid, LPVOID * ppvObj) PURE;
STDMETHOD_(ULONG,AddRef) (THIS) PURE;
STDMETHOD_(ULONG,Release) (THIS) PURE;
// IDsFolder methods
STDMETHOD(ShowProperties)(THIS_ HWND hwndParent, LPCWSTR pszObjectPath, PBOOL pbDisplayed) PURE;
};
/********************************************************************
Find Printer Interface. This inferface allows a user to find
a printer either on the network or in the DS if one is
available.
********************************************************************/
#undef INTERFACE
#define INTERFACE IFindPrinter
DECLARE_INTERFACE_(IFindPrinter, IUnknown)
{
// *** IUnknown methods ***
STDMETHOD(QueryInterface) (THIS_ REFIID riid, LPVOID * ppvObj) PURE;
STDMETHOD_(ULONG,AddRef) (THIS) PURE;
STDMETHOD_(ULONG,Release) (THIS) PURE;
// IFindPrinter methods
STDMETHOD(FindPrinter)(THIS_ HWND hwnd, LPWSTR pszBuffer, UINT *puSize) PURE;
};
/********************************************************************
IPageSwitch - Interface used as a connection point for
the connect to printer dialog when integrated in a wizard.
********************************************************************/
#undef INTERFACE
#define INTERFACE IPageSwitch
DECLARE_INTERFACE(IPageSwitch)
{
// *** INotifyReflect methods ***
//
// This functions provide opportunity to the client to change
// the next/prev page ID and/or allow/deny advancing to the
// next/prev page.
//
// S_OK: means you can advance to the next/prev page
// S_FALSE: means you cant advance to the next/prev page
//
STDMETHOD(GetPrevPageID)( THIS_ UINT *puPageID ) PURE;
STDMETHOD(GetNextPageID)( THIS_ UINT *puPageID ) PURE;
//
// The property page calls this method when the printer connection is
// successfully created and we are about to advance to the
// next/prev page
//
STDMETHOD(SetPrinterInfo)( THIS_ LPCWSTR pszPrinterName, LPCWSTR pszComment, LPCWSTR pszLocation, LPCWSTR pszShareName ) PURE;
//
// This method provide notification to the client that
// the user clicked "Cancel" button on the wizard - which
// normaly leads to closing the wizard.
//
// S_OK - Prevent cancel operation
// S_FALSE - Allow cancel operation
//
STDMETHOD(QueryCancel)( THIS ) PURE;
};
//
// The API function for creating the ConnectToPrinterDlg style
// property page
//
HRESULT
ConnectToPrinterPropertyPage(
OUT HPROPSHEETPAGE *phPsp,
OUT UINT *puPageID,
IN IPageSwitch *pPageSwitchController
);
/********************************************************************
IPrnStream flags
********************************************************************/
typedef enum _PrinterPersistentFlags
{
PRST_PRINTER_DATA = 1<<0,
PRST_PRINTER_INFO_2 = 1<<1,
PRST_PRINTER_INFO_7 = 1<<2,
PRST_PRINTER_SEC = 1<<3,
PRST_USER_DEVMODE = 1<<4,
PRST_PRINTER_DEVMODE = 1<<5,
PRST_COLOR_PROF = 1<<6,
PRST_FORCE_NAME = 1<<7,
PRST_RESOLVE_NAME = 1<<8,
PRST_RESOLVE_PORT = 1<<9,
PRST_RESOLVE_SHARE = 1<<10,
PRST_DONT_GENERATE_SHARE = 1<<11,
PRST_MINIMUM_SETTINGS = PRST_PRINTER_DATA | PRST_PRINTER_INFO_2 | PRST_PRINTER_DEVMODE,
PRST_ALL_SETTINGS = PRST_MINIMUM_SETTINGS |
PRST_PRINTER_INFO_7 |
PRST_PRINTER_SEC |
PRST_USER_DEVMODE |
PRST_COLOR_PROF,
} PrinterPersistentFlags;
/********************************************************************
IPrnStream query flags.
********************************************************************/
typedef enum _PrinterPersistentQueryFlag
{
kPrinterPersistentPrinterInfo2,
kPrinterPersistentPrinterInfo7,
kPrinterPersistentUserDevMode,
kPrinterPersistentPrinterDevMode,
kPrinterPersistentSecurity,
kPrinterPersistentColorProfile,
} PrinterPersistentQueryFlag;
typedef union _PersistentInfo
{
PRINTER_INFO_2 *pi2;
PRINTER_INFO_7 *pi7;
DEVMODE *pDevMode;
SECURITY_DESCRIPTOR *pszSecurity;
LPWSTR pMultiSzColor;
} PersistentInfo;
/********************************************************************
IPrnStream interface definition
********************************************************************/
#undef INTERFACE
#define INTERFACE IPrnStream
DECLARE_INTERFACE_(IPrnStream, IUnknown)
{
// *** IUnknown methods ***
STDMETHOD(QueryInterface) (THIS_ REFIID riid, LPVOID * ppvObj) PURE;
STDMETHOD_(ULONG,AddRef) (THIS) PURE;
STDMETHOD_(ULONG,Release) (THIS) PURE;
// IPrnStream methods
STDMETHOD(BindPrinterAndFile)(THIS_ LPCWSTR pszPrinter, LPCWSTR pszFile) PURE;
STDMETHOD(StorePrinterInfo)(THIS_ DWORD dwFlag) PURE;
STDMETHOD(RestorePrinterInfo)(THIS_ DWORD dwFlag) PURE;
STDMETHOD(QueryPrinterInfo)(THIS_ PrinterPersistentQueryFlag Flag, PersistentInfo *pPrstInfo) PURE;
};
/********************************************************************
Error codes returned by IPrnStream methods
********************************************************************/
typedef enum _PrnPrstError
{
//
// When storing/ restoring opereations called and
// BindPrinterAndFile wasn't called or failed
//
PRN_PERSIST_ERROR_INVALID_OBJ = 0x1,
//
// Failed to write Printer data because writing failure
//
PRN_PERSIST_ERROR_WRITE_PRNDATA = 0x2,
//
// Failed to restore Printer data because SetPrinterData failed
//
PRN_PERSIST_ERROR_RESTORE_PRNDATA = 0x3,
//
// Failed to restore Printer data because because reading failure
//
PRN_PERSIST_ERROR_READ_PRNDATA = 0x4,
//
// Failed to store Printer Info 2 because writing failure
//
PRN_PERSIST_ERROR_WRITE_PI2 = 0x5,
//
// Failed to store Printer Info 2 because GetPrinter failure
//
PRN_PERSIST_ERROR_GET_PI2 = 0x6,
//
// Failed to restore Printer Info 2 because reading failure
//
PRN_PERSIST_ERROR_READ_PI2 = 0x7,
//
// Failed to restore Printer Info 2 because SetPrinter failure
//
PRN_PERSIST_ERROR_RESTORE_PI2 = 0x8,
//
// Failed to store Printer Info 7 because writing failure
//
PRN_PERSIST_ERROR_WRITE_PI7 = 0x9,
//
// Failed to store Printer Info 7 because GetPrinter failure
//
PRN_PERSIST_ERROR_GET_PI7 = 0xa,
//
// Failed to restore Printer Info 7 because reading failure
//
PRN_PERSIST_ERROR_READ_PI7 = 0xb,
//
// Failed to restore Printer Info 7 because SetPrinter failure
//
PRN_PERSIST_ERROR_RESTORE_PI7 = 0xc,
//
// Failed to store Printer Security Descriptor because writing failure
//
PRN_PERSIST_ERROR_WRITE_SEC = 0xd,
//
// Failed to store Printer Security Descriptor because GetPrinter failure
//
PRN_PERSIST_ERROR_GET_SEC = 0xe,
//
// Failed to restore Printer Security Descriptor because reading failure
//
PRN_PERSIST_ERROR_READ_SEC = 0xf,
//
// Failed to restore Printer Security Descriptor because SetPrinter failure
//
PRN_PERSIST_ERROR_RESTORE_SEC = 0x10,
//
// Failed to store Printer Color Profiles because writing failure
//
PRN_PERSIST_ERROR_WRITE_COLOR_PRF = 0x11,
//
// Failed to store Printer Color Profiles because EnumcolorProfiles failure
//
PRN_PERSIST_ERROR_GET_COLOR_PRF = 0x12,
//
// Failed to restore Printer Color Profiles because reading failure
//
PRN_PERSIST_ERROR_READ_COLOR_PRF = 0x13,
//
// Failed to restore Printer Color Profiles because AddColorProfile failure
//
PRN_PERSIST_ERROR_RESTORE_COLOR_PRF = 0x14,
//
// Failed to store User DevMode because writing failure
//
PRN_PERSIST_ERROR_WRITE_USR_DEVMODE = 0x15,
//
// Failed to store User DevMode because GetPrinter failure
//
PRN_PERSIST_ERROR_GET_USR_DEVMODE = 0x16,
//
// Failed to restore User DevMode because reading failure
//
PRN_PERSIST_ERROR_READ_USR_DEVMODE = 0x17,
//
// Failed to restore User DevMode because SetPrinter failure
//
PRN_PERSIST_ERROR_RESTORE_USR_DEVMODE = 0x18,
//
// Failed to store Printer DevMode because writing failure
//
PRN_PERSIST_ERROR_WRITE_PRN_DEVMODE = 0x19,
//
// Failed to store Printer DevMode because GetPrinter failure
//
PRN_PERSIST_ERROR_GET_PRN_DEVMODE = 0x1a,
//
// Failed to restore Printer DevMode because reading failure
//
PRN_PERSIST_ERROR_READ_PRN_DEVMODE = 0x1b,
//
// Failed to restore Printer DevMode because SetPrinter failure
//
PRN_PERSIST_ERROR_RESTORE_PRN_DEVMODE = 0x1c,
//
// Failed because of unresolved printer name conflict
//
PRN_PERSIST_ERROR_PRN_NAME_CONFLICT = 0x1d,
//
// Failed because of printer name conflict
//
PRN_PERSIST_ERROR_UNBOUND = 0x1e,
//
// Restoring failure because failure at building backup info
//
PRN_PERSIST_ERROR_BACKUP = 0x1f,
//
// Restoring failure and Backup Failure too ; printer settings in undefined status
//
PRN_PERSIST_ERROR_FATAL = 0xffff
} PrnPrstError;
/********************************************************************
IID_IPrintUIServices interface definition
********************************************************************/
#undef INTERFACE
#define INTERFACE IPrintUIServices
DECLARE_INTERFACE_(IPrintUIServices, IUnknown)
{
// *** IUnknown methods ***
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE;
STDMETHOD_(ULONG,AddRef)(THIS) PURE;
STDMETHOD_(ULONG,Release)(THIS) PURE;
// *** IID_IPrintUIServices methods ***
STDMETHOD(GenerateShareName)(THIS_ LPCTSTR lpszServer, LPCTSTR lpszBaseName, LPTSTR lpszOut, int cchMaxChars) PURE;
};
#ifdef __cplusplus
}
#endif
#endif // ndef _PRTLIB_HXX