Disable TabDragController tests that fail with a real compositor.
[chromium-blink-merge.git] / chrome / browser / ui / libgtk2ui / select_file_dialog_impl.h
blob5429fdbf0de8265e3422f2d5eb483631b03d782c
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
3 // found in the LICENSE file.
4 //
5 // This file implements common select dialog functionality between GTK and KDE.
7 #ifndef CHROME_BROWSER_UI_LIBGTK2UI_SELECT_FILE_DIALOG_IMPL_H_
8 #define CHROME_BROWSER_UI_LIBGTK2UI_SELECT_FILE_DIALOG_IMPL_H_
10 #include <set>
12 #include "base/compiler_specific.h"
13 #include "base/nix/xdg_util.h"
14 #include "ui/aura/window.h"
15 #include "ui/shell_dialogs/select_file_dialog.h"
16 #include "ui/shell_dialogs/select_file_policy.h"
18 namespace libgtk2ui {
20 // Shared implementation SelectFileDialog used by SelectFileDialogImplGTK
21 class SelectFileDialogImpl : public ui::SelectFileDialog {
22 public:
23 // Main factory method which returns correct type.
24 static ui::SelectFileDialog* Create(Listener* listener,
25 ui::SelectFilePolicy* policy);
27 // Factory method for creating a GTK-styled SelectFileDialogImpl
28 static SelectFileDialogImpl* NewSelectFileDialogImplGTK(
29 Listener* listener,
30 ui::SelectFilePolicy* policy);
31 // Factory method for creating a KDE-styled SelectFileDialogImpl
32 static SelectFileDialogImpl* NewSelectFileDialogImplKDE(
33 Listener* listener,
34 ui::SelectFilePolicy* policy,
35 base::nix::DesktopEnvironment desktop);
37 // Returns true if the SelectFileDialog class returned by
38 // NewSelectFileDialogImplKDE will actually work.
39 static bool CheckKDEDialogWorksOnUIThread();
41 // BaseShellDialog implementation.
42 virtual bool IsRunning(gfx::NativeWindow parent_window) const OVERRIDE;
43 virtual void ListenerDestroyed() OVERRIDE;
45 protected:
46 explicit SelectFileDialogImpl(Listener* listener,
47 ui::SelectFilePolicy* policy);
48 virtual ~SelectFileDialogImpl();
50 // SelectFileDialog implementation.
51 // |params| is user data we pass back via the Listener interface.
52 virtual void SelectFileImpl(
53 Type type,
54 const base::string16& title,
55 const base::FilePath& default_path,
56 const FileTypeInfo* file_types,
57 int file_type_index,
58 const base::FilePath::StringType& default_extension,
59 gfx::NativeWindow owning_window,
60 void* params) = 0;
62 // Wrapper for base::DirectoryExists() that allow access on the UI
63 // thread. Use this only in the file dialog functions, where it's ok
64 // because the file dialog has to do many stats anyway. One more won't
65 // hurt too badly and it's likely already cached.
66 bool CallDirectoryExistsOnUIThread(const base::FilePath& path);
68 // The file filters.
69 FileTypeInfo file_types_;
71 // The index of the default selected file filter.
72 // Note: This starts from 1, not 0.
73 size_t file_type_index_;
75 // The set of all parent windows for which we are currently running dialogs.
76 std::set<aura::Window*> parents_;
78 // The type of dialog we are showing the user.
79 Type type_;
81 // These two variables track where the user last saved a file or opened a
82 // file so that we can display future dialogs with the same starting path.
83 static base::FilePath* last_saved_path_;
84 static base::FilePath* last_opened_path_;
86 DISALLOW_COPY_AND_ASSIGN(SelectFileDialogImpl);
89 } // namespace libgtk2ui
91 #endif // CHROME_BROWSER_UI_LIBGTK2UI_SELECT_FILE_DIALOG_IMPL_H_