--- oup/current/Tools/MetaEditor.pas 2007/06/04 22:07:29 209 +++ oup/current/Tools/MetaEditor.pas 2007/06/15 15:12:11 217 @@ -1,28 +1,41 @@ unit MetaEditor; + interface + uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, - Dialogs, VirtualTrees, _FileManager; + Dialogs, _BaseTemplate, ExtCtrls, VirtualTrees, StdCtrls; type - TForm_Meta = class(TForm) + TForm_Meta = class(TForm_BaseTemplate) VST: TVirtualStringTree; - procedure FormClose(Sender: TObject; var Action: TCloseAction); + Panel2: TPanel; + splitter: TSplitter; procedure FormCreate(Sender: TObject); + procedure VSTInitChildren(Sender: TBaseVirtualTree; Node: PVirtualNode; + var ChildCount: Cardinal); + procedure FormClose(Sender: TObject; var Action: TCloseAction); + procedure VSTFocusChanged(Sender: TBaseVirtualTree; Node: PVirtualNode; + Column: TColumnIndex); + procedure VSTFocusChanging(Sender: TBaseVirtualTree; OldNode, + NewNode: PVirtualNode; OldColumn, NewColumn: TColumnIndex; + var Allowed: Boolean); procedure VSTGetText(Sender: TBaseVirtualTree; Node: PVirtualNode; Column: TColumnIndex; TextType: TVSTTextType; var CellText: WideString); + procedure VSTPaintText(Sender: TBaseVirtualTree; + const TargetCanvas: TCanvas; Node: PVirtualNode; Column: TColumnIndex; + TextType: TVSTTextType); private + procedure NewCon(ID: Integer); public - FileManager: TFileManager; end; var Form_Meta: TForm_Meta; implementation -uses - Data, _DataTypes, _FileTypes; {$R *.dfm} +uses _MetaManager, _FileTypes, Data; type PNodeData = ^TNodeData; @@ -43,38 +56,112 @@ begin end; - -procedure TForm_Meta.FormClose(Sender: TObject; var Action: TCloseAction); +procedure TForm_Meta.NewCon(ID: Integer); +var + a,b,c: Int64; + i: Integer; + data: TNodeData; + node: PVirtualNode; begin - FileManager.Free; - Action := caFree; + if ID >= 0 then + begin + QueryPerformanceFrequency(c); + QueryPerformanceCounter(a); + if not Assigned(Meta) then + Meta := TMetaManager.Create(ID); + QueryPerformanceCounter(b); + ShowMessage('Loading Done - ' + FloatToStr((b-a)/c) + 's'); + + VST.Clear; + VST.BeginUpdate; + for i := 0 to Meta.FileCount - 1 do + begin + if Assigned(Meta.FileById[i]) then + begin + data.Field := Meta.FileById[i]; + node := AddVSTEntry(VST, nil, data); + if Meta.FileById[i].ChildCount > 0 then + VST.HasChildren[node] := True; + end; + end; + VST.EndUpdate; + end; end; -procedure TForm_Meta.FormCreate(Sender: TObject); +procedure TForm_Meta.VSTInitChildren(Sender: TBaseVirtualTree; + Node: PVirtualNode; var ChildCount: Cardinal); var - a,b,c: Int64; + data: PNodeData; + newdata: TNodeData; + newnode: PVirtualNode; i: Integer; - data: TNodeData; + id: Integer; begin - VST.NodeDataSize := SizeOf(TNodeData); - VST.Font.Charset := AppSettings.CharSet; - VST.Clear; + data := VST.GetNodeData(node); + for i := 0 to Meta.FileById[TFile(data.Field).FileID].ChildCount - 1 do + begin + id := Meta.FileById[TFile(data.Field).FileID].LinkByIndex[i].DestID; + Meta.InitFile(id); + newdata.Field := Meta.FileById[id]; + newnode := AddVSTEntry(VST, Node, newdata); + if Meta.FileById[id].ChildCount > 0 then + VST.HasChildren[newnode] := True; + end; + ChildCount := Meta.FileById[TFile(data.Field).FileID].ChildCount; +end; - QueryPerformanceFrequency(c); - QueryPerformanceCounter(a); - FileManager := TFileManager.Create(1); - QueryPerformanceCounter(b); - ShowMessage('Loading Done - ' + FloatToStr((b-a)/c) + 's'); - for i := 0 to FileManager.FileCount - 1 do +procedure TForm_Meta.VSTFocusChanged(Sender: TBaseVirtualTree; + Node: PVirtualNode; Column: TColumnIndex); +var + data: PNodeData; +begin + data := Sender.GetNodeData(Node); + if data.Field is TFile then begin - data.Field := FileManager.FileById[i]; - AddVSTEntry(VST, nil, data); + TFile(data.Field).InitEditor; + if Assigned(TFile(data.Field).Editor) then + begin + panel2.InsertControl(TFile(data.Field).Editor); + TFile(data.Field).Opened := True; + end; end; end; +procedure TForm_Meta.VSTFocusChanging(Sender: TBaseVirtualTree; OldNode, + NewNode: PVirtualNode; OldColumn, NewColumn: TColumnIndex; + var Allowed: Boolean); +var + data: PNodeData; + i: Integer; +begin + data := Sender.GetNodeData(NewNode); + if data.Field is TFile then + begin + TFile(data.Field).InitEditor; + if Assigned(TFile(data.Field).Editor) then + Allowed := not TFile(data.Field).Opened + else + Allowed := True; + end; + if Allowed and Assigned(OldNode) then + begin + data := Sender.GetNodeData(OldNode); + if data.Field is TFile then + begin + if TFile(data.Field).Opened then + begin + if panel2.ControlCount > 0 then + for i := 0 to panel2.ControlCount - 1 do + panel2.RemoveControl(panel2.Controls[i]); + TFile(data.Field).Opened := False; + end; + end; + end; +end; + procedure TForm_Meta.VSTGetText(Sender: TBaseVirtualTree; Node: PVirtualNode; Column: TColumnIndex; TextType: TVSTTextType; var CellText: WideString); @@ -86,115 +173,73 @@ begin if TextType = ttNormal then begin case Column of - 0: begin - if Data.Field is TFile then + 0: begin - CellText := TFile(Data.Field).FileName; + if Data.Field is TFile then + begin + CellText := TFile(Data.Field).FileName; + if CellText = '' then + CellText := 'Unnamed'; + end; end; - end; -{ 0: - CellText := Data.Caption; 1: - if Data.DataType > 0 then - CellText := '0x' + IntToHex(Data.Offset, 8) - else if Data.Offset > 0 then - CellText := '0x' + IntToHex(Data.Offset, 8); + begin + if Data.Field is TFile then + CellText := TFile(Data.Field).FileExt; + end; 2: - if Data.DataType > 0 then - CellText := GetDataType(Data.DataType); - 3: - if Data.DataType > 0 then - CellText := Data.Value //GetValue(data.DataType, data.Offset) - else if Length(Data.Value) > 0 then - CellText := IntToStr(StrToInt(Data.Value)) + ' Bytes'; - 4: - CellText := Data.Description; -} end; + begin + if Data.Field is TFile then + CellText := IntToStr(TFile(Data.Field).FileID); + end; + end; end; end; -{ -procedure WriteStructureInfos; +procedure TForm_Meta.VSTPaintText(Sender: TBaseVirtualTree; + const TargetCanvas: TCanvas; Node: PVirtualNode; Column: TColumnIndex; + TextType: TVSTTextType); var - i, j: Integer; - pdata: PNodeData; - Data: TNodeData; - node: PVirtualNode; + Data: PNodeData; begin - VST.BeginUpdate; - if VST.RootNodeCount = 0 then + Data := Sender.GetNodeData(Node); + if TextType = ttNormal then begin - structs := LoadStructureDefinition(ConID, fileid); - if structs.Data then - begin - if Length(structs.Global) > 0 then - begin - for i := 0 to High(structs.Global) do - begin - Data.Caption := structs.Global[i].Name; - Data.Offset := structs.Global[i].offset; - Data.DataType := structs.Global[i].datatype; - Data.Value := GetValue(structs.Global[i].datatype, structs.Global[i].offset); - Data.Description := structs.Global[i].description; - AddVSTEntry(VST, nil, Data); - end; - end; - if Length(structs.Subs) > 0 then - begin - for i := 0 to High(structs.Subs) do + case Column of + 0: begin - with structs.Subs[i] do + if Data.Field is TFile then begin - if Length(Entries) > 0 then - begin - if Pos('#', SubName) > 0 then - begin - Data.Offset := StrToInt('$'+MidStr(SubName, Pos('#', SubName) + 1, 8)); - Data.Value := '$' + - MidStr(SubName, PosEx('#', SubName, Pos('#', SubName) + 1) + 1, 8); - Data.Caption := MidStr(SubName, 1, Pos('#', SubName) - 1); - Data.Description := SubDesc; - end - else - begin - Data.Caption := SubName; - Data.Description := SubDesc; - Data.Offset := 0; - Data.Value := ''; - end; - Data.DataType := 0; - node := AddVSTEntry(VST, nil, Data); - Data.Description := ''; - for j := 0 to High(Entries) do - begin - Data.Caption := Entries[j].Name; - Data.Offset := Entries[j].offset; - Data.DataType := Entries[j].datatype; - Data.Value := GetValue(Entries[j].datatype, Entries[j].offset); - Data.Description := Entries[j].description; - AddVSTEntry(VST, node, Data); - end; - end; + if Length(TFile(Data.Field).FileName) = 0 then + TargetCanvas.Font.Color := $C06060; + if TFile(Data.Field).FileSize = 0 then + TargetCanvas.Font.Color := $2020A0; end; end; - end; - end; - if VST.RootNodeCount > 0 then - VST.FocusedNode := VST.GetFirst; - end - else - begin - Node := VST.GetFirst; - while Assigned(Node) do - begin - pdata := VST.GetNodeData(Node); - if pdata.DataType > 0 then - pdata.Value := GetValue(pdata.Datatype, pdata.Offset); - Node := VST.GetNext(Node); end; end; - VST.EndUpdate; end; -} + + + +procedure TForm_Meta.FormClose(Sender: TObject; var Action: TCloseAction); +begin + Meta.Free; + inherited; +end; + +procedure TForm_Meta.FormCreate(Sender: TObject); +begin + inherited; + OnNewConnection := NewCon; + FConnectionID := -1; + + VST.NodeDataSize := SizeOf(TNodeData); + VST.Font.Charset := AppSettings.CharSet; + VST.Clear; + + UpdateConList; +end; + end.