Module
x/silicon/bindings/bindings.ts
Deno module to generate images from source code using Aloxaf/silicon.
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109// Auto-generated with deno_bindgenfunction encode(v: string | Uint8Array): Uint8Array { if (typeof v !== "string") return v return new TextEncoder().encode(v)}
function decode(v: Uint8Array): string { return new TextDecoder().decode(v)}
// deno-lint-ignore no-explicit-anyfunction readPointer(v: any): Uint8Array { const ptr = new Deno.UnsafePointerView(v) const lengthBe = new Uint8Array(4) const view = new DataView(lengthBe.buffer) ptr.copyInto(lengthBe, 0) const buf = new Uint8Array(view.getUint32(0)) ptr.copyInto(buf, 4) return buf}
const url = new URL( "https://github.com/skanehira/deno-silicon/releases/download/v0.0.5/", import.meta.url,)
import { dlopen, FetchOptions } from "https://deno.land/x/plug@1.0.1/mod.ts"let uri = url.toString()if (!uri.endsWith("/")) uri += "/"
let darwin: string | { aarch64: string; x86_64: string } = uri
const opts: FetchOptions = { name: "deno_silicon", url: { darwin, windows: uri, linux: uri, }, cache: "use",}const { symbols } = await dlopen(opts, { font_list: { parameters: [], result: "buffer", nonblocking: false }, generate: { parameters: ["buffer", "usize"], result: "buffer", nonblocking: false, }, theme_list: { parameters: [], result: "buffer", nonblocking: false },})export type Options = { code: string language: string no_line_number: boolean no_round_corner: boolean no_window_controls: boolean background_color: string font: string highlight_lines: string line_offset: number line_pad: number pad_horiz: number pad_vert: number shadow_blur_radius: number shadow_color: string shadow_offset_x: number shadow_offset_y: number tab_width: number theme: string}export type SiliconResult = | { FontList: { data: Array<string> } } | { ThemeList: { data: Array<string> } } | { Image: { data: string } } | { Error: { error: string } }export function font_list() { const rawResult = symbols.font_list() const result = readPointer(rawResult) return JSON.parse(decode(result)) as SiliconResult}export function generate(a0: Options) { const a0_buf = encode(JSON.stringify(a0))
const rawResult = symbols.generate(a0_buf, a0_buf.byteLength) const result = readPointer(rawResult) return JSON.parse(decode(result)) as SiliconResult}export function theme_list() { const rawResult = symbols.theme_list() const result = readPointer(rawResult) return JSON.parse(decode(result)) as SiliconResult}