3 Copyright (C) 2018-2019 Free Software Foundation, Inc.
5 This file is part of GDB.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
20 #ifndef CLI_CLI_STYLE_H
21 #define CLI_CLI_STYLE_H
26 /* A single CLI style option. */
27 class cli_style_option
31 /* Construct a CLI style option with a foreground color. */
32 cli_style_option (const char *name
, ui_file_style::basic_color fg
);
34 /* Construct a CLI style option with an intensity. */
35 cli_style_option (const char *name
, ui_file_style::intensity i
);
37 /* Construct a CLI style option with an intensity. */
38 cli_style_option (ui_file_style::intensity val
);
40 /* Return a ui_file_style corresponding to the settings in this CLI
42 ui_file_style
style () const;
44 /* Return the style name. */
45 const char *name () { return m_name
; };
47 /* Call once to register this CLI style with the CLI engine. */
48 void add_setshow_commands (enum command_class theclass
,
49 const char *prefix_doc
,
50 struct cmd_list_element
**set_list
,
51 void (*do_set
) (const char *args
, int from_tty
),
52 struct cmd_list_element
**show_list
,
53 void (*do_show
) (const char *args
, int from_tty
));
55 /* Return the 'set style NAME' command list, that can be used
56 to build a lambda DO_SET to call add_setshow_commands. */
57 struct cmd_list_element
*set_list () { return m_set_list
; };
59 /* Same as SET_LIST but for the show command list. */
60 struct cmd_list_element
*show_list () { return m_show_list
; };
68 const char *m_foreground
;
70 const char *m_background
;
72 const char *m_intensity
;
74 /* Storage for prefixes needed when registering the commands. */
75 std::string m_show_prefix
;
76 std::string m_set_prefix
;
77 /* Storage for command lists needed when registering
79 struct cmd_list_element
*m_set_list
= nullptr;
80 struct cmd_list_element
*m_show_list
= nullptr;
82 /* Callback to show the foreground. */
83 static void do_show_foreground (struct ui_file
*file
, int from_tty
,
84 struct cmd_list_element
*cmd
,
86 /* Callback to show the background. */
87 static void do_show_background (struct ui_file
*file
, int from_tty
,
88 struct cmd_list_element
*cmd
,
90 /* Callback to show the intensity. */
91 static void do_show_intensity (struct ui_file
*file
, int from_tty
,
92 struct cmd_list_element
*cmd
,
96 /* The file name style. */
97 extern cli_style_option file_name_style
;
99 /* The function name style. */
100 extern cli_style_option function_name_style
;
102 /* The variable name style. */
103 extern cli_style_option variable_name_style
;
105 /* The address style. */
106 extern cli_style_option address_style
;
108 /* The highlight style. */
109 extern cli_style_option highlight_style
;
111 /* The title style. */
112 extern cli_style_option title_style
;
114 /* The metadata style. */
115 extern cli_style_option metadata_style
;
117 /* True if source styling is enabled. */
118 extern bool source_styling
;
120 /* True if styling is enabled. */
121 extern bool cli_styling
;
123 #endif /* CLI_CLI_STYLE_H */