--- np2/macosx/fdefine.cpp 2003/11/12 19:06:33 1.3 +++ np2/macosx/fdefine.cpp 2003/11/24 20:44:14 1.6 @@ -3,6 +3,7 @@ #include "dosio.h" #include "fdefine.h" #include "strres.h" +#include "fontdata.h" void Setfiletype(int ftype, OSType *creator, OSType *fileType) { @@ -80,6 +81,9 @@ static int Getfiletype(FInfo *fndrinfo) case '.HDI': return(FTYPE_HDI); + + case 'BMP ': + return(FTYPE_BMP); } return(FTYPE_NONE); } @@ -87,9 +91,11 @@ static int Getfiletype(FInfo *fndrinfo) static int GetFileExt(char* filename) { char* p; + char* n; int ftype; p = file_getext((char *)filename); + n = file_getname((char *)filename); if ((!milstr_cmp(p, str_d88)) || (!milstr_cmp(p, str_d98))) { ftype = FTYPE_D88; } @@ -105,9 +111,25 @@ static int GetFileExt(char* filename) { else if ((!milstr_cmp(p, str_hdi))) { ftype = FTYPE_HDI; } - else { + else if ((!milstr_cmp(p, "xdf")) || (!milstr_cmp(p, "dup")) || (!milstr_cmp(p, "hdm"))) { ftype = FTYPE_BETA; } + else if ( + (!file_cmpname(n, v98fontname)) || + (!file_cmpname(n, pc88ankname)) || + (!file_cmpname(n, pc88knj1name))|| + (!file_cmpname(n, pc88knj2name))|| + (!file_cmpname(n, fm7ankname)) || + (!file_cmpname(n, fm7knjname)) || + (!file_cmpname(n, x1ank1name)) || + (!file_cmpname(n, x1ank2name)) || + (!file_cmpname(n, x1knjname)) || + (!file_cmpname(n, x68kfontname))) { + ftype = FTYPE_SMIL; + } + else { + ftype = FTYPE_NONE; + } return(ftype); } @@ -118,14 +140,14 @@ int file_getftype(char* filename) { FInfo fndrInfo; int ftype; - mkstr255(fname, filename); - FSMakeFSSpec(0, 0, fname, &fss); - if (FSpGetFInfo(&fss, &fndrInfo) != noErr) { - return(FTYPE_NONE); - } - ftype = Getfiletype(&fndrInfo); + ftype = GetFileExt(filename); if (ftype == FTYPE_NONE) { - ftype = GetFileExt(filename); - } + mkstr255(fname, filename); + FSMakeFSSpec(0, 0, fname, &fss); + if (FSpGetFInfo(&fss, &fndrInfo) != noErr) { + return(FTYPE_NONE); + } + ftype = Getfiletype(&fndrInfo); + } return(ftype); }