nadesiko3 3.3.45 → 3.3.49

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (329) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +143 -132
  3. package/batch/browsers.template.md +3 -3
  4. package/batch/build_browsers.nako3 +72 -72
  5. package/batch/build_command.nako3 +44 -44
  6. package/batch/build_nako_version.nako3 +42 -42
  7. package/batch/calc_hash.nako3 +29 -29
  8. package/batch/cmd_txt2json.nako3 +74 -74
  9. package/batch/command.txt +270 -338
  10. package/batch/command_nakopad.txt +9 -69
  11. package/batch/download-extlib.nako3 +43 -43
  12. package/batch/gen_command_nakopad.nako3 +57 -57
  13. package/batch/jsplugin2text.nako3 +285 -285
  14. package/batch/pickup_command.nako3 +110 -110
  15. package/batch/pickup_reserved_words.nako3 +11 -11
  16. package/batch/publish_version.nako3 +46 -46
  17. package/batch/show_agents.js +14 -14
  18. package/batch/turtle2js.nako3 +21 -21
  19. package/bin/cnako3 +10 -10
  20. package/core/.editorconfig +6 -0
  21. package/core/.eslintrc.cjs +33 -0
  22. package/core/.github/dependabot.yml +7 -0
  23. package/core/.github/workflows/nodejs.yml +37 -0
  24. package/core/.github/workflows/super-linter.yml +61 -0
  25. package/core/.github/workflows/textlint.yml +199 -0
  26. package/core/LICENSE +21 -0
  27. package/core/README.md +66 -0
  28. package/core/batch/build_nako_version.nako3 +42 -0
  29. package/core/command/snako.mjs +105 -0
  30. package/core/command/snako.mts +116 -0
  31. package/core/index.mjs +21 -0
  32. package/core/index.mts +21 -0
  33. package/core/package.json +47 -0
  34. package/core/sample/hello.nako3 +7 -0
  35. package/core/sample/hoge.mjs +4 -0
  36. package/core/sample/hoge.mts +6 -0
  37. package/core/src/nako3.mjs +858 -0
  38. package/core/src/nako3.mts +967 -0
  39. package/core/src/nako_colors.mjs +78 -0
  40. package/core/src/nako_colors.mts +86 -0
  41. package/core/src/nako_core_version.mjs +8 -0
  42. package/core/src/nako_core_version.mts +19 -0
  43. package/core/src/nako_csv.mjs +185 -0
  44. package/core/src/nako_csv.mts +188 -0
  45. package/core/src/nako_errors.mjs +173 -0
  46. package/core/src/nako_errors.mts +197 -0
  47. package/core/src/nako_from_dncl.mjs +255 -0
  48. package/core/src/nako_from_dncl.mts +250 -0
  49. package/core/src/nako_gen.mjs +1648 -0
  50. package/core/src/nako_gen.mts +1719 -0
  51. package/core/src/nako_gen_async.mjs +1659 -0
  52. package/core/src/nako_gen_async.mts +1732 -0
  53. package/core/src/nako_global.mjs +107 -0
  54. package/core/src/nako_global.mts +138 -0
  55. package/core/src/nako_indent.mjs +445 -0
  56. package/core/src/nako_indent.mts +492 -0
  57. package/core/src/nako_josi_list.mjs +38 -0
  58. package/core/src/nako_josi_list.mts +45 -0
  59. package/core/src/nako_lex_rules.mjs +253 -0
  60. package/core/src/nako_lex_rules.mts +260 -0
  61. package/core/src/nako_lexer.mjs +609 -0
  62. package/core/src/nako_lexer.mts +612 -0
  63. package/core/src/nako_logger.mjs +199 -0
  64. package/core/src/nako_logger.mts +232 -0
  65. package/core/src/nako_parser3.mjs +2439 -0
  66. package/core/src/nako_parser3.mts +2195 -0
  67. package/core/src/nako_parser_base.mjs +370 -0
  68. package/core/src/nako_parser_base.mts +370 -0
  69. package/core/src/nako_parser_const.mjs +37 -0
  70. package/core/src/nako_parser_const.mts +37 -0
  71. package/core/src/nako_prepare.mjs +304 -0
  72. package/core/src/nako_prepare.mts +315 -0
  73. package/core/src/nako_reserved_words.mjs +38 -0
  74. package/core/src/nako_reserved_words.mts +38 -0
  75. package/core/src/nako_source_mapping.mjs +207 -0
  76. package/core/src/nako_source_mapping.mts +262 -0
  77. package/core/src/nako_test.mjs +37 -0
  78. package/core/src/nako_types.mjs +25 -0
  79. package/core/src/nako_types.mts +151 -0
  80. package/core/src/plugin_csv.mjs +49 -0
  81. package/core/src/plugin_csv.mts +50 -0
  82. package/core/src/plugin_math.mjs +328 -0
  83. package/core/src/plugin_math.mts +326 -0
  84. package/core/src/plugin_promise.mjs +91 -0
  85. package/core/src/plugin_promise.mts +91 -0
  86. package/core/src/plugin_system.mjs +2832 -0
  87. package/core/src/plugin_system.mts +2690 -0
  88. package/core/src/plugin_test.mjs +34 -0
  89. package/core/src/plugin_test.mts +34 -0
  90. package/core/test/array_test.mjs +34 -0
  91. package/core/test/basic_test.mjs +344 -0
  92. package/core/test/calc_test.mjs +140 -0
  93. package/core/test/core_module_test.mjs +23 -0
  94. package/core/test/debug_test.mjs +16 -0
  95. package/core/test/dncl_test.mjs +94 -0
  96. package/core/test/error_message_test.mjs +210 -0
  97. package/core/test/error_test.mjs +16 -0
  98. package/core/test/flow_test.mjs +373 -0
  99. package/core/test/func_call.mjs +160 -0
  100. package/core/test/func_test.mjs +149 -0
  101. package/core/test/indent_test.mjs +364 -0
  102. package/core/test/lex_test.mjs +168 -0
  103. package/core/test/literal_test.mjs +73 -0
  104. package/core/test/nako_lexer_test.mjs +35 -0
  105. package/core/test/nako_logger_test.mjs +76 -0
  106. package/core/test/nako_logger_test.mts +78 -0
  107. package/core/test/plugin_csv_test.mjs +38 -0
  108. package/core/test/plugin_promise_test.mjs +18 -0
  109. package/core/test/plugin_system_test.mjs +630 -0
  110. package/core/test/prepare_test.mjs +96 -0
  111. package/core/test/re_test.mjs +22 -0
  112. package/core/test/side_effects_test.mjs +92 -0
  113. package/core/test/variable_scope_test.mjs +149 -0
  114. package/core/tsconfig.json +101 -0
  115. package/demo/ace_editor.html +89 -89
  116. package/demo/ace_editor_tabs.html +161 -161
  117. package/demo/basic.html +71 -71
  118. package/demo/browsers.html +9 -10
  119. package/demo/css/basic.css +3 -3
  120. package/demo/css/common.css +157 -157
  121. package/demo/css/editor.css +8 -8
  122. package/demo/css/flow.css +3 -3
  123. package/demo/css/index.css +3 -3
  124. package/demo/flow.html +98 -98
  125. package/demo/graph.html +53 -53
  126. package/demo/image/nakopad-icon256.png +0 -0
  127. package/demo/index.html +133 -133
  128. package/demo/js/common.js +17 -17
  129. package/demo/js/turtle3d_test.js +44 -44
  130. package/demo/js/turtle_test.js +45 -45
  131. package/demo/nako3/calc.nako3 +4 -4
  132. package/demo/runscript.html +47 -47
  133. package/demo/runscript2.html +33 -33
  134. package/demo/runscript3.html +35 -35
  135. package/demo/runscript4.html +33 -33
  136. package/demo/turtle.html +58 -58
  137. package/demo/turtle2.html +141 -141
  138. package/demo/turtle3.html +279 -279
  139. package/demo/turtle3d.html +58 -58
  140. package/demo/turtle3d2.html +107 -107
  141. package/demo/version.html +24 -24
  142. package/doc/SETUP.md +157 -157
  143. package/doc/about.md +17 -17
  144. package/doc/browsers.md +26 -26
  145. package/doc/docgen.md +21 -21
  146. package/doc/editor.md +44 -44
  147. package/doc/files.md +39 -39
  148. package/doc/plugins.md +234 -234
  149. package/doc/release.md +79 -79
  150. package/doc/textlint.md +43 -43
  151. package/doc/win32.md +57 -57
  152. package/package.json +195 -192
  153. package/release/_hash.txt +28 -28
  154. package/release/_script-tags.txt +14 -14
  155. package/release/command.json +1 -1
  156. package/release/command.json.js +1 -1
  157. package/release/command_cnako3.json +1 -1
  158. package/release/command_list.json +1 -1
  159. package/release/editor.js +1 -1
  160. package/release/nako_gen_async.js +1 -1
  161. package/release/plugin_csv.js +1 -1
  162. package/release/stats.json +1 -1
  163. package/release/version.js +1 -1
  164. package/release/wnako3.js +1 -1
  165. package/release/wnako3webworker.js +1 -1
  166. package/src/browsers.txt +11 -12
  167. package/src/browsers_agents.json +2 -2
  168. package/src/browsers_agents.mjs +1 -1
  169. package/src/cnako3.mjs +17 -10
  170. package/src/cnako3.mts +18 -12
  171. package/src/cnako3mod.mjs +707 -687
  172. package/src/cnako3mod.mts +712 -696
  173. package/src/commander_ja.mjs +164 -164
  174. package/src/commander_ja.mts +161 -161
  175. package/src/enako3.mjs +68 -69
  176. package/src/era.mjs +22 -22
  177. package/src/image_turtle-elephant.mjs +2 -5
  178. package/src/image_turtle-panda.mjs +2 -5
  179. package/src/image_turtle64.mjs +2 -5
  180. package/src/index.mjs +9 -9
  181. package/src/index.mts +10 -11
  182. package/src/nako3editorfix.sfd +106 -106
  183. package/src/nako_version.mjs +8 -8
  184. package/src/nako_version.mts +2 -2
  185. package/src/plugin_browser.mjs +213 -212
  186. package/src/plugin_browser.mts +206 -205
  187. package/src/plugin_browser_ajax.mjs +399 -399
  188. package/src/plugin_browser_audio.mjs +109 -109
  189. package/src/plugin_browser_canvas.mjs +449 -449
  190. package/src/plugin_browser_chart.mjs +294 -294
  191. package/src/plugin_browser_color.mjs +49 -49
  192. package/src/plugin_browser_crypto.mjs +26 -26
  193. package/src/plugin_browser_dialog.mjs +53 -53
  194. package/src/plugin_browser_dom_basic.mjs +336 -336
  195. package/src/plugin_browser_dom_event.mjs +193 -193
  196. package/src/plugin_browser_dom_parts.mjs +396 -396
  197. package/src/plugin_browser_geolocation.mjs +51 -51
  198. package/src/plugin_browser_hotkey.mjs +25 -25
  199. package/src/plugin_browser_html.mjs +59 -59
  200. package/src/plugin_browser_in_worker.mjs +45 -45
  201. package/src/plugin_browser_location.mjs +21 -21
  202. package/src/plugin_browser_speech.mjs +111 -111
  203. package/src/plugin_browser_storage.mjs +121 -121
  204. package/src/plugin_browser_system.mjs +31 -31
  205. package/src/plugin_browser_websocket.mjs +73 -73
  206. package/src/plugin_caniuse.mjs +29 -29
  207. package/src/plugin_datetime.mjs +394 -394
  208. package/src/plugin_httpserver.mjs +277 -0
  209. package/src/plugin_httpserver.mts +286 -0
  210. package/src/plugin_kansuji.mjs +224 -224
  211. package/src/plugin_keigo.mjs +55 -55
  212. package/src/plugin_markup.mjs +32 -32
  213. package/src/plugin_node.mjs +1047 -1047
  214. package/src/plugin_node.mts +980 -980
  215. package/src/plugin_turtle.mjs +647 -647
  216. package/src/plugin_webworker.mjs +334 -334
  217. package/src/plugin_weykturtle3d.mjs +1214 -1214
  218. package/src/plugin_worker.mjs +95 -95
  219. package/src/repl.nako3 +63 -63
  220. package/src/wnako3.mjs +12 -12
  221. package/src/wnako3.mts +11 -11
  222. package/src/wnako3_editor.css +215 -215
  223. package/src/wnako3_editor.mjs +1542 -1542
  224. package/src/wnako3_editor.mts +1657 -1656
  225. package/src/wnako3mod.mjs +213 -213
  226. package/src/wnako3mod.mts +214 -214
  227. package/src/wnako3webworker.mjs +69 -68
  228. package/test/ace_editor/karma.config.js +94 -94
  229. package/test/ace_editor/test/.babelrc.json +3 -3
  230. package/test/ace_editor/test/ace_editor_test.js +178 -178
  231. package/test/ace_editor/test/html/custom_context.html +139 -139
  232. package/test/async/async_basic_test.mjs +122 -122
  233. package/test/browser/karma.config.js +221 -221
  234. package/test/browser/test/.babelrc.json +3 -3
  235. package/test/browser/test/compare_util.js +50 -50
  236. package/test/browser/test/html/div_basic.html +2 -2
  237. package/test/browser/test/html/event_dom_form.html +4 -4
  238. package/test/browser/test/html/event_dom_scrolldiv.html +5 -5
  239. package/test/browser/test/import_plugin_checker.js +24 -24
  240. package/test/browser/test/plugin_browser_test.js +51 -51
  241. package/test/browser/test/plugin_browser_test_ajax.js +123 -123
  242. package/test/browser/test/plugin_browser_test_color.js +18 -18
  243. package/test/browser/test/plugin_browser_test_dialog.js +72 -72
  244. package/test/browser/test/plugin_browser_test_dom_event.js +598 -598
  245. package/test/browser/test/plugin_browser_test_dom_parts.js +125 -125
  246. package/test/browser/test/plugin_browser_test_system.js +9 -9
  247. package/test/browser/test/plugin_turtle_test.js +817 -817
  248. package/test/browser/test/plugin_webworker_test.js +86 -86
  249. package/test/browser/test/require_test.js +68 -68
  250. package/test/bundled/karma.config.base.js +117 -117
  251. package/test/bundled/karma.config.js +86 -86
  252. package/test/bundled/test/.babelrc.json +3 -3
  253. package/test/bundled/test/bundled_test.js +69 -69
  254. package/test/bundled/test/html/custom_context.html +65 -65
  255. package/test/bundled/test/html/custom_debug.html +66 -66
  256. package/test/bundled/test4b.cmd +52 -52
  257. package/test/bundled/test_base/.babelrc.json +3 -3
  258. package/test/bundled/test_base/_checktool_test.js +25 -25
  259. package/test/bundled/test_base/basic_ajax_test.js +56 -56
  260. package/test/bundled/test_base/basic_async_test.js +18 -18
  261. package/test/bundled/test_base/basic_test.js +153 -153
  262. package/test/bundled/test_base/calc_test.js +132 -132
  263. package/test/bundled/test_base/css/browsers_box.css +114 -114
  264. package/test/bundled/test_base/html/custom_context.html +69 -69
  265. package/test/bundled/test_base/html/custom_debug.html +71 -71
  266. package/test/bundled/test_base/js/browsers_box.js +72 -72
  267. package/test/bundled/test_base/plugin_csv_test.js +37 -37
  268. package/test/bundled/test_base/plugin_datetime_test.js +115 -115
  269. package/test/bundled/test_base/plugin_kansuji_test.js +49 -49
  270. package/test/bundled/test_base/plugin_system_test.js +410 -410
  271. package/test/bundled/test_base/plugin_webworker_test.js +53 -53
  272. package/test/bundled/test_base/test_utils.js +191 -191
  273. package/test/common/plugin_browser_test.mjs +22 -24
  274. package/test/common/plugin_browser_ut_audio_test.mjs +108 -108
  275. package/test/common/plugin_browser_ut_color_test.mjs +21 -21
  276. package/test/common/plugin_browser_ut_dialog_test.mjs +100 -100
  277. package/test/common/plugin_browser_ut_html_test.mjs +13 -13
  278. package/test/common/plugin_browser_ut_system_test.mjs +10 -10
  279. package/test/common/plugin_markup_test.mjs +23 -23
  280. package/test/jsconfig.json +19 -19
  281. package/test/karma.config.js +91 -91
  282. package/test/node/async_test.mjs +96 -82
  283. package/test/node/commander_ja_test.mjs +89 -89
  284. package/test/node/error_message_test.mjs +243 -253
  285. package/test/node/kai_test.nako3 +6 -6
  286. package/test/node/node_test.mjs +60 -60
  287. package/test/node/plugin_broken.js.txt +3 -3
  288. package/test/node/plugin_browser_ut_ajax_test.mjs.todo +357 -357
  289. package/test/node/plugin_browser_ut_location_test.mjs +42 -42
  290. package/test/node/plugin_markup_test.mjs +47 -46
  291. package/test/node/plugin_math_test.mjs +45 -44
  292. package/test/node/plugin_node_test.mjs +98 -97
  293. package/test/node/plugin_test.mjs +44 -43
  294. package/test/node/relative_import_test_1.nako3 +1 -1
  295. package/test/node/relative_import_test_2.nako3 +2 -2
  296. package/test/node/require_nako3_test.mjs +67 -66
  297. package/test/node/requiretest.nako3 +4 -4
  298. package/test/node/requiretest_indirect.nako3 +1 -1
  299. package/test/node/requiretest_name.nako3 +5 -5
  300. package/test/node/runtime_error.nako3 +2 -2
  301. package/test/node/scope1.nako3 +10 -10
  302. package/test/node/scope2.nako3 +12 -12
  303. package/test/node/side_effects_test.mjs +39 -119
  304. package/test/node/sjis.txt +5 -5
  305. package/test/node/syntax_error.nako3 +1 -1
  306. package/test/node/wnako3_editor_test.mjs +384 -384
  307. package/tools/README.md +12 -7
  308. package/tools/check_new_version.nako3 +25 -25
  309. package/tools/nako3edit/html/daisyui/LICENSE +22 -22
  310. package/tools/nako3edit/html/daisyui/version_2.14.1 +1 -1
  311. package/tools/nako3edit/html/edit.html +170 -170
  312. package/tools/nako3edit/html/edit_plugin.js +6 -6
  313. package/tools/nako3edit/html/files.html +125 -125
  314. package/tools/nako3edit/html/nako3edit.css +65 -65
  315. package/tools/nako3edit/index.mjs +248 -244
  316. package/tools/nako3server/index.html +10 -0
  317. package/tools/nako3server/index.mjs +116 -116
  318. package/tools/nako3server/index.nako3 +34 -0
  319. package/release/nako_gen_async.js.LICENSE.txt +0 -35
  320. package/release/plugin_caniuse.js.LICENSE.txt +0 -11
  321. package/release/plugin_csv.js.LICENSE.txt +0 -15
  322. package/release/plugin_datetime.js.LICENSE.txt +0 -15
  323. package/release/plugin_kansuji.js.LICENSE.txt +0 -3
  324. package/release/plugin_markup.js.LICENSE.txt +0 -11
  325. package/release/plugin_turtle.js.LICENSE.txt +0 -15
  326. package/release/plugin_webworker.js.LICENSE.txt +0 -3
  327. package/release/plugin_weykturtle3d.js.LICENSE.txt +0 -3
  328. package/release/wnako3webworker.js.LICENSE.txt +0 -131
  329. package/tools/nako3edit/a.sqlite3 +0 -0
@@ -0,0 +1,199 @@
1
+ /** NakoLogger */
2
+ import { NakoError } from './nako_errors.mjs';
3
+ import { NakoColors } from './nako_colors.mjs';
4
+ /** ログレベル - 数字が高いほど優先度が高い。 */
5
+ export class LogLevel {
6
+ // string to level no
7
+ static fromS(levelStr) {
8
+ let level = LogLevel.trace;
9
+ switch (levelStr) {
10
+ case 'all':
11
+ level = LogLevel.all;
12
+ break;
13
+ case 'trace':
14
+ level = LogLevel.trace;
15
+ break;
16
+ case 'debug':
17
+ level = LogLevel.debug;
18
+ break;
19
+ case 'info':
20
+ level = LogLevel.info;
21
+ break;
22
+ case 'warn':
23
+ level = LogLevel.warn;
24
+ break;
25
+ case 'error':
26
+ level = LogLevel.error;
27
+ break;
28
+ case 'stdout':
29
+ level = LogLevel.stdout;
30
+ break;
31
+ default:
32
+ throw new Error('[NakoLogger] unknown logger level:' + levelStr);
33
+ }
34
+ return level;
35
+ }
36
+ static toString(level) {
37
+ const levels = ['all', 'trace', 'debug', 'info', 'warn', 'error', 'stdout'];
38
+ return levels[level];
39
+ }
40
+ }
41
+ // level no
42
+ LogLevel.all = 0;
43
+ LogLevel.trace = 1;
44
+ LogLevel.debug = 2;
45
+ LogLevel.info = 3;
46
+ LogLevel.warn = 4;
47
+ LogLevel.error = 5;
48
+ LogLevel.stdout = 6;
49
+ /**
50
+ * エラー位置を日本語で表示する。
51
+ * たとえば `stringifyPosition({ file: "foo.txt", line: 5 })` は `"foo.txt(6行目):"` を出力する。
52
+ */
53
+ function stringifyPosition(p) {
54
+ if (!p) {
55
+ return '';
56
+ }
57
+ return `${p.file || ''}${p.line === undefined ? '' : `(${p.line + 1}行目): `}`;
58
+ }
59
+ /**
60
+ * コンパイラのログ情報を出力するためのクラス。
61
+ * trace(), debug(), info(), warn(), error() はそれぞれメッセージに `[警告]` などのタグとエラー位置の日本語表現を付けて表示する。
62
+ * error() は引数にエラーオブジェクトを受け取ることもでき、その場合エラーオブジェクトからエラーメッセージとエラー位置が取り出される。
63
+ */
64
+ export class NakoLogger {
65
+ constructor() {
66
+ this.listeners = [];
67
+ this.logs = '';
68
+ this.position = '';
69
+ }
70
+ getErrorLogs() {
71
+ return [this.logs.replace(/\s+$/, ''), this.position];
72
+ }
73
+ clear() {
74
+ this.logs = '';
75
+ this.position = '';
76
+ }
77
+ /**
78
+ * sendメソッドで送られた情報を受け取るコールバックを設定する。
79
+ * @param levelStr
80
+ * @param callback
81
+ */
82
+ addListener(levelStr, callback) {
83
+ const level = LogLevel.fromS(levelStr);
84
+ this.listeners.push({ level, callback });
85
+ }
86
+ /**
87
+ * addListenerメソッドで設定したコールバックを取り外す。
88
+ * @param {LogListener} callback
89
+ */
90
+ removeListener(callback) {
91
+ this.listeners = this.listeners.filter((l) => l.callback !== callback);
92
+ }
93
+ /** 本体開発時のデバッグ情報(debugより更に詳細な情報)
94
+ * @param {string} message
95
+ * @param {Position | null} position
96
+ */
97
+ trace(message, position = null) {
98
+ this.sendI(LogLevel.trace, `${NakoColors.color.bold}[デバッグ情報(詳細)]${NakoColors.color.reset}${stringifyPosition(position)}${message}`, position);
99
+ }
100
+ /** 本体開発時のデバッグ情報
101
+ * @param {string} message
102
+ * @param {Position | null} position
103
+ */
104
+ debug(message, position = null) {
105
+ this.sendI(LogLevel.debug, `${NakoColors.color.bold}[デバッグ情報]${NakoColors.color.reset}${stringifyPosition(position)}${message}`, position);
106
+ }
107
+ /** ユーザープログラムのデバッグ情報(あまり重要ではないもの)
108
+ * @param {string} message
109
+ * @param {Position | null} position
110
+ */
111
+ info(message, position = null) {
112
+ this.sendI(LogLevel.info, `${NakoColors.color.bold}${NakoColors.color.blue}[情報]${NakoColors.color.reset}${stringifyPosition(position)}${message}`, position);
113
+ }
114
+ /** ユーザープログラムのデバッグ情報(重要なもの)
115
+ * @param {string} message
116
+ * @param {Position | null} position
117
+ */
118
+ warn(message, position = null) {
119
+ this.sendI(LogLevel.warn, `${NakoColors.color.bold}${NakoColors.color.green}[警告]${NakoColors.color.reset}${stringifyPosition(position)}${message}`, position);
120
+ }
121
+ /** エラーメッセージ
122
+ * @param {string | Error} message
123
+ * @param {Position | null} position
124
+ */
125
+ error(message, position = null) {
126
+ // NakoErrorか判定 (`message instanceof NakoError`では判定できない場合がある)
127
+ if (message instanceof Error && typeof message.type === 'string') {
128
+ // NakoErrorか
129
+ const etype = message.type;
130
+ switch (etype) {
131
+ case 'NakoRuntimeError':
132
+ case 'NakoError':
133
+ if (message instanceof NakoError) {
134
+ const e = message;
135
+ let pos = position;
136
+ if (pos === null || pos === undefined) {
137
+ pos = { file: e.file, line: e.line || 0, startOffset: 0, endOffset: 0 };
138
+ }
139
+ this.sendI(LogLevel.error, e.message, pos);
140
+ return;
141
+ }
142
+ }
143
+ }
144
+ if (message instanceof Error) {
145
+ // 一般のエラーの場合は、messageのみ取得できる。
146
+ message = message.message;
147
+ }
148
+ this.sendI(LogLevel.error, `${NakoColors.color.bold}${NakoColors.color.red}[エラー]${NakoColors.color.reset}${stringifyPosition(position)}${message}`, position);
149
+ }
150
+ /** ユーザープログラムのデバッグ情報(すべて)
151
+ * @param {string} message
152
+ * @param {Position | null} position
153
+ */
154
+ stdout(message, position = null) {
155
+ this.sendI(LogLevel.stdout, `${message}`, position);
156
+ }
157
+ /** 指定したlevelのlistenerにメッセージを送る。htmlやbrowserConsoleは無ければnodeConsoleから生成する。 */
158
+ send(levelStr, nodeConsole, position, html = null, browserConsole = null) {
159
+ const i = LogLevel.fromS(levelStr);
160
+ this.sendI(i, nodeConsole, position, html, browserConsole);
161
+ }
162
+ /** 指定したlevelのlistenerにメッセージを送る。htmlやbrowserConsoleは無ければnodeConsoleから生成する。 */
163
+ sendI(level, nodeConsole, position, html = null, browserConsole = null) {
164
+ const makeData = () => {
165
+ // nodeConsoleからnoColor, nodeCondoleなどの形式を生成する。
166
+ const formats = NakoColors.convertColorTextFormat(nodeConsole);
167
+ // ログが複数行から構成される場合は、htmlでの表現にborderを設定する。
168
+ let style = '';
169
+ if (nodeConsole.includes('\n')) {
170
+ style += 'border-top: 1px solid #8080806b; border-bottom: 1px solid #8080806b;';
171
+ }
172
+ // 各イベントリスナーが受け取るデータ
173
+ const data = {
174
+ noColor: formats.noColor,
175
+ nodeConsole: formats.nodeConsole,
176
+ browserConsole: browserConsole || formats.browserConsole,
177
+ html: `<div style="${style}">` + (html || formats.html) + '</div>',
178
+ level: LogLevel.toString(level),
179
+ position
180
+ };
181
+ return data;
182
+ };
183
+ // エラーならログに追加
184
+ if (level === LogLevel.error) {
185
+ const data = makeData();
186
+ this.logs += data.noColor + '\n';
187
+ if (position && this.position !== null) {
188
+ this.position = `l${position.line}:${position.file}`;
189
+ }
190
+ }
191
+ // 登録したリスナーに通知する
192
+ for (const l of this.listeners) {
193
+ if (l.level <= level) {
194
+ const data = makeData();
195
+ l.callback(data);
196
+ }
197
+ }
198
+ }
199
+ }
@@ -0,0 +1,232 @@
1
+ /** NakoLogger */
2
+ import { NakoError } from './nako_errors.mjs'
3
+ import { NakoColors } from './nako_colors.mjs'
4
+ import { Token, Ast } from './nako_types.mjs'
5
+
6
+ /** ログレベル - 数字が高いほど優先度が高い。 */
7
+
8
+ export class LogLevel {
9
+ // level no
10
+ public static all = 0
11
+ public static trace = 1
12
+ public static debug = 2
13
+ public static info = 3
14
+ public static warn = 4
15
+ public static error = 5
16
+ public static stdout = 6
17
+
18
+ // string to level no
19
+ public static fromS (levelStr: string): number {
20
+ let level: number = LogLevel.trace
21
+ switch (levelStr) {
22
+ case 'all': level = LogLevel.all; break
23
+ case 'trace': level = LogLevel.trace; break
24
+ case 'debug': level = LogLevel.debug; break
25
+ case 'info': level = LogLevel.info; break
26
+ case 'warn': level = LogLevel.warn; break
27
+ case 'error': level = LogLevel.error; break
28
+ case 'stdout': level = LogLevel.stdout; break
29
+ default:
30
+ throw new Error('[NakoLogger] unknown logger level:' + levelStr)
31
+ }
32
+ return level
33
+ }
34
+
35
+ public static toString (level: number): string {
36
+ const levels: string[] = ['all', 'trace', 'debug', 'info', 'warn', 'error', 'stdout']
37
+ return levels[level]
38
+ }
39
+ }
40
+
41
+ /** Source Code Position */
42
+ interface Position {
43
+ startOffset: number;
44
+ endOffset: number;
45
+ line: number;
46
+ file: string;
47
+ }
48
+ type PositionOrNull = Position | Token | Ast | null;
49
+
50
+ interface LogListenerData {
51
+ position: PositionOrNull; // ログの送信時にposition引数で渡されたデータ
52
+ level: string; // ログの重要度(内部的にはnumber、入出力時stringに変換)
53
+ noColor: string; // 例: '[情報](2行目): foo'
54
+ nodeConsole: string; // 例: '\x1B[1m\x1B[34m[情報]\x1B[0m(2行目): foo\x1B[0m'
55
+ browserConsole: string[]; // 例: ['%c%c[情報]%c(2行目): foo', 'color: inherit; font-weight: bold;', ...]
56
+ html: string; // 例: '<div style="">...</div>'
57
+ }
58
+ type LogListener = (data: LogListenerData) => void;
59
+
60
+ /**
61
+ * エラー位置を日本語で表示する。
62
+ * たとえば `stringifyPosition({ file: "foo.txt", line: 5 })` は `"foo.txt(6行目):"` を出力する。
63
+ */
64
+ function stringifyPosition (p: PositionOrNull): string {
65
+ if (!p) { return '' }
66
+ return `${p.file || ''}${p.line === undefined ? '' : `(${p.line + 1}行目): `}`
67
+ }
68
+
69
+ interface NakoLoggerListener {
70
+ level: number;
71
+ callback: LogListener;
72
+ }
73
+
74
+ /**
75
+ * コンパイラのログ情報を出力するためのクラス。
76
+ * trace(), debug(), info(), warn(), error() はそれぞれメッセージに `[警告]` などのタグとエラー位置の日本語表現を付けて表示する。
77
+ * error() は引数にエラーオブジェクトを受け取ることもでき、その場合エラーオブジェクトからエラーメッセージとエラー位置が取り出される。
78
+ */
79
+ export class NakoLogger {
80
+ private listeners: NakoLoggerListener[];
81
+ private logs: string
82
+ private position: string
83
+ public constructor () {
84
+ this.listeners = []
85
+ this.logs = ''
86
+ this.position = ''
87
+ }
88
+
89
+ public getErrorLogs (): [string, string] {
90
+ return [this.logs.replace(/\s+$/, ''), this.position]
91
+ }
92
+
93
+ public clear (): void {
94
+ this.logs = ''
95
+ this.position = ''
96
+ }
97
+
98
+ /**
99
+ * sendメソッドで送られた情報を受け取るコールバックを設定する。
100
+ * @param levelStr
101
+ * @param callback
102
+ */
103
+ public addListener (levelStr: string, callback: LogListener): void {
104
+ const level: number = LogLevel.fromS(levelStr)
105
+ this.listeners.push({ level, callback })
106
+ }
107
+
108
+ /**
109
+ * addListenerメソッドで設定したコールバックを取り外す。
110
+ * @param {LogListener} callback
111
+ */
112
+ public removeListener (callback: LogListener): void {
113
+ this.listeners = this.listeners.filter((l) => l.callback !== callback)
114
+ }
115
+
116
+ /** 本体開発時のデバッグ情報(debugより更に詳細な情報)
117
+ * @param {string} message
118
+ * @param {Position | null} position
119
+ */
120
+ public trace (message: string, position: PositionOrNull = null):void {
121
+ this.sendI(LogLevel.trace, `${NakoColors.color.bold}[デバッグ情報(詳細)]${NakoColors.color.reset}${stringifyPosition(position)}${message}`, position)
122
+ }
123
+
124
+ /** 本体開発時のデバッグ情報
125
+ * @param {string} message
126
+ * @param {Position | null} position
127
+ */
128
+ public debug (message: string, position: PositionOrNull = null): void {
129
+ this.sendI(LogLevel.debug, `${NakoColors.color.bold}[デバッグ情報]${NakoColors.color.reset}${stringifyPosition(position)}${message}`, position)
130
+ }
131
+
132
+ /** ユーザープログラムのデバッグ情報(あまり重要ではないもの)
133
+ * @param {string} message
134
+ * @param {Position | null} position
135
+ */
136
+ public info (message: string, position: PositionOrNull = null): void {
137
+ this.sendI(LogLevel.info, `${NakoColors.color.bold}${NakoColors.color.blue}[情報]${NakoColors.color.reset}${stringifyPosition(position)}${message}`, position)
138
+ }
139
+
140
+ /** ユーザープログラムのデバッグ情報(重要なもの)
141
+ * @param {string} message
142
+ * @param {Position | null} position
143
+ */
144
+ public warn (message: string, position: PositionOrNull = null):void {
145
+ this.sendI(LogLevel.warn, `${NakoColors.color.bold}${NakoColors.color.green}[警告]${NakoColors.color.reset}${stringifyPosition(position)}${message}`, position)
146
+ }
147
+
148
+ /** エラーメッセージ
149
+ * @param {string | Error} message
150
+ * @param {Position | null} position
151
+ */
152
+ public error (message: string | Error | NakoError, position: PositionOrNull = null):void {
153
+ // NakoErrorか判定 (`message instanceof NakoError`では判定できない場合がある)
154
+ if (message instanceof Error && typeof (message as NakoError).type === 'string') {
155
+ // NakoErrorか
156
+ const etype: string = (message as NakoError).type
157
+ switch (etype) {
158
+ case 'NakoRuntimeError':
159
+ case 'NakoError':
160
+ if (message instanceof NakoError) {
161
+ const e: NakoError = message as NakoError
162
+ let pos: any = position
163
+ if (pos === null || pos === undefined) {
164
+ pos = { file: e.file, line: e.line || 0, startOffset: 0, endOffset: 0 }
165
+ }
166
+ this.sendI(LogLevel.error, e.message, pos)
167
+ return
168
+ }
169
+ }
170
+ }
171
+ if (message instanceof Error) {
172
+ // 一般のエラーの場合は、messageのみ取得できる。
173
+ message = message.message
174
+ }
175
+ this.sendI(
176
+ LogLevel.error,
177
+ `${NakoColors.color.bold}${NakoColors.color.red}[エラー]${NakoColors.color.reset}${stringifyPosition(position)}${message}`,
178
+ position)
179
+ }
180
+
181
+ /** ユーザープログラムのデバッグ情報(すべて)
182
+ * @param {string} message
183
+ * @param {Position | null} position
184
+ */
185
+ public stdout (message: string, position: PositionOrNull = null): void {
186
+ this.sendI(LogLevel.stdout, `${message}`, position)
187
+ }
188
+
189
+ /** 指定したlevelのlistenerにメッセージを送る。htmlやbrowserConsoleは無ければnodeConsoleから生成する。 */
190
+ public send (levelStr: string, nodeConsole: string, position: PositionOrNull, html: string|null = null, browserConsole: [string, string] | null = null): void {
191
+ const i = LogLevel.fromS(levelStr)
192
+ this.sendI(i, nodeConsole, position, html, browserConsole)
193
+ }
194
+
195
+ /** 指定したlevelのlistenerにメッセージを送る。htmlやbrowserConsoleは無ければnodeConsoleから生成する。 */
196
+ public sendI (level: number, nodeConsole: string, position: PositionOrNull, html: string|null = null, browserConsole: [string, string] | null = null): void {
197
+ const makeData = () => {
198
+ // nodeConsoleからnoColor, nodeCondoleなどの形式を生成する。
199
+ const formats = NakoColors.convertColorTextFormat(nodeConsole)
200
+ // ログが複数行から構成される場合は、htmlでの表現にborderを設定する。
201
+ let style = ''
202
+ if (nodeConsole.includes('\n')) {
203
+ style += 'border-top: 1px solid #8080806b; border-bottom: 1px solid #8080806b;'
204
+ }
205
+ // 各イベントリスナーが受け取るデータ
206
+ const data: LogListenerData = {
207
+ noColor: formats.noColor,
208
+ nodeConsole: formats.nodeConsole,
209
+ browserConsole: browserConsole || formats.browserConsole,
210
+ html: `<div style="${style}">` + (html || formats.html) + '</div>', // 各行を style: block で表示するために、<div>で囲む。
211
+ level: LogLevel.toString(level),
212
+ position
213
+ }
214
+ return data
215
+ }
216
+ // エラーならログに追加
217
+ if (level === LogLevel.error) {
218
+ const data = makeData()
219
+ this.logs += data.noColor + '\n'
220
+ if (position && this.position !== null) {
221
+ this.position = `l${position.line}:${position.file}`
222
+ }
223
+ }
224
+ // 登録したリスナーに通知する
225
+ for (const l of this.listeners) {
226
+ if (l.level <= level) {
227
+ const data = makeData()
228
+ l.callback(data)
229
+ }
230
+ }
231
+ }
232
+ }