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

Side by Side Diff: chrome/browser/ui/global_error/global_error_service.h

Issue 2409443002: Make GlobalErrorService's ownership model slightly less insane. (Closed)
Patch Set: commentary Created 4 years 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_BROWSER_UI_GLOBAL_ERROR_GLOBAL_ERROR_SERVICE_H_ 5 #ifndef CHROME_BROWSER_UI_GLOBAL_ERROR_GLOBAL_ERROR_SERVICE_H_
6 #define CHROME_BROWSER_UI_GLOBAL_ERROR_GLOBAL_ERROR_SERVICE_H_ 6 #define CHROME_BROWSER_UI_GLOBAL_ERROR_GLOBAL_ERROR_SERVICE_H_
7 7
8 #include <map>
9 #include <memory>
8 #include <vector> 10 #include <vector>
9 11
10 #include "base/macros.h" 12 #include "base/macros.h"
11 #include "components/keyed_service/core/keyed_service.h" 13 #include "components/keyed_service/core/keyed_service.h"
12 14
13 class GlobalError; 15 class GlobalError;
14 class Profile; 16 class Profile;
15 17
16 // This service manages a list of errors that are meant to be shown globally. 18 // This service manages a list of errors that are meant to be shown globally.
17 // If an error applies to an entire profile and not just to a tab then the 19 // If an error applies to an entire profile and not just to a tab then the
18 // error should be shown using this service. Examples of global errors are: 20 // error should be shown using this service. Examples of global errors are:
19 // - the previous session crashed for a given profile. 21 // - the previous session crashed for a given profile.
20 // - a sync error occurred 22 // - a sync error occurred
21 class GlobalErrorService : public KeyedService { 23 class GlobalErrorService : public KeyedService {
22 public: 24 public:
23 // Type used to represent the list of currently active errors. 25 // Type used to represent the list of currently active errors.
24 typedef std::vector<GlobalError*> GlobalErrorList; 26 using GlobalErrorList = std::vector<GlobalError*>;
25 27
26 // Constructs a GlobalErrorService object for the given profile. The profile 28 // Constructs a GlobalErrorService object for the given profile. The profile
27 // maybe NULL for tests. 29 // maybe NULL for tests.
28 explicit GlobalErrorService(Profile* profile); 30 explicit GlobalErrorService(Profile* profile);
29 ~GlobalErrorService() override; 31 ~GlobalErrorService() override;
30 32
31 // Adds the given error to the list of global errors and displays it on 33 // Adds the given error to the list of global errors and displays it on
32 // browswer windows. If no browser windows are open then the error is 34 // browser windows. If no browser windows are open then the error is
33 // displayed once a browser window is opened. This class takes ownership of 35 // displayed once a browser window is opened.
34 // the error. 36 void AddGlobalError(std::unique_ptr<GlobalError> error);
35 void AddGlobalError(GlobalError* error);
36 37
37 // Hides the given error and removes it from the list of global errors. Caller 38 // Hides the given error and removes it from the list of global errors.
38 // then takes ownership of the error and is responsible for deleting it. 39 // Ownership is returned to the caller.
39 void RemoveGlobalError(GlobalError* error); 40 std::unique_ptr<GlobalError> RemoveGlobalError(GlobalError* error);
41
42 // DEPRECATED; DO NOT USE!
43 // http://crbug.com/673578
44 //
45 // These functions allow adding and removing of a GlobalError that is not
46 // owned by the GlobalErrorService. In this case, the error's lifetime must
47 // exceed that of the GlobalErrorService.
48 //
49 // Do not add more uses of these functions, and remove existing uses.
50 void AddUnownedGlobalError(GlobalError* error);
51 void RemoveUnownedGlobalError(GlobalError* error);
40 52
41 // Gets the error with the given command ID or NULL if no such error exists. 53 // Gets the error with the given command ID or NULL if no such error exists.
42 // This class maintains ownership of the returned error. 54 // This class maintains ownership of the returned error.
43 GlobalError* GetGlobalErrorByMenuItemCommandID(int command_id) const; 55 GlobalError* GetGlobalErrorByMenuItemCommandID(int command_id) const;
44 56
45 // Gets the highest severity error that has a app menu item. 57 // Gets the highest severity error that has a app menu item.
46 // Returns NULL if no such error exists. 58 // Returns NULL if no such error exists.
47 GlobalError* GetHighestSeverityGlobalErrorWithAppMenuItem() const; 59 GlobalError* GetHighestSeverityGlobalErrorWithAppMenuItem() const;
48 60
49 // Gets the first error that has a bubble view which hasn't been shown yet. 61 // Gets the first error that has a bubble view which hasn't been shown yet.
50 // Returns NULL if no such error exists. 62 // Returns NULL if no such error exists.
51 GlobalError* GetFirstGlobalErrorWithBubbleView() const; 63 GlobalError* GetFirstGlobalErrorWithBubbleView() const;
52 64
53 // Gets all errors. 65 // Gets all errors.
54 const GlobalErrorList& errors() { return errors_; } 66 const GlobalErrorList& errors() { return all_errors_; }
55 67
56 // Post a notification that a global error has changed and that the error UI 68 // Post a notification that a global error has changed and that the error UI
57 // should update it self. Pass NULL for the given error to mean all error UIs 69 // should update it self. Pass NULL for the given error to mean all error UIs
58 // should update. 70 // should update.
59 void NotifyErrorsChanged(GlobalError* error); 71 void NotifyErrorsChanged(GlobalError* error);
60 72
61 private: 73 private:
62 GlobalErrorList errors_; 74 GlobalErrorList all_errors_;
75 std::map<GlobalError*, std::unique_ptr<GlobalError>> owned_errors_;
63 Profile* profile_; 76 Profile* profile_;
64 77
65 DISALLOW_COPY_AND_ASSIGN(GlobalErrorService); 78 DISALLOW_COPY_AND_ASSIGN(GlobalErrorService);
66 }; 79 };
67 80
68 #endif // CHROME_BROWSER_UI_GLOBAL_ERROR_GLOBAL_ERROR_SERVICE_H_ 81 #endif // CHROME_BROWSER_UI_GLOBAL_ERROR_GLOBAL_ERROR_SERVICE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698