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.
- package/LICENSE +21 -21
- package/README.md +143 -143
- package/batch/.DS_Store +0 -0
- package/batch/browsers.template.md +3 -3
- package/batch/build_browsers.nako3 +72 -72
- package/batch/build_command.nako3 +44 -44
- package/batch/build_nako_version.nako3 +42 -42
- package/batch/calc_hash.nako3 +29 -29
- package/batch/cmd_txt2json.nako3 +74 -74
- package/batch/command.txt +162 -83
- package/batch/command_nakopad.txt +69 -0
- package/batch/download-extlib.nako3 +43 -43
- package/batch/gen_command_nakopad.nako3 +57 -57
- package/batch/jsplugin2text.nako3 +285 -285
- package/batch/pickup_command.nako3 +113 -110
- package/batch/pickup_reserved_words.nako3 +11 -11
- package/batch/publish_version.nako3 +46 -46
- package/batch/show_agents.js +14 -14
- package/batch/turtle2js.nako3 +21 -21
- package/bin/cnako3 +10 -10
- package/core/LICENSE +21 -21
- package/core/README.md +66 -66
- package/core/batch/build_nako_version.nako3 +42 -42
- package/core/command/snako.mjs +105 -105
- package/core/command/snako.mts +116 -116
- package/core/index.mjs +21 -21
- package/core/package.json +47 -47
- package/core/sample/hello.nako3 +7 -7
- package/core/sample/hoge.mjs +4 -4
- package/core/sample/hoge.mts +6 -6
- package/core/src/nako3.mjs +870 -858
- package/core/src/nako3.mts +983 -967
- package/core/src/nako_colors.mjs +78 -78
- package/core/src/nako_colors.mts +86 -86
- package/core/src/nako_core_version.mjs +8 -8
- package/core/src/nako_core_version.mts +19 -19
- package/core/src/nako_csv.mjs +185 -185
- package/core/src/nako_csv.mts +188 -188
- package/core/src/nako_errors.mjs +173 -173
- package/core/src/nako_errors.mts +197 -197
- package/core/src/nako_from_dncl.mjs +255 -255
- package/core/src/nako_from_dncl.mts +250 -250
- package/core/src/nako_gen.mjs +1647 -1648
- package/core/src/nako_gen.mts +1718 -1719
- package/core/src/nako_gen_async.mjs +1659 -1659
- package/core/src/nako_gen_async.mts +1732 -1732
- package/core/src/nako_global.mjs +109 -107
- package/core/src/nako_global.mts +141 -138
- package/core/src/nako_indent.mjs +445 -445
- package/core/src/nako_indent.mts +492 -492
- package/core/src/nako_josi_list.mjs +38 -38
- package/core/src/nako_josi_list.mts +45 -45
- package/core/src/nako_lex_rules.mjs +253 -253
- package/core/src/nako_lex_rules.mts +260 -260
- package/core/src/nako_lexer.mjs +609 -609
- package/core/src/nako_lexer.mts +612 -612
- package/core/src/nako_logger.mjs +199 -199
- package/core/src/nako_logger.mts +232 -232
- package/core/src/nako_parser3.mjs +2441 -2439
- package/core/src/nako_parser3.mts +2197 -2195
- package/core/src/nako_parser_base.mjs +371 -370
- package/core/src/nako_parser_base.mts +372 -370
- package/core/src/nako_parser_const.mjs +37 -37
- package/core/src/nako_parser_const.mts +37 -37
- package/core/src/nako_prepare.mjs +304 -304
- package/core/src/nako_prepare.mts +315 -315
- package/core/src/nako_reserved_words.mjs +38 -38
- package/core/src/nako_reserved_words.mts +38 -38
- package/core/src/nako_source_mapping.mjs +207 -207
- package/core/src/nako_source_mapping.mts +262 -262
- package/core/src/nako_test.mjs +37 -37
- package/core/src/nako_types.mjs +13 -25
- package/core/src/nako_types.mts +144 -151
- package/core/src/plugin_csv.mjs +49 -49
- package/core/src/plugin_csv.mts +50 -50
- package/core/src/plugin_math.mjs +328 -328
- package/core/src/plugin_math.mts +326 -326
- package/core/src/plugin_promise.mjs +91 -91
- package/core/src/plugin_promise.mts +91 -91
- package/core/src/plugin_system.mjs +2832 -2832
- package/core/src/plugin_system.mts +2690 -2690
- package/core/src/plugin_test.mjs +34 -34
- package/core/src/plugin_test.mts +34 -34
- package/demo/.DS_Store +0 -0
- package/demo/ace_editor.html +89 -89
- package/demo/ace_editor_tabs.html +161 -161
- package/demo/basic.html +71 -71
- package/demo/browsers.html +10 -9
- package/demo/css/basic.css +3 -3
- package/demo/css/common.css +157 -157
- package/demo/css/editor.css +8 -8
- package/demo/css/flow.css +3 -3
- package/demo/css/index.css +3 -3
- package/demo/extlib/.DS_Store +0 -0
- package/demo/flow.html +98 -98
- package/demo/graph.html +53 -53
- package/demo/image/nakopad-icon256.png +0 -0
- package/demo/index.html +133 -133
- package/demo/js/common.js +17 -17
- package/demo/js/turtle3d_test.js +44 -44
- package/demo/js/turtle_test.js +45 -45
- package/demo/nako3/calc.nako3 +4 -4
- package/demo/runscript.html +47 -47
- package/demo/runscript2.html +33 -33
- package/demo/runscript3.html +35 -35
- package/demo/runscript4.html +33 -33
- package/demo/turtle.html +58 -58
- package/demo/turtle2.html +141 -141
- package/demo/turtle3.html +279 -279
- package/demo/turtle3d.html +58 -58
- package/demo/turtle3d2.html +107 -107
- package/demo/version.html +24 -24
- package/doc/SETUP.md +157 -157
- package/doc/about.md +17 -17
- package/doc/browsers.md +26 -26
- package/doc/docgen.md +21 -21
- package/doc/editor.md +44 -44
- package/doc/files.md +39 -39
- package/doc/plugins.md +234 -234
- package/doc/release.md +79 -79
- package/doc/textlint.md +43 -43
- package/doc/win32.md +57 -57
- package/package.json +195 -195
- package/release/_hash.txt +28 -28
- package/release/_script-tags.txt +14 -14
- package/release/command.json +1 -1
- package/release/command.json.js +1 -1
- package/release/command_cnako3.json +1 -1
- package/release/command_list.json +1 -1
- package/release/editor.js +1 -1
- package/release/nako_gen_async.js +2 -1
- package/release/nako_gen_async.js.LICENSE.txt +35 -0
- package/release/plugin_caniuse.js.LICENSE.txt +11 -0
- package/release/plugin_csv.js +1 -1
- package/release/plugin_csv.js.LICENSE.txt +15 -0
- package/release/plugin_datetime.js.LICENSE.txt +15 -0
- package/release/plugin_kansuji.js.LICENSE.txt +3 -0
- package/release/plugin_markup.js.LICENSE.txt +11 -0
- package/release/plugin_turtle.js.LICENSE.txt +15 -0
- package/release/plugin_webworker.js.LICENSE.txt +3 -0
- package/release/plugin_weykturtle3d.js.LICENSE.txt +3 -0
- package/release/stats.json +1 -1
- package/release/version.js +1 -1
- package/release/wnako3.js +1 -1
- package/release/wnako3.js.LICENSE.txt +203 -1
- package/release/wnako3webworker.js +2 -1
- package/release/wnako3webworker.js.LICENSE.txt +131 -0
- package/src/.DS_Store +0 -0
- package/src/browsers.txt +12 -11
- package/src/browsers_agents.json +2 -2
- package/src/browsers_agents.mjs +1 -1
- package/src/cnako3.mjs +17 -17
- package/src/cnako3.mts +18 -18
- package/src/cnako3mod.mjs +682 -707
- package/src/cnako3mod.mts +688 -712
- package/src/commander_ja.mjs +164 -164
- package/src/commander_ja.mts +161 -161
- package/src/enako3.mjs +68 -68
- package/src/era.mjs +22 -22
- package/src/image_turtle-elephant.mjs +2 -2
- package/src/image_turtle-panda.mjs +2 -2
- package/src/image_turtle64.mjs +2 -2
- package/src/index.mjs +9 -9
- package/src/index.mts +10 -10
- package/src/nako3editorfix.sfd +106 -106
- package/src/nako_version.mjs +8 -8
- package/src/nako_version.mts +2 -2
- package/src/plugin_browser.mjs +213 -213
- package/src/plugin_browser.mts +206 -206
- package/src/plugin_browser_ajax.mjs +399 -399
- package/src/plugin_browser_audio.mjs +109 -109
- package/src/plugin_browser_canvas.mjs +449 -449
- package/src/plugin_browser_chart.mjs +294 -294
- package/src/plugin_browser_color.mjs +49 -49
- package/src/plugin_browser_crypto.mjs +26 -26
- package/src/plugin_browser_dialog.mjs +53 -53
- package/src/plugin_browser_dom_basic.mjs +336 -336
- package/src/plugin_browser_dom_event.mjs +193 -193
- package/src/plugin_browser_dom_parts.mjs +396 -396
- package/src/plugin_browser_geolocation.mjs +51 -51
- package/src/plugin_browser_hotkey.mjs +25 -25
- package/src/plugin_browser_html.mjs +59 -59
- package/src/plugin_browser_in_worker.mjs +45 -45
- package/src/plugin_browser_location.mjs +21 -21
- package/src/plugin_browser_speech.mjs +111 -111
- package/src/plugin_browser_storage.mjs +121 -121
- package/src/plugin_browser_system.mjs +31 -31
- package/src/plugin_browser_websocket.mjs +73 -73
- package/src/plugin_caniuse.mjs +29 -29
- package/src/plugin_datetime.mjs +394 -394
- package/src/plugin_httpserver.mjs +277 -277
- package/src/plugin_httpserver.mts +286 -286
- package/src/plugin_kansuji.mjs +224 -224
- package/src/plugin_keigo.mjs +55 -55
- package/src/plugin_markup.mjs +32 -32
- package/src/plugin_node.mjs +1047 -1047
- package/src/plugin_node.mts +980 -980
- package/src/plugin_turtle.mjs +647 -647
- package/src/plugin_webworker.mjs +334 -334
- package/src/plugin_weykturtle3d.mjs +1214 -1214
- package/src/plugin_worker.mjs +95 -95
- package/src/repl.nako3 +63 -63
- package/src/wnako3.mjs +12 -12
- package/src/wnako3.mts +11 -11
- package/src/wnako3_editor.css +215 -215
- package/src/wnako3_editor.mjs +1542 -1542
- package/src/wnako3_editor.mts +1658 -1657
- package/src/wnako3mod.mjs +213 -213
- package/src/wnako3mod.mts +214 -214
- package/src/wnako3webworker.mjs +69 -69
- package/test/.DS_Store +0 -0
- package/test/ace_editor/karma.config.js +94 -94
- package/test/ace_editor/test/.babelrc.json +3 -3
- package/test/ace_editor/test/ace_editor_test.js +178 -178
- package/test/ace_editor/test/html/custom_context.html +139 -139
- package/test/async/async_basic_test.mjs +122 -122
- package/test/browser/.DS_Store +0 -0
- package/test/browser/karma.config.js +221 -221
- package/test/browser/test/.babelrc.json +3 -3
- package/test/browser/test/compare_util.js +50 -50
- package/test/browser/test/html/div_basic.html +2 -2
- package/test/browser/test/html/event_dom_form.html +4 -4
- package/test/browser/test/html/event_dom_scrolldiv.html +5 -5
- package/test/browser/test/import_plugin_checker.js +24 -24
- package/test/browser/test/plugin_browser_test.js +51 -51
- package/test/browser/test/plugin_browser_test_ajax.js +123 -123
- package/test/browser/test/plugin_browser_test_color.js +18 -18
- package/test/browser/test/plugin_browser_test_dialog.js +72 -72
- package/test/browser/test/plugin_browser_test_dom_event.js +598 -598
- package/test/browser/test/plugin_browser_test_dom_parts.js +125 -125
- package/test/browser/test/plugin_browser_test_system.js +9 -9
- package/test/browser/test/plugin_turtle_test.js +817 -817
- package/test/browser/test/plugin_webworker_test.js +86 -86
- package/test/browser/test/require_test.js +68 -68
- package/test/bundled/.DS_Store +0 -0
- package/test/bundled/karma.config.base.js +117 -117
- package/test/bundled/karma.config.js +86 -86
- package/test/bundled/test/.babelrc.json +3 -3
- package/test/bundled/test/bundled_test.js +69 -69
- package/test/bundled/test/html/custom_context.html +65 -65
- package/test/bundled/test/html/custom_debug.html +66 -66
- package/test/bundled/test4b.cmd +52 -52
- package/test/bundled/test_base/.DS_Store +0 -0
- package/test/bundled/test_base/.babelrc.json +3 -3
- package/test/bundled/test_base/_checktool_test.js +25 -25
- package/test/bundled/test_base/basic_ajax_test.js +56 -56
- package/test/bundled/test_base/basic_async_test.js +18 -18
- package/test/bundled/test_base/basic_test.js +153 -153
- package/test/bundled/test_base/calc_test.js +132 -132
- package/test/bundled/test_base/css/browsers_box.css +114 -114
- package/test/bundled/test_base/html/custom_context.html +69 -69
- package/test/bundled/test_base/html/custom_debug.html +71 -71
- package/test/bundled/test_base/js/browsers_box.js +72 -72
- package/test/bundled/test_base/plugin_csv_test.js +37 -37
- package/test/bundled/test_base/plugin_datetime_test.js +115 -115
- package/test/bundled/test_base/plugin_kansuji_test.js +49 -49
- package/test/bundled/test_base/plugin_system_test.js +410 -410
- package/test/bundled/test_base/plugin_webworker_test.js +53 -53
- package/test/bundled/test_base/test_utils.js +191 -191
- package/test/common/.DS_Store +0 -0
- package/test/common/plugin_browser_test.mjs +22 -22
- package/test/common/plugin_browser_ut_audio_test.mjs +108 -108
- package/test/common/plugin_browser_ut_color_test.mjs +21 -21
- package/test/common/plugin_browser_ut_dialog_test.mjs +100 -100
- package/test/common/plugin_browser_ut_html_test.mjs +13 -13
- package/test/common/plugin_browser_ut_system_test.mjs +10 -10
- package/test/common/plugin_markup_test.mjs +23 -23
- package/test/jsconfig.json +19 -19
- package/test/karma.config.js +91 -91
- package/test/node/.DS_Store +0 -0
- package/test/node/async_test.mjs +96 -96
- package/test/node/commander_ja_test.mjs +89 -89
- package/test/node/error_message_test.mjs +243 -243
- package/test/node/kai_test.nako3 +6 -6
- package/test/node/node_test.mjs +60 -60
- package/test/node/plugin_broken.js.txt +3 -3
- package/test/node/plugin_browser_ut_ajax_test.mjs.todo +357 -357
- package/test/node/plugin_browser_ut_location_test.mjs +42 -42
- package/test/node/plugin_markup_test.mjs +47 -47
- package/test/node/plugin_math_test.mjs +45 -45
- package/test/node/plugin_node_test.mjs +98 -98
- package/test/node/plugin_test.mjs +44 -44
- package/test/node/relative_import_test_1.nako3 +1 -1
- package/test/node/relative_import_test_2.nako3 +2 -2
- package/test/node/require_nako3_test.mjs +67 -67
- package/test/node/requiretest.nako3 +4 -4
- package/test/node/requiretest_indirect.nako3 +1 -1
- package/test/node/requiretest_name.nako3 +5 -5
- package/test/node/runtime_error.nako3 +2 -2
- package/test/node/scope1.nako3 +10 -10
- package/test/node/scope2.nako3 +12 -12
- package/test/node/side_effects_test.mjs +39 -39
- package/test/node/sjis.txt +5 -5
- package/test/node/syntax_error.nako3 +1 -1
- package/test/node/wnako3_editor_test.mjs +384 -384
- package/tools/.DS_Store +0 -0
- package/tools/README.md +12 -12
- package/tools/check_new_version.nako3 +25 -25
- package/tools/nako3edit/.DS_Store +0 -0
- package/tools/nako3edit/a.sqlite3 +0 -0
- package/tools/nako3edit/html/.DS_Store +0 -0
- package/tools/nako3edit/html/daisyui/LICENSE +22 -22
- package/tools/nako3edit/html/daisyui/version_2.14.1 +1 -1
- package/tools/nako3edit/html/edit.html +170 -170
- package/tools/nako3edit/html/edit_plugin.js +6 -6
- package/tools/nako3edit/html/files.html +125 -125
- package/tools/nako3edit/html/nako3edit.css +65 -65
- package/tools/nako3edit/index.mjs +248 -248
- package/tools/nako3server/index.html +10 -10
- package/tools/nako3server/index.mjs +116 -116
- package/tools/nako3server/index.nako3 +34 -34
- package/core/.editorconfig +0 -6
- package/core/.eslintrc.cjs +0 -33
- package/core/.github/dependabot.yml +0 -7
- package/core/.github/workflows/nodejs.yml +0 -37
- package/core/.github/workflows/super-linter.yml +0 -61
- package/core/.github/workflows/textlint.yml +0 -199
- package/core/index.mts +0 -21
- package/core/test/array_test.mjs +0 -34
- package/core/test/basic_test.mjs +0 -344
- package/core/test/calc_test.mjs +0 -140
- package/core/test/core_module_test.mjs +0 -23
- package/core/test/debug_test.mjs +0 -16
- package/core/test/dncl_test.mjs +0 -94
- package/core/test/error_message_test.mjs +0 -210
- package/core/test/error_test.mjs +0 -16
- package/core/test/flow_test.mjs +0 -373
- package/core/test/func_call.mjs +0 -160
- package/core/test/func_test.mjs +0 -149
- package/core/test/indent_test.mjs +0 -364
- package/core/test/lex_test.mjs +0 -168
- package/core/test/literal_test.mjs +0 -73
- package/core/test/nako_lexer_test.mjs +0 -35
- package/core/test/nako_logger_test.mjs +0 -76
- package/core/test/nako_logger_test.mts +0 -78
- package/core/test/plugin_csv_test.mjs +0 -38
- package/core/test/plugin_promise_test.mjs +0 -18
- package/core/test/plugin_system_test.mjs +0 -630
- package/core/test/prepare_test.mjs +0 -96
- package/core/test/re_test.mjs +0 -22
- package/core/test/side_effects_test.mjs +0 -92
- package/core/test/variable_scope_test.mjs +0 -149
- package/core/tsconfig.json +0 -101
package/core/src/nako_logger.mts
CHANGED
|
@@ -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
|
+
}
|