conf.c 15.6 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5
/*
 * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
 * Released under the terms of the GNU GPL v2.0.
 */

E
EGRY Gabor 已提交
6
#include <locale.h>
L
Linus Torvalds 已提交
7
#include <ctype.h>
8
#include <stdio.h>
9
#include <stdlib.h>
L
Linus Torvalds 已提交
10 11
#include <string.h>
#include <time.h>
12
#include <unistd.h>
S
Sam Ravnborg 已提交
13
#include <getopt.h>
L
Linus Torvalds 已提交
14
#include <sys/stat.h>
15
#include <sys/time.h>
16
#include <errno.h>
L
Linus Torvalds 已提交
17 18 19 20 21

#include "lkc.h"

static void conf(struct menu *menu);
static void check_conf(struct menu *menu);
22
static void xfgets(char *str, int size, FILE *in);
L
Linus Torvalds 已提交
23

S
Sam Ravnborg 已提交
24 25 26 27 28 29 30
enum input_mode {
	oldaskconfig,
	silentoldconfig,
	oldconfig,
	allnoconfig,
	allyesconfig,
	allmodconfig,
S
Sam Ravnborg 已提交
31
	alldefconfig,
S
Sam Ravnborg 已提交
32 33
	randconfig,
	defconfig,
S
Sam Ravnborg 已提交
34
	savedefconfig,
35
	listnewconfig,
36
	olddefconfig,
S
Sam Ravnborg 已提交
37 38
} input_mode = oldaskconfig;

L
Linus Torvalds 已提交
39
static int indent = 1;
40
static int tty_stdio;
L
Linus Torvalds 已提交
41
static int valid_stdin = 1;
42
static int sync_kconfig;
L
Linus Torvalds 已提交
43
static int conf_cnt;
J
J.A. Magallon 已提交
44
static char line[128];
L
Linus Torvalds 已提交
45 46
static struct menu *rootEntry;

47
static void print_help(struct menu *menu)
48
{
49 50 51 52 53 54
	struct gstr help = str_new();

	menu_get_ext_help(menu, &help);

	printf("\n%s\n", str_get(&help));
	str_free(&help);
55 56
}

J
J.A. Magallon 已提交
57
static void strip(char *str)
L
Linus Torvalds 已提交
58
{
J
J.A. Magallon 已提交
59
	char *p = str;
L
Linus Torvalds 已提交
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
	int l;

	while ((isspace(*p)))
		p++;
	l = strlen(p);
	if (p != str)
		memmove(str, p, l + 1);
	if (!l)
		return;
	p = str + l - 1;
	while ((isspace(*p)))
		*p-- = 0;
}

static void check_stdin(void)
{
76
	if (!valid_stdin) {
77 78 79
		printf(_("aborted!\n\n"));
		printf(_("Console input/output is redirected. "));
		printf(_("Run 'make oldconfig' to update configuration.\n\n"));
L
Linus Torvalds 已提交
80 81 82 83
		exit(1);
	}
}

84
static int conf_askvalue(struct symbol *sym, const char *def)
L
Linus Torvalds 已提交
85 86 87 88
{
	enum symbol_type type = sym_get_type(sym);

	if (!sym_has_value(sym))
E
EGRY Gabor 已提交
89
		printf(_("(NEW) "));
L
Linus Torvalds 已提交
90 91 92 93 94 95 96 97

	line[0] = '\n';
	line[1] = 0;

	if (!sym_is_changable(sym)) {
		printf("%s\n", def);
		line[0] = '\n';
		line[1] = 0;
98
		return 0;
L
Linus Torvalds 已提交
99 100 101
	}

	switch (input_mode) {
S
Sam Ravnborg 已提交
102 103
	case oldconfig:
	case silentoldconfig:
L
Linus Torvalds 已提交
104 105
		if (sym_has_value(sym)) {
			printf("%s\n", def);
106
			return 0;
L
Linus Torvalds 已提交
107 108
		}
		check_stdin();
109
		/* fall through */
S
Sam Ravnborg 已提交
110
	case oldaskconfig:
L
Linus Torvalds 已提交
111
		fflush(stdout);
112
		xfgets(line, 128, stdin);
113 114
		if (!tty_stdio)
			printf("\n");
115
		return 1;
L
Linus Torvalds 已提交
116 117 118 119 120 121 122 123 124
	default:
		break;
	}

	switch (type) {
	case S_INT:
	case S_HEX:
	case S_STRING:
		printf("%s\n", def);
125
		return 1;
L
Linus Torvalds 已提交
126 127 128 129
	default:
		;
	}
	printf("%s", line);
130
	return 1;
L
Linus Torvalds 已提交
131 132
}

T
Trevor Keith 已提交
133
static int conf_string(struct menu *menu)
L
Linus Torvalds 已提交
134 135
{
	struct symbol *sym = menu->sym;
136
	const char *def;
L
Linus Torvalds 已提交
137 138

	while (1) {
E
EGRY Gabor 已提交
139
		printf("%*s%s ", indent - 1, "", _(menu->prompt->text));
L
Linus Torvalds 已提交
140 141 142 143
		printf("(%s) ", sym->name);
		def = sym_get_string_value(sym);
		if (sym_get_string_value(sym))
			printf("[%s] ", def);
144 145
		if (!conf_askvalue(sym, def))
			return 0;
L
Linus Torvalds 已提交
146 147 148 149 150 151
		switch (line[0]) {
		case '\n':
			break;
		case '?':
			/* print help */
			if (line[1] == '\n') {
152
				print_help(menu);
L
Linus Torvalds 已提交
153 154 155
				def = NULL;
				break;
			}
156
			/* fall through */
L
Linus Torvalds 已提交
157 158 159 160 161 162 163 164 165 166 167 168 169 170 171
		default:
			line[strlen(line)-1] = 0;
			def = line;
		}
		if (def && sym_set_string_value(sym, def))
			return 0;
	}
}

static int conf_sym(struct menu *menu)
{
	struct symbol *sym = menu->sym;
	tristate oldval, newval;

	while (1) {
E
EGRY Gabor 已提交
172
		printf("%*s%s ", indent - 1, "", _(menu->prompt->text));
L
Linus Torvalds 已提交
173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193
		if (sym->name)
			printf("(%s) ", sym->name);
		putchar('[');
		oldval = sym_get_tristate_value(sym);
		switch (oldval) {
		case no:
			putchar('N');
			break;
		case mod:
			putchar('M');
			break;
		case yes:
			putchar('Y');
			break;
		}
		if (oldval != no && sym_tristate_within_range(sym, no))
			printf("/n");
		if (oldval != mod && sym_tristate_within_range(sym, mod))
			printf("/m");
		if (oldval != yes && sym_tristate_within_range(sym, yes))
			printf("/y");
194
		if (menu_has_help(menu))
L
Linus Torvalds 已提交
195 196
			printf("/?");
		printf("] ");
197 198
		if (!conf_askvalue(sym, sym_get_string_value(sym)))
			return 0;
L
Linus Torvalds 已提交
199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230
		strip(line);

		switch (line[0]) {
		case 'n':
		case 'N':
			newval = no;
			if (!line[1] || !strcmp(&line[1], "o"))
				break;
			continue;
		case 'm':
		case 'M':
			newval = mod;
			if (!line[1])
				break;
			continue;
		case 'y':
		case 'Y':
			newval = yes;
			if (!line[1] || !strcmp(&line[1], "es"))
				break;
			continue;
		case 0:
			newval = oldval;
			break;
		case '?':
			goto help;
		default:
			continue;
		}
		if (sym_set_tristate_value(sym, newval))
			return 0;
help:
231
		print_help(menu);
L
Linus Torvalds 已提交
232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258
	}
}

static int conf_choice(struct menu *menu)
{
	struct symbol *sym, *def_sym;
	struct menu *child;
	bool is_new;

	sym = menu->sym;
	is_new = !sym_has_value(sym);
	if (sym_is_changable(sym)) {
		conf_sym(menu);
		sym_calc_value(sym);
		switch (sym_get_tristate_value(sym)) {
		case no:
			return 1;
		case mod:
			return 0;
		case yes:
			break;
		}
	} else {
		switch (sym_get_tristate_value(sym)) {
		case no:
			return 1;
		case mod:
E
EGRY Gabor 已提交
259
			printf("%*s%s\n", indent - 1, "", _(menu_get_prompt(menu)));
L
Linus Torvalds 已提交
260 261 262 263 264 265 266 267 268
			return 0;
		case yes:
			break;
		}
	}

	while (1) {
		int cnt, def;

E
EGRY Gabor 已提交
269
		printf("%*s%s\n", indent - 1, "", _(menu_get_prompt(menu)));
L
Linus Torvalds 已提交
270 271
		def_sym = sym_get_choice_value(sym);
		cnt = def = 0;
272
		line[0] = 0;
L
Linus Torvalds 已提交
273 274 275 276
		for (child = menu->list; child; child = child->next) {
			if (!menu_is_visible(child))
				continue;
			if (!child->sym) {
E
EGRY Gabor 已提交
277
				printf("%*c %s\n", indent, '*', _(menu_get_prompt(child)));
L
Linus Torvalds 已提交
278 279 280 281 282 283 284 285
				continue;
			}
			cnt++;
			if (child->sym == def_sym) {
				def = cnt;
				printf("%*c", indent, '>');
			} else
				printf("%*c", indent, ' ');
E
EGRY Gabor 已提交
286
			printf(" %d. %s", cnt, _(menu_get_prompt(child)));
L
Linus Torvalds 已提交
287 288 289
			if (child->sym->name)
				printf(" (%s)", child->sym->name);
			if (!sym_has_value(child->sym))
E
EGRY Gabor 已提交
290
				printf(_(" (NEW)"));
L
Linus Torvalds 已提交
291 292
			printf("\n");
		}
E
EGRY Gabor 已提交
293
		printf(_("%*schoice"), indent - 1, "");
L
Linus Torvalds 已提交
294 295 296 297 298
		if (cnt == 1) {
			printf("[1]: 1\n");
			goto conf_childs;
		}
		printf("[1-%d", cnt);
299
		if (menu_has_help(menu))
L
Linus Torvalds 已提交
300 301 302
			printf("?");
		printf("]: ");
		switch (input_mode) {
S
Sam Ravnborg 已提交
303 304
		case oldconfig:
		case silentoldconfig:
L
Linus Torvalds 已提交
305 306 307 308 309 310
			if (!is_new) {
				cnt = def;
				printf("%d\n", cnt);
				break;
			}
			check_stdin();
311
			/* fall through */
S
Sam Ravnborg 已提交
312
		case oldaskconfig:
L
Linus Torvalds 已提交
313
			fflush(stdout);
314
			xfgets(line, 128, stdin);
L
Linus Torvalds 已提交
315 316
			strip(line);
			if (line[0] == '?') {
317
				print_help(menu);
L
Linus Torvalds 已提交
318 319 320 321 322 323 324 325 326
				continue;
			}
			if (!line[0])
				cnt = def;
			else if (isdigit(line[0]))
				cnt = atoi(line);
			else
				continue;
			break;
327 328
		default:
			break;
L
Linus Torvalds 已提交
329 330 331 332 333 334 335 336 337 338 339
		}

	conf_childs:
		for (child = menu->list; child; child = child->next) {
			if (!child->sym || !menu_is_visible(child))
				continue;
			if (!--cnt)
				break;
		}
		if (!child)
			continue;
340
		if (line[0] && line[strlen(line) - 1] == '?') {
341
			print_help(child);
L
Linus Torvalds 已提交
342 343 344
			continue;
		}
		sym_set_choice_value(sym, child->sym);
345
		for (child = child->list; child; child = child->next) {
L
Linus Torvalds 已提交
346
			indent += 2;
347
			conf(child);
L
Linus Torvalds 已提交
348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369
			indent -= 2;
		}
		return 1;
	}
}

static void conf(struct menu *menu)
{
	struct symbol *sym;
	struct property *prop;
	struct menu *child;

	if (!menu_is_visible(menu))
		return;

	sym = menu->sym;
	prop = menu->prompt;
	if (prop) {
		const char *prompt;

		switch (prop->type) {
		case P_MENU:
S
Sam Ravnborg 已提交
370
			if ((input_mode == silentoldconfig ||
371
			     input_mode == listnewconfig ||
372
			     input_mode == olddefconfig) &&
373
			    rootEntry != menu) {
L
Linus Torvalds 已提交
374 375 376
				check_conf(menu);
				return;
			}
377
			/* fall through */
L
Linus Torvalds 已提交
378 379 380 381 382
		case P_COMMENT:
			prompt = menu_get_prompt(menu);
			if (prompt)
				printf("%*c\n%*c %s\n%*c\n",
					indent, '*',
E
EGRY Gabor 已提交
383
					indent, '*', _(prompt),
L
Linus Torvalds 已提交
384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428
					indent, '*');
		default:
			;
		}
	}

	if (!sym)
		goto conf_childs;

	if (sym_is_choice(sym)) {
		conf_choice(menu);
		if (sym->curr.tri != mod)
			return;
		goto conf_childs;
	}

	switch (sym->type) {
	case S_INT:
	case S_HEX:
	case S_STRING:
		conf_string(menu);
		break;
	default:
		conf_sym(menu);
		break;
	}

conf_childs:
	if (sym)
		indent += 2;
	for (child = menu->list; child; child = child->next)
		conf(child);
	if (sym)
		indent -= 2;
}

static void check_conf(struct menu *menu)
{
	struct symbol *sym;
	struct menu *child;

	if (!menu_is_visible(menu))
		return;

	sym = menu->sym;
429 430 431
	if (sym && !sym_has_value(sym)) {
		if (sym_is_changable(sym) ||
		    (sym_is_choice(sym) && sym_get_tristate_value(sym) == yes)) {
432 433
			if (input_mode == listnewconfig) {
				if (sym->name && !sym_is_choice_value(sym)) {
434
					printf("%s%s\n", CONFIG_, sym->name);
435
				}
436
			} else if (input_mode != olddefconfig) {
437 438 439 440 441
				if (!conf_cnt++)
					printf(_("*\n* Restart config...\n*\n"));
				rootEntry = menu_get_parent_menu(menu);
				conf(rootEntry);
			}
L
Linus Torvalds 已提交
442 443 444 445 446 447 448
		}
	}

	for (child = menu->list; child; child = child->next)
		check_conf(child);
}

S
Sam Ravnborg 已提交
449 450 451 452 453
static struct option long_opts[] = {
	{"oldaskconfig",    no_argument,       NULL, oldaskconfig},
	{"oldconfig",       no_argument,       NULL, oldconfig},
	{"silentoldconfig", no_argument,       NULL, silentoldconfig},
	{"defconfig",       optional_argument, NULL, defconfig},
S
Sam Ravnborg 已提交
454
	{"savedefconfig",   required_argument, NULL, savedefconfig},
S
Sam Ravnborg 已提交
455 456 457
	{"allnoconfig",     no_argument,       NULL, allnoconfig},
	{"allyesconfig",    no_argument,       NULL, allyesconfig},
	{"allmodconfig",    no_argument,       NULL, allmodconfig},
S
Sam Ravnborg 已提交
458
	{"alldefconfig",    no_argument,       NULL, alldefconfig},
S
Sam Ravnborg 已提交
459
	{"randconfig",      no_argument,       NULL, randconfig},
460
	{"listnewconfig",   no_argument,       NULL, listnewconfig},
461 462 463 464 465 466 467
	{"olddefconfig",    no_argument,       NULL, olddefconfig},
	/*
	 * oldnoconfig is an alias of olddefconfig, because people already
	 * are dependent on its behavior(sets new symbols to their default
	 * value but not 'n') with the counter-intuitive name.
	 */
	{"oldnoconfig",     no_argument,       NULL, olddefconfig},
S
Sam Ravnborg 已提交
468 469 470
	{NULL, 0, NULL, 0}
};

471 472 473 474 475 476 477 478 479
static void conf_usage(const char *progname)
{

	printf("Usage: %s [option] <kconfig-file>\n", progname);
	printf("[option] is _one_ of the following:\n");
	printf("  --listnewconfig         List new options\n");
	printf("  --oldaskconfig          Start a new configuration using a line-oriented program\n");
	printf("  --oldconfig             Update a configuration using a provided .config as base\n");
	printf("  --silentoldconfig       Same as oldconfig, but quietly, additionally update deps\n");
480 481
	printf("  --olddefconfig          Same as silentoldconfig but sets new symbols to their default value\n");
	printf("  --oldnoconfig           An alias of olddefconfig\n");
482 483 484 485 486 487 488 489 490
	printf("  --defconfig <file>      New config with default defined in <file>\n");
	printf("  --savedefconfig <file>  Save the minimal current configuration to <file>\n");
	printf("  --allnoconfig           New config where all options are answered with no\n");
	printf("  --allyesconfig          New config where all options are answered with yes\n");
	printf("  --allmodconfig          New config where all options are answered with mod\n");
	printf("  --alldefconfig          New config with all symbols set to default\n");
	printf("  --randconfig            New config with random answer to all options\n");
}

L
Linus Torvalds 已提交
491 492
int main(int ac, char **av)
{
493
	const char *progname = av[0];
494
	int opt;
495
	const char *name, *defconfig_file = NULL /* gcc uninit */;
L
Linus Torvalds 已提交
496 497
	struct stat tmpstat;

E
EGRY Gabor 已提交
498 499 500 501
	setlocale(LC_ALL, "");
	bindtextdomain(PACKAGE, LOCALEDIR);
	textdomain(PACKAGE);

502 503
	tty_stdio = isatty(0) && isatty(1) && isatty(2);

504
	while ((opt = getopt_long(ac, av, "", long_opts, NULL)) != -1) {
S
Sam Ravnborg 已提交
505
		input_mode = (enum input_mode)opt;
506
		switch (opt) {
S
Sam Ravnborg 已提交
507
		case silentoldconfig:
508
			sync_kconfig = 1;
L
Linus Torvalds 已提交
509
			break;
S
Sam Ravnborg 已提交
510
		case defconfig:
S
Sam Ravnborg 已提交
511
		case savedefconfig:
512
			defconfig_file = optarg;
L
Linus Torvalds 已提交
513
			break;
S
Sam Ravnborg 已提交
514
		case randconfig:
515 516 517
		{
			struct timeval now;
			unsigned int seed;
518
			char *seed_env;
519 520 521 522 523 524 525

			/*
			 * Use microseconds derived seed,
			 * compensate for systems where it may be zero
			 */
			gettimeofday(&now, NULL);
			seed = (unsigned int)((now.tv_sec + 1) * (now.tv_usec + 1));
526 527 528 529

			seed_env = getenv("KCONFIG_SEED");
			if( seed_env && *seed_env ) {
				char *endp;
530
				int tmp = (int)strtol(seed_env, &endp, 0);
531 532 533 534
				if (*endp == '\0') {
					seed = tmp;
				}
			}
535
			fprintf( stderr, "KCONFIG_SEED=0x%X\n", seed );
536
			srand(seed);
L
Linus Torvalds 已提交
537
			break;
538
		}
539 540 541 542 543 544 545
		case oldaskconfig:
		case oldconfig:
		case allnoconfig:
		case allyesconfig:
		case allmodconfig:
		case alldefconfig:
		case listnewconfig:
546
		case olddefconfig:
547
			break;
S
Sam Ravnborg 已提交
548
		case '?':
549
			conf_usage(progname);
550
			exit(1);
S
Sam Ravnborg 已提交
551
			break;
L
Linus Torvalds 已提交
552 553
		}
	}
554
	if (ac == optind) {
555
		printf(_("%s: Kconfig file missing\n"), av[0]);
556
		conf_usage(progname);
557
		exit(1);
L
Linus Torvalds 已提交
558
	}
559
	name = av[optind];
L
Linus Torvalds 已提交
560 561
	conf_parse(name);
	//zconfdump(stdout);
562
	if (sync_kconfig) {
563 564
		name = conf_get_configname();
		if (stat(name, &tmpstat)) {
565
			fprintf(stderr, _("***\n"
566
				"*** Configuration file \"%s\" not found!\n"
567 568 569
				"***\n"
				"*** Please run some configurator (e.g. \"make oldconfig\" or\n"
				"*** \"make menuconfig\" or \"make xconfig\").\n"
570
				"***\n"), name);
571 572 573 574
			exit(1);
		}
	}

L
Linus Torvalds 已提交
575
	switch (input_mode) {
S
Sam Ravnborg 已提交
576
	case defconfig:
L
Linus Torvalds 已提交
577 578 579
		if (!defconfig_file)
			defconfig_file = conf_get_default_confname();
		if (conf_read(defconfig_file)) {
E
EGRY Gabor 已提交
580
			printf(_("***\n"
L
Linus Torvalds 已提交
581
				"*** Can't find default configuration \"%s\"!\n"
E
EGRY Gabor 已提交
582
				"***\n"), defconfig_file);
L
Linus Torvalds 已提交
583 584 585
			exit(1);
		}
		break;
S
Sam Ravnborg 已提交
586
	case savedefconfig:
S
Sam Ravnborg 已提交
587 588 589
	case silentoldconfig:
	case oldaskconfig:
	case oldconfig:
590
	case listnewconfig:
591
	case olddefconfig:
L
Linus Torvalds 已提交
592 593
		conf_read(NULL);
		break;
S
Sam Ravnborg 已提交
594 595 596
	case allnoconfig:
	case allyesconfig:
	case allmodconfig:
S
Sam Ravnborg 已提交
597
	case alldefconfig:
S
Sam Ravnborg 已提交
598
	case randconfig:
599
		name = getenv("KCONFIG_ALLCONFIG");
600 601 602
		if (!name)
			break;
		if ((strcmp(name, "") != 0) && (strcmp(name, "1") != 0)) {
603 604 605 606 607 608
			if (conf_read_simple(name, S_DEF_USER)) {
				fprintf(stderr,
					_("*** Can't read seed configuration \"%s\"!\n"),
					name);
				exit(1);
			}
609 610 611
			break;
		}
		switch (input_mode) {
S
Sam Ravnborg 已提交
612 613 614
		case allnoconfig:	name = "allno.config"; break;
		case allyesconfig:	name = "allyes.config"; break;
		case allmodconfig:	name = "allmod.config"; break;
S
Sam Ravnborg 已提交
615
		case alldefconfig:	name = "alldef.config"; break;
S
Sam Ravnborg 已提交
616
		case randconfig:	name = "allrandom.config"; break;
617 618
		default: break;
		}
619 620 621 622 623 624 625
		if (conf_read_simple(name, S_DEF_USER) &&
		    conf_read_simple("all.config", S_DEF_USER)) {
			fprintf(stderr,
				_("*** KCONFIG_ALLCONFIG set, but no \"%s\" or \"all.config\" file found\n"),
				name);
			exit(1);
		}
626
		break;
L
Linus Torvalds 已提交
627 628 629
	default:
		break;
	}
630 631 632 633 634 635

	if (sync_kconfig) {
		if (conf_get_changed()) {
			name = getenv("KCONFIG_NOSILENTUPDATE");
			if (name && *name) {
				fprintf(stderr,
636
					_("\n*** The configuration requires explicit update.\n\n"));
637 638 639
				return 1;
			}
		}
640
		valid_stdin = tty_stdio;
641 642
	}

643
	switch (input_mode) {
S
Sam Ravnborg 已提交
644
	case allnoconfig:
645 646
		conf_set_all_new_symbols(def_no);
		break;
S
Sam Ravnborg 已提交
647
	case allyesconfig:
648 649
		conf_set_all_new_symbols(def_yes);
		break;
S
Sam Ravnborg 已提交
650
	case allmodconfig:
651 652
		conf_set_all_new_symbols(def_mod);
		break;
S
Sam Ravnborg 已提交
653 654 655
	case alldefconfig:
		conf_set_all_new_symbols(def_default);
		break;
S
Sam Ravnborg 已提交
656
	case randconfig:
657 658
		conf_set_all_new_symbols(def_random);
		break;
S
Sam Ravnborg 已提交
659
	case defconfig:
660 661
		conf_set_all_new_symbols(def_default);
		break;
S
Sam Ravnborg 已提交
662 663
	case savedefconfig:
		break;
S
Sam Ravnborg 已提交
664
	case oldaskconfig:
665 666
		rootEntry = &rootmenu;
		conf(&rootmenu);
S
Sam Ravnborg 已提交
667
		input_mode = silentoldconfig;
668
		/* fall through */
S
Sam Ravnborg 已提交
669
	case oldconfig:
670
	case listnewconfig:
671
	case olddefconfig:
S
Sam Ravnborg 已提交
672
	case silentoldconfig:
673 674 675 676
		/* Update until a loop caused no more changes */
		do {
			conf_cnt = 0;
			check_conf(&rootmenu);
677
		} while (conf_cnt &&
678
			 (input_mode != listnewconfig &&
679
			  input_mode != olddefconfig));
680 681
		break;
	}
L
Linus Torvalds 已提交
682

683 684 685 686 687
	if (sync_kconfig) {
		/* silentoldconfig is used during the build so we shall update autoconf.
		 * All other commands are only used to generate a config.
		 */
		if (conf_get_changed() && conf_write(NULL)) {
688
			fprintf(stderr, _("\n*** Error during writing of the configuration.\n\n"));
689 690 691
			exit(1);
		}
		if (conf_write_autoconf()) {
692
			fprintf(stderr, _("\n*** Error during update of the configuration.\n\n"));
693 694
			return 1;
		}
S
Sam Ravnborg 已提交
695 696 697 698 699 700
	} else if (input_mode == savedefconfig) {
		if (conf_write_defconfig(defconfig_file)) {
			fprintf(stderr, _("n*** Error while saving defconfig to: %s\n\n"),
			        defconfig_file);
			return 1;
		}
701
	} else if (input_mode != listnewconfig) {
702
		if (conf_write(NULL)) {
703
			fprintf(stderr, _("\n*** Error during writing of the configuration.\n\n"));
704 705
			exit(1);
		}
R
Roman Zippel 已提交
706
	}
707
	return 0;
L
Linus Torvalds 已提交
708
}
709

710 711 712
/*
 * Helper function to facilitate fgets() by Jean Sacren.
 */
713
void xfgets(char *str, int size, FILE *in)
714 715 716 717
{
	if (fgets(str, size, in) == NULL)
		fprintf(stderr, "\nError in reading or end of file.\n");
}