3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk/*
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * CDDL HEADER START
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major *
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * The contents of this file are subject to the terms of the
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * Common Development and Distribution License, Version 1.0 only
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * (the "License"). You may not use this file except in compliance
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * with the License.
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major *
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * or http://www.opensolaris.org/os/licensing.
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * See the License for the specific language governing permissions
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * and limitations under the License.
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major *
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * When distributing Covered Code, include this CDDL HEADER in each
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * If applicable, add the following below this CDDL HEADER, with the
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * fields enclosed by brackets "[]" replaced with your own identifying
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * information: Portions Copyright [yyyy] [name of copyright owner]
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major *
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major * CDDL HEADER END
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major */
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major/* Copyright (c) 1988 AT&T */
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major/* All Rights Reserved */
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Major
1f48f8236de7de97be1c6b9d06bef50b379c8801jenkins/*
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk * Copyright (c) 1997, by Sun Mircrosystems, Inc.
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk * All rights reserved.
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk */
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk
a622f6b14edb724c3cdbc8b5836a109d4ac80086Peter Major#pragma ident "%Z%%M% %I% %E% SMI" /* SVr4.0 1.12 */
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk
1bad1b69167cb45dd69ec6863eedcaf795df19d7Peter Major/*LINTLIBRARY*/
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk#include <sys/types.h>
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk#include "private.h"
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk
dfc4e0fc3052835b2a069aa9d869fa1161c33fe6Peter Majorvoid
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk_post_item(MENU *m, ITEM *k)
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk{
76d469e3669d93cc170f9e255fd24a9eb022bda3jeff.schenk int foreon = FALSE;
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk int backon = FALSE;
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk int greyon = FALSE;
d7acdbdfb47e51f588dbf7bafc4706000a44aca5Jonathan Scudder chtype c;
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk int i;
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk /* Display the mark region of the item */
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk if (!Selectable(k)) {
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk (void) wattron(Win(m), Grey(m));
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk greyon = TRUE;
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk for (i = Marklen(m); i > 0; i--) {
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk (void) waddch(Win(m), ' ');
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk }
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk } else {
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk if (Value(k) || k == Current(m)) {
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk (void) wattron(Win(m), Fore(m));
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk foreon = TRUE;
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk } else {
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk (void) wattron(Win(m), Back(m));
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk backon = TRUE;
87b3fc65db52638e30547ac9de01938f83b78758Peter Major }
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk
97d9dc3f5c53b6801baddd5100b9fae431ac7e06jeff.schenk /* Display the mark */
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk if (Value(k) || (OneValue(m) && k == Current(m))) {
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk if (Marklen(m)) {
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk (void) waddstr(Win(m), Mark(m));
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk }
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk } else {
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk for (i = Marklen(m); i > 0; i--) {
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk (void) waddch(Win(m), ' ');
a622f6b14edb724c3cdbc8b5836a109d4ac80086Peter Major }
87b3fc65db52638e30547ac9de01938f83b78758Peter Major }
87b3fc65db52638e30547ac9de01938f83b78758Peter Major }
87b3fc65db52638e30547ac9de01938f83b78758Peter Major
87b3fc65db52638e30547ac9de01938f83b78758Peter Major /* Display the name */
87b3fc65db52638e30547ac9de01938f83b78758Peter Major
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk (void) waddnstr(Win(m), Name(k), MaxName(m));
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk if (ShowDesc(m) && MaxDesc(m) != 0) {
3548b37cc2745ea64284ccfd29a9725f06dd1d7bjeff.schenk c = Pad(m);
} else {
c = ' ';
}
for (i = MaxName(m) - NameLen(k); i > 0; i--) {
(void) waddch(Win(m), c);
}
/* Display the description */
if (ShowDesc(m) && MaxDesc(m) != 0) {
(void) waddch(Win(m), Pad(m));
if (DescriptionLen(k) != 0) {
(void) waddstr(Win(m), Description(k));
}
for (i = MaxDesc(m) - DescriptionLen(k); i > 0; i--) {
(void) waddch(Win(m), ' ');
}
}
if (foreon) {
(void) wattroff(Win(m), Fore(m));
}
if (backon) {
(void) wattroff(Win(m), Back(m));
}
if (greyon) {
(void) wattroff(Win(m), Grey(m));
}
}
void
_move_post_item(MENU *m, ITEM *k)
{
(void) wmove(Win(m), Y(k), X(k) * (Itemlen(m)+1));
_post_item(m, k);
}
int
unpost_menu(MENU *m)
{
if (!m) {
return (E_BAD_ARGUMENT);
}
if (Indriver(m)) {
return (E_BAD_STATE);
}
if (!Posted(m)) {
return (E_NOT_POSTED);
}
Iterm(m);
Mterm(m);
(void) werase(US(m));
wsyncup(US(m));
(void) delwin(Sub(m));
Sub(m) = (WINDOW *) NULL;
(void) delwin(Win(m));
Win(m) = (WINDOW *) NULL;
ResetPost(m);
return (E_OK);
}
/*
* This routine draws the item indicated by oldcur first and then
* draws the item indicated by Current. This will have the affect
* of unselecting the first item and selecting the next.
*/
void
_movecurrent(MENU *m, ITEM *oldcur)
{
if (oldcur != Current(m)) {
_move_post_item(m, oldcur);
_move_post_item(m, Current(m));
}
}
/*
* Draw the entire menu into the super window
* This routine assumes all items have been linked and
* that the menu is in at least a pre-post state.
*/
void
_draw(MENU *m)
{
int k;
ITEM *i, *j;
ITEM *si, *sj;
k = 0; /* Line number */
i = IthItem(m, 0);
si = Cyclic(m) ? i : (ITEM *) NULL;
do {
(void) wmove(Win(m), k++, 0);
j = i;
sj = Cyclic(m) ? j : (ITEM *) NULL;
do {
_post_item(m, j);
if ((j = Right(j)) != sj) {
(void) waddch(Win(m), ' ');
}
} while (j != sj);
} while ((i = Down(i)) != si);
}
int
post_menu(MENU *m)
{
ITEM **ip;
int r, c; /* visible # of rows and cols */
if (!m) {
return (E_BAD_ARGUMENT);
}
if (Indriver(m)) {
return (E_BAD_STATE);
}
if (Posted(m)) {
return (E_POSTED);
}
/* Make sure there is at least one item present */
if (Items(m) && IthItem(m, 0)) {
getmaxyx(US(m), r, c);
/* Make sure the menu fits into the window horizontally */
if (c < Width(m) || r < Height(m)) {
return (E_NO_ROOM);
}
/* Create the menu window and derived windows */
if ((Win(m) = newwin(Rows(m), Width(m), 0, 0)) ==
(WINDOW *) NULL) {
return (E_SYSTEM_ERROR);
}
/*
* Take the minimum of the height of the menu (Height), the
* physical height of the window (r), and the number of rows
* in the menu (Rows).
*/
r = min(min(r, Rows(m)), Height(m));
if ((Sub(m) = derwin(Win(m), r, Width(m), 0, 0)) ==
(WINDOW *) NULL) {
return (E_SYSTEM_ERROR);
}
/* If needed, link all items in the menu */
if (LinkNeeded(m)) {
_link_items(m);
}
SetPost(m);
/* If only one value can be set then unset all values */
/* to start. */
if (OneValue(m)) {
for (ip = Items(m); *ip; ip++) {
Value(*ip) = FALSE;
}
}
/* Go do the drawing of the menu */
_draw(m);
Minit(m);
Iinit(m);
_show(m); /* Display the menu */
return (E_OK);
}
return (E_NOT_CONNECTED);
}