Update JS_NewTypedArray() to C level API

This commit is contained in:
Dmitry Volyntsev 2024-05-09 13:13:45 -07:00
parent 97be5a32af
commit 9c2a19eaac
2 changed files with 17 additions and 5 deletions

View File

@ -53429,14 +53429,26 @@ static JSValue js_typed_array_get_byteOffset(JSContext *ctx,
return JS_NewInt32(ctx, ta->offset);
}
JSValue JS_NewTypedArray(JSContext *ctx, int argc, JSValueConst *argv,
JSValue JS_NewTypedArray(JSContext *ctx, size_t length, const void *init,
JSTypedArrayEnum type)
{
JSValue args[1], ret;
if (type < JS_TYPED_ARRAY_UINT8C || type > JS_TYPED_ARRAY_FLOAT64)
return JS_ThrowRangeError(ctx, "invalid typed array type");
return js_typed_array_constructor(ctx, JS_UNDEFINED, argc, argv,
JS_CLASS_UINT8C_ARRAY + type);
args[0] = JS_NewInt64(ctx, length);
ret = js_typed_array_constructor(ctx, JS_UNDEFINED, 1, (JSValueConst *)args,
JS_CLASS_UINT8C_ARRAY + type);
JS_FreeValue(ctx, args[0]);
if (init != NULL && !JS_IsException(ret)) {
JSObject *p = JS_VALUE_GET_OBJ(ret);
size_t len = length * (1 << typed_array_size_log2(p->class_id));
memcpy(p->u.array.u.ptr, init, len);
}
return ret;
}
/* Return the buffer associated to the typed array or an exception if

View File

@ -845,8 +845,8 @@ typedef enum JSTypedArrayEnum {
JS_TYPED_ARRAY_FLOAT64,
} JSTypedArrayEnum;
JSValue JS_NewTypedArray(JSContext *ctx, int argc, JSValueConst *argv,
JSTypedArrayEnum array_type);
JSValue JS_NewTypedArray(JSContext *ctx, size_t length, const void *init,
JSTypedArrayEnum type);
JSValue JS_GetTypedArrayBuffer(JSContext *ctx, JSValueConst obj,
size_t *pbyte_offset,
size_t *pbyte_length,