| Index: webrtc/base/file.h
|
| diff --git a/webrtc/base/file.h b/webrtc/base/file.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..3401c28abe5e96be580f3981e3e6730257716d46
|
| --- /dev/null
|
| +++ b/webrtc/base/file.h
|
| @@ -0,0 +1,67 @@
|
| +/*
|
| + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
|
| + *
|
| + * Use of this source code is governed by a BSD-style license
|
| + * that can be found in the LICENSE file in the root of the source
|
| + * tree. An additional intellectual property rights grant can be found
|
| + * in the file PATENTS. All contributing project authors may
|
| + * be found in the AUTHORS file in the root of the source tree.
|
| + */
|
| +
|
| +#ifndef WEBRTC_BASE_FILE_H_
|
| +#define WEBRTC_BASE_FILE_H_
|
| +
|
| +#include <stdint.h>
|
| +
|
| +#include <string>
|
| +
|
| +#include "webrtc/base/platform_file.h"
|
| +#include "webrtc/base/constructormagic.h"
|
| +
|
| +namespace rtc {
|
| +
|
| +// This class wraps the platform specific APIs for simple file interactions.
|
| +//
|
| +// The various read and write methods are best effort, i.e. if an underlying
|
| +// call does not manage to read/write all the data more calls will be performed,
|
| +// until an error is detected or all data is read/written.
|
| +class File {
|
| + public:
|
| + // Wraps the given PlatformFile. This class is then responsible for closing
|
| + // the file, which will be done in the destructor if Close is never called.
|
| + explicit File(PlatformFile);
|
| + ~File();
|
| +
|
| + File(File&& other);
|
| + File& operator=(File&& other);
|
| +
|
| + static File Open(const std::string& path);
|
| +
|
| + size_t Write(const uint8_t* data, size_t length);
|
| + size_t Read(uint8_t* buffer, size_t length);
|
| +
|
| + // The current position in the file after a call to these methods is platform
|
| + // dependent (MSVC gives position offset+length, most other
|
| + // compilers/platforms do not alter the position), i.e. do not depend on it,
|
| + // do a Seek before any subsequent Read/Write.
|
| + size_t WriteAt(const uint8_t* data, size_t length, size_t offset);
|
| + size_t ReadAt(uint8_t* buffer, size_t length, size_t offset);
|
| +
|
| + // Attempt to position the file at the given offset from the start.
|
| + // Returns true if successful, false otherwise.
|
| + bool Seek(size_t offset);
|
| +
|
| + // Attempt to close the file. Returns true if successful, false otherwise,
|
| + // most notably when the file is already closed.
|
| + bool Close();
|
| +
|
| + bool IsOpen();
|
| +
|
| + private:
|
| + PlatformFile file_;
|
| + RTC_DISALLOW_COPY_AND_ASSIGN(File);
|
| +};
|
| +
|
| +} // namespace rtc
|
| +
|
| +#endif // WEBRTC_BASE_FILE_H_
|
|
|