Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(221)

Side by Side Diff: chrome/installer/util/delete_tree_work_item.h

Issue 1976443005: Revert of Add best-effort/allow rollback flags on WorkItem. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@simple_list_tests
Patch Set: Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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 #ifndef CHROME_INSTALLER_UTIL_DELETE_TREE_WORK_ITEM_H_ 5 #ifndef CHROME_INSTALLER_UTIL_DELETE_TREE_WORK_ITEM_H_
6 #define CHROME_INSTALLER_UTIL_DELETE_TREE_WORK_ITEM_H_ 6 #define CHROME_INSTALLER_UTIL_DELETE_TREE_WORK_ITEM_H_
7 7
8 #include <stddef.h>
9
10 #include <memory>
11 #include <vector>
12
8 #include "base/files/file_path.h" 13 #include "base/files/file_path.h"
9 #include "base/files/scoped_temp_dir.h" 14 #include "base/files/scoped_temp_dir.h"
10 #include "chrome/installer/util/work_item.h" 15 #include "chrome/installer/util/work_item.h"
11 16
12 // A WorkItem subclass that recursively deletes a file system hierarchy at the 17 // A WorkItem subclass that recursively deletes a file system hierarchy at the
13 // given root path. The file system hierarchy could be a single file, or a 18 // given root path. The file system hierarchy could be a single file, or a
14 // directory. 19 // directory.
15 // The file system hierarchy to be deleted can have one or more key files. If 20 // The file system hierarchy to be deleted can have one or more key files. If
16 // specified, deletion will be performed only if all key files are not in use. 21 // specified, deletion will be performed only if all key files are not in use.
17 class DeleteTreeWorkItem : public WorkItem { 22 class DeleteTreeWorkItem : public WorkItem {
18 public: 23 public:
19 ~DeleteTreeWorkItem() override; 24 ~DeleteTreeWorkItem() override;
20 25
26 bool Do() override;
27
28 void Rollback() override;
29
21 private: 30 private:
22 friend class WorkItem; 31 friend class WorkItem;
23 32
24 // |root_path| will be moved to |temp_path| (rather than copied there and then 33 // |root_path| will be moved to |temp_path| (rather than copied there and then
25 // deleted). For best results in this case, |root_path| and |temp_path| 34 // deleted). For best results in this case, |root_path| and |temp_path|
26 // should be on the same volume; otherwise, the move will be simulated 35 // should be on the same volume; otherwise, the move will be simulated
27 // by a copy-and-delete operation. 36 // by a copy-and-delete operation.
28 DeleteTreeWorkItem(const base::FilePath& root_path, 37 DeleteTreeWorkItem(const base::FilePath& root_path,
29 const base::FilePath& temp_path); 38 const base::FilePath& temp_path,
30 39 const std::vector<base::FilePath>& key_paths);
31 // WorkItem:
32 bool DoImpl() override;
33 void RollbackImpl() override;
34 40
35 // Return temporary path for work based on |backup_path_| and |root_path_|. 41 // Return temporary path for work based on |backup_path_| and |root_path_|.
36 base::FilePath GetBackupPath(); 42 base::FilePath GetBackupPath();
37 43
38 // Attempts to delete |root_path_|. Returns true on success. 44 // Attempts to delete |root_path_|. Returns true on success.
39 bool DeleteRoot(); 45 bool DeleteRoot();
40 46
41 // Attempts to move |root_path_| to backup. Returns true on success. 47 // Attempts to move |root_path_| to backup. Returns true on success.
42 bool MoveRootToBackup(); 48 bool MoveRootToBackup();
43 49
44 // Root path to delete. 50 // Root path to delete.
45 const base::FilePath root_path_; 51 base::FilePath root_path_;
46 52
47 // Temporary directory that can be used. 53 // Temporary directory that can be used.
48 const base::FilePath temp_path_; 54 base::FilePath temp_path_;
55
56 // The number of key files.
57 ptrdiff_t num_key_files_;
58
59 // Contains the paths to the key files. If specified, deletion will be
60 // performed only if none of the key files are in use.
61 std::unique_ptr<base::FilePath[]> key_paths_;
62
63 // Contains the temp directories for the backed-up key files. The directories
64 // are created and populated in Do() as-needed. We don't use a standard
65 // container for this since base::ScopedTempDir isn't CopyConstructible.
66 std::unique_ptr<base::ScopedTempDir[]> key_backup_paths_;
49 67
50 // The temporary directory into which the original root_path_ has been moved. 68 // The temporary directory into which the original root_path_ has been moved.
51 base::ScopedTempDir backup_path_; 69 base::ScopedTempDir backup_path_;
52 70
53 // Set to true once root_path_ has been moved into backup_path_. 71 // Set to true once root_path_ has been moved into backup_path_.
54 bool moved_to_backup_ = false; 72 bool moved_to_backup_;
55 }; 73 };
56 74
57 #endif // CHROME_INSTALLER_UTIL_DELETE_TREE_WORK_ITEM_H_ 75 #endif // CHROME_INSTALLER_UTIL_DELETE_TREE_WORK_ITEM_H_
OLDNEW
« no previous file with comments | « chrome/installer/util/delete_reg_value_work_item.cc ('k') | chrome/installer/util/delete_tree_work_item.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698