| Index: chrome/browser/webdata/web_data_service_factory.cc
 | 
| diff --git a/chrome/browser/webdata/web_data_service_factory.cc b/chrome/browser/webdata/web_data_service_factory.cc
 | 
| index 25a6af764bfc92279bf2aabc402b68da37837a6f..c687186a78d6514d216cf2515464112790261d25 100644
 | 
| --- a/chrome/browser/webdata/web_data_service_factory.cc
 | 
| +++ b/chrome/browser/webdata/web_data_service_factory.cc
 | 
| @@ -8,11 +8,16 @@
 | 
|  #include "base/files/file_path.h"
 | 
|  #include "chrome/browser/profiles/profile_dependency_manager.h"
 | 
|  #include "chrome/browser/ui/profile_error_dialog.h"
 | 
| +#include "chrome/browser/webdata/autocomplete_syncable_service.h"
 | 
| +#include "chrome/browser/webdata/autofill_profile_syncable_service.h"
 | 
|  #include "chrome/browser/webdata/autofill_web_data_service_impl.h"
 | 
|  #include "chrome/common/chrome_constants.h"
 | 
| +#include "content/public/browser/browser_thread.h"
 | 
|  #include "grit/chromium_strings.h"
 | 
|  #include "grit/generated_resources.h"
 | 
|  
 | 
| +using content::BrowserThread;
 | 
| +
 | 
|  namespace {
 | 
|  
 | 
|  // Callback to show error dialog on profile load error.
 | 
| @@ -22,6 +27,15 @@ void ProfileErrorCallback(sql::InitStatus status) {
 | 
|        IDS_COULDNT_OPEN_PROFILE_ERROR : IDS_PROFILE_TOO_NEW_ERROR);
 | 
|  }
 | 
|  
 | 
| +void InitSyncableServicesOnDBThread(scoped_refptr<WebDataService> web_data) {
 | 
| +  DCHECK(BrowserThread::CurrentlyOn(BrowserThread::DB));
 | 
| +
 | 
| +  // Currently only Autocomplete and Autofill profiles use the new Sync API, but
 | 
| +  // all the database data should migrate to this API over time.
 | 
| +  AutocompleteSyncableService::CreateForWebDataService(web_data);
 | 
| +  AutofillProfileSyncableService::CreateForWebDataService(web_data);
 | 
| +}
 | 
| +
 | 
|  }  // namespace
 | 
|  
 | 
|  WebDataServiceWrapper::WebDataServiceWrapper() {}
 | 
| @@ -31,6 +45,10 @@ WebDataServiceWrapper::WebDataServiceWrapper(Profile* profile) {
 | 
|    path = path.Append(chrome::kWebDataFilename);
 | 
|    web_data_service_ = new WebDataService(base::Bind(&ProfileErrorCallback));
 | 
|    web_data_service_->Init(path);
 | 
| +
 | 
| +  BrowserThread::PostTask(BrowserThread::DB, FROM_HERE,
 | 
| +                          base::Bind(&InitSyncableServicesOnDBThread,
 | 
| +                                     web_data_service_));
 | 
|  }
 | 
|  
 | 
|  WebDataServiceWrapper::~WebDataServiceWrapper() {
 | 
| 
 |