8#ifndef ELLIPSIS_STR32_H
9#define ELLIPSIS_STR32_H 1
28 if (!__LOC_ID_0_1[0] + !__LOC_ID_0_2[0]) {
29 return !__LOC_ID_0_2[0] - !__LOC_ID_0_1[0];
31 return (__LOC_ID_0_1[0] < __LOC_ID_0_2[0]) ? -1 : (__LOC_ID_0_1[0] > __LOC_ID_0_2[0] ? +1 : 0);
49#define STRINGIFY(...) STRINGIFY_(__VA_ARGS__)
50#define STRINGIFY_(...) #__VA_ARGS__
52#define ELLIPSIS_CONTRACT_VIOLATION(COUNT, VERB, CTYPE, CSTR, ...) \
54 static char const contract_format_ ## COUNT[] = \
55 __FILE__ ":" STRINGIFY(__LINE__) ": violation of " CTYPE " `" CSTR "`" __VA_OPT__(", ") __VA_ARGS__ "\n";\
57 ? fputs(contract_format_ ## COUNT, stderr) \
61#define ELLIPSIS_CONTRACT_IMPL(COUNT, COND, ACTION, VERB, CSTR, CTYPE, ...) \
64 : (ELLIPSIS_CONTRACT_VIOLATION(COUNT, VERB, CTYPE, CSTR __VA_OPT__(,) __VA_ARGS__) \
69#define ELLIPSIS_TO_VOIDS(...) ((void*)((uintptr_t)((__VA_ARGS__)-(__VA_ARGS__))))
71#define ELLIPSIS_TEST_ICE(...) (false ? ELLIPSIS_TO_VOIDS(__VA_ARGS__) : (ellipsis‿contracts‿is_ice*)nullptr)
73#define ELLIPSIS_CONTRACT_ICE_OR_TRUE(...) \
75 ELLIPSIS_TEST_ICE(__VA_ARGS__), \
76 ellipsis‿contracts‿is_ice*: (__VA_ARGS__), \
79#define ELLIPSIS_CONTRACT_CHECK_STATIC(CTYPE, COND, CSTR, ...) \
81 static_assert(ELLIPSIS_CONTRACT_ICE_OR_TRUE(COND), \
82 "compile time violation of " CTYPE " " CSTR \
83 __VA_OPT__(", ") __VA_ARGS__ );\
86#define ELLIPSIS_CONTRACT(COUNT, COND, ACTION, VERB, CSTR, CTYPE, ...) \
90 ELLIPSIS_TEST_ICE(COND), \
91 ellipsis‿contracts‿is_ice*: ELLIPSIS_CONTRACT_CHECK_STATIC(CTYPE, COND, CSTR __VA_OPT__(,) __VA_ARGS__), \
92 default: ELLIPSIS_CONTRACT_IMPL(COUNT, COND, ACTION, VERB, CSTR, CTYPE __VA_OPT__(,) __VA_ARGS__));\
157#ifndef DOXYGEN_SPECIAL
171 [[deprecated(
"use const member length instead")]]
173#ifndef DOXYGEN_SPECIAL
193#define ELLIPSIS_STR32_OVERLAY(N) \
196 size_t const length;\
197 size_t const padding;\
198 unsigned const :(offsetof(ellipsis‿str32, array)-2*sizeof(size_t));\
199 ellipsis‿str32‿base array[N];\
204#define ELLIPSIS_STR32_STATIC(N, ...) \
206 static const ELLIPSIS_STR32_OVERLAY( \
207 sizeof((ellipsis‿str32‿base[]){__VA_ARGS__ }) \
208 /sizeof(ellipsis‿str32‿base)) \
211 .array = {__VA_ARGS__ }, \
212 };&__LOC_ID_1_1;})->fa)
234#if __clang__ && (__clang_major__ < 30)
235#define ELLIPSIS_STR32_LITERAL_LOCAL(N, ...) ELLIPSIS_STR32_STATIC(N, __VA_ARGS__)
237#define ELLIPSIS_STR32_LITERAL_LOCAL(N, ...) \
238 ((static const ELLIPSIS_STR32_OVERLAY( \
239 sizeof((ellipsis‿str32‿base[]){__VA_ARGS__ }) \
240 /sizeof(ellipsis‿str32‿base))) \
243 .array = {__VA_ARGS__ }, \
247#define ELLIPSIS_STR32_LITERAL_GLOBAL(N, ...) \
248 ((const ELLIPSIS_STR32_OVERLAY( \
249 sizeof((ellipsis‿str32‿base[]){__VA_ARGS__ }) \
250 /sizeof(ellipsis‿str32‿base))) \
253 .array = {__VA_ARGS__ }, \
256#define ELLIPSIS_STR32_LITERAL ELLIPSIS_STR32_LITERAL_LOCAL
284 *__LOC_ID_0_3= *__LOC_ID_0_4;
285 *__LOC_ID_0_4=
nullptr;
287 *__LOC_ID_0_3=
nullptr;
304 *__LOC_ID_0_5= *__LOC_ID_0_6;
305 *__LOC_ID_0_6=
nullptr;
307 *__LOC_ID_0_5=
nullptr;
323 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
326 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
327 [[__maybe_unused__]]
register bool defer_return_flag =
false;
330 goto DEFER_END_ID_1_2;
334 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
335 unsigned (*DEFER_LOC_ID_1_1)[DEFER_LOC_ID_0_2] = {};
338 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
339 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
340 {
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");}
348 defer_return_flag =
true;
355[[__maybe_unused__]] DEFER_END_ID_1_2:;
356 return DEFER_LOC_ID_0_1;
378 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
381 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
382 [[__maybe_unused__]]
register bool defer_return_flag =
false;
385 goto DEFER_END_ID_1_4;
389 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
390 unsigned (*DEFER_LOC_ID_1_2)[DEFER_LOC_ID_0_2] = {};
393 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
394 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
395 {
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");}
400 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);
404 defer_return_flag =
true;
411[[__maybe_unused__]] DEFER_END_ID_1_4:;
412 return DEFER_LOC_ID_0_1;
426 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
429 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
430 [[__maybe_unused__]]
register bool defer_return_flag =
false;
433 goto DEFER_END_ID_1_6;
437 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
438 unsigned (*DEFER_LOC_ID_1_3)[DEFER_LOC_ID_0_2] = {};
441 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
442 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
443 {
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");}
448 do {
ELLIPSIS_CONTRACT(5, s && t, abort,
true,
"s ∧ t",
"assertion",
"argument FA arrays for concatenation must not be null");}
while (
false);
449 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);
453 defer_return_flag =
true;
460[[__maybe_unused__]] DEFER_END_ID_1_6:;
461 return DEFER_LOC_ID_0_1;
496 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
499 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
500 [[__maybe_unused__]]
register bool defer_return_flag =
false;
503 goto DEFER_END_ID_1_8;
507 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
508 unsigned (*DEFER_LOC_ID_1_4)[DEFER_LOC_ID_0_2] = {};
511 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
512 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
513 {
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");}
521 defer_return_flag =
true;
528[[__maybe_unused__]] DEFER_END_ID_1_8:;
529 return DEFER_LOC_ID_0_1;
551 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
554 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
555 [[__maybe_unused__]]
register bool defer_return_flag =
false;
558 goto DEFER_END_ID_1_10;
562 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
563 unsigned (*DEFER_LOC_ID_1_5)[DEFER_LOC_ID_0_2] = {};
566 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
567 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
568 {
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");}
573 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);
574 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);
578 defer_return_flag =
true;
585[[__maybe_unused__]] DEFER_END_ID_1_10:;
586 return DEFER_LOC_ID_0_1;
610 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
613 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
614 [[__maybe_unused__]]
register bool defer_return_flag =
false;
617 goto DEFER_END_ID_1_12;
621 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
622 unsigned (*DEFER_LOC_ID_1_6)[DEFER_LOC_ID_0_2] = {};
625 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
626 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
627 {
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");}
632 do {
ELLIPSIS_CONTRACT(12, s, abort,
true,
"s",
"assertion",
"can only shrink existing array");}
while (
false);
633 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);
634 do {
ELLIPSIS_CONTRACT(14, length <= s->
length, abort,
true,
"length ≤ s→length",
"assertion",
"can\'t shrink array to make it longer");}
while (
false);
638 defer_return_flag =
true;
645[[__maybe_unused__]] DEFER_END_ID_1_12:;
646 return DEFER_LOC_ID_0_1;
661 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
664 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
665 [[__maybe_unused__]]
register bool defer_return_flag =
false;
668 goto DEFER_END_ID_1_14;
671 do {
ELLIPSIS_CONTRACT(15, s, abort,
true,
"s",
"assertion",
"substring from non-existing string");}
while (
false);
672 do {
ELLIPSIS_CONTRACT(16, pos < s->
length, abort,
true,
"pos < s→length",
"assertion",
"start of substring is out of bounds");}
while (
false);
674 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
675 unsigned (*DEFER_LOC_ID_1_7)[DEFER_LOC_ID_0_2] = {};
678 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
679 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
680 {
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");}
688 defer_return_flag =
true;
695[[__maybe_unused__]] DEFER_END_ID_1_14:;
696 return DEFER_LOC_ID_0_1;
714 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
717 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
718 [[__maybe_unused__]]
register bool defer_return_flag =
false;
721 goto DEFER_END_ID_1_16;
724 do {
ELLIPSIS_CONTRACT(18, s, abort,
true,
"s",
"assertion",
"copy of non-existing string");}
while (
false);
726 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
727 unsigned (*DEFER_LOC_ID_1_8)[DEFER_LOC_ID_0_2] = {};
730 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
731 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
732 {
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");}
740 defer_return_flag =
true;
747[[__maybe_unused__]] DEFER_END_ID_1_16:;
748 return DEFER_LOC_ID_0_1;
762 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
765 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
766 [[__maybe_unused__]]
register bool defer_return_flag =
false;
769 goto DEFER_END_ID_1_18;
773 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
774 unsigned (*DEFER_LOC_ID_1_9)[DEFER_LOC_ID_0_2] = {};
777 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
778 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
779 {
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");}
787 defer_return_flag =
true;
794[[__maybe_unused__]] DEFER_END_ID_1_18:;
795 return DEFER_LOC_ID_0_1;
817 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
820 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
821 [[__maybe_unused__]]
register bool defer_return_flag =
false;
824 goto DEFER_END_ID_1_20;
828 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
829 unsigned (*DEFER_LOC_ID_1_10)[DEFER_LOC_ID_0_2] = {};
832 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
833 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
834 {
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");}
839 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);
843 defer_return_flag =
true;
850[[__maybe_unused__]] DEFER_END_ID_1_20:;
851 return DEFER_LOC_ID_0_1;
865 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
868 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
869 [[__maybe_unused__]]
register bool defer_return_flag =
false;
872 goto DEFER_END_ID_1_22;
876 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
877 unsigned (*DEFER_LOC_ID_1_11)[DEFER_LOC_ID_0_2] = {};
880 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
881 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
882 {
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");}
887 do {
ELLIPSIS_CONTRACT(24, s && t, unreachable,
false,
"s ∧ t",
"assumption",
"argument FA arrays for concatenation must not be null");}
while (
false);
888 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);
892 defer_return_flag =
true;
899[[__maybe_unused__]] DEFER_END_ID_1_22:;
900 return DEFER_LOC_ID_0_1;
935 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
938 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
939 [[__maybe_unused__]]
register bool defer_return_flag =
false;
942 goto DEFER_END_ID_1_24;
946 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
947 unsigned (*DEFER_LOC_ID_1_12)[DEFER_LOC_ID_0_2] = {};
950 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
951 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
952 {
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");}
960 defer_return_flag =
true;
967[[__maybe_unused__]] DEFER_END_ID_1_24:;
968 return DEFER_LOC_ID_0_1;
990 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
993 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
994 [[__maybe_unused__]]
register bool defer_return_flag =
false;
997 goto DEFER_END_ID_1_26;
1001 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1002 unsigned (*DEFER_LOC_ID_1_13)[DEFER_LOC_ID_0_2] = {};
1005 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1006 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1007 {
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");}
1012 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);
1013 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);
1017 defer_return_flag =
true;
1024[[__maybe_unused__]] DEFER_END_ID_1_26:;
1025 return DEFER_LOC_ID_0_1;
1049 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1052 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1053 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1056 goto DEFER_END_ID_1_28;
1060 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1061 unsigned (*DEFER_LOC_ID_1_14)[DEFER_LOC_ID_0_2] = {};
1064 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1065 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1066 {
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");}
1071 do {
ELLIPSIS_CONTRACT(31, s, unreachable,
false,
"s",
"assumption",
"can only shrink existing array");}
while (
false);
1072 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);
1073 do {
ELLIPSIS_CONTRACT(33, length <= s->
length, unreachable,
false,
"length ≤ s→length",
"assumption",
"can\'t shrink array to make it longer");}
while (
false);
1077 defer_return_flag =
true;
1084[[__maybe_unused__]] DEFER_END_ID_1_28:;
1085 return DEFER_LOC_ID_0_1;
1100 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1103 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1104 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1107 goto DEFER_END_ID_1_30;
1110 do {
ELLIPSIS_CONTRACT(34, s, unreachable,
false,
"s",
"assumption",
"substring from non-existing string");}
while (
false);
1111 do {
ELLIPSIS_CONTRACT(35, pos < s->
length, unreachable,
false,
"pos < s→length",
"assumption",
"start of substring is out of bounds");}
while (
false);
1113 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1114 unsigned (*DEFER_LOC_ID_1_15)[DEFER_LOC_ID_0_2] = {};
1117 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1118 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1119 {
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");}
1127 defer_return_flag =
true;
1134[[__maybe_unused__]] DEFER_END_ID_1_30:;
1135 return DEFER_LOC_ID_0_1;
1153 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1156 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1157 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1160 goto DEFER_END_ID_1_32;
1163 do {
ELLIPSIS_CONTRACT(37, s, unreachable,
false,
"s",
"assumption",
"copy of non-existing string");}
while (
false);
1165 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1166 unsigned (*DEFER_LOC_ID_1_16)[DEFER_LOC_ID_0_2] = {};
1169 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1170 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1171 {
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");}
1179 defer_return_flag =
true;
1186[[__maybe_unused__]] DEFER_END_ID_1_32:;
1187 return DEFER_LOC_ID_0_1;
1217 memset(_ar, 0, _n*
sizeof(_ar[0]));
1243 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1246 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1247 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1250 goto DEFER_END_ID_1_34;
1253 ELLIPSIS_CONTRACT(39, __LOC_ID_0_7, abort,
true,
"__LOC(0, 1)",
"precondition",
"copy of non-existing string");
1256 defer_return_flag =
true;
1263[[__maybe_unused__]] DEFER_END_ID_1_34:;
1264 return DEFER_LOC_ID_0_1;
1291 extern void (qsort)(
void*, size_t, size_t, int (*)(
const void*,
const void*));
1293 size_t rlen = p->
length - offs;
1294 if (rlen < len) len = rlen;
1311 extern void* (bsearch)(
void const*,
void const*,
size_t,
size_t,
int (*)(
const void*,
const void*));
1313 size_t rlen = p->
length - offs;
1314 if (rlen < len) len = rlen;
1336#ifndef DOXYGEN_SPECIAL
1337#define ellipsis_str32_construct(LEN, S) ELLIPSIS_ERROR_CHECK(ellipsis‿str32‿construct, "unable to construct string", LEN, S)
1346#define ELLIPSIS_STR32_CONSTRUCT(S) ellipsis_str32_construct(sizeof S - 1, "" S "")
1371#define ELLIPSIS_STR32_STRING_LITERAL(S) ELLIPSIS_STR32_LITERAL((sizeof(U"" S)/sizeof(U'0')) - 1, U"" S U"")
1392 typeof(
char*) DEFER_LOC_ID_0_1;
1393 if (__func__[0] ==
'm' && __func__[1] ==
'a' && __func__[2] ==
'i' && __func__[3] ==
'n' && !__func__[4]) {
1394 DEFER_LOC_ID_0_1 = (typeof(
char*)) {};
1396 [[__maybe_unused__]]
register unsigned DEFER_LOC_ID_0_2 = 1U;
1397 [[__maybe_unused__]]
register bool defer_return_flag =
false;
1400 goto DEFER_END_ID_1_36;
1403 ELLIPSIS_CONTRACT(40, __LOC_ID_0_9, abort,
true,
"__LOC(0, 1)",
"precondition",
"attempt to copy empty string");
1405 [[__maybe_unused__, __deprecated__(
"dummy variable for better diagnostics")]]
1406 unsigned (*DEFER_LOC_ID_1_17)[DEFER_LOC_ID_0_2] = {};
1409 [[__maybe_unused__, __deprecated__(
"invalid termination of a deferred block")]]
1410 register bool const defer_return_flag =
false, defer_break_flag =
false, defer_continue_flag =
false;
1411 {
ELLIPSIS_CONTRACT(41, ((typeof(DEFER_LOC_ID_0_1))DEFER_LOC_ID_0_1), unreachable,
false,
"defer_return_value",
"conclusion",
"could not copy UTF-32 string to multi-byte");}
1419 defer_return_flag =
true;
1426[[__maybe_unused__]] DEFER_END_ID_1_36:;
1427 return DEFER_LOC_ID_0_1;
#define GNU_ATTR_COUNTED_BY(...)
Definition ellipsis-error.h:59
#define STDC_ATTR_NODISCARD(...)
Definition ellipsis-error.h:68
#define GNU_ATTR_MALLOC(...)
Definition ellipsis-error.h:44
#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
ellipsis‿str32 * ellipsis‿str32‿append‿_Inner(ellipsis‿str32 *restrict s, s->array[0] c)
Definition ellipsis-str32.c:169
ellipsis‿str32 * ellipsis‿str32‿grow‿_Inner(ellipsis‿str32 *restrict s, size_t length)
Definition ellipsis-str32.c:212
ellipsis‿str32 * ellipsis‿str32‿concat‿_Inner(ellipsis‿str32 const *s, ellipsis‿str32 const *t)
Definition ellipsis-str32.c:178
char *() ellipsis‿str32‿dup‿inst(ellipsis‿str32 const *restrict s)
Definition ellipsis-str32.c:866
ellipsis‿str32 * ellipsis‿str32‿sub‿_Inner(ellipsis‿str32 const *s, size_t pos, size_t len)
Definition ellipsis-str32.c:250
ellipsis‿str32 * ellipsis‿str32‿alloc‿_Inner(size_t len)
Definition ellipsis-str32.c:157
ellipsis‿str32‿dup ellipsis‿str32‿dup
ellipsis‿str32 const * ellipsis‿str32‿cpy_const‿_Inner(ellipsis‿str32 const *restrict s)
Definition ellipsis-str32.c:267
ellipsis‿str32 * ellipsis‿str32‿shrink‿_Inner(ellipsis‿str32 s[restrict static 1], size_t length)
Definition ellipsis-str32.c:238
ellipsis‿str32 * ellipsis‿str32‿concat_inplace‿_Inner(ellipsis‿str32 const *s0, ellipsis‿str32 const *t)
Definition ellipsis-str32.c:193
int ellipsis‿str32‿fputs_entities(ellipsis‿str32 const *restrict s, FILE *stream)
Definition ellipsis-str32.c:758
thread_local bool volatile ellipsis‿contracts‿verbose‿dynamic
#define ELLIPSIS_CONTRACT(COUNT, COND, ACTION, VERB, CSTR, CTYPE,...)
Definition ellipsis-str32.h:86
thread_local bool volatile ellipsis‿contracts‿proceed‿dynamic
thread_local bool volatile ellipsis‿contracts‿ignore‿dynamic
A structure with a flexible array member of base type ellipsis‿str32‿base.
Definition ellipsis-str32.h:156
ellipsis‿str32 * ellipsis‿str32‿remove(ellipsis‿str32 s[restrict static 1], size_t)
Remove (at most) the indicated amount of elements from the ellipsis‿str32 return a new one and delete...
Definition ellipsis-str32.c:118
int ellipsis‿str32‿fputs(ellipsis‿str32 const *restrict, FILE *)
Write a ellipsis‿str32 to a stream.
ellipsis‿str32 * ellipsis‿str32‿alloc(size_t len)
Allocate a ellipsis‿str32 with elements as given by the parameter.
Definition ellipsis-str32.h:321
ellipsis‿str32 const * ellipsis‿str32‿cpy_const‿_Insta(ellipsis‿str32 const *restrict s)
Copy or link to a const-qualified ellipsis‿str32.
Definition ellipsis-str32.c:596
ellipsis‿str32 * ellipsis‿str32‿cpy(ellipsis‿str32 const *restrict __LOC_ID_0_7)
Allocate a ellipsis‿str32 and copy the data to which the parameter points into it.
Definition ellipsis-str32.h:1241
ellipsis‿str32 * ellipsis‿str32‿concat(ellipsis‿str32 const *s, ellipsis‿str32 const *t)
Concatenate two ellipsis‿str32 into a new one.
Definition ellipsis-str32.h:424
int ellipsis‿str32‿compareInternal(void const *A, void const *B)
Definition ellipsis-str32.h:1271
ellipsis‿str32 * ellipsis‿str32‿alloc‿_Insta(size_t len)
Allocate a ellipsis‿str32 with elements as given by the parameter.
Definition ellipsis-str32.c:282
size_t const length
Current length of this instance.
Definition ellipsis-str32.h:165
void ellipsis‿str32‿base‿destroy(size_t _n, ellipsis‿str32‿base _ar[static _n])
Destroy an element of type ellipsis‿str32‿base.
Definition ellipsis-str32.h:1216
int ellipsis‿str32‿base‿compare(ellipsis‿str32‿base const *__LOC_ID_0_1, ellipsis‿str32‿base const *__LOC_ID_0_2)
compare two char32_t by value
Definition ellipsis-str32.h:27
ellipsis‿str32 * ellipsis‿str32‿concat_inplace(ellipsis‿str32 const *s, ellipsis‿str32 const *t)
Concatenate two ellipsis‿str32 into a new one and delete s.
Definition ellipsis-str32.h:494
ellipsis‿str32 * ellipsis‿str32‿append‿_Ctra(ellipsis‿str32 *restrict s, ellipsis‿str32‿base c)
Append a new element to a ellipsis‿str32 and return a new object.
Definition ellipsis-str32.h:815
ellipsis‿str32 * ellipsis‿str32‿shrink‿_Insta(ellipsis‿str32 s[restrict static 1], size_t length)
Shrink the ellipsis‿str32 to exactly the indicated amount of elements return a new one and delete the...
Definition ellipsis-str32.c:514
ellipsis‿str32 * ellipsis‿str32‿sub(ellipsis‿str32 const *restrict s, size_t pos, size_t len)
Allocate a ellipsis‿str32 with len elements and copy the data from *s at position pos onward.
Definition ellipsis-str32.h:659
ellipsis‿str32 const * ellipsis‿str32‿cpy_const(ellipsis‿str32 const *restrict s)
Copy or link to a const-qualified ellipsis‿str32.
Definition ellipsis-str32.h:712
void ellipsis‿str32‿cmove(ellipsis‿str32 const *__LOC_ID_0_5[restrict static 1], ellipsis‿str32 const **restrict __LOC_ID_0_6)
Move a ellipsis‿str32 const pointed to by the second parameter to the one pointed to by the first.
Definition ellipsis-str32.h:300
void ellipsis‿str32‿move(ellipsis‿str32 *__LOC_ID_0_3[restrict static 1], ellipsis‿str32 **restrict __LOC_ID_0_4)
Move a ellipsis‿str32 pointed to by the second parameter to the one pointed to by the first.
Definition ellipsis-str32.h:280
ellipsis‿str32 * ellipsis‿str32‿concat_inplace‿_Ctra(ellipsis‿str32 const *s, ellipsis‿str32 const *t)
Concatenate two ellipsis‿str32 into a new one and delete s.
Definition ellipsis-str32.h:933
ellipsis‿str32 * ellipsis‿str32‿grow‿_Insta(ellipsis‿str32 *restrict s, size_t length)
Grow the ellipsis‿str32 to (at least) the indicated amount of elements return a new one and delete th...
Definition ellipsis-str32.c:466
size_t length_mod
Modifiable length of this instance.
Definition ellipsis-str32.h:172
ellipsis‿str32 * ellipsis‿str32‿sub‿_Ctra(ellipsis‿str32 const *restrict s, size_t pos, size_t len)
Allocate a ellipsis‿str32 with len elements and copy the data from *s at position pos onward.
Definition ellipsis-str32.h:1098
ellipsis‿str32 * ellipsis‿str32‿concat‿_Ctra(ellipsis‿str32 const *s, ellipsis‿str32 const *t)
Concatenate two ellipsis‿str32 into a new one.
Definition ellipsis-str32.h:863
ellipsis‿str32 * ellipsis‿str32‿shrink‿_Ctra(ellipsis‿str32 s[restrict static 1], size_t length)
Shrink the ellipsis‿str32 to exactly the indicated amount of elements return a new one and delete the...
Definition ellipsis-str32.h:1047
ellipsis‿str32 const * ellipsis‿str32‿cpy_const‿_Ctra(ellipsis‿str32 const *restrict s)
Copy or link to a const-qualified ellipsis‿str32.
Definition ellipsis-str32.h:1151
ellipsis‿str32 * ellipsis‿str32‿alloc‿_Ctra(size_t len)
Allocate a ellipsis‿str32 with elements as given by the parameter.
Definition ellipsis-str32.h:760
void ellipsis‿str32‿delete(ellipsis‿str32 const *)
Delete a ellipsis‿str32 pointed to by the parameter.
Definition ellipsis-str32.c:625
ellipsis‿str32 * ellipsis‿str32‿shrink(ellipsis‿str32 s[restrict static 1], size_t length)
Shrink the ellipsis‿str32 to exactly the indicated amount of elements return a new one and delete the...
Definition ellipsis-str32.h:608
ellipsis‿str32‿base const * ellipsis‿str32‿search(ellipsis‿str32‿base const el[static 1], ellipsis‿str32 const *p, size_t offs, size_t len)
search for an element in a ellipsis‿str32
Definition ellipsis-str32.h:1310
ellipsis‿str32 * ellipsis‿str32‿grow‿_Ctra(ellipsis‿str32 *restrict s, size_t length)
Grow the ellipsis‿str32 to (at least) the indicated amount of elements return a new one and delete th...
Definition ellipsis-str32.h:988
ellipsis‿str32 * ellipsis‿str32‿append(ellipsis‿str32 *restrict s, ellipsis‿str32‿base c)
Append a new element to a ellipsis‿str32 and return a new object.
Definition ellipsis-str32.h:376
ellipsis‿str32 * ellipsis‿str32‿concat_inplace‿_Insta(ellipsis‿str32 const *s, ellipsis‿str32 const *t)
Concatenate two ellipsis‿str32 into a new one and delete s.
Definition ellipsis-str32.c:422
char32_t ellipsis‿str32‿base
Definition ellipsis-str32.h:20
ellipsis‿str32 * ellipsis‿str32‿append‿_Insta(ellipsis‿str32 *restrict s, ellipsis‿str32‿base c)
Append a new element to a ellipsis‿str32 and return a new object.
Definition ellipsis-str32.c:326
ellipsis‿str32 * ellipsis‿str32‿construct(size_t __LOC_ID_0_8, char const [static __LOC_ID_0_8])
Construct a ellipsis‿str32 from a character array of length len.
ellipsis‿str32‿base array[]
The current data array.
Definition ellipsis-str32.h:190
ellipsis‿str32 * ellipsis‿str32‿concat‿_Insta(ellipsis‿str32 const *s, ellipsis‿str32 const *t)
Concatenate two ellipsis‿str32 into a new one.
Definition ellipsis-str32.c:363
size_t const capacity
Maximal length of this instance.
Definition ellipsis-str32.h:182
ellipsis‿str32 * ellipsis‿str32‿grow(ellipsis‿str32 *restrict s, size_t length)
Grow the ellipsis‿str32 to (at least) the indicated amount of elements return a new one and delete th...
Definition ellipsis-str32.h:549
ellipsis‿str32 * ellipsis‿str32‿sub‿_Insta(ellipsis‿str32 const *restrict s, size_t pos, size_t len)
Allocate a ellipsis‿str32 with len elements and copy the data from *s at position pos onward.
Definition ellipsis-str32.c:554
void ellipsis‿str32‿sort(ellipsis‿str32 *p, size_t offs, size_t len)
sort a ellipsis‿str32 in place.
Definition ellipsis-str32.h:1290
int ellipsis‿str32‿compare(ellipsis‿str32 const *s, ellipsis‿str32 const *t)
Compare two arrays lexicographically.
Definition ellipsis-str32.c:129