summaryrefslogtreecommitdiff
path: root/libopie2
Side-by-side diff
Diffstat (limited to 'libopie2') (more/less context) (show whitespace changes)
-rw-r--r--libopie2/opiecore/opiecore.pro2
-rw-r--r--libopie2/opiecore/osharedpointer.h136
-rw-r--r--libopie2/opiecore/osmartpointer.cpp57
-rw-r--r--libopie2/opiecore/osmartpointer.h17
4 files changed, 201 insertions, 11 deletions
diff --git a/libopie2/opiecore/opiecore.pro b/libopie2/opiecore/opiecore.pro
index 8189a7c..e72576c 100644
--- a/libopie2/opiecore/opiecore.pro
+++ b/libopie2/opiecore/opiecore.pro
@@ -6,30 +6,32 @@ HEADERS = oapplication.h \
odebug.h \
oglobal.h \
oglobalsettings.h \
okeyconfigmanager.h \
okeyfilter.h \
opluginloader.h \
oprocess.h \
oprocctrl.h \
+ osharedpointer.h \
osmartpointer.h \
ostorageinfo.h \
xmltree.h
SOURCES = oapplication.cpp \
oconfig.cpp \
odebug.cpp \
oglobal.cpp \
oglobalsettings.cpp \
okeyconfigmanager.cpp \
okeyfilter.cpp \
opluginloader.cpp \
oprocess.cpp \
oprocctrl.cpp \
+ osmartpointer.cpp \
ostorageinfo.cpp \
xmltree.cpp
# The following files are currently not compileable on mac !
# Therfore I removed them from the build .. (eilers)
CONFTEST = $$system( echo $CONFIG_TARGET_MACOSX )
diff --git a/libopie2/opiecore/osharedpointer.h b/libopie2/opiecore/osharedpointer.h
new file mode 100644
index 0000000..f19d836
--- a/dev/null
+++ b/libopie2/opiecore/osharedpointer.h
@@ -0,0 +1,136 @@
+// -*- Mode: C++; -*-
+/*
+ This file is part of the Opie Project
+ Copyright (C) 2004 Rajko Albrecht <alwin@handhelds.org>
+ Copyright (C) 2004 Holger Hans Peter Freyther <freyther@handhelds.org>
+ Copyright (C) The Opie Team <opie-devel@handhelds.org>
+ =.
+ .=l.
+ .>+-=
+_;:, .> :=|. This program is free software; you can
+.> <`_, > . <= redistribute it and/or modify it under
+:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
+.="- .-=="i, .._ License as published by the Free Software
+- . .-<_> .<> Foundation; either version 2 of the License,
+ ._= =} : or (at your option) any later version.
+ .%`+i> _;_.
+ .i_,=:_. -<s. This program is distributed in the hope that
+ + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
+ : .. .:, . . . without even the implied warranty of
+ =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
+ _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
+..}^=.= = ; Library General Public License for more
+++= -. .` .: details.
+: = ...= . :.=-
+-. .:....=;==+<; You should have received a copy of the GNU
+ -_. . . )=. = Library General Public License along with
+ -- :-=` this library; see the file COPYING.LIB.
+ If not, write to the Free Software Foundation,
+ Inc., 59 Temple Place - Suite 330,
+ Boston, MA 02111-1307, USA.
+*/
+
+
+#ifndef O_SHARED_POINTER_H
+#define O_SHARED_POINTER_H
+
+#include <opie2/osmartpointer.h>
+
+/*!
+ * \file osharedpointer.h
+ * \brief Adapter with Refcounting around any data type
+ * \author Rajko Albrecht and Holger Hans Peter Freyther
+ */
+
+namespace Opie {
+namespace Core {
+template<class T>
+class OSharedPointerData : public ORefCount {
+public:
+ OSharedPointerData( T* dt ) {
+ data = dt;
+ }
+
+ ~OSharedPointerData() {
+ delete data;
+ }
+
+ T *data;
+};
+
+
+/**
+ * \brief A small Adapter around any Pointer
+ *
+ *
+ *
+ */
+template<class T>
+class OSharedPointer {
+ typedef OSharedPointerData<T> Data;
+ Data* data;
+
+ void unref() {
+ if (data) { data->Decr(); if (!data->Shared()) delete data; }
+ data = 0;
+ }
+
+public:
+ OSharedPointer () { data = 0;}
+
+ OSharedPointer( T* t ) {
+ data = new Data( t );
+ data->Incr();
+ }
+
+ OSharedPointer( const OSharedPointer<T>& p ) {
+ if ( data = p.data ) data->Incr();
+ }
+
+ ~OSharedPointer() {
+ unref();
+ }
+
+ OSharedPointer<T> &operator=( const OSharedPointer<T>& p ) {
+ // already same: nothing to do
+ if (data == p.data) return *this;
+ // decouple reference
+ unref();
+ // establish new reference
+ if (data = p.data) data->Incr();
+ return *this;
+ }
+
+ OSharedPointer<T> &operator=( T *p ) {
+ unref();
+ data = new Data( p );
+ data->Incr();
+
+ return *this;
+ }
+
+ operator T* () const { return data->data; }
+ T& operator*() { return *data->data; }
+ const T& operator*()const { return data->data; }
+
+ //! deref with method call
+ T* operator-> () {return data->data; }
+ //! deref with const method call
+ const T* operator-> ()const {return data->data; }
+
+
+ //! supports "if (pointer)"
+ operator bool () const { return (data != 0 && data->data != 0); }
+ //! "if (pointer)" as non const
+ operator bool () { return ( data != 0 && data->data != NULL );}
+
+ //! support if (!pointer)"
+ bool operator! () const { return (data == 0 || data->data == 0); }
+ //! support if (!pointer)" as non const
+ bool operator! () { return (data == 0 || data->data == 0); }
+};
+
+}
+}
+
+#endif
diff --git a/libopie2/opiecore/osmartpointer.cpp b/libopie2/opiecore/osmartpointer.cpp
new file mode 100644
index 0000000..480e03a
--- a/dev/null
+++ b/libopie2/opiecore/osmartpointer.cpp
@@ -0,0 +1,57 @@
+// -*- Mode: C++; -*-
+/*
+ This file is part of the Opie Project
+ Copyright (C) 2004 Rajko Albrecht <alwin@handhelds.org>
+ Copyright (C) The Opie Team <opie-devel@handhelds.org>
+ =.
+ .=l.
+ .>+-=
+_;:, .> :=|. This program is free software; you can
+.> <`_, > . <= redistribute it and/or modify it under
+:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
+.="- .-=="i, .._ License as published by the Free Software
+- . .-<_> .<> Foundation; either version 2 of the License,
+ ._= =} : or (at your option) any later version.
+ .%`+i> _;_.
+ .i_,=:_. -<s. This program is distributed in the hope that
+ + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
+ : .. .:, . . . without even the implied warranty of
+ =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
+ _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
+..}^=.= = ; Library General Public License for more
+++= -. .` .: details.
+: = ...= . :.=-
+-. .:....=;==+<; You should have received a copy of the GNU
+ -_. . . )=. = Library General Public License along with
+ -- :-=` this library; see the file COPYING.LIB.
+ If not, write to the Free Software Foundation,
+ Inc., 59 Temple Place - Suite 330,
+ Boston, MA 02111-1307, USA.
+*/
+
+#include "osmartpointer.h"
+
+namespace Opie {
+namespace Core {
+
+ORefCount::ORefCount()
+ : m_RefCount(0)
+{}
+
+ORefCount::~ORefCount()
+{}
+
+void ORefCount::Incr() {
+ ++m_RefCount;
+}
+
+void ORefCount::Decr() {
+ --m_RefCount;
+}
+
+bool ORefCount::Shared() {
+ return (m_RefCount > 0);
+}
+
+}
+}
diff --git a/libopie2/opiecore/osmartpointer.h b/libopie2/opiecore/osmartpointer.h
index e9cee0c..f2f6464 100644
--- a/libopie2/opiecore/osmartpointer.h
+++ b/libopie2/opiecore/osmartpointer.h
@@ -43,32 +43,27 @@ _;:, .> :=|. This program is free software; you can
namespace Opie {
namespace Core {
//! simple reference counter class
class ORefCount {
protected:
//! reference count member
- long m_RefCount;
+ unsigned long m_RefCount;
public:
//! first reference must be added after "new" via Pointer()
- ORefCount() : m_RefCount(0)
- {}
- virtual ~ORefCount() {}
+ ORefCount();
+ virtual ~ORefCount();
//! add a reference
- void Incr() {
- ++m_RefCount;
- }
+ void Incr();
//! delete a reference
- void Decr() {
- --m_RefCount;
- }
+ void Decr();
//! is it referenced
- bool Shared() { return (m_RefCount > 0); }
+ bool Shared();
};
//! reference counting wrapper class
template<class T> class OSmartPointer {
//! pointer to object
/*!
* this object must contain Incr(), Decr() and Shared()
* methode as public members. The best way is, that it will be a child