color: use git_colorbool enum type to store colorbools
We traditionally used "int" to store and pass around the values defined by "enum git_colorbool" (which were originally just #define macros). Using an int doesn't produce incorrect results, but using the actual enum makes the intent of the code more clear. It would be nice if the compiler could catch cases where we used the enum and an int interchangeably, since it's very easy to accidentally check the boolean true/false of a colorbool like: if (branch_use_color) This is wrong because GIT_COLOR_UNKNOWN and GIT_COLOR_AUTO evaluate to true in C, even though we may ultimately decide not to use color. But C is pretty happy to convert between ints and enums (even with various -Wenum-* warnings). So this sadly doesn't protect us from such mistakes, but it hopefully does make the code easier to read. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
5e9ddd3c06
commit
e9330ae4b8
@@ -39,7 +39,7 @@ static void init_color(struct repository *r, int use_color,
|
||||
static int check_color_config(struct repository *r, const char *var)
|
||||
{
|
||||
const char *value;
|
||||
int ret;
|
||||
enum git_colorbool ret;
|
||||
|
||||
if (repo_config_get_value(r, var, &value))
|
||||
ret = GIT_COLOR_UNKNOWN;
|
||||
|
||||
2
advice.c
2
advice.c
@@ -7,7 +7,7 @@
|
||||
#include "help.h"
|
||||
#include "string-list.h"
|
||||
|
||||
static int advice_use_color = GIT_COLOR_UNKNOWN;
|
||||
static enum git_colorbool advice_use_color = GIT_COLOR_UNKNOWN;
|
||||
static char advice_colors[][COLOR_MAXLEN] = {
|
||||
GIT_COLOR_RESET,
|
||||
GIT_COLOR_YELLOW, /* HINT */
|
||||
|
||||
@@ -46,7 +46,7 @@ static struct object_id head_oid;
|
||||
static int recurse_submodules = 0;
|
||||
static int submodule_propagate_branches = 0;
|
||||
|
||||
static int branch_use_color = GIT_COLOR_UNKNOWN;
|
||||
static enum git_colorbool branch_use_color = GIT_COLOR_UNKNOWN;
|
||||
static char branch_colors[][COLOR_MAXLEN] = {
|
||||
GIT_COLOR_RESET,
|
||||
GIT_COLOR_NORMAL, /* PLAIN */
|
||||
|
||||
@@ -64,7 +64,7 @@ static const char *color_interactive_slots[] = {
|
||||
[CLEAN_COLOR_RESET] = "reset",
|
||||
};
|
||||
|
||||
static int clean_use_color = GIT_COLOR_UNKNOWN;
|
||||
static enum git_colorbool clean_use_color = GIT_COLOR_UNKNOWN;
|
||||
static char clean_colors[][COLOR_MAXLEN] = {
|
||||
[CLEAN_COLOR_ERROR] = GIT_COLOR_BOLD_RED,
|
||||
[CLEAN_COLOR_HEADER] = GIT_COLOR_BOLD,
|
||||
|
||||
@@ -936,7 +936,7 @@ static int prepare_to_commit(const char *index_file, const char *prefix,
|
||||
strbuf_addstr(&committer_ident, git_committer_info(IDENT_STRICT));
|
||||
if (use_editor && include_status) {
|
||||
int ident_shown = 0;
|
||||
int saved_color_setting;
|
||||
enum git_colorbool saved_color_setting;
|
||||
struct ident_split ci, ai;
|
||||
const char *hint_cleanup_all = allow_empty_message ?
|
||||
_("Please enter the commit message for your changes."
|
||||
|
||||
@@ -568,9 +568,9 @@ static void get_color(const struct config_location_options *opts,
|
||||
}
|
||||
|
||||
struct get_colorbool_config_data {
|
||||
int get_colorbool_found;
|
||||
int get_diff_color_found;
|
||||
int get_color_ui_found;
|
||||
enum git_colorbool get_colorbool_found;
|
||||
enum git_colorbool get_diff_color_found;
|
||||
enum git_colorbool get_color_ui_found;
|
||||
const char *get_colorbool_slot;
|
||||
};
|
||||
|
||||
|
||||
@@ -27,7 +27,7 @@ static const char * const push_usage[] = {
|
||||
NULL,
|
||||
};
|
||||
|
||||
static int push_use_color = GIT_COLOR_UNKNOWN;
|
||||
static enum git_colorbool push_use_color = GIT_COLOR_UNKNOWN;
|
||||
static char push_colors[][COLOR_MAXLEN] = {
|
||||
GIT_COLOR_RESET,
|
||||
GIT_COLOR_RED, /* ERROR */
|
||||
|
||||
@@ -29,7 +29,7 @@ static const char*const show_branch_usage[] = {
|
||||
NULL
|
||||
};
|
||||
|
||||
static int showbranch_use_color = GIT_COLOR_UNKNOWN;
|
||||
static enum git_colorbool showbranch_use_color = GIT_COLOR_UNKNOWN;
|
||||
|
||||
static struct strvec default_args = STRVEC_INIT;
|
||||
|
||||
|
||||
4
color.c
4
color.c
@@ -9,7 +9,7 @@
|
||||
#include "pager.h"
|
||||
#include "strbuf.h"
|
||||
|
||||
static int git_use_color_default = GIT_COLOR_AUTO;
|
||||
static enum git_colorbool git_use_color_default = GIT_COLOR_AUTO;
|
||||
int color_stdout_is_tty = -1;
|
||||
|
||||
/*
|
||||
@@ -404,7 +404,7 @@ static int check_auto_color(int fd)
|
||||
return 0;
|
||||
}
|
||||
|
||||
int want_color_fd(int fd, int var)
|
||||
int want_color_fd(int fd, enum git_colorbool var)
|
||||
{
|
||||
/*
|
||||
* NEEDSWORK: This function is sometimes used from multiple threads, and
|
||||
|
||||
2
color.h
2
color.h
@@ -106,7 +106,7 @@ enum git_colorbool git_config_colorbool(const char *var, const char *value);
|
||||
* Return a boolean whether to use color, where the argument 'var' is
|
||||
* one of GIT_COLOR_UNKNOWN, GIT_COLOR_NEVER, GIT_COLOR_ALWAYS, GIT_COLOR_AUTO.
|
||||
*/
|
||||
int want_color_fd(int fd, int var);
|
||||
int want_color_fd(int fd, enum git_colorbool var);
|
||||
#define want_color(colorbool) want_color_fd(1, (colorbool))
|
||||
#define want_color_stderr(colorbool) want_color_fd(2, (colorbool))
|
||||
|
||||
|
||||
@@ -749,7 +749,7 @@ static void show_line_to_eol(const char *line, int len, const char *reset)
|
||||
|
||||
static void dump_sline(struct sline *sline, const char *line_prefix,
|
||||
unsigned long cnt, int num_parent,
|
||||
int use_color, int result_deleted)
|
||||
enum git_colorbool use_color, int result_deleted)
|
||||
{
|
||||
unsigned long mark = (1UL<<num_parent);
|
||||
unsigned long no_pre_delete = (2UL<<num_parent);
|
||||
|
||||
6
diff.c
6
diff.c
@@ -57,7 +57,7 @@ static int diff_detect_rename_default;
|
||||
static int diff_indent_heuristic = 1;
|
||||
static int diff_rename_limit_default = 1000;
|
||||
static int diff_suppress_blank_empty;
|
||||
static int diff_use_color_default = GIT_COLOR_UNKNOWN;
|
||||
static enum git_colorbool diff_use_color_default = GIT_COLOR_UNKNOWN;
|
||||
static int diff_color_moved_default;
|
||||
static int diff_color_moved_ws_default;
|
||||
static int diff_context_default = 3;
|
||||
@@ -2309,7 +2309,7 @@ static void free_diff_words_data(struct emit_callback *ecbdata)
|
||||
}
|
||||
}
|
||||
|
||||
const char *diff_get_color(int diff_use_color, enum color_diff ix)
|
||||
const char *diff_get_color(enum git_colorbool diff_use_color, enum color_diff ix)
|
||||
{
|
||||
if (want_color(diff_use_color))
|
||||
return diff_colors[ix];
|
||||
@@ -4481,7 +4481,7 @@ static void fill_metainfo(struct strbuf *msg,
|
||||
struct diff_options *o,
|
||||
struct diff_filepair *p,
|
||||
int *must_show_header,
|
||||
int use_color)
|
||||
enum git_colorbool use_color)
|
||||
{
|
||||
const char *set = diff_get_color(use_color, DIFF_METAINFO);
|
||||
const char *reset = diff_get_color(use_color, DIFF_RESET);
|
||||
|
||||
5
diff.h
5
diff.h
@@ -7,6 +7,7 @@
|
||||
#include "hash.h"
|
||||
#include "pathspec.h"
|
||||
#include "strbuf.h"
|
||||
#include "color.h"
|
||||
|
||||
struct oidset;
|
||||
|
||||
@@ -283,7 +284,7 @@ struct diff_options {
|
||||
/* diff-filter bits */
|
||||
unsigned int filter, filter_not;
|
||||
|
||||
int use_color;
|
||||
enum git_colorbool use_color;
|
||||
|
||||
/* Number of context lines to generate in patch output. */
|
||||
int context;
|
||||
@@ -459,7 +460,7 @@ enum color_diff {
|
||||
DIFF_FILE_NEW_BOLD = 22,
|
||||
};
|
||||
|
||||
const char *diff_get_color(int diff_use_color, enum color_diff ix);
|
||||
const char *diff_get_color(enum git_colorbool diff_use_color, enum color_diff ix);
|
||||
#define diff_get_color_opt(o, ix) \
|
||||
diff_get_color((o)->use_color, ix)
|
||||
|
||||
|
||||
2
grep.h
2
grep.h
@@ -159,7 +159,7 @@ struct grep_opt {
|
||||
int pathname;
|
||||
int null_following_name;
|
||||
int only_matching;
|
||||
int color;
|
||||
enum git_colorbool color;
|
||||
int max_depth;
|
||||
int funcname;
|
||||
int funcbody;
|
||||
|
||||
@@ -57,7 +57,7 @@ static const char *color_decorate_slots[] = {
|
||||
[DECORATION_GRAFTED] = "grafted",
|
||||
};
|
||||
|
||||
static const char *decorate_get_color(int decorate_use_color, enum decoration_type ix)
|
||||
static const char *decorate_get_color(enum git_colorbool decorate_use_color, enum decoration_type ix)
|
||||
{
|
||||
if (want_color(decorate_use_color))
|
||||
return decoration_colors[ix];
|
||||
@@ -341,7 +341,7 @@ static void show_name(struct strbuf *sb, const struct name_decoration *decoratio
|
||||
*/
|
||||
void format_decorations(struct strbuf *sb,
|
||||
const struct commit *commit,
|
||||
int use_color,
|
||||
enum git_colorbool use_color,
|
||||
const struct decoration_options *opts)
|
||||
{
|
||||
const struct name_decoration *decoration;
|
||||
|
||||
@@ -1,6 +1,8 @@
|
||||
#ifndef LOG_TREE_H
|
||||
#define LOG_TREE_H
|
||||
|
||||
#include "color.h"
|
||||
|
||||
struct rev_info;
|
||||
|
||||
struct log_info {
|
||||
@@ -26,7 +28,7 @@ int log_tree_diff_flush(struct rev_info *);
|
||||
int log_tree_commit(struct rev_info *, struct commit *);
|
||||
void show_log(struct rev_info *opt);
|
||||
void format_decorations(struct strbuf *sb, const struct commit *commit,
|
||||
int use_color, const struct decoration_options *opts);
|
||||
enum git_colorbool use_color, const struct decoration_options *opts);
|
||||
void show_decorations(struct rev_info *opt, struct commit *commit);
|
||||
void log_write_email_headers(struct rev_info *opt, struct commit *commit,
|
||||
char **extra_headers_p,
|
||||
|
||||
@@ -50,7 +50,7 @@ int parse_opt_expiry_date_cb(const struct option *opt, const char *arg,
|
||||
int parse_opt_color_flag_cb(const struct option *opt, const char *arg,
|
||||
int unset)
|
||||
{
|
||||
int value;
|
||||
enum git_colorbool value;
|
||||
|
||||
if (!arg)
|
||||
arg = unset ? "never" : (const char *)opt->defval;
|
||||
|
||||
6
pretty.c
6
pretty.c
@@ -470,7 +470,7 @@ static inline void strbuf_add_with_color(struct strbuf *sb, const char *color,
|
||||
|
||||
static void append_line_with_color(struct strbuf *sb, struct grep_opt *opt,
|
||||
const char *line, size_t linelen,
|
||||
int color, enum grep_context ctx,
|
||||
enum git_colorbool color, enum grep_context ctx,
|
||||
enum grep_header_field field)
|
||||
{
|
||||
const char *buf, *eol, *line_color, *match_color;
|
||||
@@ -899,7 +899,7 @@ struct format_commit_context {
|
||||
const char *message;
|
||||
char *commit_encoding;
|
||||
size_t width, indent1, indent2;
|
||||
int auto_color;
|
||||
enum git_colorbool auto_color;
|
||||
int padding;
|
||||
|
||||
/* These offsets are relative to the start of the commit message. */
|
||||
@@ -2167,7 +2167,7 @@ static int pp_utf8_width(const char *start, const char *end)
|
||||
}
|
||||
|
||||
static void strbuf_add_tabexpand(struct strbuf *sb, struct grep_opt *opt,
|
||||
int color, int tabwidth, const char *line,
|
||||
enum git_colorbool color, int tabwidth, const char *line,
|
||||
int linelen)
|
||||
{
|
||||
const char *tab;
|
||||
|
||||
3
pretty.h
3
pretty.h
@@ -3,6 +3,7 @@
|
||||
|
||||
#include "date.h"
|
||||
#include "string-list.h"
|
||||
#include "color.h"
|
||||
|
||||
struct commit;
|
||||
struct repository;
|
||||
@@ -46,7 +47,7 @@ struct pretty_print_context {
|
||||
struct rev_info *rev;
|
||||
const char *output_encoding;
|
||||
struct string_list *mailmap;
|
||||
int color;
|
||||
enum git_colorbool color;
|
||||
struct ident_split *from_ident;
|
||||
unsigned encode_email_headers:1;
|
||||
struct pretty_print_describe_status *describe_status;
|
||||
|
||||
@@ -95,7 +95,7 @@ struct ref_format {
|
||||
const char *format;
|
||||
const char *rest;
|
||||
int quote_style;
|
||||
int use_color;
|
||||
enum git_colorbool use_color;
|
||||
|
||||
/* Internal state to ref-filter */
|
||||
int need_color_reset_at_eol;
|
||||
|
||||
@@ -27,9 +27,9 @@ static struct keyword_entry keywords[] = {
|
||||
};
|
||||
|
||||
/* Returns a color setting (GIT_COLOR_NEVER, etc). */
|
||||
static int use_sideband_colors(void)
|
||||
static enum git_colorbool use_sideband_colors(void)
|
||||
{
|
||||
static int use_sideband_colors_cached = GIT_COLOR_UNKNOWN;
|
||||
static enum git_colorbool use_sideband_colors_cached = GIT_COLOR_UNKNOWN;
|
||||
|
||||
const char *key = "color.remote";
|
||||
struct strbuf sb = STRBUF_INIT;
|
||||
|
||||
@@ -30,7 +30,7 @@
|
||||
#include "color.h"
|
||||
#include "bundle-uri.h"
|
||||
|
||||
static int transport_use_color = GIT_COLOR_UNKNOWN;
|
||||
static enum git_colorbool transport_use_color = GIT_COLOR_UNKNOWN;
|
||||
static char transport_colors[][COLOR_MAXLEN] = {
|
||||
GIT_COLOR_RESET,
|
||||
GIT_COLOR_RED /* REJECTED */
|
||||
|
||||
@@ -111,7 +111,7 @@ struct wt_status {
|
||||
int amend;
|
||||
enum commit_whence whence;
|
||||
int nowarn;
|
||||
int use_color;
|
||||
enum git_colorbool use_color;
|
||||
int no_gettext;
|
||||
int display_comment_prefix;
|
||||
int relative_paths;
|
||||
|
||||
Reference in New Issue
Block a user