| 1 | unit fClientRPCLogger;
 | 
|---|
| 2 | 
 | 
|---|
| 3 | interface
 | 
|---|
| 4 | 
 | 
|---|
| 5 | uses
 | 
|---|
| 6 |   Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
 | 
|---|
| 7 |   StdCtrls, ExtCtrls, ComCtrls, Clipbrd, Menus, uRpcLogEntry;
 | 
|---|
| 8 | 
 | 
|---|
| 9 | type
 | 
|---|
| 10 |   TfrmRpcClientLogger = class(TForm)
 | 
|---|
| 11 |     cbxEnableRPCLogging: TCheckBox;
 | 
|---|
| 12 |     lblMaxRPCEntries: TLabel;
 | 
|---|
| 13 |     UpDown1: TUpDown;
 | 
|---|
| 14 |     maxRpcLogEntriesNumericUpDown: TEdit;
 | 
|---|
| 15 |     rpcLogListBox: TListBox;
 | 
|---|
| 16 |     Panel1: TPanel;
 | 
|---|
| 17 |     lblRPCName: TLabel;
 | 
|---|
| 18 |     lblRPCDebugID: TLabel;
 | 
|---|
| 19 |     lblClientName: TLabel;
 | 
|---|
| 20 |     lblClientDebugID: TLabel;
 | 
|---|
| 21 |     lblContext: TLabel;
 | 
|---|
| 22 |     lblDuration: TLabel;
 | 
|---|
| 23 |     edtRPCName: TEdit;
 | 
|---|
| 24 |     edtRPCDebugID: TEdit;
 | 
|---|
| 25 |     edtClientName: TEdit;
 | 
|---|
| 26 |     edtClientDebugID: TEdit;
 | 
|---|
| 27 |     edtContext: TEdit;
 | 
|---|
| 28 |     edtDuration1: TEdit;
 | 
|---|
| 29 |     lblParams: TLabel;
 | 
|---|
| 30 |     lblResults: TLabel;
 | 
|---|
| 31 |     MainMenu1: TMainMenu;
 | 
|---|
| 32 |     PopupMenu1: TPopupMenu;
 | 
|---|
| 33 |     File1: TMenuItem;
 | 
|---|
| 34 |     mnuFileClose: TMenuItem;
 | 
|---|
| 35 |     Edit1: TMenuItem;
 | 
|---|
| 36 |     HGelp1: TMenuItem;
 | 
|---|
| 37 |     mnuHelpAbout: TMenuItem;
 | 
|---|
| 38 |     mnuEditCopyToClipboard: TMenuItem;
 | 
|---|
| 39 |     mnuPopupCopyToClipboard: TMenuItem;
 | 
|---|
| 40 |     ParamsMemoBox: TRichEdit;
 | 
|---|
| 41 |     ResultsMemoBox: TRichEdit;
 | 
|---|
| 42 |     Edit2: TEdit;
 | 
|---|
| 43 |     btnClose: TButton;
 | 
|---|
| 44 |     procedure FormClose(Sender: TObject; var Action: TCloseAction);
 | 
|---|
| 45 |     procedure UpDown1Click(Sender: TObject; Button: TUDBtnType);
 | 
|---|
| 46 |     procedure mnuEditCopyToClipboardClick(Sender: TObject);
 | 
|---|
| 47 |     procedure rpcLogListBoxClick(Sender: TObject);
 | 
|---|
| 48 |     procedure mnuPopupCopyToClipboardClick(Sender: TObject);
 | 
|---|
| 49 |     procedure mnuFileCloseClick(Sender: TObject);
 | 
|---|
| 50 |     procedure btnCloseClick(Sender: TObject);
 | 
|---|
| 51 |   private
 | 
|---|
| 52 |     { Private declarations }
 | 
|---|
| 53 |   public
 | 
|---|
| 54 |     { Public declarations }
 | 
|---|
| 55 |     procedure DisplayRpcEntry(entry: TRpcLogEntry);
 | 
|---|
| 56 |     procedure AddRpcLogEntry(entry: TRPCLogEntry; overrideCheckBox: Boolean);
 | 
|---|
| 57 |   end;
 | 
|---|
| 58 | 
 | 
|---|
| 59 | var
 | 
|---|
| 60 |   frmRpcClientLogger: TfrmRpcClientLogger;
 | 
|---|
| 61 | 
 | 
|---|
| 62 | implementation
 | 
|---|
| 63 | 
 | 
|---|
| 64 | {$R *.DFM}
 | 
|---|
| 65 | 
 | 
|---|
| 66 | procedure TfrmRpcClientLogger.AddRpcLogEntry(entry: TRPCLogEntry; overrideCheckBox: Boolean);
 | 
|---|
| 67 | var
 | 
|---|
| 68 |   Str, Str1: String;
 | 
|---|
| 69 |   Max: Integer;
 | 
|---|
| 70 | begin
 | 
|---|
| 71 |   if (cbxEnableRPCLogging.Checked or overrideCheckBox) then
 | 
|---|
| 72 |   begin
 | 
|---|
| 73 |     // If the list is full we need to delete the 0th item till we have room for one.
 | 
|---|
| 74 |     while (rpcLogListBox.Items.Count >= StrToInt(maxRpcLogEntriesNumericUpDown.Text)) do
 | 
|---|
| 75 |       rpcLogListBox.Items.Delete(0);
 | 
|---|
| 76 |     with entry do
 | 
|---|
| 77 |     begin
 | 
|---|
| 78 |       Max := 30;
 | 
|---|
| 79 |       if Length(Name) > 30 then
 | 
|---|
| 80 |         Max := Length(Name);
 | 
|---|
| 81 |       Str := Copy(Name+'                                                   ',1,Max);
 | 
|---|
| 82 |       Str1 := '      '+IntToStr(Duration);
 | 
|---|
| 83 |       Str := Str + '   cId: '+IntToStr(UniqueClientId)+'  time ='+Copy(Str1,Length(Str1)-5,Length(Str1))+' ms   rpcId: '+IntToStr(UniqueId)+'   '+ClientName;
 | 
|---|
| 84 |     end;    // with
 | 
|---|
| 85 |     rpcLogListBox.Items.AddObject(Str, entry);
 | 
|---|
| 86 |   end;
 | 
|---|
| 87 | end;
 | 
|---|
| 88 | 
 | 
|---|
| 89 |     procedure TfrmRpcClientLogger.FormClose(Sender: TObject; var Action: TCloseAction);
 | 
|---|
| 90 |     begin
 | 
|---|
| 91 |       //
 | 
|---|
| 92 |     end;
 | 
|---|
| 93 |     procedure TfrmRpcClientLogger.UpDown1Click(Sender: TObject; Button: TUDBtnType);
 | 
|---|
| 94 |     begin
 | 
|---|
| 95 |       //
 | 
|---|
| 96 |     end;
 | 
|---|
| 97 | 
 | 
|---|
| 98 | procedure TfrmRpcClientLogger.mnuEditCopyToClipboardClick(Sender: TObject);
 | 
|---|
| 99 | begin
 | 
|---|
| 100 |   if RpcLogListBox.ItemIndex > -1 then
 | 
|---|
| 101 |     mnuPopupCopyToClipboardClick(Self);
 | 
|---|
| 102 | end;
 | 
|---|
| 103 | procedure TfrmRpcClientLogger.rpcLogListBoxClick(Sender: TObject);
 | 
|---|
| 104 | begin
 | 
|---|
| 105 |   DisplayRpcEntry(TRpcLogEntry(rpcLogListBox.Items.Objects[rpcLogListBox.ItemIndex]));
 | 
|---|
| 106 |   mnuEditCopyToClipboard.Enabled := True;
 | 
|---|
| 107 | end;
 | 
|---|
| 108 | 
 | 
|---|
| 109 | procedure TfrmRpcClientLogger.mnuPopupCopyToClipboardClick(Sender: TObject);
 | 
|---|
| 110 | var
 | 
|---|
| 111 |   RPCEntry: TRpcLogEntry;
 | 
|---|
| 112 | begin
 | 
|---|
| 113 |   RPCEntry := TRpcLogEntry(RpcLogListBox.Items.Objects[RpcLogListBox.ItemIndex]);
 | 
|---|
| 114 |   Edit2.Text := RPCEntry.CreateClipBoardString;
 | 
|---|
| 115 |   Edit2.SelectAll;
 | 
|---|
| 116 |   Edit2.CopyToClipBoard;
 | 
|---|
| 117 | end;
 | 
|---|
| 118 |     
 | 
|---|
| 119 | 
 | 
|---|
| 120 | 
 | 
|---|
| 121 | //    private void rpcLogListBox_SelectedIndexChanged(object sender, System.EventArgs e)
 | 
|---|
| 122 | 
 | 
|---|
| 123 | procedure TfrmRpcClientLogger.DisplayRpcEntry(entry: TRpcLogEntry);
 | 
|---|
| 124 | var
 | 
|---|
| 125 |   Str : String;
 | 
|---|
| 126 | begin
 | 
|---|
| 127 |   Str := entry.CreateParamsDisplayString; //.Split('\n');
 | 
|---|
| 128 |   ParamsMemoBox.Lines.Clear;
 | 
|---|
| 129 |   ParamsMemoBox.Lines.Add(Str);
 | 
|---|
| 130 | 
 | 
|---|
| 131 |   resultsMemoBox.Text      := entry.CreateResultsDisplayString();
 | 
|---|
| 132 |   edtRpcName.Text      := entry.Name;
 | 
|---|
| 133 |   edtRPCDebugId.Text    := IntToStr(entry.UniqueId);
 | 
|---|
| 134 |   edtContext.Text      := entry.Context;
 | 
|---|
| 135 |   if(entry.Duration < 1) then
 | 
|---|
| 136 |     edtDuration1.Text := '<1ms'
 | 
|---|
| 137 |   else
 | 
|---|
| 138 |     edtDuration1.Text := IntToStr(entry.Duration) + ' ms';
 | 
|---|
| 139 |   edtClientName.Text    := entry.ClientName;
 | 
|---|
| 140 |   edtClientDebugId.Text  := IntToStr(entry.UniqueClientId);
 | 
|---|
| 141 | end;
 | 
|---|
| 142 | 
 | 
|---|
| 143 | {
 | 
|---|
| 144 | procedure TfrmRpcClientLogger.FormClose(Sender: TObject;
 | 
|---|
| 145 |   var Action: TCloseAction);
 | 
|---|
| 146 | begin
 | 
|---|
| 147 |       OnRpcLoggerClose(Self,nil);
 | 
|---|
| 148 | end;
 | 
|---|
| 149 | 
 | 
|---|
| 150 | procedure TfrmRpcClientLogger.UpDown1Click(Sender: TObject;
 | 
|---|
| 151 |   Button: TUDBtnType);
 | 
|---|
| 152 | begin
 | 
|---|
| 153 |       // In case the max entry value is less than the rpc log entries delete the entries
 | 
|---|
| 154 |       while (StrToInt(maxRpcLogEntriesNumericUpDown.Text) < rpcLogListBox.Items.Count)
 | 
|---|
| 155 |         rpcLogListBox.Items.Delete(0);
 | 
|---|
| 156 | end;
 | 
|---|
| 157 | 
 | 
|---|
| 158 | procedure TfrmRpcClientLogger.mnuEditCopyToClipboardClick(Sender: TObject);
 | 
|---|
| 159 | var
 | 
|---|
| 160 |   Clip: TClipBoard;
 | 
|---|
| 161 | begin
 | 
|---|
| 162 |       // Build a string and put it on the clipboard here.
 | 
|---|
| 163 | //      Clipboard.SetDataObject(((RpcLogEntry)rpcLogListBox.SelectedItem).CreateClipboardString());
 | 
|---|
| 164 |   Clip ::= ClipBoard;
 | 
|---|
| 165 |   Clip.SetTextBuf(PChar((RpcLogEntry)(rpcLogListBox.Items[rpcLogListBox.ItemIndex]).CreateClipboardString));
 | 
|---|
| 166 | end;
 | 
|---|
| 167 | 
 | 
|---|
| 168 | procedure TfrmRpcClientLogger.rpcLogListBoxClick(Sender: TObject);
 | 
|---|
| 169 | begin
 | 
|---|
| 170 |   DisplayRpcEntry((RpcLogEntry)rpcLogListBox.Items[rpcLogListBox.SelectedIndex]);
 | 
|---|
| 171 |   mnuEditCopyToClipboard.Enabled := True;
 | 
|---|
| 172 | end;
 | 
|---|
| 173 | 
 | 
|---|
| 174 | procedure TfrmRpcClientLogger.mnuPopupCopyToClipboardClick(
 | 
|---|
| 175 |   Sender: TObject);
 | 
|---|
| 176 | begin
 | 
|---|
| 177 |   mnuEditCopyToClipboardClick(Sender);
 | 
|---|
| 178 | end;
 | 
|---|
| 179 | }
 | 
|---|
| 180 | procedure TfrmRpcClientLogger.mnuFileCloseClick(Sender: TObject);
 | 
|---|
| 181 | begin
 | 
|---|
| 182 |   Self.Visible := False;
 | 
|---|
| 183 | end;
 | 
|---|
| 184 | 
 | 
|---|
| 185 | procedure TfrmRpcClientLogger.btnCloseClick(Sender: TObject);
 | 
|---|
| 186 | begin
 | 
|---|
| 187 |   Self.Visible := False;
 | 
|---|
| 188 | end;
 | 
|---|
| 189 | 
 | 
|---|
| 190 | end.
 | 
|---|