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

Unified Diff: webkit/fileapi/sandbox_quota_client.cc

Issue 7003021: Added DeleteOriginData to QuotaClient (Closed)
Patch Set: Add tests Created 9 years, 7 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
Index: webkit/fileapi/sandbox_quota_client.cc
diff --git a/webkit/fileapi/sandbox_quota_client.cc b/webkit/fileapi/sandbox_quota_client.cc
index b35e7ba23c7e3c874b268dd6bf7faf21a3dea115..b596d7b5224be21931f751a10ab9516f9f35b2aa 100644
--- a/webkit/fileapi/sandbox_quota_client.cc
+++ b/webkit/fileapi/sandbox_quota_client.cc
@@ -289,4 +289,53 @@ void SandboxQuotaClient::DidGetOriginsForHost(
pending_origins_for_host_callbacks_.Run(type_and_host, origins);
}
+class SandboxQuotaClient::DeleteOriginTask
michaeln 2011/05/13 07:28:02 probably better to move this class definition up i
tzik (google) 2011/05/13 14:22:24 Done.
+ : public QuotaThreadTask {
+ public:
+ DeleteOriginTask(
+ SandboxQuotaClient* quota_client,
+ scoped_refptr<MessageLoopProxy> file_message_loop,
+ const GURL& origin,
+ FileSystemType type,
+ DeletionCallback* callback)
+ : QuotaThreadTask(quota_client, file_message_loop),
+ file_system_context_(quota_client->file_system_context_),
+ origin_(origin),
+ type_(type),
+ status_(quota::kQuotaStatusUnknown),
+ callback_(callback) {
+ }
+
+ virtual ~DeleteOriginTask() {}
+
+ virtual void RunOnTargetThread() OVERRIDE {
+ if (file_system_context_->
+ DeleteDataForOriginAndTypeOnFileThread(origin_, type_))
kinuko 2011/05/13 07:26:00 style-nit: weird indentation file_system_context_
tzik (google) 2011/05/13 14:22:24 Done.
+ status_ = quota::kQuotaStatusOk;
+ else
+ status_ = quota::kQuotaErrorInvalidModification;
+ }
+
+ virtual void Completed() OVERRIDE {
+ callback_->Run(status_);
michaeln 2011/05/13 07:28:02 i'm not sure if the callbacks are expected to be r
tzik (google) 2011/05/13 14:22:24 We believe, that's no problem. It's same to others
+ }
+ private:
+ FileSystemContext* file_system_context_;
+ GURL origin_;
+ FileSystemType type_;
+ quota::QuotaStatusCode status_;
+ scoped_ptr<DeletionCallback> callback_;
+};
+
+void SandboxQuotaClient::DeleteOriginData(const GURL& origin,
michaeln 2011/05/13 07:28:02 please move this method up in the .cc file to matc
tzik (google) 2011/05/13 14:22:24 Done.
+ StorageType type,
+ DeletionCallback* callback) {
+ FileSystemType fs_type = QuotaStorageTypeToFileSystemType(type);
+ DCHECK(fs_type != kFileSystemTypeUnknown);
+ scoped_refptr<DeleteOriginTask> task(
+ new DeleteOriginTask(this, file_message_loop_,
+ origin, fs_type, callback));
+ task->Start();
+}
+
} // namespace fileapi

Powered by Google App Engine
This is Rietveld 408576698