Skip to content

Commit 52d4417

Browse files
author
blake2-ppc
committed
---
yaml --- r: 64214 b: refs/heads/snap-stage3 c: 6a95e49 h: refs/heads/master v: v3
1 parent 00f38cc commit 52d4417

File tree

3 files changed

+42
-1
lines changed

3 files changed

+42
-1
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
---
22
refs/heads/master: 2d28d645422c1617be58c8ca7ad9a457264ca850
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
4-
refs/heads/snap-stage3: 92842d6516d2c5d92bad553585340f2ae3284308
4+
refs/heads/snap-stage3: 6a95e49fc5bad1367f597bf0eeab7197c9ca226a
55
refs/heads/try: 7b78b52e602bb3ea8174f9b2006bff3315f03ef9
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
//! Container traits for extra
12+
13+
use std::container::Mutable;
14+
15+
/// A double-ended sequence that allows querying, insertion and deletion at both ends.
16+
pub trait Deque<T> : Mutable {
17+
/// Provide a reference to the front element, or None if the sequence is empty
18+
fn front<'a>(&'a self) -> Option<&'a T>;
19+
20+
/// Provide a mutable reference to the front element, or None if the sequence is empty
21+
fn front_mut<'a>(&'a mut self) -> Option<&'a mut T>;
22+
23+
/// Provide a reference to the back element, or None if the sequence is empty
24+
fn back<'a>(&'a self) -> Option<&'a T>;
25+
26+
/// Provide a mutable reference to the back element, or None if the sequence is empty
27+
fn back_mut<'a>(&'a mut self) -> Option<&'a mut T>;
28+
29+
/// Insert an element first in the sequence
30+
fn push_front(&mut self, elt: T);
31+
32+
/// Insert an element last in the sequence
33+
fn push_back(&mut self, elt: T);
34+
35+
/// Remove the last element and return it, or None if the sequence is empty
36+
fn pop_back(&mut self) -> Option<T>;
37+
38+
/// Remove the first element and return it, or None if the sequence is empty
39+
fn pop_front(&mut self) -> Option<T>;
40+
}

branches/snap-stage3/src/libextra/extra.rs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -67,6 +67,7 @@ pub mod flatpipes;
6767

6868
// Collections
6969

70+
pub mod container;
7071
pub mod bitv;
7172
pub mod deque;
7273
pub mod fun_treemap;

0 commit comments

Comments
 (0)