summaryrefslogtreecommitdiffstats
path: root/kjs/reference_list.cpp
diff options
context:
space:
mode:
authortoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
committertoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
commitce4a32fe52ef09d8f5ff1dd22c001110902b60a2 (patch)
tree5ac38a06f3dde268dc7927dc155896926aaf7012 /kjs/reference_list.cpp
downloadtdelibs-ce4a32fe52ef09d8f5ff1dd22c001110902b60a2.tar.gz
tdelibs-ce4a32fe52ef09d8f5ff1dd22c001110902b60a2.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/kdelibs@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kjs/reference_list.cpp')
-rw-r--r--kjs/reference_list.cpp154
1 files changed, 154 insertions, 0 deletions
diff --git a/kjs/reference_list.cpp b/kjs/reference_list.cpp
new file mode 100644
index 000000000..d60fbd260
--- /dev/null
+++ b/kjs/reference_list.cpp
@@ -0,0 +1,154 @@
+// -*- c-basic-offset: 2 -*-
+/*
+ * This file is part of the KDE libraries
+ * Copyright (C) 2003 Apple Computer, Inc
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library 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., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+ *
+ */
+
+#include "reference_list.h"
+
+namespace KJS {
+ class ReferenceListNode {
+ friend class ReferenceList;
+ friend class ReferenceListIterator;
+
+ protected:
+ ReferenceListNode(const Reference &ref) : reference(ref), next(NULL) {}
+
+ private:
+ Reference reference;
+ ReferenceListNode *next;
+ };
+
+ class ReferenceListHeadNode : private ReferenceListNode {
+ friend class ReferenceList;
+ friend class ReferenceListIterator;
+
+ ReferenceListHeadNode(const Reference &ref) : ReferenceListNode(ref), refcount(1), length(0) {}
+ int refcount;
+ int length;
+ };
+
+}
+
+using namespace KJS;
+
+// ReferenceList
+
+ReferenceList::ReferenceList() :
+ head(NULL),
+ tail(NULL)
+{
+}
+
+ReferenceList::ReferenceList(const ReferenceList &list)
+{
+ head = list.head;
+ tail = list.tail;
+ if (head != NULL) {
+ head->refcount++;
+ }
+}
+
+ReferenceList &ReferenceList::operator=(const ReferenceList &list)
+{
+ ReferenceList tmp(list);
+ tmp.swap(*this);
+
+ return *this;
+}
+
+void ReferenceList::swap(ReferenceList &list)
+{
+ ReferenceListHeadNode *tmpHead = list.head;
+ list.head = head;
+ head = tmpHead;
+
+ ReferenceListNode *tmpTail = list.tail;
+ list.tail = tail;
+ tail = tmpTail;
+}
+
+
+void ReferenceList::append(const Reference& ref)
+{
+ if (tail == NULL) {
+ tail = head = new ReferenceListHeadNode(ref);
+ } else {
+ tail->next = new ReferenceListNode(ref);
+ tail = tail->next;
+ }
+ head->length++;
+}
+
+int ReferenceList::length()
+{
+ return head ? head->length : 0;
+}
+
+ReferenceList::~ReferenceList()
+{
+ if (head != NULL && --(head->refcount) == 0) {
+ ReferenceListNode *next;
+
+ for (ReferenceListNode *p = head; p != NULL; p = next) {
+ next = p->next;
+ if (p == head) {
+ delete (ReferenceListHeadNode *)p;
+ } else {
+ delete p;
+ }
+ }
+ }
+}
+
+ReferenceListIterator ReferenceList::begin() const
+{
+ return ReferenceListIterator(head);
+}
+
+ReferenceListIterator ReferenceList::end() const
+{
+ return ReferenceListIterator(NULL);
+}
+
+
+// ReferenceListIterator
+
+
+ReferenceListIterator::ReferenceListIterator(ReferenceListNode *n) :
+ node(n)
+{
+}
+
+bool ReferenceListIterator::operator!=(const ReferenceListIterator &it) const
+{
+ return node != it.node;
+}
+
+const Reference *ReferenceListIterator::operator->() const
+{
+ return &node->reference;
+}
+
+const Reference &ReferenceListIterator::operator++(int /*i*/)
+{
+ const Reference &ref = node->reference;
+ node = node->next;
+ return ref;
+}