6 Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
7 ComCtrls, ToolWin, StdCtrls, ExtCtrls, SsParser, BottleDef, Menus,
8 Clipbrd, Logs, ShellAPI, Commctrl, DirectSstp, Contnrs, StrUtils,
9 TalkShowFrame, SppList, HtmlOutputConfig, HtmlOutputProgress,
10 SearchLog, IniFiles, BRegExp, RegexUtils;
13 //
\83\8d\83O
\82Ì
\95Û
\91¶
\95û
\96@
14 TSaveLogType = (stLog, stLogWithChannels, stText, stXML);
16 //
\83\8a\83X
\83g
\83r
\83\85\81[
\82Ì
\83X
\83N
\83\8d\81[
\83\8b\95û
\8cü
17 TLVScrollDir = (lvScrollUp, lvScrollDown);
19 TfrmLog = class(TForm)
21 tbtnClear: TToolButton;
24 StatusBar: TStatusBar;
25 tbtnSaveLog: TToolButton;
26 PopupMenuPreview: TPopupMenu;
28 tbtnVoteMessage: TToolButton;
29 PopupMenuListView: TPopupMenu;
30 mnPopUpVoteMessage: TMenuItem;
31 SaveDialog: TSaveDialog;
34 mnPopUpCopyScript: TMenuItem;
35 PopupMenuSaveLog: TPopupMenu;
37 mnSaveLogChannel: TMenuItem;
38 mnSaveLogScript: TMenuItem;
39 mnSaveLogXML: TMenuItem;
40 ToolButton1: TToolButton;
42 mnPopUpAgreeMessage: TMenuItem;
43 tbtnAgreeMessage: TToolButton;
44 ToolButton2: TToolButton;
45 tbtnPreviewStyle: TToolButton;
46 PopupMenuPreviewStyle: TPopupMenu;
47 mnPreviewStyleConversation: TMenuItem;
48 mnPreviewStyleScript: TMenuItem;
49 mnPreviewStyleScriptWithLineBreak: TMenuItem;
51 tabBottleLog: TTabControl;
53 tbtnDownloadLog: TToolButton;
54 PopupMenuTab: TPopupMenu;
55 mnCloseTab: TMenuItem;
56 tbtnFindBottle: TToolButton;
57 tbtnOpenLog: TToolButton;
58 OpenDialog: TOpenDialog;
59 tbtnInsertCue: TToolButton;
60 mnInsertCue: TMenuItem;
61 PopupMenuListPreviewStyle: TPopupMenu;
62 mnListPreviewStyleNormal: TMenuItem;
63 mnListPreviewStyleTagStripped: TMenuItem;
64 tbtnListPreviewStyle: TToolButton;
65 mnListPreviewStyleNoColor: TMenuItem;
66 SsParserForTalkShow: TSsParser;
67 mnPreviewStyleConversationImage: TMenuItem;
68 pnlPreviewArea: TPanel;
69 TalkShowFrame: TfrmTalkShow;
71 tbtnSendEditor: TToolButton;
72 mnSendEditor: TMenuItem;
73 timScrollTimer: TTimer;
74 mnChangeTabName: TMenuItem;
77 mnDeleteLogItem: TMenuItem;
78 mnTabSaveXMLLog: TMenuItem;
79 mnSaveHTML: TMenuItem;
80 mnPopupCopyGhost: TMenuItem;
81 procedure tbtnClearClick(Sender: TObject);
82 procedure FormCreate(Sender: TObject);
83 procedure lvwLogChange(Sender: TObject; Item: TListItem;
85 procedure lvwLogDblClick(Sender: TObject);
86 procedure lvwLogKeyPress(Sender: TObject; var Key: Char);
87 procedure FormDestroy(Sender: TObject);
88 procedure lvwLogClick(Sender: TObject);
89 procedure mnSaveLogClick(Sender: TObject);
90 procedure lvwLogColumnClick(Sender: TObject; Column: TListColumn);
91 procedure mnPopUpCopyScriptClick(Sender: TObject);
92 procedure mnSaveLogChannelClick(Sender: TObject);
93 procedure mnSaveLogScriptClick(Sender: TObject);
94 procedure mnSaveLogXMLClick(Sender: TObject);
95 procedure lvwLogData(Sender: TObject; Item: TListItem);
96 procedure PopupMenuListViewPopup(Sender: TObject);
97 procedure lvwLogCustomDrawItem(Sender: TCustomListView;
98 Item: TListItem; State: TCustomDrawState; var DefaultDraw: Boolean);
99 procedure PopupMenuPreviewStylePopup(Sender: TObject);
100 procedure mnPreviewStyleClick(Sender: TObject);
101 procedure tbtnPreviewStyleClick(Sender: TObject);
102 procedure tabBottleLogChange(Sender: TObject);
103 procedure tabBottleLogChanging(Sender: TObject;
104 var AllowChange: Boolean);
105 procedure tabBottleLogContextPopup(Sender: TObject; MousePos: TPoint;
106 var Handled: Boolean);
107 procedure mnCloseTabClick(Sender: TObject);
108 procedure tbtnFindBottleClick(Sender: TObject);
109 procedure tbtnOpenLogClick(Sender: TObject);
110 procedure tabBottleLogMouseDown(Sender: TObject; Button: TMouseButton;
111 Shift: TShiftState; X, Y: Integer);
112 procedure tabBottleLogDragOver(Sender, Source: TObject; X, Y: Integer;
113 State: TDragState; var Accept: Boolean);
114 procedure tabBottleLogDragDrop(Sender, Source: TObject; X, Y: Integer);
115 procedure tabBottleLogEndDrag(Sender, Target: TObject; X, Y: Integer);
116 procedure lvwLogDrawItem(Sender: TCustomListView; Item: TListItem;
117 Rect: TRect; State: TOwnerDrawState);
118 procedure mnListPreviewStyleClick(Sender: TObject);
119 procedure tbtnListPreviewStyleClick(Sender: TObject);
120 procedure PopupMenuListPreviewStylePopup(Sender: TObject);
121 procedure lvwLogDragOver(Sender, Source: TObject; X, Y: Integer;
122 State: TDragState; var Accept: Boolean);
123 procedure lvwLogDragDrop(Sender, Source: TObject; X, Y: Integer);
124 procedure timScrollTimerTimer(Sender: TObject);
125 procedure mnChangeTabNameClick(Sender: TObject);
126 procedure lvwLogStartDrag(Sender: TObject;
127 var DragObject: TDragObject);
128 procedure lvwLogEndDrag(Sender, Target: TObject; X, Y: Integer);
129 procedure mnTabSaveXMLLogClick(Sender: TObject);
130 procedure mnSaveHTMLClick(Sender: TObject);
131 procedure mnPopupCopyGhostClick(Sender: TObject);
134 FLastScript: String; //
\83X
\83N
\83\8a\83v
\83g
\8dÄ
\95`
\89æ
\97}
\90§
\97p
135 FBottleLogList: TObjectList;
137 FDragTabIndex: integer; //
\83^
\83u
\83h
\83\89\83b
\83O
\83h
\83\8d\83b
\83v
\8aÖ
\98A
138 FDragTabDest: integer; //
\83h
\83\8d\83b
\83v
\82·
\82é
\88Ê
\92u(
\82·
\82®
\89E
\82É
\82
\82é
\83^
\83u
\82Ì
\83C
\83\93\83f
\83b
\83N
\83X)
140 //
\83\8a\83X
\83g
\83r
\83\85\81[
\83h
\83\89\83b
\83O
\83h
\83\8d\83b
\83v
\8aÖ
\98A
141 FLVScrollDir: TLVScrollDir; //
\83X
\83N
\83\8d\81[
\83\8b\95û
\8cü
142 FLVDragDest: integer; //
\83h
\83\8d\83b
\83v
\82·
\82é
\88Ê
\92u(
\82·
\82®
\89º
\82É
\82
\82é
\83A
\83C
\83e
\83\80\82ÌIndex)
144 procedure UpdateScript(const Script: String);
145 procedure UpdateScriptConversationColor(const Script: String);
146 procedure UpdateScriptScript(const Script: String);
147 procedure mnURLClick(Sender: TObject);
148 procedure ExtractURLs(Script: String; Result: TStrings);
149 function GetDefaultFileName(const Name: String; const Ext: String): String;
150 function BottleLogTitled(const LogName: String): TBottleLogList;
151 procedure DrawSingleLineScript(LogItem: TLogItem; Rect: TRect;
153 procedure PreviewStyleChange;
154 procedure DrawListViewDragBorder(const Rect: TRect);
155 procedure DoSaveLogXML(Log: TBottleLogList);
156 procedure DoCloseTab(const Index: integer);
157 function DoSearchLog(Condition: TSearchCond): TBottleLogList;
158 procedure SearchLogIndivisual(Condition: TSearchCond;
159 LogList, Result: TBottleLogList; UntilIndex: integer = -1);
161 procedure CreateParams(var Params: TCreateParams); override;
164 function SelectedBottleLog: TBottleLogList;
165 property BottleLogList: TObjectList read FBottleLogList;
166 procedure AddCurrentScriptLog(const LogName, Script, Channel, MID, Ghost: String;
167 const LogTime: TDateTime; const Vote, Agree: integer);
168 procedure AddCurrentSystemLog(const LogName, MessageString: String);
169 procedure VoteLog(const MID: String; const Vote: integer);
170 procedure AgreeLog(const MID: String; const Agree: integer);
171 procedure SetBottleState(const MID: String; State: TLogState);
172 procedure AllBottleOpened;
173 procedure LogLoaded(Sender: TObject);
174 procedure LogLoadFailure(Sender: TObject; const Message: String);
175 procedure LogLoadWork(Sender: TObject);
176 procedure HTMLOutputWork(Sender: TObject; const Count: integer;
177 var Canceled: boolean);
179 procedure UpdateWindow;
180 procedure SelAndFocusMessage(const MID: String);
183 TBottleLogDragObject = class(TDragControlObjectEx)
185 FBottleLogList: TBottleLogList;
187 procedure SetBottleLogList(const Value: TBottleLogList);
188 procedure SetLogItem(const Value: TLogItem);
190 function GetDragImages: TDragImageList; override;
192 property BottleLogList: TBottleLogList read FBottleLogList write SetBottleLogList;
193 property LogItem: TLogItem read FLogItem write SetLogItem;
219 procedure TfrmLog.AddCurrentScriptLog(const LogName, Script, Channel, MID, Ghost: String;
220 const LogTime: TDateTime; const Vote, Agree: integer);
223 BottleLogTitled(LogName).AddScriptLog(Script, Channel, MID, Ghost, LogTime, Vote, Agree);
224 if SelectedBottleLog <> BottleLogTitled(LogName) then Exit;
225 lvwLog.OnChange := nil; //
\83C
\83x
\83\93\83g
\94
\90¶(
\82¢
\82ë
\82¢
\82ë
\8dÄ
\95`
\89æ
\82ª
\8bN
\82«
\82é)
\82Ì
\97}
\90§
226 if lvwLog.Selected <> nil then Sel := lvwLog.Selected.Index else Sel := -1;
227 lvwLog.Items.Count := SelectedBottleLog.Count;
229 if Sel >= 0 then begin
230 lvwLog.Selected := lvwLog.Items[Sel + 1];
231 lvwLog.Selected.Focused := true;
233 if not lvwLog.Focused then
234 ListView_Scroll(lvwLog.Handle, 0, High(integer));
235 lvwLog.OnChange := lvwLogChange;
238 procedure TfrmLog.AddCurrentSystemLog(const LogName, MessageString: String);
241 BottleLogTitled(LogName).AddSystemLog(MessageString);
242 if SelectedBottleLog <> BottleLogTitled(LogName) then Exit;
243 lvwLog.OnChange := nil;
244 if lvwLog.Selected <> nil then Sel := lvwLog.Selected.Index else Sel := -1;
245 lvwLog.Items.Count := SelectedBottleLog.Count;
247 if Sel >= 0 then begin
248 lvwLog.Selected := lvwLog.Items[Sel + 1];
249 lvwLog.Selected.Focused := true;
251 if not lvwLog.Focused then
252 ListView_Scroll(lvwLog.Handle, 0, High(integer));
253 lvwLog.OnChange := lvwLogChange;
258 procedure TfrmLog.tbtnClearClick(Sender: TObject);
260 if SelectedBottleLog = nil then Exit;
261 DoCloseTab(tabBottleLog.TabIndex);
264 procedure TfrmLog.FormCreate(Sender: TObject);
267 FLVDragDest := -1; //
\83\8a\83X
\83g
\83r
\83\85\81[
\82Ì
\83h
\83\89\83b
\83O
\92\86\82Å
\82Í
\82È
\82¢
268 FBottleLogList := TObjectList.Create;
270 SsParser.TagPattern.Assign(frmSender.SsParser.TagPattern);
271 SsParser.MetaPattern.Assign(frmSender.SsParser.MetaPattern);
273 with Pref.LogWindowPosition do begin
276 Self.Width := Right - Left + 1;
277 Self.Height := Bottom - Top + 1;
279 lvwLog.DoubleBuffered := true;
280 pnlPreviewArea.Height := Pref.LogWindowDividerPos;
283 while Token(Pref.LogWindowColumnWidth, ',', i) <> '' do begin
284 lvwLog.Columns[i].Width := StrToIntDef(Token(Pref.LogWindowColumnWidth, ',', i), 100);
288 SsParserForTalkShow.TagPattern.Assign(SsParser.TagPattern);
289 SsParserForTalkShow.MetaPattern.Assign(SsParser.MetaPattern);
290 SsParserForTalkShow.EscapeInvalidMeta := false;
291 SsParserForTalkShow.LeaveEscape := false;
292 TalkShowFrame.SsParser := self.SsParserForTalkShow;
294 TalkShowFrame.SetPreviewFont(edtScript.Font);
295 TalkShowFrame.PrevControl := lvwLog;
298 UpdateWindow; // Reset window color and enabled status of some buttons
301 procedure TfrmLog.FormDestroy(Sender: TObject);
306 for i := 0 to lvwLog.Columns.Count-1 do begin
307 if i > 0 then WidthStr := WidthStr + ',';
308 WidthStr := WidthStr + IntToStr(lvwLog.Column[i].Width);
310 Pref.LogWindowColumnWidth := WidthStr;
312 with Pref.LogWindowPosition do begin
315 Right := Self.Left + Self.Width - 1;
316 Bottom := Self.Top + Self.Height - 1;
318 Pref.LogWindowDividerPos := pnlPreviewArea.Height;
320 FreeAndNil(FBottleLogList);
323 procedure TfrmLog.lvwLogChange(Sender: TObject; Item: TListItem;
324 Change: TItemChange);
325 var Script, Text: String;
327 Selected, IsNormalBottle: boolean;
330 IsNormalBottle := false;
331 if SelectedBottleLog <> nil then begin
332 if Change = ctState then begin
334 if lvwLog.Selected <> nil then begin
336 StatusBar.Panels[0].Text := Format('%d/%d
\8c\8f', [lvwLog.Selected.Index+1,
337 SelectedBottleLog.Count]);
338 Log := SelectedBottleLog.Bottles[lvwLog.Selected.Index];
339 // if (Log.LogType = ltBottle) and not frmSender.Connecting then begin
340 if Log.LogType = ltBottle then begin
341 IsNormalBottle := true;
342 Script := Log.Script;
343 Text := Format('%d
\83o
\83C
\83g/%d
\95b -
\83_
\83u
\83\8b\83N
\83\8a\83b
\83N
\82Å
\8dÄ
\90¶',
344 [Length(Log.Script), frmSender.SsPlayTime.PlayTime(Log.Script) div 1000]);
345 StatusBar.Panels[1].Text := Text;
346 if Pref.LogWindowPreviewStyle = psImageConversation then
347 TalkShowFrame.View(Log)
349 UpdateScript(Script);
351 StatusBar.Panels[1].Text := '';
352 UpdateScript(''); //
\83\8d\83O
\83v
\83\8c\83r
\83\85\81[
\95\94\82ð
\83N
\83\8a\83A
355 StatusBar.Panels[0].Text := IntToStr(SelectedBottleLog.Count) + '
\8c\8f';
356 StatusBar.Panels[1].Text := '';
357 UpdateScript(Script); //
\83\8d\83O
\83v
\83\8c\83r
\83\85\81[
\95\94\83N
\83\8a\83A
360 tbtnSaveLog.Enabled := lvwLog.Items.Count > 0;
362 StatusBar.Panels[0].Text := '';
363 UpdateScript(''); //
\83\8d\83O
\83v
\83\8c\83r
\83\85\81[
\95\94\83N
\83\8a\83A
365 frmSender.actVoteMessage.Enabled := Selected and IsNormalBottle;
366 frmSender.actAgreeMessage.Enabled := Selected and IsNormalBottle;
367 frmSender.actSendToEditor.Enabled := Selected and IsNormalBottle;
368 frmSender.actInsertCue.Enabled := Selected;
369 frmSender.actDeleteLogItem.Enabled := Selected;
370 mnPopUpCopyScript.Enabled := Selected and IsNormalBottle;
371 mnPopupCopyGhost.Enabled := Selected and IsNormalBottle;
374 procedure TfrmLog.lvwLogDblClick(Sender: TObject);
375 var Script, ErrorMes: String;
376 Log, CueItem: TLogItem;
379 if lvwLog.Selected = nil then
381 Log := SelectedBottleLog.Bottles[lvwLog.Selected.Index];
382 if Log = nil then Exit;
383 if Log.LogType <> ltBottle then
385 Script := frmSender.ScriptTransForSSTP(Log.Script, ErrorMes);
386 if ErrorMes <> '' then
388 Res := MessageDlg('
\96â
\91è
\82Ì
\82 \82é
\83X
\83N
\83\8a\83v
\83g
\82Å
\82·
\81B
\8dÄ
\90¶
\82Å
\82«
\82Ü
\82¹
\82ñ
\81B'#13#10+
390 '
\8b
\90§
\93I
\82É
\8dÄ
\90¶
\82µ
\82Ü
\82·
\82©?'#13#10,
391 mtWarning, mbOkCancel, 0
393 if Res = mrCancel then
397 CueItem := TLogItem.Create(Log);
399 CueItem.Script := Script;
400 frmSender.BottleSstp.Unshift(CueItem);
406 procedure TfrmLog.UpdateScriptConversationColor(const Script: String);
409 UnyuTalking, Talked, InSynchronized: boolean;
412 frmSender.DoTrans(scr, [toConvertURL]);
413 SsParser.LeaveEscape := false;
414 SsParser.InputString := scr;
415 UnyuTalking := false;
416 Talked := false; //'\h\u\h\u'
\82Ì
\82æ
\82¤
\82È
\83X
\83N
\83\8a\83v
\83g
\82Å
\8bó
\82«
\8ds
\82ð
\8dì
\82ç
\82È
\82¢
\82½
\82ß
\82Ì
\91[
\92u
417 InSynchronized := false;
418 edtScript.Text := '';
419 edtScript.Color := Pref.BgColor;
420 for i := 0 to SsParser.Count-1 do begin
421 if (SsParser[i] = '\_s') and not InSynchronized then begin
422 InSynchronized := true;
424 edtScript.SelText := #13#10;
427 end else if (SsParser[i] = '\_s') and InSynchronized then begin
428 InSynchronized := false;
430 edtScript.SelText := #13#10;
434 if (SsParser[i] = '\u') and not UnyuTalking then begin
437 edtScript.SelText := #13#10;
441 if (SsParser[i] = '\h') and UnyuTalking then begin
442 UnyuTalking := false;
444 edtScript.SelText := #13#10;
448 if SsParser.MarkUpType[i] = mtStr then begin
449 if InSynchronized then
450 edtScript.SelAttributes.Color := Pref.TalkColorS
451 else if UnyuTalking then
452 edtScript.SelAttributes.Color := Pref.TalkColorU
454 edtScript.SelAttributes.Color := Pref.TalkColorH;
455 edtScript.SelText := SsParser[i];
458 if SsParser.MarkUpType[i] = mtMeta then begin
459 edtScript.SelAttributes.Color := Pref.MetaWordColor;
460 edtScript.SelText := SsParser[i];
466 procedure TfrmLog.lvwLogKeyPress(Sender: TObject; var Key: Char);
468 if Key = #13 then lvwLogDblClick(Sender);
471 procedure TfrmLog.CreateParams(var Params: TCreateParams);
474 Params.ExStyle := Params.ExStyle or WS_EX_APPWINDOW;
477 procedure TfrmLog.lvwLogClick(Sender: TObject);
479 //
\89E
\83N
\83\8a\83b
\83N
\82Å
\83\81\83j
\83\85\81[
\8fo
\82·
\82Æ
\82«
\82É
\94
\90¶
\82·
\82é
\95s
\8bï
\8d\87\91Î
\8dô
481 Selected := Selected;
484 procedure TfrmLog.lvwLogColumnClick(Sender: TObject; Column: TListColumn);
485 var SortType: TBottleLogSortType;
489 if SelectedBottleLog = nil then
491 if lvwLog.Selected <> nil then
492 SelectedMID := SelectedBottleLog.Bottles[lvwLog.Selected.Index].MID
496 SortColumn := Column.Index;
498 -1: SortType := stLogTime;
499 subChannel: SortType := stChannel;
500 subGhost: SortType := stGhost;
501 subVotes: SortType := stVote;
502 subAgrees: SortType := stAgree;
503 subScript: SortType := stScript;
505 SortType := stLogTime;
508 SelectedBottleLog.SortBottles(SortType);
510 if Length(SelectedMID) > 0 then
511 SelAndFocusMessage(SelectedMID);
515 procedure TfrmLog.mnPopUpCopyScriptClick(Sender: TObject);
520 Log := SelectedBottleLog.Bottles[frmLog.lvwLog.Selected.Index];
521 if Log = nil then Exit;
523 Clip.SetTextBuf(PChar(Log.Script));
526 procedure TfrmLog.SetBottleState(const MID: String; State: TLogState);
530 for i := 0 to FBottleLogList.Count-1 do begin
531 Bottle := (FBottleLogList[i] as TBottleLogList).Bottle(MID);
532 if Bottle <> nil then begin
533 Bottle.State := State;
534 lvwLog.OnChange := nil;
536 lvwLog.OnChange := lvwLogChange;
541 procedure TfrmLog.mnSaveLogClick(Sender: TObject);
543 if SelectedBottleLog = nil then Exit;
544 SaveDialog.FileName := GetDefaultFileName(SelectedBottleLog.Title, '.log');
545 SaveDialog.InitialDir := ExtractFileDir(Application.ExeName);
546 SaveDialog.DefaultExt := 'log';
547 SaveDialog.FilterIndex := 1;
548 if SaveDialog.Execute then
549 SelectedBottleLog.SaveToSstpLog(SaveDialog.FileName, false);
552 procedure TfrmLog.mnSaveLogChannelClick(Sender: TObject);
554 if SelectedBottleLog = nil then Exit;
555 SaveDialog.FileName := GetDefaultFileName(SelectedBottleLog.Title, '.log');
556 SaveDialog.InitialDir := ExtractFileDir(Application.ExeName);
557 SaveDialog.DefaultExt := 'log';
558 SaveDialog.FilterIndex := 1;
559 if SaveDialog.Execute then
560 SelectedBottleLog.SaveToSstpLog(SaveDialog.FileName, true);
563 procedure TfrmLog.mnSaveLogScriptClick(Sender: TObject);
565 if SelectedBottleLog = nil then Exit;
566 SaveDialog.FileName := GetDefaultFileName(SelectedBottleLog.Title, '.txt');
567 SaveDialog.InitialDir := ExtractFileDir(Application.ExeName);
568 SaveDialog.DefaultExt := 'txt';
569 SaveDialog.FilterIndex := 2;
570 if SaveDialog.Execute then
571 SelectedBottleLog.SaveToText(SaveDialog.FileName);
574 procedure TfrmLog.mnSaveLogXMLClick(Sender: TObject);
576 if SelectedBottleLog = nil then Exit;
577 DoSaveLogXML(SelectedBottleLog);
580 procedure TfrmLog.lvwLogData(Sender: TObject; Item: TListItem);
584 if Item = nil then Exit;
586 Log := SelectedBottleLog.Bottles[i];
588 Caption := FormatDateTime('yy/mm/dd hh:nn:ss', Log.LogTime);
590 SubItems.Add(Log.Channel);
591 SubItems.Add(Log.Ghost);
592 if Log.LogType = ltBottle then begin
593 if Log.Votes > 0 then
594 SubItems.Add(IntToStr(Log.Votes))
597 if Log.Agrees > 0 then
598 SubItems.Add(IntToStr(Log.Agrees))
602 //
\83V
\83X
\83e
\83\80\83\8d\83O
\82È
\82Ç
\82Í
\93\8a\95[
\81E
\93¯
\88Ó
\82ð
\95\
\8e¦
\82µ
\82È
\82¢
606 SubItems.Add(Log.Script);
608 if Log.LogType = ltBottle then begin
610 lsUnopened: ImageIndex := IconBottle;
611 lsPlaying: ImageIndex := IconPlaying;
612 lsOpened: ImageIndex := IconOpened;
615 ImageIndex := IconSystemLog;
619 procedure TfrmLog.UpdateWindow;
620 var EnabledFlag: boolean;
622 lvwLog.Color := Pref.BgColor;
623 lvwLog.Font.Color := Pref.TextColor;
624 if SelectedBottleLog <> nil then begin
625 Caption := '
\83\8d\83O - ' + SelectedBottleLog.Title;
626 StatusBar.Panels[0].Text := IntToStr(SelectedBottleLog.Count) + '
\8c\8f';
627 lvwLog.Items.Count := SelectedBottleLog.Count;
629 Caption := '
\83\8d\83O';
630 StatusBar.Panels[0].Text := '';
631 StatusBar.Panels[1].Text := '';
632 lvwLog.Items.Count := 0;
635 EnabledFlag := SelectedBottleLog <> nil;
636 tbtnClear.Enabled := EnabledFlag;
637 tbtnSaveLog.Enabled := EnabledFlag;
638 tbtnFindBottle.Enabled := EnabledFlag;
643 procedure TfrmLog.PopupMenuListViewPopup(Sender: TObject);
649 for i := mnJumpURL.Count-1 downto 0 do begin
650 mnJumpURL.Items[i].Free;
652 mnJumpURL.Enabled := false;
653 if lvwLog.Selected = nil then Exit;
654 Log := SelectedBottleLog.Bottles[lvwLog.Selected.Index];
655 if Log = nil then Exit;
656 Urls := TStringList.Create;
658 ExtractURLs(Log.Script, Urls);
659 for i := 0 to Urls.Count-1 do begin
660 Child := TMenuItem.Create(Self);
662 Caption := Format('(&%d) %s', [i+1, StringReplace(Urls[i], '&', '&&', [rfReplaceAll])]);
664 OnClick := mnURLClick;
665 AutoHotkeys := maManual;
666 mnJumpURL.Add(Child);
669 mnJumpURL.Enabled := Urls.Count > 0;
675 procedure TfrmLog.mnURLClick(Sender: TObject);
676 var LogItem: TLogItem;
682 if (lvwLog.Selected = nil) or (SelectedBottleLog = nil) then Exit;
683 LogItem := SelectedBottleLog[lvwLog.Selected.Index] as TLogItem;
684 Urls := TStringList.Create;
686 ExtractURLs(LogItem.Script, Urls);
687 URL := Urls[(Sender as TMenuItem).Tag];
688 if Pref.BrowserExeName='' then
690 ShellExecute(Handle, 'open', PChar(URL), nil, nil, SW_SHOW);
693 Command := Pref.BrowserExeName+' '+URL;
694 WinExec(PChar(Command), SW_SHOW);
702 procedure TfrmLog.ExtractURLs(Script: String; Result: TStrings);
703 var i, u, j: integer;
707 SsParser.InputString := Script;
708 SsParser.LeaveEscape := true;
709 for i := 0 to SsParser.Count-1 do begin
710 if (SsParser.Match(SsParser[i], '\URL%b') > 0)
711 and (SsParser.MarkUpType[i] = mtTag) then
713 for u := 7 downto 1 do begin
714 if (SsParser.Match(SsParser[i],
715 '\URL%b'+StringReplace(StringOfChar('-', u*2),
716 '-', '%b', [rfReplaceAll]))) > 0 then begin
717 for j := 1 to u do begin
718 s := SsParser.GetParam(SsParser[i], j*2);
719 if Pos('http://', s) > 0 then Result.Add(s);
724 if SsParser.Match(SsParser[i], '\URL%b%b') = 0 then begin //
\8aÈ
\88Õ
\94ÅURL
\95Ï
\8a·
725 //
\8aÈ
\88Õ
\8c`
\8e®\URL
\83^
\83O
\95Ï
\8a·
726 s := SsParser.GetParam(SsParser[i], 1);
727 if Pos('http://', s) > 0 then Result.Add(s);
733 procedure TfrmLog.SelAndFocusMessage(const MID: String);
737 for i := 0 to SelectedBottleLog.Count-1 do begin
738 Log := SelectedBottleLog.Items[i] as TLogItem;
739 if Log.MID = MID then begin
740 lvwLog.Items[i].Selected := true;
741 lvwLog.Items[i].Focused := true;
746 procedure TfrmLog.lvwLogCustomDrawItem(Sender: TCustomListView;
747 Item: TListItem; State: TCustomDrawState; var DefaultDraw: Boolean);
752 procedure TfrmLog.UpdateScript(const Script: String);
754 if Script <> FLastScript then begin
755 if Pref.LogWindowPreviewStyle = psConversation then begin
756 UpdateScriptConversationColor(Script);
758 UpdateScriptScript(Script);
760 SendMessage(edtScript.Handle, EM_LINESCROLL, Low(integer), Low(integer)); //
\83X
\83N
\83\8d\81[
\83\8b\96ß
\82µ
761 FLastScript := Script;
765 procedure TfrmLog.PopupMenuPreviewStylePopup(Sender: TObject);
768 with PopupMenuPreviewStyle do
769 for i := 0 to Items.Count-1 do
770 Items[i].Checked := Items[i].Tag = Ord(Pref.LogWindowPreviewStyle)
773 procedure TfrmLog.mnPreviewStyleClick(Sender: TObject);
776 with PopupMenuPreviewStyle do
777 for i := 0 to Items.Count-1 do
778 Items[i].Checked := (Sender as TMenuItem).Tag = Items[i].Tag;
779 Pref.LogWindowPreviewStyle := TLogWindowPreviewStyle((Sender as TMenuItem).Tag);
782 lvwLogChange(self, lvwLog.Selected, ctState);
785 procedure TfrmLog.UpdateScriptScript(const Script: String);
787 UnyuTalking, InSynchronized: boolean;
790 edtScript.Color := Pref.BgColor;
791 SsParser.LeaveEscape := true;
792 SsParser.InputString := Script;
793 edtScript.Text := '';
794 edtScript.SelAttributes.Color := clWindowText;
795 UnyuTalking := false;
796 InSynchronized := false;
797 for i := 0 to SsParser.Count-1 do begin
798 case SsParser.MarkUpType[i] of
800 if InSynchronized then
801 edtScript.SelAttributes.Color := Pref.TalkColorS
802 else if UnyuTalking then
803 edtScript.SelAttributes.Color := Pref.TalkColorU
805 edtScript.SelAttributes.Color := Pref.TalkColorH;
808 edtScript.SelAttributes.Color := Pref.MarkUpColor;
809 if SsParser[i] = '\h' then
811 else if SsParser[i] = '\u' then
813 else if SsParser[i] = '\_s' then
814 InSynchronized := not InSynchronized;
816 mtMeta: edtScript.SelAttributes.Color := Pref.MetaWordColor;
817 mtTagErr: edtScript.SelAttributes.Color := Pref.MarkErrorColor;
819 edtScript.SelText := SsParser[i];
820 if (SsParser[i] = '\n') and (Pref.LogWindowPreviewStyle = psScriptWithLineBreak) then
821 edtScript.SelText := #13#10;
825 procedure TfrmLog.tbtnPreviewStyleClick(Sender: TObject);
828 sel := Ord(Pref.LogWindowPreviewStyle);
830 if sel > Ord(High(TLogWindowPreviewStyle)) then sel := 0;
831 Pref.LogWindowPreviewStyle := TLogWindowPreviewStyle(sel);
834 lvwLogChange(self, lvwLog.Selected, ctState);
837 function TfrmLog.SelectedBottleLog: TBottleLogList;
839 if tabBottleLog.TabIndex >= 0 then
840 Result := FBottleLogList.Items[tabBottleLog.TabIndex] as TBottleLogList
845 procedure TfrmLog.tabBottleLogChange(Sender: TObject);
847 // StatusBar
\82Ì
\8c\8f\90\94\95\
\8e¦
\82âListView.Items.Count
\82ð
\8dX
\90V
\82·
\82é
849 //
\83A
\83C
\83e
\83\80\82Ì
\91I
\91ð
\8fó
\91Ô
\82ð
\95\9c\8bA
\82·
\82é
850 with SelectedBottleLog do
851 if (SelectedIndex >= 0) and (Count > SelectedIndex) then
853 lvwLog.Items[SelectedIndex].Selected := true;
854 if lvwLog.Focused then lvwLog.Selected.Focused := true;
856 lvwLogChange(Self, nil, ctState);
859 procedure TfrmLog.LogLoaded(Sender: TObject);
861 if SelectedBottleLog = Sender then begin
866 procedure TfrmLog.UpdateTab;
869 cur := tabBottleLog.tabIndex;
870 tabBottleLog.Tabs.Clear;
871 for i := 0 to FBottleLogList.Count - 1 do begin
872 tabBottleLog.Tabs.Add((FBottleLogList[i] as TBottleLogList).Title);
874 if FBottleLogList.Count > 0 then begin
875 if cur < FBottleLogList.Count then
876 tabBottleLog.TabIndex := cur
878 tabBottleLog.TabIndex := FBottleLogList.Count-1;
882 procedure TfrmLog.LogLoadFailure(Sender: TObject; const Message: String);
885 ShowMessage(Message);
886 if Sender = SelectedBottleLog then UpdateWindow;
889 procedure TfrmLog.AgreeLog(const MID: String; const Agree: integer);
894 for i := 0 to FBottleLogList.Count - 1 do begin
895 if (FBottleLogList[i] as TBottleLogList).Bottle(MID) <> nil then begin
896 (FBottleLogList[i] as TBottleLogList).Bottle(MID).Agrees := Agree;
900 if flag then lvwLog.Invalidate;
903 procedure TfrmLog.VoteLog(const MID: String; const Vote: integer);
908 for i := 0 to FBottleLogList.Count - 1 do begin
909 if (FBottleLogList[i] as TBottleLogList).Bottle(MID) <> nil then begin
910 (FBottleLogList[i] as TBottleLogList).Bottle(MID).Votes := Vote;
914 if flag then lvwLog.Invalidate;
917 procedure TfrmLog.tabBottleLogChanging(Sender: TObject;
918 var AllowChange: Boolean);
920 //
\8c»
\8dÝ
\91I
\91ð
\82³
\82ê
\82Ä
\82¢
\82é
\83\8d\83O
\82Ì
\91I
\91ð
\8fó
\91Ô
\82ð
\95Û
\91¶
921 if SelectedBottleLog = nil then Exit;
922 if lvwLog.Selected <> nil then
923 SelectedBottleLog.SelectedIndex := lvwLog.Selected.Index
925 SelectedBottleLog.SelectedIndex := -1;
928 procedure TfrmLog.tabBottleLogContextPopup(Sender: TObject;
929 MousePos: TPoint; var Handled: Boolean);
931 with tabBottleLog do begin
932 Tag := IndexOfTabAt(MousePos.X, MousePos.Y);
933 if Tag < 0 then Handled := true;
937 procedure TfrmLog.mnCloseTabClick(Sender: TObject);
939 DoCloseTab(tabBottleLog.Tag);
942 procedure TfrmLog.tbtnFindBottleClick(Sender: TObject);
943 var ResultLog: TBottleLogList;
946 CList, GList: THashedStringList;
948 Application.CreateForm(TfrmSearchLog, frmSearchLog);
949 Cond := TSearchCond.Create(nil);
954 //
\8c»
\8dÝ
\83\8d\83O
\82É
\82 \82é
\83S
\81[
\83X
\83g
\82Æ
\83`
\83\83\83\93\83l
\83\8b\82Ì
\83\8a\83X
\83g
\82ð
\8eæ
\93¾
955 //
\8fd
\82½
\82¢
\82©
\82à??
956 CList := THashedStringList.Create;
957 GList := THashedStringList.Create;
959 for i := 0 to BottleLogList.Count-1 do
961 with BottleLogList[i] as TBottleLogList do
963 ExtractUniqueChannels(CList);
964 ExtractUniqueGhosts(GList);
969 ChannelList := CList;
978 Cond.Assign(Condition);
981 frmSearchLog.Release;
983 //
\8c\9f\8dõ
\8eÀ
\8ds
984 ResultLog := DoSearchLog(Cond);
985 //
\90V
\83^
\83u
\82ð
\8dì
\90¬
\82µ
\82Ä
\89æ
\96Ê
\8dX
\90V
986 BottleLogList.Add(ResultLog);
988 tabBottleLog.TabIndex := BottleLogList.Count-1;
995 procedure TfrmLog.tbtnOpenLogClick(Sender: TObject);
996 var BottleLog: TBottleLogList;
1000 if OpenDialog.Execute then begin
1001 for i := 0 to OpenDialog.Files.Count-1 do begin
1002 BottleLog := TBottleLogList.Create(ExtractFileName(OpenDialog.Files[i]));
1006 OnLoaded := LogLoaded;
1007 OnLoadFailure := LogLoadFailure;
1008 OnLoadWork := LogLoadWork;
1009 BottleLog.LoadFromXMLFile(OpenDialog.Files[i]);
1011 Index := BottleLogList.Add(BottleLog); //
\8dÅ
\8cã
\82É
\8aJ
\82¢
\82½
\83\8d\83O
\82Ì
\88Ê
\92u
\82ð
\8bL
\89¯
1017 if Index >= 0 then tabBottleLog.TabIndex := Index;
1022 function TfrmLog.GetDefaultFileName(const Name, Ext: String): String;
1024 Result := StringReplace(Name, '/', '', [rfReplaceAll]);
1025 Result := StringReplace(Result, ' ', '', [rfReplaceAll]);
1026 Result := SafeFileName(Result);
1027 Result := ChangeFileExt(Result, Ext);
1030 function TfrmLog.BottleLogTitled(const LogName: String): TBottleLogList;
1033 for i := 0 to FBottleLogList.Count-1 do begin
1034 if (FBottleLogList[i] as TBottleLogList).Title = LogName then begin
1035 Result := (FBottleLogList[i] as TBottleLogList);
1039 //
\8c©
\82Â
\82©
\82ç
\82È
\82¢
\8fê
\8d\87
1040 Result := TBottleLogList.Create(LogName); //
\90V
\82µ
\82
\8dì
\82é
1041 FBottleLogList.Add(Result);
1043 if FBottleLogList.Count = 1 then tabBottleLog.TabIndex := 0;
1046 procedure TfrmLog.AllBottleOpened;
1048 Log: TBottleLogList;
1050 for i := 0 to FBottleLogList.Count-1 do begin
1051 Log := FBottleLogList[i] as TBottleLogList;
1052 for j := 0 to Log.Count-1 do begin
1053 Log.Bottles[j].State := lsOpened;
1058 procedure TfrmLog.tabBottleLogMouseDown(Sender: TObject;
1059 Button: TMouseButton; Shift: TShiftState; X, Y: Integer);
1062 with tabBottleLog do begin
1063 Index := IndexOfTabAt(X, Y);
1064 if Index = -1 then Exit; //
\83^
\83u
\82ª
\82È
\82¢
\82Ì
\82Å
\83h
\83\89\83b
\83O
\82Å
\82«
\82È
\82¢
1065 if Button = mbLeft then begin
1066 FDragTabIndex := Index; //
\83h
\83\89\83b
\83O
\82·
\82é
\83^
\83u
\82Ì
\83C
\83\93\83f
\83b
\83N
\83X
\82ð
\95Û
\91¶
1068 FDragTabDest := -1; //
\83h
\83\89\83b
\83O
\98g
\90ü
\95`
\89æ
\83t
\83\89\83O
\83N
\83\8a\83A
\82Ì
\82½
\82ß
1073 procedure TfrmLog.tabBottleLogDragOver(Sender, Source: TObject; X,
1074 Y: Integer; State: TDragState; var Accept: Boolean);
1075 var TargetRect: TRect;
1076 OldDest, Index: integer;
1079 //
\83^
\83u
\82Ì
\83h
\83\89\83b
\83O(
\83^
\83u
\82Ì
\8f\87\94Ô
\93ü
\82ê
\91Ö
\82¦)
\82Ü
\82½
\82Í
\81A
1080 //
\83\8d\83O
\83A
\83C
\83e
\83\80\82Ì
\83h
\83\89\83b
\83O(
\83\8d\83O
\82ð
\95Ê
\82Ì
\83^
\83u
\82É
\88Ú
\93®)
\82Ì
1081 //
\97¼
\95û
\82Ì
\83h
\83\89\83b
\83O
\82ð
\8eó
\82¯
\95t
\82¯
\82é
1083 if Source = tabBottleLog then
1085 //
\83^
\83u
\82Ì
\8f\87\94Ô
\93ü
\82ê
\91Ö
\82¦
\82Ì
\8fê
\8d\87
1087 with tabBottleLog do begin
1088 OldDest := FDragTabDest;
1089 FDragTabDest := IndexOfTabAt(X, Y);
1090 if FDragTabDest = -1 then begin
1091 Accept := false; //
\82±
\82Ì
\8fê
\8d\87\82Í
\83h
\83\8d\83b
\83v
\82ð
\94F
\82ß
\82È
\82¢
1094 with Canvas do begin
1098 if (OldDest <> FDragTabDest) and (OldDest >= 0) then begin
1099 //
\88È
\91O
\82Ì
\98g
\90ü
\8fÁ
\8b\8e
1100 TargetRect := TabRect(OldDest);
1101 with Canvas do begin
1102 Brush.Style := bsClear;
1103 Rectangle(TargetRect.Left, TargetRect.Top,
1104 TargetRect.Right, TargetRect.Bottom);
1107 if (OldDest <> FDragTabDest) then begin
1108 //
\90V
\82µ
\82¢
\98g
\90ü
\95`
\89æ
1109 TargetRect := TabRect(FDragTabDest);
1110 with Canvas do begin
1111 Brush.Style := bsClear;
1112 Rectangle(TargetRect.Left, TargetRect.Top,
1113 TargetRect.Right, TargetRect.Bottom);
1117 end else if Source is TBottleLogDragObject then
1119 //
\83\8d\83O
\8d\80\96Ú
\82Ì
\83h
\83\89\83b
\83O(
\83\8d\83O
\82ð
\95Ê
\82Ì
\83^
\83u
\82É
\88Ú
\93®
\82·
\82é)
\82Ì
\8fê
\8d\87
1120 Index := tabBottleLog.IndexOfTabAt(X, Y);
1121 if tabBottleLog.TabIndex <> Index then
1123 FLVDragDest := -1; //
\98g
\90ü
\82Í
\82Ü
\82¾
\95\
\8e¦
\82³
\82ê
\82È
\82¢
\82Í
\82¸
1124 //
\83^
\83u
\82ð
\90Ø
\91Ö
\82¦
\82é
1125 tabBottleLogChanging(Self, dummy);
1126 tabBottleLog.TabIndex := Index;
1132 procedure TfrmLog.tabBottleLogDragDrop(Sender, Source: TObject; X,
1134 var DestIndex: integer;
1136 with tabBottleLog do begin
1137 DestIndex := IndexOfTabAt(X, Y);
1138 Tabs.Move(FDragTabIndex, DestIndex);
1139 FBottleLogList.Move(FDragTabIndex, DestIndex);
1143 procedure TfrmLog.tabBottleLogEndDrag(Sender, Target: TObject; X,
1146 //
\8b
\90§
\93I
\82É
\83^
\83u
\82ð
\8dÄ
\95`
\89æ
\82³
\82¹
\82é
\81B
\98g
\90ü
\8fÁ
\82µ
\91Î
\8dô
1147 tabBottleLog.Tabs.BeginUpdate;
1148 tabBottleLog.Tabs.EndUpdate;
1151 procedure TfrmLog.LogLoadWork(Sender: TObject);
1153 if Sender = SelectedBottleLog then
1156 lvwLog.Items.Count := SelectedBottleLog.Count;
1160 procedure TfrmLog.lvwLogDrawItem(Sender: TCustomListView; Item: TListItem;
1161 Rect: TRect; State: TOwnerDrawState);
1168 DummyStr: TStringList;
1170 Bottle := SelectedBottleLog.Bottles[Item.Index];
1171 if Bottle.HasURL = huUndefined then
1173 DummyStr := TStringList.Create;
1175 ExtractURLs(Bottle.Script, DummyStr);
1176 if DummyStr.Count > 0 then
1177 Bottle.HasURL := huYes
1179 Bottle.HasURL := huNo;
1185 //
\94w
\8ci
\8fÁ
\8b\8e
1186 ListView_GetItemRect(lvwLog.Handle, Item.Index, DestRect, LVIR_BOUNDS);
1188 //
\94w
\8ci
\82Ì
\90F
\82Í
\91I
\91ð
\8fó
\91Ô
\81E
\91I
\91ð
\94ñ
\83A
\83N
\83e
\83B
\83u
\8fó
\91Ô
\81E
\92Ê
\8fí
\8fó
\91Ô
\82Ì3
\92Ê
\82è
1189 lvwLog.Canvas.Brush.Style := bsSolid;
1190 if Item.Selected then begin
1191 if lvwLog.Focused then
1192 lvwLog.Canvas.Brush.Color := clHighlight
1194 lvwLog.Canvas.Brush.Color := clBtnFace;
1196 lvwLog.Canvas.Brush.Color := Pref.BgColor;
1198 lvwLog.Canvas.FillRect(DestRect);
1199 lvwLog.Canvas.Brush.Style := bsClear;
1200 //
\83t
\83H
\81[
\83J
\83X
\82ª
\82 \82é
\8fê
\8d\87\82É
\82Í
\83t
\83H
\81[
\83J
\83X
\82Ì
\98g
\90ü
\82ð
\88ø
\82
1201 if Item.Focused and lvwLog.Focused then
1202 lvwLog.Canvas.DrawFocusRect(DestRect);
1204 //
\83h
\83\89\83b
\83O
\92\86\82È
\82ç
\98g
\90ü
\82ð
\95`
\89æ
\82·
\82é
1205 if FLVDragDest = Item.Index then
1207 DestRect := Item.DisplayRect(drBounds);
1208 DrawListViewDragBorder(DestRect);
1211 if Item.Selected then
1213 if lvwLog.Focused then
1214 lvwLog.Canvas.Font.Color := clHighlightText
1216 lvwLog.Canvas.Font.Color := clWindowText;
1218 lvwLog.Canvas.Font.Color := Pref.TextColor;
1219 lvwLog.Canvas.Refresh;
1221 //
\83L
\83\83\83v
\83V
\83\87\83\93(
\93ú
\95t)
1222 ListView_GetItemRect(lvwLog.Handle, Item.Index, DestRect, LVIR_LABEL);
1223 Inc(DestRect.Left, 2);
1224 Inc(DestRect.Top, 2);
1225 Dec(DestRect.Right, 2);
1226 DrawTextEx(lvwLog.Canvas.Handle, PChar(Item.Caption), -1, DestRect,
1227 DT_SINGLELINE or DT_RIGHT, nil);
1228 ListView_GetItemRect(lvwLog.Handle, Item.Index, DestRect, LVIR_ICON);
1229 Ico := TIcon.Create;
1231 lvwLog.SmallImages.GetIcon(Item.ImageIndex, Ico);
1232 lvwLog.Canvas.Draw(DestRect.Left, DestRect.Top, Ico);
1236 //
\83L
\83\83\83v
\83V
\83\87\83\93\82Å
\82à
\83X
\83N
\83\8a\83v
\83g
\82Å
\82à
\82È
\82¢
\82à
\82Ì
1237 for sub := 0 to Item.SubItems.Count-1 do
1239 if sub = SubScript then Continue;
1240 ListView_GetSubItemRect(lvwLog.Handle, Item.Index, sub + 1,
1241 LVIR_BOUNDS, @DestRect);
1242 if DestRect.Right - DestRect.Left <= 16 then
1244 //
\8b·
\82·
\82¬
\82é
\8fê
\8d\87\82Í
\95¶
\8e\9a\97ñ
\82ð
\95`
\89æ
\82µ
\82È
\82¢
\81B
1245 // 16
\82Æ
\82¢
\82¤
\90\94\8e\9a\82Í
\8eÀ
\91ª
\92l
\81B
\89½
\82©
\82Ì
\83o
\83O
\82Á
\82Û
1246 lvwLog.Canvas.FillRect(DestRect);
1249 Inc(DestRect.Left, 2);
1250 Inc(DestRect.Top, 2);
1251 Dec(DestRect.Right, 2);
1252 Ex := DT_NOPREFIX or DT_SINGLELINE or DT_END_ELLIPSIS;
1253 if lvwLog.Columns[sub+1].Alignment = taRightJustify then
1254 Ex := Ex or DT_RIGHT;
1255 DrawTextEx(lvwLog.Canvas.Handle, PChar(Item.SubItems[sub]), -1, DestRect,
1258 //
\83X
\83N
\83\8a\83v
\83g
1259 ListView_GetSubItemRect(lvwLog.Handle, Item.Index, SubScript + 1,
1260 LVIR_BOUNDS, @DestRect);
1261 Script := Item.SubItems[SubScript];
1262 DrawSingleLineScript(Bottle, DestRect, Item);
1266 procedure TfrmLog.DrawSingleLineScript(LogItem: TLogItem;
1267 Rect: TRect; Item: TListItem);
1270 UnyuTalking, Synchronized, Spaced: boolean;
1271 Mark: TSsMarkUpType;
1274 procedure ScopeChange;
1276 if (not Spaced) and (Pref.LogListPreviewStyle = psTagStripped) then
1283 Script := LogItem.Script;
1286 if LogItem.HasURL = huYes then
1288 Ico := TIcon.Create;
1290 lvwLog.SmallImages.GetIcon(IconURL, Ico);
1291 lvwLog.Canvas.Draw(Rect.Left + x, Rect.Top, Ico);
1298 if Pref.LogListPreviewStyle = psNoColor then
1303 DrawTextEx(lvwLog.Canvas.Handle, PChar(Script), -1, Rect,
1304 DT_SINGLELINE or DT_END_ELLIPSIS or DT_NOPREFIX, nil);
1308 SsParser.LeaveEscape := Pref.LogListPreviewStyle = psNormal;
1309 SsParser.InputString := Script;
1311 UnyuTalking := false;
1312 Synchronized := false;
1313 Spaced := true; //
\83^
\83O
\8fÈ
\97ª
\95\
\8e¦
\8e\9e\82É
\95s
\95K
\97v
\82É
\83X
\83R
\81[
\83v
\95Ï
\8a·
\8e\9e\82Ì
\83X
\83y
\81[
\83X
\82ð
\8bó
\82¯
\82È
\82¢
1314 //
\82½
\82ß
\82Ì
\83t
\83\89\83O
1315 for i := 0 to SsParser.Count - 1 do begin
1316 if SsParser[i] = '\h' then
1318 UnyuTalking := false;
1320 end else if SsParser[i] = '\u' then
1322 UnyuTalking := true;
1324 end else if SsParser[i] = '\_s' then
1326 Synchronized := not Synchronized;
1328 end else if (Pos('\n', SsParser[i]) = 1) or (SsParser[i] = '\c') then
1332 Mark := SsParser.MarkUpType[i];
1336 lvwLog.Canvas.Font.Color := Pref.MetaWordColor;
1340 if Pref.LogListPreviewStyle = psNormal then
1341 lvwLog.Canvas.Font.Color := Pref.MarkUpColor
1347 lvwLog.Canvas.Font.Color := Pref.MarkErrorColor;
1350 if Synchronized then
1351 lvwLog.Canvas.Font.Color := Pref.TalkColorS
1352 else if UnyuTalking then
1353 lvwLog.Canvas.Font.Color := Pref.TalkColorU
1355 lvwLog.Canvas.Font.Color := Pref.TalkColorH;
1358 if Item.Selected then
1360 if lvwLog.Focused then
1361 lvwLog.Canvas.Font.Color := clHighlightText
1363 lvwLog.Canvas.Font.Color := clWindowText;
1365 lvwLog.Canvas.Refresh;
1366 w := lvwLog.Canvas.TextWidth(SsParser[i]);
1367 lvwLog.Canvas.TextRect(Rect, Rect.Left + x, Rect.Top + 2, SsParser[i]);
1369 if Rect.Right - Rect.Left < x then Break;
1373 procedure TfrmLog.mnListPreviewStyleClick(Sender: TObject);
1376 with PopupMenuListPreviewStyle do
1377 for i := 0 to Items.Count-1 do
1378 Items[i].Checked := (Sender as TMenuItem).Tag = Items[i].Tag;
1379 Pref.LogListPreviewStyle := TLogListPreviewStyle((Sender as TMenuItem).Tag);
1383 procedure TfrmLog.tbtnListPreviewStyleClick(Sender: TObject);
1386 sel := Ord(Pref.LogListPreviewStyle);
1388 if sel > Ord(High(TLogListPreviewStyle)) then sel := 0;
1389 Pref.LogListPreviewStyle := TLogListPreviewStyle(sel);
1393 procedure TfrmLog.PopupMenuListPreviewStylePopup(Sender: TObject);
1396 with PopupMenuListPreviewStyle do
1397 for i := 0 to Items.Count-1 do
1398 Items[i].Checked := Items[i].Tag = Ord(Pref.LogListPreviewStyle)
1401 procedure TfrmLog.PreviewStyleChange;
1403 if Pref.LogWindowPreviewStyle = psImageConversation then
1405 if Spps.Count = 0 then
1406 ShowMessage('
\83T
\81[
\83t
\83B
\83X
\83v
\83\8c\83r
\83\85\81[
\97p
\83v
\83\89\83O
\83C
\83\93\82ª
\91¶
\8dÝ
\82µ
\82Ü
\82¹
\82ñ
\81B');
1407 edtScript.Visible := false;
1408 TalkShowFrame.Visible := true;
1411 edtScript.Visible := true;
1412 TalkShowFrame.Visible := false;
1416 procedure TfrmLog.lvwLogDragOver(Sender, Source: TObject; X, Y: Integer;
1417 State: TDragState; var Accept: Boolean);
1421 Rec: TRect; //
\83_
\83~
\81[
\81B
1424 //
\82Æ
\82è
\82 \82¦
\82¸
\8eó
\82¯
\95t
\82¯
\82é
\89Â
\94\
\90«
\82ª
\82 \82é
\82Ì
\82ÍTBottleLogDragObject
\82¾
\82¯
1425 if not (Source is TBottleLogDragObject) then
1428 Target := lvwLog.GetItemAt(X, Y);
1430 //
\82±
\82ê
\88È
\91O
\82É
\95`
\89æ
\82³
\82ê
\82Ä
\82¢
\82½
\98g
\82Ì
\83C
\83\93\83f
\83b
\83N
\83X
1431 OldDest := FLVDragDest;
1433 //
\83h
\83\8d\83b
\83v
\88Ê
\92u
\82É Item
\82ª
\82 \82ê
\82Î
\83h
\83\8d\83b
\83v
\82ð
\8b\96\89Â
\82·
\82é
1434 if Target <> nil then
1437 FLVDragDest := Target.Index;
1444 //
\88È
\91O
\82Ì
\98g
\90ü
\82ð
\8dí
\8f\9c
1445 if (OldDest > -1) and (FLVDragDest <> OldDest) then
1447 Rec := lvwLog.Items[OldDest].DisplayRect(drBounds);
1448 DrawListViewDragBorder(Rec);
1450 //
\83h
\83\89\83b
\83O
\90æ
\82Ì
\98g
\90ü
\82ð
\95`
\89æ
1451 if (Target <> nil) and (FLVDragDest <> OldDest) then
1453 Rec := Target.DisplayRect(drBounds);
1454 DrawListViewDragBorder(Rec);
1457 //
\83X
\83N
\83\8d\81[
\83\8b\8aÖ
\8cW
1458 if lvwLog.Items.Count > 0 then
1460 if (lvwLog.topItem <> nil) and (Y - lvwLog.TopItem.Top < 10) then
1462 FLVScrollDir := lvScrollDown;
1463 if not timScrollTimer.Enabled then
1464 timScrollTimer.Enabled := true;
1465 end else if (lvwLog.Height - Y) < 10 then
1467 FLVScrollDir := lvScrollUp;
1468 if not timScrollTimer.Enabled then
1469 timScrollTimer.Enabled := true;
1472 timScrollTimer.Enabled := false;
1474 timScrollTimer.Enabled := false;
1477 procedure TfrmLog.lvwLogDragDrop(Sender, Source: TObject; X, Y: Integer);
1479 TargetItem: integer;
1480 Src: TBottleLogDragObject;
1483 timScrollTimer.Enabled := false;
1485 if not (Source is TBottleLogDragObject) then
1487 Src := Source as TBottleLogDragObject;
1489 if lvwLog.GetItemAt(X, Y) <> nil then
1490 TargetItem := lvwLog.GetItemAt(X, Y).Index
1494 lvwLog.Items.BeginUpdate; //
\83h
\83\8d\83b
\83v
\92\86\82Í
\95\
\8e¦
\82ð
\97}
\8e~
\82·
\82é
\81@
\8fd
\97v
\81I
1496 //
\83h
\83\8d\83b
\83v
\88Ê
\92u
\82É Item
\82ð
\88Ú
\93®
\82·
\82é
1497 if (GetAsyncKeyState(VK_CONTROL) and $8000) > 0 then
1498 begin //
\83R
\83s
\81[
\88Ú
\93®
\82Ì
\8fê
\8d\87
1499 SrcLog := TLogItem.Create(Src.LogItem);
1500 end else //
\88Ú
\93®
\82¾
\82¯
\82·
\82é
\8fê
\8d\87
1502 SrcLog := Src.BottleLogList.Extract(Src.LogItem);
1504 if TargetItem >= 0 then
1506 //
\82·
\82Å
\82É
\91¶
\8dÝ
\82·
\82é
\83A
\83C
\83e
\83\80\82Ì
\8fã
\82É
\83h
\83\8d\83b
\83v
\82µ
\82½
\8fê
\8d\87
1507 SelectedBottleLog.Insert(TargetItem, SrcLog);
1510 // ListView
\82Ì
\97]
\94\92\82É
\83h
\83\8d\83b
\83v
\82µ
\82½
\8fê
\8d\87(Insert
\82Å
\82«
\82È
\82¢)
1511 TargetItem := SelectedBottleLog.Add(SrcLog);
1513 lvwLog.Items[TargetItem].Selected := true;
1514 lvwLog.Items[TargetItem].Focused := true;
1516 lvwLog.Items.EndUpdate;
1521 procedure TfrmLog.timScrollTimerTimer(Sender: TObject);
1523 ScrollHeight: Integer;
1525 //
\83X
\83N
\83\8d\81[
\83\8b\97Ê
\82ð
\8b\81\82ß
\82é
1527 if lvwLog.Items.Count > 2 then
1529 ScrollHeight := lvwLog.Items[1].Top - lvwLog.Items[0].Top;
1532 case FLVScrollDir of
1533 lvScrollUp: lvwLog.Scroll(0, ScrollHeight);
1534 lvSCrollDown: lvwLog.Scroll(0, -ScrollHeight);
1536 lvwLog.Invalidate; //
\8dÅ
\90V
\82Ì
\8fó
\91Ô
\82É
\8dÄ
\95`
\89æ
\82·
\82é
1540 procedure TfrmLog.mnChangeTabNameClick(Sender: TObject);
1543 Name := (FBottleLogList[tabBottleLog.Tag] as TBottleLogList).Title;
1544 InputQuery('
\96¼
\91O
\82Ì
\95Ï
\8dX', '
\90V
\82µ
\82¢
\83^
\83u
\82Ì
\96¼
\91O', Name);
1545 (FBottleLogList[tabBottleLog.Tag] as TBottleLogList).Title := Name;
1549 procedure TfrmLog.lvwLogStartDrag(Sender: TObject;
1550 var DragObject: TDragObject);
1551 var Drag: TBottleLogDragObject;
1553 //
\92Ê
\8fí
\82ÌListView
\97p
\82Ì
\83h
\83\89\83b
\83O
\83I
\83u
\83W
\83F
\83N
\83g
\82Í
1554 // OS
\82É
\82æ
\82Á
\82Ä
\82Í
\81A
\88Ú
\93®
\82·
\82é
\82Æ
\82«
\82É
\83A
\83C
\83e
\83\80\82Ì
\83C
\83\81\81[
\83W
\82ð
\94¼
\93§
\96¾
\82Å
\95`
\89æ
\82µ
\82Ä
\82µ
\82Ü
\82¤
\81B
1555 // TDragObject
\82©
\82ç
\92¼
\90Ú
\8cp
\8f³
\82µ
\82½
\82¾
\82¯
\82Ì
\82à
\82Ì(
\83C
\83\81\81[
\83W
\82ð
\8e\9d\82Á
\82Ä
\82¢
\82È
\82¢)
\82ð
\8eg
\82¤
\82Æ
1556 //
\94¼
\93§
\96¾
\83C
\83\81\81[
\83W
\82Ì
\95`
\89æ
\82Í
\97}
\90§
\82Å
\82«
\82é
\81B
1557 Drag := TBottleLogDragObject.Create(lvwLog);
1558 Drag.BottleLogList := SelectedBottleLog;
1559 Drag.LogItem := SelectedBottleLog.Bottles[lvwLog.Selected.Index];
1563 procedure TfrmLog.lvwLogEndDrag(Sender, Target: TObject; X, Y: Integer);
1565 //
\98g
\90ü
\8fÁ
\82µ
\97p
\82É
\8b
\90§
\93I
\82É
\8dÄ
\95`
\89æ
\82³
\82¹
\82é
1566 timScrollTimer.Enabled := false;
1571 procedure TfrmLog.DrawListViewDragBorder(const Rect: TRect);
1575 InflateRect(Rec, -1, -1);
1576 with lvwLog.Canvas do
1580 Brush.Style := bsClear;
1581 Refresh; //
\95K
\97v
1586 procedure TfrmLog.DoSaveLogXML(Log: TBottleLogList);
1588 SaveDialog.FileName := GetDefaultFileName(Log.Title, '.xml');
1589 SaveDialog.InitialDir := ExtractFileDir(Application.ExeName);
1590 SaveDialog.DefaultExt := 'xml';
1591 SaveDialog.FilterIndex := 3;
1592 if SaveDialog.Execute then
1593 Log.SaveToXmlFile(SaveDialog.FileName);
1596 procedure TfrmLog.DoCloseTab(const Index: integer);
1599 PrevSelection: TBottleLogList; //
\95Â
\82¶
\82½
\82Æ
\82«
\83^
\83u
\82ª
\82¸
\82ê
\82È
\82¢
\82æ
\82¤
\82É
\82·
\82é
\8f\88\97\9d\97p
1602 if Pref.ConfirmOnTabClose then
1604 Confirm := Format('
\83^
\83u"%s"
\82ð
\95Â
\82¶
\82Ü
\82·
\82©?', [(FBottleLogList[Index] as TBottleLogList).Title]);
1605 if MessageDlg(Confirm, mtConfirmation, mbOkCancel, 0) = mrCancel then
1608 PrevSelection := SelectedBottleLog;
1609 FBottleLogList.Delete(Index);
1611 //
\83^
\83u
\82¸
\82ê
\96h
\8e~
\8f\88\97\9d
1612 for i := 0 to FBottleLogList.Count-1 do
1613 if FBottleLogList[i] = PrevSelection then
1614 tabBottleLog.TabIndex := i;
1616 lvwLogChange(Self, nil, ctState);
1619 procedure TfrmLog.HTMLOutputWork(Sender: TObject; const Count: integer;
1620 var Canceled: boolean);
1622 frmHTMLOutputProgress.ProgressBar.Position := Count;
1623 Application.ProcessMessages;
1624 if frmHTMLOutputProgress.Canceled then
1628 function TfrmLog.DoSearchLog(Condition: TSearchCond): TBottleLogList;
1629 var i, UntilIndex: integer;
1631 Result := TBottleLogList.Create('
\8c\9f\8dõ
\8c\8b\89Ê');
1632 if Condition.SearchLogRange in [srSelectedLogList, srAboveSelectedLog] then
1634 if SelectedBottleLog = nil then
1636 ShowMessage('
\8c\9f\8dõ
\91Î
\8fÛ
\82ª
\82 \82è
\82Ü
\82¹
\82ñ');
1642 if Condition.SearchLogRange = srSelectedLogList then
1644 else if lvwLog.Selected = nil then
1647 UntilIndex := lvwLog.Selected.Index;
1648 SearchLogIndivisual(Condition, SelectedBottleLog, Result, UntilIndex);
1650 end else if Condition.SearchLogRange = srAllLogLists then
1652 for i := 0 to BottleLogList.Count-1 do
1654 SearchLogIndivisual(Condition, BottleLogList[i] as TBottleLogList,
1659 if Result.Count = 0 then
1660 Result.AddSystemLog('
\8c©
\82Â
\82©
\82è
\82Ü
\82¹
\82ñ
\82Å
\82µ
\82½
\81B');
1663 procedure TfrmLog.SearchLogIndivisual(Condition: TSearchCond; LogList,
1664 Result: TBottleLogList; UntilIndex: integer = -1);
1667 Bottle, New: TLogItem;
1670 // 1
\8cÂ
\82Ì
\83\8d\83O
\83^
\83u
\82É
\91Î
\82µ
\82Ä
\8c\9f\8dõ
\82ð
\82©
\82¯
\82é
\81BUntilIndex
\82Å
\94Í
\88Í
\8ew
\92è(
\8fÈ
\97ª
\8e\9e\82»
\82Ì
\83^
\83u
\91S
\91Ì)
1671 if UntilIndex >= 0 then
1674 Max := LogList.Count-1;
1675 for i := 0 to Max do
1677 //
\8fð
\8c\8f\94»
\92è
1678 Bottle := LogList.Bottles[i];
1679 if Bottle.LogType <> ltBottle then
1682 //
\83X
\83N
\83\8a\83v
\83g
\83p
\83^
\81[
\83\93\82Å
\89ð
\90Í
1683 if Condition.ScriptPattern <> '' then
1685 if Condition.ScriptRegExp then
1688 if not RegExp.Match(Condition.ScriptPattern, Bottle.Script) then
1692 Ok := false; //
\96
\82È
\90³
\8bK
\95\
\8c»
\82ð
\8fR
\82é
1696 if not AnsiContainsText(Bottle.Script, Condition.ScriptPattern) then
1700 //
\83`
\83\83\83\93\83l
\83\8b\96¼
\81A
\83S
\81[
\83X
\83g
\96¼
\81A
\93\8a\95[
\93¯
\88Ó
1701 if Condition.Channel <> '' then
1702 if not AnsiContainsText(Bottle.Channel, Condition.Channel) then
1704 if Condition.Ghost <> '' then
1705 if not AnsiContainsText(Bottle.Ghost, Condition.Ghost) then
1707 if Condition.MinVote > Bottle.Votes then
1709 if Condition.MinAgree > Bottle.Agrees then
1711 //
\8fð
\8c\8f\82É
\88ê
\92v
\82µ
\82½
\82à
\82Ì
\82ð
\8c\8b\89Ê
\83\8a\83X
\83g
\82É
\92Ç
\89Á
1714 New := TLogItem.Create(Bottle); //
\83R
\83s
\81[
\83R
\83\93\83X
\83g
\83\89\83N
\83^
1715 New.State := lsOpened;
1721 { TBottleLogDragObject }
1723 function TBottleLogDragObject.GetDragImages: TDragImageList;
1725 //
\92\86\93r
\94¼
\92[
\82È
\83h
\83\89\83b
\83O
\83C
\83\81\81[
\83W
\82ð
\95\
\8e¦
\82µ
\82È
\82¢
\82æ
\82¤
\82É
\82·
\82é
1729 procedure TBottleLogDragObject.SetBottleLogList(
1730 const Value: TBottleLogList);
1732 FBottleLogList := Value;
1735 procedure TBottleLogDragObject.SetLogItem(const Value: TLogItem);
1740 procedure TfrmLog.mnTabSaveXMLLogClick(Sender: TObject);
1742 DoSaveLogXML(FBottleLogList[tabBottleLog.Tag] as TBottleLogList);
1745 procedure TfrmLog.mnSaveHTMLClick(Sender: TObject);
1747 LogList, SB: TBottleLogList;
1749 Options: THTMLOutputOptions;
1751 SB := SelectedBottleLog;
1754 if SB.Count = 0 then
1756 Application.CreateForm(TfrmHTMLOutputConfig, frmHTMLOutputConfig);
1757 with frmHTMLOutputConfig do
1759 // Show HTML save option dialog
1762 LogList := TBottleLogList.Create('');
1766 for i := SB.Count-1 downto 0 do
1767 if SB.Bottles[i].LogType = ltBottle then
1768 LogList.Add(TLogItem.Create(SB.Bottles[i]));
1770 if SB.Bottles[lvwLog.Selected.Index].LogType = ltBottle then
1771 LogList.Add(TLogItem.Create(SB.Bottles[lvwLog.Selected.Index]))
1773 ShowMessage('
\82±
\82Ì
\83\81\83b
\83Z
\81[
\83W
\82Í
\95Û
\91¶
\82Å
\82«
\82Ü
\82¹
\82ñ');
1775 for i := lvwLog.Selected.Index downto 0 do
1776 if SB.Bottles[i].LogType = ltBottle then
1777 LogList.Add(TLogItem.Create(SB.Bottles[i]));
1779 Options.ImageDir := ImageDir;
1780 Options.UseColor := UseColor;
1781 Options.ImageType := ImageType;
1782 Application.CreateForm(TfrmHTMLOutputProgress, frmHTMLOutputProgress);
1784 frmHTMLOutputProgress.Show;
1785 LogList.OnHTMLOutputWork := HTMLOutputWork;
1786 LogList.SaveToHTML(FileName, Options, SsParser);
1788 frmHTMLOutputProgress.Release;
1798 procedure TfrmLog.mnPopupCopyGhostClick(Sender: TObject);
1803 Log := SelectedBottleLog.Bottles[frmLog.lvwLog.Selected.Index];
1804 if Log = nil then Exit;
1805 Clip := ClipBoard();
1806 Clip.SetTextBuf(PChar(Log.Ghost));