diff options
author | Lewis Russell <lewis6991@gmail.com> | 2023-01-25 10:20:45 +0000 |
---|---|---|
committer | Lewis Russell <lewis6991@gmail.com> | 2023-01-25 11:48:55 +0000 |
commit | b278e0740e1cafb5818de9de9206eea4dfee9795 (patch) | |
tree | 9714b6e2e581f503d460ab9df5d0402196bdaa66 | |
parent | 38ed4321646c8e167182c440ecd320ef12cadcad (diff) | |
download | rneovim-b278e0740e1cafb5818de9de9206eea4dfee9795.tar.gz rneovim-b278e0740e1cafb5818de9de9206eea4dfee9795.tar.bz2 rneovim-b278e0740e1cafb5818de9de9206eea4dfee9795.zip |
refactor(optionstr.c): break up did_option_listflags
-rw-r--r-- | src/nvim/optionstr.c | 44 |
1 files changed, 19 insertions, 25 deletions
diff --git a/src/nvim/optionstr.c b/src/nvim/optionstr.c index 527f9be94e..2c4ff1f22b 100644 --- a/src/nvim/optionstr.c +++ b/src/nvim/optionstr.c @@ -1533,30 +1533,14 @@ static void did_set_optexpr(buf_T *buf, win_T *win, char **varp, char **gvarp) } } -// handle options that are a list of flags. -static void did_set_option_listflags(buf_T *buf, win_T *win, char **varp, char *errbuf, - size_t errbuflen, char **errmsg) +// handle option that is a list of flags. +static void did_set_option_listflag(char **varp, char *flags, char *errbuf, size_t errbuflen, + char **errmsg) { - char *p = NULL; - if (varp == &p_ww) { // 'whichwrap' - p = WW_ALL; - } else if (varp == &p_shm) { // 'shortmess' - p = SHM_ALL; - } else if (varp == &(p_cpo)) { // 'cpoptions' - p = CPO_VI; - } else if (varp == &(buf->b_p_fo)) { // 'formatoptions' - p = FO_ALL; - } else if (varp == &win->w_p_cocu) { // 'concealcursor' - p = COCU_ALL; - } else if (varp == &p_mouse) { // 'mouse' - p = MOUSE_ALL; - } - if (p != NULL) { - for (char *s = *varp; *s; s++) { - if (vim_strchr(p, (uint8_t)(*s)) == NULL) { - *errmsg = illegal_char(errbuf, errbuflen, *s); - break; - } + for (char *s = *varp; *s; s++) { + if (vim_strchr(flags, *s) == NULL) { + *errmsg = illegal_char(errbuf, errbuflen, *s); + break; } } } @@ -1871,8 +1855,18 @@ static char *did_set_string_option_for(buf_T *buf, win_T *win, int opt_idx, char qf_process_qftf_option(&errmsg); } else if (gvarp == &p_tfu) { // 'tagfunc' set_tagfunc_option(&errmsg); - } else { - did_set_option_listflags(buf, win, varp, errbuf, errbuflen, &errmsg); + } else if (varp == &p_ww) { // 'whichwrap' + did_set_option_listflag(varp, WW_ALL, errbuf, errbuflen, &errmsg); + } else if (varp == &p_shm) { // 'shortmess' + did_set_option_listflag(varp, SHM_ALL, errbuf, errbuflen, &errmsg); + } else if (varp == &(p_cpo)) { // 'cpoptions' + did_set_option_listflag(varp, CPO_VI, errbuf, errbuflen, &errmsg); + } else if (varp == &(buf->b_p_fo)) { // 'formatoptions' + did_set_option_listflag(varp, FO_ALL, errbuf, errbuflen, &errmsg); + } else if (varp == &win->w_p_cocu) { // 'concealcursor' + did_set_option_listflag(varp, COCU_ALL, errbuf, errbuflen, &errmsg); + } else if (varp == &p_mouse) { // 'mouse' + did_set_option_listflag(varp, MOUSE_ALL, errbuf, errbuflen, &errmsg); } // If error detected, restore the previous value. |