Add .clang-format
This commit is contained in:
parent
143100fe82
commit
72df66b2b0
6
.clang-format
Normal file
6
.clang-format
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
BasedOnStyle: LLVM
|
||||
IndentWidth: 4
|
||||
BreakBeforeBraces: Allman
|
||||
IncludeBlocks: Regroup
|
||||
ColumnLimit: 80
|
58
main.c
58
main.c
@ -16,14 +16,16 @@
|
||||
_a < _b ? _a : _b; \
|
||||
})
|
||||
|
||||
typedef struct {
|
||||
typedef struct
|
||||
{
|
||||
void *elem_storage;
|
||||
size_t elem_count;
|
||||
size_t elem_size;
|
||||
size_t elem_count_cap;
|
||||
} cvec;
|
||||
|
||||
int cvec_new(cvec *dest, size_t elem_size) {
|
||||
int cvec_new(cvec *dest, size_t elem_size)
|
||||
{
|
||||
size_t init_count_cap = 1;
|
||||
cvec result = {
|
||||
.elem_storage = malloc(init_count_cap * elem_size),
|
||||
@ -39,7 +41,8 @@ int cvec_new(cvec *dest, size_t elem_size) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
int cvec_extend(cvec *dest) {
|
||||
int cvec_extend(cvec *dest)
|
||||
{
|
||||
dest->elem_count_cap *= 2;
|
||||
dest->elem_storage =
|
||||
realloc(dest->elem_storage, dest->elem_count_cap * dest->elem_size);
|
||||
@ -49,8 +52,10 @@ int cvec_extend(cvec *dest) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
int cvec_append(cvec *dest, void *elem) {
|
||||
if (dest->elem_count == dest->elem_count_cap) {
|
||||
int cvec_append(cvec *dest, void *elem)
|
||||
{
|
||||
if (dest->elem_count == dest->elem_count_cap)
|
||||
{
|
||||
if (cvec_extend(dest))
|
||||
return -1;
|
||||
}
|
||||
@ -63,7 +68,8 @@ int cvec_append(cvec *dest, void *elem) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
int cvec_shrink(cvec *dest) {
|
||||
int cvec_shrink(cvec *dest)
|
||||
{
|
||||
dest->elem_count_cap /= 2;
|
||||
dest->elem_storage =
|
||||
realloc(dest->elem_storage, dest->elem_count_cap * dest->elem_size);
|
||||
@ -73,10 +79,12 @@ int cvec_shrink(cvec *dest) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
int cvec_pop(cvec *dest) {
|
||||
int cvec_pop(cvec *dest)
|
||||
{
|
||||
dest->elem_count--;
|
||||
|
||||
if (dest->elem_count < dest->elem_count_cap / 2) {
|
||||
if (dest->elem_count < dest->elem_count_cap / 2)
|
||||
{
|
||||
if (cvec_shrink(dest))
|
||||
return -1;
|
||||
}
|
||||
@ -85,20 +93,23 @@ int cvec_pop(cvec *dest) {
|
||||
}
|
||||
|
||||
void cvec_free(cvec vec);
|
||||
int cvec_erase(cvec *dest) {
|
||||
int cvec_erase(cvec *dest)
|
||||
{
|
||||
size_t elem_size = dest->elem_size;
|
||||
cvec_free(*dest);
|
||||
return cvec_new(dest, elem_size);
|
||||
}
|
||||
|
||||
typedef enum {
|
||||
typedef enum
|
||||
{
|
||||
CVEC_PRINT_FLAG_NONE = 0,
|
||||
CVEC_PRINT_FLAG_ELLIPSIS = 1,
|
||||
CVEC_PRINT_FLAG_MULTILINE = 2,
|
||||
} cvec_print_flag;
|
||||
|
||||
typedef void (*cvec_print_func)(void *elem);
|
||||
void cvec_print(cvec vec, cvec_print_func print_func, cvec_print_flag flags) {
|
||||
void cvec_print(cvec vec, cvec_print_func print_func, cvec_print_flag flags)
|
||||
{
|
||||
size_t print_left = min(vec.elem_count, 3);
|
||||
size_t print_center = max((long int)vec.elem_count - 6, 0);
|
||||
size_t print_right = min(max((long int)vec.elem_count - 3, 0), 3);
|
||||
@ -110,21 +121,26 @@ void cvec_print(cvec vec, cvec_print_func print_func, cvec_print_flag flags) {
|
||||
if (flags & CVEC_PRINT_FLAG_MULTILINE)
|
||||
printf("\n");
|
||||
|
||||
for (size_t i = 0; i < print_left; i++) {
|
||||
for (size_t i = 0; i < print_left; i++)
|
||||
{
|
||||
print_func(vec.elem_storage + elems_printed * vec.elem_size);
|
||||
printf("%c ", sep);
|
||||
elems_printed++;
|
||||
}
|
||||
|
||||
if (flags & CVEC_PRINT_FLAG_ELLIPSIS) {
|
||||
if (flags & CVEC_PRINT_FLAG_ELLIPSIS)
|
||||
{
|
||||
printf("... %lu elements in between ... ", print_center);
|
||||
|
||||
if (flags & CVEC_PRINT_FLAG_MULTILINE)
|
||||
printf("\n");
|
||||
|
||||
elems_printed += print_center;
|
||||
} else {
|
||||
for (size_t i = 0; i < print_center; i++) {
|
||||
}
|
||||
else
|
||||
{
|
||||
for (size_t i = 0; i < print_center; i++)
|
||||
{
|
||||
print_func(vec.elem_storage + elems_printed * vec.elem_size);
|
||||
|
||||
if (elems_printed != vec.elem_count - 1)
|
||||
@ -134,7 +150,8 @@ void cvec_print(cvec vec, cvec_print_func print_func, cvec_print_flag flags) {
|
||||
}
|
||||
}
|
||||
|
||||
for (size_t i = 0; i < print_right; i++) {
|
||||
for (size_t i = 0; i < print_right; i++)
|
||||
{
|
||||
print_func(vec.elem_storage + elems_printed * vec.elem_size);
|
||||
|
||||
if (elems_printed != vec.elem_count - 1)
|
||||
@ -152,7 +169,8 @@ void cvec_print(cvec vec, cvec_print_func print_func, cvec_print_flag flags) {
|
||||
void cvec_free(cvec vec) { free(vec.elem_storage); }
|
||||
|
||||
#define CVEC_PRIMITIVE_PRINT_FUNC(type, type_name, format_flag) \
|
||||
void cvec_##type_name##_print_func(void *elem) { \
|
||||
void cvec_##type_name##_print_func(void *elem) \
|
||||
{ \
|
||||
type _elem = *(type *)elem; \
|
||||
printf(format_flag, _elem); \
|
||||
}
|
||||
@ -168,7 +186,8 @@ CVEC_PRIMITIVE_PRINT_FUNC(double, double, "%f")
|
||||
cvec_append(dest, &_elem); \
|
||||
})
|
||||
|
||||
int main() {
|
||||
int main()
|
||||
{
|
||||
int ret = 0;
|
||||
cvec vec = {0};
|
||||
cvec uint_vec = {0};
|
||||
@ -199,7 +218,8 @@ int main() {
|
||||
|
||||
cvec_print(vec, cvec_int_print_func, CVEC_PRINT_FLAG_NONE);
|
||||
|
||||
for (int i = 0; i < 100; i++) {
|
||||
for (int i = 0; i < 100; i++)
|
||||
{
|
||||
ret = cvec_append(&vec, &(int){5 + i});
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
|
Loading…
x
Reference in New Issue
Block a user