| // 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. |
| |
| #ifndef THIRD_PARTY_ZLIB_GOOGLE_ZIP_H_ |
| #define THIRD_PARTY_ZLIB_GOOGLE_ZIP_H_ |
| |
| #include <vector> |
| |
| #include "base/callback.h" |
| #include "base/files/file_path.h" |
| #include "build/build_config.h" |
| |
| namespace zip { |
| |
| // Zip the contents of src_dir into dest_file. src_path must be a directory. |
| // An entry will *not* be created in the zip for the root folder -- children |
| // of src_dir will be at the root level of the created zip. For each file in |
| // src_dir, include it only if the callback |filter_cb| returns true. Otherwise |
| // omit it. |
| typedef base::Callback<bool(const base::FilePath&)> FilterCallback; |
| bool ZipWithFilterCallback(const base::FilePath& src_dir, |
| const base::FilePath& dest_file, |
| const FilterCallback& filter_cb); |
| |
| // Convenience method for callers who don't need to set up the filter callback. |
| // If |include_hidden_files| is true, files starting with "." are included. |
| // Otherwise they are omitted. |
| bool Zip(const base::FilePath& src_dir, const base::FilePath& dest_file, |
| bool include_hidden_files); |
| |
| #if defined(OS_POSIX) |
| // Zips files listed in |src_relative_paths| to destination specified by file |
| // descriptor |dest_fd|, without taking ownership of |dest_fd|. The paths listed |
| // in |src_relative_paths| are relative to the |src_dir| and will be used as the |
| // file names in the created zip file. All source paths must be under |src_dir| |
| // in the file system hierarchy. |
| bool ZipFiles(const base::FilePath& src_dir, |
| const std::vector<base::FilePath>& src_relative_paths, |
| int dest_fd); |
| #endif // defined(OS_POSIX) |
| |
| // Unzip the contents of zip_file into dest_dir. |
| // For each file in zip_file, include it only if the callback |filter_cb| |
| // returns true. Otherwise omit it. |
| // If |log_skipped_files| is true, files skipped during extraction are printed |
| // to debug log. |
| typedef base::Callback<bool(const base::FilePath&)> FilterCallback; |
| bool UnzipWithFilterCallback(const base::FilePath& zip_file, |
| const base::FilePath& dest_dir, |
| const FilterCallback& filter_cb, |
| bool log_skipped_files); |
| |
| // Unzip the contents of zip_file into dest_dir. |
| bool Unzip(const base::FilePath& zip_file, const base::FilePath& dest_dir); |
| |
| } // namespace zip |
| |
| #endif // THIRD_PARTY_ZLIB_GOOGLE_ZIP_H_ |