| Index: components/webdata/common/web_database_backend.cc
|
| diff --git a/components/webdata/common/web_database_backend.cc b/components/webdata/common/web_database_backend.cc
|
| index 1408bd2b9d8613ab61a2fbae136ff58bd7375a7e..cba430ab371ed6fc9bf196eeedf0db0f8938860c 100644
|
| --- a/components/webdata/common/web_database_backend.cc
|
| +++ b/components/webdata/common/web_database_backend.cc
|
| @@ -59,7 +59,8 @@ sql::InitStatus WebDatabaseBackend::LoadDatabaseIfNecessary() {
|
| if (init_status_ != sql::INIT_OK) {
|
| LOG(ERROR) << "Cannot initialize the web database: " << init_status_;
|
| diagnostics_ += sql::GetCorruptFileDiagnosticsInfo(db_path_);
|
| - db_.reset();
|
| + if (!catastrophic_error_occurred_)
|
| + db_.reset();
|
| return init_status_;
|
| }
|
|
|
| @@ -124,9 +125,22 @@ void WebDatabaseBackend::DatabaseErrorCallback(int error,
|
| if (!catastrophic_error_occurred_ && sql::IsErrorCatastrophic(error)) {
|
| catastrophic_error_occurred_ = true;
|
| diagnostics_ = db_->GetDiagnosticInfo(error, statement);
|
| +
|
| + task_runner_->PostTask(
|
| + FROM_HERE,
|
| + base::Bind(&WebDatabaseBackend::RazeAndCloseDatabase, this));
|
| }
|
| }
|
|
|
| +void WebDatabaseBackend::RazeAndCloseDatabase() {
|
| + if (!db_)
|
| + return;
|
| +
|
| + db_->GetSQLConnection()->RollbackAllTransactions();
|
| + db_->GetSQLConnection()->Raze();
|
| + db_.reset();
|
| +}
|
| +
|
| void WebDatabaseBackend::Commit() {
|
| DCHECK(db_);
|
| DCHECK_EQ(sql::INIT_OK, init_status_);
|
|
|