| // 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 JSDataView get toJS |
| /// Converts this [ByteData] to a [JSDataView] by either casting, unwrapping, |
| /// or cloning the [ByteData]. |
| /// |
| /// > [!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 [ByteData] is a wrapper around a `DataView` |
| /// if it was converted via [JSDataViewToByteData.toDart]. If it is a wrapper, |
| /// this getter unwraps it and returns the `DataView`. If it's instantiated in |
| /// Dart, this getter clones this [ByteData]'s values into a new [JSDataView]. |
| /// |
| /// Avoid assuming that modifications to this [ByteData] will affect the |
| /// returned [JSDataView] and vice versa on all compilers unless it was first |
| /// converted via [JSDataViewToByteData.toDart]. |
| /// |
| /// @description Check that this operation converts this [ByteData] to a |
| /// [JSDataView]. |
| /// @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() { |
| var bd = ByteData(1); |
| bd.setInt8(0, 42); |
| JSDataView dv = bd.toJS; |
| globalContext["dv"] = dv; |
| eval("globalThis.v = globalThis.dv.getInt8();"); |
| Expect.equals(42, (globalContext["v"] as JSNumber).toDartInt); |
| } |