summaryrefslogtreecommitdiff
path: root/libopie
authorzecke <zecke>2002-10-05 21:20:45 (UTC)
committer zecke <zecke>2002-10-05 21:20:45 (UTC)
commitd0c61661d694574dfaf18162e015c493cd1d571c (patch) (side-by-side diff)
tree7761e3c8d503534e7e9ca43e0019251d56ff58bb /libopie
parent6e217b24b1eb09d922e35dc5126fa5ec578915b8 (diff)
downloadopie-d0c61661d694574dfaf18162e015c493cd1d571c.zip
opie-d0c61661d694574dfaf18162e015c493cd1d571c.tar.gz
opie-d0c61661d694574dfaf18162e015c493cd1d571c.tar.bz2
Implemented the factory
now I can finally do switching
Diffstat (limited to 'libopie') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie/ofileselector/ofilefactory.cpp44
1 files changed, 31 insertions, 13 deletions
diff --git a/libopie/ofileselector/ofilefactory.cpp b/libopie/ofileselector/ofilefactory.cpp
index f752149..aa143b4 100644
--- a/libopie/ofileselector/ofilefactory.cpp
+++ b/libopie/ofileselector/ofilefactory.cpp
@@ -1,40 +1,58 @@
#include "ofilefactory.h"
OFileFactory::OFileFactory() {
}
OFileFactory::~OFileFactory() {
}
QStringList OFileFactory::lister()const {
QStringList list;
QMap<QString, listerFact>::ConstIterator it;
for ( it = m_lister.begin(); it != m_lister.end(); ++it ) {
- list << (*it);
+ list << it.key();
}
return list;
}
QStringList OFileFactory::views()const {
QStringList list;
-
+ QMap<QString, viewFact>::ConstIterator it;
+ for (it = m_view.begin(); it != m_view.end(); ++it ) {
+ list << it.key();
+ }
return list;
}
OFileView* OFileFactory::view( const QString& name,
- OFileSelector*, QWidget* ) {
-
-}
-OLister* OFileFactory::lister(const QString&, OFileSelector*) {
+ OFileSelector* sel, QWidget* par) {
+ OFileView* vie= 0l;
-}
-void OFileFactory::addLister( const QString&, listerFact fact ) {
+ QMap<QString, viewFact>::Iterator it;
+ it = m_view.find( name );
+ if ( it != m_view.end() ) {
+ vie = (*(it.data() ) )(sel, par);
+ }
+ return vie;
}
-void OFileFactory::addView( const QString&, viewFact fact ) {
+OLister* OFileFactory::lister(const QString& name, OFileSelector* sel) {
+ OLister* lis = 0l;
+ QMap<QString, listerFact>::Iterator it;
+ it = m_lister.find( name );
+ if ( it != m_lister.end() ) {
+ lis = (*(it.data() ) )(sel);
+ }
+ return lis;
}
-void OFileFactory::removeLister( const QString& ) {
-
+void OFileFactory::addLister( const QString& name, listerFact fact ) {
+ m_lister.insert( name, fact );
}
-void OFileFactory::removeView( const QString& ) {
-
+void OFileFactory::addView( const QString& name, viewFact fact ) {
+ m_view.insert( name, fact );
+}
+void OFileFactory::removeLister( const QString& name) {
+ m_lister.remove( name );
+}
+void OFileFactory::removeView( const QString& name) {
+ m_view.remove( name );
}