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