diff options
Diffstat (limited to 'clients/tde/src/app/views')
-rw-r--r-- | clients/tde/src/app/views/Makefile.am | 5 | ||||
-rw-r--r-- | clients/tde/src/app/views/instrumentview.cpp | 75 | ||||
-rw-r--r-- | clients/tde/src/app/views/instrumentview.h | 41 |
3 files changed, 121 insertions, 0 deletions
diff --git a/clients/tde/src/app/views/Makefile.am b/clients/tde/src/app/views/Makefile.am new file mode 100644 index 0000000..fa77152 --- /dev/null +++ b/clients/tde/src/app/views/Makefile.am @@ -0,0 +1,5 @@ +INCLUDES = -I$(top_srcdir)/src/part $(all_includes) +METASOURCES = AUTO +noinst_LTLIBRARIES = libinstrumentview.la +libinstrumentview_la_SOURCES = instrumentview.cpp + diff --git a/clients/tde/src/app/views/instrumentview.cpp b/clients/tde/src/app/views/instrumentview.cpp new file mode 100644 index 0000000..4b3d92e --- /dev/null +++ b/clients/tde/src/app/views/instrumentview.cpp @@ -0,0 +1,75 @@ +//Author: Timothy Pearson <kb9vqf@pearsoncomputing.net>, (C) 2012 +//Copyright: See COPYING file that comes with this distribution + +#include "instrumentview.h" + +#include <tqtimer.h> + +#include <klibloader.h> +#include <klocale.h> +#include <kmessagebox.h> + +namespace RemoteLab { + +InstrumentView::InstrumentView(const TQString &library, TQWidget *parentWidget, const char *name, WFlags f) + : KMdiChildView(parentWidget, name, f) + , m_libraryName(library) + , m_instrumentPart( 0 ) +{ + init(); +} + +InstrumentView::InstrumentView(const TQString &library, const TQString &caption, TQWidget *parentWidget, const char *name, WFlags f) + : KMdiChildView(caption, parentWidget, name, f) + , m_libraryName(library) + , m_instrumentPart( 0 ) +{ + init(); +} + +InstrumentView::~InstrumentView() { + // +} + +void InstrumentView::init() { + KLibFactory *factory = KLibLoader::self()->factory(m_libraryName.ascii()); + + if (!factory) { + KMessageBox::error( this, i18n("TDE could not find the Remote Laboratory Communications Analyzer Part, or the Remote Laboratory Communications Analyzer Part could not be started. Did you make install?") ); + TQTimer::singleShot(0, this, SLOT(close())); + } + else { + m_instrumentPart = (InstrumentPart *)factory->create(TQT_TQOBJECT(this), "part", "KParts::ReadOnlyPart"); + } +} + +bool InstrumentView::queryExit() { + if( !m_instrumentPart ) //apparently std::exit() still calls this function, and abort() causes a crash.. + return true; + + m_instrumentPart->closeURL(); + + return true; +} + +void InstrumentView::closeConnections() { + queryExit(); +} + +void InstrumentView::connectServer(TQString server) { + if (m_instrumentPart) { + m_instrumentPart->openURL(KURL(server)); + } +} + +/********************************************** + SESSION MANAGEMENT + **********************************************/ + +void InstrumentView::saveProperties( KConfig *config ) { +} + +void InstrumentView::readProperties( KConfig *config ) { +} + +} //namespace RemoteLab
\ No newline at end of file diff --git a/clients/tde/src/app/views/instrumentview.h b/clients/tde/src/app/views/instrumentview.h new file mode 100644 index 0000000..c9df8d2 --- /dev/null +++ b/clients/tde/src/app/views/instrumentview.h @@ -0,0 +1,41 @@ +//Author: Timothy Pearson <kb9vqf@pearsoncomputing.net>, (C) 2012 +//Copyright: See COPYING file that comes with this distribution + +#ifndef SPECTRUMANALYZERVIEW_H +#define SPECTRUMANALYZERVIEW_H + +#include <kconfig.h> +#include <kparts/part.h> +#include <kmdichildview.h> + +class KAction; + +namespace RemoteLab { + +typedef KParts::ReadOnlyPart InstrumentPart; + +class InstrumentView : public KMdiChildView +{ + Q_OBJECT + + public: + InstrumentView(const TQString &library, TQWidget *parentWidget=0L, const char *name=0L, WFlags f=0); + InstrumentView(const TQString &library, const TQString &caption, TQWidget *parentWidget=0L, const char *name=0L, WFlags f=0); + ~InstrumentView(); + void connectServer(TQString server); + void closeConnections(); + + protected: + virtual void saveProperties( KConfig * ); + virtual void readProperties( KConfig * ); + virtual bool queryExit(); + + private: + void init(); + TQString m_libraryName; + RemoteLab::InstrumentPart *m_instrumentPart; +}; + +} // namespace RemoteLab + +#endif |