+ if (check_for_git()) {
+ runcmd qw(git fetch -p),$remotename,
+ '+refs/heads/*:refs/remotes/origin/*';
+ }
+ fetch_from_archive();
+}
+
+sub pull () {
+ fetch();
+ runcmd qw(git merge -m),"Merge from $suite [dgit]",lref(uploadbranch());
+}
+
+sub dopush () {
+ runcmd qw(git diff --quiet HEAD);
+ my $clogp = parsechangelog();
+ $package = $clogp->{Source};
+ my $dscfn = "${package}_$clogp->{Version}.dsc";
+ stat $dscfn or die "$dscfn $!";
+ $dsc = parsecontrol("../$dscfn");
+ prep_ud();
+ chdir $ud or die $!;
+ print "checking that $dscfn corresponds to HEAD\n";
+ runcmd qw(dpkg-source -x --), "../../../../$dscfn";
+ my $tree = mktree_in_ud_from_only_subdir();
+ chdir '../../../..' or die $!;
+ runcmd qw(git diff --exit-code), $tree;
+#fetch from alioth
+#do fast forward check and maybe fake merge
+# if (!is_fast_fwd(mainbranch
+# runcmd qw(git fetch -p ), $alioth_git,
+# map { lref($_).":".rref($_) }
+# (uploadbranch());
+ $dsc->{$ourdscfield} = rev_parse('HEAD');
+ $dsc->save("../$dscfn.tmp") or die $!;
+ rename "../$dscfn.tmp","../$dscfn" or die "$dscfn $!";
+ if ($sign) {
+ runcmd qw(git tag -s),@git_tag_opts,qw(-m),
+ "Release $dsc->{Version} for $suite [dgit]";
+ unlink "../$dscfn.asc" or $!==&ENOENT or die "$dscfn.asc $!";
+ runcmd qw(gpg --clearsign),@gpg_opts,"../$dscfn";
+ rename "../$dscfn.asc","../$dscfn" or die "$dscfn $!";
+ }
+ if (!$nopush) {
+ runcmd qw(git push),$remotename,"HEAD:".lref(uploadbranch());
+ runcmd qw(dput),"../$dscfn";
+ }