// Copyright 2015 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef IOS_CHROME_BROWSER_SYNC_GLUE_SYNC_START_UTIL_H_ #define IOS_CHROME_BROWSER_SYNC_GLUE_SYNC_START_UTIL_H_ #include "sync/api/syncable_service.h" namespace base { class FilePath; } // Various utilities for kicking off sync initialization from data types or // other services. namespace ios { namespace sync_start_util { // Creates a StartSyncFlare that a SyncableService can use to tell // sync_driver::SyncService it needs sync to start ASAP. Typically this would // be given to the SyncableService on construction. // // The flare built by this function is designed to be Run()able from any thread // so that non-UI types don't have to deal with posting tasks. // // |browser_state_path| is used to get a hold of the actual ChromeBrowserState* // once the request to start sync is safely in UI Thread land. syncer::SyncableService::StartSyncFlare GetFlareForSyncableService( const base::FilePath& browser_state_path); } // namespace sync_start_util } // namespace ios #endif // IOS_CHROME_BROWSER_SYNC_GLUE_SYNC_START_UTIL_H_