mirror of
https://github.com/AppleWin/AppleWin.git
synced 2025-01-24 16:30:01 +00:00
Cleaned up ImageOpen()
This commit is contained in:
parent
7935b18c15
commit
bdf8dfdfe7
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
@ -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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user