Chromium Code Reviews| Index: tools/android/timemodified/timemodified.cc |
| diff --git a/tools/android/timemodified/timemodified.cc b/tools/android/timemodified/timemodified.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..6fa55d8569d82a8d33a8ac319736bd08704db512 |
| --- /dev/null |
| +++ b/tools/android/timemodified/timemodified.cc |
| @@ -0,0 +1,62 @@ |
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
|
frankf
2013/06/20 22:52:38
13
craigdh
2013/07/02 17:26:12
Done.
|
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +// Md5sum implementation for Android. This version handles files as well as |
|
frankf
2013/06/20 22:52:38
Update doc
craigdh
2013/07/02 17:26:12
Done.
|
| +// directories. Its output is sorted by file path. |
| + |
| +#include <iostream> |
| +#include <string> |
| + |
| +#include "base/file_util.h" |
| +#include "base/files/file_enumerator.h" |
| +#include "base/files/file_path.h" |
| +#include "base/logging.h" |
| +#include "base/platform_file.h" |
| +#include "base/time.h" |
| + |
| +namespace { |
| + |
| +bool PrintFileAccessTime(const base::FilePath& path) { |
| + base::PlatformFileInfo file_info; |
| + if (!file_util::GetFileInfo(path, &file_info)) |
| + return false; |
| + std::cout << file_info.last_modified.ToTimeT() << " " |
| + << base::MakeAbsoluteFilePath(path).value() << std::endl; |
| +} |
| + |
| +// Prints the access times of all files contained in |files|. This handles |
| +// directories by walking them recursively. Excludes .svn directories and files |
| +// under them. |
| +bool PrintAccessTimesRecursively(int num_files, const char** files) { |
| + const std::string svn_dir_component = FILE_PATH_LITERAL("/.svn/"); |
| + for (const char** file = files; file != files + num_files; ++file) { |
| + base::FilePath file_path(*file); |
| + if (file_util::DirectoryExists(file_path)) { |
| + base::FileEnumerator file_enumerator( |
| + file_path, true /* recurse */, base::FileEnumerator::FILES); |
| + for (base::FilePath child, empty; |
| + (child = file_enumerator.Next()) != empty; ) { |
|
frankf
2013/06/20 22:52:38
I think a while loop here is more readable.
craigdh
2013/07/02 17:26:12
Done.
|
| + // If the path contains /.svn/, ignore it. |
| + if (child.value().find(svn_dir_component) == std::string::npos) { |
| + if (!PrintFileAccessTime(child)) |
|
frankf
2013/06/20 22:52:38
Can we log the failure cases for debugging.
craigdh
2013/07/02 17:26:12
Done.
|
| + return false; |
| + } |
| + } |
| + } else { |
| + if (!PrintFileAccessTime(file_path)) |
| + return false; |
| + } |
| + } |
| + return true; |
| +} |
| + |
| +} // namespace |
| + |
| +int main(int argc, const char* argv[]) { |
| + if (argc < 2) { |
| + LOG(ERROR) << "Usage: timemodified <path/to/file_or_dir> ..."; |
| + return 1; |
| + } |
| + return PrintAccessTimesRecursively(argc - 1, argv + 1); |
| +} |