Cleaned up ImageOpen()

This commit is contained in:
mpohoreski 2006-03-09 21:40:16 +00:00
parent 7935b18c15
commit bdf8dfdfe7
2 changed files with 153 additions and 116 deletions

View File

@ -736,139 +736,165 @@ void ImageInitialize () {
//=========================================================================== //===========================================================================
int ImageOpen (LPCTSTR imagefilename, int ImageOpen (LPCTSTR imagefilename,
HIMAGE *imagehandle, HIMAGE *hDiskImage_,
BOOL *writeprotected, BOOL *pWriteProtected_,
BOOL createifnecessary) { BOOL bCreateIfNecessary)
if (!(imagefilename && imagehandle && writeprotected && workbuffer)) {
return -1; if (! (imagefilename && hDiskImage_ && pWriteProtected_ && workbuffer))
return IMAGE_ERROR_BAD_POINTER; // HACK: MAGIC # -1
// TRY TO OPEN THE IMAGE FILE // TRY TO OPEN THE IMAGE FILE
HANDLE file = INVALID_HANDLE_VALUE; HANDLE file = INVALID_HANDLE_VALUE;
if (!*writeprotected)
file = CreateFile(imagefilename, if (! *pWriteProtected_)
file = CreateFile(imagefilename,
GENERIC_READ | GENERIC_WRITE, GENERIC_READ | GENERIC_WRITE,
FILE_SHARE_READ | FILE_SHARE_WRITE, FILE_SHARE_READ | FILE_SHARE_WRITE,
(LPSECURITY_ATTRIBUTES)NULL, (LPSECURITY_ATTRIBUTES)NULL,
OPEN_EXISTING, OPEN_EXISTING,
FILE_ATTRIBUTE_NORMAL, FILE_ATTRIBUTE_NORMAL,
NULL); NULL);
if (file == INVALID_HANDLE_VALUE) {
file = CreateFile(imagefilename,
GENERIC_READ,
FILE_SHARE_READ,
(LPSECURITY_ATTRIBUTES)NULL,
OPEN_EXISTING,
FILE_ATTRIBUTE_NORMAL,
NULL);
if (file != INVALID_HANDLE_VALUE)
*writeprotected = 1;
}
if ((file == INVALID_HANDLE_VALUE) && createifnecessary)
file = CreateFile(imagefilename,
GENERIC_READ | GENERIC_WRITE,
FILE_SHARE_READ | FILE_SHARE_WRITE,
(LPSECURITY_ATTRIBUTES)NULL,
CREATE_NEW,
FILE_ATTRIBUTE_NORMAL,
NULL);
// IF WE AREN'T ABLE TO OPEN THE FILE, RETURN // File may have read-only attribute set, so try to open as read-only.
if (file == INVALID_HANDLE_VALUE) if (file == INVALID_HANDLE_VALUE)
return 1; {
file = CreateFile(
imagefilename,
GENERIC_READ,
FILE_SHARE_READ,
(LPSECURITY_ATTRIBUTES)NULL,
OPEN_EXISTING,
FILE_ATTRIBUTE_NORMAL,
NULL );
// DETERMINE THE FILE'S EXTENSION AND CONVERT IT TO LOWERCASE if (file != INVALID_HANDLE_VALUE)
LPCTSTR imagefileext = imagefilename; *pWriteProtected_ = 1;
if (_tcsrchr(imagefileext,TEXT('\\'))) }
imagefileext = _tcsrchr(imagefileext,TEXT('\\'))+1;
if (_tcsrchr(imagefileext,TEXT('.')))
imagefileext = _tcsrchr(imagefileext,TEXT('.'));
TCHAR ext[_MAX_EXT];
_tcsncpy(ext,imagefileext,_MAX_EXT);
CharLowerBuff(ext,_tcslen(ext));
DWORD size = GetFileSize(file,NULL); if ((file == INVALID_HANDLE_VALUE) && bCreateIfNecessary)
LPBYTE view = NULL; file = CreateFile(
LPBYTE imageptr = NULL; imagefilename,
DWORD format = 0xFFFFFFFF; GENERIC_READ | GENERIC_WRITE,
if (size > 0) { FILE_SHARE_READ | FILE_SHARE_WRITE,
(LPSECURITY_ATTRIBUTES)NULL,
CREATE_NEW,
FILE_ATTRIBUTE_NORMAL,
NULL );
// MAP THE FILE INTO MEMORY FOR USE BY THE DETECTION FUNCTIONS // IF WE AREN'T ABLE TO OPEN THE FILE, RETURN
HANDLE mapping = CreateFileMapping(file, if (file == INVALID_HANDLE_VALUE)
(LPSECURITY_ATTRIBUTES)NULL, return IMAGE_ERROR_UNABLE_TO_OPEN; // HACK: MAGIC # 1
PAGE_READONLY,
0,0,NULL);
view = (LPBYTE)MapViewOfFile(mapping,FILE_MAP_READ,0,0,0);
imageptr = view;
if (imageptr) {
// DETERMINE WHETHER THE FILE HAS A 128-BYTE MACBINARY HEADER // DETERMINE THE FILE'S EXTENSION AND CONVERT IT TO LOWERCASE
if ((size > 128) && LPCTSTR imagefileext = imagefilename;
(!*imageptr) && if (_tcsrchr(imagefileext,TEXT('\\')))
(*(imageptr+1) < 120) && imagefileext = _tcsrchr(imagefileext,TEXT('\\'))+1;
(!*(imageptr+*(imageptr+1)+2)) && if (_tcsrchr(imagefileext,TEXT('.')))
(*(imageptr+0x7A) == 0x81) && imagefileext = _tcsrchr(imagefileext,TEXT('.'));
(*(imageptr+0x7B) == 0x81)) { TCHAR ext[_MAX_EXT];
imageptr += 128; _tcsncpy(ext,imagefileext,_MAX_EXT);
size -= 128; CharLowerBuff(ext,_tcslen(ext));
}
// CALL THE DETECTION FUNCTIONS IN ORDER, LOOKING FOR A MATCH DWORD size = GetFileSize(file,NULL);
DWORD possibleformat = 0xFFFFFFFF; LPBYTE view = NULL;
int loop = 0; LPBYTE pImage = NULL;
while ((loop < IMAGETYPES) && (format == 0xFFFFFFFF)) {
if (*ext && _tcsstr(imagetype[loop].rejectexts,ext))
++loop;
else {
DWORD result = imagetype[loop].detect(imageptr,size);
if (result == 2)
format = loop;
else if ((result == 1) && (possibleformat == 0xFFFFFFFF))
possibleformat = loop++;
else
++loop;
}
}
if (format == 0xFFFFFFFF)
format = possibleformat;
// CLOSE THE MEMORY MAPPING const DWORD UNKNOWN_FORMAT = 0xFFFFFFFF;
UnmapViewOfFile(view); DWORD format = UNKNOWN_FORMAT;
}
CloseHandle(mapping);
}
else
{
// WE CREATE ONLY DOS ORDER (DO) OR 6656-NIBBLE (NIB) FORMAT FILES if (size > 0)
for (int loop = 1; loop <= 4; loop += 3) {
if (*ext && _tcsstr(imagetype[loop].createexts,ext)) { // MAP THE FILE INTO MEMORY FOR USE BY THE DETECTION FUNCTIONS
format = loop; HANDLE mapping = CreateFileMapping(
break; file,
} (LPSECURITY_ATTRIBUTES)NULL,
} PAGE_READONLY,
0,0,NULL );
// IF THE FILE DOES MATCH A KNOWN FORMAT... view = (LPBYTE)MapViewOfFile(mapping,FILE_MAP_READ,0,0,0);
if (format != 0xFFFFFFFF) { pImage = view;
// CREATE A RECORD FOR THE FILE, AND RETURN AN IMAGE HANDLE if (pImage)
*imagehandle = (HIMAGE)VirtualAlloc(NULL,sizeof(imageinforec),MEM_COMMIT,PAGE_READWRITE); {
if (*imagehandle) { // DETERMINE WHETHER THE FILE HAS A 128-BYTE MACBINARY HEADER
ZeroMemory(*imagehandle,sizeof(imageinforec)); if ((size > 128) &&
_tcsncpy(((imageinfoptr)*imagehandle)->filename,imagefilename,MAX_PATH); (!*pImage) &&
((imageinfoptr)*imagehandle)->format = format; (*(pImage+1) < 120) &&
((imageinfoptr)*imagehandle)->file = file; (!*(pImage+*(pImage+1)+2)) &&
((imageinfoptr)*imagehandle)->offset = imageptr-view; (*(pImage+0x7A) == 0x81) &&
((imageinfoptr)*imagehandle)->writeprotected = *writeprotected; (*(pImage+0x7B) == 0x81))
for (int track = 0; track < TRACKS; track++) {
((imageinfoptr)*imagehandle)->validtrack[track] = (size > 0); pImage += 128;
return 0; size -= 128;
} }
}
CloseHandle(file); // CALL THE DETECTION FUNCTIONS IN ORDER, LOOKING FOR A MATCH
if (!(size > 0)) DWORD possibleformat = UNKNOWN_FORMAT; // 0xFFFFFFFF;
DeleteFile(imagefilename); int loop = 0;
return 2; while ((loop < IMAGETYPES) && (format == UNKNOWN_FORMAT)) // 0xFFFFFFFF)) {
{
if (*ext && _tcsstr(imagetype[loop].rejectexts,ext))
++loop;
else
{
DWORD result = imagetype[loop].detect(pImage,size);
if (result == 2)
format = loop;
else if ((result == 1) && (possibleformat == UNKNOWN_FORMAT)) // 0xFFFFFFFF))
possibleformat = loop++;
else
++loop;
}
}
if (format == UNKNOWN_FORMAT) // 0xFFFFFFFF)
format = possibleformat;
// CLOSE THE MEMORY MAPPING
UnmapViewOfFile(view);
}
CloseHandle(mapping);
}
else
{
// WE CREATE ONLY DOS ORDER (DO) OR 6656-NIBBLE (NIB) FORMAT FILES
for (int loop = 1; loop <= 4; loop += 3)
{
if (*ext && _tcsstr(imagetype[loop].createexts,ext))
{
format = loop;
break;
}
}
}
// IF THE FILE DOES MATCH A KNOWN FORMAT...
if (format != UNKNOWN_FORMAT)
{
// CREATE A RECORD FOR THE FILE, AND RETURN AN IMAGE HANDLE
*hDiskImage_ = (HIMAGE)VirtualAlloc(NULL,sizeof(imageinforec),MEM_COMMIT,PAGE_READWRITE);
if (*hDiskImage_)
{
ZeroMemory(*hDiskImage_,sizeof(imageinforec));
_tcsncpy(((imageinfoptr)*hDiskImage_)->filename,imagefilename,MAX_PATH);
((imageinfoptr)*hDiskImage_)->format = format;
((imageinfoptr)*hDiskImage_)->file = file;
((imageinfoptr)*hDiskImage_)->offset = pImage-view;
((imageinfoptr)*hDiskImage_)->writeprotected = *pWriteProtected_;
for (int track = 0; track < TRACKS; track++)
((imageinfoptr)*hDiskImage_)->validtrack[track] = (size > 0);
return IMAGE_ERROR_NONE; // HACK: MAGIC # 0
}
}
CloseHandle(file);
if (!(size > 0))
DeleteFile(imagefilename);
return IMAGE_ERROR_BAD_SIZE; // HACK: MAGIC # 2
} }
//=========================================================================== //===========================================================================

View File

@ -8,6 +8,17 @@ BOOL ImageBoot (HIMAGE);
void ImageClose (HIMAGE); void ImageClose (HIMAGE);
void ImageDestroy (); void ImageDestroy ();
void ImageInitialize (); void ImageInitialize ();
int ImageOpen (LPCTSTR,HIMAGE *,BOOL *,BOOL);
enum ImageError_e
{
IMAGE_ERROR_BAD_POINTER =-1,
IMAGE_ERROR_NONE = 0,
IMAGE_ERROR_UNABLE_TO_OPEN = 1,
IMAGE_ERROR_BAD_SIZE = 2
};
//int ImageOpen (LPCTSTR,HIMAGE *,BOOL *,BOOL);
int ImageOpen (LPCTSTR imagefilename, HIMAGE *hDiskImage_, BOOL *pWriteProtected_, BOOL bCreateIfNecessary );
void ImageReadTrack (HIMAGE,int,int,LPBYTE,int *); void ImageReadTrack (HIMAGE,int,int,LPBYTE,int *);
void ImageWriteTrack (HIMAGE,int,int,LPBYTE,int); void ImageWriteTrack (HIMAGE,int,int,LPBYTE,int);