NeoMutt  2025-01-09-41-g086358
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
dump.c File Reference

Colour Dump Command. More...

#include "config.h"
#include <stdbool.h>
#include <stdio.h>
#include "mutt/lib.h"
#include "config/lib.h"
#include "core/lib.h"
#include "gui/lib.h"
#include "dump.h"
#include "pager/lib.h"
#include "attr.h"
#include "color.h"
#include "parse_color.h"
#include "quoted.h"
#include "regex4.h"
#include "simple2.h"
+ Include dependency graph for dump.c:

Go to the source code of this file.

Functions

void color_log_color_attrs (struct AttrColor *ac, struct Buffer *swatch)
 Get a colourful string to represent a colour in the log.
 
const char * color_log_attrs_list (int attrs)
 Get a string to represent some attributes in the log.
 
const char * color_log_name (char *buf, int buflen, struct ColorElement *elem)
 Get a string to represent a colour name.
 
void quoted_colors_dump (struct Buffer *buf)
 Dump all the Quoted colours.
 
void regex_colors_dump (struct Buffer *buf)
 Dump all the Regex colours.
 
void simple_colors_dump (struct Buffer *buf)
 Dump all the Simple colours.
 
void status_colors_dump (struct Buffer *buf)
 Dump all the Status colours.
 
void color_dump (void)
 Display all the colours in the Pager.
 

Detailed Description

Colour Dump Command.

Authors
  • Richard Russon

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 http://www.gnu.org/licenses/.

Definition in file dump.c.

Function Documentation

◆ color_log_color_attrs()

void color_log_color_attrs ( struct AttrColor ac,
struct Buffer swatch 
)

Get a colourful string to represent a colour in the log.

Parameters
acColour
swatchBuffer for swatch
Note
Do not free the returned string

Definition at line 55 of file dump.c.

56{
57 buf_reset(swatch);
58
59 if (ac->attrs & A_BLINK)
60 buf_add_printf(swatch, "\033[5m");
61 if (ac->attrs & A_BOLD)
62 buf_add_printf(swatch, "\033[1m");
63 if (ac->attrs & A_ITALIC)
64 buf_add_printf(swatch, "\033[3m");
65 if (ac->attrs == A_NORMAL)
66 buf_add_printf(swatch, "\033[0m");
67 if (ac->attrs & A_REVERSE)
68 buf_add_printf(swatch, "\033[7m");
69 if (ac->attrs & A_STANDOUT)
70 buf_add_printf(swatch, "\033[1m");
71 if (ac->attrs & A_UNDERLINE)
72 buf_add_printf(swatch, "\033[4m");
73
74 if (ac->fg.color >= 0)
75 {
76 switch (ac->fg.type)
77 {
78 case CT_SIMPLE:
79 {
80 buf_add_printf(swatch, "\033[%dm", 30 + ac->fg.color);
81 break;
82 }
83
84 case CT_PALETTE:
85 {
86 buf_add_printf(swatch, "\033[38;5;%dm", ac->fg.color);
87 break;
88 }
89
90 case CT_RGB:
91 {
92 int r = (ac->fg.color >> 16) & 0xff;
93 int g = (ac->fg.color >> 8) & 0xff;
94 int b = (ac->fg.color >> 0) & 0xff;
95 buf_add_printf(swatch, "\033[38;2;%d;%d;%dm", r, g, b);
96 break;
97 }
98 }
99 }
100
101 if (ac->bg.color >= 0)
102 {
103 switch (ac->bg.type)
104 {
105 case CT_SIMPLE:
106 {
107 buf_add_printf(swatch, "\033[%dm", 40 + ac->bg.color);
108 break;
109 }
110
111 case CT_PALETTE:
112 {
113 buf_add_printf(swatch, "\033[48;5;%dm", ac->bg.color);
114 break;
115 }
116
117 case CT_RGB:
118 {
119 int r = (ac->bg.color >> 16) & 0xff;
120 int g = (ac->bg.color >> 8) & 0xff;
121 int b = (ac->bg.color >> 0) & 0xff;
122 buf_add_printf(swatch, "\033[48;2;%d;%d;%dm", r, g, b);
123 break;
124 }
125 }
126 }
127
128 buf_addstr(swatch, "XXXXXX\033[0m");
129}
@ CT_SIMPLE
Simple colour, e.g. "Red".
Definition: attr.h:36
@ CT_PALETTE
Palette colour, e.g. "color207".
Definition: attr.h:37
@ CT_RGB
True colour, e.g. "#11AAFF".
Definition: attr.h:38
int buf_add_printf(struct Buffer *buf, const char *fmt,...)
Format a string appending a Buffer.
Definition: buffer.c:204
void buf_reset(struct Buffer *buf)
Reset an existing Buffer.
Definition: buffer.c:76
size_t buf_addstr(struct Buffer *buf, const char *s)
Add a string to a Buffer.
Definition: buffer.c:226
#define A_ITALIC
Definition: mutt_curses.h:49
struct ColorElement bg
Background colour.
Definition: attr.h:68
struct ColorElement fg
Foreground colour.
Definition: attr.h:67
int attrs
Text attributes, e.g. A_BOLD.
Definition: attr.h:69
enum ColorType type
Type of Colour.
Definition: attr.h:58
color_t color
Colour.
Definition: attr.h:57
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ color_log_attrs_list()

const char * color_log_attrs_list ( int  attrs)

Get a string to represent some attributes in the log.

Parameters
attrsAttributes, e.g. A_UNDERLINE
Return values
ptrGenerated string
Note
Do not free the returned string

Definition at line 138 of file dump.c.

139{
140 static char text[64];
141
142 text[0] = '\0';
143 int pos = 0;
144 // We can ignore the A_NORMAL case
145 if (attrs & A_BLINK)
146 pos += snprintf(text + pos, sizeof(text) - pos, "blink ");
147 if (attrs & A_BOLD)
148 pos += snprintf(text + pos, sizeof(text) - pos, "bold ");
149 if (attrs & A_ITALIC)
150 pos += snprintf(text + pos, sizeof(text) - pos, "italic ");
151 if (attrs & A_REVERSE)
152 pos += snprintf(text + pos, sizeof(text) - pos, "reverse ");
153 if (attrs & A_STANDOUT)
154 pos += snprintf(text + pos, sizeof(text) - pos, "standout ");
155 if (attrs & A_UNDERLINE)
156 pos += snprintf(text + pos, sizeof(text) - pos, "underline ");
157
158 return text;
159}
+ Here is the caller graph for this function:

◆ color_log_name()

const char * color_log_name ( char *  buf,
int  buflen,
struct ColorElement elem 
)

Get a string to represent a colour name.

Parameters
bufBuffer for the result
buflenLength of the Buffer
elemColour to use
Return values
ptrGenerated string

Definition at line 168 of file dump.c.

169{
170 if (elem->color < 0)
171 return "default";
172
173 switch (elem->type)
174 {
175 case CT_SIMPLE:
176 {
177 const char *prefix = NULL;
178 switch (elem->prefix)
179 {
181 prefix = "alert";
182 break;
184 prefix = "bright";
185 break;
187 prefix = "light";
188 break;
189 default:
190 prefix = "";
191 break;
192 }
193
194 const char *name = mutt_map_get_name(elem->color, ColorNames);
195 snprintf(buf, buflen, "%s%s", prefix, name);
196 break;
197 }
198
199 case CT_PALETTE:
200 {
201 if (elem->color < 256)
202 snprintf(buf, buflen, "color%d", elem->color);
203 else
204 snprintf(buf, buflen, "BAD:%d", elem->color); // LCOV_EXCL_LINE
205 break;
206 }
207
208 case CT_RGB:
209 {
210 int r = (elem->color >> 16) & 0xff;
211 int g = (elem->color >> 8) & 0xff;
212 int b = (elem->color >> 0) & 0xff;
213 snprintf(buf, buflen, "#%02x%02x%02x", r, g, b);
214 break;
215 }
216 }
217
218 return buf;
219}
@ COLOR_PREFIX_ALERT
"alert" colour prefix
Definition: attr.h:47
@ COLOR_PREFIX_LIGHT
"light" colour prefix
Definition: attr.h:49
@ COLOR_PREFIX_BRIGHT
"bright" colour prefix
Definition: attr.h:48
const char * mutt_map_get_name(int val, const struct Mapping *map)
Lookup a string for a constant.
Definition: mapping.c:42
const struct Mapping ColorNames[]
Mapping between a colour name and an ncurses colour.
Definition: parse_color.c:41
enum ColorPrefix prefix
Optional Colour Modifier.
Definition: attr.h:59
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ quoted_colors_dump()

void quoted_colors_dump ( struct Buffer buf)

Dump all the Quoted colours.

Parameters
bufBuffer for result

Definition at line 225 of file dump.c.

226{
227 struct Buffer *swatch = buf_pool_get();
228 char color_fg[64] = { 0 };
229 char color_bg[64] = { 0 };
230
231 buf_addstr(buf, _("# Quoted Colors\n"));
232 for (int i = 0; i < 10; i++)
233 {
235 if (!attr_color_is_set(ac))
236 continue;
237
238 color_log_color_attrs(ac, swatch);
239 buf_add_printf(buf, "color quoted%d %-20s %-16s %-16s # %s\n", i,
241 color_log_name(color_fg, sizeof(color_fg), &ac->fg),
242 color_log_name(color_bg, sizeof(color_bg), &ac->bg),
243 buf_string(swatch));
244 }
245
246 buf_addstr(buf, "\n");
247 buf_pool_release(&swatch);
248}
bool attr_color_is_set(const struct AttrColor *ac)
Is the object coloured?
Definition: attr.c:179
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
Definition: buffer.h:96
void color_log_color_attrs(struct AttrColor *ac, struct Buffer *swatch)
Get a colourful string to represent a colour in the log.
Definition: dump.c:55
const char * color_log_name(char *buf, int buflen, struct ColorElement *elem)
Get a string to represent a colour name.
Definition: dump.c:168
const char * color_log_attrs_list(int attrs)
Get a string to represent some attributes in the log.
Definition: dump.c:138
struct AttrColor * simple_color_get(enum ColorId cid)
Get the colour of an object by its ID.
Definition: simple.c:95
@ MT_COLOR_QUOTED0
Pager: quoted text, level 0.
Definition: color.h:59
#define _(a)
Definition: message.h:28
struct Buffer * buf_pool_get(void)
Get a Buffer from the pool.
Definition: pool.c:82
void buf_pool_release(struct Buffer **ptr)
Return a Buffer to the pool.
Definition: pool.c:96
A curses colour and its attributes.
Definition: attr.h:66
String manipulation buffer.
Definition: buffer.h:36
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ regex_colors_dump()

void regex_colors_dump ( struct Buffer buf)

Dump all the Regex colours.

Parameters
bufBuffer for result

Definition at line 254 of file dump.c.

255{
256 struct Buffer *swatch = buf_pool_get();
257 struct Buffer *pattern = buf_pool_get();
258 char color_fg[64] = { 0 };
259 char color_bg[64] = { 0 };
260
261 for (enum ColorId cid = MT_COLOR_NONE; cid != MT_COLOR_MAX; cid++)
262 {
263 if (cid == MT_COLOR_STATUS)
264 continue;
265
266 if (!mutt_color_has_pattern(cid))
267 continue;
268
269 struct RegexColorList *rcl = regex_colors_get_list(cid);
270 if (STAILQ_EMPTY(rcl))
271 continue;
272
273 const char *name = mutt_map_get_name(cid, ColorFields);
274 if (!name)
275 continue; // LCOV_EXCL_LINE
276
277 buf_add_printf(buf, _("# Regex Color %s\n"), name);
278
279 struct RegexColor *rc = NULL;
280 STAILQ_FOREACH(rc, rcl, entries)
281 {
282 struct AttrColor *ac = &rc->attr_color;
283
284 buf_reset(pattern);
285 pretty_var(rc->pattern, pattern);
286 color_log_color_attrs(ac, swatch);
287 buf_add_printf(buf, "color %-16s %-20s %-16s %-16s %-30s # %s\n", name,
289 color_log_name(color_fg, sizeof(color_fg), &ac->fg),
290 color_log_name(color_bg, sizeof(color_bg), &ac->bg),
291 buf_string(pattern), buf_string(swatch));
292 }
293 buf_addstr(buf, "\n");
294 }
295
296 buf_pool_release(&swatch);
297 buf_pool_release(&pattern);
298}
struct RegexColorList * regex_colors_get_list(enum ColorId cid)
Return the RegexColorList for a Colour ID.
Definition: regex.c:190
bool mutt_color_has_pattern(enum ColorId cid)
Check if a color object supports a regex pattern.
Definition: color.c:98
const struct Mapping ColorFields[]
Mapping of colour names to their IDs.
Definition: command.c:55
ColorId
List of all coloured objects.
Definition: color.h:36
@ MT_COLOR_MAX
Definition: color.h:99
@ MT_COLOR_STATUS
Status bar (takes a pattern)
Definition: color.h:80
@ MT_COLOR_NONE
No colour.
Definition: color.h:37
size_t pretty_var(const char *str, struct Buffer *buf)
Escape and stringify a config item value.
Definition: dump.c:86
#define STAILQ_FOREACH(var, head, field)
Definition: queue.h:390
#define STAILQ_EMPTY(head)
Definition: queue.h:382
A regular expression and a color to highlight a line.
Definition: regex4.h:36
struct AttrColor attr_color
Colour and attributes to apply.
Definition: regex4.h:37
char * pattern
Pattern to match.
Definition: regex4.h:38
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ simple_colors_dump()

void simple_colors_dump ( struct Buffer buf)

Dump all the Simple colours.

Parameters
bufBuffer for result

Definition at line 304 of file dump.c.

305{
306 struct Buffer *swatch = buf_pool_get();
307 char color_fg[64] = { 0 };
308 char color_bg[64] = { 0 };
309
310 int count = 0;
311 for (enum ColorId cid = MT_COLOR_NONE + 1; cid < MT_COLOR_MAX; cid++)
312 {
313 if (COLOR_QUOTED(cid) || (cid == MT_COLOR_STATUS))
314 continue;
315
316 struct AttrColor *ac = simple_color_get(cid);
317 if (attr_color_is_set(ac))
318 count++;
319 }
320
321 if (count > 0)
322 {
323 buf_addstr(buf, _("# Simple Colors\n"));
324 for (enum ColorId cid = MT_COLOR_NONE + 1; cid < MT_COLOR_MAX; cid++)
325 {
326 if (COLOR_QUOTED(cid) || COLOR_COMPOSE(cid) || (cid == MT_COLOR_STATUS))
327 continue;
328
329 struct AttrColor *ac = simple_color_get(cid);
330 if (!attr_color_is_set(ac))
331 continue;
332
333 const char *name = mutt_map_get_name(cid, ColorFields);
334 if (!name)
335 continue;
336
337 color_log_color_attrs(ac, swatch);
338 buf_add_printf(buf, "color %-18s %-20s %-16s %-16s # %s\n", name,
340 color_log_name(color_fg, sizeof(color_fg), &ac->fg),
341 color_log_name(color_bg, sizeof(color_bg), &ac->bg),
342 buf_string(swatch));
343 }
344 buf_addstr(buf, "\n");
345 }
346
347 count = 0;
349 {
350 struct AttrColor *ac = simple_color_get(i);
351 if (attr_color_is_set(ac))
352 count++;
353 }
354
355 if (count > 0)
356 {
357 buf_addstr(buf, _("# Compose Colors\n"));
358 for (int i = 0; ColorFields[i].name; i++)
359 {
360 enum ColorId cid = ColorFields[i].value;
361
362 if (!COLOR_COMPOSE(cid))
363 continue;
364
365 struct AttrColor *ac = simple_color_get(cid);
366 if (!attr_color_is_set(ac))
367 continue;
368
369 color_log_color_attrs(ac, swatch);
370 buf_add_printf(buf, "color %-24s %-20s %-16s %-16s # %s\n",
372 color_log_name(color_fg, sizeof(color_fg), &ac->fg),
373 color_log_name(color_bg, sizeof(color_bg), &ac->bg),
374 buf_string(swatch));
375 }
376 buf_addstr(buf, "\n");
377 }
378
379 buf_pool_release(&swatch);
380}
@ MT_COLOR_COMPOSE_SECURITY_SIGN
Mail will be signed.
Definition: color.h:46
@ MT_COLOR_COMPOSE_HEADER
Header labels, e.g. From:
Definition: color.h:42
#define COLOR_QUOTED(cid)
Definition: quoted.h:28
#define COLOR_COMPOSE(cid)
Definition: simple2.h:32
int value
Integer value.
Definition: mapping.h:35
const char * name
String value.
Definition: mapping.h:34
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ status_colors_dump()

void status_colors_dump ( struct Buffer buf)

Dump all the Status colours.

Parameters
bufBuffer for result

Definition at line 386 of file dump.c.

387{
388 struct Buffer *swatch = buf_pool_get();
389 struct Buffer *pattern = buf_pool_get();
390 char color_fg[64] = { 0 };
391 char color_bg[64] = { 0 };
392
393 bool set = false;
394
395 const enum ColorId cid = MT_COLOR_STATUS;
396 struct AttrColor *ac = simple_color_get(cid);
397 if (attr_color_is_set(ac))
398 set = true;
399
400 struct RegexColorList *rcl = regex_colors_get_list(cid);
401 if (!STAILQ_EMPTY(rcl))
402 set = true;
403
404 if (set)
405 {
406 buf_addstr(buf, _("# Status Colors\n"));
407
408 color_log_color_attrs(ac, swatch);
409 buf_add_printf(buf, "color status %-20s %-16s %-16s # %s\n",
411 color_log_name(color_fg, sizeof(color_fg), &ac->fg),
412 color_log_name(color_bg, sizeof(color_bg), &ac->bg),
413 buf_string(swatch));
414
415 struct RegexColor *rc = NULL;
416 STAILQ_FOREACH(rc, rcl, entries)
417 {
418 ac = &rc->attr_color;
419
422 color_log_color_attrs(ac, swatch);
423 if (rc->match == 0)
424 {
425 buf_add_printf(buf, "color status %-20s %-16s %-16s %-30s # %s\n",
427 color_log_name(color_fg, sizeof(color_fg), &ac->fg),
428 color_log_name(color_bg, sizeof(color_bg), &ac->bg),
429 buf_string(pattern), buf_string(swatch));
430 }
431 else
432 {
433 buf_add_printf(buf, "color status %-20s %-16s %-16s %-28s %d # %s\n",
435 color_log_name(color_fg, sizeof(color_fg), &ac->fg),
436 color_log_name(color_bg, sizeof(color_bg), &ac->bg),
437 buf_string(pattern), rc->match, buf_string(swatch));
438 }
439 }
440 buf_addstr(buf, "\n");
441 }
442
443 buf_pool_release(&swatch);
445}
int match
Substring to match, 0 for old behaviour.
Definition: regex4.h:40
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ color_dump()

void color_dump ( void  )

Display all the colours in the Pager.

Definition at line 450 of file dump.c.

451{
452 struct Buffer *tempfile = buf_pool_get();
453
454 buf_mktemp(tempfile);
455 FILE *fp = mutt_file_fopen(buf_string(tempfile), "w");
456 if (!fp)
457 {
458 // LCOV_EXCL_START
459 // L10N: '%s' is the file name of the temporary file
460 mutt_error(_("Could not create temporary file %s"), buf_string(tempfile));
461 buf_pool_release(&tempfile);
462 return;
463 // LCOV_EXCL_STOP
464 }
465
466 struct Buffer *buf = buf_pool_get();
467
472
473#ifdef USE_DEBUG_COLOR
475 ansi_colors_dump(buf);
478#endif
479
481 buf_pool_release(&buf);
482 mutt_file_fclose(&fp);
483
484 struct PagerData pdata = { 0 };
485 struct PagerView pview = { &pdata };
486
487 pdata.fname = buf_string(tempfile);
488
489 pview.banner = "color";
490 pview.flags = MUTT_SHOWCOLOR;
491 pview.mode = PAGER_MODE_OTHER;
492
493 mutt_do_pager(&pview, NULL);
494 buf_pool_release(&tempfile);
495}
void simple_colors_dump(struct Buffer *buf)
Dump all the Simple colours.
Definition: dump.c:304
void quoted_colors_dump(struct Buffer *buf)
Dump all the Quoted colours.
Definition: dump.c:225
void regex_colors_dump(struct Buffer *buf)
Dump all the Regex colours.
Definition: dump.c:254
void status_colors_dump(struct Buffer *buf)
Dump all the Status colours.
Definition: dump.c:386
void ansi_colors_dump(struct Buffer *buf)
Dump all the ANSI colours.
Definition: debug.c:83
void curses_colors_dump(struct Buffer *buf)
Dump all the Curses colours.
Definition: debug.c:143
void merged_colors_dump(struct Buffer *buf)
Dump all the Merged colours.
Definition: debug.c:176
int mutt_do_pager(struct PagerView *pview, struct Email *e)
Display some page-able text to the user (help or attachment)
Definition: do_pager.c:122
size_t mutt_file_save_str(FILE *fp, const char *str)
Save a string to a file.
Definition: file.c:1572
#define mutt_file_fclose(FP)
Definition: file.h:139
#define mutt_file_fopen(PATH, MODE)
Definition: file.h:138
#define mutt_error(...)
Definition: logging2.h:92
#define log_multiline(LEVEL, STRING)
Definition: logging2.h:96
@ LL_DEBUG1
Log at debug level 1.
Definition: logging2.h:43
#define MUTT_SHOWCOLOR
Show characters in color otherwise don't show characters.
Definition: lib.h:62
@ PAGER_MODE_OTHER
Pager is invoked via 3rd path. Non-email content is likely to be shown.
Definition: lib.h:140
Data to be displayed by PagerView.
Definition: lib.h:159
const char * fname
Name of the file to read.
Definition: lib.h:163
Paged view into some data.
Definition: lib.h:170
struct PagerData * pdata
Data that pager displays. NOTNULL.
Definition: lib.h:171
enum PagerMode mode
Pager mode.
Definition: lib.h:172
PagerFlags flags
Additional settings to tweak pager's function.
Definition: lib.h:173
const char * banner
Title to display in status bar.
Definition: lib.h:174
#define buf_mktemp(buf)
Definition: tmp.h:33
+ Here is the call graph for this function:
+ Here is the caller graph for this function: