* [PATCH 0/1] git-gui: add possibility to open currently selected file @ 2019-12-26 19:01 Zoli Szabó via GitGitGadget 2019-12-26 19:01 ` [PATCH 1/1] " Zoli Szabó via GitGitGadget 2019-12-29 19:32 ` [PATCH v2 0/1] git-gui: allow opening " Zoli Szabó via GitGitGadget 0 siblings, 2 replies; 14+ messages in thread From: Zoli Szabó via GitGitGadget @ 2019-12-26 19:01 UTC (permalink / raw) To: git; +Cc: Pratyush Yadav ...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: * Diff header path context menu -> Open; * or double-clicking the diff header path. One "downside" of the approach is that 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: add possibility to open currently selected file git-gui.sh | 26 ++++++++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) base-commit: 23cbe427c44645a3ab0449919e55bade5eb264bc Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-499%2Fzoliszabo%2Fgit-gui%2Fopen-current-file-v1 Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-499/zoliszabo/git-gui/open-current-file-v1 Pull-Request: https://github.com/gitgitgadget/git/pull/499 -- gitgitgadget ^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH 1/1] git-gui: add possibility to open currently selected file 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 ` Zoli Szabó via GitGitGadget 2019-12-27 19:34 ` Pratyush Yadav 2019-12-29 19:32 ` [PATCH v2 0/1] git-gui: allow opening " Zoli Szabó via GitGitGadget 1 sibling, 1 reply; 14+ messages in thread From: Zoli Szabó via GitGitGadget @ 2019-12-26 19:01 UTC (permalink / raw) To: git; +Cc: Pratyush Yadav, Zoli Szabó From: =?UTF-8?q?Zoli=20Szab=C3=B3?= <zoli.szabo@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: - Diff header path context menu -> Open; - or double-clicking the diff header path. One "downside" of the approach is that executable files will be run and not opened for editing. Signed-off-by: Zoli Szabó <zoli.szabo@gmail.com> --- git-gui.sh | 26 ++++++++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/git-gui.sh b/git-gui.sh index c1be733e3e..705b97f7ab 100755 --- a/git-gui.sh +++ b/git-gui.sh @@ -2248,8 +2248,8 @@ proc do_git_gui {} { } } -proc do_explore {} { - global _gitworktree +# Get the system-specific explorer app/command. +proc get_explorer {} { set explorer {} if {[is_Cygwin] || [is_Windows]} { set explorer "explorer.exe" @@ -2259,9 +2259,25 @@ proc do_explore {} { # freedesktop.org-conforming system is our best shot set explorer "xdg-open" } + return $explorer +} + +proc do_explore {} { + global _gitworktree + set explorer [get_explorer] 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)? +proc do_file_open {file} { + global _gitworktree + set explorer [get_explorer] + set full_file_path [file join $_gitworktree $file] + eval exec $explorer [list [file nativename $full_file_path]] & +} + set is_quitting 0 set ret_code 1 @@ -3530,8 +3546,14 @@ $ctxm add command \ -type STRING \ -- $current_diff_path } +$ctxm add command \ + -label [mc Open] \ + -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} # -- Diff Body # -- gitgitgadget ^ permalink raw reply related [flat|nested] 14+ messages in thread
* Re: [PATCH 1/1] git-gui: add possibility to open currently selected file 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 13:23 ` Zoli Szabó 0 siblings, 2 replies; 14+ messages in thread From: Pratyush Yadav @ 2019-12-27 19:34 UTC (permalink / raw) To: Zoli Szabó via GitGitGadget; +Cc: git, Zoli Szabó Hi Zoli, Thanks for the patch. On 26/12/19 07:01PM, Zoli Szabó via GitGitGadget wrote: > From: =?UTF-8?q?Zoli=20Szab=C3=B3?= <zoli.szabo@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: > - Diff header path context menu -> Open; Would it be a better idea to have this option in the diff body context menu (.vpane.lower.diff.body.ctxm) instead? The problem I see with the way its currently done is visibility/discovery. It is not very likely for a user to try and click the file name which doesn't give any indication that it is clickable. So how will someone who hasn't read this commit message know that they can use this neat feature. The diff body context menu is much more "visible" IMO. > - or double-clicking the diff header path. An alternative to the above suggestion would be to make this path underlined and blue in color (like a hyperlink in a web browser). This will give the indication that this is not just plain text. I like the latter idea more, but I don't mind either. > One "downside" of the approach is that executable files will be run > and not opened for editing. FWIW, I do not see it as a downside at all. The menu option is called "open" not "edit". So if you click it, you should expect the file to open. In case its a binary file, executing it is the correct outcome. In case its a text file, opening it in the editor is the correct outcome. > Signed-off-by: Zoli Szabó <zoli.szabo@gmail.com> > --- > git-gui.sh | 26 ++++++++++++++++++++++++-- > 1 file changed, 24 insertions(+), 2 deletions(-) > > diff --git a/git-gui.sh b/git-gui.sh > index c1be733e3e..705b97f7ab 100755 > --- a/git-gui.sh > +++ b/git-gui.sh > @@ -2248,8 +2248,8 @@ proc do_git_gui {} { > } > } > > -proc do_explore {} { > - global _gitworktree > +# Get the system-specific explorer app/command. > +proc get_explorer {} { > set explorer {} Not exactly related to this patch, but this line is redundant. No point in clearing 'explorer' only to set it in the very next if-else chain. > if {[is_Cygwin] || [is_Windows]} { > set explorer "explorer.exe" > @@ -2259,9 +2259,25 @@ proc do_explore {} { > # freedesktop.org-conforming system is our best shot > set explorer "xdg-open" > } > + return $explorer > +} > + > +proc do_explore {} { > + global _gitworktree > + set explorer [get_explorer] > 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). Nitpick: This comment doesn't really add a whole lot of information. The procedure name already make it pretty clear that it will open a file. And it is pretty easy to understand from reading the body of the procedure that it will be relative to the working tree. So, I think it can be removed altogether. But even if you think it should stay, please at least make it more concise. Maybe something like: Open file relative to the working tree by the default associated app. > +# FIXME: What about executables (will be run, not opened for editing)? Again, I think running the executables is the correct behaviour. So I don't think this needs any fixing. > +proc do_file_open {file} { > + global _gitworktree > + set explorer [get_explorer] > + set full_file_path [file join $_gitworktree $file] > + eval exec $explorer [list [file nativename $full_file_path]] & This executes $explorer, which is 'explorer.exe' on Windows. I'm not a heavy Windows user but AFAIK it is a file manager. This makes it quite different from 'xdg-open' which is used to open _any_ file/URL in the user's default application. So it also happens to open _directories_ in the default file explorer which was the original intention of this procedure. Have you tested it on Windows? Does 'explorer.exe' do the correct thing? Looking at MacOS's 'open' man page, I think it should also work like xdg-open and shouldn't be a problem. > +} > + > set is_quitting 0 > set ret_code 1 > > @@ -3530,8 +3546,14 @@ $ctxm add command \ > -type STRING \ > -- $current_diff_path > } > +$ctxm add command \ > + -label [mc Open] \ > + -command { > + do_file_open $current_diff_path > + } Nitpick: no need to make the command multi-line. So, change it to something like: -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} > > # -- Diff Body > # Tested on Linux. Works fine. Looking forward to the re-roll. -- Regards, Pratyush Yadav ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH 1/1] git-gui: add possibility to open currently selected file 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 13:23 ` Zoli Szabó 1 sibling, 1 reply; 14+ messages in thread From: Junio C Hamano @ 2019-12-27 22:32 UTC (permalink / raw) To: Pratyush Yadav; +Cc: Zoli Szabó via GitGitGadget, git, Zoli Szabó Pratyush Yadav <me@yadavpratyush.com> writes: > Have you tested it on Windows? Does 'explorer.exe' do the correct thing? > > Looking at MacOS's 'open' man page, I think it should also work like > xdg-open and shouldn't be a problem. > ... > Tested on Linux. Works fine. Looking forward to the re-roll. > Subject: Re: [PATCH 1/1] git-gui: add possibility to open currently selected file The phrasing on the title is a bit awkward. "add possibility to do X" is better spelled "allow doing X", no? ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: Re: [PATCH 1/1] git-gui: add possibility to open currently selected file 2019-12-27 22:32 ` Junio C Hamano @ 2019-12-29 20:15 ` Zoli Szabó 2019-12-29 23:14 ` Junio C Hamano 0 siblings, 1 reply; 14+ messages in thread From: Zoli Szabó @ 2019-12-29 20:15 UTC (permalink / raw) To: Junio C Hamano, Pratyush Yadav; +Cc: git On 2019.12.28 00:32, Junio C Hamano wrote: > The phrasing on the title is a bit awkward. "add possibility to do > X" is better spelled "allow doing X", no? Thank you, Junio, for the hint. Updated the commit message accordingly (PATCH v2). ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH 1/1] git-gui: add possibility to open currently selected file 2019-12-29 20:15 ` Zoli Szabó @ 2019-12-29 23:14 ` Junio C Hamano 2019-12-30 16:13 ` Zoli Szabó 0 siblings, 1 reply; 14+ messages in thread From: Junio C Hamano @ 2019-12-29 23:14 UTC (permalink / raw) To: Zoli Szabó; +Cc: Pratyush Yadav, git Zoli Szabó <zoli.szabo@gmail.com> writes: > On 2019.12.28 00:32, Junio C Hamano wrote: > >> The phrasing on the title is a bit awkward. "add possibility to do >> X" is better spelled "allow doing X", no? > > Thank you, Junio, for the hint. Updated the commit message accordingly > (PATCH v2). Also, do not start the body of the proposed log message with half sentence. The title is supposed to be a full sentence. ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: Re: [PATCH 1/1] git-gui: add possibility to open currently selected file 2019-12-29 23:14 ` Junio C Hamano @ 2019-12-30 16:13 ` Zoli Szabó 0 siblings, 0 replies; 14+ messages in thread From: Zoli Szabó @ 2019-12-30 16:13 UTC (permalink / raw) To: Junio C Hamano; +Cc: Pratyush Yadav, git Adapted the commit message once again (PATCH v3). On 2019.12.30 01:14, Junio C Hamano wrote: > Zoli Szabó <zoli.szabo@gmail.com> writes: > >> On 2019.12.28 00:32, Junio C Hamano wrote: >> >>> The phrasing on the title is a bit awkward. "add possibility to do >>> X" is better spelled "allow doing X", no? >> >> Thank you, Junio, for the hint. Updated the commit message accordingly >> (PATCH v2). > > Also, do not start the body of the proposed log message with half > sentence. The title is supposed to be a full sentence. > > > ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: Re: [PATCH 1/1] git-gui: add possibility to open currently selected file 2019-12-27 19:34 ` Pratyush Yadav 2019-12-27 22:32 ` Junio C Hamano @ 2019-12-29 13:23 ` Zoli Szabó 1 sibling, 0 replies; 14+ messages in thread From: Zoli Szabó @ 2019-12-29 13:23 UTC (permalink / raw) To: Pratyush Yadav; +Cc: git Hi Pratyush, Thanks for your thorough review. On 2019.12.27 21:34, Pratyush Yadav wrote: >> ...This change enables just that by: >> - Diff header path context menu -> Open; > > Would it be a better idea to have this option in the diff body context > menu (.vpane.lower.diff.body.ctxm) instead? The problem I see with the > way its currently done is visibility/discovery. It is not very likely > for a user to try and click the file name which doesn't give any > indication that it is clickable. So how will someone who hasn't read > this commit message know that they can use this neat feature. The diff > body context menu is much more "visible" IMO. > >> - or double-clicking the diff header path. > > An alternative to the above suggestion would be to make this path > underlined and blue in color (like a hyperlink in a web browser). This > will give the indication that this is not just plain text. > > I like the latter idea more, but I don't mind either. For me, the body context menu holds the diff-related options, I am not sure the "Open" fits in there. But I do like your suggestion of making the filename web browser-link-like. I'll try to implement that. >> One "downside" of the approach is that executable files will be run >> and not opened for editing. > > FWIW, I do not see it as a downside at all. The menu option is called > "open" not "edit". So if you click it, you should expect the file to > open. In case its a binary file, executing it is the correct outcome. In > case its a text file, opening it in the editor is the correct outcome. Alright then. >> +proc do_file_open {file} { >> + global _gitworktree >> + set explorer [get_explorer] >> + set full_file_path [file join $_gitworktree $file] >> + eval exec $explorer [list [file nativename $full_file_path]] & > > This executes $explorer, which is 'explorer.exe' on Windows. I'm not a > heavy Windows user but AFAIK it is a file manager. This makes it quite > different from 'xdg-open' which is used to open _any_ file/URL in the > user's default application. So it also happens to open _directories_ in > the default file explorer which was the original intention of this > procedure. > > Have you tested it on Windows? Does 'explorer.exe' do the correct thing? > > Looking at MacOS's 'open' man page, I think it should also work like > xdg-open and shouldn't be a problem. I am in fact working on this patch on Windows. explorer.exe works also for files and even brings up the "Open with..." dialog for not-recognized file types. > Tested on Linux. Works fine. Looking forward to the re-roll. Thanks for testing it on Linux. Since I am working on Windows, I just read about `xdg-open` and `open` and assumed everything should work OK. All other points I agree with you and will push a new version of the patch. Thanks, Zoli ^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH v2 0/1] git-gui: allow opening currently selected file 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-29 19:32 ` Zoli Szabó via GitGitGadget 2019-12-29 19:32 ` [PATCH v2 1/1] " Zoli Szabó via GitGitGadget 2019-12-30 15:56 ` [PATCH v3 0/1] " Zoli Szabó via GitGitGadget 1 sibling, 2 replies; 14+ messages in thread From: Zoli Szabó via GitGitGadget @ 2019-12-29 19:32 UTC (permalink / raw) To: git; +Cc: Pratyush Yadav ...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 ^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH v2 1/1] git-gui: allow opening currently selected file 2019-12-29 19:32 ` [PATCH v2 0/1] git-gui: allow opening " Zoli Szabó via GitGitGadget @ 2019-12-29 19:32 ` Zoli Szabó via GitGitGadget 2019-12-30 15:56 ` [PATCH v3 0/1] " Zoli Szabó via GitGitGadget 1 sibling, 0 replies; 14+ messages in thread From: Zoli Szabó via GitGitGadget @ 2019-12-29 19:32 UTC (permalink / raw) To: git; +Cc: Pratyush Yadav, Zoli Szabó From: =?UTF-8?q?Zoli=20Szab=C3=B3?= <zoli.szabo@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> --- git-gui.sh | 29 ++++++++++++++++++++++++----- 1 file changed, 24 insertions(+), 5 deletions(-) diff --git a/git-gui.sh b/git-gui.sh index c1be733e3e..8920e4ddb0 100755 --- a/git-gui.sh +++ b/git-gui.sh @@ -2248,9 +2248,8 @@ proc do_git_gui {} { } } -proc do_explore {} { - global _gitworktree - set explorer {} +# Get the system-specific explorer app/command. +proc get_explorer {} { if {[is_Cygwin] || [is_Windows]} { set explorer "explorer.exe" } elseif {[is_MacOSX]} { @@ -2259,9 +2258,23 @@ proc do_explore {} { # freedesktop.org-conforming system is our best shot set explorer "xdg-open" } + return $explorer +} + +proc do_explore {} { + global _gitworktree + set explorer [get_explorer] eval exec $explorer [list [file nativename $_gitworktree]] & } +# Open file relative to the working tree by the default associated app. +proc do_file_open {file} { + global _gitworktree + set explorer [get_explorer] + set full_file_path [file join $_gitworktree $file] + eval exec $explorer [list [file nativename $full_file_path]] & +} + set is_quitting 0 set ret_code 1 @@ -3513,9 +3526,11 @@ tlabel .vpane.lower.diff.header.file \ -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 @@ -3530,8 +3545,12 @@ $ctxm add command \ -type STRING \ -- $current_diff_path } +$ctxm add command \ + -label [mc Open] \ + -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 <Button-1> {do_file_open $current_diff_path} # -- Diff Body # -- gitgitgadget ^ permalink raw reply related [flat|nested] 14+ messages in thread
* [PATCH v3 0/1] git-gui: allow opening currently selected file 2019-12-29 19:32 ` [PATCH v2 0/1] git-gui: allow opening " Zoli Szabó via GitGitGadget 2019-12-29 19:32 ` [PATCH v2 1/1] " Zoli Szabó via GitGitGadget @ 2019-12-30 15:56 ` 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 1 sibling, 1 reply; 14+ messages in thread From: Zoli Szabó via GitGitGadget @ 2019-12-30 15:56 UTC (permalink / raw) To: git; +Cc: Pratyush Yadav ...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 in default app 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-v3 Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-499/zoliszabo/git-gui/open-current-file-v3 Pull-Request: https://github.com/gitgitgadget/git/pull/499 Range-diff vs v2: 1: a6fde256f8 ! 1: 1b2363be72 git-gui: allow opening currently selected file @@ -1,8 +1,6 @@ Author: Zoli Szabó <zoli.szabo@gmail.com> - git-gui: allow opening currently selected file - - ...in the default associated app (e.g. in a text editor / IDE). + git-gui: allow opening currently selected file in default app 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, -- gitgitgadget ^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH v3 1/1] git-gui: allow opening currently selected file in default app 2019-12-30 15:56 ` [PATCH v3 0/1] " Zoli Szabó via GitGitGadget @ 2019-12-30 15:56 ` Zoli Szabó via GitGitGadget 2019-12-30 19:41 ` Pratyush Yadav 0 siblings, 1 reply; 14+ messages in thread From: Zoli Szabó via GitGitGadget @ 2019-12-30 15:56 UTC (permalink / raw) To: git; +Cc: Pratyush Yadav, Zoli Szabó From: =?UTF-8?q?Zoli=20Szab=C3=B3?= <zoli.szabo@gmail.com> 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> --- git-gui.sh | 29 ++++++++++++++++++++++++----- 1 file changed, 24 insertions(+), 5 deletions(-) diff --git a/git-gui.sh b/git-gui.sh index c1be733e3e..8920e4ddb0 100755 --- a/git-gui.sh +++ b/git-gui.sh @@ -2248,9 +2248,8 @@ proc do_git_gui {} { } } -proc do_explore {} { - global _gitworktree - set explorer {} +# Get the system-specific explorer app/command. +proc get_explorer {} { if {[is_Cygwin] || [is_Windows]} { set explorer "explorer.exe" } elseif {[is_MacOSX]} { @@ -2259,9 +2258,23 @@ proc do_explore {} { # freedesktop.org-conforming system is our best shot set explorer "xdg-open" } + return $explorer +} + +proc do_explore {} { + global _gitworktree + set explorer [get_explorer] eval exec $explorer [list [file nativename $_gitworktree]] & } +# Open file relative to the working tree by the default associated app. +proc do_file_open {file} { + global _gitworktree + set explorer [get_explorer] + set full_file_path [file join $_gitworktree $file] + eval exec $explorer [list [file nativename $full_file_path]] & +} + set is_quitting 0 set ret_code 1 @@ -3513,9 +3526,11 @@ tlabel .vpane.lower.diff.header.file \ -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 @@ -3530,8 +3545,12 @@ $ctxm add command \ -type STRING \ -- $current_diff_path } +$ctxm add command \ + -label [mc Open] \ + -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 <Button-1> {do_file_open $current_diff_path} # -- Diff Body # -- gitgitgadget ^ permalink raw reply related [flat|nested] 14+ messages in thread
* Re: [PATCH v3 1/1] git-gui: allow opening currently selected file in default app 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ó 0 siblings, 1 reply; 14+ messages in thread From: Pratyush Yadav @ 2019-12-30 19:41 UTC (permalink / raw) To: Zoli Szabó via GitGitGadget; +Cc: git, Zoli Szabó Hi Zoli, On 30/12/19 03:56PM, Zoli Szabó via GitGitGadget wrote: > From: =?UTF-8?q?Zoli=20Szab=C3=B3?= <zoli.szabo@gmail.com> > > 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; Semi-colon left in by mistake? > > Note: executable files will be run and not opened for editing. > > Signed-off-by: Zoli Szabó <zoli.szabo@gmail.com> > --- > git-gui.sh | 29 ++++++++++++++++++++++++----- > 1 file changed, 24 insertions(+), 5 deletions(-) > > diff --git a/git-gui.sh b/git-gui.sh > index c1be733e3e..8920e4ddb0 100755 > --- a/git-gui.sh > +++ b/git-gui.sh > @@ -2259,9 +2258,23 @@ proc do_explore {} { > +# Open file relative to the working tree by the default associated > app. > +proc do_file_open {file} { > + global _gitworktree > + set explorer [get_explorer] > + set full_file_path [file join $_gitworktree $file] > + eval exec $explorer [list [file nativename $full_file_path]] & IIUC, this line can be simplified to: exec $explorer [file nativename $full_file_path] & It works fine for me including on files with spaces in their names, but a test on Windows would be appreciated just to rule out any hidden surprises. No need to send a re-roll just for these two small things. I have updated the commit locally before pushing the new version out [0]. The rest of the patch looks good. Will merge. Thanks. > +} > + > set is_quitting 0 > set ret_code 1 > [0] https://github.com/prati0100/git-gui/tree/zs/open-current-file -- Regards, Pratyush Yadav ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: Re: [PATCH v3 1/1] git-gui: allow opening currently selected file in default app 2019-12-30 19:41 ` Pratyush Yadav @ 2019-12-30 20:31 ` Zoli Szabó 0 siblings, 0 replies; 14+ messages in thread From: Zoli Szabó @ 2019-12-30 20:31 UTC (permalink / raw) To: Pratyush Yadav; +Cc: git On 2019.12.30 21:41, Pratyush Yadav wrote: > Hi Zoli, > > On 30/12/19 03:56PM, Zoli Szabó via GitGitGadget wrote: >> From: =?UTF-8?q?Zoli=20Szab=C3=B3?= <zoli.szabo@gmail.com> >> >> 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; > > Semi-colon left in by mistake? > Yes, that should have been a simple period (.), signaling the end of the sentence. >> + eval exec $explorer [list [file nativename $full_file_path]] & > > IIUC, this line can be simplified to: > > exec $explorer [file nativename $full_file_path] & > > It works fine for me including on files with spaces in their names, but > a test on Windows would be appreciated just to rule out any hidden > surprises. You're right. It can be simplified like you have proposed. Tested it and works correctly also on Windows. (Since I have copied that line from the existing `do_explore` proc, the same simplification can be done there too. (I did not realize this myself, since I am just learning some TCL in order to have this feature in Git GUI...)) > > No need to send a re-roll just for these two small things. I have > updated the commit locally before pushing the new version out [0]. The > rest of the patch looks good. Will merge. Thanks. > > [0] https://github.com/prati0100/git-gui/tree/zs/open-current-file > Thank you very much for your support! All the best, Zoli ^ permalink raw reply [flat|nested] 14+ messages in thread
end of thread, other threads:[~2019-12-30 20:31 UTC | newest] Thread overview: 14+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 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 ` [PATCH v2 0/1] git-gui: allow opening " Zoli Szabó via GitGitGadget 2019-12-29 19:32 ` [PATCH v2 1/1] " 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ó
Code repositories for project(s) associated with this public inbox https://80x24.org/mirrors/git.git This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).