7 a_u16 (*eval
)(a_u16
const table
[0x100], void const *pdata
, a_size nbyte
, a_u16 value
);
10 static JSClassID liba_crc16_class_id
;
12 static void liba_crc16_finalizer(JSRuntime
*rt
, JSValue val
)
14 js_free_rt(rt
, JS_GetOpaque(val
, liba_crc16_class_id
));
17 static JSClassDef liba_crc16_class
= {"crc16", .finalizer
= liba_crc16_finalizer
};
19 static JSValue
liba_crc16_ctor(JSContext
*ctx
, JSValueConst new_target
, int argc
, JSValueConst
*argv
)
21 JSValue proto
, clazz
= JS_UNDEFINED
;
22 struct crc16
*const self
= (struct crc16
*)js_mallocz(ctx
, sizeof(struct crc16
));
23 if (!self
) { return JS_EXCEPTION
; }
25 if (JS_ToUint32(ctx
, &poly
, argv
[0])) { goto fail
; }
29 reversed
= JS_ToBool(ctx
, argv
[1]);
30 if (reversed
< 0) { goto fail
; }
34 a_crc16l_init(self
->table
, (a_u16
)poly
);
35 self
->eval
= a_crc16l
;
39 a_crc16m_init(self
->table
, (a_u16
)poly
);
40 self
->eval
= a_crc16m
;
42 proto
= JS_GetPropertyStr(ctx
, new_target
, "prototype");
43 if (JS_IsException(proto
)) { goto fail
; }
44 clazz
= JS_NewObjectProtoClass(ctx
, proto
, liba_crc16_class_id
);
45 JS_FreeValue(ctx
, proto
);
46 if (JS_IsException(clazz
)) { goto fail
; }
47 JS_SetOpaque(clazz
, self
);
51 JS_FreeValue(ctx
, clazz
);
55 static JSValue
liba_crc16_gen(JSContext
*ctx
, JSValueConst this_val
, int argc
, JSValueConst
*argv
)
57 struct crc16
*const self
= (struct crc16
*)JS_GetOpaque2(ctx
, this_val
, liba_crc16_class_id
);
58 if (!self
) { return JS_EXCEPTION
; }
60 if (JS_ToUint32(ctx
, &poly
, argv
[0])) { return JS_EXCEPTION
; }
64 reversed
= JS_ToBool(ctx
, argv
[1]);
65 if (reversed
< 0) { return JS_EXCEPTION
; }
69 a_crc16l_init(self
->table
, (a_u16
)poly
);
70 self
->eval
= a_crc16l
;
74 a_crc16m_init(self
->table
, (a_u16
)poly
);
75 self
->eval
= a_crc16m
;
80 static JSValue
liba_crc16_eval(JSContext
*ctx
, JSValueConst this_val
, int argc
, JSValueConst
*argv
)
82 struct crc16
*const self
= (struct crc16
*)JS_GetOpaque2(ctx
, this_val
, liba_crc16_class_id
);
83 if (!self
) { return JS_EXCEPTION
; }
88 if (JS_ToUint32(ctx
, &x
, argv
[1])) { return JS_EXCEPTION
; }
92 if (JS_IsArray(ctx
, argv
[0]))
94 a_byte
*p
= JS_GetArrayBuffer(ctx
, &n
, argv
[0]);
95 if (p
) { value
= self
->eval(self
->table
, p
, n
, value
); }
99 char const *const p
= JS_ToCStringLen(ctx
, &n
, argv
[0]);
100 value
= self
->eval(self
->table
, p
, n
, value
);
101 JS_FreeCString(ctx
, p
);
103 return JS_NewUint32(ctx
, value
);
106 static JSValue
liba_crc16_pack(JSContext
*ctx
, JSValueConst this_val
, int argc
, JSValueConst
*argv
)
108 JSValue val
= JS_UNDEFINED
;
109 struct crc16
*const self
= (struct crc16
*)JS_GetOpaque2(ctx
, this_val
, liba_crc16_class_id
);
110 if (!self
) { return JS_EXCEPTION
; }
115 if (JS_ToUint32(ctx
, &x
, argv
[1])) { return JS_EXCEPTION
; }
119 char const *const s
= JS_ToCStringLen(ctx
, &n
, argv
[0]);
120 value
= self
->eval(self
->table
, s
, n
, value
);
121 a_byte
*p
= (a_byte
*)js_malloc(ctx
, n
+ 2);
122 if (p
) { a_copy(p
, s
, n
); }
124 self
->eval
== a_crc16m
125 ? a_u16_setb(p
+ n
, value
)
126 : a_u16_setl(p
+ n
, value
);
127 val
= js_array_u8_new(ctx
, p
, (uint32_t)n
+ 2);
129 JS_FreeCString(ctx
, s
);
139 static JSValue
liba_crc16_get(JSContext
*ctx
, JSValueConst this_val
, int magic
)
141 struct crc16
*const self
= (struct crc16
*)JS_GetOpaque2(ctx
, this_val
, liba_crc16_class_id
);
142 if (!self
) { return JS_EXCEPTION
; }
143 if (magic
== self_table_
)
145 return js_array_u16_new(ctx
, self
->table
, 0x100);
150 static JSCFunctionListEntry
const liba_crc16_proto
[] = {
151 JS_PROP_STRING_DEF("[Symbol.toStringTag]", "a.crc16", 0),
152 JS_CGETSET_MAGIC_DEF("table", liba_crc16_get
, NULL
, self_table_
),
153 JS_CFUNC_DEF("gen", 2, liba_crc16_gen
),
154 JS_CFUNC_DEF("eval", 2, liba_crc16_eval
),
155 JS_CFUNC_DEF("pack", 2, liba_crc16_pack
),
158 int js_liba_crc16_init(JSContext
*ctx
, JSModuleDef
*m
)
160 JS_NewClassID(&liba_crc16_class_id
);
161 JS_NewClass(JS_GetRuntime(ctx
), liba_crc16_class_id
, &liba_crc16_class
);
163 JSValue
const proto
= JS_NewObject(ctx
);
164 JS_SetPropertyFunctionList(ctx
, proto
, liba_crc16_proto
, A_LEN(liba_crc16_proto
));
166 JSValue
const clazz
= JS_NewCFunction2(ctx
, liba_crc16_ctor
, "crc16", 2, JS_CFUNC_constructor
, 0);
167 JS_SetConstructor(ctx
, clazz
, proto
);
168 JS_SetClassProto(ctx
, liba_crc16_class_id
, proto
);
170 return JS_SetModuleExport(ctx
, m
, "crc16", clazz
);