8#ifndef ELLIPSIS_CARRAY_H
9#define ELLIPSIS_CARRAY_H 1
32 for (
size_t __LOC_ID_1_1 = 0; __LOC_ID_1_1 < __LOC_ID_0_1; ++__LOC_ID_1_1) {
33 free((
void*)__LOC_ID_0_2[__LOC_ID_1_1]);
35 memset((
void*)__LOC_ID_0_2, 0, __LOC_ID_0_1*
sizeof(__LOC_ID_0_2[0]));
43 register int __LOC_ID_1_2;
44 if (__LOC_ID_0_3[0]) {
45 if (__LOC_ID_0_4[0]) {
46 __LOC_ID_1_2 = strcmp(__LOC_ID_0_3[0], __LOC_ID_0_4[0]);
51 if (__LOC_ID_0_4[0]) {
75#define STRINGIFY(...) STRINGIFY_(__VA_ARGS__)
76#define STRINGIFY_(...) #__VA_ARGS__
78#define ELLIPSIS_CONTRACT_VIOLATION(COUNT, VERB, CTYPE, CSTR, ...) \
80 static char const contract_format_ ## COUNT[] = \
81 __FILE__ ":" STRINGIFY(__LINE__) ": violation of " CTYPE " `" CSTR "`" __VA_OPT__(", ") __VA_ARGS__ "\n";\
83 ? fputs(contract_format_ ## COUNT, stderr) \
87#define ELLIPSIS_CONTRACT_IMPL(COUNT, COND, ACTION, VERB, CSTR, CTYPE, ...) \
90 : (ELLIPSIS_CONTRACT_VIOLATION(COUNT, VERB, CTYPE, CSTR __VA_OPT__(,) __VA_ARGS__) \
95#define ELLIPSIS_TO_VOIDS(...) ((void*)((uintptr_t)((__VA_ARGS__)-(__VA_ARGS__))))
97#define ELLIPSIS_TEST_ICE(...) (false ? ELLIPSIS_TO_VOIDS(__VA_ARGS__) : (ellipsis‿contracts‿is_ice*)nullptr)
99#define ELLIPSIS_CONTRACT_ICE_OR_TRUE(...) \
101 ELLIPSIS_TEST_ICE(__VA_ARGS__), \
102 ellipsis‿contracts‿is_ice*: (__VA_ARGS__), \
105#define ELLIPSIS_CONTRACT_CHECK_STATIC(CTYPE, COND, CSTR, ...) \
107 static_assert(ELLIPSIS_CONTRACT_ICE_OR_TRUE(COND), \
108 "compile time violation of " CTYPE " " CSTR \
109 __VA_OPT__(", ") __VA_ARGS__ );\
112#define ELLIPSIS_CONTRACT(COUNT, COND, ACTION, VERB, CSTR, CTYPE, ...) \
116 ELLIPSIS_TEST_ICE(COND), \
117 ellipsis‿contracts‿is_ice*: ELLIPSIS_CONTRACT_CHECK_STATIC(CTYPE, COND, CSTR __VA_OPT__(,) __VA_ARGS__), \
118 default: ELLIPSIS_CONTRACT_IMPL(COUNT, COND, ACTION, VERB, CSTR, CTYPE __VA_OPT__(,) __VA_ARGS__));\
183#ifndef DOXYGEN_SPECIAL
197 [[deprecated(
"use const member length instead")]]
199#ifndef DOXYGEN_SPECIAL
219#define ELLIPSIS_CARRAY_OVERLAY(N) \
222 size_t const length;\
223 size_t const padding;\
224 unsigned const :(offsetof(ellipsis‿carray, array)-2*sizeof(size_t));\
225 ellipsis‿carray‿base array[N];\
230#define ELLIPSIS_CARRAY_STATIC(N, ...) \
232 static const ELLIPSIS_CARRAY_OVERLAY( \
233 sizeof((ellipsis‿carray‿base[]){__VA_ARGS__ }) \
234 /sizeof(ellipsis‿carray‿base)) \
237 .array = {__VA_ARGS__ }, \
238 };&__LOC_ID_1_3;})->fa)
260#if __clang__ && (__clang_major__ < 30)
261#define ELLIPSIS_CARRAY_LITERAL_LOCAL(N, ...) ELLIPSIS_CARRAY_STATIC(N, __VA_ARGS__)
263#define ELLIPSIS_CARRAY_LITERAL_LOCAL(N, ...) \
264 ((static const ELLIPSIS_CARRAY_OVERLAY( \
265 sizeof((ellipsis‿carray‿base[]){__VA_ARGS__ }) \
266 /sizeof(ellipsis‿carray‿base))) \
269 .array = {__VA_ARGS__ }, \
273#define ELLIPSIS_CARRAY_LITERAL_GLOBAL(N, ...) \
274 ((const ELLIPSIS_CARRAY_OVERLAY( \
275 sizeof((ellipsis‿carray‿base[]){__VA_ARGS__ }) \
276 /sizeof(ellipsis‿carray‿base))) \
279 .array = {__VA_ARGS__ }, \
282#define ELLIPSIS_CARRAY_LITERAL ELLIPSIS_CARRAY_LITERAL_LOCAL
310 *__LOC_ID_0_5= *__LOC_ID_0_6;
311 *__LOC_ID_0_6=
nullptr;
313 *__LOC_ID_0_5=
nullptr;
330 *__LOC_ID_0_7= *__LOC_ID_0_8;
331 *__LOC_ID_0_8=
nullptr;
333 *__LOC_ID_0_7=
nullptr;
349 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
352 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
353 [[__maybe_unused__]]
register bool defer_return_flag =
false;
356 goto DEFER_END_ID_1_2;
360 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
361 unsigned (*DEFER_LOC_ID_1_1)[DEFER_LOC_ID_0_2] = {};
364 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
365 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
366 {
ELLIPSIS_CONTRACT(1, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), unreachable,
false,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assumption",
"out of memory when growing an FA array");}
374 defer_return_flag =
true;
381[[__maybe_unused__]] DEFER_END_ID_1_2:;
382 return DEFER_LOC_ID_0_1;
404 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
407 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
408 [[__maybe_unused__]]
register bool defer_return_flag =
false;
411 goto DEFER_END_ID_1_4;
415 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
416 unsigned (*DEFER_LOC_ID_1_2)[DEFER_LOC_ID_0_2] = {};
419 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
420 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
421 {
ELLIPSIS_CONTRACT(2, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), unreachable,
false,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assumption",
"out of memory when creating a one element FA array");}
426 do {
ELLIPSIS_CONTRACT(3, !s || (s->length < s->capacity) || (s->capacity < SIZE_MAX), abort,
true,
"¬s ∨ (s→length < s→capacity) ∨ (s→capacity < SIZE_MAX)",
"assertion",
"FA array is a its limits");}
while (
false);
430 defer_return_flag =
true;
437[[__maybe_unused__]] DEFER_END_ID_1_4:;
438 return DEFER_LOC_ID_0_1;
452 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
455 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
456 [[__maybe_unused__]]
register bool defer_return_flag =
false;
459 goto DEFER_END_ID_1_6;
463 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
464 unsigned (*DEFER_LOC_ID_1_3)[DEFER_LOC_ID_0_2] = {};
467 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
468 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
469 {
ELLIPSIS_CONTRACT(4, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), unreachable,
false,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assumption",
"out of memory when concatenating two FA arrays");}
474 do {
ELLIPSIS_CONTRACT(5, s && t, abort,
true,
"s ∧ t",
"assertion",
"argument FA arrays for concatenation must not be null");}
while (
false);
475 do {
ELLIPSIS_CONTRACT(6, s->length <= (SIZE_MAX - t->length), abort,
true,
"s→length ≤ (SIZE_MAX − t→length)",
"assertion",
"concatenation of FA would be too long");}
while (
false);
479 defer_return_flag =
true;
486[[__maybe_unused__]] DEFER_END_ID_1_6:;
487 return DEFER_LOC_ID_0_1;
522 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
525 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
526 [[__maybe_unused__]]
register bool defer_return_flag =
false;
529 goto DEFER_END_ID_1_8;
533 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
534 unsigned (*DEFER_LOC_ID_1_4)[DEFER_LOC_ID_0_2] = {};
537 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
538 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
539 {
ELLIPSIS_CONTRACT(7, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), unreachable,
false,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assumption",
"out of memory when growing an FA array");}
547 defer_return_flag =
true;
554[[__maybe_unused__]] DEFER_END_ID_1_8:;
555 return DEFER_LOC_ID_0_1;
577 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
580 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
581 [[__maybe_unused__]]
register bool defer_return_flag =
false;
584 goto DEFER_END_ID_1_10;
588 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
589 unsigned (*DEFER_LOC_ID_1_5)[DEFER_LOC_ID_0_2] = {};
592 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
593 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
594 {
ELLIPSIS_CONTRACT(8, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), unreachable,
false,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assumption",
"out of memory when growing an FA array");}
599 do {
ELLIPSIS_CONTRACT(9, !s || ((
bool)((s)->
capacity)), abort,
true,
"¬s ∨ ((bool)((s)→capacity))",
"assertion",
"flexible array object must be in allocated storage to be growable");}
while (
false);
600 do {
ELLIPSIS_CONTRACT(10, !s || s->length < SIZE_MAX, abort,
true,
"¬s ∨ s→length < SIZE_MAX",
"assertion",
"FA array is a its limits");}
while (
false);
604 defer_return_flag =
true;
611[[__maybe_unused__]] DEFER_END_ID_1_10:;
612 return DEFER_LOC_ID_0_1;
636 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
639 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
640 [[__maybe_unused__]]
register bool defer_return_flag =
false;
643 goto DEFER_END_ID_1_12;
647 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
648 unsigned (*DEFER_LOC_ID_1_6)[DEFER_LOC_ID_0_2] = {};
651 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
652 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
653 {
ELLIPSIS_CONTRACT(11, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), unreachable,
false,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assumption",
"out of memory when shrinking an FA array");}
658 do {
ELLIPSIS_CONTRACT(12, s, abort,
true,
"s",
"assertion",
"can only shrink existing array");}
while (
false);
659 do {
ELLIPSIS_CONTRACT(13, ((
bool)((s)->
capacity)), abort,
true,
"((bool)((s)→capacity))",
"assertion",
"flexible array object must be in allocated storage to be shrinkable");}
while (
false);
660 do {
ELLIPSIS_CONTRACT(14, length <= s->
length, abort,
true,
"length ≤ s→length",
"assertion",
"can\'t shrink array to make it longer");}
while (
false);
664 defer_return_flag =
true;
671[[__maybe_unused__]] DEFER_END_ID_1_12:;
672 return DEFER_LOC_ID_0_1;
687 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
690 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
691 [[__maybe_unused__]]
register bool defer_return_flag =
false;
694 goto DEFER_END_ID_1_14;
697 do {
ELLIPSIS_CONTRACT(15, s, abort,
true,
"s",
"assertion",
"substring from non-existing string");}
while (
false);
698 do {
ELLIPSIS_CONTRACT(16, pos < s->
length, abort,
true,
"pos < s→length",
"assertion",
"start of substring is out of bounds");}
while (
false);
700 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
701 unsigned (*DEFER_LOC_ID_1_7)[DEFER_LOC_ID_0_2] = {};
704 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
705 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
706 {
ELLIPSIS_CONTRACT(17, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), unreachable,
false,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assumption",
"out of memory when growing an FA array");}
714 defer_return_flag =
true;
721[[__maybe_unused__]] DEFER_END_ID_1_14:;
722 return DEFER_LOC_ID_0_1;
740 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
743 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
744 [[__maybe_unused__]]
register bool defer_return_flag =
false;
747 goto DEFER_END_ID_1_16;
750 do {
ELLIPSIS_CONTRACT(18, s, abort,
true,
"s",
"assertion",
"copy of non-existing string");}
while (
false);
752 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
753 unsigned (*DEFER_LOC_ID_1_8)[DEFER_LOC_ID_0_2] = {};
756 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
757 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
758 {
ELLIPSIS_CONTRACT(19, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), unreachable,
false,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assumption",
"copy operation failed");}
766 defer_return_flag =
true;
773[[__maybe_unused__]] DEFER_END_ID_1_16:;
774 return DEFER_LOC_ID_0_1;
788 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
791 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
792 [[__maybe_unused__]]
register bool defer_return_flag =
false;
795 goto DEFER_END_ID_1_18;
799 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
800 unsigned (*DEFER_LOC_ID_1_9)[DEFER_LOC_ID_0_2] = {};
803 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
804 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
805 {
ELLIPSIS_CONTRACT(20, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), abort,
true,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assertion",
"out of memory when growing an FA array");}
813 defer_return_flag =
true;
820[[__maybe_unused__]] DEFER_END_ID_1_18:;
821 return DEFER_LOC_ID_0_1;
843 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
846 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
847 [[__maybe_unused__]]
register bool defer_return_flag =
false;
850 goto DEFER_END_ID_1_20;
854 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
855 unsigned (*DEFER_LOC_ID_1_10)[DEFER_LOC_ID_0_2] = {};
858 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
859 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
860 {
ELLIPSIS_CONTRACT(21, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), abort,
true,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assertion",
"out of memory when creating a one element FA array");}
865 do {
ELLIPSIS_CONTRACT(22, !s || (s->length < s->capacity) || (s->capacity < SIZE_MAX), unreachable,
false,
"¬s ∨ (s→length < s→capacity) ∨ (s→capacity < SIZE_MAX)",
"assumption",
"FA array is a its limits");}
while (
false);
869 defer_return_flag =
true;
876[[__maybe_unused__]] DEFER_END_ID_1_20:;
877 return DEFER_LOC_ID_0_1;
891 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
894 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
895 [[__maybe_unused__]]
register bool defer_return_flag =
false;
898 goto DEFER_END_ID_1_22;
902 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
903 unsigned (*DEFER_LOC_ID_1_11)[DEFER_LOC_ID_0_2] = {};
906 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
907 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
908 {
ELLIPSIS_CONTRACT(23, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), abort,
true,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assertion",
"out of memory when concatenating two FA arrays");}
913 do {
ELLIPSIS_CONTRACT(24, s && t, unreachable,
false,
"s ∧ t",
"assumption",
"argument FA arrays for concatenation must not be null");}
while (
false);
914 do {
ELLIPSIS_CONTRACT(25, s->length <= (SIZE_MAX - t->length), unreachable,
false,
"s→length ≤ (SIZE_MAX − t→length)",
"assumption",
"concatenation of FA would be too long");}
while (
false);
918 defer_return_flag =
true;
925[[__maybe_unused__]] DEFER_END_ID_1_22:;
926 return DEFER_LOC_ID_0_1;
961 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
964 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
965 [[__maybe_unused__]]
register bool defer_return_flag =
false;
968 goto DEFER_END_ID_1_24;
972 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
973 unsigned (*DEFER_LOC_ID_1_12)[DEFER_LOC_ID_0_2] = {};
976 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
977 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
978 {
ELLIPSIS_CONTRACT(26, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), abort,
true,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assertion",
"out of memory when growing an FA array");}
986 defer_return_flag =
true;
993[[__maybe_unused__]] DEFER_END_ID_1_24:;
994 return DEFER_LOC_ID_0_1;
1016 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1019 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1020 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1023 goto DEFER_END_ID_1_26;
1027 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1028 unsigned (*DEFER_LOC_ID_1_13)[DEFER_LOC_ID_0_2] = {};
1031 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1032 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1033 {
ELLIPSIS_CONTRACT(27, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), abort,
true,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assertion",
"out of memory when growing an FA array");}
1038 do {
ELLIPSIS_CONTRACT(28, !s || ((
bool)((s)->
capacity)), unreachable,
false,
"¬s ∨ ((bool)((s)→capacity))",
"assumption",
"flexible array object must be in allocated storage to be growable");}
while (
false);
1039 do {
ELLIPSIS_CONTRACT(29, !s || s->length < SIZE_MAX, unreachable,
false,
"¬s ∨ s→length < SIZE_MAX",
"assumption",
"FA array is a its limits");}
while (
false);
1043 defer_return_flag =
true;
1050[[__maybe_unused__]] DEFER_END_ID_1_26:;
1051 return DEFER_LOC_ID_0_1;
1075 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1078 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1079 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1082 goto DEFER_END_ID_1_28;
1086 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1087 unsigned (*DEFER_LOC_ID_1_14)[DEFER_LOC_ID_0_2] = {};
1090 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1091 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1092 {
ELLIPSIS_CONTRACT(30, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), abort,
true,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assertion",
"out of memory when shrinking an FA array");}
1097 do {
ELLIPSIS_CONTRACT(31, s, unreachable,
false,
"s",
"assumption",
"can only shrink existing array");}
while (
false);
1098 do {
ELLIPSIS_CONTRACT(32, ((
bool)((s)->
capacity)), unreachable,
false,
"((bool)((s)→capacity))",
"assumption",
"flexible array object must be in allocated storage to be shrinkable");}
while (
false);
1099 do {
ELLIPSIS_CONTRACT(33, length <= s->
length, unreachable,
false,
"length ≤ s→length",
"assumption",
"can\'t shrink array to make it longer");}
while (
false);
1103 defer_return_flag =
true;
1110[[__maybe_unused__]] DEFER_END_ID_1_28:;
1111 return DEFER_LOC_ID_0_1;
1126 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1129 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1130 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1133 goto DEFER_END_ID_1_30;
1136 do {
ELLIPSIS_CONTRACT(34, s, unreachable,
false,
"s",
"assumption",
"substring from non-existing string");}
while (
false);
1137 do {
ELLIPSIS_CONTRACT(35, pos < s->
length, unreachable,
false,
"pos < s→length",
"assumption",
"start of substring is out of bounds");}
while (
false);
1139 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1140 unsigned (*DEFER_LOC_ID_1_15)[DEFER_LOC_ID_0_2] = {};
1143 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1144 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1145 {
ELLIPSIS_CONTRACT(36, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), abort,
true,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assertion",
"out of memory when growing an FA array");}
1153 defer_return_flag =
true;
1160[[__maybe_unused__]] DEFER_END_ID_1_30:;
1161 return DEFER_LOC_ID_0_1;
1179 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1182 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1183 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1186 goto DEFER_END_ID_1_32;
1189 do {
ELLIPSIS_CONTRACT(37, s, unreachable,
false,
"s",
"assumption",
"copy of non-existing string");}
while (
false);
1191 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1192 unsigned (*DEFER_LOC_ID_1_16)[DEFER_LOC_ID_0_2] = {};
1195 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1196 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1197 {
ELLIPSIS_CONTRACT(38, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), abort,
true,
"((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1)",
"assertion",
"copy operation failed");}
1205 defer_return_flag =
true;
1212[[__maybe_unused__]] DEFER_END_ID_1_32:;
1213 return DEFER_LOC_ID_0_1;
1254 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1257 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1258 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1261 goto DEFER_END_ID_1_34;
1264 ELLIPSIS_CONTRACT(39, __LOC_ID_0_9, abort,
true,
"__LOC(0, 1)",
"precondition",
"copy of non-existing string");
1267 defer_return_flag =
true;
1274[[__maybe_unused__]] DEFER_END_ID_1_34:;
1275 return DEFER_LOC_ID_0_1;
1302 extern void (qsort)(
void*, size_t, size_t, int (*)(
const void*,
const void*));
1304 size_t rlen = p->
length - offs;
1305 if (rlen < len) len = rlen;
1322 extern void* (bsearch)(
void const*,
void const*,
size_t,
size_t,
int (*)(
const void*,
const void*));
1324 size_t rlen = p->
length - offs;
1325 if (rlen < len) len = rlen;
ellipsis‿carray * ellipsis‿carray‿shrink‿_Inner(ellipsis‿carray s[restrict static 1], size_t length)
Definition ellipsis-carray.c:228
ellipsis‿carray const * ellipsis‿carray‿cpy_const‿_Inner(ellipsis‿carray const *restrict s)
Definition ellipsis-carray.c:257
ellipsis‿carray * ellipsis‿carray‿alloc‿_Inner(size_t len)
Definition ellipsis-carray.c:147
ellipsis‿carray * ellipsis‿carray‿concat‿_Inner(ellipsis‿carray const *s, ellipsis‿carray const *t)
Definition ellipsis-carray.c:168
ellipsis‿carray * ellipsis‿carray‿concat_inplace‿_Inner(ellipsis‿carray const *s0, ellipsis‿carray const *t)
Definition ellipsis-carray.c:183
ellipsis‿carray * ellipsis‿carray‿grow‿_Inner(ellipsis‿carray *restrict s, size_t length)
Definition ellipsis-carray.c:202
ellipsis‿carray * ellipsis‿carray‿sub‿_Inner(ellipsis‿carray const *s, size_t pos, size_t len)
Definition ellipsis-carray.c:240
ellipsis‿carray * ellipsis‿carray‿append‿_Inner(ellipsis‿carray *restrict s, s->array[0] c)
Definition ellipsis-carray.c:159
thread_local bool volatile ellipsis‿contracts‿verbose‿dynamic
#define ELLIPSIS_CONTRACT(COUNT, COND, ACTION, VERB, CSTR, CTYPE,...)
Definition ellipsis-carray.h:112
thread_local bool volatile ellipsis‿contracts‿proceed‿dynamic
thread_local bool volatile ellipsis‿contracts‿ignore‿dynamic
@ keep
Definition ellipsis-category.h:56
#define GNU_ATTR_COUNTED_BY(...)
Definition ellipsis-error.h:59
#define STDC_ATTR_NODISCARD(...)
Definition ellipsis-error.h:68
#define GNU_ATTR_STRICT_FLEX_ARRAY(...)
Definition ellipsis-error.h:54
#define GNU_ATTR_RETURNS_NONNULL
Definition ellipsis-error.h:34
struct ellipsis‿contracts‿is_ice ellipsis‿contracts‿is_ice
Definition ellipsis-expression.c:24
static ellipsis‿token‿dictionary functions
Definition ellipsis-macros.c:89
A structure with a flexible array member of base type ellipsis‿carray‿base.
Definition ellipsis-carray.h:182
ellipsis‿carray * ellipsis‿carray‿alloc‿_Insta(size_t len)
Allocate a ellipsis‿carray with elements as given by the parameter.
Definition ellipsis-carray.c:272
int ellipsis‿carray‿base‿compare(ellipsis‿carray‿base const __LOC_ID_0_3[static 1], ellipsis‿carray‿base const __LOC_ID_0_4[static 1])
Definition ellipsis-carray.h:42
int ellipsis‿carray‿compare(ellipsis‿carray const *s, ellipsis‿carray const *t)
Compare two arrays lexicographically.
Definition ellipsis-carray.c:119
ellipsis‿carray * ellipsis‿carray‿concat_inplace‿_Ctra(ellipsis‿carray const *s, ellipsis‿carray const *t)
Concatenate two ellipsis‿carray into a new one and delete s.
Definition ellipsis-carray.h:959
ellipsis‿carray * ellipsis‿carray‿append(ellipsis‿carray *restrict s, ellipsis‿carray‿base c)
Append a new element to a ellipsis‿carray and return a new object.
Definition ellipsis-carray.h:402
size_t const length
Current length of this instance.
Definition ellipsis-carray.h:191
ellipsis‿carray * ellipsis‿carray‿cpy(ellipsis‿carray const *restrict __LOC_ID_0_9)
Allocate a ellipsis‿carray and copy the data to which the parameter points into it.
Definition ellipsis-carray.h:1252
void ellipsis‿carray‿base‿destroy(size_t __LOC_ID_0_1, ellipsis‿carray‿base const __LOC_ID_0_2[__LOC_ID_0_1])
Destroy a ellipsis‿carray‿base by freeing the pointed-to character array.
Definition ellipsis-carray.h:31
ellipsis‿carray const * ellipsis‿carray‿cpy_const(ellipsis‿carray const *restrict s)
Copy or link to a const-qualified ellipsis‿carray.
Definition ellipsis-carray.h:738
ellipsis‿carray‿base array[]
The current data array.
Definition ellipsis-carray.h:216
ellipsis‿carray * ellipsis‿carray‿grow‿_Ctra(ellipsis‿carray *restrict s, size_t length)
Grow the ellipsis‿carray to (at least) the indicated amount of elements return a new one and delete t...
Definition ellipsis-carray.h:1014
ellipsis‿carray * ellipsis‿carray‿alloc‿_Ctra(size_t len)
Allocate a ellipsis‿carray with elements as given by the parameter.
Definition ellipsis-carray.h:786
void ellipsis‿carray‿move(ellipsis‿carray *__LOC_ID_0_5[restrict static 1], ellipsis‿carray **restrict __LOC_ID_0_6)
Move a ellipsis‿carray pointed to by the second parameter to the one pointed to by the first.
Definition ellipsis-carray.h:306
ellipsis‿carray * ellipsis‿carray‿grow‿_Insta(ellipsis‿carray *restrict s, size_t length)
Grow the ellipsis‿carray to (at least) the indicated amount of elements return a new one and delete t...
Definition ellipsis-carray.c:456
ellipsis‿carray const * ellipsis‿carray‿cpy_const‿_Insta(ellipsis‿carray const *restrict s)
Copy or link to a const-qualified ellipsis‿carray.
Definition ellipsis-carray.c:586
ellipsis‿carray * ellipsis‿carray‿sub‿_Insta(ellipsis‿carray const *restrict s, size_t pos, size_t len)
Allocate a ellipsis‿carray with len elements and copy the data from *s at position pos onward.
Definition ellipsis-carray.c:544
ellipsis‿carray * ellipsis‿carray‿sub(ellipsis‿carray const *restrict s, size_t pos, size_t len)
Allocate a ellipsis‿carray with len elements and copy the data from *s at position pos onward.
Definition ellipsis-carray.h:685
size_t length_mod
Modifiable length of this instance.
Definition ellipsis-carray.h:198
int ellipsis‿carray‿compareInternal(void const *A, void const *B)
Definition ellipsis-carray.h:1282
ellipsis‿carray * ellipsis‿carray‿shrink‿_Ctra(ellipsis‿carray s[restrict static 1], size_t length)
Shrink the ellipsis‿carray to exactly the indicated amount of elements return a new one and delete th...
Definition ellipsis-carray.h:1073
void ellipsis‿carray‿delete(ellipsis‿carray const *)
Delete a ellipsis‿carray pointed to by the parameter.
Definition ellipsis-carray.c:615
void ellipsis‿carray‿cmove(ellipsis‿carray const *__LOC_ID_0_7[restrict static 1], ellipsis‿carray const **restrict __LOC_ID_0_8)
Move a ellipsis‿carray const pointed to by the second parameter to the one pointed to by the first.
Definition ellipsis-carray.h:326
ellipsis‿carray‿base const * ellipsis‿carray‿search(ellipsis‿carray‿base const el[static 1], ellipsis‿carray const *p, size_t offs, size_t len)
search for an element in a ellipsis‿carray
Definition ellipsis-carray.h:1321
ellipsis‿carray * ellipsis‿carray‿append‿_Ctra(ellipsis‿carray *restrict s, ellipsis‿carray‿base c)
Append a new element to a ellipsis‿carray and return a new object.
Definition ellipsis-carray.h:841
ellipsis‿carray * ellipsis‿carray‿concat_inplace(ellipsis‿carray const *s, ellipsis‿carray const *t)
Concatenate two ellipsis‿carray into a new one and delete s.
Definition ellipsis-carray.h:520
ellipsis‿carray * ellipsis‿carray‿concat‿_Insta(ellipsis‿carray const *s, ellipsis‿carray const *t)
Concatenate two ellipsis‿carray into a new one.
Definition ellipsis-carray.c:353
void ellipsis‿carray‿sort(ellipsis‿carray *p, size_t offs, size_t len)
sort a ellipsis‿carray in place.
Definition ellipsis-carray.h:1301
ellipsis‿carray * ellipsis‿carray‿alloc(size_t len)
Allocate a ellipsis‿carray with elements as given by the parameter.
Definition ellipsis-carray.h:347
ellipsis‿carray * ellipsis‿carray‿grow(ellipsis‿carray *restrict s, size_t length)
Grow the ellipsis‿carray to (at least) the indicated amount of elements return a new one and delete t...
Definition ellipsis-carray.h:575
ellipsis‿carray * ellipsis‿carray‿concat_inplace‿_Insta(ellipsis‿carray const *s, ellipsis‿carray const *t)
Concatenate two ellipsis‿carray into a new one and delete s.
Definition ellipsis-carray.c:412
ellipsis‿carray * ellipsis‿carray‿shrink(ellipsis‿carray s[restrict static 1], size_t length)
Shrink the ellipsis‿carray to exactly the indicated amount of elements return a new one and delete th...
Definition ellipsis-carray.h:634
ellipsis‿carray * ellipsis‿carray‿append‿_Insta(ellipsis‿carray *restrict s, ellipsis‿carray‿base c)
Append a new element to a ellipsis‿carray and return a new object.
Definition ellipsis-carray.c:316
char const * ellipsis‿carray‿base
A pointer to a private character array.
Definition ellipsis-carray.h:25
size_t const capacity
Maximal length of this instance.
Definition ellipsis-carray.h:208
ellipsis‿carray * ellipsis‿carray‿shrink‿_Insta(ellipsis‿carray s[restrict static 1], size_t length)
Shrink the ellipsis‿carray to exactly the indicated amount of elements return a new one and delete th...
Definition ellipsis-carray.c:504
ellipsis‿carray * ellipsis‿carray‿remove(ellipsis‿carray s[restrict static 1], size_t)
Remove (at most) the indicated amount of elements from the ellipsis‿carray return a new one and delet...
Definition ellipsis-carray.c:108
ellipsis‿carray * ellipsis‿carray‿sub‿_Ctra(ellipsis‿carray const *restrict s, size_t pos, size_t len)
Allocate a ellipsis‿carray with len elements and copy the data from *s at position pos onward.
Definition ellipsis-carray.h:1124
ellipsis‿carray * ellipsis‿carray‿concat‿_Ctra(ellipsis‿carray const *s, ellipsis‿carray const *t)
Concatenate two ellipsis‿carray into a new one.
Definition ellipsis-carray.h:889
ellipsis‿carray const * ellipsis‿carray‿cpy_const‿_Ctra(ellipsis‿carray const *restrict s)
Copy or link to a const-qualified ellipsis‿carray.
Definition ellipsis-carray.h:1177
ellipsis‿carray * ellipsis‿carray‿concat(ellipsis‿carray const *s, ellipsis‿carray const *t)
Concatenate two ellipsis‿carray into a new one.
Definition ellipsis-carray.h:450