diff options
author | dt <qtc-committer@nokia.com> | 2009-05-12 14:59:06 +0200 |
---|---|---|
committer | dt <qtc-committer@nokia.com> | 2009-05-12 14:59:06 +0200 |
commit | 27e968c7e9b034cfb6e2f707b424b8a2d398ac26 (patch) | |
tree | ebfb84727a53d66b0c98c719aa9e9a761d1b59bf /src/plugins/qt4projectmanager/qtuicodemodelsupport.cpp | |
parent | af199594a65d3784d7201f572be9db8550697f24 (diff) | |
download | qt-creator-27e968c7e9b034cfb6e2f707b424b8a2d398ac26.tar.gz |
Compile
Diffstat (limited to 'src/plugins/qt4projectmanager/qtuicodemodelsupport.cpp')
-rw-r--r-- | src/plugins/qt4projectmanager/qtuicodemodelsupport.cpp | 157 |
1 files changed, 157 insertions, 0 deletions
diff --git a/src/plugins/qt4projectmanager/qtuicodemodelsupport.cpp b/src/plugins/qt4projectmanager/qtuicodemodelsupport.cpp new file mode 100644 index 0000000000..baf1e00855 --- /dev/null +++ b/src/plugins/qt4projectmanager/qtuicodemodelsupport.cpp @@ -0,0 +1,157 @@ +#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) +{ + qDebug()<<"ctor Qt4UiCodeModelSupport for"<<m_sourceName; + init(); +} + +Qt4UiCodeModelSupport::~Qt4UiCodeModelSupport() +{ + qDebug()<<"dtor ~Qt4UiCodeModelSupport for"<<m_sourceName; +} + +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)) { + qDebug()<<"ui*h file is more recent then source file, using information from ui*h file"<<m_fileName; + QTextStream stream(&file); + m_contents = stream.readAll().toUtf8(); + m_cacheTime = uiHeaderTime; + return; + } + } + + qDebug()<<"ui*h file not found, or not recent enough, trying to create it on the fly"; + QFile file(m_sourceName); + if (file.open(QFile::ReadOnly)) { + QTextStream stream(&file); + const QString contents = stream.readAll(); + if (runUic(contents)) { + qDebug()<<"created on the fly"; + return; + } else { + // uic run was unsuccesfull + qDebug()<<"uic run wasn't succesfull"; + 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 { + qDebug()<<"Could open "<<m_sourceName<<"needed for the cpp model"; + 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(); +// qDebug()<<"\nusing uic from"<<m_project->qtVersion(m_project->activeBuildConfiguration())->uicCommand(); +// qDebug()<<"resulted in:"; +// qDebug()<< m_contents; +// qDebug()<<"============================="; + return true; + } else { + 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(); + uic.kill(); + } + return false; +} + +void Qt4UiCodeModelSupport::updateFromEditor(Designer::Internal::FormWindowEditor *fw) +{ + qDebug()<<"Qt4UiCodeModelSupport::updateFromEditor"<<fw; + if (runUic(fw->contents())) { + qDebug()<<"runUic: success, updated on the fly"; + updateDocument(); + } else { + qDebug()<<"runUic: failed, not updated"; + } +} + +void Qt4UiCodeModelSupport::updateFromBuild() +{ + qDebug()<<"Qt4UiCodeModelSupport::updateFromBuild() for file"<<m_sourceName; + // 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) { + qDebug()<<"Cache is still more recent then source"; + return; + } else { + QFileInfo fi(m_fileName); + QDateTime uiHeaderTime = fi.exists() ? fi.lastModified() : QDateTime(); + if (uiHeaderTime.isValid() && (uiHeaderTime > sourceTime)) { + if (m_cacheTime >= uiHeaderTime) + return; + qDebug()<<"found ui*h updating from it"; + + QFile file(m_fileName); + if (file.open(QFile::ReadOnly)) { + QTextStream stream(&file); + m_contents = stream.readAll().toUtf8(); + m_cacheTime = uiHeaderTime; + updateDocument(); + return; + } + } + + qDebug()<<"ui*h not found or not more recent then source not changing anything"; + } +} + |