-
Notifications
You must be signed in to change notification settings - Fork 2.6k
Expand file tree
/
Copy pathIdStack.java
More file actions
94 lines (71 loc) · 1.71 KB
/
IdStack.java
File metadata and controls
94 lines (71 loc) · 1.71 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
package com.reactnativenavigation.viewcontrollers.stack;
import com.reactnativenavigation.utils.StringUtils;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import androidx.annotation.NonNull;
import static com.reactnativenavigation.utils.CollectionUtils.*;
public class IdStack<E> implements Iterable<String> {
private final ArrayList<String> deque = new ArrayList<>();
private final Map<String, E> map = new HashMap<>();
public void push(String id, E item) {
deque.add(id);
map.put(id, item);
}
public void set(String id, E item, int index) {
deque.add(index, id);
map.put(id, item);
}
public E peek() {
return isEmpty() ? null : map.get(last(deque));
}
public E pop() {
return isEmpty() ? null : map.remove(removeLast(deque));
}
public boolean isEmpty() {
return deque.isEmpty();
}
public int size() {
return deque.size();
}
public String peekId() {
return last(deque);
}
public void clear() {
deque.clear();
map.clear();
}
public E get(final String id) {
return map.get(id);
}
public E get(final int index) {
return map.get(deque.get(index));
}
public boolean containsId(final String id) {
return deque.contains(id);
}
public E remove(final String id) {
if (!containsId(id)) {
return null;
}
deque.remove(id);
return map.remove(id);
}
public boolean isTop(final String id) {
return StringUtils.isEqual(id, peekId());
}
@NonNull
@Override
public Iterator<String> iterator() {
return deque.iterator();
}
public List<E> values() {
return map(deque, map::get);
}
public void remove(Iterator<String> iterator, String id) {
iterator.remove();
map.remove(id);
}
}