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_core.h" | 5 #include "chrome/browser/sync/glue/sync_backend_host_core.h" |
| 6 | 6 |
| 7 #include "base/files/file_util.h" | 7 #include "base/files/file_util.h" |
| 8 #include "base/metrics/histogram.h" | 8 #include "base/metrics/histogram.h" |
| 9 #include "chrome/browser/sync/glue/device_info.h" | 9 #include "chrome/browser/sync/glue/device_info.h" |
| 10 #include "chrome/browser/sync/glue/invalidation_adapter.h" | 10 #include "chrome/browser/sync/glue/invalidation_adapter.h" |
| 11 #include "chrome/browser/sync/glue/sync_backend_registrar.h" | 11 #include "chrome/browser/sync/glue/sync_backend_registrar.h" |
| 12 #include "chrome/browser/sync/glue/synced_device_tracker.h" | 12 #include "chrome/browser/sync/glue/synced_device_tracker.h" |
| 13 #include "chrome/common/chrome_version_info.h" | 13 #include "chrome/common/chrome_version_info.h" |
| 14 #include "components/invalidation/invalidation_util.h" | 14 #include "components/invalidation/invalidation_util.h" |
| 15 #include "components/invalidation/object_id_invalidation_map.h" | 15 #include "components/invalidation/object_id_invalidation_map.h" |
| 16 #include "sync/internal_api/public/events/protocol_event.h" | 16 #include "sync/internal_api/public/events/protocol_event.h" |
| 17 #include "sync/internal_api/public/http_post_provider_factory.h" | 17 #include "sync/internal_api/public/http_post_provider_factory.h" |
| 18 #include "sync/internal_api/public/internal_components_factory.h" | 18 #include "sync/internal_api/public/internal_components_factory.h" |
| 19 #include "sync/internal_api/public/sessions/commit_counters.h" | 19 #include "sync/internal_api/public/sessions/commit_counters.h" |
| 20 #include "sync/internal_api/public/sessions/status_counters.h" | 20 #include "sync/internal_api/public/sessions/status_counters.h" |
| 21 #include "sync/internal_api/public/sessions/sync_session_snapshot.h" | 21 #include "sync/internal_api/public/sessions/sync_session_snapshot.h" |
| 22 #include "sync/internal_api/public/sessions/update_counters.h" | 22 #include "sync/internal_api/public/sessions/update_counters.h" |
| 23 #include "sync/internal_api/public/sync_context_proxy.h" | 23 #include "sync/internal_api/public/sync_context_proxy.h" |
| 24 #include "sync/internal_api/public/sync_manager.h" | 24 #include "sync/internal_api/public/sync_manager.h" |
| 25 #include "sync/internal_api/public/sync_manager_factory.h" | 25 #include "sync/internal_api/public/sync_manager_factory.h" |
| 26 #include "sync/syncable/directory.h" | |
| 26 #include "url/gurl.h" | 27 #include "url/gurl.h" |
| 27 | 28 |
| 28 // Helper macros to log with the syncer thread name; useful when there | 29 // Helper macros to log with the syncer thread name; useful when there |
| 29 // are multiple syncers involved. | 30 // are multiple syncers involved. |
| 30 | 31 |
| 31 #define SLOG(severity) LOG(severity) << name_ << ": " | 32 #define SLOG(severity) LOG(severity) << name_ << ": " |
| 32 | 33 |
| 33 #define SDVLOG(verbose_level) DVLOG(verbose_level) << name_ << ": " | 34 #define SDVLOG(verbose_level) DVLOG(verbose_level) << name_ << ": " |
| 34 | 35 |
| 35 static const int kSaveChangesIntervalSeconds = 10; | 36 static const int kSaveChangesIntervalSeconds = 10; |
| (...skipping 619 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 655 } | 656 } |
| 656 | 657 |
| 657 void SyncBackendHostCore::DoRetryConfiguration( | 658 void SyncBackendHostCore::DoRetryConfiguration( |
| 658 const base::Closure& retry_callback) { | 659 const base::Closure& retry_callback) { |
| 659 DCHECK_EQ(base::MessageLoop::current(), sync_loop_); | 660 DCHECK_EQ(base::MessageLoop::current(), sync_loop_); |
| 660 host_.Call(FROM_HERE, | 661 host_.Call(FROM_HERE, |
| 661 &SyncBackendHostImpl::RetryConfigurationOnFrontendLoop, | 662 &SyncBackendHostImpl::RetryConfigurationOnFrontendLoop, |
| 662 retry_callback); | 663 retry_callback); |
| 663 } | 664 } |
| 664 | 665 |
| 666 void SyncBackendHostCore::DoFlushDirectory() { | |
| 667 DCHECK_EQ(base::MessageLoop::current(), sync_loop_); | |
| 668 syncer::syncable::Directory* directory = | |
|
Nicolas Zea
2014/09/15 22:38:59
What will this do if the SBH isn't initialized yet
maxbogue
2014/09/16 15:34:31
Which part will currently crash? How would the cal
Nicolas Zea
2014/09/18 16:52:17
The SyncManager is only created when DoInitialize
maxbogue
2014/09/22 17:23:25
Fixed this in PSS.
| |
| 669 sync_manager()->GetUserShare()->directory.get(); | |
| 670 if (directory != NULL) { | |
| 671 directory->SaveChanges(); | |
| 672 } | |
| 673 } | |
| 674 | |
| 665 void SyncBackendHostCore::SendBufferedProtocolEventsAndEnableForwarding() { | 675 void SyncBackendHostCore::SendBufferedProtocolEventsAndEnableForwarding() { |
| 666 DCHECK_EQ(base::MessageLoop::current(), sync_loop_); | 676 DCHECK_EQ(base::MessageLoop::current(), sync_loop_); |
| 667 forward_protocol_events_ = true; | 677 forward_protocol_events_ = true; |
| 668 | 678 |
| 669 if (sync_manager_) { | 679 if (sync_manager_) { |
| 670 // Grab our own copy of the buffered events. | 680 // Grab our own copy of the buffered events. |
| 671 // The buffer is not modified by this operation. | 681 // The buffer is not modified by this operation. |
| 672 std::vector<syncer::ProtocolEvent*> buffered_events; | 682 std::vector<syncer::ProtocolEvent*> buffered_events; |
| 673 sync_manager_->GetBufferedProtocolEvents().release(&buffered_events); | 683 sync_manager_->GetBufferedProtocolEvents().release(&buffered_events); |
| 674 | 684 |
| (...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 756 base::TimeDelta::FromSeconds(kSaveChangesIntervalSeconds), | 766 base::TimeDelta::FromSeconds(kSaveChangesIntervalSeconds), |
| 757 this, &SyncBackendHostCore::SaveChanges); | 767 this, &SyncBackendHostCore::SaveChanges); |
| 758 } | 768 } |
| 759 | 769 |
| 760 void SyncBackendHostCore::SaveChanges() { | 770 void SyncBackendHostCore::SaveChanges() { |
| 761 DCHECK_EQ(base::MessageLoop::current(), sync_loop_); | 771 DCHECK_EQ(base::MessageLoop::current(), sync_loop_); |
| 762 sync_manager_->SaveChanges(); | 772 sync_manager_->SaveChanges(); |
| 763 } | 773 } |
| 764 | 774 |
| 765 } // namespace browser_sync | 775 } // namespace browser_sync |
| OLD | NEW |