xref: /openbsd-src/lib/libmenu/m_format.c (revision 62a742911104f98b9185b2c6b6007d9b1c36396c)
1 /*	$OpenBSD: m_format.c,v 1.4 1998/07/24 16:38:55 millert Exp $	*/
2 
3 /****************************************************************************
4  * Copyright (c) 1998 Free Software Foundation, Inc.                        *
5  *                                                                          *
6  * Permission is hereby granted, free of charge, to any person obtaining a  *
7  * copy of this software and associated documentation files (the            *
8  * "Software"), to deal in the Software without restriction, including      *
9  * without limitation the rights to use, copy, modify, merge, publish,      *
10  * distribute, distribute with modifications, sublicense, and/or sell       *
11  * copies of the Software, and to permit persons to whom the Software is    *
12  * furnished to do so, subject to the following conditions:                 *
13  *                                                                          *
14  * The above copyright notice and this permission notice shall be included  *
15  * in all copies or substantial portions of the Software.                   *
16  *                                                                          *
17  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  *
18  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF               *
19  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   *
20  * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,   *
21  * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR    *
22  * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR    *
23  * THE USE OR OTHER DEALINGS IN THE SOFTWARE.                               *
24  *                                                                          *
25  * Except as contained in this notice, the name(s) of the above copyright   *
26  * holders shall not be used in advertising or otherwise to promote the     *
27  * sale, use or other dealings in this Software without prior written       *
28  * authorization.                                                           *
29  ****************************************************************************/
30 
31 /****************************************************************************
32  *   Author: Juergen Pfeifer <Juergen.Pfeifer@T-Online.de> 1995,1997        *
33  ****************************************************************************/
34 
35 /***************************************************************************
36 * Module m_format                                                          *
37 * Set and get maximum numbers of rows and columns in menus                 *
38 ***************************************************************************/
39 
40 #include "menu.priv.h"
41 
42 MODULE_ID("$From: m_format.c,v 1.7 1998/02/11 12:13:49 tom Exp $")
43 
44 #define minimum(a,b) ((a)<(b) ? (a): (b))
45 
46 /*---------------------------------------------------------------------------
47 |   Facility      :  libnmenu
48 |   Function      :  int set_menu_format(MENU *menu, int rows, int cols)
49 |
50 |   Description   :  Sets the maximum number of rows and columns of items
51 |                    that may be displayed at one time on a menu. If the
52 |                    menu contains more items than can be displayed at
53 |                    once, the menu will be scrollable.
54 |
55 |   Return Values :  E_OK                   - success
56 |                    E_BAD_ARGUMENT         - invalid values passed
57 |                    E_NOT_CONNECTED        - there are no items connected
58 |                    E_POSTED               - the menu is already posted
59 +--------------------------------------------------------------------------*/
60 int set_menu_format(MENU *menu, int rows, int cols)
61 {
62   int total_rows, total_cols;
63 
64   if (rows<0 || cols<0)
65     RETURN(E_BAD_ARGUMENT);
66 
67   if (menu)
68     {
69       if ( menu->status & _POSTED )
70 	RETURN(E_POSTED);
71 
72       if (!(menu->items))
73 	RETURN(E_NOT_CONNECTED);
74 
75       if (rows==0)
76 	rows = menu->frows;
77       if (cols==0)
78 	cols = menu->fcols;
79 
80       if (menu->pattern)
81 	Reset_Pattern(menu);
82 
83       menu->frows = rows;
84       menu->fcols = cols;
85 
86       assert(rows>0 && cols>0);
87       total_rows = (menu->nitems - 1)/cols + 1;
88       total_cols = (menu->status & O_ROWMAJOR) ?
89 	minimum(menu->nitems,cols) :
90 	  (menu->nitems-1)/total_rows + 1;
91 
92       menu->rows    = total_rows;
93       menu->cols    = total_cols;
94       menu->arows   = minimum(total_rows,rows);
95       menu->toprow  = 0;
96       menu->curitem = *(menu->items);
97       assert(menu->curitem);
98       menu->status |= _LINK_NEEDED;
99       _nc_Calculate_Item_Length_and_Width(menu);
100     }
101   else
102     {
103       if (rows>0) _nc_Default_Menu.frows = rows;
104       if (cols>0) _nc_Default_Menu.fcols = cols;
105     }
106 
107   RETURN(E_OK);
108 }
109 
110 /*---------------------------------------------------------------------------
111 |   Facility      :  libnmenu
112 |   Function      :  void menu_format(const MENU *menu, int *rows, int *cols)
113 |
114 |   Description   :  Returns the maximum number of rows and columns that may
115 |                    be displayed at one time on menu.
116 |
117 |   Return Values :  -
118 +--------------------------------------------------------------------------*/
119 void menu_format(const MENU *menu, int *rows, int *cols)
120 {
121   if (rows)
122     *rows = Normalize_Menu(menu)->frows;
123   if (cols)
124     *cols = Normalize_Menu(menu)->fcols;
125 }
126 
127 /* m_format.c ends here */
128