xref: /netbsd/usr.bin/menuc/mdb.h (revision b6a156ad)
1 /*	$NetBSD: mdb.h,v 1.12 2019/06/23 22:46:41 christos Exp $	*/
2 
3 /*
4  * Copyright 1997 Piermont Information Systems Inc.
5  * All rights reserved.
6  *
7  * Written by Philip A. Nelson for Piermont Information Systems Inc.
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions
11  * are met:
12  * 1. Redistributions of source code must retain the above copyright
13  *    notice, this list of conditions and the following disclaimer.
14  * 2. Redistributions in binary form must reproduce the above copyright
15  *    notice, this list of conditions and the following disclaimer in the
16  *    documentation and/or other materials provided with the distribution.
17  * 3. The name of Piermont Information Systems Inc. may not be used to endorse
18  *    or promote products derived from this software without specific prior
19  *    written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY PIERMONT INFORMATION SYSTEMS INC. ``AS IS''
22  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24  * ARE DISCLAIMED. IN NO EVENT SHALL PIERMONT INFORMATION SYSTEMS INC. BE
25  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
31  * THE POSSIBILITY OF SUCH DAMAGE.
32  *
33  */
34 
35 /* mdb.h - definitions for the menu database. */
36 
37 #ifndef MDB_H
38 #define MDB_H
39 
40 /* forward declaration */
41 typedef struct menu_info menu_info;
42 
43 /* The declarations for the balanced binary trees. */
44 
45 typedef struct id_rec {
46 	/* The balanced binary tree fields. */
47 	char  *id;      /* The name. */
48 	short balance;  /* For the balanced tree. */
49 	struct id_rec *left, *right; /* Tree pointers. */
50 
51 	/* Other information fields. */
52 	menu_info *info;
53 	int menu_no;
54 } id_rec;
55 
56 
57 /* menu definitions records. */
58 
59 typedef struct action {
60 	char *code;
61 	int   endwin;
62 } action;
63 
64 typedef struct optn_info {
65 	char *name;
66 	int   name_is_code;
67 	int   menu;
68 	int   issub;
69 	int   doexit;
70 	action optact;
71 	struct optn_info *next;
72 } optn_info;
73 
74 struct menu_info {
75 	char *title;
76 	char *helpstr;
77 	char *exitstr;
78 	int mopt;
79 	int y, x;
80 	int h, w;
81 	int numopt;
82 	int name_is_code;
83 	optn_info *optns;
84 	action expact;
85 	action postact;
86 	action exitact;
87 };
88 
89 /* defines for mopt */
90 #define MC_NOEXITOPT		0x001
91 #define MC_NOBOX		0x002
92 #define MC_SCROLL		0x004
93 #define MC_NOSHORTCUT		0x008
94 #define MC_NOCLEAR		0x010
95 #define MC_DFLTEXIT		0x020
96 #define MC_ALWAYS_SCROLL	0x040
97 #define MC_SUBMENU 		0x080
98 #define	MC_CONTINUOUS 		0x100
99 #define MC_VALID		0x200
100 #endif
101