/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz

« back to all changes in this revision

Viewing changes to branch.py

  • Committer: Jelmer Vernooij
  • Date: 2007-04-03 17:16:07 UTC
  • mfrom: (187 trunk)
  • mto: This revision was merged to the branch mainline in revision 188.
  • Revision ID: jelmer@samba.org-20070403171607-0zaskazouokrm4cq
Tags: bzr-gtk-0.15.2
PrepareĀ forĀ 0.15.2

Show diffs side-by-side

added added

removed removed

Lines of Context:
27
27
from errors import show_bzr_error
28
28
 
29
29
from bzrlib.branch import Branch
 
30
from bzrlib.config import GlobalConfig
30
31
import bzrlib.errors as errors
31
32
 
32
33
from dialog import error_dialog, info_dialog
33
34
 
34
 
from branchbox import BranchSelectionBox
 
35
from history import UrlHistory
35
36
 
36
37
class BranchDialog(gtk.Dialog):
37
38
    """ New implementation of the Branch dialog. """
38
 
 
39
 
    def __init__(self, path=None, parent=None, remote_path=None):
 
39
    def __init__(self, path=None, parent=None):
40
40
        """ Initialize the Branch dialog. """
41
41
        gtk.Dialog.__init__(self, title="Branch - Olive",
42
42
                                  parent=parent,
48
48
        
49
49
        # Create the widgets
50
50
        self._button_branch = gtk.Button(_("_Branch"), use_underline=True)
51
 
        self._remote_branch = BranchSelectionBox()
52
51
        self._button_revision = gtk.Button('')
 
52
        self._image_browse = gtk.Image()
 
53
        self._filechooser = gtk.FileChooserButton(_("Please select a folder"))
 
54
        self._combo = gtk.ComboBoxEntry()
53
55
        self._label_location = gtk.Label(_("Branch location:"))
54
 
        self._label_location.set_alignment(0, 0.5)
55
56
        self._label_destination = gtk.Label(_("Destination:"))
56
57
        self._label_nick = gtk.Label(_("Branck nick:"))
57
58
        self._label_revision = gtk.Label(_("Revision:"))
58
 
        self._filechooser = gtk.FileChooserButton(_("Please select a folder"))
59
 
        self._filechooser.set_action(gtk.FILE_CHOOSER_ACTION_SELECT_FOLDER)
60
59
        self._hbox_revision = gtk.HBox()
61
60
        self._entry_revision = gtk.Entry()
62
61
        self._entry_nick = gtk.Entry()
64
63
        # Set callbacks
65
64
        self._button_branch.connect('clicked', self._on_branch_clicked)
66
65
        self._button_revision.connect('clicked', self._on_revision_clicked)
67
 
        self._remote_branch.connect('branch-changed', self._on_branch_changed)
68
 
 
 
66
        self._combo.connect('changed', self._on_combo_changed)
 
67
        
69
68
        # Create the table and pack the widgets into it
70
69
        self._table = gtk.Table(rows=3, columns=2)
71
70
        self._table.attach(self._label_location, 0, 1, 0, 1)
72
 
        self._table.attach(self._remote_branch, 1, 2, 0, 1)
73
71
        self._table.attach(self._label_destination, 0, 1, 1, 2)
74
72
        self._table.attach(self._label_nick, 0, 1, 2, 3)
75
73
        self._table.attach(self._label_revision, 0, 1, 3, 4)
 
74
        self._table.attach(self._combo, 1, 2, 0, 1)
76
75
        self._table.attach(self._filechooser, 1, 2, 1, 2)
77
76
        self._table.attach(self._entry_nick, 1, 2, 2, 3)
78
77
        self._table.attach(self._hbox_revision, 1, 2, 3, 4)
79
78
        
80
79
        # Set properties
81
 
        self._image_browse = gtk.Image()
82
80
        self._image_browse.set_from_stock(gtk.STOCK_OPEN, gtk.ICON_SIZE_BUTTON)
83
81
        self._button_revision.set_image(self._image_browse)
84
82
        self._button_revision.set_sensitive(False)
 
83
        self._filechooser.set_action(gtk.FILE_CHOOSER_ACTION_SELECT_FOLDER)
 
84
        self._label_location.set_alignment(0, 0.5)
85
85
        self._label_destination.set_alignment(0, 0.5)
86
86
        self._label_nick.set_alignment(0, 0.5)
87
87
        self._label_revision.set_alignment(0, 0.5)
88
88
        self._table.set_row_spacings(3)
89
89
        self._table.set_col_spacings(3)
90
90
        self.vbox.set_spacing(3)
91
 
        if remote_path is not None:
92
 
            self._remote_branch.set_url(remote_path)
93
91
        if self.path is not None:
94
92
            self._filechooser.set_filename(self.path)
95
93
        
101
99
        
102
100
        # Show the dialog
103
101
        self.vbox.show_all()
 
102
        
 
103
        # Build branch history
 
104
        self._history = UrlHistory(GlobalConfig(), 'branch_history')
 
105
        self._build_history()
 
106
    
 
107
    def _build_history(self):
 
108
        """ Build up the branch history. """
 
109
        self._combo_model = gtk.ListStore(str)
 
110
        for item in self._history.get_entries():
 
111
            self._combo_model.append([ item ])
 
112
        self._combo.set_model(self._combo_model)
 
113
        self._combo.set_text_column(0)
104
114
    
105
115
    def _get_last_revno(self):
106
116
        """ Get the revno of the last revision (if any). """
 
117
        location = self._combo.get_child().get_text()
107
118
        try:
108
 
            br = self._remote_branch.get_branch()
 
119
            br = Branch.open(location)
 
120
        except:
 
121
            return None
 
122
        else:
109
123
            return br.revno()
110
 
        except:
111
 
            pass
112
124
    
113
125
    def _on_revision_clicked(self, button):
114
126
        """ Browse for revision button clicked handler. """
115
127
        from revbrowser import RevisionBrowser
116
128
        
 
129
        location = self._combo.get_child().get_text()
117
130
        
118
131
        try:
119
 
            br = self._remote_branch.get_branch()
 
132
            br = Branch.open(location)
120
133
        except:
121
134
            return
122
 
        revb = RevisionBrowser(br, self)
123
 
        response = revb.run()
124
 
        if response != gtk.RESPONSE_NONE:
125
 
            revb.hide()
126
 
    
127
 
            if response == gtk.RESPONSE_OK:
128
 
                if revb.selected_revno is not None:
129
 
                    self._entry_revision.set_text(revb.selected_revno)
 
135
        else:
 
136
            revb = RevisionBrowser(br, self)
 
137
            response = revb.run()
 
138
            if response != gtk.RESPONSE_NONE:
 
139
                revb.hide()
130
140
        
131
 
            revb.destroy()
 
141
                if response == gtk.RESPONSE_OK:
 
142
                    if revb.selected_revno is not None:
 
143
                        self._entry_revision.set_text(revb.selected_revno)
 
144
            
 
145
                revb.destroy()
132
146
    
133
147
    @show_bzr_error
134
148
    def _on_branch_clicked(self, button):
135
149
        """ Branch button clicked handler. """
136
 
        location = self._remote_branch.get_url()
 
150
        location = self._combo.get_child().get_text()
137
151
        if location is '':
138
152
            error_dialog(_('Missing branch location'),
139
153
                         _('You must specify a branch location.'))
183
197
        
184
198
        self.response(gtk.RESPONSE_OK)
185
199
    
186
 
    def _on_branch_changed(self, widget, event):
 
200
    def _on_combo_changed(self, widget):
187
201
        """ We try to get the last revision if focus lost. """
188
202
        rev = self._get_last_revno()
189
203
        if rev is None:
193
207
            self._entry_revision.set_text(str(rev))
194
208
            self._button_revision.set_sensitive(True)
195
209
            if self._entry_nick.get_text() == '':
196
 
                self._entry_nick.set_text(os.path.basename(self._remote_branch.get_url().rstrip("/\\")))
 
210
                self._entry_nick.set_text(os.path.basename(self._combo.get_child().get_text().rstrip("/\\")))