/*++ Copyright (c) 1998 Microsoft Corporation Module Name: migutil.h Abstract: Includes all header files necessary to use the lib generated by common\migutil. Declares a bunch of utility functions and macros. Declares project-wide MAX constants. Author: Jim Schmidt (jimschm) 23-Aug-1996 Revision History: Many changes, see SLM log for details. --*/ #pragma once #ifdef __cplusplus extern "C" { #endif // // MAX constants // #define MAX_PATH_PLUS_NUL (MAX_PATH+1) #define MAX_MBCHAR_PATH (MAX_PATH_PLUS_NUL*2) #define MAX_WCHAR_PATH MAX_PATH_PLUS_NUL #define MAX_MBCHAR_PRINTABLE_PATH (MAX_PATH*2) #define MAX_WCHAR_PRINTABLE_PATH MAX_PATH #define MAX_SERVER_NAMEA (64*2) #define MAX_USER_NAMEA (MAX_PATH) #define MAX_REGISTRY_KEYA (1024 * 2) #define MAX_REGISTRY_VALUE_NAMEA (260 * 2) #define MAX_COMPONENT_NAMEA (256 * 2) #define MAX_COMPUTER_NAMEA (64 * 2) #define MAX_CMDLINEA (1024 * 2) // maximum number of chars in a Win95 command line #define MAX_TRANSLATION 32 #define MAX_KEYBOARDLAYOUT 64 #define MAX_INF_SECTION_NAME 128 #define MAX_INF_KEY_NAME 128 #define MAX_SERVER_NAMEW 64 #define MAX_USER_NAMEW (MAX_PATH) #define MAX_REGISTRY_KEYW 1024 #define MAX_REGISTRY_VALUE_NAMEW 260 #define MAX_COMPONENT_NAMEW 256 #define MAX_COMPUTER_NAMEW 64 #define MAX_CMDLINEW 1024 // maximum number of chars in a Win95 command line #ifdef UNICODE #define MAX_SERVER_NAME MAX_SERVER_NAMEW #define MAX_USER_NAME MAX_USER_NAMEW #define MAX_REGISTRY_KEY MAX_REGISTRY_KEYW #define MAX_REGISTRY_VALUE_NAME MAX_REGISTRY_VALUE_NAMEW #define MAX_COMPONENT_NAME MAX_COMPONENT_NAMEW #define MAX_COMPUTER_NAME MAX_COMPUTER_NAMEW #define MAX_CMDLINE MAX_CMDLINEW #define MAX_TCHAR_PATH MAX_WCHAR_PATH #define MAX_TCHAR_PRINTABLE_PATH MAX_WCHAR_PRINTABLE_PATH #else #define MAX_SERVER_NAME MAX_SERVER_NAMEA #define MAX_USER_NAME MAX_USER_NAMEA #define MAX_REGISTRY_KEY MAX_REGISTRY_KEYA #define MAX_REGISTRY_VALUE_NAME MAX_REGISTRY_VALUE_NAMEA #define MAX_COMPONENT_NAME MAX_COMPONENT_NAMEA #define MAX_COMPUTER_NAME MAX_COMPUTER_NAMEA #define MAX_CMDLINE MAX_CMDLINEA #define MAX_TCHAR_PATH MAX_MBCHAR_PATH #define MAX_TCHAR_PRINTABLE_PATH MAX_MBCHAR_PRINTABLE_PATH #endif // // Critical Section APIs, implemented because TryEnterCriticalSection is // supported only on NT, and we need it on Win9x. // typedef struct { HANDLE EventHandle; } OUR_CRITICAL_SECTION, *POUR_CRITICAL_SECTION; BOOL InitializeOurCriticalSection ( OUR_CRITICAL_SECTION *pcs ); VOID DeleteOurCriticalSection ( OUR_CRITICAL_SECTION *pcs ); BOOL EnterOurCriticalSection ( OUR_CRITICAL_SECTION *pcs ); VOID LeaveOurCriticalSection ( OUR_CRITICAL_SECTION *pcs ); BOOL TryEnterOurCriticalSection ( OUR_CRITICAL_SECTION *pcs ); PSTR UnicodeToCcs ( PCWSTR Source ); // // Fail-proof memory allocators // PVOID SafeHeapAlloc ( HANDLE g_hHeap, DWORD Flags, SIZE_T Size ); PVOID SafeHeapReAlloc ( HANDLE g_hHeap, DWORD Flags, PVOID OldBlock, SIZE_T Size ); // // Includes of util modules // extern HINSTANCE g_hInst; extern HANDLE g_hHeap; extern OSVERSIONINFOA g_OsInfo; extern BOOL g_IsMbcp; #include "debug.h" #include "log.h" #include "staticsz.h" #include "growbuf.h" // must appear before strings.h and file.h #include "strings.h" #include "poolmem.h" #include "growlist.h" #include "file.h" #include "reg.h" #include "ipc.h" #include "fileenum.h" #include "inf.h" #include "unicode.h" #include "hash.h" #include "persist.h" VOID CenterWindow ( HWND Wnd, HWND Parent OPTIONAL ); VOID TurnOnWaitCursor ( VOID ); VOID TurnOffWaitCursor ( VOID ); // // Version APIs // typedef struct { WORD CodePage; WORD Language; } TRANSLATION, *PTRANSLATION; typedef struct { GROWBUFFER GrowBuf; PBYTE VersionBuffer; PTRANSLATION Translations; PBYTE StringBuffer; UINT Size; DWORD Handle; VS_FIXEDFILEINFO *FixedInfo; UINT FixedInfoSize; CHAR TranslationStr[MAX_TRANSLATION]; UINT MaxTranslations; UINT CurrentTranslation; UINT CurrentDefaultTranslation; PCSTR FileSpec; PCSTR VersionField; } VERSION_STRUCTA, *PVERSION_STRUCTA; typedef struct { GROWBUFFER GrowBuf; PBYTE VersionBuffer; PTRANSLATION Translations; PBYTE StringBuffer; UINT Size; DWORD Handle; VS_FIXEDFILEINFO *FixedInfo; UINT FixedInfoSize; WCHAR TranslationStr[MAX_TRANSLATION]; UINT MaxTranslations; UINT CurrentTranslation; UINT CurrentDefaultTranslation; PCWSTR FileSpec; PCWSTR VersionField; } VERSION_STRUCTW, *PVERSION_STRUCTW; BOOL CreateVersionStructA ( OUT PVERSION_STRUCTA VersionStruct, IN PCSTR FileSpec ); VOID DestroyVersionStructA ( IN PVERSION_STRUCTA VersionStruct ); PCSTR EnumFirstVersionTranslationA ( IN OUT PVERSION_STRUCTA VersionStruct ); PCSTR EnumNextVersionTranslationA ( IN OUT PVERSION_STRUCTA VersionStruct ); PCSTR EnumFirstVersionValueA ( IN OUT PVERSION_STRUCTA VersionStruct, IN PCSTR VersionField ); PCSTR EnumNextVersionValueA ( IN OUT PVERSION_STRUCTA VersionStruct ); BOOL CreateVersionStructW ( OUT PVERSION_STRUCTW VersionStruct, IN PCWSTR FileSpec ); VOID DestroyVersionStructW ( IN PVERSION_STRUCTW VersionStruct ); PCWSTR EnumFirstVersionTranslationW ( IN OUT PVERSION_STRUCTW VersionStruct ); PCWSTR EnumNextVersionTranslationW ( IN OUT PVERSION_STRUCTW VersionStruct ); PCWSTR EnumFirstVersionValueW ( IN OUT PVERSION_STRUCTW VersionStruct, IN PCWSTR VersionField ); PCWSTR EnumNextVersionValueW ( IN OUT PVERSION_STRUCTW VersionStruct ); ULONGLONG VerGetFileVer ( IN PVERSION_STRUCTA VersionStruct ); ULONGLONG VerGetProductVer ( IN PVERSION_STRUCTA VersionStruct ); DWORD VerGetFileDateLo ( IN PVERSION_STRUCTA VersionStruct ); DWORD VerGetFileDateHi ( IN PVERSION_STRUCTA VersionStruct ); DWORD VerGetFileVerOs ( IN PVERSION_STRUCTA VersionStruct ); DWORD VerGetFileVerType ( IN PVERSION_STRUCTA VersionStruct ); // // Reusable memory alloc, kind of like a GROWBUFFER but more simple // PVOID ReuseAlloc ( HANDLE Heap, PVOID OldPtr, SIZE_T SizeNeeded ); VOID ReuseFree ( HANDLE Heap, PVOID Ptr ); VOID OutOfMemory_Terminate ( VOID ); VOID SetOutOfMemoryParent ( HWND hwnd ); // // Error condition tags. // // These tags should be used for all error conditions. // #define ERROR_CRITICAL #define ERROR_NONCRITICAL #define ERROR_TRIVIAL #define ERROR_ABNORMAL_CONDITION // // OSVERSION macros... // #define BUILDNUMBER() (LOWORD(g_OsInfo.dwBuildNumber)) #define ISNT() (g_OsInfo.dwPlatformId == VER_PLATFORM_WIN32_NT) #define ISWIN9X() (g_OsInfo.dwPlatformId == VER_PLATFORM_WIN32_WINDOWS) #define ISWIN95_GOLDEN() (ISWIN95() && BUILDNUMBER() <= 1000) #define ISWIN95_OSR2() (ISWIN95() && BUILDNUMBER() > 1000) #define ISWIN95() (ISWIN9X() && !ISATLEASTWIN98()) #define ISMEMPHIS() (ISWIN9X() && g_OsInfo.dwMajorVersion==4 && g_OsInfo.dwMinorVersion==10) #define ISMILLENNIUM() (ISWIN9X() && g_OsInfo.dwMajorVersion==4 && g_OsInfo.dwMinorVersion==90) #define ISATLEASTOSR2() (ISWIN9X() && g_OsInfo.dwMajorVersion>=4 && BUILDNUMBER()>1000) #define ISATLEASTWIN98() (ISWIN9X() && g_OsInfo.dwMajorVersion>=4 && g_OsInfo.dwMinorVersion>=10) // // Platform macros... // extern BOOL g_IsPc98; #define ISPC98() (g_IsPc98) // // Boot drive letter // extern PCSTR g_BootDrivePathA; extern PCWSTR g_BootDrivePathW; extern PCSTR g_BootDriveA; extern PCWSTR g_BootDriveW; extern CHAR g_BootDriveLetterA; extern WCHAR g_BootDriveLetterW; // // String Mapping // #define STRMAP_ANY_MATCH 0 #define STRMAP_COMPLETE_MATCH_ONLY 0x0001 #define STRMAP_FIRST_CHAR_MUST_MATCH 0x0002 #define STRMAP_RETURN_AFTER_FIRST_REPLACE 0x0004 #define STRMAP_REQUIRE_WACK_OR_NUL 0x0008 typedef struct { BOOL UnicodeData; // // The filter can replace NewSubString. (The filter must also // set NewSubStringSizeInBytes when replacing NewSubString.) // union { struct { PCWSTR OriginalString; PCWSTR BeginningOfMatch; PCWSTR CurrentString; PCWSTR OldSubString; PCWSTR NewSubString; INT NewSubStringSizeInBytes; } Unicode; struct { PCSTR OriginalString; PCSTR BeginningOfMatch; PCSTR CurrentString; PCSTR OldSubString; PCSTR NewSubString; INT NewSubStringSizeInBytes; } Ansi; }; } REG_REPLACE_DATA, *PREG_REPLACE_DATA; typedef BOOL(REG_REPLACE_FILTER_PROTOTYPE)(PREG_REPLACE_DATA Data); typedef REG_REPLACE_FILTER_PROTOTYPE * REG_REPLACE_FILTER; typedef struct TAG_CHARNODE { WORD Char; WORD Flags; PVOID OriginalStr; PVOID ReplacementStr; INT ReplacementBytes; struct TAG_CHARNODE *NextLevel; struct TAG_CHARNODE *NextPeer; } CHARNODE, *PCHARNODE; typedef struct { CHARNODE Node; REG_REPLACE_FILTER Filter; ULONG_PTR ExtraData; } CHARNODEEX, *PCHARNODEEX; typedef struct { POOLHANDLE Pool; PCHARNODE FirstLevelRoot; BOOL UsesExNode; BOOL UsesFilter; BOOL UsesExtraData; } MAPSTRUCT, *PMAPSTRUCT; // // APIs // PMAPSTRUCT CreateStringMappingEx ( IN BOOL UsesFilter, IN BOOL UsesExtraData ); #define CreateStringMapping() CreateStringMappingEx(FALSE,FALSE) VOID DestroyStringMapping ( IN PMAPSTRUCT Map ); VOID AddStringMappingPairExA ( IN OUT PMAPSTRUCT Map, IN PCSTR Old, IN PCSTR New, IN REG_REPLACE_FILTER Filter, OPTIONAL IN ULONG_PTR ExtraData, OPTIONAL IN DWORD Flags ); #define AddStringMappingPairA(Map,Old,New) AddStringMappingPairExA(Map,Old,New,NULL,0,0) VOID AddStringMappingPairExW ( IN OUT PMAPSTRUCT Map, IN PCWSTR Old, IN PCWSTR New, IN REG_REPLACE_FILTER Filter, OPTIONAL IN ULONG_PTR ExtraData, OPTIONAL IN DWORD Flags ); #define AddStringMappingPairW(Map,Old,New) AddStringMappingPairExW(Map,Old,New,NULL,0,0) BOOL MappingSearchAndReplaceExA ( IN PMAPSTRUCT Map, IN PCSTR SrcBuffer, OUT PSTR Buffer, // can be the same as SrcBuffer IN INT InboundBytes, OPTIONAL OUT PINT OutboundBytesPtr, OPTIONAL IN INT MaxSizeInBytes, IN DWORD Flags, OUT ULONG_PTR *ExtraDataValue, OPTIONAL OUT PCSTR *EndOfString OPTIONAL ); #define MappingSearchAndReplaceA(map,buffer,maxbytes) MappingSearchAndReplaceExA(map,buffer,buffer,0,NULL,maxbytes,0,NULL,NULL) BOOL MappingSearchAndReplaceExW ( IN PMAPSTRUCT Map, IN PCWSTR SrcBuffer, OUT PWSTR Buffer, // can be the same as SrcBuffer IN INT InboundBytes, OPTIONAL OUT PINT OutboundBytes, OPTIONAL IN INT MaxSizeInBytes, IN DWORD Flags, OUT ULONG_PTR *ExtraDataValue, OPTIONAL OUT PCWSTR *EndOfString OPTIONAL ); #define MappingSearchAndReplaceW(map,buffer,maxbytes) MappingSearchAndReplaceExW(map,buffer,buffer,0,NULL,maxbytes,0,NULL,NULL) BOOL MappingMultiTableSearchAndReplaceExA ( IN PMAPSTRUCT *MapArray, IN UINT MapArrayCount, IN PCSTR SrcBuffer, OUT PSTR Buffer, // can be the same as SrcBuffer IN INT InboundBytes, OPTIONAL OUT PINT OutboundBytesPtr, OPTIONAL IN INT MaxSizeInBytes, IN DWORD Flags, OUT ULONG_PTR *ExtraDataValue, OPTIONAL OUT PCSTR *EndOfString OPTIONAL ); #define MappingMultiTableSearchAndReplaceA(array,count,buffer,maxbytes) \ MappingMultiTableSearchAndReplaceExA(array,count,buffer,buffer,0,NULL,maxbytes,0,NULL,NULL) BOOL MappingMultiTableSearchAndReplaceExW ( IN PMAPSTRUCT *MapArray, IN UINT MapArrayCount, IN PCWSTR SrcBuffer, OUT PWSTR Buffer, // can be the same as SrcBuffer IN INT InboundBytes, OPTIONAL OUT PINT OutboundBytes, OPTIONAL IN INT MaxSizeInBytes, IN DWORD Flags, OUT ULONG_PTR *ExtraDataValue, OPTIONAL OUT PCWSTR *EndOfString OPTIONAL ); #define MappingMultiTableSearchAndReplaceW(array,count,buffer,maxbytes) \ MappingMultiTableSearchAndReplaceExW(array,count,buffer,buffer,0,NULL,maxbytes,0,NULL,NULL) HANDLE StartThread ( IN PTHREAD_START_ROUTINE Address, IN PVOID Arg ); typedef struct { WCHAR DisplayName[80]; ULONGLONG Checksum; WCHAR Version[80]; WCHAR Publisher[80]; WCHAR ProductID[80]; WCHAR RegisteredOwner[80]; WCHAR RegisteredCompany[80]; WCHAR Language[80]; WCHAR SupportUrl[80]; WCHAR SupportTelephone[80]; WCHAR HelpLink[80]; WCHAR InstallLocation[80]; WCHAR InstallSource[80]; WCHAR InstallDate[80]; WCHAR Contact[80]; WCHAR Comments[80]; WCHAR Image[80]; WCHAR ReadmeUrl[80]; WCHAR UpdateInfoUrl[80]; } INSTALLEDAPPW, *PINSTALLEDAPPW; PINSTALLEDAPPW GetInstalledAppsW ( IN OUT PGROWBUFFER Buffer, OUT PUINT Count OPTIONAL ); typedef PVOID MOVELISTW; MOVELISTW AllocateMoveListW ( IN POOLHANDLE PoolHandle ); // // Free move list by destrying the pool it was allocated from // BOOL InsertMoveIntoListW ( IN MOVELISTW List, IN PCWSTR Source, IN PCWSTR Destination ); MOVELISTW RemoveMoveListOverlapW ( IN MOVELISTW List ); BOOL OutputMoveListW ( IN HANDLE File, IN MOVELISTW List, OPTIONAL IN BOOL AddNestedMoves ); BOOL BuildSystemDirectoryPathA ( OUT PSTR Buffer, IN UINT BufferSizeInTchars, IN PCSTR SubPath OPTIONAL ); BOOL BuildSystemDirectoryPathW ( OUT PWSTR Buffer, IN UINT BufferSizeInTchars, IN PCWSTR SubPath OPTIONAL ); HMODULE LoadSystemLibraryA ( IN PCSTR DllFileName ); HMODULE LoadSystemLibraryW ( IN PCWSTR DllFileName ); DWORD OurGetModuleFileNameA ( IN HMODULE Module, OUT PSTR Buffer, IN INT BufferChars ); DWORD OurGetModuleFileNameW ( IN HMODULE Module, OUT PWSTR Buffer, IN INT BufferChars ); // // by default, everybody should use OurGetModuleFileName which makes sure // the output buffer is nul-terminated; this also helps keeping code prefast-clean // #undef GetModuleFileName #define GetModuleFileNameA OurGetModuleFileNameA #define GetModuleFileNameW OurGetModuleFileNameW #ifdef UNICODE #define g_BootDrivePath g_BootDrivePathW #define g_BootDrive g_BootDriveW #define g_BootDriveLetter g_BootDriveLetterW #define MOVELIST MOVELISTW #define AllocateMoveList AllocateMoveListW #define InsertMoveIntoList InsertMoveIntoListW #define RemoveMoveListOverlap RemoveMoveListOverlapW #define OutputMoveList OutputMoveListW #define VERSION_STRUCT VERSION_STRUCTW #define PVERSION_STRUCT PVERSION_STRUCTW #define CreateVersionStruct CreateVersionStructW #define DestroyVersionStruct DestroyVersionStructW #define EnumFirstVersionTranslation EnumFirstVersionTranslationW #define EnumNextVersionTranslation EnumNextVersionTranslationW #define EnumFirstVersionValue EnumFirstVersionValueW #define EnumNextVersionValue EnumNextVersionValueW #define PINSTALLEDAPP PINSTALLEDAPPW #define GetInstalledApps GetInstalledAppsW #define AddStringMappingPairEx AddStringMappingPairExW #define AddStringMappingPair AddStringMappingPairW #define MappingSearchAndReplaceEx MappingSearchAndReplaceExW #define MappingSearchAndReplace MappingSearchAndReplaceW #define MappingMultiTableSearchAndReplaceEx MappingMultiTableSearchAndReplaceExW #define MappingMultiTableSearchAndReplace MappingMultiTableSearchAndReplaceW #define BuildSystemDirectoryPath BuildSystemDirectoryPathW #define LoadSystemLibrary LoadSystemLibraryW #define OurGetModuleFileName OurGetModuleFileNameW #define GetModuleFileName OurGetModuleFileNameW #else #define g_BootDrivePath g_BootDrivePathA #define g_BootDrive g_BootDriveA #define g_BootDriveLetter g_BootDriveLetterA #define VERSION_STRUCT VERSION_STRUCTA #define PVERSION_STRUCT PVERSION_STRUCTA #define CreateVersionStruct CreateVersionStructA #define DestroyVersionStruct DestroyVersionStructA #define EnumFirstVersionTranslation EnumFirstVersionTranslationA #define EnumNextVersionTranslation EnumNextVersionTranslationA #define EnumFirstVersionValue EnumFirstVersionValueA #define EnumNextVersionValue EnumNextVersionValueA #define AddStringMappingPairEx AddStringMappingPairExA #define AddStringMappingPair AddStringMappingPairA #define MappingSearchAndReplaceEx MappingSearchAndReplaceExA #define MappingSearchAndReplace MappingSearchAndReplaceA #define MappingMultiTableSearchAndReplaceEx MappingMultiTableSearchAndReplaceExA #define MappingMultiTableSearchAndReplace MappingMultiTableSearchAndReplaceA #define BuildSystemDirectoryPath BuildSystemDirectoryPathA #define LoadSystemLibrary LoadSystemLibraryA #define OurGetModuleFileName OurGetModuleFileNameA #define GetModuleFileName OurGetModuleFileNameA #endif #ifdef __cplusplus } #endif