annotate src/hgtabwidget.h @ 505:1c05e7576ea5

Fix bug #292: "Merge that results in no changes leaves interface in inconsistent state." Show uncommitted state whenever a merge is present, even if no file changes
author Chris Cannam
date Mon, 17 Oct 2011 16:25:02 +0100
parents 896b7903e8f2
children 470829a21f98
rev   line source
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@244 8 Copyright (c) 2011 Chris Cannam
Chris@244 9 Copyright (c) 2011 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 */
Chris@57 17
Chris@96 18 #ifndef HGTABWIDGET_H
Chris@96 19 #define HGTABWIDGET_H
jtkorhonen@0 20
Chris@43 21 #include "changeset.h"
jtkorhonen@0 22 #include "common.h"
Chris@92 23 #include "filestates.h"
jtkorhonen@0 24
Chris@50 25 #include <QMenu>
Chris@50 26 #include <QListWidget>
Chris@50 27 #include <QGroupBox>
Chris@50 28 #include <QVBoxLayout>
Chris@50 29 #include <QCheckBox>
Chris@50 30 #include <QLabel>
Chris@88 31 #include <QTabWidget>
Chris@86 32
Chris@88 33 class FileStatusWidget;
Chris@116 34 class HistoryWidget;
jtkorhonen@0 35
Chris@96 36 class HgTabWidget: public QTabWidget
jtkorhonen@0 37 {
jtkorhonen@0 38 Q_OBJECT
jtkorhonen@0 39
jtkorhonen@0 40 public:
Chris@287 41 HgTabWidget(QWidget *parent, QString workFolderPath);
Chris@91 42
jtkorhonen@0 43 void updateWorkFolderFileList(QString fileList);
Chris@120 44
Chris@120 45 void setNewLog(QString hgLogList);
Chris@120 46 void addIncrementalLog(QString hgLogList);
Chris@120 47
Chris@287 48 void setLocalPath(QString workFolderPath);
jtkorhonen@0 49
Chris@153 50 void setCurrent(QStringList ids, QString branch);
Chris@128 51
Chris@505 52 void setHaveMerge(bool);
Chris@505 53
Chris@230 54 void updateFileStates();
Chris@154 55 void updateHistory();
Chris@154 56
Chris@116 57 FileStates getFileStates() { return m_fileStates; }
Chris@90 58
Chris@163 59 bool canDiff() const;
Chris@90 60 bool canCommit() const;
Chris@109 61 bool canRevert() const;
Chris@92 62 bool canAdd() const;
Chris@92 63 bool canRemove() const;
Chris@163 64 bool canResolve() const;
Chris@425 65 bool canIgnore() const;
Chris@172 66 bool haveChangesToCommit() const;
Chris@95 67
Chris@103 68 QStringList getAllCommittableFiles() const;
Chris@109 69 QStringList getAllRevertableFiles() const;
Chris@326 70 QStringList getAllUnresolvedFiles() const;
Chris@109 71
Chris@95 72 QStringList getSelectedAddableFiles() const;
Chris@95 73 QStringList getSelectedRemovableFiles() const;
Chris@163 74
Chris@484 75 bool shouldShowAll() const;
Chris@484 76
Chris@95 77 signals:
Chris@95 78 void selectionChanged();
Chris@484 79 void showAllChanged();
jtkorhonen@0 80
Chris@141 81 void commit();
Chris@141 82 void revert();
Chris@141 83 void diffWorkingFolder();
Chris@168 84 void showSummary();
Chris@311 85 void newBranch();
Chris@311 86 void noBranch();
Chris@141 87
Chris@141 88 void updateTo(QString id);
Chris@148 89 void diffToParent(QString id, QString parent);
Chris@289 90 void showSummary(Changeset *);
Chris@141 91 void diffToCurrent(QString id);
Chris@141 92 void mergeFrom(QString id);
Chris@278 93 void newBranch(QString id);
Chris@141 94 void tag(QString id);
Chris@141 95
Chris@326 96 void annotateFiles(QStringList);
Chris@326 97 void diffFiles(QStringList);
Chris@326 98 void commitFiles(QStringList);
Chris@326 99 void revertFiles(QStringList);
Chris@361 100 void renameFiles(QStringList);
Chris@361 101 void copyFiles(QStringList);
Chris@326 102 void addFiles(QStringList);
Chris@326 103 void removeFiles(QStringList);
Chris@326 104 void redoFileMerges(QStringList);
Chris@326 105 void markFilesResolved(QStringList);
Chris@326 106 void ignoreFiles(QStringList);
Chris@326 107 void unIgnoreFiles(QStringList);
Chris@326 108
Chris@94 109 public slots:
Chris@94 110 void clearSelections();
Chris@153 111 void showWorkTab();
Chris@153 112 void showHistoryTab();
Chris@94 113
jtkorhonen@0 114 private:
Chris@116 115 FileStatusWidget *m_fileStatusWidget;
Chris@116 116 HistoryWidget *m_historyWidget;
Chris@116 117 FileStates m_fileStates;
Chris@505 118 bool m_haveMerge;
jtkorhonen@0 119
Chris@91 120 Changesets parseChangeSets(QString changeSetsStr);
jtkorhonen@0 121 };
jtkorhonen@0 122
Chris@96 123 #endif // HGTABWIDGET_H