Index: content/browser/in_process_webkit/indexed_db_quota_client.cc |
diff --git a/content/browser/in_process_webkit/indexed_db_quota_client.cc b/content/browser/in_process_webkit/indexed_db_quota_client.cc |
index 4c3aaac2312071e613e8a82fe403add1dd012af4..1af8c75632d7fa2a6d3ddf1a236dc615fa556650 100644 |
--- a/content/browser/in_process_webkit/indexed_db_quota_client.cc |
+++ b/content/browser/in_process_webkit/indexed_db_quota_client.cc |
@@ -31,6 +31,30 @@ class IndexedDBQuotaClient::HelperTask : public quota::QuotaThreadTask { |
scoped_refptr<IndexedDBContext> indexed_db_context_; |
}; |
+class IndexedDBQuotaClient::DeleteOriginTask : public HelperTask { |
+ public: |
+ DeleteOriginTask(IndexedDBQuotaClient* client, |
+ base::MessageLoopProxy* webkit_thread_message_loop, |
+ const GURL& origin_url, |
+ DeletionCallback* callback) |
+ : HelperTask(client, webkit_thread_message_loop), |
+ origin_url_(origin_url), callback_(callback) { |
+ } |
+ private: |
+ virtual void RunOnTargetThread() OVERRIDE { |
+ indexed_db_context_->DeleteIndexedDBForOrigin(origin_url_); |
+ } |
+ virtual void Aborted() OVERRIDE { |
+ callback_.reset(); |
+ } |
+ virtual void Completed() OVERRIDE { |
+ callback_->Run(quota::kQuotaStatusOk); |
+ callback_.reset(); |
+ } |
+ GURL origin_url_; |
+ scoped_ptr<DeletionCallback> callback_; |
+}; |
+ |
class IndexedDBQuotaClient::GetOriginUsageTask : public HelperTask { |
public: |
GetOriginUsageTask( |
@@ -43,12 +67,10 @@ class IndexedDBQuotaClient::GetOriginUsageTask : public HelperTask { |
private: |
virtual void RunOnTargetThread() OVERRIDE { |
- string16 origin_id = DatabaseUtil::GetOriginIdentifier(origin_url_); |
- FilePath file_path = indexed_db_context_->GetIndexedDBFilePath(origin_id); |
- usage_ = 0; |
- usage_ = file_util::ComputeDirectorySize(file_path); |
+ usage_ = indexed_db_context_->InitializeDiskUsage(origin_url_); |
michaeln
2011/08/04 22:11:55
Its a little odd to see this function calling an '
dgrogan
2011/08/04 23:44:56
You're right. Changed.
|
} |
virtual void Completed() OVERRIDE { |
+ DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
client_->DidGetOriginUsage(origin_url_, usage_); |
} |
GURL origin_url_; |
@@ -202,9 +224,16 @@ void IndexedDBQuotaClient::GetOriginsForHost( |
void IndexedDBQuotaClient::DeleteOriginData(const GURL& origin, |
quota::StorageType type, |
DeletionCallback* callback) { |
- // TODO(tzik): implement me |
- callback->Run(quota::kQuotaErrorNotSupported); |
- delete callback; |
+ if (type != quota::kStorageTypeTemporary) { |
+ callback->Run(quota::kQuotaErrorNotSupported); |
+ return; |
+ } |
+ scoped_refptr<DeleteOriginTask> task( |
+ new DeleteOriginTask(this, |
+ webkit_thread_message_loop_, |
+ origin, |
+ callback)); |
+ task->Start(); |
} |
void IndexedDBQuotaClient::DidGetOriginUsage( |