8#ifndef ELLIPSIS_TARRAY_H
9#define ELLIPSIS_TARRAY_H 1
26 if (!__LOC_ID_0_1[0] + !__LOC_ID_0_2[0]) {
27 return !__LOC_ID_0_2[0] - !__LOC_ID_0_1[0];
47#define STRINGIFY(...) STRINGIFY_(__VA_ARGS__)
48#define STRINGIFY_(...) #__VA_ARGS__
50#define ELLIPSIS_CONTRACT_VIOLATION(COUNT, VERB, CTYPE, CSTR, ...) \
52 static char const contract_format_ ## COUNT[] = \
53 __FILE__ ":" STRINGIFY(__LINE__) ": violation of " CTYPE " `" CSTR "`" __VA_OPT__(", ") __VA_ARGS__ "\n";\
55 ? fputs(contract_format_ ## COUNT, stderr) \
59#define ELLIPSIS_CONTRACT_IMPL(COUNT, COND, ACTION, VERB, CSTR, CTYPE, ...) \
62 : (ELLIPSIS_CONTRACT_VIOLATION(COUNT, VERB, CTYPE, CSTR __VA_OPT__(,) __VA_ARGS__) \
67#define ELLIPSIS_TO_VOIDS(...) ((void*)((uintptr_t)((__VA_ARGS__)-(__VA_ARGS__))))
69#define ELLIPSIS_TEST_ICE(...) (false ? ELLIPSIS_TO_VOIDS(__VA_ARGS__) : (ellipsis‿contracts‿is_ice*)nullptr)
71#define ELLIPSIS_CONTRACT_ICE_OR_TRUE(...) \
73 ELLIPSIS_TEST_ICE(__VA_ARGS__), \
74 ellipsis‿contracts‿is_ice*: (__VA_ARGS__), \
77#define ELLIPSIS_CONTRACT_CHECK_STATIC(CTYPE, COND, CSTR, ...) \
79 static_assert(ELLIPSIS_CONTRACT_ICE_OR_TRUE(COND), \
80 "compile time violation of " CTYPE " " CSTR \
81 __VA_OPT__(", ") __VA_ARGS__ );\
84#define ELLIPSIS_CONTRACT(COUNT, COND, ACTION, VERB, CSTR, CTYPE, ...) \
88 ELLIPSIS_TEST_ICE(COND), \
89 ellipsis‿contracts‿is_ice*: ELLIPSIS_CONTRACT_CHECK_STATIC(CTYPE, COND, CSTR __VA_OPT__(,) __VA_ARGS__), \
90 default: ELLIPSIS_CONTRACT_IMPL(COUNT, COND, ACTION, VERB, CSTR, CTYPE __VA_OPT__(,) __VA_ARGS__));\
155#ifndef DOXYGEN_SPECIAL
169 [[deprecated(
"use const member length instead")]]
171#ifndef DOXYGEN_SPECIAL
191#define ELLIPSIS_TARRAY_OVERLAY(N) \
194 size_t const length;\
195 size_t const padding;\
196 unsigned const :(offsetof(ellipsis‿token‿array, array)-2*sizeof(size_t));\
197 ellipsis‿token‿array‿base array[N];\
199 ellipsis‿token‿array fa;\
202#define ELLIPSIS_TARRAY_STATIC(N, ...) \
204 static const ELLIPSIS_TARRAY_OVERLAY( \
205 sizeof((ellipsis‿token‿array‿base[]){__VA_ARGS__ }) \
206 /sizeof(ellipsis‿token‿array‿base)) \
209 .array = {__VA_ARGS__ }, \
210 };&__LOC_ID_1_1;})->fa)
232#if __clang__ && (__clang_major__ < 30)
233#define ELLIPSIS_TARRAY_LITERAL_LOCAL(N, ...) ELLIPSIS_TARRAY_STATIC(N, __VA_ARGS__)
235#define ELLIPSIS_TARRAY_LITERAL_LOCAL(N, ...) \
236 ((static const ELLIPSIS_TARRAY_OVERLAY( \
237 sizeof((ellipsis‿token‿array‿base[]){__VA_ARGS__ }) \
238 /sizeof(ellipsis‿token‿array‿base))) \
241 .array = {__VA_ARGS__ }, \
245#define ELLIPSIS_TARRAY_LITERAL_GLOBAL(N, ...) \
246 ((const ELLIPSIS_TARRAY_OVERLAY( \
247 sizeof((ellipsis‿token‿array‿base[]){__VA_ARGS__ }) \
248 /sizeof(ellipsis‿token‿array‿base))) \
251 .array = {__VA_ARGS__ }, \
254#define ELLIPSIS_TARRAY_LITERAL ELLIPSIS_TARRAY_LITERAL_LOCAL
282 *__LOC_ID_0_3= *__LOC_ID_0_4;
283 *__LOC_ID_0_4=
nullptr;
285 *__LOC_ID_0_3=
nullptr;
302 *__LOC_ID_0_5= *__LOC_ID_0_6;
303 *__LOC_ID_0_6=
nullptr;
305 *__LOC_ID_0_5=
nullptr;
321 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
324 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
325 [[__maybe_unused__]]
register bool defer_return_flag =
false;
328 goto DEFER_END_ID_1_2;
332 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
333 unsigned (*DEFER_LOC_ID_1_1)[DEFER_LOC_ID_0_2] = {};
336 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
337 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
338 {
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");}
346 defer_return_flag =
true;
353[[__maybe_unused__]] DEFER_END_ID_1_2:;
354 return DEFER_LOC_ID_0_1;
376 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
379 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
380 [[__maybe_unused__]]
register bool defer_return_flag =
false;
383 goto DEFER_END_ID_1_4;
387 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
388 unsigned (*DEFER_LOC_ID_1_2)[DEFER_LOC_ID_0_2] = {};
391 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
392 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
393 {
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");}
398 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);
402 defer_return_flag =
true;
409[[__maybe_unused__]] DEFER_END_ID_1_4:;
410 return DEFER_LOC_ID_0_1;
424 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
427 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
428 [[__maybe_unused__]]
register bool defer_return_flag =
false;
431 goto DEFER_END_ID_1_6;
435 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
436 unsigned (*DEFER_LOC_ID_1_3)[DEFER_LOC_ID_0_2] = {};
439 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
440 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
441 {
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");}
446 do {
ELLIPSIS_CONTRACT(5, s && t, abort,
true,
"s ∧ t",
"assertion",
"argument FA arrays for concatenation must not be null");}
while (
false);
447 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);
451 defer_return_flag =
true;
458[[__maybe_unused__]] DEFER_END_ID_1_6:;
459 return DEFER_LOC_ID_0_1;
494 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
497 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
498 [[__maybe_unused__]]
register bool defer_return_flag =
false;
501 goto DEFER_END_ID_1_8;
505 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
506 unsigned (*DEFER_LOC_ID_1_4)[DEFER_LOC_ID_0_2] = {};
509 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
510 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
511 {
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");}
519 defer_return_flag =
true;
526[[__maybe_unused__]] DEFER_END_ID_1_8:;
527 return DEFER_LOC_ID_0_1;
549 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
552 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
553 [[__maybe_unused__]]
register bool defer_return_flag =
false;
556 goto DEFER_END_ID_1_10;
560 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
561 unsigned (*DEFER_LOC_ID_1_5)[DEFER_LOC_ID_0_2] = {};
564 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
565 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
566 {
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");}
571 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);
572 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);
576 defer_return_flag =
true;
583[[__maybe_unused__]] DEFER_END_ID_1_10:;
584 return DEFER_LOC_ID_0_1;
608 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
611 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
612 [[__maybe_unused__]]
register bool defer_return_flag =
false;
615 goto DEFER_END_ID_1_12;
619 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
620 unsigned (*DEFER_LOC_ID_1_6)[DEFER_LOC_ID_0_2] = {};
623 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
624 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
625 {
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");}
630 do {
ELLIPSIS_CONTRACT(12, s, abort,
true,
"s",
"assertion",
"can only shrink existing array");}
while (
false);
631 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);
632 do {
ELLIPSIS_CONTRACT(14, length <= s->
length, abort,
true,
"length ≤ s→length",
"assertion",
"can\'t shrink array to make it longer");}
while (
false);
636 defer_return_flag =
true;
643[[__maybe_unused__]] DEFER_END_ID_1_12:;
644 return DEFER_LOC_ID_0_1;
659 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
662 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
663 [[__maybe_unused__]]
register bool defer_return_flag =
false;
666 goto DEFER_END_ID_1_14;
669 do {
ELLIPSIS_CONTRACT(15, s, abort,
true,
"s",
"assertion",
"substring from non-existing string");}
while (
false);
670 do {
ELLIPSIS_CONTRACT(16, pos < s->
length, abort,
true,
"pos < s→length",
"assertion",
"start of substring is out of bounds");}
while (
false);
672 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
673 unsigned (*DEFER_LOC_ID_1_7)[DEFER_LOC_ID_0_2] = {};
676 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
677 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
678 {
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");}
686 defer_return_flag =
true;
693[[__maybe_unused__]] DEFER_END_ID_1_14:;
694 return DEFER_LOC_ID_0_1;
712 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
715 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
716 [[__maybe_unused__]]
register bool defer_return_flag =
false;
719 goto DEFER_END_ID_1_16;
722 do {
ELLIPSIS_CONTRACT(18, s, abort,
true,
"s",
"assertion",
"copy of non-existing string");}
while (
false);
724 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
725 unsigned (*DEFER_LOC_ID_1_8)[DEFER_LOC_ID_0_2] = {};
728 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
729 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
730 {
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");}
738 defer_return_flag =
true;
745[[__maybe_unused__]] DEFER_END_ID_1_16:;
746 return DEFER_LOC_ID_0_1;
760 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
763 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
764 [[__maybe_unused__]]
register bool defer_return_flag =
false;
767 goto DEFER_END_ID_1_18;
771 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
772 unsigned (*DEFER_LOC_ID_1_9)[DEFER_LOC_ID_0_2] = {};
775 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
776 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
777 {
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");}
785 defer_return_flag =
true;
792[[__maybe_unused__]] DEFER_END_ID_1_18:;
793 return DEFER_LOC_ID_0_1;
815 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
818 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
819 [[__maybe_unused__]]
register bool defer_return_flag =
false;
822 goto DEFER_END_ID_1_20;
826 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
827 unsigned (*DEFER_LOC_ID_1_10)[DEFER_LOC_ID_0_2] = {};
830 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
831 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
832 {
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");}
837 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);
841 defer_return_flag =
true;
848[[__maybe_unused__]] DEFER_END_ID_1_20:;
849 return DEFER_LOC_ID_0_1;
863 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
866 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
867 [[__maybe_unused__]]
register bool defer_return_flag =
false;
870 goto DEFER_END_ID_1_22;
874 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
875 unsigned (*DEFER_LOC_ID_1_11)[DEFER_LOC_ID_0_2] = {};
878 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
879 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
880 {
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");}
885 do {
ELLIPSIS_CONTRACT(24, s && t, unreachable,
false,
"s ∧ t",
"assumption",
"argument FA arrays for concatenation must not be null");}
while (
false);
886 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);
890 defer_return_flag =
true;
897[[__maybe_unused__]] DEFER_END_ID_1_22:;
898 return DEFER_LOC_ID_0_1;
933 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
936 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
937 [[__maybe_unused__]]
register bool defer_return_flag =
false;
940 goto DEFER_END_ID_1_24;
944 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
945 unsigned (*DEFER_LOC_ID_1_12)[DEFER_LOC_ID_0_2] = {};
948 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
949 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
950 {
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");}
958 defer_return_flag =
true;
965[[__maybe_unused__]] DEFER_END_ID_1_24:;
966 return DEFER_LOC_ID_0_1;
988 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
991 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
992 [[__maybe_unused__]]
register bool defer_return_flag =
false;
995 goto DEFER_END_ID_1_26;
999 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1000 unsigned (*DEFER_LOC_ID_1_13)[DEFER_LOC_ID_0_2] = {};
1003 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1004 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1005 {
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");}
1010 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);
1011 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);
1015 defer_return_flag =
true;
1022[[__maybe_unused__]] DEFER_END_ID_1_26:;
1023 return DEFER_LOC_ID_0_1;
1047 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1050 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1051 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1054 goto DEFER_END_ID_1_28;
1058 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1059 unsigned (*DEFER_LOC_ID_1_14)[DEFER_LOC_ID_0_2] = {};
1062 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1063 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1064 {
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");}
1069 do {
ELLIPSIS_CONTRACT(31, s, unreachable,
false,
"s",
"assumption",
"can only shrink existing array");}
while (
false);
1070 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);
1071 do {
ELLIPSIS_CONTRACT(33, length <= s->
length, unreachable,
false,
"length ≤ s→length",
"assumption",
"can\'t shrink array to make it longer");}
while (
false);
1075 defer_return_flag =
true;
1082[[__maybe_unused__]] DEFER_END_ID_1_28:;
1083 return DEFER_LOC_ID_0_1;
1098 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1101 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1102 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1105 goto DEFER_END_ID_1_30;
1108 do {
ELLIPSIS_CONTRACT(34, s, unreachable,
false,
"s",
"assumption",
"substring from non-existing string");}
while (
false);
1109 do {
ELLIPSIS_CONTRACT(35, pos < s->
length, unreachable,
false,
"pos < s→length",
"assumption",
"start of substring is out of bounds");}
while (
false);
1111 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1112 unsigned (*DEFER_LOC_ID_1_15)[DEFER_LOC_ID_0_2] = {};
1115 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1116 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1117 {
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");}
1125 defer_return_flag =
true;
1132[[__maybe_unused__]] DEFER_END_ID_1_30:;
1133 return DEFER_LOC_ID_0_1;
1151 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1154 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1155 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1158 goto DEFER_END_ID_1_32;
1161 do {
ELLIPSIS_CONTRACT(37, s, unreachable,
false,
"s",
"assumption",
"copy of non-existing string");}
while (
false);
1163 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1164 unsigned (*DEFER_LOC_ID_1_16)[DEFER_LOC_ID_0_2] = {};
1167 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1168 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1169 {
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");}
1177 defer_return_flag =
true;
1184[[__maybe_unused__]] DEFER_END_ID_1_32:;
1185 return DEFER_LOC_ID_0_1;
1215 memset(_ar, 0, _n*
sizeof(_ar[0]));
1241 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1244 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1245 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1248 goto DEFER_END_ID_1_34;
1251 ELLIPSIS_CONTRACT(39, __LOC_ID_0_7, abort,
true,
"__LOC(0, 1)",
"precondition",
"copy of non-existing string");
1254 defer_return_flag =
true;
1261[[__maybe_unused__]] DEFER_END_ID_1_34:;
1262 return DEFER_LOC_ID_0_1;
1289 extern void (qsort)(
void*, size_t, size_t, int (*)(
const void*,
const void*));
1291 size_t rlen = p->
length - offs;
1292 if (rlen < len) len = rlen;
1309 extern void* (bsearch)(
void const*,
void const*,
size_t,
size_t,
int (*)(
const void*,
const void*));
1311 size_t rlen = p->
length - offs;
1312 if (rlen < len) len = rlen;
#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
int ellipsis‿str32‿compare(ellipsis‿str32 const *s, ellipsis‿str32 const *t)
Definition ellipsis-str32.c:129
ellipsis‿token‿array const * ellipsis‿token‿array‿cpy_const‿_Inner(ellipsis‿token‿array const *restrict s)
Definition ellipsis-tarray.c:257
ellipsis‿token‿array * ellipsis‿token‿array‿alloc‿_Inner(size_t len)
Definition ellipsis-tarray.c:147
ellipsis‿token‿array * ellipsis‿token‿array‿concat‿_Inner(ellipsis‿token‿array const *s, ellipsis‿token‿array const *t)
Definition ellipsis-tarray.c:168
ellipsis‿token‿array * ellipsis‿token‿array‿grow‿_Inner(ellipsis‿token‿array *restrict s, size_t length)
Definition ellipsis-tarray.c:202
ellipsis‿token‿array * ellipsis‿token‿array‿append‿_Inner(ellipsis‿token‿array *restrict s, s->array[0] c)
Definition ellipsis-tarray.c:159
ellipsis‿token‿array * ellipsis‿token‿array‿concat_inplace‿_Inner(ellipsis‿token‿array const *s0, ellipsis‿token‿array const *t)
Definition ellipsis-tarray.c:183
ellipsis‿token‿array * ellipsis‿token‿array‿shrink‿_Inner(ellipsis‿token‿array s[restrict static 1], size_t length)
Definition ellipsis-tarray.c:228
ellipsis‿token‿array * ellipsis‿token‿array‿sub‿_Inner(ellipsis‿token‿array const *s, size_t pos, size_t len)
Definition ellipsis-tarray.c:240
thread_local bool volatile ellipsis‿contracts‿verbose‿dynamic
#define ELLIPSIS_CONTRACT(COUNT, COND, ACTION, VERB, CSTR, CTYPE,...)
Definition ellipsis-tarray.h:84
ellipsis‿token * ellipsis‿token‿array‿base
Definition ellipsis-tarray.h:13
thread_local bool volatile ellipsis‿contracts‿proceed‿dynamic
thread_local bool volatile ellipsis‿contracts‿ignore‿dynamic
A token element as recognized during processing.
Definition ellipsis-token.h:94
A structure with a flexible array member of base type ellipsis‿token‿array‿base.
Definition ellipsis-tarray.h:154
ellipsis‿token‿array * ellipsis‿token‿array‿concat‿_Insta(ellipsis‿token‿array const *s, ellipsis‿token‿array const *t)
Concatenate two ellipsis‿token‿array into a new one.
Definition ellipsis-tarray.c:353
ellipsis‿token‿array * ellipsis‿token‿array‿grow‿_Ctra(ellipsis‿token‿array *restrict s, size_t length)
Grow the ellipsis‿token‿array to (at least) the indicated amount of elements return a new one and del...
Definition ellipsis-tarray.h:986
ellipsis‿token‿array * ellipsis‿token‿array‿concat‿_Ctra(ellipsis‿token‿array const *s, ellipsis‿token‿array const *t)
Concatenate two ellipsis‿token‿array into a new one.
Definition ellipsis-tarray.h:861
ellipsis‿token‿array * ellipsis‿token‿array‿cpy(ellipsis‿token‿array const *restrict __LOC_ID_0_7)
Allocate a ellipsis‿token‿array and copy the data to which the parameter points into it.
Definition ellipsis-tarray.h:1239
size_t const length
Current length of this instance.
Definition ellipsis-tarray.h:163
ellipsis‿token‿array * ellipsis‿token‿array‿alloc‿_Ctra(size_t len)
Allocate a ellipsis‿token‿array with elements as given by the parameter.
Definition ellipsis-tarray.h:758
void ellipsis‿token‿array‿cmove(ellipsis‿token‿array const *__LOC_ID_0_5[restrict static 1], ellipsis‿token‿array const **restrict __LOC_ID_0_6)
Move a ellipsis‿token‿array const pointed to by the second parameter to the one pointed to by the fir...
Definition ellipsis-tarray.h:298
size_t length_mod
Modifiable length of this instance.
Definition ellipsis-tarray.h:170
ellipsis‿token‿array * ellipsis‿token‿array‿concat_inplace‿_Ctra(ellipsis‿token‿array const *s, ellipsis‿token‿array const *t)
Concatenate two ellipsis‿token‿array into a new one and delete s.
Definition ellipsis-tarray.h:931
ellipsis‿token‿array * ellipsis‿token‿array‿append‿_Insta(ellipsis‿token‿array *restrict s, ellipsis‿token‿array‿base c)
Append a new element to a ellipsis‿token‿array and return a new object.
Definition ellipsis-tarray.c:316
ellipsis‿token‿array * ellipsis‿token‿array‿sub‿_Insta(ellipsis‿token‿array const *restrict s, size_t pos, size_t len)
Allocate a ellipsis‿token‿array with len elements and copy the data from *s at position pos onward.
Definition ellipsis-tarray.c:544
ellipsis‿token‿array * ellipsis‿token‿array‿remove(ellipsis‿token‿array s[restrict static 1], size_t)
Remove (at most) the indicated amount of elements from the ellipsis‿token‿array return a new one and ...
Definition ellipsis-tarray.c:108
int ellipsis‿token‿array‿base‿compare(ellipsis‿token‿array‿base const *__LOC_ID_0_1, ellipsis‿token‿array‿base const *__LOC_ID_0_2)
compare the pointed-to tokens
Definition ellipsis-tarray.h:25
ellipsis‿token‿array * ellipsis‿token‿array‿grow(ellipsis‿token‿array *restrict s, size_t length)
Grow the ellipsis‿token‿array to (at least) the indicated amount of elements return a new one and del...
Definition ellipsis-tarray.h:547
ellipsis‿token‿array * ellipsis‿token‿array‿sub(ellipsis‿token‿array const *restrict s, size_t pos, size_t len)
Allocate a ellipsis‿token‿array with len elements and copy the data from *s at position pos onward.
Definition ellipsis-tarray.h:657
ellipsis‿token‿array * ellipsis‿token‿array‿alloc(size_t len)
Allocate a ellipsis‿token‿array with elements as given by the parameter.
Definition ellipsis-tarray.h:319
ellipsis‿token‿array * ellipsis‿token‿array‿append(ellipsis‿token‿array *restrict s, ellipsis‿token‿array‿base c)
Append a new element to a ellipsis‿token‿array and return a new object.
Definition ellipsis-tarray.h:374
ellipsis‿token‿array * ellipsis‿token‿array‿grow‿_Insta(ellipsis‿token‿array *restrict s, size_t length)
Grow the ellipsis‿token‿array to (at least) the indicated amount of elements return a new one and del...
Definition ellipsis-tarray.c:456
ellipsis‿token‿array * ellipsis‿token‿array‿append‿_Ctra(ellipsis‿token‿array *restrict s, ellipsis‿token‿array‿base c)
Append a new element to a ellipsis‿token‿array and return a new object.
Definition ellipsis-tarray.h:813
void ellipsis‿token‿array‿sort(ellipsis‿token‿array *p, size_t offs, size_t len)
sort a ellipsis‿token‿array in place.
Definition ellipsis-tarray.h:1288
ellipsis‿token‿array * ellipsis‿token‿array‿concat_inplace(ellipsis‿token‿array const *s, ellipsis‿token‿array const *t)
Concatenate two ellipsis‿token‿array into a new one and delete s.
Definition ellipsis-tarray.h:492
ellipsis‿token‿array const * ellipsis‿token‿array‿cpy_const(ellipsis‿token‿array const *restrict s)
Copy or link to a const-qualified ellipsis‿token‿array.
Definition ellipsis-tarray.h:710
ellipsis‿token‿array * ellipsis‿token‿array‿shrink‿_Insta(ellipsis‿token‿array s[restrict static 1], size_t length)
Shrink the ellipsis‿token‿array to exactly the indicated amount of elements return a new one and dele...
Definition ellipsis-tarray.c:504
ellipsis‿token‿array * ellipsis‿token‿array‿alloc‿_Insta(size_t len)
Allocate a ellipsis‿token‿array with elements as given by the parameter.
Definition ellipsis-tarray.c:272
ellipsis‿token‿array * ellipsis‿token‿array‿concat(ellipsis‿token‿array const *s, ellipsis‿token‿array const *t)
Concatenate two ellipsis‿token‿array into a new one.
Definition ellipsis-tarray.h:422
int ellipsis‿token‿array‿compareInternal(void const *A, void const *B)
Definition ellipsis-tarray.h:1269
size_t const capacity
Maximal length of this instance.
Definition ellipsis-tarray.h:180
ellipsis‿token‿array‿base const * ellipsis‿token‿array‿search(ellipsis‿token‿array‿base const el[static 1], ellipsis‿token‿array const *p, size_t offs, size_t len)
search for an element in a ellipsis‿token‿array
Definition ellipsis-tarray.h:1308
ellipsis‿token‿array‿base array[]
The current data array.
Definition ellipsis-tarray.h:188
ellipsis‿token‿array * ellipsis‿token‿array‿concat_inplace‿_Insta(ellipsis‿token‿array const *s, ellipsis‿token‿array const *t)
Concatenate two ellipsis‿token‿array into a new one and delete s.
Definition ellipsis-tarray.c:412
ellipsis‿token‿array * ellipsis‿token‿array‿shrink‿_Ctra(ellipsis‿token‿array s[restrict static 1], size_t length)
Shrink the ellipsis‿token‿array to exactly the indicated amount of elements return a new one and dele...
Definition ellipsis-tarray.h:1045
ellipsis‿token‿array const * ellipsis‿token‿array‿cpy_const‿_Insta(ellipsis‿token‿array const *restrict s)
Copy or link to a const-qualified ellipsis‿token‿array.
Definition ellipsis-tarray.c:586
ellipsis‿token‿array * ellipsis‿token‿array‿sub‿_Ctra(ellipsis‿token‿array const *restrict s, size_t pos, size_t len)
Allocate a ellipsis‿token‿array with len elements and copy the data from *s at position pos onward.
Definition ellipsis-tarray.h:1096
void ellipsis‿token‿array‿delete(ellipsis‿token‿array const *)
Delete a ellipsis‿token‿array pointed to by the parameter.
Definition ellipsis-tarray.c:615
ellipsis‿token‿array * ellipsis‿token‿array‿shrink(ellipsis‿token‿array s[restrict static 1], size_t length)
Shrink the ellipsis‿token‿array to exactly the indicated amount of elements return a new one and dele...
Definition ellipsis-tarray.h:606
void ellipsis‿token‿array‿move(ellipsis‿token‿array *__LOC_ID_0_3[restrict static 1], ellipsis‿token‿array **restrict __LOC_ID_0_4)
Move a ellipsis‿token‿array pointed to by the second parameter to the one pointed to by the first.
Definition ellipsis-tarray.h:278
ellipsis‿token‿array const * ellipsis‿token‿array‿cpy_const‿_Ctra(ellipsis‿token‿array const *restrict s)
Copy or link to a const-qualified ellipsis‿token‿array.
Definition ellipsis-tarray.h:1149
void ellipsis‿token‿array‿base‿destroy(size_t _n, ellipsis‿token‿array‿base _ar[static _n])
Destroy an element of type ellipsis‿token‿array‿base.
Definition ellipsis-tarray.h:1214
int ellipsis‿token‿array‿compare(ellipsis‿token‿array const *s, ellipsis‿token‿array const *t)
Compare two arrays lexicographically.
Definition ellipsis-tarray.c:119