Chris@57
|
1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
|
Chris@57
|
2
|
Chris@57
|
3 /*
|
Chris@57
|
4 EasyMercurial
|
Chris@57
|
5
|
Chris@57
|
6 Based on HgExplorer by Jari Korhonen
|
Chris@57
|
7 Copyright (c) 2010 Jari Korhonen
|
Chris@560
|
8 Copyright (c) 2012 Chris Cannam
|
Chris@560
|
9 Copyright (c) 2012 Queen Mary, University of London
|
Chris@57
|
10
|
Chris@57
|
11 This program is free software; you can redistribute it and/or
|
Chris@57
|
12 modify it under the terms of the GNU General Public License as
|
Chris@57
|
13 published by the Free Software Foundation; either version 2 of the
|
Chris@57
|
14 License, or (at your option) any later version. See the file
|
Chris@57
|
15 COPYING included with this distribution for more information.
|
Chris@57
|
16 */
|
jtkorhonen@0
|
17
|
Chris@96
|
18 #include "hgtabwidget.h"
|
jtkorhonen@0
|
19 #include "common.h"
|
Chris@88
|
20 #include "filestatuswidget.h"
|
Chris@116
|
21 #include "historywidget.h"
|
Chris@44
|
22
|
Chris@50
|
23 #include <QClipboard>
|
Chris@50
|
24 #include <QContextMenuEvent>
|
Chris@50
|
25 #include <QApplication>
|
Chris@50
|
26
|
Chris@44
|
27 #include <iostream>
|
jtkorhonen@0
|
28
|
Chris@96
|
29 HgTabWidget::HgTabWidget(QWidget *parent,
|
Chris@95
|
30 QString workFolderPath) :
|
Chris@505
|
31 QTabWidget(parent),
|
Chris@505
|
32 m_haveMerge(false)
|
jtkorhonen@0
|
33 {
|
Chris@326
|
34 // Work tab
|
Chris@116
|
35 m_fileStatusWidget = new FileStatusWidget;
|
Chris@116
|
36 m_fileStatusWidget->setLocalPath(workFolderPath);
|
Chris@326
|
37
|
Chris@116
|
38 connect(m_fileStatusWidget, SIGNAL(selectionChanged()),
|
Chris@95
|
39 this, SIGNAL(selectionChanged()));
|
Chris@326
|
40
|
Chris@484
|
41 connect(m_fileStatusWidget, SIGNAL(showAllChanged()),
|
Chris@484
|
42 this, SIGNAL(showAllChanged()));
|
Chris@326
|
43
|
Chris@326
|
44 connect(m_fileStatusWidget, SIGNAL(annotateFiles(QStringList)),
|
Chris@326
|
45 this, SIGNAL(annotateFiles(QStringList)));
|
Chris@326
|
46
|
Chris@326
|
47 connect(m_fileStatusWidget, SIGNAL(diffFiles(QStringList)),
|
Chris@326
|
48 this, SIGNAL(diffFiles(QStringList)));
|
Chris@326
|
49
|
Chris@326
|
50 connect(m_fileStatusWidget, SIGNAL(commitFiles(QStringList)),
|
Chris@326
|
51 this, SIGNAL(commitFiles(QStringList)));
|
Chris@326
|
52
|
Chris@326
|
53 connect(m_fileStatusWidget, SIGNAL(revertFiles(QStringList)),
|
Chris@326
|
54 this, SIGNAL(revertFiles(QStringList)));
|
Chris@326
|
55
|
Chris@361
|
56 connect(m_fileStatusWidget, SIGNAL(renameFiles(QStringList)),
|
Chris@361
|
57 this, SIGNAL(renameFiles(QStringList)));
|
Chris@361
|
58
|
Chris@361
|
59 connect(m_fileStatusWidget, SIGNAL(copyFiles(QStringList)),
|
Chris@361
|
60 this, SIGNAL(copyFiles(QStringList)));
|
Chris@361
|
61
|
Chris@326
|
62 connect(m_fileStatusWidget, SIGNAL(addFiles(QStringList)),
|
Chris@326
|
63 this, SIGNAL(addFiles(QStringList)));
|
Chris@326
|
64
|
Chris@326
|
65 connect(m_fileStatusWidget, SIGNAL(removeFiles(QStringList)),
|
Chris@326
|
66 this, SIGNAL(removeFiles(QStringList)));
|
Chris@326
|
67
|
Chris@326
|
68 connect(m_fileStatusWidget, SIGNAL(redoFileMerges(QStringList)),
|
Chris@326
|
69 this, SIGNAL(redoFileMerges(QStringList)));
|
Chris@326
|
70
|
Chris@326
|
71 connect(m_fileStatusWidget, SIGNAL(markFilesResolved(QStringList)),
|
Chris@326
|
72 this, SIGNAL(markFilesResolved(QStringList)));
|
Chris@326
|
73
|
Chris@326
|
74 connect(m_fileStatusWidget, SIGNAL(ignoreFiles(QStringList)),
|
Chris@326
|
75 this, SIGNAL(ignoreFiles(QStringList)));
|
Chris@326
|
76
|
Chris@326
|
77 connect(m_fileStatusWidget, SIGNAL(unIgnoreFiles(QStringList)),
|
Chris@326
|
78 this, SIGNAL(unIgnoreFiles(QStringList)));
|
Chris@326
|
79
|
Chris@116
|
80 addTab(m_fileStatusWidget, tr("My work"));
|
Chris@88
|
81
|
Chris@326
|
82 // History graph tab
|
Chris@116
|
83 m_historyWidget = new HistoryWidget;
|
Chris@116
|
84 addTab(m_historyWidget, tr("History"));
|
Chris@141
|
85
|
Chris@141
|
86 connect(m_historyWidget, SIGNAL(commit()),
|
Chris@141
|
87 this, SIGNAL(commit()));
|
Chris@141
|
88
|
Chris@141
|
89 connect(m_historyWidget, SIGNAL(revert()),
|
Chris@141
|
90 this, SIGNAL(revert()));
|
Chris@141
|
91
|
Chris@168
|
92 connect(m_historyWidget, SIGNAL(showSummary()),
|
Chris@168
|
93 this, SIGNAL(showSummary()));
|
Chris@168
|
94
|
Chris@311
|
95 connect(m_historyWidget, SIGNAL(newBranch()),
|
Chris@311
|
96 this, SIGNAL(newBranch()));
|
Chris@311
|
97
|
Chris@311
|
98 connect(m_historyWidget, SIGNAL(noBranch()),
|
Chris@311
|
99 this, SIGNAL(noBranch()));
|
Chris@311
|
100
|
Chris@141
|
101 connect(m_historyWidget, SIGNAL(diffWorkingFolder()),
|
Chris@141
|
102 this, SIGNAL(diffWorkingFolder()));
|
Chris@141
|
103
|
Chris@153
|
104 connect(m_historyWidget, SIGNAL(showWork()),
|
Chris@153
|
105 this, SLOT(showWorkTab()));
|
Chris@153
|
106
|
Chris@141
|
107 connect(m_historyWidget, SIGNAL(updateTo(QString)),
|
Chris@141
|
108 this, SIGNAL(updateTo(QString)));
|
Chris@141
|
109
|
Chris@141
|
110 connect(m_historyWidget, SIGNAL(diffToCurrent(QString)),
|
Chris@141
|
111 this, SIGNAL(diffToCurrent(QString)));
|
Chris@141
|
112
|
Chris@148
|
113 connect(m_historyWidget, SIGNAL(diffToParent(QString, QString)),
|
Chris@148
|
114 this, SIGNAL(diffToParent(QString, QString)));
|
Chris@141
|
115
|
Chris@289
|
116 connect(m_historyWidget, SIGNAL(showSummary(Changeset *)),
|
Chris@289
|
117 this, SIGNAL(showSummary(Changeset *)));
|
Chris@288
|
118
|
Chris@141
|
119 connect(m_historyWidget, SIGNAL(mergeFrom(QString)),
|
Chris@141
|
120 this, SIGNAL(mergeFrom(QString)));
|
Chris@141
|
121
|
Chris@278
|
122 connect(m_historyWidget, SIGNAL(newBranch(QString)),
|
Chris@278
|
123 this, SIGNAL(newBranch(QString)));
|
Chris@278
|
124
|
Chris@514
|
125 connect(m_historyWidget, SIGNAL(closeBranch(QString)),
|
Chris@514
|
126 this, SIGNAL(closeBranch(QString)));
|
Chris@514
|
127
|
Chris@141
|
128 connect(m_historyWidget, SIGNAL(tag(QString)),
|
Chris@141
|
129 this, SIGNAL(tag(QString)));
|
jtkorhonen@32
|
130 }
|
jtkorhonen@32
|
131
|
Chris@96
|
132 void HgTabWidget::clearSelections()
|
Chris@94
|
133 {
|
Chris@116
|
134 m_fileStatusWidget->clearSelections();
|
Chris@94
|
135 }
|
Chris@94
|
136
|
Chris@153
|
137 void HgTabWidget::setCurrent(QStringList ids, QString branch)
|
Chris@128
|
138 {
|
Chris@505
|
139 m_historyWidget->setCurrent(ids, branch, haveChangesToCommit());
|
Chris@129
|
140 }
|
Chris@129
|
141
|
Chris@506
|
142 void HgTabWidget::setClosedHeadIds(QSet<QString> closed)
|
Chris@506
|
143 {
|
Chris@506
|
144 m_historyWidget->setClosedHeadIds(closed);
|
Chris@506
|
145 }
|
Chris@506
|
146
|
Chris@608
|
147 void HgTabWidget::clearAll()
|
Chris@608
|
148 {
|
Chris@608
|
149 m_fileStatusWidget->clearWidgets();
|
Chris@608
|
150 m_historyWidget->clear();
|
Chris@608
|
151 }
|
Chris@608
|
152
|
Chris@230
|
153 void HgTabWidget::updateFileStates()
|
Chris@230
|
154 {
|
Chris@230
|
155 m_fileStatusWidget->updateWidgets();
|
Chris@230
|
156 }
|
Chris@230
|
157
|
Chris@154
|
158 void HgTabWidget::updateHistory()
|
Chris@154
|
159 {
|
Chris@154
|
160 m_historyWidget->update();
|
Chris@154
|
161 }
|
Chris@154
|
162
|
Chris@555
|
163 void HgTabWidget::setSearchText(QString text)
|
Chris@555
|
164 {
|
Chris@555
|
165 m_fileStatusWidget->setSearchText(text);
|
Chris@555
|
166 m_historyWidget->setSearchText(text);
|
Chris@555
|
167 }
|
Chris@555
|
168
|
Chris@163
|
169 bool HgTabWidget::canDiff() const
|
Chris@163
|
170 {
|
Chris@237
|
171 return canRevert();
|
Chris@163
|
172 }
|
Chris@163
|
173
|
Chris@96
|
174 bool HgTabWidget::canCommit() const
|
Chris@90
|
175 {
|
Chris@505
|
176 if (!haveChangesToCommit()) return false;
|
Chris@505
|
177 if (!getAllUnresolvedFiles().empty()) return false;
|
Chris@326
|
178 return true;
|
Chris@90
|
179 }
|
jtkorhonen@0
|
180
|
Chris@109
|
181 bool HgTabWidget::canRevert() const
|
Chris@109
|
182 {
|
Chris@237
|
183 // Not the same as canCommit() -- we can revert (and diff)
|
Chris@237
|
184 // unresolved files, but we can't commit them
|
Chris@505
|
185 if (!haveChangesToCommit() &&
|
Chris@505
|
186 getAllUnresolvedFiles().empty()) return false;
|
Chris@326
|
187 return true;
|
Chris@109
|
188 }
|
Chris@109
|
189
|
Chris@96
|
190 bool HgTabWidget::canAdd() const
|
Chris@95
|
191 {
|
Chris@327
|
192 // Permit this only when work tab is visible
|
Chris@327
|
193 if (currentIndex() != 0) return false;
|
Chris@327
|
194
|
Chris@505
|
195 QStringList addable = getSelectedAddableFiles();
|
Chris@204
|
196 if (addable.empty()) return false;
|
Chris@204
|
197
|
Chris@505
|
198 QStringList removable = getSelectedRemovableFiles();
|
Chris@204
|
199 if (!removable.empty()) return false;
|
Chris@204
|
200
|
Chris@326
|
201 return true;
|
Chris@95
|
202 }
|
Chris@95
|
203
|
Chris@96
|
204 bool HgTabWidget::canRemove() const
|
Chris@95
|
205 {
|
Chris@327
|
206 // Permit this only when work tab is visible
|
Chris@327
|
207 if (currentIndex() != 0) return false;
|
Chris@327
|
208
|
Chris@505
|
209 if (getSelectedRemovableFiles().empty()) return false;
|
Chris@505
|
210 if (!getSelectedAddableFiles().empty()) return false;
|
Chris@95
|
211 return true;
|
Chris@95
|
212 }
|
Chris@95
|
213
|
Chris@163
|
214 bool HgTabWidget::canResolve() const
|
Chris@95
|
215 {
|
Chris@505
|
216 return !getAllUnresolvedFiles().empty();
|
Chris@95
|
217 }
|
Chris@95
|
218
|
Chris@425
|
219 bool HgTabWidget::canIgnore() const
|
Chris@425
|
220 {
|
Chris@425
|
221 return canAdd();
|
Chris@425
|
222 }
|
Chris@425
|
223
|
Chris@172
|
224 bool HgTabWidget::haveChangesToCommit() const
|
Chris@172
|
225 {
|
Chris@505
|
226 return m_haveMerge || m_fileStatusWidget->haveChangesToCommit();
|
Chris@172
|
227 }
|
Chris@172
|
228
|
Chris@109
|
229 QStringList HgTabWidget::getAllCommittableFiles() const
|
Chris@109
|
230 {
|
Chris@116
|
231 return m_fileStatusWidget->getAllCommittableFiles();
|
Chris@109
|
232 }
|
Chris@109
|
233
|
Chris@109
|
234 QStringList HgTabWidget::getAllRevertableFiles() const
|
Chris@109
|
235 {
|
Chris@116
|
236 return m_fileStatusWidget->getAllRevertableFiles();
|
Chris@109
|
237 }
|
Chris@109
|
238
|
Chris@96
|
239 QStringList HgTabWidget::getSelectedAddableFiles() const
|
Chris@95
|
240 {
|
Chris@116
|
241 return m_fileStatusWidget->getSelectedAddableFiles();
|
Chris@95
|
242 }
|
Chris@95
|
243
|
Chris@96
|
244 QStringList HgTabWidget::getSelectedRemovableFiles() const
|
Chris@95
|
245 {
|
Chris@116
|
246 return m_fileStatusWidget->getSelectedRemovableFiles();
|
Chris@95
|
247 }
|
Chris@95
|
248
|
Chris@163
|
249 QStringList HgTabWidget::getAllUnresolvedFiles() const
|
Chris@163
|
250 {
|
Chris@163
|
251 return m_fileStatusWidget->getAllUnresolvedFiles();
|
Chris@163
|
252 }
|
Chris@163
|
253
|
Chris@96
|
254 void HgTabWidget::updateWorkFolderFileList(QString fileList)
|
jtkorhonen@0
|
255 {
|
Chris@116
|
256 m_fileStates.parseStates(fileList);
|
Chris@116
|
257 m_fileStatusWidget->setFileStates(m_fileStates);
|
jtkorhonen@0
|
258 }
|
jtkorhonen@0
|
259
|
Chris@505
|
260 void HgTabWidget::setHaveMerge(bool haveMerge)
|
Chris@505
|
261 {
|
Chris@505
|
262 if (m_haveMerge != haveMerge) {
|
Chris@505
|
263 m_haveMerge = haveMerge;
|
Chris@505
|
264 m_historyWidget->setShowUncommitted(haveChangesToCommit());
|
Chris@505
|
265 updateHistory();
|
Chris@505
|
266 }
|
Chris@505
|
267 }
|
Chris@505
|
268
|
Chris@120
|
269 void HgTabWidget::setNewLog(QString hgLogList)
|
jtkorhonen@0
|
270 {
|
Chris@120
|
271 m_historyWidget->parseNewLog(hgLogList);
|
Chris@134
|
272 if (m_historyWidget->haveNewItems()) {
|
Chris@153
|
273 showHistoryTab();
|
Chris@134
|
274 }
|
Chris@120
|
275 }
|
Chris@120
|
276
|
Chris@120
|
277 void HgTabWidget::addIncrementalLog(QString hgLogList)
|
Chris@120
|
278 {
|
Chris@120
|
279 m_historyWidget->parseIncrementalLog(hgLogList);
|
Chris@134
|
280 if (m_historyWidget->haveNewItems()) {
|
Chris@153
|
281 showHistoryTab();
|
Chris@134
|
282 }
|
jtkorhonen@0
|
283 }
|
jtkorhonen@0
|
284
|
Chris@287
|
285 void HgTabWidget::setLocalPath(QString workFolderPath)
|
jtkorhonen@0
|
286 {
|
Chris@116
|
287 m_fileStatusWidget->setLocalPath(workFolderPath);
|
Chris@106
|
288 }
|
Chris@153
|
289
|
Chris@153
|
290 void HgTabWidget::showWorkTab()
|
Chris@153
|
291 {
|
Chris@153
|
292 setCurrentWidget(m_fileStatusWidget);
|
Chris@153
|
293 }
|
Chris@153
|
294
|
Chris@153
|
295 void HgTabWidget::showHistoryTab()
|
Chris@153
|
296 {
|
Chris@153
|
297 setCurrentWidget(m_historyWidget);
|
Chris@153
|
298 }
|
Chris@153
|
299
|
Chris@484
|
300 bool HgTabWidget::shouldShowAll() const
|
Chris@484
|
301 {
|
Chris@484
|
302 return m_fileStatusWidget->shouldShowAll();
|
Chris@484
|
303 }
|
Chris@484
|
304
|