xref: /aosp_15_r20/external/curl/src/tool_msgs.c (revision 6236dae45794135f37c4eb022389c904c8b0090d)
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