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

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

Issue 936153002: Add FileReaderInterface. Move StringFileWriter to StringFile and (Closed) Base URL: https://chromium.googlesource.com/crashpad/crashpad@master
Patch Set: Created 5 years, 10 months 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
(Empty)
1 // Copyright 2014 The Crashpad Authors. All rights reserved.
2 //
3 // Licensed under the Apache License, Version 2.0 (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
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14
15 #include "util/file/file_reader.h"
16
17 #include "base/logging.h"
18
19 namespace crashpad {
20
21 WeakFileHandleFileReader::WeakFileHandleFileReader(FileHandle file_handle)
22 : file_handle_(file_handle) {
23 }
24
25 WeakFileHandleFileReader::~WeakFileHandleFileReader() {
26 }
27
28 ssize_t WeakFileHandleFileReader::Read(void* data, size_t size) {
29 DCHECK_NE(file_handle_, kInvalidFileHandle);
30
31 // TODO(mark): Read no more than SSIZE_MAX bytes in a single call.
Robert Sesek 2015/02/18 18:44:28 In LoggingReadFile, you just use a checked_cast fo
32 ssize_t nread = ReadFile(file_handle_, data, size);
33 if (nread < 0) {
34 PLOG(ERROR) << "read";
35 return -1;
36 }
37
38 return nread;
39 }
40
41 FileOffset WeakFileHandleFileReader::Seek(FileOffset offset, int whence) {
42 DCHECK_NE(file_handle_, kInvalidFileHandle);
43 return LoggingSeekFile(file_handle_, offset, whence);
44 }
45
46 FileReader::FileReader()
47 : file_(),
48 weak_file_handle_file_reader_(kInvalidFileHandle) {
49 }
50
51 FileReader::~FileReader() {
52 }
53
54 bool FileReader::Open(const base::FilePath& path,
55 FileWriteMode write_mode,
56 FilePermissions permissions) {
57 CHECK(!file_.is_valid());
58 file_.reset(LoggingOpenFileForRead(path));
59 if (!file_.is_valid()) {
60 return false;
61 }
62
63 weak_file_handle_file_reader_.set_file_handle(file_.get());
64 return true;
65 }
66
67 void FileReader::Close() {
68 CHECK(file_.is_valid());
69
70 weak_file_handle_file_reader_.set_file_handle(kInvalidFileHandle);
71 file_.reset();
72 }
73
74 ssize_t FileReader::Read(void* data, size_t size) {
75 DCHECK(file_.is_valid());
76 return weak_file_handle_file_reader_.Read(data, size);
77 }
78
79 FileOffset FileReader::Seek(FileOffset offset, int whence) {
80 DCHECK(file_.is_valid());
81 return weak_file_handle_file_reader_.Seek(offset, whence);
82 }
83
84 } // namespace crashpad
OLDNEW
« util/file/file_reader.h ('K') | « util/file/file_reader.h ('k') | util/file/file_writer.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698