summaryrefslogtreecommitdiffstats
path: root/llvm/unittests/ADT/ilistTest.cpp
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2010-05-12 21:35:19 +0000
committerDaniel Dunbar <daniel@zuster.org>2010-05-12 21:35:19 +0000
commit959ae59997ac1ec65819671f974e0ee6730323cf (patch)
treeb9426d9101c561bf9301834d85ed4c53b416e3f0 /llvm/unittests/ADT/ilistTest.cpp
parent6f97c4e7bc155f7200db4e53f33feb3c5d1bff95 (diff)
downloadbcm5719-llvm-959ae59997ac1ec65819671f974e0ee6730323cf.tar.gz
bcm5719-llvm-959ae59997ac1ec65819671f974e0ee6730323cf.zip
ADT: Add ilist_node::get{Prev,Next}Node, which return the adjacent node or null.
- This provides a convenient alternative to using something llvm::prior or manual iterator access, for example:: if (T *Prev = foo->getPrevNode()) ... instead of:: iterator it(foo); if (it != begin()) { --it; ... } - Chris, please review. llvm-svn: 103647
Diffstat (limited to 'llvm/unittests/ADT/ilistTest.cpp')
-rw-r--r--llvm/unittests/ADT/ilistTest.cpp39
1 files changed, 39 insertions, 0 deletions
diff --git a/llvm/unittests/ADT/ilistTest.cpp b/llvm/unittests/ADT/ilistTest.cpp
new file mode 100644
index 00000000000..3bf04dccc2c
--- /dev/null
+++ b/llvm/unittests/ADT/ilistTest.cpp
@@ -0,0 +1,39 @@
+//===- llvm/unittest/ADT/APInt.cpp - APInt unit tests ---------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include <ostream>
+#include "gtest/gtest.h"
+#include "llvm/ADT/ilist.h"
+#include "llvm/ADT/ilist_node.h"
+
+using namespace llvm;
+
+namespace {
+
+struct Node : ilist_node<Node> {
+ int Value;
+
+ Node() {}
+ Node(int _Value) : Value(_Value) {}
+};
+
+TEST(ilistTest, Basic) {
+ ilist<Node> List;
+ List.push_back(Node(1));
+ EXPECT_EQ(1, List.back().Value);
+ EXPECT_EQ(0, List.back().getPrevNode());
+ EXPECT_EQ(0, List.back().getNextNode());
+
+ List.push_back(Node(2));
+ EXPECT_EQ(2, List.back().Value);
+ EXPECT_EQ(2, List.front().getNextNode()->Value);
+ EXPECT_EQ(1, List.back().getPrevNode()->Value);
+}
+
+}
OpenPOWER on IntegriCloud