diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | e9ae80694875f869892f13f4fcaf1170a00dea41 (patch) | |
tree | aa2f8d8a217e2d376224c8d46b7397b68d35de2d /kxsldbg/kxsldbgpart/qxsldbgdoc.cpp | |
download | tdewebdev-e9ae80694875f869892f13f4fcaf1170a00dea41.tar.gz tdewebdev-e9ae80694875f869892f13f4fcaf1170a00dea41.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdewebdev@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kxsldbg/kxsldbgpart/qxsldbgdoc.cpp')
-rw-r--r-- | kxsldbg/kxsldbgpart/qxsldbgdoc.cpp | 162 |
1 files changed, 162 insertions, 0 deletions
diff --git a/kxsldbg/kxsldbgpart/qxsldbgdoc.cpp b/kxsldbg/kxsldbgpart/qxsldbgdoc.cpp new file mode 100644 index 00000000..69105338 --- /dev/null +++ b/kxsldbg/kxsldbgpart/qxsldbgdoc.cpp @@ -0,0 +1,162 @@ +/** + File : qxsldbgdoc.cpp + Author : Keith Isdale + Date : 19th April 2002 + Description : The document to handle source and breakpoints + */ + +#include "qxsldbgdoc.h" +#include <ktexteditor/markinterface.h> +#include <ktexteditor/editorchooser.h> +#include <qfile.h> +#include <qdir.h> +#include <qtextstream.h> +#include <qptrlist.h> + + +QXsldbgDoc::QXsldbgDoc(QWidget *parent, KURL url) + : QObject(0L, "QXsldbgDoc"), kDoc(0L),kView(0L), locked(false) +{ + kDoc = KTextEditor::createDocument("libkatepart", 0L,"KTextEditor::Document"); + connect(kDoc, SIGNAL(started(KIO::Job *)), this, SLOT(lockDoc())); + connect(kDoc, SIGNAL(completed()), this, SLOT(unlockDoc())); + if (kDoc){ + kView = kDoc->createView(parent, "QXsldbgDocView"); + KURL cleanUrl; + // convert paths relative to PWD into a absolute path + QString relUrl = url.prettyURL(); + if (!relUrl.contains(":/")){ + if (!(relUrl.left(1) == "/")) + relUrl.prepend(QDir::currentDirPath() + "/"); + cleanUrl.setFileName(relUrl); + }else{ + cleanUrl = url; + } + kDoc->openURL(cleanUrl); + } +} + + +QXsldbgDoc::~QXsldbgDoc() +{ + if (kDoc){ + if (kDoc->views().count() == 1){ + kDoc->closeURL(false); + delete kDoc; + } + } +} + +void QXsldbgDoc::slotResult( KIO::Job *job ) +{ + if ( job->error() != 0 ){ + }else{ + } + emit docChanged(); +} + +KURL QXsldbgDoc::url() const +{ + if (kDoc) + return kDoc->url(); + else + return KURL(); +} + +void QXsldbgDoc::refresh() +{ + if (kDoc){ + KURL lastUrl = kDoc->url(); + kDoc->closeURL(false); + kDoc->openURL(lastUrl); + } +} + + +void QXsldbgDoc::enableBreakPoint(uint lineNumber, bool state) +{ + if (locked) + return; + + KTextEditor::MarkInterface *markIf = KTextEditor::markInterface(kDoc); + if (markIf){ + if (state){ + markIf->setMark(lineNumber, KTextEditor::MarkInterface::BreakpointActive); + }else{ + markIf->removeMark(lineNumber, KTextEditor::MarkInterface::BreakpointDisabled); + } + } +} + +void QXsldbgDoc::addBreakPoint(uint lineNumber, bool enabled) +{ + if (locked) + return; + + KTextEditor::MarkInterface *markIf = KTextEditor::markInterface(kDoc); + if (markIf){ + if (enabled) + markIf->setMark(lineNumber, KTextEditor::MarkInterface::BreakpointActive); + else + markIf->setMark(lineNumber, KTextEditor::MarkInterface::BreakpointDisabled); + } +} + +void QXsldbgDoc::deleteBreakPoint(uint lineNumber) +{ + if (locked) + return; + + KTextEditor::MarkInterface *markIf = KTextEditor::markInterface(kDoc); + if (markIf) + markIf->clearMark(lineNumber); +} + + +void QXsldbgDoc::clearMarks(bool allMarkTypes) +{ + if (locked) + return; + + KTextEditor::MarkInterface *markIf = KTextEditor::markInterface(kDoc); + if (markIf){ + if (!allMarkTypes){ + QPtrList<KTextEditor::Mark> marks = markIf->marks(); + while ( marks.current()) { + markIf->removeMark(marks.current()->line, KTextEditor::MarkInterface::Execution); + markIf->removeMark(marks.current()->line, KTextEditor::MarkInterface::BreakpointReached); + marks.next(); + } + }else { + markIf->clearMarks(); + } + } + +} + +void QXsldbgDoc::selectBreakPoint(uint lineNumber, bool reachedBreakPoint) +{ + if (locked) + return; + + clearMarks(false); + KTextEditor::MarkInterface *markIf = KTextEditor::markInterface(kDoc); + if (markIf){ + if (reachedBreakPoint){ + //markIf->setMark(lineNumber, KTextEditor::MarkInterface::BreakpointReached); + }else{ + markIf->setMark(lineNumber, KTextEditor::MarkInterface::Execution); + } + } +} + +void QXsldbgDoc::lockDoc() +{ + locked = true; +} + +void QXsldbgDoc::unlockDoc() +{ + locked = false; +} +#include "qxsldbgdoc.moc" |