| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/media_galleries/media_scan_manager.h" | 5 #include "chrome/browser/media_galleries/media_scan_manager.h" |
| 6 | 6 |
| 7 #include "base/file_util.h" | 7 #include "base/file_util.h" |
| 8 #include "base/files/file_enumerator.h" | 8 #include "base/files/file_enumerator.h" |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/metrics/histogram.h" | 10 #include "base/metrics/histogram.h" |
| (...skipping 354 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 365 scans_for_profile->second.observer->OnScanFinished(extension->id(), | 365 scans_for_profile->second.observer->OnScanFinished(extension->id(), |
| 366 gallery_count, | 366 gallery_count, |
| 367 file_counts); | 367 file_counts); |
| 368 return; | 368 return; |
| 369 } | 369 } |
| 370 | 370 |
| 371 // On first scan for the |profile|, register to listen for extension unload. | 371 // On first scan for the |profile|, register to listen for extension unload. |
| 372 if (scanning_extensions->empty()) { | 372 if (scanning_extensions->empty()) { |
| 373 registrar_.Add( | 373 registrar_.Add( |
| 374 this, | 374 this, |
| 375 chrome::NOTIFICATION_EXTENSION_UNLOADED, | 375 chrome::NOTIFICATION_EXTENSION_UNLOADED_DEPRECATED, |
| 376 content::Source<Profile>(profile)); | 376 content::Source<Profile>(profile)); |
| 377 } | 377 } |
| 378 | 378 |
| 379 scanning_extensions->insert(extension->id()); | 379 scanning_extensions->insert(extension->id()); |
| 380 scans_for_profile->second.observer->OnScanStarted(extension->id()); | 380 scans_for_profile->second.observer->OnScanStarted(extension->id()); |
| 381 | 381 |
| 382 if (folder_finder_) | 382 if (folder_finder_) |
| 383 return; | 383 return; |
| 384 | 384 |
| 385 MediaFolderFinder::MediaFolderFinderResultsCallback callback = | 385 MediaFolderFinder::MediaFolderFinderResultsCallback callback = |
| (...skipping 18 matching lines...) Expand all Loading... |
| 404 !scans_for_profile->second.scanning_extensions.erase(extension->id())) { | 404 !scans_for_profile->second.scanning_extensions.erase(extension->id())) { |
| 405 return; | 405 return; |
| 406 } | 406 } |
| 407 | 407 |
| 408 scans_for_profile->second.observer->OnScanCancelled(extension->id()); | 408 scans_for_profile->second.observer->OnScanCancelled(extension->id()); |
| 409 | 409 |
| 410 // No more scanning extensions for |profile|, so stop listening for unloads. | 410 // No more scanning extensions for |profile|, so stop listening for unloads. |
| 411 if (scans_for_profile->second.scanning_extensions.empty()) { | 411 if (scans_for_profile->second.scanning_extensions.empty()) { |
| 412 registrar_.Remove( | 412 registrar_.Remove( |
| 413 this, | 413 this, |
| 414 chrome::NOTIFICATION_EXTENSION_UNLOADED, | 414 chrome::NOTIFICATION_EXTENSION_UNLOADED_DEPRECATED, |
| 415 content::Source<Profile>(profile)); | 415 content::Source<Profile>(profile)); |
| 416 } | 416 } |
| 417 | 417 |
| 418 if (!ScanInProgress()) { | 418 if (!ScanInProgress()) { |
| 419 folder_finder_.reset(); | 419 folder_finder_.reset(); |
| 420 DCHECK(!scan_start_time_.is_null()); | 420 DCHECK(!scan_start_time_.is_null()); |
| 421 UMA_HISTOGRAM_LONG_TIMES("MediaGalleries.ScanCancelTime", | 421 UMA_HISTOGRAM_LONG_TIMES("MediaGalleries.ScanCancelTime", |
| 422 base::Time::Now() - scan_start_time_); | 422 base::Time::Now() - scan_start_time_); |
| 423 scan_start_time_ = base::Time(); | 423 scan_start_time_ = base::Time(); |
| 424 } | 424 } |
| 425 } | 425 } |
| 426 | 426 |
| 427 void MediaScanManager::SetMediaFolderFinderFactory( | 427 void MediaScanManager::SetMediaFolderFinderFactory( |
| 428 const MediaFolderFinderFactory& factory) { | 428 const MediaFolderFinderFactory& factory) { |
| 429 testing_folder_finder_factory_ = factory; | 429 testing_folder_finder_factory_ = factory; |
| 430 } | 430 } |
| 431 | 431 |
| 432 MediaScanManager::ScanObservers::ScanObservers() : observer(NULL) {} | 432 MediaScanManager::ScanObservers::ScanObservers() : observer(NULL) {} |
| 433 MediaScanManager::ScanObservers::~ScanObservers() {} | 433 MediaScanManager::ScanObservers::~ScanObservers() {} |
| 434 | 434 |
| 435 void MediaScanManager::Observe( | 435 void MediaScanManager::Observe( |
| 436 int type, const content::NotificationSource& source, | 436 int type, const content::NotificationSource& source, |
| 437 const content::NotificationDetails& details) { | 437 const content::NotificationDetails& details) { |
| 438 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); | 438 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
| 439 switch (type) { | 439 switch (type) { |
| 440 case chrome::NOTIFICATION_EXTENSION_UNLOADED: { | 440 case chrome::NOTIFICATION_EXTENSION_UNLOADED_DEPRECATED: { |
| 441 Profile* profile = content::Source<Profile>(source).ptr(); | 441 Profile* profile = content::Source<Profile>(source).ptr(); |
| 442 extensions::Extension* extension = const_cast<extensions::Extension*>( | 442 extensions::Extension* extension = const_cast<extensions::Extension*>( |
| 443 content::Details<extensions::UnloadedExtensionInfo>( | 443 content::Details<extensions::UnloadedExtensionInfo>( |
| 444 details)->extension); | 444 details)->extension); |
| 445 DCHECK(extension); | 445 DCHECK(extension); |
| 446 CancelScan(profile, extension); | 446 CancelScan(profile, extension); |
| 447 break; | 447 break; |
| 448 } | 448 } |
| 449 default: | 449 default: |
| 450 NOTREACHED(); | 450 NOTREACHED(); |
| (...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 525 gallery_count, | 525 gallery_count, |
| 526 file_counts); | 526 file_counts); |
| 527 } | 527 } |
| 528 } | 528 } |
| 529 scanning_extensions->clear(); | 529 scanning_extensions->clear(); |
| 530 preferences->SetLastScanCompletionTime(base::Time::Now()); | 530 preferences->SetLastScanCompletionTime(base::Time::Now()); |
| 531 } | 531 } |
| 532 registrar_.RemoveAll(); | 532 registrar_.RemoveAll(); |
| 533 folder_finder_.reset(); | 533 folder_finder_.reset(); |
| 534 } | 534 } |
| OLD | NEW |