|  | // Copyright 2014 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. | 
|  |  | 
|  | #ifndef BASE_FILES_SCOPED_FILE_H_ | 
|  | #define BASE_FILES_SCOPED_FILE_H_ | 
|  |  | 
|  | #include <stdio.h> | 
|  |  | 
|  | #include <memory> | 
|  |  | 
|  | #include "base/base_export.h" | 
|  | #include "base/logging.h" | 
|  | #include "base/scoped_generic.h" | 
|  | #include "build_config.h" | 
|  |  | 
|  | namespace base { | 
|  |  | 
|  | namespace internal { | 
|  |  | 
|  | #if defined(OS_POSIX) || defined(OS_FUCHSIA) | 
|  | struct BASE_EXPORT ScopedFDCloseTraits { | 
|  | static int InvalidValue() { | 
|  | return -1; | 
|  | } | 
|  | static void Free(int fd); | 
|  | }; | 
|  | #endif | 
|  |  | 
|  | // Functor for |ScopedFILE| (below). | 
|  | struct ScopedFILECloser { | 
|  | inline void operator()(FILE* x) const { | 
|  | if (x) | 
|  | fclose(x); | 
|  | } | 
|  | }; | 
|  |  | 
|  | }  // namespace internal | 
|  |  | 
|  | // ----------------------------------------------------------------------------- | 
|  |  | 
|  | #if defined(OS_POSIX) || defined(OS_FUCHSIA) | 
|  | // A low-level Posix file descriptor closer class. Use this when writing | 
|  | // platform-specific code, especially that does non-file-like things with the | 
|  | // FD (like sockets). | 
|  | // | 
|  | // If you're writing low-level Windows code, see base/win/scoped_handle.h | 
|  | // which provides some additional functionality. | 
|  | // | 
|  | // If you're writing cross-platform code that deals with actual files, you | 
|  | // should generally use base::File instead which can be constructed with a | 
|  | // handle, and in addition to handling ownership, has convenient cross-platform | 
|  | // file manipulation functions on it. | 
|  | typedef ScopedGeneric<int, internal::ScopedFDCloseTraits> ScopedFD; | 
|  | #endif | 
|  |  | 
|  | // Automatically closes |FILE*|s. | 
|  | typedef std::unique_ptr<FILE, internal::ScopedFILECloser> ScopedFILE; | 
|  |  | 
|  | }  // namespace base | 
|  |  | 
|  | #endif  // BASE_FILES_SCOPED_FILE_H_ |