/[CvsGraph]/cvsgraph/readconf.c
ViewVC logotype

Diff of /cvsgraph/readconf.c

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph | View Patch Patch

revision 1.1, Tue Jan 1 21:03:23 2002 UTC revision 1.17, Sun Aug 29 12:07:05 2004 UTC
# Line 2  Line 2 
2   * CvsGraph graphical representation generator of brances and revisions   * CvsGraph graphical representation generator of brances and revisions
3   * of a file in cvs/rcs.   * of a file in cvs/rcs.
4   *   *
5   * Copyright (C) 2001  B. Stultiens   * Copyright (C) 2001,2002  B. Stultiens
6   *   *
7   * This program is free software; you can redistribute it and/or modify   * This program is free software; you can redistribute it and/or modify
8   * it under the terms of the GNU General Public License as published by   * it under the terms of the GNU General Public License as published by
# Line 50  Line 50 
50                  font_t  *f;                  font_t  *f;
51                  char    **s;                  char    **s;
52                  color_t *c;                  color_t *c;
53                  int     val;    /* FIXME: Oops, sizeof(int) must be sizeof(void *) */                  double  *d;
54                    INTTYPE val;
55          } confref;          } confref;
56  } keyword_t;  } keyword_t;
57    
58  typedef union {  typedef union {
59          keyword_t       *kw;          keyword_t       *kw;
60          int             i;          int             i;
61            double          d;
62          char            *str;          char            *str;
63  } YYSTYPE;  } YYSTYPE;
64    
# Line 73  Line 75 
75          TYPE_BOOLEAN,          TYPE_BOOLEAN,
76          TYPE_COLOR,          TYPE_COLOR,
77          TYPE_FONT,          TYPE_FONT,
78          TYPE_STRING          TYPE_STRING,
79            TYPE_DOUBLE
80  };  };
81    
82  static keyword_t keywords[] = {  static keyword_t keywords[] = {
83          { "branch_bgcolor",     TYPE_COLOR,     { &conf.branch_bgcolor } },          { "branch_bgcolor",     TYPE_COLOR,     { &conf.branch_bgcolor } },
84          { "branch_bspace",      TYPE_NUMBER,    { &conf.branch_bspace } },          { "branch_bspace",      TYPE_NUMBER,    { &conf.branch_bspace } },
85          { "branch_color",       TYPE_COLOR,     { &conf.branch_color } },          { "branch_color",       TYPE_COLOR,     { &conf.branch_color } },
86          { "branch_font",        TYPE_FONT,      { &conf.branch_font } },          { "branch_font",        TYPE_FONT,      { &conf.branch_font.gdfont } },
87            { "branch_ttfont",      TYPE_STRING,    { &conf.branch_font.ttfont } },
88            { "branch_ttsize",      TYPE_DOUBLE,    { &conf.branch_font.ttsize } },
89            { "branch_tag_color",   TYPE_COLOR,     { &conf.branch_tag_color } },
90            { "branch_tag_font",    TYPE_FONT,      { &conf.branch_tag_font.gdfont } },
91            { "branch_tag_ttfont",  TYPE_STRING,    { &conf.branch_tag_font.ttfont } },
92            { "branch_tag_ttsize",  TYPE_DOUBLE,    { &conf.branch_tag_font.ttsize } },
93          { "branch_lspace",      TYPE_NUMBER,    { &conf.branch_lspace } },          { "branch_lspace",      TYPE_NUMBER,    { &conf.branch_lspace } },
94          { "branch_rspace",      TYPE_NUMBER,    { &conf.branch_rspace } },          { "branch_rspace",      TYPE_NUMBER,    { &conf.branch_rspace } },
95          { "branch_tspace",      TYPE_NUMBER,    { &conf.branch_tspace } },          { "branch_tspace",      TYPE_NUMBER,    { &conf.branch_tspace } },
96          { "branch_connect",     TYPE_NUMBER,    { &conf.branch_connect } },          { "branch_connect",     TYPE_NUMBER,    { &conf.branch_connect } },
97          { "branch_margin",      TYPE_NUMBER,    { &conf.branch_margin } },          { "branch_margin",      TYPE_NUMBER,    { &conf.branch_margin } },
98          { "branch_dupbox",      TYPE_BOOLEAN,   { &conf.branch_dupbox } },          { "branch_dupbox",      TYPE_BOOLEAN,   { &conf.branch_dupbox } },
99            { "branch_fold",        TYPE_BOOLEAN,   { &conf.branch_fold } },
100            { "branch_foldall",     TYPE_BOOLEAN,   { &conf.branch_foldall } },
101            { "branch_subtree",     TYPE_STRING,    { &conf.branch_subtree } },
102          { "upside_down",        TYPE_BOOLEAN,   { &conf.upside_down } },          { "upside_down",        TYPE_BOOLEAN,   { &conf.upside_down } },
103          { "auto_kern",          TYPE_BOOLEAN,   { &conf.auto_kern } },          { "left_right",         TYPE_BOOLEAN,   { &conf.left_right } },
104            { "auto_stretch",       TYPE_BOOLEAN,   { &conf.auto_stretch } },
105          { "color_bg",           TYPE_COLOR,     { &conf.color_bg } },          { "color_bg",           TYPE_COLOR,     { &conf.color_bg } },
106            { "transparent_bg",     TYPE_BOOLEAN,   { &conf.transparent_bg } },
107          { "cvsmodule",          TYPE_STRING,    { &conf.cvsmodule } },          { "cvsmodule",          TYPE_STRING,    { &conf.cvsmodule } },
108          { "cvsroot",            TYPE_STRING,    { &conf.cvsroot } },          { "cvsroot",            TYPE_STRING,    { &conf.cvsroot } },
109          { "date_format",        TYPE_STRING,    { &conf.date_format } },          { "date_format",        TYPE_STRING,    { &conf.date_format } },
110          { "box_shadow",         TYPE_BOOLEAN,   { &conf.box_shadow } },          { "box_shadow",         TYPE_BOOLEAN,   { &conf.box_shadow } },
111          { "strip_untagged",     TYPE_BOOLEAN,   { &conf.strip_untagged } },          { "strip_untagged",     TYPE_BOOLEAN,   { &conf.strip_untagged } },
112          { "strip_first_rev",    TYPE_BOOLEAN,   { &conf.strip_first_rev } },          { "strip_first_rev",    TYPE_BOOLEAN,   { &conf.strip_first_rev } },
113            { "anti_alias",         TYPE_BOOLEAN,   { &conf.anti_alias } },
114            { "use_ttf",            TYPE_BOOLEAN,   { &conf.use_ttf } },
115            { "parse_logs",         TYPE_BOOLEAN,   { &conf.parse_logs } },
116            { "html_level",         TYPE_NUMBER,    { &conf.html_level } },
117            { "thick_lines",        TYPE_NUMBER,    { &conf.thick_lines } },
118            { "msg_color",          TYPE_COLOR,     { &conf.msg_color } },
119            { "msg_font",           TYPE_FONT,      { &conf.msg_font.gdfont } },
120            { "msg_ttfont",         TYPE_STRING,    { &conf.msg_font.ttfont } },
121            { "msg_ttsize",         TYPE_DOUBLE,    { &conf.msg_font.ttsize } },
122            { "rev_hidenumber",     TYPE_BOOLEAN,   { &conf.rev_hidenumber } },
123          { "rev_color",          TYPE_COLOR,     { &conf.rev_color } },          { "rev_color",          TYPE_COLOR,     { &conf.rev_color } },
124          { "rev_bgcolor",        TYPE_COLOR,     { &conf.rev_bgcolor } },          { "rev_bgcolor",        TYPE_COLOR,     { &conf.rev_bgcolor } },
125          { "rev_font",           TYPE_FONT,      { &conf.rev_font } },          { "rev_font",           TYPE_FONT,      { &conf.rev_font.gdfont } },
126            { "rev_ttfont",         TYPE_STRING,    { &conf.rev_font.ttfont } },
127            { "rev_ttsize",         TYPE_DOUBLE,    { &conf.rev_font.ttsize } },
128          { "rev_separator",      TYPE_NUMBER,    { &conf.rev_separator } },          { "rev_separator",      TYPE_NUMBER,    { &conf.rev_separator } },
129          { "rev_minline",        TYPE_NUMBER,    { &conf.rev_minline } },          { "rev_minline",        TYPE_NUMBER,    { &conf.rev_minline } },
130          { "rev_maxline",        TYPE_NUMBER,    { &conf.rev_maxline } },          { "rev_maxline",        TYPE_NUMBER,    { &conf.rev_maxline } },
# Line 108  Line 134 
134          { "rev_bspace",         TYPE_NUMBER,    { &conf.rev_bspace } },          { "rev_bspace",         TYPE_NUMBER,    { &conf.rev_bspace } },
135          { "rev_text",           TYPE_STRING,    { &conf.rev_text } },          { "rev_text",           TYPE_STRING,    { &conf.rev_text } },
136          { "rev_text_color",     TYPE_COLOR,     { &conf.rev_text_color } },          { "rev_text_color",     TYPE_COLOR,     { &conf.rev_text_color } },
137          { "rev_text_font",      TYPE_FONT,      { &conf.rev_text_font } },          { "rev_text_font",      TYPE_FONT,      { &conf.rev_text_font.gdfont } },
138            { "rev_text_ttfont",    TYPE_STRING,    { &conf.rev_text_font.ttfont } },
139            { "rev_text_ttsize",    TYPE_DOUBLE,    { &conf.rev_text_font.ttsize } },
140            { "rev_maxtags",        TYPE_NUMBER,    { &conf.rev_maxtags } },
141            { "merge_color",        TYPE_COLOR,     { &conf.merge_color } },
142            { "merge_from",         TYPE_STRING,    { &conf.merge_from } },
143            { "merge_to",           TYPE_STRING,    { &conf.merge_to } },
144            { "merge_findall",      TYPE_BOOLEAN,   { &conf.merge_findall } },
145            { "merge_front",        TYPE_BOOLEAN,   { &conf.merge_front } },
146            { "merge_nocase",       TYPE_BOOLEAN,   { &conf.merge_nocase } },
147            { "merge_arrows",       TYPE_BOOLEAN,   { &conf.merge_arrows } },
148            { "arrow_width",        TYPE_NUMBER,    { &conf.arrow_width } },
149            { "arrow_length",       TYPE_NUMBER,    { &conf.arrow_length } },
150          { "tag_color",          TYPE_COLOR,     { &conf.tag_color } },          { "tag_color",          TYPE_COLOR,     { &conf.tag_color } },
151          { "tag_font",           TYPE_FONT,      { &conf.tag_font } },          { "tag_font",           TYPE_FONT,      { &conf.tag_font.gdfont } },
152            { "tag_ttfont",         TYPE_STRING,    { &conf.tag_font.ttfont } },
153            { "tag_ttsize",         TYPE_DOUBLE,    { &conf.tag_font.ttsize } },
154            { "tag_ignore",         TYPE_STRING,    { &conf.tag_ignore } },
155            { "tag_ignore_merge",   TYPE_BOOLEAN,   { &conf.tag_ignore_merge } },
156            { "tag_nocase",         TYPE_BOOLEAN,   { &conf.tag_nocase } },
157            { "tag_negate",         TYPE_BOOLEAN,   { &conf.tag_negate } },
158          { "title",              TYPE_STRING,    { &conf.title } },          { "title",              TYPE_STRING,    { &conf.title } },
159          { "title_x",            TYPE_NUMBER,    { &conf.title_x } },          { "title_x",            TYPE_NUMBER,    { &conf.title_x } },
160          { "title_y",            TYPE_NUMBER,    { &conf.title_y } },          { "title_y",            TYPE_NUMBER,    { &conf.title_y } },
161          { "title_font",         TYPE_FONT,      { &conf.title_font } },          { "title_font",         TYPE_FONT,      { &conf.title_font.gdfont } },
162            { "title_ttfont",       TYPE_STRING,    { &conf.title_font.ttfont } },
163            { "title_ttsize",       TYPE_DOUBLE,    { &conf.title_font.ttsize } },
164          { "title_align",        TYPE_NUMBER,    { &conf.title_align } },          { "title_align",        TYPE_NUMBER,    { &conf.title_align } },
165          { "title_color",        TYPE_COLOR,     { &conf.title_color } },          { "title_color",        TYPE_COLOR,     { &conf.title_color } },
166          { "margin_top",         TYPE_NUMBER,    { &conf.margin_top } },          { "margin_top",         TYPE_NUMBER,    { &conf.margin_top } },
# Line 130  Line 176 
176          { "map_rev_alt",        TYPE_STRING,    { &conf.map_rev_alt } },          { "map_rev_alt",        TYPE_STRING,    { &conf.map_rev_alt } },
177          { "map_diff_href",      TYPE_STRING,    { &conf.map_diff_href } },          { "map_diff_href",      TYPE_STRING,    { &conf.map_diff_href } },
178          { "map_diff_alt",       TYPE_STRING,    { &conf.map_diff_alt } },          { "map_diff_alt",       TYPE_STRING,    { &conf.map_diff_alt } },
179            { "map_merge_href",     TYPE_STRING,    { &conf.map_merge_href } },
180            { "map_merge_alt",      TYPE_STRING,    { &conf.map_merge_alt } },
181          { "jpeg",               TYPE_VALUE,     { (void *)IMAGE_JPEG } },          { "jpeg",               TYPE_VALUE,     { (void *)IMAGE_JPEG } },
182          { "png",                TYPE_VALUE,     { (void *)IMAGE_PNG } },          { "png",                TYPE_VALUE,     { (void *)IMAGE_PNG } },
183          { "gif",                TYPE_VALUE,     { (void *)IMAGE_GIF } },          { "gif",                TYPE_VALUE,     { (void *)IMAGE_GIF } },
184          { "true",               TYPE_VALUE,     { (void *)1 } },          { "true",               TYPE_VALUE,     { (void *)1 } },
185          { "false",              TYPE_VALUE,     { (void *)0 } },          { "false",              TYPE_VALUE,     { (void *)0 } },
186            { "not",                TYPE_VALUE,     { (void *)-1 } },
187          { "left",               TYPE_VALUE,     { (void *)0 } },          { "left",               TYPE_VALUE,     { (void *)0 } },
188          { "center",             TYPE_VALUE,     { (void *)1 } },          { "center",             TYPE_VALUE,     { (void *)1 } },
189          { "right",              TYPE_VALUE,     { (void *)2 } },          { "right",              TYPE_VALUE,     { (void *)2 } },
# Line 143  Line 192 
192          { "medium",             TYPE_VALUE,     { (void *)2 } },          { "medium",             TYPE_VALUE,     { (void *)2 } },
193          { "large",              TYPE_VALUE,     { (void *)3 } },          { "large",              TYPE_VALUE,     { (void *)3 } },
194          { "giant",              TYPE_VALUE,     { (void *)4 } },          { "giant",              TYPE_VALUE,     { (void *)4 } },
195            { "HTML3",              TYPE_VALUE,     { (void *)1 } },
196            { "HTML4",              TYPE_VALUE,     { (void *)2 } },
197            { "XHTML",              TYPE_VALUE,     { (void *)3 } },
198  };  };
199    
200  #define NKEYWORDS       (sizeof(keywords) / sizeof(keywords[0]))  #define NKEYWORDS       (sizeof(keywords) / sizeof(keywords[0]))
# Line 209  Line 261 
261          fprintf(DEBUGSTREAM, "%i\n", i);          fprintf(DEBUGSTREAM, "%i\n", i);
262  }  }
263    
264  static void debug_pfont(const char *n, font_t f)  static void debug_pdouble(const char *n, double d)
265    {
266            debug_pname(n);
267            fprintf(DEBUGSTREAM, "%g\n", d);
268    }
269    
270    static void debug_pfont(const char *n, gdFontPtr f)
271  {  {
272          const char *s = "<Unknown font>";          const char *s = "<Unknown font>";
273          debug_pname(n);          debug_pname(n);
# Line 241  Line 299 
299          debug_pcolor("color_bg", &conf.color_bg);          debug_pcolor("color_bg", &conf.color_bg);
300          debug_pbool("box_shadow", conf.box_shadow);          debug_pbool("box_shadow", conf.box_shadow);
301          debug_pbool("upside_down", conf.upside_down);          debug_pbool("upside_down", conf.upside_down);
302            debug_pbool("left_right", conf.left_right);
303          debug_pbool("strip_untagged", conf.strip_untagged);          debug_pbool("strip_untagged", conf.strip_untagged);
304          debug_pbool("strip_first_rev", conf.strip_first_rev);          debug_pbool("strip_first_rev", conf.strip_first_rev);
305          debug_pbool("auto_kern", conf.auto_kern);          debug_pbool("auto_stretch", conf.auto_stretch);
306            debug_pbool("anti_alias", conf.anti_alias);
307          debug_pfont("tag_font", conf.tag_font);          debug_pbool("use_ttf", conf.use_ttf);
308            debug_pint("thick_lines", conf.thick_lines);
309    
310            debug_pfont("tag_font", conf.tag_font.gdfont);
311            debug_pstring("tag_ttfont", conf.tag_font.ttfont);
312            debug_psouble("tag_ttsize", conf.tag_font.ttsize);
313          debug_pcolor("tag_color", &conf.tag_color);          debug_pcolor("tag_color", &conf.tag_color);
314    
315          debug_pfont("rev_font", conf.rev_font);          debug_pfont("rev_font", conf.rev_font.gdfont);
316            debug_pstring("rev_ttfont", conf.rev_font.ttfont);
317            debug_pdouble("rev_ttsize", conf.rev_font.ttsize);
318          debug_pcolor("rev_color", &conf.rev_color);          debug_pcolor("rev_color", &conf.rev_color);
319          debug_pcolor("rev_bgcolor", &conf.rev_bgcolor);          debug_pcolor("rev_bgcolor", &conf.rev_bgcolor);
320          debug_pint("rev_separator", conf.rev_separator);          debug_pint("rev_separator", conf.rev_separator);
# Line 260  Line 326 
326          debug_pint("rev_bspace", conf.rev_bspace);          debug_pint("rev_bspace", conf.rev_bspace);
327          debug_pstring("rev_text", conf.rev_text);          debug_pstring("rev_text", conf.rev_text);
328          debug_pcolor("rev_text_color", &conf.rev_text_color);          debug_pcolor("rev_text_color", &conf.rev_text_color);
329          debug_pfont("rev_text_font", conf.rev_text_font);          debug_pfont("rev_text_font", conf.rev_text_font.gdfont);
330            debug_pstring("rev_text_ttfont", conf.rev_text_font.ttfont);
331          debug_pfont("branch_font", conf.branch_font);          debug_pdouble("rev_text_ttsize", conf.rev_text_font.ttsize);
332    
333            debug_pfont("branch_font", conf.branch_font.gdfont);
334            debug_pstring("branch_ttfont", conf.branch_font.ttfont);
335            debug_pdouble("branch_ttsize", conf.branch_font.ttsize);
336          debug_pcolor("branch_color", &conf.branch_color);          debug_pcolor("branch_color", &conf.branch_color);
337            debug_pfont("branch_tag_font", conf.branch_tag_font.gdfont);
338            debug_pstring("branch_tag_ttfont", conf.branch_tag_font.ttfont);
339            debug_pdouble("branch_tag_ttsize", conf.branch_tag_font.ttsize);
340            debug_pcolor("branch_tag_color", &conf.branch_tag_color);
341          debug_pcolor("branch_bgcolor", &conf.branch_bgcolor);          debug_pcolor("branch_bgcolor", &conf.branch_bgcolor);
342          debug_pint("branch_lspace", conf.branch_lspace);          debug_pint("branch_lspace", conf.branch_lspace);
343          debug_pint("branch_rspace", conf.branch_rspace);          debug_pint("branch_rspace", conf.branch_rspace);
# Line 276  Line 350 
350          debug_pstring("title", conf.title);          debug_pstring("title", conf.title);
351          debug_pint("title_x", conf.title_x);          debug_pint("title_x", conf.title_x);
352          debug_pint("title_y", conf.title_y);          debug_pint("title_y", conf.title_y);
353          debug_pfont("title_font", conf.title_font);          debug_pfont("title_font", conf.title_font.gdfont);
354            debug_pstring("title_ttfont", conf.title_font.ttfont);
355            debug_pdouble("title_ttsize", conf.title_font.ttsize);
356          debug_pint("title_align", conf.title_align);          debug_pint("title_align", conf.title_align);
357          debug_pcolor("title_color", &conf.title_color);          debug_pcolor("title_color", &conf.title_color);
358    
# Line 468  Line 544 
544                                                  c[0] = get_input();                                                  c[0] = get_input();
545                                                  c[1] = get_input();                                                  c[1] = get_input();
546                                                  c[2] = '\0';                                                  c[2] = '\0';
547                                                  if(!isxdigit(c[0]) || !isxdigit(c[1]))                                                  if(!isxdigit((int)(unsigned char)c[0]) || !isxdigit((int)(unsigned char)c[1]))
548                                                          yyerror("Invalid hex escape");                                                          stack_msg(MSG_ERR, "config: %d: Invalid hex escape", line_number);
549                                                  add_str((int)strtol(c, NULL, 16));                                                  add_str((int)strtol(c, NULL, 16));
550                                                  break;                                                  break;
551                                          case '0':                                          case '0':
# Line 488  Line 564 
564                                                  add_str((int)strtol(c, NULL, 8));                                                  add_str((int)strtol(c, NULL, 8));
565                                                  break;                                                  break;
566                                          case EOF:                                          case EOF:
567                                                    yyerror("Unexpected EOF in escape");                                                  yyerror("Unexpected EOF in escape");
568                                                    break;                                                  break;
569                                          }                                          }
570                                          break;                                          break;
571                                  case '"':                                  case '"':
# Line 519  Line 595 
595                                  while(1)                                  while(1)
596                                  {                                  {
597                                          ch = get_input();                                          ch = get_input();
598                                          if(isalpha(ch) || ch == '_')                                          if(isalnum(ch) || ch == '_')
599                                                  add_str(ch);                                                  add_str(ch);
600                                          else                                          else
601                                          {                                          {
# Line 530  Line 606 
606                                  skw.keyword = get_str();                                  skw.keyword = get_str();
607                                  kw = bsearch(&skw, keywords, NKEYWORDS, sizeof(keywords[0]), cmp_kw);                                  kw = bsearch(&skw, keywords, NKEYWORDS, sizeof(keywords[0]), cmp_kw);
608                                  if(!kw)                                  if(!kw)
609                                          yyerror("Unknown keyword '%s'", skw.keyword);                                  {
610                                            stack_msg(MSG_ERR, "config: %d: Unknown keyword '%s'", line_number, skw.keyword);
611                                            yylval.kw = NULL;
612                                            return TYPE_KEYWORD;
613                                    }
614                                  xfree(skw.keyword);                                  xfree(skw.keyword);
615                                  if(kw->type == TYPE_VALUE)                                  if(kw->type == TYPE_VALUE)
616                                  {                                  {
617                                          yylval.i = kw->confref.val;                                          yylval.i = (int)kw->confref.val;
618                                          return TYPE_NUMBER;                                          return TYPE_NUMBER;
619                                  }                                  }
620                                  yylval.kw = kw;                                  yylval.kw = kw;
# Line 544  Line 624 
624                          {                          {
625                                  char *s;                                  char *s;
626                                  char *eptr;                                  char *eptr;
627                                    int type = TYPE_NUMBER;
628                                  /* Collect number */                                  /* Collect number */
629                                  reset_str();                                  reset_str();
630                                  add_str(ch);                                  add_str(ch);
631                                  while(1)                                  while(1)
632                                  {                                  {
633                                          ch = get_input();                                          ch = get_input();
634                                          if(isxdigit(ch) || ch == 'x' || ch == 'X') /* Not exact, but close enough */                                          if(isxdigit(ch) || ch == 'x' || ch == 'X' || ch == '.') /* Not exact, but close enough */
635                                                  add_str(ch);                                                  add_str(ch);
636                                          else                                          else
637                                          {                                          {
638                                                  unget_input(ch);                                                  unget_input(ch);
639                                                  break;                                                  break;
640                                          }                                          }
641                                            if(ch == '.')
642                                                    type = TYPE_DOUBLE;
643                                  }                                  }
644                                  s = get_str();                                  s = get_str();
645                                  yylval.i = strtol(s, &eptr, 0);                                  if(type == TYPE_DOUBLE)
646                                  if(*eptr)                                  {
647                                          yyerror("Invalid number");                                          yylval.d = strtod(s, &eptr);
648                                            if(*eptr)
649                                                    stack_msg(MSG_ERR, "config: %d: Invalid floating point number", line_number);
650                                    }
651                                    else
652                                    {
653                                            yylval.i = strtol(s, &eptr, 0);
654                                            if(*eptr)
655                                                    stack_msg(MSG_ERR, "config: %d: Invalid number", line_number);
656                                    }
657                                  xfree(s);                                  xfree(s);
658                                  return TYPE_NUMBER;                                  return type;
659                          }                          }
660                          else                          else
661                                  yyerror("Unmatched text '%c' (0x%02x)", isprint(ch) ? ch : ' ', ch);                                  yyerror("Unmatched text '%c' (0x%02x)", isprint(ch) ? ch : ' ', ch);
# Line 578  Line 670 
670          if(*s != '#' || strlen(s) != 7)          if(*s != '#' || strlen(s) != 7)
671          {          {
672  colorerror:  colorerror:
673                  yyerror("Invalid color value");                  stack_msg(MSG_ERR, "config: %d: Invalid color value '%s'", line_number, s);
674                    return;
675          }          }
676          c->b = strtol(s+5, &cptr, 16);          c->b = strtol(s+5, &cptr, 16);
677          if(*cptr)          if(*cptr)
# Line 636  Line 729 
729                  if(token == EOF)                  if(token == EOF)
730                  {                  {
731                          if(state)                          if(state)
732                                  yyerror("Unexpected EOF");                                  stack_msg(MSG_ERR, "config: %d: Unexpected EOF", line_number);
733                          break;                          break;
734                  }                  }
735    
# Line 649  Line 742 
742                                  state = 1;                                  state = 1;
743                          }                          }
744                          else if(token != ';')                          else if(token != ';')
745                                  yyerror("Keyword expected");                                  stack_msg(MSG_ERR, "config: %d: Keyword expected", line_number);
746                          break;                          break;
747                  case 1:                  case 1:
748                          if(token != '=')                          if(token != '=')
749                                  yyerror("'=' expected");                          {
750                          state = 2;                                  stack_msg(MSG_ERR, "config: %d: '=' expected", line_number);
751                                    while(1)
752                                    {
753                                            token = config_lex();
754                                            if(token == ';')
755                                            {
756                                                    state = 0;
757                                                    break;
758                                            }
759                                            else if(token == EOF)
760                                                    break;
761                                    }
762                            }
763                            else
764                                    state = 2;
765                          break;                          break;
766                  case 2:                  case 2:
767                            if(!kw)
768                            {
769                                    /* Error recovery of failed keyword */
770                                    state = 3;
771                                    break;
772                            }
773                          if(kw->type == TYPE_FONT || kw->type == TYPE_BOOLEAN)                          if(kw->type == TYPE_FONT || kw->type == TYPE_BOOLEAN)
774                                  t = TYPE_NUMBER;                                  t = TYPE_NUMBER;
775                          else if(kw->type == TYPE_COLOR)                          else if(kw->type == TYPE_COLOR)
776                                  t = TYPE_STRING;                                  t = TYPE_STRING;
777                          else                          else
778                                  t = kw->type;                                  t = kw->type;
779    
780                            if(token == TYPE_NUMBER && kw->type == TYPE_DOUBLE)
781                            {
782                                    /* Auto promote numbers to doubles if required */
783                                    yylval.d = (double)yylval.i;
784                                    token = TYPE_DOUBLE;
785                            }
786    
787                          if(token != t)                          if(token != t)
788                          {                          {
789                                  char *e;                                  char *e;
790                                  switch(kw->type)                                  switch(kw->type)
791                                  {                                  {
792                                  case TYPE_STRING:       e = "String"; break;                                  case TYPE_STRING:       e = "String"; yylval.str = xstrdup("error recovery"); break;
793                                  case TYPE_NUMBER:       e = "Number"; break;                                  case TYPE_NUMBER:       e = "Number"; yylval.i = 0; break;
794                                  case TYPE_COLOR:        e = "Color"; break;                                  case TYPE_COLOR:        e = "Color"; yylval.str = xstrdup("#123456"); break;
795                                  case TYPE_FONT:         e = "Font"; break;                                  case TYPE_FONT:         e = "Font"; yylval.i = 0; break;
796                                  case TYPE_BOOLEAN:      e = "Boolean"; break;                                  case TYPE_BOOLEAN:      e = "Boolean"; yylval.i = 0; break;
797                                  default:                e = "Internal error: Unknown type"; break;                                  case TYPE_DOUBLE:       e = "Double"; yylval.d = 0.0; break;
798                                    default:                e = "Internal error: Unknown type"; yylval.i = 0; break;
799                                  }                                  }
800                                  yyerror("%s expected", e);                                  stack_msg(MSG_ERR, "config: %d: %s expected", line_number, e);
801                          }                          }
802  #ifdef DEBUG  #ifdef DEBUG
803                          printf("processing: '%s'\n", kw->keyword);                          printf("processing: '%s'\n", kw->keyword);
# Line 690  Line 811 
811                                          *kw->confref.i = yylval.i;                                          *kw->confref.i = yylval.i;
812                                          break;                                          break;
813                                  case TYPE_BOOLEAN:                                  case TYPE_BOOLEAN:
814                                          *kw->confref.i = yylval.i != 0;                                          if(yylval.i == -1)
815                                                    *kw->confref.i = !*kw->confref.i;
816                                            else
817                                                    *kw->confref.i = yylval.i != 0;
818                                          break;                                          break;
819                                  case TYPE_COLOR:                                  case TYPE_COLOR:
820                                          set_color(kw->confref.c, yylval.str);                                          set_color(kw->confref.c, yylval.str);
821                                          break;                                          break;
822                                  case TYPE_FONT:                                  case TYPE_FONT:
823                                          *kw->confref.f = get_font(yylval.i);                                          kw->confref.f->gdfont = get_font(yylval.i);
824                                            break;
825                                    case TYPE_DOUBLE:
826                                            *kw->confref.d = yylval.d;
827                                          break;                                          break;
828                                  default:                                  default:
829                                          yyerror("Internal error: Unknown type passed %d", kw->type);                                          yyerror("Internal error: Unknown type passed %d", kw->type);
# Line 706  Line 833 
833                          break;                          break;
834                  case 3:                  case 3:
835                          if(token != ';')                          if(token != ';')
836                                  yyerror("';' expected");                                  stack_msg(MSG_ERR, "config: %d: ';' expected", line_number);
837                          state = 0;                          state = 0;
838                          break;                          break;
839                  default:                  default:

Legend:
Removed from v.1.1  
changed lines
  Added in v.1.17

  ViewVC Help
Powered by ViewVC 1.1.0 with CvsGraph 1.7.0