nadesiko3 3.3.49 → 3.3.52

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 (343) 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 +162 -83
  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 +113 -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 +870 -858
  32. package/core/src/nako3.mts +983 -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 +109 -107
  48. package/core/src/nako_global.mts +141 -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 +2441 -2439
  60. package/core/src/nako_parser3.mts +2197 -2195
  61. package/core/src/nako_parser_base.mjs +371 -370
  62. package/core/src/nako_parser_base.mts +372 -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 +13 -25
  73. package/core/src/nako_types.mts +144 -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 +2 -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/wnako3.js.LICENSE.txt +203 -1
  146. package/release/wnako3webworker.js +2 -1
  147. package/release/wnako3webworker.js.LICENSE.txt +131 -0
  148. package/src/.DS_Store +0 -0
  149. package/src/browsers.txt +12 -11
  150. package/src/browsers_agents.json +2 -2
  151. package/src/browsers_agents.mjs +1 -1
  152. package/src/cnako3.mjs +17 -17
  153. package/src/cnako3.mts +18 -18
  154. package/src/cnako3mod.mjs +682 -707
  155. package/src/cnako3mod.mts +688 -712
  156. package/src/commander_ja.mjs +164 -164
  157. package/src/commander_ja.mts +161 -161
  158. package/src/enako3.mjs +68 -68
  159. package/src/era.mjs +22 -22
  160. package/src/image_turtle-elephant.mjs +2 -2
  161. package/src/image_turtle-panda.mjs +2 -2
  162. package/src/image_turtle64.mjs +2 -2
  163. package/src/index.mjs +9 -9
  164. package/src/index.mts +10 -10
  165. package/src/nako3editorfix.sfd +106 -106
  166. package/src/nako_version.mjs +8 -8
  167. package/src/nako_version.mts +2 -2
  168. package/src/plugin_browser.mjs +213 -213
  169. package/src/plugin_browser.mts +206 -206
  170. package/src/plugin_browser_ajax.mjs +399 -399
  171. package/src/plugin_browser_audio.mjs +109 -109
  172. package/src/plugin_browser_canvas.mjs +449 -449
  173. package/src/plugin_browser_chart.mjs +294 -294
  174. package/src/plugin_browser_color.mjs +49 -49
  175. package/src/plugin_browser_crypto.mjs +26 -26
  176. package/src/plugin_browser_dialog.mjs +53 -53
  177. package/src/plugin_browser_dom_basic.mjs +336 -336
  178. package/src/plugin_browser_dom_event.mjs +193 -193
  179. package/src/plugin_browser_dom_parts.mjs +396 -396
  180. package/src/plugin_browser_geolocation.mjs +51 -51
  181. package/src/plugin_browser_hotkey.mjs +25 -25
  182. package/src/plugin_browser_html.mjs +59 -59
  183. package/src/plugin_browser_in_worker.mjs +45 -45
  184. package/src/plugin_browser_location.mjs +21 -21
  185. package/src/plugin_browser_speech.mjs +111 -111
  186. package/src/plugin_browser_storage.mjs +121 -121
  187. package/src/plugin_browser_system.mjs +31 -31
  188. package/src/plugin_browser_websocket.mjs +73 -73
  189. package/src/plugin_caniuse.mjs +29 -29
  190. package/src/plugin_datetime.mjs +394 -394
  191. package/src/plugin_httpserver.mjs +277 -277
  192. package/src/plugin_httpserver.mts +286 -286
  193. package/src/plugin_kansuji.mjs +224 -224
  194. package/src/plugin_keigo.mjs +55 -55
  195. package/src/plugin_markup.mjs +32 -32
  196. package/src/plugin_node.mjs +1047 -1047
  197. package/src/plugin_node.mts +980 -980
  198. package/src/plugin_turtle.mjs +647 -647
  199. package/src/plugin_webworker.mjs +334 -334
  200. package/src/plugin_weykturtle3d.mjs +1214 -1214
  201. package/src/plugin_worker.mjs +95 -95
  202. package/src/repl.nako3 +63 -63
  203. package/src/wnako3.mjs +12 -12
  204. package/src/wnako3.mts +11 -11
  205. package/src/wnako3_editor.css +215 -215
  206. package/src/wnako3_editor.mjs +1542 -1542
  207. package/src/wnako3_editor.mts +1658 -1657
  208. package/src/wnako3mod.mjs +213 -213
  209. package/src/wnako3mod.mts +214 -214
  210. package/src/wnako3webworker.mjs +69 -69
  211. package/test/.DS_Store +0 -0
  212. package/test/ace_editor/karma.config.js +94 -94
  213. package/test/ace_editor/test/.babelrc.json +3 -3
  214. package/test/ace_editor/test/ace_editor_test.js +178 -178
  215. package/test/ace_editor/test/html/custom_context.html +139 -139
  216. package/test/async/async_basic_test.mjs +122 -122
  217. package/test/browser/.DS_Store +0 -0
  218. package/test/browser/karma.config.js +221 -221
  219. package/test/browser/test/.babelrc.json +3 -3
  220. package/test/browser/test/compare_util.js +50 -50
  221. package/test/browser/test/html/div_basic.html +2 -2
  222. package/test/browser/test/html/event_dom_form.html +4 -4
  223. package/test/browser/test/html/event_dom_scrolldiv.html +5 -5
  224. package/test/browser/test/import_plugin_checker.js +24 -24
  225. package/test/browser/test/plugin_browser_test.js +51 -51
  226. package/test/browser/test/plugin_browser_test_ajax.js +123 -123
  227. package/test/browser/test/plugin_browser_test_color.js +18 -18
  228. package/test/browser/test/plugin_browser_test_dialog.js +72 -72
  229. package/test/browser/test/plugin_browser_test_dom_event.js +598 -598
  230. package/test/browser/test/plugin_browser_test_dom_parts.js +125 -125
  231. package/test/browser/test/plugin_browser_test_system.js +9 -9
  232. package/test/browser/test/plugin_turtle_test.js +817 -817
  233. package/test/browser/test/plugin_webworker_test.js +86 -86
  234. package/test/browser/test/require_test.js +68 -68
  235. package/test/bundled/.DS_Store +0 -0
  236. package/test/bundled/karma.config.base.js +117 -117
  237. package/test/bundled/karma.config.js +86 -86
  238. package/test/bundled/test/.babelrc.json +3 -3
  239. package/test/bundled/test/bundled_test.js +69 -69
  240. package/test/bundled/test/html/custom_context.html +65 -65
  241. package/test/bundled/test/html/custom_debug.html +66 -66
  242. package/test/bundled/test4b.cmd +52 -52
  243. package/test/bundled/test_base/.DS_Store +0 -0
  244. package/test/bundled/test_base/.babelrc.json +3 -3
  245. package/test/bundled/test_base/_checktool_test.js +25 -25
  246. package/test/bundled/test_base/basic_ajax_test.js +56 -56
  247. package/test/bundled/test_base/basic_async_test.js +18 -18
  248. package/test/bundled/test_base/basic_test.js +153 -153
  249. package/test/bundled/test_base/calc_test.js +132 -132
  250. package/test/bundled/test_base/css/browsers_box.css +114 -114
  251. package/test/bundled/test_base/html/custom_context.html +69 -69
  252. package/test/bundled/test_base/html/custom_debug.html +71 -71
  253. package/test/bundled/test_base/js/browsers_box.js +72 -72
  254. package/test/bundled/test_base/plugin_csv_test.js +37 -37
  255. package/test/bundled/test_base/plugin_datetime_test.js +115 -115
  256. package/test/bundled/test_base/plugin_kansuji_test.js +49 -49
  257. package/test/bundled/test_base/plugin_system_test.js +410 -410
  258. package/test/bundled/test_base/plugin_webworker_test.js +53 -53
  259. package/test/bundled/test_base/test_utils.js +191 -191
  260. package/test/common/.DS_Store +0 -0
  261. package/test/common/plugin_browser_test.mjs +22 -22
  262. package/test/common/plugin_browser_ut_audio_test.mjs +108 -108
  263. package/test/common/plugin_browser_ut_color_test.mjs +21 -21
  264. package/test/common/plugin_browser_ut_dialog_test.mjs +100 -100
  265. package/test/common/plugin_browser_ut_html_test.mjs +13 -13
  266. package/test/common/plugin_browser_ut_system_test.mjs +10 -10
  267. package/test/common/plugin_markup_test.mjs +23 -23
  268. package/test/jsconfig.json +19 -19
  269. package/test/karma.config.js +91 -91
  270. package/test/node/.DS_Store +0 -0
  271. package/test/node/async_test.mjs +96 -96
  272. package/test/node/commander_ja_test.mjs +89 -89
  273. package/test/node/error_message_test.mjs +243 -243
  274. package/test/node/kai_test.nako3 +6 -6
  275. package/test/node/node_test.mjs +60 -60
  276. package/test/node/plugin_broken.js.txt +3 -3
  277. package/test/node/plugin_browser_ut_ajax_test.mjs.todo +357 -357
  278. package/test/node/plugin_browser_ut_location_test.mjs +42 -42
  279. package/test/node/plugin_markup_test.mjs +47 -47
  280. package/test/node/plugin_math_test.mjs +45 -45
  281. package/test/node/plugin_node_test.mjs +98 -98
  282. package/test/node/plugin_test.mjs +44 -44
  283. package/test/node/relative_import_test_1.nako3 +1 -1
  284. package/test/node/relative_import_test_2.nako3 +2 -2
  285. package/test/node/require_nako3_test.mjs +67 -67
  286. package/test/node/requiretest.nako3 +4 -4
  287. package/test/node/requiretest_indirect.nako3 +1 -1
  288. package/test/node/requiretest_name.nako3 +5 -5
  289. package/test/node/runtime_error.nako3 +2 -2
  290. package/test/node/scope1.nako3 +10 -10
  291. package/test/node/scope2.nako3 +12 -12
  292. package/test/node/side_effects_test.mjs +39 -39
  293. package/test/node/sjis.txt +5 -5
  294. package/test/node/syntax_error.nako3 +1 -1
  295. package/test/node/wnako3_editor_test.mjs +384 -384
  296. package/tools/.DS_Store +0 -0
  297. package/tools/README.md +12 -12
  298. package/tools/check_new_version.nako3 +25 -25
  299. package/tools/nako3edit/.DS_Store +0 -0
  300. package/tools/nako3edit/a.sqlite3 +0 -0
  301. package/tools/nako3edit/html/.DS_Store +0 -0
  302. package/tools/nako3edit/html/daisyui/LICENSE +22 -22
  303. package/tools/nako3edit/html/daisyui/version_2.14.1 +1 -1
  304. package/tools/nako3edit/html/edit.html +170 -170
  305. package/tools/nako3edit/html/edit_plugin.js +6 -6
  306. package/tools/nako3edit/html/files.html +125 -125
  307. package/tools/nako3edit/html/nako3edit.css +65 -65
  308. package/tools/nako3edit/index.mjs +248 -248
  309. package/tools/nako3server/index.html +10 -10
  310. package/tools/nako3server/index.mjs +116 -116
  311. package/tools/nako3server/index.nako3 +34 -34
  312. package/core/.editorconfig +0 -6
  313. package/core/.eslintrc.cjs +0 -33
  314. package/core/.github/dependabot.yml +0 -7
  315. package/core/.github/workflows/nodejs.yml +0 -37
  316. package/core/.github/workflows/super-linter.yml +0 -61
  317. package/core/.github/workflows/textlint.yml +0 -199
  318. package/core/index.mts +0 -21
  319. package/core/test/array_test.mjs +0 -34
  320. package/core/test/basic_test.mjs +0 -344
  321. package/core/test/calc_test.mjs +0 -140
  322. package/core/test/core_module_test.mjs +0 -23
  323. package/core/test/debug_test.mjs +0 -16
  324. package/core/test/dncl_test.mjs +0 -94
  325. package/core/test/error_message_test.mjs +0 -210
  326. package/core/test/error_test.mjs +0 -16
  327. package/core/test/flow_test.mjs +0 -373
  328. package/core/test/func_call.mjs +0 -160
  329. package/core/test/func_test.mjs +0 -149
  330. package/core/test/indent_test.mjs +0 -364
  331. package/core/test/lex_test.mjs +0 -168
  332. package/core/test/literal_test.mjs +0 -73
  333. package/core/test/nako_lexer_test.mjs +0 -35
  334. package/core/test/nako_logger_test.mjs +0 -76
  335. package/core/test/nako_logger_test.mts +0 -78
  336. package/core/test/plugin_csv_test.mjs +0 -38
  337. package/core/test/plugin_promise_test.mjs +0 -18
  338. package/core/test/plugin_system_test.mjs +0 -630
  339. package/core/test/prepare_test.mjs +0 -96
  340. package/core/test/re_test.mjs +0 -22
  341. package/core/test/side_effects_test.mjs +0 -92
  342. package/core/test/variable_scope_test.mjs +0 -149
  343. 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
+ }