aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/nvim/api/vim.c2
-rw-r--r--src/nvim/main.c23
2 files changed, 13 insertions, 12 deletions
diff --git a/src/nvim/api/vim.c b/src/nvim/api/vim.c
index b82a7553cb..b691dee2ef 100644
--- a/src/nvim/api/vim.c
+++ b/src/nvim/api/vim.c
@@ -1997,7 +1997,7 @@ Array nvim_get_proc_children(Integer pid, Error *err)
DLOG("fallback to vim._os_proc_children()");
Array a = ARRAY_DICT_INIT;
ADD(a, INTEGER_OBJ(pid));
- String s = cstr_to_string("return vim._os_proc_children(select(...))");
+ String s = cstr_to_string("return vim._os_proc_children(...)");
Object o = nlua_exec(s, a, err);
api_free_string(s);
api_free_array(a);
diff --git a/src/nvim/main.c b/src/nvim/main.c
index 843ca5f855..a3588ac5df 100644
--- a/src/nvim/main.c
+++ b/src/nvim/main.c
@@ -821,7 +821,6 @@ static void handle_remote_client(mparm_T *params, int remote_args,
Boolean should_exit = true;
Boolean tabbed;
- int files;
int t_argc = remote_args;
Array args = ARRAY_DICT_INIT;
@@ -839,12 +838,17 @@ static void handle_remote_client(mparm_T *params, int remote_args,
Object o = nlua_exec(s, a, &err);
api_free_string(s);
api_free_array(a);
+ if (ERROR_SET(&err)) {
+ mch_errmsg(err.msg);
+ mch_errmsg("\n");
+ os_exit(2);
+ }
if (o.type == kObjectTypeDictionary) {
rvobj.data.dictionary = o.data.dictionary;
- } else if (!ERROR_SET(&err)) {
- api_set_error(&err, kErrorTypeException,
- "Function returned unexpected value");
+ } else {
+ mch_errmsg("vim._cs_remote returned unexpected value\n");
+ os_exit(3);
}
for (size_t i = 0; i < rvobj.data.dictionary.size ; i++) {
@@ -853,18 +857,15 @@ static void handle_remote_client(mparm_T *params, int remote_args,
tabbed = rvobj.data.dictionary.items[i].value.data.boolean;
} else if (strcmp(rvobj.data.dictionary.items[i].key.data, "should_exit") == 0) {
should_exit = rvobj.data.dictionary.items[i].value.data.boolean;
- } else if (strcmp(rvobj.data.dictionary.items[i].key.data, "files") == 0) {
- files = (int)rvobj.data.dictionary.items[i].value.data.integer;
}
}
if (should_exit) {
os_exit(0);
- } else {
- if (tabbed) {
- params->window_count = files;
- params->window_layout = WIN_TABS;
- }
+ }
+ if (tabbed) {
+ params->window_count = argc - remote_args - 1;
+ params->window_layout = WIN_TABS;
}
}