/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: Curtis Hovey
  • Date: 2011-09-05 03:44:26 UTC
  • mto: This revision was merged to the branch mainline in revision 741.
  • Revision ID: sinzui.is@verizon.net-20110905034426-p98pxnay9rmzkr99
Fix the initializer for many classes.
Replace Gtk.Dialog.vbox with .get_content_area().

Show diffs side-by-side

added added

removed removed

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