Compare commits

...

2 Commits

Author SHA1 Message Date
Dmitry Volyntsev
9ef7beae31
Merge 9c2a19eaac5d1a2b79e924f480fd0a4f3500b525 into 20d2b404af65edc5d66ee6f11a59f930ea3d1b88 2025-09-06 18:03:43 +02:00
Dmitry Volyntsev
9c2a19eaac Update JS_NewTypedArray() to C level API 2024-05-09 13:50:28 -07:00
2 changed files with 17 additions and 5 deletions

View File

@ -53110,14 +53110,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,
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

@ -882,8 +882,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,