summaryrefslogtreecommitdiffstats
path: root/webkit/appcache/appcache.cc
diff options
context:
space:
mode:
authorjennb@chromium.org <jennb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-26 23:10:09 +0000
committerjennb@chromium.org <jennb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-26 23:10:09 +0000
commit49672df7e74a0633a0ee92e89b4daff904765638 (patch)
treede848215c76faf23ad3e99d456b8a056c8e61491 /webkit/appcache/appcache.cc
parentc21b90496d356e5d8e56231dc8c4d4962a67f117 (diff)
downloadchromium_src-49672df7e74a0633a0ee92e89b4daff904765638.zip
chromium_src-49672df7e74a0633a0ee92e89b4daff904765638.tar.gz
chromium_src-49672df7e74a0633a0ee92e89b4daff904765638.tar.bz2
Skeleton classes for appcache library framework. This is a work in progress. Committing early to allow other code to use these objects, but still need to consider refptrs and add unittests.
TEST=none (will add when classes are fleshed out more) BUG=none Review URL: http://codereview.chromium.org/174034 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@24554 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/appcache/appcache.cc')
-rw-r--r--webkit/appcache/appcache.cc51
1 files changed, 51 insertions, 0 deletions
diff --git a/webkit/appcache/appcache.cc b/webkit/appcache/appcache.cc
new file mode 100644
index 0000000..d202308
--- /dev/null
+++ b/webkit/appcache/appcache.cc
@@ -0,0 +1,51 @@
+// Copyright (c) 2009 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 "webkit/appcache/appcache.h"
+
+#include "base/logging.h"
+#include "webkit/appcache/appcache_group.h"
+#include "webkit/appcache/appcache_host.h"
+#include "webkit/appcache/appcache_service.h"
+
+namespace appcache {
+
+AppCache::~AppCache() {
+ DCHECK(associated_hosts_.empty());
+ DCHECK(!owning_group_);
+ service_->RemoveCache(this);
+}
+
+void AppCache::UnassociateHost(AppCacheHost* host) {
+ associated_hosts_.erase(host);
+
+ // Inform group if this cache is no longer in use.
+ if (associated_hosts_.empty()) {
+ if (!owning_group_ || owning_group_->RemoveCache(this)) {
+ owning_group_ = NULL;
+ delete this;
+ }
+ }
+}
+
+void AppCache::AddEntry(const GURL& url, const AppCacheEntry& entry) {
+ DCHECK(entries_.find(url) == entries_.end());
+ entries_.insert(EntryMap::value_type(url, entry));
+}
+
+void AppCache::AddOrModifyEntry(const GURL& url, const AppCacheEntry& entry) {
+ std::pair<EntryMap::iterator, bool> ret =
+ entries_.insert(EntryMap::value_type(url, entry));
+
+ // Entry already exists. Merge the types of the new and existing entries.
+ if (!ret.second)
+ ret.first->second.add_types(entry.types());
+}
+
+AppCacheEntry* AppCache::GetEntry(const GURL& url) {
+ EntryMap::iterator it = entries_.find(url);
+ return (it != entries_.end()) ? &(it->second) : NULL;
+}
+
+} // namespace appcache