summaryrefslogtreecommitdiffstats
path: root/move/Makefile
Commit message (Expand)AuthorAgeFilesLines
* prefer collecting data in "install" rule when un_live_tree_boot is donePascal Rigaux2004-05-171-2/+3
* add some "sudo" where neededPascal Rigaux2004-05-171-6/+6
* - rationalize the MakefilePascal Rigaux2004-05-111-13/+22
* i don't need i18n.dirs, so i don't need the special case for check_dirsPascal Rigaux2004-05-071-1/+1
* fix check_dirsPascal Rigaux2004-05-071-1/+1
* fix buildPascal Rigaux2004-05-061-1/+1
* - install all langsPascal Rigaux2004-05-061-23/+25
* xfree[34X] are removedPascal Rigaux2004-05-061-1/+1
* for complete build, one need to do "build" before "install"Pascal Rigaux2004-04-131-1/+1
* rename rule "all" to "default" (it doesn't do all)Pascal Rigaux2004-04-131-1/+1
* also build various subdirs in mdk-stage1 in case it's not donePascal Rigaux2004-04-081-1/+1
* - move from /usr/bin/stage2 to /usr/lib/stage2Pascal Rigaux2004-04-051-6/+6
* set volsetPascal Rigaux2003-12-081-1/+3
* titi fixes sound initscript for some alsa devicesGuillaume Cottenceau2003-12-051-1/+2
* default config file of konsole has a large font :/Guillaume Cottenceau2003-12-051-1/+1
* smaller isolinux progress barPascal Rigaux2003-12-041-1/+1
* *** empty log message ***Guillaume Cottenceau2003-12-041-1/+1
* OOo launches netscape so we need a fake netscapeGuillaume Cottenceau2003-12-031-1/+1
* add md5sum to the isoPascal Rigaux2003-12-031-0/+1
* we need usb/firewire support for usb/fireware cdroms!Guillaume Cottenceau2003-12-021-1/+1
* empty help.pmPascal Rigaux2003-12-021-1/+2
* don't have a CVS directory on isoGuillaume Cottenceau2003-12-011-0/+1
* ignore failing to build nvidia clpPascal Rigaux2003-11-281-1/+1
* allow to halt machineGuillaume Cottenceau2003-11-271-1/+3
* allow to reboot the machineGuillaume Cottenceau2003-11-261-1/+1
* we can't keep perl in memory if we want to eject cdromGuillaume Cottenceau2003-11-261-1/+1
* allow X to restart after dying through X_move script, startkde also through s...Guillaume Cottenceau2003-11-261-1/+2
* no need to skip network.pm anymorePascal Rigaux2003-11-251-1/+1
* - handle nvidia.clpPascal Rigaux2003-11-251-0/+1
* put backgrounds directly in /usr/share/wallpapersGuillaume Cottenceau2003-11-211-1/+2
* found no way to write into /var/run/utmp than to create my own program :(Guillaume Cottenceau2003-11-201-1/+5
* have the syslinux progress bar whitePascal Rigaux2003-11-201-1/+1
* new splash screenPascal Rigaux2003-11-201-1/+4
* make_live_tree_boot replacing files by symlinks is responsible for fontconfig...Guillaume Cottenceau2003-11-191-0/+2
* use boot imagesGuillaume Cottenceau2003-11-191-1/+3
* uneeded now since we use etc-monitorer.plGuillaume Cottenceau2003-11-191-1/+1
* default and supplementary wallpapersGuillaume Cottenceau2003-11-191-0/+1
* build & install drakx mo filesPascal Rigaux2003-11-181-0/+3
* have system configuration files automagically saved on the usb key with dnoti...Guillaume Cottenceau2003-11-181-0/+2
* when we need to change something in MDK-Common (here, substInFile), allow us ...Guillaume Cottenceau2003-11-171-0/+3
* fix -sort in mkisofsPascal Rigaux2003-11-171-2/+2
* have a better global coherency between clp'sPascal Rigaux2003-11-171-0/+1
* add a "making iso" rulePascal Rigaux2003-11-171-4/+17
* remove unused stuffPascal Rigaux2003-11-171-6/+0
* preliminary support for saving system configuration data on usb keyGuillaume Cottenceau2003-11-141-1/+1
* be sure remaining /etc files are at least available ROGuillaume Cottenceau2003-11-121-1/+2
* network.pm doesn't exist anymorePascal Rigaux2003-11-121-1/+1
* add an icon on the desktop to run mdk_totemPascal Rigaux2003-11-121-0/+1
* also copy perl-install/*/*.pm filesPascal Rigaux2003-11-101-2/+2
* create and handle always_i18n_xxx clp'sPascal Rigaux2003-11-071-0/+1
N(" -f - print version, release and arch with name. ") . N(" -g - print groups with name also. ") . N(" -i - print useful information in human readable form. ") . N(" -l - list files in package. ") . N(" -m - equivalent to -du ") . N(" -r - print version and release with name also. ") . N(" -s - next package is a source package (same as --src). ") . N(" -u - remove package if a more recent version is already installed. ") . N(" -y - impose fuzzy search (same as --fuzzy). ") . N(" -Y - like -y, but forces to match case-insensitively. ") . "\n" . N(" names or rpm files given on command line are queried. "); exit(1); } sub escape_shell ($) { my ($s) = @_; if ($s =~ /\s|'|"/) { $s =~ s/"/\\"/g; $s = qq("$s"); } else { return $s; } } #- parse arguments list. @ARGV or usage(); my $urpm = urpm->new_parse_cmdline or exit(1); #- we really don't want logs on stdout, and remove verbose if not asked. $urpm->{info} = sub { print STDERR "$_[0]\n" }; $urpm->{log} = sub { print STDERR "$_[0]\n" } if $options{verbose} > 0; #- improve speed if using any list_... options. $options{nodepslist} = $options{list_aliases} || $options{list_nodes} || $options{list_media} || $options{dump_config} || $options{list_url}; $options{nolock} = 1 if $options{nodepslist}; if ($options{env}) { print N("using specific environment on %s\n", $options{env}); #- setting new environment. $urpm->{config} = "$options{env}/urpmi.cfg"; $urpm->{skiplist} = "$options{env}/skip.list"; $urpm->{instlist} = "$options{env}/inst.list"; $urpm->{prefer_list} = "$options{env}/prefer.list"; $urpm->{prefer_vendor_list} = "$options{env}/prefer.vendor.list"; $urpm->{statedir} = $options{env}; } #- should we ignore arch compatibility if ($options{ignorearch}) { urpm::shunt_ignorearch() } my $rpm_lock = $options{upgrade} && !$options{env} && !$options{nolock} && urpm::lock::rpm_db($urpm, '', wait => $options{wait_lock}); my $urpmi_lock = !$options{nolock} && urpm::lock::urpmi_db($urpm, '', wait => $options{wait_lock}); urpm::media::configure($urpm, nocheck_access => 1, nodepslist => $options{nodepslist}, media => $options{media}, searchmedia => $options{searchmedia}, excludemedia => $options{excludemedia}, sortmedia => $options{sortmedia}, synthesis => $options{synthesis}, update => $options{update}, parallel => $options{parallel}, probe_with => $options{probe_with}, usedistrib => $options{usedistrib}, cmdline_skiplist => $options{skip}, ); my $state = {}; my %requested; if ($options{list_aliases}) { local $_; open my $parallelfh, "/etc/urpmi/parallel.cfg"; while (<$parallelfh>) { chomp; s/#.*$//; s/^\s*//; s/\s*$//; /\s*([^:]*):/ and print "$1\n"; } close $parallelfh; } elsif ($options{list_nodes}) { $options{parallel} or $urpm->{fatal}(1, N("--list-nodes can only be used with --parallel")); foreach (keys %{$urpm->{parallel_handler}{nodes} || {}}) { print "$_\n"; } exit 0; } elsif ($options{list_media} || $options{list_url}) { foreach (@{$urpm->{media}}) { next if $options{list_media} eq 'update' && !$_->{update}; next if $options{list_media} eq 'active' && $_->{ignore}; print $_->{name} . ($options{list_url} ? " $_->{url}" : "") . "\n"; } exit 0; } elsif ($options{dump_config}) { foreach (@{$urpm->{media}}) { $_->{update} and print "--update "; $_->{virtual} and print "--virtual "; print escape_shell($_->{name}), " ", escape_shell($_->{url}), " "; $_->{with_synthesis} and print "with " . escape_shell($_->{with_synthesis}); print "\n"; } exit 0; } elsif ($options{list}) { # --list lists all available packages: select them all @{$state->{selected}}{0 .. $#{$urpm->{depslist}}} = (); } else { %requested = $urpm->register_rpms(@files); my $search_packages = sub { my ($names, %more_options) = @_; urpm::select::search_packages($urpm, \%requested, $names, use_provides => $options{use_provides}, fuzzy => $urpm->{options}{fuzzy}, caseinsensitive => $options{caseinsensitive}, %more_options, ); }; #- search the packages according to the selection given by the user. if (@names) { $search_packages->(\@names, all => $options{all}) or $options{force} or exit 1; } if (@src_names) { $search_packages->(\@src_names, src => 1) or $options{force} or exit 1; } #- keep track of choices, don't propagate but mark them selected. my $stop_on_choices = sub { my (undef, undef, $state_, $choices) = @_; $state_->{selected}{join '|', sort { $a <=> $b } map { $_ ? $_->id : () } @$choices} = 0; }; #- open/close of database should be moved here, in order to allow testing #- some bogus case and check for integrity. (note auto_select implies upgrade). if ($options{what_requires}) { #- search for packages that require one of the proposed packages. my (@properties, %requires, %properties, $dep); #- keep in mind the requested id (if given) in order to prefer these packages #- on choices instead of anything other one. @properties = keys %requested; if (@properties) { #- build a requires to packages id hash. foreach my $pkg (@{$urpm->{depslist}}) { foreach ($pkg->requires_nosense) { $requires{$_}{$pkg->id} = undef; } } #- for each dep property evaluated, examine which package will be obsoleted on $db, #- then examine provides that will be removed (which need to be satisfied by another #- package present or by a new package to upgrade), then requires not satisfied and #- finally conflicts that will force a new upgrade or a remove. while (defined ($dep = shift @properties)) { #- take the best package for each choices of same name. my $packages = $urpm->find_candidate_packages($dep); foreach (values %$packages) { my ($best_requested, $best); foreach (@$_) { if ($best_requested || exists $requested{$_->id}) { if ($best_requested && $best_requested != $_) { $_->compare_pkg($best_requested) > 0 and $best_requested = $_; } else { $best_requested = $_; } } elsif ($best && $best != $_) { $_->compare_pkg($best) > 0 and $best = $_; } else { $best = $_; } } #- examine all proposed choices. my $pkg = $best_requested || $best or next; exists $state->{selected}{$pkg->id} and next; $state->{selected}{$pkg->id} = undef; next if !$requested{$dep} && !$options{what_requires_recursive}; #- for all provides of package, look up what is requiring them. foreach ($pkg->provides) { if (my ($n, $s) = /^([^\s\[]*)(?:\[\*\])?\[?([^\s\]]*\s*[^\s\]]*)/) { if (my @l = grep { $_ ne $pkg->name } map { $_->name } $urpm->packages_providing($n)) { #- If another package provides this requirement, #- then don't bother finding stuff that needs it as it will be invalid $urpm->{log}(sprintf "skipping package(s) requiring %s via %s, since %s is also provided by %s", $pkg->name, $n, $n, join(' ', @l)); next; } foreach (map { $urpm->{depslist}[$_] } grep { ! exists $state->{selected}{$_} && ! exists $properties{$_} } keys %{$requires{$n} || {}}) { if (grep { URPM::ranges_overlap("$n $s", $_) } $_->requires) { push @properties, $_->id; $urpm->{debug} and $urpm->{debug}(sprintf "adding package %s (requires %s%s)", $_->name, $pkg->name, $n eq $pkg->name ? '' : " via $n"); $properties{$_->id} = undef; } } } } } } } } elsif ($options{auto_select} || $options{upgrade}) { urpm::select::resolve_dependencies($urpm, $state, \%requested, keep => $options{keep}, rpmdb => $options{env} && "$options{env}/rpmdb.cz", auto_select => $options{auto_select}, callback_choices => $stop_on_choices); $options{deps} or delete @{$state->{selected}}{grep { exists $state->{selected}{$_} && ! defined $state->{selected}{$_} } keys %{$state->{selected}}}; } elsif ($options{deps}) { #- only deps required. my $empty_db = new URPM; #- URPM has same methods as URPM::DB and empty URPM will be seen as empty URPM::DB. $urpm->resolve_requested($empty_db, $state, \%requested, callback_choices => $stop_on_choices, nodeps => 1); } else { $state->{selected} = \%requested; } my %need_xml_info; $need_xml_info{info} = 1 if $options{info} || $options{sourcerpm}; $need_xml_info{files} = 1 if $options{files}; $need_xml_info{changelog} = 1 if $options{changelog}; if ($options{sources} || %need_xml_info) { my ($local_sources, $list) = urpm::get_pkgs::selected2list($urpm, $state->{selected}); my %xml_info_pkgs; if (%need_xml_info) { # get descriptions of update sources my $updates_descr = urpm::get_updates_description($urpm); my @selected = uniq(map { keys %$_ } @$list); foreach my $medium (@{$urpm->{media} || []}) { my @l = grep { $medium->{start} <= $_ && $_ <= $medium->{end} } @selected or next; my @pkgs = map { $urpm->{depslist}[$_] } @l or next; if (my $dir = file_from_local_url($medium->{url})) { $urpm->{log}("getting information from rpms from $dir"); $local_sources->{$_->id} = "$dir/" . $_->filename foreach @pkgs; } else { foreach my $xml_info (grep { $need_xml_info{$_} } 'info', 'files', 'changelog') { if (my $xml_info_file = urpm::media::any_xml_info($urpm, $medium, $xml_info, $options{verbose} < 0)) { require urpm::xml_info; require urpm::xml_info_pkg; $urpm->{log}("getting information from $xml_info_file"); my %nodes = urpm::xml_info::get_nodes($xml_info, $xml_info_file, [ map { scalar $_->fullname } @pkgs ]); put_in_hash($xml_info_pkgs{$_->id} ||= {}, $nodes{$_->fullname}) foreach @pkgs; } else { my $pkgs_text = join(' ', map { $_->name } @pkgs); if ($xml_info eq 'info') { $urpm->{info}((int(@pkgs) == 1) ? N("no xml info for medium \"%s\", only partial result for package %s", $medium->{name}, $pkgs_text) : N("no xml info for medium \"%s\", only partial result for packages %s", $medium->{name}, $pkgs_text)); } else { $urpm->{error}((int(@pkgs) == 1) ? N("no xml info for medium \"%s\", unable to return any result for package %s",$medium->{name}, $pkgs_text) : N("no xml info for medium \"%s\", unable to return any result for packages %s", $medium->{name}, $pkgs_text)); } } } } } foreach (keys %{$state->{selected}}) { foreach my $id (split /\|/, $_) { my $pkg = $urpm->{depslist}[$id] or next; #- even if non-root, search for a header in the global cachedir my $file = $local_sources->{$id} || "$urpm->{cachedir}/headers/" . $pkg->header_filename; if (-s $file) { $pkg->update_header($file, keep_all_tags => 1); } elsif ($xml_info_pkgs{$id}) { # using the proxy urpm::xml_info_pkg object $pkg = urpm::xml_info_pkg->new($xml_info_pkgs{$id}, $pkg); } if ($options{info}) { printf "%-12s: %s\n", "Name", $pkg->name; printf "%-12s: %s\n", "Version", $pkg->version; printf "%-12s: %s\n", "Release", $pkg->release; printf "%-12s: %s\n", "Group", $pkg->group; printf "%-12s: %-28s %12s: %s\n", "Size", $pkg->size, "Architecture", $pkg->arch; if ($pkg->sourcerpm || $pkg->buildhost) { if ($pkg->sourcerpm && $pkg->buildhost) { printf "%-12s: %-28s %12s: %s\n", "Source RPM", $pkg->sourcerpm, "Build Host", $pkg->buildhost; } elsif ($pkg->sourcerpm) { $pkg->sourcerpm and printf "%-12s: %s\n", "Source RPM", $pkg->sourcerpm; } else { $pkg->sourcerpm and printf "%-12s: %s\n", "Build Host", $pkg->buildhost; } } $pkg->packager and printf "%-12s: %s\n", "Packager", $pkg->packager; $pkg->url and printf "%-12s: %s\n", "URL", $pkg->url; $pkg->summary and printf "%-12s: %s\n", "Summary", $pkg->summary; my $updesc = $updates_descr->{URPM::pkg2media($urpm->{media}, $pkg)->{name}}{$pkg->name}; $pkg->description && !$updesc->{description} and printf "%-12s:\n%s\n", "Description", $pkg->description; if ($updesc) { $updesc->{description} and printf "%-12s:\n%s\n", "Description", $updesc->{description}; $updesc->{updated} and printf "%-20s: %s\n", "Last updated", $updesc->{updated}; $updesc->{importance} and printf "%-20s: %s\n", "Update importance", $updesc->{importance}; $updesc->{pre} and printf "%-20s:\n%s\n", "Reason for update", $updesc->{pre}; } } if ($options{files}) { if ($pkg->files) { print join("\n", $pkg->files) . "\n"; } } if (my @tags = grep { $options{$_} } 'sourcerpm') { print $pkg->name, ': ', $pkg->$_, "\n" foreach @tags; } if ($options{changelog}) { if (my @changelogs = $pkg->changelogs) { foreach (@changelogs) { print "* " . urpm::msg::localtime2changelog($_->{time}) . " $_->{name}\n$_->{text}\n\n"; } } else { print STDERR N("No changelog found\n"); } } } } } elsif ($options{sources}) { print join "\n", values %$local_sources; values %$local_sources and print "\n"; foreach (0..$#{$urpm->{media} || []}) { print join "\n", values %{$list->[$_]}; values %{$list->[$_]} and print "\n"; } } exit 0; } elsif ($options{summary}) { foreach (keys %{$state->{selected}}) { foreach (split /\|/, $_) { my $pkg = $urpm->{depslist}[$_] or next; printf "%s : %s ( %s%s-%s )\n", $pkg->name, $pkg->summary, ($pkg->epoch ? $pkg->epoch . ':' : ''), $pkg->version, $pkg->release; } } exit 0; } elsif ($options{provides}) { my @l = uniq_ { scalar $_->fullname } map { $urpm->{depslist}[$_] } map { split /\|/, $_ } keys %{$state->{selected}}; foreach my $pkg (@l) { if (@l > 1) { printf "%s: %s\n", $pkg->name, $_ foreach $pkg->provides; } else { print "$_\n" foreach $pkg->provides; } } exit 0; } } $urpmi_lock and $urpmi_lock->unlock; $rpm_lock and $rpm_lock->unlock; #- print sub for query. my $query_sub = sub { my ($id) = @_; my $pkg = $urpm->{depslist}[$id]; my $str = ''; $options{group} and $str .= $pkg->group . '/'; $str .= $pkg->name; $options{version} and $str .= '-' . $pkg->version; $options{release} and $str .= '-' . $pkg->release; $options{arch} and $str .= '.' . $pkg->arch; $str; }; my %hack_only_one; if ($options{complete}) { foreach my $removal (grep { $state->{rejected}{$_}{removed} && !$state->{rejected}{$_}{obsoleted} } keys %{$state->{rejected} || {}}) { print '@removing@' . $removal . "\n"; } foreach my $selected (values %{$state->{selected} || {}}) { if (ref($selected) eq 'HASH' && ref($selected->{unsatisfied}) eq 'ARRAY') { foreach (@{$selected->{unsatisfied}}) { exists $hack_only_one{$_} and next; print '@unsatisfied@' . $_ . "\n"; $hack_only_one{$_} = undef; } } } } foreach my $id (sort { eval { $urpm->{depslist}[$a]->name cmp $urpm->{depslist}[$b]->name } || $a <=> $b } $state->{selected} ? keys %{$state->{selected}} : keys %requested) { my $class = $state->{selected}{$id} || $requested{$id}; if (ref($class) eq 'ARRAY') { foreach my $choices (@{$class || []}) { exists $hack_only_one{$choices} and next; print join('|', map { $query_sub->($_) } @$choices), "\n"; $hack_only_one{$choices} = undef; } } else { print join('|', map { $query_sub->($_) } split '\|', $id), "\n"; } }