git-svn-id: file:///Users/lillianskinner/Downloads/platinum/twl/TwlToolsRED@586 7061adef-622a-194b-ae81-725974e89856

This commit is contained in:
mizu 2013-01-16 01:32:58 +00:00
parent 87a51d3bcb
commit f37398b865
4 changed files with 88 additions and 42 deletions

Binary file not shown.

Binary file not shown.

View File

@ -101,7 +101,7 @@ begin
{$I-} {$I-}
//ログファイル作成 //ログファイル作成
ListBox_log.Items.Add('Create Log file'); ListBox_log.Items.Add('Create Log file');
s := 'log.txt'; s := ExtractFilePath(Application.Exename)+'log.txt';
AssignFile (flog,s); AssignFile (flog,s);
Rewrite(flog); Rewrite(flog);
if IOResult <> 0 then begin if IOResult <> 0 then begin
@ -119,8 +119,8 @@ begin
(Rec.Name <> '.') and (Rec.Name <> '..') and (Rec.name<>'log.txt')then (Rec.Name <> '.') and (Rec.Name <> '..') and (Rec.name<>'log.txt')then
begin begin
Inc(Count); Inc(Count);
//ListBox_log.Items.Add(' ********************************** '); //ListBox_log.Items.Add('**********************************');
Writeln(flog,' ********************************** '); Writeln(flog,'**********************************');
sf := 'file: '+Rec.Name; sf := 'file: '+Rec.Name;
//ListBox_log.Items.Add(sf); //ListBox_log.Items.Add(sf);
Writeln(flog,sf); Writeln(flog,sf);
@ -166,22 +166,39 @@ begin
s := s+'Cannot read fat id='+ inttostr(i); s := s+'Cannot read fat id='+ inttostr(i);
break; break;
end; end;
size := (fat.bottom - fat.top)+1;
sectors := size shr 9;//div 512
if (size and $1ff) <>0 then inc(sectors);
size := sectors shl 9;
inc(all_sectors,sectors);
//max_sectors = (DHT_OVERLAY_MAX/512 - total_sectors) / (nums-i); //max_sectors = (DHT_OVERLAY_MAX/512 - total_sectors) / (nums-i);
if (total_sectors < 1024)then max_sectors := (1024 - total_sectors) div (nums-i) if (total_sectors < 1024)then max_sectors := (1024 - total_sectors) div (nums-i)
else max_sectors := 0; else max_sectors := 0;
btm := fat.bottom; btm := fat.bottom and $fffffe00; //512単位
if (fat.bottom and $1ff)<>0 then inc(btm,512);//上方向に丸める
if max_sectors = 0 then begin//残検証サイズなければ丸ごと検証外 if max_sectors = 0 then begin//残検証サイズなければ丸ごと検証外
top := fat.top; top := fat.top;
ss := '(A9 Overlay の全部)'; ss := '(A9 Overlay の全部)';
end else begin end else begin
top := fat.top and $fffffe00; //512単位
size := fat.top and $01ff;
if size<>0 then begin
inc(top,512);////上方向に丸める
//先頭の未検証部分 .. 不要?
s := 'offset'+inttostr(i)+' = 0x'+ inttohex(fat.top,8)
+' ; 0x'+ inttohex(fat.top,8)
+'-0x' + inttohex(top-1,8)+ss;
//ListBox_log.Items.Add(s);
Writeln(flog,s);
s := 'length'+ inttostr(i) + ' = 0x' + inttohex(size,4)
+ ' ; '+ inttostr(size)+' bytes';
//ListBox_log.Items.Add(s);
Writeln(flog,s);
inc(noc_size,512);
inc(noc_sectors,1);
inc(all_sectors,1);
end;
size := btm - top;
sectors := size shr 9;//div 512
inc(all_sectors,sectors);
if sectors > max_sectors then begin //最大割当サイズ超 if sectors > max_sectors then begin //最大割当サイズ超
sectors := sectors - max_sectors;//検証されないセクタ数 sectors := sectors - max_sectors;//残りセクタ数
top := fat.top + max_sectors; inc(top,max_sectors*512);//残り先頭
inc(total_sectors,max_sectors); inc(total_sectors,max_sectors);
ss := '(A9 Overlay の一部)'; ss := '(A9 Overlay の一部)';
end else begin //超過なし end else begin //超過なし
@ -189,11 +206,11 @@ begin
sectors := 0; sectors := 0;
end; end;
end; end;
if sectors > 0 then begin if sectors > 0 then begin//残りあり
size := sectors shl 9; size := sectors shl 9;
s := 'offset'+inttostr(i)+' = 0x'+ inttohex(top,8) s := 'offset'+inttostr(i)+' = 0x'+ inttohex(top,8)
+' ; 0x'+ inttohex(top,8) +' ; 0x'+ inttohex(top,8)
+'-0x' + inttohex(btm,8)+ss; +'-0x' + inttohex(btm-1,8)+ss;
//ListBox_log.Items.Add(s); //ListBox_log.Items.Add(s);
Writeln(flog,s); Writeln(flog,s);
s := 'length'+ inttostr(i) + ' = 0x' + inttohex(size,4) s := 'length'+ inttostr(i) + ' = 0x' + inttohex(size,4)
@ -205,12 +222,13 @@ begin
end; end;
end; end;
if i = nums then begin //中断なし if i = nums then begin //中断なし
//ListBox_log.Items.Add(' ');
//ListBox_log.Items.Add('total sectors = '+inttostr(all_sectors)); //ListBox_log.Items.Add('total sectors = '+inttostr(all_sectors));
//ListBox_log.Items.Add('no check sectors = '+inttostr(noc_sectors)); //ListBox_log.Items.Add('no check sectors = '+inttostr(noc_sectors));
//ListBox_log.Items.Add('no check size = '+inttostr(noc_size)); //ListBox_log.Items.Add('no check size = '+inttostr(noc_size));
//ListBox_log.Items.Add(' '); //間をあける Writeln(flog); //改行
Writeln(flog); //開業
Writeln(flog,'total sectors = '+inttostr(all_sectors)); Writeln(flog,'total sectors = '+inttostr(all_sectors));
Writeln(flog,'check sectors = '+inttostr(total_sectors));
Writeln(flog,'no check sectors = '+inttostr(noc_sectors)); Writeln(flog,'no check sectors = '+inttostr(noc_sectors));
Writeln(flog,'no check size = '+inttostr(noc_size)); Writeln(flog,'no check size = '+inttostr(noc_size));
if noc_size > 0 then s:= 'NG' if noc_size > 0 then s:= 'NG'
@ -224,7 +242,7 @@ begin
if (s='OK') or (s='NG') then s := 'done'; if (s='OK') or (s='NG') then s := 'done';
ss := sf + ' : ' + s; ss := sf + ' : ' + s;
ListBox_log.Items.Add(ss); ListBox_log.Items.Add(ss);
end; end;
until (FindNext(Rec) <> 0); until (FindNext(Rec) <> 0);
finally finally
FindClose(Rec); FindClose(Rec);

View File

@ -88,9 +88,10 @@ implementation
function TForm1.CheckSrlHeader: integer; function TForm1.CheckSrlHeader: integer;
var var
Rec: TSearchRec; Rec: TSearchRec;
s,ss: String; sf,s,ss: String;
i,n,Count: integer; i,n,Count: integer;
fsrl: file; fsrl: file;
flog:TextFile;
romh: TRomh; romh: TRomh;
noc_size,noc_sectors,size,sectors,nums,max_sectors,total_sectors: integer; noc_size,noc_sectors,size,sectors,nums,max_sectors,total_sectors: integer;
fat: TRom_Fat; fat: TRom_Fat;
@ -98,26 +99,38 @@ var
begin begin
{$I-} {$I-}
Count :=0; //ログファイル作成
//指定ディレクトリからファイルを取り出す ListBox_log.Items.Add('Create Log file');
// ** 内容で判別しないので違うファイル置かないよう注意 ** s := 'log.txt';
if FindFirst(SrlDir + '*.*', faAnyFile, Rec) = 0 then AssignFile (flog,s);
try Rewrite(flog);
if IOResult <> 0 then begin
Count := -1;
ListBox_log.Items.Add('faild')
end else begin
Count := 0;
//指定ディレクトリからファイルを取り出す
// ** 内容で判別しないので違うファイル置かないよう注意 **
if FindFirst(SrlDir + '*.*', faAnyFile, Rec) = 0 then
try
repeat repeat
//フォルダやカレントディレクトリや親ディレクトリは対象外 //フォルダやカレントディレクトリや親ディレクトリは対象外
if not((Rec.Attr and faDirectory > 0)) and if not((Rec.Attr and faDirectory > 0)) and
(Rec.Name <> '.') and (Rec.Name <> '..') then (Rec.Name <> '.') and (Rec.Name <> '..') and (Rec.name<>'log.txt')then
begin begin
Inc(Count); Inc(Count);
ListBox_log.Items.Add(' ********************************** '); //ListBox_log.Items.Add(' ********************************** ');
ListBox_log.Items.Add('file: '+Rec.Name); Writeln(flog,' ********************************** ');
sf := 'file: '+Rec.Name;
//ListBox_log.Items.Add(sf);
Writeln(flog,sf);
AssignFile (fsrl,SrlDir+Rec.Name); AssignFile (fsrl,SrlDir+Rec.Name);
FileMode := fmOpenRead;//リード専用指定 FileMode := fmOpenRead;//リード専用指定
Reset(fsrl,1);//ファイル開く Reset(fsrl,1);//ファイル開く
if IOResult = 0 then begin if IOResult = 0 then begin
BlockRead(fsrl,romh,SizeOf(TRomh),n);//ヘッダリード BlockRead(fsrl,romh,SizeOf(TRomh),n);//ヘッダリード
if SizeOf(TRomh) <> n then if SizeOf(TRomh) <> n then
s := ' file error' s := ' header read error'
else begin else begin
//SetLength(s,12); //SetLength(s,12);
s := '[ ( )]'; s := '[ ( )]';
@ -126,12 +139,16 @@ begin
s[i+1] := romh.title[i]; s[i+1] := romh.title[i];
end; end;
s[15] := romh.game_code[4];//idの文字目(仕向地) s[15] := romh.game_code[4];//idの文字目(仕向地)
ListBox_log.Items.Add(s); //title //ListBox_log.Items.Add(s); //title
Writeln(flog,s);
s := 'game_code = '; s := 'game_code = ';
for i:=1 to 4 do s[12+i] := romh.game_code[i]; for i:=1 to 4 do s[12+i] := romh.game_code[i];
ListBox_log.Items.Add(s); //game code //ListBox_log.Items.Add(s); //game code
ListBox_log.Items.Add('version = '+inttostr(romh.rom_version)); //ListBox_log.Items.Add('version = '+inttostr(romh.rom_version));
ListBox_log.Items.Add(' '); //間をあける //ListBox_log.Items.Add(' ');
Writeln(flog,s);
Writeln(flog,'version = '+inttostr(romh.rom_version));
Writeln(flog);//改行
//オーバレイチェック //オーバレイチェック
if romh.main_ovt_size >31 then begin if romh.main_ovt_size >31 then begin
@ -177,19 +194,25 @@ begin
s := 'offset'+inttostr(i)+' = 0x'+ inttohex(top,8) s := 'offset'+inttostr(i)+' = 0x'+ inttohex(top,8)
+' ; 0x'+ inttohex(top,8) +' ; 0x'+ inttohex(top,8)
+'-0x' + inttohex(btm,8)+ss; +'-0x' + inttohex(btm,8)+ss;
ListBox_log.Items.Add(s); //ListBox_log.Items.Add(s);
Writeln(flog,s);
s := 'length'+ inttostr(i) + ' = 0x' + inttohex(size,4) s := 'length'+ inttostr(i) + ' = 0x' + inttohex(size,4)
+ ' ; '+ inttostr(size)+' bytes'; + ' ; '+ inttostr(size)+' bytes';
ListBox_log.Items.Add(s); //ListBox_log.Items.Add(s);
Writeln(flog,s);
inc(noc_size,size); inc(noc_size,size);
inc(noc_sectors,sectors); inc(noc_sectors,sectors);
end; end;
end; end;
if i = nums then begin //中断なし if i = nums then begin //中断なし
ListBox_log.Items.Add('total sectors = '+inttostr(all_sectors)); //ListBox_log.Items.Add('total sectors = '+inttostr(all_sectors));
ListBox_log.Items.Add('no check sectors = '+inttostr(noc_sectors)); //ListBox_log.Items.Add('no check sectors = '+inttostr(noc_sectors));
ListBox_log.Items.Add('no check size = '+inttostr(noc_size)); //ListBox_log.Items.Add('no check size = '+inttostr(noc_size));
ListBox_log.Items.Add(' '); //間をあける //ListBox_log.Items.Add(' '); //間をあける
Writeln(flog); //開業
Writeln(flog,'total sectors = '+inttostr(all_sectors));
Writeln(flog,'no check sectors = '+inttostr(noc_sectors));
Writeln(flog,'no check size = '+inttostr(noc_size));
if noc_size > 0 then s:= 'NG' if noc_size > 0 then s:= 'NG'
else s:= 'OK'; else s:= 'OK';
end; end;
@ -197,12 +220,16 @@ begin
end; end;
end else s := ' Open Error'; end else s := ' Open Error';
CloseFile(fsrl); CloseFile(fsrl);
ListBox_log.Items.Add(s); Writeln(flog,s);//結果
if (s='OK') or (s='NG') then s := 'done';
ss := sf + ' : ' + s;
ListBox_log.Items.Add(ss);
end; end;
until (FindNext(Rec) <> 0); until (FindNext(Rec) <> 0);
finally finally
FindClose(Rec); FindClose(Rec);
end;
CloseFile(flog);
end; end;
{$I+} {$I+}
Result :=Count; Result :=Count;
@ -213,15 +240,16 @@ end;
procedure TForm1.Button1Click(Sender: TObject); procedure TForm1.Button1Click(Sender: TObject);
var var
FileCount :integer; FileCount :integer;
s :string;
begin begin
ListBox_log.Clear; ListBox_log.Clear;
//指定ディレクトリのsrlファイルをチェック //指定ディレクトリのsrlファイルをチェック
FileCount := CheckSrlHeader; FileCount := CheckSrlHeader;
if FileCount>0 then begin if FileCount>0 then begin
ListBox_log.Items.Add(' ------------------------------ '); ListBox_log.Items.Add(' ------------------------------ ');
ListBox_log.Items.Add('total '+inttostr(FileCount)+' files'); s := 'total '+inttostr(FileCount)+' files';
end else end else if FileCount = 0 then s := ' file not ditect' ;
ListBox_log.Items.Add(' file not ditect'); ListBox_log.Items.Add(s);
end; end;