\"      $NetBSD: curses_slk.3,v 1.3 2025/04/11 23:57:20 uwe Exp $
\"
\" Copyright (c) 2017 The NetBSD Foundation, Inc.
\" All rights reserved.
\"
\" This code is derived from software contributed to The NetBSD Foundation
\" by Roy Marples.
\"
\" Redistribution and use in source and binary forms, with or without
\" modification, are permitted provided that the following conditions
\" are met:
\" 1. Redistributions of source code must retain the above copyright
\"    notice, this list of conditions and the following disclaimer.
\" 2. Redistributions in binary form must reproduce the above copyright
\"    notice, this list of conditions and the following disclaimer in the
\"    documentation and/or other materials provided with the distribution.
\"
\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
\" PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
\" POSSIBILITY OF SUCH DAMAGE.
\"
\"
Dd September 29, 2018
Dt CURSES_SLK 3
Os
Sh NAME
Nm slk_attroff ,
Nm slk_attr_off ,
Nm slk_attron ,
Nm slk_attr_on ,
Nm slk_attrset ,
Nm slk_attr_set ,
Nm slk_clear ,
Nm slk_color ,
Nm slk_init ,
Nm slk_label ,
Nm slk_noutrefresh ,
Nm slk_refresh ,
Nm slk_restore ,
Nm slk_set ,
Nm slk_touch ,
Nm slk_wset
Nd Curses soft label key routines
Sh LIBRARY
Lb libcurses
Sh SYNOPSIS
In curses.h
Ft int
Fn slk_attroff "const chtype attr"
Ft int
Fn slk_attr_off "const attr_t attr" "void *opt"
Ft int
Fn slk_attron "const chtype attr"
Ft int
Fn slk_attr_on "const attr_t attr" "void *opt"
Ft int
Fn slk_attrset "const chtype attr"
Ft int
Fn slk_attr_set "const attr_t attr" "short pair" "void *opt"
Ft void
Fn slk_clear "void"
Ft int
Fn slk_color "short pair"
Ft int
Fn slk_init "int fmt"
Ft char *
Fn slk_label "int labnum"
Ft int
Fn slk_noutrefresh "void"
Ft int
Fn slk_refresh "void"
Ft int
Fn slk_restore "void"
Ft int
Fn slk_set "int labnum" "const char *label" "int justify"
Ft int
Fn slk_touch "void"
Ft int
Fn slk_wset "int labnum" "const wchar_t *label" "int justify"
Sh DESCRIPTION
This Curses interface manipulates the set of soft function-key labels that
exist on some terminals.
For those terminals that do not have soft labels, Curses takes over the bottom
line of
Dv stdstr ,
reducing the size of
Va stdscr
and the value of the
Dv LINES
external variable.
There can be up to eight labels of up to eight display columns each.
Pp
To use soft labels,
Fn slk_init
must be called before
Xr initscr 3 ,
Xr newterm 3 ,
or
Xr ripoffline 3
is called.
If
Xr newterm 3
eventually uses a line from
Va stdscr
to emulate the soft labels, then
Fa fmt
determines how the labels are arranged on the screen from the following list:
Bl -tag -width ERR -compact
It 0
indicates a 3-2-3 arrangement.
It 1
indicates a 4-4 arrangement.
El
Pp
The
Fn slk_set
and
Fn slk_wset
functions specify the text of soft label number
Fa labnum ,
within the range from 1 to 8 inclusive.
The
Fa label
argument is the string to be put on the label.
The
Fa justify
argument can have the following values to indicate how to justify
Fa label
within the space reserved for it:
Bl -tag -width ERR -compact
It 0
Left align.
It 1
Center align.
It 2
Right align.
El
Pp
The
Fn slk_refresh
and
Fn slk_noutrefresh
functions correspond to the
Xr wrefresh 3
and
Xr wnoutrefresh 3
functions.
Pp
The
Fn slk_label
function returns a pointer to the text displayed in the label.
Pp
The
Fn slk_clear
function immediately clears the soft labels from the screen.
Pp
The
Fn slk_restore
function immediately restores the soft labels to the screen after a call to
Fn slk_clear .
Pp
The
Fn slk_touch
function forces all soft labels to be output the next time
Fn slk_noutrefresh
or
Fn slk_refresh
is called.
Pp
The
Fn slk_attron ,
Fn slk_attrset
and
Fn slk_attroff
functions correspond to
Xr attron 3 ,
Xr attrset 3
and
Xr attroff 3 .
The have an effect only if soft labels are simulated on the bottom line of the
screen.
Pp
The
Fn slk_attr_on ,
Fn slk_attr_set ,
Fn slk_color
and
Fn slk_attr_off
functions correspond to
Xr attr_on 3 ,
Xr attr_set 3 ,
Xr color_set 3
and
Xr attr_off 3
and thus support the attribute constants with the WA_ prefix and color.
The have an effect only if soft labels are simulated on the bottom line of the
screen.
Pp
The
Fa opt
argument is reserved for future use.
Currently the application must provide a NULL pointer as
Fa opt .
Sh RETURN VALUES
Functions returning pointers will return
Dv NULL
if an error is detected.
The functions that return an int will return one of the following
values:
Pp
Bl -tag -width ERR -compact
It Er OK
The function completed successfully.
It Er ERR
An error occurred in the function.
El
Sh SEE ALSO
Xr terminfo 5
Sh NOTES
This has not been tested on a terminal with real soft label keys.
Dv label_height ,
Dv label_width ,
Dv label_format
and
Dv lab_f*
are currently not used.
Sh STANDARDS
The
Nx
Curses library complies with the X/Open Curses specification, part of the
Single Unix Specification.
Sh HISTORY
The Curses package appeared in
Bx 4.0 .
The soft label key functions were added in
Nx 8.0 .