summaryrefslogtreecommitdiffstats
path: root/webkit/support
diff options
context:
space:
mode:
Diffstat (limited to 'webkit/support')
-rw-r--r--webkit/support/simple_database_system.cc193
-rw-r--r--webkit/support/simple_database_system.h84
-rw-r--r--webkit/support/test_webkit_client.cc2
-rw-r--r--webkit/support/test_webkit_client.h2
-rw-r--r--webkit/support/webkit_support.cc2
-rw-r--r--webkit/support/webkit_support.gypi6
6 files changed, 283 insertions, 6 deletions
diff --git a/webkit/support/simple_database_system.cc b/webkit/support/simple_database_system.cc
new file mode 100644
index 0000000..c1749a5
--- /dev/null
+++ b/webkit/support/simple_database_system.cc
@@ -0,0 +1,193 @@
+// 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/support/simple_database_system.h"
+
+#include "base/auto_reset.h"
+#include "base/file_util.h"
+#include "base/message_loop.h"
+#include "base/threading/platform_thread.h"
+#include "base/utf_string_conversions.h"
+#include "third_party/sqlite/sqlite3.h"
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebDatabase.h"
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebString.h"
+#include "webkit/database/database_util.h"
+#include "webkit/database/vfs_backend.h"
+
+using webkit_database::DatabaseTracker;
+using webkit_database::DatabaseUtil;
+using webkit_database::VfsBackend;
+
+SimpleDatabaseSystem* SimpleDatabaseSystem::instance_ = NULL;
+
+SimpleDatabaseSystem* SimpleDatabaseSystem::GetInstance() {
+ DCHECK(instance_);
+ return instance_;
+}
+
+SimpleDatabaseSystem::SimpleDatabaseSystem()
+ : waiting_for_dbs_to_close_(false) {
+ CHECK(temp_dir_.CreateUniqueTempDir());
+ db_tracker_ = new DatabaseTracker(temp_dir_.path(), false, NULL);
+ db_tracker_->AddObserver(this);
+ DCHECK(!instance_);
+ instance_ = this;
+}
+
+SimpleDatabaseSystem::~SimpleDatabaseSystem() {
+ db_tracker_->RemoveObserver(this);
+ instance_ = NULL;
+}
+
+base::PlatformFile SimpleDatabaseSystem::OpenFile(
+ const string16& vfs_file_name, int desired_flags) {
+ base::PlatformFile file_handle = base::kInvalidPlatformFileValue;
+ FilePath file_name = GetFullFilePathForVfsFile(vfs_file_name);
+ if (file_name.empty()) {
+ VfsBackend::OpenTempFileInDirectory(
+ db_tracker_->DatabaseDirectory(), desired_flags, &file_handle);
+ } else {
+ VfsBackend::OpenFile(file_name, desired_flags, &file_handle);
+ }
+
+ return file_handle;
+}
+
+int SimpleDatabaseSystem::DeleteFile(
+ const string16& vfs_file_name, bool sync_dir) {
+ // We try to delete the file multiple times, because that's what the default
+ // VFS does (apparently deleting a file can sometimes fail on Windows).
+ // We sleep for 10ms between retries for the same reason.
+ const int kNumDeleteRetries = 3;
+ int num_retries = 0;
+ int error_code = SQLITE_OK;
+ FilePath file_name = GetFullFilePathForVfsFile(vfs_file_name);
+ do {
+ error_code = VfsBackend::DeleteFile(file_name, sync_dir);
+ } while ((++num_retries < kNumDeleteRetries) &&
+ (error_code == SQLITE_IOERR_DELETE) &&
+ (base::PlatformThread::Sleep(10), 1));
+
+ return error_code;
+}
+
+long SimpleDatabaseSystem::GetFileAttributes(const string16& vfs_file_name) {
+ return VfsBackend::GetFileAttributes(
+ GetFullFilePathForVfsFile(vfs_file_name));
+}
+
+long long SimpleDatabaseSystem::GetFileSize(const string16& vfs_file_name) {
+ return VfsBackend::GetFileSize(GetFullFilePathForVfsFile(vfs_file_name));
+}
+
+void SimpleDatabaseSystem::DatabaseOpened(const string16& origin_identifier,
+ const string16& database_name,
+ const string16& description,
+ int64 estimated_size) {
+ int64 database_size = 0;
+ int64 space_available = 0;
+ database_connections_.AddConnection(origin_identifier, database_name);
+ db_tracker_->DatabaseOpened(origin_identifier, database_name, description,
+ estimated_size, &database_size, &space_available);
+ SetFullFilePathsForVfsFile(origin_identifier, database_name);
+
+ OnDatabaseSizeChanged(origin_identifier, database_name,
+ database_size, space_available);
+}
+
+void SimpleDatabaseSystem::DatabaseModified(const string16& origin_identifier,
+ const string16& database_name) {
+ DCHECK(database_connections_.IsDatabaseOpened(
+ origin_identifier, database_name));
+ db_tracker_->DatabaseModified(origin_identifier, database_name);
+}
+
+void SimpleDatabaseSystem::DatabaseClosed(const string16& origin_identifier,
+ const string16& database_name) {
+ DCHECK(database_connections_.IsDatabaseOpened(
+ origin_identifier, database_name));
+ db_tracker_->DatabaseClosed(origin_identifier, database_name);
+ database_connections_.RemoveConnection(origin_identifier, database_name);
+
+ if (waiting_for_dbs_to_close_ && database_connections_.IsEmpty())
+ MessageLoop::current()->PostTask(FROM_HERE, new MessageLoop::QuitTask());
+}
+
+void SimpleDatabaseSystem::OnDatabaseSizeChanged(
+ const string16& origin_identifier,
+ const string16& database_name,
+ int64 database_size,
+ int64 space_available) {
+ if (database_connections_.IsOriginUsed(origin_identifier)) {
+ WebKit::WebDatabase::updateDatabaseSize(
+ origin_identifier, database_name, database_size, space_available);
+ }
+}
+
+void SimpleDatabaseSystem::OnDatabaseScheduledForDeletion(
+ const string16& origin_identifier,
+ const string16& database_name) {
+ WebKit::WebDatabase::closeDatabaseImmediately(
+ origin_identifier, database_name);
+}
+
+void SimpleDatabaseSystem::databaseOpened(const WebKit::WebDatabase& database) {
+ DatabaseOpened(database.securityOrigin().databaseIdentifier(),
+ database.name(), database.displayName(),
+ database.estimatedSize());
+}
+
+void SimpleDatabaseSystem::databaseModified(
+ const WebKit::WebDatabase& database) {
+ DatabaseModified(database.securityOrigin().databaseIdentifier(),
+ database.name());
+}
+
+void SimpleDatabaseSystem::databaseClosed(const WebKit::WebDatabase& database) {
+ DatabaseClosed(database.securityOrigin().databaseIdentifier(),
+ database.name());
+}
+
+void SimpleDatabaseSystem::ClearAllDatabases() {
+ // Wait for all databases to be closed.
+ if (!database_connections_.IsEmpty()) {
+ AutoReset<bool> waiting_for_dbs_auto_reset(
+ &waiting_for_dbs_to_close_, true);
+ MessageLoop::ScopedNestableTaskAllower nestable(MessageLoop::current());
+ MessageLoop::current()->Run();
+ }
+
+ db_tracker_->CloseTrackerDatabaseAndClearCaches();
+ file_util::Delete(db_tracker_->DatabaseDirectory(), true);
+ file_names_.clear();
+}
+
+void SimpleDatabaseSystem::SetDatabaseQuota(int64 quota) {
+ db_tracker_->SetDefaultQuota(quota);
+}
+
+void SimpleDatabaseSystem::SetFullFilePathsForVfsFile(
+ const string16& origin_identifier,
+ const string16& database_name) {
+ string16 vfs_file_name = origin_identifier + ASCIIToUTF16("/") +
+ database_name + ASCIIToUTF16("#");
+ FilePath file_name =
+ DatabaseUtil::GetFullFilePathForVfsFile(db_tracker_, vfs_file_name);
+
+ base::AutoLock file_names_auto_lock(file_names_lock_);
+ file_names_[vfs_file_name] = file_name;
+ file_names_[vfs_file_name + ASCIIToUTF16("-journal")] =
+ FilePath::FromWStringHack(file_name.ToWStringHack() +
+ ASCIIToWide("-journal"));
+}
+
+FilePath SimpleDatabaseSystem::GetFullFilePathForVfsFile(
+ const string16& vfs_file_name) {
+ if (vfs_file_name.empty()) // temp file, used for vacuuming
+ return FilePath();
+
+ base::AutoLock file_names_auto_lock(file_names_lock_);
+ DCHECK(file_names_.find(vfs_file_name) != file_names_.end());
+ return file_names_[vfs_file_name];
+}
diff --git a/webkit/support/simple_database_system.h b/webkit/support/simple_database_system.h
new file mode 100644
index 0000000..682c123
--- /dev/null
+++ b/webkit/support/simple_database_system.h
@@ -0,0 +1,84 @@
+// 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.
+
+#ifndef WEBKIT_SUPPORT_SIMPLE_DATABASE_SYSTEM_H_
+#define WEBKIT_SUPPORT_SIMPLE_DATABASE_SYSTEM_H_
+
+#include "base/file_path.h"
+#include "base/hash_tables.h"
+#include "base/platform_file.h"
+#include "base/ref_counted.h"
+#include "base/scoped_temp_dir.h"
+#include "base/string16.h"
+#include "base/synchronization/lock.h"
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebDatabaseObserver.h"
+#include "webkit/database/database_connections.h"
+#include "webkit/database/database_tracker.h"
+
+class SimpleDatabaseSystem : public webkit_database::DatabaseTracker::Observer,
+ public WebKit::WebDatabaseObserver {
+ public:
+ static SimpleDatabaseSystem* GetInstance();
+ SimpleDatabaseSystem();
+ ~SimpleDatabaseSystem();
+
+ // VFS functions
+ base::PlatformFile OpenFile(const string16& vfs_file_name, int desired_flags);
+ int DeleteFile(const string16& vfs_file_name, bool sync_dir);
+ long GetFileAttributes(const string16& vfs_file_name);
+ long long GetFileSize(const string16& vfs_file_name);
+
+ // database tracker functions
+ void DatabaseOpened(const string16& origin_identifier,
+ const string16& database_name,
+ const string16& description,
+ int64 estimated_size);
+ void DatabaseModified(const string16& origin_identifier,
+ const string16& database_name);
+ void DatabaseClosed(const string16& origin_identifier,
+ const string16& database_name);
+
+ // DatabaseTracker::Observer implementation
+ virtual void OnDatabaseSizeChanged(const string16& origin_identifier,
+ const string16& database_name,
+ int64 database_size,
+ int64 space_available);
+ virtual void OnDatabaseScheduledForDeletion(const string16& origin_identifier,
+ const string16& database_name);
+
+ // WebDatabaseObserver implementation
+ virtual void databaseOpened(const WebKit::WebDatabase& database);
+ virtual void databaseModified(const WebKit::WebDatabase& database);
+ virtual void databaseClosed(const WebKit::WebDatabase& database);
+
+ void ClearAllDatabases();
+ void SetDatabaseQuota(int64 quota);
+
+ private:
+ // The calls that come from the database tracker run on the main thread.
+ // Therefore, we can only call DatabaseUtil::GetFullFilePathForVfsFile()
+ // on the main thread. However, the VFS calls run on the DB thread and
+ // they need to crack VFS file paths. To resolve this problem, we store
+ // a map of vfs_file_names to file_paths. The map is updated on the main
+ // thread on each DatabaseOpened() call that comes from the database
+ // tracker, and is read on the DB thread by each VFS call.
+ void SetFullFilePathsForVfsFile(const string16& origin_identifier,
+ const string16& database_name);
+ FilePath GetFullFilePathForVfsFile(const string16& vfs_file_name);
+
+ static SimpleDatabaseSystem* instance_;
+
+ bool waiting_for_dbs_to_close_;
+
+ ScopedTempDir temp_dir_;
+
+ scoped_refptr<webkit_database::DatabaseTracker> db_tracker_;
+
+ base::Lock file_names_lock_;
+ base::hash_map<string16, FilePath> file_names_;
+
+ webkit_database::DatabaseConnections database_connections_;
+};
+
+#endif // WEBKIT_SUPPORT_SIMPLE_DATABASE_SYSTEM_H_
diff --git a/webkit/support/test_webkit_client.cc b/webkit/support/test_webkit_client.cc
index 73c8a41..7b90dea 100644
--- a/webkit/support/test_webkit_client.cc
+++ b/webkit/support/test_webkit_client.cc
@@ -40,10 +40,10 @@
#include "webkit/glue/webkit_glue.h"
#include "webkit/glue/webkitclient_impl.h"
#include "webkit/gpu/webgraphicscontext3d_in_process_impl.h"
+#include "webkit/support/simple_database_system.h"
#include "webkit/support/weburl_loader_mock_factory.h"
#include "webkit/tools/test_shell/mock_webclipboard_impl.h"
#include "webkit/tools/test_shell/simple_appcache_system.h"
-#include "webkit/tools/test_shell/simple_database_system.h"
#include "webkit/tools/test_shell/simple_file_system.h"
#include "webkit/tools/test_shell/simple_resource_loader_bridge.h"
#include "webkit/tools/test_shell/simple_webcookiejar_impl.h"
diff --git a/webkit/support/test_webkit_client.h b/webkit/support/test_webkit_client.h
index efeecf6..8867864 100644
--- a/webkit/support/test_webkit_client.h
+++ b/webkit/support/test_webkit_client.h
@@ -7,10 +7,10 @@
#include "webkit/glue/webfileutilities_impl.h"
#include "webkit/glue/webkitclient_impl.h"
+#include "webkit/support/simple_database_system.h"
#include "webkit/support/weburl_loader_mock_factory.h"
#include "webkit/tools/test_shell/mock_webclipboard_impl.h"
#include "webkit/tools/test_shell/simple_appcache_system.h"
-#include "webkit/tools/test_shell/simple_database_system.h"
#include "webkit/tools/test_shell/simple_file_system.h"
#include "webkit/tools/test_shell/simple_webcookiejar_impl.h"
#include "webkit/tools/test_shell/test_shell_webmimeregistry_impl.h"
diff --git a/webkit/support/webkit_support.cc b/webkit/support/webkit_support.cc
index 83fae0c..89c39cc 100644
--- a/webkit/support/webkit_support.cc
+++ b/webkit/support/webkit_support.cc
@@ -47,9 +47,9 @@
#include "webkit/plugins/npapi/webplugin_page_delegate.h"
#include "webkit/plugins/npapi/webplugininfo.h"
#include "webkit/support/platform_support.h"
+#include "webkit/support/simple_database_system.h"
#include "webkit/support/test_webplugin_page_delegate.h"
#include "webkit/support/test_webkit_client.h"
-#include "webkit/tools/test_shell/simple_database_system.h"
#include "webkit/tools/test_shell/simple_file_system.h"
#include "webkit/tools/test_shell/simple_resource_loader_bridge.h"
diff --git a/webkit/support/webkit_support.gypi b/webkit/support/webkit_support.gypi
index 5b682c0..b62b4bb 100644
--- a/webkit/support/webkit_support.gypi
+++ b/webkit/support/webkit_support.gypi
@@ -83,13 +83,11 @@
'<(DEPTH)/webkit/tools/test_shell/mock_webclipboard_impl.h',
'<(DEPTH)/webkit/tools/test_shell/simple_appcache_system.cc',
'<(DEPTH)/webkit/tools/test_shell/simple_appcache_system.h',
+ '<(DEPTH)/webkit/tools/test_shell/simple_clipboard_impl.cc',
'<(DEPTH)/webkit/tools/test_shell/simple_file_system.cc',
'<(DEPTH)/webkit/tools/test_shell/simple_file_system.h',
'<(DEPTH)/webkit/tools/test_shell/simple_file_writer.cc',
'<(DEPTH)/webkit/tools/test_shell/simple_file_writer.h',
- '<(DEPTH)/webkit/tools/test_shell/simple_clipboard_impl.cc',
- '<(DEPTH)/webkit/tools/test_shell/simple_database_system.cc',
- '<(DEPTH)/webkit/tools/test_shell/simple_database_system.h',
'<(DEPTH)/webkit/tools/test_shell/simple_resource_loader_bridge.cc',
'<(DEPTH)/webkit/tools/test_shell/simple_resource_loader_bridge.h',
'<(DEPTH)/webkit/tools/test_shell/simple_socket_stream_bridge.cc',
@@ -102,6 +100,8 @@
'<(DEPTH)/webkit/tools/test_shell/test_shell_webblobregistry_impl.h',
'<(DEPTH)/webkit/tools/test_shell/test_shell_webmimeregistry_impl.cc',
'<(DEPTH)/webkit/tools/test_shell/test_shell_webmimeregistry_impl.h',
+ 'simple_database_system.cc',
+ 'simple_database_system.h',
],
'conditions': [
['inside_chromium_build==0', {