sapling/lib/clib/buffer.h
Wez Furlong 31bcfbe58e hg: disable check-code tests for C code
Summary:
They're actively fighting against the clang-format config
and don't have an auto-fix.

Reviewed By: quark-zju

Differential Revision: D8283622

fbshipit-source-id: 2de45f50e6370a5ed14915c6ff23dc843ff14e8a
2018-06-05 19:21:43 -07:00

64 lines
1.7 KiB
C

// Copyright (c) 2004-present, Facebook, Inc.
// All Rights Reserved.
//
// This software may be used and distributed according to the terms of the
// GNU General Public License version 2 or any later version.
// buffer.c: declarations for a generic mechanism to expand a heap-allocated
// buffer. this is for internal use only.
// no-check-code
#ifndef FBHGEXT_CLIB_BUFFER_H
#define FBHGEXT_CLIB_BUFFER_H
#include <stdbool.h>
#include <stddef.h>
#include <stdlib.h>
static inline bool expand_to_fit(
void** buffer,
size_t num_slots_used,
size_t* num_slots_total,
size_t input_count,
size_t item_sz,
const float factor,
const size_t min_increment,
const size_t max_increment) {
size_t remaining = *num_slots_total - num_slots_used;
if (input_count > remaining) {
// need realloc
size_t new_slots_total = factor * ((float)*num_slots_total);
if (new_slots_total < min_increment + *num_slots_total) {
new_slots_total = min_increment + *num_slots_total;
}
if (new_slots_total > max_increment + *num_slots_total) {
new_slots_total = max_increment + *num_slots_total;
}
if (new_slots_total < input_count + *num_slots_total) {
new_slots_total = input_count + *num_slots_total;
}
void* newbuffer = realloc(*buffer, item_sz * new_slots_total);
if (newbuffer == NULL) {
return false;
}
*buffer = newbuffer;
*num_slots_total = new_slots_total;
}
return true;
}
extern bool buffer_append(
char** buffer,
size_t* buffer_idx,
size_t* buffer_sz,
char* input,
size_t input_sz,
const float factor,
const size_t min_increment,
const size_t max_increment);
#endif /* FBHGEXT_CLIB_BUFFER_H */