Index: chrome/common/extensions/value_counter.cc |
diff --git a/chrome/common/extensions/value_counter.cc b/chrome/common/extensions/value_counter.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..156e3adef00263f9265dfeb90a7477ba517bbef0 |
--- /dev/null |
+++ b/chrome/common/extensions/value_counter.cc |
@@ -0,0 +1,67 @@ |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "chrome/common/extensions/value_counter.h" |
+ |
+#include "base/values.h" |
+ |
+#include <algorithm> |
+ |
+namespace extensions { |
+ |
+ValueCounter::ValueCounter() { |
+} |
+ |
+ValueCounter::~ValueCounter() { |
+} |
+ |
+ValueCounter::Entry::Entry(const base::Value& value) |
+ : value_(value.DeepCopy()), |
+ count_(1) { |
+} |
+ |
+ValueCounter::Entry::~Entry() { |
+} |
+ |
+int ValueCounter::Entry::Increment() { |
+ return ++count_; |
+} |
+ |
+int ValueCounter::Entry::Decrement() { |
+ return --count_; |
+} |
+ |
+int ValueCounter::Add(const base::Value& value) { |
+ return AddImpl(value, true); |
+} |
+ |
+int ValueCounter::Remove(const base::Value& value) { |
+ for (EntryList::iterator it = entries_.begin(); it != entries_.end(); it++) { |
+ (*it)->value()->GetType(); |
+ if ((*it)->value()->Equals(&value)) { |
+ int remaining = (*it)->Decrement(); |
+ if (remaining == 0) { |
+ std::swap(*it, entries_.back()); |
+ entries_.pop_back(); |
+ } |
+ return remaining; |
+ } |
+ } |
+ return 0; |
+} |
+ |
+int ValueCounter::AddIfMissing(const base::Value& value) { |
+ return AddImpl(value, false); |
+} |
+ |
+int ValueCounter::AddImpl(const base::Value& value, bool increment) { |
+ for (EntryList::iterator it = entries_.begin(); it != entries_.end(); it++) { |
+ if ((*it)->value()->Equals(&value)) |
+ return increment ? (*it)->Increment() : (*it)->count(); |
+ } |
+ entries_.push_back(linked_ptr<Entry>(new Entry(value))); |
+ return 1; |
+} |
+ |
+} // namespace extensions |