From: "Zoli Szabó via GitGitGadget" <gitgitgadget@gmail.com>
To: git@vger.kernel.org
Cc: Pratyush Yadav <me@yadavpratyush.com>
Subject: [PATCH v2 0/1] git-gui: allow opening currently selected file
Date: Sun, 29 Dec 2019 19:32:09 +0000 [thread overview]
Message-ID: <pull.499.v2.git.1577647930.gitgitgadget@gmail.com> (raw)
In-Reply-To: <pull.499.git.1577386915.gitgitgadget@gmail.com>
...in the default associated app (e.g. in a text editor / IDE).
Many times there's the need to quickly open a source file (the one you're
looking at in Git GUI) in the predefined text editor / IDE. Of course, the
file can be searched for in your preferred file manager or directly in the
text editor, but having the option to directly open the current file from
Git GUI would be just faster. This change enables just that by:
* clicking the diff header path (which is now highlighted as a hyperlink)
* or diff header path context menu -> Open;
Note: executable files will be run and not opened for editing.
Signed-off-by: Zoli Szabó zoli.szabo@gmail.com [zoli.szabo@gmail.com]
Zoli Szabó (1):
git-gui: allow opening currently selected file
git-gui.sh | 29 ++++++++++++++++++++++++-----
1 file changed, 24 insertions(+), 5 deletions(-)
base-commit: 23cbe427c44645a3ab0449919e55bade5eb264bc
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-499%2Fzoliszabo%2Fgit-gui%2Fopen-current-file-v2
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-499/zoliszabo/git-gui/open-current-file-v2
Pull-Request: https://github.com/gitgitgadget/git/pull/499
Range-diff vs v1:
1: fce80f1b95 ! 1: a6fde256f8 git-gui: add possibility to open currently selected file
@@ -1,6 +1,6 @@
Author: Zoli Szabó <zoli.szabo@gmail.com>
- git-gui: add possibility to open currently selected file
+ git-gui: allow opening currently selected file
...in the default associated app (e.g. in a text editor / IDE).
@@ -9,11 +9,10 @@
the file can be searched for in your preferred file manager or directly
in the text editor, but having the option to directly open the current
file from Git GUI would be just faster. This change enables just that by:
- - Diff header path context menu -> Open;
- - or double-clicking the diff header path.
+ - clicking the diff header path (which is now highlighted as a hyperlink)
+ - or diff header path context menu -> Open;
- One "downside" of the approach is that executable files will be run
- and not opened for editing.
+ Note: executable files will be run and not opened for editing.
Signed-off-by: Zoli Szabó <zoli.szabo@gmail.com>
@@ -26,11 +25,12 @@
-proc do_explore {} {
- global _gitworktree
+- set explorer {}
+# Get the system-specific explorer app/command.
+proc get_explorer {} {
- set explorer {}
if {[is_Cygwin] || [is_Windows]} {
set explorer "explorer.exe"
+ } elseif {[is_MacOSX]} {
@@
# freedesktop.org-conforming system is our best shot
set explorer "xdg-open"
@@ -44,9 +44,7 @@
eval exec $explorer [list [file nativename $_gitworktree]] &
}
-+# Trigger opening a file (relative to the working tree) by the default
-+# associated app of the OS (e.g. a text editor or IDE).
-+# FIXME: What about executables (will be run, not opened for editing)?
++# Open file relative to the working tree by the default associated app.
+proc do_file_open {file} {
+ global _gitworktree
+ set explorer [get_explorer]
@@ -57,18 +55,30 @@
set is_quitting 0
set ret_code 1
+@@
+ -justify left
+ tlabel .vpane.lower.diff.header.path \
+ -background gold \
+- -foreground black \
++ -foreground blue \
+ -anchor w \
+- -justify left
++ -justify left \
++ -font [eval font create [font configure font_ui] -underline 1] \
++ -cursor hand2
+ pack .vpane.lower.diff.header.status -side left
+ pack .vpane.lower.diff.header.file -side left
+ pack .vpane.lower.diff.header.path -fill x
@@
-type STRING \
-- $current_diff_path
}
+$ctxm add command \
+ -label [mc Open] \
-+ -command {
-+ do_file_open $current_diff_path
-+ }
++ -command {do_file_open $current_diff_path}
lappend diff_actions [list $ctxm entryconf [$ctxm index last] -state]
bind_button3 .vpane.lower.diff.header.path "tk_popup $ctxm %X %Y"
-+bind .vpane.lower.diff.header.path <Double-1> {do_file_open $current_diff_path}
++bind .vpane.lower.diff.header.path <Button-1> {do_file_open $current_diff_path}
# -- Diff Body
#
--
gitgitgadget
next prev parent reply other threads:[~2019-12-29 19:32 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-12-26 19:01 [PATCH 0/1] git-gui: add possibility to open currently selected file Zoli Szabó via GitGitGadget
2019-12-26 19:01 ` [PATCH 1/1] " Zoli Szabó via GitGitGadget
2019-12-27 19:34 ` Pratyush Yadav
2019-12-27 22:32 ` Junio C Hamano
2019-12-29 20:15 ` Zoli Szabó
2019-12-29 23:14 ` Junio C Hamano
2019-12-30 16:13 ` Zoli Szabó
2019-12-29 13:23 ` Zoli Szabó
2019-12-29 19:32 ` Zoli Szabó via GitGitGadget [this message]
2019-12-29 19:32 ` [PATCH v2 1/1] git-gui: allow opening " Zoli Szabó via GitGitGadget
2019-12-30 15:56 ` [PATCH v3 0/1] " Zoli Szabó via GitGitGadget
2019-12-30 15:56 ` [PATCH v3 1/1] git-gui: allow opening currently selected file in default app Zoli Szabó via GitGitGadget
2019-12-30 19:41 ` Pratyush Yadav
2019-12-30 20:31 ` Zoli Szabó
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=pull.499.v2.git.1577647930.gitgitgadget@gmail.com \
--to=gitgitgadget@gmail.com \
--cc=git@vger.kernel.org \
--cc=me@yadavpratyush.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.