Add u8 and i8 methods too
This commit is contained in:
parent
44f4805d9d
commit
4c86c8b7f4
56
bytes.ts
56
bytes.ts
@ -39,45 +39,65 @@ export function to_base64(b: BinaryLike): string {
|
||||
return encodeBase64(to_utf8(b));
|
||||
}
|
||||
|
||||
export function read_u8(b: Uint8Array, i = 0) {
|
||||
return b[i];
|
||||
}
|
||||
|
||||
export function write_u8(b: Uint8Array, n: number, i = 0) {
|
||||
if (n < 0 || 0xff < n) throw new TypeError(`input out of range, expected u8`);
|
||||
b[i] = n;
|
||||
}
|
||||
|
||||
export function read_i8(b: Uint8Array, i = 0) {
|
||||
const n = b[i];
|
||||
return n | ((n & 0x80) * 0x1fffffe);
|
||||
}
|
||||
|
||||
export function write_i8(b: Uint8Array, n: number, i = 0) {
|
||||
if (n < -0x80 || 0x7f < n)
|
||||
throw new TypeError(`input out of range, expected i8`);
|
||||
b[i] = n;
|
||||
}
|
||||
|
||||
export function read_u16_be(b: Uint8Array, i = 0) {
|
||||
return (b[i++] << 8) + b[i++];
|
||||
}
|
||||
|
||||
export function read_i16_be(b: Uint8Array, i = 0) {
|
||||
const n = (b[i++] << 8) + b[i++];
|
||||
return n | ((n & 0x8000) * 0x1fffe);
|
||||
}
|
||||
|
||||
export function read_u32_be(b: Uint8Array, i = 0) {
|
||||
return ((b[i++] << 24) + (b[i++] << 16) + (b[i++] << 8) + b[i++]) >>> 0;
|
||||
}
|
||||
|
||||
export function read_i32_be(b: Uint8Array, i = 0) {
|
||||
return (b[i++] << 24) + (b[i++] << 16) + (b[i++] << 8) + b[i++];
|
||||
return (b[i++] << 8) + b[i];
|
||||
}
|
||||
|
||||
export function write_u16_be(b: Uint8Array, n: number, i = 0) {
|
||||
if (n < 0 || 0xffff < n)
|
||||
throw new TypeError(`input out of range, expected u16`);
|
||||
(b[i++] = n >>> 8), (b[i++] = n);
|
||||
(b[i++] = n >>> 8), (b[i] = n);
|
||||
}
|
||||
|
||||
export function read_i16_be(b: Uint8Array, i = 0) {
|
||||
const n = (b[i++] << 8) + b[i];
|
||||
return n | ((n & 0x8000) * 0x1fffe);
|
||||
}
|
||||
|
||||
export function write_i16_be(b: Uint8Array, n: number, i = 0) {
|
||||
if (n < -0x8000 || 0x7fff < n)
|
||||
throw new TypeError(`input out of range, expected i16`);
|
||||
(b[i++] = n >>> 8), (b[i++] = n);
|
||||
(b[i++] = n >>> 8), (b[i] = n);
|
||||
}
|
||||
|
||||
export function read_u32_be(b: Uint8Array, i = 0) {
|
||||
return ((b[i++] << 24) + (b[i++] << 16) + (b[i++] << 8) + b[i]) >>> 0;
|
||||
}
|
||||
|
||||
export function write_u32_be(b: Uint8Array, n: number, i = 0) {
|
||||
if (n < 0 || 0xffffffff < n)
|
||||
throw new TypeError(`input out of range, expected u32`);
|
||||
(b[i++] = n >>> 24), (b[i++] = n >>> 16), (b[i++] = n >>> 8), (b[i++] = n);
|
||||
(b[i++] = n >>> 24), (b[i++] = n >>> 16), (b[i++] = n >>> 8), (b[i] = n);
|
||||
}
|
||||
|
||||
export function read_i32_be(b: Uint8Array, i = 0) {
|
||||
return (b[i++] << 24) + (b[i++] << 16) + (b[i++] << 8) + b[i];
|
||||
}
|
||||
|
||||
export function write_i32_be(b: Uint8Array, n: number, i = 0) {
|
||||
if (n < -0x80000000 || 0x7fffffff < n)
|
||||
throw new TypeError(`input out of range, expected i32`);
|
||||
(b[i++] = n >>> 24), (b[i++] = n >>> 16), (b[i++] = n >>> 8), (b[i++] = n);
|
||||
(b[i++] = n >>> 24), (b[i++] = n >>> 16), (b[i++] = n >>> 8), (b[i] = n);
|
||||
}
|
||||
|
||||
export { equals as buf_eq, concat as buf_concat } from "jsr:@std/bytes@^1.0.4";
|
||||
|
@ -1,5 +1,5 @@
|
||||
{
|
||||
"name": "@luaneko/lstd",
|
||||
"version": "0.1.4",
|
||||
"version": "0.1.5",
|
||||
"exports": "./mod.ts"
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user