mirror of
https://github.com/DoneJS-Runtime/quickjs-done-nextgen.git
synced 2025-01-09 17:43:15 +00:00
Remove js_new_bf() (#189)
And replace the open-coded JS_NewBigInt() logic at its one call site with the real thing.
This commit is contained in:
parent
d17129035d
commit
4fc814311a
1 changed files with 6 additions and 25 deletions
31
quickjs.c
31
quickjs.c
|
@ -11802,17 +11802,6 @@ int JS_ToBigInt64(JSContext *ctx, int64_t *pres, JSValueConst val)
|
||||||
return JS_ToBigInt64Free(ctx, pres, js_dup(val));
|
return JS_ToBigInt64Free(ctx, pres, js_dup(val));
|
||||||
}
|
}
|
||||||
|
|
||||||
static JSBigInt *js_new_bf(JSContext *ctx)
|
|
||||||
{
|
|
||||||
JSBigInt *p;
|
|
||||||
p = js_malloc(ctx, sizeof(*p));
|
|
||||||
if (!p)
|
|
||||||
return NULL;
|
|
||||||
p->header.ref_count = 1;
|
|
||||||
bf_init(ctx->bf_ctx, &p->num);
|
|
||||||
return p;
|
|
||||||
}
|
|
||||||
|
|
||||||
static JSValue JS_NewBigInt(JSContext *ctx)
|
static JSValue JS_NewBigInt(JSContext *ctx)
|
||||||
{
|
{
|
||||||
JSBigInt *p;
|
JSBigInt *p;
|
||||||
|
@ -33010,33 +32999,25 @@ static int JS_ReadFunctionBytecode(BCReaderState *s, JSFunctionBytecode *b,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static JSValue JS_ReadBigInt(BCReaderState *s, int tag)
|
static JSValue JS_ReadBigInt(BCReaderState *s)
|
||||||
{
|
{
|
||||||
JSValue obj = JS_UNDEFINED;
|
JSValue obj;
|
||||||
uint8_t v8;
|
uint8_t v8;
|
||||||
int32_t e;
|
int32_t e;
|
||||||
uint32_t len;
|
uint32_t len;
|
||||||
limb_t l, i, n;
|
limb_t l, i, n;
|
||||||
JSBigInt *p;
|
|
||||||
limb_t v;
|
limb_t v;
|
||||||
bf_t *a;
|
bf_t *a;
|
||||||
|
|
||||||
p = js_new_bf(s->ctx);
|
obj = JS_NewBigInt(s->ctx);
|
||||||
if (!p)
|
if (JS_IsException(obj))
|
||||||
goto fail;
|
goto fail;
|
||||||
switch(tag) {
|
|
||||||
case BC_TAG_BIG_INT:
|
|
||||||
obj = JS_MKPTR(JS_TAG_BIG_INT, p);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
abort();
|
|
||||||
}
|
|
||||||
|
|
||||||
/* sign + exponent */
|
/* sign + exponent */
|
||||||
if (bc_get_sleb128(s, &e))
|
if (bc_get_sleb128(s, &e))
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
a = &p->num;
|
a = JS_GetBigInt(obj);
|
||||||
a->sign = e & 1;
|
a->sign = e & 1;
|
||||||
e >>= 1;
|
e >>= 1;
|
||||||
if (e == 0)
|
if (e == 0)
|
||||||
|
@ -33775,7 +33756,7 @@ static JSValue JS_ReadObjectRec(BCReaderState *s)
|
||||||
obj = JS_ReadObjectValue(s);
|
obj = JS_ReadObjectValue(s);
|
||||||
break;
|
break;
|
||||||
case BC_TAG_BIG_INT:
|
case BC_TAG_BIG_INT:
|
||||||
obj = JS_ReadBigInt(s, tag);
|
obj = JS_ReadBigInt(s);
|
||||||
break;
|
break;
|
||||||
case BC_TAG_OBJECT_REFERENCE:
|
case BC_TAG_OBJECT_REFERENCE:
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue