Leaked source code of windows server 2003
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.
 
 
 
 
 
 

536 lines
16 KiB

/*++
Copyright (c) 1996-2002 Microsoft Corp. & Ricoh Co., Ltd. All rights reserved.
FILE: COMMON.C
Abstract: Implementation of common functions for rendering & UI
plugin module.
Functions: OEMGetInfo
OEMDevMode
RWFileData
Environment: Windows NT Unidrv5 driver
Revision History:
04/07/1997 -zhanw-
Created it.
02/29/2000 -Masatoshi Kubokura-
Modified for PCL5e/PScript plugin from RPDL code.
05/31/2000 -Masatoshi Kubokura-
V.1.11
08/02/2000 -Masatoshi Kubokura-
V.1.11 for NT4
09/22/2000 -Masatoshi Kubokura-
Last modified for XP inbox.
02/26/2002 -Masatoshi Kubokura-
Include strsafe.h
Add FileNameBufSize as arg3 at RWFileData().
--*/
#include <minidrv.h>
#include "devmode.h"
#include "oem.h"
#include "resource.h"
#ifndef WINNT_40
#include "strsafe.h" // @Feb/26/2002
#endif // !WINNT_40
// shared data file between rendering and UI plugin
#ifndef WINNT_40
#define SHAREDFILENAME L"RIAF5.BIN"
#else // WINNT_40
#define SHAREDFILENAME L"\\2\\RIA%.3ls%02x.BIN"
DWORD gdwDrvMemPoolTag = 'meoD'; // minidrv.h requires this global var
#endif // WINNT_40
#if DBG && !defined(KM_DRIVER)
INT giDebugLevel = DBG_ERROR;
#endif
////////////////////////////////////////////////////////
// INTERNAL PROTOTYPES
////////////////////////////////////////////////////////
static BOOL BInitOEMExtraData(POEMUD_EXTRADATA pOEMExtra);
static BOOL BMergeOEMExtraData(POEMUD_EXTRADATA pdmIn, POEMUD_EXTRADATA pdmOut);
static BOOL BIsValidOEMDevModeParam(DWORD dwMode, POEMDMPARAM pOEMDevModeParam);
#if DBG
static void VDumpOEMDevModeParam(POEMDMPARAM pOEMDevModeParam);
#endif // DBG
//////////////////////////////////////////////////////////////////////////
// Function: OEMGetInfo
//////////////////////////////////////////////////////////////////////////
BOOL APIENTRY OEMGetInfo(DWORD dwInfo, PVOID pBuffer, DWORD cbSize, PDWORD pcbNeeded)
{
#if DBG
LPCSTR OEM_INFO[] = { "Bad Index",
"OEMGI_GETSIGNATURE",
"OEMGI_GETINTERFACEVERSION",
"OEMGI_GETVERSION",
};
VERBOSE((DLLTEXT("OEMGetInfo(%s) entry.\n"), OEM_INFO[dwInfo]));
#endif // DBG
// Validate parameters.
if( ( (OEMGI_GETSIGNATURE != dwInfo) &&
(OEMGI_GETINTERFACEVERSION != dwInfo) &&
(OEMGI_GETVERSION != dwInfo) ) ||
(NULL == pcbNeeded)
)
{
ERR(("OEMGetInfo() ERROR_INVALID_PARAMETER.\n"));
// Did not write any bytes.
if(NULL != pcbNeeded)
*pcbNeeded = 0;
return FALSE;
}
// Need/wrote 4 bytes.
*pcbNeeded = 4;
// Validate buffer size. Minimum size is four bytes.
if( (NULL == pBuffer) || (4 > cbSize) )
{
ERR(("OEMGetInfo() ERROR_INSUFFICIENT_BUFFER.\n"));
return FALSE;
}
// Write information to buffer.
switch(dwInfo)
{
case OEMGI_GETSIGNATURE:
*(LPDWORD)pBuffer = OEM_SIGNATURE;
break;
case OEMGI_GETINTERFACEVERSION:
*(LPDWORD)pBuffer = PRINTER_OEMINTF_VERSION;
break;
case OEMGI_GETVERSION:
*(LPDWORD)pBuffer = OEM_VERSION;
break;
}
return TRUE;
} //*** OEMGetInfo
//////////////////////////////////////////////////////////////////////////
// Function: OEMDevMode
//////////////////////////////////////////////////////////////////////////
BOOL APIENTRY OEMDevMode(DWORD dwMode, POEMDMPARAM pOEMDevModeParam)
{
#if DBG
LPCSTR OEMDevMode_fMode[] = { "NULL",
"OEMDM_SIZE",
"OEMDM_DEFAULT",
"OEMDM_CONVERT",
"OEMDM_MERGE",
};
VERBOSE((DLLTEXT("OEMDevMode(%s) entry.\n"), OEMDevMode_fMode[dwMode]));
#endif // DBG
// Validate parameters.
if(!BIsValidOEMDevModeParam(dwMode, pOEMDevModeParam))
{
#if DBG
ERR(("OEMDevMode() ERROR_INVALID_PARAMETER.\n"));
VDumpOEMDevModeParam(pOEMDevModeParam);
#endif // DBG
return FALSE;
}
// Verify OEM extra data size.
if( (dwMode != OEMDM_SIZE) &&
sizeof(OEMUD_EXTRADATA) > pOEMDevModeParam->cbBufSize )
{
ERR(("OEMDevMode() ERROR_INSUFFICIENT_BUFFER.\n"));
return FALSE;
}
// Handle dwMode.
switch(dwMode)
{
case OEMDM_SIZE:
pOEMDevModeParam->cbBufSize = sizeof(OEMUD_EXTRADATA);
break;
case OEMDM_DEFAULT:
#if defined(WINNT_40) && defined(DISKLESSMODEL) // @Aug/02/2000
// Because NT4 spooler doesn't support collate, we clear dmCollate.
// Later at OEMUICallBack, if printer collate is available, we set
// dmCollate.
pOEMDevModeParam->pPublicDMIn->dmCollate = DMCOLLATE_FALSE;
pOEMDevModeParam->pPublicDMIn->dmFields &= ~DM_COLLATE;
#endif
return BInitOEMExtraData((POEMUD_EXTRADATA)pOEMDevModeParam->pOEMDMOut);
case OEMDM_CONVERT:
case OEMDM_MERGE:
if(!BMergeOEMExtraData((POEMUD_EXTRADATA)pOEMDevModeParam->pOEMDMIn,
(POEMUD_EXTRADATA)pOEMDevModeParam->pOEMDMOut) )
{
ERR(("OEMUD OEMDevMode(): not valid OEM Extra Data.\n"));
return FALSE;
}
break;
}
return TRUE;
} //*** OEMDevMode
//////////////////////////////////////////////////////////////////////////
// Function: BInitOEMExtraData
//
// Description: Initializes OEM Extra data.
//
// Parameters:
// pOEMExtra Pointer to a OEM Extra data.
// dwSize Size of OEM extra data.
//
// Returns: TRUE if successful; FALSE otherwise.
//
// Comments:
//
// History:
// 02/11/1997 APresley Created.
// 02/28/2000 Masatoshi Kubokura Modified for PCL5e/PScript
//
//////////////////////////////////////////////////////////////////////////
BOOL BInitOEMExtraData(POEMUD_EXTRADATA pOEMExtra)
{
INT num;
// Initialize OEM Extra data.
pOEMExtra->dmOEMExtra.dwSize = sizeof(OEMUD_EXTRADATA);
pOEMExtra->dmOEMExtra.dwSignature = OEM_SIGNATURE;
pOEMExtra->dmOEMExtra.dwVersion = OEM_VERSION;
pOEMExtra->fUiOption = 0;
pOEMExtra->JobType = IDC_RADIO_JOB_NORMAL;
pOEMExtra->LogDisabled = IDC_RADIO_LOG_DISABLED;
return TRUE;
} //*** BInitOEMExtraData
//////////////////////////////////////////////////////////////////////////
// Function: BMergeOEMExtraData
//
// Description: Validates and merges OEM Extra data.
//
// Parameters:
// pdmIn pointer to an input OEM private devmode containing the settings
// to be validated and merged. Its size is current.
// pdmOut pointer to the output OEM private devmode containing the
// default settings.
//
// Returns: TRUE if valid; FALSE otherwise.
//
// Comments:
//
// History:
// 02/11/1997 APresley Created.
// 04/08/1997 ZhanW Modified the interface
// 08/11/1997 Masatoshi Kubokura Modified for RPDL
//
//////////////////////////////////////////////////////////////////////////
BOOL BMergeOEMExtraData(POEMUD_EXTRADATA pdmIn, POEMUD_EXTRADATA pdmOut)
{
if(pdmIn) {
LPBYTE pDst = (LPBYTE)&(pdmOut->fUiOption);
LPBYTE pSrc = (LPBYTE)&(pdmIn->fUiOption);
DWORD dwCount = sizeof(OEMUD_EXTRADATA) - sizeof(OEM_DMEXTRAHEADER);
//
// copy over the private fields, if they are valid
//
while (dwCount-- > 0)
*pDst++ = *pSrc++;
}
return TRUE;
} //*** BMergeOEMExtraData
//////////////////////////////////////////////////////////////////////////
// Function: BIsValidOEMDevModeParam
//
// Description: Validates OEM_DEVMODEPARAM structure.
//
// Parameters:
// dwMode calling mode
// pOEMDevModeParam Pointer to a OEMDEVMODEPARAM structure.
//
// Returns: TRUE if valid; FALSE otherwise.
//
// Comments:
//
// History:
// 02/11/1997 APresley Created.
//
//////////////////////////////////////////////////////////////////////////
static BOOL BIsValidOEMDevModeParam(DWORD dwMode, POEMDMPARAM pOEMDevModeParam)
{
BOOL bValid = TRUE;
if(NULL == pOEMDevModeParam)
{
ERR(("OEMUD IsValidOEMDevModeParam(): pOEMDevModeParam is NULL.\n"));
return FALSE;
}
if(sizeof(OEMDMPARAM) > pOEMDevModeParam->cbSize)
{
ERR(("OEMUD IsValidOEMDevModeParam(): cbSize is smaller than sizeof(OEM_DEVMODEPARAM).\n"));
bValid = FALSE;
}
if(NULL == pOEMDevModeParam->hPrinter)
{
ERR(("OEMUD IsValidOEMDevModeParam(): hPrinter is NULL.\n"));
bValid = FALSE;
}
if(NULL == pOEMDevModeParam->hModule)
{
ERR(("OEMUD IsValidOEMDevModeParam(): hModule is NULL.\n"));
bValid = FALSE;
}
if( (0 != pOEMDevModeParam->cbBufSize) &&
(NULL == pOEMDevModeParam->pOEMDMOut)
)
{
ERR(("OEMUD IsValidOEMDevModeParam(): pOEMDMOut is NULL when it should not be.\n"));
bValid = FALSE;
}
if( (OEMDM_MERGE == dwMode) && (NULL == pOEMDevModeParam->pOEMDMIn) )
{
ERR(("OEMUD IsValidOEMDevModeParam(): pOEMDMIn is NULL when it should not be.\n"));
bValid = FALSE;
}
return bValid;
} //*** BIsValidOEMDevModeParam
#if DBG
//////////////////////////////////////////////////////////////////////////
// Function: VDumpOEMDevModeParam
//
// Description: Debug dump of OEM_DEVMODEPARAM structure.
//
// Parameters:
// pOEMDevModeParam Pointer to an OEM DevMode param structure.
//
// Returns: N/A.
//
// Comments:
//
// History:
// 02/18/1997 APresley Created.
//
//////////////////////////////////////////////////////////////////////////
static void VDumpOEMDevModeParam(POEMDMPARAM pOEMDevModeParam)
{
// Can't dump if pOEMDevModeParam NULL.
if(NULL != pOEMDevModeParam)
{
VERBOSE(("\n\tOEM_DEVMODEPARAM dump:\n\n"));
VERBOSE(("\tcbSize = %d.\n", pOEMDevModeParam->cbSize));
VERBOSE(("\thPrinter = %#lx.\n", pOEMDevModeParam->hPrinter));
VERBOSE(("\thModule = %#lx.\n", pOEMDevModeParam->hModule));
VERBOSE(("\tpPublicDMIn = %#lx.\n", pOEMDevModeParam->pPublicDMIn));
VERBOSE(("\tpPublicDMOut = %#lx.\n", pOEMDevModeParam->pPublicDMOut));
VERBOSE(("\tpOEMDMIn = %#lx.\n", pOEMDevModeParam->pOEMDMIn));
VERBOSE(("\tpOEMDMOut = %#lx.\n", pOEMDevModeParam->pOEMDMOut));
VERBOSE(("\tcbBufSize = %d.\n", pOEMDevModeParam->cbBufSize));
}
} //*** VDumpOEMDevModeParam
#endif // DBG
//////////////////////////////////////////////////////////////////////////
// Function: RWFileData
//
// Description: Read/Write common file between UI plugin and rendering
// plugin
//
// Parameters:
// pFileData pointer to file data structure
// pwszFileName pointer to file name of private devmode
// FileNameBufSize file name buffer size (add 02/26/2002)
// type GENERIC_READ/GENERIC_WRITE
//
// Returns: TRUE if valid; FALSE otherwise.
//
// Comments: Rendering plugin records printing-done flag to the file.
// Both rendering plugin and UI plugin can know that status.
//
// History:
// 09/30/1998 Masatoshi Kubokura Created.
// 08/16/1999 takashim modified for Unidrv5.4 on NT4.
// 09/01/1999 Kubokura modified for Unidrv5.4 on NT4.
// 02/26/2002 Kubokura added FileNameBufSize param.
//
//////////////////////////////////////////////////////////////////////////
BOOL RWFileData(PFILEDATA pFileData, LPWSTR pwszFileName, LONG FileNameBufSize, LONG type)
{
HANDLE hFile;
DWORD dwSize;
BOOL bRet = FALSE;
#ifndef KM_DRIVER
WCHAR szFileName[MY_MAX_PATH]; // MY_MAX_PATH=80
#endif // KM_DRIVER
#if DBG
giDebugLevel = DBG_VERBOSE;
#endif
VERBOSE(("** Filename[0]=%d (%ls) **\n", pwszFileName[0], pwszFileName));
#ifndef KM_DRIVER
#ifndef WINNT_40
//
// CAUTION:
// TempPath is different whether EMF spool is enable(system) or not(user).
// We need to store the file name to private devmode.
//
// Set data data file name to private devmode at first time
if (0 == pwszFileName[0])
{
if (0 == (dwSize = GetTempPath(MY_MAX_PATH, szFileName)))
{
ERR(("Could not get temp directory."));
return bRet;
}
// @Feb/26/2002 ->
// wcscpy(&szFileName[dwSize], SHAREDFILENAME);
StringCbCopyW(&szFileName[dwSize], sizeof(szFileName) - dwSize, SHAREDFILENAME);
// @Feb/26/2002 <-
VERBOSE(("** Set Filename: %ls **\n", szFileName));
// copy file name to private devmode
// @Feb/26/2002 ->
// wcscpy(pwszFileName, szFileName);
StringCbCopyW(pwszFileName, FileNameBufSize, szFileName);
// @Feb/26/2002 <-
}
#else // WINNT_40
//
// CAUTION:
// The file path differs on each PC in printer sharing.
// We always update the file name (with path) of private devmode.
// (@Sep/03/99)
//
// Kernel-mode driver (NT4 RPDLRES.DLL) can access files under
// %systemroot%\system32. Driver directory will be OK.
if (GetPrinterDriverDirectory(NULL, NULL, 1, (PBYTE)szFileName,
sizeof(szFileName), &dwSize))
{
WCHAR szValue[MY_MAX_PATH] = L"XXXX";
DWORD dwSize2;
DWORD dwNum = 0; // @Sep/21/99
PWCHAR pwszTmp; // @Sep/21/99
// Make unique filename "RIAXXXNN.BIN". "XXX" is filled with top 3char of username.
dwSize2 = GetEnvironmentVariable(L"USERNAME", szValue, MY_MAX_PATH);
// @Sep/21/99 ->
// wsprintf(&szFileName[dwSize/sizeof(WCHAR)-1], SHAREDFILENAME, szValue, dwSize2);
pwszTmp = szValue;
while (dwSize2-- > 0)
dwNum += (DWORD)*pwszTmp++;
wsprintf(&szFileName[dwSize/sizeof(WCHAR)-1], SHAREDFILENAME, szValue, (BYTE)dwNum);
// @Sep/21/99 <-
VERBOSE(("** Set Filename: %ls **\n", szFileName));
// copy file name to private devmode
wcscpy(pwszFileName, szFileName);
}
else
{
ERR(("Could not get printer driver directory.(dwSize=%d)", dwSize));
return bRet;
}
#endif // WINNT_40
hFile = CreateFile((LPTSTR) pwszFileName, // filename
type, // open for read/write
FILE_SHARE_READ, // share to read
NULL, // no security
OPEN_ALWAYS, // open existing file,or open new if not exist
FILE_ATTRIBUTE_NORMAL, // normal file
NULL); // no attr. template
if (INVALID_HANDLE_VALUE == hFile)
{
ERR(("Could not create data file."));
return bRet;
}
if (GENERIC_WRITE == type)
bRet = WriteFile(hFile, (PBYTE)pFileData, sizeof(FILEDATA), &dwSize, NULL);
else if (GENERIC_READ == type)
bRet = ReadFile(hFile, (PBYTE)pFileData, sizeof(FILEDATA), &dwSize, NULL);
VERBOSE(("** RWFileData: bRet=%d, dwSize=%d**\n", bRet, dwSize));
// Close files.
CloseHandle(hFile);
#else // KM_DRIVER
if (0 != pwszFileName[0])
{
PBYTE pTemp;
if (GENERIC_WRITE == type)
{
hFile = DrvMapFileForWrite(pwszFileName, sizeof (FILEDATA),
&pTemp, &dwSize);
if (NULL != hFile)
{
memcpy(pTemp, pFileData, sizeof (FILEDATA));
DrvUnMapFile(hFile);
bRet = TRUE;
}
}
else
{
hFile = DrvMapFileForRead(pwszFileName, &pTemp, &dwSize);
if (NULL != hFile)
{
memcpy(pFileData, pTemp, sizeof (FILEDATA));
DrvUnMapFile(hFile);
bRet = TRUE;
}
}
}
#endif // KM_DRIVER
#if DBG
giDebugLevel = DBG_ERROR;
#endif
return bRet;
} //*** RWFileData