summaryrefslogtreecommitdiffstats
path: root/cmd-lock-session.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@openbsd.org>2009-09-24 14:17:09 +0000
committerNicholas Marriott <nicm@openbsd.org>2009-09-24 14:17:09 +0000
commit8fa1858a2c02aafa31695a12fa40cd5dbdd53cd2 (patch)
treeabec88eed0aa73acb73d0cb95a5bb684a4a94cce /cmd-lock-session.c
parent1764ef81efce5f265f61107f0b1e91d73b858fb4 (diff)
New lock-client and lock-session commands to lock an individual client or all
clients attached to a session respectively.
Diffstat (limited to 'cmd-lock-session.c')
-rw-r--r--cmd-lock-session.c53
1 files changed, 53 insertions, 0 deletions
diff --git a/cmd-lock-session.c b/cmd-lock-session.c
new file mode 100644
index 00000000..c0a6569c
--- /dev/null
+++ b/cmd-lock-session.c
@@ -0,0 +1,53 @@
+/* $OpenBSD$ */
+
+/*
+ * Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net>
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER
+ * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
+ * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include <sys/types.h>
+
+#include "tmux.h"
+
+/*
+ * Lock all clients attached to a session.
+ */
+
+int cmd_lock_session_exec(struct cmd *, struct cmd_ctx *);
+
+const struct cmd_entry cmd_lock_session_entry = {
+ "lock-session", "locks",
+ CMD_TARGET_SESSION_USAGE,
+ 0, 0,
+ cmd_target_init,
+ cmd_target_parse,
+ cmd_lock_session_exec,
+ cmd_target_free,
+ cmd_target_print
+};
+
+int
+cmd_lock_session_exec(struct cmd *self, struct cmd_ctx *ctx)
+{
+ struct cmd_target_data *data = self->data;
+ struct session *s;
+
+ if ((s = cmd_find_session(ctx, data->target)) == NULL)
+ return (-1);
+
+ server_lock_session(s);
+ recalculate_sizes();
+
+ return (0);
+}