/[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.4, Tue Apr 23 23:02:54 2002 UTC revision 1.19, Wed Oct 20 22:03:36 2004 UTC
# Line 51  Line 51 
51                  char    **s;                  char    **s;
52                  color_t *c;                  color_t *c;
53                  double  *d;                  double  *d;
54                  int     val;    /* FIXME: Oops, sizeof(int) must be sizeof(void *) */                  INTTYPE val;
55          } confref;          } confref;
56  } keyword_t;  } keyword_t;
57    
# Line 96  Line 96 
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_resort",      TYPE_BOOLEAN,   { &conf.branch_resort } },
102            { "branch_subtree",     TYPE_STRING,    { &conf.branch_subtree } },
103          { "upside_down",        TYPE_BOOLEAN,   { &conf.upside_down } },          { "upside_down",        TYPE_BOOLEAN,   { &conf.upside_down } },
104            { "left_right",         TYPE_BOOLEAN,   { &conf.left_right } },
105          { "auto_stretch",       TYPE_BOOLEAN,   { &conf.auto_stretch } },          { "auto_stretch",       TYPE_BOOLEAN,   { &conf.auto_stretch } },
106          { "color_bg",           TYPE_COLOR,     { &conf.color_bg } },          { "color_bg",           TYPE_COLOR,     { &conf.color_bg } },
107          { "transparent_bg",     TYPE_BOOLEAN,   { &conf.transparent_bg } },          { "transparent_bg",     TYPE_BOOLEAN,   { &conf.transparent_bg } },
# Line 109  Line 114 
114          { "anti_alias",         TYPE_BOOLEAN,   { &conf.anti_alias } },          { "anti_alias",         TYPE_BOOLEAN,   { &conf.anti_alias } },
115          { "use_ttf",            TYPE_BOOLEAN,   { &conf.use_ttf } },          { "use_ttf",            TYPE_BOOLEAN,   { &conf.use_ttf } },
116          { "parse_logs",         TYPE_BOOLEAN,   { &conf.parse_logs } },          { "parse_logs",         TYPE_BOOLEAN,   { &conf.parse_logs } },
117            { "html_level",         TYPE_NUMBER,    { &conf.html_level } },
118          { "thick_lines",        TYPE_NUMBER,    { &conf.thick_lines } },          { "thick_lines",        TYPE_NUMBER,    { &conf.thick_lines } },
119            { "msg_color",          TYPE_COLOR,     { &conf.msg_color } },
120            { "msg_font",           TYPE_FONT,      { &conf.msg_font.gdfont } },
121            { "msg_ttfont",         TYPE_STRING,    { &conf.msg_font.ttfont } },
122            { "msg_ttsize",         TYPE_DOUBLE,    { &conf.msg_font.ttsize } },
123            { "rev_hidenumber",     TYPE_BOOLEAN,   { &conf.rev_hidenumber } },
124          { "rev_color",          TYPE_COLOR,     { &conf.rev_color } },          { "rev_color",          TYPE_COLOR,     { &conf.rev_color } },
125          { "rev_bgcolor",        TYPE_COLOR,     { &conf.rev_bgcolor } },          { "rev_bgcolor",        TYPE_COLOR,     { &conf.rev_bgcolor } },
126          { "rev_font",           TYPE_FONT,      { &conf.rev_font.gdfont } },          { "rev_font",           TYPE_FONT,      { &conf.rev_font.gdfont } },
# Line 127  Line 138 
138          { "rev_text_font",      TYPE_FONT,      { &conf.rev_text_font.gdfont } },          { "rev_text_font",      TYPE_FONT,      { &conf.rev_text_font.gdfont } },
139          { "rev_text_ttfont",    TYPE_STRING,    { &conf.rev_text_font.ttfont } },          { "rev_text_ttfont",    TYPE_STRING,    { &conf.rev_text_font.ttfont } },
140          { "rev_text_ttsize",    TYPE_DOUBLE,    { &conf.rev_text_font.ttsize } },          { "rev_text_ttsize",    TYPE_DOUBLE,    { &conf.rev_text_font.ttsize } },
141            { "rev_maxtags",        TYPE_NUMBER,    { &conf.rev_maxtags } },
142            { "merge_color",        TYPE_COLOR,     { &conf.merge_color } },
143            { "merge_from",         TYPE_STRING,    { &conf.merge_from } },
144            { "merge_to",           TYPE_STRING,    { &conf.merge_to } },
145            { "merge_findall",      TYPE_BOOLEAN,   { &conf.merge_findall } },
146            { "merge_front",        TYPE_BOOLEAN,   { &conf.merge_front } },
147            { "merge_nocase",       TYPE_BOOLEAN,   { &conf.merge_nocase } },
148            { "merge_arrows",       TYPE_BOOLEAN,   { &conf.merge_arrows } },
149            { "merge_cvsnt",        TYPE_BOOLEAN,   { &conf.merge_cvsnt } },
150            { "merge_cvsnt_color",  TYPE_COLOR,     { &conf.merge_cvsnt_color } },
151            { "arrow_width",        TYPE_NUMBER,    { &conf.arrow_width } },
152            { "arrow_length",       TYPE_NUMBER,    { &conf.arrow_length } },
153          { "tag_color",          TYPE_COLOR,     { &conf.tag_color } },          { "tag_color",          TYPE_COLOR,     { &conf.tag_color } },
154          { "tag_font",           TYPE_FONT,      { &conf.tag_font.gdfont } },          { "tag_font",           TYPE_FONT,      { &conf.tag_font.gdfont } },
155          { "tag_ttfont",         TYPE_STRING,    { &conf.tag_font.ttfont } },          { "tag_ttfont",         TYPE_STRING,    { &conf.tag_font.ttfont } },
156          { "tag_ttsize",         TYPE_DOUBLE,    { &conf.tag_font.ttsize } },          { "tag_ttsize",         TYPE_DOUBLE,    { &conf.tag_font.ttsize } },
157            { "tag_ignore",         TYPE_STRING,    { &conf.tag_ignore } },
158            { "tag_ignore_merge",   TYPE_BOOLEAN,   { &conf.tag_ignore_merge } },
159            { "tag_nocase",         TYPE_BOOLEAN,   { &conf.tag_nocase } },
160            { "tag_negate",         TYPE_BOOLEAN,   { &conf.tag_negate } },
161          { "title",              TYPE_STRING,    { &conf.title } },          { "title",              TYPE_STRING,    { &conf.title } },
162          { "title_x",            TYPE_NUMBER,    { &conf.title_x } },          { "title_x",            TYPE_NUMBER,    { &conf.title_x } },
163          { "title_y",            TYPE_NUMBER,    { &conf.title_y } },          { "title_y",            TYPE_NUMBER,    { &conf.title_y } },
# Line 152  Line 179 
179          { "map_rev_alt",        TYPE_STRING,    { &conf.map_rev_alt } },          { "map_rev_alt",        TYPE_STRING,    { &conf.map_rev_alt } },
180          { "map_diff_href",      TYPE_STRING,    { &conf.map_diff_href } },          { "map_diff_href",      TYPE_STRING,    { &conf.map_diff_href } },
181          { "map_diff_alt",       TYPE_STRING,    { &conf.map_diff_alt } },          { "map_diff_alt",       TYPE_STRING,    { &conf.map_diff_alt } },
182            { "map_merge_href",     TYPE_STRING,    { &conf.map_merge_href } },
183            { "map_merge_alt",      TYPE_STRING,    { &conf.map_merge_alt } },
184          { "jpeg",               TYPE_VALUE,     { (void *)IMAGE_JPEG } },          { "jpeg",               TYPE_VALUE,     { (void *)IMAGE_JPEG } },
185          { "png",                TYPE_VALUE,     { (void *)IMAGE_PNG } },          { "png",                TYPE_VALUE,     { (void *)IMAGE_PNG } },
186          { "gif",                TYPE_VALUE,     { (void *)IMAGE_GIF } },          { "gif",                TYPE_VALUE,     { (void *)IMAGE_GIF } },
# Line 166  Line 195 
195          { "medium",             TYPE_VALUE,     { (void *)2 } },          { "medium",             TYPE_VALUE,     { (void *)2 } },
196          { "large",              TYPE_VALUE,     { (void *)3 } },          { "large",              TYPE_VALUE,     { (void *)3 } },
197          { "giant",              TYPE_VALUE,     { (void *)4 } },          { "giant",              TYPE_VALUE,     { (void *)4 } },
198            { "HTML3",              TYPE_VALUE,     { (void *)1 } },
199            { "HTML4",              TYPE_VALUE,     { (void *)2 } },
200            { "XHTML",              TYPE_VALUE,     { (void *)3 } },
201  };  };
202    
203  #define NKEYWORDS       (sizeof(keywords) / sizeof(keywords[0]))  #define NKEYWORDS       (sizeof(keywords) / sizeof(keywords[0]))
# Line 270  Line 302 
302          debug_pcolor("color_bg", &conf.color_bg);          debug_pcolor("color_bg", &conf.color_bg);
303          debug_pbool("box_shadow", conf.box_shadow);          debug_pbool("box_shadow", conf.box_shadow);
304          debug_pbool("upside_down", conf.upside_down);          debug_pbool("upside_down", conf.upside_down);
305            debug_pbool("left_right", conf.left_right);
306          debug_pbool("strip_untagged", conf.strip_untagged);          debug_pbool("strip_untagged", conf.strip_untagged);
307          debug_pbool("strip_first_rev", conf.strip_first_rev);          debug_pbool("strip_first_rev", conf.strip_first_rev);
308          debug_pbool("auto_stretch", conf.auto_stretch);          debug_pbool("auto_stretch", conf.auto_stretch);
# Line 514  Line 547 
547                                                  c[0] = get_input();                                                  c[0] = get_input();
548                                                  c[1] = get_input();                                                  c[1] = get_input();
549                                                  c[2] = '\0';                                                  c[2] = '\0';
550                                                  if(!isxdigit(c[0]) || !isxdigit(c[1]))                                                  if(!isxdigit((int)(unsigned char)c[0]) || !isxdigit((int)(unsigned char)c[1]))
551                                                          yyerror("Invalid hex escape");                                                          stack_msg(MSG_ERR, "config: %d: Invalid hex escape", line_number);
552                                                  add_str((int)strtol(c, NULL, 16));                                                  add_str((int)strtol(c, NULL, 16));
553                                                  break;                                                  break;
554                                          case '0':                                          case '0':
# Line 534  Line 567 
567                                                  add_str((int)strtol(c, NULL, 8));                                                  add_str((int)strtol(c, NULL, 8));
568                                                  break;                                                  break;
569                                          case EOF:                                          case EOF:
570                                                    yyerror("Unexpected EOF in escape");                                                  yyerror("Unexpected EOF in escape");
571                                                    break;                                                  break;
572                                          }                                          }
573                                          break;                                          break;
574                                  case '"':                                  case '"':
# Line 565  Line 598 
598                                  while(1)                                  while(1)
599                                  {                                  {
600                                          ch = get_input();                                          ch = get_input();
601                                          if(isalpha(ch) || ch == '_')                                          if(isalnum(ch) || ch == '_')
602                                                  add_str(ch);                                                  add_str(ch);
603                                          else                                          else
604                                          {                                          {
# Line 576  Line 609 
609                                  skw.keyword = get_str();                                  skw.keyword = get_str();
610                                  kw = bsearch(&skw, keywords, NKEYWORDS, sizeof(keywords[0]), cmp_kw);                                  kw = bsearch(&skw, keywords, NKEYWORDS, sizeof(keywords[0]), cmp_kw);
611                                  if(!kw)                                  if(!kw)
612                                          yyerror("Unknown keyword '%s'", skw.keyword);                                  {
613                                            stack_msg(MSG_ERR, "config: %d: Unknown keyword '%s'", line_number, skw.keyword);
614                                            yylval.kw = NULL;
615                                            return TYPE_KEYWORD;
616                                    }
617                                  xfree(skw.keyword);                                  xfree(skw.keyword);
618                                  if(kw->type == TYPE_VALUE)                                  if(kw->type == TYPE_VALUE)
619                                  {                                  {
620                                          yylval.i = kw->confref.val;                                          yylval.i = (int)kw->confref.val;
621                                          return TYPE_NUMBER;                                          return TYPE_NUMBER;
622                                  }                                  }
623                                  yylval.kw = kw;                                  yylval.kw = kw;
# Line 612  Line 649 
649                                  {                                  {
650                                          yylval.d = strtod(s, &eptr);                                          yylval.d = strtod(s, &eptr);
651                                          if(*eptr)                                          if(*eptr)
652                                                  yyerror("Invalid floating point number");                                                  stack_msg(MSG_ERR, "config: %d: Invalid floating point number", line_number);
653                                  }                                  }
654                                  else                                  else
655                                  {                                  {
656                                          yylval.i = strtol(s, &eptr, 0);                                          yylval.i = strtol(s, &eptr, 0);
657                                          if(*eptr)                                          if(*eptr)
658                                                  yyerror("Invalid number");                                                  stack_msg(MSG_ERR, "config: %d: Invalid number", line_number);
659                                  }                                  }
660                                  xfree(s);                                  xfree(s);
661                                  return type;                                  return type;
# Line 636  Line 673 
673          if(*s != '#' || strlen(s) != 7)          if(*s != '#' || strlen(s) != 7)
674          {          {
675  colorerror:  colorerror:
676                  yyerror("Invalid color value");                  stack_msg(MSG_ERR, "config: %d: Invalid color value '%s'", line_number, s);
677                    return;
678          }          }
679          c->b = strtol(s+5, &cptr, 16);          c->b = strtol(s+5, &cptr, 16);
680          if(*cptr)          if(*cptr)
# Line 694  Line 732 
732                  if(token == EOF)                  if(token == EOF)
733                  {                  {
734                          if(state)                          if(state)
735                                  yyerror("Unexpected EOF");                                  stack_msg(MSG_ERR, "config: %d: Unexpected EOF", line_number);
736                          break;                          break;
737                  }                  }
738    
# Line 707  Line 745 
745                                  state = 1;                                  state = 1;
746                          }                          }
747                          else if(token != ';')                          else if(token != ';')
748                                  yyerror("Keyword expected");                                  stack_msg(MSG_ERR, "config: %d: Keyword expected", line_number);
749                          break;                          break;
750                  case 1:                  case 1:
751                          if(token != '=')                          if(token != '=')
752                                  yyerror("'=' expected");                          {
753                          state = 2;                                  stack_msg(MSG_ERR, "config: %d: '=' expected", line_number);
754                                    while(1)
755                                    {
756                                            token = config_lex();
757                                            if(token == ';')
758                                            {
759                                                    state = 0;
760                                                    break;
761                                            }
762                                            else if(token == EOF)
763                                                    break;
764                                    }
765                            }
766                            else
767                                    state = 2;
768                          break;                          break;
769                  case 2:                  case 2:
770                            if(!kw)
771                            {
772                                    /* Error recovery of failed keyword */
773                                    state = 3;
774                                    break;
775                            }
776                          if(kw->type == TYPE_FONT || kw->type == TYPE_BOOLEAN)                          if(kw->type == TYPE_FONT || kw->type == TYPE_BOOLEAN)
777                                  t = TYPE_NUMBER;                                  t = TYPE_NUMBER;
778                          else if(kw->type == TYPE_COLOR)                          else if(kw->type == TYPE_COLOR)
# Line 734  Line 792 
792                                  char *e;                                  char *e;
793                                  switch(kw->type)                                  switch(kw->type)
794                                  {                                  {
795                                  case TYPE_STRING:       e = "String"; break;                                  case TYPE_STRING:       e = "String"; yylval.str = xstrdup("error recovery"); break;
796                                  case TYPE_NUMBER:       e = "Number"; break;                                  case TYPE_NUMBER:       e = "Number"; yylval.i = 0; break;
797                                  case TYPE_COLOR:        e = "Color"; break;                                  case TYPE_COLOR:        e = "Color"; yylval.str = xstrdup("#123456"); break;
798                                  case TYPE_FONT:         e = "Font"; break;                                  case TYPE_FONT:         e = "Font"; yylval.i = 0; break;
799                                  case TYPE_BOOLEAN:      e = "Boolean"; break;                                  case TYPE_BOOLEAN:      e = "Boolean"; yylval.i = 0; break;
800                                  case TYPE_DOUBLE:       e = "Double"; break;                                  case TYPE_DOUBLE:       e = "Double"; yylval.d = 0.0; break;
801                                  default:                e = "Internal error: Unknown type"; break;                                  default:                e = "Internal error: Unknown type"; yylval.i = 0; break;
802                                  }                                  }
803                                  yyerror("%s expected", e);                                  stack_msg(MSG_ERR, "config: %d: %s expected", line_number, e);
804                          }                          }
805  #ifdef DEBUG  #ifdef DEBUG
806                          printf("processing: '%s'\n", kw->keyword);                          printf("processing: '%s'\n", kw->keyword);
# Line 778  Line 836 
836                          break;                          break;
837                  case 3:                  case 3:
838                          if(token != ';')                          if(token != ';')
839                                  yyerror("';' expected");                                  stack_msg(MSG_ERR, "config: %d: ';' expected", line_number);
840                          state = 0;                          state = 0;
841                          break;                          break;
842                  default:                  default:

Legend:
Removed from v.1.4  
changed lines
  Added in v.1.19

  ViewVC Help
Powered by ViewVC 1.1.0 with CvsGraph 1.7.0