| Index: webkit/browser/fileapi/sandbox_file_stream_writer.cc | 
| diff --git a/webkit/browser/fileapi/sandbox_file_stream_writer.cc b/webkit/browser/fileapi/sandbox_file_stream_writer.cc | 
| deleted file mode 100644 | 
| index 8fd39bc33124e8a90cab144f60307c38f5fafffc..0000000000000000000000000000000000000000 | 
| --- a/webkit/browser/fileapi/sandbox_file_stream_writer.cc | 
| +++ /dev/null | 
| @@ -1,247 +0,0 @@ | 
| -// 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 "webkit/browser/fileapi/sandbox_file_stream_writer.h" | 
| - | 
| -#include "base/files/file_util_proxy.h" | 
| -#include "base/sequenced_task_runner.h" | 
| -#include "net/base/io_buffer.h" | 
| -#include "net/base/net_errors.h" | 
| -#include "webkit/browser/blob/file_stream_reader.h" | 
| -#include "webkit/browser/fileapi/file_observers.h" | 
| -#include "webkit/browser/fileapi/file_stream_writer.h" | 
| -#include "webkit/browser/fileapi/file_system_context.h" | 
| -#include "webkit/browser/fileapi/file_system_operation_runner.h" | 
| -#include "webkit/browser/quota/quota_manager_proxy.h" | 
| -#include "webkit/common/fileapi/file_system_util.h" | 
| - | 
| -namespace storage { | 
| - | 
| -namespace { | 
| - | 
| -// Adjust the |quota| value in overwriting case (i.e. |file_size| > 0 and | 
| -// |file_offset| < |file_size|) to make the remaining quota calculation easier. | 
| -// Specifically this widens the quota for overlapping range (so that we can | 
| -// simply compare written bytes against the adjusted quota). | 
| -int64 AdjustQuotaForOverlap(int64 quota, | 
| -                            int64 file_offset, | 
| -                            int64 file_size) { | 
| -  DCHECK_LE(file_offset, file_size); | 
| -  if (quota < 0) | 
| -    quota = 0; | 
| -  int64 overlap = file_size - file_offset; | 
| -  if (kint64max - overlap > quota) | 
| -    quota += overlap; | 
| -  return quota; | 
| -} | 
| - | 
| -}  // namespace | 
| - | 
| -SandboxFileStreamWriter::SandboxFileStreamWriter( | 
| -    FileSystemContext* file_system_context, | 
| -    const FileSystemURL& url, | 
| -    int64 initial_offset, | 
| -    const UpdateObserverList& observers) | 
| -    : file_system_context_(file_system_context), | 
| -      url_(url), | 
| -      initial_offset_(initial_offset), | 
| -      observers_(observers), | 
| -      file_size_(0), | 
| -      total_bytes_written_(0), | 
| -      allowed_bytes_to_write_(0), | 
| -      has_pending_operation_(false), | 
| -      default_quota_(kint64max), | 
| -      weak_factory_(this) { | 
| -  DCHECK(url_.is_valid()); | 
| -} | 
| - | 
| -SandboxFileStreamWriter::~SandboxFileStreamWriter() {} | 
| - | 
| -int SandboxFileStreamWriter::Write( | 
| -    net::IOBuffer* buf, int buf_len, | 
| -    const net::CompletionCallback& callback) { | 
| -  has_pending_operation_ = true; | 
| -  if (local_file_writer_) | 
| -    return WriteInternal(buf, buf_len, callback); | 
| - | 
| -  net::CompletionCallback write_task = | 
| -      base::Bind(&SandboxFileStreamWriter::DidInitializeForWrite, | 
| -                 weak_factory_.GetWeakPtr(), | 
| -                 make_scoped_refptr(buf), buf_len, callback); | 
| -  file_system_context_->operation_runner()->CreateSnapshotFile( | 
| -      url_, base::Bind(&SandboxFileStreamWriter::DidCreateSnapshotFile, | 
| -                       weak_factory_.GetWeakPtr(), write_task)); | 
| -  return net::ERR_IO_PENDING; | 
| -} | 
| - | 
| -int SandboxFileStreamWriter::Cancel(const net::CompletionCallback& callback) { | 
| -  if (!has_pending_operation_) | 
| -    return net::ERR_UNEXPECTED; | 
| - | 
| -  DCHECK(!callback.is_null()); | 
| -  cancel_callback_ = callback; | 
| -  return net::ERR_IO_PENDING; | 
| -} | 
| - | 
| -int SandboxFileStreamWriter::WriteInternal( | 
| -    net::IOBuffer* buf, int buf_len, | 
| -    const net::CompletionCallback& callback) { | 
| -  // allowed_bytes_to_write could be negative if the file size is | 
| -  // greater than the current (possibly new) quota. | 
| -  DCHECK(total_bytes_written_ <= allowed_bytes_to_write_ || | 
| -         allowed_bytes_to_write_ < 0); | 
| -  if (total_bytes_written_ >= allowed_bytes_to_write_) { | 
| -    has_pending_operation_ = false; | 
| -    return net::ERR_FILE_NO_SPACE; | 
| -  } | 
| - | 
| -  if (buf_len > allowed_bytes_to_write_ - total_bytes_written_) | 
| -    buf_len = allowed_bytes_to_write_ - total_bytes_written_; | 
| - | 
| -  DCHECK(local_file_writer_.get()); | 
| -  const int result = local_file_writer_->Write( | 
| -      buf, buf_len, | 
| -      base::Bind(&SandboxFileStreamWriter::DidWrite, weak_factory_.GetWeakPtr(), | 
| -                 callback)); | 
| -  if (result != net::ERR_IO_PENDING) | 
| -    has_pending_operation_ = false; | 
| -  return result; | 
| -} | 
| - | 
| -void SandboxFileStreamWriter::DidCreateSnapshotFile( | 
| -    const net::CompletionCallback& callback, | 
| -    base::File::Error file_error, | 
| -    const base::File::Info& file_info, | 
| -    const base::FilePath& platform_path, | 
| -    const scoped_refptr<storage::ShareableFileReference>& file_ref) { | 
| -  DCHECK(!file_ref.get()); | 
| - | 
| -  if (CancelIfRequested()) | 
| -    return; | 
| -  if (file_error != base::File::FILE_OK) { | 
| -    callback.Run(net::FileErrorToNetError(file_error)); | 
| -    return; | 
| -  } | 
| -  if (file_info.is_directory) { | 
| -    // We should not be writing to a directory. | 
| -    callback.Run(net::ERR_ACCESS_DENIED); | 
| -    return; | 
| -  } | 
| -  file_size_ = file_info.size; | 
| -  if (initial_offset_ > file_size_) { | 
| -    LOG(ERROR) << initial_offset_ << ", " << file_size_; | 
| -    // This shouldn't happen as long as we check offset in the renderer. | 
| -    NOTREACHED(); | 
| -    initial_offset_ = file_size_; | 
| -  } | 
| -  DCHECK(!local_file_writer_.get()); | 
| -  local_file_writer_.reset(FileStreamWriter::CreateForLocalFile( | 
| -      file_system_context_->default_file_task_runner(), | 
| -      platform_path, | 
| -      initial_offset_, | 
| -      FileStreamWriter::OPEN_EXISTING_FILE)); | 
| - | 
| -  storage::QuotaManagerProxy* quota_manager_proxy = | 
| -      file_system_context_->quota_manager_proxy(); | 
| -  if (!quota_manager_proxy) { | 
| -    // If we don't have the quota manager or the requested filesystem type | 
| -    // does not support quota, we should be able to let it go. | 
| -    allowed_bytes_to_write_ = default_quota_; | 
| -    callback.Run(net::OK); | 
| -    return; | 
| -  } | 
| - | 
| -  DCHECK(quota_manager_proxy->quota_manager()); | 
| -  quota_manager_proxy->quota_manager()->GetUsageAndQuota( | 
| -      url_.origin(), | 
| -      FileSystemTypeToQuotaStorageType(url_.type()), | 
| -      base::Bind(&SandboxFileStreamWriter::DidGetUsageAndQuota, | 
| -                 weak_factory_.GetWeakPtr(), callback)); | 
| -} | 
| - | 
| -void SandboxFileStreamWriter::DidGetUsageAndQuota( | 
| -    const net::CompletionCallback& callback, | 
| -    storage::QuotaStatusCode status, | 
| -    int64 usage, | 
| -    int64 quota) { | 
| -  if (CancelIfRequested()) | 
| -    return; | 
| -  if (status != storage::kQuotaStatusOk) { | 
| -    LOG(WARNING) << "Got unexpected quota error : " << status; | 
| -    callback.Run(net::ERR_FAILED); | 
| -    return; | 
| -  } | 
| - | 
| -  allowed_bytes_to_write_ = quota - usage; | 
| -  callback.Run(net::OK); | 
| -} | 
| - | 
| -void SandboxFileStreamWriter::DidInitializeForWrite( | 
| -    net::IOBuffer* buf, int buf_len, | 
| -    const net::CompletionCallback& callback, | 
| -    int init_status) { | 
| -  if (CancelIfRequested()) | 
| -    return; | 
| -  if (init_status != net::OK) { | 
| -    has_pending_operation_ = false; | 
| -    callback.Run(init_status); | 
| -    return; | 
| -  } | 
| -  allowed_bytes_to_write_ = AdjustQuotaForOverlap( | 
| -      allowed_bytes_to_write_, initial_offset_, file_size_); | 
| -  const int result = WriteInternal(buf, buf_len, callback); | 
| -  if (result != net::ERR_IO_PENDING) | 
| -    callback.Run(result); | 
| -} | 
| - | 
| -void SandboxFileStreamWriter::DidWrite( | 
| -    const net::CompletionCallback& callback, | 
| -    int write_response) { | 
| -  DCHECK(has_pending_operation_); | 
| -  has_pending_operation_ = false; | 
| - | 
| -  if (write_response <= 0) { | 
| -    if (CancelIfRequested()) | 
| -      return; | 
| -    callback.Run(write_response); | 
| -    return; | 
| -  } | 
| - | 
| -  if (total_bytes_written_ + write_response + initial_offset_ > file_size_) { | 
| -    int overlapped = file_size_ - total_bytes_written_ - initial_offset_; | 
| -    if (overlapped < 0) | 
| -      overlapped = 0; | 
| -    observers_.Notify(&FileUpdateObserver::OnUpdate, | 
| -                      MakeTuple(url_, write_response - overlapped)); | 
| -  } | 
| -  total_bytes_written_ += write_response; | 
| - | 
| -  if (CancelIfRequested()) | 
| -    return; | 
| -  callback.Run(write_response); | 
| -} | 
| - | 
| -bool SandboxFileStreamWriter::CancelIfRequested() { | 
| -  if (cancel_callback_.is_null()) | 
| -    return false; | 
| - | 
| -  net::CompletionCallback pending_cancel = cancel_callback_; | 
| -  has_pending_operation_ = false; | 
| -  cancel_callback_.Reset(); | 
| -  pending_cancel.Run(net::OK); | 
| -  return true; | 
| -} | 
| - | 
| -int SandboxFileStreamWriter::Flush(const net::CompletionCallback& callback) { | 
| -  DCHECK(!has_pending_operation_); | 
| -  DCHECK(cancel_callback_.is_null()); | 
| - | 
| -  // Write() is not called yet, so there's nothing to flush. | 
| -  if (!local_file_writer_) | 
| -    return net::OK; | 
| - | 
| -  return local_file_writer_->Flush(callback); | 
| -} | 
| - | 
| -}  // namespace storage | 
|  |