OLD | NEW |
| (Empty) |
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "net/disk_cache/memory/mem_rankings.h" | |
6 | |
7 #include "base/logging.h" | |
8 #include "net/disk_cache/memory/mem_entry_impl.h" | |
9 | |
10 namespace disk_cache { | |
11 | |
12 MemRankings::~MemRankings() { | |
13 DCHECK(!head_ && !tail_); | |
14 } | |
15 | |
16 void MemRankings::Insert(MemEntryImpl* node) { | |
17 if (head_) | |
18 head_->set_prev(node); | |
19 | |
20 if (!tail_) | |
21 tail_ = node; | |
22 | |
23 node->set_prev(NULL); | |
24 node->set_next(head_); | |
25 head_ = node; | |
26 } | |
27 | |
28 void MemRankings::Remove(MemEntryImpl* node) { | |
29 MemEntryImpl* prev = node->prev(); | |
30 MemEntryImpl* next = node->next(); | |
31 | |
32 if (head_ == node) | |
33 head_ = next; | |
34 | |
35 if (tail_ == node) | |
36 tail_ = prev; | |
37 | |
38 if (prev) | |
39 prev->set_next(next); | |
40 | |
41 if (next) | |
42 next->set_prev(prev); | |
43 | |
44 node->set_next(NULL); | |
45 node->set_prev(NULL); | |
46 } | |
47 | |
48 void MemRankings::UpdateRank(MemEntryImpl* node) { | |
49 Remove(node); | |
50 Insert(node); | |
51 } | |
52 | |
53 MemEntryImpl* MemRankings::GetNext(MemEntryImpl* node) { | |
54 if (!node) | |
55 return head_; | |
56 | |
57 return node->next(); | |
58 } | |
59 | |
60 MemEntryImpl* MemRankings::GetPrev(MemEntryImpl* node) { | |
61 if (!node) | |
62 return tail_; | |
63 | |
64 return node->prev(); | |
65 } | |
66 | |
67 } // namespace disk_cache | |
OLD | NEW |