Chromium Code Reviews| Index: ui/base/win/open_file_name_win.h |
| diff --git a/ui/base/win/open_file_name_win.h b/ui/base/win/open_file_name_win.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..8392efc32bc167cf1fa4a06a738db4b47e7048fb |
| --- /dev/null |
| +++ b/ui/base/win/open_file_name_win.h |
| @@ -0,0 +1,60 @@ |
| +// Copyright (c) 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef UI_BASE_WIN_OPEN_FILE_NAME_WIN_H_ |
| +#define UI_BASE_WIN_OPEN_FILE_NAME_WIN_H_ |
| + |
| +#include <Windows.h> |
| +#include <Commdlg.h> |
| + |
| +#include <vector> |
| + |
| +#include "base/macros.h" |
| +#include "base/strings/string16.h" |
| +#include "base/tuple.h" |
| + |
| +namespace base { |
| +class FilePath; |
| +} // namespace base |
| + |
| +namespace ui { |
| +namespace win { |
| + |
| +// Encapsulates an OPENFILENAME struct and related buffers. Also provides static |
| +// methods for interpreting the properties of an OPENFILENAME. |
| +class OpenFileName { |
| + public: |
| + // Initializes the OPENFILENAME, which may be accessed using Get(). All fields |
| + // will be NULL except for |lStructSize|, |lpstrFile|, and |nMaxFile|. The |
| + // file buffer will initially contain a null-terminated empty string. |
| + OpenFileName(HWND parent_window, DWORD flags); |
| + ~OpenFileName(); |
| + |
| + // Sets |lpstrInitialDir| and |lpstrFile|. |
| + void SetInitialSelection(const base::FilePath& initial_directory, |
| + const base::FilePath& initial_filename); |
| + |
| + // Returns the single selected file, or an empty path if there are more or |
| + // less than one results. |
| + base::FilePath GetSingleResult(); |
| + |
| + // Returns the selected file or files. |
| + void GetResult(base::FilePath* directory, |
|
sky
2014/07/31 16:27:31
const FilePath&? Also, is there a reason you separ
erikwright (departed)
2014/07/31 16:39:29
Both parameters are out-parameters, unless this is
|
| + std::vector<base::FilePath>* filenames); |
| + |
| + // Returns the OPENFILENAME structure. |
| + OPENFILENAME* Get(); |
|
sky
2014/07/31 16:27:31
nit: inline this and name it name it to match fiel
erikwright (departed)
2014/08/01 13:26:09
Renamed to GetOPENFILENAME(). Which seems a little
|
| + |
| + private: |
| + OPENFILENAME openfilename_; |
| + base::string16 initial_directory_buffer_; |
| + wchar_t filename_buffer_[UNICODE_STRING_MAX_CHARS]; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(OpenFileName); |
| +}; |
| + |
| +} // namespace win |
| +} // namespace ui |
| + |
| +#endif // UI_BASE_WIN_OPEN_FILE_NAME_WIN_H_ |