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 | bd9e6617827818fd043452c08c606f07b78014a0 (patch) | |
tree | 425bb4c3168f9c02f10150f235d2cb998dcc6108 /kspy/spy.cpp | |
download | tdesdk-bd9e6617827818fd043452c08c606f07b78014a0.tar.gz tdesdk-bd9e6617827818fd043452c08c606f07b78014a0.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/kdesdk@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kspy/spy.cpp')
-rw-r--r-- | kspy/spy.cpp | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/kspy/spy.cpp b/kspy/spy.cpp new file mode 100644 index 00000000..341f5b62 --- /dev/null +++ b/kspy/spy.cpp @@ -0,0 +1,115 @@ +/*************************************************************************** + spy.cpp - description + ------------------- + begin : Tue May 1 02:59:33 BST 2001 + copyright : (C) 2001 by Richard Moore + email : rich@kde.org + ***************************************************************************/ + +/*************************************************************************** + * * + * 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. * + * * + ***************************************************************************/ + +#include <klistviewsearchline.h> +#include <klocale.h> + +#include <qlabel.h> +#include <qlayout.h> +#include <qlistview.h> +#include <qsplitter.h> +#include <ktabwidget.h> +#include <qvbox.h> + +#include "navview.h" +#include "propsview.h" +#include "sigslotview.h" +#include "receiversview.h" +#include "classinfoview.h" +#include "spy.h" + +extern "C" +{ + KDE_EXPORT void* init_libkspy() + { + qWarning( "KSpy: Initialising...\n" ); + Spy *s = new Spy(); + s->show(); + + return 0; + } +} + +Spy::Spy( QWidget *parent, const char *name ) + : QWidget( parent, name ) +{ + QVBoxLayout *layout = new QVBoxLayout( this, 11, 6 ); + + QSplitter *div = new QSplitter( this ); + layout->addWidget( div ); + + QVBox *leftPane = new QVBox( div ); + + KListViewSearchLine *searchLine = new KListViewSearchLine( leftPane, "search line" ); + mNavView = new NavView( leftPane, "navigation view" ); + searchLine->setListView( mNavView ); + + KTabWidget *tabs = new KTabWidget( div ); + + mPropsView = new PropsView( tabs, "properties view" ); + tabs->addTab( mPropsView, i18n( "Properties" ) ); + + mSigSlotView = new SigSlotView( tabs, "signals and slots view" ); + tabs->addTab( mSigSlotView, i18n( "Signals && Slots" ) ); + + mReceiversView = new ReceiversView( tabs, "receivers view" ); + tabs->addTab( mReceiversView, i18n( "Receivers" ) ); + + mClassInfoView = new ClassInfoView( tabs, "class info view" ); + tabs->addTab( mClassInfoView, i18n( "Class Info" ) ); + + mNavView->buildTree(); + + connect( mNavView, SIGNAL( selected( QObject * ) ), + mPropsView, SLOT( setTarget( QObject * ) ) ); + connect( mNavView, SIGNAL( selected( QObject * ) ), + mSigSlotView, SLOT( setTarget( QObject * ) ) ); + connect( mNavView, SIGNAL( selected( QObject * ) ), + mReceiversView, SLOT( setTarget( QObject * ) ) ); + connect( mNavView, SIGNAL( selected( QObject * ) ), + mClassInfoView, SLOT( setTarget( QObject * ) ) ); +} + +Spy::~Spy() +{ +} + + +void Spy::setTarget( QWidget *target ) +{ + mTarget = target; + mPropsView->buildList( mTarget ); + mSigSlotView->buildList( mTarget ); + mReceiversView->buildList( mTarget ); + mClassInfoView->buildList( mTarget ); +} + +void Spy::keyPressEvent( QKeyEvent *event ) +{ + if ( event->key() == Qt::Key_Up ) { + event->accept(); + QApplication::postEvent( mNavView, new QKeyEvent( QEvent::KeyPress, Qt::Key_Up, 0, 0 ) ); + } else if ( event->key() == Qt::Key_Down ) { + event->accept(); + QApplication::postEvent( mNavView, new QKeyEvent( QEvent::KeyPress, Qt::Key_Down, 0, 0 ) ); + } else if ( event->key() == Qt::Key_Return ) { + event->accept(); + mNavView->expandVisibleTree(); + } +} + +#include "spy.moc" |