Mercurial > hg > easyhg
view historywidget.cpp @ 122:c3e8342d2de9
* Further fix to incremental log (put new changesets on the correct end of the list!)
author | Chris Cannam |
---|---|
date | Mon, 29 Nov 2010 11:14:29 +0000 |
parents | c92f5859c707 |
children | 3afa1ce339ec |
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ /* EasyMercurial Based on HgExplorer by Jari Korhonen Copyright (c) 2010 Jari Korhonen Copyright (c) 2010 Chris Cannam Copyright (c) 2010 Queen Mary, University of London This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. See the file COPYING included with this distribution for more information. */ #include "historywidget.h" #include "changesetscene.h" #include "panned.h" #include "panner.h" #include "grapher.h" #include "debug.h" #include <iostream> #include <QGridLayout> HistoryWidget::HistoryWidget() { m_panned = new Panned; m_panner = new Panner; QGridLayout *layout = new QGridLayout; layout->addWidget(m_panned, 0, 0); layout->addWidget(m_panner, 0, 1); m_panner->setMaximumWidth(80); m_panner->connectToPanned(m_panned); setLayout(layout); } HistoryWidget::~HistoryWidget() { clearChangesets(); } void HistoryWidget::clearChangesets() { foreach (Changeset *cs, m_changesets) delete cs; m_changesets.clear(); } void HistoryWidget::parseNewLog(QString log) { DEBUG << "HistoryWidget::parseNewLog: log has " << log.length() << " chars" << endl; Changesets csets = Changeset::parseChangesets(log); DEBUG << "HistoryWidget::parseNewLog: log has " << csets.size() << " changesets" << endl; clearChangesets(); m_changesets = csets; layoutAll(); } void HistoryWidget::parseIncrementalLog(QString log) { DEBUG << "HistoryWidget::parseIncrementalLog: log has " << log.length() << " chars" << endl; Changesets csets = Changeset::parseChangesets(log); DEBUG << "HistoryWidget::parseIncrementalLog: log has " << csets.size() << " changesets" << endl; if (!csets.empty()) { csets << m_changesets; m_changesets = csets; layoutAll(); } } void HistoryWidget::layoutAll() { setChangesetParents(); ChangesetScene *scene = new ChangesetScene(); ChangesetItem *tipItem = 0; if (!m_changesets.empty()) { Grapher g(scene); try { g.layout(m_changesets); } catch (std::string s) { std::cerr << "Internal error: Layout failed: " << s << std::endl; } tipItem = g.getItemFor(m_changesets[0]); DEBUG << "tipItem is " << tipItem << " for tip changeset " << m_changesets[0]->id() << endl; } QGraphicsScene *oldScene = m_panned->scene(); m_panned->setScene(scene); m_panner->setScene(scene); if (oldScene) delete oldScene; if (tipItem) tipItem->ensureVisible(); } void HistoryWidget::setChangesetParents() { for (int i = 0; i+1 < m_changesets.size(); ++i) { Changeset *cs = m_changesets[i]; if (cs->parents().empty()) { QStringList list; list.push_back(m_changesets[i+1]->id()); cs->setParents(list); } } }