OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 UI_VIEWS_WIDGET_WIDGET_REMOVALS_OBSERVER_H_ | 5 #ifndef UI_VIEWS_WIDGET_WIDGET_REMOVALS_OBSERVER_H_ |
6 #define UI_VIEWS_WIDGET_WIDGET_REMOVALS_OBSERVER_H_ | 6 #define UI_VIEWS_WIDGET_WIDGET_REMOVALS_OBSERVER_H_ |
7 | 7 |
8 #include "ui/views/views_export.h" | 8 #include "ui/views/views_export.h" |
9 | 9 |
10 namespace views { | 10 namespace views { |
11 | 11 |
12 class Widget; | 12 class Widget; |
13 class View; | 13 class View; |
14 | 14 |
15 // |WidgetRemovalsObserver| complements |WidgetObserver| with additional | 15 // |WidgetRemovalsObserver| complements |WidgetObserver| with additional |
16 // notifications. These include events occurring during tear down like view | 16 // notifications. These include events occurring during tear down like view |
17 // removal. For this reason, it is recommended that subclasses not also inherit | 17 // removal. For this reason, it is recommended that subclasses not also inherit |
18 // from |View|. | 18 // from |View|. |
19 class VIEWS_EXPORT WidgetRemovalsObserver { | 19 class VIEWS_EXPORT WidgetRemovalsObserver { |
20 public: | 20 public: |
21 // Called immediately before a descendant view of |widget| is removed. | 21 // Called immediately before a descendant view of |widget| is removed |
| 22 // from this widget. Won't be called if the view is moved within the |
| 23 // same widget, but will be called if it's moved to a different widget. |
| 24 // Only called on the root of a view tree; it implies that all of the |
| 25 // descendants of |view| will be removed. |
22 virtual void OnWillRemoveView(Widget* widget, View* view) {} | 26 virtual void OnWillRemoveView(Widget* widget, View* view) {} |
23 | 27 |
24 protected: | 28 protected: |
25 virtual ~WidgetRemovalsObserver() {} | 29 virtual ~WidgetRemovalsObserver() {} |
26 }; | 30 }; |
27 | 31 |
28 } // namespace views | 32 } // namespace views |
29 | 33 |
30 #endif // UI_VIEWS_WIDGET_WIDGET_REMOVALS_OBSERVER_H_ | 34 #endif // UI_VIEWS_WIDGET_WIDGET_REMOVALS_OBSERVER_H_ |
OLD | NEW |