1*6236dae4SAndroid Build Coastguard Worker /***************************************************************************
2*6236dae4SAndroid Build Coastguard Worker * _ _ ____ _
3*6236dae4SAndroid Build Coastguard Worker * Project ___| | | | _ \| |
4*6236dae4SAndroid Build Coastguard Worker * / __| | | | |_) | |
5*6236dae4SAndroid Build Coastguard Worker * | (__| |_| | _ <| |___
6*6236dae4SAndroid Build Coastguard Worker * \___|\___/|_| \_\_____|
7*6236dae4SAndroid Build Coastguard Worker *
8*6236dae4SAndroid Build Coastguard Worker * Copyright (C) Daniel Stenberg, <[email protected]>, et al.
9*6236dae4SAndroid Build Coastguard Worker *
10*6236dae4SAndroid Build Coastguard Worker * This software is licensed as described in the file COPYING, which
11*6236dae4SAndroid Build Coastguard Worker * you should have received as part of this distribution. The terms
12*6236dae4SAndroid Build Coastguard Worker * are also available at https://curl.se/docs/copyright.html.
13*6236dae4SAndroid Build Coastguard Worker *
14*6236dae4SAndroid Build Coastguard Worker * You may opt to use, copy, modify, merge, publish, distribute and/or sell
15*6236dae4SAndroid Build Coastguard Worker * copies of the Software, and permit persons to whom the Software is
16*6236dae4SAndroid Build Coastguard Worker * furnished to do so, under the terms of the COPYING file.
17*6236dae4SAndroid Build Coastguard Worker *
18*6236dae4SAndroid Build Coastguard Worker * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
19*6236dae4SAndroid Build Coastguard Worker * KIND, either express or implied.
20*6236dae4SAndroid Build Coastguard Worker *
21*6236dae4SAndroid Build Coastguard Worker * SPDX-License-Identifier: curl
22*6236dae4SAndroid Build Coastguard Worker *
23*6236dae4SAndroid Build Coastguard Worker ***************************************************************************/
24*6236dae4SAndroid Build Coastguard Worker #include "tool_setup.h"
25*6236dae4SAndroid Build Coastguard Worker
26*6236dae4SAndroid Build Coastguard Worker #include "curlx.h"
27*6236dae4SAndroid Build Coastguard Worker
28*6236dae4SAndroid Build Coastguard Worker #include "tool_cfgable.h"
29*6236dae4SAndroid Build Coastguard Worker #include "tool_msgs.h"
30*6236dae4SAndroid Build Coastguard Worker #include "tool_cb_prg.h"
31*6236dae4SAndroid Build Coastguard Worker #include "terminal.h"
32*6236dae4SAndroid Build Coastguard Worker
33*6236dae4SAndroid Build Coastguard Worker #include "memdebug.h" /* keep this as LAST include */
34*6236dae4SAndroid Build Coastguard Worker
35*6236dae4SAndroid Build Coastguard Worker #define WARN_PREFIX "Warning: "
36*6236dae4SAndroid Build Coastguard Worker #define NOTE_PREFIX "Note: "
37*6236dae4SAndroid Build Coastguard Worker #define ERROR_PREFIX "curl: "
38*6236dae4SAndroid Build Coastguard Worker
39*6236dae4SAndroid Build Coastguard Worker static void voutf(struct GlobalConfig *config,
40*6236dae4SAndroid Build Coastguard Worker const char *prefix,
41*6236dae4SAndroid Build Coastguard Worker const char *fmt,
42*6236dae4SAndroid Build Coastguard Worker va_list ap) CURL_PRINTF(3, 0);
43*6236dae4SAndroid Build Coastguard Worker
voutf(struct GlobalConfig * config,const char * prefix,const char * fmt,va_list ap)44*6236dae4SAndroid Build Coastguard Worker static void voutf(struct GlobalConfig *config,
45*6236dae4SAndroid Build Coastguard Worker const char *prefix,
46*6236dae4SAndroid Build Coastguard Worker const char *fmt,
47*6236dae4SAndroid Build Coastguard Worker va_list ap)
48*6236dae4SAndroid Build Coastguard Worker {
49*6236dae4SAndroid Build Coastguard Worker size_t width = (get_terminal_columns() - strlen(prefix));
50*6236dae4SAndroid Build Coastguard Worker DEBUGASSERT(!strchr(fmt, '\n'));
51*6236dae4SAndroid Build Coastguard Worker if(!config->silent) {
52*6236dae4SAndroid Build Coastguard Worker size_t len;
53*6236dae4SAndroid Build Coastguard Worker char *ptr;
54*6236dae4SAndroid Build Coastguard Worker char *print_buffer;
55*6236dae4SAndroid Build Coastguard Worker
56*6236dae4SAndroid Build Coastguard Worker print_buffer = vaprintf(fmt, ap);
57*6236dae4SAndroid Build Coastguard Worker if(!print_buffer)
58*6236dae4SAndroid Build Coastguard Worker return;
59*6236dae4SAndroid Build Coastguard Worker len = strlen(print_buffer);
60*6236dae4SAndroid Build Coastguard Worker
61*6236dae4SAndroid Build Coastguard Worker ptr = print_buffer;
62*6236dae4SAndroid Build Coastguard Worker while(len > 0) {
63*6236dae4SAndroid Build Coastguard Worker fputs(prefix, tool_stderr);
64*6236dae4SAndroid Build Coastguard Worker
65*6236dae4SAndroid Build Coastguard Worker if(len > width) {
66*6236dae4SAndroid Build Coastguard Worker size_t cut = width-1;
67*6236dae4SAndroid Build Coastguard Worker
68*6236dae4SAndroid Build Coastguard Worker while(!ISBLANK(ptr[cut]) && cut) {
69*6236dae4SAndroid Build Coastguard Worker cut--;
70*6236dae4SAndroid Build Coastguard Worker }
71*6236dae4SAndroid Build Coastguard Worker if(0 == cut)
72*6236dae4SAndroid Build Coastguard Worker /* not a single cutting position was found, just cut it at the
73*6236dae4SAndroid Build Coastguard Worker max text width then! */
74*6236dae4SAndroid Build Coastguard Worker cut = width-1;
75*6236dae4SAndroid Build Coastguard Worker
76*6236dae4SAndroid Build Coastguard Worker (void)fwrite(ptr, cut + 1, 1, tool_stderr);
77*6236dae4SAndroid Build Coastguard Worker fputs("\n", tool_stderr);
78*6236dae4SAndroid Build Coastguard Worker ptr += cut + 1; /* skip the space too */
79*6236dae4SAndroid Build Coastguard Worker len -= cut + 1;
80*6236dae4SAndroid Build Coastguard Worker }
81*6236dae4SAndroid Build Coastguard Worker else {
82*6236dae4SAndroid Build Coastguard Worker fputs(ptr, tool_stderr);
83*6236dae4SAndroid Build Coastguard Worker fputs("\n", tool_stderr);
84*6236dae4SAndroid Build Coastguard Worker len = 0;
85*6236dae4SAndroid Build Coastguard Worker }
86*6236dae4SAndroid Build Coastguard Worker }
87*6236dae4SAndroid Build Coastguard Worker curl_free(print_buffer);
88*6236dae4SAndroid Build Coastguard Worker }
89*6236dae4SAndroid Build Coastguard Worker }
90*6236dae4SAndroid Build Coastguard Worker
91*6236dae4SAndroid Build Coastguard Worker /*
92*6236dae4SAndroid Build Coastguard Worker * Emit 'note' formatted message on configured 'errors' stream, if verbose was
93*6236dae4SAndroid Build Coastguard Worker * selected.
94*6236dae4SAndroid Build Coastguard Worker */
notef(struct GlobalConfig * config,const char * fmt,...)95*6236dae4SAndroid Build Coastguard Worker void notef(struct GlobalConfig *config, const char *fmt, ...)
96*6236dae4SAndroid Build Coastguard Worker {
97*6236dae4SAndroid Build Coastguard Worker va_list ap;
98*6236dae4SAndroid Build Coastguard Worker va_start(ap, fmt);
99*6236dae4SAndroid Build Coastguard Worker if(config->tracetype)
100*6236dae4SAndroid Build Coastguard Worker voutf(config, NOTE_PREFIX, fmt, ap);
101*6236dae4SAndroid Build Coastguard Worker va_end(ap);
102*6236dae4SAndroid Build Coastguard Worker }
103*6236dae4SAndroid Build Coastguard Worker
104*6236dae4SAndroid Build Coastguard Worker /*
105*6236dae4SAndroid Build Coastguard Worker * Emit warning formatted message on configured 'errors' stream unless
106*6236dae4SAndroid Build Coastguard Worker * mute (--silent) was selected.
107*6236dae4SAndroid Build Coastguard Worker */
warnf(struct GlobalConfig * config,const char * fmt,...)108*6236dae4SAndroid Build Coastguard Worker void warnf(struct GlobalConfig *config, const char *fmt, ...)
109*6236dae4SAndroid Build Coastguard Worker {
110*6236dae4SAndroid Build Coastguard Worker va_list ap;
111*6236dae4SAndroid Build Coastguard Worker va_start(ap, fmt);
112*6236dae4SAndroid Build Coastguard Worker voutf(config, WARN_PREFIX, fmt, ap);
113*6236dae4SAndroid Build Coastguard Worker va_end(ap);
114*6236dae4SAndroid Build Coastguard Worker }
115*6236dae4SAndroid Build Coastguard Worker
116*6236dae4SAndroid Build Coastguard Worker /*
117*6236dae4SAndroid Build Coastguard Worker * Emit help formatted message on given stream. This is for errors with or
118*6236dae4SAndroid Build Coastguard Worker * related to command line arguments.
119*6236dae4SAndroid Build Coastguard Worker */
helpf(FILE * errors,const char * fmt,...)120*6236dae4SAndroid Build Coastguard Worker void helpf(FILE *errors, const char *fmt, ...)
121*6236dae4SAndroid Build Coastguard Worker {
122*6236dae4SAndroid Build Coastguard Worker if(fmt) {
123*6236dae4SAndroid Build Coastguard Worker va_list ap;
124*6236dae4SAndroid Build Coastguard Worker va_start(ap, fmt);
125*6236dae4SAndroid Build Coastguard Worker DEBUGASSERT(!strchr(fmt, '\n'));
126*6236dae4SAndroid Build Coastguard Worker fputs("curl: ", errors); /* prefix it */
127*6236dae4SAndroid Build Coastguard Worker vfprintf(errors, fmt, ap);
128*6236dae4SAndroid Build Coastguard Worker va_end(ap);
129*6236dae4SAndroid Build Coastguard Worker fputs("\n", errors); /* newline it */
130*6236dae4SAndroid Build Coastguard Worker }
131*6236dae4SAndroid Build Coastguard Worker fprintf(errors, "curl: try 'curl --help' "
132*6236dae4SAndroid Build Coastguard Worker #ifdef USE_MANUAL
133*6236dae4SAndroid Build Coastguard Worker "or 'curl --manual' "
134*6236dae4SAndroid Build Coastguard Worker #endif
135*6236dae4SAndroid Build Coastguard Worker "for more information\n");
136*6236dae4SAndroid Build Coastguard Worker }
137*6236dae4SAndroid Build Coastguard Worker
138*6236dae4SAndroid Build Coastguard Worker /*
139*6236dae4SAndroid Build Coastguard Worker * Emit error message on error stream if not muted. When errors are not tied
140*6236dae4SAndroid Build Coastguard Worker * to command line arguments, use helpf() for such errors.
141*6236dae4SAndroid Build Coastguard Worker */
errorf(struct GlobalConfig * config,const char * fmt,...)142*6236dae4SAndroid Build Coastguard Worker void errorf(struct GlobalConfig *config, const char *fmt, ...)
143*6236dae4SAndroid Build Coastguard Worker {
144*6236dae4SAndroid Build Coastguard Worker if(!config->silent || config->showerror) {
145*6236dae4SAndroid Build Coastguard Worker va_list ap;
146*6236dae4SAndroid Build Coastguard Worker va_start(ap, fmt);
147*6236dae4SAndroid Build Coastguard Worker voutf(config, ERROR_PREFIX, fmt, ap);
148*6236dae4SAndroid Build Coastguard Worker va_end(ap);
149*6236dae4SAndroid Build Coastguard Worker }
150*6236dae4SAndroid Build Coastguard Worker }
151