mirror of
https://github.com/tmux/tmux.git
synced 2025-01-08 08:58:47 +00:00
Merge branch 'obsd-master'
This commit is contained in:
commit
2159ff3256
@ -136,10 +136,9 @@ cmd_command_prompt_callback(struct client *c, void *data, const char *s,
|
|||||||
int done)
|
int done)
|
||||||
{
|
{
|
||||||
struct cmd_command_prompt_cdata *cdata = data;
|
struct cmd_command_prompt_cdata *cdata = data;
|
||||||
struct cmdq_item *new_item;
|
char *new_template, *prompt, *ptr, *error;
|
||||||
char *new_template, *prompt, *ptr;
|
|
||||||
char *input = NULL;
|
char *input = NULL;
|
||||||
struct cmd_parse_result *pr;
|
enum cmd_parse_status status;
|
||||||
|
|
||||||
if (s == NULL)
|
if (s == NULL)
|
||||||
return (0);
|
return (0);
|
||||||
@ -166,21 +165,10 @@ cmd_command_prompt_callback(struct client *c, void *data, const char *s,
|
|||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
pr = cmd_parse_from_string(new_template, NULL);
|
status = cmd_parse_and_append(new_template, NULL, c, NULL, &error);
|
||||||
switch (pr->status) {
|
if (status == CMD_PARSE_ERROR) {
|
||||||
case CMD_PARSE_EMPTY:
|
cmdq_append(c, cmdq_get_error(error));
|
||||||
new_item = NULL;
|
free(error);
|
||||||
break;
|
|
||||||
case CMD_PARSE_ERROR:
|
|
||||||
new_item = cmdq_get_error(pr->error);
|
|
||||||
free(pr->error);
|
|
||||||
cmdq_append(c, new_item);
|
|
||||||
break;
|
|
||||||
case CMD_PARSE_SUCCESS:
|
|
||||||
new_item = cmdq_get_command(pr->cmdlist, NULL);
|
|
||||||
cmd_list_free(pr->cmdlist);
|
|
||||||
cmdq_append(c, new_item);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!done)
|
if (!done)
|
||||||
|
@ -87,8 +87,8 @@ cmd_confirm_before_callback(struct client *c, void *data, const char *s,
|
|||||||
__unused int done)
|
__unused int done)
|
||||||
{
|
{
|
||||||
struct cmd_confirm_before_data *cdata = data;
|
struct cmd_confirm_before_data *cdata = data;
|
||||||
struct cmdq_item *new_item;
|
char *error;
|
||||||
struct cmd_parse_result *pr;
|
enum cmd_parse_status status;
|
||||||
|
|
||||||
if (c->flags & CLIENT_DEAD)
|
if (c->flags & CLIENT_DEAD)
|
||||||
return (0);
|
return (0);
|
||||||
@ -98,21 +98,10 @@ cmd_confirm_before_callback(struct client *c, void *data, const char *s,
|
|||||||
if (tolower((u_char)s[0]) != 'y' || s[1] != '\0')
|
if (tolower((u_char)s[0]) != 'y' || s[1] != '\0')
|
||||||
return (0);
|
return (0);
|
||||||
|
|
||||||
pr = cmd_parse_from_string(cdata->cmd, NULL);
|
status = cmd_parse_and_append(cdata->cmd, NULL, c, NULL, &error);
|
||||||
switch (pr->status) {
|
if (status == CMD_PARSE_ERROR) {
|
||||||
case CMD_PARSE_EMPTY:
|
cmdq_append(c, cmdq_get_error(error));
|
||||||
new_item = NULL;
|
free(error);
|
||||||
break;
|
|
||||||
case CMD_PARSE_ERROR:
|
|
||||||
new_item = cmdq_get_error(pr->error);
|
|
||||||
free(pr->error);
|
|
||||||
cmdq_append(c, new_item);
|
|
||||||
break;
|
|
||||||
case CMD_PARSE_SUCCESS:
|
|
||||||
new_item = cmdq_get_command(pr->cmdlist, NULL);
|
|
||||||
cmd_list_free(pr->cmdlist);
|
|
||||||
cmdq_append(c, new_item);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return (0);
|
return (0);
|
||||||
|
@ -197,11 +197,10 @@ static int
|
|||||||
cmd_display_panes_key(struct client *c, struct key_event *event)
|
cmd_display_panes_key(struct client *c, struct key_event *event)
|
||||||
{
|
{
|
||||||
struct cmd_display_panes_data *cdata = c->overlay_data;
|
struct cmd_display_panes_data *cdata = c->overlay_data;
|
||||||
struct cmdq_item *new_item;
|
char *cmd, *expanded, *error;
|
||||||
char *cmd, *expanded;
|
|
||||||
struct window *w = c->session->curw->window;
|
struct window *w = c->session->curw->window;
|
||||||
struct window_pane *wp;
|
struct window_pane *wp;
|
||||||
struct cmd_parse_result *pr;
|
enum cmd_parse_status status;
|
||||||
|
|
||||||
if (event->key < '0' || event->key > '9')
|
if (event->key < '0' || event->key > '9')
|
||||||
return (-1);
|
return (-1);
|
||||||
@ -214,21 +213,10 @@ cmd_display_panes_key(struct client *c, struct key_event *event)
|
|||||||
xasprintf(&expanded, "%%%u", wp->id);
|
xasprintf(&expanded, "%%%u", wp->id);
|
||||||
cmd = cmd_template_replace(cdata->command, expanded, 1);
|
cmd = cmd_template_replace(cdata->command, expanded, 1);
|
||||||
|
|
||||||
pr = cmd_parse_from_string(cmd, NULL);
|
status = cmd_parse_and_append(cmd, NULL, c, NULL, &error);
|
||||||
switch (pr->status) {
|
if (status == CMD_PARSE_ERROR) {
|
||||||
case CMD_PARSE_EMPTY:
|
cmdq_append(c, cmdq_get_error(error));
|
||||||
new_item = NULL;
|
free(error);
|
||||||
break;
|
|
||||||
case CMD_PARSE_ERROR:
|
|
||||||
new_item = cmdq_get_error(pr->error);
|
|
||||||
free(pr->error);
|
|
||||||
cmdq_append(c, new_item);
|
|
||||||
break;
|
|
||||||
case CMD_PARSE_SUCCESS:
|
|
||||||
new_item = cmdq_get_command(pr->cmdlist, NULL);
|
|
||||||
cmd_list_free(pr->cmdlist);
|
|
||||||
cmdq_append(c, new_item);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
free(cmd);
|
free(cmd);
|
||||||
|
@ -65,13 +65,12 @@ cmd_if_shell_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
struct cmd_find_state *target = cmdq_get_target(item);
|
struct cmd_find_state *target = cmdq_get_target(item);
|
||||||
struct cmdq_state *state = cmdq_get_state(item);
|
struct cmdq_state *state = cmdq_get_state(item);
|
||||||
struct cmd_if_shell_data *cdata;
|
struct cmd_if_shell_data *cdata;
|
||||||
char *shellcmd, *cmd;
|
char *shellcmd, *cmd, *error;
|
||||||
const char *file;
|
const char *file;
|
||||||
struct cmdq_item *new_item;
|
|
||||||
struct client *c = cmd_find_client(item, NULL, 1);
|
struct client *c = cmd_find_client(item, NULL, 1);
|
||||||
struct session *s = target->s;
|
struct session *s = target->s;
|
||||||
struct cmd_parse_input pi;
|
struct cmd_parse_input pi;
|
||||||
struct cmd_parse_result *pr;
|
enum cmd_parse_status status;
|
||||||
|
|
||||||
shellcmd = format_single_from_target(item, args->argv[0], c);
|
shellcmd = format_single_from_target(item, args->argv[0], c);
|
||||||
if (args_has(args, 'F')) {
|
if (args_has(args, 'F')) {
|
||||||
@ -91,19 +90,11 @@ cmd_if_shell_exec(struct cmd *self, struct cmdq_item *item)
|
|||||||
pi.c = c;
|
pi.c = c;
|
||||||
cmd_find_copy_state(&pi.fs, target);
|
cmd_find_copy_state(&pi.fs, target);
|
||||||
|
|
||||||
pr = cmd_parse_from_string(cmd, &pi);
|
status = cmd_parse_and_insert(cmd, &pi, item, state, &error);
|
||||||
switch (pr->status) {
|
if (status == CMD_PARSE_ERROR) {
|
||||||
case CMD_PARSE_EMPTY:
|
cmdq_error(item, "%s", error);
|
||||||
break;
|
free(error);
|
||||||
case CMD_PARSE_ERROR:
|
|
||||||
cmdq_error(item, "%s", pr->error);
|
|
||||||
free(pr->error);
|
|
||||||
return (CMD_RETURN_ERROR);
|
return (CMD_RETURN_ERROR);
|
||||||
case CMD_PARSE_SUCCESS:
|
|
||||||
new_item = cmdq_get_command(pr->cmdlist, state);
|
|
||||||
cmdq_insert_after(item, new_item);
|
|
||||||
cmd_list_free(pr->cmdlist);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
return (CMD_RETURN_NORMAL);
|
return (CMD_RETURN_NORMAL);
|
||||||
}
|
}
|
||||||
|
52
cmd-parse.y
52
cmd-parse.y
@ -793,6 +793,58 @@ cmd_parse_from_string(const char *s, struct cmd_parse_input *pi)
|
|||||||
return (cmd_parse_from_buffer(s, strlen(s), pi));
|
return (cmd_parse_from_buffer(s, strlen(s), pi));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum cmd_parse_status
|
||||||
|
cmd_parse_and_insert(const char *s, struct cmd_parse_input *pi,
|
||||||
|
struct cmdq_item *after, struct cmdq_state *state, char **error)
|
||||||
|
{
|
||||||
|
struct cmd_parse_result *pr;
|
||||||
|
struct cmdq_item *item;
|
||||||
|
|
||||||
|
pr = cmd_parse_from_string(s, pi);
|
||||||
|
switch (pr->status) {
|
||||||
|
case CMD_PARSE_EMPTY:
|
||||||
|
break;
|
||||||
|
case CMD_PARSE_ERROR:
|
||||||
|
if (error != NULL)
|
||||||
|
*error = pr->error;
|
||||||
|
else
|
||||||
|
free(pr->error);
|
||||||
|
break;
|
||||||
|
case CMD_PARSE_SUCCESS:
|
||||||
|
item = cmdq_get_command(pr->cmdlist, state);
|
||||||
|
cmdq_insert_after(after, item);
|
||||||
|
cmd_list_free(pr->cmdlist);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return (pr->status);
|
||||||
|
}
|
||||||
|
|
||||||
|
enum cmd_parse_status
|
||||||
|
cmd_parse_and_append(const char *s, struct cmd_parse_input *pi,
|
||||||
|
struct client *c, struct cmdq_state *state, char **error)
|
||||||
|
{
|
||||||
|
struct cmd_parse_result *pr;
|
||||||
|
struct cmdq_item *item;
|
||||||
|
|
||||||
|
pr = cmd_parse_from_string(s, pi);
|
||||||
|
switch (pr->status) {
|
||||||
|
case CMD_PARSE_EMPTY:
|
||||||
|
break;
|
||||||
|
case CMD_PARSE_ERROR:
|
||||||
|
if (error != NULL)
|
||||||
|
*error = pr->error;
|
||||||
|
else
|
||||||
|
free(pr->error);
|
||||||
|
break;
|
||||||
|
case CMD_PARSE_SUCCESS:
|
||||||
|
item = cmdq_get_command(pr->cmdlist, state);
|
||||||
|
cmdq_append(c, item);
|
||||||
|
cmd_list_free(pr->cmdlist);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return (pr->status);
|
||||||
|
}
|
||||||
|
|
||||||
struct cmd_parse_result *
|
struct cmd_parse_result *
|
||||||
cmd_parse_from_buffer(const void *buf, size_t len, struct cmd_parse_input *pi)
|
cmd_parse_from_buffer(const void *buf, size_t len, struct cmd_parse_input *pi)
|
||||||
{
|
{
|
||||||
|
30
control.c
30
control.c
@ -56,14 +56,13 @@ control_error(struct cmdq_item *item, void *data)
|
|||||||
/* Control input callback. Read lines and fire commands. */
|
/* Control input callback. Read lines and fire commands. */
|
||||||
static void
|
static void
|
||||||
control_callback(__unused struct client *c, __unused const char *path,
|
control_callback(__unused struct client *c, __unused const char *path,
|
||||||
int error, int closed, struct evbuffer *buffer, __unused void *data)
|
int read_error, int closed, struct evbuffer *buffer, __unused void *data)
|
||||||
{
|
{
|
||||||
char *line;
|
char *line, *error;
|
||||||
struct cmdq_item *item;
|
|
||||||
struct cmdq_state *state;
|
struct cmdq_state *state;
|
||||||
struct cmd_parse_result *pr;
|
enum cmd_parse_status status;
|
||||||
|
|
||||||
if (closed || error != 0)
|
if (closed || read_error != 0)
|
||||||
c->flags |= CLIENT_EXIT;
|
c->flags |= CLIENT_EXIT;
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
@ -77,22 +76,11 @@ control_callback(__unused struct client *c, __unused const char *path,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
pr = cmd_parse_from_string(line, NULL);
|
state = cmdq_new_state(NULL, NULL, CMDQ_STATE_CONTROL);
|
||||||
switch (pr->status) {
|
status = cmd_parse_and_append(line, NULL, c, state, &error);
|
||||||
case CMD_PARSE_EMPTY:
|
if (status == CMD_PARSE_ERROR)
|
||||||
break;
|
cmdq_append(c, cmdq_get_callback(control_error, error));
|
||||||
case CMD_PARSE_ERROR:
|
cmdq_free_state(state);
|
||||||
item = cmdq_get_callback(control_error, pr->error);
|
|
||||||
cmdq_append(c, item);
|
|
||||||
break;
|
|
||||||
case CMD_PARSE_SUCCESS:
|
|
||||||
state = cmdq_new_state(NULL, NULL, CMDQ_STATE_CONTROL);
|
|
||||||
item = cmdq_get_command(pr->cmdlist, state);
|
|
||||||
cmdq_append(c, item);
|
|
||||||
cmdq_free_state(state);
|
|
||||||
cmd_list_free(pr->cmdlist);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
free(line);
|
free(line);
|
||||||
}
|
}
|
||||||
|
40
menu.c
40
menu.c
@ -183,11 +183,11 @@ menu_key_cb(struct client *c, struct key_event *event)
|
|||||||
struct mouse_event *m = &event->m;
|
struct mouse_event *m = &event->m;
|
||||||
u_int i;
|
u_int i;
|
||||||
int count = menu->count, old = md->choice;
|
int count = menu->count, old = md->choice;
|
||||||
const struct menu_item *item;
|
|
||||||
struct cmdq_item *new_item;
|
|
||||||
struct cmdq_state *new_state;
|
|
||||||
struct cmd_parse_result *pr;
|
|
||||||
const char *name;
|
const char *name;
|
||||||
|
const struct menu_item *item;
|
||||||
|
struct cmdq_state *state;
|
||||||
|
enum cmd_parse_status status;
|
||||||
|
char *error;
|
||||||
|
|
||||||
if (KEYC_IS_MOUSE(event->key)) {
|
if (KEYC_IS_MOUSE(event->key)) {
|
||||||
if (md->flags & MENU_NOMOUSE) {
|
if (md->flags & MENU_NOMOUSE) {
|
||||||
@ -272,27 +272,19 @@ chosen:
|
|||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
pr = cmd_parse_from_string(item->command, NULL);
|
if (md->item != NULL)
|
||||||
switch (pr->status) {
|
event = cmdq_get_event(md->item);
|
||||||
case CMD_PARSE_EMPTY:
|
else
|
||||||
break;
|
event = NULL;
|
||||||
case CMD_PARSE_ERROR:
|
state = cmdq_new_state(&md->fs, event, 0);
|
||||||
new_item = cmdq_get_error(pr->error);
|
|
||||||
free(pr->error);
|
status = cmd_parse_and_append(item->command, NULL, c, state, &error);
|
||||||
cmdq_append(c, new_item);
|
if (status == CMD_PARSE_ERROR) {
|
||||||
break;
|
cmdq_append(c, cmdq_get_error(error));
|
||||||
case CMD_PARSE_SUCCESS:
|
free(error);
|
||||||
if (md->item != NULL)
|
|
||||||
event = cmdq_get_event(md->item);
|
|
||||||
else
|
|
||||||
event = NULL;
|
|
||||||
new_state = cmdq_new_state(&md->fs, event, 0);
|
|
||||||
new_item = cmdq_get_command(pr->cmdlist, new_state);
|
|
||||||
cmdq_free_state(new_state);
|
|
||||||
cmd_list_free(pr->cmdlist);
|
|
||||||
cmdq_append(c, new_item);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
cmdq_free_state(state);
|
||||||
|
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
40
mode-tree.c
40
mode-tree.c
@ -1063,36 +1063,22 @@ void
|
|||||||
mode_tree_run_command(struct client *c, struct cmd_find_state *fs,
|
mode_tree_run_command(struct client *c, struct cmd_find_state *fs,
|
||||||
const char *template, const char *name)
|
const char *template, const char *name)
|
||||||
{
|
{
|
||||||
struct cmdq_item *new_item;
|
struct cmdq_state *state;
|
||||||
struct cmdq_state *new_state;
|
char *command, *error;
|
||||||
char *command;
|
enum cmd_parse_status status;
|
||||||
struct cmd_parse_result *pr;
|
|
||||||
|
|
||||||
command = cmd_template_replace(template, name, 1);
|
command = cmd_template_replace(template, name, 1);
|
||||||
if (command == NULL || *command == '\0') {
|
if (command != NULL && *command != '\0') {
|
||||||
free(command);
|
state = cmdq_new_state(fs, NULL, 0);
|
||||||
return;
|
status = cmd_parse_and_append(command, NULL, c, state, &error);
|
||||||
}
|
if (status == CMD_PARSE_ERROR) {
|
||||||
|
if (c != NULL) {
|
||||||
pr = cmd_parse_from_string(command, NULL);
|
*error = toupper((u_char)*error);
|
||||||
switch (pr->status) {
|
status_message_set(c, "%s", error);
|
||||||
case CMD_PARSE_EMPTY:
|
}
|
||||||
break;
|
free(error);
|
||||||
case CMD_PARSE_ERROR:
|
|
||||||
if (c != NULL) {
|
|
||||||
*pr->error = toupper((u_char)*pr->error);
|
|
||||||
status_message_set(c, "%s", pr->error);
|
|
||||||
}
|
}
|
||||||
free(pr->error);
|
cmdq_free_state(state);
|
||||||
break;
|
|
||||||
case CMD_PARSE_SUCCESS:
|
|
||||||
new_state = cmdq_new_state(fs, NULL, 0);
|
|
||||||
new_item = cmdq_get_command(pr->cmdlist, new_state);
|
|
||||||
cmdq_free_state(new_state);
|
|
||||||
cmdq_append(c, new_item);
|
|
||||||
cmd_list_free(pr->cmdlist);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
free(command);
|
free(command);
|
||||||
}
|
}
|
||||||
|
38
popup.c
38
popup.c
@ -222,12 +222,12 @@ popup_key_cb(struct client *c, struct key_event *event)
|
|||||||
struct popup_data *pd = c->overlay_data;
|
struct popup_data *pd = c->overlay_data;
|
||||||
struct mouse_event *m = &event->m;
|
struct mouse_event *m = &event->m;
|
||||||
struct cmd_find_state *fs = &pd->fs;
|
struct cmd_find_state *fs = &pd->fs;
|
||||||
struct cmdq_item *new_item;
|
|
||||||
struct cmdq_state *new_state;
|
|
||||||
struct cmd_parse_result *pr;
|
|
||||||
struct format_tree *ft;
|
struct format_tree *ft;
|
||||||
const char *cmd, *buf;
|
const char *cmd, *buf;
|
||||||
size_t len;
|
size_t len;
|
||||||
|
struct cmdq_state *state;
|
||||||
|
enum cmd_parse_status status;
|
||||||
|
char *error;
|
||||||
|
|
||||||
if (KEYC_IS_MOUSE(event->key)) {
|
if (KEYC_IS_MOUSE(event->key)) {
|
||||||
if (pd->dragging != OFF) {
|
if (pd->dragging != OFF) {
|
||||||
@ -295,27 +295,19 @@ popup_key_cb(struct client *c, struct key_event *event)
|
|||||||
cmd = format_expand(ft, pd->cmd);
|
cmd = format_expand(ft, pd->cmd);
|
||||||
format_free(ft);
|
format_free(ft);
|
||||||
|
|
||||||
pr = cmd_parse_from_string(cmd, NULL);
|
if (pd->item != NULL)
|
||||||
switch (pr->status) {
|
event = cmdq_get_event(pd->item);
|
||||||
case CMD_PARSE_EMPTY:
|
else
|
||||||
break;
|
event = NULL;
|
||||||
case CMD_PARSE_ERROR:
|
state = cmdq_new_state(&pd->fs, event, 0);
|
||||||
new_item = cmdq_get_error(pr->error);
|
|
||||||
free(pr->error);
|
status = cmd_parse_and_append(cmd, NULL, c, state, &error);
|
||||||
cmdq_append(c, new_item);
|
if (status == CMD_PARSE_ERROR) {
|
||||||
break;
|
cmdq_append(c, cmdq_get_error(error));
|
||||||
case CMD_PARSE_SUCCESS:
|
free(error);
|
||||||
if (pd->item != NULL)
|
|
||||||
event = cmdq_get_event(pd->item);
|
|
||||||
else
|
|
||||||
event = NULL;
|
|
||||||
new_state = cmdq_new_state(&pd->fs, event, 0);
|
|
||||||
new_item = cmdq_get_command(pr->cmdlist, new_state);
|
|
||||||
cmdq_free_state(new_state);
|
|
||||||
cmd_list_free(pr->cmdlist);
|
|
||||||
cmdq_append(c, new_item);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
cmdq_free_state(state);
|
||||||
|
|
||||||
return (1);
|
return (1);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
|
6
tmux.h
6
tmux.h
@ -2091,6 +2091,12 @@ void cmd_parse_empty(struct cmd_parse_input *);
|
|||||||
struct cmd_parse_result *cmd_parse_from_file(FILE *, struct cmd_parse_input *);
|
struct cmd_parse_result *cmd_parse_from_file(FILE *, struct cmd_parse_input *);
|
||||||
struct cmd_parse_result *cmd_parse_from_string(const char *,
|
struct cmd_parse_result *cmd_parse_from_string(const char *,
|
||||||
struct cmd_parse_input *);
|
struct cmd_parse_input *);
|
||||||
|
enum cmd_parse_status cmd_parse_and_insert(const char *,
|
||||||
|
struct cmd_parse_input *, struct cmdq_item *,
|
||||||
|
struct cmdq_state *, char **);
|
||||||
|
enum cmd_parse_status cmd_parse_and_append(const char *,
|
||||||
|
struct cmd_parse_input *, struct client *,
|
||||||
|
struct cmdq_state *, char **);
|
||||||
struct cmd_parse_result *cmd_parse_from_buffer(const void *, size_t,
|
struct cmd_parse_result *cmd_parse_from_buffer(const void *, size_t,
|
||||||
struct cmd_parse_input *);
|
struct cmd_parse_input *);
|
||||||
struct cmd_parse_result *cmd_parse_from_arguments(int, char **,
|
struct cmd_parse_result *cmd_parse_from_arguments(int, char **,
|
||||||
|
Loading…
Reference in New Issue
Block a user