mirror of
https://github.com/git/git.git
synced 2024-11-23 18:05:29 +08:00
5575c713c2
The reftable library is now prepared to expect that the memory allocation function given to it may fail to allocate and to deal with such an error. * ps/reftable-alloc-failures: (26 commits) reftable/basics: fix segfault when growing `names` array fails reftable/basics: ban standard allocator functions reftable: introduce `REFTABLE_FREE_AND_NULL()` reftable: fix calls to free(3P) reftable: handle trivial allocation failures reftable/tree: handle allocation failures reftable/pq: handle allocation failures when adding entries reftable/block: handle allocation failures reftable/blocksource: handle allocation failures reftable/iter: handle allocation failures when creating indexed table iter reftable/stack: handle allocation failures in auto compaction reftable/stack: handle allocation failures in `stack_compact_range()` reftable/stack: handle allocation failures in `reftable_new_stack()` reftable/stack: handle allocation failures on reload reftable/reader: handle allocation failures in `reader_init_iter()` reftable/reader: handle allocation failures for unindexed reader reftable/merged: handle allocation failures in `merged_table_init_iter()` reftable/writer: handle allocation failures in `reftable_new_writer()` reftable/writer: handle allocation failures in `writer_index_hash()` reftable/record: handle allocation failures when decoding records ...
68 lines
1.7 KiB
C
68 lines
1.7 KiB
C
/*
|
|
Copyright 2020 Google LLC
|
|
|
|
Use of this source code is governed by a BSD-style
|
|
license that can be found in the LICENSE file or at
|
|
https://developers.google.com/open-source/licenses/bsd
|
|
*/
|
|
|
|
#ifndef READER_H
|
|
#define READER_H
|
|
|
|
#include "block.h"
|
|
#include "record.h"
|
|
#include "reftable-iterator.h"
|
|
#include "reftable-reader.h"
|
|
|
|
uint64_t block_source_size(struct reftable_block_source *source);
|
|
|
|
int block_source_read_block(struct reftable_block_source *source,
|
|
struct reftable_block *dest, uint64_t off,
|
|
uint32_t size);
|
|
void block_source_close(struct reftable_block_source *source);
|
|
|
|
/* metadata for a block type */
|
|
struct reftable_reader_offsets {
|
|
int is_present;
|
|
uint64_t offset;
|
|
uint64_t index_offset;
|
|
};
|
|
|
|
/* The state for reading a reftable file. */
|
|
struct reftable_reader {
|
|
/* for convenience, associate a name with the instance. */
|
|
char *name;
|
|
struct reftable_block_source source;
|
|
|
|
/* Size of the file, excluding the footer. */
|
|
uint64_t size;
|
|
|
|
/* 'sha1' for SHA1, 's256' for SHA-256 */
|
|
uint32_t hash_id;
|
|
|
|
uint32_t block_size;
|
|
uint64_t min_update_index;
|
|
uint64_t max_update_index;
|
|
/* Length of the OID keys in the 'o' section */
|
|
int object_id_len;
|
|
int version;
|
|
|
|
struct reftable_reader_offsets ref_offsets;
|
|
struct reftable_reader_offsets obj_offsets;
|
|
struct reftable_reader_offsets log_offsets;
|
|
|
|
uint64_t refcount;
|
|
};
|
|
|
|
const char *reader_name(struct reftable_reader *r);
|
|
|
|
int reader_init_iter(struct reftable_reader *r,
|
|
struct reftable_iterator *it,
|
|
uint8_t typ);
|
|
|
|
/* initialize a block reader to read from `r` */
|
|
int reader_init_block_reader(struct reftable_reader *r, struct block_reader *br,
|
|
uint64_t next_off, uint8_t want_typ);
|
|
|
|
#endif
|