1 1.7 agc /* $NetBSD: option.c,v 1.7 2003/10/13 14:34:25 agc Exp $ */ 2 1.3 perry 3 1.1 cjs /* 4 1.7 agc * Copyright (c) 1988 Mark Nudelman 5 1.1 cjs * Copyright (c) 1988, 1993 6 1.1 cjs * The Regents of the University of California. All rights reserved. 7 1.1 cjs * 8 1.1 cjs * Redistribution and use in source and binary forms, with or without 9 1.1 cjs * modification, are permitted provided that the following conditions 10 1.1 cjs * are met: 11 1.1 cjs * 1. Redistributions of source code must retain the above copyright 12 1.1 cjs * notice, this list of conditions and the following disclaimer. 13 1.1 cjs * 2. Redistributions in binary form must reproduce the above copyright 14 1.1 cjs * notice, this list of conditions and the following disclaimer in the 15 1.1 cjs * documentation and/or other materials provided with the distribution. 16 1.6 agc * 3. Neither the name of the University nor the names of its contributors 17 1.6 agc * may be used to endorse or promote products derived from this software 18 1.6 agc * without specific prior written permission. 19 1.6 agc * 20 1.6 agc * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 21 1.6 agc * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22 1.6 agc * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23 1.6 agc * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 24 1.6 agc * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25 1.6 agc * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26 1.6 agc * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27 1.6 agc * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28 1.6 agc * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29 1.6 agc * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30 1.6 agc * SUCH DAMAGE. 31 1.6 agc */ 32 1.6 agc 33 1.4 christos #include <sys/cdefs.h> 34 1.1 cjs #ifndef lint 35 1.4 christos #if 0 36 1.1 cjs static char sccsid[] = "@(#)option.c 8.1 (Berkeley) 6/6/93"; 37 1.4 christos #else 38 1.7 agc __RCSID("$NetBSD: option.c,v 1.7 2003/10/13 14:34:25 agc Exp $"); 39 1.4 christos #endif 40 1.1 cjs #endif /* not lint */ 41 1.1 cjs 42 1.1 cjs #include <stdio.h> 43 1.4 christos #include <stdlib.h> 44 1.4 christos #include <unistd.h> 45 1.4 christos 46 1.4 christos #include "less.h" 47 1.4 christos #include "extern.h" 48 1.1 cjs 49 1.1 cjs int top_scroll; /* Repaint screen from top */ 50 1.1 cjs int bs_mode; /* How to process backspaces */ 51 1.1 cjs int caseless; /* Do "caseless" searches */ 52 1.1 cjs int cbufs = 10; /* Current number of buffers */ 53 1.1 cjs int linenums = 1; /* Use line numbers */ 54 1.1 cjs int quit_at_eof; 55 1.1 cjs int squeeze; /* Squeeze multiple blank lines into one */ 56 1.1 cjs int tabstop = 8; /* Tab settings */ 57 1.1 cjs 58 1.1 cjs char *firstsearch; 59 1.1 cjs 60 1.4 christos int 61 1.1 cjs option(argc, argv) 62 1.1 cjs int argc; 63 1.1 cjs char **argv; 64 1.1 cjs { 65 1.1 cjs static int sc_window_set = 0; 66 1.1 cjs int ch; 67 1.1 cjs char *p; 68 1.1 cjs 69 1.1 cjs /* backward compatible processing for "+/search" */ 70 1.1 cjs char **a; 71 1.1 cjs for (a = argv; *a; ++a) 72 1.1 cjs if ((*a)[0] == '+' && (*a)[1] == '/') 73 1.1 cjs (*a)[0] = '-'; 74 1.1 cjs 75 1.1 cjs optind = 1; /* called twice, re-init getopt. */ 76 1.4 christos while ((ch = getopt(argc, argv, "0123456789/:ceinst:ux:f")) != -1) 77 1.1 cjs switch((char)ch) { 78 1.1 cjs case '0': case '1': case '2': case '3': case '4': 79 1.1 cjs case '5': case '6': case '7': case '8': case '9': 80 1.1 cjs /* 81 1.1 cjs * kludge: more was originally designed to take 82 1.1 cjs * a number after a dash. 83 1.1 cjs */ 84 1.1 cjs if (!sc_window_set) { 85 1.1 cjs p = argv[optind - 1]; 86 1.1 cjs if (p[0] == '-' && p[1] == ch && !p[2]) 87 1.1 cjs sc_height = atoi(++p); 88 1.1 cjs else 89 1.1 cjs sc_height = atoi(argv[optind] + 1); 90 1.1 cjs sc_window_set = 1; 91 1.1 cjs } 92 1.1 cjs break; 93 1.1 cjs case '/': 94 1.1 cjs firstsearch = optarg; 95 1.1 cjs break; 96 1.1 cjs case 'c': 97 1.1 cjs top_scroll = 1; 98 1.1 cjs break; 99 1.1 cjs case 'e': 100 1.1 cjs quit_at_eof = 1; 101 1.1 cjs break; 102 1.1 cjs case 'i': 103 1.1 cjs caseless = 1; 104 1.1 cjs break; 105 1.1 cjs case 'n': 106 1.1 cjs linenums = 0; 107 1.1 cjs break; 108 1.1 cjs case 's': 109 1.1 cjs squeeze = 1; 110 1.1 cjs break; 111 1.1 cjs case 'u': 112 1.1 cjs bs_mode = 1; 113 1.1 cjs break; 114 1.1 cjs case 'x': 115 1.1 cjs tabstop = atoi(optarg); 116 1.1 cjs if (tabstop <= 0) 117 1.1 cjs tabstop = 8; 118 1.1 cjs break; 119 1.5 wiz case 'f': /* ignore -f, compatibility with old more */ 120 1.1 cjs break; 121 1.1 cjs case '?': 122 1.1 cjs default: 123 1.1 cjs fprintf(stderr, 124 1.2 cjs "usage: more [-ceinus] [-x tabs] [-/ pattern] [-#] [file ...]\n"); 125 1.1 cjs exit(1); 126 1.1 cjs } 127 1.1 cjs return(optind); 128 1.1 cjs } 129