X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=HTMLCreate.pas;h=baf9a40c430664789b56e9a8b55f28dfbfd289e2;hb=refs%2Fheads%2FBb52;hp=82707a9ac0877d9f885f0d83bcda8056b2659337;hpb=0d66593c54e44c46e246478a99eb7f3a46f60ded;p=gikonavigoeson%2Fgikonavi.git
diff --git a/HTMLCreate.pas b/HTMLCreate.pas
index 82707a9..baf9a40 100644
--- a/HTMLCreate.pas
+++ b/HTMLCreate.pas
@@ -15,9 +15,32 @@ uses
{HttpApp,} YofUtils, {URLMon,} BoardGroup, {gzip,} {Dolib,}
{bmRegExp,} AbonUnit, MojuUtils, Setting,
ExternalBoardManager, ExternalBoardPlugInMain{,}
- {Sort,} ,GikoBayesian;
+ {Sort,} ,GikoBayesian, HintWindow, ActiveX;
type
+
+ PResLinkRec = ^TResLinkRec;
+ TResLinkRec = record
+ FBbs: string;
+ FKey : string;
+ end;
+
+ TBufferedWebBrowser = class(TStringList)
+ private
+ //! «ÞuEU
+ FBrowser: TWebBrowser;
+ //! ½sÜŽßé©ÌTCY
+ FBuffSize: Integer;
+ //! uEUÌIHTMLDocument2C^tF[XðÛ·é open©çcloseÌÔÅ
+ FBrowserDoc: Variant;
+ public
+ constructor Create(Browser: TWebBrowser; BuffSize: Integer);
+ destructor Destory;
+ procedure Open;
+ procedure Close;
+ procedure Flush;
+ function Add(const S: string): Integer; override;
+ end;
THTMLCreate = class(TObject)
private
{ Private é¾ }
@@ -31,20 +54,34 @@ type
constructor Create;
function AddBeProfileLink(AID : string; ANum: Integer):string ;
- procedure CreateUsePluginHTML(doc: Variant; ThreadItem: TThreadItem; var sTitle: string);
- procedure CreateUseSKINHTML(doc: Variant; ThreadItem: TThreadItem; ReadList: TStringList);
- procedure CreateUseCSSHTML(doc: Variant; ThreadItem: TThreadItem; ReadList: TStringList; sTitle: string );
- procedure CreateDefaultHTML (doc: Variant; ThreadItem: TThreadItem; ReadList: TStringList; sTitle: string );
- function ConvertResAnchor(res: string): string;
+ procedure CreateUsePluginHTML(html:TBufferedWebBrowser; ThreadItem: TThreadItem; var sTitle: string);
+ procedure CreateUseSKINHTML(html:TBufferedWebBrowser; ThreadItem: TThreadItem; ReadList: TStringList);
+ procedure CreateUseCSSHTML(html:TBufferedWebBrowser; ThreadItem: TThreadItem; ReadList: TStringList; sTitle: string );
+ procedure CreateDefaultHTML (html:TBufferedWebBrowser; ThreadItem: TThreadItem; ReadList: TStringList; sTitle: string );
+ procedure ConvertResAnchor(PRes: PResRec);
+ procedure separateNumber(var st: String; var et: String; const Text, Separator: String);
+ function checkComma(const s : String; var j : Integer; var No : String) : boolean;
+ function addResAnchor(PAddRes: PResRec; PResLink : PResLinkRec; dat : boolean;
+ var s : String; j : Integer; const No: String) : string;
public
{ Public é¾ }
- function AddAnchorTag(s: string): string;
+ procedure AddAnchorTag(PRes: PResRec);
function LoadFromSkin(fileName: string; ThreadItem: TThreadItem; SizeByte: Integer): string;
- function SkinedRes(skin: string; Res: TResRec; No: string): string;
+ function SkinedRes(const skin: string; PRes: PResRec; const No: string): string;
+ procedure ConvRes( PRes : PResRec; PResLink : PResLinkRec; DatToHTML: boolean = false); overload;
function ConvRes(const Body, Bbs, Key, ParamBBS, ParamKey, ParamStart, ParamTo, ParamNoFirst, ParamTrue : string; DatToHTML: boolean = false): string; overload;
- function ConvRes(const Body, Bbs, Key, ParamBBS, ParamKey, ParamStart, ParamTo, ParamNoFirst, ParamTrue, FullURL : string): string; overload;
- procedure CreateHTML2(doc: Variant; ThreadItem: TThreadItem; var sTitle: string);
+ procedure CreateHTML2(Browser: TWebBrowser; ThreadItem: TThreadItem; var sTitle: string);
procedure CreateHTML3(var html: TStringList; ThreadItem: TThreadItem; var sTitle: string);
+ //X|bvAbvÌì¬
+ procedure SetResPopupText(Hint :TResPopup; threadItem: TThreadItem; StNum, ToNum: Integer; Title, First: Boolean);
+ //N̶ñ©çX|bvAbvpÌURLÉÏ··é
+ class function GetRespopupURL(AText, AThreadURL : string): string;
+ //wèµ½pXÉXLàµÍCSSÌt@CÌRs[ðìé
+ class procedure SkinorCSSFilesCopy(path: string);
+ //datPsðXɪð·é
+ class procedure DivideStrLine(Line: string; PRes: PResRec);
+ //HTML©çN^Oðí·é
+ class function DeleteLink(const s: string): string;
end;
var
@@ -120,23 +157,25 @@ begin
//----- Æè ¦¸©¿ã`µáÝ·pBRgAEgµÄàæµ
// â詽ªêµ¢¯ÇAIvV_CAOÌvr
[p try
- try
- if ThreadItem.ParentBoard <> nil then
- if ThreadItem.ParentBoard.ParentCategory <> nil then
- CustomStringReplace( Skin, '&BBSNAME', ThreadItem.ParentBoard.ParentCategory.ParenTBBS.Title);
- CustomStringReplace( Skin, '&THREADURL', ThreadItem.URL);
- except end;
- CustomStringReplace( Skin, '&BOARDNAME', ThreadItem.ParentBoard.Title);
- CustomStringReplace( Skin, '&BOARDURL', ThreadItem.ParentBoard.URL);
- CustomStringReplace( Skin, '&THREADNAME', ThreadItem.Title);
- CustomStringReplace( Skin, '&SKINPATH', GikoSys.Setting.CSSFileName);
- CustomStringReplace( Skin, '&GETRESCOUNT', IntToStr( ThreadItem.NewReceive - 1 ));
- CustomStringReplace( Skin, '&NEWRESCOUNT', IntToStr( ThreadItem.NewResCount ));
- CustomStringReplace( Skin, '&ALLRESCOUNT', IntToStr( ThreadItem.AllResCount ));
-
- CustomStringReplace( Skin, '&NEWDATE', FormatDateTime('yyyy/mm/dd(ddd) hh:mm', ThreadItem.RoundDate));
- CustomStringReplace( Skin, '&SIZEKB', IntToStr( Floor( SizeByte / 1024 ) ));
- CustomStringReplace( Skin, '&SIZE', IntToStr( SizeByte ));
+ if GikoSys.Setting.UseKatjushaType then begin
+ try
+ if ThreadItem.ParentBoard <> nil then
+ if ThreadItem.ParentBoard.ParentCategory <> nil then
+ CustomStringReplace( Skin, '&BBSNAME', ThreadItem.ParentBoard.ParentCategory.ParenTBBS.Title);
+ CustomStringReplace( Skin, '&THREADURL', ThreadItem.URL);
+ except end;
+ CustomStringReplace( Skin, '&BOARDNAME', ThreadItem.ParentBoard.Title);
+ CustomStringReplace( Skin, '&BOARDURL', ThreadItem.ParentBoard.URL);
+ CustomStringReplace( Skin, '&THREADNAME', ThreadItem.Title);
+ CustomStringReplace( Skin, '&SKINPATH', GikoSys.Setting.CSSFileName);
+ CustomStringReplace( Skin, '&GETRESCOUNT', IntToStr( ThreadItem.NewReceive - 1 ));
+ CustomStringReplace( Skin, '&NEWRESCOUNT', IntToStr( ThreadItem.NewResCount ));
+ CustomStringReplace( Skin, '&ALLRESCOUNT', IntToStr( ThreadItem.AllResCount ));
+
+ CustomStringReplace( Skin, '&NEWDATE', FormatDateTime('yyyy/mm/dd(ddd) hh:mm', ThreadItem.RoundDate));
+ CustomStringReplace( Skin, '&SIZEKB', IntToStr( Floor( SizeByte / 1024 ) ));
+ CustomStringReplace( Skin, '&SIZE', IntToStr( SizeByte ));
+ end
//----- ±±ÜÅ
end;
Result := Skin.Text;
@@ -147,56 +186,70 @@ end;
// XÌlðu··é
function THTMLCreate.SkinedRes(
- skin: string;
- Res: TResRec;
- No: string
+ const skin: string;
+ PRes: PResRec;
+ const No: string
): string;
+const
+ FORMT_NAME = '%s ';
+ FORMT_NUM = '%s ';
+ FORMT_MAILNAME = '%s ';
var
spamminess : Extended;
+{$IFDEF SPAM_FILTER_ENABLED}
wordCount : TWordCount;
+{$ENDIF}
begin
-
+{$IFDEF SPAM_FILTER_ENABLED}
wordCount := TWordCount.Create;
try
spamminess := Floor( GikoSys.SpamParse(
Res.FName + '<>' + Res.FMailTo + '<>' + Res.FBody, wordCount ) * 100 );
-
- Skin := CustomStringReplace( Skin, ' ',
- '' + No + ' ');
- Skin := CustomStringReplace( Skin, ' ', No);
- Skin := CustomStringReplace( Skin, ' ', '' + Res.FName + ' ');
- Skin := CustomStringReplace( Skin, ' ',
- '' + Res.FName + ' ');
- Skin := CustomStringReplace( Skin, ' ', Res.FMailTo);
- Skin := CustomStringReplace( Skin, ' ', Res.FDateTime);
- Skin := CustomStringReplace( Skin, ' ', Res.FBody);
- Skin := CustomStringReplace( Skin, ' ', FloatToStr( spamminess ) );
- Skin := CustomStringReplace( Skin, ' ', FloatToStr( 100 - spamminess ) );
+{$ELSE}
+ spamminess := 0;
+{$ENDIF}
+ Result := CustomStringReplace( skin, ' ', FloatToStr( spamminess ) );
+ Result := CustomStringReplace( Result, ' ', FloatToStr( 100 - spamminess ) );
+ Result := CustomStringReplace( Result, ' ', PRes.FMailTo);
+ Result := CustomStringReplace( Result, ' ', PRes.FDateTime);
+ Result := CustomStringReplace( Result, ' ', No);
+ Result := CustomStringReplace( Result, ' ',
+ Format(FORMT_NAME, [PRes.FName]));
+ Result := CustomStringReplace( Result, ' ',
+ Format(FORMT_NUM, [No, No, No]));
+ Result := CustomStringReplace( Result, ' ',
+ Format(FORMT_MAILNAME,[PRes.FMailTo, PRes.FName]));
+ Result := CustomStringReplace( Result, ' ', PRes.FBody);
//----- ©¿ã`µáÝ·pBRgAEgµÄàæµ
- Skin := CustomStringReplace( Skin, '&NUMBER',
- '' + No + ' ');
- Skin := CustomStringReplace( Skin, '&PLAINNUMBER', No);
- Skin := CustomStringReplace( Skin, '&NAME', '' + Res.FName + ' ');
- Skin := CustomStringReplace( Skin, '&MAILNAME',
- '' + Res.FName + ' ');
- Skin := CustomStringReplace( Skin, '&MAIL', Res.FMailTo);
- Skin := CustomStringReplace( Skin, '&DATE', Res.FDateTime);
- Skin := CustomStringReplace( Skin, '&MESSAGE', Res.FBody);
- Skin := CustomStringReplace( Skin, '&SPAMMINESS', FloatToStr( spamminess ) );
- Skin := CustomStringReplace( Skin, '&NONSPAMMINESS', FloatToStr( 100 - spamminess ) );
+ if GikoSys.Setting.UseKatjushaType then begin
+ Result := CustomStringReplace( Result, '&NUMBER',
+ '' + No + ' ');
+ Result := CustomStringReplace( Result, '&PLAINNUMBER', No);
+ Result := CustomStringReplace( Result, '&NAME', '' + PRes.FName + ' ');
+ Result := CustomStringReplace( Result, '&MAILNAME',
+ '' + PRes.FName + ' ');
+ Result := CustomStringReplace( Result, '&MAIL', PRes.FMailTo);
+ Result := CustomStringReplace( Result, '&DATE', PRes.FDateTime);
+ Result := CustomStringReplace( Result, '&MESSAGE', PRes.FBody);
+ Result := CustomStringReplace( Result, '&SPAMMINESS', FloatToStr( spamminess ) );
+ Result := CustomStringReplace( Result, '&NONSPAMMINESS', FloatToStr( 100 - spamminess ) );
+ end;
//----- ±±ÜÅ
-
- Result := Skin;
+{$IFDEF SPAM_FILTER_ENABLED}
finally
wordCount.Free;
end;
+{$ENDIF}
end;
(*************************************************************************
*http://̶ñðanchor^Ot«É·éB
*************************************************************************)
-function THTMLCreate.AddAnchorTag(s: string): string;
+procedure THTMLCreate.AddAnchorTag(PRes: PResRec);
+const
+ _HEAD : array[0..9] of String =
+ ('', 'h', 'ht', '', 'htt', '', 'http://', '', '', '');
var
url: string;
href: string;
@@ -205,10 +258,14 @@ var
idx, idx2: Integer;
pos : PChar;
pp, pe : PChar;
+ s : String;
+ len : Integer;
begin
- Result := '';
+ s := PRes.FBody;
+ PRes.FBody := '';
- while True do begin
+ //while True do begin
+ repeat
idx := MaxInt;
idx2 := MaxInt;
pp := PChar(s);
@@ -225,63 +282,62 @@ begin
if idx = MaxInt then begin
//Nª³¢æB
- Result := Result + s;
- Break;
- end;
-
- if (idx > 1) and (idx > anchorLen) and
- (AnsiStrPosEx(pp + idx - 1 - anchorLen, pp + idx, pANCHORs, pANCHORe) <> nil) then begin
- //ùÉN^OªÂ¢Ä¢éÁۢƫÍV
- //ðT·A¬¶Å©Â©çȯêÎå¶Åõ
- pos := AnsiStrPosEx(pp + idx, pe, pCTAGLs, pCTAGLe);
- if pos = nil then
- pos := AnsiStrPosEx(pp + idx, pe, pCTAGUs, pCTAGUe);
- if pos = nil then
- b := Length(REF_MARK[idx2])
- else
- b := pos - pp + 1;
-
- Result := Result + Copy(s, 1, idx + b);
- Delete(s, 1, idx + b);
- Continue;
- end;
-
- Result := Result + Copy(s, 1, idx - 1);
- Delete(s, 1, idx - 1);
- b := Length( s ) + 1;
- pp := PChar(s);
- for i := 1 to b do begin
- pe := AnsiStrPosEx(pURLCHARs, pURLCHARe, pp, pp + 1);
-
- if pe = nil then begin
- //URL¶áÈ¢¶©IÆ©A¶ªÈÈÁ½B
- url := Copy(s, 1, i - 1);
- case idx2 of
- 1 : href := 'h' + url;
- 2 : href := 'ht' + url;
- 4 : href := 'htt' + url;
- 6 : href := 'http://' + url;
+ len := Length(PRes.FBody);
+ SetLength(PRes.FBody, Length(s) + len);
+ Move(pp^, PRes.FBody[len + 1], Length(s));
+ end else begin
+ if (idx > anchorLen) and
+ (AnsiStrPosEx(pp + idx - 1 - anchorLen, pp + idx, pANCHORs, pANCHORe) <> nil) then begin
+ //ùÉN^OªÂ¢Ä¢éÁۢƫÍV
+ //ðT·A¬¶Å©Â©çȯêÎå¶Åõ
+ pos := AnsiStrPosEx(pp + idx, pe, pCTAGLs, pCTAGLe);
+ if pos = nil then
+ pos := AnsiStrPosEx(pp + idx, pe, pCTAGUs, pCTAGUe);
+ if pos = nil then
+ b := Length(REF_MARK[idx2])
else
- href := url;
+ b := pos - (pp + idx) + 1;
+
+ len := Length(PRes.FBody);
+ SetLength(PRes.FBody, len + idx + b );
+ Move(pp^, PRes.FBody[len + 1], idx + b);
+ Delete(s, 1, idx + b);
+ end else begin
+ pp := PChar(s);
+ len := Length(PRes.FBody);
+ SetLength(PRes.FBody, len + idx - 1);
+ Move(pp^, PRes.FBody[len + 1], idx - 1);
+
+ Delete(s, 1, idx - 1);
+ b := Length( s ) + 1;
+ pp := PChar(s);
+ for i := 1 to b do begin
+ //PoCg¶ÅURLÉg¦È¢¶Èç
+ if (AnsiStrPosEx(pURLCHARs, pURLCHARe, pp, pp + 1) = nil) then begin
+ url := Copy(s, 1, i - 1);
+ Delete(s, 1, i - 1);
+ href := Format('%s%s', [_HEAD[idx2], url]);
+ PRes.FBody
+ := Format('%s%s ', [PRes.FBody, href, url]);
+ Break;
+ end;
+ //ê¶ißéB
+ Inc(pp);
end;
-
- Result := Result + '' + url + ' ';
- Delete(s, 1, i - 1);
- Break;
end;
- //ê¶ißéB
- Inc(pp);
end;
- end;
+ until idx = MaxInt;
end;
//øAAIDFÎÛÆÈéútID¶ñAANum:XÔ AURLF»ÌXbhÌURL
function THTMLCreate.AddBeProfileLink(AID : string; ANum: Integer):string ;
+const
+ BE_MARK : string = 'BE:';
var
p : integer;
BNum, BMark : string;
begin
- p := AnsiPos('BE:', AnsiUpperCase(AID));
+ p := AnsiPos(BE_MARK, AnsiUpperCase(AID));
if p > 0 then begin
BNum := Copy(AID, p, Length(AID));
AID := Copy(AID, 1, p - 1);
@@ -296,393 +352,398 @@ begin
end else
Result := AID;
end;
-(*************************************************************************
- *
- * from HotZonu
- *************************************************************************)
-function THTMLCreate.ConvRes(const Body, Bbs, Key,
- ParamBBS, ParamKey, ParamStart, ParamTo, ParamNoFirst, ParamTrue : string;
- DatToHTML: boolean = false): string;
-type
- PIndex = ^TIndex;
- TIndex = record
- FIndexFrom : integer;
- FIndexTo : integer;
- FNo : string;
+procedure THTMLCreate.separateNumber(var st: String; var et: String; const Text:String; const Separator: String);
+var
+ p : Integer;
+begin
+ p := Pos(Separator,Text);
+ if (p > 0 ) then begin
+ st := Copy(Text, 1, p - 1);
+ et := Copy(Text, p + Length(Separator), Length(Text));
+ end else begin
+ st := Text;
+ et := Text;
end;
+end;
+procedure THTMLCreate.ConvRes( PRes : PResRec; PResLink : PResLinkRec; DatToHTML: boolean = false);
const
GT = '>';
- SN = '0123456789-';
- ZN = 'OPQRSTUVWX|';
+ SN = '0123456789';
+ //õÎÛ̶ñS
+ TOKEN : array[0..5] of string = (GT+GT, GT, '', '', ' 0 then begin
+ No := No + ch;
+ end else if (ch = '-') then begin
+ if sw then break;
+ if No = '' then break;
+ No := No + ch;
+ sw := true;
+ end else begin
+ break;
+ end;
end;
- p := AnsiPos(Separator, S);
- if (p > 0) then Result := Copy(S, 1, p - 1) else Result := S;
end;
+
begin
- { v1.0 b2 - 03 }
- s := Body;
- r := Body;
- i := 1;
- sw := False;
- No := '';
- List:= TList.Create;
- oc := '';
- sp := 0;
- chk := False;
- al := False;
- while true do begin
- b := ByteType(s, i);
- case b of
- mbSingleByte : begin
- if (not sw) and (Copy(s,i,8) = GT + GT) then begin
- if (AnsiPos(' ')) or
- ((Chk) and (oc = '')) or
- ((not Chk) and (al)) then
- begin
- sw := True;
- sp := i;
- //i := i + 1;
- oc:='';
- end;
- end else
- if (sw) then begin
- sx := Copy(s,i,1);
- if (AnsiPos(sx, SN) > 0) then begin
- No := No + sx;
- end else begin
- if (No <> '') and (No <> '-') then begin
- Add(sp, i, No);
- al := True;
- end;
- sw := False;
- //
- i := i - 1;
- //
- No := '';
- oc:='';
- //chk := False;
+ //s É{¶ðSüêé
+ s := PRes.FBody;
+ //ÊðNA
+ PRes.FBody := '';
+
+ //
+ while Length(s) > 2 do begin
+ pmin := Length(s) + 1;
+ i := Length(token);
+ for j := 0 to 5 do begin
+ pos := AnsiPos(TOKEN[j], s);
+ if pos <> 0 then begin
+ if pos < pmin then begin
+ //ÇêÅqbgµ½©Û¶
+ i := j;
+ //ŬlðXV
+ pmin := pos;
+ end;
+ end;
+ end;
+
+ //qbgµ½¶ñÌêÂèOÜÅÊÉRs[
+ PRes.FBody := PRes.FBody + Copy(s, 1, pmin - 1);
+ Delete(s, 1, pmin - 1);
+
+ if i = 6 then begin
+ //qbgȵ
+ end else if (i = 4) or (i = 5) then begin
+ //' ' or ' ' ÜÅRs[
+ pmin := AnsiPos('' , s);
+ pos := AnsiPos('' , s);
+ if (pmin <> 0) and (pos <> 0) then begin
+ if (pmin > pos) then begin
+ pmin := pos;
+ end;
+ end else if (pos <> 0) then begin
+ pmin := pos;
+ end;
+ rink := Copy(s, 1, pmin + 3);
+ PRes.FBody := PRes.FBody + rink;
+ Delete(s, 1, pmin + 3);
+
+ pmin := Length(rink);
+ i := Length(TOKEN);
+ for j := 0 to 3 do begin
+ pos := AnsiPos(TOKEN[j], rink);
+ if pos <> 0 then begin
+ if pos < pmin then begin
+ //ÇêÅqbgµ½©Û¶
+ i := j;
+ //ŬlðXV
+ pmin := pos;
end;
- end else begin
- if Copy(s,i,1) = '<' then oc := '';
- oc := oc + Copy(s,i,1);
- chk := False;
- al := False;
end;
end;
- mbLeadByte : begin
- if (not sw) and (Copy(s,i,4) = '') then begin
- sw := True;
- sp := i;
- i := i + 3;
- chk := True;
- end else
- if (not sw) and (Copy(s,i,2) = '') then begin
- sw := True;
- sp := i;
- i := i + 1;
- chk := True;
- end else
- if (sw) then begin
- sx := Copy(s,i,2);
- if (AnsiPos(sx, ZN) > 0) then begin
- No := No + ZenToHan(sx);
- end else begin
- if (No <> '') and (No <> '-') and (No <> '|') then begin
- Add(sp, i, No);
- end;
- sw := False;
- i := i - 1;
- No := '';
+ // XAJ[ªÜÜêÄ¢½ç,ª±ÀèAJ[Ƶĵ¤
+ if i <= 3 then begin
+ No := '';
+ j := 1;
+ len := Length(s);
+ cm := checkComma(s, j, No);
+ len := Length(s);
+ while cm do begin
+ oc := '';
+ No := '';
+ sw := false;
+ db := false;
+ getNumberString;
+ //I[ÜÅsÁÄÌI¹©`FbN
+ if j <= len then begin
+ if db then j := j - 2
+ else j := j - 1;
end;
- end else begin
- oc := '';
- chk := False;
+ addResAnchor(PRes, PResLink, DatToHTML, s, j, No);
+ j := 1;
+ len := Length(s);
+ cm := checkComma(s, j, No);
end;
- al := False;
end;
- end;
- inc(i);
- if (i > Length(Body)) then begin
- if (sw) then begin
- if (No <> '') then Add(sp, i, No);
+ end else begin
+ //½©µç©Â©Á½p^[
+ j := Length(TOKEN[i]) + 1;
+ oc := '';
+ No := '';
+ sw := false;
+ db := false;
+ len := Length(s);
+ getNumberString;
+ //I[ÜÅsÁÄÌI¹©`FbN
+ if j <= len then begin
+ if db then j := j - 2
+ else j := j - 1;
end;
- Break;
+ addResAnchor(PRes, PResLink, DatToHTML, s, j, No);
end;
end;
- for i := List.Count - 1 downto 0 do begin
- if (AnsiPos('-', PIndex(List[i]).FNo) > 0) then begin
- st := ChooseString(PIndex(List[i]).FNo, '-', 0);
- et := ChooseString(PIndex(List[i]).FNo, '-', 1);
- end else begin
- st := PIndex(List[i]).FNo;
- et := PIndex(List[i]).FNo;
+ if Length(s) > 0 then begin
+ PRes.FBody := PRes.FBody + s;
+ end;
+end;
+function THTMLCreate.checkComma(
+ const s : String;
+ var j : Integer;
+ var No : String
+) : boolean;
+var
+ bType : TMbcsByteType;
+begin
+ Result := false;
+ if (Length(s) > 0) then begin
+ bType := ByteType(s, j);
+ if ((bType = mbSingleByte) and (s[j] = ',') or
+ ((bType = mbLeadByte) and (ZenToHan(Copy(s, j ,2)) = ','))) then begin
+ Result := true;
+ if (bType = mbSingleByte) then
+ Inc(j)
+ else
+ Inc(j, 2);
+ No := '';
end;
- if not DatToHTML then
- r := Copy(r,0, PIndex(List[i]).FIndexFrom - 1) +
- Format('',
- [ParamBBS, Bbs, ParamKey, Key, ParamStart, st, ParamTo, et, ParamNoFirst, ParamTrue]) +
- Copy(r,PIndex(List[i]).FIndexFrom, PIndex(List[i]).FIndexTo - PIndex(List[i]).FIndexFrom) + ' ' +
- Copy(r,PIndex(List[i]).FIndexTo,Length(r))
- else
- r := Copy(r,0, PIndex(List[i]).FIndexFrom - 1) +
- Format('', [st]) +
- Copy(r,PIndex(List[i]).FIndexFrom, PIndex(List[i]).FIndexTo - PIndex(List[i]).FIndexFrom) + ' ' +
- Copy(r,PIndex(List[i]).FIndexTo,Length(r));
-
- Dispose(PIndex(List[i]));
end;
- List.Free;
- Result := r;
end;
+function THTMLCreate.addResAnchor(
+ PAddRes: PResRec; PResLink : PResLinkRec; dat : boolean;
+ var s : String; j : Integer; const No: String) : string;
+const
+ FORMAT_LINK = '';
+var
+ st,et : string;
+begin
-function THTMLCreate.ConvRes(
- const Body, Bbs, Key, ParamBBS, ParamKey,
- ParamStart, ParamTo, ParamNoFirst,
- ParamTrue, FullURL : string
-): string;
-type
- PIndex = ^TIndex;
- TIndex = record
- FIndexFrom : integer;
- FIndexTo : integer;
- FNo : string;
+ //½àª©Â©çȢƫ
+ if No = '' then begin
+ PAddRes.FBody := PAddRes.FBody + Copy(s, 1, j - 1);
+ end else begin
+ separateNumber(st, et, No, '-');
+
+ if not dat then begin
+ PAddRes.FBody := PAddRes.FBody +
+ Format(FORMAT_LINK, [PResLink.FBbs, PResLink.FKey, st, et]);
+ end else begin
+ PAddRes.FBody := PAddRes.FBody + Format(' ', [st]);
+ end;
+ PAddRes.FBody := PAddRes.FBody + Copy(s, 1, j - 1) + ' ';
end;
+ Delete(s, 1, j - 1);
+end;
+
+(*************************************************************************
+ *
+ * from HotZonu
+ *************************************************************************)
+function THTMLCreate.ConvRes(const Body, Bbs, Key,
+ ParamBBS, ParamKey, ParamStart, ParamTo, ParamNoFirst, ParamTrue : string;
+ DatToHTML: boolean = false): string;
const
GT = '>';
- SN = '0123456789-';
- ZN = 'OPQRSTUVWX|';
+ SN = '0123456789';
+ FORMAT_LINK = '';
+ //õÎÛ̶ñS
+ TOKEN : array[0..5] of string = (GT+GT, GT, '', '', ' ', [st]);
+ end;
+ Result := Result + Copy(s, 1, j - 1) + ' ';
+ end;
+ Delete(s, 1, j - 1);
end;
- function ChooseString(const Text, Separator: string; Index: integer): string;
- var
- S : string;
- i, p : integer;
+
+ procedure getNumberString;
begin
- S := Text;
- for i := 0 to Index - 1 do begin
- if (AnsiPos(Separator, S) = 0) then S := ''
- else S := Copy(S, AnsiPos(Separator, S) + Length(Separator), Length(S));
+ while (j <= len) do begin
+ if (ByteType(s, j) = mbSingleByte) then begin
+ //1byte¶
+ ch := s[j];
+ Inc(j);
+ db := false;
+ end else begin
+ //2byte¶
+ ch := ZenToHan(Copy(s, j, 2));
+ Inc(j, 2);
+ db := true;
+ end;
+
+ if System.Pos(ch, SN) > 0 then begin
+ No := No + ch;
+ end else if (ch = '-') then begin
+ if sw then break;
+ if No = '' then break;
+ No := No + ch;
+ sw := true;
+ end else begin
+ break;
+ end;
+ end;
+ end;
+
+ function checkComma : boolean;
+ begin
+ j := 1;
+ len := Length(s);
+ if ((len > 0) and (s[j] = ',')) or ((len > 1) and (ZenToHan(Copy(s, j ,2)) = ',')) then begin
+ Result := true;
+ if (ByteType(s, j) = mbSingleByte) then
+ Inc(j)
+ else
+ Inc(j, 2);
+ No := '';
+ end else begin
+ Result := false;
end;
- p := AnsiPos(Separator, S);
- if (p > 0) then Result := Copy(S, 1, p - 1) else Result := S;
end;
begin
- { v1.0 b2 - 03 }
+ //s É{¶ðSüêé
s := Body;
- r := Body;
- i := 1;
- sw := False;
- No := '';
- List:= TList.Create;
- oc := '';
- sp := 0;
- chk := False;
- al := False;
- while true do begin
- b := ByteType(s, i);
- case b of
- mbSingleByte : begin
- if (not sw) and (Copy(s,i,8) = GT + GT) then begin
- if (AnsiPos('')) or
- ((Chk) and (oc = '')) or
- ((not Chk) and (al)) then
- begin
- sw := True;
- sp := i;
- //i := i + 1;
- oc:='';
- end;
- end else
- if (sw) then begin
- sx := Copy(s,i,1);
- if (AnsiPos(sx, SN) > 0) then begin
- No := No + sx;
- end else begin
- if (No <> '') and (No <> '-') then begin
- Add(sp, i, No);
- al := True;
- end;
- sw := False;
- //
- i := i - 1;
- //
- No := '';
- oc:='';
- //chk := False;
- end;
- end else begin
- if Copy(s,i,1) = '<' then oc := '';
- oc := oc + Copy(s,i,1);
- chk := False;
- al := False;
+ //ÊðNA
+ Result := '';
+
+ //
+ while Length(s) > 2 do begin
+ pmin := Length(s) + 1;
+ i := Length(token);
+ for j := 0 to 5 do begin
+ pos := AnsiPos(TOKEN[j], s);
+ if pos <> 0 then begin
+ if pos < pmin then begin
+ //ÇêÅqbgµ½©Û¶
+ i := j;
+ //ŬlðXV
+ pmin := pos;
end;
end;
- mbLeadByte : begin
- if (not sw) and (Copy(s,i,4) = '') then begin
- sw := True;
- sp := i;
- i := i + 3;
- chk := True;
- end else
- if (not sw) and (Copy(s,i,2) = '') then begin
- sw := True;
- sp := i;
- i := i + 1;
- chk := True;
- end else
- if (sw) then begin
- sx := Copy(s,i,2);
- if (AnsiPos(sx, ZN) > 0) then begin
- No := No + ZenToHan(sx);
- end else begin
- if (No <> '') and (No <> '-') and (No <> '|') then begin
- Add(sp, i, No);
- end;
- sw := False;
- i := i - 1;
- No := '';
+ end;
+
+ //qbgµ½¶ñÌêÂèOÜÅÊÉRs[
+ Result := Result + Copy(s, 1, pmin - 1);
+ Delete(s, 1, pmin - 1);
+
+ if i = 6 then begin
+ //qbgȵ
+ end else if (i = 4) or (i = 5) then begin
+ //' ' or ' ' ÜÅRs[
+ pmin := AnsiPos('' , s);
+ pos := AnsiPos('' , s);
+ if (pmin <> 0) and (pos <> 0) then begin
+ if (pmin > pos) then begin
+ pmin := pos;
+ end;
+ end else if (pos <> 0) then begin
+ pmin := pos;
+ end;
+ rink := Copy(s, 1, pmin + 3);
+ Result := Result + rink;
+ Delete(s, 1, pmin + 3);
+
+ pmin := Length(rink);
+ i := Length(TOKEN);
+ for j := 0 to 3 do begin
+ pos := AnsiPos(TOKEN[j], rink);
+ if pos <> 0 then begin
+ if pos < pmin then begin
+ //ÇêÅqbgµ½©Û¶
+ i := j;
+ //ŬlðXV
+ pmin := pos;
end;
- end else begin
- oc := '';
- chk := False;
end;
- al := False;
end;
- end;
- inc(i);
- if (i > Length(Body)) then begin
- if (sw) then begin
- if (No <> '') then Add(sp, i, No);
+ // XAJ[ªÜÜêÄ¢½ç,ª±ÀèAJ[Ƶĵ¤
+ if i <= 3 then begin
+ No := '';
+ cm := checkComma;
+ len := Length(s);
+ while cm do begin
+ oc := '';
+ No := '';
+ sw := false;
+ db := false;
+ getNumberString;
+ Result := addResAnchor(Result);
+ cm := checkComma;
+ end;
end;
- Break;
- end;
- end;
- for i := List.Count - 1 downto 0 do begin
- //plName := Copy(PluginName, LastDelimiter('\',PluginName) + 1, Length(PluginName) - LastDelimiter('/',PluginName) -1 );
- if (AnsiPos('-', PIndex(List[i]).FNo) > 0) then begin
- st := ChooseString(PIndex(List[i]).FNo, '-', 0);
- et := ChooseString(PIndex(List[i]).FNo, '-', 1);
end else begin
- st := PIndex(List[i]).FNo;
- et := PIndex(List[i]).FNo;
+ //½©µç©Â©Á½p^[
+ j := Length(TOKEN[i]) + 1;
+ oc := '';
+ No := '';
+ sw := false;
+ db := false;
+ len := Length(s);
+ getNumberString;
+ Result := addResAnchor(Result);
end;
- r := Copy(r,0, PIndex(List[i]).FIndexFrom - 1) +
- Format('',
- [FullURL, ParamStart, st, ParamTo, et, ParamNoFirst, ParamTrue]) +
- Copy(r,PIndex(List[i]).FIndexFrom, PIndex(List[i]).FIndexTo - PIndex(List[i]).FIndexFrom) + ' ' +
- Copy(r,PIndex(List[i]).FIndexTo,Length(r));
- Dispose(PIndex(List[i]));
end;
- List.Free;
- Result := r;
+ Result := Result + s;
end;
-function THTMLCreate.ConvertResAnchor(res: string): string;
+procedure THTMLCreate.ConvertResAnchor(PRes: PResRec);
const
_HEAD : string = '';
@@ -693,15 +754,17 @@ const
var
i, j, k: Integer;
tmp: string;
+ res: string;
begin
- Result := '';
+ res := PRes.FBody;
+ PRes.FBody := '';
i := AnsiPos(_HEAD, res);
while i <> 0 do begin
- Result := Result + Copy(res, 1, i -1);
+ PRes.FBody := PRes.FBody + Copy(res, 1, i -1);
Delete(res, 1, i - 1);
j := AnsiPos(_TAIL, res);
if j = 0 then begin
- Result := Result + res;
+ PRes.FBody := PRes.FBody + res;
Exit;
end;
tmp := Copy(res, 1, j - 1);
@@ -709,11 +772,11 @@ begin
if (AnsiPos(_ST, tmp) <> 0) and (AnsiPos(_TO, tmp) <> 0) then begin
Delete(tmp, 1, AnsiPos(_ST, tmp) + 3);
Delete(tmp, AnsiPos(_TO, tmp), Length(tmp));
- Result := Result + ' ';
+ PRes.FBody := PRes.FBody + ' ';
end else if (AnsiPos(_STA, tmp) <> 0) and (AnsiPos(_END, tmp) <> 0) then begin
Delete(tmp, 1, AnsiPos(_STA, tmp) + 6);
Delete(tmp, AnsiPos(_END, tmp), Length(tmp));
- Result := Result + ' ';
+ PRes.FBody := PRes.FBody + ' ';
end else begin
k := LastDelimiter('/', tmp);
Delete(tmp, 1, k);
@@ -722,237 +785,206 @@ begin
else
Delete(tmp, AnsiPos('"', tmp), Length(tmp));
- Result := Result + ' ';
+ PRes.FBody := PRes.FBody + ' ';
end;
i := AnsiPos(_HEAD, res);
end;
- Result := Result + res;
+ PRes.FBody := PRes.FBody + res;
end;
//Pluginðp·éBoardÌXbhÌHTMLð쬵ÄdocÉ«Þ
-procedure THTMLCreate.CreateUsePluginHTML(doc: Variant; ThreadItem: TThreadItem; var sTitle: string);
+procedure THTMLCreate.CreateUsePluginHTML(html:TBufferedWebBrowser; ThreadItem: TThreadItem; var sTitle: string);
var
i: integer;
NewReceiveNo: Integer;
boardPlugIn : TBoardPlugIn;
UserOptionalStyle: string;
begin
- if ThreadItem <> nil then begin
- if ThreadItem.ParentBoard.IsBoardPlugInAvailable then begin
- //===== vOCÉæé\¦
- boardPlugIn := ThreadItem.ParentBoard.BoardPlugIn;
- NewReceiveNo := ThreadItem.NewReceive;
- // tHgâTCYÌÝè
- UserOptionalStyle := GikoSys.SetUserOptionalStyle;
- try
- doc.open;
- // wb_
- doc.Write( boardPlugIn.GetHeader( DWORD( threadItem ),
- '' ) + #13#10 );
- doc.Write('
' + #13#10 );
-
- for i := 0 to threadItem.Count - 1 do begin
- // 1 ÍK¸\¦
- if i <> 0 then begin
- // \¦ÍÍðÀè
- case GikoSys.ResRange of
- Ord( grrKoko ):
- if ThreadItem.Kokomade > (i + 1) then
- Continue;
- Ord( grrNew ):
- if NewReceiveNo > (i + 1) then
- Continue;
- 10..65535:
- if (threadItem.Count - i) > GikoSys.ResRange then
- Continue;
- end;
- end;
-
- // V
}[N
- if (NewReceiveNo = (i + 1)) or ((NewReceiveNo = 0) and (i = 0)) then begin
- try
- if GikoSys.Setting.UseSkin then begin
- if FileExists( GikoSys.GetSkinNewmarkFileName ) then
- doc.Write( LoadFromSkin( GikoSys.GetSkinNewmarkFileName, ThreadItem, ThreadItem.Size ) + #13#10 )
- else
- doc.Write( ' ' + #13#10 );
- end else if GikoSys.Setting.UseCSS then begin
- doc.Write('
V
X ' + FormatDateTime('yyyy/mm/dd(ddd) hh:mm', ThreadItem.RoundDate) + '
' + #13#10);
- end else begin
- doc.Write('');
- doc.Write(' ');
- doc.Write('V
X ' + FormatDateTime('yyyy/mm/dd(ddd) hh:mm', ThreadItem.RoundDate) + '
');
- doc.Write(' + #13#10');
- end;
- except
- doc.Write( ' ' + #13#10);
- end;
- end;
-
- // X
- doc.Write( boardPlugIn.GetRes( DWORD( threadItem ), i + 1 ) + #13#10 );
+ //===== vOCÉæé\¦
+ boardPlugIn := ThreadItem.ParentBoard.BoardPlugIn;
+ NewReceiveNo := ThreadItem.NewReceive;
+ // tHgâTCYÌÝè
+ UserOptionalStyle := GikoSys.SetUserOptionalStyle;
+ html.add(boardPlugIn.GetHeader( DWORD( threadItem ),
+ '' ));
+ html.Add('
');
+ html.Flush;
+
+ for i := 0 to threadItem.Count - 1 do begin
+ // 1 ÍK¸\¦
+ if i <> 0 then begin
+ // \¦ÍÍðÀè
+ case GikoSys.ResRange of
+ Ord( grrKoko ):
+ if ThreadItem.Kokomade > (i + 1) then
+ Continue;
+ Ord( grrNew ):
+ if NewReceiveNo > (i + 1) then
+ Continue;
+ 10..65535:
+ if (threadItem.Count - i) > GikoSys.ResRange then
+ Continue;
+ end;
+ end;
- if ThreadItem.Kokomade = (i + 1) then begin
- // ±±ÜÅÇñ¾
- try
- if GikoSys.Setting.UseSkin then begin
- if FileExists( GikoSys.GetSkinBookmarkFileName ) then
- doc.Write( LoadFromSkin( GikoSys.GetSkinBookmarkFileName, ThreadItem, ThreadItem.Size ) + #13#10 )
- else
- doc.Write( ' ' + #13#10 );
- end else if GikoSys.Setting.UseCSS then begin
- doc.Write('RRÜÅÇñ¾
' + #13#10 );
- end else begin
- doc.Write(' ');
- doc.Write(' ');
- doc.Write('' + #13#10 );
- end;
- except
- doc.Write( ' ' + #13#10 );
- end;
- end;
+ // V
}[N
+ if (NewReceiveNo = (i + 1)) or ((NewReceiveNo = 0) and (i = 0)) then begin
+ try
+ if GikoSys.Setting.UseSkin then begin
+ if FileExists( GikoSys.GetSkinNewmarkFileName ) then
+ html.Add( LoadFromSkin( GikoSys.GetSkinNewmarkFileName, ThreadItem, ThreadItem.Size ))
+ else
+ html.Add( ' ');
+ end else if GikoSys.Setting.UseCSS then begin
+ html.Add('V
X ' + FormatDateTime('yyyy/mm/dd(ddd) hh:mm', ThreadItem.RoundDate) + '
');
+ end else begin
+ html.Add(' ');
+ html.Add(' ');
+ html.Add('V
X ' + FormatDateTime('yyyy/mm/dd(ddd) hh:mm', ThreadItem.RoundDate) + '
');
+ html.Add('');
end;
+ except
+ html.Add( ' ');
+ end;
+ end;
+ // X
+ html.Add( boardPlugIn.GetRes( DWORD( threadItem ), i + 1 ));
- // XL(tb^)
- doc.Write( boardPlugIn.GetFooter( DWORD( threadItem ), ' ' ) + #13#10 );
- finally
- doc.Close;
+ if ThreadItem.Kokomade = (i + 1) then begin
+ // ±±ÜÅÇñ¾
+ try
+ if GikoSys.Setting.UseSkin then begin
+ if FileExists( GikoSys.GetSkinBookmarkFileName ) then
+ html.Add( LoadFromSkin( GikoSys.GetSkinBookmarkFileName, ThreadItem, ThreadItem.Size ))
+ else
+ html.Add( ' ');
+ end else if GikoSys.Setting.UseCSS then begin
+ html.Add('RRÜÅÇñ¾
');
+ end else begin
+ html.Add(' ');
+ html.Add(' ');
+ html.Add('');
+ end;
+ except
+ html.Add(' ');
end;
-
end;
end;
+
+
+ // XL(tb^)
+ html.Add( boardPlugIn.GetFooter( DWORD( threadItem ), ' ' ));
end;
-procedure THTMLCreate.CreateUseSKINHTML(doc: Variant; ThreadItem: TThreadItem; ReadList: TStringList);
+procedure THTMLCreate.CreateUseSKINHTML(html:TBufferedWebBrowser; ThreadItem: TThreadItem; ReadList: TStringList);
+const
+ KOKO_TAG = ' ';
+ NEW_TAG = ' ';
var
i: integer;
- No: string;
- CSSFileName: string;
NewReceiveNo: Integer;
Res: TResRec;
UserOptionalStyle: string;
SkinHeader: string;
SkinNewRes: string;
SkinRes: string;
- strTmp : string;
- function ReplaceRes( skin: string ): string;
- begin
- Result := SkinedRes( skin, Res, No );
- end;
+ ThreadName : string;
+ ResLink :TResLinkRec;
begin
- if ThreadItem <> nil then begin
- // XLgp
- if GikoSys.Setting.UseSkin then begin
- NewReceiveNo := ThreadItem.NewReceive;
- // tHgâTCYÌÝè
- UserOptionalStyle := GikoSys.SetUserOptionalStyle;
- CSSFileName := GikoSys.GetStyleSheetDir + GikoSys.Setting.CSSFileName;
- doc.open;
- try
- doc.charset := 'Shift_JIS';
-
- // XLÌÝè
- try
- SkinHeader := LoadFromSkin( GikoSys.GetSkinHeaderFileName, ThreadItem, ThreadItem.Size);
- if Length( UserOptionalStyle ) > 0 then
- SkinHeader := CustomStringReplace( SkinHeader, '',
- '');
- doc.Write( SkinHeader + #13#10);
- except
- end;
-
- try
- SkinNewRes := LoadFromSkin( GikoSys.GetSkinNewResFileName, ThreadItem, ThreadItem.Size);
- except
- end;
-
- try
- SkinRes := LoadFromSkin( GikoSys.GetSkinResFileName, ThreadItem, ThreadItem.Size );
- except
- end;
-
- doc.Write('
' + #13#10);
- doc.Write(' ' + #13#10);
-
- for i := 0 to ReadList.Count - 1 do begin
- // 1 ÍK¸\¦
- if i <> 0 then begin
- // \¦ÍÍðÀè
- case GikoSys.ResRange of
- Ord( grrKoko ):
- if ThreadItem.Kokomade > (i + 1) then
- Continue;
- Ord( grrNew ):
- if NewReceiveNo > (i + 1) then
- Continue;
- 10..65535:
- if (threadItem.Count - i) > GikoSys.ResRange then
- Continue;
- end;
- end;
-
- // V
}[N
- if (NewReceiveNo = i + 1) or ((NewReceiveNo = 0) and (i = 0)) then begin
- try
- if FileExists( GikoSys.GetSkinNewmarkFileName ) then
- doc.Write( LoadFromSkin( GikoSys.GetSkinNewmarkFileName, ThreadItem, ThreadItem.Size ) + #13#10)
- else
- doc.Write( ' ' + #13#10 );
- except
- doc.Write( ' ' + #13#10 );
- end;
- end;
+ NewReceiveNo := ThreadItem.NewReceive;
+ // tHgâTCYÌÝè
+ UserOptionalStyle := GikoSys.SetUserOptionalStyle;
+ ThreadName := ChangeFileExt(ThreadItem.FileName, '');
+ ResLink.FBbs := ThreadItem.ParentBoard.BBSID;
+ ResLink.FKey := ThreadName;
+ // XLÌÝè
+ try
+ SkinHeader := LoadFromSkin( GikoSys.GetSkinHeaderFileName, ThreadItem, ThreadItem.Size);
+ if Length( UserOptionalStyle ) > 0 then
+ SkinHeader := CustomStringReplace( SkinHeader, '',
+ '');
+ html.Add( SkinHeader );
+ except
+ end;
- if (Trim(ReadList[i]) <> '') then begin
- No := IntToStr(i + 1);
+ SkinNewRes := LoadFromSkin( GikoSys.GetSkinNewResFileName, ThreadItem, ThreadItem.Size);
+ SkinRes := LoadFromSkin( GikoSys.GetSkinResFileName, ThreadItem, ThreadItem.Size );
+
+ html.Add('
'#13#10' ');
+ html.Flush;
+
+ for i := 0 to ReadList.Count - 1 do begin
+ // 1 ÍK¸\¦
+ if i <> 0 then begin
+ // \¦ÍÍðÀè
+ case GikoSys.ResRange of
+ Ord( grrKoko ):
+ if ThreadItem.Kokomade > (i + 1) then
+ Continue;
+ Ord( grrNew ):
+ if NewReceiveNo > (i + 1) then
+ Continue;
+ 10..65535:
+ if (threadItem.Count - i) > GikoSys.ResRange then
+ Continue;
+ end;
+ end;
- Res := DivideStrLine(ReadList[i]);
- Res.FBody := ConvRes(AddAnchorTag(Res.FBody), ThreadItem.ParentBoard.BBSID, ChangeFileExt(ThreadItem.FileName, ''), 'bbs', 'key', 'st', 'to', 'nofirst', 'true');
- Res.FDateTime := AddBeProfileLink(Res.FDateTime, i + 1);
+ // V
}[N
+ if (NewReceiveNo = i + 1) or ((NewReceiveNo = 0) and (i = 0)) then begin
+ if FileExists( GikoSys.GetSkinNewmarkFileName ) then
+ html.Add( LoadFromSkin( GikoSys.GetSkinNewmarkFileName, ThreadItem, ThreadItem.Size ))
+ else
+ html.Add( NEW_TAG );
+ end;
- try
- if NewReceiveNo <= (i + 1) then
- // V
X
- strTmp := ReplaceRes( SkinNewRes )
- else
- // ÊíÌX
- strTmp := ReplaceRes( SkinRes );
-
- doc.Write( strTmp + #13#10 );
- except
- end;
- end;
+ if (Trim(ReadList[i]) <> '') then begin
+ DivideStrLine(ReadList[i], @Res);
+ AddAnchorTag(@Res);
+ ConvRes(@Res, @ResLink);
+ Res.FDateTime := AddBeProfileLink(Res.FDateTime, i + 1);
- if ThreadItem.Kokomade = (i + 1) then begin
- // ±±ÜÅÇñ¾
- try
- if FileExists( GikoSys.GetSkinBookmarkFileName ) then
- doc.Write( LoadFromSkin( GikoSys.GetSkinBookmarkFileName, ThreadItem, ThreadItem.Size ) + #13#10 )
- else
- doc.Write( ' ' + #13#10 );
- except
- doc.Write( ' ' + #13#10 );
- end;
- end;
- end;
+ if NewReceiveNo <= (i + 1) then
+ // V
X
+ html.Add(SkinedRes(SkinNewRes, @Res, IntToStr(i + 1)))
+ else
+ // ÊíÌX
+ html.Add(SkinedRes(SkinRes, @Res, IntToStr(i + 1)));
+ end;
- doc.Write(' ' + #13#10);
- // XL(tb^)
- try
- doc.Write( LoadFromSkin( GikoSys.GetSkinFooterFileName, ThreadItem, ThreadItem.Size ) + #13#10 );
- except
- end;
- finally
- doc.close;
- end;
+ if ThreadItem.Kokomade = (i + 1) then begin
+ // ±±ÜÅÇñ¾
+ if FileExists( GikoSys.GetSkinBookmarkFileName ) then
+ html.Add( LoadFromSkin( GikoSys.GetSkinBookmarkFileName, ThreadItem, ThreadItem.Size ))
+ else
+ html.Add( KOKO_TAG );
end;
end;
+
+ html.Add(' ');
+ // XL(tb^)
+ html.Add( LoadFromSkin( GikoSys.GetSkinFooterFileName, ThreadItem, ThreadItem.Size ) );
end;
-procedure THTMLCreate.CreateUseCSSHTML(doc: Variant; ThreadItem: TThreadItem; ReadList: TStringList; sTitle: string );
+procedure THTMLCreate.CreateUseCSSHTML(html:TBufferedWebBrowser; ThreadItem: TThreadItem; ReadList: TStringList; sTitle: string );
+const
+ FORMAT_NOMAIL = ' '
+ + '%s
';
+
+ FORMAT_SHOWMAIL = '%s
';
+
+ FORMAT_NOSHOW = ' '
+ + '%s
';
var
i: integer;
No: string;
@@ -960,175 +992,150 @@ var
NewReceiveNo: Integer;
Res: TResRec;
UserOptionalStyle: string;
+ ThreadName :String;
+ ResLink :TResLinkRec;
begin
- if ThreadItem <> nil then begin
- doc.open;
- try
- doc.charset := 'Shift_JIS';
- NewReceiveNo := ThreadItem.NewReceive;
- // tHgâTCYÌÝè
- UserOptionalStyle := GikoSys.SetUserOptionalStyle;
- CSSFileName := GikoSys.GetStyleSheetDir + GikoSys.Setting.CSSFileName;
- if GikoSys.Setting.UseCSS and FileExists(CSSFileName) then begin
- //CSSgp
- doc.Write('' + #13#10);
- doc.Write(' ' + #13#10);
- doc.Write('' + sTitle + ' ' + #13#10);
- doc.Write(' ' + #13#10);
- if Length( UserOptionalStyle ) > 0 then
- doc.Write('' + #13#10);
- doc.Write('' + #13#10);
- doc.Write('' + #13#10);
- doc.Write(' ' + #13#10);
- doc.Write('
' + #13#10);
- doc.Write('' + sTitle + '
' + #13#10);
- for i := 0 to ReadList.Count - 1 do begin
- // 1 ÍK¸\¦
- if i <> 0 then begin
- // \¦ÍÍðÀè
- case GikoSys.ResRange of
- Ord( grrKoko ):
- if ThreadItem.Kokomade > (i + 1) then
- Continue;
- Ord( grrNew ):
- if NewReceiveNo > (i + 1) then
- Continue;
- 10..65535:
- if (threadItem.Count - i) > GikoSys.ResRange then
- Continue;
- end;
- end;
-
- if (NewReceiveNo = (i + 1)) or ((NewReceiveNo = 0) and (i = 0)) then begin
- doc.Write('V
X ' + FormatDateTime('yyyy/mm/dd(ddd) hh:mm', ThreadItem.RoundDate) + '
' + #13#10);
- end;
-
- if (Trim(ReadList[i]) <> '') then begin
- No := IntToStr(i + 1);
- Res := DivideStrLine(ReadList[i]);
- Res.FBody := ConvRes(AddAnchorTag(Res.FBody), ThreadItem.ParentBoard.BBSID, ChangeFileExt(ThreadItem.FileName, ''), 'bbs', 'key', 'st', 'to', 'nofirst', 'true');
- Res.FDateTime := AddBeProfileLink(Res.FDateTime, i + 1);
- if Res.FMailTo = '' then
- doc.Write(' '
- + ''
- + '' + Res.FBody + '
' + #13#10)
- else if GikoSys.Setting.ShowMail then
- doc.Write(' '
- + ''
- + '' + Res.FBody + '
' + #13#10)
- else
- doc.Write(' '
- + ''
- + '' + Res.FBody + '
' + #13#10);
- end;
+ NewReceiveNo := ThreadItem.NewReceive;
+ ThreadName := ChangeFileExt(ThreadItem.FileName, '');
+ ResLink.FBbs := ThreadItem.ParentBoard.BBSID;
+ ResLink.FKey := ThreadName;
+ // tHgâTCYÌÝè
+ UserOptionalStyle := GikoSys.SetUserOptionalStyle;
+ CSSFileName := GikoSys.GetStyleSheetDir + GikoSys.Setting.CSSFileName;
+ if GikoSys.Setting.UseCSS and FileExists(CSSFileName) then begin
+ //CSSgp
+ html.Add('');
+ html.Add(' ');
+ html.Add('' + sTitle + ' ');
+ html.Add(' ');
+ if Length( UserOptionalStyle ) > 0 then
+ html.Add('');
+ html.Add(''#13#10'');
+ html.Add(' '#13#10'
');
+ html.Add('' + sTitle + '
');
+ html.Flush;
+ for i := 0 to ReadList.Count - 1 do begin
+ // 1 ÍK¸\¦
+ if i <> 0 then begin
+ // \¦ÍÍðÀè
+ case GikoSys.ResRange of
+ Ord( grrKoko ):
+ if ThreadItem.Kokomade > (i + 1) then
+ Continue;
+ Ord( grrNew ):
+ if NewReceiveNo > (i + 1) then
+ Continue;
+ 10..65535:
+ if (threadItem.Count - i) > GikoSys.ResRange then
+ Continue;
+ end;
+ end;
- if ThreadItem.Kokomade = (i + 1) then begin
- doc.Write('RRÜÅÇñ¾
' + #13#10);
- end;
+ if (NewReceiveNo = (i + 1)) or ((NewReceiveNo = 0) and (i = 0)) then begin
+ html.Add('V
X ' + FormatDateTime('yyyy/mm/dd(ddd) hh:mm', ThreadItem.RoundDate) + '
');
+ end;
- end;
+ if (Trim(ReadList[i]) <> '') then begin
+ No := IntToStr(i + 1);
+ DivideStrLine(ReadList[i], @Res);
+ AddAnchorTag(@Res);
+ ConvRes(@Res, @ResLink);
+ Res.FDateTime := AddBeProfileLink(Res.FDateTime, i + 1);
+ if Res.FMailTo = '' then
+ html.Add(Format(FORMAT_NOMAIL, [No, No, No, Res.FName, Res.FDateTime, Res.FBody]))
+ else if GikoSys.Setting.ShowMail then
+ html.Add(Format(FORMAT_SHOWMAIL, [No, No, No, Res.FMailTo, Res.FName, Res.FMailTo, Res.FDateTime, Res.FBody]))
+ else
+ html.Add(Format(FORMAT_NOSHOW, [No, No, No, Res.FMailTo, Res.FName, Res.FDateTime, Res.FBody]));
+ end;
- doc.Write(' ' + #13#10);
- doc.Write(' ' + #13#10);
- doc.Write('' + #13#10);
+ if ThreadItem.Kokomade = (i + 1) then begin
+ html.Add('RRÜÅÇñ¾
');
end;
- finally
- doc.Close;
+
end;
+
+ html.Add(' ');
+ html.Add(' ');
+ html.Add('');
end;
end;
-procedure THTMLCreate.CreateDefaultHTML (doc: Variant; ThreadItem: TThreadItem; ReadList: TStringList; sTitle: string );
+procedure THTMLCreate.CreateDefaultHTML (html:TBufferedWebBrowser; ThreadItem: TThreadItem; ReadList: TStringList; sTitle: string );
var
i: integer;
No: string;
NewReceiveNo: Integer;
Res: TResRec;
+ ThreadName: String;
+ ResLink : TResLinkRec;
begin
- if ThreadItem <> nil then begin
- doc.open;
- try
- doc.charset := 'Shift_JIS';
- NewReceiveNo := ThreadItem.NewReceive;
- doc.Write('' + #13#10);
- doc.Write(' ' + #13#10);
- doc.Write('' + sTitle + ' ' + #13#10);
- doc.Write('' + #13#10);
- doc.Write(' ' + #13#10);
- doc.Write('' + sTitle + ' ' + #13#10);
- doc.Write('' + #13#10);
- doc.Write('
' + #13#10);
- for i := 0 to ReadList.Count - 1 do begin
- // 1 ÍK¸\¦
- if i <> 0 then begin
- // \¦ÍÍðÀè
- case GikoSys.ResRange of
- Ord( grrKoko ):
- if ThreadItem.Kokomade > (i + 1) then
- Continue;
- Ord( grrNew ):
- if NewReceiveNo > (i + 1) then
- Continue;
- 10..65535:
- if (threadItem.Count - i) > GikoSys.ResRange then
- Continue;
- end;
- end;
+ NewReceiveNo := ThreadItem.NewReceive;
+ ThreadName := ChangeFileExt(ThreadItem.FileName, '');
+ ResLink.FBbs := ThreadItem.ParentBoard.BBSID;
+ ResLink.FKey := ThreadName;
+ html.Add('');
+ html.Add(' ');
+ html.Add('' + sTitle + ' ');
+ html.Add('');
+ html.Add(' ');
+ html.Add('' + sTitle + ' ');
+ html.Add('');
+ html.Add('
');
+ html.Flush;
+ for i := 0 to ReadList.Count - 1 do begin
+ // 1 ÍK¸\¦
+ if i <> 0 then begin
+ // \¦ÍÍðÀè
+ case GikoSys.ResRange of
+ Ord( grrKoko ):
+ if ThreadItem.Kokomade > (i + 1) then
+ Continue;
+ Ord( grrNew ):
+ if NewReceiveNo > (i + 1) then
+ Continue;
+ 10..65535:
+ if (threadItem.Count - i) > GikoSys.ResRange then
+ Continue;
+ end;
+ end;
- if (NewReceiveNo = (i + 1)) or ((NewReceiveNo = 0) and (i = 0)) then begin
- doc.Write(' ' + #13#10);
- doc.Write(' ' + #13#10);
- doc.Write('V
X ' + FormatDateTime('yyyy/mm/dd(ddd) hh:mm', ThreadItem.RoundDate) + '
' + #13#10);
- doc.Write('' + #13#10);
- end;
+ if (NewReceiveNo = (i + 1)) or ((NewReceiveNo = 0) and (i = 0)) then begin
+ html.Add(' ');
+ html.Add(' ');
+ html.Add('V
X ' + FormatDateTime('yyyy/mm/dd(ddd) hh:mm', ThreadItem.RoundDate) + '
');
+ html.Add('');
+ end;
- if (Trim(ReadList[i]) <> '') then begin
- No := IntToStr(i + 1);
- Res := DivideStrLine(ReadList[i]);
- Res.FBody := ConvRes(AddAnchorTag(Res.FBody), ThreadItem.ParentBoard.BBSID, ChangeFileExt(ThreadItem.FileName, ''), 'bbs', 'key', 'st', 'to', 'nofirst', 'true');
- Res.FDateTime := AddBeProfileLink(Res.FDateTime, i + 1);
- if Res.FMailTo = '' then
- doc.Write('' + No + ' ¼OF ' + Res.FName + ' eúF ' + Res.FDateTime+ ' ' + Res.Fbody + ' ' + #13#10)
- else if GikoSys.Setting.ShowMail then
- doc.Write(' ' + No + ' ¼OF ' + Res.FName + ' [' + Res.FMailTo + '] eúF ' + Res.FDateTime+ ' ' + Res.Fbody + ' ' + #13#10)
- else
- doc.Write(' ' + No + ' ¼OF ' + Res.FName + ' eúF ' + Res.FDateTime+ ' ' + Res.Fbody + ' ' + #13#10);
- end;
- if ThreadItem.Kokomade = (i + 1) then begin
- doc.Write(' ' + #13#10);
- doc.Write(' ' + #13#10);
- doc.Write('' + #13#10);
- end;
- end;
- doc.Write(' ' + #13#10);
- doc.Write(' ' + #13#10);
- doc.Write('' + #13#10);
- finally
- doc.Close;
+ if (Trim(ReadList[i]) <> '') then begin
+ No := IntToStr(i + 1);
+ DivideStrLine(ReadList[i], @Res);
+ AddAnchorTag(@Res);
+ ConvRes(@Res, @ResLink);
+ Res.FDateTime := AddBeProfileLink(Res.FDateTime, i + 1);
+ if Res.FMailTo = '' then
+ html.Add('' + No + ' ¼OF ' + Res.FName + ' eúF ' + Res.FDateTime+ ' ' + Res.Fbody + ' '#13#10)
+ else if GikoSys.Setting.ShowMail then
+ html.Add(' ' + No + ' ¼OF ' + Res.FName + ' [' + Res.FMailTo + '] eúF ' + Res.FDateTime+ ' ' + Res.Fbody + ' '#13#10)
+ else
+ html.Add(' ' + No + ' ¼OF ' + Res.FName + ' eúF ' + Res.FDateTime+ ' ' + Res.Fbody + ' '#13#10);
+ end;
+ if ThreadItem.Kokomade = (i + 1) then begin
+ html.Add(' ');
+ html.Add(' ');
+ html.Add('');
end;
end;
+ html.Add(' '#13#10' '#13#10'');
end;
-procedure THTMLCreate.CreateHTML2(doc: Variant; ThreadItem: TThreadItem; var sTitle: string);
+procedure THTMLCreate.CreateHTML2(Browser: TWebBrowser; ThreadItem: TThreadItem; var sTitle: string);
var
ReadList: TStringList;
CSSFileName: string;
FileName: string;
Res: TResRec;
+ body : TBufferedWebBrowser;
{$IFDEF DEBUG}
st, rt: Cardinal;
{$ENDIF}
@@ -1138,43 +1145,51 @@ begin
st := GetTickCount;
{$ENDIF}
if ThreadItem <> nil then begin
- if ThreadItem.ParentBoard.IsBoardPlugInAvailable then begin
- CreateUsePluginHTML(doc, ThreadItem, sTitle);
- end else begin
- ShortDayNames[1] := 'ú'; ShortDayNames[2] := '';
- ShortDayNames[3] := 'Î'; ShortDayNames[4] := '
';
- ShortDayNames[5] := 'Ø'; ShortDayNames[6] := 'à';
- ShortDayNames[7] := 'y';
-
- ReadList := TStringList.Create;
- try
- if ThreadItem.IsLogFile then begin
- FileName := ThreadItem.GetThreadFileName;
- ReadList.LoadFromFile(FileName);
- GikoSys.FAbon.IndividualAbon(ReadList, ChangeFileExt(FileName,'.NG'));
- GikoSys.FAbon.Execute(ReadList); // Ú`ñµÄ
- GikoSys.FSelectResFilter.Execute(ReadList); //XÌtB^Oð·é
- if ThreadItem.Title = '' then begin
- Res := DivideStrLine(ReadList[0]);
- sTitle := Res.FTitle;
- end else
- sTitle := ThreadItem.Title
- end else begin
- sTitle := CustomStringReplace(ThreadItem.Title, 'M', ',');
- end;
-
- // tHgâTCYÌÝè
- CSSFileName := GikoSys.GetStyleSheetDir + GikoSys.Setting.CSSFileName;
- if GikoSys.Setting.UseSkin then begin
- CreateUseSKINHTML(doc, ThreadItem, ReadList);
- end else if GikoSys.Setting.UseCSS and FileExists(CSSFileName) then begin
- CreateUseCSSHTML(doc, ThreadItem, ReadList, sTitle);
- end else begin
- CreateDefaultHTML(doc, ThreadItem, ReadList, sTitle);
+ body := TBufferedWebBrowser.Create(Browser, 100);
+ try
+ body.Open;
+ if ThreadItem.ParentBoard.IsBoardPlugInAvailable then begin
+ CreateUsePluginHTML(body, ThreadItem, sTitle);
+ end else begin
+ ShortDayNames[1] := 'ú'; ShortDayNames[2] := '';
+ ShortDayNames[3] := 'Î'; ShortDayNames[4] := '
';
+ ShortDayNames[5] := 'Ø'; ShortDayNames[6] := 'à';
+ ShortDayNames[7] := 'y';
+
+ ReadList := TStringList.Create;
+ try
+ if ThreadItem.IsLogFile then begin
+ ReadList.BeginUpdate;
+ FileName := ThreadItem.GetThreadFileName;
+ ReadList.LoadFromFile(FileName);
+ ReadList.EndUpdate;
+ GikoSys.FAbon.IndividualAbon(ReadList, ChangeFileExt(FileName,'.NG'));
+ GikoSys.FAbon.Execute(ReadList); // Ú`ñµÄ
+ GikoSys.FSelectResFilter.Execute(ReadList); //XÌtB^Oð·é
+ if ThreadItem.Title = '' then begin
+ DivideStrLine(ReadList[0], @Res);
+ sTitle := Res.FTitle;
+ end else
+ sTitle := ThreadItem.Title
+ end else begin
+ sTitle := CustomStringReplace(ThreadItem.Title, 'M', ',');
+ end;
+ // tHgâTCYÌÝè
+ CSSFileName := GikoSys.GetStyleSheetDir + GikoSys.Setting.CSSFileName;
+ if GikoSys.Setting.UseSkin then begin
+ CreateUseSKINHTML(body, ThreadItem, ReadList);
+ end else if GikoSys.Setting.UseCSS and FileExists(CSSFileName) then begin
+ CreateUseCSSHTML(body, ThreadItem, ReadList, sTitle);
+ end else begin
+ CreateDefaultHTML(body, ThreadItem, ReadList, sTitle);
+ end;
+ finally
+ ReadList.Free;
end;
- finally
- ReadList.Free;
end;
+ finally
+ body.Close;
+ body.Free;
end;
end;
{$IFDEF DEBUG}
@@ -1201,18 +1216,23 @@ var
SkinHeader: string;
SkinRes: string;
tmp, tmp1: string;
+ ThreadName: String;
+ ResLink : TResLinkRec;
function LoadSkin( fileName: string ): string;
begin
Result := LoadFromSkin( fileName, ThreadItem, ThreadItem.Size );
end;
function ReplaceRes( skin: string ): string;
begin
- Result := SkinedRes( skin, Res, No );
+ Result := SkinedRes( skin, @Res, No );
end;
begin
if ThreadItem <> nil then begin
CSSFileName := GikoSys.GetStyleSheetDir + GikoSys.Setting.CSSFileName;
+ ThreadName := ChangeFileExt(ThreadItem.FileName, '');
+ ResLink.FBbs := ThreadItem.ParentBoard.BBSID;
+ ResLink.FKey := ThreadName;
html.Clear;
html.BeginUpdate;
//if ThreadItem.IsBoardPlugInAvailable then begin
@@ -1244,7 +1264,9 @@ begin
for i := 0 to threadItem.Count - 1 do begin
// X
- html.Append( ConvertResAnchor(boardPlugIn.GetRes( DWORD( threadItem ), i + 1 )) );
+ Res.FBody := boardPlugIn.GetRes( DWORD( threadItem ), i + 1 );
+ ConvertResAnchor(@Res);
+ html.Append( Res.FBody );
end;
// XL(tb^)
@@ -1267,7 +1289,7 @@ begin
GikoSys.FAbon.IndividualAbon(ReadList, ChangeFileExt(FileName,'.NG'));
GikoSys.FAbon.Execute(ReadList); // Ú`ñµÄ
GikoSys.FSelectResFilter.Execute(ReadList); //XÌtB^Oð·é
- Res := DivideStrLine(ReadList[0]);
+ DivideStrLine(ReadList[0], @Res);
//Res.FTitle := CustomStringReplace(Res.FTitle, 'M', ',');
sTitle := Res.FTitle;
end else begin
@@ -1302,9 +1324,10 @@ begin
if (Trim(ReadList[i]) <> '') then begin
No := IntToStr(i + 1);
- Res := DivideStrLine(ReadList[i]);
- Res.FBody := AddAnchorTag(Res.FBody);
- Res.FBody := ConvertResAnchor(ConvRes(Res.FBody, ThreadItem.ParentBoard.BBSID, ChangeFileExt(ThreadItem.FileName, ''), 'bbs', 'key', 'st', 'to', 'nofirst', 'true', true));
+ DivideStrLine(ReadList[i], @Res);
+ AddAnchorTag(@Res);
+ ConvRes(@Res, @ResLink, true);
+ ConvertResAnchor(@Res);
try
html.Append( ReplaceRes( SkinRes ) );
@@ -1340,9 +1363,10 @@ begin
for i := 0 to ReadList.Count - 1 do begin
if (Trim(ReadList[i]) <> '') then begin
No := IntToStr(i + 1);
- Res := DivideStrLine(ReadList[i]);
- Res.FBody := AddAnchorTag(Res.FBody);
- Res.FBody := ConvertResAnchor(ConvRes(Res.FBody, ThreadItem.ParentBoard.BBSID, ChangeFileExt(ThreadItem.FileName, ''), 'bbs', 'key', 'st', 'to', 'nofirst', 'true', true));
+ DivideStrLine(ReadList[i], @Res);
+ AddAnchorTag(@Res);
+ ConvRes(@Res, @ResLink, true);
+ ConvertResAnchor(@Res);
if Res.FMailTo = '' then
html.Append(' '
+ '