Предварительный просмотр Git push
Как я могу увидеть, какие коммиты фактически будут перенаправлены в удаленный репозиторий?
Насколько я знаю, всякий раз, когда я вытаскиваю мастер из удаленного репозитория, коммиты, скорее всего, будут сгенерированы, даже если они пусты.
Это приводит к тому, что локальный мастер будет "вперед", даже если на самом деле ничего не нажать.
Теперь, если я попробую (от мастера):
git cherry origin master
У меня есть идея, что будет толкнуть, хотя в этом также отображаются некоторые коммиты, которые я уже нажал. Есть ли способ отображать только новый контент, который будет нажат?
Ответы
Ответ 1
Помните origin/master
- это ссылка, которая указывает на заголовок главной ветки на удаленном сервере с именем origin
при последнем нажатии, поэтому вы можете использовать команду, например
$ git log origin/master..master
Вы можете использовать git-preview-push
ниже этих комментариев на выходе git push --dry-run --porcelain
:
#! /usr/bin/env perl
use warnings;
use strict;
die "Usage: $0 remote refspec\n" unless @ARGV == 2;
my($origin,$refspec) = @ARGV;
my @cmd = qw/ git push --dry-run --porcelain /;
no warnings 'exec';
open my $fh, "-|" => @cmd, $origin, $refspec or die "$0: exec: $!";
# <flag> \t <from>:<to> \t <summary> (<reason>)
my $update = qr/^ (.*) \t # flag (optional)
(\S+):(\S+) \t # from:to
(.+) # summary
(?:[ ] \((.+)\))? # reason
$/x;
while (<$fh>) {
next unless my($flag,$from,$to,$summary,$reason) = /$update/;
if ($flag eq "!") {
print "$0: $refspec rejected:\n", $_;
}
elsif ($flag eq "=") {
print "$0: $refspec up-to-date\n";
}
if ($summary =~ /^[0-9a-f]+\.\.[0-9a-f]+$/) {
system("git log --pretty=oneline $summary") == 0
or warn "$0: git log exited " . ($? >> 8);
}
elsif ($summary eq "[new branch]") {
print "$0: $refspec creates a new branch.\n";
}
}
Пример использования:
$ git preview-push /tmp/bare master
To /tmp/bare
270f8e6bec7af9b2509710eb1ae986a8e97068ec baz
4c3d1e89f5d6b0d493c9d0c7a06420d6b2eb5af7 bar
Ответ 2
Я написал инструмент для этого: git wtf: https://github.com/michaelklishin/git-wtf. Цвета и все такое!
В качестве бонуса он также покажет вам связь между ветвью функций и ветвью интеграции.
Ответ 3
Я добавил следующие псевдонимы в свой файл ~/.gitconfig, чтобы показать, что было бы объединено (во время pull), что бы было нажато, и псевдоним для разграничения с удаленным:
[alias]
# diff remote branch (e.g., git diff origin/master master)
difr = "diff @{u}"
# similar to hg incoming/outgoing, showing what would be pulled/pushed
# use option "-p" to see actual patch
incoming = "!git remote update -p; git log [email protected]{u}"
# showing what would be pushed (see also alias difr)
outgoing = log @{u}..
Ответ 4
Если вы поместите это в свой профиль Bash, вы сможете запустить grin (Git remote incoming) и grout (Git удаленный исходящий), чтобы увидеть разницу между фиксациями, входящими и исходящими для основного источника
function parse_git_branch {
git branch --no-color 2> /dev/null | sed -e '/^[^*]/d' -e 's/* \(.*\)/\1/'
}
function gd2 {
echo branch \($1\) has these commits and \($2\) does not
git log $2..$1 --no-merges --format='%h | Author:%an | Date:%ad | %s' --date=local
}
function grin {
git fetch origin master
gd2 FETCH_HEAD $(parse_git_branch)
}
function grout {
git fetch origin master
gd2 $(parse_git_branch) FETCH_HEAD
}