2009-06-01 22:58:49 +00:00
|
|
|
/* $OpenBSD$ */
|
|
|
|
|
|
|
|
/*
|
2016-01-19 15:59:12 +00:00
|
|
|
* Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com>
|
2009-06-01 22:58:49 +00:00
|
|
|
*
|
|
|
|
* 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 <sys/ioctl.h>
|
|
|
|
|
2011-05-18 20:24:29 +00:00
|
|
|
#include <netinet/in.h>
|
|
|
|
|
2016-11-15 14:02:32 +00:00
|
|
|
#include <curses.h>
|
2009-06-01 22:58:49 +00:00
|
|
|
#include <errno.h>
|
|
|
|
#include <fcntl.h>
|
2011-05-18 20:24:29 +00:00
|
|
|
#include <resolv.h>
|
2009-10-12 13:01:18 +00:00
|
|
|
#include <stdlib.h>
|
2009-06-01 22:58:49 +00:00
|
|
|
#include <string.h>
|
|
|
|
#include <termios.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include "tmux.h"
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static int tty_log_fd = -1;
|
2015-10-31 13:12:03 +00:00
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static int tty_client_ready(struct client *, struct window_pane *);
|
2016-04-30 18:59:02 +00:00
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void tty_set_italics(struct tty *);
|
|
|
|
static int tty_try_colour(struct tty *, int, const char *);
|
2016-10-11 13:21:59 +00:00
|
|
|
static void tty_force_cursor_colour(struct tty *, const char *);
|
|
|
|
static void tty_cursor_pane(struct tty *, const struct tty_ctx *, u_int,
|
|
|
|
u_int);
|
2017-03-15 09:21:21 +00:00
|
|
|
static void tty_cursor_pane_unless_wrap(struct tty *,
|
|
|
|
const struct tty_ctx *, u_int, u_int);
|
2017-02-08 23:53:03 +00:00
|
|
|
static void tty_invalidate(struct tty *);
|
2016-10-10 21:29:23 +00:00
|
|
|
static void tty_colours(struct tty *, const struct grid_cell *);
|
2017-01-07 15:28:13 +00:00
|
|
|
static void tty_check_fg(struct tty *, const struct window_pane *,
|
|
|
|
struct grid_cell *);
|
|
|
|
static void tty_check_bg(struct tty *, const struct window_pane *,
|
|
|
|
struct grid_cell *);
|
2016-10-10 21:29:23 +00:00
|
|
|
static void tty_colours_fg(struct tty *, const struct grid_cell *);
|
|
|
|
static void tty_colours_bg(struct tty *, const struct grid_cell *);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2016-10-11 13:21:59 +00:00
|
|
|
static void tty_region_pane(struct tty *, const struct tty_ctx *, u_int,
|
|
|
|
u_int);
|
2016-11-15 15:17:28 +00:00
|
|
|
static void tty_region(struct tty *, u_int, u_int);
|
2016-11-15 14:02:32 +00:00
|
|
|
static void tty_margin_pane(struct tty *, const struct tty_ctx *);
|
2016-11-15 15:17:28 +00:00
|
|
|
static void tty_margin(struct tty *, u_int, u_int);
|
2016-10-10 21:29:23 +00:00
|
|
|
static int tty_large_region(struct tty *, const struct tty_ctx *);
|
2016-10-13 20:27:27 +00:00
|
|
|
static int tty_fake_bce(const struct tty *, const struct window_pane *,
|
|
|
|
u_int);
|
2016-10-10 21:29:23 +00:00
|
|
|
static void tty_redraw_region(struct tty *, const struct tty_ctx *);
|
|
|
|
static void tty_emulate_repeat(struct tty *, enum tty_code_code,
|
|
|
|
enum tty_code_code, u_int);
|
|
|
|
static void tty_repeat_space(struct tty *, u_int);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
static void tty_draw_pane(struct tty *, const struct tty_ctx *, u_int);
|
2016-10-10 21:29:23 +00:00
|
|
|
static void tty_cell(struct tty *, const struct grid_cell *,
|
|
|
|
const struct window_pane *);
|
|
|
|
static void tty_default_colours(struct grid_cell *,
|
|
|
|
const struct window_pane *);
|
2016-10-13 20:27:27 +00:00
|
|
|
static void tty_default_attributes(struct tty *, const struct window_pane *,
|
|
|
|
u_int);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2016-11-15 14:02:32 +00:00
|
|
|
#define tty_use_margin(tty) \
|
2017-04-18 21:41:42 +00:00
|
|
|
((tty)->term_type == TTY_VT420)
|
2010-09-11 16:19:22 +00:00
|
|
|
|
2017-04-18 18:21:37 +00:00
|
|
|
#define tty_pane_full_width(tty, ctx) \
|
2012-05-05 18:45:55 +00:00
|
|
|
((ctx)->xoff == 0 && screen_size_x((ctx)->wp->screen) >= (tty)->sx)
|
|
|
|
|
2017-04-19 06:52:27 +00:00
|
|
|
#define TTY_BLOCK_INTERVAL (100000 /* 100 milliseconds */)
|
|
|
|
#define TTY_BLOCK_START(tty) (1 + ((tty)->sx * (tty)->sy) * 8)
|
|
|
|
#define TTY_BLOCK_STOP(tty) (1 + ((tty)->sx * (tty)->sy) / 8)
|
|
|
|
|
2015-10-31 13:12:03 +00:00
|
|
|
void
|
|
|
|
tty_create_log(void)
|
|
|
|
{
|
|
|
|
char name[64];
|
|
|
|
|
|
|
|
xsnprintf(name, sizeof name, "tmux-out-%ld.log", (long)getpid());
|
|
|
|
|
|
|
|
tty_log_fd = open(name, O_WRONLY|O_CREAT|O_TRUNC, 0644);
|
|
|
|
if (tty_log_fd != -1 && fcntl(tty_log_fd, F_SETFD, FD_CLOEXEC) == -1)
|
|
|
|
fatal("fcntl failed");
|
|
|
|
}
|
|
|
|
|
2015-07-13 15:51:31 +00:00
|
|
|
int
|
2012-05-22 14:32:28 +00:00
|
|
|
tty_init(struct tty *tty, struct client *c, int fd, char *term)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2015-07-13 15:51:31 +00:00
|
|
|
if (!isatty(fd))
|
|
|
|
return (-1);
|
|
|
|
|
2009-09-23 06:05:02 +00:00
|
|
|
memset(tty, 0, sizeof *tty);
|
2009-08-11 21:28:11 +00:00
|
|
|
|
2009-07-07 17:24:32 +00:00
|
|
|
if (term == NULL || *term == '\0')
|
2017-01-11 16:09:57 +00:00
|
|
|
tty->term_name = xstrdup("unknown");
|
2009-06-01 22:58:49 +00:00
|
|
|
else
|
2017-01-11 16:09:57 +00:00
|
|
|
tty->term_name = xstrdup(term);
|
2017-04-05 10:49:46 +00:00
|
|
|
|
2009-09-23 06:05:02 +00:00
|
|
|
tty->fd = fd;
|
2012-05-22 14:32:28 +00:00
|
|
|
tty->client = c;
|
2009-09-23 06:05:02 +00:00
|
|
|
|
2011-05-20 19:17:39 +00:00
|
|
|
tty->cstyle = 0;
|
2011-05-20 19:03:58 +00:00
|
|
|
tty->ccolour = xstrdup("");
|
2009-09-23 06:05:02 +00:00
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
tty->flags = 0;
|
2016-11-15 14:02:32 +00:00
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
tty->term_flags = 0;
|
2016-11-15 14:02:32 +00:00
|
|
|
tty->term_type = TTY_UNKNOWN;
|
2015-07-13 15:51:31 +00:00
|
|
|
|
|
|
|
return (0);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2017-05-31 10:29:15 +00:00
|
|
|
void
|
2009-09-23 06:12:58 +00:00
|
|
|
tty_resize(struct tty *tty)
|
|
|
|
{
|
2017-04-05 10:49:46 +00:00
|
|
|
struct client *c = tty->client;
|
|
|
|
struct winsize ws;
|
|
|
|
u_int sx, sy;
|
2009-09-23 06:12:58 +00:00
|
|
|
|
|
|
|
if (ioctl(tty->fd, TIOCGWINSZ, &ws) != -1) {
|
2010-06-05 16:47:11 +00:00
|
|
|
sx = ws.ws_col;
|
|
|
|
if (sx == 0)
|
|
|
|
sx = 80;
|
|
|
|
sy = ws.ws_row;
|
|
|
|
if (sy == 0)
|
|
|
|
sy = 24;
|
|
|
|
} else {
|
|
|
|
sx = 80;
|
|
|
|
sy = 24;
|
2009-09-23 06:12:58 +00:00
|
|
|
}
|
2017-04-05 10:49:46 +00:00
|
|
|
log_debug("%s: %s now %ux%u", __func__, c->name, sx, sy);
|
2017-05-31 10:29:15 +00:00
|
|
|
tty_set_size(tty, sx, sy);
|
2017-02-08 23:53:03 +00:00
|
|
|
tty_invalidate(tty);
|
2009-09-23 06:12:58 +00:00
|
|
|
}
|
|
|
|
|
2017-05-31 10:29:15 +00:00
|
|
|
void
|
2016-11-15 14:02:32 +00:00
|
|
|
tty_set_size(struct tty *tty, u_int sx, u_int sy)
|
|
|
|
{
|
2012-02-15 17:25:02 +00:00
|
|
|
tty->sx = sx;
|
|
|
|
tty->sy = sy;
|
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2017-02-10 12:59:18 +00:00
|
|
|
tty_read_callback(__unused int fd, __unused short events, void *data)
|
2009-11-05 08:45:08 +00:00
|
|
|
{
|
|
|
|
struct tty *tty = data;
|
2017-04-05 10:49:46 +00:00
|
|
|
struct client *c = tty->client;
|
2017-02-10 12:59:18 +00:00
|
|
|
size_t size = EVBUFFER_LENGTH(tty->in);
|
|
|
|
int nread;
|
|
|
|
|
|
|
|
nread = evbuffer_read(tty->in, tty->fd, -1);
|
2017-08-24 08:48:37 +00:00
|
|
|
if (nread == 0 || nread == -1) {
|
2017-06-06 14:53:28 +00:00
|
|
|
event_del(&tty->event_in);
|
2017-08-24 08:48:37 +00:00
|
|
|
server_client_lost(tty->client);
|
2017-02-10 12:59:18 +00:00
|
|
|
return;
|
2017-06-06 14:53:28 +00:00
|
|
|
}
|
2017-04-05 10:49:46 +00:00
|
|
|
log_debug("%s: read %d bytes (already %zu)", c->name, nread, size);
|
2009-11-05 08:45:08 +00:00
|
|
|
|
|
|
|
while (tty_keys_next(tty))
|
|
|
|
;
|
|
|
|
}
|
|
|
|
|
2017-04-19 06:52:27 +00:00
|
|
|
static void
|
|
|
|
tty_timer_callback(__unused int fd, __unused short events, void *data)
|
|
|
|
{
|
|
|
|
struct tty *tty = data;
|
|
|
|
struct client *c = tty->client;
|
|
|
|
struct timeval tv = { .tv_usec = TTY_BLOCK_INTERVAL };
|
|
|
|
|
|
|
|
log_debug("%s: %zu discarded", c->name, tty->discarded);
|
|
|
|
|
2018-08-19 16:45:03 +00:00
|
|
|
c->flags |= CLIENT_ALLREDRAWFLAGS;
|
2017-04-19 06:52:27 +00:00
|
|
|
c->discarded += tty->discarded;
|
|
|
|
|
|
|
|
if (tty->discarded < TTY_BLOCK_STOP(tty)) {
|
|
|
|
tty->flags &= ~TTY_BLOCK;
|
|
|
|
tty_invalidate(tty);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
tty->discarded = 0;
|
|
|
|
evtimer_add(&tty->timer, &tv);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
tty_block_maybe(struct tty *tty)
|
|
|
|
{
|
|
|
|
struct client *c = tty->client;
|
|
|
|
size_t size = EVBUFFER_LENGTH(tty->out);
|
|
|
|
struct timeval tv = { .tv_usec = TTY_BLOCK_INTERVAL };
|
|
|
|
|
|
|
|
if (size < TTY_BLOCK_START(tty))
|
|
|
|
return (0);
|
|
|
|
|
|
|
|
if (tty->flags & TTY_BLOCK)
|
|
|
|
return (1);
|
|
|
|
tty->flags |= TTY_BLOCK;
|
|
|
|
|
|
|
|
log_debug("%s: can't keep up, %zu discarded", c->name, size);
|
|
|
|
|
|
|
|
evbuffer_drain(tty->out, size);
|
|
|
|
c->discarded += size;
|
|
|
|
|
|
|
|
tty->discarded = 0;
|
|
|
|
evtimer_add(&tty->timer, &tv);
|
|
|
|
return (1);
|
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2017-02-10 12:59:18 +00:00
|
|
|
tty_write_callback(__unused int fd, __unused short events, void *data)
|
2009-11-04 21:47:42 +00:00
|
|
|
{
|
2017-02-10 12:59:18 +00:00
|
|
|
struct tty *tty = data;
|
2017-04-05 10:49:46 +00:00
|
|
|
struct client *c = tty->client;
|
2017-02-10 12:59:18 +00:00
|
|
|
size_t size = EVBUFFER_LENGTH(tty->out);
|
|
|
|
int nwrite;
|
|
|
|
|
|
|
|
nwrite = evbuffer_write(tty->out, tty->fd);
|
|
|
|
if (nwrite == -1)
|
|
|
|
return;
|
2017-04-05 10:49:46 +00:00
|
|
|
log_debug("%s: wrote %d bytes (of %zu)", c->name, nwrite, size);
|
2017-02-10 12:59:18 +00:00
|
|
|
|
2017-05-09 13:04:36 +00:00
|
|
|
if (c->redraw > 0) {
|
|
|
|
if ((size_t)nwrite >= c->redraw)
|
|
|
|
c->redraw = 0;
|
|
|
|
else
|
|
|
|
c->redraw -= nwrite;
|
|
|
|
log_debug("%s: waiting for redraw, %zu bytes left", c->name,
|
|
|
|
c->redraw);
|
|
|
|
} else if (tty_block_maybe(tty))
|
2017-04-19 06:52:27 +00:00
|
|
|
return;
|
|
|
|
|
2017-02-10 15:39:43 +00:00
|
|
|
if (EVBUFFER_LENGTH(tty->out) != 0)
|
|
|
|
event_add(&tty->event_out, NULL);
|
2009-11-04 21:47:42 +00:00
|
|
|
}
|
|
|
|
|
2017-02-10 12:59:18 +00:00
|
|
|
int
|
|
|
|
tty_open(struct tty *tty, char **cause)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2017-02-10 12:59:18 +00:00
|
|
|
tty->term = tty_term_find(tty->term_name, tty->fd, cause);
|
|
|
|
if (tty->term == NULL) {
|
|
|
|
tty_close(tty);
|
|
|
|
return (-1);
|
|
|
|
}
|
|
|
|
tty->flags |= TTY_OPENED;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2017-04-19 06:52:27 +00:00
|
|
|
tty->flags &= ~(TTY_NOCURSOR|TTY_FREEZE|TTY_BLOCK|TTY_TIMER);
|
2009-09-23 07:25:31 +00:00
|
|
|
|
2017-02-10 12:59:18 +00:00
|
|
|
event_set(&tty->event_in, tty->fd, EV_PERSIST|EV_READ,
|
|
|
|
tty_read_callback, tty);
|
|
|
|
tty->in = evbuffer_new();
|
2009-09-23 12:03:30 +00:00
|
|
|
|
2017-02-10 12:59:18 +00:00
|
|
|
event_set(&tty->event_out, tty->fd, EV_WRITE, tty_write_callback, tty);
|
|
|
|
tty->out = evbuffer_new();
|
2009-11-04 21:47:42 +00:00
|
|
|
|
2017-04-19 06:52:27 +00:00
|
|
|
evtimer_set(&tty->timer, tty_timer_callback, tty);
|
|
|
|
|
2017-02-10 12:59:18 +00:00
|
|
|
tty_start_tty(tty);
|
|
|
|
|
|
|
|
tty_keys_build(tty);
|
|
|
|
|
|
|
|
return (0);
|
2012-03-17 21:27:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
tty_start_tty(struct tty *tty)
|
|
|
|
{
|
2017-05-15 16:44:04 +00:00
|
|
|
struct client *c = tty->client;
|
|
|
|
struct termios tio;
|
2017-02-10 12:59:18 +00:00
|
|
|
|
|
|
|
if (tty->fd != -1 && tcgetattr(tty->fd, &tty->tio) == 0) {
|
|
|
|
setblocking(tty->fd, 0);
|
|
|
|
event_add(&tty->event_in, NULL);
|
|
|
|
|
|
|
|
memcpy(&tio, &tty->tio, sizeof tio);
|
|
|
|
tio.c_iflag &= ~(IXON|IXOFF|ICRNL|INLCR|IGNCR|IMAXBEL|ISTRIP);
|
|
|
|
tio.c_iflag |= IGNBRK;
|
|
|
|
tio.c_oflag &= ~(OPOST|ONLCR|OCRNL|ONLRET);
|
|
|
|
tio.c_lflag &= ~(IEXTEN|ICANON|ECHO|ECHOE|ECHONL|ECHOCTL|
|
|
|
|
ECHOPRT|ECHOKE|ISIG);
|
|
|
|
tio.c_cc[VMIN] = 1;
|
|
|
|
tio.c_cc[VTIME] = 0;
|
|
|
|
if (tcsetattr(tty->fd, TCSANOW, &tio) == 0)
|
|
|
|
tcflush(tty->fd, TCIOFLUSH);
|
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
|
|
|
|
tty_putcode(tty, TTYC_SMCUP);
|
2009-07-10 07:11:59 +00:00
|
|
|
|
2017-03-08 14:34:35 +00:00
|
|
|
tty_putcode(tty, TTYC_SMKX);
|
2009-06-01 22:58:49 +00:00
|
|
|
tty_putcode(tty, TTYC_CLEAR);
|
|
|
|
|
2017-05-15 16:44:04 +00:00
|
|
|
if (tty_acs_needed(tty)) {
|
|
|
|
log_debug("%s: using capabilities for ACS", c->name);
|
|
|
|
tty_putcode(tty, TTYC_ENACS);
|
|
|
|
} else
|
|
|
|
log_debug("%s: using UTF-8 for ACS", c->name);
|
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
tty_putcode(tty, TTYC_CNORM);
|
|
|
|
if (tty_term_has(tty->term, TTYC_KMOUS))
|
2015-04-25 15:57:48 +00:00
|
|
|
tty_puts(tty, "\033[?1000l\033[?1002l\033[?1006l\033[?1005l");
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2015-10-23 15:52:54 +00:00
|
|
|
if (tty_term_flag(tty->term, TTYC_XT)) {
|
2015-10-27 15:58:42 +00:00
|
|
|
if (options_get_number(global_options, "focus-events")) {
|
2013-06-23 13:10:46 +00:00
|
|
|
tty->flags |= TTY_FOCUS;
|
|
|
|
tty_puts(tty, "\033[?1004h");
|
|
|
|
}
|
2017-04-18 21:41:42 +00:00
|
|
|
tty_puts(tty, "\033[c");
|
2013-06-23 13:10:46 +00:00
|
|
|
}
|
2012-03-15 10:36:00 +00:00
|
|
|
|
2009-08-11 19:32:25 +00:00
|
|
|
tty->flags |= TTY_STARTED;
|
2017-02-08 23:53:03 +00:00
|
|
|
tty_invalidate(tty);
|
2011-05-20 19:03:58 +00:00
|
|
|
|
|
|
|
tty_force_cursor_colour(tty, "");
|
2015-04-19 21:34:21 +00:00
|
|
|
|
|
|
|
tty->mouse_drag_flag = 0;
|
|
|
|
tty->mouse_drag_update = NULL;
|
|
|
|
tty->mouse_drag_release = NULL;
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
tty_stop_tty(struct tty *tty)
|
|
|
|
{
|
|
|
|
struct winsize ws;
|
|
|
|
|
2009-08-11 19:32:25 +00:00
|
|
|
if (!(tty->flags & TTY_STARTED))
|
|
|
|
return;
|
|
|
|
tty->flags &= ~TTY_STARTED;
|
|
|
|
|
2017-04-19 06:52:27 +00:00
|
|
|
event_del(&tty->timer);
|
|
|
|
tty->flags &= ~TTY_BLOCK;
|
|
|
|
|
2017-02-10 12:59:18 +00:00
|
|
|
event_del(&tty->event_in);
|
|
|
|
event_del(&tty->event_out);
|
2009-11-04 21:47:42 +00:00
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
/*
|
|
|
|
* Be flexible about error handling and try not kill the server just
|
|
|
|
* because the fd is invalid. Things like ssh -t can easily leave us
|
|
|
|
* with a dead tty.
|
|
|
|
*/
|
|
|
|
if (ioctl(tty->fd, TIOCGWINSZ, &ws) == -1)
|
|
|
|
return;
|
|
|
|
if (tcsetattr(tty->fd, TCSANOW, &tty->tio) == -1)
|
|
|
|
return;
|
|
|
|
|
|
|
|
tty_raw(tty, tty_term_string2(tty->term, TTYC_CSR, 0, ws.ws_row - 1));
|
2017-05-15 16:44:04 +00:00
|
|
|
if (tty_acs_needed(tty))
|
2010-09-11 16:19:22 +00:00
|
|
|
tty_raw(tty, tty_term_string(tty->term, TTYC_RMACS));
|
2009-06-01 22:58:49 +00:00
|
|
|
tty_raw(tty, tty_term_string(tty->term, TTYC_SGR0));
|
|
|
|
tty_raw(tty, tty_term_string(tty->term, TTYC_RMKX));
|
|
|
|
tty_raw(tty, tty_term_string(tty->term, TTYC_CLEAR));
|
2013-06-02 07:52:15 +00:00
|
|
|
if (tty_term_has(tty->term, TTYC_SS) && tty->cstyle != 0) {
|
|
|
|
if (tty_term_has(tty->term, TTYC_SE))
|
|
|
|
tty_raw(tty, tty_term_string(tty->term, TTYC_SE));
|
2011-05-26 07:08:48 +00:00
|
|
|
else
|
2013-06-02 07:52:15 +00:00
|
|
|
tty_raw(tty, tty_term_string1(tty->term, TTYC_SS, 0));
|
2011-05-20 19:17:39 +00:00
|
|
|
}
|
2015-02-05 11:46:57 +00:00
|
|
|
if (tty->mode & MODE_BRACKETPASTE)
|
|
|
|
tty_raw(tty, "\033[?2004l");
|
2011-05-20 19:03:58 +00:00
|
|
|
tty_raw(tty, tty_term_string(tty->term, TTYC_CR));
|
2009-06-01 22:58:49 +00:00
|
|
|
|
|
|
|
tty_raw(tty, tty_term_string(tty->term, TTYC_CNORM));
|
|
|
|
if (tty_term_has(tty->term, TTYC_KMOUS))
|
2015-04-25 15:57:48 +00:00
|
|
|
tty_raw(tty, "\033[?1000l\033[?1002l\033[?1006l\033[?1005l");
|
2013-03-22 10:34:46 +00:00
|
|
|
|
2015-10-23 15:52:54 +00:00
|
|
|
if (tty_term_flag(tty->term, TTYC_XT)) {
|
2013-06-23 13:10:46 +00:00
|
|
|
if (tty->flags & TTY_FOCUS) {
|
|
|
|
tty->flags &= ~TTY_FOCUS;
|
2015-01-30 12:33:03 +00:00
|
|
|
tty_raw(tty, "\033[?1004l");
|
2013-06-23 13:10:46 +00:00
|
|
|
}
|
|
|
|
}
|
2009-07-10 07:11:59 +00:00
|
|
|
|
2016-11-15 14:02:32 +00:00
|
|
|
if (tty_use_margin(tty))
|
|
|
|
tty_raw(tty, "\033[?69l"); /* DECLRMM */
|
2009-07-10 07:11:59 +00:00
|
|
|
tty_raw(tty, tty_term_string(tty->term, TTYC_RMCUP));
|
2013-03-22 10:34:46 +00:00
|
|
|
|
|
|
|
setblocking(tty->fd, 1);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-11 19:32:25 +00:00
|
|
|
tty_close(struct tty *tty)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2012-03-17 18:24:07 +00:00
|
|
|
if (event_initialized(&tty->key_timer))
|
|
|
|
evtimer_del(&tty->key_timer);
|
2009-08-11 19:32:25 +00:00
|
|
|
tty_stop_tty(tty);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-08-11 20:29:04 +00:00
|
|
|
if (tty->flags & TTY_OPENED) {
|
2017-02-10 12:59:18 +00:00
|
|
|
evbuffer_free(tty->in);
|
|
|
|
event_del(&tty->event_in);
|
|
|
|
evbuffer_free(tty->out);
|
|
|
|
event_del(&tty->event_out);
|
2009-11-04 21:47:42 +00:00
|
|
|
|
2009-08-11 20:29:04 +00:00
|
|
|
tty_term_free(tty->term);
|
|
|
|
tty_keys_free(tty);
|
|
|
|
|
|
|
|
tty->flags &= ~TTY_OPENED;
|
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-08-11 20:29:04 +00:00
|
|
|
if (tty->fd != -1) {
|
|
|
|
close(tty->fd);
|
|
|
|
tty->fd = -1;
|
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-11 19:32:25 +00:00
|
|
|
tty_free(struct tty *tty)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-08-11 19:32:25 +00:00
|
|
|
tty_close(tty);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2012-07-10 11:53:01 +00:00
|
|
|
free(tty->ccolour);
|
2017-01-11 16:09:57 +00:00
|
|
|
free(tty->term_name);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2016-11-15 14:02:32 +00:00
|
|
|
void
|
|
|
|
tty_set_type(struct tty *tty, int type)
|
|
|
|
{
|
|
|
|
tty->term_type = type;
|
|
|
|
|
|
|
|
if (tty_use_margin(tty))
|
|
|
|
tty_puts(tty, "\033[?69h"); /* DECLRMM */
|
|
|
|
}
|
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
void
|
|
|
|
tty_raw(struct tty *tty, const char *s)
|
|
|
|
{
|
2013-03-22 10:34:46 +00:00
|
|
|
ssize_t n, slen;
|
|
|
|
u_int i;
|
|
|
|
|
|
|
|
slen = strlen(s);
|
|
|
|
for (i = 0; i < 5; i++) {
|
|
|
|
n = write(tty->fd, s, slen);
|
|
|
|
if (n >= 0) {
|
|
|
|
s += n;
|
|
|
|
slen -= n;
|
|
|
|
if (slen == 0)
|
|
|
|
break;
|
|
|
|
} else if (n == -1 && errno != EAGAIN)
|
|
|
|
break;
|
|
|
|
usleep(100);
|
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
tty_putcode(struct tty *tty, enum tty_code_code code)
|
|
|
|
{
|
|
|
|
tty_puts(tty, tty_term_string(tty->term, code));
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
tty_putcode1(struct tty *tty, enum tty_code_code code, int a)
|
|
|
|
{
|
|
|
|
if (a < 0)
|
|
|
|
return;
|
|
|
|
tty_puts(tty, tty_term_string1(tty->term, code, a));
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
tty_putcode2(struct tty *tty, enum tty_code_code code, int a, int b)
|
|
|
|
{
|
|
|
|
if (a < 0 || b < 0)
|
|
|
|
return;
|
|
|
|
tty_puts(tty, tty_term_string2(tty->term, code, a, b));
|
|
|
|
}
|
|
|
|
|
2017-05-31 08:43:44 +00:00
|
|
|
void
|
|
|
|
tty_putcode3(struct tty *tty, enum tty_code_code code, int a, int b, int c)
|
|
|
|
{
|
|
|
|
if (a < 0 || b < 0 || c < 0)
|
|
|
|
return;
|
|
|
|
tty_puts(tty, tty_term_string3(tty->term, code, a, b, c));
|
|
|
|
}
|
|
|
|
|
2011-05-20 19:03:58 +00:00
|
|
|
void
|
|
|
|
tty_putcode_ptr1(struct tty *tty, enum tty_code_code code, const void *a)
|
|
|
|
{
|
|
|
|
if (a != NULL)
|
|
|
|
tty_puts(tty, tty_term_ptr1(tty->term, code, a));
|
|
|
|
}
|
|
|
|
|
2011-05-18 20:24:29 +00:00
|
|
|
void
|
2014-04-17 12:57:28 +00:00
|
|
|
tty_putcode_ptr2(struct tty *tty, enum tty_code_code code, const void *a,
|
|
|
|
const void *b)
|
2011-05-18 20:24:29 +00:00
|
|
|
{
|
|
|
|
if (a != NULL && b != NULL)
|
|
|
|
tty_puts(tty, tty_term_ptr2(tty->term, code, a, b));
|
|
|
|
}
|
|
|
|
|
2017-02-08 23:53:03 +00:00
|
|
|
static void
|
|
|
|
tty_add(struct tty *tty, const char *buf, size_t len)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2017-04-05 10:49:46 +00:00
|
|
|
struct client *c = tty->client;
|
|
|
|
|
2017-04-19 06:52:27 +00:00
|
|
|
if (tty->flags & TTY_BLOCK) {
|
|
|
|
tty->discarded += len;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-02-10 12:59:18 +00:00
|
|
|
evbuffer_add(tty->out, buf, len);
|
2017-05-09 13:04:36 +00:00
|
|
|
log_debug("%s: %.*s", c->name, (int)len, buf);
|
2017-04-19 06:52:27 +00:00
|
|
|
c->written += len;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2015-10-31 13:12:03 +00:00
|
|
|
if (tty_log_fd != -1)
|
2017-02-08 23:53:03 +00:00
|
|
|
write(tty_log_fd, buf, len);
|
2017-02-10 12:59:18 +00:00
|
|
|
if (tty->flags & TTY_STARTED)
|
|
|
|
event_add(&tty->event_out, NULL);
|
2017-02-08 23:53:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
tty_puts(struct tty *tty, const char *s)
|
|
|
|
{
|
|
|
|
if (*s != '\0')
|
|
|
|
tty_add(tty, s, strlen(s));
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
tty_putc(struct tty *tty, u_char ch)
|
|
|
|
{
|
2010-09-11 16:19:22 +00:00
|
|
|
const char *acs;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2010-09-11 16:19:22 +00:00
|
|
|
if (tty->cell.attr & GRID_ATTR_CHARSET) {
|
|
|
|
acs = tty_acs_get(tty, ch);
|
2017-02-08 23:53:03 +00:00
|
|
|
if (acs != NULL)
|
|
|
|
tty_add(tty, acs, strlen(acs));
|
|
|
|
else
|
|
|
|
tty_add(tty, &ch, 1);
|
|
|
|
} else
|
|
|
|
tty_add(tty, &ch, 1);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
|
|
|
if (ch >= 0x20 && ch != 0x7f) {
|
2016-10-14 21:48:00 +00:00
|
|
|
if (tty->cx >= tty->sx) {
|
2009-10-12 17:19:47 +00:00
|
|
|
tty->cx = 1;
|
|
|
|
if (tty->cy != tty->rlower)
|
|
|
|
tty->cy++;
|
2016-10-14 21:48:00 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* On !xenl terminals, force the cursor position to
|
|
|
|
* where we think it should be after a line wrap - this
|
|
|
|
* means it works on sensible terminals as well.
|
|
|
|
*/
|
|
|
|
if (tty->term->flags & TERM_EARLYWRAP)
|
|
|
|
tty_putcode2(tty, TTYC_CUP, tty->cy, tty->cx);
|
2009-06-01 22:58:49 +00:00
|
|
|
} else
|
|
|
|
tty->cx++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-06-24 16:01:02 +00:00
|
|
|
void
|
2013-01-18 02:16:21 +00:00
|
|
|
tty_putn(struct tty *tty, const void *buf, size_t len, u_int width)
|
2009-06-24 16:01:02 +00:00
|
|
|
{
|
2017-02-08 23:53:03 +00:00
|
|
|
tty_add(tty, buf, len);
|
2017-04-25 18:30:29 +00:00
|
|
|
if (tty->cx + width > tty->sx) {
|
|
|
|
tty->cx = (tty->cx + width) - tty->sx;
|
|
|
|
if (tty->cx <= tty->sx)
|
|
|
|
tty->cy++;
|
|
|
|
else
|
|
|
|
tty->cx = tty->cy = UINT_MAX;
|
|
|
|
} else
|
2017-03-15 15:22:14 +00:00
|
|
|
tty->cx += width;
|
2009-06-24 16:01:02 +00:00
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2015-04-29 15:59:08 +00:00
|
|
|
tty_set_italics(struct tty *tty)
|
|
|
|
{
|
|
|
|
const char *s;
|
|
|
|
|
|
|
|
if (tty_term_has(tty->term, TTYC_SITM)) {
|
2015-10-27 15:58:42 +00:00
|
|
|
s = options_get_string(global_options, "default-terminal");
|
2015-04-29 15:59:08 +00:00
|
|
|
if (strcmp(s, "screen") != 0 && strncmp(s, "screen-", 7) != 0) {
|
|
|
|
tty_putcode(tty, TTYC_SITM);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
tty_putcode(tty, TTYC_SMSO);
|
|
|
|
}
|
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
void
|
|
|
|
tty_set_title(struct tty *tty, const char *title)
|
|
|
|
{
|
2011-05-08 19:53:06 +00:00
|
|
|
if (!tty_term_has(tty->term, TTYC_TSL) ||
|
|
|
|
!tty_term_has(tty->term, TTYC_FSL))
|
2009-06-01 22:58:49 +00:00
|
|
|
return;
|
|
|
|
|
2011-05-08 19:53:06 +00:00
|
|
|
tty_putcode(tty, TTYC_TSL);
|
2009-06-01 22:58:49 +00:00
|
|
|
tty_puts(tty, title);
|
2011-05-08 19:53:06 +00:00
|
|
|
tty_putcode(tty, TTYC_FSL);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2016-10-11 13:21:59 +00:00
|
|
|
static void
|
2011-05-20 19:03:58 +00:00
|
|
|
tty_force_cursor_colour(struct tty *tty, const char *ccolour)
|
|
|
|
{
|
|
|
|
if (*ccolour == '\0')
|
|
|
|
tty_putcode(tty, TTYC_CR);
|
|
|
|
else
|
2013-06-02 07:52:15 +00:00
|
|
|
tty_putcode_ptr1(tty, TTYC_CS, ccolour);
|
2012-07-10 11:53:01 +00:00
|
|
|
free(tty->ccolour);
|
2011-05-20 19:03:58 +00:00
|
|
|
tty->ccolour = xstrdup(ccolour);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
tty_update_mode(struct tty *tty, int mode, struct screen *s)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
|
|
|
int changed;
|
|
|
|
|
2015-12-28 14:02:52 +00:00
|
|
|
if (s != NULL && strcmp(s->ccolour, tty->ccolour) != 0)
|
2011-05-20 19:03:58 +00:00
|
|
|
tty_force_cursor_colour(tty, s->ccolour);
|
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
if (tty->flags & TTY_NOCURSOR)
|
|
|
|
mode &= ~MODE_CURSOR;
|
|
|
|
|
|
|
|
changed = mode ^ tty->mode;
|
2015-05-19 08:48:37 +00:00
|
|
|
if (changed & MODE_BLINKING) {
|
|
|
|
if (tty_term_has(tty->term, TTYC_CVVIS))
|
|
|
|
tty_putcode(tty, TTYC_CVVIS);
|
|
|
|
else
|
|
|
|
tty_putcode(tty, TTYC_CNORM);
|
|
|
|
changed |= MODE_CURSOR;
|
|
|
|
}
|
|
|
|
if (changed & MODE_CURSOR) {
|
|
|
|
if (mode & MODE_CURSOR)
|
|
|
|
tty_putcode(tty, TTYC_CNORM);
|
|
|
|
else
|
2009-06-01 22:58:49 +00:00
|
|
|
tty_putcode(tty, TTYC_CIVIS);
|
|
|
|
}
|
2015-05-06 07:52:06 +00:00
|
|
|
if (s != NULL && tty->cstyle != s->cstyle) {
|
2013-06-02 07:52:15 +00:00
|
|
|
if (tty_term_has(tty->term, TTYC_SS)) {
|
2011-05-20 19:17:39 +00:00
|
|
|
if (s->cstyle == 0 &&
|
2013-06-02 07:52:15 +00:00
|
|
|
tty_term_has(tty->term, TTYC_SE))
|
|
|
|
tty_putcode(tty, TTYC_SE);
|
2011-05-20 19:17:39 +00:00
|
|
|
else
|
2013-06-02 07:52:15 +00:00
|
|
|
tty_putcode1(tty, TTYC_SS, s->cstyle);
|
2011-05-20 19:17:39 +00:00
|
|
|
}
|
|
|
|
tty->cstyle = s->cstyle;
|
|
|
|
}
|
2015-11-23 20:53:09 +00:00
|
|
|
if (changed & ALL_MOUSE_MODES) {
|
2010-12-29 21:49:06 +00:00
|
|
|
if (mode & ALL_MOUSE_MODES) {
|
2013-03-22 10:34:46 +00:00
|
|
|
/*
|
|
|
|
* Enable the SGR (1006) extension unconditionally, as
|
2017-01-11 22:36:07 +00:00
|
|
|
* it is safe from misinterpretation.
|
2013-03-22 10:34:46 +00:00
|
|
|
*/
|
|
|
|
tty_puts(tty, "\033[?1006h");
|
2017-02-01 09:55:07 +00:00
|
|
|
if (mode & MODE_MOUSE_ALL)
|
|
|
|
tty_puts(tty, "\033[?1003h");
|
|
|
|
else if (mode & MODE_MOUSE_BUTTON)
|
2010-12-29 21:49:06 +00:00
|
|
|
tty_puts(tty, "\033[?1002h");
|
2011-01-15 00:46:19 +00:00
|
|
|
else if (mode & MODE_MOUSE_STANDARD)
|
|
|
|
tty_puts(tty, "\033[?1000h");
|
2010-05-31 19:51:29 +00:00
|
|
|
} else {
|
2017-02-01 09:55:07 +00:00
|
|
|
if (tty->mode & MODE_MOUSE_ALL)
|
|
|
|
tty_puts(tty, "\033[?1003l");
|
|
|
|
else if (tty->mode & MODE_MOUSE_BUTTON)
|
2010-12-29 21:49:06 +00:00
|
|
|
tty_puts(tty, "\033[?1002l");
|
2011-01-15 00:46:19 +00:00
|
|
|
else if (tty->mode & MODE_MOUSE_STANDARD)
|
|
|
|
tty_puts(tty, "\033[?1000l");
|
2013-03-22 10:34:46 +00:00
|
|
|
tty_puts(tty, "\033[?1006l");
|
2010-05-31 19:51:29 +00:00
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
2012-03-03 09:43:22 +00:00
|
|
|
if (changed & MODE_BRACKETPASTE) {
|
|
|
|
if (mode & MODE_BRACKETPASTE)
|
|
|
|
tty_puts(tty, "\033[?2004h");
|
|
|
|
else
|
|
|
|
tty_puts(tty, "\033[?2004l");
|
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
tty->mode = mode;
|
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2014-04-17 14:45:49 +00:00
|
|
|
tty_emulate_repeat(struct tty *tty, enum tty_code_code code,
|
|
|
|
enum tty_code_code code1, u_int n)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
|
|
|
if (tty_term_has(tty->term, code))
|
|
|
|
tty_putcode1(tty, code, n);
|
|
|
|
else {
|
|
|
|
while (n-- > 0)
|
|
|
|
tty_putcode(tty, code1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2012-05-22 09:09:16 +00:00
|
|
|
tty_repeat_space(struct tty *tty, u_int n)
|
|
|
|
{
|
2017-04-05 10:49:46 +00:00
|
|
|
static char s[500];
|
|
|
|
|
|
|
|
if (*s != ' ')
|
|
|
|
memset(s, ' ', sizeof s);
|
|
|
|
|
|
|
|
while (n > sizeof s) {
|
|
|
|
tty_putn(tty, s, sizeof s, sizeof s);
|
|
|
|
n -= sizeof s;
|
|
|
|
}
|
|
|
|
if (n != 0)
|
|
|
|
tty_putn(tty, s, n, n);
|
2012-05-22 09:09:16 +00:00
|
|
|
}
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
/* Is this window bigger than the terminal? */
|
|
|
|
int
|
|
|
|
tty_window_bigger(struct tty *tty)
|
|
|
|
{
|
2018-08-20 19:05:34 +00:00
|
|
|
struct client *c = tty->client;
|
|
|
|
struct session *s = c->session;
|
|
|
|
struct window *w = s->curw->window;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
|
2018-08-20 19:05:34 +00:00
|
|
|
return (tty->sx < w->sx || tty->sy - status_line_size(c) < w->sy);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* What offset should this window be drawn at? */
|
|
|
|
int
|
|
|
|
tty_window_offset(struct tty *tty, u_int *ox, u_int *oy, u_int *sx, u_int *sy)
|
|
|
|
{
|
|
|
|
*ox = tty->oox;
|
|
|
|
*oy = tty->ooy;
|
|
|
|
*sx = tty->osx;
|
|
|
|
*sy = tty->osy;
|
|
|
|
|
|
|
|
return (tty->oflag);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* What offset should this window be drawn at? */
|
|
|
|
static int
|
|
|
|
tty_window_offset1(struct tty *tty, u_int *ox, u_int *oy, u_int *sx, u_int *sy)
|
|
|
|
{
|
2018-08-20 19:05:34 +00:00
|
|
|
struct client *c = tty->client;
|
|
|
|
struct window *w = c->session->curw->window;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
struct window_pane *wp = w->active;
|
|
|
|
u_int cx, cy, lines;
|
|
|
|
|
2018-08-20 19:05:34 +00:00
|
|
|
lines = status_line_size(c);
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (tty->sx >= w->sx && tty->sy - lines >= w->sy) {
|
|
|
|
*ox = 0;
|
|
|
|
*oy = 0;
|
|
|
|
*sx = w->sx;
|
|
|
|
*sy = w->sy;
|
2018-08-21 08:27:19 +00:00
|
|
|
|
|
|
|
c->pan_window = NULL;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
return (0);
|
|
|
|
}
|
|
|
|
|
|
|
|
*sx = tty->sx;
|
|
|
|
*sy = tty->sy - lines;
|
|
|
|
|
2018-08-21 08:27:19 +00:00
|
|
|
if (c->pan_window == w) {
|
|
|
|
if (c->pan_ox + *sx > w->sx)
|
|
|
|
c->pan_ox = w->sx - *sx;
|
|
|
|
*ox = c->pan_ox;
|
|
|
|
if (c->pan_oy + *sy > w->sy)
|
|
|
|
c->pan_oy = w->sy - *sy;
|
|
|
|
*oy = c->pan_oy;
|
|
|
|
return (1);
|
|
|
|
}
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (~wp->screen->mode & MODE_CURSOR) {
|
|
|
|
*ox = 0;
|
|
|
|
*oy = 0;
|
|
|
|
} else {
|
|
|
|
cx = wp->xoff + wp->screen->cx;
|
|
|
|
cy = wp->yoff + wp->screen->cy;
|
|
|
|
|
|
|
|
if (cx < *sx)
|
|
|
|
*ox = 0;
|
|
|
|
else if (cx > w->sx - *sx)
|
|
|
|
*ox = w->sx - *sx;
|
|
|
|
else
|
|
|
|
*ox = cx - *sx / 2;
|
|
|
|
|
|
|
|
if (cy < *sy)
|
|
|
|
*oy = 0;
|
|
|
|
else if (cy > w->sy - *sy)
|
|
|
|
*oy = w->sy - *sy;
|
|
|
|
else
|
|
|
|
*oy = cy - *sy / 2;
|
|
|
|
}
|
|
|
|
|
2018-08-21 08:27:19 +00:00
|
|
|
c->pan_window = NULL;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
return (1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Update stored offsets for a window and redraw if necessary. */
|
|
|
|
void
|
|
|
|
tty_update_window_offset(struct window *w)
|
|
|
|
{
|
|
|
|
struct client *c;
|
|
|
|
|
|
|
|
TAILQ_FOREACH(c, &clients, entry) {
|
|
|
|
if (c->session != NULL && c->session->curw->window == w)
|
|
|
|
tty_update_client_offset(c);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Update stored offsets for a client and redraw if necessary. */
|
|
|
|
void
|
|
|
|
tty_update_client_offset(struct client *c)
|
|
|
|
{
|
|
|
|
u_int ox, oy, sx, sy;
|
|
|
|
|
|
|
|
c->tty.oflag = tty_window_offset1(&c->tty, &ox, &oy, &sx, &sy);
|
|
|
|
if (ox == c->tty.oox &&
|
|
|
|
oy == c->tty.ooy &&
|
|
|
|
sx == c->tty.osx &&
|
|
|
|
sy == c->tty.osy)
|
|
|
|
return;
|
|
|
|
|
|
|
|
log_debug ("%s: %s offset has changed (%u,%u %ux%u -> %u,%u %ux%u)",
|
|
|
|
__func__, c->name, c->tty.oox, c->tty.ooy, c->tty.osx, c->tty.osy,
|
|
|
|
ox, oy, sx, sy);
|
|
|
|
|
|
|
|
c->tty.oox = ox;
|
|
|
|
c->tty.ooy = oy;
|
|
|
|
c->tty.osx = sx;
|
|
|
|
c->tty.osy = sy;
|
|
|
|
|
|
|
|
c->flags |= CLIENT_REDRAWWINDOW;
|
|
|
|
}
|
|
|
|
|
2012-03-15 09:10:33 +00:00
|
|
|
/*
|
|
|
|
* Is the region large enough to be worth redrawing once later rather than
|
|
|
|
* probably several times now? Currently yes if it is more than 50% of the
|
|
|
|
* pane.
|
|
|
|
*/
|
2016-10-10 21:29:23 +00:00
|
|
|
static int
|
2015-11-18 14:27:44 +00:00
|
|
|
tty_large_region(__unused struct tty *tty, const struct tty_ctx *ctx)
|
2012-03-15 09:10:33 +00:00
|
|
|
{
|
|
|
|
struct window_pane *wp = ctx->wp;
|
|
|
|
|
|
|
|
return (ctx->orlower - ctx->orupper >= screen_size_y(wp->screen) / 2);
|
|
|
|
}
|
|
|
|
|
2015-04-19 21:05:27 +00:00
|
|
|
/*
|
|
|
|
* Return if BCE is needed but the terminal doesn't have it - it'll need to be
|
|
|
|
* emulated.
|
|
|
|
*/
|
2016-10-10 21:29:23 +00:00
|
|
|
static int
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_fake_bce(const struct tty *tty, const struct window_pane *wp, u_int bg)
|
2015-04-19 21:05:27 +00:00
|
|
|
{
|
|
|
|
struct grid_cell gc;
|
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
if (tty_term_flag(tty->term, TTYC_BCE))
|
|
|
|
return (0);
|
|
|
|
|
2015-04-19 21:05:27 +00:00
|
|
|
memcpy(&gc, &grid_default_cell, sizeof gc);
|
2016-05-30 09:50:20 +00:00
|
|
|
if (wp != NULL)
|
|
|
|
tty_default_colours(&gc, wp);
|
2015-04-19 21:05:27 +00:00
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
if (bg != 8 || gc.bg != 8)
|
|
|
|
return (1);
|
|
|
|
return (0);
|
2015-04-19 21:05:27 +00:00
|
|
|
}
|
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
/*
|
|
|
|
* Redraw scroll region using data from screen (already updated). Used when
|
|
|
|
* CSR not supported, or window is a pane that doesn't take up the full
|
|
|
|
* width of the terminal.
|
|
|
|
*/
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_redraw_region(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-07-22 20:53:38 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
|
|
|
struct screen *s = wp->screen;
|
2016-07-15 00:49:08 +00:00
|
|
|
u_int i;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
|
|
|
/*
|
2012-03-15 09:10:33 +00:00
|
|
|
* If region is large, schedule a window redraw. In most cases this is
|
|
|
|
* likely to be followed by some more scrolling.
|
2009-06-01 22:58:49 +00:00
|
|
|
*/
|
2012-03-15 09:10:33 +00:00
|
|
|
if (tty_large_region(tty, ctx)) {
|
2009-06-01 22:58:49 +00:00
|
|
|
wp->flags |= PANE_REDRAW;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2009-07-22 20:53:38 +00:00
|
|
|
if (ctx->ocy < ctx->orupper || ctx->ocy > ctx->orlower) {
|
|
|
|
for (i = ctx->ocy; i < screen_size_y(s); i++)
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_draw_pane(tty, ctx, i);
|
2009-06-01 22:58:49 +00:00
|
|
|
} else {
|
2009-07-22 20:53:38 +00:00
|
|
|
for (i = ctx->orupper; i <= ctx->orlower; i++)
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_draw_pane(tty, ctx, i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Is this position visible in the pane? */
|
|
|
|
static int
|
2018-08-20 18:45:32 +00:00
|
|
|
tty_is_visible(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py,
|
|
|
|
u_int nx, u_int ny)
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
{
|
2018-08-20 18:45:32 +00:00
|
|
|
u_int xoff = ctx->xoff + px, yoff = ctx->yoff + py, lines;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
|
|
|
|
if (!ctx->bigger)
|
|
|
|
return (1);
|
2018-08-20 18:45:32 +00:00
|
|
|
|
|
|
|
if (status_at_line(tty->client) == 0)
|
2018-08-20 19:05:34 +00:00
|
|
|
lines = status_line_size(tty->client);
|
2018-08-20 18:45:32 +00:00
|
|
|
else
|
|
|
|
lines = 0;
|
2018-08-20 19:05:34 +00:00
|
|
|
|
2018-08-20 18:45:32 +00:00
|
|
|
if (xoff + nx <= ctx->ox || xoff >= ctx->ox + ctx->sx ||
|
|
|
|
yoff + ny <= ctx->oy || yoff >= lines + ctx->oy + ctx->sy) {
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
return (0);
|
|
|
|
}
|
|
|
|
return (1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Clamp line position to visible part of pane. */
|
|
|
|
static int
|
2018-08-20 18:45:32 +00:00
|
|
|
tty_clamp_line(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py,
|
|
|
|
u_int nx, u_int *i, u_int *x, u_int *rx, u_int *ry)
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
{
|
2018-08-26 13:10:39 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
|
|
|
u_int xoff = wp->xoff + px;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
|
2018-08-20 18:45:32 +00:00
|
|
|
if (!tty_is_visible(tty, ctx, px, py, nx, 1))
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
return (0);
|
2018-08-20 18:34:04 +00:00
|
|
|
*ry = ctx->yoff + py - ctx->oy;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
|
|
|
|
if (xoff >= ctx->ox && xoff + nx <= ctx->ox + ctx->sx) {
|
|
|
|
/* All visible. */
|
|
|
|
*i = 0;
|
2018-08-26 13:10:39 +00:00
|
|
|
*x = ctx->xoff + px - ctx->ox;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
*rx = nx;
|
|
|
|
} else if (xoff < ctx->ox && xoff + nx > ctx->ox + ctx->sx) {
|
|
|
|
/* Both left and right not visible. */
|
|
|
|
*i = ctx->ox;
|
|
|
|
*x = 0;
|
|
|
|
*rx = ctx->sx;
|
|
|
|
} else if (xoff < ctx->ox) {
|
|
|
|
/* Left not visible. */
|
2018-08-26 13:10:39 +00:00
|
|
|
*i = ctx->ox - (ctx->xoff + px);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
*x = 0;
|
|
|
|
*rx = nx - *i;
|
|
|
|
} else {
|
|
|
|
/* Right not visible. */
|
|
|
|
*i = 0;
|
2018-08-26 13:10:39 +00:00
|
|
|
*x = (ctx->xoff + px) - ctx->ox;
|
|
|
|
*rx = nx - ((ctx->xoff + px) + nx - ctx->sx);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
return (1);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
/* Clear a line. */
|
2017-05-10 16:47:03 +00:00
|
|
|
static void
|
|
|
|
tty_clear_line(struct tty *tty, const struct window_pane *wp, u_int py,
|
|
|
|
u_int px, u_int nx, u_int bg)
|
|
|
|
{
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
struct client *c = tty->client;
|
|
|
|
|
|
|
|
log_debug("%s: %s, %u at %u,%u", __func__, c->name, nx, px, py);
|
2017-05-10 16:47:03 +00:00
|
|
|
|
|
|
|
/* Nothing to clear. */
|
|
|
|
if (nx == 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
/* If genuine BCE is available, can try escape sequences. */
|
|
|
|
if (!tty_fake_bce(tty, wp, bg)) {
|
|
|
|
/* Off the end of the line, use EL if available. */
|
|
|
|
if (px + nx >= tty->sx && tty_term_has(tty->term, TTYC_EL)) {
|
|
|
|
tty_cursor(tty, px, py);
|
|
|
|
tty_putcode(tty, TTYC_EL);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* At the start of the line. Use EL1. */
|
|
|
|
if (px == 0 && tty_term_has(tty->term, TTYC_EL1)) {
|
|
|
|
tty_cursor(tty, px + nx - 1, py);
|
|
|
|
tty_putcode(tty, TTYC_EL1);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Section of line. Use ECH if possible. */
|
|
|
|
if (tty_term_has(tty->term, TTYC_ECH)) {
|
|
|
|
tty_cursor(tty, px, py);
|
|
|
|
tty_putcode1(tty, TTYC_ECH, nx);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Couldn't use an escape sequence, use spaces. */
|
2017-05-10 18:40:13 +00:00
|
|
|
tty_cursor(tty, px, py);
|
2017-05-10 16:47:03 +00:00
|
|
|
tty_repeat_space(tty, nx);
|
|
|
|
}
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
/* Clear a line, adjusting to visible part of pane. */
|
|
|
|
static void
|
|
|
|
tty_clear_pane_line(struct tty *tty, const struct tty_ctx *ctx, u_int py,
|
|
|
|
u_int px, u_int nx, u_int bg)
|
|
|
|
{
|
2018-08-20 18:34:04 +00:00
|
|
|
struct client *c = tty->client;
|
|
|
|
u_int i, x, rx, ry;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
|
2018-08-20 18:34:04 +00:00
|
|
|
log_debug("%s: %s, %u at %u,%u", __func__, c->name, nx, px, py);
|
|
|
|
|
2018-08-20 18:45:32 +00:00
|
|
|
if (tty_clamp_line(tty, ctx, px, py, nx, &i, &x, &rx, &ry))
|
2018-08-20 18:34:04 +00:00
|
|
|
tty_clear_line(tty, ctx->wp, ry, x, rx, bg);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Clamp area position to visible part of pane. */
|
|
|
|
static int
|
2018-08-20 18:45:32 +00:00
|
|
|
tty_clamp_area(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py,
|
|
|
|
u_int nx, u_int ny, u_int *i, u_int *j, u_int *x, u_int *y, u_int *rx,
|
|
|
|
u_int *ry)
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
{
|
2018-08-26 13:10:39 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
|
|
|
u_int xoff = wp->xoff + px, yoff = wp->yoff + py;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
|
2018-08-20 18:45:32 +00:00
|
|
|
if (!tty_is_visible(tty, ctx, px, py, nx, ny))
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
return (0);
|
|
|
|
|
|
|
|
if (xoff >= ctx->ox && xoff + nx <= ctx->ox + ctx->sx) {
|
|
|
|
/* All visible. */
|
|
|
|
*i = 0;
|
2018-08-26 13:10:39 +00:00
|
|
|
*x = ctx->xoff + px - ctx->ox;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
*rx = nx;
|
|
|
|
} else if (xoff < ctx->ox && xoff + nx > ctx->ox + ctx->sx) {
|
|
|
|
/* Both left and right not visible. */
|
|
|
|
*i = ctx->ox;
|
|
|
|
*x = 0;
|
|
|
|
*rx = ctx->sx;
|
|
|
|
} else if (xoff < ctx->ox) {
|
|
|
|
/* Left not visible. */
|
2018-08-26 13:10:39 +00:00
|
|
|
*i = ctx->ox - (ctx->xoff + px);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
*x = 0;
|
|
|
|
*rx = nx - *i;
|
|
|
|
} else {
|
|
|
|
/* Right not visible. */
|
|
|
|
*i = 0;
|
2018-08-26 13:10:39 +00:00
|
|
|
*x = (ctx->xoff + px) - ctx->ox;
|
|
|
|
*rx = nx - ((ctx->xoff + px) + nx - ctx->sx);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
}
|
|
|
|
if (yoff >= ctx->oy && yoff + ny <= ctx->oy + ctx->sy) {
|
|
|
|
/* All visible. */
|
|
|
|
*j = 0;
|
2018-08-26 13:10:39 +00:00
|
|
|
*y = ctx->yoff + py - ctx->oy;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
*ry = ny;
|
|
|
|
} else if (yoff < ctx->oy && yoff + ny > ctx->oy + ctx->sy) {
|
|
|
|
/* Both left and right not visible. */
|
|
|
|
*j = ctx->oy;
|
|
|
|
*y = 0;
|
|
|
|
*ry = ctx->sy;
|
|
|
|
} else if (yoff < ctx->oy) {
|
|
|
|
/* Left not visible. */
|
2018-08-26 13:10:39 +00:00
|
|
|
*j = ctx->oy - (ctx->yoff + py);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
*y = 0;
|
|
|
|
*ry = ny - *j;
|
|
|
|
} else {
|
|
|
|
/* Right not visible. */
|
|
|
|
*j = 0;
|
2018-08-26 13:10:39 +00:00
|
|
|
*y = (ctx->yoff + py) - ctx->oy;
|
|
|
|
*ry = ny - ((ctx->yoff + py) + ny - ctx->sy);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
}
|
|
|
|
return (1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Clear an area, adjusting to visible part of pane. */
|
2017-05-10 16:47:03 +00:00
|
|
|
static void
|
|
|
|
tty_clear_area(struct tty *tty, const struct window_pane *wp, u_int py,
|
|
|
|
u_int ny, u_int px, u_int nx, u_int bg)
|
|
|
|
{
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
struct client *c = tty->client;
|
|
|
|
u_int yy;
|
|
|
|
char tmp[64];
|
2017-05-10 16:47:03 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
log_debug("%s: %s, %u,%u at %u,%u", __func__, c->name, nx, ny, px, py);
|
2017-05-10 16:47:03 +00:00
|
|
|
|
|
|
|
/* Nothing to clear. */
|
|
|
|
if (nx == 0 || ny == 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
/* If genuine BCE is available, can try escape sequences. */
|
|
|
|
if (!tty_fake_bce(tty, wp, bg)) {
|
2017-05-12 11:13:43 +00:00
|
|
|
/* Use ED if clearing off the bottom of the terminal. */
|
2017-05-10 16:47:03 +00:00
|
|
|
if (px == 0 &&
|
|
|
|
px + nx >= tty->sx &&
|
|
|
|
py + ny >= tty->sy &&
|
|
|
|
tty_term_has(tty->term, TTYC_ED)) {
|
|
|
|
tty_cursor(tty, 0, py);
|
|
|
|
tty_putcode(tty, TTYC_ED);
|
|
|
|
return;
|
|
|
|
}
|
2017-05-12 10:50:11 +00:00
|
|
|
|
|
|
|
/*
|
2017-05-12 11:13:43 +00:00
|
|
|
* On VT420 compatible terminals we can use DECFRA if the
|
|
|
|
* background colour isn't default (because it doesn't work
|
|
|
|
* after SGR 0).
|
2017-05-12 10:50:11 +00:00
|
|
|
*/
|
|
|
|
if (tty->term_type == TTY_VT420 && bg != 8) {
|
|
|
|
xsnprintf(tmp, sizeof tmp, "\033[32;%u;%u;%u;%u$x",
|
|
|
|
py + 1, px + 1, py + ny, px + nx);
|
|
|
|
tty_puts(tty, tmp);
|
|
|
|
return;
|
|
|
|
}
|
2017-05-12 11:13:43 +00:00
|
|
|
|
2017-05-12 23:06:43 +00:00
|
|
|
/* Full lines can be scrolled away to clear them. */
|
|
|
|
if (px == 0 &&
|
2017-05-12 23:10:19 +00:00
|
|
|
px + nx >= tty->sx &&
|
2017-05-12 23:06:43 +00:00
|
|
|
ny > 2 &&
|
|
|
|
tty_term_has(tty->term, TTYC_CSR) &&
|
|
|
|
tty_term_has(tty->term, TTYC_INDN)) {
|
|
|
|
tty_region(tty, py, py + ny - 1);
|
|
|
|
tty_margin_off(tty);
|
2017-05-15 07:54:44 +00:00
|
|
|
tty_putcode1(tty, TTYC_INDN, ny);
|
2017-05-12 23:06:43 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-05-12 11:13:43 +00:00
|
|
|
/*
|
|
|
|
* If margins are supported, can just scroll the area off to
|
|
|
|
* clear it.
|
|
|
|
*/
|
2017-05-12 11:19:24 +00:00
|
|
|
if (nx > 2 &&
|
|
|
|
ny > 2 &&
|
2017-05-12 23:06:43 +00:00
|
|
|
tty_term_has(tty->term, TTYC_CSR) &&
|
2017-05-12 11:19:24 +00:00
|
|
|
tty_use_margin(tty) &&
|
|
|
|
tty_term_has(tty->term, TTYC_INDN)) {
|
2017-05-12 11:13:43 +00:00
|
|
|
tty_region(tty, py, py + ny - 1);
|
|
|
|
tty_margin(tty, px, px + nx - 1);
|
2017-05-15 07:54:44 +00:00
|
|
|
tty_putcode1(tty, TTYC_INDN, ny);
|
2017-05-12 11:13:43 +00:00
|
|
|
return;
|
|
|
|
}
|
2017-05-10 16:47:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Couldn't use an escape sequence, loop over the lines. */
|
|
|
|
for (yy = py; yy < py + ny; yy++)
|
|
|
|
tty_clear_line(tty, wp, yy, px, nx, bg);
|
|
|
|
}
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
/* Clear an area in a pane. */
|
|
|
|
static void
|
|
|
|
tty_clear_pane_area(struct tty *tty, const struct tty_ctx *ctx, u_int py,
|
|
|
|
u_int ny, u_int px, u_int nx, u_int bg)
|
|
|
|
{
|
|
|
|
u_int i, j, x, y, rx, ry;
|
|
|
|
|
2018-08-20 18:45:32 +00:00
|
|
|
if (tty_clamp_area(tty, ctx, px, py, nx, ny, &i, &j, &x, &y, &rx, &ry))
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_clear_area(tty, ctx->wp, y, ry, x, rx, bg);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
tty_draw_pane(struct tty *tty, const struct tty_ctx *ctx, u_int py)
|
2015-04-19 21:05:27 +00:00
|
|
|
{
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
|
|
|
struct screen *s = wp->screen;
|
2018-08-20 18:34:04 +00:00
|
|
|
u_int nx = screen_size_x(s), i, x, rx, ry;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
|
|
|
|
log_debug("%s: %s %u %d", __func__, tty->client->name, py, ctx->bigger);
|
|
|
|
|
|
|
|
if (!ctx->bigger) {
|
2018-08-20 18:34:04 +00:00
|
|
|
tty_draw_line(tty, wp, s, 0, py, nx, ctx->xoff, ctx->yoff);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
return;
|
|
|
|
}
|
2018-08-20 18:45:32 +00:00
|
|
|
if (tty_clamp_line(tty, ctx, 0, py, nx, &i, &x, &rx, &ry))
|
2018-08-20 18:34:04 +00:00
|
|
|
tty_draw_line(tty, wp, s, i, py, rx, x, ry);
|
2015-04-19 21:05:27 +00:00
|
|
|
}
|
|
|
|
|
2018-01-12 16:41:00 +00:00
|
|
|
static const struct grid_cell *
|
|
|
|
tty_check_codeset(struct tty *tty, const struct grid_cell *gc)
|
|
|
|
{
|
|
|
|
static struct grid_cell new;
|
|
|
|
u_int n;
|
|
|
|
|
|
|
|
/* Characters less than 0x7f are always fine, no matter what. */
|
|
|
|
if (gc->data.size == 1 && *gc->data.data < 0x7f)
|
|
|
|
return (gc);
|
|
|
|
|
|
|
|
/* UTF-8 terminal and a UTF-8 character - fine. */
|
|
|
|
if (tty->flags & TTY_UTF8)
|
|
|
|
return (gc);
|
|
|
|
|
|
|
|
/* Replace by the right number of underscores. */
|
|
|
|
n = gc->data.width;
|
|
|
|
if (n > UTF8_SIZE)
|
|
|
|
n = UTF8_SIZE;
|
|
|
|
memcpy(&new, gc, sizeof new);
|
|
|
|
new.data.size = n;
|
|
|
|
memset(new.data.data, '_', n);
|
|
|
|
return (&new);
|
|
|
|
}
|
|
|
|
|
2015-04-19 21:05:27 +00:00
|
|
|
void
|
|
|
|
tty_draw_line(struct tty *tty, const struct window_pane *wp,
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
struct screen *s, u_int px, u_int py, u_int nx, u_int atx, u_int aty)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2017-11-15 19:18:57 +00:00
|
|
|
struct grid *gd = s->grid;
|
2017-02-21 16:25:04 +00:00
|
|
|
struct grid_cell gc, last;
|
2018-01-12 16:41:00 +00:00
|
|
|
const struct grid_cell *gcp;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
struct grid_line *gl;
|
|
|
|
u_int i, j, ux, sx, width;
|
2017-04-16 20:32:14 +00:00
|
|
|
int flags, cleared = 0;
|
2017-02-21 16:25:04 +00:00
|
|
|
char buf[512];
|
2017-07-21 14:25:29 +00:00
|
|
|
size_t len, old_len;
|
2018-07-04 09:44:07 +00:00
|
|
|
u_int cellsize;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
log_debug("%s: px=%u py=%u nx=%u atx=%u aty=%u", __func__,
|
|
|
|
px, py, nx, atx, aty);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* py is the line in the screen to draw.
|
|
|
|
* px is the start x and nx is the width to draw.
|
|
|
|
* atx,aty is the line on the terminal to draw it.
|
|
|
|
*/
|
|
|
|
|
2017-04-16 20:32:14 +00:00
|
|
|
flags = (tty->flags & TTY_NOCURSOR);
|
2015-05-06 07:52:06 +00:00
|
|
|
tty->flags |= TTY_NOCURSOR;
|
|
|
|
tty_update_mode(tty, tty->mode, s);
|
2009-10-09 07:23:28 +00:00
|
|
|
|
2016-11-15 15:17:28 +00:00
|
|
|
tty_region_off(tty);
|
|
|
|
tty_margin_off(tty);
|
|
|
|
|
2017-05-11 11:38:49 +00:00
|
|
|
/*
|
|
|
|
* Clamp the width to cellsize - note this is not cellused, because
|
|
|
|
* there may be empty background cells after it (from BCE).
|
|
|
|
*/
|
2009-06-01 22:58:49 +00:00
|
|
|
sx = screen_size_x(s);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (nx > sx)
|
|
|
|
nx = sx;
|
2018-07-04 09:44:07 +00:00
|
|
|
cellsize = grid_get_line(gd, gd->hsize + py)->cellsize;
|
|
|
|
if (sx > cellsize)
|
|
|
|
sx = cellsize;
|
2009-06-01 22:58:49 +00:00
|
|
|
if (sx > tty->sx)
|
|
|
|
sx = tty->sx;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (sx > nx)
|
|
|
|
sx = nx;
|
2017-07-21 22:55:45 +00:00
|
|
|
ux = 0;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (py == 0)
|
|
|
|
gl = NULL;
|
|
|
|
else
|
|
|
|
gl = grid_get_line(gd, gd->hsize + py - 1);
|
2017-04-25 18:30:29 +00:00
|
|
|
if (wp == NULL ||
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
gl == NULL ||
|
|
|
|
(~gl->flags & GRID_LINE_WRAPPED) ||
|
|
|
|
atx != 0 ||
|
2017-04-25 18:30:29 +00:00
|
|
|
tty->cx < tty->sx ||
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
nx < tty->sx) {
|
|
|
|
if (nx < tty->sx &&
|
|
|
|
atx == 0 &&
|
|
|
|
px + sx != nx &&
|
2017-04-25 18:30:29 +00:00
|
|
|
tty_term_has(tty->term, TTYC_EL1) &&
|
|
|
|
!tty_fake_bce(tty, wp, 8)) {
|
|
|
|
tty_default_attributes(tty, wp, 8);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_cursor(tty, nx - 1, aty);
|
2017-04-25 18:30:29 +00:00
|
|
|
tty_putcode(tty, TTYC_EL1);
|
|
|
|
cleared = 1;
|
|
|
|
}
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (px + sx != 0)
|
|
|
|
tty_cursor(tty, atx, aty);
|
2017-04-25 18:30:29 +00:00
|
|
|
} else
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
log_debug("%s: wrapped line %u", __func__, aty);
|
2017-02-21 16:25:04 +00:00
|
|
|
|
|
|
|
memcpy(&last, &grid_default_cell, sizeof last);
|
|
|
|
len = 0;
|
|
|
|
width = 0;
|
2009-10-12 17:19:47 +00:00
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
for (i = 0; i < sx; i++) {
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
grid_view_get_cell(gd, px + i, py, &gc);
|
2018-01-12 16:41:00 +00:00
|
|
|
gcp = tty_check_codeset(tty, &gc);
|
2017-02-21 16:25:04 +00:00
|
|
|
if (len != 0 &&
|
2018-01-12 16:41:00 +00:00
|
|
|
((gcp->attr & GRID_ATTR_CHARSET) ||
|
|
|
|
gcp->flags != last.flags ||
|
|
|
|
gcp->attr != last.attr ||
|
|
|
|
gcp->fg != last.fg ||
|
|
|
|
gcp->bg != last.bg ||
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
ux + width + gcp->data.width >= nx ||
|
2018-01-12 16:41:00 +00:00
|
|
|
(sizeof buf) - len < gcp->data.size)) {
|
2017-02-21 16:25:04 +00:00
|
|
|
tty_attributes(tty, &last, wp);
|
|
|
|
tty_putn(tty, buf, len, width);
|
2017-07-21 22:55:45 +00:00
|
|
|
ux += width;
|
2017-02-21 16:25:04 +00:00
|
|
|
|
|
|
|
len = 0;
|
|
|
|
width = 0;
|
|
|
|
}
|
|
|
|
|
2018-01-12 16:41:00 +00:00
|
|
|
if (gcp->flags & GRID_FLAG_SELECTED)
|
2018-01-16 17:03:18 +00:00
|
|
|
screen_select_cell(s, &last, gcp);
|
2017-02-21 16:25:04 +00:00
|
|
|
else
|
2018-01-16 17:03:18 +00:00
|
|
|
memcpy(&last, gcp, sizeof last);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ux + gcp->data.width > nx) {
|
2018-01-16 17:03:18 +00:00
|
|
|
tty_attributes(tty, &last, wp);
|
2018-01-12 16:41:00 +00:00
|
|
|
for (j = 0; j < gcp->data.width; j++) {
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ux + j > nx)
|
2017-11-15 19:18:57 +00:00
|
|
|
break;
|
|
|
|
tty_putc(tty, ' ');
|
|
|
|
ux++;
|
|
|
|
}
|
2018-01-16 17:03:18 +00:00
|
|
|
} else if (gcp->attr & GRID_ATTR_CHARSET) {
|
|
|
|
tty_attributes(tty, &last, wp);
|
|
|
|
for (j = 0; j < gcp->data.size; j++)
|
|
|
|
tty_putc(tty, gcp->data.data[j]);
|
|
|
|
ux += gc.data.width;
|
|
|
|
} else {
|
2018-01-12 16:41:00 +00:00
|
|
|
memcpy(buf + len, gcp->data.data, gcp->data.size);
|
|
|
|
len += gcp->data.size;
|
|
|
|
width += gcp->data.width;
|
2017-02-21 16:25:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (len != 0) {
|
2017-07-21 14:25:29 +00:00
|
|
|
if (grid_cells_equal(&last, &grid_default_cell)) {
|
|
|
|
old_len = len;
|
2017-07-21 22:55:45 +00:00
|
|
|
while (len > 0 && buf[len - 1] == ' ') {
|
2017-07-21 14:25:29 +00:00
|
|
|
len--;
|
2017-07-21 22:55:45 +00:00
|
|
|
width--;
|
|
|
|
}
|
2017-07-21 14:25:29 +00:00
|
|
|
log_debug("%s: trimmed %zu spaces", __func__,
|
|
|
|
old_len - len);
|
|
|
|
}
|
|
|
|
if (len != 0) {
|
|
|
|
tty_attributes(tty, &last, wp);
|
|
|
|
tty_putn(tty, buf, len, width);
|
2017-07-21 22:55:45 +00:00
|
|
|
ux += width;
|
2017-07-21 14:25:29 +00:00
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (!cleared && ux < nx) {
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_default_attributes(tty, wp, 8);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_clear_line(tty, wp, aty, atx + ux, nx - ux, 8);
|
2009-10-09 07:23:28 +00:00
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2015-05-06 07:52:06 +00:00
|
|
|
tty->flags = (tty->flags & ~TTY_NOCURSOR) | flags;
|
2011-05-20 19:03:58 +00:00
|
|
|
tty_update_mode(tty, tty->mode, s);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2016-04-30 18:59:02 +00:00
|
|
|
static int
|
2015-05-12 22:40:38 +00:00
|
|
|
tty_client_ready(struct client *c, struct window_pane *wp)
|
|
|
|
{
|
|
|
|
if (c->session == NULL || c->tty.term == NULL)
|
|
|
|
return (0);
|
2018-08-19 16:45:03 +00:00
|
|
|
if (c->flags & (CLIENT_REDRAWWINDOW|CLIENT_SUSPENDED))
|
2015-05-12 22:40:38 +00:00
|
|
|
return (0);
|
|
|
|
if (c->tty.flags & TTY_FREEZE)
|
|
|
|
return (0);
|
|
|
|
if (c->session->curw->window != wp->window)
|
|
|
|
return (0);
|
2018-08-25 12:55:50 +00:00
|
|
|
if (wp->layout_cell == NULL)
|
|
|
|
return (0);
|
2015-05-12 22:40:38 +00:00
|
|
|
return (1);
|
|
|
|
}
|
|
|
|
|
2009-07-22 20:56:58 +00:00
|
|
|
void
|
2015-05-12 22:40:38 +00:00
|
|
|
tty_write(void (*cmdfn)(struct tty *, const struct tty_ctx *),
|
|
|
|
struct tty_ctx *ctx)
|
2009-07-22 20:56:58 +00:00
|
|
|
{
|
|
|
|
struct window_pane *wp = ctx->wp;
|
|
|
|
struct client *c;
|
|
|
|
|
|
|
|
if (wp == NULL)
|
|
|
|
return;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (wp->flags & (PANE_REDRAW|PANE_DROP))
|
2009-07-22 20:56:58 +00:00
|
|
|
return;
|
|
|
|
|
2015-04-24 23:17:11 +00:00
|
|
|
TAILQ_FOREACH(c, &clients, entry) {
|
2015-05-12 22:40:38 +00:00
|
|
|
if (!tty_client_ready(c, wp))
|
2009-07-22 20:56:58 +00:00
|
|
|
continue;
|
2012-01-29 09:37:02 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
ctx->bigger = tty_window_offset(&c->tty, &ctx->ox, &ctx->oy,
|
|
|
|
&ctx->sx, &ctx->sy);
|
|
|
|
|
2012-08-14 08:58:25 +00:00
|
|
|
ctx->xoff = wp->xoff;
|
|
|
|
ctx->yoff = wp->yoff;
|
2018-08-20 19:05:34 +00:00
|
|
|
|
2012-08-14 08:58:25 +00:00
|
|
|
if (status_at_line(c) == 0)
|
2018-08-20 19:05:34 +00:00
|
|
|
ctx->yoff += status_line_size(c);
|
2012-01-29 09:37:02 +00:00
|
|
|
|
2012-08-14 08:58:25 +00:00
|
|
|
cmdfn(&c->tty, ctx);
|
2009-07-22 20:56:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_insertcharacter(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-12-03 22:50:09 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ctx->bigger ||
|
|
|
|
!tty_pane_full_width(tty, ctx) ||
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_fake_bce(tty, wp, ctx->bg) ||
|
|
|
|
(!tty_term_has(tty->term, TTYC_ICH) &&
|
|
|
|
!tty_term_has(tty->term, TTYC_ICH1))) {
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_draw_pane(tty, ctx, ctx->ocy);
|
2009-06-01 22:58:49 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-12-03 22:50:09 +00:00
|
|
|
tty_cursor_pane(tty, ctx, ctx->ocx, ctx->ocy);
|
2009-10-12 09:29:58 +00:00
|
|
|
|
2016-10-03 19:19:18 +00:00
|
|
|
tty_emulate_repeat(tty, TTYC_ICH, TTYC_ICH1, ctx->num);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_deletecharacter(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-12-03 22:50:09 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ctx->bigger ||
|
|
|
|
!tty_pane_full_width(tty, ctx) ||
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_fake_bce(tty, wp, ctx->bg) ||
|
2009-08-21 12:29:59 +00:00
|
|
|
(!tty_term_has(tty->term, TTYC_DCH) &&
|
|
|
|
!tty_term_has(tty->term, TTYC_DCH1))) {
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_draw_pane(tty, ctx, ctx->ocy);
|
2009-06-01 22:58:49 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-12-03 22:50:09 +00:00
|
|
|
tty_cursor_pane(tty, ctx, ctx->ocx, ctx->ocy);
|
2009-10-12 09:29:58 +00:00
|
|
|
|
2016-10-03 19:19:18 +00:00
|
|
|
tty_emulate_repeat(tty, TTYC_DCH, TTYC_DCH1, ctx->num);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2013-01-15 23:18:55 +00:00
|
|
|
void
|
|
|
|
tty_cmd_clearcharacter(struct tty *tty, const struct tty_ctx *ctx)
|
|
|
|
{
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ctx->bigger) {
|
|
|
|
tty_draw_pane(tty, ctx, ctx->ocy);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-05-12 10:50:11 +00:00
|
|
|
tty_default_attributes(tty, ctx->wp, ctx->bg);
|
2013-01-15 23:18:55 +00:00
|
|
|
|
|
|
|
tty_cursor_pane(tty, ctx, ctx->ocx, ctx->ocy);
|
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
if (tty_term_has(tty->term, TTYC_ECH) &&
|
2017-04-18 15:27:47 +00:00
|
|
|
!tty_fake_bce(tty, ctx->wp, 8))
|
2013-01-15 23:18:55 +00:00
|
|
|
tty_putcode1(tty, TTYC_ECH, ctx->num);
|
2017-04-05 10:49:46 +00:00
|
|
|
else
|
|
|
|
tty_repeat_space(tty, ctx->num);
|
2013-01-15 23:18:55 +00:00
|
|
|
}
|
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_insertline(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ctx->bigger ||
|
|
|
|
!tty_pane_full_width(tty, ctx) ||
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_fake_bce(tty, ctx->wp, ctx->bg) ||
|
2009-12-03 22:50:09 +00:00
|
|
|
!tty_term_has(tty->term, TTYC_CSR) ||
|
2009-11-26 14:46:08 +00:00
|
|
|
!tty_term_has(tty->term, TTYC_IL1)) {
|
2009-07-22 20:53:38 +00:00
|
|
|
tty_redraw_region(tty, ctx);
|
2009-06-01 22:58:49 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_default_attributes(tty, ctx->wp, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-12-03 22:50:09 +00:00
|
|
|
tty_region_pane(tty, ctx, ctx->orupper, ctx->orlower);
|
2016-11-15 15:17:28 +00:00
|
|
|
tty_margin_off(tty);
|
2009-12-03 22:50:09 +00:00
|
|
|
tty_cursor_pane(tty, ctx, ctx->ocx, ctx->ocy);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-07-22 16:45:31 +00:00
|
|
|
tty_emulate_repeat(tty, TTYC_IL, TTYC_IL1, ctx->num);
|
2017-05-12 14:13:54 +00:00
|
|
|
tty->cx = tty->cy = UINT_MAX;
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_deleteline(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ctx->bigger ||
|
|
|
|
!tty_pane_full_width(tty, ctx) ||
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_fake_bce(tty, ctx->wp, ctx->bg) ||
|
2009-11-26 14:46:08 +00:00
|
|
|
!tty_term_has(tty->term, TTYC_CSR) ||
|
|
|
|
!tty_term_has(tty->term, TTYC_DL1)) {
|
2009-07-22 20:53:38 +00:00
|
|
|
tty_redraw_region(tty, ctx);
|
2009-06-01 22:58:49 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_default_attributes(tty, ctx->wp, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-12-03 22:50:09 +00:00
|
|
|
tty_region_pane(tty, ctx, ctx->orupper, ctx->orlower);
|
2016-11-15 15:17:28 +00:00
|
|
|
tty_margin_off(tty);
|
2009-12-03 22:50:09 +00:00
|
|
|
tty_cursor_pane(tty, ctx, ctx->ocx, ctx->ocy);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-07-22 16:45:31 +00:00
|
|
|
tty_emulate_repeat(tty, TTYC_DL, TTYC_DL1, ctx->num);
|
2017-05-12 14:13:54 +00:00
|
|
|
tty->cx = tty->cy = UINT_MAX;
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_clearline(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-12-03 22:50:09 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
2018-08-20 18:34:04 +00:00
|
|
|
u_int nx;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2017-05-10 16:47:03 +00:00
|
|
|
nx = screen_size_x(wp->screen);
|
2018-08-20 18:34:04 +00:00
|
|
|
tty_clear_pane_line(tty, ctx, ctx->ocy, 0, nx, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_clearendofline(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-12-03 22:50:09 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
2018-08-20 18:34:04 +00:00
|
|
|
u_int nx;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2017-05-10 16:47:03 +00:00
|
|
|
nx = screen_size_x(wp->screen) - ctx->ocx;
|
2018-08-20 18:34:04 +00:00
|
|
|
tty_clear_pane_line(tty, ctx, ctx->ocy, ctx->ocx, nx, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_clearstartofline(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2016-10-13 20:27:27 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
|
|
|
|
2018-08-20 18:34:04 +00:00
|
|
|
tty_clear_pane_line(tty, ctx, ctx->ocy, 0, ctx->ocx + 1, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_reverseindex(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2017-05-12 13:00:56 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
|
|
|
|
2009-10-21 13:42:44 +00:00
|
|
|
if (ctx->ocy != ctx->orupper)
|
|
|
|
return;
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ctx->bigger ||
|
|
|
|
!tty_pane_full_width(tty, ctx) ||
|
2017-05-12 13:00:56 +00:00
|
|
|
tty_fake_bce(tty, wp, 8) ||
|
2009-11-12 08:05:23 +00:00
|
|
|
!tty_term_has(tty->term, TTYC_CSR) ||
|
|
|
|
!tty_term_has(tty->term, TTYC_RI)) {
|
2009-07-22 20:53:38 +00:00
|
|
|
tty_redraw_region(tty, ctx);
|
2009-06-01 22:58:49 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-05-12 13:00:56 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
2009-12-03 22:50:09 +00:00
|
|
|
|
2009-10-21 13:42:44 +00:00
|
|
|
tty_region_pane(tty, ctx, ctx->orupper, ctx->orlower);
|
2016-11-15 15:17:28 +00:00
|
|
|
tty_margin_off(tty);
|
2009-10-21 13:42:44 +00:00
|
|
|
tty_cursor_pane(tty, ctx, ctx->ocx, ctx->orupper);
|
2009-12-03 22:50:09 +00:00
|
|
|
|
2009-10-21 13:42:44 +00:00
|
|
|
tty_putcode(tty, TTYC_RI);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_linefeed(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-12-03 22:50:09 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-10-21 13:42:44 +00:00
|
|
|
if (ctx->ocy != ctx->orlower)
|
|
|
|
return;
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ctx->bigger ||
|
|
|
|
(!tty_pane_full_width(tty, ctx) && !tty_use_margin(tty)) ||
|
2017-04-18 15:27:47 +00:00
|
|
|
tty_fake_bce(tty, wp, 8) ||
|
2009-06-01 22:58:49 +00:00
|
|
|
!tty_term_has(tty->term, TTYC_CSR)) {
|
2017-02-08 15:24:48 +00:00
|
|
|
tty_redraw_region(tty, ctx);
|
2009-06-01 22:58:49 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-05-12 13:00:56 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
2009-12-03 22:50:09 +00:00
|
|
|
|
2009-10-21 13:42:44 +00:00
|
|
|
tty_region_pane(tty, ctx, ctx->orupper, ctx->orlower);
|
2016-11-15 14:02:32 +00:00
|
|
|
tty_margin_pane(tty, ctx);
|
|
|
|
|
|
|
|
/*
|
2018-04-23 07:41:30 +00:00
|
|
|
* If we want to wrap a pane while using margins, the cursor needs to
|
|
|
|
* be exactly on the right of the region. If the cursor is entirely off
|
|
|
|
* the edge - move it back to the right. Some terminals are funny about
|
|
|
|
* this and insert extra spaces, so only use the right if margins are
|
|
|
|
* enabled.
|
2016-11-15 14:02:32 +00:00
|
|
|
*/
|
2018-04-23 07:41:30 +00:00
|
|
|
if (ctx->xoff + ctx->ocx > tty->rright) {
|
|
|
|
if (!tty_use_margin(tty))
|
|
|
|
tty_cursor(tty, 0, ctx->yoff + ctx->ocy);
|
|
|
|
else
|
|
|
|
tty_cursor(tty, tty->rright, ctx->yoff + ctx->ocy);
|
|
|
|
} else
|
2016-11-15 14:02:32 +00:00
|
|
|
tty_cursor_pane(tty, ctx, ctx->ocx, ctx->ocy);
|
2009-12-03 22:50:09 +00:00
|
|
|
|
2009-10-21 13:42:44 +00:00
|
|
|
tty_putc(tty, '\n');
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2017-02-08 17:31:09 +00:00
|
|
|
void
|
|
|
|
tty_cmd_scrollup(struct tty *tty, const struct tty_ctx *ctx)
|
|
|
|
{
|
|
|
|
struct window_pane *wp = ctx->wp;
|
2017-05-15 07:54:44 +00:00
|
|
|
u_int i;
|
2017-02-08 17:31:09 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ctx->bigger ||
|
|
|
|
(!tty_pane_full_width(tty, ctx) && !tty_use_margin(tty)) ||
|
2017-04-18 15:27:47 +00:00
|
|
|
tty_fake_bce(tty, wp, 8) ||
|
2017-02-08 17:31:09 +00:00
|
|
|
!tty_term_has(tty->term, TTYC_CSR)) {
|
|
|
|
tty_redraw_region(tty, ctx);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-05-12 13:00:56 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
2017-02-08 17:31:09 +00:00
|
|
|
|
|
|
|
tty_region_pane(tty, ctx, ctx->orupper, ctx->orlower);
|
|
|
|
tty_margin_pane(tty, ctx);
|
|
|
|
|
2017-05-15 07:54:44 +00:00
|
|
|
if (ctx->num == 1 || !tty_term_has(tty->term, TTYC_INDN)) {
|
2018-04-23 07:41:30 +00:00
|
|
|
if (!tty_use_margin(tty))
|
|
|
|
tty_cursor(tty, 0, tty->rlower);
|
|
|
|
else
|
|
|
|
tty_cursor(tty, tty->rright, tty->rlower);
|
2017-05-15 07:54:44 +00:00
|
|
|
for (i = 0; i < ctx->num; i++)
|
2017-02-08 17:31:09 +00:00
|
|
|
tty_putc(tty, '\n');
|
2018-04-23 07:41:30 +00:00
|
|
|
} else {
|
|
|
|
tty_cursor(tty, 0, tty->cy);
|
2017-05-15 07:54:44 +00:00
|
|
|
tty_putcode1(tty, TTYC_INDN, ctx->num);
|
2018-04-23 07:41:30 +00:00
|
|
|
}
|
2017-02-08 17:31:09 +00:00
|
|
|
}
|
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_clearendofscreen(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-12-03 22:50:09 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
2017-05-10 16:47:03 +00:00
|
|
|
u_int px, py, nx, ny;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2017-05-10 16:47:03 +00:00
|
|
|
tty_region_pane(tty, ctx, 0, screen_size_y(wp->screen) - 1);
|
2016-11-15 15:17:28 +00:00
|
|
|
tty_margin_off(tty);
|
2009-10-12 09:09:35 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
px = 0;
|
2017-05-10 16:47:03 +00:00
|
|
|
nx = screen_size_x(wp->screen);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
py = ctx->ocy + 1;
|
2017-05-10 16:47:03 +00:00
|
|
|
ny = screen_size_y(wp->screen) - ctx->ocy - 1;
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_clear_pane_area(tty, ctx, py, ny, px, nx, ctx->bg);
|
2017-05-10 16:47:03 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
px = ctx->ocx;
|
2017-05-10 16:47:03 +00:00
|
|
|
nx = screen_size_x(wp->screen) - ctx->ocx;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
py = ctx->ocy;
|
2017-05-10 16:47:03 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_clear_pane_line(tty, ctx, py, px, nx, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_clearstartofscreen(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-12-03 22:50:09 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
2017-05-10 16:47:03 +00:00
|
|
|
u_int px, py, nx, ny;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2017-02-06 19:26:49 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2017-05-10 16:47:03 +00:00
|
|
|
tty_region_pane(tty, ctx, 0, screen_size_y(wp->screen) - 1);
|
2016-11-15 15:17:28 +00:00
|
|
|
tty_margin_off(tty);
|
2009-10-12 09:09:35 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
px = 0;
|
2017-05-10 16:47:03 +00:00
|
|
|
nx = screen_size_x(wp->screen);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
py = 0;
|
2017-05-10 16:47:03 +00:00
|
|
|
ny = ctx->ocy - 1;
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_clear_pane_area(tty, ctx, py, ny, px, nx, ctx->bg);
|
2017-05-10 16:47:03 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
px = 0;
|
2017-05-10 16:47:03 +00:00
|
|
|
nx = ctx->ocx + 1;
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
py = ctx->ocy;
|
2017-05-10 16:47:03 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_clear_pane_line(tty, ctx, py, px, nx, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_clearscreen(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-12-03 22:50:09 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
2017-05-10 16:47:03 +00:00
|
|
|
u_int px, py, nx, ny;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2016-10-13 20:27:27 +00:00
|
|
|
tty_default_attributes(tty, wp, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2017-05-10 16:47:03 +00:00
|
|
|
tty_region_pane(tty, ctx, 0, screen_size_y(wp->screen) - 1);
|
2016-11-15 15:17:28 +00:00
|
|
|
tty_margin_off(tty);
|
2009-10-12 09:09:35 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
px = 0;
|
2017-05-10 16:47:03 +00:00
|
|
|
nx = screen_size_x(wp->screen);
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
py = 0;
|
2017-05-10 16:47:03 +00:00
|
|
|
ny = screen_size_y(wp->screen);
|
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_clear_pane_area(tty, ctx, py, ny, px, nx, ctx->bg);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2009-06-03 23:30:40 +00:00
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_alignmenttest(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-03 23:30:40 +00:00
|
|
|
{
|
2009-07-22 16:45:31 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
|
|
|
struct screen *s = wp->screen;
|
|
|
|
u_int i, j;
|
2009-06-03 23:30:40 +00:00
|
|
|
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
if (ctx->bigger) {
|
|
|
|
wp->flags |= PANE_REDRAW;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-04-19 21:05:27 +00:00
|
|
|
tty_attributes(tty, &grid_default_cell, wp);
|
2009-06-03 23:30:40 +00:00
|
|
|
|
2009-10-12 09:09:35 +00:00
|
|
|
tty_region_pane(tty, ctx, 0, screen_size_y(s) - 1);
|
2016-11-15 15:17:28 +00:00
|
|
|
tty_margin_off(tty);
|
2009-06-03 23:30:40 +00:00
|
|
|
|
|
|
|
for (j = 0; j < screen_size_y(s); j++) {
|
2009-10-12 09:29:58 +00:00
|
|
|
tty_cursor_pane(tty, ctx, 0, j);
|
2009-06-03 23:30:40 +00:00
|
|
|
for (i = 0; i < screen_size_x(s); i++)
|
|
|
|
tty_putc(tty, 'E');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
void
|
2009-08-12 09:41:59 +00:00
|
|
|
tty_cmd_cell(struct tty *tty, const struct tty_ctx *ctx)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2018-08-20 18:45:32 +00:00
|
|
|
if (!tty_is_visible(tty, ctx, ctx->ocx, ctx->ocy, 1, 1))
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
if (ctx->xoff + ctx->ocx - ctx->ox > tty->sx - 1 &&
|
|
|
|
ctx->ocy == ctx->orlower) {
|
2017-01-11 23:10:04 +00:00
|
|
|
if (tty_pane_full_width(tty, ctx))
|
|
|
|
tty_region_pane(tty, ctx, ctx->orupper, ctx->orlower);
|
|
|
|
else
|
|
|
|
tty_margin_off(tty);
|
|
|
|
}
|
2009-10-12 17:19:47 +00:00
|
|
|
|
2017-03-15 09:21:21 +00:00
|
|
|
tty_cursor_pane_unless_wrap(tty, ctx, ctx->ocx, ctx->ocy);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2017-02-08 15:49:29 +00:00
|
|
|
tty_cell(tty, ctx->cell, ctx->wp);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2017-02-08 16:45:18 +00:00
|
|
|
void
|
|
|
|
tty_cmd_cells(struct tty *tty, const struct tty_ctx *ctx)
|
|
|
|
{
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
struct window_pane *wp = ctx->wp;
|
|
|
|
|
2018-08-20 18:45:32 +00:00
|
|
|
if (!tty_is_visible(tty, ctx, ctx->ocx, ctx->ocy, ctx->num, 1))
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
if (ctx->bigger &&
|
|
|
|
(ctx->ocx < ctx->ox || ctx->ocx + ctx->num > ctx->ox + ctx->sx)) {
|
|
|
|
if (!ctx->wrapped ||
|
|
|
|
!tty_pane_full_width(tty, ctx) ||
|
|
|
|
(tty->term->flags & TERM_EARLYWRAP) ||
|
|
|
|
ctx->xoff + ctx->ocx != 0 ||
|
|
|
|
ctx->yoff + ctx->ocy != tty->cy + 1 ||
|
|
|
|
tty->cx < tty->sx ||
|
|
|
|
tty->cy == tty->rlower)
|
|
|
|
tty_draw_pane(tty, ctx, ctx->ocy);
|
|
|
|
else
|
|
|
|
wp->flags |= PANE_REDRAW;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-03-15 09:21:21 +00:00
|
|
|
tty_cursor_pane_unless_wrap(tty, ctx, ctx->ocx, ctx->ocy);
|
2017-02-08 16:45:18 +00:00
|
|
|
|
|
|
|
tty_attributes(tty, ctx->cell, ctx->wp);
|
|
|
|
tty_putn(tty, ctx->ptr, ctx->num, ctx->num);
|
|
|
|
}
|
|
|
|
|
2011-05-18 20:24:29 +00:00
|
|
|
void
|
|
|
|
tty_cmd_setselection(struct tty *tty, const struct tty_ctx *ctx)
|
|
|
|
{
|
|
|
|
char *buf;
|
|
|
|
size_t off;
|
|
|
|
|
|
|
|
if (!tty_term_has(tty->term, TTYC_MS))
|
|
|
|
return;
|
|
|
|
|
|
|
|
off = 4 * ((ctx->num + 2) / 3) + 1; /* storage for base64 */
|
|
|
|
buf = xmalloc(off);
|
|
|
|
|
|
|
|
b64_ntop(ctx->ptr, ctx->num, buf, off);
|
|
|
|
tty_putcode_ptr2(tty, TTYC_MS, "", buf);
|
|
|
|
|
2012-07-10 11:53:01 +00:00
|
|
|
free(buf);
|
2011-05-18 20:24:29 +00:00
|
|
|
}
|
|
|
|
|
2011-03-07 23:46:27 +00:00
|
|
|
void
|
|
|
|
tty_cmd_rawstring(struct tty *tty, const struct tty_ctx *ctx)
|
|
|
|
{
|
2017-03-24 14:45:00 +00:00
|
|
|
tty_add(tty, ctx->ptr, ctx->num);
|
2017-02-08 23:53:03 +00:00
|
|
|
tty_invalidate(tty);
|
2011-03-07 23:46:27 +00:00
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2015-04-19 21:05:27 +00:00
|
|
|
tty_cell(struct tty *tty, const struct grid_cell *gc,
|
|
|
|
const struct window_pane *wp)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2018-01-12 16:41:00 +00:00
|
|
|
const struct grid_cell *gcp;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
|
|
|
/* Skip last character if terminal is stupid. */
|
2016-10-14 21:48:00 +00:00
|
|
|
if ((tty->term->flags & TERM_EARLYWRAP) &&
|
|
|
|
tty->cy == tty->sy - 1 &&
|
|
|
|
tty->cx == tty->sx - 1)
|
2009-06-01 22:58:49 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
/* If this is a padding character, do nothing. */
|
|
|
|
if (gc->flags & GRID_FLAG_PADDING)
|
|
|
|
return;
|
|
|
|
|
|
|
|
/* Set the attributes. */
|
2015-04-19 21:05:27 +00:00
|
|
|
tty_attributes(tty, gc, wp);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2013-01-18 02:16:21 +00:00
|
|
|
/* Get the cell and if ASCII write with putc to do ACS translation. */
|
2018-01-12 16:41:00 +00:00
|
|
|
gcp = tty_check_codeset(tty, gc);
|
|
|
|
if (gcp->data.size == 1) {
|
|
|
|
if (*gcp->data.data < 0x20 || *gcp->data.data == 0x7f)
|
2009-06-01 22:58:49 +00:00
|
|
|
return;
|
2018-01-12 16:41:00 +00:00
|
|
|
tty_putc(tty, *gcp->data.data);
|
2009-06-01 22:58:49 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2013-01-18 02:16:21 +00:00
|
|
|
/* Write the data. */
|
2018-01-12 16:41:00 +00:00
|
|
|
tty_putn(tty, gcp->data.data, gcp->data.size, gcp->data.width);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
tty_reset(struct tty *tty)
|
|
|
|
{
|
|
|
|
struct grid_cell *gc = &tty->cell;
|
|
|
|
|
2017-02-06 19:45:23 +00:00
|
|
|
if (!grid_cells_equal(gc, &grid_default_cell)) {
|
2017-05-15 16:44:04 +00:00
|
|
|
if ((gc->attr & GRID_ATTR_CHARSET) && tty_acs_needed(tty))
|
2017-02-06 19:45:23 +00:00
|
|
|
tty_putcode(tty, TTYC_RMACS);
|
|
|
|
tty_putcode(tty, TTYC_SGR0);
|
|
|
|
memcpy(gc, &grid_default_cell, sizeof *gc);
|
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2017-02-06 19:45:23 +00:00
|
|
|
memcpy(&tty->last_cell, &grid_default_cell, sizeof tty->last_cell);
|
|
|
|
tty->last_wp = -1;
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2017-02-08 23:53:03 +00:00
|
|
|
static void
|
|
|
|
tty_invalidate(struct tty *tty)
|
|
|
|
{
|
|
|
|
memcpy(&tty->cell, &grid_default_cell, sizeof tty->cell);
|
|
|
|
|
|
|
|
memcpy(&tty->last_cell, &grid_default_cell, sizeof tty->last_cell);
|
|
|
|
tty->last_wp = -1;
|
|
|
|
|
|
|
|
tty->cx = tty->cy = UINT_MAX;
|
|
|
|
|
|
|
|
tty->rupper = tty->rleft = UINT_MAX;
|
|
|
|
tty->rlower = tty->rright = UINT_MAX;
|
|
|
|
|
|
|
|
if (tty->flags & TTY_STARTED) {
|
|
|
|
tty_putcode(tty, TTYC_SGR0);
|
|
|
|
|
|
|
|
tty->mode = ALL_MODES;
|
|
|
|
tty_update_mode(tty, MODE_CURSOR, NULL);
|
|
|
|
|
|
|
|
tty_cursor(tty, 0, 0);
|
|
|
|
tty_region_off(tty);
|
|
|
|
tty_margin_off(tty);
|
|
|
|
} else
|
|
|
|
tty->mode = MODE_CURSOR;
|
|
|
|
}
|
|
|
|
|
2016-11-15 15:17:28 +00:00
|
|
|
/* Turn off margin. */
|
|
|
|
void
|
|
|
|
tty_region_off(struct tty *tty)
|
|
|
|
{
|
|
|
|
tty_region(tty, 0, tty->sy - 1);
|
|
|
|
}
|
|
|
|
|
2009-10-12 09:16:59 +00:00
|
|
|
/* Set region inside pane. */
|
2016-10-11 13:21:59 +00:00
|
|
|
static void
|
2015-12-11 16:37:21 +00:00
|
|
|
tty_region_pane(struct tty *tty, const struct tty_ctx *ctx, u_int rupper,
|
|
|
|
u_int rlower)
|
2009-10-12 09:09:35 +00:00
|
|
|
{
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_region(tty, ctx->yoff + rupper - ctx->oy,
|
|
|
|
ctx->yoff + rlower - ctx->oy);
|
2009-10-12 09:09:35 +00:00
|
|
|
}
|
|
|
|
|
2009-10-12 09:16:59 +00:00
|
|
|
/* Set region at absolute position. */
|
2016-11-15 15:17:28 +00:00
|
|
|
static void
|
2009-10-12 09:16:59 +00:00
|
|
|
tty_region(struct tty *tty, u_int rupper, u_int rlower)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-10-12 09:09:35 +00:00
|
|
|
if (tty->rlower == rlower && tty->rupper == rupper)
|
|
|
|
return;
|
2009-06-01 22:58:49 +00:00
|
|
|
if (!tty_term_has(tty->term, TTYC_CSR))
|
|
|
|
return;
|
2009-10-12 09:09:35 +00:00
|
|
|
|
|
|
|
tty->rupper = rupper;
|
|
|
|
tty->rlower = rlower;
|
2009-10-12 13:01:18 +00:00
|
|
|
|
2009-10-21 09:36:53 +00:00
|
|
|
/*
|
|
|
|
* Some terminals (such as PuTTY) do not correctly reset the cursor to
|
|
|
|
* 0,0 if it is beyond the last column (they do not reset their wrap
|
|
|
|
* flag so further output causes a line feed). As a workaround, do an
|
|
|
|
* explicit move to 0 first.
|
|
|
|
*/
|
|
|
|
if (tty->cx >= tty->sx)
|
|
|
|
tty_cursor(tty, 0, tty->cy);
|
|
|
|
|
2009-10-12 09:09:35 +00:00
|
|
|
tty_putcode2(tty, TTYC_CSR, tty->rupper, tty->rlower);
|
2017-02-16 12:56:01 +00:00
|
|
|
tty->cx = tty->cy = UINT_MAX;
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2016-11-15 15:17:28 +00:00
|
|
|
/* Turn off margin. */
|
|
|
|
void
|
|
|
|
tty_margin_off(struct tty *tty)
|
|
|
|
{
|
|
|
|
tty_margin(tty, 0, tty->sx - 1);
|
|
|
|
}
|
|
|
|
|
2016-11-15 14:02:32 +00:00
|
|
|
/* Set margin inside pane. */
|
|
|
|
static void
|
|
|
|
tty_margin_pane(struct tty *tty, const struct tty_ctx *ctx)
|
|
|
|
{
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_margin(tty, ctx->xoff - ctx->ox,
|
|
|
|
ctx->xoff + ctx->wp->sx - 1 - ctx->ox);
|
2016-11-15 14:02:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Set margin at absolute position. */
|
2016-11-15 15:17:28 +00:00
|
|
|
static void
|
2016-11-15 14:02:32 +00:00
|
|
|
tty_margin(struct tty *tty, u_int rleft, u_int rright)
|
|
|
|
{
|
|
|
|
char s[64];
|
|
|
|
|
|
|
|
if (!tty_use_margin(tty))
|
|
|
|
return;
|
|
|
|
if (tty->rleft == rleft && tty->rright == rright)
|
|
|
|
return;
|
|
|
|
|
2017-02-07 18:27:46 +00:00
|
|
|
tty_putcode2(tty, TTYC_CSR, tty->rupper, tty->rlower);
|
2017-02-07 17:13:28 +00:00
|
|
|
|
2016-11-15 14:02:32 +00:00
|
|
|
tty->rleft = rleft;
|
|
|
|
tty->rright = rright;
|
|
|
|
|
2017-02-07 18:27:46 +00:00
|
|
|
if (rleft == 0 && rright == tty->sx - 1)
|
|
|
|
snprintf(s, sizeof s, "\033[s");
|
|
|
|
else
|
|
|
|
snprintf(s, sizeof s, "\033[%u;%us", rleft + 1, rright + 1);
|
2016-11-15 14:02:32 +00:00
|
|
|
tty_puts(tty, s);
|
2017-02-16 12:56:01 +00:00
|
|
|
tty->cx = tty->cy = UINT_MAX;
|
2016-11-15 14:02:32 +00:00
|
|
|
}
|
|
|
|
|
2017-03-15 09:21:21 +00:00
|
|
|
/*
|
|
|
|
* Move the cursor, unless it would wrap itself when the next character is
|
|
|
|
* printed.
|
|
|
|
*/
|
|
|
|
static void
|
|
|
|
tty_cursor_pane_unless_wrap(struct tty *tty, const struct tty_ctx *ctx,
|
|
|
|
u_int cx, u_int cy)
|
|
|
|
{
|
2017-04-25 18:30:29 +00:00
|
|
|
if (!ctx->wrapped ||
|
|
|
|
!tty_pane_full_width(tty, ctx) ||
|
2017-03-15 09:21:21 +00:00
|
|
|
(tty->term->flags & TERM_EARLYWRAP) ||
|
|
|
|
ctx->xoff + cx != 0 ||
|
|
|
|
ctx->yoff + cy != tty->cy + 1 ||
|
2017-03-15 15:22:14 +00:00
|
|
|
tty->cx < tty->sx ||
|
|
|
|
tty->cy == tty->rlower)
|
2017-03-15 09:21:21 +00:00
|
|
|
tty_cursor_pane(tty, ctx, cx, cy);
|
|
|
|
else
|
|
|
|
log_debug("%s: will wrap at %u,%u", __func__, tty->cx, tty->cy);
|
|
|
|
}
|
|
|
|
|
2009-10-12 13:01:18 +00:00
|
|
|
/* Move cursor inside pane. */
|
2016-10-11 13:21:59 +00:00
|
|
|
static void
|
2009-10-12 09:29:58 +00:00
|
|
|
tty_cursor_pane(struct tty *tty, const struct tty_ctx *ctx, u_int cx, u_int cy)
|
|
|
|
{
|
Support for windows larger than the client.
This adds two new options, window-size and default-size, and a new
command, resize-window.
The force-width and force-height options, and the session_width and
session_height formats have been removed.
The new window-size option tells tmux how to work out the size of
windows: largest means it picks the size of the largest session,
smallest the smallest session (similar to the old behaviour) and
manual means that it does not automatically resize
windows. aggressive-resize modifies the choice of session for largest
and smallest as it did before.
If a window is in a session attached to a client that is too small,
only part of the window is shown. tmux attempts to keep the cursor
visible, so the part of the window displayed is changed as the cursor
moves (with a small delay, to try and avoid excess redrawing when
applications redraw status lines or similar that are not currently
visible).
Drawing windows which are larger than the client is not as efficient
as those which fit, particularly when the cursor moves, so it is
recommended to avoid using this on slow machines or networks (set
window-size to smallest or manual).
The resize-window command can be used to resize a window manually. If
it is used, the window-size option is automatically set to manual for
the window (undo this with "setw -u window-size"). resize-window works
in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has
-a and -A flags. -a sets the window to the size of the smallest client
(what it would be if window-size was smallest) and -A the largest.
For the same behaviour as force-width or force-height, use
resize-width -x or -y.
If the global window-size option is set to manual, the default-size
option is used for new windows. If -x or -y is used with new-session,
that sets the default-size option for the new session.
The maximum size of a window is 10000x10000. But expect applications
to complain and higher memory use if you make a window that big. The
minimum size is the size required for the current layout including
borders.
This change allows some code improvements, most notably that since
windows can now never be cropped, that code can be removed from the
layout code, and since panes can now never be outside the size of the
window, window_pane_visible can be removed.
2018-08-20 14:22:14 +00:00
|
|
|
tty_cursor(tty, ctx->xoff + cx - ctx->ox, ctx->yoff + cy - ctx->oy);
|
2009-10-12 09:29:58 +00:00
|
|
|
}
|
|
|
|
|
2009-10-12 13:01:18 +00:00
|
|
|
/* Move cursor to absolute position. */
|
2009-10-12 09:29:58 +00:00
|
|
|
void
|
|
|
|
tty_cursor(struct tty *tty, u_int cx, u_int cy)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-10-12 13:01:18 +00:00
|
|
|
struct tty_term *term = tty->term;
|
|
|
|
u_int thisx, thisy;
|
|
|
|
int change;
|
2009-12-03 22:50:09 +00:00
|
|
|
|
2009-10-12 13:01:18 +00:00
|
|
|
if (cx > tty->sx - 1)
|
|
|
|
cx = tty->sx - 1;
|
|
|
|
|
|
|
|
thisx = tty->cx;
|
|
|
|
thisy = tty->cy;
|
|
|
|
|
|
|
|
/* No change. */
|
|
|
|
if (cx == thisx && cy == thisy)
|
|
|
|
return;
|
|
|
|
|
2009-10-12 14:54:19 +00:00
|
|
|
/* Very end of the line, just use absolute movement. */
|
|
|
|
if (thisx > tty->sx - 1)
|
|
|
|
goto absolute;
|
|
|
|
|
2009-10-12 13:01:18 +00:00
|
|
|
/* Move to home position (0, 0). */
|
|
|
|
if (cx == 0 && cy == 0 && tty_term_has(term, TTYC_HOME)) {
|
|
|
|
tty_putcode(tty, TTYC_HOME);
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Zero on the next line. */
|
2017-08-21 21:01:21 +00:00
|
|
|
if (cx == 0 && cy == thisy + 1 && thisy != tty->rlower &&
|
|
|
|
(!tty_use_margin(tty) || tty->rleft == 0)) {
|
2009-06-01 22:58:49 +00:00
|
|
|
tty_putc(tty, '\r');
|
2009-10-12 13:01:18 +00:00
|
|
|
tty_putc(tty, '\n');
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
2009-10-12 16:41:02 +00:00
|
|
|
/* Moving column or row. */
|
2009-10-12 13:01:18 +00:00
|
|
|
if (cy == thisy) {
|
2009-10-12 16:41:02 +00:00
|
|
|
/*
|
|
|
|
* Moving column only, row staying the same.
|
|
|
|
*/
|
|
|
|
|
2009-10-12 13:01:18 +00:00
|
|
|
/* To left edge. */
|
2017-08-21 21:02:58 +00:00
|
|
|
if (cx == 0 && (!tty_use_margin(tty) || tty->rleft == 0)) {
|
2009-10-12 13:01:18 +00:00
|
|
|
tty_putc(tty, '\r');
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* One to the left. */
|
|
|
|
if (cx == thisx - 1 && tty_term_has(term, TTYC_CUB1)) {
|
|
|
|
tty_putcode(tty, TTYC_CUB1);
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* One to the right. */
|
|
|
|
if (cx == thisx + 1 && tty_term_has(term, TTYC_CUF1)) {
|
|
|
|
tty_putcode(tty, TTYC_CUF1);
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Calculate difference. */
|
|
|
|
change = thisx - cx; /* +ve left, -ve right */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Use HPA if change is larger than absolute, otherwise move
|
|
|
|
* the cursor with CUB/CUF.
|
|
|
|
*/
|
2010-06-05 16:32:22 +00:00
|
|
|
if ((u_int) abs(change) > cx && tty_term_has(term, TTYC_HPA)) {
|
2009-10-12 13:01:18 +00:00
|
|
|
tty_putcode1(tty, TTYC_HPA, cx);
|
|
|
|
goto out;
|
|
|
|
} else if (change > 0 && tty_term_has(term, TTYC_CUB)) {
|
2016-05-30 09:26:49 +00:00
|
|
|
if (change == 2 && tty_term_has(term, TTYC_CUB1)) {
|
|
|
|
tty_putcode(tty, TTYC_CUB1);
|
|
|
|
tty_putcode(tty, TTYC_CUB1);
|
|
|
|
goto out;
|
|
|
|
}
|
2009-10-12 13:01:18 +00:00
|
|
|
tty_putcode1(tty, TTYC_CUB, change);
|
|
|
|
goto out;
|
|
|
|
} else if (change < 0 && tty_term_has(term, TTYC_CUF)) {
|
|
|
|
tty_putcode1(tty, TTYC_CUF, -change);
|
|
|
|
goto out;
|
|
|
|
}
|
2009-10-12 16:41:02 +00:00
|
|
|
} else if (cx == thisx) {
|
|
|
|
/*
|
|
|
|
* Moving row only, column staying the same.
|
|
|
|
*/
|
2009-10-12 13:01:18 +00:00
|
|
|
|
|
|
|
/* One above. */
|
2009-12-03 22:50:09 +00:00
|
|
|
if (thisy != tty->rupper &&
|
2009-10-12 13:01:18 +00:00
|
|
|
cy == thisy - 1 && tty_term_has(term, TTYC_CUU1)) {
|
|
|
|
tty_putcode(tty, TTYC_CUU1);
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* One below. */
|
2009-10-16 19:09:40 +00:00
|
|
|
if (thisy != tty->rlower &&
|
2009-10-12 13:01:18 +00:00
|
|
|
cy == thisy + 1 && tty_term_has(term, TTYC_CUD1)) {
|
|
|
|
tty_putcode(tty, TTYC_CUD1);
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Calculate difference. */
|
|
|
|
change = thisy - cy; /* +ve up, -ve down */
|
|
|
|
|
|
|
|
/*
|
2009-12-03 22:50:09 +00:00
|
|
|
* Try to use VPA if change is larger than absolute or if this
|
|
|
|
* change would cross the scroll region, otherwise use CUU/CUD.
|
2009-10-12 13:01:18 +00:00
|
|
|
*/
|
2010-06-05 16:32:22 +00:00
|
|
|
if ((u_int) abs(change) > cy ||
|
2009-10-12 13:01:18 +00:00
|
|
|
(change < 0 && cy - change > tty->rlower) ||
|
2009-10-12 16:37:43 +00:00
|
|
|
(change > 0 && cy - change < tty->rupper)) {
|
|
|
|
if (tty_term_has(term, TTYC_VPA)) {
|
|
|
|
tty_putcode1(tty, TTYC_VPA, cy);
|
|
|
|
goto out;
|
|
|
|
}
|
2009-10-12 13:01:18 +00:00
|
|
|
} else if (change > 0 && tty_term_has(term, TTYC_CUU)) {
|
|
|
|
tty_putcode1(tty, TTYC_CUU, change);
|
|
|
|
goto out;
|
|
|
|
} else if (change < 0 && tty_term_has(term, TTYC_CUD)) {
|
|
|
|
tty_putcode1(tty, TTYC_CUD, -change);
|
|
|
|
goto out;
|
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
2009-10-12 13:01:18 +00:00
|
|
|
|
2009-10-12 14:54:19 +00:00
|
|
|
absolute:
|
2009-10-12 13:01:18 +00:00
|
|
|
/* Absolute movement. */
|
|
|
|
tty_putcode2(tty, TTYC_CUP, cy, cx);
|
|
|
|
|
|
|
|
out:
|
|
|
|
tty->cx = cx;
|
|
|
|
tty->cy = cy;
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2015-04-19 21:05:27 +00:00
|
|
|
tty_attributes(struct tty *tty, const struct grid_cell *gc,
|
|
|
|
const struct window_pane *wp)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-10-28 08:52:36 +00:00
|
|
|
struct grid_cell *tc = &tty->cell, gc2;
|
2017-03-22 07:16:54 +00:00
|
|
|
int changed;
|
2009-10-28 08:27:33 +00:00
|
|
|
|
2017-02-06 19:45:23 +00:00
|
|
|
/* Ignore cell if it is the same as the last one. */
|
|
|
|
if (wp != NULL &&
|
|
|
|
(int)wp->id == tty->last_wp &&
|
|
|
|
~(wp->window->flags & WINDOW_STYLECHANGED) &&
|
|
|
|
gc->attr == tty->last_cell.attr &&
|
|
|
|
gc->fg == tty->last_cell.fg &&
|
|
|
|
gc->bg == tty->last_cell.bg)
|
|
|
|
return;
|
|
|
|
tty->last_wp = (wp != NULL ? (int)wp->id : -1);
|
|
|
|
memcpy(&tty->last_cell, gc, sizeof tty->last_cell);
|
|
|
|
|
|
|
|
/* Copy cell and update default colours. */
|
2010-03-01 22:44:31 +00:00
|
|
|
memcpy(&gc2, gc, sizeof gc2);
|
2016-05-30 09:50:20 +00:00
|
|
|
if (wp != NULL)
|
|
|
|
tty_default_colours(&gc2, wp);
|
2009-10-28 08:52:36 +00:00
|
|
|
|
2009-08-05 16:26:38 +00:00
|
|
|
/*
|
|
|
|
* If no setab, try to use the reverse attribute as a best-effort for a
|
|
|
|
* non-default background. This is a bit of a hack but it doesn't do
|
|
|
|
* any serious harm and makes a couple of applications happier.
|
|
|
|
*/
|
|
|
|
if (!tty_term_has(tty->term, TTYC_SETAB)) {
|
2010-03-01 22:44:31 +00:00
|
|
|
if (gc2.attr & GRID_ATTR_REVERSE) {
|
|
|
|
if (gc2.fg != 7 && gc2.fg != 8)
|
2009-11-04 13:34:26 +00:00
|
|
|
gc2.attr &= ~GRID_ATTR_REVERSE;
|
2009-08-05 16:26:38 +00:00
|
|
|
} else {
|
2010-03-01 22:44:31 +00:00
|
|
|
if (gc2.bg != 0 && gc2.bg != 8)
|
2009-11-04 13:34:26 +00:00
|
|
|
gc2.attr |= GRID_ATTR_REVERSE;
|
2009-08-05 16:26:38 +00:00
|
|
|
}
|
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2010-03-01 22:44:31 +00:00
|
|
|
/* Fix up the colours if necessary. */
|
2017-01-07 15:28:13 +00:00
|
|
|
tty_check_fg(tty, wp, &gc2);
|
|
|
|
tty_check_bg(tty, wp, &gc2);
|
2010-03-01 22:44:31 +00:00
|
|
|
|
2009-11-04 13:34:26 +00:00
|
|
|
/* If any bits are being cleared, reset everything. */
|
2010-03-01 22:44:31 +00:00
|
|
|
if (tc->attr & ~gc2.attr)
|
2009-11-04 13:34:26 +00:00
|
|
|
tty_reset(tty);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Set the colours. This may call tty_reset() (so it comes next) and
|
|
|
|
* may add to (NOT remove) the desired attributes by changing new_attr.
|
|
|
|
*/
|
2010-03-01 22:44:31 +00:00
|
|
|
tty_colours(tty, &gc2);
|
2009-11-04 13:34:26 +00:00
|
|
|
|
2009-06-01 22:58:49 +00:00
|
|
|
/* Filter out attribute bits already set. */
|
2010-03-01 22:44:31 +00:00
|
|
|
changed = gc2.attr & ~tc->attr;
|
|
|
|
tc->attr = gc2.attr;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
|
|
|
/* Set the attributes. */
|
|
|
|
if (changed & GRID_ATTR_BRIGHT)
|
|
|
|
tty_putcode(tty, TTYC_BOLD);
|
|
|
|
if (changed & GRID_ATTR_DIM)
|
|
|
|
tty_putcode(tty, TTYC_DIM);
|
2015-04-29 15:59:08 +00:00
|
|
|
if (changed & GRID_ATTR_ITALICS)
|
|
|
|
tty_set_italics(tty);
|
2009-06-01 22:58:49 +00:00
|
|
|
if (changed & GRID_ATTR_UNDERSCORE)
|
|
|
|
tty_putcode(tty, TTYC_SMUL);
|
|
|
|
if (changed & GRID_ATTR_BLINK)
|
|
|
|
tty_putcode(tty, TTYC_BLINK);
|
|
|
|
if (changed & GRID_ATTR_REVERSE) {
|
|
|
|
if (tty_term_has(tty->term, TTYC_REV))
|
|
|
|
tty_putcode(tty, TTYC_REV);
|
|
|
|
else if (tty_term_has(tty->term, TTYC_SMSO))
|
|
|
|
tty_putcode(tty, TTYC_SMSO);
|
|
|
|
}
|
|
|
|
if (changed & GRID_ATTR_HIDDEN)
|
|
|
|
tty_putcode(tty, TTYC_INVIS);
|
2017-03-22 07:16:54 +00:00
|
|
|
if (changed & GRID_ATTR_STRIKETHROUGH)
|
|
|
|
tty_putcode(tty, TTYC_SMXX);
|
2017-05-15 16:44:04 +00:00
|
|
|
if ((changed & GRID_ATTR_CHARSET) && tty_acs_needed(tty))
|
2009-06-01 22:58:49 +00:00
|
|
|
tty_putcode(tty, TTYC_SMACS);
|
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2010-03-01 22:44:31 +00:00
|
|
|
tty_colours(struct tty *tty, const struct grid_cell *gc)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-10-28 08:27:33 +00:00
|
|
|
struct grid_cell *tc = &tty->cell;
|
2016-07-15 00:49:08 +00:00
|
|
|
int have_ax;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-10-28 08:27:33 +00:00
|
|
|
/* No changes? Nothing is necessary. */
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->fg == tc->fg && gc->bg == tc->bg)
|
2009-10-28 08:52:36 +00:00
|
|
|
return;
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-10-28 08:27:33 +00:00
|
|
|
/*
|
|
|
|
* Is either the default colour? This is handled specially because the
|
|
|
|
* best solution might be to reset both colours to default, in which
|
|
|
|
* case if only one is default need to fall onward to set the other
|
|
|
|
* colour.
|
|
|
|
*/
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->fg == 8 || gc->bg == 8) {
|
2009-10-28 08:27:33 +00:00
|
|
|
/*
|
|
|
|
* If don't have AX but do have op, send sgr0 (op can't
|
|
|
|
* actually be used because it is sometimes the same as sgr0
|
|
|
|
* and sometimes isn't). This resets both colours to default.
|
|
|
|
*
|
|
|
|
* Otherwise, try to set the default colour only as needed.
|
|
|
|
*/
|
2015-04-15 22:10:13 +00:00
|
|
|
have_ax = tty_term_flag(tty->term, TTYC_AX);
|
2009-10-28 08:27:33 +00:00
|
|
|
if (!have_ax && tty_term_has(tty->term, TTYC_OP))
|
|
|
|
tty_reset(tty);
|
|
|
|
else {
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->fg == 8 && tc->fg != 8) {
|
2009-10-28 08:27:33 +00:00
|
|
|
if (have_ax)
|
|
|
|
tty_puts(tty, "\033[39m");
|
2016-07-15 00:49:08 +00:00
|
|
|
else if (tc->fg != 7)
|
2009-10-28 08:27:33 +00:00
|
|
|
tty_putcode1(tty, TTYC_SETAF, 7);
|
|
|
|
tc->fg = 8;
|
|
|
|
}
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->bg == 8 && tc->bg != 8) {
|
2009-12-03 22:50:09 +00:00
|
|
|
if (have_ax)
|
2009-10-28 08:27:33 +00:00
|
|
|
tty_puts(tty, "\033[49m");
|
2016-07-15 00:49:08 +00:00
|
|
|
else if (tc->bg != 0)
|
2009-10-28 08:27:33 +00:00
|
|
|
tty_putcode1(tty, TTYC_SETAB, 0);
|
|
|
|
tc->bg = 8;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-10-28 08:27:33 +00:00
|
|
|
/* Set the foreground colour. */
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->fg != 8 && gc->fg != tc->fg)
|
2010-03-01 22:44:31 +00:00
|
|
|
tty_colours_fg(tty, gc);
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2009-10-28 08:27:33 +00:00
|
|
|
/*
|
|
|
|
* Set the background colour. This must come after the foreground as
|
|
|
|
* tty_colour_fg() can call tty_reset().
|
|
|
|
*/
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->bg != 8 && gc->bg != tc->bg)
|
2009-11-26 21:37:13 +00:00
|
|
|
tty_colours_bg(tty, gc);
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2017-01-07 15:28:13 +00:00
|
|
|
static void
|
|
|
|
tty_check_fg(struct tty *tty, const struct window_pane *wp,
|
|
|
|
struct grid_cell *gc)
|
2010-03-01 22:44:31 +00:00
|
|
|
{
|
2016-07-15 00:49:08 +00:00
|
|
|
u_char r, g, b;
|
|
|
|
u_int colours;
|
2017-01-12 00:19:32 +00:00
|
|
|
int c;
|
2010-03-01 22:44:31 +00:00
|
|
|
|
2017-06-03 07:15:23 +00:00
|
|
|
/*
|
|
|
|
* Perform substitution if this pane has a palette. If the bright
|
|
|
|
* attribute is set, use the bright entry in the palette by changing to
|
|
|
|
* the aixterm colour.
|
|
|
|
*/
|
|
|
|
if (~gc->flags & GRID_FLAG_NOPALETTE) {
|
|
|
|
c = gc->fg;
|
2017-06-04 08:02:20 +00:00
|
|
|
if (c < 8 && gc->attr & GRID_ATTR_BRIGHT)
|
2017-06-03 07:15:23 +00:00
|
|
|
c += 90;
|
|
|
|
if ((c = window_pane_get_palette(wp, c)) != -1)
|
|
|
|
gc->fg = c;
|
|
|
|
}
|
2017-01-07 15:28:13 +00:00
|
|
|
|
2016-01-29 11:13:56 +00:00
|
|
|
/* Is this a 24-bit colour? */
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->fg & COLOUR_FLAG_RGB) {
|
2016-01-29 11:13:56 +00:00
|
|
|
/* Not a 24-bit terminal? Translate to 256-colour palette. */
|
2017-05-31 08:43:44 +00:00
|
|
|
if (!tty_term_has(tty->term, TTYC_SETRGBF)) {
|
2016-07-15 00:49:08 +00:00
|
|
|
colour_split_rgb(gc->fg, &r, &g, &b);
|
|
|
|
gc->fg = colour_find_rgb(r, g, b);
|
|
|
|
} else
|
2016-03-03 12:58:15 +00:00
|
|
|
return;
|
2016-01-29 11:13:56 +00:00
|
|
|
}
|
2017-01-12 00:30:41 +00:00
|
|
|
|
|
|
|
/* How many colours does this terminal have? */
|
|
|
|
if ((tty->term->flags|tty->term_flags) & TERM_256COLOURS)
|
|
|
|
colours = 256;
|
|
|
|
else
|
|
|
|
colours = tty_term_number(tty->term, TTYC_COLORS);
|
2015-04-15 22:34:46 +00:00
|
|
|
|
2010-03-01 22:44:31 +00:00
|
|
|
/* Is this a 256-colour colour? */
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->fg & COLOUR_FLAG_256) {
|
2010-03-01 22:44:31 +00:00
|
|
|
/* And not a 256 colour mode? */
|
2017-01-12 00:30:41 +00:00
|
|
|
if (colours != 256) {
|
2010-03-01 22:44:31 +00:00
|
|
|
gc->fg = colour_256to16(gc->fg);
|
|
|
|
if (gc->fg & 8) {
|
|
|
|
gc->fg &= 7;
|
2015-04-15 22:34:46 +00:00
|
|
|
if (colours >= 16)
|
|
|
|
gc->fg += 90;
|
|
|
|
else
|
|
|
|
gc->attr |= GRID_ATTR_BRIGHT;
|
2010-03-01 22:44:31 +00:00
|
|
|
} else
|
|
|
|
gc->attr &= ~GRID_ATTR_BRIGHT;
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Is this an aixterm colour? */
|
|
|
|
if (gc->fg >= 90 && gc->fg <= 97 && colours < 16) {
|
|
|
|
gc->fg -= 90;
|
|
|
|
gc->attr |= GRID_ATTR_BRIGHT;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-07 15:28:13 +00:00
|
|
|
static void
|
|
|
|
tty_check_bg(struct tty *tty, const struct window_pane *wp,
|
|
|
|
struct grid_cell *gc)
|
2010-03-01 22:44:31 +00:00
|
|
|
{
|
2016-07-15 00:49:08 +00:00
|
|
|
u_char r, g, b;
|
|
|
|
u_int colours;
|
2017-01-12 00:19:32 +00:00
|
|
|
int c;
|
2010-03-01 22:44:31 +00:00
|
|
|
|
2017-06-03 07:15:23 +00:00
|
|
|
/* Perform substitution if this pane has a palette. */
|
|
|
|
if (~gc->flags & GRID_FLAG_NOPALETTE) {
|
|
|
|
if ((c = window_pane_get_palette(wp, gc->bg)) != -1)
|
|
|
|
gc->bg = c;
|
|
|
|
}
|
2017-01-07 15:28:13 +00:00
|
|
|
|
2016-01-29 11:13:56 +00:00
|
|
|
/* Is this a 24-bit colour? */
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->bg & COLOUR_FLAG_RGB) {
|
2016-01-29 11:13:56 +00:00
|
|
|
/* Not a 24-bit terminal? Translate to 256-colour palette. */
|
2017-05-31 08:43:44 +00:00
|
|
|
if (!tty_term_has(tty->term, TTYC_SETRGBB)) {
|
2016-07-15 00:49:08 +00:00
|
|
|
colour_split_rgb(gc->bg, &r, &g, &b);
|
|
|
|
gc->bg = colour_find_rgb(r, g, b);
|
|
|
|
} else
|
2016-03-03 12:58:15 +00:00
|
|
|
return;
|
2016-01-29 11:13:56 +00:00
|
|
|
}
|
2017-01-12 00:30:41 +00:00
|
|
|
|
|
|
|
/* How many colours does this terminal have? */
|
|
|
|
if ((tty->term->flags|tty->term_flags) & TERM_256COLOURS)
|
|
|
|
colours = 256;
|
|
|
|
else
|
|
|
|
colours = tty_term_number(tty->term, TTYC_COLORS);
|
2015-04-15 22:34:46 +00:00
|
|
|
|
2010-03-01 22:44:31 +00:00
|
|
|
/* Is this a 256-colour colour? */
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->bg & COLOUR_FLAG_256) {
|
2010-03-01 22:44:31 +00:00
|
|
|
/*
|
|
|
|
* And not a 256 colour mode? Translate to 16-colour
|
|
|
|
* palette. Bold background doesn't exist portably, so just
|
|
|
|
* discard the bold bit if set.
|
|
|
|
*/
|
2017-01-12 00:30:41 +00:00
|
|
|
if (colours != 256) {
|
2010-03-01 22:44:31 +00:00
|
|
|
gc->bg = colour_256to16(gc->bg);
|
2015-04-15 22:34:46 +00:00
|
|
|
if (gc->bg & 8) {
|
2010-03-01 22:44:31 +00:00
|
|
|
gc->bg &= 7;
|
2015-04-15 22:34:46 +00:00
|
|
|
if (colours >= 16)
|
|
|
|
gc->fg += 90;
|
|
|
|
}
|
2010-03-01 22:44:31 +00:00
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Is this an aixterm colour? */
|
2015-04-15 22:34:46 +00:00
|
|
|
if (gc->bg >= 90 && gc->bg <= 97 && colours < 16)
|
2010-03-01 22:44:31 +00:00
|
|
|
gc->bg -= 90;
|
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2010-03-01 22:44:31 +00:00
|
|
|
tty_colours_fg(struct tty *tty, const struct grid_cell *gc)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-10-28 08:27:33 +00:00
|
|
|
struct grid_cell *tc = &tty->cell;
|
2009-12-14 21:33:38 +00:00
|
|
|
char s[32];
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2016-07-15 00:49:08 +00:00
|
|
|
/* Is this a 24-bit or 256-colour colour? */
|
2018-05-07 13:39:09 +00:00
|
|
|
if (gc->fg & COLOUR_FLAG_RGB || gc->fg & COLOUR_FLAG_256) {
|
2016-07-15 00:49:08 +00:00
|
|
|
if (tty_try_colour(tty, gc->fg, "38") == 0)
|
2009-10-28 08:27:33 +00:00
|
|
|
goto save_fg;
|
2016-01-29 11:13:56 +00:00
|
|
|
/* Should not get here, already converted in tty_check_fg. */
|
2010-03-01 22:44:31 +00:00
|
|
|
return;
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2009-12-14 21:33:38 +00:00
|
|
|
/* Is this an aixterm bright colour? */
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->fg >= 90 && gc->fg <= 97) {
|
|
|
|
xsnprintf(s, sizeof s, "\033[%dm", gc->fg);
|
2010-03-01 22:44:31 +00:00
|
|
|
tty_puts(tty, s);
|
|
|
|
goto save_fg;
|
2009-12-14 21:33:38 +00:00
|
|
|
}
|
|
|
|
|
2009-10-28 08:27:33 +00:00
|
|
|
/* Otherwise set the foreground colour. */
|
2016-07-15 00:49:08 +00:00
|
|
|
tty_putcode1(tty, TTYC_SETAF, gc->fg);
|
2009-10-28 08:27:33 +00:00
|
|
|
|
2009-12-03 22:50:09 +00:00
|
|
|
save_fg:
|
2009-10-28 08:27:33 +00:00
|
|
|
/* Save the new values in the terminal current cell. */
|
2016-07-15 00:49:08 +00:00
|
|
|
tc->fg = gc->fg;
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2009-11-26 21:37:13 +00:00
|
|
|
tty_colours_bg(struct tty *tty, const struct grid_cell *gc)
|
2009-06-01 22:58:49 +00:00
|
|
|
{
|
2009-10-28 08:27:33 +00:00
|
|
|
struct grid_cell *tc = &tty->cell;
|
2009-12-14 21:33:38 +00:00
|
|
|
char s[32];
|
2009-06-01 22:58:49 +00:00
|
|
|
|
2016-07-15 00:49:08 +00:00
|
|
|
/* Is this a 24-bit or 256-colour colour? */
|
2018-05-07 13:39:09 +00:00
|
|
|
if (gc->bg & COLOUR_FLAG_RGB || gc->bg & COLOUR_FLAG_256) {
|
2016-07-15 00:49:08 +00:00
|
|
|
if (tty_try_colour(tty, gc->bg, "48") == 0)
|
2009-10-28 08:27:33 +00:00
|
|
|
goto save_bg;
|
2016-01-29 11:13:56 +00:00
|
|
|
/* Should not get here, already converted in tty_check_bg. */
|
2010-03-01 22:44:31 +00:00
|
|
|
return;
|
2009-06-01 22:58:49 +00:00
|
|
|
}
|
|
|
|
|
2009-12-14 21:33:38 +00:00
|
|
|
/* Is this an aixterm bright colour? */
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->bg >= 90 && gc->bg <= 97) {
|
|
|
|
xsnprintf(s, sizeof s, "\033[%dm", gc->bg + 10);
|
2015-04-15 22:34:46 +00:00
|
|
|
tty_puts(tty, s);
|
|
|
|
goto save_bg;
|
2009-12-14 21:33:38 +00:00
|
|
|
}
|
|
|
|
|
2009-10-28 08:27:33 +00:00
|
|
|
/* Otherwise set the background colour. */
|
2016-07-15 00:49:08 +00:00
|
|
|
tty_putcode1(tty, TTYC_SETAB, gc->bg);
|
2009-10-28 08:27:33 +00:00
|
|
|
|
|
|
|
save_bg:
|
|
|
|
/* Save the new values in the terminal current cell. */
|
2016-07-15 00:49:08 +00:00
|
|
|
tc->bg = gc->bg;
|
2009-10-28 08:27:33 +00:00
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static int
|
2016-07-15 00:49:08 +00:00
|
|
|
tty_try_colour(struct tty *tty, int colour, const char *type)
|
2009-10-28 08:27:33 +00:00
|
|
|
{
|
2016-07-15 00:49:08 +00:00
|
|
|
u_char r, g, b;
|
2009-10-28 08:27:33 +00:00
|
|
|
char s[32];
|
|
|
|
|
2016-07-15 00:49:08 +00:00
|
|
|
if (colour & COLOUR_FLAG_256) {
|
|
|
|
/*
|
2018-02-04 10:10:39 +00:00
|
|
|
* If the user has specified -2 to the client (meaning
|
|
|
|
* TERM_256COLOURS is set), setaf and setab may not work (or
|
|
|
|
* they may not want to use them), so send the usual sequence.
|
|
|
|
*
|
|
|
|
* Also if RGB is set, setaf and setab do not support the 256
|
|
|
|
* colour palette so use the sequences directly there too.
|
2016-07-15 00:49:08 +00:00
|
|
|
*/
|
2018-02-04 10:10:39 +00:00
|
|
|
if ((tty->term_flags & TERM_256COLOURS) ||
|
|
|
|
tty_term_has(tty->term, TTYC_RGB))
|
2016-07-15 00:49:08 +00:00
|
|
|
goto fallback_256;
|
2015-10-23 15:52:54 +00:00
|
|
|
|
2016-07-15 00:49:08 +00:00
|
|
|
/*
|
|
|
|
* If the terminfo entry has 256 colours and setaf and setab
|
|
|
|
* exist, assume that they work correctly.
|
|
|
|
*/
|
|
|
|
if (tty->term->flags & TERM_256COLOURS) {
|
|
|
|
if (*type == '3') {
|
|
|
|
if (!tty_term_has(tty->term, TTYC_SETAF))
|
|
|
|
goto fallback_256;
|
|
|
|
tty_putcode1(tty, TTYC_SETAF, colour & 0xff);
|
|
|
|
} else {
|
|
|
|
if (!tty_term_has(tty->term, TTYC_SETAB))
|
|
|
|
goto fallback_256;
|
|
|
|
tty_putcode1(tty, TTYC_SETAB, colour & 0xff);
|
|
|
|
}
|
|
|
|
return (0);
|
2015-09-25 23:30:12 +00:00
|
|
|
}
|
2016-07-15 00:49:08 +00:00
|
|
|
goto fallback_256;
|
2014-02-14 14:37:08 +00:00
|
|
|
}
|
2009-10-28 08:27:33 +00:00
|
|
|
|
2016-07-15 00:49:08 +00:00
|
|
|
if (colour & COLOUR_FLAG_RGB) {
|
2017-05-31 08:43:44 +00:00
|
|
|
if (*type == '3') {
|
|
|
|
if (!tty_term_has(tty->term, TTYC_SETRGBF))
|
|
|
|
return (-1);
|
|
|
|
colour_split_rgb(colour & 0xffffff, &r, &g, &b);
|
|
|
|
tty_putcode3(tty, TTYC_SETRGBF, r, g, b);
|
|
|
|
} else {
|
|
|
|
if (!tty_term_has(tty->term, TTYC_SETRGBB))
|
|
|
|
return (-1);
|
|
|
|
colour_split_rgb(colour & 0xffffff, &r, &g, &b);
|
|
|
|
tty_putcode3(tty, TTYC_SETRGBB, r, g, b);
|
|
|
|
}
|
2016-07-15 00:49:08 +00:00
|
|
|
return (0);
|
|
|
|
}
|
2016-01-29 11:13:56 +00:00
|
|
|
|
2016-07-15 00:49:08 +00:00
|
|
|
return (-1);
|
2016-01-29 11:13:56 +00:00
|
|
|
|
2016-07-15 00:49:08 +00:00
|
|
|
fallback_256:
|
|
|
|
xsnprintf(s, sizeof s, "\033[%s;5;%dm", type, colour & 0xff);
|
2018-02-04 10:10:39 +00:00
|
|
|
log_debug("%s: 256 colour fallback: %s", tty->client->name, s);
|
2016-01-29 11:13:56 +00:00
|
|
|
tty_puts(tty, s);
|
|
|
|
return (0);
|
|
|
|
}
|
|
|
|
|
2016-10-10 21:29:23 +00:00
|
|
|
static void
|
2015-04-19 21:05:27 +00:00
|
|
|
tty_default_colours(struct grid_cell *gc, const struct window_pane *wp)
|
|
|
|
{
|
2016-05-30 09:50:20 +00:00
|
|
|
struct window *w = wp->window;
|
|
|
|
struct options *oo = w->options;
|
|
|
|
const struct grid_cell *agc, *pgc, *wgc;
|
2017-01-12 00:19:32 +00:00
|
|
|
int c;
|
2015-04-19 21:05:27 +00:00
|
|
|
|
2016-05-30 09:50:20 +00:00
|
|
|
if (w->flags & WINDOW_STYLECHANGED) {
|
|
|
|
w->flags &= ~WINDOW_STYLECHANGED;
|
|
|
|
agc = options_get_style(oo, "window-active-style");
|
|
|
|
memcpy(&w->active_style, agc, sizeof w->active_style);
|
|
|
|
wgc = options_get_style(oo, "window-style");
|
|
|
|
memcpy(&w->style, wgc, sizeof w->style);
|
|
|
|
} else {
|
|
|
|
agc = &w->active_style;
|
|
|
|
wgc = &w->style;
|
|
|
|
}
|
2015-04-19 21:05:27 +00:00
|
|
|
pgc = &wp->colgc;
|
|
|
|
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->fg == 8) {
|
|
|
|
if (pgc->fg != 8)
|
2015-04-19 21:05:27 +00:00
|
|
|
gc->fg = pgc->fg;
|
2016-07-15 00:49:08 +00:00
|
|
|
else if (wp == w->active && agc->fg != 8)
|
2015-04-19 21:05:27 +00:00
|
|
|
gc->fg = agc->fg;
|
2016-07-15 00:49:08 +00:00
|
|
|
else
|
2015-04-19 21:05:27 +00:00
|
|
|
gc->fg = wgc->fg;
|
2017-01-07 15:28:13 +00:00
|
|
|
|
2017-01-12 00:19:32 +00:00
|
|
|
if (gc->fg != 8 &&
|
|
|
|
(c = window_pane_get_palette(wp, gc->fg)) != -1)
|
|
|
|
gc->fg = c;
|
2015-04-19 21:05:27 +00:00
|
|
|
}
|
|
|
|
|
2016-07-15 00:49:08 +00:00
|
|
|
if (gc->bg == 8) {
|
|
|
|
if (pgc->bg != 8)
|
2015-04-19 21:05:27 +00:00
|
|
|
gc->bg = pgc->bg;
|
2016-07-15 00:49:08 +00:00
|
|
|
else if (wp == w->active && agc->bg != 8)
|
2015-04-19 21:05:27 +00:00
|
|
|
gc->bg = agc->bg;
|
2016-07-15 00:49:08 +00:00
|
|
|
else
|
2015-04-19 21:05:27 +00:00
|
|
|
gc->bg = wgc->bg;
|
2017-01-07 15:28:13 +00:00
|
|
|
|
2017-01-12 00:19:32 +00:00
|
|
|
if (gc->bg != 8 &&
|
|
|
|
(c = window_pane_get_palette(wp, gc->bg)) != -1)
|
|
|
|
gc->bg = c;
|
2015-04-19 21:05:27 +00:00
|
|
|
}
|
|
|
|
}
|
2016-10-13 20:27:27 +00:00
|
|
|
|
|
|
|
static void
|
|
|
|
tty_default_attributes(struct tty *tty, const struct window_pane *wp, u_int bg)
|
|
|
|
{
|
|
|
|
static struct grid_cell gc;
|
|
|
|
|
|
|
|
memcpy(&gc, &grid_default_cell, sizeof gc);
|
|
|
|
gc.bg = bg;
|
|
|
|
tty_attributes(tty, &gc, wp);
|
|
|
|
}
|