Accept more flags in bjson read/write methods (#479)

Change the last argument from a boolean to an integer and export the
JS_READ_* and JS_WRITE_* flags on the bjson module object.
This commit is contained in:
Ben Noordhuis 2024-08-12 16:53:39 +02:00 committed by GitHub
parent 5a50ce3b08
commit da1d3cb994
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 16 additions and 8 deletions

View file

@ -4103,14 +4103,13 @@ static JSValue js_bjson_read(JSContext *ctx, JSValue this_val,
return JS_EXCEPTION; return JS_EXCEPTION;
if (JS_ToIndex(ctx, &len, argv[2])) if (JS_ToIndex(ctx, &len, argv[2]))
return JS_EXCEPTION; return JS_EXCEPTION;
if (JS_ToInt32(ctx, &flags, argv[3]))
return JS_EXCEPTION;
buf = JS_GetArrayBuffer(ctx, &size, argv[0]); buf = JS_GetArrayBuffer(ctx, &size, argv[0]);
if (!buf) if (!buf)
return JS_EXCEPTION; return JS_EXCEPTION;
if (pos + len > size) if (pos + len > size)
return JS_ThrowRangeError(ctx, "array buffer overflow"); return JS_ThrowRangeError(ctx, "array buffer overflow");
flags = 0;
if (JS_ToBool(ctx, argv[3]))
flags |= JS_READ_OBJ_REFERENCE;
obj = JS_ReadObject(ctx, buf + pos, len, flags); obj = JS_ReadObject(ctx, buf + pos, len, flags);
return obj; return obj;
} }
@ -4123,9 +4122,8 @@ static JSValue js_bjson_write(JSContext *ctx, JSValue this_val,
JSValue array; JSValue array;
int flags; int flags;
flags = 0; if (JS_ToInt32(ctx, &flags, argv[1]))
if (JS_ToBool(ctx, argv[1])) return JS_EXCEPTION;
flags |= JS_WRITE_OBJ_REFERENCE;
buf = JS_WriteObject(ctx, &len, argv[0], flags); buf = JS_WriteObject(ctx, &len, argv[0], flags);
if (!buf) if (!buf)
return JS_EXCEPTION; return JS_EXCEPTION;
@ -4138,6 +4136,16 @@ static JSValue js_bjson_write(JSContext *ctx, JSValue this_val,
static const JSCFunctionListEntry js_bjson_funcs[] = { static const JSCFunctionListEntry js_bjson_funcs[] = {
JS_CFUNC_DEF("read", 4, js_bjson_read ), JS_CFUNC_DEF("read", 4, js_bjson_read ),
JS_CFUNC_DEF("write", 2, js_bjson_write ), JS_CFUNC_DEF("write", 2, js_bjson_write ),
#define DEF(x) JS_PROP_INT32_DEF(#x, JS_##x, JS_PROP_CONFIGURABLE)
DEF(READ_OBJ_BYTECODE),
DEF(READ_OBJ_REFERENCE),
DEF(READ_OBJ_SAB),
DEF(WRITE_OBJ_BYTECODE),
DEF(WRITE_OBJ_REFERENCE),
DEF(WRITE_OBJ_SAB),
DEF(WRITE_OBJ_STRIP_DEBUG),
DEF(WRITE_OBJ_STRIP_SOURCE),
#undef DEF
}; };
static int js_bjson_init(JSContext *ctx, JSModuleDef *m) static int js_bjson_init(JSContext *ctx, JSModuleDef *m)

View file

@ -129,9 +129,9 @@ function bjson_test_reference()
array[i].idx = i; array[i].idx = i;
array[i].typed_array = new Uint8Array(array_buffer, i, 1); array[i].typed_array = new Uint8Array(array_buffer, i, 1);
} }
buf = bjson.write(array, true); buf = bjson.write(array, bjson.WRITE_OBJ_REFERENCE);
array = bjson.read(buf, 0, buf.byteLength, true); array = bjson.read(buf, 0, buf.byteLength, bjson.READ_OBJ_REFERENCE);
/* check the result */ /* check the result */
for(i = 0; i < n; i++) { for(i = 0; i < n; i++) {