mirror of
https://github.com/neovim/neovim.git
synced 2025-09-29 06:28:35 +00:00
refactor(options): remove getoption_T
and introduce OptVal
(#23850)
Removes the `getoption_T` struct and also introduces the `OptVal` struct to unify the methods of getting/setting different option value types. This is the first of many PRs to reduce code duplication in the Vim option code as well as to make options easier to maintain. It also increases the flexibility and extensibility of options. Which opens the door for things like Array and Dictionary options.
This commit is contained in:
@@ -1112,7 +1112,7 @@ static void command_line_scan(mparm_T *parmp)
|
||||
} else if (STRNICMP(argv[0] + argv_idx, "clean", 5) == 0) {
|
||||
parmp->use_vimrc = "NONE";
|
||||
parmp->clean = true;
|
||||
set_option_value_give_err("shadafile", 0L, "NONE", 0);
|
||||
set_option_value_give_err("shadafile", STATIC_CSTR_AS_OPTVAL("NONE"), 0);
|
||||
} else if (STRNICMP(argv[0] + argv_idx, "luamod-dev", 9) == 0) {
|
||||
nlua_disable_preload = true;
|
||||
} else {
|
||||
@@ -1126,7 +1126,7 @@ static void command_line_scan(mparm_T *parmp)
|
||||
}
|
||||
break;
|
||||
case 'A': // "-A" start in Arabic mode.
|
||||
set_option_value_give_err("arabic", 1L, NULL, 0);
|
||||
set_option_value_give_err("arabic", BOOLEAN_OPTVAL(true), 0);
|
||||
break;
|
||||
case 'b': // "-b" binary mode.
|
||||
// Needs to be effective before expanding file names, because
|
||||
@@ -1156,8 +1156,8 @@ static void command_line_scan(mparm_T *parmp)
|
||||
usage();
|
||||
os_exit(0);
|
||||
case 'H': // "-H" start in Hebrew mode: rl + keymap=hebrew set.
|
||||
set_option_value_give_err("keymap", 0L, "hebrew", 0);
|
||||
set_option_value_give_err("rl", 1L, NULL, 0);
|
||||
set_option_value_give_err("keymap", STATIC_CSTR_AS_OPTVAL("hebrew"), 0);
|
||||
set_option_value_give_err("rl", BOOLEAN_OPTVAL(true), 0);
|
||||
break;
|
||||
case 'M': // "-M" no changes or writing of files
|
||||
reset_modifiable();
|
||||
@@ -1237,7 +1237,7 @@ static void command_line_scan(mparm_T *parmp)
|
||||
// default is 10: a little bit verbose
|
||||
p_verbose = get_number_arg(argv[0], &argv_idx, 10);
|
||||
if (argv[0][argv_idx] != NUL) {
|
||||
set_option_value_give_err("verbosefile", 0L, argv[0] + argv_idx, 0);
|
||||
set_option_value_give_err("verbosefile", CSTR_AS_OPTVAL(argv[0] + argv_idx), 0);
|
||||
argv_idx = (int)strlen(argv[0]);
|
||||
}
|
||||
break;
|
||||
@@ -1245,7 +1245,7 @@ static void command_line_scan(mparm_T *parmp)
|
||||
// "-w {scriptout}" write to script
|
||||
if (ascii_isdigit((argv[0])[argv_idx])) {
|
||||
n = get_number_arg(argv[0], &argv_idx, 10);
|
||||
set_option_value_give_err("window", n, NULL, 0);
|
||||
set_option_value_give_err("window", NUMBER_OPTVAL(n), 0);
|
||||
break;
|
||||
}
|
||||
want_argument = true;
|
||||
@@ -1341,7 +1341,7 @@ static void command_line_scan(mparm_T *parmp)
|
||||
break;
|
||||
|
||||
case 'i': // "-i {shada}" use for shada
|
||||
set_option_value_give_err("shadafile", 0L, argv[0], 0);
|
||||
set_option_value_give_err("shadafile", CSTR_AS_OPTVAL(argv[0]), 0);
|
||||
break;
|
||||
|
||||
case 'l': // "-l" Lua script: args after "-l".
|
||||
@@ -1351,7 +1351,7 @@ static void command_line_scan(mparm_T *parmp)
|
||||
parmp->no_swap_file = true;
|
||||
parmp->use_vimrc = parmp->use_vimrc ? parmp->use_vimrc : "NONE";
|
||||
if (p_shadafile == NULL || *p_shadafile == NUL) {
|
||||
set_option_value_give_err("shadafile", 0L, "NONE", 0);
|
||||
set_option_value_give_err("shadafile", STATIC_CSTR_AS_OPTVAL("NONE"), 0);
|
||||
}
|
||||
parmp->luaf = argv[0];
|
||||
argc--;
|
||||
@@ -1387,7 +1387,7 @@ scripterror:
|
||||
if (ascii_isdigit(*(argv[0]))) {
|
||||
argv_idx = 0;
|
||||
n = get_number_arg(argv[0], &argv_idx, 10);
|
||||
set_option_value_give_err("window", n, NULL, 0);
|
||||
set_option_value_give_err("window", NUMBER_OPTVAL(n), 0);
|
||||
argv_idx = -1;
|
||||
break;
|
||||
}
|
||||
@@ -1782,7 +1782,7 @@ static void edit_buffers(mparm_T *parmp, char *cwd)
|
||||
|
||||
p_shm_save = xstrdup(p_shm);
|
||||
snprintf(buf, sizeof(buf), "F%s", p_shm);
|
||||
set_option_value_give_err("shm", 0L, buf, 0);
|
||||
set_option_value_give_err("shm", CSTR_AS_OPTVAL(buf), 0);
|
||||
}
|
||||
} else {
|
||||
if (curwin->w_next == NULL) { // just checking
|
||||
@@ -1826,7 +1826,7 @@ static void edit_buffers(mparm_T *parmp, char *cwd)
|
||||
}
|
||||
|
||||
if (p_shm_save != NULL) {
|
||||
set_option_value_give_err("shm", 0L, p_shm_save, 0);
|
||||
set_option_value_give_err("shm", CSTR_AS_OPTVAL(p_shm_save), 0);
|
||||
xfree(p_shm_save);
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user