forked from sabotage-linux/netbsd-curses
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Implement POSIX Curses Soft Label Key functions.
- Loading branch information
Showing
25 changed files
with
1,176 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,244 @@ | ||
.\" $NetBSD: curses_slk.3,v 1.1 2017/01/24 17:27:30 roy 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 January 12, 2017 | ||
.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" "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 | ||
.Dv 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 | ||
.Dv 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 . |
Oops, something went wrong.