diff options
| author | deanm@google.com <deanm@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-09-08 09:05:29 +0000 | 
|---|---|---|
| committer | deanm@google.com <deanm@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-09-08 09:05:29 +0000 | 
| commit | 88eb0a862e97af4ec2e7c6fe1b5d32652cb8a854 (patch) | |
| tree | d34d730c0f353066cf120faa0348bf9042888b61 /chrome | |
| parent | 90e8d0661e7ad64e2d708ed9b20de5e4a093783d (diff) | |
| download | chromium_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
Diffstat (limited to 'chrome')
| -rw-r--r-- | chrome/common/win_util.cc | 18 | 
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); | 
