diff options
-rw-r--r-- | chrome/browser/renderer_host/database_dispatcher_host.cc | 14 | ||||
-rw-r--r-- | chrome/common/database_util.cc | 15 | ||||
-rw-r--r-- | chrome/common/database_util.h | 3 | ||||
-rw-r--r-- | chrome/common/render_messages_internal.h | 8 | ||||
-rw-r--r-- | chrome/renderer/renderer_webkitclient_impl.cc | 6 | ||||
-rw-r--r-- | chrome/renderer/renderer_webkitclient_impl.h | 3 | ||||
-rw-r--r-- | chrome/worker/worker_webkitclient_impl.cc | 6 | ||||
-rw-r--r-- | chrome/worker/worker_webkitclient_impl.h | 3 | ||||
-rw-r--r-- | webkit/database/vfs_backend.cc | 25 | ||||
-rw-r--r-- | webkit/database/vfs_backend.h | 6 | ||||
-rw-r--r-- | webkit/glue/webkitclient_impl.cc | 7 | ||||
-rw-r--r-- | webkit/glue/webkitclient_impl.h | 6 | ||||
-rw-r--r-- | webkit/support/test_webkit_client.cc | 5 | ||||
-rw-r--r-- | webkit/support/test_webkit_client.h | 3 | ||||
-rw-r--r-- | webkit/tools/test_shell/simple_database_system.cc | 8 | ||||
-rw-r--r-- | webkit/tools/test_shell/simple_database_system.h | 4 | ||||
-rw-r--r-- | webkit/tools/test_shell/test_shell_webkit_init.h | 5 |
17 files changed, 39 insertions, 88 deletions
diff --git a/chrome/browser/renderer_host/database_dispatcher_host.cc b/chrome/browser/renderer_host/database_dispatcher_host.cc index 8ce3df7..c77fc37 100644 --- a/chrome/browser/renderer_host/database_dispatcher_host.cc +++ b/chrome/browser/renderer_host/database_dispatcher_host.cc @@ -157,13 +157,12 @@ void DatabaseDispatcherHost::DatabaseOpenFile(const string16& vfs_file_name, IPC::Message* reply_msg) { DCHECK(ChromeThread::CurrentlyOn(ChromeThread::FILE)); base::PlatformFile target_handle = base::kInvalidPlatformFileValue; - base::PlatformFile target_dir_handle = base::kInvalidPlatformFileValue; string16 origin_identifier; string16 database_name; if (vfs_file_name.empty()) { VfsBackend::OpenTempFileInDirectory(db_tracker_->DatabaseDirectory(), desired_flags, process_handle_, - &target_handle, &target_dir_handle); + &target_handle); } else if (DatabaseUtil::CrackVfsFileName(vfs_file_name, &origin_identifier, &database_name, NULL) && !db_tracker_->IsDatabaseScheduledForDeletion(origin_identifier, @@ -172,23 +171,16 @@ void DatabaseDispatcherHost::DatabaseOpenFile(const string16& vfs_file_name, DatabaseUtil::GetFullFilePathForVfsFile(db_tracker_, vfs_file_name); if (!db_file.empty()) { VfsBackend::OpenFile(db_file, desired_flags, process_handle_, - &target_handle, &target_dir_handle); + &target_handle); } } -#if defined(OS_POSIX) - if (target_dir_handle >= 0) - close(target_dir_handle); - target_dir_handle = -1; -#endif - ViewHostMsg_DatabaseOpenFile::WriteReplyParams( reply_msg, #if defined(OS_WIN) target_handle #elif defined(OS_POSIX) - base::FileDescriptor(target_handle, true), - base::FileDescriptor(target_dir_handle, true) + base::FileDescriptor(target_handle, true) #endif ); Send(reply_msg); diff --git a/chrome/common/database_util.cc b/chrome/common/database_util.cc index f149f08..fe196c6 100644 --- a/chrome/common/database_util.cc +++ b/chrome/common/database_util.cc @@ -19,35 +19,24 @@ using WebKit::WebKitClient; using WebKit::WebString; WebKitClient::FileHandle DatabaseUtil::databaseOpenFile( - const WebString& vfs_file_name, int desired_flags, - WebKitClient::FileHandle* dir_handle) { + const WebString& vfs_file_name, int desired_flags) { IPC::PlatformFileForTransit file_handle; #if defined(OS_WIN) file_handle = base::kInvalidPlatformFileValue; #elif defined(OS_POSIX) file_handle = base::FileDescriptor(base::kInvalidPlatformFileValue, true); - base::FileDescriptor dir_handle_rv = - base::FileDescriptor(base::kInvalidPlatformFileValue, true); #endif scoped_refptr<IPC::SyncMessageFilter> filter = ChildThread::current()->sync_message_filter(); filter->Send(new ViewHostMsg_DatabaseOpenFile( - vfs_file_name, - desired_flags, - &file_handle -#if defined(OS_POSIX) - , &dir_handle_rv -#endif - )); + vfs_file_name, desired_flags, &file_handle)); #if defined(OS_WIN) return file_handle; #elif defined(OS_POSIX) - if (dir_handle) - *dir_handle = dir_handle_rv.fd; return file_handle.fd; #endif } diff --git a/chrome/common/database_util.h b/chrome/common/database_util.h index 70bd029..9c263af 100644 --- a/chrome/common/database_util.h +++ b/chrome/common/database_util.h @@ -12,8 +12,7 @@ class DatabaseUtil { public: static WebKit::WebKitClient::FileHandle databaseOpenFile( - const WebKit::WebString& vfs_file_name, - int desired_flags, WebKit::WebKitClient::FileHandle* dir_handle); + const WebKit::WebString& vfs_file_name, int desired_flags); static int databaseDeleteFile(const WebKit::WebString& vfs_file_name, bool sync_dir); static long databaseGetFileAttributes(const WebKit::WebString& vfs_file_name); diff --git a/chrome/common/render_messages_internal.h b/chrome/common/render_messages_internal.h index 076aab4..50053a3 100644 --- a/chrome/common/render_messages_internal.h +++ b/chrome/common/render_messages_internal.h @@ -2151,18 +2151,10 @@ IPC_BEGIN_MESSAGES(ViewHost) bool /* result */) // Asks the browser process to open a DB file with the given name. -#if defined (OS_WIN) IPC_SYNC_MESSAGE_CONTROL2_1(ViewHostMsg_DatabaseOpenFile, string16 /* vfs file name */, int /* desired flags */, IPC::PlatformFileForTransit /* file_handle */) -#elif defined(OS_POSIX) - IPC_SYNC_MESSAGE_CONTROL2_2(ViewHostMsg_DatabaseOpenFile, - string16 /* vfs file name */, - int /* desired flags */, - IPC::PlatformFileForTransit /* file_handle */, - base::FileDescriptor /* dir_handle */) -#endif // Asks the browser process to delete a DB file IPC_SYNC_MESSAGE_CONTROL2_1(ViewHostMsg_DatabaseDeleteFile, diff --git a/chrome/renderer/renderer_webkitclient_impl.cc b/chrome/renderer/renderer_webkitclient_impl.cc index b9c1dd6..f9b5ffc 100644 --- a/chrome/renderer/renderer_webkitclient_impl.cc +++ b/chrome/renderer/renderer_webkitclient_impl.cc @@ -290,10 +290,8 @@ void RendererWebKitClientImpl::SandboxSupport::getRenderStyleForStrike( //------------------------------------------------------------------------------ WebKitClient::FileHandle RendererWebKitClientImpl::databaseOpenFile( - const WebString& vfs_file_name, int desired_flags, - WebKitClient::FileHandle* dir_handle) { - return DatabaseUtil::databaseOpenFile(vfs_file_name, desired_flags, - dir_handle); + const WebString& vfs_file_name, int desired_flags) { + return DatabaseUtil::databaseOpenFile(vfs_file_name, desired_flags); } int RendererWebKitClientImpl::databaseDeleteFile( diff --git a/chrome/renderer/renderer_webkitclient_impl.h b/chrome/renderer/renderer_webkitclient_impl.h index 7d90520..7e7de1e 100644 --- a/chrome/renderer/renderer_webkitclient_impl.h +++ b/chrome/renderer/renderer_webkitclient_impl.h @@ -51,8 +51,7 @@ class RendererWebKitClientImpl : public webkit_glue::WebKitClientImpl { const WebKit::WebURL& url, bool is_local_storage); virtual WebKit::WebKitClient::FileHandle databaseOpenFile( - const WebKit::WebString& vfs_file_name, int desired_flags, - WebKit::WebKitClient::FileHandle* dir_handle); + const WebKit::WebString& vfs_file_name, int desired_flags); virtual int databaseDeleteFile(const WebKit::WebString& vfs_file_name, bool sync_dir); virtual long databaseGetFileAttributes( diff --git a/chrome/worker/worker_webkitclient_impl.cc b/chrome/worker/worker_webkitclient_impl.cc index 4af2cf2..6bc5a86 100644 --- a/chrome/worker/worker_webkitclient_impl.cc +++ b/chrome/worker/worker_webkitclient_impl.cc @@ -108,10 +108,8 @@ WebSharedWorkerRepository* WorkerWebKitClientImpl::sharedWorkerRepository() { } WebKitClient::FileHandle WorkerWebKitClientImpl::databaseOpenFile( - const WebString& vfs_file_name, int desired_flags, - WebKitClient::FileHandle* dir_handle) { - return DatabaseUtil::databaseOpenFile(vfs_file_name, desired_flags, - dir_handle); + const WebString& vfs_file_name, int desired_flags) { + return DatabaseUtil::databaseOpenFile(vfs_file_name, desired_flags); } int WorkerWebKitClientImpl::databaseDeleteFile( diff --git a/chrome/worker/worker_webkitclient_impl.h b/chrome/worker/worker_webkitclient_impl.h index deb76c2..0500976 100644 --- a/chrome/worker/worker_webkitclient_impl.h +++ b/chrome/worker/worker_webkitclient_impl.h @@ -40,8 +40,7 @@ class WorkerWebKitClientImpl : public webkit_glue::WebKitClientImpl, virtual WebKit::WebSharedWorkerRepository* sharedWorkerRepository(); virtual WebKit::WebKitClient::FileHandle databaseOpenFile( - const WebKit::WebString& vfs_file_name, int desired_flags, - WebKit::WebKitClient::FileHandle* dir_handle); + const WebKit::WebString& vfs_file_name, int desired_flags); virtual int databaseDeleteFile(const WebKit::WebString& vfs_file_name, bool sync_dir); virtual long databaseGetFileAttributes( diff --git a/webkit/database/vfs_backend.cc b/webkit/database/vfs_backend.cc index 8cb8e05..0d9cb4f 100644 --- a/webkit/database/vfs_backend.cc +++ b/webkit/database/vfs_backend.cc @@ -71,8 +71,7 @@ bool VfsBackend::OpenFileFlagsAreConsistent(int desired_flags) { void VfsBackend::OpenFile(const FilePath& file_path, int desired_flags, base::ProcessHandle handle, - base::PlatformFile* target_handle, - base::PlatformFile* target_dir_handle) { + base::PlatformFile* target_handle) { DCHECK(!file_path.empty()); // Verify the flags for consistency and create the database @@ -118,22 +117,6 @@ void VfsBackend::OpenFile(const FilePath& file_path, } #elif defined(OS_POSIX) *target_handle = file_handle; - - int file_type = desired_flags & 0x00007F00; - bool creating_new_file = (desired_flags & SQLITE_OPEN_CREATE); - if (creating_new_file && ((file_type == SQLITE_OPEN_MASTER_JOURNAL) || - (file_type == SQLITE_OPEN_MAIN_JOURNAL))) { - // We return a handle to the containing directory because on POSIX - // systems the VFS might want to fsync it after changing a file. - // By returning it here, we avoid an extra IPC call. - *target_dir_handle = base::CreatePlatformFile( - file_path.DirName().ToWStringHack(), - base::PLATFORM_FILE_OPEN | base::PLATFORM_FILE_READ, NULL); - if (*target_dir_handle == base::kInvalidPlatformFileValue) { - base::ClosePlatformFile(*target_handle); - *target_handle = base::kInvalidPlatformFileValue; - } - } #endif } } @@ -143,8 +126,7 @@ void VfsBackend::OpenTempFileInDirectory( const FilePath& dir_path, int desired_flags, base::ProcessHandle handle, - base::PlatformFile* target_handle, - base::PlatformFile* target_dir_handle) { + base::PlatformFile* target_handle) { // We should be able to delete temp files when they're closed // and create them as needed if (!(desired_flags & SQLITE_OPEN_DELETEONCLOSE) || @@ -157,8 +139,7 @@ void VfsBackend::OpenTempFileInDirectory( if (!file_util::CreateTemporaryFileInDir(dir_path, &temp_file_path)) return; - OpenFile(temp_file_path, desired_flags, handle, - target_handle, target_dir_handle); + OpenFile(temp_file_path, desired_flags, handle, target_handle); } // static diff --git a/webkit/database/vfs_backend.h b/webkit/database/vfs_backend.h index 97ce7e0..267ce90 100644 --- a/webkit/database/vfs_backend.h +++ b/webkit/database/vfs_backend.h @@ -18,14 +18,12 @@ class VfsBackend { static void OpenFile(const FilePath& file_path, int desired_flags, base::ProcessHandle handle, - base::PlatformFile* target_handle, - base::PlatformFile* target_dir_handle); + base::PlatformFile* target_handle); static void OpenTempFileInDirectory(const FilePath& dir_path, int desired_flags, base::ProcessHandle handle, - base::PlatformFile* target_handle, - base::PlatformFile* target_dir_handle); + base::PlatformFile* target_handle); static int DeleteFile(const FilePath& file_path, bool sync_dir); diff --git a/webkit/glue/webkitclient_impl.cc b/webkit/glue/webkitclient_impl.cc index a065ad8..29b812a 100644 --- a/webkit/glue/webkitclient_impl.cc +++ b/webkit/glue/webkitclient_impl.cc @@ -333,11 +333,18 @@ void WebKitClientImpl::callOnMainThread(void (*func)(void*), void* context) { main_loop_->PostTask(FROM_HERE, NewRunnableFunction(func, context)); } +// TODO: remove this method once https://bugs.webkit.org/show_bug.cgi?id=38869 +// is resolved. base::PlatformFile WebKitClientImpl::databaseOpenFile( const WebKit::WebString& vfs_file_name, int desired_flags, base::PlatformFile* dir_handle) { if (dir_handle) *dir_handle = base::kInvalidPlatformFileValue; + return databaseOpenFile(vfs_file_name, desired_flags); +} + +base::PlatformFile WebKitClientImpl::databaseOpenFile( + const WebKit::WebString& vfs_file_name, int desired_flags) { return base::kInvalidPlatformFileValue; } diff --git a/webkit/glue/webkitclient_impl.h b/webkit/glue/webkitclient_impl.h index 6b8e345..0f70841 100644 --- a/webkit/glue/webkitclient_impl.h +++ b/webkit/glue/webkitclient_impl.h @@ -23,10 +23,16 @@ class WebKitClientImpl : public WebKit::WebKitClient { // WebKitClient methods (partial implementation): virtual WebKit::WebThemeEngine* themeEngine(); + + // TODO: remove this method once https://bugs.webkit.org/show_bug.cgi?id=38869 + // is resolved. virtual base::PlatformFile databaseOpenFile( const WebKit::WebString& vfs_file_name, int desired_flags, base::PlatformFile* dir_handle); + + virtual base::PlatformFile databaseOpenFile( + const WebKit::WebString& vfs_file_name, int desired_flags); virtual int databaseDeleteFile(const WebKit::WebString& vfs_file_name, bool sync_dir); virtual long databaseGetFileAttributes( diff --git a/webkit/support/test_webkit_client.cc b/webkit/support/test_webkit_client.cc index 749fa80..874717c 100644 --- a/webkit/support/test_webkit_client.cc +++ b/webkit/support/test_webkit_client.cc @@ -156,10 +156,9 @@ bool TestWebKitClient::sandboxEnabled() { } WebKit::WebKitClient::FileHandle TestWebKitClient::databaseOpenFile( - const WebKit::WebString& vfs_file_name, int desired_flags, - WebKit::WebKitClient::FileHandle* dir_handle) { + const WebKit::WebString& vfs_file_name, int desired_flags) { return SimpleDatabaseSystem::GetInstance()->OpenFile( - vfs_file_name, desired_flags, dir_handle); + vfs_file_name, desired_flags); } int TestWebKitClient::databaseDeleteFile(const WebKit::WebString& vfs_file_name, diff --git a/webkit/support/test_webkit_client.h b/webkit/support/test_webkit_client.h index c0c8a6a..3e106a9 100644 --- a/webkit/support/test_webkit_client.h +++ b/webkit/support/test_webkit_client.h @@ -26,8 +26,7 @@ class TestWebKitClient : public webkit_glue::WebKitClientImpl { virtual WebKit::WebCookieJar* cookieJar(); virtual bool sandboxEnabled(); virtual WebKit::WebKitClient::FileHandle databaseOpenFile( - const WebKit::WebString& vfs_file_name, int desired_flags, - WebKit::WebKitClient::FileHandle* dir_handle); + const WebKit::WebString& vfs_file_name, int desired_flags); virtual int databaseDeleteFile(const WebKit::WebString& vfs_file_name, bool sync_dir); virtual long databaseGetFileAttributes( diff --git a/webkit/tools/test_shell/simple_database_system.cc b/webkit/tools/test_shell/simple_database_system.cc index fbb4cac..8f87dc2 100644 --- a/webkit/tools/test_shell/simple_database_system.cc +++ b/webkit/tools/test_shell/simple_database_system.cc @@ -46,18 +46,16 @@ SimpleDatabaseSystem::~SimpleDatabaseSystem() { } base::PlatformFile SimpleDatabaseSystem::OpenFile( - const string16& vfs_file_name, int desired_flags, - base::PlatformFile* dir_handle) { + 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, - base::GetCurrentProcessHandle(), &file_handle, dir_handle); + base::GetCurrentProcessHandle(), &file_handle); } else { VfsBackend::OpenFile(file_name, desired_flags, - base::GetCurrentProcessHandle(), &file_handle, - dir_handle); + base::GetCurrentProcessHandle(), &file_handle); } return file_handle; diff --git a/webkit/tools/test_shell/simple_database_system.h b/webkit/tools/test_shell/simple_database_system.h index 8441d31..6ec1be6 100644 --- a/webkit/tools/test_shell/simple_database_system.h +++ b/webkit/tools/test_shell/simple_database_system.h @@ -24,9 +24,7 @@ class SimpleDatabaseSystem : public webkit_database::DatabaseTracker::Observer, ~SimpleDatabaseSystem(); // VFS functions - base::PlatformFile OpenFile(const string16& vfs_file_name, - int desired_flags, - base::PlatformFile* dir_handle); + 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); diff --git a/webkit/tools/test_shell/test_shell_webkit_init.h b/webkit/tools/test_shell/test_shell_webkit_init.h index c4e79b4..9158f16 100644 --- a/webkit/tools/test_shell/test_shell_webkit_init.h +++ b/webkit/tools/test_shell/test_shell_webkit_init.h @@ -134,10 +134,9 @@ class TestShellWebKitInit : public webkit_glue::WebKitClientImpl { } virtual WebKit::WebKitClient::FileHandle databaseOpenFile( - const WebKit::WebString& vfs_file_name, int desired_flags, - WebKit::WebKitClient::FileHandle* dir_handle) { + const WebKit::WebString& vfs_file_name, int desired_flags) { return SimpleDatabaseSystem::GetInstance()->OpenFile( - vfs_file_name, desired_flags, dir_handle); + vfs_file_name, desired_flags); } virtual int databaseDeleteFile(const WebKit::WebString& vfs_file_name, |