NAME
Tickit::Console::Tab
- represent a single tab on a Tickit::Console
DESCRIPTION
Objects in this class represent a single switchable tab within a Tickit::Console. They are not constructed directly, but instead are returned by the add_tab
method of the underlying Tickit::Console
object.
PARAMETERS
The following extra parameters may be passed to the constructor, or via the add_tab
method on the Tickit::Console
object:
- timestamp_format => STRING or String::Tagged
-
If defined, every line is prefixed with a timestamp built by applying the
POSIX::strftime
function to this string. If a String::Tagged instance is applied it will preserve all the formatting from it. - datestamp_format => STRING or String::Tagged
-
If defined, every time a line is added to the buffer, if it starts a new day since the previous message (because the format yields a different string), this message is added as well to the scroller.
- localtime => CODE
-
If defined, provides an alternative function to
CORE::localtime
for converting an epoch value into a timestamp. For example, this may be set tosub { gmtime $_[0] }
to generate timestamps in UTC instead of using the local timezone.
METHODS
name
set_name
$name = $tab->name;
$tab->set_name( $name );
Returns or sets the tab name text
append_line
$tab->append_line( $string, %opts );
Appends a line of text to the tab. $string
may either be a plain perl string, or an instance of String::Tagged containing formatting tags, as specified by Tickit::Widget::Scroller. Options will be passed to the Tickit::Widget::Scroller::Item::Line used to contain the string.
Also recognises the following options:
- time => NUM
-
Overrides the epoch
time()
value used to generate a timestamp for this line - timestamp_format => STRING or String::Tagged
-
Overrides the stored format for generating a timestamp string.
- datestamp_format => STRING or String::Tagged
-
Overrides the stored format for generating a datestamp string.
prepend_line
$tab->prepend_line( $string, %opts );
As append_line
, but prepends it at the beginning of the scroller.
bind_key
$tab->bind_key( $key, $code );
Installs a callback to invoke if the given key is pressed while this tab has focus, overwriting any previous callback for the same key. The code block is invoked as
$result = $code->( $tab, $key );
If $code
is missing or undef
, any existing callback is removed.
This callback will be invoked before one defined on the console object itself, if present. If it returns a false value, then the one on the console will be invoked instead.
AUTHOR
Paul Evans <leonerd@leonerd.org.uk>