setCustomConsole
Configure custom console behavior for handling keyboard input and output display
namespace CheerpX { class Linux { setCustomConsole( writeFunc: (buf: Buffer) => void, cols: number, rows: number ): (keyCode: number) => void; }}
Parameters
- writeFunc (
(buf: Buffer) => void
) - Function to handle the output sent to the console. - cols (
number
) - Number of columns for the console. - rows (
number
) - Number of rows for the console.
Returns
setCustomConsole
returns a function of type (keyCode: number) => void
. This function should be called to simulate user input by sending key codes to the console.
Examples
Read and write strings
const decoder = new TextDecoder("utf-8");
const send = cx.setCustomConsole( (buf) => { const string = decoder.decode(buf); console.log(string); }, 40, 60);
// Send a stringconst str = "Hello, world!\n";for (let i = 0; i < str.length; i++) { send(str.charCodeAt(i));}
Use with Xterm.jsdata:image/s3,"s3://crabby-images/56c34/56c344827d1091bf0f55a06b41eb2ea3e9c2f9b2" alt=""
const term = new Terminal({ convertEol: true });term.open(document.getElementById("terminal"));
const send = cx.setCustomConsole( (buf) => { term.write(new Uint8Array(buf)); }, term.cols, term.rows);term.onData((str) => { for (let i = 0; i < str.length; i++) { send(str.charCodeAt(i)); }});