less: stop using data/bss. Code got smaller too.

# size busybox_old busybox_unstripped
   text    data     bss     dec     hex filename
 700719    2896   17880  721495   b0257 busybox_old
 700547    2832   17432  720811   affab busybox_unstripped
# size */*/less.o
   text    data     bss     dec     hex filename
   6861      50     344    7255    1c57 busybox.t0/miscutils/less.o
   6657       0       0    6657    1a01 busybox.t1/miscutils/less.o
1_6_stable
Denis Vlasenko 2007-05-31 15:55:03 +00:00
parent 199c0d542b
commit a1d24a0b6e
1 changed files with 83 additions and 48 deletions

View File

@ -72,27 +72,6 @@ enum {
TILDES = 1, TILDES = 1,
}; };
static unsigned max_displayed_line;
static unsigned width;
static const char *empty_line_marker = "~";
static char *filename;
static char **files;
static unsigned num_files = 1;
static unsigned current_file = 1;
static const char **buffer;
static const char **flines;
static int cur_fline; /* signed */
static unsigned max_fline;
static unsigned max_lineno; /* this one tracks linewrap */
static ssize_t eof_error = 1; /* eof if 0, error if < 0 */
static char terminated = 1;
static size_t readpos;
static size_t readeof;
/* last position in last line, taking into account tabs */
static size_t linepos;
/* Command line options */ /* Command line options */
enum { enum {
FLAG_E = 1, FLAG_E = 1,
@ -104,25 +83,79 @@ enum {
LESS_STATE_MATCH_BACKWARDS = 1 << 15, LESS_STATE_MATCH_BACKWARDS = 1 << 15,
}; };
#if ENABLE_FEATURE_LESS_MARKS #if !ENABLE_FEATURE_LESS_REGEXP
static unsigned mark_lines[15][2];
static unsigned num_marks;
#endif
#if ENABLE_FEATURE_LESS_REGEXP
static unsigned *match_lines;
static int match_pos; /* signed! */
static unsigned num_matches;
static regex_t pattern;
static unsigned pattern_valid;
#else
enum { pattern_valid = 0 }; enum { pattern_valid = 0 };
#endif #endif
static struct termios term_orig, term_vi; struct globals {
int cur_fline; /* signed */
/* File pointer to get input from */ int kbd_fd; /* fd to get input from */
static int kbd_fd; /* last position in last line, taking into account tabs */
size_t linepos;
unsigned max_displayed_line;
unsigned max_fline;
unsigned max_lineno; /* this one tracks linewrap */
unsigned width;
ssize_t eof_error; /* eof if 0, error if < 0 */
size_t readpos;
size_t readeof;
const char **buffer;
const char **flines;
const char *empty_line_marker;
unsigned num_files;
unsigned current_file;
char *filename;
char **files;
#if ENABLE_FEATURE_LESS_MARKS
unsigned num_marks;
unsigned mark_lines[15][2];
#endif
#if ENABLE_FEATURE_LESS_REGEXP
unsigned *match_lines;
int match_pos; /* signed! */
unsigned num_matches;
regex_t pattern;
smallint pattern_valid;
#endif
smallint terminated;
struct termios term_orig, term_less;
};
#define G (*ptr_to_globals)
#define cur_fline (G.cur_fline )
#define kbd_fd (G.kbd_fd )
#define linepos (G.linepos )
#define max_displayed_line (G.max_displayed_line)
#define max_fline (G.max_fline )
#define max_lineno (G.max_lineno )
#define width (G.width )
#define eof_error (G.eof_error )
#define readpos (G.readpos )
#define readeof (G.readeof )
#define buffer (G.buffer )
#define flines (G.flines )
#define empty_line_marker (G.empty_line_marker )
#define num_files (G.num_files )
#define current_file (G.current_file )
#define filename (G.filename )
#define files (G.files )
#define num_marks (G.num_marks )
#define mark_lines (G.mark_lines )
#define match_lines (G.match_lines )
#define match_pos (G.match_pos )
#define num_matches (G.num_matches )
#define pattern (G.pattern )
#define pattern_valid (G.pattern_valid )
#define terminated (G.terminated )
#define term_orig (G.term_orig )
#define term_less (G.term_less )
#define INIT_G() do { \
PTR_TO_GLOBALS = xzalloc(sizeof(G)); \
empty_line_marker = "~"; \
num_files = 1; \
current_file = 1; \
eof_error = 1; \
terminated = 1; \
} while (0)
/* Reset terminal input to normal */ /* Reset terminal input to normal */
static void set_tty_cooked(void) static void set_tty_cooked(void)
@ -380,12 +413,12 @@ static void cap_cur_fline(int nlines)
} }
} }
static char controls[] = static const char controls[] =
/* NUL: never encountered; TAB: not converted */ /* NUL: never encountered; TAB: not converted */
/**/"\x01\x02\x03\x04\x05\x06\x07\x08" "\x0a\x0b\x0c\x0d\x0e\x0f" /**/"\x01\x02\x03\x04\x05\x06\x07\x08" "\x0a\x0b\x0c\x0d\x0e\x0f"
"\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f" "\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f"
"\x7f\x9b"; /* DEL and infamous Meta-ESC :( */ "\x7f\x9b"; /* DEL and infamous Meta-ESC :( */
static char ctrlconv[] = static const char ctrlconv[] =
/* '\n': it's a former NUL - subst with '@', not 'J' */ /* '\n': it's a former NUL - subst with '@', not 'J' */
"\x40\x41\x42\x43\x44\x45\x46\x47\x48\x49\x40\x4b\x4c\x4d\x4e\x4f" "\x40\x41\x42\x43\x44\x45\x46\x47\x48\x49\x40\x4b\x4c\x4d\x4e\x4f"
"\x50\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5a\x5b\x5c\x5d\x5e\x5f"; "\x50\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5a\x5b\x5c\x5d\x5e\x5f";
@ -604,7 +637,7 @@ static void getch_nowait(char* input, int sz)
FD_SET(0, &readfds); FD_SET(0, &readfds);
} }
FD_SET(kbd_fd, &readfds); FD_SET(kbd_fd, &readfds);
tcsetattr(kbd_fd, TCSANOW, &term_vi); tcsetattr(kbd_fd, TCSANOW, &term_less);
select(kbd_fd + 1, &readfds, NULL, NULL, NULL); select(kbd_fd + 1, &readfds, NULL, NULL, NULL);
input[0] = '\0'; input[0] = '\0';
@ -668,7 +701,7 @@ static char* less_gets(int sz)
/* I be damned if I know why is it needed *repeatedly*, /* I be damned if I know why is it needed *repeatedly*,
* but it is needed. Is it because of stdio? */ * but it is needed. Is it because of stdio? */
tcsetattr(kbd_fd, TCSANOW, &term_vi); tcsetattr(kbd_fd, TCSANOW, &term_less);
read(kbd_fd, &c, 1); read(kbd_fd, &c, 1);
if (c == 0x0d) if (c == 0x0d)
@ -1244,6 +1277,8 @@ int less_main(int argc, char **argv)
{ {
int keypress; int keypress;
INIT_G();
/* TODO: -x: do not interpret backspace, -xx: tab also */ /* TODO: -x: do not interpret backspace, -xx: tab also */
/* -xxx: newline also */ /* -xxx: newline also */
/* -w N: assume width N (-xxx -w 32: hex viewer of sorts) */ /* -w N: assume width N (-xxx -w 32: hex viewer of sorts) */
@ -1283,16 +1318,16 @@ int less_main(int argc, char **argv)
tcgetattr(kbd_fd, &term_orig); tcgetattr(kbd_fd, &term_orig);
signal(SIGTERM, sig_catcher); signal(SIGTERM, sig_catcher);
signal(SIGINT, sig_catcher); signal(SIGINT, sig_catcher);
term_vi = term_orig; term_less = term_orig;
term_vi.c_lflag &= ~(ICANON | ECHO); term_less.c_lflag &= ~(ICANON | ECHO);
term_vi.c_iflag &= ~(IXON | ICRNL); term_less.c_iflag &= ~(IXON | ICRNL);
/*term_vi.c_oflag &= ~ONLCR;*/ /*term_less.c_oflag &= ~ONLCR;*/
term_vi.c_cc[VMIN] = 1; term_less.c_cc[VMIN] = 1;
term_vi.c_cc[VTIME] = 0; term_less.c_cc[VTIME] = 0;
/* Want to do it just once, but it doesn't work, */ /* Want to do it just once, but it doesn't work, */
/* so we are redoing it (see code above). Mystery... */ /* so we are redoing it (see code above). Mystery... */
/*tcsetattr(kbd_fd, TCSANOW, &term_vi);*/ /*tcsetattr(kbd_fd, TCSANOW, &term_less);*/
reinitialize(); reinitialize();
while (1) { while (1) {