nadesiko3 3.3.48 → 3.3.49
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/.editorconfig +6 -0
- package/core/.eslintrc.cjs +33 -0
- package/core/.github/dependabot.yml +7 -0
- package/core/.github/workflows/nodejs.yml +37 -0
- package/core/.github/workflows/super-linter.yml +61 -0
- package/core/.github/workflows/textlint.yml +199 -0
- package/core/LICENSE +21 -0
- package/core/README.md +66 -0
- package/core/batch/build_nako_version.nako3 +42 -0
- package/core/command/snako.mjs +105 -0
- package/core/command/snako.mts +116 -0
- package/core/index.mjs +21 -0
- package/core/index.mts +21 -0
- package/core/package.json +47 -0
- package/core/sample/hello.nako3 +7 -0
- package/core/sample/hoge.mjs +4 -0
- package/core/sample/hoge.mts +6 -0
- package/core/src/nako3.mjs +858 -0
- package/core/src/nako3.mts +967 -0
- package/core/src/nako_colors.mjs +78 -0
- package/core/src/nako_colors.mts +86 -0
- package/core/src/nako_core_version.mjs +8 -0
- package/core/src/nako_core_version.mts +19 -0
- package/core/src/nako_csv.mjs +185 -0
- package/core/src/nako_csv.mts +188 -0
- package/core/src/nako_errors.mjs +173 -0
- package/core/src/nako_errors.mts +197 -0
- package/core/src/nako_from_dncl.mjs +255 -0
- package/core/src/nako_from_dncl.mts +250 -0
- package/core/src/nako_gen.mjs +1648 -0
- package/core/src/nako_gen.mts +1719 -0
- package/core/src/nako_gen_async.mjs +1659 -0
- package/core/src/nako_gen_async.mts +1732 -0
- package/core/src/nako_global.mjs +107 -0
- package/core/src/nako_global.mts +138 -0
- package/core/src/nako_indent.mjs +445 -0
- package/core/src/nako_indent.mts +492 -0
- package/core/src/nako_josi_list.mjs +38 -0
- package/core/src/nako_josi_list.mts +45 -0
- package/core/src/nako_lex_rules.mjs +253 -0
- package/core/src/nako_lex_rules.mts +260 -0
- package/core/src/nako_lexer.mjs +609 -0
- package/core/src/nako_lexer.mts +612 -0
- package/core/src/nako_logger.mjs +199 -0
- package/core/src/nako_logger.mts +232 -0
- package/core/src/nako_parser3.mjs +2439 -0
- package/core/src/nako_parser3.mts +2195 -0
- package/core/src/nako_parser_base.mjs +370 -0
- package/core/src/nako_parser_base.mts +370 -0
- package/core/src/nako_parser_const.mjs +37 -0
- package/core/src/nako_parser_const.mts +37 -0
- package/core/src/nako_prepare.mjs +304 -0
- package/core/src/nako_prepare.mts +315 -0
- package/core/src/nako_reserved_words.mjs +38 -0
- package/core/src/nako_reserved_words.mts +38 -0
- package/core/src/nako_source_mapping.mjs +207 -0
- package/core/src/nako_source_mapping.mts +262 -0
- package/core/src/nako_test.mjs +37 -0
- package/core/src/nako_types.mjs +25 -0
- package/core/src/nako_types.mts +151 -0
- package/core/src/plugin_csv.mjs +49 -0
- package/core/src/plugin_csv.mts +50 -0
- package/core/src/plugin_math.mjs +328 -0
- package/core/src/plugin_math.mts +326 -0
- package/core/src/plugin_promise.mjs +91 -0
- package/core/src/plugin_promise.mts +91 -0
- package/core/src/plugin_system.mjs +2832 -0
- package/core/src/plugin_system.mts +2690 -0
- package/core/src/plugin_test.mjs +34 -0
- package/core/src/plugin_test.mts +34 -0
- package/core/test/array_test.mjs +34 -0
- package/core/test/basic_test.mjs +344 -0
- package/core/test/calc_test.mjs +140 -0
- package/core/test/core_module_test.mjs +23 -0
- package/core/test/debug_test.mjs +16 -0
- package/core/test/dncl_test.mjs +94 -0
- package/core/test/error_message_test.mjs +210 -0
- package/core/test/error_test.mjs +16 -0
- package/core/test/flow_test.mjs +373 -0
- package/core/test/func_call.mjs +160 -0
- package/core/test/func_test.mjs +149 -0
- package/core/test/indent_test.mjs +364 -0
- package/core/test/lex_test.mjs +168 -0
- package/core/test/literal_test.mjs +73 -0
- package/core/test/nako_lexer_test.mjs +35 -0
- package/core/test/nako_logger_test.mjs +76 -0
- package/core/test/nako_logger_test.mts +78 -0
- package/core/test/plugin_csv_test.mjs +38 -0
- package/core/test/plugin_promise_test.mjs +18 -0
- package/core/test/plugin_system_test.mjs +630 -0
- package/core/test/prepare_test.mjs +96 -0
- package/core/test/re_test.mjs +22 -0
- package/core/test/side_effects_test.mjs +92 -0
- package/core/test/variable_scope_test.mjs +149 -0
- package/core/tsconfig.json +101 -0
- package/package.json +4 -2
- package/release/_hash.txt +12 -12
- package/release/_script-tags.txt +14 -14
- package/release/editor.js +1 -1
- package/release/stats.json +1 -1
- package/release/version.js +1 -1
- package/release/wnako3.js +1 -1
- package/src/nako_version.mjs +2 -2
- package/src/nako_version.mts +2 -2
- package/test/async/async_basic_test.mjs +3 -3
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import assert from 'assert'
|
|
2
|
+
import { NakoCompiler } from '../src/nako3.mjs'
|
|
3
|
+
import { NakoDncl } from '../src/nako_from_dncl.mjs'
|
|
4
|
+
|
|
5
|
+
describe('dncl (#1140)', () => {
|
|
6
|
+
const cmp = (/** @type {string} */ src, /** @type {string} */ expected) => {
|
|
7
|
+
src = NakoDncl.convert(src, 'main.nako3')
|
|
8
|
+
src = src.replace(/\s+$/, '')
|
|
9
|
+
expected = expected.replace(/\s+$/, '')
|
|
10
|
+
assert.strictEqual(src, expected)
|
|
11
|
+
}
|
|
12
|
+
const cmpNako = async (/** @type {string} */ code, /** @type {string} */ res) => {
|
|
13
|
+
const nako = new NakoCompiler()
|
|
14
|
+
nako.logger.debug('code=' + code)
|
|
15
|
+
assert.strictEqual((await nako.runAsync(code)).log, res)
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
it('代入文', () => {
|
|
19
|
+
cmp('!DNCLモード\n' +
|
|
20
|
+
'A←3\n',
|
|
21
|
+
// ---
|
|
22
|
+
'!DNCLモード\n' +
|
|
23
|
+
'A=3\n')
|
|
24
|
+
cmp('!DNCLモード\n' +
|
|
25
|
+
'A←3, B←5\n',
|
|
26
|
+
// ---
|
|
27
|
+
'!DNCLモード\n' +
|
|
28
|
+
'A=3, B=5\n')
|
|
29
|
+
})
|
|
30
|
+
it('もし文', () => {
|
|
31
|
+
cmp('!DNCLモード\n' +
|
|
32
|
+
'もしA=5ならば\n「OK」と表示\nを実行する',
|
|
33
|
+
// ---
|
|
34
|
+
'!DNCLモード\n' +
|
|
35
|
+
'もしA=5ならば\n「OK」と表示\nここまで')
|
|
36
|
+
})
|
|
37
|
+
// 実行テスト
|
|
38
|
+
it('簡単な実行テスト', async () => {
|
|
39
|
+
await cmpNako('!DNCLモード\nA←5,B←6,C←7。Cを表示する', '7')
|
|
40
|
+
await cmpNako('!DNCLモード\nA=[]。A[1]=3;A[2]=3;Aの要素数を表示する', '2')
|
|
41
|
+
})
|
|
42
|
+
it('配列の入れ替え', async () => {
|
|
43
|
+
await cmpNako('!DNCLモード\nA={{11,12,13},{21,22,23}}。A[1,2]を表示する', '21')
|
|
44
|
+
await cmpNako('!DNCLモード\nA={}。A[1]={11,12,13}, A[2]={21,22,23};A[2,1]を表示する', '12')
|
|
45
|
+
await cmpNako('!DNCLモード\nA={{11,12,13},{21,22,23}}。B=A[3,2];Bを表示する', '23')
|
|
46
|
+
await cmpNako('!DNCLモード\nA={{11,12,13},{21,22,23}}。C=2;AA=A[1+C,1];AAを表示', '13')
|
|
47
|
+
await cmpNako('!DNCLモード\nA={{11,12,13},{21,22,23}}。X=2;Y=1;AA=A[X,Y+1];AAを表示', '22')
|
|
48
|
+
})
|
|
49
|
+
it('配列の自動初期化(#1143)', async () => {
|
|
50
|
+
await cmpNako('!DNCLモード\nA[1]←111。A[1]を表示する', '111')
|
|
51
|
+
await cmpNako('!DNCLモード\nA[3,3]=3;A[3,3]を表示する', '3')
|
|
52
|
+
await cmpNako('!DNCLモード\nA[3,2,1]=30;A[3,2,1]を表示する', '30')
|
|
53
|
+
await cmpNako('!DNCLモード\nA[1,1]=11,A[1,2]=12;A[1,2]を表示する', '12')
|
|
54
|
+
})
|
|
55
|
+
it('インデントを|で表現する', async () => {
|
|
56
|
+
await cmpNako('!DNCLモード\nA=3;もしA>1ならば\n|A←A+1\nを実行する。\nAを表示する。', '4')
|
|
57
|
+
})
|
|
58
|
+
it('表示エミュレート', async () => {
|
|
59
|
+
await cmpNako('!DNCLモード\nx←10,y←20\nxと"-"とyを表示する。', '10-20')
|
|
60
|
+
await cmpNako('!DNCLモード\nx←10,y←20\n"("とxと","とyと")"を表示する。', '(10,20)')
|
|
61
|
+
await cmpNako('!DNCLモード\nx←10,y←20,z←30\n"("とxと","とyと","とzと")"を表示する。', '(10,20,30)')
|
|
62
|
+
await cmpNako('!DNCLモード\nx←10,y←20\n「<」とxと","とyと「>」を表示する。', '<10,20>')
|
|
63
|
+
// #1079
|
|
64
|
+
await cmpNako('!DNCLモード\nx←10,y←20\n「<」 と x と "," と y と 「>」 を 表示する。', '<10,20>')
|
|
65
|
+
})
|
|
66
|
+
it('乱数エミュレート #1146', async () => {
|
|
67
|
+
await cmpNako('!DNCLモード\nr ← 乱数 (5,10)\nもし(rが5以上)かつ(rが10以下)ならば「OK」と表示する。', 'OK')
|
|
68
|
+
await cmpNako('!DNCLモード\nr ← 乱数 (1,6)\nもし(rが1以上)かつ(rが6以下)ならば「OK」と表示する。', 'OK')
|
|
69
|
+
})
|
|
70
|
+
it('二進 #1146', async () => {
|
|
71
|
+
await cmpNako('!DNCLモード\nA← 二進 (9)\nAを表示する。', '1001')
|
|
72
|
+
await cmpNako('!DNCLモード\nA← 二進 (255)\nAを表示する。', '11111111')
|
|
73
|
+
await cmpNako('!DNCLモード\n二進で表示 (255)', '11111111')
|
|
74
|
+
})
|
|
75
|
+
it('減らす・増やす #1149', async () => {
|
|
76
|
+
await cmpNako('!DNCLモード\nsaihu←1000。syuppi←500。saihuをsyuppi減らす。saihuを表示する。', '500')
|
|
77
|
+
await cmpNako('!DNCLモード\nsaihu←1000。syuppi←500。saihuをsyuppi増やす。saihuを表示する。', '1500')
|
|
78
|
+
})
|
|
79
|
+
it('DNCLで「もし」文の否定形が動かない #1148', async () => {
|
|
80
|
+
await cmpNako('!DNCLモード\nkosu←1\nもし、kosu>27でないならば\n|「OK」を表示する。\nを実行する。\n', 'OK')
|
|
81
|
+
})
|
|
82
|
+
it('DNCLで後判定のループが動かない #1147', async () => {
|
|
83
|
+
await cmpNako('!DNCLモード\nA←1\n繰り返し,\nAを表示する\nAを1増やす\nを,A>3になるまで実行する\n', '1\n2\n3')
|
|
84
|
+
await cmpNako('!DNCLモード\nA←1\n繰り返し,\nAを表示する\nAを1だけ増やす\nを,A>3になるまで実行する\n', '1\n2\n3')
|
|
85
|
+
})
|
|
86
|
+
it('DNCLで÷は整数の割り算 #1152', async () => {
|
|
87
|
+
await cmpNako('!DNCLモード\n7/2を表示する', '3.5')
|
|
88
|
+
await cmpNako('!DNCLモード\n7÷2を表示する', '3')
|
|
89
|
+
})
|
|
90
|
+
it('「!」を💡で書けるようにする #1184', async () => {
|
|
91
|
+
await cmpNako('💡DNCLモード\n7/2を表示する', '3.5')
|
|
92
|
+
await cmpNako('💡DNCLモード\n7÷2を表示する', '3')
|
|
93
|
+
})
|
|
94
|
+
})
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
/* eslint-disable no-undef */
|
|
2
|
+
import { NakoCompiler } from '../src/nako3.mjs'
|
|
3
|
+
import { NakoSyntaxError, NakoRuntimeError, NakoIndentError, NakoLexerError } from '../src/nako_errors.mjs'
|
|
4
|
+
import assert from 'assert'
|
|
5
|
+
|
|
6
|
+
// eslint-disable-next-line no-undef
|
|
7
|
+
describe('error_message', () => {
|
|
8
|
+
const nako = new NakoCompiler()
|
|
9
|
+
const cmp = (/** @type {string} */ code, /** @type {string[]} */ resArr, /** @type {typeof NakoLexerError} */ ErrorClass, _nako = nako) => {
|
|
10
|
+
_nako.reset()
|
|
11
|
+
_nako.logger.debug('code=' + code)
|
|
12
|
+
assert.rejects(
|
|
13
|
+
async () => await _nako.run(code, path.join(__dirname, 'main.nako3')),
|
|
14
|
+
(err) => {
|
|
15
|
+
assert(err instanceof ErrorClass)
|
|
16
|
+
for (const res of resArr) {
|
|
17
|
+
if (!err.message.includes(res)) {
|
|
18
|
+
throw new Error(`${JSON.stringify(err.message)} が ${JSON.stringify(res)} を含みません。`)
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return true
|
|
22
|
+
}
|
|
23
|
+
)
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
describe('字句解析エラー', () => {
|
|
27
|
+
it('エラー位置の取得', () => {
|
|
28
|
+
cmp('\n「こんに{ちは」と表示する', [
|
|
29
|
+
'2行目',
|
|
30
|
+
'main.nako3'
|
|
31
|
+
], NakoLexerError)
|
|
32
|
+
})
|
|
33
|
+
})
|
|
34
|
+
|
|
35
|
+
describe('構文エラー', () => {
|
|
36
|
+
it('比較', () => {
|
|
37
|
+
return cmp('「こんにち」はを表示', [
|
|
38
|
+
'不完全な文です。',
|
|
39
|
+
'演算子『=』が解決していません。',
|
|
40
|
+
'演算子『=』は『文字列『こんにち』と単語『を表示』が等しいかどうかの比較』として使われています。',
|
|
41
|
+
'main.nako3'
|
|
42
|
+
], NakoSyntaxError)
|
|
43
|
+
})
|
|
44
|
+
it('単項演算子', () => {
|
|
45
|
+
cmp('!(はい + 1)', [
|
|
46
|
+
'不完全な文です。',
|
|
47
|
+
'演算子『not』が解決していません。',
|
|
48
|
+
'演算子『not』は『演算子『+』に演算子『not』を適用した式』として使われています。',
|
|
49
|
+
'main.nako3'
|
|
50
|
+
], NakoSyntaxError)
|
|
51
|
+
})
|
|
52
|
+
it('2項演算子', () => {
|
|
53
|
+
cmp('1 + 2', [
|
|
54
|
+
'不完全な文です。',
|
|
55
|
+
'演算子『+』が解決していません。',
|
|
56
|
+
'演算子『+』は『数値1と数値2に演算子『+』を適用した式』として使われています。',
|
|
57
|
+
'main.nako3'
|
|
58
|
+
], NakoSyntaxError)
|
|
59
|
+
})
|
|
60
|
+
it('変数のみの式', () => {
|
|
61
|
+
cmp('A', [
|
|
62
|
+
'不完全な文です。',
|
|
63
|
+
'単語『A』が解決していません。',
|
|
64
|
+
'main.nako3'
|
|
65
|
+
], NakoSyntaxError)
|
|
66
|
+
})
|
|
67
|
+
it('複数のノードが使われていない場合', () => {
|
|
68
|
+
cmp('あ「こんにちは」はは表示', [
|
|
69
|
+
'不完全な文です。',
|
|
70
|
+
'単語『あ』、演算子『=』が解決していません。',
|
|
71
|
+
'演算子『=』は『文字列『こんにちは』と単語『は表示』が等しいかどうかの比較』として使われています。',
|
|
72
|
+
'main.nako3'
|
|
73
|
+
], NakoSyntaxError)
|
|
74
|
+
})
|
|
75
|
+
it('関数の宣言でエラー', () => {
|
|
76
|
+
cmp('●30とは', [
|
|
77
|
+
'関数30の宣言でエラー。',
|
|
78
|
+
'main.nako3'
|
|
79
|
+
], NakoSyntaxError)
|
|
80
|
+
})
|
|
81
|
+
it('"_"がある場合', () => {
|
|
82
|
+
cmp(
|
|
83
|
+
'a = [ _\n' +
|
|
84
|
+
' 1, 2, 3\n' +
|
|
85
|
+
']\n' +
|
|
86
|
+
'「こんにちは」」と表示する', [
|
|
87
|
+
'4行目',
|
|
88
|
+
'main.nako3'
|
|
89
|
+
], NakoLexerError
|
|
90
|
+
)
|
|
91
|
+
})
|
|
92
|
+
})
|
|
93
|
+
describe('実行時エラー', () => {
|
|
94
|
+
it('「エラー発生」の場合', () => {
|
|
95
|
+
cmp(
|
|
96
|
+
'「エラーメッセージ」のエラー発生', [
|
|
97
|
+
'1行目'
|
|
98
|
+
], NakoRuntimeError)
|
|
99
|
+
})
|
|
100
|
+
it('エラー位置をプロパティから取得 - 単純な例', () => {
|
|
101
|
+
assert.throws(
|
|
102
|
+
() => nako.run('1を表示\n1のエラー発生', 'main.nako3'),
|
|
103
|
+
err => {
|
|
104
|
+
assert.strictEqual(err.type, 'NakoRuntimeError')
|
|
105
|
+
assert.strictEqual(err.line, 1) // 2行目
|
|
106
|
+
assert.strictEqual(err.file, 'main.nako3')
|
|
107
|
+
return true
|
|
108
|
+
}
|
|
109
|
+
)
|
|
110
|
+
})
|
|
111
|
+
it('エラー位置をプロパティから取得 - 前後に文がある場合', () => {
|
|
112
|
+
assert.throws(
|
|
113
|
+
() => nako.run('1を表示\n1を表示。1のエラー発生。1を表示。', 'main.nako3'),
|
|
114
|
+
err => {
|
|
115
|
+
assert.strictEqual(err.type, 'NakoRuntimeError')
|
|
116
|
+
assert.strictEqual(err.line, 1) // 2行目
|
|
117
|
+
assert.strictEqual(err.file, 'main.nako3')
|
|
118
|
+
return true
|
|
119
|
+
}
|
|
120
|
+
)
|
|
121
|
+
})
|
|
122
|
+
it('エラー位置をプロパティから取得 - 1行目の場合', () => {
|
|
123
|
+
assert.throws(
|
|
124
|
+
() => nako.run('1のエラー発生', 'main.nako3'),
|
|
125
|
+
err => {
|
|
126
|
+
assert.strictEqual(err.type, 'NakoRuntimeError')
|
|
127
|
+
assert.strictEqual(err.line, 0) // 1行目
|
|
128
|
+
assert.strictEqual(err.file, 'main.nako3')
|
|
129
|
+
return true
|
|
130
|
+
}
|
|
131
|
+
)
|
|
132
|
+
})
|
|
133
|
+
it('エラー位置をプロパティから取得 - repeatTimes', () => {
|
|
134
|
+
const nako = new NakoCompiler()
|
|
135
|
+
assert.throws(
|
|
136
|
+
() => nako.run('3回\n1のエラー発生\nここまで', 'main.nako3'),
|
|
137
|
+
err => {
|
|
138
|
+
assert.strictEqual(err.type, 'NakoRuntimeError')
|
|
139
|
+
assert.strictEqual(err.line, 1) // 2行目
|
|
140
|
+
assert.strictEqual(err.file, 'main.nako3')
|
|
141
|
+
return true
|
|
142
|
+
}
|
|
143
|
+
)
|
|
144
|
+
})
|
|
145
|
+
it('「秒後」の中でエラーが発生した場合', async () => {
|
|
146
|
+
const nako = new NakoCompiler()
|
|
147
|
+
const logger = nako.getLogger()
|
|
148
|
+
logger.addListener('error', ({ level, noColor }) => {
|
|
149
|
+
const s = (noColor + '\n').split('\n')[0]
|
|
150
|
+
assert.strictEqual(level, 'error')
|
|
151
|
+
assert.strictEqual(s, '[実行時エラー]main.nako3(2行目): 1')
|
|
152
|
+
})
|
|
153
|
+
await nako.run('0.0001秒後には\n1のエラー発生\nここまで', 'main.nako3')
|
|
154
|
+
})
|
|
155
|
+
})
|
|
156
|
+
describe('インデント構文のエラー', () => {
|
|
157
|
+
it('『ここまで』を使用', () => {
|
|
158
|
+
cmp(
|
|
159
|
+
'!インデント構文\n' +
|
|
160
|
+
'もしはいならば\n' +
|
|
161
|
+
'ここまで\n', [
|
|
162
|
+
'3行目',
|
|
163
|
+
'main.nako3',
|
|
164
|
+
'インデント構文が有効化されているときに『ここまで』を使うことはできません。'
|
|
165
|
+
], NakoIndentError)
|
|
166
|
+
})
|
|
167
|
+
it('『ここまで』を使用 - "_"を使った場合', () => {
|
|
168
|
+
cmp(
|
|
169
|
+
'!インデント構文\n' +
|
|
170
|
+
'A=[ _\n' +
|
|
171
|
+
']\n' +
|
|
172
|
+
'ここまで\n', [
|
|
173
|
+
'4行目',
|
|
174
|
+
'main.nako3'
|
|
175
|
+
], NakoIndentError)
|
|
176
|
+
})
|
|
177
|
+
})
|
|
178
|
+
describe('警告の表示', () => {
|
|
179
|
+
it('未定義の変数を参照したとき', () => {
|
|
180
|
+
const compiler = new NakoCompiler()
|
|
181
|
+
let log = ''
|
|
182
|
+
compiler.logger.addListener('warn', ({ noColor }) => { log += noColor })
|
|
183
|
+
compiler.run('xを表示', 'main.nako3')
|
|
184
|
+
assert.strictEqual(log.split('。')[0], '[警告]main.nako3(1行目): 変数『x』は定義されていません')
|
|
185
|
+
})
|
|
186
|
+
it('存在しない高速化オプションを指定したとき', () => {
|
|
187
|
+
const compiler = new NakoCompiler()
|
|
188
|
+
let log = ''
|
|
189
|
+
compiler.logger.addListener('warn', ({ noColor }) => { log += noColor })
|
|
190
|
+
compiler.run('「あ」で実行速度優先\nここまで', 'main.nako3')
|
|
191
|
+
assert.strictEqual(log, '[警告]main.nako3(1行目): 実行速度優先文のオプション『あ』は存在しません。')
|
|
192
|
+
})
|
|
193
|
+
it('ユーザー定義関数を上書きしたとき', () => {
|
|
194
|
+
const compiler = new NakoCompiler()
|
|
195
|
+
let log = ''
|
|
196
|
+
compiler.logger.addListener('warn', ({ noColor }) => { log += noColor }, false)
|
|
197
|
+
compiler.run('●Aとは\nここまで\n●Aとは\nここまで', 'main.nako3')
|
|
198
|
+
assert.strictEqual(log, '[警告]main.nako3(3行目): 関数『A』は既に定義されています。')
|
|
199
|
+
})
|
|
200
|
+
it('プラグイン関数を上書きしたとき', () => {
|
|
201
|
+
const compiler = new NakoCompiler()
|
|
202
|
+
let log = ''
|
|
203
|
+
compiler.logger.addListener('warn', ({ noColor }) => { log += noColor }, false)
|
|
204
|
+
compiler.run('●(Aを)足すとは\nここまで', 'main.nako3')
|
|
205
|
+
// 上記は「main::足す」という関数を定義したことになる
|
|
206
|
+
// assert.strictEqual(log, '[警告]main.nako3(1行目): 関数『足』は既に定義されています。')
|
|
207
|
+
assert.strictEqual(log, '')
|
|
208
|
+
})
|
|
209
|
+
})
|
|
210
|
+
})
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import assert from 'assert'
|
|
2
|
+
import { NakoCompiler } from '../src/nako3.mjs'
|
|
3
|
+
|
|
4
|
+
describe('error_test', () => {
|
|
5
|
+
// nako.logger.addListener('trace', ({ browserConsole }) => { console.log(...browserConsole) })
|
|
6
|
+
const cmp = async (/** @type {string} */ code, /** @type {string} */ res) => {
|
|
7
|
+
const nako = new NakoCompiler()
|
|
8
|
+
nako.logger.debug('code=' + code)
|
|
9
|
+
assert.strictEqual((await nako.runAsync(code)).log, res)
|
|
10
|
+
}
|
|
11
|
+
// --- test ---
|
|
12
|
+
it('エラー処理 - 基本', async () => {
|
|
13
|
+
await cmp('123を表示', '123')
|
|
14
|
+
await cmp('エラー監視;「hoge」のエラー発生;エラーならば;「ERR」と表示;ここまで', 'ERR')
|
|
15
|
+
})
|
|
16
|
+
})
|