| // Copyright (c) 2025, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| /// @assertion JSInt32Array get toJS |
| /// Converts this [Int32List] to a [JSInt32Array] by either casting, |
| /// unwrapping, or cloning the [Int32List]. |
| /// |
| /// > [!NOTE] |
| /// > Depending on whether code is compiled to JavaScript or Wasm, this |
| /// > conversion will have different semantics. |
| /// |
| /// When compiling to JavaScript, all typed lists are the equivalent |
| /// JavaScript typed arrays, and therefore this getter simply casts. |
| /// |
| /// When compiling to Wasm, this [Int32List] is a wrapper around a |
| /// `Int32Array` if it was converted via [JSInt32ArrayToInt32List.toDart]. If |
| /// it is a wrapper, this getter unwraps it and returns the `Int32Array`. If |
| /// it's instantiated in Dart, this getter clones this [Int32List]'s values |
| /// into a new [JSInt32Array]. |
| /// |
| /// Avoid assuming that modifications to this [Int32List] will affect the |
| /// returned [JSInt32Array] and vice versa on all compilers unless it was |
| /// converted first via [JSInt32ArrayToInt32List.toDart]. |
| /// |
| /// @description Check that this operation converts this [Int32List] to a |
| /// [JSInt32Array]. Test an array instantiated in Dart. |
| /// @author sgrekhov22@gmail.com |
| |
| import 'dart:js_interop'; |
| import 'dart:js_interop_unsafe'; |
| import 'dart:typed_data'; |
| import '../../../Utils/expect.dart'; |
| import '../js_utils.dart'; |
| |
| main() { |
| Int32List l1 = Int32List(0); |
| JSInt32Array a1 = l1.toJS; |
| globalContext["a1"] = a1; |
| eval("globalThis.len1 = globalThis.a1.length;"); |
| Expect.equals(0, (globalContext["len1"] as JSNumber).toDartInt); |
| if (isJS) { |
| // Casting case. `toDart` returns the same object. |
| Expect.identical(l1, a1.toDart); |
| } |
| if (isWasm) { |
| // The `Int32List` was instantiated in Dart. This is a cloning case. |
| Expect.notIdentical(l1, a1.toDart); |
| } |
| |
| Int32List l2 = Int32List.fromList([1, -2, 333333]); |
| JSInt32Array a2 = l2.toJS; |
| Expect.listEquals(l2, a2.toDart.toList()); |
| l2[2] = 3; |
| if (isJS) { |
| // Casting case. `toDart` returns the same object. |
| Expect.listEquals(l2, a2.toDart.toList()); |
| } |
| if (isWasm) { |
| // `a2` was cloned. Changes in `l2` don't affect it. |
| Expect.listEquals([1, -2, 333333], a2.toDart.toList()); |
| } |
| } |