UNPKG

recoder-code

Version:

🚀 AI-powered development platform - Chat with 32+ models, build projects, automate workflows. Free models included!

140 lines (139 loc) • 4.52 kB
import type { IGetToken } from '@tokenizer/token'; export interface IFileInfo { /** * File size in bytes */ size?: number; /** * MIME-type of file */ mimeType?: string; /** * File path */ path?: string; /** * File URL */ url?: string; } export interface IRandomAccessFileInfo extends IFileInfo { /** * File size in bytes */ size: number; } export interface IReadChunkOptions { /** * Number of bytes to read. */ length?: number; /** * Position where to begin reading from the file. * Default it is `tokenizer.position`. * Position may not be less than `tokenizer.position`, unless `supportsRandomAccess()` returns `true`. */ position?: number; /** * If set, will not throw an EOF error if not all off the requested data could be read */ mayBeLess?: boolean; } export interface IRandomAccessTokenizer extends ITokenizer { /** * Provide access to information of the underlying information stream or file. */ fileInfo: IRandomAccessFileInfo; /** * Change the position (offset) of the tokenizer * @param position New position */ setPosition(position: number): void; } /** * The tokenizer allows us to read or peek from the tokenizer-stream. * The tokenizer-stream is an abstraction of a stream, file or Buffer. */ export interface ITokenizer { /** * Provide access to information of the underlying information stream or file. */ readonly fileInfo: IFileInfo; /** * Offset in bytes (= number of bytes read) since beginning of file or stream */ readonly position: number; /** * Peek (read ahead) buffer from tokenizer * @param buffer - Target buffer to fill with data peek from the tokenizer-stream * @param options - Read behaviour options * @returns Promise with number of bytes read */ peekBuffer(buffer: Uint8Array, options?: IReadChunkOptions): Promise<number>; /** * Peek (read ahead) buffer from tokenizer * @param buffer - Target buffer to fill with data peeked from the tokenizer-stream * @param options - Additional read options * @returns Promise with number of bytes read */ readBuffer(buffer: Uint8Array, options?: IReadChunkOptions): Promise<number>; /** * Peek a token from the tokenizer-stream. * @param token - Token to peek from the tokenizer-stream. * @param position - Offset where to begin reading within the file. If position is null, data will be read from the current file position. * @param maybeless - If set, will not throw an EOF error if the less then the requested length could be read. */ peekToken<T>(token: IGetToken<T>, position?: number | null, maybeless?: boolean): Promise<T>; /** * Read a token from the tokenizer-stream. * @param token - Token to peek from the tokenizer-stream. * @param position - Offset where to begin reading within the file. If position is null, data will be read from the current file position. */ readToken<T>(token: IGetToken<T>, position?: number): Promise<T>; /** * Peek a numeric token from the stream * @param token - Numeric token * @returns Promise with number */ peekNumber(token: IGetToken<number>): Promise<number>; /** * Read a numeric token from the stream * @param token - Numeric token * @returns Promise with number */ readNumber(token: IGetToken<number>): Promise<number>; /** * Ignore given number of bytes * @param length - Number of bytes ignored */ ignore(length: number): Promise<number>; /** * Clean up resources. * It does not close the stream for StreamReader, but is does close the file-descriptor. */ close(): Promise<void>; /** * Abort pending asynchronous operations */ abort(): Promise<void>; /** * Returns true when the underlying file supports random access */ supportsRandomAccess(): boolean; } export type OnClose = () => Promise<void>; export interface ITokenizerOptions { /** * Pass additional file information to the tokenizer */ fileInfo?: IFileInfo; /** * On tokenizer close handler */ onClose?: OnClose; /** * Pass `AbortSignal` which can stop active async operations * Ref: https://developer.mozilla.org/en-US/docs/Web/API/AbortSignal */ abortSignal?: AbortSignal; }