99 lines
3.5 KiB
C
99 lines
3.5 KiB
C
/*-
|
|
* Copyright (c) 1991, 1993, 1994
|
|
* The Regents of the University of California. All rights reserved.
|
|
* Copyright (c) 1991, 1993, 1994, 1995, 1996
|
|
* Keith Bostic. All rights reserved.
|
|
*
|
|
* See the LICENSE file for redistribution information.
|
|
*
|
|
* @(#)options.h 10.16 (Berkeley) 5/16/96
|
|
*/
|
|
|
|
/*
|
|
* Edit option information. Historically, if you set a boolean or numeric
|
|
* edit option value to its "default" value, it didn't show up in the :set
|
|
* display, i.e. it wasn't considered "changed". String edit options would
|
|
* show up as changed, regardless. We maintain a parallel set of values
|
|
* which are the default values and never consider an edit option changed
|
|
* if it was reset to the default value.
|
|
*
|
|
* Macros to retrieve boolean, integral and string option values, and to
|
|
* set, clear and test boolean option values. Some options (secure, lines,
|
|
* columns, terminal type) are global in scope, and are therefore stored
|
|
* in the global area. The offset in the global options array is stored
|
|
* in the screen's value field. This is set up when the options are first
|
|
* initialized.
|
|
*/
|
|
#define O_V(sp, o, fld) \
|
|
(F_ISSET(&(sp)->opts[(o)], OPT_GLOBAL) ? \
|
|
(sp)->gp->opts[(sp)->opts[(o)].o_cur.val].fld : \
|
|
(sp)->opts[(o)].fld)
|
|
|
|
/* Global option macros. */
|
|
#define OG_CLR(gp, o) ((gp)->opts[(o)].o_cur.val) = 0
|
|
#define OG_SET(gp, o) ((gp)->opts[(o)].o_cur.val) = 1
|
|
#define OG_STR(gp, o) ((gp)->opts[(o)].o_cur.str)
|
|
#define OG_VAL(gp, o) ((gp)->opts[(o)].o_cur.val)
|
|
#define OG_ISSET(gp, o) OG_VAL(gp, o)
|
|
|
|
#define OG_D_STR(gp, o) ((gp)->opts[(o)].o_def.str)
|
|
#define OG_D_VAL(gp, o) ((gp)->opts[(o)].o_def.val)
|
|
|
|
/* Flags to o_set(). */
|
|
#define OS_DEF 0x01 /* Set the default value. */
|
|
#define OS_FREE 0x02 /* Free old string if set. */
|
|
#define OS_STR 0x04 /* Set to the str value. */
|
|
#define OS_STRDUP 0x08 /* Copy and set to the str value. */
|
|
|
|
struct _option {
|
|
union {
|
|
u_long val; /* Value or boolean. */
|
|
char *str; /* String. */
|
|
} o_cur;
|
|
#define O_CLR(sp, o) o_set(sp, o, 0, NULL, 0)
|
|
#define O_SET(sp, o) o_set(sp, o, 0, NULL, 1)
|
|
#define O_STR(sp, o) O_V(sp, o, o_cur.str)
|
|
#define O_VAL(sp, o) O_V(sp, o, o_cur.val)
|
|
#define O_ISSET(sp, o) O_VAL(sp, o)
|
|
|
|
union {
|
|
u_long val; /* Value or boolean. */
|
|
char *str; /* String. */
|
|
} o_def;
|
|
#define O_D_CLR(sp, o) o_set(sp, o, OS_DEF, NULL, 0)
|
|
#define O_D_SET(sp, o) o_set(sp, o, OS_DEF, NULL, 1)
|
|
#define O_D_STR(sp, o) O_V(sp, o, o_def.str)
|
|
#define O_D_VAL(sp, o) O_V(sp, o, o_def.val)
|
|
#define O_D_ISSET(sp, o) O_D_VAL(sp, o)
|
|
|
|
#define OPT_GLOBAL 0x01 /* Option is global. */
|
|
#define OPT_SELECTED 0x02 /* Selected for display. */
|
|
u_int8_t flags;
|
|
};
|
|
|
|
/* List of option names, associated update functions and information. */
|
|
struct _optlist {
|
|
char *name; /* Name. */
|
|
/* Change function. */
|
|
int (*func) __P((SCR *, OPTION *, char *, u_long *));
|
|
/* Type of object. */
|
|
enum { OPT_0BOOL, OPT_1BOOL, OPT_NUM, OPT_STR } type;
|
|
|
|
#define OPT_ADISP 0x001 /* Always display the option. */
|
|
#define OPT_ALWAYS 0x002 /* Always call the support function. */
|
|
#define OPT_NDISP 0x004 /* Never display the option. */
|
|
#define OPT_NOSAVE 0x008 /* Mkexrc command doesn't save. */
|
|
#define OPT_NOSET 0x010 /* Option may not be unset. */
|
|
#define OPT_NOUNSET 0x020 /* Option may not be unset. */
|
|
#define OPT_NOZERO 0x040 /* Option may not be set to 0. */
|
|
u_int8_t flags;
|
|
};
|
|
|
|
/* Option argument to opts_dump(). */
|
|
enum optdisp { NO_DISPLAY, ALL_DISPLAY, CHANGED_DISPLAY, SELECT_DISPLAY };
|
|
|
|
/* Options array. */
|
|
extern OPTLIST const optlist[];
|
|
|
|
#include "options_def.h"
|