Home  /  Autodocs  /  console.device

NAME

CMD_READ
return the next input from the keyboard

FUNCTION

Read the next input, generally from the keyboard. The form of this input is as an ANSI byte stream: i.e. either ASCII text or control sequences. Raw input events received by the console device can be selectively filtered via the aSRE and aRRE control sequences (see the write command). Keys are converted via the keymap associated with the unit, which is modified with AskKeyMap and SetKeyMap

If, for example, raw keycodes had been enabled by writing <CSI>1{ to the console (where <CSI> is $9B or Esc[), keys would return raw keycode reports with the information from the input event itself, in the form: <CSI>1;0;<keycode>;<qualifiers>;0;0;<seconds>;<microseconds>q

If there is no pending input, this command will not be satisfied, but if there is some input, but not as much as can fill io_Length, the request will be satisfied with the input currently available.

INPUTS

io_Message
mn_ReplyPort set if quick I/O is not possible

io_Device
Preset by the call to OpenDevice

io_Unit
Preset by the call to OpenDevice

io_Command
CMD_READ

io_Flags
IOF_QUICK if quick I/O possible, else zero

io_Length
sizeof(*buffer)

io_Data
char buffer[] a pointer to the destination for the characters to read from the keyboard.

RESULT

This function sets the error field in the IOStdReq, and fills in the io_Data area with the next input, and io_Actual with the number of bytes read.

SEE ALSO

exec/io.h, devices/console.h