| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "sync/syncable/on_disk_directory_backing_store.h" | 5 #include "sync/syncable/on_disk_directory_backing_store.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/stl_util.h" | 8 #include "base/stl_util.h" |
| 9 #include "base/metrics/histogram.h" | 9 #include "base/metrics/histogram.h" |
| 10 #include "sync/syncable/syncable-inl.h" | 10 #include "sync/syncable/syncable-inl.h" |
| (...skipping 11 matching lines...) Expand all Loading... |
| 22 }; | 22 }; |
| 23 | 23 |
| 24 } // namespace | 24 } // namespace |
| 25 | 25 |
| 26 OnDiskDirectoryBackingStore::OnDiskDirectoryBackingStore( | 26 OnDiskDirectoryBackingStore::OnDiskDirectoryBackingStore( |
| 27 const std::string& dir_name, const base::FilePath& backing_filepath) | 27 const std::string& dir_name, const base::FilePath& backing_filepath) |
| 28 : DirectoryBackingStore(dir_name), | 28 : DirectoryBackingStore(dir_name), |
| 29 allow_failure_for_test_(false), | 29 allow_failure_for_test_(false), |
| 30 backing_filepath_(backing_filepath) { | 30 backing_filepath_(backing_filepath) { |
| 31 db_->set_exclusive_locking(); | 31 db_->set_exclusive_locking(); |
| 32 db_->set_page_size(4096); | 32 db_->set_page_size(databasePageSize_); |
| 33 } | 33 } |
| 34 | 34 |
| 35 OnDiskDirectoryBackingStore::~OnDiskDirectoryBackingStore() { } | 35 OnDiskDirectoryBackingStore::~OnDiskDirectoryBackingStore() { } |
| 36 | 36 |
| 37 DirOpenResult OnDiskDirectoryBackingStore::TryLoad( | 37 DirOpenResult OnDiskDirectoryBackingStore::TryLoad( |
| 38 Directory::MetahandlesMap* handles_map, | 38 Directory::MetahandlesMap* handles_map, |
| 39 JournalIndex* delete_journals, | 39 JournalIndex* delete_journals, |
| 40 MetahandleSet* metahandles_to_purge, | 40 MetahandleSet* metahandles_to_purge, |
| 41 Directory::KernelLoadInfo* kernel_load_info) { | 41 Directory::KernelLoadInfo* kernel_load_info) { |
| 42 DCHECK(CalledOnValidThread()); | 42 DCHECK(CalledOnValidThread()); |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 78 | 78 |
| 79 // The fallback: delete the current database and return a fresh one. We can | 79 // The fallback: delete the current database and return a fresh one. We can |
| 80 // fetch the user's data from the cloud. | 80 // fetch the user's data from the cloud. |
| 81 STLDeleteValues(handles_map); | 81 STLDeleteValues(handles_map); |
| 82 STLDeleteElements(delete_journals); | 82 STLDeleteElements(delete_journals); |
| 83 db_.reset(new sql::Connection); | 83 db_.reset(new sql::Connection); |
| 84 // TODO: Manually propagating the default database settings is | 84 // TODO: Manually propagating the default database settings is |
| 85 // brittle. Either have a helper to set these up (or generate a new | 85 // brittle. Either have a helper to set these up (or generate a new |
| 86 // connection), or add something like Reset() to sql::Connection. | 86 // connection), or add something like Reset() to sql::Connection. |
| 87 db_->set_exclusive_locking(); | 87 db_->set_exclusive_locking(); |
| 88 db_->set_page_size(4096); | 88 db_->set_page_size(databasePageSize_); |
| 89 db_->set_histogram_tag("SyncDirectory"); | 89 db_->set_histogram_tag("SyncDirectory"); |
| 90 base::DeleteFile(backing_filepath_, false); | 90 base::DeleteFile(backing_filepath_, false); |
| 91 | 91 |
| 92 result = TryLoad(handles_map, delete_journals, metahandles_to_purge, | 92 result = TryLoad(handles_map, delete_journals, metahandles_to_purge, |
| 93 kernel_load_info); | 93 kernel_load_info); |
| 94 if (result == OPENED) { | 94 if (result == OPENED) { |
| 95 UMA_HISTOGRAM_ENUMERATION( | 95 UMA_HISTOGRAM_ENUMERATION( |
| 96 "Sync.DirectoryOpenResult", SECOND_TRY_SUCCESS, RESULT_COUNT); | 96 "Sync.DirectoryOpenResult", SECOND_TRY_SUCCESS, RESULT_COUNT); |
| 97 } else { | 97 } else { |
| 98 UMA_HISTOGRAM_ENUMERATION( | 98 UMA_HISTOGRAM_ENUMERATION( |
| (...skipping 10 matching lines...) Expand all Loading... |
| 109 // immediately so a developer can investigate. | 109 // immediately so a developer can investigate. |
| 110 // | 110 // |
| 111 // Developers: If you're not interested in debugging this right now, just move | 111 // Developers: If you're not interested in debugging this right now, just move |
| 112 // aside the 'Sync Data' directory in your profile. This is similar to what | 112 // aside the 'Sync Data' directory in your profile. This is similar to what |
| 113 // the code would do if this DCHECK were disabled. | 113 // the code would do if this DCHECK were disabled. |
| 114 NOTREACHED() << "Crashing to preserve corrupt sync database"; | 114 NOTREACHED() << "Crashing to preserve corrupt sync database"; |
| 115 } | 115 } |
| 116 | 116 |
| 117 } // namespace syncable | 117 } // namespace syncable |
| 118 } // namespace syncer | 118 } // namespace syncer |
| OLD | NEW |