nadesiko3 3.3.49 → 3.3.50

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 (342) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +143 -143
  3. package/batch/.DS_Store +0 -0
  4. package/batch/browsers.template.md +3 -3
  5. package/batch/build_browsers.nako3 +72 -72
  6. package/batch/build_command.nako3 +44 -44
  7. package/batch/build_nako_version.nako3 +42 -42
  8. package/batch/calc_hash.nako3 +29 -29
  9. package/batch/cmd_txt2json.nako3 +74 -74
  10. package/batch/command.txt +79 -0
  11. package/batch/command_nakopad.txt +69 -0
  12. package/batch/download-extlib.nako3 +43 -43
  13. package/batch/gen_command_nakopad.nako3 +57 -57
  14. package/batch/jsplugin2text.nako3 +285 -285
  15. package/batch/pickup_command.nako3 +110 -110
  16. package/batch/pickup_reserved_words.nako3 +11 -11
  17. package/batch/publish_version.nako3 +46 -46
  18. package/batch/show_agents.js +14 -14
  19. package/batch/turtle2js.nako3 +21 -21
  20. package/bin/cnako3 +10 -10
  21. package/core/LICENSE +21 -21
  22. package/core/README.md +66 -66
  23. package/core/batch/build_nako_version.nako3 +42 -42
  24. package/core/command/snako.mjs +105 -105
  25. package/core/command/snako.mts +116 -116
  26. package/core/index.mjs +21 -21
  27. package/core/package.json +47 -47
  28. package/core/sample/hello.nako3 +7 -7
  29. package/core/sample/hoge.mjs +4 -4
  30. package/core/sample/hoge.mts +6 -6
  31. package/core/src/nako3.mjs +864 -858
  32. package/core/src/nako3.mts +976 -967
  33. package/core/src/nako_colors.mjs +78 -78
  34. package/core/src/nako_colors.mts +86 -86
  35. package/core/src/nako_core_version.mjs +8 -8
  36. package/core/src/nako_core_version.mts +19 -19
  37. package/core/src/nako_csv.mjs +185 -185
  38. package/core/src/nako_csv.mts +188 -188
  39. package/core/src/nako_errors.mjs +173 -173
  40. package/core/src/nako_errors.mts +197 -197
  41. package/core/src/nako_from_dncl.mjs +255 -255
  42. package/core/src/nako_from_dncl.mts +250 -250
  43. package/core/src/nako_gen.mjs +1647 -1648
  44. package/core/src/nako_gen.mts +1718 -1719
  45. package/core/src/nako_gen_async.mjs +1659 -1659
  46. package/core/src/nako_gen_async.mts +1732 -1732
  47. package/core/src/nako_global.mjs +107 -107
  48. package/core/src/nako_global.mts +138 -138
  49. package/core/src/nako_indent.mjs +445 -445
  50. package/core/src/nako_indent.mts +492 -492
  51. package/core/src/nako_josi_list.mjs +38 -38
  52. package/core/src/nako_josi_list.mts +45 -45
  53. package/core/src/nako_lex_rules.mjs +253 -253
  54. package/core/src/nako_lex_rules.mts +260 -260
  55. package/core/src/nako_lexer.mjs +609 -609
  56. package/core/src/nako_lexer.mts +612 -612
  57. package/core/src/nako_logger.mjs +199 -199
  58. package/core/src/nako_logger.mts +232 -232
  59. package/core/src/nako_parser3.mjs +2439 -2439
  60. package/core/src/nako_parser3.mts +2195 -2195
  61. package/core/src/nako_parser_base.mjs +370 -370
  62. package/core/src/nako_parser_base.mts +370 -370
  63. package/core/src/nako_parser_const.mjs +37 -37
  64. package/core/src/nako_parser_const.mts +37 -37
  65. package/core/src/nako_prepare.mjs +304 -304
  66. package/core/src/nako_prepare.mts +315 -315
  67. package/core/src/nako_reserved_words.mjs +38 -38
  68. package/core/src/nako_reserved_words.mts +38 -38
  69. package/core/src/nako_source_mapping.mjs +207 -207
  70. package/core/src/nako_source_mapping.mts +262 -262
  71. package/core/src/nako_test.mjs +37 -37
  72. package/core/src/nako_types.mjs +25 -25
  73. package/core/src/nako_types.mts +151 -151
  74. package/core/src/plugin_csv.mjs +49 -49
  75. package/core/src/plugin_csv.mts +50 -50
  76. package/core/src/plugin_math.mjs +328 -328
  77. package/core/src/plugin_math.mts +326 -326
  78. package/core/src/plugin_promise.mjs +91 -91
  79. package/core/src/plugin_promise.mts +91 -91
  80. package/core/src/plugin_system.mjs +2832 -2832
  81. package/core/src/plugin_system.mts +2690 -2690
  82. package/core/src/plugin_test.mjs +34 -34
  83. package/core/src/plugin_test.mts +34 -34
  84. package/demo/.DS_Store +0 -0
  85. package/demo/ace_editor.html +89 -89
  86. package/demo/ace_editor_tabs.html +161 -161
  87. package/demo/basic.html +71 -71
  88. package/demo/browsers.html +10 -9
  89. package/demo/css/basic.css +3 -3
  90. package/demo/css/common.css +157 -157
  91. package/demo/css/editor.css +8 -8
  92. package/demo/css/flow.css +3 -3
  93. package/demo/css/index.css +3 -3
  94. package/demo/extlib/.DS_Store +0 -0
  95. package/demo/flow.html +98 -98
  96. package/demo/graph.html +53 -53
  97. package/demo/image/nakopad-icon256.png +0 -0
  98. package/demo/index.html +133 -133
  99. package/demo/js/common.js +17 -17
  100. package/demo/js/turtle3d_test.js +44 -44
  101. package/demo/js/turtle_test.js +45 -45
  102. package/demo/nako3/calc.nako3 +4 -4
  103. package/demo/runscript.html +47 -47
  104. package/demo/runscript2.html +33 -33
  105. package/demo/runscript3.html +35 -35
  106. package/demo/runscript4.html +33 -33
  107. package/demo/turtle.html +58 -58
  108. package/demo/turtle2.html +141 -141
  109. package/demo/turtle3.html +279 -279
  110. package/demo/turtle3d.html +58 -58
  111. package/demo/turtle3d2.html +107 -107
  112. package/demo/version.html +24 -24
  113. package/doc/SETUP.md +157 -157
  114. package/doc/about.md +17 -17
  115. package/doc/browsers.md +26 -26
  116. package/doc/docgen.md +21 -21
  117. package/doc/editor.md +44 -44
  118. package/doc/files.md +39 -39
  119. package/doc/plugins.md +234 -234
  120. package/doc/release.md +79 -79
  121. package/doc/textlint.md +43 -43
  122. package/doc/win32.md +57 -57
  123. package/package.json +195 -195
  124. package/release/_hash.txt +28 -28
  125. package/release/_script-tags.txt +14 -14
  126. package/release/command.json +1 -1
  127. package/release/command.json.js +1 -1
  128. package/release/command_cnako3.json +1 -1
  129. package/release/command_list.json +1 -1
  130. package/release/editor.js +1 -1
  131. package/release/nako_gen_async.js +1 -1
  132. package/release/nako_gen_async.js.LICENSE.txt +35 -0
  133. package/release/plugin_caniuse.js.LICENSE.txt +11 -0
  134. package/release/plugin_csv.js +1 -1
  135. package/release/plugin_csv.js.LICENSE.txt +15 -0
  136. package/release/plugin_datetime.js.LICENSE.txt +15 -0
  137. package/release/plugin_kansuji.js.LICENSE.txt +3 -0
  138. package/release/plugin_markup.js.LICENSE.txt +11 -0
  139. package/release/plugin_turtle.js.LICENSE.txt +15 -0
  140. package/release/plugin_webworker.js.LICENSE.txt +3 -0
  141. package/release/plugin_weykturtle3d.js.LICENSE.txt +3 -0
  142. package/release/stats.json +1 -1
  143. package/release/version.js +1 -1
  144. package/release/wnako3.js +1 -1
  145. package/release/wnako3webworker.js +1 -1
  146. package/release/wnako3webworker.js.LICENSE.txt +131 -0
  147. package/src/.DS_Store +0 -0
  148. package/src/browsers.txt +12 -11
  149. package/src/browsers_agents.json +2 -2
  150. package/src/browsers_agents.mjs +1 -1
  151. package/src/cnako3.mjs +17 -17
  152. package/src/cnako3.mts +18 -18
  153. package/src/cnako3mod.mjs +707 -707
  154. package/src/cnako3mod.mts +712 -712
  155. package/src/commander_ja.mjs +164 -164
  156. package/src/commander_ja.mts +161 -161
  157. package/src/enako3.mjs +68 -68
  158. package/src/era.mjs +22 -22
  159. package/src/image_turtle-elephant.mjs +2 -2
  160. package/src/image_turtle-panda.mjs +2 -2
  161. package/src/image_turtle64.mjs +2 -2
  162. package/src/index.mjs +9 -9
  163. package/src/index.mts +10 -10
  164. package/src/nako3editorfix.sfd +106 -106
  165. package/src/nako_version.mjs +8 -8
  166. package/src/nako_version.mts +2 -2
  167. package/src/plugin_browser.mjs +213 -213
  168. package/src/plugin_browser.mts +206 -206
  169. package/src/plugin_browser_ajax.mjs +399 -399
  170. package/src/plugin_browser_audio.mjs +109 -109
  171. package/src/plugin_browser_canvas.mjs +449 -449
  172. package/src/plugin_browser_chart.mjs +294 -294
  173. package/src/plugin_browser_color.mjs +49 -49
  174. package/src/plugin_browser_crypto.mjs +26 -26
  175. package/src/plugin_browser_dialog.mjs +53 -53
  176. package/src/plugin_browser_dom_basic.mjs +336 -336
  177. package/src/plugin_browser_dom_event.mjs +193 -193
  178. package/src/plugin_browser_dom_parts.mjs +396 -396
  179. package/src/plugin_browser_geolocation.mjs +51 -51
  180. package/src/plugin_browser_hotkey.mjs +25 -25
  181. package/src/plugin_browser_html.mjs +59 -59
  182. package/src/plugin_browser_in_worker.mjs +45 -45
  183. package/src/plugin_browser_location.mjs +21 -21
  184. package/src/plugin_browser_speech.mjs +111 -111
  185. package/src/plugin_browser_storage.mjs +121 -121
  186. package/src/plugin_browser_system.mjs +31 -31
  187. package/src/plugin_browser_websocket.mjs +73 -73
  188. package/src/plugin_caniuse.mjs +29 -29
  189. package/src/plugin_datetime.mjs +394 -394
  190. package/src/plugin_httpserver.mjs +277 -277
  191. package/src/plugin_httpserver.mts +286 -286
  192. package/src/plugin_kansuji.mjs +224 -224
  193. package/src/plugin_keigo.mjs +55 -55
  194. package/src/plugin_markup.mjs +32 -32
  195. package/src/plugin_node.mjs +1047 -1047
  196. package/src/plugin_node.mts +980 -980
  197. package/src/plugin_turtle.mjs +647 -647
  198. package/src/plugin_webworker.mjs +334 -334
  199. package/src/plugin_weykturtle3d.mjs +1214 -1214
  200. package/src/plugin_worker.mjs +95 -95
  201. package/src/repl.nako3 +63 -63
  202. package/src/wnako3.mjs +12 -12
  203. package/src/wnako3.mts +11 -11
  204. package/src/wnako3_editor.css +215 -215
  205. package/src/wnako3_editor.mjs +1542 -1542
  206. package/src/wnako3_editor.mts +1658 -1657
  207. package/src/wnako3mod.mjs +213 -213
  208. package/src/wnako3mod.mts +214 -214
  209. package/src/wnako3webworker.mjs +69 -69
  210. package/test/.DS_Store +0 -0
  211. package/test/ace_editor/karma.config.js +94 -94
  212. package/test/ace_editor/test/.babelrc.json +3 -3
  213. package/test/ace_editor/test/ace_editor_test.js +178 -178
  214. package/test/ace_editor/test/html/custom_context.html +139 -139
  215. package/test/async/async_basic_test.mjs +122 -122
  216. package/test/browser/.DS_Store +0 -0
  217. package/test/browser/karma.config.js +221 -221
  218. package/test/browser/test/.babelrc.json +3 -3
  219. package/test/browser/test/compare_util.js +50 -50
  220. package/test/browser/test/html/div_basic.html +2 -2
  221. package/test/browser/test/html/event_dom_form.html +4 -4
  222. package/test/browser/test/html/event_dom_scrolldiv.html +5 -5
  223. package/test/browser/test/import_plugin_checker.js +24 -24
  224. package/test/browser/test/plugin_browser_test.js +51 -51
  225. package/test/browser/test/plugin_browser_test_ajax.js +123 -123
  226. package/test/browser/test/plugin_browser_test_color.js +18 -18
  227. package/test/browser/test/plugin_browser_test_dialog.js +72 -72
  228. package/test/browser/test/plugin_browser_test_dom_event.js +598 -598
  229. package/test/browser/test/plugin_browser_test_dom_parts.js +125 -125
  230. package/test/browser/test/plugin_browser_test_system.js +9 -9
  231. package/test/browser/test/plugin_turtle_test.js +817 -817
  232. package/test/browser/test/plugin_webworker_test.js +86 -86
  233. package/test/browser/test/require_test.js +68 -68
  234. package/test/bundled/.DS_Store +0 -0
  235. package/test/bundled/karma.config.base.js +117 -117
  236. package/test/bundled/karma.config.js +86 -86
  237. package/test/bundled/test/.babelrc.json +3 -3
  238. package/test/bundled/test/bundled_test.js +69 -69
  239. package/test/bundled/test/html/custom_context.html +65 -65
  240. package/test/bundled/test/html/custom_debug.html +66 -66
  241. package/test/bundled/test4b.cmd +52 -52
  242. package/test/bundled/test_base/.DS_Store +0 -0
  243. package/test/bundled/test_base/.babelrc.json +3 -3
  244. package/test/bundled/test_base/_checktool_test.js +25 -25
  245. package/test/bundled/test_base/basic_ajax_test.js +56 -56
  246. package/test/bundled/test_base/basic_async_test.js +18 -18
  247. package/test/bundled/test_base/basic_test.js +153 -153
  248. package/test/bundled/test_base/calc_test.js +132 -132
  249. package/test/bundled/test_base/css/browsers_box.css +114 -114
  250. package/test/bundled/test_base/html/custom_context.html +69 -69
  251. package/test/bundled/test_base/html/custom_debug.html +71 -71
  252. package/test/bundled/test_base/js/browsers_box.js +72 -72
  253. package/test/bundled/test_base/plugin_csv_test.js +37 -37
  254. package/test/bundled/test_base/plugin_datetime_test.js +115 -115
  255. package/test/bundled/test_base/plugin_kansuji_test.js +49 -49
  256. package/test/bundled/test_base/plugin_system_test.js +410 -410
  257. package/test/bundled/test_base/plugin_webworker_test.js +53 -53
  258. package/test/bundled/test_base/test_utils.js +191 -191
  259. package/test/common/.DS_Store +0 -0
  260. package/test/common/plugin_browser_test.mjs +22 -22
  261. package/test/common/plugin_browser_ut_audio_test.mjs +108 -108
  262. package/test/common/plugin_browser_ut_color_test.mjs +21 -21
  263. package/test/common/plugin_browser_ut_dialog_test.mjs +100 -100
  264. package/test/common/plugin_browser_ut_html_test.mjs +13 -13
  265. package/test/common/plugin_browser_ut_system_test.mjs +10 -10
  266. package/test/common/plugin_markup_test.mjs +23 -23
  267. package/test/jsconfig.json +19 -19
  268. package/test/karma.config.js +91 -91
  269. package/test/node/.DS_Store +0 -0
  270. package/test/node/async_test.mjs +96 -96
  271. package/test/node/commander_ja_test.mjs +89 -89
  272. package/test/node/error_message_test.mjs +243 -243
  273. package/test/node/kai_test.nako3 +6 -6
  274. package/test/node/node_test.mjs +60 -60
  275. package/test/node/plugin_broken.js.txt +3 -3
  276. package/test/node/plugin_browser_ut_ajax_test.mjs.todo +357 -357
  277. package/test/node/plugin_browser_ut_location_test.mjs +42 -42
  278. package/test/node/plugin_markup_test.mjs +47 -47
  279. package/test/node/plugin_math_test.mjs +45 -45
  280. package/test/node/plugin_node_test.mjs +98 -98
  281. package/test/node/plugin_test.mjs +44 -44
  282. package/test/node/relative_import_test_1.nako3 +1 -1
  283. package/test/node/relative_import_test_2.nako3 +2 -2
  284. package/test/node/require_nako3_test.mjs +67 -67
  285. package/test/node/requiretest.nako3 +4 -4
  286. package/test/node/requiretest_indirect.nako3 +1 -1
  287. package/test/node/requiretest_name.nako3 +5 -5
  288. package/test/node/runtime_error.nako3 +2 -2
  289. package/test/node/scope1.nako3 +10 -10
  290. package/test/node/scope2.nako3 +12 -12
  291. package/test/node/side_effects_test.mjs +39 -39
  292. package/test/node/sjis.txt +5 -5
  293. package/test/node/syntax_error.nako3 +1 -1
  294. package/test/node/wnako3_editor_test.mjs +384 -384
  295. package/tools/.DS_Store +0 -0
  296. package/tools/README.md +12 -12
  297. package/tools/check_new_version.nako3 +25 -25
  298. package/tools/nako3edit/.DS_Store +0 -0
  299. package/tools/nako3edit/a.sqlite3 +0 -0
  300. package/tools/nako3edit/html/.DS_Store +0 -0
  301. package/tools/nako3edit/html/daisyui/LICENSE +22 -22
  302. package/tools/nako3edit/html/daisyui/version_2.14.1 +1 -1
  303. package/tools/nako3edit/html/edit.html +170 -170
  304. package/tools/nako3edit/html/edit_plugin.js +6 -6
  305. package/tools/nako3edit/html/files.html +125 -125
  306. package/tools/nako3edit/html/nako3edit.css +65 -65
  307. package/tools/nako3edit/index.mjs +248 -248
  308. package/tools/nako3server/index.html +10 -10
  309. package/tools/nako3server/index.mjs +116 -116
  310. package/tools/nako3server/index.nako3 +34 -34
  311. package/core/.editorconfig +0 -6
  312. package/core/.eslintrc.cjs +0 -33
  313. package/core/.github/dependabot.yml +0 -7
  314. package/core/.github/workflows/nodejs.yml +0 -37
  315. package/core/.github/workflows/super-linter.yml +0 -61
  316. package/core/.github/workflows/textlint.yml +0 -199
  317. package/core/index.mts +0 -21
  318. package/core/test/array_test.mjs +0 -34
  319. package/core/test/basic_test.mjs +0 -344
  320. package/core/test/calc_test.mjs +0 -140
  321. package/core/test/core_module_test.mjs +0 -23
  322. package/core/test/debug_test.mjs +0 -16
  323. package/core/test/dncl_test.mjs +0 -94
  324. package/core/test/error_message_test.mjs +0 -210
  325. package/core/test/error_test.mjs +0 -16
  326. package/core/test/flow_test.mjs +0 -373
  327. package/core/test/func_call.mjs +0 -160
  328. package/core/test/func_test.mjs +0 -149
  329. package/core/test/indent_test.mjs +0 -364
  330. package/core/test/lex_test.mjs +0 -168
  331. package/core/test/literal_test.mjs +0 -73
  332. package/core/test/nako_lexer_test.mjs +0 -35
  333. package/core/test/nako_logger_test.mjs +0 -76
  334. package/core/test/nako_logger_test.mts +0 -78
  335. package/core/test/plugin_csv_test.mjs +0 -38
  336. package/core/test/plugin_promise_test.mjs +0 -18
  337. package/core/test/plugin_system_test.mjs +0 -630
  338. package/core/test/prepare_test.mjs +0 -96
  339. package/core/test/re_test.mjs +0 -22
  340. package/core/test/side_effects_test.mjs +0 -92
  341. package/core/test/variable_scope_test.mjs +0 -149
  342. package/core/tsconfig.json +0 -101
@@ -1,232 +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
- }
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
+ }