mirror of
https://github.com/tmux/tmux.git
synced 2025-01-14 12:48:56 +00:00
Easy bits of arg printing for list-keys.
This commit is contained in:
parent
7325fea37d
commit
642c0b00ab
7
CHANGES
7
CHANGES
@ -1,3 +1,8 @@
|
||||
05 June 2008
|
||||
|
||||
* Infrastructure for printing arguments in list-keys output. Easy ones only for
|
||||
now.
|
||||
|
||||
04 June 2008
|
||||
|
||||
* Add some vi(1) key bindings in copy mode, and support binding ^[, ^\, ^]
|
||||
@ -403,4 +408,4 @@
|
||||
(including mutt, emacs). No status bar yet and no key remapping or other
|
||||
customisation.
|
||||
|
||||
$Id: CHANGES,v 1.109 2008-06-04 20:01:35 nicm Exp $
|
||||
$Id: CHANGES,v 1.110 2008-06-05 16:35:31 nicm Exp $
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-attach-session.c,v 1.15 2008-06-03 16:55:09 nicm Exp $ */
|
||||
/* $Id: cmd-attach-session.c,v 1.16 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -26,11 +26,11 @@
|
||||
* Attach existing session to the current terminal.
|
||||
*/
|
||||
|
||||
int cmd_attach_session_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_attach_session_exec(void *, struct cmd_ctx *);
|
||||
void cmd_attach_session_send(void *, struct buffer *);
|
||||
void cmd_attach_session_recv(void **, struct buffer *);
|
||||
void cmd_attach_session_free(void *);
|
||||
int cmd_attach_session_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_attach_session_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_attach_session_send(struct cmd *, struct buffer *);
|
||||
void cmd_attach_session_recv(struct cmd *, struct buffer *);
|
||||
void cmd_attach_session_free(struct cmd *);
|
||||
|
||||
struct cmd_attach_session_data {
|
||||
char *cname;
|
||||
@ -47,17 +47,17 @@ const struct cmd_entry cmd_attach_session_entry = {
|
||||
cmd_attach_session_send,
|
||||
cmd_attach_session_recv,
|
||||
cmd_attach_session_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_attach_session_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_attach_session_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_attach_session_data *data;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->flag_detach = 0;
|
||||
@ -93,14 +93,14 @@ cmd_attach_session_parse(
|
||||
usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
cmd_attach_session_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_attach_session_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_attach_session_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_attach_session_data *data = ptr;
|
||||
struct cmd_attach_session_data *data = self->data;
|
||||
struct session *s;
|
||||
char *cause;
|
||||
|
||||
@ -131,9 +131,9 @@ cmd_attach_session_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_attach_session_send(void *ptr, struct buffer *b)
|
||||
cmd_attach_session_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_attach_session_data *data = ptr;
|
||||
struct cmd_attach_session_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -141,20 +141,20 @@ cmd_attach_session_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_attach_session_recv(void **ptr, struct buffer *b)
|
||||
cmd_attach_session_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_attach_session_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_attach_session_free(void *ptr)
|
||||
cmd_attach_session_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_attach_session_data *data = ptr;
|
||||
struct cmd_attach_session_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-bind-key.c,v 1.12 2008-06-03 05:35:50 nicm Exp $ */
|
||||
/* $Id: cmd-bind-key.c,v 1.13 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -26,11 +26,11 @@
|
||||
* Bind a key to a command, this recurses through cmd_*.
|
||||
*/
|
||||
|
||||
int cmd_bind_key_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_bind_key_exec(void *, struct cmd_ctx *);
|
||||
void cmd_bind_key_send(void *, struct buffer *);
|
||||
void cmd_bind_key_recv(void **, struct buffer *);
|
||||
void cmd_bind_key_free(void *);
|
||||
int cmd_bind_key_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_bind_key_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_bind_key_send(struct cmd *, struct buffer *);
|
||||
void cmd_bind_key_recv(struct cmd *, struct buffer *);
|
||||
void cmd_bind_key_free(struct cmd *);
|
||||
|
||||
struct cmd_bind_key_data {
|
||||
int key;
|
||||
@ -46,17 +46,17 @@ const struct cmd_entry cmd_bind_key_entry = {
|
||||
cmd_bind_key_send,
|
||||
cmd_bind_key_recv,
|
||||
cmd_bind_key_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_bind_key_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_bind_key_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_bind_key_data *data;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cmd = NULL;
|
||||
|
||||
while ((opt = getopt(argc, argv, "")) != EOF) {
|
||||
@ -86,14 +86,14 @@ usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
error:
|
||||
cmd_bind_key_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_bind_key_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_bind_key_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_bind_key_data *data = ptr;
|
||||
struct cmd_bind_key_data *data = self->data;
|
||||
|
||||
if (data == NULL)
|
||||
return;
|
||||
@ -106,28 +106,28 @@ cmd_bind_key_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_bind_key_send(void *ptr, struct buffer *b)
|
||||
cmd_bind_key_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_bind_key_data *data = ptr;
|
||||
struct cmd_bind_key_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send(data->cmd, b);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_bind_key_recv(void **ptr, struct buffer *b)
|
||||
cmd_bind_key_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_bind_key_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cmd = cmd_recv(b);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_bind_key_free(void *ptr)
|
||||
cmd_bind_key_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_bind_key_data *data = ptr;
|
||||
struct cmd_bind_key_data *data = self->data;
|
||||
|
||||
if (data->cmd != NULL)
|
||||
cmd_free(data->cmd);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-copy-mode.c,v 1.8 2008-06-03 05:35:50 nicm Exp $ */
|
||||
/* $Id: cmd-copy-mode.c,v 1.9 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Enter copy mode. Only valid when bound to a key.
|
||||
*/
|
||||
|
||||
void cmd_copy_mode_exec(void *, struct cmd_ctx *);
|
||||
void cmd_copy_mode_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_copy_mode_entry = {
|
||||
"copy-mode", NULL,
|
||||
@ -35,15 +35,16 @@ const struct cmd_entry cmd_copy_mode_entry = {
|
||||
cmd_windowonly_send,
|
||||
cmd_windowonly_recv,
|
||||
cmd_windowonly_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_copy_mode_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_copy_mode_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct winlink *wl;
|
||||
|
||||
if ((wl = cmd_windowonly_get(ptr, ctx, NULL)) == NULL)
|
||||
if ((wl = cmd_windowonly_get(self, ctx, NULL)) == NULL)
|
||||
return;
|
||||
|
||||
window_set_mode(wl->window, &window_copy_mode);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-detach-client.c,v 1.4 2008-06-03 05:35:50 nicm Exp $ */
|
||||
/* $Id: cmd-detach-client.c,v 1.5 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Detach a client.
|
||||
*/
|
||||
|
||||
void cmd_detach_client_exec(void *, struct cmd_ctx *);
|
||||
void cmd_detach_client_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_detach_client_entry = {
|
||||
"detach-client", "detach",
|
||||
@ -35,15 +35,16 @@ const struct cmd_entry cmd_detach_client_entry = {
|
||||
cmd_clientonly_send,
|
||||
cmd_clientonly_recv,
|
||||
cmd_clientonly_free,
|
||||
NULL
|
||||
NULL,
|
||||
cmd_clientonly_print
|
||||
};
|
||||
|
||||
void
|
||||
cmd_detach_client_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_detach_client_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct client *c;
|
||||
|
||||
if ((c = cmd_clientonly_get(ptr, ctx)) == NULL)
|
||||
if ((c = cmd_clientonly_get(self, ctx)) == NULL)
|
||||
return;
|
||||
|
||||
server_write_client(c, MSG_DETACH, NULL, 0);
|
||||
|
120
cmd-generic.c
120
cmd-generic.c
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-generic.c,v 1.5 2008-06-04 16:11:52 nicm Exp $ */
|
||||
/* $Id: cmd-generic.c,v 1.6 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2008 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,13 +24,12 @@
|
||||
#include "tmux.h"
|
||||
|
||||
int
|
||||
cmd_clientonly_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_clientonly_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_clientonly_data *data;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
|
||||
while ((opt = getopt(argc, argv, "c:")) != EOF) {
|
||||
@ -53,33 +52,33 @@ cmd_clientonly_parse(
|
||||
usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
self->entry->free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_clientonly_send(void *ptr, struct buffer *b)
|
||||
cmd_clientonly_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_clientonly_data *data = ptr;
|
||||
struct cmd_clientonly_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_clientonly_recv(void **ptr, struct buffer *b)
|
||||
cmd_clientonly_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_clientonly_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_clientonly_free(void *ptr)
|
||||
cmd_clientonly_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_clientonly_data *data = ptr;
|
||||
struct cmd_clientonly_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
@ -87,23 +86,35 @@ cmd_clientonly_free(void *ptr)
|
||||
}
|
||||
|
||||
struct client *
|
||||
cmd_clientonly_get(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_clientonly_get(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_clientonly_data *data = ptr;
|
||||
struct cmd_clientonly_data *data = self->data;
|
||||
|
||||
if (data != NULL)
|
||||
return (cmd_find_client(ctx, data->cname));
|
||||
return (cmd_find_client(ctx, NULL));
|
||||
}
|
||||
|
||||
void
|
||||
cmd_clientonly_print(struct cmd *self, char *buf, size_t len)
|
||||
{
|
||||
struct cmd_clientonly_data *data = self->data;
|
||||
size_t off = 0;
|
||||
|
||||
off += xsnprintf(buf, len, "%s ", self->entry->name);
|
||||
if (data == NULL)
|
||||
return;
|
||||
if (off < len && data->cname != NULL)
|
||||
off += xsnprintf(buf + off, len - off, "-c %s ", data->cname);
|
||||
}
|
||||
|
||||
int
|
||||
cmd_sessiononly_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_sessiononly_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_sessiononly_data *data;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
|
||||
@ -135,14 +146,14 @@ cmd_sessiononly_parse(
|
||||
usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
self->entry->free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_sessiononly_send(void *ptr, struct buffer *b)
|
||||
cmd_sessiononly_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_sessiononly_data *data = ptr;
|
||||
struct cmd_sessiononly_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -150,20 +161,20 @@ cmd_sessiononly_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_sessiononly_recv(void **ptr, struct buffer *b)
|
||||
cmd_sessiononly_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_sessiononly_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_sessiononly_free(void *ptr)
|
||||
cmd_sessiononly_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_sessiononly_data *data = ptr;
|
||||
struct cmd_sessiononly_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
@ -173,24 +184,38 @@ cmd_sessiononly_free(void *ptr)
|
||||
}
|
||||
|
||||
struct session *
|
||||
cmd_sessiononly_get(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_sessiononly_get(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_sessiononly_data *data = ptr;
|
||||
struct cmd_sessiononly_data *data = self->data;
|
||||
|
||||
if (data != NULL)
|
||||
return (cmd_find_session(ctx, data->cname, data->sname));
|
||||
return (cmd_find_session(ctx, NULL, NULL));
|
||||
}
|
||||
|
||||
void
|
||||
cmd_sessiononly_print(struct cmd *self, char *buf, size_t len)
|
||||
{
|
||||
struct cmd_sessiononly_data *data = self->data;
|
||||
size_t off = 0;
|
||||
|
||||
off += xsnprintf(buf, len, "%s ", self->entry->name);
|
||||
if (data == NULL)
|
||||
return;
|
||||
if (off < len && data->cname != NULL)
|
||||
off += xsnprintf(buf + off, len - off, "-c %s ", data->cname);
|
||||
if (off < len && data->sname != NULL)
|
||||
off += xsnprintf(buf + off, len - off, "-s %s ", data->sname);
|
||||
}
|
||||
|
||||
int
|
||||
cmd_windowonly_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_windowonly_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_windowonly_data *data;
|
||||
int opt;
|
||||
const char *errstr;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->idx = -1;
|
||||
@ -231,14 +256,14 @@ usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
error:
|
||||
self->entry->free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_windowonly_send(void *ptr, struct buffer *b)
|
||||
cmd_windowonly_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_windowonly_data *data = ptr;
|
||||
struct cmd_windowonly_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -246,20 +271,20 @@ cmd_windowonly_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_windowonly_recv(void **ptr, struct buffer *b)
|
||||
cmd_windowonly_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_windowonly_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_windowonly_free(void *ptr)
|
||||
cmd_windowonly_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_windowonly_data *data = ptr;
|
||||
struct cmd_windowonly_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
@ -269,15 +294,32 @@ cmd_windowonly_free(void *ptr)
|
||||
}
|
||||
|
||||
struct winlink *
|
||||
cmd_windowonly_get(void *ptr, struct cmd_ctx *ctx, struct session **sp)
|
||||
cmd_windowonly_get(struct cmd *self, struct cmd_ctx *ctx, struct session **sp)
|
||||
{
|
||||
struct cmd_windowonly_data *data = ptr;
|
||||
struct cmd_windowonly_data *data = self->data;
|
||||
struct winlink *wl;
|
||||
|
||||
if (data == NULL) {
|
||||
wl = cmd_find_window(ctx, NULL, NULL, -1, sp);
|
||||
return (wl);
|
||||
}
|
||||
|
||||
|
||||
return (cmd_find_window(ctx, data->cname, data->sname, data->idx, sp));
|
||||
}
|
||||
|
||||
void
|
||||
cmd_windowonly_print(struct cmd *self, char *buf, size_t len)
|
||||
{
|
||||
struct cmd_windowonly_data *data = self->data;
|
||||
size_t off = 0;
|
||||
|
||||
off += xsnprintf(buf, len, "%s ", self->entry->name);
|
||||
if (data == NULL)
|
||||
return;
|
||||
if (off < len && data->cname != NULL)
|
||||
off += xsnprintf(buf + off, len - off, "-c %s ", data->cname);
|
||||
if (off < len && data->sname != NULL)
|
||||
off += xsnprintf(buf + off, len - off, "-s %s ", data->sname);
|
||||
if (off < len && data->idx != -1)
|
||||
off += xsnprintf(buf + off, len - off, "-i %d ", data->idx);
|
||||
}
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-has-session.c,v 1.7 2008-06-03 05:35:50 nicm Exp $ */
|
||||
/* $Id: cmd-has-session.c,v 1.8 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Cause client to report an error and exit with 1 if session doesn't exist.
|
||||
*/
|
||||
|
||||
void cmd_has_session_exec(void *, struct cmd_ctx *);
|
||||
void cmd_has_session_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_has_session_entry = {
|
||||
"has-session", "has",
|
||||
@ -35,15 +35,16 @@ const struct cmd_entry cmd_has_session_entry = {
|
||||
cmd_sessiononly_send,
|
||||
cmd_sessiononly_recv,
|
||||
cmd_sessiononly_free,
|
||||
NULL
|
||||
NULL,
|
||||
cmd_sessiononly_print
|
||||
};
|
||||
|
||||
void
|
||||
cmd_has_session_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_has_session_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct session *s;
|
||||
|
||||
if ((s = cmd_sessiononly_get(ptr, ctx)) == NULL)
|
||||
if ((s = cmd_sessiononly_get(self, ctx)) == NULL)
|
||||
return;
|
||||
|
||||
if (ctx->cmdclient != NULL)
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-kill-server.c,v 1.3 2008-06-03 18:13:54 nicm Exp $ */
|
||||
/* $Id: cmd-kill-server.c,v 1.4 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,7 +27,7 @@
|
||||
* Kill the server and do nothing else.
|
||||
*/
|
||||
|
||||
void cmd_kill_server_exec(void *, struct cmd_ctx *);
|
||||
void cmd_kill_server_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_kill_server_entry = {
|
||||
"kill-server", NULL,
|
||||
@ -38,11 +38,12 @@ const struct cmd_entry cmd_kill_server_entry = {
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_kill_server_exec(unused void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_kill_server_exec(unused struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
sigterm = 1;
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-kill-session.c,v 1.8 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-kill-session.c,v 1.9 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,7 +27,7 @@
|
||||
* Note this deliberately has no alias to make it hard to hit by accident.
|
||||
*/
|
||||
|
||||
void cmd_kill_session_exec(void *, struct cmd_ctx *);
|
||||
void cmd_kill_session_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_kill_session_entry = {
|
||||
"kill-session", NULL,
|
||||
@ -38,17 +38,18 @@ const struct cmd_entry cmd_kill_session_entry = {
|
||||
cmd_sessiononly_send,
|
||||
cmd_sessiononly_recv,
|
||||
cmd_sessiononly_free,
|
||||
NULL
|
||||
NULL,
|
||||
cmd_sessiononly_print
|
||||
};
|
||||
|
||||
void
|
||||
cmd_kill_session_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_kill_session_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct session *s;
|
||||
struct client *c;
|
||||
u_int i;
|
||||
|
||||
if ((s = cmd_sessiononly_get(ptr, ctx)) == NULL)
|
||||
if ((s = cmd_sessiononly_get(self, ctx)) == NULL)
|
||||
return;
|
||||
|
||||
for (i = 0; i < ARRAY_LENGTH(&clients); i++) {
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-kill-window.c,v 1.11 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-kill-window.c,v 1.12 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Destroy window.
|
||||
*/
|
||||
|
||||
void cmd_kill_window_exec(void *, struct cmd_ctx *);
|
||||
void cmd_kill_window_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_kill_window_entry = {
|
||||
"kill-window", "killw",
|
||||
@ -35,11 +35,12 @@ const struct cmd_entry cmd_kill_window_entry = {
|
||||
cmd_windowonly_send,
|
||||
cmd_windowonly_recv,
|
||||
cmd_windowonly_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_kill_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_kill_window_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct winlink *wl;
|
||||
struct session *s;
|
||||
@ -47,7 +48,7 @@ cmd_kill_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
u_int i;
|
||||
int destroyed;
|
||||
|
||||
if ((wl = cmd_windowonly_get(ptr, ctx, &s)) == NULL)
|
||||
if ((wl = cmd_windowonly_get(self, ctx, &s)) == NULL)
|
||||
return;
|
||||
|
||||
destroyed = session_detach(s, wl);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-last-window.c,v 1.9 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-last-window.c,v 1.10 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Move to last window.
|
||||
*/
|
||||
|
||||
void cmd_last_window_exec(void *, struct cmd_ctx *);
|
||||
void cmd_last_window_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_last_window_entry = {
|
||||
"last-window", "last",
|
||||
@ -35,15 +35,16 @@ const struct cmd_entry cmd_last_window_entry = {
|
||||
cmd_sessiononly_send,
|
||||
cmd_sessiononly_recv,
|
||||
cmd_sessiononly_free,
|
||||
NULL
|
||||
NULL,
|
||||
cmd_sessiononly_print
|
||||
};
|
||||
|
||||
void
|
||||
cmd_last_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_last_window_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct session *s;
|
||||
|
||||
if ((s = cmd_sessiononly_get(ptr, ctx)) == NULL)
|
||||
if ((s = cmd_sessiononly_get(self, ctx)) == NULL)
|
||||
return;
|
||||
|
||||
if (session_last(s) == 0)
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-link-window.c,v 1.16 2008-06-04 16:46:23 nicm Exp $ */
|
||||
/* $Id: cmd-link-window.c,v 1.17 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,11 +27,11 @@
|
||||
* Link a window into another session.
|
||||
*/
|
||||
|
||||
int cmd_link_window_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_link_window_exec(void *, struct cmd_ctx *);
|
||||
void cmd_link_window_send(void *, struct buffer *);
|
||||
void cmd_link_window_recv(void **, struct buffer *);
|
||||
void cmd_link_window_free(void *);
|
||||
int cmd_link_window_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_link_window_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_link_window_send(struct cmd *, struct buffer *);
|
||||
void cmd_link_window_recv(struct cmd *, struct buffer *);
|
||||
void cmd_link_window_free(struct cmd *);
|
||||
|
||||
struct cmd_link_window_data {
|
||||
char *cname;
|
||||
@ -52,18 +52,18 @@ const struct cmd_entry cmd_link_window_entry = {
|
||||
cmd_link_window_send,
|
||||
cmd_link_window_recv,
|
||||
cmd_link_window_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_link_window_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_link_window_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_link_window_data *data;
|
||||
const char *errstr;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->flag_detached = 0;
|
||||
@ -121,14 +121,14 @@ usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
error:
|
||||
cmd_link_window_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_link_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_link_window_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_link_window_data *data = ptr;
|
||||
struct cmd_link_window_data *data = self->data;
|
||||
struct session *s, *src;
|
||||
struct winlink *wl, *wl2;
|
||||
|
||||
@ -202,9 +202,9 @@ cmd_link_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_link_window_send(void *ptr, struct buffer *b)
|
||||
cmd_link_window_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_link_window_data *data = ptr;
|
||||
struct cmd_link_window_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -213,11 +213,11 @@ cmd_link_window_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_link_window_recv(void **ptr, struct buffer *b)
|
||||
cmd_link_window_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_link_window_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
@ -225,9 +225,9 @@ cmd_link_window_recv(void **ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_link_window_free(void *ptr)
|
||||
cmd_link_window_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_link_window_data *data = ptr;
|
||||
struct cmd_link_window_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-list-clients.c,v 1.6 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-list-clients.c,v 1.7 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,7 +27,7 @@
|
||||
* List all clients.
|
||||
*/
|
||||
|
||||
void cmd_list_clients_exec(void *, struct cmd_ctx *);
|
||||
void cmd_list_clients_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_list_clients_entry = {
|
||||
"list-clients", "lsc",
|
||||
@ -38,11 +38,12 @@ const struct cmd_entry cmd_list_clients_entry = {
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_list_clients_exec(unused void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_list_clients_exec(unused struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct client *c;
|
||||
u_int i;
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-list-keys.c,v 1.8 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-list-keys.c,v 1.9 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* List key bindings.
|
||||
*/
|
||||
|
||||
void cmd_list_keys_exec(void *, struct cmd_ctx *);
|
||||
void cmd_list_keys_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_list_keys_entry = {
|
||||
"list-keys", "lsk",
|
||||
@ -35,21 +35,28 @@ const struct cmd_entry cmd_list_keys_entry = {
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL
|
||||
NULL,
|
||||
NULL,
|
||||
};
|
||||
|
||||
void
|
||||
cmd_list_keys_exec(unused void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_list_keys_exec(unused struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct binding *bd;
|
||||
const char *key;
|
||||
char s[BUFSIZ];
|
||||
u_int i;
|
||||
|
||||
for (i = 0; i < ARRAY_LENGTH(&key_bindings); i++) {
|
||||
bd = ARRAY_ITEM(&key_bindings, i);
|
||||
if ((key = key_string_lookup_key(bd->key)) == NULL)
|
||||
continue;
|
||||
ctx->print(ctx, "%11s: %s", key, bd->cmd->entry->name);
|
||||
if (bd->cmd->entry->print == NULL) {
|
||||
ctx->print(ctx, "%11s: %s", key, bd->cmd->entry->name);
|
||||
continue;
|
||||
}
|
||||
bd->cmd->entry->print(bd->cmd, s, sizeof s);
|
||||
ctx->print(ctx, "%11s: %s", key, s);
|
||||
}
|
||||
|
||||
if (ctx->cmdclient != NULL)
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-list-sessions.c,v 1.13 2008-06-03 18:13:54 nicm Exp $ */
|
||||
/* $Id: cmd-list-sessions.c,v 1.14 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,7 +27,7 @@
|
||||
* List all sessions.
|
||||
*/
|
||||
|
||||
void cmd_list_sessions_exec(void *, struct cmd_ctx *);
|
||||
void cmd_list_sessions_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_list_sessions_entry = {
|
||||
"list-sessions", "ls", "",
|
||||
@ -37,11 +37,12 @@ const struct cmd_entry cmd_list_sessions_entry = {
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_list_sessions_exec(unused void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_list_sessions_exec(unused struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct session *s;
|
||||
struct winlink *wl;
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-list-windows.c,v 1.18 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-list-windows.c,v 1.19 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -26,7 +26,7 @@
|
||||
* List windows on given session.
|
||||
*/
|
||||
|
||||
void cmd_list_windows_exec(void *, struct cmd_ctx *);
|
||||
void cmd_list_windows_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_list_windows_entry = {
|
||||
"list-windows", "lsw",
|
||||
@ -37,11 +37,12 @@ const struct cmd_entry cmd_list_windows_entry = {
|
||||
cmd_sessiononly_send,
|
||||
cmd_sessiononly_recv,
|
||||
cmd_sessiononly_free,
|
||||
NULL
|
||||
NULL,
|
||||
cmd_sessiononly_print
|
||||
};
|
||||
|
||||
void
|
||||
cmd_list_windows_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_list_windows_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct session *s;
|
||||
struct winlink *wl;
|
||||
@ -49,7 +50,7 @@ cmd_list_windows_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
u_int i;
|
||||
unsigned long long size;
|
||||
|
||||
if ((s = cmd_sessiononly_get(ptr, ctx)) == NULL)
|
||||
if ((s = cmd_sessiononly_get(self, ctx)) == NULL)
|
||||
return;
|
||||
|
||||
RB_FOREACH(wl, winlinks, &s->windows) {
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-new-session.c,v 1.24 2008-06-03 21:42:37 nicm Exp $ */
|
||||
/* $Id: cmd-new-session.c,v 1.25 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -26,12 +26,12 @@
|
||||
* Create a new session and attach to the current terminal unless -d is given.
|
||||
*/
|
||||
|
||||
int cmd_new_session_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_new_session_exec(void *, struct cmd_ctx *);
|
||||
void cmd_new_session_send(void *, struct buffer *);
|
||||
void cmd_new_session_recv(void **, struct buffer *);
|
||||
void cmd_new_session_free(void *);
|
||||
void cmd_new_session_init(void **, int);
|
||||
int cmd_new_session_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_new_session_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_new_session_send(struct cmd *, struct buffer *);
|
||||
void cmd_new_session_recv(struct cmd *, struct buffer *);
|
||||
void cmd_new_session_free(struct cmd *);
|
||||
void cmd_new_session_init(struct cmd *, int);
|
||||
|
||||
struct cmd_new_session_data {
|
||||
char *name;
|
||||
@ -49,15 +49,16 @@ const struct cmd_entry cmd_new_session_entry = {
|
||||
cmd_new_session_send,
|
||||
cmd_new_session_recv,
|
||||
cmd_new_session_free,
|
||||
cmd_new_session_init
|
||||
cmd_new_session_init,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_new_session_init(void **ptr, unused int arg)
|
||||
cmd_new_session_init(struct cmd *self, unused int arg)
|
||||
{
|
||||
struct cmd_new_session_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->flag_detached = 0;
|
||||
data->name = NULL;
|
||||
data->winname = NULL;
|
||||
@ -65,14 +66,13 @@ cmd_new_session_init(void **ptr, unused int arg)
|
||||
}
|
||||
|
||||
int
|
||||
cmd_new_session_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_new_session_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_new_session_data *data;
|
||||
int opt;
|
||||
|
||||
self->entry->init(ptr, 0);
|
||||
data = *ptr;
|
||||
self->entry->init(self, 0);
|
||||
data = self->data;
|
||||
|
||||
while ((opt = getopt(argc, argv, "ds:n:")) != EOF) {
|
||||
switch (opt) {
|
||||
@ -102,14 +102,14 @@ cmd_new_session_parse(
|
||||
usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
cmd_new_session_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_new_session_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_new_session_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_new_session_data *data = ptr;
|
||||
struct cmd_new_session_data *data = self->data;
|
||||
struct client *c = ctx->cmdclient;
|
||||
struct session *s;
|
||||
char *cmd, *cause;
|
||||
@ -175,9 +175,9 @@ cmd_new_session_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_new_session_send(void *ptr, struct buffer *b)
|
||||
cmd_new_session_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_new_session_data *data = ptr;
|
||||
struct cmd_new_session_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->name);
|
||||
@ -186,11 +186,11 @@ cmd_new_session_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_new_session_recv(void **ptr, struct buffer *b)
|
||||
cmd_new_session_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_new_session_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->name = cmd_recv_string(b);
|
||||
data->winname = cmd_recv_string(b);
|
||||
@ -198,9 +198,9 @@ cmd_new_session_recv(void **ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_new_session_free(void *ptr)
|
||||
cmd_new_session_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_new_session_data *data = ptr;
|
||||
struct cmd_new_session_data *data = self->data;
|
||||
|
||||
if (data->name != NULL)
|
||||
xfree(data->name);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-new-window.c,v 1.20 2008-06-03 21:42:37 nicm Exp $ */
|
||||
/* $Id: cmd-new-window.c,v 1.21 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,12 +27,12 @@
|
||||
* Create a new window.
|
||||
*/
|
||||
|
||||
int cmd_new_window_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_new_window_exec(void *, struct cmd_ctx *);
|
||||
void cmd_new_window_send(void *, struct buffer *);
|
||||
void cmd_new_window_recv(void **, struct buffer *);
|
||||
void cmd_new_window_free(void *);
|
||||
void cmd_new_window_init(void **, int);
|
||||
int cmd_new_window_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_new_window_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_new_window_send(struct cmd *, struct buffer *);
|
||||
void cmd_new_window_recv(struct cmd *, struct buffer *);
|
||||
void cmd_new_window_free(struct cmd *);
|
||||
void cmd_new_window_init(struct cmd *, int);
|
||||
|
||||
struct cmd_new_window_data {
|
||||
char *cname;
|
||||
@ -52,15 +52,16 @@ const struct cmd_entry cmd_new_window_entry = {
|
||||
cmd_new_window_send,
|
||||
cmd_new_window_recv,
|
||||
cmd_new_window_free,
|
||||
cmd_new_window_init
|
||||
cmd_new_window_init,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_new_window_init(void **ptr, unused int arg)
|
||||
cmd_new_window_init(struct cmd *self, unused int arg)
|
||||
{
|
||||
struct cmd_new_window_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->idx = -1;
|
||||
@ -70,15 +71,14 @@ cmd_new_window_init(void **ptr, unused int arg)
|
||||
}
|
||||
|
||||
int
|
||||
cmd_new_window_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_new_window_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_new_window_data *data;
|
||||
const char *errstr;
|
||||
int opt;
|
||||
|
||||
self->entry->init(ptr, 0);
|
||||
data = *ptr;
|
||||
self->entry->init(self, 0);
|
||||
data = self->data;
|
||||
|
||||
while ((opt = getopt(argc, argv, "c:di:n:s:")) != EOF) {
|
||||
switch (opt) {
|
||||
@ -126,14 +126,14 @@ usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
error:
|
||||
cmd_new_window_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_new_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_new_window_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_new_window_data *data = ptr;
|
||||
struct cmd_new_window_data *data = self->data;
|
||||
struct session *s;
|
||||
struct winlink *wl;
|
||||
char *cmd;
|
||||
@ -163,9 +163,9 @@ cmd_new_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_new_window_send(void *ptr, struct buffer *b)
|
||||
cmd_new_window_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_new_window_data *data = ptr;
|
||||
struct cmd_new_window_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -175,11 +175,11 @@ cmd_new_window_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_new_window_recv(void **ptr, struct buffer *b)
|
||||
cmd_new_window_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_new_window_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
@ -188,9 +188,9 @@ cmd_new_window_recv(void **ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_new_window_free(void *ptr)
|
||||
cmd_new_window_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_new_window_data *data = ptr;
|
||||
struct cmd_new_window_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-next-window.c,v 1.9 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-next-window.c,v 1.10 2008-06-05 16:35:31 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Move to next window.
|
||||
*/
|
||||
|
||||
void cmd_next_window_exec(void *, struct cmd_ctx *);
|
||||
void cmd_next_window_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_next_window_entry = {
|
||||
"next-window", "next",
|
||||
@ -35,15 +35,16 @@ const struct cmd_entry cmd_next_window_entry = {
|
||||
cmd_sessiononly_send,
|
||||
cmd_sessiononly_recv,
|
||||
cmd_sessiononly_free,
|
||||
NULL
|
||||
NULL,
|
||||
cmd_sessiononly_print
|
||||
};
|
||||
|
||||
void
|
||||
cmd_next_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_next_window_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct session *s;
|
||||
|
||||
if ((s = cmd_sessiononly_get(ptr, ctx)) == NULL)
|
||||
if ((s = cmd_sessiononly_get(self, ctx)) == NULL)
|
||||
return;
|
||||
|
||||
if (session_next(s) == 0)
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-paste-buffer.c,v 1.6 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-paste-buffer.c,v 1.7 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -26,7 +26,7 @@
|
||||
* Paste paste buffer if present.
|
||||
*/
|
||||
|
||||
void cmd_paste_buffer_exec(void *, struct cmd_ctx *);
|
||||
void cmd_paste_buffer_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_paste_buffer_entry = {
|
||||
"paste-buffer", "paste",
|
||||
@ -37,15 +37,16 @@ const struct cmd_entry cmd_paste_buffer_entry = {
|
||||
cmd_windowonly_send,
|
||||
cmd_windowonly_recv,
|
||||
cmd_windowonly_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_paste_buffer_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_paste_buffer_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct winlink *wl;
|
||||
|
||||
if ((wl = cmd_windowonly_get(ptr, ctx, NULL)) == NULL)
|
||||
if ((wl = cmd_windowonly_get(self, ctx, NULL)) == NULL)
|
||||
return;
|
||||
|
||||
if (paste_buffer != NULL && *paste_buffer != '\0') {
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-previous-window.c,v 1.9 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-previous-window.c,v 1.10 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Move to previous window.
|
||||
*/
|
||||
|
||||
void cmd_previous_window_exec(void *, struct cmd_ctx *);
|
||||
void cmd_previous_window_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_previous_window_entry = {
|
||||
"previous-window", "prev",
|
||||
@ -35,15 +35,16 @@ const struct cmd_entry cmd_previous_window_entry = {
|
||||
cmd_sessiononly_send,
|
||||
cmd_sessiononly_recv,
|
||||
cmd_sessiononly_free,
|
||||
NULL
|
||||
NULL,
|
||||
cmd_sessiononly_print
|
||||
};
|
||||
|
||||
void
|
||||
cmd_previous_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_previous_window_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct session *s;
|
||||
|
||||
if ((s = cmd_sessiononly_get(ptr, ctx)) == NULL)
|
||||
if ((s = cmd_sessiononly_get(self, ctx)) == NULL)
|
||||
return;
|
||||
|
||||
if (session_previous(s) == 0)
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-refresh-client.c,v 1.4 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-refresh-client.c,v 1.5 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Refresh client.
|
||||
*/
|
||||
|
||||
void cmd_refresh_client_exec(void *, struct cmd_ctx *);
|
||||
void cmd_refresh_client_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_refresh_client_entry = {
|
||||
"refresh-client", "refresh",
|
||||
@ -35,15 +35,16 @@ const struct cmd_entry cmd_refresh_client_entry = {
|
||||
cmd_clientonly_send,
|
||||
cmd_clientonly_recv,
|
||||
cmd_clientonly_free,
|
||||
NULL
|
||||
NULL,
|
||||
cmd_clientonly_print
|
||||
};
|
||||
|
||||
void
|
||||
cmd_refresh_client_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_refresh_client_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct client *c;
|
||||
|
||||
if ((c = cmd_clientonly_get(ptr, ctx)) == NULL)
|
||||
if ((c = cmd_clientonly_get(self, ctx)) == NULL)
|
||||
return;
|
||||
|
||||
server_redraw_client(c);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-rename-session.c,v 1.8 2008-06-03 16:55:09 nicm Exp $ */
|
||||
/* $Id: cmd-rename-session.c,v 1.9 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,11 +27,11 @@
|
||||
* Change session name.
|
||||
*/
|
||||
|
||||
int cmd_rename_session_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_rename_session_exec(void *, struct cmd_ctx *);
|
||||
void cmd_rename_session_send(void *, struct buffer *);
|
||||
void cmd_rename_session_recv(void **, struct buffer *);
|
||||
void cmd_rename_session_free(void *);
|
||||
int cmd_rename_session_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_rename_session_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_rename_session_send(struct cmd *, struct buffer *);
|
||||
void cmd_rename_session_recv(struct cmd *, struct buffer *);
|
||||
void cmd_rename_session_free(struct cmd *);
|
||||
|
||||
struct cmd_rename_session_data {
|
||||
char *cname;
|
||||
@ -48,17 +48,17 @@ const struct cmd_entry cmd_rename_session_entry = {
|
||||
cmd_rename_session_send,
|
||||
cmd_rename_session_recv,
|
||||
cmd_rename_session_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_rename_session_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_rename_session_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_rename_session_data *data;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->newname = NULL;
|
||||
@ -93,14 +93,14 @@ cmd_rename_session_parse(
|
||||
usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
cmd_rename_session_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_rename_session_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_rename_session_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_rename_session_data *data = ptr;
|
||||
struct cmd_rename_session_data *data = self->data;
|
||||
struct session *s;
|
||||
|
||||
if (data == NULL)
|
||||
@ -117,9 +117,9 @@ cmd_rename_session_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_rename_session_send(void *ptr, struct buffer *b)
|
||||
cmd_rename_session_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_rename_session_data *data = ptr;
|
||||
struct cmd_rename_session_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -128,11 +128,11 @@ cmd_rename_session_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_rename_session_recv(void **ptr, struct buffer *b)
|
||||
cmd_rename_session_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_rename_session_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
@ -140,9 +140,9 @@ cmd_rename_session_recv(void **ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_rename_session_free(void *ptr)
|
||||
cmd_rename_session_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_rename_session_data *data = ptr;
|
||||
struct cmd_rename_session_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-rename-window.c,v 1.19 2008-06-04 17:54:26 nicm Exp $ */
|
||||
/* $Id: cmd-rename-window.c,v 1.20 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,11 +27,11 @@
|
||||
* Rename window by index.
|
||||
*/
|
||||
|
||||
int cmd_rename_window_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_rename_window_exec(void *, struct cmd_ctx *);
|
||||
void cmd_rename_window_send(void *, struct buffer *);
|
||||
void cmd_rename_window_recv(void **, struct buffer *);
|
||||
void cmd_rename_window_free(void *);
|
||||
int cmd_rename_window_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_rename_window_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_rename_window_send(struct cmd *, struct buffer *);
|
||||
void cmd_rename_window_recv(struct cmd *, struct buffer *);
|
||||
void cmd_rename_window_free(struct cmd *);
|
||||
|
||||
struct cmd_rename_window_data {
|
||||
char *cname;
|
||||
@ -49,18 +49,18 @@ const struct cmd_entry cmd_rename_window_entry = {
|
||||
cmd_rename_window_send,
|
||||
cmd_rename_window_recv,
|
||||
cmd_rename_window_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_rename_window_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_rename_window_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_rename_window_data *data;
|
||||
const char *errstr;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->idx = -1;
|
||||
@ -104,14 +104,14 @@ usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
error:
|
||||
cmd_rename_window_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_rename_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_rename_window_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_rename_window_data *data = ptr;
|
||||
struct cmd_rename_window_data *data = self->data;
|
||||
struct session *s;
|
||||
struct winlink *wl;
|
||||
|
||||
@ -132,9 +132,9 @@ cmd_rename_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_rename_window_send(void *ptr, struct buffer *b)
|
||||
cmd_rename_window_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_rename_window_data *data = ptr;
|
||||
struct cmd_rename_window_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -143,11 +143,11 @@ cmd_rename_window_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_rename_window_recv(void **ptr, struct buffer *b)
|
||||
cmd_rename_window_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_rename_window_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
@ -155,9 +155,9 @@ cmd_rename_window_recv(void **ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_rename_window_free(void *ptr)
|
||||
cmd_rename_window_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_rename_window_data *data = ptr;
|
||||
struct cmd_rename_window_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-scroll-mode.c,v 1.10 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-scroll-mode.c,v 1.11 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Enter scroll mode. Only valid when bound to a key.
|
||||
*/
|
||||
|
||||
void cmd_scroll_mode_exec(void *, struct cmd_ctx *);
|
||||
void cmd_scroll_mode_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_scroll_mode_entry = {
|
||||
"scroll-mode", NULL,
|
||||
@ -35,15 +35,16 @@ const struct cmd_entry cmd_scroll_mode_entry = {
|
||||
cmd_windowonly_send,
|
||||
cmd_windowonly_recv,
|
||||
cmd_windowonly_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_scroll_mode_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_scroll_mode_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct winlink *wl;
|
||||
|
||||
if ((wl = cmd_windowonly_get(ptr, ctx, NULL)) == NULL)
|
||||
if ((wl = cmd_windowonly_get(self, ctx, NULL)) == NULL)
|
||||
return;
|
||||
|
||||
window_set_mode(wl->window, &window_scroll_mode);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-select-window.c,v 1.16 2008-06-04 16:11:52 nicm Exp $ */
|
||||
/* $Id: cmd-select-window.c,v 1.17 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,8 +27,8 @@
|
||||
* Select window by index.
|
||||
*/
|
||||
|
||||
void cmd_select_window_init(void **, int);
|
||||
void cmd_select_window_exec(void *, struct cmd_ctx *);
|
||||
void cmd_select_window_init(struct cmd *, int);
|
||||
void cmd_select_window_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_select_window_entry = {
|
||||
"select-window", "selectw",
|
||||
@ -39,27 +39,28 @@ const struct cmd_entry cmd_select_window_entry = {
|
||||
cmd_windowonly_send,
|
||||
cmd_windowonly_recv,
|
||||
cmd_windowonly_free,
|
||||
cmd_select_window_init
|
||||
cmd_select_window_init,
|
||||
cmd_windowonly_print
|
||||
};
|
||||
|
||||
void
|
||||
cmd_select_window_init(void **ptr, int arg)
|
||||
cmd_select_window_init(struct cmd *self, int arg)
|
||||
{
|
||||
struct cmd_windowonly_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->idx = arg - '0';
|
||||
}
|
||||
|
||||
void
|
||||
cmd_select_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_select_window_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct winlink *wl;
|
||||
struct session *s;
|
||||
|
||||
if ((wl = cmd_windowonly_get(ptr, ctx, &s)) == NULL)
|
||||
if ((wl = cmd_windowonly_get(self, ctx, &s)) == NULL)
|
||||
return;
|
||||
|
||||
if (session_select(s, wl->idx) == 0)
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-send-keys.c,v 1.7 2008-06-03 16:55:09 nicm Exp $ */
|
||||
/* $Id: cmd-send-keys.c,v 1.8 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2008 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,11 +27,11 @@
|
||||
* Send keys to client.
|
||||
*/
|
||||
|
||||
int cmd_send_keys_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_send_keys_exec(void *, struct cmd_ctx *);
|
||||
void cmd_send_keys_send(void *, struct buffer *);
|
||||
void cmd_send_keys_recv(void **, struct buffer *);
|
||||
void cmd_send_keys_free(void *);
|
||||
int cmd_send_keys_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_send_keys_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_send_keys_send(struct cmd *, struct buffer *);
|
||||
void cmd_send_keys_recv(struct cmd *, struct buffer *);
|
||||
void cmd_send_keys_free(struct cmd *);
|
||||
|
||||
struct cmd_send_keys_data {
|
||||
char *cname;
|
||||
@ -50,19 +50,19 @@ const struct cmd_entry cmd_send_keys_entry = {
|
||||
cmd_send_keys_send,
|
||||
cmd_send_keys_recv,
|
||||
cmd_send_keys_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_send_keys_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_send_keys_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_send_keys_data *data;
|
||||
int opt, key;
|
||||
const char *errstr;
|
||||
char *s;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->idx = -1;
|
||||
@ -121,14 +121,14 @@ usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
error:
|
||||
cmd_send_keys_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_send_keys_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_send_keys_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_send_keys_data *data = ptr;
|
||||
struct cmd_send_keys_data *data = self->data;
|
||||
struct winlink *wl;
|
||||
u_int i;
|
||||
|
||||
@ -147,9 +147,9 @@ cmd_send_keys_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_send_keys_send(void *ptr, struct buffer *b)
|
||||
cmd_send_keys_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_send_keys_data *data = ptr;
|
||||
struct cmd_send_keys_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -158,11 +158,11 @@ cmd_send_keys_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_send_keys_recv(void **ptr, struct buffer *b)
|
||||
cmd_send_keys_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_send_keys_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
@ -171,9 +171,9 @@ cmd_send_keys_recv(void **ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_send_keys_free(void *ptr)
|
||||
cmd_send_keys_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_send_keys_data *data = ptr;
|
||||
struct cmd_send_keys_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-send-prefix.c,v 1.12 2008-06-03 21:42:37 nicm Exp $ */
|
||||
/* $Id: cmd-send-prefix.c,v 1.13 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Send prefix key as a key.
|
||||
*/
|
||||
|
||||
void cmd_send_prefix_exec(void *, struct cmd_ctx *);
|
||||
void cmd_send_prefix_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_send_prefix_entry = {
|
||||
"send-prefix", NULL,
|
||||
@ -35,16 +35,17 @@ const struct cmd_entry cmd_send_prefix_entry = {
|
||||
cmd_windowonly_send,
|
||||
cmd_windowonly_recv,
|
||||
cmd_windowonly_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_send_prefix_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_send_prefix_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct session *s;
|
||||
struct winlink *wl;
|
||||
|
||||
if ((wl = cmd_windowonly_get(ptr, ctx, &s)) == NULL)
|
||||
if ((wl = cmd_windowonly_get(self, ctx, &s)) == NULL)
|
||||
return;
|
||||
|
||||
window_key(wl->window, options_get_number(&s->options, "prefix-key"));
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-set-option.c,v 1.22 2008-06-04 18:34:56 nicm Exp $ */
|
||||
/* $Id: cmd-set-option.c,v 1.23 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -28,11 +28,11 @@
|
||||
* Set an option.
|
||||
*/
|
||||
|
||||
int cmd_set_option_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_set_option_exec(void *, struct cmd_ctx *);
|
||||
void cmd_set_option_send(void *, struct buffer *);
|
||||
void cmd_set_option_recv(void **, struct buffer *);
|
||||
void cmd_set_option_free(void *);
|
||||
int cmd_set_option_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_set_option_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_set_option_send(struct cmd *, struct buffer *);
|
||||
void cmd_set_option_recv(struct cmd *, struct buffer *);
|
||||
void cmd_set_option_free(struct cmd *);
|
||||
|
||||
struct cmd_set_option_data {
|
||||
char *cname;
|
||||
@ -51,17 +51,17 @@ const struct cmd_entry cmd_set_option_entry = {
|
||||
cmd_set_option_send,
|
||||
cmd_set_option_recv,
|
||||
cmd_set_option_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_set_option_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_set_option_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_set_option_data *data;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->flag_global = 1;
|
||||
@ -102,14 +102,14 @@ cmd_set_option_parse(
|
||||
usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
cmd_set_option_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_set_option_exec(void *ptr, unused struct cmd_ctx *ctx)
|
||||
cmd_set_option_exec(struct cmd *self, unused struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_set_option_data *data = ptr;
|
||||
struct cmd_set_option_data *data = self->data;
|
||||
struct client *c;
|
||||
struct session *s;
|
||||
struct options *oo;
|
||||
@ -276,9 +276,9 @@ cmd_set_option_exec(void *ptr, unused struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_set_option_send(void *ptr, struct buffer *b)
|
||||
cmd_set_option_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_set_option_data *data = ptr;
|
||||
struct cmd_set_option_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -288,11 +288,11 @@ cmd_set_option_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_set_option_recv(void **ptr, struct buffer *b)
|
||||
cmd_set_option_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_set_option_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
@ -301,9 +301,9 @@ cmd_set_option_recv(void **ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_set_option_free(void *ptr)
|
||||
cmd_set_option_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_set_option_data *data = ptr;
|
||||
struct cmd_set_option_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-set-window-option.c,v 1.2 2008-06-04 18:32:20 nicm Exp $ */
|
||||
/* $Id: cmd-set-window-option.c,v 1.3 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -28,12 +28,11 @@
|
||||
* Set a window option.
|
||||
*/
|
||||
|
||||
int cmd_set_window_option_parse(
|
||||
struct cmd *, void **, int, char **, char **);
|
||||
void cmd_set_window_option_exec(void *, struct cmd_ctx *);
|
||||
void cmd_set_window_option_send(void *, struct buffer *);
|
||||
void cmd_set_window_option_recv(void **, struct buffer *);
|
||||
void cmd_set_window_option_free(void *);
|
||||
int cmd_set_window_option_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_set_window_option_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_set_window_option_send(struct cmd *, struct buffer *);
|
||||
void cmd_set_window_option_recv(struct cmd *, struct buffer *);
|
||||
void cmd_set_window_option_free(struct cmd *);
|
||||
|
||||
struct cmd_set_window_option_data {
|
||||
char *cname;
|
||||
@ -52,18 +51,19 @@ const struct cmd_entry cmd_set_window_option_entry = {
|
||||
cmd_set_window_option_send,
|
||||
cmd_set_window_option_recv,
|
||||
cmd_set_window_option_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_set_window_option_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_set_window_option_data *data;
|
||||
int opt;
|
||||
const char *errstr;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->idx = -1;
|
||||
@ -110,14 +110,14 @@ usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
error:
|
||||
cmd_set_window_option_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_set_window_option_exec(void *ptr, unused struct cmd_ctx *ctx)
|
||||
cmd_set_window_option_exec(struct cmd *self, unused struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_set_window_option_data *data = ptr;
|
||||
struct cmd_set_window_option_data *data = self->data;
|
||||
struct winlink *wl;
|
||||
struct session *s;
|
||||
const char *errstr;
|
||||
@ -183,9 +183,9 @@ cmd_set_window_option_exec(void *ptr, unused struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_set_window_option_send(void *ptr, struct buffer *b)
|
||||
cmd_set_window_option_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_set_window_option_data *data = ptr;
|
||||
struct cmd_set_window_option_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -195,11 +195,11 @@ cmd_set_window_option_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_set_window_option_recv(void **ptr, struct buffer *b)
|
||||
cmd_set_window_option_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_set_window_option_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
@ -208,9 +208,9 @@ cmd_set_window_option_recv(void **ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_set_window_option_free(void *ptr)
|
||||
cmd_set_window_option_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_set_window_option_data *data = ptr;
|
||||
struct cmd_set_window_option_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-start-server.c,v 1.3 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-start-server.c,v 1.4 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Start the server and do nothing else.
|
||||
*/
|
||||
|
||||
void cmd_start_server_exec(void *, struct cmd_ctx *);
|
||||
void cmd_start_server_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_start_server_entry = {
|
||||
"start-server", "start",
|
||||
@ -35,11 +35,12 @@ const struct cmd_entry cmd_start_server_entry = {
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_start_server_exec(unused void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_start_server_exec(unused struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
if (ctx->cmdclient != NULL)
|
||||
server_write_client(ctx->cmdclient, MSG_EXIT, NULL, 0);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-swap-window.c,v 1.8 2008-06-03 16:55:09 nicm Exp $ */
|
||||
/* $Id: cmd-swap-window.c,v 1.9 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -27,11 +27,11 @@
|
||||
* Swap one window with another.
|
||||
*/
|
||||
|
||||
int cmd_swap_window_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_swap_window_exec(void *, struct cmd_ctx *);
|
||||
void cmd_swap_window_send(void *, struct buffer *);
|
||||
void cmd_swap_window_recv(void **, struct buffer *);
|
||||
void cmd_swap_window_free(void *);
|
||||
int cmd_swap_window_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_swap_window_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_swap_window_send(struct cmd *, struct buffer *);
|
||||
void cmd_swap_window_recv(struct cmd *, struct buffer *);
|
||||
void cmd_swap_window_free(struct cmd *);
|
||||
|
||||
struct cmd_swap_window_data {
|
||||
char *cname;
|
||||
@ -51,18 +51,18 @@ const struct cmd_entry cmd_swap_window_entry = {
|
||||
cmd_swap_window_send,
|
||||
cmd_swap_window_recv,
|
||||
cmd_swap_window_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_swap_window_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_swap_window_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_swap_window_data *data;
|
||||
const char *errstr;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->sname = NULL;
|
||||
data->flag_detached = 0;
|
||||
@ -116,14 +116,14 @@ usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
error:
|
||||
cmd_swap_window_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_swap_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_swap_window_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_swap_window_data *data = ptr;
|
||||
struct cmd_swap_window_data *data = self->data;
|
||||
struct session *s, *src;
|
||||
struct winlink *srcwl, *dstwl;
|
||||
struct window *w;
|
||||
@ -181,9 +181,9 @@ cmd_swap_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_swap_window_send(void *ptr, struct buffer *b)
|
||||
cmd_swap_window_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_swap_window_data *data = ptr;
|
||||
struct cmd_swap_window_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -192,11 +192,11 @@ cmd_swap_window_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_swap_window_recv(void **ptr, struct buffer *b)
|
||||
cmd_swap_window_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_swap_window_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->sname = cmd_recv_string(b);
|
||||
@ -204,9 +204,9 @@ cmd_swap_window_recv(void **ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_swap_window_free(void *ptr)
|
||||
cmd_swap_window_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_swap_window_data *data = ptr;
|
||||
struct cmd_swap_window_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-switch-client.c,v 1.6 2008-06-03 18:13:54 nicm Exp $ */
|
||||
/* $Id: cmd-switch-client.c,v 1.7 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -28,11 +28,11 @@
|
||||
* Switch client to a different session.
|
||||
*/
|
||||
|
||||
int cmd_switch_client_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_switch_client_exec(void *, struct cmd_ctx *);
|
||||
void cmd_switch_client_send(void *, struct buffer *);
|
||||
void cmd_switch_client_recv(void **, struct buffer *);
|
||||
void cmd_switch_client_free(void *);
|
||||
int cmd_switch_client_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_switch_client_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_switch_client_send(struct cmd *, struct buffer *);
|
||||
void cmd_switch_client_recv(struct cmd *, struct buffer *);
|
||||
void cmd_switch_client_free(struct cmd *);
|
||||
|
||||
struct cmd_switch_client_data {
|
||||
char *cname;
|
||||
@ -48,17 +48,17 @@ const struct cmd_entry cmd_switch_client_entry = {
|
||||
cmd_switch_client_send,
|
||||
cmd_switch_client_recv,
|
||||
cmd_switch_client_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_switch_client_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_switch_client_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_switch_client_data *data;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
data->cname = NULL;
|
||||
data->name = NULL;
|
||||
|
||||
@ -83,14 +83,14 @@ cmd_switch_client_parse(
|
||||
usage:
|
||||
xasprintf(cause, "usage: %s %s", self->entry->name, self->entry->usage);
|
||||
|
||||
cmd_switch_client_free(data);
|
||||
self->entry->free(self);
|
||||
return (-1);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_switch_client_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_switch_client_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_switch_client_data *data = ptr;
|
||||
struct cmd_switch_client_data *data = self->data;
|
||||
struct client *c;
|
||||
struct session *s;
|
||||
|
||||
@ -114,9 +114,9 @@ cmd_switch_client_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_switch_client_send(void *ptr, struct buffer *b)
|
||||
cmd_switch_client_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_switch_client_data *data = ptr;
|
||||
struct cmd_switch_client_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
cmd_send_string(b, data->cname);
|
||||
@ -124,20 +124,20 @@ cmd_switch_client_send(void *ptr, struct buffer *b)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_switch_client_recv(void **ptr, struct buffer *b)
|
||||
cmd_switch_client_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_switch_client_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
data->cname = cmd_recv_string(b);
|
||||
data->name = cmd_recv_string(b);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_switch_client_free(void *ptr)
|
||||
cmd_switch_client_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_switch_client_data *data = ptr;
|
||||
struct cmd_switch_client_data *data = self->data;
|
||||
|
||||
if (data->cname != NULL)
|
||||
xfree(data->cname);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-unbind-key.c,v 1.11 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-unbind-key.c,v 1.12 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -26,11 +26,11 @@
|
||||
* Unbind key from command.
|
||||
*/
|
||||
|
||||
int cmd_unbind_key_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_unbind_key_exec(void *, struct cmd_ctx *);
|
||||
void cmd_unbind_key_send(void *, struct buffer *);
|
||||
void cmd_unbind_key_recv(void **, struct buffer *);
|
||||
void cmd_unbind_key_free(void *);
|
||||
int cmd_unbind_key_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_unbind_key_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_unbind_key_send(struct cmd *, struct buffer *);
|
||||
void cmd_unbind_key_recv(struct cmd *, struct buffer *);
|
||||
void cmd_unbind_key_free(struct cmd *);
|
||||
|
||||
struct cmd_unbind_key_data {
|
||||
int key;
|
||||
@ -45,17 +45,17 @@ const struct cmd_entry cmd_unbind_key_entry = {
|
||||
cmd_unbind_key_send,
|
||||
cmd_unbind_key_recv,
|
||||
cmd_unbind_key_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
int
|
||||
cmd_unbind_key_parse(
|
||||
struct cmd *self, void **ptr, int argc, char **argv, char **cause)
|
||||
cmd_unbind_key_parse(struct cmd *self, int argc, char **argv, char **cause)
|
||||
{
|
||||
struct cmd_unbind_key_data *data;
|
||||
int opt;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
|
||||
while ((opt = getopt(argc, argv, "")) != EOF) {
|
||||
switch (opt) {
|
||||
@ -84,9 +84,9 @@ error:
|
||||
}
|
||||
|
||||
void
|
||||
cmd_unbind_key_exec(void *ptr, unused struct cmd_ctx *ctx)
|
||||
cmd_unbind_key_exec(struct cmd *self, unused struct cmd_ctx *ctx)
|
||||
{
|
||||
struct cmd_unbind_key_data *data = ptr;
|
||||
struct cmd_unbind_key_data *data = self->data;
|
||||
|
||||
if (data == NULL)
|
||||
return;
|
||||
@ -98,26 +98,26 @@ cmd_unbind_key_exec(void *ptr, unused struct cmd_ctx *ctx)
|
||||
}
|
||||
|
||||
void
|
||||
cmd_unbind_key_send(void *ptr, struct buffer *b)
|
||||
cmd_unbind_key_send(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_unbind_key_data *data = ptr;
|
||||
struct cmd_unbind_key_data *data = self->data;
|
||||
|
||||
buffer_write(b, data, sizeof *data);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_unbind_key_recv(void **ptr, struct buffer *b)
|
||||
cmd_unbind_key_recv(struct cmd *self, struct buffer *b)
|
||||
{
|
||||
struct cmd_unbind_key_data *data;
|
||||
|
||||
*ptr = data = xmalloc(sizeof *data);
|
||||
self->data = data = xmalloc(sizeof *data);
|
||||
buffer_read(b, data, sizeof *data);
|
||||
}
|
||||
|
||||
void
|
||||
cmd_unbind_key_free(void *ptr)
|
||||
cmd_unbind_key_free(struct cmd *self)
|
||||
{
|
||||
struct cmd_unbind_key_data *data = ptr;
|
||||
struct cmd_unbind_key_data *data = self->data;
|
||||
|
||||
xfree(data);
|
||||
}
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd-unlink-window.c,v 1.9 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: cmd-unlink-window.c,v 1.10 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -24,7 +24,7 @@
|
||||
* Unlink a window, unless it would be destroyed by doing so (only one link).
|
||||
*/
|
||||
|
||||
void cmd_unlink_window_exec(void *, struct cmd_ctx *);
|
||||
void cmd_unlink_window_exec(struct cmd *, struct cmd_ctx *);
|
||||
|
||||
const struct cmd_entry cmd_unlink_window_entry = {
|
||||
"unlink-window", "unlinkw",
|
||||
@ -35,11 +35,12 @@ const struct cmd_entry cmd_unlink_window_entry = {
|
||||
cmd_windowonly_send,
|
||||
cmd_windowonly_recv,
|
||||
cmd_windowonly_free,
|
||||
NULL,
|
||||
NULL
|
||||
};
|
||||
|
||||
void
|
||||
cmd_unlink_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
cmd_unlink_window_exec(struct cmd *self, struct cmd_ctx *ctx)
|
||||
{
|
||||
struct winlink *wl;
|
||||
struct session *s;
|
||||
@ -47,7 +48,7 @@ cmd_unlink_window_exec(void *ptr, struct cmd_ctx *ctx)
|
||||
u_int i;
|
||||
int destroyed;
|
||||
|
||||
if ((wl = cmd_windowonly_get(ptr, ctx, &s)) == NULL)
|
||||
if ((wl = cmd_windowonly_get(self, ctx, &s)) == NULL)
|
||||
return;
|
||||
|
||||
if (wl->window->references == 1) {
|
||||
|
12
cmd.c
12
cmd.c
@ -1,4 +1,4 @@
|
||||
/* $Id: cmd.c,v 1.41 2008-06-04 17:54:26 nicm Exp $ */
|
||||
/* $Id: cmd.c,v 1.42 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -114,7 +114,7 @@ cmd_parse(int argc, char **argv, char **cause)
|
||||
cmd = xmalloc(sizeof *cmd);
|
||||
cmd->entry = entry;
|
||||
if (entry->parse != NULL) {
|
||||
if (entry->parse(cmd, &cmd->data, argc, argv, cause) != 0) {
|
||||
if (entry->parse(cmd, argc, argv, cause) != 0) {
|
||||
xfree(cmd);
|
||||
return (NULL);
|
||||
}
|
||||
@ -143,7 +143,7 @@ usage:
|
||||
void
|
||||
cmd_exec(struct cmd *cmd, struct cmd_ctx *ctx)
|
||||
{
|
||||
cmd->entry->exec(cmd->data, ctx);
|
||||
cmd->entry->exec(cmd, ctx);
|
||||
}
|
||||
|
||||
void
|
||||
@ -164,7 +164,7 @@ cmd_send(struct cmd *cmd, struct buffer *b)
|
||||
buffer_write(b, &n, sizeof n);
|
||||
|
||||
if (cmd->entry->send != NULL)
|
||||
cmd->entry->send(cmd->data, b);
|
||||
cmd->entry->send(cmd, b);
|
||||
}
|
||||
|
||||
struct cmd *
|
||||
@ -189,7 +189,7 @@ cmd_recv(struct buffer *b)
|
||||
cmd->entry = *entryp;
|
||||
|
||||
if (cmd->entry->recv != NULL)
|
||||
cmd->entry->recv(&cmd->data, b);
|
||||
cmd->entry->recv(cmd, b);
|
||||
return (cmd);
|
||||
}
|
||||
|
||||
@ -197,7 +197,7 @@ void
|
||||
cmd_free(struct cmd *cmd)
|
||||
{
|
||||
if (cmd->data != NULL && cmd->entry->free != NULL)
|
||||
cmd->entry->free(cmd->data);
|
||||
cmd->entry->free(cmd);
|
||||
xfree(cmd);
|
||||
}
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* $Id: key-bindings.c,v 1.28 2008-06-03 05:35:51 nicm Exp $ */
|
||||
/* $Id: key-bindings.c,v 1.29 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -122,7 +122,7 @@ key_bindings_init(void)
|
||||
cmd->entry = table[i].entry;
|
||||
cmd->data = NULL;
|
||||
if (cmd->entry->init != NULL)
|
||||
cmd->entry->init(&cmd->data, table[i].key);
|
||||
cmd->entry->init(cmd, table[i].key);
|
||||
key_bindings_add(table[i].key, cmd);
|
||||
}
|
||||
}
|
||||
|
4
tmux.c
4
tmux.c
@ -1,4 +1,4 @@
|
||||
/* $Id: tmux.c,v 1.52 2008-06-04 05:40:35 nicm Exp $ */
|
||||
/* $Id: tmux.c,v 1.53 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -267,7 +267,7 @@ main(int argc, char **argv)
|
||||
if (argc == 0) {
|
||||
cmd = xmalloc(sizeof *cmd);
|
||||
cmd->entry = &cmd_new_session_entry;
|
||||
cmd->entry->init(&cmd->data, 0);
|
||||
cmd->entry->init(cmd, 0);
|
||||
} else if ((cmd = cmd_parse(argc, argv, &cause)) == NULL) {
|
||||
log_warnx("%s", cause);
|
||||
exit(1);
|
||||
|
55
tmux.h
55
tmux.h
@ -1,4 +1,4 @@
|
||||
/* $Id: tmux.h,v 1.131 2008-06-04 19:20:10 nicm Exp $ */
|
||||
/* $Id: tmux.h,v 1.132 2008-06-05 16:35:32 nicm Exp $ */
|
||||
|
||||
/*
|
||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||
@ -687,12 +687,13 @@ struct cmd_entry {
|
||||
#define CMD_CANTNEST 0x2
|
||||
int flags;
|
||||
|
||||
int (*parse)(struct cmd *, void **, int, char **, char **);
|
||||
void (*exec)(void *, struct cmd_ctx *);
|
||||
void (*send)(void *, struct buffer *);
|
||||
void (*recv)(void **, struct buffer *);
|
||||
void (*free)(void *);
|
||||
void (*init)(void **, int);
|
||||
int (*parse)(struct cmd *, int, char **, char **);
|
||||
void (*exec)(struct cmd *, struct cmd_ctx *);
|
||||
void (*send)(struct cmd *, struct buffer *);
|
||||
void (*recv)(struct cmd *, struct buffer *);
|
||||
void (*free)(struct cmd *);
|
||||
void (*init)(struct cmd *, int);
|
||||
void (*print)(struct cmd *, char *, size_t);
|
||||
};
|
||||
|
||||
/* Generic command data. */
|
||||
@ -828,26 +829,30 @@ extern const struct cmd_entry cmd_unlink_window_entry;
|
||||
|
||||
/* cmd-generic.c */
|
||||
#define CMD_CLIENTONLY_USAGE "[-c client-tty]"
|
||||
int cmd_clientonly_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_clientonly_exec(void *, struct cmd_ctx *);
|
||||
void cmd_clientonly_send(void *, struct buffer *);
|
||||
void cmd_clientonly_recv(void **, struct buffer *);
|
||||
void cmd_clientonly_free(void *);
|
||||
struct client *cmd_clientonly_get(void *, struct cmd_ctx *);
|
||||
int cmd_clientonly_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_clientonly_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_clientonly_send(struct cmd *, struct buffer *);
|
||||
void cmd_clientonly_recv(struct cmd *, struct buffer *);
|
||||
void cmd_clientonly_free(struct cmd *);
|
||||
struct client *cmd_clientonly_get(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_clientonly_print(struct cmd *, char *, size_t);
|
||||
#define CMD_SESSIONONLY_USAGE "[-c client-tty|-s session-name]"
|
||||
int cmd_sessiononly_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_sessiononly_exec(void *, struct cmd_ctx *);
|
||||
void cmd_sessiononly_send(void *, struct buffer *);
|
||||
void cmd_sessiononly_recv(void **, struct buffer *);
|
||||
void cmd_sessiononly_free(void *);
|
||||
struct session *cmd_sessiononly_get(void *, struct cmd_ctx *);
|
||||
int cmd_sessiononly_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_sessiononly_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_sessiononly_send(struct cmd *, struct buffer *);
|
||||
void cmd_sessiononly_recv(struct cmd *, struct buffer *);
|
||||
void cmd_sessiononly_free(struct cmd *);
|
||||
struct session *cmd_sessiononly_get(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_sessiononly_print(struct cmd *, char *, size_t);
|
||||
#define CMD_WINDOWONLY_USAGE "[-c client-tty|-s session-name] [-i index]"
|
||||
int cmd_windowonly_parse(struct cmd *, void **, int, char **, char **);
|
||||
void cmd_windowonly_exec(void *, struct cmd_ctx *);
|
||||
void cmd_windowonly_send(void *, struct buffer *);
|
||||
void cmd_windowonly_recv(void **, struct buffer *);
|
||||
void cmd_windowonly_free(void *);
|
||||
struct winlink *cmd_windowonly_get(void *, struct cmd_ctx *, struct session **);
|
||||
int cmd_windowonly_parse(struct cmd *, int, char **, char **);
|
||||
void cmd_windowonly_exec(struct cmd *, struct cmd_ctx *);
|
||||
void cmd_windowonly_send(struct cmd *, struct buffer *);
|
||||
void cmd_windowonly_recv(struct cmd *, struct buffer *);
|
||||
void cmd_windowonly_free(struct cmd *);
|
||||
struct winlink *cmd_windowonly_get(
|
||||
struct cmd *, struct cmd_ctx *, struct session **);
|
||||
void cmd_windowonly_print(struct cmd *, char *, size_t);
|
||||
|
||||
/* client.c */
|
||||
int client_init(const char *, struct client_ctx *, int);
|
||||
|
Loading…
Reference in New Issue
Block a user