2017-08-26 02:46:07 +03:00
|
|
|
// Copyright (c) 2004-present, Facebook, Inc.
|
|
|
|
// All Rights Reserved.
|
2016-04-01 10:46:28 +03:00
|
|
|
//
|
2017-08-26 02:46:07 +03:00
|
|
|
// This software may be used and distributed according to the terms of the
|
|
|
|
// GNU General Public License version 2 or any later version.
|
|
|
|
|
2016-04-01 10:46:28 +03:00
|
|
|
// buffer.c: declarations for a generic mechanism to expand a heap-allocated
|
|
|
|
// buffer. this is for internal use only.
|
2016-04-01 21:19:53 +03:00
|
|
|
// no-check-code
|
2016-04-01 10:46:28 +03:00
|
|
|
|
2017-08-26 02:46:07 +03:00
|
|
|
#ifndef FBHGEXT_CLIB_BUFFER_H
|
|
|
|
#define FBHGEXT_CLIB_BUFFER_H
|
2016-04-01 10:46:28 +03:00
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stddef.h>
|
2016-05-19 03:33:54 +03:00
|
|
|
#include <stdlib.h>
|
2016-04-01 10:46:28 +03:00
|
|
|
|
|
|
|
static inline bool expand_to_fit(
|
2018-06-06 05:20:17 +03:00
|
|
|
void** buffer,
|
|
|
|
size_t num_slots_used,
|
|
|
|
size_t* num_slots_total,
|
|
|
|
size_t input_count,
|
|
|
|
size_t item_sz,
|
2016-04-01 10:46:28 +03:00
|
|
|
const float factor,
|
|
|
|
const size_t min_increment,
|
|
|
|
const size_t max_increment) {
|
2016-08-27 03:14:52 +03:00
|
|
|
size_t remaining = *num_slots_total - num_slots_used;
|
|
|
|
if (input_count > remaining) {
|
2016-04-01 10:46:28 +03:00
|
|
|
// need realloc
|
2018-06-06 05:20:17 +03:00
|
|
|
size_t new_slots_total = factor * ((float)*num_slots_total);
|
2016-08-27 03:14:52 +03:00
|
|
|
if (new_slots_total < min_increment + *num_slots_total) {
|
|
|
|
new_slots_total = min_increment + *num_slots_total;
|
2016-04-01 10:46:28 +03:00
|
|
|
}
|
2016-08-27 03:14:52 +03:00
|
|
|
if (new_slots_total > max_increment + *num_slots_total) {
|
|
|
|
new_slots_total = max_increment + *num_slots_total;
|
2016-04-01 10:46:28 +03:00
|
|
|
}
|
2016-08-27 03:14:52 +03:00
|
|
|
if (new_slots_total < input_count + *num_slots_total) {
|
|
|
|
new_slots_total = input_count + *num_slots_total;
|
2016-04-01 10:46:28 +03:00
|
|
|
}
|
|
|
|
|
2018-06-06 05:20:17 +03:00
|
|
|
void* newbuffer = realloc(*buffer, item_sz * new_slots_total);
|
2016-04-01 10:46:28 +03:00
|
|
|
if (newbuffer == NULL) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
*buffer = newbuffer;
|
2016-08-27 03:14:52 +03:00
|
|
|
*num_slots_total = new_slots_total;
|
2016-04-01 10:46:28 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
extern bool buffer_append(
|
2018-06-06 05:20:17 +03:00
|
|
|
char** buffer,
|
|
|
|
size_t* buffer_idx,
|
|
|
|
size_t* buffer_sz,
|
|
|
|
char* input,
|
|
|
|
size_t input_sz,
|
2016-04-01 10:46:28 +03:00
|
|
|
const float factor,
|
|
|
|
const size_t min_increment,
|
|
|
|
const size_t max_increment);
|
|
|
|
|
2017-08-26 02:46:07 +03:00
|
|
|
#endif /* FBHGEXT_CLIB_BUFFER_H */
|