From: Ian Jackson Date: Thu, 15 Feb 2018 20:16:42 +0000 (+0000) Subject: git-debrebase: break out ffq_prev_branchinfo (nfc) X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=commitdiff_plain;h=b9bf0d9b71e04b24a9d82d23cb277d7e68b91cd1;p=dgit.git git-debrebase: break out ffq_prev_branchinfo (nfc) Signed-off-by: Ian Jackson --- diff --git a/git-debrebase b/git-debrebase index f68dfb1a..592dd292 100755 --- a/git-debrebase +++ b/git-debrebase @@ -850,6 +850,20 @@ sub cmd_analyse () { STDOUT->error and die $!; } +sub ffq_prev_branchinfo () { + # => ('status', "message", [$current, $ffq_prev]) + # 'status' may be + # branch message is undef + # weird-symref } no $current, + # notbranch } no $ffq_prev + my $current = git_get_symref(); + return ('detached', 'detached HEAD') unless defined $current; + return ('weird-symref', 'HEAD symref is not to refs/') + unless $current =~ m{^refs/}; + my $ffq_prev = "refs/$ffq_refprefix/$'"; + return ('branch', undef, $current, $ffq_prev); +} + sub record_ffq_prev () { # => ('status', "message") # 'status' may be @@ -861,11 +875,8 @@ sub record_ffq_prev () { # if not ff from some branch we should be ff from, is an fproblem # if "written", will have printed something about that to stdout, # and also some messages about ff checks - my $current = git_get_symref(); - return ('detached', 'detached HEAD') unless defined $current; - return ('weird-symref', 'HEAD symref is not to refs/') - unless $current =~ m{^refs/}; - my $ffq_prev = "refs/$ffq_refprefix/$'"; + my ($status, $message, $current, $ffq_prev) = ffq_prev_branchinfo(); + return ($status, $message) unless $status eq 'branch'; my $currentval = get_head();