/******************** Function Prototypes file *************************** * libproto.h * Function prototypes for NT printer drivers library. Also includes * a brief description of the function. * * 11:04 on Wed 14 Nov 1990 -by- Lindsay Harris [lindsayh] * * Copyright (C) Microsoft Corporation, 1990 - 1992 * ************************************************************************/ #ifndef __LIBPROTO_H__ #define __LIBPROTO_H__ #if defined(NTGDIKM) && !defined(KERNEL_MODE) #define KERNEL_MODE #endif #ifdef NTGDIKM extern ULONG gulMemID; #define DbgPrint DrvDbgPrint #define HeapAlloc(hHeap,Flags,Size) DRVALLOC( Size ) #define HeapFree( hHeap, Flags, VBits ) DRVFREE( VBits ) #ifndef FillMemory #define FillMemory(Destination,Length,Fill) memset((Destination),(Fill),(Length)) #endif //#define DRVALLOC(c) EngAllocMem(0, c,gulMemID) //#define DRVFREE(p) EngFreeMem(p) #endif /* * Until there is proper error logging:- * WinSetError( "String" ); * The String appears on the debug terminal. A \n is appended. */ void WinSetError( LPSTR ); /* * Function to add a copy of a string to a heap. Returns address of copy * of string (if successful) or 0 if memory cannot be allocated. */ LPSTR StrToHeap( HANDLE, LPSTR ); PWSTR StrToWHeap( HANDLE, LPSTR ); /* Expand to Wide too! */ PWSTR WstrToHeap( HANDLE, PWSTR ); /* WIDE version */ /* * Convert an ascii style string to WCHAR format, appending it to the * end of the wchar passed in. Returns value of first parameter. */ PWSTR strcat2WChar( PWSTR, LPSTR ); /* * Convert an ascii style string to WCHAR format, copying it to the * wchar passed in. Returns value of first parameter. */ PWSTR strcpy2WChar( PWSTR, LPSTR ); /* * The WCHAR world's equivalent of strlen(): returns the number of WCHARs * in the string passed in. */ int wchlen( PWSTR ); /* * Concatenate a PWSTR to another. Returns address of destination. */ PWSTR wchcat( PWSTR, PWSTR ); /* * Copy a PWSTR to another. Returns address of destination. */ PWSTR wchcpy( PWSTR, PWSTR ); PVOID MapFile(PWSTR); #if NTGDIKM /* * check if two strings are identical */ BOOL bSameStringW( PWCHAR pwch1, PWCHAR pwch2); /* * Some system function prototypes have vanished - replace them here. */ void DrvDbgPrint( char *, ... ); #if DBG #define RIP(x) {DrvDbgPrint((PSZ)(x)); EngDebugBreak();} #define WARNING(s) DrvDbgPrint("warning: %s",(PSZ)(s)) BOOL SetAllocCounters( VOID ); #else #define RIP(x) #define WARNING(s) #endif LPVOID DRVALLOC( DWORD cbAlloc ); BOOL DRVFREE( LPVOID pMem ); #else //NTGDIKM /* * Break into the debugger - Ye olde RIP. */ VOID DoRip( LPSTR ); #if DBG #define WARNING(s) DbgPrint("warning: %s",(PSZ)(s)) #ifdef FIREWALLS #define RIP(x) DoRip( (PSZ)(x) ) #else #define RIP(x) {DbgPrint((PSZ)(x)); DbgBreakPoint();} #endif #else #define WARNING(s) #define RIP(x) #endif //DBG // // Define kernel debugger print prototypes and macros. // These are defined in ntrtl.h which we should include // instead. For now, redefine them here to avoid breaking // other components. // #if DBG VOID NTAPI DbgBreakPoint( VOID ); ULONG __cdecl DbgPrint( PCH Format, ... ); #endif PVOID MapFile(PWSTR); #endif //NTGDIKM /* * A simplified write function. Returns TRUE if the WriteFile() * call returns TRUE and the number of bytes written equals the * number requested. * * bWrite( file_handle, address_of_data, number_of_bytes ); */ BOOL bWrite( HANDLE, void *, int ); /* * Function to copy the contents of one file to another. The files * are referenced via file handles. No positioning is done - that is * up to the user. * The second form also allows a byte count to limit the amount of data * copied. */ long lFICopy( HANDLE, HANDLE ); long lFInCopy( HANDLE, HANDLE, long ); /* * Spooler interaction functions. These allow drivers to call the * spooler directly, without going through engine stub functions. */ BOOL bSplGetFormW( HANDLE, PWSTR, DWORD, BYTE *, DWORD, DWORD * ); DWORD dwSplGetPrinterDataW( HANDLE, PWSTR, BYTE *, DWORD, DWORD * ); BOOL bSplWrite( HANDLE, ULONG, VOID * ); /* Function needed to allow the driver to reach the spooler */ BOOL bImpersonateClient( void ); /************************** HACK *************************************** * The following function is only required until the DEVMODE contains * a form name rather than an index. And even then it might be required. * ***********************************************************************/ char *_IndexToName( int ); // Generic devmode conversion routine LONG ConvertDevmode( PDEVMODE pdmIn, PDEVMODE pdmOut ); #ifndef KERNEL_MODE // Copy DEVMODE to an output buffer before return to the // caller of DrvDocumentProperties BOOL ConvertDevmodeOut( PDEVMODE pdmSrc, PDEVMODE pdmIn, PDEVMODE pdmOut, LONG lBufferSize ); // Library routine to handle common cases of DrvConvertDevmode typedef struct { WORD dmDriverVersion; // current driver version WORD dmDriverExtra; // size of current version private devmode WORD dmDriverVersion351; // 3.51 driver version WORD dmDriverExtra351; // size of 3.51 version private devmode } DRIVER_VERSION_INFO, *PDRIVER_VERSION_INFO; #define CDM_RESULT_FALSE 0 #define CDM_RESULT_TRUE 1 #define CDM_RESULT_NOT_HANDLED 2 INT CommonDrvConvertDevmode( PWSTR pPrinterName, PDEVMODE pdmIn, PDEVMODE pdmOut, PLONG pcbNeeded, DWORD fMode, PDRIVER_VERSION_INFO pDriverVersions ); UINT cdecl DQPsprintf( HINSTANCE hInst, LPWSTR pwBuf, DWORD cchBuf, LPDWORD pcchNeeded, LPWSTR pwszFormat, ... ); #endif // KERNEL_MODE #endif // !__LIBPROTO_H__