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.
1080 lines
39 KiB
1080 lines
39 KiB
/*++
|
|
|
|
Copyright (c) 1995 Microsoft Corporation
|
|
All rights reserved.
|
|
|
|
Module Name:
|
|
|
|
localspl.cxx
|
|
|
|
Abstract:
|
|
|
|
SUR localspl structures.
|
|
|
|
Author:
|
|
|
|
Albert Ting (AlbertT) 19-Feb-1995
|
|
|
|
Revision History:
|
|
|
|
--*/
|
|
|
|
#include "precomp.hxx"
|
|
#pragma hdrstop
|
|
|
|
extern "C" {
|
|
#include "spltypes.h"
|
|
}
|
|
|
|
/********************************************************************
|
|
|
|
Localspl structures; mostly defined in localspl\spltypes.h
|
|
|
|
********************************************************************/
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpIniSpooler(
|
|
PVOID pIniSpooler_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
static DEBUG_FLAGS adfSpl[] = {
|
|
{ "UpdateWinIniDevices", SPL_UPDATE_WININI_DEVICES },
|
|
{ "PrinterChanges", SPL_PRINTER_CHANGES },
|
|
{ "LogEvents", SPL_LOG_EVENTS },
|
|
{ "FormsChange", SPL_FORMS_CHANGE },
|
|
{ "BroadcastChange", SPL_BROADCAST_CHANGE },
|
|
{ "SecurityCheck", SPL_SECURITY_CHECK },
|
|
{ "OpenCreatePorts", SPL_OPEN_CREATE_PORTS },
|
|
{ "FailOpenPrintersPendDel", SPL_FAIL_OPEN_PRINTERS_PENDING_DELETION },
|
|
{ "RemoteHandleCheck", SPL_REMOTE_HANDLE_CHECK },
|
|
{ "PrinterDriverEvent", SPL_PRINTER_DRIVER_EVENT },
|
|
{ "AlwaysCreateDriverShare", SPL_ALWAYS_CREATE_DRIVER_SHARE },
|
|
{ "NoUpdatePrinterIni", SPL_NO_UPDATE_PRINTERINI },
|
|
{ "NoUpdateJobShd", SPL_NO_UPDATE_JOBSHD },
|
|
{ "ClusterReg", SPL_CLUSTER_REG },
|
|
{ "Offline", SPL_OFFLINE },
|
|
{ "PendingDeletion", SPL_PENDING_DELETION },
|
|
{ "ServerThread", SPL_SERVER_THREAD },
|
|
{ "Print", SPL_PRINT },
|
|
{ "TypeLocal", SPL_TYPE_LOCAL },
|
|
{ "TypeCluster", SPL_TYPE_CLUSTER },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
PINISPOOLER pIniSpooler = (PINISPOOLER)pIniSpooler_;
|
|
|
|
if( !( pIniSpooler->signature == ISP_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "IniSpooler*\n" );
|
|
|
|
Print( " pIniNextSpooler %x\n", pIniSpooler->pIniNextSpooler );
|
|
Print( " cRef <%d>\n", pIniSpooler->cRef );
|
|
Print( " pMachineName " ); vDumpStr( pIniSpooler->pMachineName );
|
|
Print( " pDir " ); vDumpStr( pIniSpooler->pDir );
|
|
|
|
Print( " pIniPrinter %x\n", pIniSpooler->pIniPrinter );
|
|
Print( " pIniEnvironment %x\n", pIniSpooler->pIniEnvironment );
|
|
Print( " pIniMonitor %x\n", pIniSpooler->pIniMonitor );
|
|
Print( " pIniPort %x\n", pIniSpooler->pIniPort );
|
|
Print( " pShared %x\n", pIniSpooler->pShared );
|
|
Print( " pIniNetPrint %x\n", pIniSpooler->pIniNetPrint );
|
|
Print( " pSpool %x\n", pIniSpooler->pSpool );
|
|
|
|
Print( " pDefaultSpoolDir " ); vDumpStr( pIniSpooler->pDefaultSpoolDir );
|
|
|
|
Print( " pszRegistryMonitors " ); vDumpStr( pIniSpooler->pszRegistryMonitors );
|
|
Print( "pszRegistryEnvironments " ); vDumpStr( pIniSpooler->pszRegistryEnvironments );
|
|
Print( " pszRegistryEventLog " ); vDumpStr( pIniSpooler->pszRegistryEventLog );
|
|
Print( " pszRegistryProviders " ); vDumpStr( pIniSpooler->pszRegistryProviders );
|
|
Print( " pszEventLogMsgFile " ); vDumpStr( pIniSpooler->pszEventLogMsgFile );
|
|
|
|
Print( " pDriversShareInfo %x\n", pIniSpooler->pDriversShareInfo );
|
|
Print( " pszDriversShare " ); vDumpStr( pIniSpooler->pszDriversShare );
|
|
Print( " pszRegistryForms " ); vDumpStr( pIniSpooler->pszRegistryForms );
|
|
|
|
Print( " SpoolerFlags " );
|
|
vDumpFlags( pIniSpooler->SpoolerFlags, adfSpl );
|
|
|
|
|
|
Print( " pfnReadRegistryExtra %x\n", pIniSpooler->pfnReadRegistryExtra );
|
|
Print( " pfnWriteRegistryExtra %x\n", pIniSpooler->pfnWriteRegistryExtra );
|
|
Print( " pfnFreePrinterExtra %x\n", pIniSpooler->pfnFreePrinterExtra );
|
|
|
|
Print( " cEnumNetworkPrinters <%d>\n", pIniSpooler->cEnumerateNetworkPrinters );
|
|
Print( " cAddNetPrinters <%d>\n", pIniSpooler->cAddNetPrinters );
|
|
Print( " cFormOrderMax <%d>\n", pIniSpooler->cFormOrderMax );
|
|
Print( " pNoRemotePrintDrivers " ); vDumpStr( pIniSpooler->pNoRemotePrintDrivers );
|
|
Print( " cchNoRemotePrintDrivers <%d>\n", pIniSpooler->cchNoRemotePrintDrivers );
|
|
Print( " hckRoot %x\n", pIniSpooler->hckRoot );
|
|
Print( " hckPrinters %x\n", pIniSpooler->hckPrinters );
|
|
Print( " cFullPrintingJobs <%d>\n", pIniSpooler->cFullPrintingJobs );
|
|
Print( " hEventNoPrintingJobs %x\n", pIniSpooler->hEventNoPrintingJobs );
|
|
Print( " hJobIdMap %x\n", pIniSpooler->hJobIdMap );
|
|
Print( " dwEventLogging <%d>\n", pIniSpooler->dwEventLogging );
|
|
Print( " bEnableNetPopups <%d>\n", pIniSpooler->bEnableNetPopups );
|
|
Print( " dwJobCompletionTimeout <%d>\n", pIniSpooler->dwJobCompletionTimeout );
|
|
Print( " dwBeepEnabled <%d>\n", pIniSpooler->dwBeepEnabled );
|
|
Print( "bEnableNetPopupToComputer <%d>\n", pIniSpooler->bEnableNetPopupToComputer );
|
|
Print( " bEnableRetryPopups <%d>\n", pIniSpooler->bEnableRetryPopups );
|
|
Print( " pszClusterSID " ); vDumpStr( pIniSpooler->pszClusterSID );
|
|
Print( " hClusterToken <%d>\n", pIniSpooler->hClusterToken );
|
|
Print( "dwRestartJobOnPoolTimeout <%d>\n", pIniSpooler->dwRestartJobOnPoolTimeout );
|
|
Print( " bRestartJobOnPoolEnabled <%d>\n", pIniSpooler->bRestartJobOnPoolEnabled );
|
|
Print( " bImmortal <%d>\n", pIniSpooler->bImmortal );
|
|
Print( " pszFullMachineName " ); vDumpStr( pIniSpooler->pszFullMachineName );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpIniPrintProc(
|
|
PVOID pIniPrintProc_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PINIPRINTPROC pIniPrintProc = (PINIPRINTPROC)pIniPrintProc_;
|
|
|
|
static DEBUG_FLAGS adfSpl[] = {
|
|
{ "UpdateWinIniDevices", SPL_UPDATE_WININI_DEVICES },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
if( !( pIniPrintProc->signature == IPP_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "IniPrintProc*\n" );
|
|
|
|
Print( " pNext %x\n", pIniPrintProc->pNext );
|
|
Print( " cRef <%d>\n", pIniPrintProc->cRef );
|
|
|
|
Print( " pName " ); vDumpStr( pIniPrintProc->pName );
|
|
Print( " pDLLName " ); vDumpStr( pIniPrintProc->pDLLName );
|
|
|
|
Print( " cbDatatypes %x\n", pIniPrintProc->cbDatatypes );
|
|
Print( " cDatatypes %x\n", pIniPrintProc->cDatatypes );
|
|
Print( " pDatatypes %x\n", pIniPrintProc->pDatatypes );
|
|
Print( " hLibrary %x\n", pIniPrintProc->hLibrary );
|
|
Print( " Install %x\n", pIniPrintProc->Install );
|
|
Print( " EnumDatatypes %x\n", pIniPrintProc->EnumDatatypes );
|
|
Print( " Open %x\n", pIniPrintProc->Open );
|
|
Print( " Print %x\n", pIniPrintProc->Print );
|
|
Print( " Close %x\n", pIniPrintProc->Close );
|
|
Print( " Control %x\n", pIniPrintProc->Control );
|
|
Print( " CriticalSection @ %x\n", dwAddr
|
|
+ OFFSETOF( INIPRINTPROC, CriticalSection ));
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpIniDriver(
|
|
PVOID pIniDriver_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PINIDRIVER pIniDriver = (PINIDRIVER)pIniDriver_;
|
|
|
|
static DEBUG_FLAGS adfSpl[] = {
|
|
{ "UpdateWinIniDevices", SPL_UPDATE_WININI_DEVICES },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
if( !( pIniDriver->signature == ID_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "IniDriver*\n" );
|
|
|
|
Print( " pNext %x\n", pIniDriver->pNext );
|
|
Print( " cRef <%d>\n", pIniDriver->cRef );
|
|
|
|
Print( " pName " ); vDumpStr( pIniDriver->pName );
|
|
Print( " pDriverFile " ); vDumpStr( pIniDriver->pDriverFile );
|
|
Print( " pConfigFile " ); vDumpStr( pIniDriver->pConfigFile );
|
|
Print( " pDataFile " ); vDumpStr( pIniDriver->pDataFile );
|
|
Print( " pHelpFile " ); vDumpStr( pIniDriver->pHelpFile );
|
|
|
|
Print( " cchDependentFiles %x\n", pIniDriver->cchDependentFiles );
|
|
Print( " pDependentFiles %x\n", pIniDriver->pDependentFiles );
|
|
|
|
Print( " pMonitorName " ); vDumpStr( pIniDriver->pMonitorName );
|
|
Print( " pDefaultDataType " ); vDumpStr( pIniDriver->pDefaultDataType );
|
|
|
|
Print( " cVersion %x\n", pIniDriver->cVersion );
|
|
Print( " pIniLangMonitor %x\n", pIniDriver->pIniLangMonitor );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpIniVersion(
|
|
PVOID pIniVersion_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PINIVERSION pIniVersion = (PINIVERSION)pIniVersion_;
|
|
|
|
if( !( pIniVersion->signature == IV_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "IniVersion*\n" );
|
|
|
|
Print( " pNext %x\n", pIniVersion->pNext );
|
|
Print( " pName " ); vDumpStr( pIniVersion->pName );
|
|
Print( " szDirectory " ); vDumpStr( pIniVersion->szDirectory );
|
|
Print( " cMajorVersion %x\n", pIniVersion->cMajorVersion );
|
|
Print( " cMinorVersion %x\n", pIniVersion->cMinorVersion );
|
|
Print( " pIniDriver %x\n", pIniVersion->pIniDriver );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpIniEnvironment(
|
|
PVOID pIniEnvironment_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PINIENVIRONMENT pIniEnvironment = (PINIENVIRONMENT)pIniEnvironment_;
|
|
|
|
if( !( pIniEnvironment->signature == IE_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "IniEnvironment*\n" );
|
|
|
|
Print( " pNext %x\n", pIniEnvironment->pNext );
|
|
Print( " cRef <%d>\n", pIniEnvironment->cRef );
|
|
|
|
Print( " pName " ); vDumpStr( pIniEnvironment->pName );
|
|
Print( " pDirectory " ); vDumpStr( pIniEnvironment->pDirectory );
|
|
|
|
Print( " pIniVersion %x\n", pIniEnvironment->pIniVersion );
|
|
Print( " pIniPrintProc %x\n", pIniEnvironment->pIniPrintProc );
|
|
Print( " pIniSpooler %x\n", pIniEnvironment->pIniSpooler );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpIniMonitor(
|
|
PVOID pIniMonitor_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PINIMONITOR pIniMonitor = (PINIMONITOR)pIniMonitor_;
|
|
|
|
if( !( pIniMonitor->signature == IMO_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "IniMonitor*\n" );
|
|
|
|
Print( " pNext %x\n", pIniMonitor->pNext );
|
|
Print( " cRef <%d>\n", pIniMonitor->cRef );
|
|
|
|
Print( " pName " ); vDumpStr( pIniMonitor->pName );
|
|
Print( " pMonitorDll " ); vDumpStr( pIniMonitor->pMonitorDll );
|
|
|
|
Print( " hModule %x\n", pIniMonitor->hModule );
|
|
Print( " == Monitor2 ==\n" );
|
|
Print( " EnumPorts %x\n", pIniMonitor->Monitor2.pfnEnumPorts );
|
|
Print( " OpenPort %x\n", pIniMonitor->Monitor2.pfnOpenPort );
|
|
Print( " OpenPortEx %x\n", pIniMonitor->Monitor2.pfnOpenPortEx );
|
|
Print( " StartDocPort %x\n", pIniMonitor->Monitor2.pfnStartDocPort );
|
|
Print( " WritePort %x\n", pIniMonitor->Monitor2.pfnWritePort );
|
|
Print( " ReadPort %x\n", pIniMonitor->Monitor2.pfnReadPort );
|
|
Print( " EndDocPort %x\n", pIniMonitor->Monitor2.pfnEndDocPort );
|
|
Print( " ClosePort %x\n", pIniMonitor->Monitor2.pfnClosePort );
|
|
Print( " AddPort %x\n", pIniMonitor->Monitor2.pfnAddPort );
|
|
Print( " AddPortsEx %x\n", pIniMonitor->Monitor2.pfnAddPortEx );
|
|
Print( " ConfigurePort %x\n", pIniMonitor->Monitor2.pfnConfigurePort );
|
|
Print( " DeletePort %x\n", pIniMonitor->Monitor2.pfnDeletePort );
|
|
Print( " GetPDFromPort %x\n", pIniMonitor->Monitor2.pfnGetPrinterDataFromPort );
|
|
Print( " SetPortTimeOuts %x\n", pIniMonitor->Monitor2.pfnSetPortTimeOuts );
|
|
Print( " XcvOpenPort %x\n", pIniMonitor->Monitor2.pfnXcvOpenPort );
|
|
Print( " XcvDataPort %x\n", pIniMonitor->Monitor2.pfnXcvDataPort );
|
|
Print( " XcvClosePort %x\n", pIniMonitor->Monitor2.pfnXcvClosePort );
|
|
Print( " Shutdown %x\n", pIniMonitor->Monitor2.pfnShutdown );
|
|
|
|
Print( " Monitor @ %x\n", dwAddr + OFFSETOF( INIMONITOR, Monitor ));
|
|
Print( " pIniSpooler %x\n", pIniMonitor->pIniSpooler );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpIniPort(
|
|
PVOID pIniPort_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PINIPORT pIniPort = (PINIPORT)pIniPort_;
|
|
|
|
if( !( pIniPort->signature == IPO_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "IniPort*\n" );
|
|
|
|
Print( " pNext %x\n", pIniPort->pNext );
|
|
Print( " cRef <%d>\n", pIniPort->cRef );
|
|
|
|
Print( " pName " ); vDumpStr( pIniPort->pName );
|
|
|
|
Print( " hProc %x\n", pIniPort->hProc );
|
|
Print( " Status %x\n", pIniPort->Status );
|
|
Print( " PrinterStatus %x\n", pIniPort->PrinterStatus );
|
|
Print( " pszStatus " ); vDumpStr( pIniPort->pszStatus );
|
|
|
|
Print( " Semaphore %x\n", pIniPort->Semaphore );
|
|
Print( " pIniJob %x\n", pIniPort->pIniJob );
|
|
Print( " cPrinters <%d>\n", pIniPort->cPrinters );
|
|
Print( " ppIniPrinter %x\n", pIniPort->ppIniPrinter );
|
|
Print( " pIniMonitor %x\n", pIniPort->pIniMonitor );
|
|
Print( " pIniLangMonitor %x\n", pIniPort->pIniLangMonitor );
|
|
|
|
Print( " hEvent %x\n", pIniPort->hEvent );
|
|
Print( " hPort %x\n", pIniPort->hPort );
|
|
Print( " Ready %x\n", pIniPort->Ready );
|
|
Print( " hPortThread %x\n", pIniPort->hPortThread );
|
|
Print( " pIniSpooler %x\n", pIniPort->pIniSpooler );
|
|
Print( "InCriticalSection %x\n", pIniPort->InCriticalSection );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpIniJob(
|
|
PVOID pIniJob_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PINIJOB pIniJob = (PINIJOB)pIniJob_;
|
|
|
|
static DEBUG_FLAGS adfJobStatus[] = {
|
|
{ "Printing", JOB_PRINTING },
|
|
{ "Paused", JOB_PAUSED },
|
|
{ "Error", JOB_ERROR },
|
|
{ "Offline", JOB_OFFLINE },
|
|
{ "PaperOut", JOB_PAPEROUT },
|
|
{ "PendingDeletion", JOB_PENDING_DELETION },
|
|
{ "Spooling", JOB_SPOOLING },
|
|
{ "Despooling", JOB_DESPOOLING },
|
|
{ "Direct", JOB_DIRECT },
|
|
{ "Complete", JOB_COMPLETE },
|
|
{ "Printed", JOB_PRINTED },
|
|
{ "Restart", JOB_RESTART },
|
|
{ "Remote", JOB_REMOTE },
|
|
{ "NotificationSent", JOB_NOTIFICATION_SENT },
|
|
{ "PrintToFile", JOB_PRINT_TO_FILE },
|
|
{ "TypeAddJob", JOB_TYPE_ADDJOB },
|
|
{ "BlockedDevQ", JOB_BLOCKED_DEVQ },
|
|
{ "SchecduleJob", JOB_SCHEDULE_JOB },
|
|
{ "Timeout", JOB_TIMEOUT },
|
|
{ "Abandon", JOB_ABANDON },
|
|
{ "Deleted", JOB_DELETED },
|
|
{ "TrueEOJ", JOB_TRUE_EOJ },
|
|
{ "Compound/Hidden", JOB_COMPOUND },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
if( !( pIniJob->signature == IJ_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "IniJob*\n" );
|
|
|
|
Print( " pIniNextJob %x\n", pIniJob->pIniNextJob );
|
|
Print( " pIniPrevJob %x\n", pIniJob->pIniPrevJob );
|
|
Print( " cRef <%d>\n", pIniJob->cRef );
|
|
Print( " Status " ); vDumpFlags( pIniJob->Status, adfJobStatus );
|
|
Print( " JobId <%d>\n", pIniJob->JobId );
|
|
Print( " Priority <%d>\n", pIniJob->Priority );
|
|
|
|
Print( " pNotify " ); vDumpStr( pIniJob->pNotify );
|
|
Print( " pUser " ); vDumpStr( pIniJob->pUser );
|
|
Print( " pMachineName " ); vDumpStr( pIniJob->pMachineName );
|
|
Print( " pDocument " ); vDumpStr( pIniJob->pDocument );
|
|
Print( " pOutputFile " ); vDumpStr( pIniJob->pOutputFile );
|
|
|
|
Print( " pIniPrinter %x\n", pIniJob->pIniPrinter );
|
|
Print( " pIniDriver %x\n", pIniJob->pIniDriver );
|
|
Print( " pDevMode %x\n", pIniJob->pDevMode );
|
|
Print( " pIniPrintProc %x\n", pIniJob->pIniPrintProc );
|
|
Print( " pDatatype " ); vDumpStr( pIniJob->pDatatype );
|
|
Print( " pParameters " ); vDumpStr( pIniJob->pParameters );
|
|
|
|
Print( " Submitted @ %x\n", dwAddr + OFFSETOF( INIJOB, Submitted ));
|
|
Print( " Time %x\n", pIniJob->Time );
|
|
Print( " StartTime %x\n", pIniJob->StartTime );
|
|
Print( " UntilTime %x\n", pIniJob->UntilTime );
|
|
|
|
Print( " Size %x\n", pIniJob->Size );
|
|
Print( " hWriteFile %x\n", pIniJob->hWriteFile );
|
|
Print( " pStatus " ); vDumpStr( pIniJob->pStatus );
|
|
|
|
Print( " pBuffer %x\n", pIniJob->pBuffer );
|
|
Print( " cbBuffer %x\n", pIniJob->cbBuffer );
|
|
Print( " WaitForRead %x\n", pIniJob->WaitForRead );
|
|
Print( " WaitForWrite %x\n", pIniJob->WaitForWrite );
|
|
|
|
Print( "StartDocComplete %x\n", pIniJob->StartDocComplete );
|
|
Print( " StartDocError %x\n", pIniJob->StartDocError );
|
|
Print( " pIniPort %x\n", pIniJob->pIniPort );
|
|
Print( " hToken %x\n", pIniJob->hToken );
|
|
Print( " pSD %x\n", pIniJob->pSecurityDescriptor );
|
|
Print( " cPagesPrinted %x\n", pIniJob->cPagesPrinted );
|
|
Print( " cPages %x\n", pIniJob->cPages );
|
|
|
|
Print( " GenerateOnClose %x\n", pIniJob->GenerateOnClose );
|
|
Print( " cbPrinted %x\n", pIniJob->cbPrinted );
|
|
|
|
Print( " NextJobId %x\n", pIniJob->NextJobId );
|
|
Print( " pCurrentIniJob %x\n", pIniJob->pCurrentIniJob );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpSpool(
|
|
PVOID pSpool_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PSPOOL pSpool = (PSPOOL)pSpool_;
|
|
|
|
if( !( pSpool->signature == SJ_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "Spool*\n" );
|
|
|
|
Print( " pNext %x\n", pSpool->pNext );
|
|
Print( " cRef <%d>\n", pSpool->cRef );
|
|
|
|
Print( " pName " ); vDumpStr( pSpool->pName );
|
|
Print( " pDatatpe " ); vDumpStr( pSpool->pDatatype );
|
|
|
|
|
|
Print( " pIniPrintProc %x\n", pSpool->pIniPrintProc );
|
|
Print( " pDevMode %x\n", pSpool->pDevMode );
|
|
Print( " pIniPrinter %x\n", pSpool->pIniPrinter );
|
|
Print( " pIniPort %x\n", pSpool->pIniPort );
|
|
Print( " pIniJob %x\n", pSpool->pIniJob );
|
|
Print( " TypeofHandle %x\n", pSpool->TypeofHandle );
|
|
Print( " pIniNetPort %x\n", pSpool->pIniNetPort );
|
|
Print( " hPort %x\n", pSpool->hPort );
|
|
Print( " Status %x\n", pSpool->Status );
|
|
Print( " GrantedAccess %x\n", pSpool->GrantedAccess );
|
|
Print( " ChangeFlags %x\n", pSpool->ChangeFlags );
|
|
Print( " WaitFlags %x\n", pSpool->WaitFlags );
|
|
Print( " pChangeFlags %x\n", pSpool->pChangeFlags );
|
|
Print( " ChangeEvent %x\n", pSpool->ChangeEvent );
|
|
Print( " OpenPortError %x\n", pSpool->OpenPortError );
|
|
Print( " hNotify %x\n", pSpool->hNotify );
|
|
Print( " eStatus %x\n", pSpool->eStatus );
|
|
Print( " pIniSpooler %x\n", pSpool->pIniSpooler );
|
|
|
|
Print( " GenerateOnClose %x\n", pSpool->GenerateOnClose );
|
|
Print( " hFile %x\n", pSpool->hFile );
|
|
Print( "adwNotifyVectors @ %x\n", dwAddr
|
|
+ OFFSETOF( SPOOL, adwNotifyVectors ));
|
|
|
|
Print( " pUserName " ); vDumpStr( pSpool->SplClientInfo1.pUserName );
|
|
Print( " pMachineName " ); vDumpStr( pSpool->SplClientInfo1.pMachineName );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpIniPrinter(
|
|
PVOID pIniPrinter_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PINIPRINTER pIniPrinter = (PINIPRINTER)pIniPrinter_;
|
|
|
|
static DEBUG_FLAGS adfStatus[] = {
|
|
{ "Paused", PRINTER_PAUSED },
|
|
{ "Error", PRINTER_ERROR },
|
|
{ "Offline", PRINTER_OFFLINE },
|
|
{ "PaperOut", PRINTER_PAPEROUT },
|
|
{ "PendingDeletion", PRINTER_PENDING_DELETION },
|
|
{ "ZombieObject", PRINTER_ZOMBIE_OBJECT },
|
|
{ "PendingCreation", PRINTER_PENDING_CREATION },
|
|
{ "Ok", PRINTER_OK },
|
|
{ "FromReg", PRINTER_FROM_REG },
|
|
{ "WasShared", PRINTER_WAS_SHARED },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
static DEBUG_FLAGS adfAttributes[] = {
|
|
{ "Queued", PRINTER_ATTRIBUTE_QUEUED },
|
|
{ "Direct", PRINTER_ATTRIBUTE_DIRECT },
|
|
{ "Default", PRINTER_ATTRIBUTE_DEFAULT },
|
|
{ "Shared", PRINTER_ATTRIBUTE_SHARED },
|
|
{ "Network", PRINTER_ATTRIBUTE_NETWORK },
|
|
{ "Hidden", PRINTER_ATTRIBUTE_HIDDEN },
|
|
{ "Local", PRINTER_ATTRIBUTE_LOCAL },
|
|
{ "DevQ", PRINTER_ATTRIBUTE_ENABLE_DEVQ },
|
|
{ "KeepPrintedJobs", PRINTER_ATTRIBUTE_KEEPPRINTEDJOBS },
|
|
{ "DoCompletedFirst", PRINTER_ATTRIBUTE_DO_COMPLETE_FIRST },
|
|
{ "WorkOffline", PRINTER_ATTRIBUTE_WORK_OFFLINE },
|
|
{ "EnableBidi", PRINTER_ATTRIBUTE_ENABLE_BIDI },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
if( !( pIniPrinter->signature == IP_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "IniPrinter*\n" );
|
|
|
|
Print( " pNext %x\n", pIniPrinter->pNext );
|
|
Print( " cRef %x\n", pIniPrinter->cRef );
|
|
Print( " pName " ); vDumpStr( pIniPrinter->pName );
|
|
Print( " pShareName " ); vDumpStr( pIniPrinter->pShareName );
|
|
|
|
Print( " pIniPrintProc %x\n", pIniPrinter->pIniPrintProc );
|
|
|
|
Print( " pDatatype " ); vDumpStr( pIniPrinter->pDatatype );
|
|
Print( " pParameters " ); vDumpStr( pIniPrinter->pParameters );
|
|
Print( " pComment " ); vDumpStr( pIniPrinter->pComment );
|
|
|
|
Print( " pIniDriver %x\n", pIniPrinter->pIniDriver );
|
|
Print( " cbDevMode %x\n", pIniPrinter->cbDevMode );
|
|
Print( " pDevMode %x\n", pIniPrinter->pDevMode );
|
|
Print( " Priority <%d>\n", pIniPrinter->Priority );
|
|
Print( " DefaultPriority <%d>\n", pIniPrinter->DefaultPriority );
|
|
|
|
Print( " StartTime %x\n", pIniPrinter->StartTime );
|
|
Print( " UntilTime %x\n", pIniPrinter->UntilTime );
|
|
Print( " pSepFile " ); vDumpStr( pIniPrinter->pSepFile );
|
|
|
|
Print( " Status " );
|
|
vDumpFlags( pIniPrinter->Status, adfStatus );
|
|
|
|
Print( " pLocation " ); vDumpStr( pIniPrinter->pLocation );
|
|
Print( " Attributes " );
|
|
vDumpFlags( pIniPrinter->Attributes, adfAttributes );
|
|
|
|
Print( " cJobs <%d>\n", pIniPrinter->cJobs );
|
|
Print( " AveragePPM %x\n", pIniPrinter->AveragePPM );
|
|
Print( " GenerateOnClose %x\n", pIniPrinter->GenerateOnClose );
|
|
Print( " pIniNetPort %x\n", pIniPrinter->pIniNetPort );
|
|
Print( " ==== pIniFirstJob %x\n", pIniPrinter->pIniFirstJob );
|
|
Print( " pIniLastJob %x\n", pIniPrinter->pIniLastJob );
|
|
Print( " pSecurityDescriptor %x\n", pIniPrinter->pSecurityDescriptor );
|
|
Print( " pSpool %x\n", pIniPrinter->pSpool );
|
|
|
|
Print( " pSpoolDir " ); vDumpStr( pIniPrinter->pSpoolDir );
|
|
Print( " cTotalJobs %x\n", pIniPrinter->cTotalJobs );
|
|
Print( " cTotalBytes %x\n", pIniPrinter->cTotalBytes );
|
|
Print( " stUpTime " ); vDumpTime( pIniPrinter->stUpTime );
|
|
Print( " MaxcRef %x\n", pIniPrinter->MaxcRef );
|
|
Print( " cTotalPagesPrinted %x\n", pIniPrinter->cTotalPagesPrinted );
|
|
Print( " cSpooling %x\n", pIniPrinter->cSpooling );
|
|
Print( " cMaxSpooling %x\n", pIniPrinter->cMaxSpooling );
|
|
Print( " cErrorOutOfPaper %x\n", pIniPrinter->cErrorOutOfPaper );
|
|
Print( " cErrorNotReady %x\n", pIniPrinter->cErrorNotReady );
|
|
Print( " cJobError %x\n", pIniPrinter->cJobError );
|
|
Print( " pIniSpooler %x\n", pIniPrinter->pIniSpooler );
|
|
Print( " cZombieRef %x\n", pIniPrinter->cZombieRef );
|
|
Print( " dwLastError %x\n", pIniPrinter->dwLastError );
|
|
Print( " pExtraData %x\n", pIniPrinter->pExtraData );
|
|
Print( " cChangeID %x\n", pIniPrinter->cChangeID );
|
|
Print( " dnsTimeout %x\n", pIniPrinter->dnsTimeout );
|
|
Print( " txTimeout %x\n", pIniPrinter->txTimeout );
|
|
Print( " pszObjectGUID " ); vDumpStr( pIniPrinter->pszObjectGUID );
|
|
Print( " DsKeyUpdate %x\n", pIniPrinter->DsKeyUpdate );
|
|
Print( "DsKeyUpdateForeground %x\n", pIniPrinter->DsKeyUpdateForeground );
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
/********************************************************************
|
|
|
|
Devmodes
|
|
|
|
********************************************************************/
|
|
|
|
DEBUG_FLAGS gadfDevModeFields[] = {
|
|
{ "Orientation", DM_ORIENTATION },
|
|
{ "PaperSize", DM_PAPERSIZE },
|
|
{ "PaperLength", DM_PAPERLENGTH },
|
|
{ "PaperWidth", DM_PAPERWIDTH },
|
|
{ "Scale", DM_SCALE },
|
|
{ "Copies", DM_COPIES },
|
|
{ "DefaultSource", DM_DEFAULTSOURCE },
|
|
{ "PrintQuality", DM_PRINTQUALITY },
|
|
{ "Color", DM_COLOR },
|
|
{ "Duplex", DM_DUPLEX },
|
|
{ "YResolution", DM_YRESOLUTION },
|
|
{ "TTOption", DM_TTOPTION },
|
|
{ "Collate", DM_COLLATE },
|
|
{ "FormName", DM_FORMNAME },
|
|
{ "LogPixels", DM_LOGPIXELS },
|
|
{ "BitsPerPel", DM_BITSPERPEL },
|
|
{ "PelsWidth", DM_PELSWIDTH },
|
|
{ "PelsHeight", DM_PELSHEIGHT },
|
|
{ "DisplayFlags", DM_DISPLAYFLAGS },
|
|
{ "DisplayFrequency", DM_DISPLAYFREQUENCY },
|
|
{ "ICMMethod", DM_ICMMETHOD },
|
|
{ "ICMIntent", DM_ICMINTENT },
|
|
{ "MediaType", DM_MEDIATYPE },
|
|
{ "DitherType", DM_DITHERTYPE },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
DEBUG_VALUES gadvDevModeDefaultSource[] = {
|
|
{ "Upper/OnlyOne", DMBIN_UPPER },
|
|
{ "Lower", DMBIN_LOWER },
|
|
{ "Middle", DMBIN_MIDDLE },
|
|
{ "Manual", DMBIN_MANUAL },
|
|
{ "Envelope", DMBIN_ENVELOPE },
|
|
{ "EnvManual", DMBIN_ENVMANUAL },
|
|
{ "Auto", DMBIN_AUTO },
|
|
{ "Tractor", DMBIN_TRACTOR },
|
|
{ "SmallFmt", DMBIN_SMALLFMT },
|
|
{ "LargeFmt", DMBIN_LARGEFMT },
|
|
{ "LargeCapacity", DMBIN_LARGECAPACITY },
|
|
{ "Cassette", DMBIN_CASSETTE },
|
|
{ "FormSource", DMBIN_FORMSOURCE },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
DEBUG_VALUES gadvDevModePapers[] = {
|
|
{ "Letter", DMPAPER_LETTER },
|
|
{ "Legal", DMPAPER_LEGAL },
|
|
{ "A4", DMPAPER_A4 },
|
|
{ "CSheet", DMPAPER_CSHEET },
|
|
{ "DSheet", DMPAPER_DSHEET },
|
|
{ "ESheet", DMPAPER_ESHEET },
|
|
{ "LetterSmall", DMPAPER_LETTERSMALL },
|
|
{ "Tabloid", DMPAPER_TABLOID },
|
|
{ "Ledger", DMPAPER_LEDGER },
|
|
{ "Statement", DMPAPER_STATEMENT },
|
|
{ "Executive", DMPAPER_EXECUTIVE },
|
|
{ "A3", DMPAPER_A3 },
|
|
{ "A4Small", DMPAPER_A4SMALL },
|
|
{ "A5", DMPAPER_A5 },
|
|
{ "B4", DMPAPER_B4 },
|
|
{ "B5", DMPAPER_B5 },
|
|
{ "Folio", DMPAPER_FOLIO },
|
|
{ "Quarto", DMPAPER_QUARTO },
|
|
{ "10x14", DMPAPER_10X14 },
|
|
{ "11x17", DMPAPER_11X17 },
|
|
{ "Note", DMPAPER_NOTE },
|
|
{ "Env_9", DMPAPER_ENV_9 },
|
|
{ "Env_10", DMPAPER_ENV_10 },
|
|
{ "Env_11", DMPAPER_ENV_11 },
|
|
{ "Env_12", DMPAPER_ENV_12 },
|
|
{ "Env_14", DMPAPER_ENV_14 },
|
|
{ "Env_DL", DMPAPER_ENV_DL },
|
|
{ "Env_C5", DMPAPER_ENV_C6 },
|
|
{ "Env_C65", DMPAPER_ENV_C65 },
|
|
{ "Env_B4", DMPAPER_ENV_B4 },
|
|
{ "Env_B5", DMPAPER_ENV_B5 },
|
|
{ "Env_B6", DMPAPER_ENV_B6 },
|
|
{ "Env_Italy", DMPAPER_ENV_ITALY },
|
|
{ "Env_Monarch", DMPAPER_ENV_MONARCH },
|
|
{ "Env_Personal", DMPAPER_ENV_PERSONAL },
|
|
{ "Fanfold_US", DMPAPER_FANFOLD_US },
|
|
{ "Fanfold_Std_German", DMPAPER_FANFOLD_STD_GERMAN },
|
|
{ "Fanfold_Lgl_German", DMPAPER_FANFOLD_LGL_GERMAN },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
DEBUG_VALUES gadvDevModePrintQuality[] = {
|
|
{ "High", (ULONG_PTR)DMRES_HIGH },
|
|
{ "Medium", (ULONG_PTR)DMRES_MEDIUM },
|
|
{ "Low", (ULONG_PTR)DMRES_LOW },
|
|
{ "Draft", (ULONG_PTR)DMRES_DRAFT },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
DEBUG_VALUES gadvDevModeColor[] = {
|
|
{ "Color", DMCOLOR_COLOR },
|
|
{ "Monochrome", DMCOLOR_MONOCHROME },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
DEBUG_VALUES gadvDevModeDuplex[] = {
|
|
{ "Simplex", DMDUP_SIMPLEX },
|
|
{ "Horizontal", DMDUP_HORIZONTAL },
|
|
{ "Vertical", DMDUP_VERTICAL },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
DEBUG_VALUES gadvDevModeTTOption[] = {
|
|
{ "Bitmap", DMTT_BITMAP },
|
|
{ "DownLoad", DMTT_DOWNLOAD },
|
|
{ "SubDev", DMTT_SUBDEV },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
DEBUG_VALUES gadvDevModeCollate[] = {
|
|
{ "True", DMCOLLATE_TRUE },
|
|
{ "False", DMCOLLATE_FALSE },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
DEBUG_VALUES gadvDevModeICMMethod[] = {
|
|
{ "None", DMICMMETHOD_NONE },
|
|
{ "System", DMICMMETHOD_SYSTEM },
|
|
{ "Driver", DMICMMETHOD_DRIVER },
|
|
{ "Device", DMICMMETHOD_DEVICE },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
|
|
DEBUG_VALUES gadvDevModeICMIntent[] = {
|
|
{ "Saturate", DMICM_SATURATE },
|
|
{ "Contrast", DMICM_CONTRAST },
|
|
{ "ColorMetric", DMICM_COLORIMETRIC },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
|
|
DEBUG_VALUES gadvDevModeMediaType[] = {
|
|
{ "Standard", DMMEDIA_STANDARD },
|
|
{ "Glossy", DMMEDIA_GLOSSY },
|
|
{ "Transparency", DMMEDIA_TRANSPARENCY },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
|
|
DEBUG_VALUES gadvDevModeDitherType[] = {
|
|
{ "None", DMDITHER_NONE },
|
|
{ "Coarse", DMDITHER_COARSE },
|
|
{ "Fine", DMDITHER_FINE },
|
|
{ "LineArt", DMDITHER_LINEART },
|
|
{ "GrayScale", DMDITHER_GRAYSCALE },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
DEBUG_VALUES gadvDevModeOrient[] = {
|
|
{ "Portrait", DMORIENT_PORTRAIT },
|
|
{ "Landscape", DMORIENT_LANDSCAPE },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpDevMode(
|
|
PVOID pDevMode_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PDEVMODE pDevMode = (PDEVMODE)pDevMode_;
|
|
|
|
ULONG_PTR dwTotalSize = pDevMode->dmSize + pDevMode->dmDriverExtra;
|
|
|
|
Print( "DevMode*\n" );
|
|
|
|
Print( " dmDeviceName %ws\n", pDevMode->dmDeviceName );
|
|
Print( " dmSpecVersion %x\n", pDevMode->dmSpecVersion );
|
|
Print( " dmDriverVersion %x\n", pDevMode->dmDriverVersion );
|
|
|
|
Print( "==== dmSize %x <%d> TotalSize %x <%d>\n",
|
|
pDevMode->dmSize,
|
|
pDevMode->dmSize,
|
|
dwTotalSize, dwTotalSize );
|
|
|
|
Print( " dmDriverExtra %x <%d>\n",
|
|
pDevMode->dmDriverExtra,
|
|
pDevMode->dmDriverExtra );
|
|
|
|
Print( " dmFields " );
|
|
vDumpFlags( pDevMode->dmFields, gadfDevModeFields );
|
|
|
|
Print( " dmOrientation " );
|
|
vDumpValue( pDevMode->dmOrientation, gadvDevModeOrient );
|
|
|
|
Print( " dmPaperSize " );
|
|
vDumpValue( pDevMode->dmPaperSize, gadvDevModePapers );
|
|
|
|
Print( " dmPaperLength %x\n", pDevMode->dmPaperLength );
|
|
Print( " dmPaperWidth %x\n", pDevMode->dmPaperWidth );
|
|
Print( " dmScale %x\n", pDevMode->dmScale );
|
|
Print( " dmCopies %x\n", pDevMode->dmCopies );
|
|
Print( " dmDefaultSource " );
|
|
vDumpValue( pDevMode->dmDefaultSource, gadvDevModeDefaultSource );
|
|
|
|
Print( " dmPrintQuality " );
|
|
vDumpValue( pDevMode->dmPrintQuality, gadvDevModePrintQuality );
|
|
|
|
Print( " dmColor " );
|
|
vDumpValue( pDevMode->dmColor, gadvDevModeColor );
|
|
|
|
Print( " dmDuplex " );
|
|
vDumpValue( pDevMode->dmDuplex, gadvDevModeDuplex );
|
|
|
|
Print( " dmYResolution %x\n", pDevMode->dmYResolution );
|
|
|
|
Print( " dmTTOption " );
|
|
vDumpValue( pDevMode->dmTTOption, gadvDevModeTTOption );
|
|
|
|
Print( " dmCollate " );
|
|
vDumpValue( pDevMode->dmCollate, gadvDevModeCollate );
|
|
|
|
Print( "==== dmFormName %ws\n", pDevMode->dmFormName );
|
|
Print( " dmLogPixels %x\n", pDevMode->dmLogPixels );
|
|
Print( " dmBitsPerPel %x\n", pDevMode->dmBitsPerPel );
|
|
Print( " dmPelsWidth %x\n", pDevMode->dmPelsWidth );
|
|
Print( " dmPelsHeight %x\n", pDevMode->dmPelsHeight );
|
|
|
|
Print( " dmDisplayFlags %x\n", pDevMode->dmDisplayFlags );
|
|
Print( " dmDisplayFrequency %x\n", pDevMode->dmDisplayFrequency );
|
|
|
|
Print( "==== dmICMMethod " );
|
|
vDumpValue( pDevMode->dmICMMethod, gadvDevModeICMMethod );
|
|
|
|
Print( " dmICMIntent " );
|
|
vDumpValue( pDevMode->dmICMIntent, gadvDevModeICMIntent );
|
|
|
|
Print( " dmMediaType " );
|
|
vDumpValue( pDevMode->dmMediaType, gadvDevModeMediaType );
|
|
|
|
Print( " dmDitherType " );
|
|
vDumpValue( pDevMode->dmDitherType, gadvDevModeDitherType );
|
|
|
|
Print( "==== Private at %x\n", dwAddr+pDevMode->dmSize );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpDevModeA(
|
|
PVOID pDevModeA_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PDEVMODEA pDevMode = (PDEVMODEA)pDevModeA_;
|
|
|
|
ULONG_PTR dwTotalSize = pDevMode->dmSize + pDevMode->dmDriverExtra;
|
|
|
|
Print( "DevModeA*\n" );
|
|
|
|
Print( " dmDeviceName %hs\n", pDevMode->dmDeviceName );
|
|
Print( " dmSpecVersion %x\n", pDevMode->dmSpecVersion );
|
|
Print( " dmDriverVersion %x\n", pDevMode->dmDriverVersion );
|
|
|
|
Print( "==== dmSize %x <%d> TotalSize %x <%d>\n",
|
|
pDevMode->dmSize,
|
|
pDevMode->dmSize,
|
|
dwTotalSize, dwTotalSize );
|
|
|
|
Print( " dmDriverExtra %x <%d>\n",
|
|
pDevMode->dmDriverExtra,
|
|
pDevMode->dmDriverExtra );
|
|
|
|
Print( " dmFields " );
|
|
vDumpFlags( pDevMode->dmFields, gadfDevModeFields );
|
|
|
|
Print( " dmOrientation " );
|
|
vDumpValue( pDevMode->dmOrientation, gadvDevModeOrient );
|
|
|
|
Print( " dmPaperSize " );
|
|
vDumpValue( pDevMode->dmPaperSize, gadvDevModePapers );
|
|
|
|
Print( " dmPaperLength %x\n", pDevMode->dmPaperLength );
|
|
Print( " dmPaperWidth %x\n", pDevMode->dmPaperWidth );
|
|
Print( " dmScale %x\n", pDevMode->dmScale );
|
|
Print( " dmCopies %x\n", pDevMode->dmCopies );
|
|
Print( " dmDefaultSource " );
|
|
vDumpValue( pDevMode->dmDefaultSource, gadvDevModeDefaultSource );
|
|
|
|
Print( " dmPrintQuality " );
|
|
vDumpValue( pDevMode->dmPrintQuality, gadvDevModePrintQuality );
|
|
|
|
Print( " dmColor " );
|
|
vDumpValue( pDevMode->dmColor, gadvDevModeColor );
|
|
|
|
Print( " dmDuplex " );
|
|
vDumpValue( pDevMode->dmDuplex, gadvDevModeDuplex );
|
|
|
|
Print( " dmYResolution %x\n", pDevMode->dmYResolution );
|
|
|
|
Print( " dmTTOption " );
|
|
vDumpValue( pDevMode->dmTTOption, gadvDevModeTTOption );
|
|
|
|
Print( " dmCollate " );
|
|
vDumpValue( pDevMode->dmCollate, gadvDevModeCollate );
|
|
|
|
Print( "==== dmFormName %hs\n", pDevMode->dmFormName );
|
|
Print( " dmLogPixels %x\n", pDevMode->dmLogPixels );
|
|
Print( " dmBitsPerPel %x\n", pDevMode->dmBitsPerPel );
|
|
Print( " dmPelsWidth %x\n", pDevMode->dmPelsWidth );
|
|
Print( " dmPelsHeight %x\n", pDevMode->dmPelsHeight );
|
|
|
|
Print( " dmDisplayFlags %x\n", pDevMode->dmDisplayFlags );
|
|
Print( " dmDisplayFrequency %x\n", pDevMode->dmDisplayFrequency );
|
|
|
|
Print( "==== dmICMMethod " );
|
|
vDumpValue( pDevMode->dmICMMethod, gadvDevModeICMMethod );
|
|
|
|
Print( " dmICMIntent " );
|
|
vDumpValue( pDevMode->dmICMIntent, gadvDevModeICMIntent );
|
|
|
|
Print( " dmMediaType " );
|
|
vDumpValue( pDevMode->dmMediaType, gadvDevModeMediaType );
|
|
|
|
Print( " dmDitherType " );
|
|
vDumpValue( pDevMode->dmDitherType, gadvDevModeDitherType );
|
|
|
|
Print( "==== Private at %x\n", dwAddr+pDevMode->dmSize );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
#if 0
|
|
BOOL
|
|
TDebugExt::
|
|
bDumpIniPrinter(
|
|
PVOID pIniPrinter_,
|
|
ULONG_PTR dwAddr
|
|
)
|
|
{
|
|
PIniPrinter pIniPrinter = (PIniPrinter)pIniPrinter_;
|
|
|
|
static DEBUG_FLAGS adfSpl[] = {
|
|
{ "UpdateWinIniDevices", SPL_UPDATE_WININI_DEVICES },
|
|
{ NULL, 0 }
|
|
};
|
|
|
|
if( !( pIniPrinter->signature == ID_SIGNATURE )){
|
|
return FALSE;
|
|
}
|
|
|
|
Print( "IniPrinter*\n" );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
Extension entrypoints.
|
|
|
|
********************************************************************/
|
|
|
|
DEBUG_EXT_ENTRY( ds, INISPOOLER, bDumpIniSpooler, "&localspl!pLocalIniSpooler", FALSE )
|
|
|
|
DEBUG_EXT_ENTRY( ddev, DEVMODE, bDumpDevMode, NULL, FALSE )
|
|
DEBUG_EXT_ENTRY( ddeva, DEVMODEA, bDumpDevModeA, NULL, FALSE )
|
|
|
|
DEBUG_EXT_ENTRY( dlcs,
|
|
MCritSec,
|
|
bDumpCritSec,
|
|
"&localspl!hcsSpoolerSection",
|
|
TRUE )
|
|
|
|
DEBUG_EXT_HEAD(lastlog)
|
|
{
|
|
DEBUG_EXT_SETUP_VARS();
|
|
|
|
ULONG_PTR dwAddress = 0;
|
|
|
|
//
|
|
// Read in localspl's gDbgPointers.
|
|
//
|
|
DBG_POINTERS DbgPointers;
|
|
ULONG_PTR ppDbgPointers = 0;
|
|
ULONG_PTR pDbgPointers = 0;
|
|
|
|
ppDbgPointers = EvalExpression( "&localspl!gpDbgPointers" );
|
|
|
|
if( !ppDbgPointers ){
|
|
Print( "<Unable to resolve localspl!gpDbgPointers>\n" );
|
|
return;
|
|
}
|
|
|
|
move( pDbgPointers, ppDbgPointers );
|
|
|
|
if( !pDbgPointers ){
|
|
Print( "<Unable to read valid localspl!gpDbgPointers>\n" );
|
|
return;
|
|
}
|
|
|
|
move( DbgPointers, pDbgPointers );
|
|
|
|
if( !DbgPointers.pbtTraceLog ){
|
|
Print( "<Unable to read valid DbgPointers.pbtTraceLog>\n" );
|
|
return;
|
|
}
|
|
|
|
vDumpTraceWithFlags( lpArgumentString, (ULONG_PTR)DbgPointers.pbtTraceLog );
|
|
}
|
|
|
|
/********************************************************************
|
|
|
|
Signature matching dump function.
|
|
|
|
********************************************************************/
|
|
|
|
|
|
#define DEBUG_EXT_TRY_SETUP() \
|
|
PBYTE var = (PBYTE)EvalExpression( lpArgumentString ); \
|
|
PVOID pvData; \
|
|
BOOL bDone; \
|
|
Print( "%x ", var )
|
|
|
|
#define DEBUG_EXT_TRY( struct, func ) \
|
|
pvData = LocalAlloc( LPTR, sizeof( struct )); \
|
|
move2( pvData, var, sizeof( struct )); \
|
|
bDone = TDebugExt::func( pvData, (ULONG_PTR)var ); \
|
|
LocalFree( pvData ); \
|
|
\
|
|
if( bDone ){ \
|
|
return; \
|
|
}
|
|
|
|
#define DEBUG_EXT_TRY_DONE() \
|
|
Print( "<No Match %x>\n", var )
|
|
|
|
|
|
DEBUG_EXT_HEAD( d )
|
|
{
|
|
DEBUG_EXT_SETUP_VARS();
|
|
DEBUG_EXT_TRY_SETUP();
|
|
|
|
DEBUG_EXT_TRY( INISPOOLER, bDumpIniSpooler );
|
|
DEBUG_EXT_TRY( INIPRINTER, bDumpIniPrinter );
|
|
DEBUG_EXT_TRY( INIPRINTPROC, bDumpIniPrintProc );
|
|
DEBUG_EXT_TRY( INIVERSION, bDumpIniVersion );
|
|
DEBUG_EXT_TRY( INIDRIVER, bDumpIniDriver );
|
|
DEBUG_EXT_TRY( INIENVIRONMENT, bDumpIniEnvironment );
|
|
DEBUG_EXT_TRY( INIMONITOR, bDumpIniMonitor );
|
|
DEBUG_EXT_TRY( INIJOB, bDumpIniJob );
|
|
DEBUG_EXT_TRY( INIPORT, bDumpIniPort );
|
|
DEBUG_EXT_TRY( SPOOL, bDumpSpool );
|
|
|
|
DEBUG_EXT_TRY_DONE();
|
|
}
|