1 /* $NetBSD: option.h,v 1.3 2011/07/03 20:14:13 tron Exp $ */ 2 3 /* 4 * Copyright (C) 1984-2011 Mark Nudelman 5 * 6 * You may distribute under the terms of either the GNU General Public 7 * License or the Less License, as specified in the README file. 8 * 9 * For more information about less, or for information on how to 10 * contact the author, see the README file. 11 */ 12 13 14 #define END_OPTION_STRING ('$') 15 16 /* 17 * Types of options. 18 */ 19 #define BOOL 01 /* Boolean option: 0 or 1 */ 20 #define TRIPLE 02 /* Triple-valued option: 0, 1 or 2 */ 21 #define NUMBER 04 /* Numeric option */ 22 #define STRING 010 /* String-valued option */ 23 #define NOVAR 020 /* No associated variable */ 24 #define REPAINT 040 /* Repaint screen after toggling option */ 25 #define NO_TOGGLE 0100 /* Option cannot be toggled with "-" cmd */ 26 #define HL_REPAINT 0200 /* Repaint hilites after toggling option */ 27 #define NO_QUERY 0400 /* Option cannot be queried with "_" cmd */ 28 #define INIT_HANDLER 01000 /* Call option handler function at startup */ 29 30 #define OTYPE (BOOL|TRIPLE|NUMBER|STRING|NOVAR) 31 32 #define OLETTER_NONE '\1' /* Invalid option letter */ 33 34 /* 35 * Argument to a handling function tells what type of activity: 36 */ 37 #define INIT 0 /* Initialization (from command line) */ 38 #define QUERY 1 /* Query (from _ or - command) */ 39 #define TOGGLE 2 /* Change value (from - command) */ 40 41 /* Flag to toggle_option to specify how to "toggle" */ 42 #define OPT_NO_TOGGLE 0 43 #define OPT_TOGGLE 1 44 #define OPT_UNSET 2 45 #define OPT_SET 3 46 #define OPT_NO_PROMPT 0100 47 48 /* Error code from findopt_name */ 49 #define OPT_AMBIG 1 50 51 struct optname 52 { 53 char *oname; /* Long (GNU-style) option name */ 54 struct optname *onext; /* List of synonymous option names */ 55 }; 56 57 #define OPTNAME_MAX 32 /* Max length of long option name */ 58 59 struct loption 60 { 61 char oletter; /* The controlling letter (a-z) */ 62 struct optname *onames; /* Long (GNU-style) option name */ 63 int otype; /* Type of the option */ 64 int odefault; /* Default value */ 65 int *ovar; /* Pointer to the associated variable */ 66 void (*ofunc) /* Pointer to special handling function */ 67 __P((int, char *)); 68 char *odesc[3]; /* Description of each value */ 69 }; 70 71