summaryrefslogtreecommitdiff
path: root/libopie2/opiecore/okeyfilter.cpp
authoralwin <alwin>2004-08-01 16:20:38 (UTC)
committer alwin <alwin>2004-08-01 16:20:38 (UTC)
commite9f9eb19567a2afa354c36490ee8f4b191cf9395 (patch) (side-by-side diff)
tree264557433a4acf15e9bde6ab800d4a8df362d70e /libopie2/opiecore/okeyfilter.cpp
parent67e2e98457418bc491efd2d4567f851e77a0441a (diff)
downloadopie-e9f9eb19567a2afa354c36490ee8f4b191cf9395.zip
opie-e9f9eb19567a2afa354c36490ee8f4b191cf9395.tar.gz
opie-e9f9eb19567a2afa354c36490ee8f4b191cf9395.tar.bz2
made interface binary clean eg. inst() returns a hidden class
documentation
Diffstat (limited to 'libopie2/opiecore/okeyfilter.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/okeyfilter.cpp53
1 files changed, 39 insertions, 14 deletions
diff --git a/libopie2/opiecore/okeyfilter.cpp b/libopie2/opiecore/okeyfilter.cpp
index d806dbd..b064272 100644
--- a/libopie2/opiecore/okeyfilter.cpp
+++ b/libopie2/opiecore/okeyfilter.cpp
@@ -33,17 +33,28 @@ _;:, .> :=|. This program is free software; you can
namespace Opie {
namespace Core {
-QValueList<QWSServer::KeyboardFilter*> OKeyFilter::filterList;
-QValueList<QWSServer::KeyboardFilter*> OKeyFilter::preFilterList;
+class OKeyFilterPrivate:public OKeyFilter, QWSServer::KeyboardFilter
+{
+ static QValueList<QWSServer::KeyboardFilter*> filterList;
+ static QValueList<QWSServer::KeyboardFilter*> preFilterList;
+protected:
+ OKeyFilterPrivate(const OKeyFilterPrivate&):OKeyFilter(),QWSServer::KeyboardFilter(){};
+ virtual void addPreHandler(QWSServer::KeyboardFilter*);
+ virtual void remPreHandler(QWSServer::KeyboardFilter*);
+
+public:
+ OKeyFilterPrivate();
+ virtual ~OKeyFilterPrivate();
+ virtual bool filter( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat );
+ virtual void addHandler(QWSServer::KeyboardFilter*);
+ virtual void remHandler(QWSServer::KeyboardFilter*);
+};
+
+QValueList<QWSServer::KeyboardFilter*> OKeyFilterPrivate::filterList;
+QValueList<QWSServer::KeyboardFilter*> OKeyFilterPrivate::preFilterList;
OKeyFilter::OKeyFilter()
- :QWSServer::KeyboardFilter()
{
- filterList.clear();
- preFilterList.clear();
- if ( isQWS( ) ) {
- QWSServer::setKeyboardFilter ( this );
- }
}
OKeyFilter::~OKeyFilter()
@@ -54,12 +65,12 @@ OKeyFilter* OKeyFilter::inst()
{
static OKeyFilter*ofilter = 0;
if (!ofilter) {
- ofilter = new OKeyFilter;
+ ofilter = new OKeyFilterPrivate;
}
return ofilter;
}
-bool OKeyFilter::filter( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat )
+bool OKeyFilterPrivate::filter( int unicode, int keycode, int modifiers, bool isPress, bool autoRepeat )
{
QValueList<QWSServer::KeyboardFilter*>::Iterator iter;
for (iter=preFilterList.begin();iter!=preFilterList.end();++iter) {
@@ -75,7 +86,7 @@ bool OKeyFilter::filter( int unicode, int keycode, int modifiers, bool isPress,
return false;
}
-void OKeyFilter::addHandler(QWSServer::KeyboardFilter*aF)
+void OKeyFilterPrivate::addHandler(QWSServer::KeyboardFilter*aF)
{
if (filterList.find(aF)!=filterList.end()) {
return;
@@ -84,7 +95,7 @@ void OKeyFilter::addHandler(QWSServer::KeyboardFilter*aF)
filterList.append(aF);
}
-void OKeyFilter::remHandler(QWSServer::KeyboardFilter*aF)
+void OKeyFilterPrivate::remHandler(QWSServer::KeyboardFilter*aF)
{
QValueList<QWSServer::KeyboardFilter*>::Iterator iter;
if ( (iter=filterList.find(aF))==filterList.end() ) {
@@ -94,7 +105,7 @@ void OKeyFilter::remHandler(QWSServer::KeyboardFilter*aF)
filterList.remove(iter);
}
-void OKeyFilter::addPreHandler(QWSServer::KeyboardFilter*aF)
+void OKeyFilterPrivate::addPreHandler(QWSServer::KeyboardFilter*aF)
{
if (preFilterList.find(aF)!=preFilterList.end()) {
return;
@@ -103,7 +114,7 @@ void OKeyFilter::addPreHandler(QWSServer::KeyboardFilter*aF)
preFilterList.append(aF);
}
-void OKeyFilter::remPreHandler(QWSServer::KeyboardFilter*aF)
+void OKeyFilterPrivate::remPreHandler(QWSServer::KeyboardFilter*aF)
{
QValueList<QWSServer::KeyboardFilter*>::Iterator iter;
if ( (iter=preFilterList.find(aF))==preFilterList.end() ) {
@@ -113,6 +124,20 @@ void OKeyFilter::remPreHandler(QWSServer::KeyboardFilter*aF)
preFilterList.remove(iter);
}
+OKeyFilterPrivate::OKeyFilterPrivate()
+ :OKeyFilter(),QWSServer::KeyboardFilter()
+{
+ filterList.clear();
+ preFilterList.clear();
+ if ( isQWS( ) ) {
+ QWSServer::setKeyboardFilter ( this );
+ }
+}
+
+OKeyFilterPrivate::~OKeyFilterPrivate()
+{
+}
+
/* namespace Core */
}
/* namespace Opie */