summaryrefslogtreecommitdiffstats
path: root/contrib/less/optfunc.c
diff options
context:
space:
mode:
authordelphij <delphij@FreeBSD.org>2009-05-08 23:34:35 +0000
committerdelphij <delphij@FreeBSD.org>2009-05-08 23:34:35 +0000
commitd069efd47cacc3156036ed37d5532d6a1d4f55c3 (patch)
tree2526f6b109843b646672c1537476dc51e56c0454 /contrib/less/optfunc.c
parent6aa3e25391d160482339ee072c010bcd22dfbbd1 (diff)
downloadFreeBSD-src-d069efd47cacc3156036ed37d5532d6a1d4f55c3.zip
FreeBSD-src-d069efd47cacc3156036ed37d5532d6a1d4f55c3.tar.gz
Flatten all tags of the dist tree of less.
Diffstat (limited to 'contrib/less/optfunc.c')
-rw-r--r--contrib/less/optfunc.c668
1 files changed, 0 insertions, 668 deletions
diff --git a/contrib/less/optfunc.c b/contrib/less/optfunc.c
deleted file mode 100644
index f296b79..0000000
--- a/contrib/less/optfunc.c
+++ /dev/null
@@ -1,668 +0,0 @@
-/*
- * Copyright (C) 1984-2007 Mark Nudelman
- *
- * You may distribute under the terms of either the GNU General Public
- * License or the Less License, as specified in the README file.
- *
- * For more information about less, or for information on how to
- * contact the author, see the README file.
- */
-
-
-/*
- * Handling functions for command line options.
- *
- * Most options are handled by the generic code in option.c.
- * But all string options, and a few non-string options, require
- * special handling specific to the particular option.
- * This special processing is done by the "handling functions" in this file.
- *
- * Each handling function is passed a "type" and, if it is a string
- * option, the string which should be "assigned" to the option.
- * The type may be one of:
- * INIT The option is being initialized from the command line.
- * TOGGLE The option is being changed from within the program.
- * QUERY The setting of the option is merely being queried.
- */
-
-#include "less.h"
-#include "option.h"
-
-extern int nbufs;
-extern int bufspace;
-extern int pr_type;
-extern int plusoption;
-extern int swindow;
-extern int sc_height;
-extern int secure;
-extern int dohelp;
-extern int any_display;
-extern char openquote;
-extern char closequote;
-extern char *prproto[];
-extern char *eqproto;
-extern char *hproto;
-extern char *wproto;
-extern IFILE curr_ifile;
-extern char version[];
-extern int jump_sline;
-extern int jump_sline_fraction;
-extern int less_is_more;
-#if LOGFILE
-extern char *namelogfile;
-extern int force_logfile;
-extern int logfile;
-#endif
-#if TAGS
-public char *tagoption = NULL;
-extern char *tags;
-#endif
-#if MSDOS_COMPILER
-extern int nm_fg_color, nm_bg_color;
-extern int bo_fg_color, bo_bg_color;
-extern int ul_fg_color, ul_bg_color;
-extern int so_fg_color, so_bg_color;
-extern int bl_fg_color, bl_bg_color;
-#endif
-
-
-#if LOGFILE
-/*
- * Handler for -o option.
- */
- public void
-opt_o(type, s)
- int type;
- char *s;
-{
- PARG parg;
-
- if (secure)
- {
- error("log file support is not available", NULL_PARG);
- return;
- }
- switch (type)
- {
- case INIT:
- namelogfile = s;
- break;
- case TOGGLE:
- if (ch_getflags() & CH_CANSEEK)
- {
- error("Input is not a pipe", NULL_PARG);
- return;
- }
- if (logfile >= 0)
- {
- error("Log file is already in use", NULL_PARG);
- return;
- }
- s = skipsp(s);
- namelogfile = lglob(s);
- use_logfile(namelogfile);
- sync_logfile();
- break;
- case QUERY:
- if (logfile < 0)
- error("No log file", NULL_PARG);
- else
- {
- parg.p_string = namelogfile;
- error("Log file \"%s\"", &parg);
- }
- break;
- }
-}
-
-/*
- * Handler for -O option.
- */
- public void
-opt__O(type, s)
- int type;
- char *s;
-{
- force_logfile = TRUE;
- opt_o(type, s);
-}
-#endif
-
-/*
- * Handlers for -l option.
- */
- public void
-opt_l(type, s)
- int type;
- char *s;
-{
- int err;
- int n;
- char *t;
-
- switch (type)
- {
- case INIT:
- t = s;
- n = getnum(&t, "l", &err);
- if (err || n <= 0)
- {
- error("Line number is required after -l", NULL_PARG);
- return;
- }
- plusoption = TRUE;
- ungetsc(s);
- break;
- }
-}
-
-/*
- * Handlers for -j option.
- */
- public void
-opt_j(type, s)
- int type;
- char *s;
-{
- PARG parg;
- char buf[16];
- int len;
- int err;
-
- switch (type)
- {
- case INIT:
- case TOGGLE:
- if (*s == '.')
- {
- s++;
- jump_sline_fraction = getfraction(&s, "j", &err);
- if (err)
- error("Invalid line fraction", NULL_PARG);
- else
- calc_jump_sline();
- } else
- {
- int sline = getnum(&s, "j", &err);
- if (err)
- error("Invalid line number", NULL_PARG);
- else
- {
- jump_sline = sline;
- jump_sline_fraction = -1;
- }
- }
- break;
- case QUERY:
- if (jump_sline_fraction < 0)
- {
- parg.p_int = jump_sline;
- error("Position target at screen line %d", &parg);
- } else
- {
-
- sprintf(buf, ".%06d", jump_sline_fraction);
- len = strlen(buf);
- while (len > 2 && buf[len-1] == '0')
- len--;
- buf[len] = '\0';
- parg.p_string = buf;
- error("Position target at screen position %s", &parg);
- }
- break;
- }
-}
-
- public void
-calc_jump_sline()
-{
- if (jump_sline_fraction < 0)
- return;
- jump_sline = sc_height * jump_sline_fraction / NUM_FRAC_DENOM;
-}
-
-#if USERFILE
- public void
-opt_k(type, s)
- int type;
- char *s;
-{
- PARG parg;
-
- switch (type)
- {
- case INIT:
- if (lesskey(s, 0))
- {
- parg.p_string = s;
- error("Cannot use lesskey file \"%s\"", &parg);
- }
- break;
- }
-}
-#endif
-
-#if TAGS
-/*
- * Handler for -t option.
- */
- public void
-opt_t(type, s)
- int type;
- char *s;
-{
- IFILE save_ifile;
- POSITION pos;
-
- switch (type)
- {
- case INIT:
- tagoption = s;
- /* Do the rest in main() */
- break;
- case TOGGLE:
- if (secure)
- {
- error("tags support is not available", NULL_PARG);
- break;
- }
- findtag(skipsp(s));
- save_ifile = save_curr_ifile();
- /*
- * Try to open the file containing the tag
- * and search for the tag in that file.
- */
- if (edit_tagfile() || (pos = tagsearch()) == NULL_POSITION)
- {
- /* Failed: reopen the old file. */
- reedit_ifile(save_ifile);
- break;
- }
- unsave_ifile(save_ifile);
- jump_loc(pos, jump_sline);
- break;
- }
-}
-
-/*
- * Handler for -T option.
- */
- public void
-opt__T(type, s)
- int type;
- char *s;
-{
- PARG parg;
-
- switch (type)
- {
- case INIT:
- tags = s;
- break;
- case TOGGLE:
- s = skipsp(s);
- tags = lglob(s);
- break;
- case QUERY:
- parg.p_string = tags;
- error("Tags file \"%s\"", &parg);
- break;
- }
-}
-#endif
-
-/*
- * Handler for -p option.
- */
- public void
-opt_p(type, s)
- int type;
- register char *s;
-{
- switch (type)
- {
- case INIT:
- /*
- * Unget a search command for the specified string.
- * {{ This won't work if the "/" command is
- * changed or invalidated by a .lesskey file. }}
- */
- plusoption = TRUE;
- ungetsc(s);
- /*
- * In "more" mode, the -p argument is a command,
- * not a search string, so we don't need a slash.
- */
- if (!less_is_more)
- ungetsc("/");
- break;
- }
-}
-
-/*
- * Handler for -P option.
- */
- public void
-opt__P(type, s)
- int type;
- register char *s;
-{
- register char **proto;
- PARG parg;
-
- switch (type)
- {
- case INIT:
- case TOGGLE:
- /*
- * Figure out which prototype string should be changed.
- */
- switch (*s)
- {
- case 's': proto = &prproto[PR_SHORT]; s++; break;
- case 'm': proto = &prproto[PR_MEDIUM]; s++; break;
- case 'M': proto = &prproto[PR_LONG]; s++; break;
- case '=': proto = &eqproto; s++; break;
- case 'h': proto = &hproto; s++; break;
- case 'w': proto = &wproto; s++; break;
- default: proto = &prproto[PR_SHORT]; break;
- }
- free(*proto);
- *proto = save(s);
- break;
- case QUERY:
- parg.p_string = prproto[pr_type];
- error("%s", &parg);
- break;
- }
-}
-
-/*
- * Handler for the -b option.
- */
- /*ARGSUSED*/
- public void
-opt_b(type, s)
- int type;
- char *s;
-{
- switch (type)
- {
- case INIT:
- case TOGGLE:
- /*
- * Set the new number of buffers.
- */
- ch_setbufspace(bufspace);
- break;
- case QUERY:
- break;
- }
-}
-
-/*
- * Handler for the -i option.
- */
- /*ARGSUSED*/
- public void
-opt_i(type, s)
- int type;
- char *s;
-{
- switch (type)
- {
- case TOGGLE:
- chg_caseless();
- break;
- case QUERY:
- case INIT:
- break;
- }
-}
-
-/*
- * Handler for the -V option.
- */
- /*ARGSUSED*/
- public void
-opt__V(type, s)
- int type;
- char *s;
-{
- switch (type)
- {
- case TOGGLE:
- case QUERY:
- dispversion();
- break;
- case INIT:
- /*
- * Force output to stdout per GNU standard for --version output.
- */
- any_display = 1;
- putstr("less ");
- putstr(version);
- putstr("\nCopyright (C) 1984-2007 Mark Nudelman\n\n");
- putstr("less comes with NO WARRANTY, to the extent permitted by law.\n");
- putstr("For information about the terms of redistribution,\n");
- putstr("see the file named README in the less distribution.\n");
- putstr("Homepage: http://www.greenwoodsoftware.com/less\n");
- quit(QUIT_OK);
- break;
- }
-}
-
-#if MSDOS_COMPILER
-/*
- * Parse an MSDOS color descriptor.
- */
- static void
-colordesc(s, fg_color, bg_color)
- char *s;
- int *fg_color;
- int *bg_color;
-{
- int fg, bg;
- int err;
-
- fg = getnum(&s, "D", &err);
- if (err)
- {
- error("Missing fg color in -D", NULL_PARG);
- return;
- }
- if (*s != '.')
- bg = 0;
- else
- {
- s++;
- bg = getnum(&s, "D", &err);
- if (err)
- {
- error("Missing fg color in -D", NULL_PARG);
- return;
- }
- }
- if (*s != '\0')
- error("Extra characters at end of -D option", NULL_PARG);
- *fg_color = fg;
- *bg_color = bg;
-}
-
-/*
- * Handler for the -D option.
- */
- /*ARGSUSED*/
- public void
-opt_D(type, s)
- int type;
- char *s;
-{
- switch (type)
- {
- case INIT:
- case TOGGLE:
- switch (*s++)
- {
- case 'n':
- colordesc(s, &nm_fg_color, &nm_bg_color);
- break;
- case 'd':
- colordesc(s, &bo_fg_color, &bo_bg_color);
- break;
- case 'u':
- colordesc(s, &ul_fg_color, &ul_bg_color);
- break;
- case 'k':
- colordesc(s, &bl_fg_color, &bl_bg_color);
- break;
- case 's':
- colordesc(s, &so_fg_color, &so_bg_color);
- break;
- default:
- error("-D must be followed by n, d, u, k or s", NULL_PARG);
- break;
- }
- if (type == TOGGLE)
- {
- at_enter(AT_STANDOUT);
- at_exit();
- }
- break;
- case QUERY:
- break;
- }
-}
-#endif
-
-/*
- * Handler for the -x option.
- */
- public void
-opt_x(type, s)
- int type;
- register char *s;
-{
- extern int tabstops[];
- extern int ntabstops;
- extern int tabdefault;
- char msg[60+(4*TABSTOP_MAX)];
- int i;
- PARG p;
-
- switch (type)
- {
- case INIT:
- case TOGGLE:
- /* Start at 1 because tabstops[0] is always zero. */
- for (i = 1; i < TABSTOP_MAX; )
- {
- int n = 0;
- s = skipsp(s);
- while (*s >= '0' && *s <= '9')
- n = (10 * n) + (*s++ - '0');
- if (n > tabstops[i-1])
- tabstops[i++] = n;
- s = skipsp(s);
- if (*s++ != ',')
- break;
- }
- if (i < 2)
- return;
- ntabstops = i;
- tabdefault = tabstops[ntabstops-1] - tabstops[ntabstops-2];
- break;
- case QUERY:
- strcpy(msg, "Tab stops ");
- if (ntabstops > 2)
- {
- for (i = 1; i < ntabstops; i++)
- {
- if (i > 1)
- strcat(msg, ",");
- sprintf(msg+strlen(msg), "%d", tabstops[i]);
- }
- sprintf(msg+strlen(msg), " and then ");
- }
- sprintf(msg+strlen(msg), "every %d spaces",
- tabdefault);
- p.p_string = msg;
- error("%s", &p);
- break;
- }
-}
-
-
-/*
- * Handler for the -" option.
- */
- public void
-opt_quote(type, s)
- int type;
- register char *s;
-{
- char buf[3];
- PARG parg;
-
- switch (type)
- {
- case INIT:
- case TOGGLE:
- if (s[0] == '\0')
- {
- openquote = closequote = '\0';
- break;
- }
- if (s[1] != '\0' && s[2] != '\0')
- {
- error("-\" must be followed by 1 or 2 chars", NULL_PARG);
- return;
- }
- openquote = s[0];
- if (s[1] == '\0')
- closequote = openquote;
- else
- closequote = s[1];
- break;
- case QUERY:
- buf[0] = openquote;
- buf[1] = closequote;
- buf[2] = '\0';
- parg.p_string = buf;
- error("quotes %s", &parg);
- break;
- }
-}
-
-/*
- * "-?" means display a help message.
- * If from the command line, exit immediately.
- */
- /*ARGSUSED*/
- public void
-opt_query(type, s)
- int type;
- char *s;
-{
- switch (type)
- {
- case QUERY:
- case TOGGLE:
- error("Use \"h\" for help", NULL_PARG);
- break;
- case INIT:
- dohelp = 1;
- }
-}
-
-/*
- * Get the "screen window" size.
- */
- public int
-get_swindow()
-{
- if (swindow > 0)
- return (swindow);
- return (sc_height + swindow);
-}
-
OpenPOWER on IntegriCloud