]> granicus.if.org Git - sudo/commitdiff
Use warningx in yyerror() so the conversation function gets used
authorTodd C. Miller <Todd.Miller@courtesan.com>
Mon, 15 Mar 2010 14:44:06 +0000 (10:44 -0400)
committerTodd C. Miller <Todd.Miller@courtesan.com>
Mon, 15 Mar 2010 14:44:06 +0000 (10:44 -0400)
when built as part of sudoers.

plugins/sudoers/gram.c
plugins/sudoers/gram.y

index a52015dd0bf4237dc2aeaa19036881a4540eb3db..6aecb8b477b7f18743f6a2d1c0a1c80643f1a7c2 100644 (file)
@@ -110,17 +110,16 @@ yyerror(s)
        errorfile = estrdup(sudoers);
     }
     if (verbose && s != NULL) {
-       /* XXX - conversation function when called via plugin */
 #ifndef TRACELEXER
-       (void) fprintf(stderr, ">>> %s: %s near line %d <<<\n", sudoers, s,
+       warningx(">>> %s: %s near line %d <<<", sudoers, s,
            sudolineno ? sudolineno - 1 : 0);
 #else
-       (void) fprintf(stderr, "<*> ");
+       fputs("<*> ", stderr);
 #endif
     }
     parse_error = TRUE;
 }
-#line 114 "./gram.y"
+#line 113 "./gram.y"
 #ifndef YYSTYPE_DEFINED
 #define YYSTYPE_DEFINED
 typedef union {
@@ -136,7 +135,7 @@ typedef union {
     int tok;
 } YYSTYPE;
 #endif /* YYSTYPE_DEFINED */
-#line 140 "y.tab.c"
+#line 139 "y.tab.c"
 #define COMMAND 257
 #define ALIAS 258
 #define DEFVAR 259
@@ -618,7 +617,7 @@ short *yyss;
 short *yysslim;
 YYSTYPE *yyvs;
 int yystacksize;
-#line 597 "./gram.y"
+#line 596 "./gram.y"
 static struct defaults *
 new_default(var, val, op)
     char *var;
@@ -809,7 +808,7 @@ init_parser(path, quiet)
     sudolineno = 1;
     verbose = !quiet;
 }
-#line 761 "y.tab.c"
+#line 760 "y.tab.c"
 /* allocate initial stack or double stack size, up to YYMAXDEPTH */
 #if defined(__cplusplus) || defined(__STDC__)
 static int yygrowstack(void)
@@ -1015,127 +1014,127 @@ yyreduce:
     switch (yyn)
     {
 case 1:
-#line 187 "./gram.y"
+#line 186 "./gram.y"
 { ; }
 break;
 case 5:
-#line 195 "./gram.y"
+#line 194 "./gram.y"
 {
                            ;
                        }
 break;
 case 6:
-#line 198 "./gram.y"
+#line 197 "./gram.y"
 {
                            yyerrok;
                        }
 break;
 case 7:
-#line 201 "./gram.y"
+#line 200 "./gram.y"
 {
                            add_userspec(yyvsp[-1].member, yyvsp[0].privilege);
                        }
 break;
 case 8:
-#line 204 "./gram.y"
+#line 203 "./gram.y"
 {
                            ;
                        }
 break;
 case 9:
-#line 207 "./gram.y"
+#line 206 "./gram.y"
 {
                            ;
                        }
 break;
 case 10:
-#line 210 "./gram.y"
+#line 209 "./gram.y"
 {
                            ;
                        }
 break;
 case 11:
-#line 213 "./gram.y"
+#line 212 "./gram.y"
 {
                            ;
                        }
 break;
 case 12:
-#line 216 "./gram.y"
+#line 215 "./gram.y"
 {
                            add_defaults(DEFAULTS, NULL, yyvsp[0].defaults);
                        }
 break;
 case 13:
-#line 219 "./gram.y"
+#line 218 "./gram.y"
 {
                            add_defaults(DEFAULTS_USER, yyvsp[-1].member, yyvsp[0].defaults);
                        }
 break;
 case 14:
-#line 222 "./gram.y"
+#line 221 "./gram.y"
 {
                            add_defaults(DEFAULTS_RUNAS, yyvsp[-1].member, yyvsp[0].defaults);
                        }
 break;
 case 15:
-#line 225 "./gram.y"
+#line 224 "./gram.y"
 {
                            add_defaults(DEFAULTS_HOST, yyvsp[-1].member, yyvsp[0].defaults);
                        }
 break;
 case 16:
-#line 228 "./gram.y"
+#line 227 "./gram.y"
 {
                            add_defaults(DEFAULTS_CMND, yyvsp[-1].member, yyvsp[0].defaults);
                        }
 break;
 case 18:
-#line 234 "./gram.y"
+#line 233 "./gram.y"
 {
                            list_append(yyvsp[-2].defaults, yyvsp[0].defaults);
                            yyval.defaults = yyvsp[-2].defaults;
                        }
 break;
 case 19:
-#line 240 "./gram.y"
+#line 239 "./gram.y"
 {
                            yyval.defaults = new_default(yyvsp[0].string, NULL, TRUE);
                        }
 break;
 case 20:
-#line 243 "./gram.y"
+#line 242 "./gram.y"
 {
                            yyval.defaults = new_default(yyvsp[0].string, NULL, FALSE);
                        }
 break;
 case 21:
-#line 246 "./gram.y"
+#line 245 "./gram.y"
 {
                            yyval.defaults = new_default(yyvsp[-2].string, yyvsp[0].string, TRUE);
                        }
 break;
 case 22:
-#line 249 "./gram.y"
+#line 248 "./gram.y"
 {
                            yyval.defaults = new_default(yyvsp[-2].string, yyvsp[0].string, '+');
                        }
 break;
 case 23:
-#line 252 "./gram.y"
+#line 251 "./gram.y"
 {
                            yyval.defaults = new_default(yyvsp[-2].string, yyvsp[0].string, '-');
                        }
 break;
 case 25:
-#line 258 "./gram.y"
+#line 257 "./gram.y"
 {
                            list_append(yyvsp[-2].privilege, yyvsp[0].privilege);
                            yyval.privilege = yyvsp[-2].privilege;
                        }
 break;
 case 26:
-#line 264 "./gram.y"
+#line 263 "./gram.y"
 {
                            struct privilege *p = emalloc(sizeof(*p));
                            list2tq(&p->hostlist, yyvsp[-2].member);
@@ -1146,51 +1145,51 @@ case 26:
                        }
 break;
 case 27:
-#line 274 "./gram.y"
+#line 273 "./gram.y"
 {
                            yyval.member = yyvsp[0].member;
                            yyval.member->negated = FALSE;
                        }
 break;
 case 28:
-#line 278 "./gram.y"
+#line 277 "./gram.y"
 {
                            yyval.member = yyvsp[0].member;
                            yyval.member->negated = TRUE;
                        }
 break;
 case 29:
-#line 284 "./gram.y"
+#line 283 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, ALIAS);
                        }
 break;
 case 30:
-#line 287 "./gram.y"
+#line 286 "./gram.y"
 {
                            yyval.member = new_member(NULL, ALL);
                        }
 break;
 case 31:
-#line 290 "./gram.y"
+#line 289 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, NETGROUP);
                        }
 break;
 case 32:
-#line 293 "./gram.y"
+#line 292 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, NTWKADDR);
                        }
 break;
 case 33:
-#line 296 "./gram.y"
+#line 295 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, WORD);
                        }
 break;
 case 35:
-#line 302 "./gram.y"
+#line 301 "./gram.y"
 {
                            list_append(yyvsp[-2].cmndspec, yyvsp[0].cmndspec);
 #ifdef HAVE_SELINUX
@@ -1221,7 +1220,7 @@ case 35:
                        }
 break;
 case 36:
-#line 332 "./gram.y"
+#line 331 "./gram.y"
 {
                            struct cmndspec *cs = emalloc(sizeof(*cs));
                            if (yyvsp[-3].runas != NULL) {
@@ -1248,80 +1247,80 @@ case 36:
                        }
 break;
 case 37:
-#line 358 "./gram.y"
+#line 357 "./gram.y"
 {
                            yyval.member = yyvsp[0].member;
                            yyval.member->negated = FALSE;
                        }
 break;
 case 38:
-#line 362 "./gram.y"
+#line 361 "./gram.y"
 {
                            yyval.member = yyvsp[0].member;
                            yyval.member->negated = TRUE;
                        }
 break;
 case 39:
-#line 368 "./gram.y"
+#line 367 "./gram.y"
 {
                            yyval.string = yyvsp[0].string;
                        }
 break;
 case 40:
-#line 373 "./gram.y"
+#line 372 "./gram.y"
 {
                            yyval.string = yyvsp[0].string;
                        }
 break;
 case 41:
-#line 378 "./gram.y"
+#line 377 "./gram.y"
 {
                            yyval.seinfo.role = NULL;
                            yyval.seinfo.type = NULL;
                        }
 break;
 case 42:
-#line 382 "./gram.y"
+#line 381 "./gram.y"
 {
                            yyval.seinfo.role = yyvsp[0].string;
                            yyval.seinfo.type = NULL;
                        }
 break;
 case 43:
-#line 386 "./gram.y"
+#line 385 "./gram.y"
 {
                            yyval.seinfo.type = yyvsp[0].string;
                            yyval.seinfo.role = NULL;
                        }
 break;
 case 44:
-#line 390 "./gram.y"
+#line 389 "./gram.y"
 {
                            yyval.seinfo.role = yyvsp[-1].string;
                            yyval.seinfo.type = yyvsp[0].string;
                        }
 break;
 case 45:
-#line 394 "./gram.y"
+#line 393 "./gram.y"
 {
                            yyval.seinfo.type = yyvsp[-1].string;
                            yyval.seinfo.role = yyvsp[0].string;
                        }
 break;
 case 46:
-#line 400 "./gram.y"
+#line 399 "./gram.y"
 {
                            yyval.runas = NULL;
                        }
 break;
 case 47:
-#line 403 "./gram.y"
+#line 402 "./gram.y"
 {
                            yyval.runas = yyvsp[-1].runas;
                        }
 break;
 case 48:
-#line 408 "./gram.y"
+#line 407 "./gram.y"
 {
                            yyval.runas = emalloc(sizeof(struct runascontainer));
                            yyval.runas->runasusers = yyvsp[0].member;
@@ -1329,7 +1328,7 @@ case 48:
                        }
 break;
 case 49:
-#line 413 "./gram.y"
+#line 412 "./gram.y"
 {
                            yyval.runas = emalloc(sizeof(struct runascontainer));
                            yyval.runas->runasusers = yyvsp[-2].member;
@@ -1337,7 +1336,7 @@ case 49:
                        }
 break;
 case 50:
-#line 418 "./gram.y"
+#line 417 "./gram.y"
 {
                            yyval.runas = emalloc(sizeof(struct runascontainer));
                            yyval.runas->runasusers = NULL;
@@ -1345,73 +1344,73 @@ case 50:
                        }
 break;
 case 51:
-#line 425 "./gram.y"
+#line 424 "./gram.y"
 {
                            yyval.tag.nopasswd = yyval.tag.noexec = yyval.tag.setenv = yyval.tag.transcript = UNSPEC;
                        }
 break;
 case 52:
-#line 428 "./gram.y"
+#line 427 "./gram.y"
 {
                            yyval.tag.nopasswd = TRUE;
                        }
 break;
 case 53:
-#line 431 "./gram.y"
+#line 430 "./gram.y"
 {
                            yyval.tag.nopasswd = FALSE;
                        }
 break;
 case 54:
-#line 434 "./gram.y"
+#line 433 "./gram.y"
 {
                            yyval.tag.noexec = TRUE;
                        }
 break;
 case 55:
-#line 437 "./gram.y"
+#line 436 "./gram.y"
 {
                            yyval.tag.noexec = FALSE;
                        }
 break;
 case 56:
-#line 440 "./gram.y"
+#line 439 "./gram.y"
 {
                            yyval.tag.setenv = TRUE;
                        }
 break;
 case 57:
-#line 443 "./gram.y"
+#line 442 "./gram.y"
 {
                            yyval.tag.setenv = FALSE;
                        }
 break;
 case 58:
-#line 446 "./gram.y"
+#line 445 "./gram.y"
 {
                            yyval.tag.transcript = TRUE;
                        }
 break;
 case 59:
-#line 449 "./gram.y"
+#line 448 "./gram.y"
 {
                            yyval.tag.transcript = FALSE;
                        }
 break;
 case 60:
-#line 454 "./gram.y"
+#line 453 "./gram.y"
 {
                            yyval.member = new_member(NULL, ALL);
                        }
 break;
 case 61:
-#line 457 "./gram.y"
+#line 456 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, ALIAS);
                        }
 break;
 case 62:
-#line 460 "./gram.y"
+#line 459 "./gram.y"
 {
                            struct sudo_command *c = emalloc(sizeof(*c));
                            c->cmnd = yyvsp[0].command.cmnd;
@@ -1420,7 +1419,7 @@ case 62:
                        }
 break;
 case 65:
-#line 472 "./gram.y"
+#line 471 "./gram.y"
 {
                            char *s;
                            if ((s = alias_add(yyvsp[-2].string, HOSTALIAS, yyvsp[0].member)) != NULL) {
@@ -1430,14 +1429,14 @@ case 65:
                        }
 break;
 case 67:
-#line 482 "./gram.y"
+#line 481 "./gram.y"
 {
                            list_append(yyvsp[-2].member, yyvsp[0].member);
                            yyval.member = yyvsp[-2].member;
                        }
 break;
 case 70:
-#line 492 "./gram.y"
+#line 491 "./gram.y"
 {
                            char *s;
                            if ((s = alias_add(yyvsp[-2].string, CMNDALIAS, yyvsp[0].member)) != NULL) {
@@ -1447,14 +1446,14 @@ case 70:
                        }
 break;
 case 72:
-#line 502 "./gram.y"
+#line 501 "./gram.y"
 {
                            list_append(yyvsp[-2].member, yyvsp[0].member);
                            yyval.member = yyvsp[-2].member;
                        }
 break;
 case 75:
-#line 512 "./gram.y"
+#line 511 "./gram.y"
 {
                            char *s;
                            if ((s = alias_add(yyvsp[-2].string, RUNASALIAS, yyvsp[0].member)) != NULL) {
@@ -1464,7 +1463,7 @@ case 75:
                        }
 break;
 case 78:
-#line 525 "./gram.y"
+#line 524 "./gram.y"
 {
                            char *s;
                            if ((s = alias_add(yyvsp[-2].string, USERALIAS, yyvsp[0].member)) != NULL) {
@@ -1474,96 +1473,96 @@ case 78:
                        }
 break;
 case 80:
-#line 535 "./gram.y"
+#line 534 "./gram.y"
 {
                            list_append(yyvsp[-2].member, yyvsp[0].member);
                            yyval.member = yyvsp[-2].member;
                        }
 break;
 case 81:
-#line 541 "./gram.y"
+#line 540 "./gram.y"
 {
                            yyval.member = yyvsp[0].member;
                            yyval.member->negated = FALSE;
                        }
 break;
 case 82:
-#line 545 "./gram.y"
+#line 544 "./gram.y"
 {
                            yyval.member = yyvsp[0].member;
                            yyval.member->negated = TRUE;
                        }
 break;
 case 83:
-#line 551 "./gram.y"
+#line 550 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, ALIAS);
                        }
 break;
 case 84:
-#line 554 "./gram.y"
+#line 553 "./gram.y"
 {
                            yyval.member = new_member(NULL, ALL);
                        }
 break;
 case 85:
-#line 557 "./gram.y"
+#line 556 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, NETGROUP);
                        }
 break;
 case 86:
-#line 560 "./gram.y"
+#line 559 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, USERGROUP);
                        }
 break;
 case 87:
-#line 563 "./gram.y"
+#line 562 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, WORD);
                        }
 break;
 case 89:
-#line 569 "./gram.y"
+#line 568 "./gram.y"
 {
                            list_append(yyvsp[-2].member, yyvsp[0].member);
                            yyval.member = yyvsp[-2].member;
                        }
 break;
 case 90:
-#line 575 "./gram.y"
+#line 574 "./gram.y"
 {
                            yyval.member = yyvsp[0].member;
                            yyval.member->negated = FALSE;
                        }
 break;
 case 91:
-#line 579 "./gram.y"
+#line 578 "./gram.y"
 {
                            yyval.member = yyvsp[0].member;
                            yyval.member->negated = TRUE;
                        }
 break;
 case 92:
-#line 585 "./gram.y"
+#line 584 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, ALIAS);
                        }
 break;
 case 93:
-#line 588 "./gram.y"
+#line 587 "./gram.y"
 {
                            yyval.member = new_member(NULL, ALL);
                        }
 break;
 case 94:
-#line 591 "./gram.y"
+#line 590 "./gram.y"
 {
                            yyval.member = new_member(yyvsp[0].string, WORD);
                        }
 break;
-#line 1515 "y.tab.c"
+#line 1514 "y.tab.c"
     }
     yyssp -= yym;
     yystate = *yyssp;
index 25e1a72f0e0ca893ca8bc0561ecc231643556439..e55acc610a1a005681445186da0b938ce54e17cd 100644 (file)
@@ -99,12 +99,11 @@ yyerror(s)
        errorfile = estrdup(sudoers);
     }
     if (verbose && s != NULL) {
-       /* XXX - conversation function when called via plugin */
 #ifndef TRACELEXER
-       (void) fprintf(stderr, ">>> %s: %s near line %d <<<\n", sudoers, s,
+       warningx(">>> %s: %s near line %d <<<", sudoers, s,
            sudolineno ? sudolineno - 1 : 0);
 #else
-       (void) fprintf(stderr, "<*> ");
+       fputs("<*> ", stderr);
 #endif
     }
     parse_error = TRUE;