blob: 68ad8e23c250de6a981b6772a53e4c8998743a88 [file] [log] [blame] [edit]
// 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 JSInt8Array get toJS
/// Converts this [Int8List] to a [JSInt8Array] by either casting,
/// unwrapping, or cloning the [Int8List].
///
/// > [!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 [Int8List] is a wrapper around a `Int8Array`
/// if it was converted via [JSInt8ArrayToInt8List.toDart]. If it is a
/// wrapper, this getter unwraps it and returns the `Int8Array`. If it's
/// instantiated in Dart, this getter clones this [Int8List]'s values into a
/// new [JSInt8Array].
///
/// Avoid assuming that modifications to this [Int8List] will affect the
/// returned [JSInt8Array] and vice versa on all compilers unless it was
/// first converted via [JSInt8ArrayToInt8List.toDart].
///
/// @description Check that this operation converts this [Int8List] to a
/// [JSInt8Array]. 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() {
Int8List l1 = Int8List(0);
JSInt8Array 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 `Int8List` was instantiated in Dart. This is a cloning case.
Expect.notIdentical(l1, a1.toDart);
}
Int8List l2 = Int8List.fromList([1, -2, 33]);
JSInt8Array 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, 33], a2.toDart.toList());
}
}