aboutsummaryrefslogtreecommitdiffstats
path: root/components/util/linked_list.rs
diff options
context:
space:
mode:
Diffstat (limited to 'components/util/linked_list.rs')
-rw-r--r--components/util/linked_list.rs21
1 files changed, 21 insertions, 0 deletions
diff --git a/components/util/linked_list.rs b/components/util/linked_list.rs
new file mode 100644
index 00000000000..5114f02c0e4
--- /dev/null
+++ b/components/util/linked_list.rs
@@ -0,0 +1,21 @@
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+//! Utility functions for doubly-linked lists.
+
+use std::collections::LinkedList;
+use std::mem;
+
+/// Splits the head off a list in O(1) time, and returns the head.
+pub fn split_off_head<T>(list: &mut LinkedList<T>) -> LinkedList<T> {
+ let tail = list.split_off(1);
+ mem::replace(list, tail)
+}
+
+/// Prepends the items in the other list to this one, leaving the other list empty.
+#[inline]
+pub fn prepend_from<T>(this: &mut LinkedList<T>, other: &mut LinkedList<T>) {
+ other.append(this);
+ mem::swap(this, other);
+}