summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authordeanm@google.com <deanm@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-08 09:05:29 +0000
committerdeanm@google.com <deanm@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-08 09:05:29 +0000
commit88eb0a862e97af4ec2e7c6fe1b5d32652cb8a854 (patch)
treed34d730c0f353066cf120faa0348bf9042888b61
parent90e8d0661e7ad64e2d708ed9b20de5e4a093783d (diff)
downloadchromium_src-88eb0a862e97af4ec2e7c6fe1b5d32652cb8a854.zip
chromium_src-88eb0a862e97af4ec2e7c6fe1b5d32652cb8a854.tar.gz
chromium_src-88eb0a862e97af4ec2e7c6fe1b5d32652cb8a854.tar.bz2
Replace a custom memcpy(wchar_t*) with the new safer lcpy API. Pass MAX_PATH not MAX_PATH+1 to GetSaveFileName, and log failures better.
Review URL: http://codereview.chromium.org/1609 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@1834 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/common/win_util.cc18
1 files changed, 14 insertions, 4 deletions
diff --git a/chrome/common/win_util.cc b/chrome/common/win_util.cc
index 8bc7651..6342f5d 100644
--- a/chrome/common/win_util.cc
+++ b/chrome/common/win_util.cc
@@ -392,11 +392,15 @@ bool SaveFileAsWithFilter(HWND owner,
unsigned* index,
std::wstring* final_name) {
DCHECK(final_name);
-
- // Initially populated by the file component of 'suggested_name', this buffer
- // will be written into by Windows when the user is done with the dialog box.
std::wstring file_part = file_util::GetFilenameFromPath(suggested_name);
+ // The size of the in/out buffer in number of characters we pass to win32
+ // GetSaveFileName. From MSDN "The buffer must be large enough to store the
+ // path and file name string or strings, including the terminating NULL
+ // character. ... The buffer should be at least 256 characters long.".
+ // _IsValidPathComDlg does a copy expecting at most MAX_PATH, otherwise will
+ // result in an error of FNERR_INVALIDFILENAME. So we should only pass the
+ // API a buffer of at most MAX_PATH.
wchar_t file_name[MAX_PATH];
base::wcslcpy(file_name, file_part.c_str(), arraysize(file_name));
@@ -432,8 +436,14 @@ bool SaveFileAsWithFilter(HWND owner,
save_as.pvReserved = NULL;
save_as.dwReserved = 0;
- if (!GetSaveFileName(&save_as))
+ if (!GetSaveFileName(&save_as)) {
+ // Zero means the dialog was closed, otherwise we had an error.
+ DWORD error_code = CommDlgExtendedError();
+ if (error_code != 0) {
+ NOTREACHED() << "GetSaveFileName failed with code: " << error_code;
+ }
return false;
+ }
// Return the user's choice.
final_name->assign(save_as.lpstrFile);