contrib / difftool / git-difftoolon commit Merge branch 'maint-1.6.1' into maint (c0250b6)
   1#!/usr/bin/env perl
   2# Copyright (c) 2009 David Aguilar
   3#
   4# This is a wrapper around the GIT_EXTERNAL_DIFF-compatible
   5# git-difftool-helper script.  This script exports
   6# GIT_EXTERNAL_DIFF and GIT_PAGER for use by git, and
   7# GIT_DIFFTOOL_NO_PROMPT and GIT_MERGE_TOOL for use by git-difftool-helper.
   8# Any arguments that are unknown to this script are forwarded to 'git diff'.
   9
  10use strict;
  11use warnings;
  12use Cwd qw(abs_path);
  13use File::Basename qw(dirname);
  14
  15my $DIR = abs_path(dirname($0));
  16
  17
  18sub usage
  19{
  20        print << 'USAGE';
  21usage: git difftool [--tool=<tool>] [--no-prompt] ["git diff" options]
  22USAGE
  23        exit 1;
  24}
  25
  26sub setup_environment
  27{
  28        $ENV{PATH} = "$DIR:$ENV{PATH}";
  29        $ENV{GIT_PAGER} = '';
  30        $ENV{GIT_EXTERNAL_DIFF} = 'git-difftool-helper';
  31}
  32
  33sub exe
  34{
  35        my $exe = shift;
  36        return defined $ENV{COMSPEC} ? "$exe.exe" : $exe;
  37}
  38
  39sub generate_command
  40{
  41        my @command = (exe('git'), 'diff');
  42        my $skip_next = 0;
  43        my $idx = -1;
  44        for my $arg (@ARGV) {
  45                $idx++;
  46                if ($skip_next) {
  47                        $skip_next = 0;
  48                        next;
  49                }
  50                if ($arg eq '-t' or $arg eq '--tool') {
  51                        usage() if $#ARGV <= $idx;
  52                        $ENV{GIT_MERGE_TOOL} = $ARGV[$idx + 1];
  53                        $skip_next = 1;
  54                        next;
  55                }
  56                if ($arg =~ /^--tool=/) {
  57                        $ENV{GIT_MERGE_TOOL} = substr($arg, 7);
  58                        next;
  59                }
  60                if ($arg eq '--no-prompt') {
  61                        $ENV{GIT_DIFFTOOL_NO_PROMPT} = 'true';
  62                        next;
  63                }
  64                if ($arg eq '-h' or $arg eq '--help') {
  65                        usage();
  66                }
  67                push @command, $arg;
  68        }
  69        return @command
  70}
  71
  72setup_environment();
  73exec(generate_command());