NAME
POE::Wheel::TermKey
- terminal key input using libtermkey
with POE
SYNOPSIS
POE::Session->create(
inline_states
=> {
_start
=>
sub
{
$_
[HEAP]{termkey} = POE::Wheel::TermKey->new(
InputEvent
=>
'got_key'
,
);
},
got_key
=>
sub
{
my
$key
=
$_
[ARG0];
my
$termkey
=
$_
[HEAP]{termkey};
"Got key: "
.
$termkey
->format_key(
$key
, FORMAT_VIM ).
"\n"
;
# Gotta exit somehow.
delete
$_
[HEAP]{termkey}
if
$key
->type_is_unicode and
$key
->utf8 eq
"C"
and
$key
->modifiers & KEYMOD_CTRL;
},
}
);
POE::Kernel->run;
DESCRIPTION
This class implements an asynchronous perl wrapper around the libtermkey
library, which provides an abstract way to read keypress events in terminal-based programs. It yields structures that describe keys, rather than simply returning raw bytes as read from the TTY device.
This class is a subclass of POE::Wheel, which internally uses an instance of Term::TermKey to access the underlying C library. For details of on general operation, including the representation of keypress events as objects, see the documentation on Term::TermKey
instead.
Proxy methods exist for normal acessors of Term::TermKey
, and the usual behaviour of getkey
or other methods is instead replaced by the InputEvent
.
CONSTRUCTOR
$wheel = POE::Wheel::TermKey->new( %args )
Returns a new instance of a POE::Wheel::TermKey
object. It takes the following named parameters:
- Term => IO or INT
-
Optional. File handle or POSIX file descriptor number for the filehandle to use as the connection to the terminal. If not supplied
STDIN
will be used. - Flags => INT
-
libtermkey
flags to pass to theTerm::TermKey
constructor. - InputEvent => STRING
-
Name of the session event to emit when a key is received. The event will be given a single argument, the
Term::TermKey::Key
event object, as$_[ARG0]
.
METHODS
$tk = $wheel->termkey
Returns the Term::TermKey
object being used to access the libtermkey
library. Normally should not be required; the proxy methods should be used instead. See below.
$flags = $wheel->get_flags
$wheel->set_flags( $flags )
$canonflags = $wheel->get_canonflags
$wheel->set_canonflags( $canonflags )
$msec = $wheel->get_waittime
$wheel->set_waittime( $msec )
$str = $wheel->get_keyname( $sym )
$sym = $wheel->keyname2sym( $keyname )
( $ev, $button, $line, $col ) = $wheel->interpret_mouse( $key )
$str = $wheel->format_key( $key, $format )
$key = $wheel->parse_key( $str, $format )
$key = $wheel->parse_key_at_pos( $str, $format )
$cmp = $wheel->keycmp( $key1, $key2 )
These methods all proxy to the Term::TermKey
object, and allow transparent use of the POE::Wheel::TermKey
object as if it was a subclass. Their arguments, behaviour and return value are therefore those provided by that class. For more detail, see the Term::TermKey documentation.
AUTHOR
Paul Evans <leonerd@leonerd.org.uk>