%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /usr/bin/X11/
Upload File :
Create Path :
Current File : //usr/bin/X11/debconf-set-selections

#!/usr/bin/perl
# This file was preprocessed, do not edit!


use warnings;
use strict;
use Debconf::Db;
use Debconf::Template;
use Getopt::Long;

use vars qw(%opts $filename $debug $error $checkonly $unseen);

sub usage {
	print STDERR <<EOF;
Usage: debconf-set-selections [-vcu] [file]
  -v, --verbose     verbose output
  -c, --checkonly   only check the input file format
  -u, --unseen      do not set the 'seen' flag when preseeding values
EOF
	exit(1);
}

sub info {
	my $msg = shift;
	print STDERR "info: $msg\n" if $debug;
}

sub warning {
	my $msg = shift;
	print STDERR "warning: $msg\n";
}

sub error {
	my $msg = shift;
	print STDERR "error: $msg\n";
	$error++
}

sub load_answer {
	my ($owner, $label, $type, $content) = @_;

	info "Loading answer for '$label'";

	my $template=Debconf::Template->get($label);
	if (! $template) {
		$template=Debconf::Template->new($label, $owner, $type);
		$template->description("Dummy template");
		$template->extended_description("This is a fake template used to pre-seed the debconf database. If you are seeing this, something is probably wrong.");
	}
	$template->type($type);

	my $question=Debconf::Question->get($label);
	if (! $question) {
		error("Cannot find a question for $label");
		return;
	}
	$question->addowner($owner, $type);
	$question->value($content);
	if (! $unseen) {
		$question->flag("seen", "true");
	}
}

sub set_flag {
	my ($owner, $label, $flag, $content) = @_;

	info "Setting $flag flag";

	my $question=Debconf::Question->get($label);
	if (! $question) {
		error("Cannot find a question for $label");
		return;
	}
	$question->flag($flag, $content);
}

my @knowntypes = qw(select boolean string multiselect note password text title);
my @knownflags = qw(seen);

sub ok_format {
	my ($owner, $label, $type, $content) = @_;
	if (! defined $owner || ! defined $label || ! defined $content) {
		error "parse error on line $.: '$_'";
		return;
	}
	elsif (! grep { $_ eq $type } @knowntypes, @knownflags) {
		warning "Unknown type $type, skipping line $.";
		return;
	}
	else {
		return 1;
	}
}

sub mungeline ($) {
	my $line=shift;
	chomp $line;
	$line=~s/\r$//;
	return $line;
}


GetOptions(
	"verbose|v" => \$debug,
	"checkonly|c" => \$checkonly,
	"unseen|u" => \$unseen,
) || usage();

{
	local $ENV{DEBCONF_NOWARNINGS} = 'yes' if $checkonly;
	Debconf::Db->load;
}

$error = 0;

unshift @ARGV, '-' unless @ARGV;
foreach my $filename (@ARGV) {
	my $input;
	if ($filename eq '-') {
		$input = \*STDIN;
	} elsif (not open $input, '<', $filename) {
		warn $!;
		next;
	}
	while (<$input>) {
		$_=mungeline($_);
		while (/\\$/ && ! eof) {
			s/\\$//;
			$_.=mungeline(<$input>);
		}
		next if /^\s*$/ || /^\s*\#/;
		my ($owner, $label, $type, $content) = /^\s*(\S+)\s+(\S+)\s+(\S+)(?:\s(.*))?/;
		if (! defined $content) {
			$content='';
		}
		if (ok_format($owner, $label, $type, $content)) {
			if (grep { $_ eq $type } @knownflags) {
				info "Trying to set '$type' flag to '$content'";
				set_flag($owner, $label, $type, $content);
			}
			else {
				info "Trying to set '$label' [$type] to '$content'";
				load_answer($owner, $label, $type, $content);
			}
		}
	}
}

if (! $checkonly) {
	Debconf::Db->save;
}

if ($error) {
	exit 1;
}


Zerion Mini Shell 1.0