summaryrefslogtreecommitdiffstats
path: root/chrome/app/hard_error_handler_win.cc
diff options
context:
space:
mode:
authorgregoryd@google.com <gregoryd@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-11-10 21:58:07 +0000
committergregoryd@google.com <gregoryd@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-11-10 21:58:07 +0000
commit50c7eb8a256dfbff20f5434f78a3f4f537c4239b (patch)
tree7885d55af005204b543f89c911c3e54a9ecf1e70 /chrome/app/hard_error_handler_win.cc
parentc08494af57caf5666d7f721ddf5f0b96d68cb460 (diff)
downloadchromium_src-50c7eb8a256dfbff20f5434f78a3f4f537c4239b.zip
chromium_src-50c7eb8a256dfbff20f5434f78a3f4f537c4239b.tar.gz
chromium_src-50c7eb8a256dfbff20f5434f78a3f4f537c4239b.tar.bz2
Add 64 bit support + code cleanup
TEST=none BUG=none Review URL: http://codereview.chromium.org/374022 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@31604 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/app/hard_error_handler_win.cc')
-rw-r--r--chrome/app/hard_error_handler_win.cc12
1 files changed, 9 insertions, 3 deletions
diff --git a/chrome/app/hard_error_handler_win.cc b/chrome/app/hard_error_handler_win.cc
index 77a8f81..26c64ff 100644
--- a/chrome/app/hard_error_handler_win.cc
+++ b/chrome/app/hard_error_handler_win.cc
@@ -9,6 +9,7 @@
#include <string>
#include "base/basictypes.h"
+#include "base/logging.h"
#include "base/string_piece.h"
#include "base/sys_string_conversions.h"
@@ -26,9 +27,14 @@ bool MakeNTUnicodeString(const std::wstring& str,
UNICODE_STRING* nt_string) {
if (str.empty())
return false;
- uint32 str_size_bytes = str.size() * sizeof(wchar_t);
- nt_string->Length = str_size_bytes;
- nt_string->MaximumLength = str_size_bytes;
+ size_t str_size_bytes = str.size() * sizeof(wchar_t);
+ if (kuint16max < str_size_bytes) {
+ // The string is too long - nt_string->Length is USHORT
+ NOTREACHED() << "The string is too long";
+ return false;
+ }
+ nt_string->Length = static_cast<USHORT>(str_size_bytes);
+ nt_string->MaximumLength = static_cast<USHORT>(str_size_bytes);
nt_string->Buffer = const_cast<wchar_t*>(str.c_str());
return true;
}