1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
|
/* DO NOT EDIT! GENERATED AUTOMATICALLY! */
/* Dummy replacement for part of the public API of the libtextstyle library.
Copyright (C) 2006-2007, 2019-2020 Free Software Foundation, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>. */
/* Written by Bruno Haible <bruno@clisp.org>, 2019. */
/* This file is used as replacement when libtextstyle with its include file
<textstyle.h> is not found.
It supports the essential API and implements it in a way that does not
provide text styling. That is, it produces plain text output via <stdio.h>
FILE objects.
Thus, it allows a package to be build with or without a dependency to
libtextstyle, with very few occurrences of '#if HAVE_LIBTEXTSTYLE'.
Restriction:
It assumes that freopen() is not being called on stdout and stderr. */
#ifndef _TEXTSTYLE_H
#define _TEXTSTYLE_H
#include <errno.h>
#include <stdarg.h>
#include <stdbool.h>
#include <stddef.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#if HAVE_TCDRAIN
# include <termios.h>
#endif
/* ----------------------------- From ostream.h ----------------------------- */
/* Describes the scope of a flush operation. */
typedef enum
{
/* Flushes buffers in this ostream_t.
Use this value if you want to write to the underlying ostream_t. */
FLUSH_THIS_STREAM = 0,
/* Flushes all buffers in the current process.
Use this value if you want to write to the same target through a
different file descriptor or a FILE stream. */
FLUSH_THIS_PROCESS = 1,
/* Flushes buffers in the current process and attempts to flush the buffers
in the kernel.
Use this value so that some other process (or the kernel itself)
may write to the same target. */
FLUSH_ALL = 2
} ostream_flush_scope_t;
/* An output stream is an object to which one can feed a sequence of bytes. */
typedef FILE * ostream_t;
static inline void
ostream_write_mem (ostream_t stream, const void *data, size_t len)
{
if (len > 0)
fwrite (data, 1, len, stream);
}
static inline void
ostream_flush (ostream_t stream, ostream_flush_scope_t scope)
{
fflush (stream);
if (scope == FLUSH_ALL)
{
int fd = fileno (stream);
if (fd >= 0)
{
/* For streams connected to a disk file: */
fsync (fd);
#if HAVE_TCDRAIN
/* For streams connected to a terminal: */
{
int retval;
do
retval = tcdrain (fd);
while (retval < 0 && errno == EINTR);
}
#endif
}
}
}
static inline void
ostream_free (ostream_t stream)
{
if (stream == stdin || stream == stderr)
fflush (stream);
else
fclose (stream);
}
static inline void
ostream_write_str (ostream_t stream, const char *string)
{
ostream_write_mem (stream, string, strlen (string));
}
static inline ptrdiff_t ostream_printf (ostream_t stream,
const char *format, ...)
#if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 1) || defined __clang__
__attribute__ ((__format__ (__printf__, 2, 3)))
#endif
;
static inline ptrdiff_t
ostream_printf (ostream_t stream, const char *format, ...)
{
va_list args;
char *temp_string;
ptrdiff_t ret;
va_start (args, format);
ret = vasprintf (&temp_string, format, args);
va_end (args);
if (ret >= 0)
{
if (ret > 0)
ostream_write_str (stream, temp_string);
free (temp_string);
}
return ret;
}
static inline ptrdiff_t ostream_vprintf (ostream_t stream,
const char *format, va_list args)
#if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 1) || defined __clang__
__attribute__ ((__format__ (__printf__, 2, 0)))
#endif
;
static inline ptrdiff_t
ostream_vprintf (ostream_t stream, const char *format, va_list args)
{
char *temp_string;
ptrdiff_t ret = vasprintf (&temp_string, format, args);
if (ret >= 0)
{
if (ret > 0)
ostream_write_str (stream, temp_string);
free (temp_string);
}
return ret;
}
/* ------------------------- From styled-ostream.h ------------------------- */
typedef ostream_t styled_ostream_t;
#define styled_ostream_write_mem ostream_write_mem
#define styled_ostream_flush ostream_flush
#define styled_ostream_free ostream_free
static inline void
styled_ostream_begin_use_class (styled_ostream_t stream _GL_UNUSED,
const char *classname _GL_UNUSED)
{
}
static inline void
styled_ostream_end_use_class (styled_ostream_t stream _GL_UNUSED,
const char *classname _GL_UNUSED)
{
}
static inline const char *
styled_ostream_get_hyperlink_ref (styled_ostream_t stream _GL_UNUSED)
{
return NULL;
}
static inline const char *
styled_ostream_get_hyperlink_id (styled_ostream_t stream _GL_UNUSED)
{
return NULL;
}
static inline void
styled_ostream_set_hyperlink (styled_ostream_t stream _GL_UNUSED,
const char *ref _GL_UNUSED,
const char *id _GL_UNUSED)
{
}
static inline void
styled_ostream_flush_to_current_style (styled_ostream_t stream _GL_UNUSED)
{
}
/* -------------------------- From file-ostream.h -------------------------- */
typedef ostream_t file_ostream_t;
#define file_ostream_write_mem ostream_write_mem
#define file_ostream_flush ostream_flush
#define file_ostream_free ostream_free
static inline file_ostream_t
file_ostream_create (FILE *fp)
{
return fp;
}
/* --------------------------- From fd-ostream.h --------------------------- */
typedef ostream_t fd_ostream_t;
#define fd_ostream_write_mem ostream_write_mem
#define fd_ostream_flush ostream_flush
#define fd_ostream_free ostream_free
static inline fd_ostream_t
fd_ostream_create (int fd, const char *filename _GL_UNUSED,
bool buffered _GL_UNUSED)
{
if (fd == 1)
return stdout;
else if (fd == 2)
return stderr;
else
return fdopen (fd, "w");
}
/* -------------------------- From term-ostream.h -------------------------- */
typedef int term_color_t;
enum
{
COLOR_DEFAULT = -1 /* unknown */
};
typedef enum
{
WEIGHT_NORMAL = 0,
WEIGHT_BOLD,
WEIGHT_DEFAULT = WEIGHT_NORMAL
} term_weight_t;
typedef enum
{
POSTURE_NORMAL = 0,
POSTURE_ITALIC, /* same as oblique */
POSTURE_DEFAULT = POSTURE_NORMAL
} term_posture_t;
typedef enum
{
UNDERLINE_OFF = 0,
UNDERLINE_ON,
UNDERLINE_DEFAULT = UNDERLINE_OFF
} term_underline_t;
typedef ostream_t term_ostream_t;
#define term_ostream_write_mem ostream_write_mem
#define term_ostream_flush ostream_flush
#define term_ostream_free ostream_free
static inline term_color_t
term_ostream_get_color (term_ostream_t stream _GL_UNUSED)
{
return COLOR_DEFAULT;
}
static inline void
term_ostream_set_color (term_ostream_t stream _GL_UNUSED,
term_color_t color _GL_UNUSED)
{
}
static inline term_color_t
term_ostream_get_bgcolor (term_ostream_t stream _GL_UNUSED)
{
return COLOR_DEFAULT;
}
static inline void
term_ostream_set_bgcolor (term_ostream_t stream _GL_UNUSED,
term_color_t color _GL_UNUSED)
{
}
static inline term_weight_t
term_ostream_get_weight (term_ostream_t stream _GL_UNUSED)
{
return WEIGHT_DEFAULT;
}
static inline void
term_ostream_set_weight (term_ostream_t stream _GL_UNUSED,
term_weight_t weight _GL_UNUSED)
{
}
static inline term_posture_t
term_ostream_get_posture (term_ostream_t stream _GL_UNUSED)
{
return POSTURE_DEFAULT;
}
static inline void
term_ostream_set_posture (term_ostream_t stream _GL_UNUSED,
term_posture_t posture _GL_UNUSED)
{
}
static inline term_underline_t
term_ostream_get_underline (term_ostream_t stream _GL_UNUSED)
{
return UNDERLINE_DEFAULT;
}
static inline void
term_ostream_set_underline (term_ostream_t stream _GL_UNUSED,
term_underline_t underline _GL_UNUSED)
{
}
static inline const char *
term_ostream_get_hyperlink_ref (term_ostream_t stream _GL_UNUSED)
{
return NULL;
}
static inline const char *
term_ostream_get_hyperlink_id (term_ostream_t stream _GL_UNUSED)
{
return NULL;
}
static inline void
term_ostream_set_hyperlink (term_ostream_t stream _GL_UNUSED,
const char *ref _GL_UNUSED,
const char *id _GL_UNUSED)
{
}
static inline void
term_ostream_flush_to_current_style (term_ostream_t stream)
{
fflush (stream);
}
typedef enum
{
TTYCTL_AUTO = 0, /* Automatic best-possible choice. */
TTYCTL_NONE, /* No control.
Result: Garbled output can occur, and the terminal can
be left in any state when the program is interrupted. */
TTYCTL_PARTIAL, /* Signal handling.
Result: Garbled output can occur, but the terminal will
be left in the default state when the program is
interrupted. */
TTYCTL_FULL /* Signal handling and disabling echo and flush-upon-signal.
Result: No garbled output, and the the terminal will
be left in the default state when the program is
interrupted. */
} ttyctl_t;
static inline term_ostream_t
term_ostream_create (int fd, const char *filename,
ttyctl_t tty_control _GL_UNUSED)
{
return fd_ostream_create (fd, filename, true);
}
/* ----------------------- From term-styled-ostream.h ----------------------- */
typedef styled_ostream_t term_styled_ostream_t;
#define term_styled_ostream_write_mem ostream_write_mem
#define term_styled_ostream_flush ostream_flush
#define term_styled_ostream_free ostream_free
#define term_styled_ostream_begin_use_class styled_ostream_begin_use_class
#define term_styled_ostream_end_use_class styled_ostream_end_use_class
#define term_styled_ostream_get_hyperlink_ref styled_ostream_get_hyperlink_ref
#define term_styled_ostream_get_hyperlink_id styled_ostream_get_hyperlink_id
#define term_styled_ostream_set_hyperlink styled_ostream_set_hyperlink
#define term_styled_ostream_flush_to_current_style styled_ostream_flush_to_current_style
static inline term_styled_ostream_t
term_styled_ostream_create (int fd, const char *filename,
ttyctl_t tty_control _GL_UNUSED,
const char *css_filename _GL_UNUSED)
{
return fd_ostream_create (fd, filename, true);
}
/* ----------------------- From html-styled-ostream.h ----------------------- */
typedef styled_ostream_t html_styled_ostream_t;
static inline html_styled_ostream_t
html_styled_ostream_create (ostream_t destination _GL_UNUSED,
const char *css_filename _GL_UNUSED)
{
abort ();
return NULL;
}
/* ------------------------------ From color.h ------------------------------ */
#define color_test_mode false
enum color_option { color_no, color_tty, color_yes, color_html };
#define color_mode color_no
#define style_file_name NULL
static inline bool
handle_color_option (const char *option _GL_UNUSED)
{
return false;
}
static inline void
handle_style_option (const char *option _GL_UNUSED)
{
}
static inline void
print_color_test (void)
{
abort ();
}
static inline void
style_file_prepare (const char *style_file_envvar _GL_UNUSED,
const char *stylesdir_envvar _GL_UNUSED,
const char *stylesdir_after_install _GL_UNUSED,
const char *default_style_file _GL_UNUSED)
{
}
/* ------------------------------ From misc.h ------------------------------ */
static inline styled_ostream_t
styled_ostream_create (int fd, const char *filename,
ttyctl_t tty_control _GL_UNUSED,
const char *css_filename _GL_UNUSED)
{
return fd_ostream_create (fd, filename, true);
}
static inline void
libtextstyle_set_failure_exit_code (int exit_code _GL_UNUSED)
{
}
#endif /* _TEXTSTYLE_H */
|