| # 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 |
| } |
| |
| } |