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.
357 lines
12 KiB
357 lines
12 KiB
/********************************************\
|
|
*
|
|
* File : fmtres.h
|
|
* Author : Kevin Gallo
|
|
* Created: 9/27/93
|
|
*
|
|
* Copyright (c) Microsoft Corp. 1993-1994
|
|
*
|
|
* Overview:
|
|
*
|
|
* Revision History:
|
|
\********************************************/
|
|
|
|
#ifndef _FMTRES_H
|
|
#define _FMTRES_H
|
|
|
|
// System includes
|
|
|
|
#include "ifaxos.h"
|
|
#include "rendserv.h"
|
|
#ifdef IFAX
|
|
#include "awnsfapi.h"
|
|
#include "awnsfint.h"
|
|
#include "printer.h"
|
|
#include "scanner.h"
|
|
#include "sosutil.h"
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
//
|
|
// Format Resolution Initializers
|
|
//
|
|
|
|
EXPORT_DLL BOOL WINAPI FRInitResolvers() ;
|
|
EXPORT_DLL BOOL WINAPI FRFreeResolvers() ;
|
|
|
|
// =================================================================
|
|
//
|
|
// Format Resolution Error Codes
|
|
//
|
|
// *******
|
|
// These are returned in GetLastError only. See below for the function return values.
|
|
// *******
|
|
//
|
|
// Format IFErrAssemble(PROCID_NONE,MODID_FMTRES,0,error code)
|
|
//
|
|
// The error code is a 16 bit value specific to the format resolution
|
|
//
|
|
// Bits 0 - 3 indicate the error type (4)
|
|
// Bits 4 - 8 indicate the extended error type (specific to each error) (4)
|
|
// Bits 10 - 15 are specific data or errors to each extended error (8)
|
|
//
|
|
// =================================================================
|
|
|
|
#define FRMAKE_ERR(err) (err)
|
|
|
|
// All system errors are possible return values as well
|
|
|
|
#define FRERR_NONE FRMAKE_ERR(0) // No error
|
|
#define FRERR_UNRESOLVED FRMAKE_ERR(1) // Unresolved - incompatible type
|
|
#define FRERR_FR_FAIL FRMAKE_ERR(2) // The desired fmtres function failed (invalid params/other/etc..)
|
|
#define FRERR_DEV_FAIL FRMAKE_ERR(3) // Device failed.
|
|
#define FRERR_SOS_CORRUPT FRMAKE_ERR(4) // Message store was corrupt
|
|
#define FRERR_FS_FAIL FRMAKE_ERR(5) // File System failure
|
|
#define FRERR_SYSTEM_FAIL FRMAKE_ERR(6) // System failure (out of memory/load lib/etc...)
|
|
|
|
// =================================================================
|
|
// EXTENDED ERRORS:
|
|
//
|
|
// The extended error code is different for every error and must be determined based on the type of error
|
|
//
|
|
// =================================================================
|
|
|
|
#define FRMAKE_EXTERR(exterr) ((exterr) << 4)
|
|
|
|
// Used for all errors
|
|
|
|
#define FREXTERR_NONE FRMAKE_EXTERR(0) // No extended error code
|
|
|
|
// Extended errors for FRERR_UNRESOLVED
|
|
|
|
// We need a NO_PROP since the INCOMP_PROP can only store 32 values and there are 32 possible bits
|
|
|
|
#define FREXTERR_INCOMP_PROP FRMAKE_EXTERR(1) // At least one attachment had incompatible properties
|
|
// - Data contains prop index (high 3 bits) and src value index (low 5)
|
|
#define FREXTERR_NO_PROP FRMAKE_EXTERR(2) // At least one attachment had a property with no values
|
|
// - Data contains prop index (high 3 bits) and src value index (low 5)
|
|
#define FREXTERR_INCOMP_PROT FRMAKE_EXTERR(3) // The protocol was incompatible
|
|
// - Data contains protocol vers (3 bits) of src (high) and tgt (low)
|
|
// Data contains reason for encryption failure
|
|
// 0 - Means machine does not support encryption at all
|
|
// 1 - Means at least one attachment could not be snet encrypted (basically lin images to snowball)
|
|
|
|
#define FREXTERR_NO_ENCRYPT FRMAKE_EXTERR(4) // Could not resolve because the target did not support encryption
|
|
#define FREXTERR_NEED_RNDRS FRMAKE_EXTERR(5) // Renderers were needed but cannot be used with this job type
|
|
|
|
// Extended errors for FRERR_SOS_CORRUPT
|
|
|
|
#define FREXTERR_OPEN_FAIL FRMAKE_EXTERR(1) // Could not open an attachment or message
|
|
#define FREXTERR_GETPROP_FAIL FRMAKE_EXTERR(2) // There was a property missing
|
|
#define FREXTERR_BAD_VALUE FRMAKE_EXTERR(3) // Property had an invalid value
|
|
#define FREXTERR_SAVE_FAIL FRMAKE_EXTERR(4) // Could not save changes
|
|
#define FREXTERR_SETPROP_FAIL FRMAKE_EXTERR(5) // Could not set a property value
|
|
|
|
#define FREXTERR_BAD_MSG FRMAKE_EXTERR(6) // The message was not properly formed
|
|
|
|
// Extended errors for FRERR_DEV_FAIL and
|
|
// Extended errors for FRERR_SYSTEM_FAIL
|
|
|
|
#define FREXTERR_NOT_ENOUGH_MEM FRMAKE_EXTERR(1) // Out of memory
|
|
#define FREXTERR_LOAD_LIBRARY FRMAKE_EXTERR(2) // Load Library failed
|
|
#define FREXTERR_GETPROCADDRESS FRMAKE_EXTERR(3) // Get Proc Address failed
|
|
|
|
// Extended errors for FRERR_FR_FAIL
|
|
|
|
#define FREXTERR_INVALID_PARAM FRMAKE_EXTERR(1) // Invalid Parameter
|
|
#define FREXTERR_INVALID_STEP FRMAKE_EXTERR(2) // Invalid step (e.g. open called before init)
|
|
|
|
// =================================================================
|
|
// ERROR DATA
|
|
//
|
|
// The error data is different for every error/extended error pair
|
|
//
|
|
// =================================================================
|
|
|
|
#define FRMAKE_ERRDATA(exterr) ((exterr) << 8)
|
|
#define FRGET_ERRDATA(exterr) (((WORD)(exterr)) >> 8)
|
|
|
|
//
|
|
// These are the property indexes for FREXTERR_INCOMP_PROP extended error
|
|
//
|
|
|
|
#define FR_PROP_UNKNOWN (0)
|
|
#define FR_PROP_ENCODING (1)
|
|
#define FR_PROP_RESOLUTION (2)
|
|
#define FR_PROP_PAGESIZE (3)
|
|
#define FR_PROP_BRAND (4)
|
|
#define FR_PROP_LENLIMIT (5)
|
|
|
|
#define FRFormCustomError(err,exterr,data) ((WORD) (((err) | (exterr)) | FRMAKE_ERRDATA(data)))
|
|
#define FRFormIFError(err,exterr,data) \
|
|
(IFErrAssemble(PROCID_NONE,MODID_FORMAT_RES,0,FRFormCustomError((err),(exterr),(data))))
|
|
|
|
#define FRGetError(err) (((WORD)(err)) & 0x000f)
|
|
#define FRGetExtError(err) (((WORD)(err)) & 0x00f0)
|
|
#define FRGetErrorCode(err) (((WORD)(err)) & 0x00ff)
|
|
#define FRGetErrorData(err) FRGET_ERRDATA(err)
|
|
|
|
#define FRSetErrorData(dwerr,data) (((dwerr) & 0xffff00ff) | FRMAKE_ERRDATA(data))
|
|
|
|
#ifdef IFAX
|
|
|
|
//
|
|
// Format resolution flags
|
|
//
|
|
// These flags are passed in to the Resolve and CanResolve calls to indicate the target device
|
|
//
|
|
|
|
typedef enum {
|
|
FRES_NORMAL = 0, // Use the default destination
|
|
FRES_SPOOL = 1, // Spool to file
|
|
FRES_VIEW = 2, // Use viewer output format
|
|
FRES_PRINT = 3, // Send to printer
|
|
FRES_XMIT = 4, // Send to transport
|
|
FRES_PRINTALL = 5, // Send to printer (all attachments)
|
|
FRES_LOCAL_SEND = 6, // Send to local user
|
|
} FRDEST ;
|
|
|
|
// Function return Codes
|
|
//
|
|
// These are the codes returned from format resolution Resolve and CanResolve
|
|
//
|
|
// If the return value is anything but FR_RESOLVED then GetLastError will contain the extended error information
|
|
// - values for GetLastError are above
|
|
//
|
|
|
|
#define FR_UNRESOLVED 0x0000
|
|
#define FR_RESOLVED 0x0001
|
|
#define FR_COMPATIBLE 0x0002
|
|
#define FR_UPDATE 0x0004
|
|
#define FR_NON_RT 0x0008 // Non real-time (too slow or uses foreground resources)
|
|
#define FR_SOS_ERR 0x4000
|
|
#define FR_SYSTEM_ERR 0x8000
|
|
|
|
#define CHK_FR_ERR(n) ((n & (FR_SOS_ERR | FR_SYSTEM_ERR)) != 0)
|
|
|
|
//
|
|
// Some typedefs
|
|
//
|
|
|
|
typedef BC REMCAPS ;
|
|
typedef LPBC LPREMCAPS ;
|
|
|
|
//
|
|
// Context based calls
|
|
// These are used for better division of work. Some can be done beforehand.
|
|
//
|
|
|
|
typedef LPVOID LPFORMATRES ;
|
|
|
|
LPFORMATRES WINAPI FRAlloc() ;
|
|
void WINAPI FRFree(LPFORMATRES lpfr) ;
|
|
|
|
BOOL WINAPI FRInit(LPFORMATRES lpfr,HSOSCLIENT hsc,LPSOSMSG lpSrcMsg,LPSOSMSG lpTgtMsg) ;
|
|
void WINAPI FRDeInit(LPFORMATRES lpfr) ;
|
|
|
|
BOOL WINAPI FROpen(LPFORMATRES lpfr,
|
|
FRDEST Dest,
|
|
lpRSProcessPipeInfo_t lpProcInfo,
|
|
LPREMCAPS lpRemCaps) ;
|
|
|
|
void WINAPI FRClose(LPFORMATRES lpfr) ;
|
|
|
|
BOOL WINAPI FRResolve(LPFORMATRES lpfr) ;
|
|
|
|
BOOL WINAPI FRCanResolve(LPFORMATRES lpfr) ;
|
|
|
|
//
|
|
// These will perform the operation completely
|
|
//
|
|
|
|
UINT WINAPI FRResolveMsg (HSOSCLIENT hsc,
|
|
LPSOSMSG lpSrcMsg,
|
|
LPSOSMSG lpTgtMsg,
|
|
FRDEST Dest,
|
|
lpRSProcessPipeInfo_t lpProcInfo) ;
|
|
|
|
UINT WINAPI FRCanResolveMsg (HSOSCLIENT hsc,
|
|
LPSOSMSG lpSrcMsg,
|
|
LPSOSMSG lpTgtMsg,
|
|
FRDEST Dest,
|
|
lpRSProcessPipeInfo_t lpProcInfo) ;
|
|
|
|
UINT WINAPI FRCompareRemCaps (HSOSCLIENT hsc,
|
|
LPSOSMSG lpSrcMsg,
|
|
LPSOSMSG lpTgtMsg,
|
|
LPREMCAPS lpRemCaps) ;
|
|
|
|
UINT WINAPI FRResolveRemote (HSOSCLIENT hsc,
|
|
LPSOSMSG lpSrcMsg,
|
|
LPSOSMSG lpTgtMsg,
|
|
FRDEST Dest,
|
|
lpRSProcessPipeInfo_t lpProcInfo,
|
|
LPREMCAPS lpRemCaps) ;
|
|
|
|
#endif
|
|
|
|
// The target message needs to allocated and open
|
|
|
|
EXPORT_DLL BOOL WINAPI FRResolveEncoding (lpEncoding_t lpSrcEnc,
|
|
lpEncoding_t lpTgtEnc,
|
|
lpTopology FAR * lplpTop) ;
|
|
|
|
#ifdef WIN32
|
|
|
|
EXPORT_DLL BOOL WINAPI FRAddNode (lpTopology FAR * lpTop, LPSTR lpszName, LPSTR RenderProc, LPVOID lpParam , UINT cbParam) ;
|
|
|
|
EXPORT_DLL BOOL WINAPI FRAddTopNode (lpTopology FAR * lpTop, lpTopNode lpNode) ;
|
|
|
|
#endif
|
|
|
|
EXPORT_DLL void WINAPI FRFreeTopology (lpTopology lpTop) ;
|
|
|
|
//
|
|
// Page size and resolution APIs
|
|
//
|
|
|
|
/***********************************************************************
|
|
|
|
@doc PRINTER EXTERNAL
|
|
|
|
@types PAPERFORMAT|Structure to hold the Paper Format Information.
|
|
|
|
@field USHORT|usPaperType|The Size of the Paper.
|
|
@field USHORT|usPaperWidth|The width of the Paper in mm.
|
|
@field USHORT|usPaperHeight|The height of the Paper in mm.
|
|
@field USHORT|usXImage|The number of pixels in x direction that will be
|
|
created in an image for this page size at the resolution specified by
|
|
the field usResInHorz by the printer driver.
|
|
@field USHORT|usYImage|The number of scanlines that will be renderd for this
|
|
page size at the resolution specified in usResInVert by the printer
|
|
driver.
|
|
@field USHORT|usResInHorz|The resolution in dpi (rounded to the closest
|
|
hundredth) in the x direction.
|
|
@field USHORT|usResInVert|The resolution in dpi (rounded to the closest
|
|
hundredth) in the y direction.
|
|
@field USHORT|usResInVert|The resolution in dpi (rounded to the closest
|
|
hundredth) in the y direction.
|
|
@field USHORT|usAspectXY|The AspectXY for a given resolution. The is equal
|
|
to the square root of the sum of squares of the resolution(in dpi)
|
|
in x and y directions.
|
|
*************************************************************************/
|
|
|
|
typedef struct _PAPERFORMAT{
|
|
USHORT usPaperType; // the equivalent windows paper size
|
|
USHORT usPaperWidth; //in mm
|
|
USHORT usPaperHeight; //in mm
|
|
USHORT usXImage; //in pixels
|
|
USHORT usYImage; //in pixels
|
|
USHORT usResInHorz; //the resolution in dpi in x dir
|
|
USHORT usResInVert; //the resolution in dpi in y dir
|
|
USHORT usAspectXY; //for the gdi info
|
|
} PAPERFORMAT, * PPAPERFORMAT;
|
|
|
|
typedef PAPERFORMAT FAR * LPPAPERFORMAT;
|
|
typedef PAPERFORMAT NEAR * NPPAPERFORMAT;
|
|
|
|
EXPORT_DLL USHORT WINAPI GetStdBytesPerLine(ULONG ulResolution,ULONG ulPaperSize);
|
|
EXPORT_DLL DWORD WINAPI GetStdPixelsPerLine(ULONG ulResolution,ULONG ulPaperSize);
|
|
EXPORT_DLL DWORD WINAPI GetStdLinesPerPage(ULONG ulResolution,ULONG ulPaperSize);
|
|
EXPORT_DLL USHORT WINAPI GetXResolution(ULONG ulResolution);
|
|
EXPORT_DLL USHORT WINAPI GetYResolution(ULONG ulResolution);
|
|
EXPORT_DLL BOOL WINAPI GetPaperFormatInfo(LPPAPERFORMAT lpPf,ULONG ulAwPaperSize,USHORT usXRes,USHORT usYRes);
|
|
|
|
EXPORT_DLL WORD WINAPI AWPaperToFaxWidth(ULONG ulPaperSize);
|
|
EXPORT_DLL ULONG WINAPI FaxWidthToAWPaper(WORD Width);
|
|
EXPORT_DLL WORD WINAPI AWPaperToFaxLength(ULONG ulPaperSize);
|
|
|
|
#ifdef IFAX
|
|
|
|
// Given an encoding and an association returns either the same encoding or a new one
|
|
|
|
BOOL WINAPI FRGetAssocEncoding (lpEncoding_t lpEnc,LPSTR lpExt) ;
|
|
|
|
// This will return the paper sizes supported with the given input paper and zoom options
|
|
// This will return at ulPaperSize if ulZoomOption is 0
|
|
|
|
ULONG WINAPI GetZoomCaps(ULONG ulPaperSize,ULONG ulZoomOption) ;
|
|
|
|
// This will give the zoom value to use to get ZoomPaperSize from OrigPaperSize
|
|
// Returns 0 if not possible
|
|
|
|
ULONG WINAPI GetZoomValue(ULONG ulOrigPaperSize,ULONG ulZoomPaperSize) ;
|
|
|
|
//
|
|
// Debug functions - stubbed out in retail
|
|
//
|
|
|
|
// Returns TRUE if the fmtres version is debug, FALSE if retail (basically whether this does anything)
|
|
// The parameters are bit arrays, not enumerated values
|
|
// -1 will disable a filter
|
|
|
|
BOOL WINAPI FRSetDestCapFilter(DWORD dwEnc,DWORD dwRes,DWORD dwPageSize,DWORD dwLenLimit) ;
|
|
BOOL WINAPI FRGetDestCapFilter(LPDWORD dwEnc,LPDWORD dwRes,LPDWORD dwPageSize,LPDWORD dwLenLimit) ;
|
|
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
} // extern "C"
|
|
#endif
|
|
|
|
#endif // _FMTRES_H
|
|
|
|
|