63261c2608
Also fix eqref/i31ref fromJS() handling to accept unwrapped Smis. This does not convert HeapNumbers to Smis if they fit. Bug: v8:7748 Change-Id: Ida70a826f9541b7f3fbe9eecbb2b4fe362b5ef70 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3829477 Commit-Queue: Matthias Liedtke <mliedtke@chromium.org> Reviewed-by: Jakob Kummerow <jkummerow@chromium.org> Cr-Commit-Position: refs/heads/main@{#82558}
48 lines
1.5 KiB
JavaScript
48 lines
1.5 KiB
JavaScript
// Copyright 2022 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Flags: --experimental-wasm-gc --wasm-gc-js-interop
|
|
|
|
d8.file.execute('test/mjsunit/wasm/wasm-module-builder.js');
|
|
|
|
var builder = new WasmModuleBuilder();
|
|
|
|
let i16Array = builder.addArray(kWasmI16, true);
|
|
|
|
builder.addFunction('getHelloArray', makeSig([], [kWasmArrayRef]))
|
|
.addBody([
|
|
...wasmI32Const(72), ...wasmI32Const(69), ...wasmI32Const(76),
|
|
...wasmI32Const(76), ...wasmI32Const(79),
|
|
kGCPrefix, kExprArrayNewFixedStatic, i16Array, 5
|
|
])
|
|
.exportFunc();
|
|
|
|
builder.addFunction('getChar', makeSig([kWasmArrayRef, kWasmI32], [kWasmI32]))
|
|
.addBody([
|
|
kExprLocalGet, 0, kGCPrefix, kExprRefAsData, kGCPrefix,
|
|
kExprRefCastStatic, i16Array, kExprLocalGet, 1, kGCPrefix, kExprArrayGetS,
|
|
i16Array
|
|
])
|
|
.exportFunc();
|
|
|
|
const instance = builder.instantiate();
|
|
const getHelloArray = instance.exports.getHelloArray;
|
|
const getChar = instance.exports.getChar;
|
|
|
|
assertEquals(
|
|
WebAssembly.experimentalConvertArrayToString(getHelloArray(), 0, 5),
|
|
'HELLO');
|
|
assertEquals(
|
|
WebAssembly.experimentalConvertArrayToString(getHelloArray(), 1, 4),
|
|
'ELLO');
|
|
assertEquals(
|
|
WebAssembly.experimentalConvertArrayToString(getHelloArray(), 0, 3), 'HEL');
|
|
|
|
const string = 'foobar'
|
|
const array =
|
|
WebAssembly.experimentalConvertStringToArray('foobar', getHelloArray());
|
|
for (let i = 0; i < string.length; ++i) {
|
|
assertEquals(getChar(array, i), string.charCodeAt(i));
|
|
}
|