WebAssembly Character Console API
twr-wasm for WebAssembly provides Consoles for interactive user I/O. Character and graphic 2D draw consoles exist. This section covers the streaming and addressable character APIs that can be used with an instance of twrConsoleDebug, twrConsoleTerminal, twrConsoleDiv. This API works with stdin, stdout, stderr and custom named consoles.
Also see the Consoles section in Getting Started
Examples
Name | View Live Link | Source Link |
---|---|---|
"terminal" in/out with a <canvas> |
View mini-term demo | Source |
Getting a Console
stdin, stdout, stderr
stdin
, stdout
, stderr
are defined in <stdio.h>
.
This section describes how to configure stdio
In C, consoles are represented by a twr_ioconsole_t
.
stdio.h also defines FILE
like this:
from <stdio.h>
:
#define stderr (FILE *)(twr_get_stderr_con())
#define stdin (FILE *)(twr_get_stdio_con())
#define stdout (FILE *)(twr_get_stdio_con())
twr_get_console
This function will retrieve a console by its name. The standard names are stdio
, stderr
, and std2d
. In addition, any named console that was passed to a module using the io
option can be retrieved with this function.
See io doc.
See the multi-io example.
io_nullcon
Returns an IoConsole that goes to the bit bucket. io_getc32 will return 0.
IO Console Functions
io_cls
For addressable display consoles only.
Clears the screen. That is, all character cells in the console are set to a space, their colors are reset to the current default colors (see io_set_colors
).
io_getc32
Waits for the user to press a key and then returns a unicode code point.
To return characters encoded with the current locale, see io_mbgetc
io_get_colors
For addressable display consoles only.
Gets the current default foreground and background colors. These colors are used by an new text updates.
The color format is a 24 bit int as RGB.
#include <twr_io.h>
void io_get_colors(twr_ioconsole_t* io, unsigned long *foreground, unsigned long *background);
io_get_cursor
Returns an integer of the current cursor position. The cursor is where the next io_putc
is going to go.
For addressable display consoles, the cursor position ranges from [0, width*height-1], inclusive.
io_get_prop
Given a string key (name) of a property, returns its integer value. The available properties varies by console type.
All consoles support: "type".Addressable consoles also support: "cursorPos", "charWidth", "charHeight", "foreColorAsRGB", "backColorAsRGB", "widthInChars", "heightInChars", "fontSize", "canvasWidth", "canvasHeight"
You can do a bitwise &
on type with the following C defines to determine a console capabilities:
IO_TYPE_CHARREAD
IO_TYPE_CHARWRITE
IO_TYPE_ADDRESSABLE_DISPLAY
IO_TYPE_CANVAS2D
For example:
io_get_width
Returns the width in characters of an addressable console.
io_get_height
Returns the height in characters of an addressable console.
io_set_colors
For addressable display consoles only.
Sets a 24 bit RGB default color for the foreground and background. The prior default colors are changed (lost). For example, if you set the default colors when you created the console (see twrConsoleTerminal Options), the defaults will no longer be active. Use io_get_colors
to save existing colors for later restoration using io_set_colors
.
A call to io_set_colors
doesn't actually cause any on screen changes. Instead, these new default colors are used in future draw and text calls. A foreground and background color is set for each cell in the console window. The cell's colors are set to these default foreground/background colors when a call to io_setc
, io_setreset
, etc is made.
#include <twr_io.h>
void io_set_colors(twr_ioconsole_t* io, unsigned long foreground, unsigned long background);
io_setc
For addressable display consoles only.
Sets a console cell to the specified character. Sends a byte to an console and supports the current locale's character encoding. This function will "stream" using the current code page. In other words, if you are in the "C" locale io_setc
it will set ASCII characters. If the current locale is set to 1252, then you can send windows-1252 encoded characters. If the current locale is UTF-8, then you can stream UTF-8 (that is, call io_setc
once for each byte of the multi-byte UTF-8 character).
io_setc32
For addressable display consoles only.
Sets a console cell to a unicode code point. The colors are set to the defaults (see io_set_colors
).
io_set_cursor
Moves the cursor. See io_get_cursor
.
io_set_cursorxy
Set's the cursor's x,y position in an addressable console.
io_setfocus
Sets the input focus to the indicated console.
io_set_range
Sets a range of characters in an addressable display.
io_setreset
For addressable display consoles only.
Sets or resets (clears) a chunky graphics "pixel". Each character cell can also be a 2x3 grid of graphic "pixels". In other words, the terminal window has pixel dimensions of width2 x height3.
The color will be set to the defaults if the impacted cell is not a graphics cell. If it is an existing graphics cell, the colors don't change.
See the terminal
example.
io_mbgetc
io_mbgetc
will get a character from stdin and encode it using the character encoding of the LC_CTYPE category of the current locale. "C" will use ASCII. UTF-8 and windows-1252 are also supported.
io_mbgets
Gets a string from a Console. Returns when the user presses "Enter". Displays a cursor character and echos the inputted characters, at the current cursor position. Uses character encoding of LC_TYPE of current locale. If the encoding is UTF-8, then the result will be multibyte.
This function is commonly used with stdin
.
This function requires that you use twrWasmModuleAsync
.
io_point
For addressable display consoles only.
Checks if a chunky graphics "pixel" is set or clear. See io_setreset
.
io_putc
Sends a byte to an IoConsole and supports the current locale's character encoding. This function will "stream" using the current code page. In other words, if you io_putc
ASCII, it will work as "normal". If the current locale is set to 1252, then you can send windows-1252 encoded characters. If the current locale is UTF-8, then you can stream UTF-8 (that is, call io_putc
once for each byte of the multi-byte UTF-8 character).
Note that when characters are sent to the browser console using stderr
they will not render to the console until a newline, return, or ASCII 03 (End-of-Text) is sent.
io_putstr
Calls io_putc
for each byte in the passed string.
io_printf
Identical to fprintf
, however io_printf will call io_begin_draw
and io_end_draw
around its drawing activities -- resulting in snapper performance.
For example:
or
io_begin_draw
For addressable display consoles only.
This call (and its matching io_end_draw) are not required. But if you bracket any call sequence that draws to the terminal window with an io_begin_draw
and io_end_draw
, the updates will be batched into one update. This will increase performance and usually prevents the user from seeing partial updates.
io_begin_draw
can be nested.
See the terminal example.
io_end_draw
For addressable display consoles only.
See io_begin_draw
.
Deprecated Functions
twr_debugcon
This function has been removed. Use stderr
or twr_conlog
.
or
twr_divcon
This function has been removed.
twr_windowcon
This function has been removed.