/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: Szilveszter Farkas (Phanatic)
  • Date: 2007-05-17 16:12:27 UTC
  • mto: This revision was merged to the branch mainline in revision 201.
  • Revision ID: szilveszter.farkas@gmail.com-20070517161227-9e37lj2rm2t0cwj6
Some small modifications to Branch, Checkout and Info to support remote branches.

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
 
17
17
import os
18
18
 
19
 
from gi.repository import Gtk
20
 
 
21
 
from bzrlib import (
22
 
    errors,
23
 
    )
 
19
try:
 
20
    import pygtk
 
21
    pygtk.require("2.0")
 
22
except:
 
23
    pass
 
24
 
 
25
import gtk
 
26
 
 
27
from errors import show_bzr_error
 
28
 
24
29
from bzrlib.branch import Branch
25
 
from bzrlib.transport import get_transport
26
 
 
27
 
from bzrlib.plugins.gtk.dialog import error_dialog, info_dialog
28
 
from bzrlib.plugins.gtk.errors import show_bzr_error
29
 
from bzrlib.plugins.gtk.i18n import _i18n
30
 
from bzrlib.plugins.gtk.branchbox import BranchSelectionBox
31
 
 
32
 
 
33
 
class BranchDialog(Gtk.Dialog):
 
30
from bzrlib.config import GlobalConfig
 
31
import bzrlib.errors as errors
 
32
 
 
33
from dialog import error_dialog, info_dialog
 
34
 
 
35
from history import UrlHistory
 
36
from olive import Preferences
 
37
 
 
38
class BranchDialog(gtk.Dialog):
34
39
    """ New implementation of the Branch dialog. """
35
 
 
36
40
    def __init__(self, path=None, parent=None, remote_path=None):
37
41
        """ Initialize the Branch dialog. """
38
 
        super(BranchDialog, self).__init__(
39
 
            title="Branch - Olive", parent=parent, flags=0,
40
 
            buttons=(Gtk.STOCK_CANCEL, Gtk.ResponseType.CANCEL))
41
 
 
 
42
        gtk.Dialog.__init__(self, title="Branch - Olive",
 
43
                                  parent=parent,
 
44
                                  flags=0,
 
45
                                  buttons=(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL))
 
46
        
42
47
        # Get arguments
43
48
        self.path = path
44
 
 
 
49
        
45
50
        # Create the widgets
46
 
        self._button_branch = Gtk.Button(_i18n("_Branch"), use_underline=True)
47
 
        self._remote_branch = BranchSelectionBox()
48
 
        self._button_revision = Gtk.Button('')
49
 
        self._label_location = Gtk.Label(label=_i18n("Branch location:"))
50
 
        self._label_location.set_alignment(0, 0.5)
51
 
        self._label_destination = Gtk.Label(label=_i18n("Destination:"))
52
 
        self._label_nick = Gtk.Label(label=_i18n("Branck nick:"))
53
 
        self._label_revision = Gtk.Label(label=_i18n("Revision:"))
54
 
        self._filechooser = Gtk.FileChooserButton(_i18n("Please select a folder"))
55
 
        self._filechooser.set_action(Gtk.FileChooserAction.SELECT_FOLDER)
56
 
        self._hbox_revision = Gtk.HBox()
57
 
        self._entry_revision = Gtk.Entry()
58
 
        self._entry_nick = Gtk.Entry()
59
 
 
 
51
        self._button_branch = gtk.Button(_("_Branch"), use_underline=True)
 
52
        self._button_revision = gtk.Button('')
 
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:"))
 
60
        self._hbox_revision = gtk.HBox()
 
61
        self._entry_revision = gtk.Entry()
 
62
        self._entry_nick = gtk.Entry()
 
63
        
60
64
        # Set callbacks
61
65
        self._button_branch.connect('clicked', self._on_branch_clicked)
62
66
        self._button_revision.connect('clicked', self._on_revision_clicked)
63
 
        self._remote_branch.connect('branch-changed', self._on_branch_changed)
64
 
 
 
67
        self._combo.child.connect('focus-out-event', self._on_combo_changed)
 
68
        
65
69
        # Create the table and pack the widgets into it
66
 
        self._table = Gtk.Table(rows=3, columns=2)
 
70
        self._table = gtk.Table(rows=3, columns=2)
67
71
        self._table.attach(self._label_location, 0, 1, 0, 1)
68
 
        self._table.attach(self._remote_branch, 1, 2, 0, 1)
69
72
        self._table.attach(self._label_destination, 0, 1, 1, 2)
70
73
        self._table.attach(self._label_nick, 0, 1, 2, 3)
71
74
        self._table.attach(self._label_revision, 0, 1, 3, 4)
 
75
        self._table.attach(self._combo, 1, 2, 0, 1)
72
76
        self._table.attach(self._filechooser, 1, 2, 1, 2)
73
77
        self._table.attach(self._entry_nick, 1, 2, 2, 3)
74
78
        self._table.attach(self._hbox_revision, 1, 2, 3, 4)
75
 
 
 
79
        
76
80
        # Set properties
77
 
        self._image_browse = Gtk.Image()
78
 
        self._image_browse.set_from_stock(Gtk.STOCK_OPEN, Gtk.IconSize.BUTTON)
 
81
        self._image_browse.set_from_stock(gtk.STOCK_OPEN, gtk.ICON_SIZE_BUTTON)
79
82
        self._button_revision.set_image(self._image_browse)
80
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)
81
86
        self._label_destination.set_alignment(0, 0.5)
82
87
        self._label_nick.set_alignment(0, 0.5)
83
88
        self._label_revision.set_alignment(0, 0.5)
84
89
        self._table.set_row_spacings(3)
85
90
        self._table.set_col_spacings(3)
86
 
        self.get_content_area().set_spacing(3)
87
 
        if remote_path is not None:
88
 
            self._remote_branch.set_url(remote_path)
 
91
        self.vbox.set_spacing(3)
89
92
        if self.path is not None:
90
93
            self._filechooser.set_filename(self.path)
91
 
 
 
94
        if remote_path is not None:
 
95
            self._combo.child.set_text(remote_path)
 
96
        
92
97
        # Pack some widgets
93
 
        self._hbox_revision.pack_start(self._entry_revision, True, True, 0)
94
 
        self._hbox_revision.pack_start(self._button_revision, False, False, 0)
95
 
        self.get_content_area().add(self._table)
96
 
        self.action_area.pack_end(self._button_branch, False, False, 0)
97
 
 
 
98
        self._hbox_revision.pack_start(self._entry_revision, True, True)
 
99
        self._hbox_revision.pack_start(self._button_revision, False, False)
 
100
        self.vbox.add(self._table)
 
101
        self.action_area.pack_end(self._button_branch)
 
102
        
98
103
        # Show the dialog
99
 
        self.get_content_area().show_all()
100
 
 
 
104
        self.vbox.show_all()
 
105
        
 
106
        # Build branch history
 
107
        self._history = UrlHistory(GlobalConfig(), 'branch_history')
 
108
        self._build_history()
 
109
    
 
110
    def _build_history(self):
 
111
        """ Build up the branch history. """
 
112
        self._combo_model = gtk.ListStore(str)
 
113
        
 
114
        for item in self._history.get_entries():
 
115
            self._combo_model.append([ item ])
 
116
        
 
117
        pref = Preferences()
 
118
        for item in pref.get_bookmarks():
 
119
            self._combo_model.append([ item ])
 
120
        
 
121
        self._combo.set_model(self._combo_model)
 
122
        self._combo.set_text_column(0)
 
123
    
101
124
    def _get_last_revno(self):
102
125
        """ Get the revno of the last revision (if any). """
 
126
        location = self._combo.get_child().get_text()
103
127
        try:
104
 
            br = self._remote_branch.get_branch()
 
128
            br = Branch.open(location)
 
129
        except:
 
130
            return None
 
131
        else:
105
132
            return br.revno()
106
 
        except:
107
 
            pass
108
 
 
 
133
    
109
134
    def _on_revision_clicked(self, button):
110
135
        """ Browse for revision button clicked handler. """
111
136
        from revbrowser import RevisionBrowser
112
 
 
113
 
 
 
137
        
 
138
        location = self._combo.get_child().get_text()
 
139
        
114
140
        try:
115
 
            br = self._remote_branch.get_branch()
 
141
            br = Branch.open(location)
116
142
        except:
117
143
            return
118
 
        revb = RevisionBrowser(br, self)
119
 
        response = revb.run()
120
 
        if response != Gtk.ResponseType.NONE:
121
 
            revb.hide()
122
 
 
123
 
            if response == Gtk.ResponseType.OK:
124
 
                if revb.selected_revno is not None:
125
 
                    self._entry_revision.set_text(revb.selected_revno)
126
 
 
127
 
            revb.destroy()
128
 
 
 
144
        else:
 
145
            revb = RevisionBrowser(br, self)
 
146
            response = revb.run()
 
147
            if response != gtk.RESPONSE_NONE:
 
148
                revb.hide()
 
149
        
 
150
                if response == gtk.RESPONSE_OK:
 
151
                    if revb.selected_revno is not None:
 
152
                        self._entry_revision.set_text(revb.selected_revno)
 
153
            
 
154
                revb.destroy()
 
155
    
129
156
    @show_bzr_error
130
157
    def _on_branch_clicked(self, button):
131
158
        """ Branch button clicked handler. """
132
 
        location = self._remote_branch.get_url()
 
159
        location = self._combo.get_child().get_text()
133
160
        if location is '':
134
 
            error_dialog(_i18n('Missing branch location'),
135
 
                         _i18n('You must specify a branch location.'))
 
161
            error_dialog(_('Missing branch location'),
 
162
                         _('You must specify a branch location.'))
136
163
            return
137
 
 
 
164
        
138
165
        destination = self._filechooser.get_filename()
139
166
        try:
140
167
            revno = int(self._entry_revision.get_text())
141
168
        except:
142
169
            revno = None
143
 
 
 
170
        
144
171
        nick = self._entry_nick.get_text()
145
172
        if nick is '':
146
173
            nick = os.path.basename(location.rstrip("/\\"))
147
 
 
 
174
        
148
175
        br_from = Branch.open(location)
149
 
 
 
176
        
150
177
        br_from.lock_read()
151
178
        try:
 
179
            from bzrlib.transport import get_transport
 
180
 
152
181
            revision_id = br_from.get_rev_id(revno)
153
182
 
154
183
            basis_dir = None
155
 
 
 
184
            
156
185
            to_location = destination + os.sep + nick
157
186
            to_transport = get_transport(to_location)
158
 
 
 
187
            
159
188
            to_transport.mkdir('.')
160
 
 
 
189
            
161
190
            try:
162
191
                # preserve whatever source format we have.
163
192
                dir = br_from.bzrdir.sprout(to_transport.base,
170
199
                raise
171
200
        finally:
172
201
            br_from.unlock()
173
 
 
174
 
        info_dialog(_i18n('Branching successful'),
175
 
                    _i18n('%d revision(s) branched.') % revs)
176
 
 
177
 
        self.response(Gtk.ResponseType.OK)
178
 
 
179
 
    def _on_branch_changed(self, widget, event):
 
202
                
 
203
        self._history.add_entry(location)
 
204
        info_dialog(_('Branching successful'),
 
205
                    _('%d revision(s) branched.') % revs)
 
206
        
 
207
        self.response(gtk.RESPONSE_OK)
 
208
    
 
209
    def _on_combo_changed(self, widget, event):
180
210
        """ We try to get the last revision if focus lost. """
181
211
        rev = self._get_last_revno()
182
212
        if rev is None:
183
 
            self._entry_revision.set_text(_i18n('N/A'))
 
213
            self._entry_revision.set_text(_('N/A'))
184
214
            self._button_revision.set_sensitive(False)
185
215
        else:
186
216
            self._entry_revision.set_text(str(rev))
187
217
            self._button_revision.set_sensitive(True)
188
218
            if self._entry_nick.get_text() == '':
189
 
                self._entry_nick.set_text(os.path.basename(self._remote_branch.get_url().rstrip("/\\")))
 
219
                self._entry_nick.set_text(os.path.basename(self._combo.get_child().get_text().rstrip("/\\")))