conf.c 14.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>
L
Linus Torvalds 已提交
16 17 18 19 20 21

#include "lkc.h"

static void conf(struct menu *menu);
static void check_conf(struct menu *menu);

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

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

44
static void print_help(struct menu *menu)
45
{
46 47 48 49 50 51
	struct gstr help = str_new();

	menu_get_ext_help(menu, &help);

	printf("\n%s\n", str_get(&help));
	str_free(&help);
52 53
}

J
J.A. Magallon 已提交
54
static void strip(char *str)
L
Linus Torvalds 已提交
55
{
J
J.A. Magallon 已提交
56
	char *p = str;
L
Linus Torvalds 已提交
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
	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)
{
73
	if (!valid_stdin) {
74 75 76
		printf(_("aborted!\n\n"));
		printf(_("Console input/output is redirected. "));
		printf(_("Run 'make oldconfig' to update configuration.\n\n"));
L
Linus Torvalds 已提交
77 78 79 80
		exit(1);
	}
}

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

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

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

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

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

	switch (type) {
	case S_INT:
	case S_HEX:
	case S_STRING:
		printf("%s\n", def);
120
		return 1;
L
Linus Torvalds 已提交
121 122 123 124
	default:
		;
	}
	printf("%s", line);
125
	return 1;
L
Linus Torvalds 已提交
126 127
}

T
Trevor Keith 已提交
128
static int conf_string(struct menu *menu)
L
Linus Torvalds 已提交
129 130
{
	struct symbol *sym = menu->sym;
131
	const char *def;
L
Linus Torvalds 已提交
132 133

	while (1) {
E
EGRY Gabor 已提交
134
		printf("%*s%s ", indent - 1, "", _(menu->prompt->text));
L
Linus Torvalds 已提交
135 136 137 138
		printf("(%s) ", sym->name);
		def = sym_get_string_value(sym);
		if (sym_get_string_value(sym))
			printf("[%s] ", def);
139 140
		if (!conf_askvalue(sym, def))
			return 0;
L
Linus Torvalds 已提交
141 142 143 144 145 146
		switch (line[0]) {
		case '\n':
			break;
		case '?':
			/* print help */
			if (line[1] == '\n') {
147
				print_help(menu);
L
Linus Torvalds 已提交
148 149 150
				def = NULL;
				break;
			}
151
			/* fall through */
L
Linus Torvalds 已提交
152 153 154 155 156 157 158 159 160 161 162 163 164 165 166
		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 已提交
167
		printf("%*s%s ", indent - 1, "", _(menu->prompt->text));
L
Linus Torvalds 已提交
168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188
		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");
189
		if (menu_has_help(menu))
L
Linus Torvalds 已提交
190 191
			printf("/?");
		printf("] ");
192 193
		if (!conf_askvalue(sym, sym_get_string_value(sym)))
			return 0;
L
Linus Torvalds 已提交
194 195 196 197 198 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
		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:
226
		print_help(menu);
L
Linus Torvalds 已提交
227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253
	}
}

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 已提交
254
			printf("%*s%s\n", indent - 1, "", _(menu_get_prompt(menu)));
L
Linus Torvalds 已提交
255 256 257 258 259 260 261 262 263
			return 0;
		case yes:
			break;
		}
	}

	while (1) {
		int cnt, def;

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

	conf_childs:
		for (child = menu->list; child; child = child->next) {
			if (!child->sym || !menu_is_visible(child))
				continue;
			if (!--cnt)
				break;
		}
		if (!child)
			continue;
335
		if (line[0] && line[strlen(line) - 1] == '?') {
336
			print_help(child);
L
Linus Torvalds 已提交
337 338 339
			continue;
		}
		sym_set_choice_value(sym, child->sym);
340
		for (child = child->list; child; child = child->next) {
L
Linus Torvalds 已提交
341
			indent += 2;
342
			conf(child);
L
Linus Torvalds 已提交
343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364
			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 已提交
365
			if ((input_mode == silentoldconfig ||
366
			     input_mode == listnewconfig ||
367
			     input_mode == oldnoconfig) &&
368
			    rootEntry != menu) {
L
Linus Torvalds 已提交
369 370 371
				check_conf(menu);
				return;
			}
372
			/* fall through */
L
Linus Torvalds 已提交
373 374 375 376 377
		case P_COMMENT:
			prompt = menu_get_prompt(menu);
			if (prompt)
				printf("%*c\n%*c %s\n%*c\n",
					indent, '*',
E
EGRY Gabor 已提交
378
					indent, '*', _(prompt),
L
Linus Torvalds 已提交
379 380 381 382 383 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
					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;
424 425 426
	if (sym && !sym_has_value(sym)) {
		if (sym_is_changable(sym) ||
		    (sym_is_choice(sym) && sym_get_tristate_value(sym) == yes)) {
427 428
			if (input_mode == listnewconfig) {
				if (sym->name && !sym_is_choice_value(sym)) {
429
					printf("%s%s\n", CONFIG_, sym->name);
430
				}
431
			} else if (input_mode != oldnoconfig) {
432 433 434 435 436
				if (!conf_cnt++)
					printf(_("*\n* Restart config...\n*\n"));
				rootEntry = menu_get_parent_menu(menu);
				conf(rootEntry);
			}
L
Linus Torvalds 已提交
437 438 439 440 441 442 443
		}
	}

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

S
Sam Ravnborg 已提交
444 445 446 447 448
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 已提交
449
	{"savedefconfig",   required_argument, NULL, savedefconfig},
S
Sam Ravnborg 已提交
450 451 452
	{"allnoconfig",     no_argument,       NULL, allnoconfig},
	{"allyesconfig",    no_argument,       NULL, allyesconfig},
	{"allmodconfig",    no_argument,       NULL, allmodconfig},
S
Sam Ravnborg 已提交
453
	{"alldefconfig",    no_argument,       NULL, alldefconfig},
S
Sam Ravnborg 已提交
454
	{"randconfig",      no_argument,       NULL, randconfig},
455
	{"listnewconfig",   no_argument,       NULL, listnewconfig},
456
	{"oldnoconfig",     no_argument,       NULL, oldnoconfig},
S
Sam Ravnborg 已提交
457 458 459
	{NULL, 0, NULL, 0}
};

460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478
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");
	printf("  --oldnoconfig           Same as silentoldconfig but set new symbols to no\n");
	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 已提交
479 480
int main(int ac, char **av)
{
481
	const char *progname = av[0];
482
	int opt;
483
	const char *name, *defconfig_file = NULL /* gcc uninit */;
L
Linus Torvalds 已提交
484 485
	struct stat tmpstat;

E
EGRY Gabor 已提交
486 487 488 489
	setlocale(LC_ALL, "");
	bindtextdomain(PACKAGE, LOCALEDIR);
	textdomain(PACKAGE);

490
	while ((opt = getopt_long(ac, av, "", long_opts, NULL)) != -1) {
S
Sam Ravnborg 已提交
491
		input_mode = (enum input_mode)opt;
492
		switch (opt) {
S
Sam Ravnborg 已提交
493
		case silentoldconfig:
494
			sync_kconfig = 1;
L
Linus Torvalds 已提交
495
			break;
S
Sam Ravnborg 已提交
496
		case defconfig:
S
Sam Ravnborg 已提交
497
		case savedefconfig:
498
			defconfig_file = optarg;
L
Linus Torvalds 已提交
499
			break;
S
Sam Ravnborg 已提交
500
		case randconfig:
501 502 503 504 505 506 507 508 509 510 511 512
		{
			struct timeval now;
			unsigned int seed;

			/*
			 * 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));
			srand(seed);
L
Linus Torvalds 已提交
513
			break;
514
		}
515 516 517 518 519 520 521 522 523
		case oldaskconfig:
		case oldconfig:
		case allnoconfig:
		case allyesconfig:
		case allmodconfig:
		case alldefconfig:
		case listnewconfig:
		case oldnoconfig:
			break;
S
Sam Ravnborg 已提交
524
		case '?':
525
			conf_usage(progname);
526
			exit(1);
S
Sam Ravnborg 已提交
527
			break;
L
Linus Torvalds 已提交
528 529
		}
	}
530
	if (ac == optind) {
531
		printf(_("%s: Kconfig file missing\n"), av[0]);
532
		conf_usage(progname);
533
		exit(1);
L
Linus Torvalds 已提交
534
	}
535
	name = av[optind];
L
Linus Torvalds 已提交
536 537
	conf_parse(name);
	//zconfdump(stdout);
538
	if (sync_kconfig) {
539 540
		name = conf_get_configname();
		if (stat(name, &tmpstat)) {
541
			fprintf(stderr, _("***\n"
542
				"*** Configuration file \"%s\" not found!\n"
543 544 545
				"***\n"
				"*** Please run some configurator (e.g. \"make oldconfig\" or\n"
				"*** \"make menuconfig\" or \"make xconfig\").\n"
546
				"***\n"), name);
547 548 549 550
			exit(1);
		}
	}

L
Linus Torvalds 已提交
551
	switch (input_mode) {
S
Sam Ravnborg 已提交
552
	case defconfig:
L
Linus Torvalds 已提交
553 554 555
		if (!defconfig_file)
			defconfig_file = conf_get_default_confname();
		if (conf_read(defconfig_file)) {
E
EGRY Gabor 已提交
556
			printf(_("***\n"
L
Linus Torvalds 已提交
557
				"*** Can't find default configuration \"%s\"!\n"
E
EGRY Gabor 已提交
558
				"***\n"), defconfig_file);
L
Linus Torvalds 已提交
559 560 561
			exit(1);
		}
		break;
S
Sam Ravnborg 已提交
562
	case savedefconfig:
S
Sam Ravnborg 已提交
563 564 565
	case silentoldconfig:
	case oldaskconfig:
	case oldconfig:
566
	case listnewconfig:
567
	case oldnoconfig:
L
Linus Torvalds 已提交
568 569
		conf_read(NULL);
		break;
S
Sam Ravnborg 已提交
570 571 572
	case allnoconfig:
	case allyesconfig:
	case allmodconfig:
S
Sam Ravnborg 已提交
573
	case alldefconfig:
S
Sam Ravnborg 已提交
574
	case randconfig:
575 576
		name = getenv("KCONFIG_ALLCONFIG");
		if (name && !stat(name, &tmpstat)) {
577
			conf_read_simple(name, S_DEF_USER);
578 579 580
			break;
		}
		switch (input_mode) {
S
Sam Ravnborg 已提交
581 582 583
		case allnoconfig:	name = "allno.config"; break;
		case allyesconfig:	name = "allyes.config"; break;
		case allmodconfig:	name = "allmod.config"; break;
S
Sam Ravnborg 已提交
584
		case alldefconfig:	name = "alldef.config"; break;
S
Sam Ravnborg 已提交
585
		case randconfig:	name = "allrandom.config"; break;
586 587 588
		default: break;
		}
		if (!stat(name, &tmpstat))
589
			conf_read_simple(name, S_DEF_USER);
590
		else if (!stat("all.config", &tmpstat))
591
			conf_read_simple("all.config", S_DEF_USER);
592
		break;
L
Linus Torvalds 已提交
593 594 595
	default:
		break;
	}
596 597 598 599 600 601

	if (sync_kconfig) {
		if (conf_get_changed()) {
			name = getenv("KCONFIG_NOSILENTUPDATE");
			if (name && *name) {
				fprintf(stderr,
602
					_("\n*** The configuration requires explicit update.\n\n"));
603 604 605 606 607 608
				return 1;
			}
		}
		valid_stdin = isatty(0) && isatty(1) && isatty(2);
	}

609
	switch (input_mode) {
S
Sam Ravnborg 已提交
610
	case allnoconfig:
611 612
		conf_set_all_new_symbols(def_no);
		break;
S
Sam Ravnborg 已提交
613
	case allyesconfig:
614 615
		conf_set_all_new_symbols(def_yes);
		break;
S
Sam Ravnborg 已提交
616
	case allmodconfig:
617 618
		conf_set_all_new_symbols(def_mod);
		break;
S
Sam Ravnborg 已提交
619 620 621
	case alldefconfig:
		conf_set_all_new_symbols(def_default);
		break;
S
Sam Ravnborg 已提交
622
	case randconfig:
623 624
		conf_set_all_new_symbols(def_random);
		break;
S
Sam Ravnborg 已提交
625
	case defconfig:
626 627
		conf_set_all_new_symbols(def_default);
		break;
S
Sam Ravnborg 已提交
628 629
	case savedefconfig:
		break;
S
Sam Ravnborg 已提交
630
	case oldaskconfig:
631 632
		rootEntry = &rootmenu;
		conf(&rootmenu);
S
Sam Ravnborg 已提交
633
		input_mode = silentoldconfig;
634
		/* fall through */
S
Sam Ravnborg 已提交
635
	case oldconfig:
636
	case listnewconfig:
637
	case oldnoconfig:
S
Sam Ravnborg 已提交
638
	case silentoldconfig:
639 640 641 642
		/* Update until a loop caused no more changes */
		do {
			conf_cnt = 0;
			check_conf(&rootmenu);
643
		} while (conf_cnt &&
644
			 (input_mode != listnewconfig &&
645
			  input_mode != oldnoconfig));
646 647
		break;
	}
L
Linus Torvalds 已提交
648

649 650 651 652 653
	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)) {
654
			fprintf(stderr, _("\n*** Error during writing of the configuration.\n\n"));
655 656 657
			exit(1);
		}
		if (conf_write_autoconf()) {
658
			fprintf(stderr, _("\n*** Error during update of the configuration.\n\n"));
659 660
			return 1;
		}
S
Sam Ravnborg 已提交
661 662 663 664 665 666
	} 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;
		}
667
	} else if (input_mode != listnewconfig) {
668
		if (conf_write(NULL)) {
669
			fprintf(stderr, _("\n*** Error during writing of the configuration.\n\n"));
670 671
			exit(1);
		}
R
Roman Zippel 已提交
672
	}
673
	return 0;
L
Linus Torvalds 已提交
674
}
675 676 677 678 679 680 681 682 683 684 685
/*
 * Helper function to facilitate fgets() by Jean Sacren.
 */
void xfgets(str, size, in)
	char *str;
	int size;
	FILE *in;
{
	if (fgets(str, size, in) == NULL)
		fprintf(stderr, "\nError in reading or end of file.\n");
}