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.
144 lines
4.4 KiB
144 lines
4.4 KiB
/*Includes-----------------------------------------------------------*/
|
|
#include "msrating.h"
|
|
#pragma hdrstop
|
|
|
|
#include <npassert.h>
|
|
#include "ratings.h"
|
|
|
|
#include "roll.h"
|
|
|
|
|
|
|
|
|
|
/*IsUrlInFile---------------------------------------------------------------*/
|
|
/*
|
|
Return VAlue length of Best Match
|
|
*/
|
|
static HRESULT IsUrlInFile(LPCTSTR pszTargetUrl, char **ppRating, const char* pFile, DWORD dwFile, HANDLE hAbortEvent, void* (WINAPI *MemAlloc)(long size))
|
|
{
|
|
LocalListRecordHeader *pllrh;
|
|
DWORD dwBytesRead;
|
|
HRESULT hrRet = S_OK;
|
|
int nBest, nActual, nCmp;
|
|
const char *pBest = NULL;
|
|
BOOL fAbort;
|
|
|
|
dwBytesRead = 0;
|
|
nBest = 0;
|
|
nActual = strlenf(pszTargetUrl);
|
|
fAbort = FALSE;
|
|
|
|
//Go through each recored until there is a match good enough or an abort
|
|
while (!fAbort && nActual != nBest && dwBytesRead <= dwFile)
|
|
{
|
|
pllrh = (LocalListRecordHeader*) pFile;
|
|
if (pllrh->nUrl > nBest &&
|
|
(
|
|
(pllrh->nUrl == nActual)
|
|
||
|
|
(
|
|
pllrh->nUrl < nActual &&
|
|
(
|
|
(pszTargetUrl[pllrh->nUrl] == '\\')
|
|
||
|
|
(pszTargetUrl[pllrh->nUrl] == '/')
|
|
||
|
|
(pszTargetUrl[pllrh->nUrl] == ':')
|
|
)
|
|
)
|
|
)
|
|
)
|
|
{
|
|
nCmp = strnicmpf(pFile+sizeof(LocalListRecordHeader), pszTargetUrl, pllrh->nUrl);
|
|
if (0==nCmp)
|
|
{
|
|
nBest = pllrh->nUrl;
|
|
pBest = pFile;
|
|
hrRet = pllrh->hrRet;
|
|
}
|
|
//the local list is alphabetized
|
|
else if (1==nCmp) break;
|
|
|
|
}
|
|
dwBytesRead += pllrh->nUrl + pllrh->nRating + sizeof(LocalListRecordHeader);
|
|
pFile += pllrh->nUrl + pllrh->nRating + sizeof(LocalListRecordHeader);
|
|
fAbort = (WAIT_OBJECT_0 == WaitForSingleObject(hAbortEvent, 0));
|
|
}
|
|
|
|
//was the match close enough??!?!?
|
|
if (!fAbort && nBest && pBest)
|
|
{
|
|
//yes, now try to copy rating
|
|
pllrh = (LocalListRecordHeader*) pBest;
|
|
if (pllrh->nRating)
|
|
{
|
|
*ppRating = (char*) MemAlloc(pllrh->nRating+1);
|
|
if (*ppRating)
|
|
{
|
|
CopyMemory(*ppRating, pBest + sizeof(LocalListRecordHeader) + pllrh->nUrl, pllrh->nRating);
|
|
(*ppRating)[pllrh->nRating] = 0;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
//no... oh well
|
|
hrRet = E_RATING_NOT_FOUND;
|
|
}
|
|
|
|
return hrRet;
|
|
}
|
|
|
|
|
|
|
|
/*RatingObtainFromLocalList-------------------------------------------------*/
|
|
/*
|
|
Grab rating information from local file.
|
|
Should operate synchronously and take small amount of time.
|
|
Doesn't check pOrd->fAbort too often.
|
|
*/
|
|
|
|
|
|
|
|
HRESULT RatingHelperProcLocalList(LPCTSTR pszTargetUrl, HANDLE hAbortEvent, void* (WINAPI *MemAlloc)(long size), char **ppRatingOut)
|
|
{
|
|
DWORD dwFile;
|
|
HRESULT hrRet = E_RATING_NOT_FOUND;
|
|
HANDLE hFile, hMap;
|
|
BOOL fAbort;
|
|
const char *pFile;
|
|
|
|
ASSERT(ppRatingOut);
|
|
//Open and check from approved list
|
|
hFile = CreateFile(
|
|
FILE_NAME_LIST, GENERIC_READ,
|
|
FILE_SHARE_WRITE, NULL, OPEN_EXISTING,
|
|
FILE_ATTRIBUTE_NORMAL | FILE_FLAG_SEQUENTIAL_SCAN, NULL);
|
|
if (hFile != INVALID_HANDLE_VALUE)
|
|
{
|
|
dwFile = GetFileSize(hFile, NULL);
|
|
hMap = CreateFileMapping(hFile, NULL, PAGE_READONLY, 0, 0, NULL);
|
|
if (hMap)
|
|
{
|
|
pFile = (const char*) MapViewOfFile(hMap, FILE_MAP_READ, 0, 0, 0);
|
|
if (pFile)
|
|
{
|
|
//check for correct file type
|
|
if (BATCAVE_LOCAL_LIST_MAGIC_COOKIE == *((DWORD*) pFile))
|
|
{
|
|
pFile += sizeof(DWORD);
|
|
dwFile -= sizeof(DWORD);
|
|
fAbort = (WAIT_OBJECT_0 == WaitForSingleObject(hAbortEvent, 0));
|
|
if (!fAbort) hrRet = IsUrlInFile(pszTargetUrl, ppRatingOut, pFile, dwFile, hAbortEvent, MemAlloc);
|
|
pFile -= sizeof(DWORD);
|
|
}
|
|
}
|
|
dwFile = (DWORD) UnmapViewOfFile((LPVOID)pFile);
|
|
CloseHandle(hMap);
|
|
}
|
|
CloseHandle(hFile);
|
|
}
|
|
return hrRet;
|
|
}
|
|
|
|
|