Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

arr.atを追加 #661

Merged
merged 3 commits into from
Jul 10, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions docs/primitive-props.md
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,12 @@ _i_ 番目の文字が存在しない場合は null が返されます。
型: `num`
配列の要素数を取得します。

### @(_v_: arr).at(_index_: num, _otherwise_?: value): value
配列の _index_ の位置の要素を返します。\
_index_ が負の場合は末尾から数えます。\
_index_ が範囲外の場合は、代わりに _otherwise_ を返します。\
_otherwise_ が省略されている場合は`null`になります。

### @(_v_: arr).push(_i_: value): null
**【この操作は配列を書き換えます】**
配列の最後に要素を追加します。
Expand Down
5 changes: 5 additions & 0 deletions src/interpreter/primitive-props.ts
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@
split: (target: VStr): VFn => FN_NATIVE(async ([splitter], _opts) => {
if (splitter) assertString(splitter);
if (splitter) {
return ARR(target.value.split(splitter ? splitter.value : '').map(s => STR(s)));

Check warning on line 89 in src/interpreter/primitive-props.ts

View workflow job for this annotation

GitHub Actions / lint

Unnecessary conditional, value is always truthy
} else {
return ARR(toArray(target.value).map(s => STR(s)));
}
Expand Down Expand Up @@ -414,6 +414,11 @@

return removed[0] ?? NULL;
}),

at: (target: VArr): VFn => FN_NATIVE(async ([index, otherwise], opts) => {
assertNumber(index);
return target.value.at(index.value) ?? otherwise ?? NULL;
}),
},

error: {
Expand Down
40 changes: 40 additions & 0 deletions test/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3183,6 +3183,46 @@ describe('primitive props', () => {
ARR([NUM(1), NUM(4), NUM(5), NUM(6), NUM(7)])
]));
});

test.concurrent('at (without default value)', async () => {
const res = await exe(`
let arr1 = [10, 20, 30]
<: [
arr1
arr1.at(0), arr1.at(1), arr1.at(2)
arr1.at(-3), arr1.at(-2), arr1.at(-1)
arr1.at(3), arr1.at(4), arr1.at(5)
arr1.at(-6), arr1.at(-5), arr1.at(-4)
]
`);
eq(res, ARR([
ARR([NUM(10), NUM(20), NUM(30)]),
NUM(10), NUM(20), NUM(30),
NUM(10), NUM(20), NUM(30),
NULL, NULL, NULL,
NULL, NULL, NULL,
]));
});

test.concurrent('at (with default value)', async () => {
const res = await exe(`
let arr1 = [10, 20, 30]
<: [
arr1
arr1.at(0, 100), arr1.at(1, 100), arr1.at(2, 100)
arr1.at(-3, 100), arr1.at(-2, 100), arr1.at(-1, 100)
arr1.at(3, 100), arr1.at(4, 100), arr1.at(5, 100)
arr1.at(-6, 100), arr1.at(-5, 100), arr1.at(-4, 100)
]
`);
eq(res, ARR([
ARR([NUM(10), NUM(20), NUM(30)]),
NUM(10), NUM(20), NUM(30),
NUM(10), NUM(20), NUM(30),
NUM(100), NUM(100), NUM(100),
NUM(100), NUM(100), NUM(100),
]));
});
});
});

Expand Down
1 change: 1 addition & 0 deletions unreleased/arr-at.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
- `arr.at`を追加
Loading