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

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

Issue 1882923003: 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, 8 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) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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_CALLBACK_WORK_ITEM_H_ 5 #ifndef CHROME_INSTALLER_UTIL_CALLBACK_WORK_ITEM_H_
6 #define CHROME_INSTALLER_UTIL_CALLBACK_WORK_ITEM_H_ 6 #define CHROME_INSTALLER_UTIL_CALLBACK_WORK_ITEM_H_
7 7
8 #include "base/callback.h" 8 #include "base/callback.h"
9 #include "base/compiler_specific.h" 9 #include "base/compiler_specific.h"
10 #include "base/gtest_prod_util.h" 10 #include "base/gtest_prod_util.h"
(...skipping 17 matching lines...) Expand all
28 // 28 //
29 // void SomeFunctionThatAddsItemsToAList(WorkItemList* item_list) { 29 // void SomeFunctionThatAddsItemsToAList(WorkItemList* item_list) {
30 // ... 30 // ...
31 // item_list->AddCallbackWorkItem(base::Bind(&SomeWorkItemCallback)); 31 // item_list->AddCallbackWorkItem(base::Bind(&SomeWorkItemCallback));
32 // ... 32 // ...
33 // } 33 // }
34 class CallbackWorkItem : public WorkItem { 34 class CallbackWorkItem : public WorkItem {
35 public: 35 public:
36 ~CallbackWorkItem() override; 36 ~CallbackWorkItem() override;
37 37
38 bool Do() override;
39 void Rollback() override;
40
41 bool IsRollback() const; 38 bool IsRollback() const;
42 39
43 private: 40 private:
44 friend class WorkItem; 41 friend class WorkItem;
45 42
46 enum RollState { 43 enum RollState {
47 RS_UNDEFINED, 44 RS_UNDEFINED,
48 RS_FORWARD, 45 RS_FORWARD,
49 RS_BACKWARD, 46 RS_BACKWARD,
50 }; 47 };
51 48
52 CallbackWorkItem(base::Callback<bool(const CallbackWorkItem&)> callback); 49 explicit CallbackWorkItem(
50 base::Callback<bool(const CallbackWorkItem&)> callback);
51
52 // WorkItem:
53 bool DoImpl() override;
54 void RollbackImpl() override;
53 55
54 base::Callback<bool(const CallbackWorkItem&)> callback_; 56 base::Callback<bool(const CallbackWorkItem&)> callback_;
55 RollState roll_state_; 57 RollState roll_state_;
56 58
57 FRIEND_TEST_ALL_PREFIXES(CallbackWorkItemTest, TestFailure); 59 FRIEND_TEST_ALL_PREFIXES(CallbackWorkItemTest, TestFailure);
58 FRIEND_TEST_ALL_PREFIXES(CallbackWorkItemTest, TestForwardBackward); 60 FRIEND_TEST_ALL_PREFIXES(CallbackWorkItemTest, TestForwardBackward);
59 }; 61 };
60 62
61 #endif // CHROME_INSTALLER_UTIL_CALLBACK_WORK_ITEM_H_ 63 #endif // CHROME_INSTALLER_UTIL_CALLBACK_WORK_ITEM_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698