OLD | NEW |
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 UI_BASE_LINUX_UI_H_ | 5 #ifndef UI_BASE_LINUX_UI_H_ |
6 #define UI_BASE_LINUX_UI_H_ | 6 #define UI_BASE_LINUX_UI_H_ |
7 | 7 |
| 8 #include "ui/base/dialogs/select_file_dialog.h" |
8 #include "ui/base/ui_export.h" | 9 #include "ui/base/ui_export.h" |
9 #include "third_party/skia/include/core/SkColor.h" | 10 #include "third_party/skia/include/core/SkColor.h" |
10 | 11 |
11 // The main entrypoint into Linux toolkit specific code. GTK code should only | 12 // The main entrypoint into Linux toolkit specific code. GTK code should only |
12 // be executed behind this interface. | 13 // be executed behind this interface. |
13 | 14 |
14 namespace gfx { | 15 namespace gfx { |
15 class Image; | 16 class Image; |
16 } | 17 } |
17 | 18 |
18 namespace ui { | 19 namespace ui { |
| 20 class SelectFilePolicy; |
19 | 21 |
20 // Adapter class with targets to render like different toolkits. Set by any | 22 // Adapter class with targets to render like different toolkits. Set by any |
21 // project that wants to do linux desktop native rendering. | 23 // project that wants to do linux desktop native rendering. |
22 // | 24 // |
23 // TODO(erg): We're hardcoding GTK2, when we'll need to have backends for (at | 25 // TODO(erg): We're hardcoding GTK2, when we'll need to have backends for (at |
24 // minimum) GTK2 and GTK3. LinuxUI::instance() should actually be a very | 26 // minimum) GTK2 and GTK3. LinuxUI::instance() should actually be a very |
25 // complex method that pokes around with dlopen against a libuigtk2.so, a | 27 // complex method that pokes around with dlopen against a libuigtk2.so, a |
26 // liuigtk3.so, etc. | 28 // liuigtk3.so, etc. |
27 class UI_EXPORT LinuxUI { | 29 class UI_EXPORT LinuxUI { |
28 public: | 30 public: |
29 virtual ~LinuxUI() {} | 31 virtual ~LinuxUI() {} |
30 | 32 |
31 // Sets the dynamically loaded singleton that draws the desktop native UI. | 33 // Sets the dynamically loaded singleton that draws the desktop native UI. |
32 static void SetInstance(LinuxUI* instance); | 34 static void SetInstance(LinuxUI* instance); |
33 | 35 |
34 // Returns a LinuxUI instance for the toolkit used in the user's desktop | 36 // Returns a LinuxUI instance for the toolkit used in the user's desktop |
35 // environment. | 37 // environment. |
36 // | 38 // |
37 // Can return NULL, in case no toolkit has been set. (For example, if we're | 39 // Can return NULL, in case no toolkit has been set. (For example, if we're |
38 // running with the "--ash" flag.) | 40 // running with the "--ash" flag.) |
39 static const LinuxUI* instance(); | 41 static const LinuxUI* instance(); |
40 | 42 |
41 // Returns an themed image per theme_provider.h | 43 // Returns an themed image per theme_provider.h |
42 virtual bool UseNativeTheme() const = 0; | 44 virtual bool UseNativeTheme() const = 0; |
43 virtual gfx::Image* GetThemeImageNamed(int id) const = 0; | 45 virtual gfx::Image* GetThemeImageNamed(int id) const = 0; |
44 virtual bool GetColor(int id, SkColor* color) const = 0; | 46 virtual bool GetColor(int id, SkColor* color) const = 0; |
| 47 |
| 48 // Returns a native file selection dialog. |
| 49 virtual SelectFileDialog* CreateSelectFileDialog( |
| 50 SelectFileDialog::Listener* listener, |
| 51 SelectFilePolicy* policy) const = 0; |
45 }; | 52 }; |
46 | 53 |
47 } // namespace ui | 54 } // namespace ui |
48 | 55 |
49 #endif // UI_BASE_LINUX_UI_H_ | 56 #endif // UI_BASE_LINUX_UI_H_ |
OLD | NEW |