You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
67 lines
2.2 KiB
67 lines
2.2 KiB
4 months ago
|
// Copyright 2017 The Chromium OS Authors. All rights reserved.
|
||
|
// Use of this source code is governed by a BSD-style license that can be
|
||
|
// found in the LICENSE file.
|
||
|
|
||
|
#ifndef _BSDIFF_PATCH_READER_H_
|
||
|
#define _BSDIFF_PATCH_READER_H_
|
||
|
|
||
|
#include <stddef.h>
|
||
|
#include <stdint.h>
|
||
|
|
||
|
#include <memory>
|
||
|
|
||
|
#include "bsdiff/control_entry.h"
|
||
|
#include "bsdiff/decompressor_interface.h"
|
||
|
#include "bsdiff/file_interface.h"
|
||
|
|
||
|
namespace bsdiff {
|
||
|
|
||
|
// A wrapper class to read and parse the data in a bsdiff patch. The reader
|
||
|
// class contains the concatenated streams of control, diff, and extra data.
|
||
|
// After initialization, this class provides the function to read the metadata
|
||
|
// embedded in the control stream sequentially and decompresses the diff & extra
|
||
|
// stream based on this metadata.
|
||
|
|
||
|
class BsdiffPatchReader {
|
||
|
public:
|
||
|
BsdiffPatchReader() = default;
|
||
|
|
||
|
// Initialize the control stream, diff stream and extra stream from the
|
||
|
// corresponding offset of |patch_data|.
|
||
|
bool Init(const uint8_t* patch_data, size_t patch_size);
|
||
|
|
||
|
// Read the control stream and parse the metadata of |diff_size_|,
|
||
|
// |extra_size_| and |offset_incremental_|.
|
||
|
bool ParseControlEntry(ControlEntry* control_entry);
|
||
|
|
||
|
// Read the data in |diff_stream_| and write |size| decompressed data to
|
||
|
// |buf|.
|
||
|
bool ReadDiffStream(uint8_t* buf, size_t size);
|
||
|
|
||
|
// Read the data in |extra_stream_| and write |size| decompressed data to
|
||
|
// |buf|.
|
||
|
bool ReadExtraStream(uint8_t* buf, size_t size);
|
||
|
|
||
|
uint64_t new_file_size() const { return new_file_size_; }
|
||
|
|
||
|
// Close the control/diff/extra stream. Return false if errors occur when
|
||
|
// closing any of these streams.
|
||
|
bool Finish();
|
||
|
|
||
|
private:
|
||
|
// The compressed stream that contains the control data; i.e. length of each
|
||
|
// diff/extra block and the corresponding offset to read in the source file.
|
||
|
std::unique_ptr<DecompressorInterface> ctrl_stream_{nullptr};
|
||
|
// The compressed stream that contains the concatenated diff blocks.
|
||
|
std::unique_ptr<DecompressorInterface> diff_stream_{nullptr};
|
||
|
// The compressed stream that contains the concatenated extra blocks.
|
||
|
std::unique_ptr<DecompressorInterface> extra_stream_{nullptr};
|
||
|
|
||
|
// Size of the target file.
|
||
|
uint64_t new_file_size_;
|
||
|
};
|
||
|
|
||
|
} // namespace bsdiff
|
||
|
|
||
|
#endif // _BSDIFF_PATCH_READER_H_
|