diff options
Diffstat (limited to 'third_party/git/git-gui/lib/remote_add.tcl')
-rw-r--r-- | third_party/git/git-gui/lib/remote_add.tcl | 190 |
1 files changed, 0 insertions, 190 deletions
diff --git a/third_party/git/git-gui/lib/remote_add.tcl b/third_party/git/git-gui/lib/remote_add.tcl deleted file mode 100644 index 480a6b30d0a9..000000000000 --- a/third_party/git/git-gui/lib/remote_add.tcl +++ /dev/null @@ -1,190 +0,0 @@ -# git-gui remote adding support -# Copyright (C) 2008 Petr Baudis - -class remote_add { - -field w ; # widget path -field w_name ; # new remote name widget -field w_loc ; # new remote location widget - -field name {}; # name of the remote the user has chosen -field location {}; # location of the remote the user has chosen - -field opt_action fetch; # action to do after registering the remote locally - -constructor dialog {} { - global repo_config use_ttk NS - - make_dialog top w - wm withdraw $top - wm title $top [mc "%s (%s): Add Remote" [appname] [reponame]] - if {$top ne {.}} { - wm geometry $top "+[winfo rootx .]+[winfo rooty .]" - } - - ${NS}::label $w.header -text [mc "Add New Remote"] \ - -font font_uibold -anchor center - pack $w.header -side top -fill x - - ${NS}::frame $w.buttons - ${NS}::button $w.buttons.create -text [mc Add] \ - -default active \ - -command [cb _add] - pack $w.buttons.create -side right - ${NS}::button $w.buttons.cancel -text [mc Cancel] \ - -command [list destroy $w] - pack $w.buttons.cancel -side right -padx 5 - pack $w.buttons -side bottom -fill x -pady 10 -padx 10 - - ${NS}::labelframe $w.desc -text [mc "Remote Details"] - - ${NS}::label $w.desc.name_l -text [mc "Name:"] - set w_name $w.desc.name_t - ${NS}::entry $w_name \ - -width 40 \ - -textvariable @name \ - -validate key \ - -validatecommand [cb _validate_name %d %S] - grid $w.desc.name_l $w_name -sticky we -padx {0 5} - - ${NS}::label $w.desc.loc_l -text [mc "Location:"] - set w_loc $w.desc.loc_t - ${NS}::entry $w_loc \ - -width 40 \ - -textvariable @location - grid $w.desc.loc_l $w_loc -sticky we -padx {0 5} - - grid columnconfigure $w.desc 1 -weight 1 - pack $w.desc -anchor nw -fill x -pady 5 -padx 5 - - ${NS}::labelframe $w.action -text [mc "Further Action"] - - ${NS}::radiobutton $w.action.fetch \ - -text [mc "Fetch Immediately"] \ - -value fetch \ - -variable @opt_action - pack $w.action.fetch -anchor nw - - ${NS}::radiobutton $w.action.push \ - -text [mc "Initialize Remote Repository and Push"] \ - -value push \ - -variable @opt_action - pack $w.action.push -anchor nw - - ${NS}::radiobutton $w.action.none \ - -text [mc "Do Nothing Else Now"] \ - -value none \ - -variable @opt_action - pack $w.action.none -anchor nw - - grid columnconfigure $w.action 1 -weight 1 - pack $w.action -anchor nw -fill x -pady 5 -padx 5 - - bind $w <Visibility> [cb _visible] - bind $w <Key-Escape> [list destroy $w] - bind $w <Key-Return> [cb _add]\;break - wm deiconify $top - tkwait window $w -} - -method _add {} { - global repo_config env - global M1B - - if {$name eq {}} { - tk_messageBox \ - -icon error \ - -type ok \ - -title [wm title $w] \ - -parent $w \ - -message [mc "Please supply a remote name."] - focus $w_name - return - } - - # XXX: We abuse check-ref-format here, but - # that should be ok. - if {[catch {git check-ref-format "remotes/$name"}]} { - tk_messageBox \ - -icon error \ - -type ok \ - -title [wm title $w] \ - -parent $w \ - -message [mc "'%s' is not an acceptable remote name." $name] - focus $w_name - return - } - - if {[catch {add_single_remote $name $location}]} { - tk_messageBox \ - -icon error \ - -type ok \ - -title [wm title $w] \ - -parent $w \ - -message [mc "Failed to add remote '%s' of location '%s'." $name $location] - focus $w_name - return - } - - switch -- $opt_action { - fetch { - set c [console::new \ - [mc "fetch %s" $name] \ - [mc "Fetching the %s" $name]] - console::exec $c [list git fetch $name] - } - push { - set cmds [list] - - # Parse the location - if { [regexp {(?:git\+)?ssh://([^/]+)(/.+)} $location xx host path] - || [regexp {([^:][^:]+):(.+)} $location xx host path]} { - set ssh ssh - if {[info exists env(GIT_SSH)]} { - set ssh $env(GIT_SSH) - } - lappend cmds [list exec $ssh $host mkdir -p $location && git --git-dir=$path init --bare] - } elseif { ! [regexp {://} $location xx] } { - lappend cmds [list exec mkdir -p $location] - lappend cmds [list exec git --git-dir=$location init --bare] - } else { - tk_messageBox \ - -icon error \ - -type ok \ - -title [wm title $w] \ - -parent $w \ - -message [mc "Do not know how to initialize repository at location '%s'." $location] - destroy $w - return - } - - set c [console::new \ - [mc "push %s" $name] \ - [mc "Setting up the %s (at %s)" $name $location]] - - lappend cmds [list exec git push -v --all $name] - console::chain $c $cmds - } - none { - } - } - - destroy $w -} - -method _validate_name {d S} { - if {$d == 1} { - if {[regexp {[~^:?*\[\0- ]} $S]} { - return 0 - } - } - return 1 -} - -method _visible {} { - grab $w - $w_name icursor end - focus $w_name -} - -} |