Kiln » TortoiseHg » TortoiseHg
Clone URL:  
Pushed to one repository · View In Graph Contained in 1.9, 1.9.1, and 1.9.2

update: create proper user interface

'smart update' feature is not implemented yet.
And all options are ignored always.

Changeset c84e24f95c20

Parent d6d05b856a50

by Yuki KODAMA

Changes to one file · Browse files at c84e24f95c20 Showing diff from parent d6d05b856a50 Diff from another changeset...

 
7
8
9
10
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
11
12
13
 
14
15
 
16
17
18
 
 
 
7
8
9
 
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
 
184
185
 
186
187
 
 
188
189
@@ -7,12 +7,183 @@
 # This software may be used and distributed according to the terms of the  # GNU General Public License version 2, incorporated herein by reference.   -from tortoisehg.hgqt import cmdui +from PyQt4.QtCore import QString, Qt +from PyQt4.QtGui import QDialog, QDialogButtonBox, QVBoxLayout, QGridLayout +from PyQt4.QtGui import QComboBox, QLabel, QLayout, QSpacerItem, QCheckBox +from PyQt4.QtGui import QPushButton + +from mercurial import hg, ui, error + +from tortoisehg.util import hglib, paths +from tortoisehg.hgqt.i18n import _ +from tortoisehg.hgqt import cmdui, csinfo + +class UpdateDialog(QDialog): + + def __init__(self, rev=None, repo=None, parent=None): + super(UpdateDialog, self).__init__(parent, Qt.WindowTitleHint or + Qt.WindowSystemMenuHint) + + self.ui = ui.ui() + if repo: + self.repo = repo + else: + root = paths.find_root() + if root: + self.repo = hg.repository(self.ui, path=root) + else: + raise 'not repository' + + # base layout box + box = QVBoxLayout() + box.setSpacing(6) + + ## main layout grid + grid = QGridLayout() + grid.setSpacing(6) + box.addLayout(grid) + + ### target revision combo + self.rev_combo = combo = QComboBox() + combo.setEditable(True) + grid.addWidget(QLabel(_('Update to:')), 0, 0) + grid.addWidget(combo, 0, 1) + + if rev is None: + combo.addItem(self.repo.dirstate.branch()) + else: + combo.addItem(QString(rev)) + combo.setCurrentIndex(0) + for name in hglib.getlivebranch(self.repo): + combo.addItem(name) + + tags = list(self.repo.tags()) + tags.sort() + tags.reverse() + for tag in tags: + combo.addItem(hglib.tounicode(tag)) + + ### target revision info + items = ('%(rev)s', ' %(branch)s', ' %(tags)s', '<br />%(summary)s') + style = csinfo.labelstyle(contents=items, width=350) + factory = csinfo.factory(self.repo, style=style) + self.target_info = factory() + grid.addWidget(QLabel(_('Target:')), 1, 0, Qt.AlignLeft | Qt.AlignTop) + grid.addWidget(self.target_info, 1, 1) + + ### parent revision info + self.ctxs = self.repo[None].parents() + if len(self.ctxs) == 2: + self.p1_info = factory() + grid.addWidget(QLabel(_('Parent 1:')), 2, 0, Qt.AlignLeft | Qt.AlignTop) + grid.addWidget(self.p1_info, 2, 1) + self.p2_info = factory() + grid.addWidget(QLabel(_('Parent 2:')), 3, 0, Qt.AlignLeft | Qt.AlignTop) + grid.addWidget(self.p2_info, 3, 1) + else: + self.p1_info = factory() + grid.addWidget(QLabel(_('Parent:')), 2, 0, Qt.AlignLeft | Qt.AlignTop) + grid.addWidget(self.p1_info, 2, 1) + + ### options + optbox = QVBoxLayout() + optbox.setSpacing(6) + grid.addWidget(QLabel(_('Options:')), 3, 0, Qt.AlignLeft | Qt.AlignTop) + grid.addLayout(optbox, 3, 1) + + self.discard_chk = QCheckBox(_('Discard local changes, no backup (-C/--clean)')) + self.merge_chk = QCheckBox(_('Always merge (when possible)')) + self.showlog_chk = QCheckBox(_('Always show command log')) + optbox.addWidget(self.discard_chk) + optbox.addWidget(self.merge_chk) + optbox.addWidget(self.showlog_chk) + + ## command widget + self.cmd = cmdui.Widget() + self.cmd.commandStarted.connect(self.command_started) + self.cmd.commandFinished.connect(self.command_finished) + self.cmd.commandCanceling.connect(self.command_canceling) + box.addWidget(self.cmd) + + ## bottom buttons + buttons = QDialogButtonBox() + self.cancel_btn = buttons.addButton(QDialogButtonBox.Cancel) + self.cancel_btn.clicked.connect(self.cancel_clicked) + self.close_btn = buttons.addButton(QDialogButtonBox.Close) + self.close_btn.clicked.connect(self.reject) + self.update_btn = buttons.addButton(_('&Update'), + QDialogButtonBox.ActionRole) + self.update_btn.clicked.connect(self.update_clicked) + box.addWidget(buttons) + + # signal handlers + self.rev_combo.editTextChanged.connect(lambda *a: self.update_info()) + self.discard_chk.toggled.connect(lambda *a: self.update_info()) + + # dialog setting + self.setLayout(box) + self.layout().setSizeConstraint(QLayout.SetFixedSize) + self.setWindowTitle(_('Update - %s') % hglib.get_reponame(self.repo)) + + # prepare to show + self.cmd.setHidden(True) + self.update_btn.setFocus() + self.cancel_btn.setHidden(True) + self.update_info() + + ### Private Methods ### + + def update_info(self): + self.p1_info.update(self.ctxs[0]) + merge = len(self.ctxs) == 2 + if merge: + self.p2_info.update(self.ctxs[1]) + new_rev = hglib.fromunicode(self.rev_combo.currentText()) + try: + new_ctx = self.repo[new_rev] + if not merge and new_ctx.rev() == self.ctxs[0].rev(): + self.target_info.setPlainText(_('(same as parent)')) + clean = self.discard_chk.isChecked() + self.update_btn.setEnabled(clean) + else: + self.target_info.update(self.repo[new_rev]) + self.update_btn.setEnabled(True) + except (error.LookupError, error.RepoLookupError, error.RepoError): + self.target_info.setPlainText(_('unknown revision!')) + self.update_btn.setDisabled(True) + + ### Signal Handlers ### + + def target_changed(self, target): + self.update_info() + + def update_clicked(self): + self.cmd.run(['update', hglib.fromunicode(self.rev_combo.currentText())]) + + def cancel_clicked(self): + self.cmd.cancel() + + def command_started(self): + self.cmd.setShown(True) + self.update_btn.setHidden(True) + self.close_btn.setHidden(True) + self.cancel_btn.setShown(True) + + def command_finished(self, wrapper): + if wrapper.data is not 0: + self.cmd.show_output(True) + self.close_btn.setShown(True) + self.cancel_btn.setHidden(True) + else: + self.reject() + + def command_canceling(self): + self.cancel_btn.setDisabled(True)    def run(ui, *pats, **opts): - args = ['update'] + rev = None   if opts.get('rev'): - args += ['-r', opts.get('rev')] + rev = opts.get('rev')   elif len(pats) == 1: - args += [pats[0]] - return cmdui.Dialog(args) + rev = [pats[0]] + return UpdateDialog(rev)