Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(313)

Side by Side Diff: util/file/file_io_win.cc

Issue 811823003: Cross platform low level file IO wrappers (Closed) Base URL: https://chromium.googlesource.com/crashpad/crashpad@master
Patch Set: . Created 6 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Crashpad Authors. All rights reserved. 1 // Copyright 2014 The Crashpad Authors. All rights reserved.
2 // 2 //
3 // Licensed under the Apache License, Version 2.0 (the "License"); 3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License. 4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at 5 // You may obtain a copy of the License at
6 // 6 //
7 // http://www.apache.org/licenses/LICENSE-2.0 7 // http://www.apache.org/licenses/LICENSE-2.0
8 // 8 //
9 // Unless required by applicable law or agreed to in writing, software 9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS, 10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and 12 // See the License for the specific language governing permissions and
13 // limitations under the License. 13 // limitations under the License.
14 14
15 #ifndef CRASHPAD_UTIL_NUMERIC_IN_RANGE_CAST_H_ 15 #include "util/file/file_io.h"
16 #define CRASHPAD_UTIL_NUMERIC_IN_RANGE_CAST_H_
17 16
18 #include "base/logging.h" 17 #include "base/logging.h"
19 #include "base/numerics/safe_conversions.h" 18 #include "base/numerics/safe_conversions.h"
20 19
21 namespace crashpad { 20 namespace crashpad {
22 21
23 //! \brief Casts to a different type if it can be done without data loss, 22 // TODO(scottmg): Handle > DWORD sized writes if necessary.
24 //! logging a warning message and returing a default value otherwise. 23
25 //! 24 ssize_t ReadFile(FileHandle file, void* buffer, size_t size) {
26 //! \param[in] source The value to convert and return. 25 DWORD size_dword = base::checked_cast<DWORD>(size);
27 //! \param[in] default_value The default value to return, in the event that \a 26 DWORD total_read = 0;
28 //! source cannot be represented in the destination type. 27 char* buffer_c = reinterpret_cast<char*>(buffer);
29 //! 28 while (size_dword > 0) {
30 //! \return \a source if it can be represented in the destination type, 29 DWORD bytes_read;
31 //! otherwise \a default_value. 30 BOOL success = ::ReadFile(file, buffer_c, size_dword, &bytes_read, nullptr);
Mark Mentovai 2014/12/17 05:39:16 If EOF is supposed to be signaled by ReadFile() re
scottmg 2014/12/17 20:18:32 Yes, you're right. (I confirmed this, which I shou
32 template <typename Destination, typename Source> 31 if (!success && GetLastError() != ERROR_MORE_DATA)
33 Destination InRangeCast(Source source, Destination default_value) { 32 return -1;
34 if (base::IsValueInRangeForNumericType<Destination>(source)) { 33
35 return static_cast<Destination>(source); 34 buffer_c += bytes_read;
35 size_dword -= bytes_read;
36 total_read += bytes_read;
36 } 37 }
38 return total_read;
39 }
37 40
38 LOG(WARNING) << "value " << source << " out of range"; 41 ssize_t WriteFile(FileHandle file, const void* buffer, size_t size) {
39 return static_cast<Destination>(default_value); 42 // TODO(scottmg): This might need to handle the limit for pipes across a
43 // network in the future.
44 DWORD size_dword = base::checked_cast<DWORD>(size);
45 DWORD bytes_written;
46 BOOL rv = ::WriteFile(file, buffer, size_dword, &bytes_written, nullptr);
47 if (!rv)
48 return -1;
49 CHECK_EQ(bytes_written, size_dword);
50 return bytes_written;
51 }
52
53 bool LoggingCloseFile(FileHandle file) {
54 BOOL rv = CloseHandle(file);
55 PLOG_IF(ERROR, !rv) << "CloseHandle";
56 return rv;
40 } 57 }
41 58
42 } // namespace crashpad 59 } // namespace crashpad
43
44 #endif // CRASHPAD_UTIL_NUMERIC_IN_RANGE_CAST_H_
OLDNEW
« util/file/file_io.h ('K') | « util/file/file_io_posix.cc ('k') | util/file/file_writer.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698