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 "chrome/browser/chromeos/drive/change_list_loader.h" | 5 #include "chrome/browser/chromeos/drive/change_list_loader.h" |
6 | 6 |
7 #include <set> | 7 #include <set> |
8 | 8 |
9 #include "base/callback.h" | 9 #include "base/callback.h" |
10 #include "base/callback_helpers.h" | 10 #include "base/callback_helpers.h" |
11 #include "base/metrics/histogram.h" | 11 #include "base/metrics/histogram.h" |
12 #include "base/strings/string_number_conversions.h" | 12 #include "base/strings/string_number_conversions.h" |
13 #include "base/time/time.h" | 13 #include "base/time/time.h" |
14 #include "chrome/browser/chromeos/drive/change_list_loader_observer.h" | 14 #include "chrome/browser/chromeos/drive/change_list_loader_observer.h" |
15 #include "chrome/browser/chromeos/drive/change_list_processor.h" | 15 #include "chrome/browser/chromeos/drive/change_list_processor.h" |
16 #include "chrome/browser/chromeos/drive/file_system_util.h" | 16 #include "chrome/browser/chromeos/drive/file_system_util.h" |
17 #include "chrome/browser/chromeos/drive/job_scheduler.h" | 17 #include "chrome/browser/chromeos/drive/job_scheduler.h" |
18 #include "chrome/browser/chromeos/drive/resource_metadata.h" | 18 #include "chrome/browser/chromeos/drive/resource_metadata.h" |
19 #include "chrome/browser/drive/event_logger.h" | 19 #include "chrome/browser/drive/event_logger.h" |
20 #include "content/public/browser/browser_thread.h" | 20 #include "content/public/browser/browser_thread.h" |
21 #include "google_apis/drive/drive_api_parser.h" | 21 #include "google_apis/drive/drive_api_parser.h" |
22 #include "google_apis/drive/gdata_wapi_parser.h" | |
23 #include "url/gurl.h" | 22 #include "url/gurl.h" |
24 | 23 |
25 using content::BrowserThread; | 24 using content::BrowserThread; |
26 | 25 |
27 namespace drive { | 26 namespace drive { |
28 namespace internal { | 27 namespace internal { |
29 | 28 |
30 typedef base::Callback<void(FileError, ScopedVector<ChangeList>)> | 29 typedef base::Callback<void(FileError, ScopedVector<ChangeList>)> |
31 FeedFetcherCallback; | 30 FeedFetcherCallback; |
32 | 31 |
(...skipping 17 matching lines...) Expand all Loading... |
50 } | 49 } |
51 | 50 |
52 virtual void Run(const FeedFetcherCallback& callback) OVERRIDE { | 51 virtual void Run(const FeedFetcherCallback& callback) OVERRIDE { |
53 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 52 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
54 DCHECK(!callback.is_null()); | 53 DCHECK(!callback.is_null()); |
55 | 54 |
56 // Remember the time stamp for usage stats. | 55 // Remember the time stamp for usage stats. |
57 start_time_ = base::TimeTicks::Now(); | 56 start_time_ = base::TimeTicks::Now(); |
58 | 57 |
59 // This is full resource list fetch. | 58 // This is full resource list fetch. |
60 scheduler_->GetAllResourceList( | 59 scheduler_->GetAllFileList( |
61 base::Bind(&FullFeedFetcher::OnFileListFetched, | 60 base::Bind(&FullFeedFetcher::OnFileListFetched, |
62 weak_ptr_factory_.GetWeakPtr(), callback)); | 61 weak_ptr_factory_.GetWeakPtr(), callback)); |
63 } | 62 } |
64 | 63 |
65 private: | 64 private: |
66 void OnFileListFetched( | 65 void OnFileListFetched(const FeedFetcherCallback& callback, |
67 const FeedFetcherCallback& callback, | 66 google_apis::GDataErrorCode status, |
68 google_apis::GDataErrorCode status, | 67 scoped_ptr<google_apis::FileList> file_list) { |
69 scoped_ptr<google_apis::ResourceList> resource_list) { | |
70 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 68 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
71 DCHECK(!callback.is_null()); | 69 DCHECK(!callback.is_null()); |
72 | 70 |
73 FileError error = GDataToFileError(status); | 71 FileError error = GDataToFileError(status); |
74 if (error != FILE_ERROR_OK) { | 72 if (error != FILE_ERROR_OK) { |
75 callback.Run(error, ScopedVector<ChangeList>()); | 73 callback.Run(error, ScopedVector<ChangeList>()); |
76 return; | 74 return; |
77 } | 75 } |
78 | 76 |
79 DCHECK(resource_list); | 77 DCHECK(file_list); |
80 change_lists_.push_back(new ChangeList(*resource_list)); | 78 change_lists_.push_back(new ChangeList(*file_list)); |
81 | 79 |
82 GURL next_url; | 80 if (!file_list->next_link().is_empty()) { |
83 if (resource_list->GetNextFeedURL(&next_url) && !next_url.is_empty()) { | |
84 // There is the remaining result so fetch it. | 81 // There is the remaining result so fetch it. |
85 scheduler_->GetRemainingFileList( | 82 scheduler_->GetRemainingFileList( |
86 next_url, | 83 file_list->next_link(), |
87 base::Bind(&FullFeedFetcher::OnFileListFetched, | 84 base::Bind(&FullFeedFetcher::OnFileListFetched, |
88 weak_ptr_factory_.GetWeakPtr(), callback)); | 85 weak_ptr_factory_.GetWeakPtr(), callback)); |
89 return; | 86 return; |
90 } | 87 } |
91 | 88 |
92 UMA_HISTOGRAM_LONG_TIMES("Drive.FullFeedLoadTime", | 89 UMA_HISTOGRAM_LONG_TIMES("Drive.FullFeedLoadTime", |
93 base::TimeTicks::Now() - start_time_); | 90 base::TimeTicks::Now() - start_time_); |
94 | 91 |
95 // Note: The fetcher is managed by ChangeListLoader, and the instance | 92 // Note: The fetcher is managed by ChangeListLoader, and the instance |
96 // will be deleted in the callback. Do not touch the fields after this | 93 // will be deleted in the callback. Do not touch the fields after this |
(...skipping 24 matching lines...) Expand all Loading... |
121 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 118 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
122 DCHECK(!callback.is_null()); | 119 DCHECK(!callback.is_null()); |
123 | 120 |
124 scheduler_->GetChangeList( | 121 scheduler_->GetChangeList( |
125 start_change_id_, | 122 start_change_id_, |
126 base::Bind(&DeltaFeedFetcher::OnChangeListFetched, | 123 base::Bind(&DeltaFeedFetcher::OnChangeListFetched, |
127 weak_ptr_factory_.GetWeakPtr(), callback)); | 124 weak_ptr_factory_.GetWeakPtr(), callback)); |
128 } | 125 } |
129 | 126 |
130 private: | 127 private: |
131 void OnChangeListFetched( | 128 void OnChangeListFetched(const FeedFetcherCallback& callback, |
132 const FeedFetcherCallback& callback, | 129 google_apis::GDataErrorCode status, |
133 google_apis::GDataErrorCode status, | 130 scoped_ptr<google_apis::ChangeList> change_list) { |
134 scoped_ptr<google_apis::ResourceList> resource_list) { | |
135 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 131 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
136 DCHECK(!callback.is_null()); | 132 DCHECK(!callback.is_null()); |
137 | 133 |
138 FileError error = GDataToFileError(status); | 134 FileError error = GDataToFileError(status); |
139 if (error != FILE_ERROR_OK) { | 135 if (error != FILE_ERROR_OK) { |
140 callback.Run(error, ScopedVector<ChangeList>()); | 136 callback.Run(error, ScopedVector<ChangeList>()); |
141 return; | 137 return; |
142 } | 138 } |
143 | 139 |
144 DCHECK(resource_list); | 140 DCHECK(change_list); |
145 change_lists_.push_back(new ChangeList(*resource_list)); | 141 change_lists_.push_back(new ChangeList(*change_list)); |
146 | 142 |
147 GURL next_url; | 143 if (!change_list->next_link().is_empty()) { |
148 if (resource_list->GetNextFeedURL(&next_url) && !next_url.is_empty()) { | |
149 // There is the remaining result so fetch it. | 144 // There is the remaining result so fetch it. |
150 scheduler_->GetRemainingChangeList( | 145 scheduler_->GetRemainingChangeList( |
151 next_url, | 146 change_list->next_link(), |
152 base::Bind(&DeltaFeedFetcher::OnChangeListFetched, | 147 base::Bind(&DeltaFeedFetcher::OnChangeListFetched, |
153 weak_ptr_factory_.GetWeakPtr(), callback)); | 148 weak_ptr_factory_.GetWeakPtr(), callback)); |
154 return; | 149 return; |
155 } | 150 } |
156 | 151 |
157 // Note: The fetcher is managed by ChangeListLoader, and the instance | 152 // Note: The fetcher is managed by ChangeListLoader, and the instance |
158 // will be deleted in the callback. Do not touch the fields after this | 153 // will be deleted in the callback. Do not touch the fields after this |
159 // invocation. | 154 // invocation. |
160 callback.Run(FILE_ERROR_OK, change_lists_.Pass()); | 155 callback.Run(FILE_ERROR_OK, change_lists_.Pass()); |
161 } | 156 } |
(...skipping 377 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
539 | 534 |
540 OnChangeListLoadComplete(error); | 535 OnChangeListLoadComplete(error); |
541 | 536 |
542 FOR_EACH_OBSERVER(ChangeListLoaderObserver, | 537 FOR_EACH_OBSERVER(ChangeListLoaderObserver, |
543 observers_, | 538 observers_, |
544 OnLoadFromServerComplete()); | 539 OnLoadFromServerComplete()); |
545 } | 540 } |
546 | 541 |
547 } // namespace internal | 542 } // namespace internal |
548 } // namespace drive | 543 } // namespace drive |
OLD | NEW |