27
27
from errors import show_bzr_error
29
29
from bzrlib.branch import Branch
30
from bzrlib.config import GlobalConfig
30
31
import bzrlib.errors as errors
32
33
from dialog import error_dialog, info_dialog
34
from branchbox import BranchSelectionBox
35
from history import UrlHistory
36
from olive import Preferences
36
38
class BranchDialog(gtk.Dialog):
37
39
""" New implementation of the Branch dialog. """
49
51
# Create the widgets
50
52
self._button_branch = gtk.Button(_("_Branch"), use_underline=True)
51
self._remote_branch = BranchSelectionBox()
52
53
self._button_revision = gtk.Button('')
54
self._image_browse = gtk.Image()
55
self._filechooser = gtk.FileChooserButton(_("Please select a folder"))
56
self._combo = gtk.ComboBoxEntry()
53
57
self._label_location = gtk.Label(_("Branch location:"))
54
self._label_location.set_alignment(0, 0.5)
55
58
self._label_destination = gtk.Label(_("Destination:"))
56
59
self._label_nick = gtk.Label(_("Branck nick:"))
57
60
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
61
self._hbox_revision = gtk.HBox()
61
62
self._entry_revision = gtk.Entry()
62
63
self._entry_nick = gtk.Entry()
65
66
self._button_branch.connect('clicked', self._on_branch_clicked)
66
67
self._button_revision.connect('clicked', self._on_revision_clicked)
67
self._remote_branch.connect('branch-changed', self._on_branch_changed)
68
self._combo.child.connect('focus-out-event', self._on_combo_changed)
69
70
# Create the table and pack the widgets into it
70
71
self._table = gtk.Table(rows=3, columns=2)
71
72
self._table.attach(self._label_location, 0, 1, 0, 1)
72
self._table.attach(self._remote_branch, 1, 2, 0, 1)
73
73
self._table.attach(self._label_destination, 0, 1, 1, 2)
74
74
self._table.attach(self._label_nick, 0, 1, 2, 3)
75
75
self._table.attach(self._label_revision, 0, 1, 3, 4)
76
self._table.attach(self._combo, 1, 2, 0, 1)
76
77
self._table.attach(self._filechooser, 1, 2, 1, 2)
77
78
self._table.attach(self._entry_nick, 1, 2, 2, 3)
78
79
self._table.attach(self._hbox_revision, 1, 2, 3, 4)
81
self._image_browse = gtk.Image()
82
82
self._image_browse.set_from_stock(gtk.STOCK_OPEN, gtk.ICON_SIZE_BUTTON)
83
83
self._button_revision.set_image(self._image_browse)
84
84
self._button_revision.set_sensitive(False)
85
self._filechooser.set_action(gtk.FILE_CHOOSER_ACTION_SELECT_FOLDER)
86
self._label_location.set_alignment(0, 0.5)
85
87
self._label_destination.set_alignment(0, 0.5)
86
88
self._label_nick.set_alignment(0, 0.5)
87
89
self._label_revision.set_alignment(0, 0.5)
88
90
self._table.set_row_spacings(3)
89
91
self._table.set_col_spacings(3)
90
92
self.vbox.set_spacing(3)
91
if remote_path is not None:
92
self._remote_branch.set_url(remote_path)
93
93
if self.path is not None:
94
94
self._filechooser.set_filename(self.path)
95
if remote_path is not None:
96
self._combo.child.set_text(remote_path)
96
98
# Pack some widgets
97
99
self._hbox_revision.pack_start(self._entry_revision, True, True)
102
104
# Show the dialog
103
105
self.vbox.show_all()
107
# Build branch history
108
self._history = UrlHistory(GlobalConfig(), 'branch_history')
109
self._build_history()
111
def _build_history(self):
112
""" Build up the branch history. """
113
self._combo_model = gtk.ListStore(str)
115
for item in self._history.get_entries():
116
self._combo_model.append([ item ])
119
for item in pref.get_bookmarks():
120
self._combo_model.append([ item ])
122
self._combo.set_model(self._combo_model)
123
self._combo.set_text_column(0)
105
125
def _get_last_revno(self):
106
126
""" Get the revno of the last revision (if any). """
127
location = self._combo.get_child().get_text()
108
br = self._remote_branch.get_branch()
129
br = Branch.open(location)
109
133
return br.revno()
113
135
def _on_revision_clicked(self, button):
114
136
""" Browse for revision button clicked handler. """
115
137
from revbrowser import RevisionBrowser
139
location = self._combo.get_child().get_text()
119
br = self._remote_branch.get_branch()
142
br = Branch.open(location)
122
revb = RevisionBrowser(br, self)
123
response = revb.run()
124
if response != gtk.RESPONSE_NONE:
127
if response == gtk.RESPONSE_OK:
128
if revb.selected_revno is not None:
129
self._entry_revision.set_text(revb.selected_revno)
146
revb = RevisionBrowser(br, self)
147
response = revb.run()
148
if response != gtk.RESPONSE_NONE:
151
if response == gtk.RESPONSE_OK:
152
if revb.selected_revno is not None:
153
self._entry_revision.set_text(revb.selected_revno)
134
158
def _on_branch_clicked(self, button):
135
159
""" Branch button clicked handler. """
136
location = self._remote_branch.get_url()
160
location = self._combo.get_child().get_text()
137
161
if location is '':
138
162
error_dialog(_('Missing branch location'),
139
163
_('You must specify a branch location.'))