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/chromeos/extensions/file_manager/event_router.h" | 5 #include "chrome/browser/chromeos/extensions/file_manager/event_router.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
9 #include "base/files/file_util.h" | 9 #include "base/files/file_util.h" |
10 #include "base/message_loop/message_loop.h" | |
11 #include "base/prefs/pref_change_registrar.h" | 10 #include "base/prefs/pref_change_registrar.h" |
12 #include "base/prefs/pref_service.h" | 11 #include "base/prefs/pref_service.h" |
13 #include "base/stl_util.h" | 12 #include "base/stl_util.h" |
14 #include "base/thread_task_runner_handle.h" | 13 #include "base/thread_task_runner_handle.h" |
15 #include "base/threading/sequenced_worker_pool.h" | 14 #include "base/threading/sequenced_worker_pool.h" |
16 #include "base/values.h" | 15 #include "base/values.h" |
17 #include "chrome/browser/app_mode/app_mode_utils.h" | 16 #include "chrome/browser/app_mode/app_mode_utils.h" |
18 #include "chrome/browser/chromeos/drive/drive_integration_service.h" | 17 #include "chrome/browser/chromeos/drive/drive_integration_service.h" |
19 #include "chrome/browser/chromeos/drive/file_change.h" | 18 #include "chrome/browser/chromeos/drive/file_change.h" |
20 #include "chrome/browser/chromeos/drive/file_system_interface.h" | 19 #include "chrome/browser/chromeos/drive/file_system_interface.h" |
(...skipping 436 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
457 if (is_on_drive) | 456 if (is_on_drive) |
458 watch_path = drive::util::ExtractDrivePath(watch_path); | 457 watch_path = drive::util::ExtractDrivePath(watch_path); |
459 | 458 |
460 WatcherMap::iterator iter = file_watchers_.find(watch_path); | 459 WatcherMap::iterator iter = file_watchers_.find(watch_path); |
461 if (iter == file_watchers_.end()) { | 460 if (iter == file_watchers_.end()) { |
462 scoped_ptr<FileWatcher> watcher(new FileWatcher(virtual_path)); | 461 scoped_ptr<FileWatcher> watcher(new FileWatcher(virtual_path)); |
463 watcher->AddExtension(extension_id); | 462 watcher->AddExtension(extension_id); |
464 | 463 |
465 if (is_on_drive) { | 464 if (is_on_drive) { |
466 // For Drive, file watching is done via OnDirectoryChanged(). | 465 // For Drive, file watching is done via OnDirectoryChanged(). |
467 base::MessageLoopProxy::current()->PostTask(FROM_HERE, | 466 base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, |
468 base::Bind(callback, true)); | 467 base::Bind(callback, true)); |
469 } else { | 468 } else { |
470 // For local files, start watching using FileWatcher. | 469 // For local files, start watching using FileWatcher. |
471 watcher->WatchLocalFile( | 470 watcher->WatchLocalFile( |
472 watch_path, | 471 watch_path, |
473 base::Bind(&EventRouter::HandleFileWatchNotification, | 472 base::Bind(&EventRouter::HandleFileWatchNotification, |
474 weak_factory_.GetWeakPtr(), | 473 weak_factory_.GetWeakPtr(), |
475 static_cast<drive::FileChange*>(NULL)), | 474 static_cast<drive::FileChange*>(NULL)), |
476 callback); | 475 callback); |
477 } | 476 } |
478 | 477 |
479 file_watchers_[watch_path] = watcher.release(); | 478 file_watchers_[watch_path] = watcher.release(); |
480 } else { | 479 } else { |
481 iter->second->AddExtension(extension_id); | 480 iter->second->AddExtension(extension_id); |
482 base::MessageLoopProxy::current()->PostTask(FROM_HERE, | 481 base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, |
483 base::Bind(callback, true)); | 482 base::Bind(callback, true)); |
484 } | 483 } |
485 } | 484 } |
486 | 485 |
487 void EventRouter::RemoveFileWatch(const base::FilePath& local_path, | 486 void EventRouter::RemoveFileWatch(const base::FilePath& local_path, |
488 const std::string& extension_id) { | 487 const std::string& extension_id) { |
489 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 488 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
490 | 489 |
491 base::FilePath watch_path = local_path; | 490 base::FilePath watch_path = local_path; |
492 // Tweak watch path for remote sources - we need to drop leading /special | 491 // Tweak watch path for remote sources - we need to drop leading /special |
493 // directory from there in order to be able to pair these events with | 492 // directory from there in order to be able to pair these events with |
(...skipping 416 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
910 void EventRouter::SetDispatchDirectoryChangeEventImplForTesting( | 909 void EventRouter::SetDispatchDirectoryChangeEventImplForTesting( |
911 const DispatchDirectoryChangeEventImplCallback& callback) { | 910 const DispatchDirectoryChangeEventImplCallback& callback) { |
912 dispatch_directory_change_event_impl_ = callback; | 911 dispatch_directory_change_event_impl_ = callback; |
913 } | 912 } |
914 | 913 |
915 base::WeakPtr<EventRouter> EventRouter::GetWeakPtr() { | 914 base::WeakPtr<EventRouter> EventRouter::GetWeakPtr() { |
916 return weak_factory_.GetWeakPtr(); | 915 return weak_factory_.GetWeakPtr(); |
917 } | 916 } |
918 | 917 |
919 } // namespace file_manager | 918 } // namespace file_manager |
OLD | NEW |