Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "chrome/browser/sync/glue/sync_backend_host_impl.h" | 5 #include "chrome/browser/sync/glue/sync_backend_host_impl.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "chrome/browser/browser_process.h" | 9 #include "chrome/browser/browser_process.h" |
| 10 #include "chrome/browser/chrome_notification_types.h" | 10 #include "chrome/browser/chrome_notification_types.h" |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 26 #include "sync/internal_api/public/base_transaction.h" | 26 #include "sync/internal_api/public/base_transaction.h" |
| 27 #include "sync/internal_api/public/events/protocol_event.h" | 27 #include "sync/internal_api/public/events/protocol_event.h" |
| 28 #include "sync/internal_api/public/http_bridge.h" | 28 #include "sync/internal_api/public/http_bridge.h" |
| 29 #include "sync/internal_api/public/internal_components_factory.h" | 29 #include "sync/internal_api/public/internal_components_factory.h" |
| 30 #include "sync/internal_api/public/internal_components_factory_impl.h" | 30 #include "sync/internal_api/public/internal_components_factory_impl.h" |
| 31 #include "sync/internal_api/public/network_resources.h" | 31 #include "sync/internal_api/public/network_resources.h" |
| 32 #include "sync/internal_api/public/sync_manager.h" | 32 #include "sync/internal_api/public/sync_manager.h" |
| 33 #include "sync/internal_api/public/sync_manager_factory.h" | 33 #include "sync/internal_api/public/sync_manager_factory.h" |
| 34 #include "sync/internal_api/public/util/experiments.h" | 34 #include "sync/internal_api/public/util/experiments.h" |
| 35 #include "sync/internal_api/public/util/sync_string_conversions.h" | 35 #include "sync/internal_api/public/util/sync_string_conversions.h" |
| 36 #include "sync/syncable/directory.h" | |
| 36 | 37 |
| 37 // Helper macros to log with the syncer thread name; useful when there | 38 // Helper macros to log with the syncer thread name; useful when there |
| 38 // are multiple syncers involved. | 39 // are multiple syncers involved. |
| 39 | 40 |
| 40 #define SLOG(severity) LOG(severity) << name_ << ": " | 41 #define SLOG(severity) LOG(severity) << name_ << ": " |
| 41 | 42 |
| 42 #define SDVLOG(verbose_level) DVLOG(verbose_level) << name_ << ": " | 43 #define SDVLOG(verbose_level) DVLOG(verbose_level) << name_ << ": " |
| 43 | 44 |
| 44 using syncer::InternalComponentsFactory; | 45 using syncer::InternalComponentsFactory; |
| 45 | 46 |
| (...skipping 467 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 513 NOTREACHED(); | 514 NOTREACHED(); |
| 514 } | 515 } |
| 515 } | 516 } |
| 516 | 517 |
| 517 SyncedDeviceTracker* SyncBackendHostImpl::GetSyncedDeviceTracker() const { | 518 SyncedDeviceTracker* SyncBackendHostImpl::GetSyncedDeviceTracker() const { |
| 518 if (!initialized()) | 519 if (!initialized()) |
| 519 return NULL; | 520 return NULL; |
| 520 return core_->synced_device_tracker(); | 521 return core_->synced_device_tracker(); |
| 521 } | 522 } |
| 522 | 523 |
| 524 void FlushDirectoryWrapper(syncer::syncable::Directory* directory) { | |
|
maniscalco
2014/09/10 17:49:03
What's the motivation for using this free function
maxbogue
2014/09/10 20:11:01
Directory::SaveChanges returns a bool, so it canno
maniscalco
2014/09/10 20:19:25
Ah, check out IgnoreResult:
https://code.google.c
maxbogue
2014/09/12 16:45:38
Done.
| |
| 525 directory->SaveChanges(); | |
| 526 } | |
| 527 | |
| 528 void SyncBackendHostImpl::FlushDirectory() const { | |
|
nyquist
2014/09/10 17:43:09
Does this require the sync engine to be initialize
maxbogue
2014/09/10 20:11:01
I kind of assumed that directory being NULL meant
| |
| 529 syncer::syncable::Directory* directory = GetUserShare()->directory.get(); | |
| 530 if (directory != nullptr) { | |
|
nyquist
2014/09/10 17:43:09
!= NULL ?
maxbogue
2014/09/10 20:11:01
Done.
| |
| 531 registrar_->sync_thread()->message_loop()->PostTask(FROM_HERE, | |
| 532 base::Bind(&FlushDirectoryWrapper, directory)); | |
|
maniscalco
2014/09/10 20:19:25
As we talked about in person over lunch, it seems
maxbogue
2014/09/12 16:45:38
Routed through SyncBackendHostCore to try to solve
| |
| 533 } | |
| 534 } | |
| 535 | |
| 523 void SyncBackendHostImpl::RequestBufferedProtocolEventsAndEnableForwarding() { | 536 void SyncBackendHostImpl::RequestBufferedProtocolEventsAndEnableForwarding() { |
| 524 registrar_->sync_thread()->message_loop()->PostTask( | 537 registrar_->sync_thread()->message_loop()->PostTask( |
| 525 FROM_HERE, | 538 FROM_HERE, |
| 526 base::Bind( | 539 base::Bind( |
| 527 &SyncBackendHostCore::SendBufferedProtocolEventsAndEnableForwarding, | 540 &SyncBackendHostCore::SendBufferedProtocolEventsAndEnableForwarding, |
| 528 core_)); | 541 core_)); |
| 529 } | 542 } |
| 530 | 543 |
| 531 void SyncBackendHostImpl::DisableProtocolEventForwarding() { | 544 void SyncBackendHostImpl::DisableProtocolEventForwarding() { |
| 532 registrar_->sync_thread()->message_loop()->PostTask( | 545 registrar_->sync_thread()->message_loop()->PostTask( |
| (...skipping 351 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 884 | 897 |
| 885 base::MessageLoop* SyncBackendHostImpl::GetSyncLoopForTesting() { | 898 base::MessageLoop* SyncBackendHostImpl::GetSyncLoopForTesting() { |
| 886 return registrar_->sync_thread()->message_loop(); | 899 return registrar_->sync_thread()->message_loop(); |
| 887 } | 900 } |
| 888 | 901 |
| 889 } // namespace browser_sync | 902 } // namespace browser_sync |
| 890 | 903 |
| 891 #undef SDVLOG | 904 #undef SDVLOG |
| 892 | 905 |
| 893 #undef SLOG | 906 #undef SLOG |
| OLD | NEW |