diff options
| author | sneurlax <sneurlax@gmail.com> | 2024-10-16 17:14:41 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-10-16 17:14:41 -0500 |
| commit | 6260fed0d483dad6d8af016e1b223c36c13dca5b (patch) | |
| tree | ff6accbbe075eef647b3666fce42ab8cf2874778 /impls/monero.ts/src/utils.ts | |
| parent | b556f50129d1a55c81cb5bcdf749f154137c9999 (diff) | |
| parent | 939040032f6e22529ccb6b5f54d9c48fc94db3d6 (diff) | |
Merge branch 'master' into rust
Diffstat (limited to 'impls/monero.ts/src/utils.ts')
| -rw-r--r-- | impls/monero.ts/src/utils.ts | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/impls/monero.ts/src/utils.ts b/impls/monero.ts/src/utils.ts index 6fa640f..e88ddcd 100644 --- a/impls/monero.ts/src/utils.ts +++ b/impls/monero.ts/src/utils.ts @@ -1,4 +1,5 @@ import { dylib } from "../mod.ts"; +import type { moneroSymbols, MoneroTsDylib, WowneroTsDylib } from "./symbols.ts"; export type Sanitizer = () => void | PromiseLike<void>; @@ -7,6 +8,17 @@ export function CString(string: string): Deno.PointerValue<string> { return Deno.UnsafePointer.of(textEncoder.encode(`${string}\x00`)); } +type SymbolWithoutPrefix = keyof typeof moneroSymbols extends `MONERO_${infer DylibSymbol}` ? DylibSymbol : never; +export function getSymbol<S extends SymbolWithoutPrefix>( + symbol: S, +): MoneroTsDylib["symbols"][`MONERO_${S}`] | WowneroTsDylib["symbols"][`WOWNERO_${S}`] { + if ("MONERO_free" in dylib.symbols) { + return dylib.symbols[`MONERO_${symbol}` as const]; + } else { + return dylib.symbols[`WOWNERO_${symbol}` as const]; + } +} + /** * This method reads string from the given pointer and frees the string. * @@ -19,7 +31,7 @@ export async function readCString(pointer: Deno.PointerValue, free = true): Prom if (!pointer) return null; const string = new Deno.UnsafePointerView(pointer).getCString(); if (free) { - await dylib.symbols.MONERO_free(pointer); + await getSymbol("free")(pointer); } return string; } |
