aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lib/Youri/Submit/Action/Dependencies.pm71
-rw-r--r--lib/Youri/Submit/Action/RebuildPackage.pm12
2 files changed, 82 insertions, 1 deletions
diff --git a/lib/Youri/Submit/Action/Dependencies.pm b/lib/Youri/Submit/Action/Dependencies.pm
new file mode 100644
index 0000000..b0cd2a1
--- /dev/null
+++ b/lib/Youri/Submit/Action/Dependencies.pm
@@ -0,0 +1,71 @@
+# $Id$
+package Youri::Submit::Action::Dependencies;
+
+=head1 NAME
+
+Youri::Submit::Action::Dependencies - Creates .deps files
+
+=head1 DESCRIPTION
+
+This action plugin ensures the creation of .deps files based
+on 'dependencies' define
+
+=cut
+
+use warnings;
+use strict;
+use Carp;
+use File::Basename;
+use base qw/Youri::Submit::Action/;
+
+sub _init {
+ my $self = shift;
+ my %options = (
+ perms => 644,
+ uphost => '',
+ user => '',
+ ssh_key => '',
+ verbose => '',
+ @_
+ );
+ croak "undefined upload host" unless $options{uphost};
+ croak "undefined ssh key" unless $options{ssh_key};
+
+ foreach my $var ('perms', 'user', 'uphost', 'ssh_key', 'verbose') {
+ $self->{"_$var"} = $options{$var};
+ }
+
+ return $self;
+}
+
+sub run {
+ my ($self, $package, $repository, $target, $define) = @_;
+ croak "Not a class method" unless ref $self;
+
+ return unless $define->{dependencies} =~ /^[\d,]+$/;
+
+ my $file = basename($package->as_file());
+ my $dest = $repository->get_upload_dir($package, $target, $define);
+ my $depsfile = "$dest$file.deps";
+ my $deps = $define->{dependencies};
+ $deps =~ tr/,/\n/;
+
+ my $cmd = "ssh -i $self->{_ssh_key} $self->{_user}\@$self->{_uphost} \"echo '$deps' > $depsfile\"";
+ print "Submit::Action::Dependencies: doing $cmd\n" if $self->{_verbose};
+ if (!$self->{_test}) {
+ if (!system($cmd)) {
+ print "Submit::Action::Dependencies: succeeded!\n";
+ return 1
+ }
+ print "Submit::Action::Dependencies: failed!\n";
+ }
+}
+=head1 COPYRIGHT AND LICENSE
+
+Copyright (C) 2002-2014, YOURI project
+
+This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
+
+=cut
+
+1;
diff --git a/lib/Youri/Submit/Action/RebuildPackage.pm b/lib/Youri/Submit/Action/RebuildPackage.pm
index d121090..a2ba4b0 100644
--- a/lib/Youri/Submit/Action/RebuildPackage.pm
+++ b/lib/Youri/Submit/Action/RebuildPackage.pm
@@ -32,6 +32,12 @@ sub run {
croak "Not a class method" unless ref $self;
$package->is_source or return 1;
+
+ my $prefix;
+ if ($package->get_file_name() =~ m/^(\d{14})\..*$/) {
+ $prefix = $1;
+ }
+
my $srpm_name = $package->get_canonical_name;
my @packages = $self->{rules}{$srpm_name} or return 1;
my $svn = $repository->get_svn_url();
@@ -44,7 +50,11 @@ sub run {
chdir 'current';
$updater->update_from_spec(glob('SPECS/*.spec'));
system('svn', 'ci', '-m', "Rebuild for new $srpm_name");
- system("mgarepo submit &");
+ if ($prefix) {
+ system("mgarepo submit --define dependencies=$prefix &");
+ } else {
+ system("mgarepo submit &");
+ }
chdir $oldcwd;
}
}