browserconsole.pas 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. unit browserconsole;
  2. {$mode objfpc}
  3. interface
  4. uses
  5. js,web;
  6. Const
  7. BrowserLineBreak = #10;
  8. DefaultMaxConsoleLines = 25;
  9. DefaultConsoleStyle = '.pasconsole { '+BrowserLineBreak+
  10. 'font-family: courier;'+BrowserLineBreak+
  11. 'font-size: 14px;'+BrowserLineBreak+
  12. 'background: #FFFFFF;'+BrowserLineBreak+
  13. 'color: #000000;'+BrowserLineBreak+
  14. 'display: block;'+BrowserLineBreak+
  15. '}';
  16. DefaultCRTConsoleStyle = '.pasconsole { '+BrowserLineBreak+
  17. 'font-family: courier;'+BrowserLineBreak+
  18. 'font-size: 14px;'+BrowserLineBreak+
  19. 'background: #000;'+BrowserLineBreak+
  20. 'color: #14fdce;'+BrowserLineBreak+
  21. 'display: block;'+BrowserLineBreak+
  22. '}';
  23. Var
  24. // Element ID for console output. If this is not set, body is used.
  25. // If you cange this, call HookConsole.
  26. ConsoleElementID : String;
  27. // Style to use for console lines. If you change this, call initconsole
  28. ConsoleStyle : String;
  29. // Style to use for console lines. You can change this at any time.
  30. MaxConsoleLines : Integer;
  31. // Copy console lines on newline to browser console log
  32. ConsoleLinesToBrowserLog : Boolean;
  33. // Clear console content
  34. Procedure ResetConsole;
  35. // Re-initialize console (style)
  36. Procedure InitConsole;
  37. // Re-hook console
  38. Procedure HookConsole;
  39. implementation
  40. Var
  41. LastLine,
  42. StyleElement,
  43. LinesParent,
  44. ConsoleElement : TJSElement;
  45. Procedure AppendLine;
  46. Var
  47. CurrentCount : Integer;
  48. S : TJSNode;
  49. begin
  50. CurrentCount:=0;
  51. S:=LinesParent.firstChild;
  52. While Assigned(S) do
  53. begin
  54. Inc(CurrentCount);
  55. S:=S.nextSibling;
  56. end;
  57. While CurrentCount>MaxConsoleLines do
  58. begin
  59. Dec(CurrentCount);
  60. LinesParent.removeChild(LinesParent.firstChild);
  61. end;
  62. LastLine:=Document.createElement('div');
  63. LastLine.className:='pasconsole';
  64. LinesParent.AppendChild(LastLine);
  65. end;
  66. Procedure WriteConsole(S : JSValue; NewLine : Boolean);
  67. Var
  68. CL: String;
  69. begin
  70. // Maybe add some way to limit line length
  71. CL:=LastLine.InnerText;
  72. CL:=CL+String(S);
  73. LastLine.InnerText:=CL;
  74. if NewLine then
  75. begin
  76. if ConsoleLinesToBrowserLog then
  77. console.log(CL);
  78. AppendLine;
  79. end;
  80. end;
  81. Procedure ResetConsole;
  82. begin
  83. if LinesParent=Nil then exit;
  84. While LinesParent.firstElementChild<>Nil do
  85. LinesParent.removeChild(LinesParent.firstElementChild);
  86. AppendLine;
  87. end;
  88. Procedure InitConsole;
  89. begin
  90. if ConsoleElement=Nil then
  91. exit;
  92. if (TJSString(ConsoleElement.nodeName).toLowerCase<>'body') then
  93. begin
  94. While ConsoleElement.firstElementChild<>Nil do
  95. ConsoleElement.removeChild(ConsoleElement.firstElementChild);
  96. end;
  97. StyleElement:=Document.createElement('style');
  98. StyleElement.innerText:=ConsoleStyle;
  99. ConsoleElement.appendChild(StyleElement);
  100. LinesParent:=Document.createElement('div');
  101. ConsoleElement.appendChild(LinesParent);
  102. end;
  103. Procedure HookConsole;
  104. begin
  105. ConsoleElement:=Nil;
  106. if (ConsoleElementID<>'') then
  107. ConsoleElement:=document.getElementById(ConsoleElementID);
  108. if (ConsoleElement=Nil) then
  109. ConsoleElement:=document.body;
  110. if ConsoleElement=Nil then
  111. exit;
  112. InitConsole;
  113. ResetConsole;
  114. SetWriteCallBack(@WriteConsole);
  115. end;
  116. initialization
  117. ConsoleLinesToBrowserLog:=True;
  118. ConsoleElementID:='pasjsconsole';
  119. ConsoleStyle:=DefaultConsoleStyle;
  120. MaxConsoleLines:=DefaultMaxConsoleLines;
  121. HookConsole;
  122. end.