dw_htmlchm.inc 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609
  1. {%mainunit dw_html}
  2. {$IFDEF chmInterface}
  3. type
  4. { TCHMHTMLWriter }
  5. TCHMHTMLWriter = class(THTMLWriter)
  6. private
  7. FOutChm: TStream;
  8. FChm: TChmWriter;
  9. FTempUncompressed: TStream;
  10. FTempUncompressedName: String;
  11. FChmTitle: String;
  12. FTOCName,
  13. FIndexName,
  14. FDefaultPage: String;
  15. FMakeSearchable,
  16. FNoBinToc,
  17. FNoBinIndex,
  18. FAutoTOC,
  19. FAutoIndex: Boolean;
  20. FOtherFiles: String;
  21. procedure ProcessOptions;
  22. function ResolveLinkIDAbs(const Name: String; Level : Integer = 0): DOMString;
  23. function RetrieveOtherFiles(const DataName: String; out PathInChm: String; out FileName: String; var Stream: TStream): Boolean;
  24. procedure LastFileAdded(Sender: TObject);
  25. procedure GenerateTOC;
  26. procedure GenerateIndex;
  27. public
  28. procedure WriteHTMLPages; override;
  29. function InterPretOption(const Cmd,Arg : String): boolean; override;
  30. class procedure Usage(List: TStrings); override;
  31. Class Function FileNameExtension : String; override;
  32. Class procedure SplitImport(var AFilename, ALinkPrefix: String); override;
  33. end;
  34. {$ELSE} // implementation
  35. { TCHMHTMLWriter }
  36. function TCHMHTMLWriter.ResolveLinkIDAbs(const Name: String; Level : Integer = 0): DOMString;
  37. begin
  38. Result:=UTF8Decode(FixHTMLpath(Engine.ResolveLink(Module,Name, True)));
  39. // for global index: don't make it relative to the current document.
  40. end;
  41. procedure TCHMHTMLWriter.ProcessOptions;
  42. var
  43. TempStream: TMemoryStream;
  44. begin
  45. if FDefaultPage = '' then
  46. FDefaultPage := 'index.html'
  47. else
  48. begin
  49. DoLog('Note: --index-page not assigned. Using default "index.html"');
  50. end;
  51. if FCSSFile <> '' then
  52. begin
  53. if not FileExists(FCSSFile) Then
  54. Raise Exception.CreateFmt('Can''t find CSS file "%S"',[FCSSFILE]);
  55. TempStream := TMemoryStream.Create;
  56. TempStream.LoadFromFile(FCSSFile);
  57. TempStream.Position := 0;
  58. FChm.AddStreamToArchive('fpdoc.css', '/', TempStream, True);
  59. TempStream.Free;
  60. end;
  61. FChm.DefaultPage := FDefaultPage;
  62. if FOtherFiles <> '' then
  63. begin
  64. FChm.FilesToCompress.LoadFromFile(FOtherFiles);
  65. end;
  66. FChm.FullTextSearch := FMakeSearchable;
  67. end;
  68. function TCHMHTMLWriter.RetrieveOtherFiles(const DataName: String; out
  69. PathInChm: String; out FileName: String; var Stream: TStream): Boolean;
  70. begin
  71. Result:=True;
  72. if Stream <> nil then
  73. Stream.Free;
  74. Stream := TMemoryStream.Create;
  75. TMemoryStream(Stream).LoadFromFile(DataName);
  76. FileName := ExtractFileName(DataName);
  77. if ExtractFileDir(DataName) <> '' then
  78. PathInChm := ExtractRelativepath(GetCurrentDir, ExtractFileDir(DataName))
  79. else
  80. PathInChm := '/';
  81. FixHTMLpath(PathInChm);
  82. Stream.Position := 0;
  83. end;
  84. procedure TCHMHTMLWriter.LastFileAdded(Sender: TObject);
  85. var
  86. TmpStream: TMemoryStream;
  87. begin
  88. TmpStream := TMemoryStream.Create;
  89. if FAutoTOC then
  90. GenerateTOC
  91. else
  92. if FTOCName <> '' then
  93. begin
  94. TmpStream.LoadFromFile(FTOCName);
  95. TmpStream.Position := 0;
  96. FChm.AppendTOC(TmpStream);
  97. TmpStream.Size := 0;
  98. end;
  99. if FAutoIndex then
  100. GenerateIndex
  101. else
  102. if FIndexName <> '' then
  103. begin
  104. TmpStream.LoadFromFile(FIndexName);
  105. TmpStream.Position := 0;
  106. FChm.AppendIndex(TmpStream);
  107. end;
  108. TmpStream.Free;
  109. DoLog('Finishing compressing...');
  110. end;
  111. function TOCSort(Item1, Item2: TChmSiteMapItem): Integer;
  112. begin
  113. Result := CompareText(LowerCase(Item1.Text), LowerCase(Item2.Text));
  114. end;
  115. function GetAlphaItem(AItems: TChmSiteMapItems; AName: String): TChmSiteMapItem;
  116. var
  117. x: Integer;
  118. begin
  119. Result := nil;
  120. for x := 0 to AItems.Count-1 do
  121. begin
  122. if AItems.Item[x].Text = AName then
  123. Exit(AItems.Item[x]);
  124. end;
  125. Result := AItems.NewItem;
  126. Result.Text := AName;
  127. end;
  128. procedure TCHMHTMLWriter.GenerateTOC;
  129. var
  130. TOC: TChmSiteMap;
  131. Element: TPasElement;
  132. j: Integer;
  133. i: Integer;
  134. AModule: TPasModule;
  135. Stream: TMemoryStream;
  136. TmpItem: TChmSiteMapItem;
  137. ObjByUnitItem,
  138. AlphaObjItem,
  139. ObjUnitItem,
  140. RoutinesByUnitItem,
  141. RoutinesUnitItem,
  142. AlphaRoutinesItem: TChmSiteMapItem;
  143. begin
  144. DoLog('Generating Table of contents...');
  145. if Assigned(Package) then
  146. begin
  147. Toc := TChmSiteMap.Create(stTOC);
  148. Stream := TMemoryStream.Create;
  149. ObjByUnitItem := TOC.Items.NewItem;
  150. ObjByUnitItem.Text := 'Classes and Objects, by Unit';
  151. AlphaObjItem := TOC.Items.NewItem;
  152. AlphaObjItem.Text := 'Alphabetical Classes and Objects List';
  153. RoutinesByUnitItem := TOC.Items.NewItem;
  154. RoutinesByUnitItem.Text := 'Routines, by Unit';
  155. AlphaRoutinesItem := TOC.Items.NewItem;
  156. AlphaRoutinesItem.Text := 'Alphabetical Routines List';
  157. // objects and classes
  158. for i := 0 to Package.Modules.Count - 1 do
  159. begin
  160. AModule := TPasModule(Package.Modules[i]);
  161. If not assigned(AModule.InterfaceSection) Then
  162. Continue;
  163. ObjUnitItem := ObjByUnitItem.Children.NewItem;
  164. ObjUnitItem.Text := AModule.Name;
  165. RoutinesUnitItem := RoutinesByUnitItem.Children.NewItem;
  166. RoutinesUnitItem.Text := AModule.Name;
  167. for j := 0 to AModule.InterfaceSection.Classes.Count-1 do
  168. begin
  169. Element := TPasClassType(AModule.InterfaceSection.Classes[j]);
  170. // by unit
  171. TmpItem := ObjUnitItem.Children.NewItem;
  172. TmpItem.Text := Element.Name;
  173. TmpItem.addLocal(FixHTMLpath(Allocator.GetFilename(Element, 0)));
  174. //alpha
  175. TmpItem := GetAlphaItem(AlphaObjItem.Children, UpperCase(Copy(Element.Name, 1, 2))).Children.NewItem;
  176. TmpItem.Text := Element.Name;
  177. TmpItem.addLocal(FixHTMLpath(Allocator.GetFilename(Element, 0)));
  178. end;
  179. // non object procedures and functions
  180. for j := 0 to AModule.InterfaceSection.Functions.Count-1 do
  181. begin
  182. Element := TPasFunctionType(AModule.InterfaceSection.Functions[j]);
  183. // by unit
  184. TmpItem := RoutinesUnitItem.Children.NewItem;
  185. TmpItem.Text := Element.Name;
  186. TmpItem.addLocal(FixHTMLpath(Allocator.GetFilename(Element, 0)));
  187. // alpha
  188. TmpItem := GetAlphaItem(AlphaRoutinesItem.Children, UpperCase(Element.Name[1])).Children.NewItem;
  189. TmpItem.Text := Element.Name;
  190. TmpItem.addLocal(FixHTMLpath(Allocator.GetFilename(Element, 0)));
  191. end;
  192. end;
  193. end;
  194. // cleanup
  195. for i := ObjByUnitItem.Children.Count-1 downto 0 do
  196. begin
  197. if ObjByUnitItem.Children.Item[i].Children.Count = 0 then
  198. ObjByUnitItem.Children.Delete(i);
  199. end;
  200. for i := RoutinesByUnitItem.Children.Count-1 downto 0 do
  201. begin
  202. if RoutinesByUnitItem.Children.Item[i].Children.Count = 0 then
  203. RoutinesByUnitItem.Children.Delete(i);
  204. end;
  205. for i := TOC.Items.Count-1 downto 0 do
  206. begin
  207. if TOC.Items.Item[i].Children.Count = 0 then
  208. TOC.Items.Delete(i);
  209. end;
  210. // Sort
  211. for i := 0 to TOC.Items.Count-1 do
  212. begin
  213. TOC.Items.Item[i].Children.Sort(TListSortCompare(@TOCSort));
  214. for j := 0 to TOC.Items.Item[i].Children.Count-1 do
  215. begin
  216. TOC.Items.Item[i].Children.Item[j].Children.Sort(TListSortCompare(@TOCSort));
  217. end;
  218. end;
  219. if not fnobintoc then
  220. fchm.AppendBinaryTOCFromSiteMap(Toc);
  221. TOC.SaveToStream(Stream);
  222. TOC.Free;
  223. fchm.AppendTOC(Stream);
  224. Stream.Free;
  225. end;
  226. type
  227. TClassMemberType = (cmtProcedure, cmtFunction, cmtConstructor, cmtDestructor,
  228. cmtInterface, cmtProperty, cmtVariable, cmtUnknown);
  229. function ElementType(Element: TPasElement): TClassMemberType;
  230. var
  231. ETypeName: String;
  232. begin
  233. Result := cmtUnknown;
  234. ETypeName := Element.ElementTypeName;
  235. //overloaded we don't care
  236. if ETypeName[1] = 'o' then ETypeName := Copy(ETypeName, 11, Length(ETypeName));
  237. if ETypeName[1] = 'f' then Exit(cmtFunction);
  238. if ETypeName[1] = 'c' then Exit(cmtConstructor);
  239. if ETypeName[1] = 'v' then Exit(cmtVariable);
  240. if ETypeName[1] = 'i' then Exit(cmtInterface);
  241. // the p's
  242. if ETypeName[4] = 'c' then Exit(cmtProcedure);
  243. if ETypeName[4] = 'p' then Exit(cmtProperty);
  244. end;
  245. procedure TCHMHTMLWriter.GenerateIndex;
  246. var
  247. Index: TChmSiteMap;
  248. i, j, k: Integer;
  249. TmpItem: TChmSiteMapItem;
  250. ParentItem: TChmSiteMapItem;
  251. AModule: TPasModule;
  252. TmpElement: TPasElement;
  253. ParentElement: TPasElement;
  254. MemberItem: TChmSiteMapItem;
  255. Stream: TMemoryStream;
  256. RedirectUrl,Urls: String;
  257. begin
  258. DoLog('Generating Index...');
  259. if Assigned(Package) then
  260. begin
  261. Index := TChmSiteMap.Create(stIndex);
  262. Stream := TMemoryStream.Create;
  263. for i := 0 to Package.Modules.Count - 1 do
  264. begin
  265. AModule := TPasModule(Package.Modules[i]);
  266. if not assigned(AModule.InterfaceSection) then
  267. continue;
  268. ParentItem := Index.Items.NewItem;
  269. ParentItem.Text := AModule.Name;
  270. ParentItem.addLocal(FixHTMLpath(Allocator.GetFilename(AModule, 0)));
  271. // classes
  272. for j := 0 to AModule.InterfaceSection.Classes.Count-1 do
  273. begin
  274. ParentElement := TPasClassType(AModule.InterfaceSection.Classes[j]);
  275. ParentItem := Index.Items.NewItem;
  276. ParentItem.Text := ParentELement.Name;
  277. ParentItem.addLocal(FixHTMLpath(Allocator.GetFilename(ParentElement, 0)));
  278. for k := 0 to TPasClassType(ParentElement).Members.Count-1 do
  279. begin
  280. TmpElement := TPasElement(TPasClassType(ParentElement).Members.Items[k]);
  281. if Engine.HidePrivate and(TmpElement.Visibility = visPrivate) then
  282. continue;
  283. if Engine.HideProtected and(TmpElement.Visibility = visProtected) then
  284. continue;
  285. Urls:=FixHTMLpath(Allocator.GetFilename(TmpElement, 0));
  286. RedirectUrl:='';
  287. if TmpElement is TPasEnumValue then
  288. RedirectUrl := UTF8Encode(ResolveLinkIDAbs(tmpElement.Parent.PathName))
  289. else
  290. RedirectUrl := UTF8Encode(ResolveLinkIDAbs(tmpElement.PathName));
  291. if(trim(RedirectUrl)<>'') and (RedirectUrl<>urls) then
  292. begin
  293. writeln('Hint: Index Resolved:',urls,' to ',RedirectUrl);
  294. urls:=RedirectUrl;
  295. end;
  296. TmpItem := ParentItem.Children.NewItem;
  297. case ElementType(TmpElement) of
  298. cmtProcedure : TmpItem.Text := TmpElement.Name + ' procedure';
  299. cmtFunction : TmpItem.Text := TmpElement.Name + ' function';
  300. cmtConstructor : TmpItem.Text := TmpElement.Name + ' constructor';
  301. cmtDestructor : TmpItem.Text := TmpElement.Name + ' destructor';
  302. cmtProperty : TmpItem.Text := TmpElement.Name + ' property';
  303. cmtVariable : TmpItem.Text := TmpElement.Name + ' variable';
  304. cmtInterface : TmpItem.Text := TmpElement.Name + ' interface';
  305. cmtUnknown : TmpItem.Text := TmpElement.Name;
  306. end;
  307. TmpItem.addLocal(Urls);
  308. {
  309. ParentElement = Class
  310. TmpElement = Member
  311. }
  312. MemberItem := nil;
  313. MemberItem := GetAlphaItem(Index.Items, TmpElement.Name);
  314. // ahh! if MemberItem.Local is empty MemberType is not shown!
  315. MemberItem.addLocal(Urls);
  316. TmpItem := MemberItem.Children.NewItem;
  317. TmpItem.Text := ParentElement.Name;
  318. TmpItem.AddLocal(Urls);
  319. end;
  320. end;
  321. // routines
  322. for j := 0 to AModule.InterfaceSection.Functions.Count-1 do
  323. begin
  324. ParentElement := TPasProcedureType(AModule.InterfaceSection.Functions[j]);
  325. TmpItem := Index.Items.NewItem;
  326. TmpItem.Text := ParentElement.Name + ' ' + ParentElement.ElementTypeName;
  327. TmpItem.addLocal(FixHTMLpath(Allocator.GetFilename(ParentElement, 0)));
  328. end;
  329. // consts
  330. for j := 0 to AModule.InterfaceSection.Consts.Count-1 do
  331. begin
  332. ParentElement := TPasElement(AModule.InterfaceSection.Consts[j]);
  333. TmpItem := Index.Items.NewItem;
  334. TmpItem.Text := ParentElement.Name;
  335. TmpItem.addLocal(FixHTMLpath(Allocator.GetFilename(ParentElement, 0)));
  336. end;
  337. // types
  338. for j := 0 to AModule.InterfaceSection.Types.Count-1 do
  339. begin
  340. ParentElement := TPasType(AModule.InterfaceSection.Types[j]);
  341. TmpItem := Index.Items.NewItem;
  342. TmpItem.Text := ParentElement.Name;
  343. TmpItem.addLocal(FixHTMLpath(Allocator.GetFilename(ParentElement, 0)));
  344. // enums
  345. if ParentELement is TPasEnumType then
  346. begin
  347. ParentItem := TmpItem;
  348. for k := 0 to TPasEnumType(ParentElement).Values.Count-1 do
  349. begin
  350. TmpElement := TPasType(TPasEnumType(ParentElement).Values.Items[k]);
  351. // subitem
  352. TmpItem := ParentItem.Children.NewItem;
  353. TmpItem.Text := TmpElement.Name;
  354. TmpItem.addLocal(ParentItem.Local);
  355. // root level
  356. TmpItem := Index.Items.NewItem;
  357. TmpItem.Text := TmpElement.Name;
  358. TmpItem.addLocal(ParentItem.Local);
  359. end;
  360. end;
  361. end;
  362. // variables
  363. for j := 0 to AModule.InterfaceSection.Variables.Count-1 do
  364. begin
  365. ParentElement := TPasElement(AModule.InterfaceSection.Variables[j]);
  366. TmpItem := Index.Items.NewItem;
  367. TmpItem.Text := ParentElement.Name + ' var';
  368. TmpItem.addLocal(FixHTMLpath(Allocator.GetFilename(ParentElement, 0)));
  369. end;
  370. // declarations
  371. {
  372. for j := 0 to AModule.InterfaceSection.Declarations.Count-1 do
  373. begin
  374. ParentElement := TPasElement(AModule.InterfaceSection.Declarations[j]);
  375. TmpItem := Index.Items.NewItem;
  376. TmpItem.Text := ParentElement.Name;
  377. TmpItem.Local := FixHTMLpath(Allocator.GetFilename(ParentElement, 0));
  378. end;
  379. // resource strings
  380. for j := 0 to AModule.InterfaceSection.ResStrings.Count-1 do
  381. begin
  382. ParentElement := TPasElement(AModule.InterfaceSection.ResStrings[j]);
  383. TmpItem := Index.Items.NewItem;
  384. TmpItem.Text := ParentElement.Name;
  385. TmpItem.Local := FixHTMLpath(Allocator.GetFilename(ParentElement, 0));
  386. end;
  387. }
  388. end;
  389. // Sort
  390. Index.Items.Sort(TListSortCompare(@TOCSort));
  391. for i := 0 to Index.Items.Count-1 do
  392. begin
  393. Index.Items.Item[i].Children.Sort(TListSortCompare(@TOCSort));
  394. end;
  395. // save
  396. Index.SaveToStream(Stream);
  397. if not fnobinindex then
  398. fchm.AppendBinaryindexFromSitemap(index,false);
  399. Index.Free;
  400. Stream.Position :=0 ;
  401. FChm.AppendIndex(Stream);
  402. Stream.Free;
  403. end;
  404. end;
  405. procedure TCHMHTMLWriter.WriteHTMLPages;
  406. var
  407. i: Integer;
  408. PageDoc: TXMLDocument;
  409. FileStream: TMemoryStream;
  410. FileName: String;
  411. FilePath: String;
  412. begin
  413. FileName := Engine.Output;
  414. if FileName = '' then
  415. Raise Exception.Create('Error: no --output option used.');
  416. if ExtractFileExt(FileName) <> FileNameExtension then
  417. FileName := ChangeFileExt(FileName, FileNameExtension);
  418. FOutChm := TFileStream.Create(FileName, fmOpenReadWrite or fmCreate);
  419. FTempUncompressedName := GetTempFileName+IntToStr(GetProcessID) +'.raw';
  420. FTempUncompressed := TFileStream.Create(FTempUncompressedName, fmOpenReadWrite or fmCreate);
  421. FChm := TChmWriter.Create(FOutChm, False);
  422. FChm.Title := FChmTitle;
  423. FChm.TempRawStream := FTempUncompressed;
  424. FChm.OnGetFileData := @RetrieveOtherFiles;
  425. FChm.OnLastFile := @LastFileAdded;
  426. fchm.hasbinarytoc:=not fnobintoc;;
  427. fchm.hasbinaryindex:=not fnobinindex;
  428. ProcessOptions;
  429. FileStream := TMemoryStream.Create;
  430. for i := 0 to PageInfos.Count - 1 do
  431. with TPageInfo(PageInfos[i]) do
  432. begin
  433. PageDoc := CreateHTMLPage(Element, SubpageIndex);
  434. try
  435. FileName := ExtractFileName(Allocator.GetFilename(Element, SubpageIndex));
  436. FilePath := '/'+FixHTMLpath(ExtractFilePath(Allocator.GetFilename(Element, SubpageIndex)));
  437. try
  438. WriteHTMLFile(PageDoc, FileStream);
  439. FChm.AddStreamToArchive(FileName, FilePath, FileStream, True);
  440. except
  441. on E: Exception do
  442. DoLog(Format(SErrCouldNotCreateFile, [FileName, e.Message]));
  443. end;
  444. finally
  445. PageDoc.Free;
  446. FileStream.Size := 0;
  447. end;
  448. end;
  449. FileStream.Free;
  450. DoLog('HTML Files written. Collecting other files and compressing...this could take some time');
  451. //write any found images to CHM stream
  452. FileStream := TMemoryStream.Create;
  453. for i := 0 to FImageFileList.Count - 1 do
  454. begin
  455. {$ifdef imagetest} DoLog(' adding image: '+FImageFileList[i]); {$endif}
  456. if FileExists(FImageFileList[i]) then
  457. begin
  458. {$ifdef imagetest} DoLog(' - found'); {$endif}
  459. FileName := ExtractFileName(FImageFileList[i]);
  460. FilePath := '/'+FixHTMLpath(ExtractFilePath(FImageFileList[i]));
  461. FileStream.LoadFromFile(FImageFileList[i]);
  462. FChm.AddStreamToArchive(FileName, FilePath, FileStream, True);
  463. FileStream.Size := 0;
  464. end
  465. else
  466. {$ifdef imagetest} DoLog(' - not found'){$endif};
  467. end;
  468. FileStream.Free;
  469. FChm.Execute;
  470. FChm.Free;
  471. // we don't need to free FTempUncompressed
  472. // FTempUncompressed.Free;
  473. FOutChm.Free;
  474. DeleteFile(FTempUncompressedName);
  475. end;
  476. function TCHMHTMLWriter.InterPretOption(const Cmd, Arg: String): boolean;
  477. begin
  478. Result:=True;
  479. FNoBinToc:=False;
  480. FnoBinIndex:=False;
  481. if Cmd = '--toc-file' then
  482. FTOCName := arg
  483. else if Cmd = '--index-file' then
  484. FIndexName := arg
  485. else if Cmd = '--default-page' then
  486. FDefaultPage := arg
  487. else if Cmd = '--other-files' then
  488. FOtherFiles := arg
  489. else if Cmd = '--auto-index' then
  490. FAutoIndex := True
  491. else if Cmd = '--auto-toc' then
  492. FAutoTOC := True
  493. else if Cmd = '--no-bintoc' then
  494. FNoBinToc := True
  495. else if Cmd = '--no-binindex' then
  496. FNoBinIndex := True
  497. else if Cmd = '--make-searchable' then
  498. FMakeSearchable := True
  499. else if Cmd = '--chm-title' then
  500. FChmTitle := arg
  501. else
  502. Result:=inherited InterPretOption(Cmd, Arg);
  503. if Length(FChmTitle) = 0 then
  504. FChmTitle := Copy(Package.Name, 2, Length(Package.Name));
  505. end;
  506. class procedure TCHMHTMLWriter.Usage(List: TStrings);
  507. begin
  508. THTMLWriter.Usage(List);
  509. List.add('--default-page');
  510. List.Add(SCHMUsageDefPage);
  511. List.add('--toc-file');
  512. List.Add(SCHMUsageTOC);
  513. List.add('--index-file');
  514. List.Add(SCHMUsageIndex);
  515. List.add('--other-files');
  516. List.Add(SCHMUsageOtrFiles);
  517. List.add('--css-file');
  518. List.Add(SCHMUsageCSSFile);
  519. List.add('--auto-index');
  520. List.Add(SCHMUsageAutoIDX);
  521. List.add('--auto-toc');
  522. List.Add(SCHMUsageAutoTOC);
  523. List.add('--make-searchable');
  524. List.Add(SCHMUsageMakeSearch);
  525. List.Add('--chm-title');
  526. List.Add(SCHMUsageChmTitle);
  527. end;
  528. Class Function TCHMHTMLWriter.FileNameExtension : String;
  529. begin
  530. result:='.chm';
  531. end;
  532. class procedure TCHMHTMLWriter.SplitImport(var AFilename, ALinkPrefix: String);
  533. var
  534. i: integer;
  535. begin
  536. i := Pos(',', AFilename);
  537. if i > 0 then
  538. begin //split into filename and prefix
  539. ALinkPrefix := Copy(AFilename,i+1,Length(AFilename));
  540. SetLength(AFilename, i-1);
  541. end
  542. else if ALinkPrefix = '' then
  543. begin //synthesize outdir\pgk.xct, ms-its:pkg.chm::/
  544. ALinkPrefix := 'ms-its:' + ChangeFileExt(ExtractFileName(AFilename), '.chm') + '::/';
  545. AFilename := ChangeFileExt(AFilename, '.xct');
  546. end;
  547. end;
  548. {$ENDIF}