diff options
author | Jim Meyering <jim@meyering.net> | 1996-06-29 04:11:43 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 1996-06-29 04:11:43 +0000 |
commit | cd53ea93c5f3ea3e2aeb9f85a9f214abf13bd053 (patch) | |
tree | a291e5e6b201a09099383f8f1ee661c6dc53c2eb | |
parent | aec69ce22065bf7a79b49ec9bea71b036dababb5 (diff) | |
download | coreutils-cd53ea93c5f3ea3e2aeb9f85a9f214abf13bd053.tar.xz |
(dc_parse_stream): Move enum states dcl into this function.
(dc_parse_stream): Remove parameter RESULT.
Adapt callers.
-rw-r--r-- | src/dircolors.c | 30 |
1 files changed, 17 insertions, 13 deletions
diff --git a/src/dircolors.c b/src/dircolors.c index 82c706168..57a4313a7 100644 --- a/src/dircolors.c +++ b/src/dircolors.c @@ -1,4 +1,3 @@ -/* FIXME: why no error for BERM? */ /* FIXME: dircolors - parse a Slackware-style DIR_COLORS file. Copyright (C) 1994, 1995 H. Peter Anvin Copyright (C) 1996 Free Software Foundation, Inc. @@ -46,9 +45,6 @@ enum Shell_syntax SHELL_SYNTAX_UNKNOWN }; -/* Parser needs these state variables. */ -enum states { ST_TERMNO, ST_TERMYES, ST_TERMSURE, ST_GLOBAL }; - #define APPEND_CHAR(C) obstack_1grow (&lsc_obstack, C) #define APPEND_TWO_CHAR_STRING(S) \ do \ @@ -58,10 +54,11 @@ enum states { ST_TERMNO, ST_TERMYES, ST_TERMSURE, ST_GLOBAL }; } \ while (0) -/* FIXME: */ +/* Accumulate in this obstack the value for the LS_COLORS environment + variable. */ static struct obstack lsc_obstack; -/* Nonzero if any of the files read were the standard input. */ +/* Nonzero if the input file was the standard input. */ static int have_read_stdin; /* FIXME: associate with ls_codes? */ @@ -225,10 +222,15 @@ append_quoted (const char *str) } } -/* FIXME: Accumulate settings in obstack and convert to string in *RESULT. */ +/* Read the file open on FP (with name FILENAME). First, look for a + `TERM name' directive where name matches the current terminal type. + Once found, translate and accumulate the associated directives onto + the global obstack LSC_OBSTACK. Give a diagnostic and return nonzero + upon failure (unrecognized keyword is the only way to fail here). + Return zero otherwise. */ static int -dc_parse_stream (FILE *fp, const char *filename, char **result) +dc_parse_stream (FILE *fp, const char *filename) { size_t line_number = 0; char *line = NULL; @@ -237,6 +239,9 @@ dc_parse_stream (FILE *fp, const char *filename, char **result) char *term; int err = 0; + /* State for the parser. */ + enum states { ST_TERMNO, ST_TERMYES, ST_TERMSURE, ST_GLOBAL }; + state = ST_GLOBAL; /* Get terminal type */ @@ -354,7 +359,7 @@ dc_parse_stream (FILE *fp, const char *filename, char **result) } static int -dc_parse_file (const char *filename, char **ls_color_string) +dc_parse_file (const char *filename) { FILE *fp; int err; @@ -378,7 +383,7 @@ dc_parse_file (const char *filename, char **ls_color_string) } } - err = dc_parse_stream (fp, filename, ls_color_string); + err = dc_parse_stream (fp, filename); if (fp != stdin && fclose (fp) == EOF) { @@ -395,7 +400,6 @@ main (int argc, char **argv) int err = 0; int optc; enum Shell_syntax syntax = SHELL_SYNTAX_UNKNOWN; - char *ls_color_string; int print_database = 0; program_name = argv[0]; @@ -476,9 +480,9 @@ dircolors' internal database")); obstack_init (&lsc_obstack); if (argc == 0) - err = dc_parse_stream (NULL, NULL, &ls_color_string); + err = dc_parse_stream (NULL, NULL); else - err = dc_parse_file (argv[0], &ls_color_string); + err = dc_parse_file (argv[0]); if (!err) { |