| // Copyright (c) 2011 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. | 
 |  | 
 | // Cross platform methods for FilePathWatcher. See the various platform | 
 | // specific implementation files, too. | 
 |  | 
 | #include "base/files/file_path_watcher.h" | 
 |  | 
 | #include "base/logging.h" | 
 | #include "build/build_config.h" | 
 |  | 
 | namespace base { | 
 |  | 
 | FilePathWatcher::~FilePathWatcher() { | 
 |   DCHECK(sequence_checker_.CalledOnValidSequence()); | 
 |   impl_->Cancel(); | 
 | } | 
 |  | 
 | // static | 
 | bool FilePathWatcher::RecursiveWatchAvailable() { | 
 | #if (defined(OS_MACOSX) && !defined(OS_IOS)) || defined(OS_WIN) || \ | 
 |     defined(OS_LINUX) || defined(OS_ANDROID) | 
 |   return true; | 
 | #else | 
 |   // FSEvents isn't available on iOS. | 
 |   return false; | 
 | #endif | 
 | } | 
 |  | 
 | FilePathWatcher::PlatformDelegate::PlatformDelegate(): cancelled_(false) { | 
 | } | 
 |  | 
 | FilePathWatcher::PlatformDelegate::~PlatformDelegate() { | 
 |   DCHECK(is_cancelled()); | 
 | } | 
 |  | 
 | bool FilePathWatcher::Watch(const FilePath& path, | 
 |                             bool recursive, | 
 |                             const Callback& callback) { | 
 |   DCHECK(sequence_checker_.CalledOnValidSequence()); | 
 |   DCHECK(path.IsAbsolute()); | 
 |   return impl_->Watch(path, recursive, callback); | 
 | } | 
 |  | 
 | }  // namespace base |