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
from bzrlib.plugins.gtk import _i18n
34
33
from dialog import error_dialog, info_dialog
36
from branchbox import BranchSelectionBox
35
from history import UrlHistory
36
from olive import Preferences
38
38
class BranchDialog(gtk.Dialog):
39
39
""" New implementation of the Branch dialog. """
41
def __init__(self, path=None, parent=None, remote_path=None):
40
def __init__(self, path=None, parent=None):
42
41
""" Initialize the Branch dialog. """
43
42
gtk.Dialog.__init__(self, title="Branch - Olive",
51
50
# Create the widgets
52
self._button_branch = gtk.Button(_i18n("_Branch"), use_underline=True)
53
self._remote_branch = BranchSelectionBox()
51
self._button_branch = gtk.Button(_("_Branch"), use_underline=True)
54
52
self._button_revision = gtk.Button('')
55
self._label_location = gtk.Label(_i18n("Branch location:"))
56
self._label_location.set_alignment(0, 0.5)
57
self._label_destination = gtk.Label(_i18n("Destination:"))
58
self._label_nick = gtk.Label(_i18n("Branck nick:"))
59
self._label_revision = gtk.Label(_i18n("Revision:"))
60
self._filechooser = gtk.FileChooserButton(_i18n("Please select a folder"))
61
self._filechooser.set_action(gtk.FILE_CHOOSER_ACTION_SELECT_FOLDER)
53
self._image_browse = gtk.Image()
54
self._filechooser = gtk.FileChooserButton(_("Please select a folder"))
55
self._combo = gtk.ComboBoxEntry()
56
self._label_location = gtk.Label(_("Branch location:"))
57
self._label_destination = gtk.Label(_("Destination:"))
58
self._label_nick = gtk.Label(_("Branck nick:"))
59
self._label_revision = gtk.Label(_("Revision:"))
62
60
self._hbox_revision = gtk.HBox()
63
61
self._entry_revision = gtk.Entry()
64
62
self._entry_nick = gtk.Entry()
67
65
self._button_branch.connect('clicked', self._on_branch_clicked)
68
66
self._button_revision.connect('clicked', self._on_revision_clicked)
69
self._remote_branch.connect('branch-changed', self._on_branch_changed)
67
self._combo.child.connect('focus-out-event', self._on_combo_changed)
71
69
# Create the table and pack the widgets into it
72
70
self._table = gtk.Table(rows=3, columns=2)
73
71
self._table.attach(self._label_location, 0, 1, 0, 1)
74
self._table.attach(self._remote_branch, 1, 2, 0, 1)
75
72
self._table.attach(self._label_destination, 0, 1, 1, 2)
76
73
self._table.attach(self._label_nick, 0, 1, 2, 3)
77
74
self._table.attach(self._label_revision, 0, 1, 3, 4)
75
self._table.attach(self._combo, 1, 2, 0, 1)
78
76
self._table.attach(self._filechooser, 1, 2, 1, 2)
79
77
self._table.attach(self._entry_nick, 1, 2, 2, 3)
80
78
self._table.attach(self._hbox_revision, 1, 2, 3, 4)
83
self._image_browse = gtk.Image()
84
81
self._image_browse.set_from_stock(gtk.STOCK_OPEN, gtk.ICON_SIZE_BUTTON)
85
82
self._button_revision.set_image(self._image_browse)
86
83
self._button_revision.set_sensitive(False)
84
self._filechooser.set_action(gtk.FILE_CHOOSER_ACTION_SELECT_FOLDER)
85
self._label_location.set_alignment(0, 0.5)
87
86
self._label_destination.set_alignment(0, 0.5)
88
87
self._label_nick.set_alignment(0, 0.5)
89
88
self._label_revision.set_alignment(0, 0.5)
90
89
self._table.set_row_spacings(3)
91
90
self._table.set_col_spacings(3)
92
91
self.vbox.set_spacing(3)
93
if remote_path is not None:
94
self._remote_branch.set_url(remote_path)
95
92
if self.path is not None:
96
93
self._filechooser.set_filename(self.path)
104
101
# Show the dialog
105
102
self.vbox.show_all()
104
# Build branch history
105
self._history = UrlHistory(GlobalConfig(), 'branch_history')
106
self._build_history()
108
def _build_history(self):
109
""" Build up the branch history. """
110
self._combo_model = gtk.ListStore(str)
112
for item in self._history.get_entries():
113
self._combo_model.append([ item ])
116
for item in pref.get_bookmarks():
117
self._combo_model.append([ item ])
119
self._combo.set_model(self._combo_model)
120
self._combo.set_text_column(0)
107
122
def _get_last_revno(self):
108
123
""" Get the revno of the last revision (if any). """
124
location = self._combo.get_child().get_text()
110
br = self._remote_branch.get_branch()
126
br = Branch.open(location)
111
130
return br.revno()
115
132
def _on_revision_clicked(self, button):
116
133
""" Browse for revision button clicked handler. """
117
134
from revbrowser import RevisionBrowser
136
location = self._combo.get_child().get_text()
121
br = self._remote_branch.get_branch()
139
br = Branch.open(location)
124
revb = RevisionBrowser(br, self)
125
response = revb.run()
126
if response != gtk.RESPONSE_NONE:
129
if response == gtk.RESPONSE_OK:
130
if revb.selected_revno is not None:
131
self._entry_revision.set_text(revb.selected_revno)
143
revb = RevisionBrowser(br, self)
144
response = revb.run()
145
if response != gtk.RESPONSE_NONE:
148
if response == gtk.RESPONSE_OK:
149
if revb.selected_revno is not None:
150
self._entry_revision.set_text(revb.selected_revno)
136
155
def _on_branch_clicked(self, button):
137
156
""" Branch button clicked handler. """
138
location = self._remote_branch.get_url()
157
location = self._combo.get_child().get_text()
139
158
if location is '':
140
error_dialog(_i18n('Missing branch location'),
141
_i18n('You must specify a branch location.'))
159
error_dialog(_('Missing branch location'),
160
_('You must specify a branch location.'))
144
163
destination = self._filechooser.get_filename()
182
info_dialog(_i18n('Branching successful'),
183
_i18n('%d revision(s) branched.') % revs)
201
self._history.add_entry(location)
202
info_dialog(_('Branching successful'),
203
_('%d revision(s) branched.') % revs)
185
205
self.response(gtk.RESPONSE_OK)
187
def _on_branch_changed(self, widget, event):
207
def _on_combo_changed(self, widget, event):
188
208
""" We try to get the last revision if focus lost. """
189
209
rev = self._get_last_revno()
191
self._entry_revision.set_text(_i18n('N/A'))
211
self._entry_revision.set_text(_('N/A'))
192
212
self._button_revision.set_sensitive(False)
194
214
self._entry_revision.set_text(str(rev))
195
215
self._button_revision.set_sensitive(True)
196
216
if self._entry_nick.get_text() == '':
197
self._entry_nick.set_text(os.path.basename(self._remote_branch.get_url().rstrip("/\\")))
217
self._entry_nick.set_text(os.path.basename(self._combo.get_child().get_text().rstrip("/\\")))