Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(58)

Unified Diff: webkit/blob/deletable_file_reference.cc

Issue 3455022: Revert 60378 (trying to track down http://crbug.com/56752 )- Flesh out URLLoa... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 10 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « webkit/blob/deletable_file_reference.h ('k') | webkit/blob/deletable_file_reference_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webkit/blob/deletable_file_reference.cc
===================================================================
--- webkit/blob/deletable_file_reference.cc (revision 60424)
+++ webkit/blob/deletable_file_reference.cc (working copy)
@@ -1,63 +0,0 @@
-// Copyright (c) 2010 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/blob/deletable_file_reference.h"
-
-#include <map>
-#include "base/file_util.h"
-#include "base/file_util_proxy.h"
-#include "base/message_loop_proxy.h"
-#include "base/singleton.h"
-
-namespace webkit_blob {
-
-namespace {
-
-typedef std::map<FilePath, DeletableFileReference*> DeleteableFileMap;
-
-DeleteableFileMap* map() {
- return Singleton<DeleteableFileMap>::get();
-}
-
-} // namespace
-
-// static
-scoped_refptr<DeletableFileReference> DeletableFileReference::Get(
- const FilePath& path) {
- DeleteableFileMap::iterator found = map()->find(path);
- DeletableFileReference* reference =
- (found == map()->end()) ? NULL : found->second;
- return scoped_refptr<DeletableFileReference>(reference);
-}
-
-// static
-scoped_refptr<DeletableFileReference> DeletableFileReference::GetOrCreate(
- const FilePath& path, base::MessageLoopProxy* file_thread) {
- DCHECK(file_thread);
- typedef std::pair<DeleteableFileMap::iterator, bool> InsertResult;
- InsertResult result = map()->insert(
- DeleteableFileMap::value_type(path, NULL));
- if (result.second == false)
- return scoped_refptr<DeletableFileReference>(result.first->second);
-
- // Wasn't in the map, create a new reference and store the pointer.
- scoped_refptr<DeletableFileReference> reference =
- new DeletableFileReference(path, file_thread);
- result.first->second = reference.get();
- return reference;
-}
-
-DeletableFileReference::DeletableFileReference(
- const FilePath& path, base::MessageLoopProxy* file_thread)
- : path_(path), file_thread_(file_thread) {
- DCHECK(map()->find(path_)->second == NULL);
-}
-
-DeletableFileReference::~DeletableFileReference() {
- DCHECK(map()->find(path_)->second == this);
- map()->erase(path_);
- base::FileUtilProxy::Delete(file_thread_, path_, NULL);
-}
-
-} // namespace webkit_blob
« no previous file with comments | « webkit/blob/deletable_file_reference.h ('k') | webkit/blob/deletable_file_reference_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698