@@ -12,6 +12,9 @@ struct add_i_state {
12
12
int use_color ;
13
13
char header_color [COLOR_MAXLEN ];
14
14
char help_color [COLOR_MAXLEN ];
15
+ char prompt_color [COLOR_MAXLEN ];
16
+ char error_color [COLOR_MAXLEN ];
17
+ char reset_color [COLOR_MAXLEN ];
15
18
};
16
19
17
20
static void init_color (struct repository * r , struct add_i_state * s ,
@@ -45,6 +48,9 @@ static void init_add_i_state(struct add_i_state *s, struct repository *r)
45
48
46
49
init_color (r , s , "header" , s -> header_color , GIT_COLOR_BOLD );
47
50
init_color (r , s , "help" , s -> help_color , GIT_COLOR_BOLD_RED );
51
+ init_color (r , s , "prompt" , s -> prompt_color , GIT_COLOR_BOLD_BLUE );
52
+ init_color (r , s , "error" , s -> error_color , GIT_COLOR_BOLD_RED );
53
+ init_color (r , s , "reset" , s -> reset_color , GIT_COLOR_RESET );
48
54
}
49
55
50
56
/*
@@ -240,7 +246,8 @@ static ssize_t list_and_choose(struct add_i_state *s,
240
246
241
247
list (s , & items -> items , & opts -> list_opts );
242
248
243
- printf ("%s%s" , opts -> prompt , "> " );
249
+ color_fprintf (stdout , s -> prompt_color , "%s" , opts -> prompt );
250
+ fputs ("> " , stdout );
244
251
fflush (stdout );
245
252
246
253
if (strbuf_getline (& input , stdin ) == EOF ) {
@@ -281,7 +288,8 @@ static ssize_t list_and_choose(struct add_i_state *s,
281
288
index = find_unique (p , items );
282
289
283
290
if (index < 0 || index >= items -> items .nr )
284
- printf (_ ("Huh (%s)?\n" ), p );
291
+ color_fprintf_ln (stdout , s -> error_color ,
292
+ _ ("Huh (%s)?" ), p );
285
293
else {
286
294
res = index ;
287
295
break ;
@@ -507,18 +515,23 @@ struct command_item {
507
515
command_t command ;
508
516
};
509
517
518
+ struct print_command_item_data {
519
+ const char * color , * reset ;
520
+ };
521
+
510
522
static void print_command_item (int i , struct string_list_item * item ,
511
523
void * print_command_item_data )
512
524
{
525
+ struct print_command_item_data * d = print_command_item_data ;
513
526
struct command_item * util = item -> util ;
514
527
515
528
if (!util -> prefix_length ||
516
529
!is_valid_prefix (item -> string , util -> prefix_length ))
517
530
printf (" %2d: %s" , i + 1 , item -> string );
518
531
else
519
- printf (" %2d: [% .*s] %s" , i + 1 ,
520
- (int )util -> prefix_length , item -> string ,
521
- item -> string + util -> prefix_length );
532
+ printf (" %2d: %s% .*s%s %s" , i + 1 ,
533
+ d -> color , (int )util -> prefix_length , item -> string ,
534
+ d -> reset , item -> string + util -> prefix_length );
522
535
}
523
536
524
537
static void command_prompt_help (struct add_i_state * s )
@@ -536,8 +549,9 @@ static void command_prompt_help(struct add_i_state *s)
536
549
int run_add_i (struct repository * r , const struct pathspec * ps )
537
550
{
538
551
struct add_i_state s = { NULL };
552
+ struct print_command_item_data data = { "[" , "]" };
539
553
struct list_and_choose_options main_loop_opts = {
540
- { 4 , N_ ("*** Commands ***" ), print_command_item , NULL },
554
+ { 4 , N_ ("*** Commands ***" ), print_command_item , & data },
541
555
N_ ("What now" ), command_prompt_help
542
556
};
543
557
struct {
@@ -568,6 +582,15 @@ int run_add_i(struct repository *r, const struct pathspec *ps)
568
582
569
583
init_add_i_state (& s , r );
570
584
585
+ /*
586
+ * When color was asked for, use the prompt color for
587
+ * highlighting, otherwise use square brackets.
588
+ */
589
+ if (s .use_color ) {
590
+ data .color = s .prompt_color ;
591
+ data .reset = s .reset_color ;
592
+ }
593
+
571
594
strbuf_addstr (& header , " " );
572
595
strbuf_addf (& header , print_file_item_data .modified_fmt ,
573
596
_ ("staged" ), _ ("unstaged" ), _ ("path" ));
0 commit comments