Skip to content
Snippets Groups Projects
qtuicodemodelsupport.cpp 5.16 KiB
Newer Older
dt's avatar
dt committed
#include "qtuicodemodelsupport.h"

#include "qt4project.h"
#include <designer/formwindoweditor.h>

using namespace Qt4ProjectManager;
using namespace Internal;

Qt4UiCodeModelSupport::Qt4UiCodeModelSupport(CppTools::CppModelManagerInterface *modelmanager,
                                             Qt4Project *project,
                                             const QString &source,
                                             const QString &uiHeaderFile)
    : CppTools::AbstractEditorSupport(modelmanager),
      m_project(project),
      m_sourceName(source),
      m_fileName(uiHeaderFile),
      m_updateIncludingFiles(false)
{
dt's avatar
dt committed
//    qDebug()<<"ctor Qt4UiCodeModelSupport for"<<m_sourceName;
dt's avatar
dt committed
    init();
}

Qt4UiCodeModelSupport::~Qt4UiCodeModelSupport()
{
dt's avatar
dt committed
//    qDebug()<<"dtor ~Qt4UiCodeModelSupport for"<<m_sourceName;
dt's avatar
dt committed
}

void Qt4UiCodeModelSupport::init()
{
    QDateTime sourceTime = QFileInfo(m_sourceName).lastModified();
    QFileInfo uiHeaderFileInfo(m_fileName);
    QDateTime uiHeaderTime = uiHeaderFileInfo.exists() ? uiHeaderFileInfo.lastModified() : QDateTime();
    if (uiHeaderTime.isValid() && (uiHeaderTime > sourceTime)) {
        QFile file(m_fileName);
        if (file.open(QFile::ReadOnly)) {
dt's avatar
dt committed
//            qDebug()<<"ui*h file is more recent then source file, using information from ui*h file"<<m_fileName;
dt's avatar
dt committed
            QTextStream stream(&file);
            m_contents = stream.readAll().toUtf8();
            m_cacheTime = uiHeaderTime;
            return;
        }
    }

dt's avatar
dt committed
//    qDebug()<<"ui*h file not found, or not recent enough, trying to create it on the fly";
dt's avatar
dt committed
    QFile file(m_sourceName);
    if (file.open(QFile::ReadOnly)) {
        QTextStream stream(&file);
        const QString contents = stream.readAll();
        if (runUic(contents)) {
dt's avatar
dt committed
//            qDebug()<<"created on the fly";
dt's avatar
dt committed
            return;
        } else {
            // uic run was unsuccesfull
dt's avatar
dt committed
//            qDebug()<<"uic run wasn't succesfull";
dt's avatar
dt committed
            m_cacheTime = QDateTime();
            m_contents = QByteArray();
            // and if the header file wasn't there, next time we need to update
            // all of the files that include this header
            if (!uiHeaderFileInfo.exists())
                m_updateIncludingFiles = true;
            return;
        }
    } else {
dt's avatar
dt committed
//        qDebug()<<"Could open "<<m_sourceName<<"needed for the cpp model";
dt's avatar
dt committed
        m_contents = QByteArray();
    }
}

QByteArray Qt4UiCodeModelSupport::contents() const
{
    return m_contents;
}

QString Qt4UiCodeModelSupport::fileName() const
{
    return m_fileName;
}

void Qt4UiCodeModelSupport::setFileName(const QString &name)
{
    if (m_fileName == name && m_cacheTime.isValid())
        return;
    m_fileName = name;
    m_contents.clear();
    m_cacheTime = QDateTime();
    init();
}

bool Qt4UiCodeModelSupport::runUic(const QString &ui) const
{
    QProcess uic;
    uic.setEnvironment(m_project->environment(m_project->activeBuildConfiguration()).toStringList());
    uic.start(m_project->qtVersion(m_project->activeBuildConfiguration())->uicCommand(), QStringList(), QIODevice::ReadWrite);
    uic.waitForStarted();
    uic.write(ui.toUtf8());
    uic.closeWriteChannel();
    if (uic.waitForFinished()) {
        m_contents = uic.readAllStandardOutput();
        m_cacheTime = QDateTime::currentDateTime();
        return true;
    } else {
dt's avatar
dt committed
//        qDebug()<<"running uic failed"<<" using uic: "<<m_project->qtVersion(m_project->activeBuildConfiguration())->uicCommand();
//        qDebug()<<uic.readAllStandardError();
//        qDebug()<<uic.readAllStandardOutput();
//        qDebug()<<uic.errorString();
//        qDebug()<<uic.error();
dt's avatar
dt committed
        uic.kill();
    }
    return false;
}

void Qt4UiCodeModelSupport::updateFromEditor(Designer::Internal::FormWindowEditor *fw)
{
dt's avatar
dt committed
//    qDebug()<<"Qt4UiCodeModelSupport::updateFromEditor"<<fw;
dt's avatar
dt committed
    if (runUic(fw->contents())) {
dt's avatar
dt committed
//        qDebug()<<"runUic: success, updated on the fly";
dt's avatar
dt committed
        updateDocument();
    } else {
dt's avatar
dt committed
//        qDebug()<<"runUic: failed, not updated";
dt's avatar
dt committed
    }
}

void Qt4UiCodeModelSupport::updateFromBuild()
{
dt's avatar
dt committed
//    qDebug()<<"Qt4UiCodeModelSupport::updateFromBuild() for file"<<m_sourceName;
dt's avatar
dt committed
    // This is mostly a fall back for the cases when uic couldn't be run
    // it pays special attention to the case where a ui_*h was newly created
    QDateTime sourceTime = QFileInfo(m_sourceName).lastModified();
    if (m_cacheTime.isValid() && m_cacheTime >= sourceTime) {
dt's avatar
dt committed
//        qDebug()<<"Cache is still more recent then source";
dt's avatar
dt committed
        return;
    } else {
        QFileInfo fi(m_fileName);
        QDateTime uiHeaderTime = fi.exists() ? fi.lastModified() : QDateTime();
        if (uiHeaderTime.isValid() && (uiHeaderTime > sourceTime)) {
            if (m_cacheTime >= uiHeaderTime)
                return;
dt's avatar
dt committed
//            qDebug()<<"found ui*h updating from it";
dt's avatar
dt committed

            QFile file(m_fileName);
            if (file.open(QFile::ReadOnly)) {
                QTextStream stream(&file);
                m_contents = stream.readAll().toUtf8();
                m_cacheTime = uiHeaderTime;
                updateDocument();
                return;
            }
        }

dt's avatar
dt committed
//        qDebug()<<"ui*h not found or not more recent then source not changing anything";
dt's avatar
dt committed
    }
}