mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2025-12-13 13:09:49 +04:00
* JS: Fix file select for fbt launch js_app * JS: badusb: Add numpad keys Co-authored-by: oldip <oldip@users.noreply.github.com> * JS: badusb: Layout support * JS: badusb: altPrint() and altPrintln() Co-authored-by: oldip <oldip@users.noreply.github.com> * JS: badusb: quit() * JS: serial: readAny() * JS: serial: end() * JS: serial: Auto disable expansion service * JS: storage: Add example script * JS: gui: text_input: Fix NULL ptr when no prop given * JS: gui: text_input: Default text props Co-authored-by: xMasterX <xMasterX@users.noreply.github.com> * JS: gui: byte_input Co-authored-by: xMasterX <xMasterX@users.noreply.github.com> * JS: gui: file_picker * JS: gui: viewDispatcher.currentView * JS: gui: view.hasProperty() * JS: gui: Add some missing typedefs comments * JS: globals: Fix toString() with negative numbers * JS: globals: parseInt() Co-authored-by: Spooks4576 <Spooks4576@users.noreply.github.com> * JS: globals: toUpperCase() and toLowerCase() Co-authored-by: Spooks4576 <Spooks4576@users.noreply.github.com> * JS: globals: Add some missing typedefs * JS: Add example for string functions Co-authored-by: Spooks4576 <Spooks4576@users.noreply.github.com> * JS: globals: __dirpath and __filepath Co-authored-by: jamisonderek <jamisonderek@users.noreply.github.com> * JS: globals: load() typedef missing scope param * JS: Add interactive REPL script example * JS: Add missing icon for file picker * JS: Rename to __filename and __dirname * JS: Move toUpperCase() and toLowerCase() to string class * JS: parseInt() refactor * JS: Typedef base param for parseInt() * Revert "JS: gui: view.hasProperty()" This reverts commit 1967ec06d4f2e9cafc4e18384ad370f7a7c44468. * JS: Move toString() to Number class * JS: Fix duplicate plugin files in plugins, `requires` is used to determine which app to distribute the .fal under `apps_data/appid/plugins` * JS: math: Missing typedefs, use camelCase * JS: badusb: layoutPath is optional in typedef * Fix ASS scoping * Rename mjs term prop type value * Change load() description * Enlarge buffers in default prop assign * More checks for default data/text size * Make PVS happy * Fix icon symbol * Update types for JS SDK * toString() was moved to number class Co-authored-by: oldip <oldip@users.noreply.github.com> Co-authored-by: xMasterX <xMasterX@users.noreply.github.com> Co-authored-by: Spooks4576 <Spooks4576@users.noreply.github.com> Co-authored-by: jamisonderek <jamisonderek@users.noreply.github.com> Co-authored-by: hedger <hedger@users.noreply.github.com> Co-authored-by: あく <alleteam@gmail.com>
113 lines
4.8 KiB
TypeScript
113 lines
4.8 KiB
TypeScript
/**
|
|
* Module for accessing the serial port
|
|
* @version Added in JS SDK 0.1
|
|
* @module
|
|
*/
|
|
|
|
/**
|
|
* @brief Initializes the serial port
|
|
*
|
|
* Automatically disables Expansion module service to prevent interference.
|
|
*
|
|
* @param port The port to initialize (`"lpuart"` or `"start"`)
|
|
* @param baudRate
|
|
* @version Added in JS SDK 0.1
|
|
*/
|
|
export declare function setup(port: "lpuart" | "usart", baudRate: number): void;
|
|
|
|
/**
|
|
* @brief Writes data to the serial port
|
|
* @param value The data to write:
|
|
* - Strings will get sent as ASCII.
|
|
* - Numbers will get sent as a single byte.
|
|
* - Arrays of numbers will get sent as a sequence of bytes.
|
|
* - `ArrayBuffer`s and `TypedArray`s will be sent as a sequence
|
|
* of bytes.
|
|
* @version Added in JS SDK 0.1
|
|
*/
|
|
export declare function write<E extends ElementType>(value: string | number | number[] | ArrayBuffer | TypedArray<E>): void;
|
|
|
|
/**
|
|
* @brief Reads data from the serial port
|
|
* @param length The number of bytes to read
|
|
* @param timeout The number of time, in milliseconds, after which this function
|
|
* will give up and return what it read up to that point. If
|
|
* unset, the function will wait forever.
|
|
* @returns The received data interpreted as ASCII, or `undefined` if 0 bytes
|
|
* were read.
|
|
* @version Added in JS SDK 0.1
|
|
*/
|
|
export declare function read(length: number, timeout?: number): string | undefined;
|
|
|
|
/**
|
|
* @brief Reads data from the serial port
|
|
*
|
|
* Data is read one character after another until either a `\r` or `\n`
|
|
* character is received, neither of which is included in the result.
|
|
*
|
|
* @param timeout The number of time, in milliseconds, after which this function
|
|
* will give up and return what it read up to that point. If
|
|
* unset, the function will wait forever. The timeout only
|
|
* applies to characters, not entire strings.
|
|
* @returns The received data interpreted as ASCII, or `undefined` if 0 bytes
|
|
* were read.
|
|
* @version Added in JS SDK 0.1
|
|
*/
|
|
export declare function readln(timeout?: number): string;
|
|
|
|
/**
|
|
* @brief Read any available amount of data from the serial port
|
|
*
|
|
* Can be useful to avoid starving your loop with small reads.
|
|
*
|
|
* @param timeout The number of time, in milliseconds, after which this function
|
|
* will give up and return nothing. If unset, the function will
|
|
* wait forever.
|
|
* @returns The received data interpreted as ASCII, or `undefined` if 0 bytes
|
|
* were read.
|
|
* @version Added in JS SDK 0.1
|
|
*/
|
|
export declare function readAny(timeout?: number): string | undefined;
|
|
|
|
/**
|
|
* @brief Reads data from the serial port
|
|
* @param length The number of bytes to read
|
|
* @param timeout The number of time, in milliseconds, after which this function
|
|
* will give up and return what it read up to that point. If
|
|
* unset, the function will wait forever.
|
|
* @returns The received data as an ArrayBuffer, or `undefined` if 0 bytes were
|
|
* read.
|
|
* @version Added in JS SDK 0.1
|
|
*/
|
|
export declare function readBytes(length: number, timeout?: number): ArrayBuffer;
|
|
|
|
/**
|
|
* @brief Reads data from the serial port, trying to match it to a pattern
|
|
* @param patterns A single pattern or an array of patterns:
|
|
* - If the argument is a single `string`, this function will
|
|
* match against the given string.
|
|
* - If the argument is an array of `number`s, this function
|
|
* will match against the given sequence of bytes,
|
|
* - If the argument is an array of `string`s, this function
|
|
* will match against any string out of the ones that were
|
|
* provided.
|
|
* - If the argument is an array of arrays of `number`s, this
|
|
* function will match against any sequence of bytes out of
|
|
* the ones that were provided.
|
|
* @param timeout The number of time, in milliseconds, after which this function
|
|
* will give up and return what it read up to that point. If
|
|
* unset, the function will wait forever. The timeout only
|
|
* applies to characters, not entire strings.
|
|
* @returns The index of the matched pattern if multiple were provided, or 0 if
|
|
* only one was provided and it matched, or `undefined` if none of the
|
|
* patterns matched.
|
|
* @version Added in JS SDK 0.1
|
|
*/
|
|
export declare function expect(patterns: string | number[] | string[] | number[][], timeout?: number): number | undefined;
|
|
|
|
/**
|
|
* @brief Deinitializes the serial port, allowing multiple initializations per script run
|
|
* @version Added in JS SDK 0.1
|
|
*/
|
|
export declare function end(): void;
|