src/printf.c

Sun, 23 Nov 2025 13:15:19 +0100

author
Mike Becker <universe@uap-core.de>
date
Sun, 23 Nov 2025 13:15:19 +0100
changeset 1508
dfc0ddd9571e
parent 1490
30ea9885cf04
permissions
-rw-r--r--

optimize sorted insertion by using the infimum instead of the supremum

The reason is that the supremum returns the equal element with the smallest index, and we want the largest.
Therefore, we use the infimum, which already gives us the largest index when there are equal elements, and increase the index by one. The infimum is also guaranteed to exist in that case.

599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 *
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 * Copyright 2021 Mike Becker, Olaf Wintermann All rights reserved.
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 *
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 * Redistribution and use in source and binary forms, with or without
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 * modification, are permitted provided that the following conditions are met:
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 *
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 * 1. Redistributions of source code must retain the above copyright
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 * notice, this list of conditions and the following disclaimer.
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 *
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * 2. Redistributions in binary form must reproduce the above copyright
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 * notice, this list of conditions and the following disclaimer in the
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 * documentation and/or other materials provided with the distribution.
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 *
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 * POSSIBILITY OF SUCH DAMAGE.
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27 */
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
28
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
29 #include "cx/printf.h"
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
30
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
31 #include <stdio.h>
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
32 #include <string.h>
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
33
643
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
34 #ifndef CX_PRINTF_SBO_SIZE
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
35 #define CX_PRINTF_SBO_SIZE 512
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
36 #endif
926
8fdd8d78c14b fix several survivors of east-const and some missing consts
Mike Becker <universe@uap-core.de>
parents: 890
diff changeset
37 const unsigned cx_printf_sbo_size = CX_PRINTF_SBO_SIZE;
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
38
643
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
39 int cx_fprintf(
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
40 void *stream,
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
41 cx_write_func wfc,
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 849
diff changeset
42 const char *fmt,
643
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
43 ...
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
44 ) {
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
45 int ret;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
46 va_list ap;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
47 va_start(ap, fmt);
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
48 ret = cx_vfprintf(stream, wfc, fmt, ap);
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
49 va_end(ap);
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
50 return ret;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
51 }
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
52
644
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
53 int cx_vfprintf(
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
54 void *stream,
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
55 cx_write_func wfc,
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 849
diff changeset
56 const char *fmt,
644
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
57 va_list ap
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
58 ) {
643
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
59 char buf[CX_PRINTF_SBO_SIZE];
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
60 va_list ap2;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
61 va_copy(ap2, ap);
643
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
62 int ret = vsnprintf(buf, CX_PRINTF_SBO_SIZE, fmt, ap);
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
63 if (ret < 0) {
1490
30ea9885cf04 exclude almost impossible negative return values for snprintf() from code coverage
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
64 // LCOV_EXCL_START
811
b02ad05c7f2d fix missing va_end() calls
Mike Becker <universe@uap-core.de>
parents: 810
diff changeset
65 va_end(ap2);
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
66 return ret;
1490
30ea9885cf04 exclude almost impossible negative return values for snprintf() from code coverage
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
67 // LCOV_EXCL_STOP
643
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
68 } else if (ret < CX_PRINTF_SBO_SIZE) {
811
b02ad05c7f2d fix missing va_end() calls
Mike Becker <universe@uap-core.de>
parents: 810
diff changeset
69 va_end(ap2);
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
70 return (int) wfc(buf, 1, ret, stream);
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
71 } else {
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
72 int len = ret + 1;
1319
aa1f580f8f59 add convenience macros for using the default allocator - relates to #669
Mike Becker <universe@uap-core.de>
parents: 1318
diff changeset
73 char *newbuf = cxMallocDefault(len);
1065
6eb7b54975ee improve coverage metrics
Mike Becker <universe@uap-core.de>
parents: 926
diff changeset
74 if (!newbuf) { // LCOV_EXCL_START
811
b02ad05c7f2d fix missing va_end() calls
Mike Becker <universe@uap-core.de>
parents: 810
diff changeset
75 va_end(ap2);
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
76 return -1;
1065
6eb7b54975ee improve coverage metrics
Mike Becker <universe@uap-core.de>
parents: 926
diff changeset
77 } // LCOV_EXCL_STOP
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
78
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
79 ret = vsnprintf(newbuf, len, fmt, ap2);
811
b02ad05c7f2d fix missing va_end() calls
Mike Becker <universe@uap-core.de>
parents: 810
diff changeset
80 va_end(ap2);
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
81 if (ret > 0) {
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
82 ret = (int) wfc(newbuf, 1, ret, stream);
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
83 }
1319
aa1f580f8f59 add convenience macros for using the default allocator - relates to #669
Mike Becker <universe@uap-core.de>
parents: 1318
diff changeset
84 cxFreeDefault(newbuf);
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
85 }
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
86 return ret;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
87 }
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
88
644
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
89 cxmutstr cx_asprintf_a(
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 849
diff changeset
90 const CxAllocator *allocator,
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 849
diff changeset
91 const char *fmt,
644
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
92 ...
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
93 ) {
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
94 va_list ap;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
95 va_start(ap, fmt);
805
26500fc24058 add constant for reading out printf sbo size - relates to #343
Mike Becker <universe@uap-core.de>
parents: 693
diff changeset
96 cxmutstr ret = cx_vasprintf_a(allocator, fmt, ap);
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
97 va_end(ap);
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
98 return ret;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
99 }
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
100
644
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
101 cxmutstr cx_vasprintf_a(
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 849
diff changeset
102 const CxAllocator *a,
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 849
diff changeset
103 const char *fmt,
644
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
104 va_list ap
fcaa0891ef28 reformat file
Mike Becker <universe@uap-core.de>
parents: 643
diff changeset
105 ) {
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
106 cxmutstr s;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
107 s.ptr = NULL;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
108 s.length = 0;
643
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
109 char buf[CX_PRINTF_SBO_SIZE];
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
110 va_list ap2;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
111 va_copy(ap2, ap);
643
5700ba9154ab #228 make buffer sizes adjustable at compile time
Mike Becker <universe@uap-core.de>
parents: 634
diff changeset
112 int ret = vsnprintf(buf, CX_PRINTF_SBO_SIZE, fmt, ap);
812
fda0f1910d7e fix unnecessary printf retry when printed string is empty
Mike Becker <universe@uap-core.de>
parents: 811
diff changeset
113 if (ret >= 0 && ret < CX_PRINTF_SBO_SIZE) {
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
114 s.ptr = cxMalloc(a, ret + 1);
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
115 if (s.ptr) {
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
116 s.length = (size_t) ret;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
117 memcpy(s.ptr, buf, ret);
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
118 s.ptr[s.length] = '\0';
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
119 }
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
120 } else {
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
121 int len = ret + 1;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
122 s.ptr = cxMalloc(a, len);
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
123 if (s.ptr) {
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
124 ret = vsnprintf(s.ptr, len, fmt, ap2);
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
125 if (ret < 0) {
1490
30ea9885cf04 exclude almost impossible negative return values for snprintf() from code coverage
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
126 // LCOV_EXCL_START
1318
12fa1d37fe48 allow changing the cxDefaultAllocator - resolves #669
Mike Becker <universe@uap-core.de>
parents: 1285
diff changeset
127 cxFree(a, s.ptr);
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
128 s.ptr = NULL;
1490
30ea9885cf04 exclude almost impossible negative return values for snprintf() from code coverage
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
129 // LCOV_EXCL_STOP
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
130 } else {
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
131 s.length = (size_t) ret;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
132 }
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
133 }
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
134 }
811
b02ad05c7f2d fix missing va_end() calls
Mike Becker <universe@uap-core.de>
parents: 810
diff changeset
135 va_end(ap2);
599
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
136 return s;
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
137 }
6536a9a75b71 #222 add printf-like functions
Mike Becker <universe@uap-core.de>
parents:
diff changeset
138
1285
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
139 int cx_sprintf_a(
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
140 const CxAllocator *alloc,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
141 char **str,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
142 size_t *len,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
143 const char *fmt,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
144 ...
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
145 ) {
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
146 va_list ap;
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
147 va_start(ap, fmt);
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
148 int ret = cx_vsprintf_a(alloc, str, len, fmt, ap);
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
149 va_end(ap);
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
150 return ret;
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
151 }
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
152
1285
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
153 int cx_vsprintf_a(
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
154 const CxAllocator *alloc,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
155 char **str,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
156 size_t *len,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
157 const char *fmt,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
158 va_list ap
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
159 ) {
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
160 va_list ap2;
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
161 va_copy(ap2, ap);
849
edb9f875b7f9 improves interface of cx_sprintf() variants
Mike Becker <universe@uap-core.de>
parents: 813
diff changeset
162 int ret = vsnprintf(*str, *len, fmt, ap);
edb9f875b7f9 improves interface of cx_sprintf() variants
Mike Becker <universe@uap-core.de>
parents: 813
diff changeset
163 if ((unsigned) ret >= *len) {
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
164 unsigned newlen = ret + 1;
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
165 char *ptr = cxRealloc(alloc, *str, newlen);
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
166 if (ptr) {
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
167 int newret = vsnprintf(ptr, newlen, fmt, ap2);
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
168 if (newret < 0) {
1490
30ea9885cf04 exclude almost impossible negative return values for snprintf() from code coverage
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
169 cxFree(alloc, ptr); // LCOV_EXCL_LINE
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
170 } else {
849
edb9f875b7f9 improves interface of cx_sprintf() variants
Mike Becker <universe@uap-core.de>
parents: 813
diff changeset
171 *len = newlen;
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
172 *str = ptr;
813
aba6d37b78bd improve program flow - relates to #353
Mike Becker <universe@uap-core.de>
parents: 812
diff changeset
173 ret = newret;
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
174 }
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
175 }
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
176 }
813
aba6d37b78bd improve program flow - relates to #353
Mike Becker <universe@uap-core.de>
parents: 812
diff changeset
177 va_end(ap2);
aba6d37b78bd improve program flow - relates to #353
Mike Becker <universe@uap-core.de>
parents: 812
diff changeset
178 return ret;
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
179 }
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
180
1285
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
181 int cx_sprintf_sa(
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
182 const CxAllocator *alloc,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
183 char *buf,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
184 size_t *len,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
185 char **str,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
186 const char *fmt,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
187 ...
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
188 ) {
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
189 va_list ap;
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
190 va_start(ap, fmt);
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
191 int ret = cx_vsprintf_sa(alloc, buf, len, str, fmt, ap);
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
192 va_end(ap);
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
193 return ret;
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
194 }
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
195
1285
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
196 int cx_vsprintf_sa(
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
197 const CxAllocator *alloc,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
198 char *buf,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
199 size_t *len,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
200 char **str,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
201 const char *fmt,
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
202 va_list ap
7acbaa74fbd0 fix allocator of some printf.h functions not being const - fixes #611
Mike Becker <universe@uap-core.de>
parents: 1065
diff changeset
203 ) {
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
204 va_list ap2;
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
205 va_copy(ap2, ap);
849
edb9f875b7f9 improves interface of cx_sprintf() variants
Mike Becker <universe@uap-core.de>
parents: 813
diff changeset
206 int ret = vsnprintf(buf, *len, fmt, ap);
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
207 *str = buf;
849
edb9f875b7f9 improves interface of cx_sprintf() variants
Mike Becker <universe@uap-core.de>
parents: 813
diff changeset
208 if ((unsigned) ret >= *len) {
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
209 unsigned newlen = ret + 1;
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
210 char *ptr = cxMalloc(alloc, newlen);
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
211 if (ptr) {
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
212 int newret = vsnprintf(ptr, newlen, fmt, ap2);
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
213 if (newret < 0) {
1490
30ea9885cf04 exclude almost impossible negative return values for snprintf() from code coverage
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
214 cxFree(alloc, ptr); // LCOV_EXCL_LINE
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
215 } else {
849
edb9f875b7f9 improves interface of cx_sprintf() variants
Mike Becker <universe@uap-core.de>
parents: 813
diff changeset
216 *len = newlen;
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
217 *str = ptr;
813
aba6d37b78bd improve program flow - relates to #353
Mike Becker <universe@uap-core.de>
parents: 812
diff changeset
218 ret = newret;
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
219 }
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
220 }
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
221 }
813
aba6d37b78bd improve program flow - relates to #353
Mike Becker <universe@uap-core.de>
parents: 812
diff changeset
222 va_end(ap2);
aba6d37b78bd improve program flow - relates to #353
Mike Becker <universe@uap-core.de>
parents: 812
diff changeset
223 return ret;
810
85859399a0cc add cx_sprintf() variants - fixes #353
Mike Becker <universe@uap-core.de>
parents: 805
diff changeset
224 }

mercurial