Windows2000/private/inet/wininet/urlcache/401inc.hxx
2020-09-30 17:12:32 +02:00

181 lines
6.1 KiB
C++

#ifndef _401INC_H_
#define _401INC_H_
namespace ie401
{
// on content upgrade, we need to check if the MUST_REVALIDATE_SZ symbol
//is set in the CACHE_CONTROL_SZ list. This is now represented by the
//MUST_REVALIDATE_CACHE_ENTRY flag in the CacheEntryType.
#define CACHE_CONTROL_SZ "Cache-Control"
#define MUST_REVALIDATE_SZ "must-revalidate"
#define IE401_NOT_A_CACHE_SUBDIRECTORY 255
#define IE401_EDITED_CACHE_ENTRY 0x00000008
// We need to know the offset into a ie401 indexfile to find the offset
//that points to the first hash table. This is at
//_MEMMAP_HEADER_SMALL.dwHashTableOffset.. The following has been cut from
//401 source to calculate that offset.
#define DIR_NAME_SIZE 8
struct CacheDir
{
DWORD nFileCount;
CHAR sDirName[DIR_NAME_SIZE];
};
#define DEFAULT_MAX_DIRS 32
// the ie401_ was prefixed below to prevent a collision with a #define
//in the current code.
#define ie401_NUM_HEADER_DATA_DWORDS 8
struct _MEMMAP_HEADER_SMALL
{
TCHAR FileSignature[(sizeof(TEXT("Client UrlCache MMF Ver 4.7")) / sizeof(TCHAR))];
DWORD FileSize;
DWORD dwHashTableOffset;
DWORD NumUrlInternalEntries;
DWORD NumUrlEntriesAlloced;
// DWORD dwGarbage; // due to /Zp8 struct alignment
LONGLONG CacheLimit;
LONGLONG CacheSize;
LONGLONG ExemptUsage;
DWORD nDirCount;
CacheDir DirArray[DEFAULT_MAX_DIRS];
DWORD dwHeaderData[ie401_NUM_HEADER_DATA_DWORDS];
};
// The rest was cut'n'pasted from 401 source to allow to define
//the structures of the hash entries themselves.
#define SLOT_BITS 6
#define SLOT_COUNT (1 << SLOT_BITS)
#define SLOT_MASK (SLOT_COUNT - 1)
// With 64 slots, the 6 low bits of HASH_ITEM::dwHash are implied by the slot.
// Currently, the low 3 bits are used instead as flags; the other 3 reserved.
// If bit0 clear, the item indicates a URL entry.
// Then bit1 set if locked, bit2 set if trailing redirect slash allowed
// If bit0 set, the item is free or a redirect entry.
// Then bit1 set if free item never used before
// OR bit2 set if a redirect entry
// hash value bits
#define HASH_BIT_NOTURL 0x0001 // bit 0
#define HASH_BIT_LOCK 0x0002 // bit 1
#define HASH_BIT_REDIR 0x0004 // bit 2
#define HASH_BIT_HASGRP 0x0008 // bit 3
#define HASH_BIT_MULTGRP 0x0010 // bit 4
#define HASH_BIT_RESERVED 0x0020 // bit 5
// hash value flag combinations
#define HASH_UNLOCKED 0 // URL entry, not locked
#define HASH_FREE 1 // free item, was once in use
#define HASH_LOCKED 2 // URL entry, locked
#define HASH_END 3 // free item, never used before
#define HASH_UNLOCKED_SLASH 4 // URL entry, not locked, trailing slash redir
#define HASH_REDIR 5 // redirect entry
#define HASH_LOCKED_SLASH 6 // URL entry, locked, trailing slash redir
#define HASH_FLAG_MASK 7 // illegal, used to mask out hash flags
struct FILEMAP_ENTRY
{
DWORD dwSig;
DWORD nBlocks;
};
struct URL_FILEMAP_ENTRY : FILEMAP_ENTRY
{
LONGLONG LastModifiedTime;
LONGLONG LastAccessedTime;
LONGLONG ExpireTime;
LONGLONG FileSize; // should be DWORD
GROUPID GroupId; // should be list
DWORD dwExemptDelta;
DWORD Size; // should be WORD
DWORD UrlNameOffset; // should be WORD
DWORD DirIndex; // should be BYTE
DWORD InternalFileNameOffset; // should be WORD
DWORD CacheEntryType;
DWORD HeaderInfoOffset; // should be WORD
DWORD HeaderInfoSize; // should be WORD
DWORD FileExtensionOffset; // should be WORD
DWORD dostLastSyncTime;
DWORD NumAccessed; // should be WORD
DWORD NumReferences; // should be WORD
DWORD dostFileCreationTime;
};
struct REDIR_FILEMAP_ENTRY : FILEMAP_ENTRY
{
DWORD dwItemOffset; // offset to hash table item of destination URL
DWORD dwHashValue; // destination URL hash value (BUGBUG: collisions?)
char szUrl[4]; // original URL, can occupy more bytes
};
struct HASH_FILEMAP_ENTRY : FILEMAP_ENTRY
{
DWORD dwNext; // offset to next element in list
DWORD nBlock; // sequence number for this block
};
struct HASH_ITEM
{
DWORD dwHash;
DWORD dwOffset;
// methods on hash value flags
DWORD GetValue(void) {return dwHash & ~SLOT_MASK;}
void MarkFree(void) {dwHash = HASH_FREE;}
void SetSlash (void) {dwHash |= HASH_BIT_REDIR;}
void SetRedir (void) {dwHash |= HASH_REDIR;}
BOOL IsLocked(void) {return dwHash & HASH_LOCKED;}
void SetLocked(void) {dwHash |= HASH_LOCKED;}
void ClearLocked(void) {dwHash &= ~HASH_LOCKED;}
void MarkGroup(void) {dwHash |= HASH_BIT_HASGRP;}
void ClearGroup(void) {dwHash &= ~HASH_BIT_HASGRP;}
BOOL HasGroup(void) {return dwHash & HASH_BIT_HASGRP;}
void MarkMultGroup(void) {dwHash |= HASH_BIT_MULTGRP | HASH_BIT_HASGRP;}
void ClearMultGroup(void) {dwHash &= ~HASH_BIT_MULTGRP;}
BOOL HasMultiGroup(void) {return dwHash & HASH_BIT_MULTGRP; }
};
// hash table parameters
#define BYTES_PER_PAGE 4096
#define ITEMS_PER_BUCKET ((BYTES_PER_PAGE - sizeof(HASH_FILEMAP_ENTRY))\
/ (SLOT_COUNT * sizeof(HASH_ITEM)))
#define BYTES_PER_TABLE (sizeof(HASH_FILEMAP_ENTRY) \
+ SLOT_COUNT * ITEMS_PER_BUCKET * sizeof(HASH_ITEM))
// HashLookupItem bits and flags
#define LOOKUP_BIT_REDIR 1
#define LOOKUP_BIT_CREATE 2
#define LOOKUP_BIT_SPARSE 4 // enable retrieval of partial file entries
#define LOOKUP_URL_NOCREATE 0 // find url entry, don't create new if not found
#define LOOKUP_URL_TRANSLATE 1 // find url entry, translate through redirects
#define LOOKUP_URL_CREATE 2 // find url entry, create new if not found
#define LOOKUP_REDIR_CREATE 3 // find redir entry, create new if not found
#define SIG_FREE 0xbadf00d
#define SIG_ALLOC 0xdeadbeef
#define SIG_HASH ('H'|('A'<<8)|('S'<<16)|('H'<<24))
#define SIG_URL ' LRU' // URL_FILEMAP_ENTRY
#define SIG_REDIR 'RDER' // REDR_FILEMAP_ENTRY
}
#endif