Files
bun.sh/src/bun.js/node/buffer.zig
Dylan Conway 5fa13625a1 upgrade zig to v0.11.0-dev.3737+9eb008717 (#3374)
* progress

* finish `@memset/@memcpy` update

* Update build.zig

* change `@enumToInt` to `@intFromEnum` and friends

* update zig versions

* it was 1

* add link to issue

* add `compileError` reminder

* fix merge

* format

* upgrade to llvm 16

* Revert "upgrade to llvm 16"

This reverts commit cc930ceb1c.

---------

Co-authored-by: Jarred Sumner <jarred@jarredsumner.com>
Co-authored-by: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com>
2023-06-21 23:38:18 -07:00

78 lines
3.3 KiB
Zig

const bun = @import("root").bun;
const JSC = bun.JSC;
const Encoder = JSC.WebCore.Encoder;
pub const BufferVectorized = struct {
pub fn fill(
str: *JSC.ZigString,
buf_ptr: [*]u8,
fill_length: usize,
encoding: JSC.Node.Encoding,
) callconv(.C) bool {
if (str.len == 0) return true;
var buf = buf_ptr[0..fill_length];
const written = switch (encoding) {
.utf8 => if (str.is16Bit())
Encoder.writeU16(str.utf16SliceAligned().ptr, str.utf16SliceAligned().len, buf.ptr, buf.len, .utf8, true)
else
Encoder.writeU8(str.slice().ptr, str.slice().len, buf.ptr, buf.len, .utf8),
.ascii => if (str.is16Bit())
Encoder.writeU16(str.utf16SliceAligned().ptr, str.utf16SliceAligned().len, buf.ptr, buf.len, .ascii, true)
else
Encoder.writeU8(str.slice().ptr, str.slice().len, buf.ptr, buf.len, .ascii),
.latin1 => if (str.is16Bit())
Encoder.writeU16(str.utf16SliceAligned().ptr, str.utf16SliceAligned().len, buf.ptr, buf.len, .latin1, true)
else
Encoder.writeU8(str.slice().ptr, str.slice().len, buf.ptr, buf.len, .latin1),
.buffer => if (str.is16Bit())
Encoder.writeU16(str.utf16SliceAligned().ptr, str.utf16SliceAligned().len, buf.ptr, buf.len, .buffer, true)
else
Encoder.writeU8(str.slice().ptr, str.slice().len, buf.ptr, buf.len, .buffer),
.utf16le, .ucs2 => if (str.is16Bit())
Encoder.writeU16(str.utf16SliceAligned().ptr, str.utf16SliceAligned().len, buf.ptr, buf.len, .utf16le, true)
else
Encoder.writeU8(str.slice().ptr, str.slice().len, buf.ptr, buf.len, .utf16le),
.base64 => if (str.is16Bit())
Encoder.writeU16(str.utf16SliceAligned().ptr, str.utf16SliceAligned().len, buf.ptr, buf.len, .base64, true)
else
Encoder.writeU8(str.slice().ptr, str.slice().len, buf.ptr, buf.len, .base64),
.base64url => if (str.is16Bit())
Encoder.writeU16(str.utf16SliceAligned().ptr, str.utf16SliceAligned().len, buf.ptr, buf.len, .base64url, true)
else
Encoder.writeU8(str.slice().ptr, str.slice().len, buf.ptr, buf.len, .base64url),
.hex => if (str.is16Bit())
Encoder.writeU16(str.utf16SliceAligned().ptr, str.utf16SliceAligned().len, buf.ptr, buf.len, .hex, true)
else
Encoder.writeU8(str.slice().ptr, str.slice().len, buf.ptr, buf.len, .hex),
} catch return false;
switch (written) {
0 => {},
1 => @memset(buf, buf[0]),
else => {
var contents = buf[0..written];
buf = buf[written..];
while (buf.len >= contents.len) {
bun.copy(u8, buf, contents);
buf = buf[contents.len..];
contents.len *= 2;
}
if (buf.len > 0) {
bun.copy(u8, buf, contents[0..buf.len]);
}
},
}
return true;
}
};
comptime {
if (!JSC.is_bindgen) {
@export(BufferVectorized.fill, .{ .name = "Bun__Buffer_fill" });
}
}